本文整理匯總了Java中org.waveprotocol.wave.client.common.util.UserAgent類的典型用法代碼示例。如果您正苦於以下問題:Java UserAgent類的具體用法?Java UserAgent怎麽用?Java UserAgent使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
UserAgent類屬於org.waveprotocol.wave.client.common.util包,在下文中一共展示了UserAgent類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getStreamFilter
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Gets the filter for a stream, creating one if one does not already exist.
*/
private FilterButton getStreamFilter(final String stream) {
FilterButton filter = streamFilters.get(stream);
if (filter == null) {
// Just in case a user can cause a stream to be called "'><script
// src='evil.js'></script><pre '", we only use safe values for CSS
// classes. There's no need for the class names to be human readable.
int streamId = streamFilters.countEntries();
String itemClass = "w-s-" + streamId;
String containerClass = STREAM_FILTER_PREFIX + streamId;
filter = new FilterButton(new DoubleClickHandler() {
@Override
public void onDoubleClick(DoubleClickEvent event) {
enableOnlyOneStream(stream);
}
}, entries, containerClass, itemClass, stream, css.stream());
self.add(filter, streamsContainer);
streamFilters.put(stream, filter);
// TODO(ohler): Make styles work in IE.
if (!UserAgent.isIE()) {
// Replace stylesheet to make the new filter work.
style.setInnerText(style.getInnerText() + filter.getCssRule());
}
}
return filter;
}
示例2: getSelectionGuarded
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Gets the current selection, trying to place it in correspond actual DOM when the selection
* itself is reported as not being in the actual document.
* @return The selection in the page's DOM document, or null if it cannot be calculated.
*/
public static SelectionW3CNative getSelectionGuarded() {
SelectionW3CNative selection = getSelectionUnsafe();
// NOTE(patcoleman) -
// It is possible for the selection to be in a node in the shadow, which
// causes errors whenever you try to read attributes.
if (selection != null && DomHelper.isUnreadable(selection.anchorNode())) {
if (UserAgent.isFirefox()) {
// In firefox, the focus can be practically anywhere, so we give up:
return null;
} else if (UserAgent.isWebkit()) {
// In webkit, the focus should be on the element the shadow dom comes from:
selection.setCaret(NativeSelectionUtil.getActiveElement(), 0);
return selection;
}
return null; // not sure what anything else does, so be safe and assume we're beyond repair.
}
return selection;
}
示例3: setFocusElement
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Ensure that the rendered content view's DOM has focus
*
* NOTE(patcoleman): Fixes firefox bug that causes invalid selections while
* mutating DOM that doesn't have focus - fixed by finding the next parent element directly
* editable, and forcing this to have the focus.
*/
private static void setFocusElement(Node node) {
if (UserAgent.isFirefox()) {
// adjust to parent if node is a text node
Element toFocus;
if (DomHelper.isTextNode(node)) {
toFocus = node.getParentElement();
} else {
toFocus = node.<Element>cast();
}
// traverse up until we have a concretely editable element:
while (toFocus != null &&
DomHelper.getContentEditability(toFocus) != ElementEditability.EDITABLE) {
toFocus = toFocus.getParentElement();
}
// then focus it:
if (toFocus != null) {
DomHelper.focus(toFocus);
}
}
}
示例4: handleDOMMutation
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Handles DOM mutation events.
* @param event
* @param contentRange last known selection
*/
public void handleDOMMutation(SignalEvent event, ContentRange contentRange) {
// Early exit if non-safari or non-mac
if (!(UserAgent.isSafari() && UserAgent.isMac())) {
return;
}
// We don't care about DOMMutations that we generate while we are reverting.
if (isReverting) {
return;
}
previousContentRange = contentRange;
Node n = event.getTarget();
if (n.getNodeType() == Node.ELEMENT_NODE) {
Element e = Element.as(event.getTarget());
if (DOM_EVENTS_IGNORE.contains(event.getType())) {
// ignore
} else if (event.getType().equals(JsEvents.DOM_NODE_INSERTED) && handleDOMNodeInserted(e)) {
} else if (event.getType().equals(JsEvents.DOM_NODE_REMOVED) && handleDOMNodeRemoved(e)) {
}
}
}
示例5: setCollapsed
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
public void setCollapsed(boolean collapsed) {
if (collapsed) {
self.setAttribute(COLLAPSED_ATTRIBUTE, COLLAPSED_VALUE);
// Webkit's incremental layout is incorrect, so we have to kick it a bit.
if (UserAgent.isWebkit()) {
self.getStyle().setDisplay(Display.INLINE_BLOCK);
// Force layout.
self.getOffsetParent();
// Revert to CSS display property (layed out correctly now).
self.getStyle().clearDisplay();
}
} else {
self.removeAttribute("c");
}
updatedCssClassNames();
}
示例6: create
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Factory constructor, creates and attaches the buffer to the DOM.
*
* @return Browser specific implementation of a paste buffer.
*/
static PasteBufferImpl create() {
PasteBufferImpl pasteBuffer;
if (UserAgent.isSafari() || QuirksConstants.FIREFOX_GREATER_THAN_VER_15) {
pasteBuffer = new PasteBufferImplSafariAndNewFirefox();
} else if (UserAgent.isFirefox() && !QuirksConstants.SANITIZES_PASTED_CONTENT) {
// Older versions of firefox doesn't sanitize pasted content and requires the
// paste buffer to be an iframe to prevent XSS.
pasteBuffer = new PasteBufferImplOldFirefox();
} else {
pasteBuffer = new PasteBufferImpl();
}
pasteBuffer.setupDom();
return pasteBuffer;
}
示例7: testUnhandledAcceleratorKeys
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Tests that an unhandled accelerator should trigger subhandlers and cancel
* browser default if unhandled and non-whitelisted.
*/
public void testUnhandledAcceleratorKeys() {
// Always cancel INS key
EditorEvent insKeyEvent = FakeEditorEvent.create(
KeySignalType.NOEFFECT, EventWrapper.KEY_INSERT);
testUnhandledAcceleratorHelper(insKeyEvent, true, true);
// test tab, a non-metesque accelerator
EditorEvent tabPressEvent = createTabSignal();
testUnhandledAcceleratorHelper(tabPressEvent, true, true);
// test an allowable combo
EditorEvent ctrlInsert = createCtrlComboKeyPress(KeySignalType.NOEFFECT,
EventWrapper.KEY_INSERT);
if (UserAgent.isLinux() || UserAgent.isWin()) {
testUnhandledAcceleratorHelper(ctrlInsert, true, false);
} else {
testUnhandledAcceleratorHelper(ctrlInsert, true, true);
}
// test something that is not whitelisted
EditorEvent ctrlY = createCtrlComboKeyPress(KeySignalType.INPUT, 'Y');
testUnhandledAcceleratorHelper(ctrlY, true, true);
testUnhandledAcceleratorHelper(ctrlY, false, false);
}
示例8: waveEnable
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
@Override
public void waveEnable(String waveApiVersion) {
if (!isActive()) {
return;
}
// HACK: See substituteIframeId() description.
// TODO(user): Remove when the Firefox bug is fixed.
if (UserAgent.isFirefox()) {
substituteIframeId();
}
waveEnabled = true;
this.waveApiVersion = waveApiVersion;
log("Wave-enabled gadget registered with API version ", waveApiVersion);
sendWaveGadgetInitialization();
setupModePolling();
}
示例9: setFocusElement
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Ensure that the rendered content view's DOM has focus
*
* NOTE(patcoleman): Fixes firefox bug that causes invalid selections while
* mutating DOM that doesn't have focus - fixed by finding the next parent element directly
* editable, and forcing this to have the focus.
*/
private static void setFocusElement(Node node) {
if (UserAgent.isFirefox()) {
// adjust to parent if node is a text node
Element toFocus = null;
if (DomHelper.isTextNode(node)) {
toFocus = node.getParentElement();
} else {
toFocus = node.<Element>cast();
}
// traverse up until we have a concretely editable element:
while (toFocus != null &&
DomHelper.getContentEditability(toFocus) != ElementEditability.EDITABLE) {
toFocus = toFocus.getParentElement();
}
// then focus it:
if (toFocus != null) {
DomHelper.focus(toFocus);
}
}
}
示例10: append
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
@Override
public ParticipantView append(
ParticipantsDomImpl impl, Conversation conv, ParticipantId participant) {
Element t = getRenderer().render(conv, participant);
DomViewHelper.attachBefore(impl.getParticipantContainer(), impl.getSimpleMenu(), t);
// Kick Webkit, because of its incremental layout bugs.
if (UserAgent.isWebkit()) {
String oldDisplay = impl.getElement().getStyle().getDisplay();
// Erase layout. Querying getOffsetParent() forces layout.
impl.getElement().getStyle().setDisplay(Display.NONE);
impl.getElement().getOffsetParent();
// Restore layout.
impl.getElement().getStyle().setProperty("display", oldDisplay);
}
return asParticipant(t);
}
示例11: LogPanel
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
private LogPanel(Logs log) {
this.log = log;
initWidget(BINDER.createAndBindUi(this));
// Add filter buttons. Global filter, then log-level filters.
StringBuilder rules = new StringBuilder();
rules.append(css.getText());
for (final Level level : Level.values()) {
String itemClass = LEVEL_CLASSES.get(level);
String containerClass = LEVEL_FILTER_PREFIX + itemClass;
FilterButton levelFilter = new FilterButton(new DoubleClickHandler() {
@Override
public void onDoubleClick(DoubleClickEvent event) {
enableOnlyMoreImportantLevels(level);
}
}, entries, containerClass, itemClass, level.name(), css.level());
levelFilters.put(level, levelFilter);
self.add(levelFilter, levelsContainer);
rules.append(levelFilter.getCssRule());
}
// TODO(ohler): Make styles work in IE; the log panel consumes the entire
// screen without them. In IE8, I've seen this crash in setInnerText().
if (!UserAgent.isIE()) {
// Inject style.
style.setInnerText(rules.toString());
Document.get().getBody().appendChild(style);
}
setActive(true);
}
示例12: DoubleBufferImage
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/**
* Create a double buffer loader for a given image widget
*
* @param spinner
* @param imageToLoad
*/
public DoubleBufferImage(Widget spinner, Widget error, Image imageToLoad) {
if (UserAgent.isIE()) {
DomHelper.makeUnselectable(doubleLoadedImage.getElement());
}
this.spinner = spinner;
this.error = error;
this.imageToLoad = imageToLoad;
}
示例13: waveEnable
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
@Override
public void waveEnable(String waveApiVersion) {
if (!isActive()) {
return;
}
log("GW.waveEnable: waveApiVersion=" + waveApiVersion);
waveEnabled = true;
// HACK: See substituteIframeId() description.
// TODO(user): Remove when the Firefox bug is fixed.
if (UserAgent.isFirefox()) {
substituteIframeId();
}
sendWaveGadgetInitialization();
GadgetWidget.this.element.getMutableDoc().addListener(
new CMutableDocument.EditingModeChangeListener() {
@Override
public void onEditingModeChanged(boolean editingMode) {
sendMode();
}
});
ui.showAsLoaded();
}
示例14: createHtml
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
private static Element createHtml(boolean isAnchor) {
Element e = isAnchor
? Document.get().createAnchorElement()
: Document.get().createSpanElement();
// Prevents some browsers (to my knowledge, currently just Webkit)
// from removing empty elements from the dom too much
if (UserAgent.isWebkit()) {
e.setAttribute("x", "y");
}
return e;
}
示例15: createTokenizer
import org.waveprotocol.wave.client.common.util.UserAgent; //導入依賴的package包/類
/** Utility for creating tokenizer based on UA. */
private RichTextTokenizer createTokenizer(Element container) {
if (UserAgent.isFirefox()) {
return new RichTextTokenizerImplFirefox<Node, Element, Text>(new HtmlViewImpl(container));
} else {
return new RichTextTokenizerImpl<Node, Element, Text>(new HtmlViewImpl(container));
}
}