summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--client/src/com/vaadin/client/WidgetUtil.java12
-rw-r--r--client/src/com/vaadin/client/connectors/GridConnector.java3
-rw-r--r--client/src/com/vaadin/client/ui/AbstractComponentConnector.java4
-rw-r--r--client/src/com/vaadin/client/ui/table/TableConnector.java7
-rw-r--r--client/src/com/vaadin/client/ui/tree/TreeConnector.java2
-rw-r--r--uitest/src/com/vaadin/tests/contextclick/BrowserContextMenuInSubComponent.java84
-rw-r--r--uitest/src/com/vaadin/tests/widgetset/client/extension/BrowserContextMenuExtensionConnector.java49
7 files changed, 158 insertions, 3 deletions
diff --git a/client/src/com/vaadin/client/WidgetUtil.java b/client/src/com/vaadin/client/WidgetUtil.java
index 631d28c26c..8161ceff19 100644
--- a/client/src/com/vaadin/client/WidgetUtil.java
+++ b/client/src/com/vaadin/client/WidgetUtil.java
@@ -1333,6 +1333,18 @@ public class WidgetUtil {
}-*/;
/**
+ * JavaScript hack to clear text selection in various browsers.
+ *
+ * @since 7.6
+ */
+ public native static void clearTextSelection()
+ /*-{
+ if ($wnd.getSelection) {
+ $wnd.getSelection().removeAllRanges();
+ }
+ }-*/;
+
+ /**
* The allowed value inaccuracy when comparing two double-typed pixel
* values.
* <p>
diff --git a/client/src/com/vaadin/client/connectors/GridConnector.java b/client/src/com/vaadin/client/connectors/GridConnector.java
index 336469139c..0b485a8e5a 100644
--- a/client/src/com/vaadin/client/connectors/GridConnector.java
+++ b/client/src/com/vaadin/client/connectors/GridConnector.java
@@ -43,6 +43,7 @@ import com.vaadin.client.DeferredWorker;
import com.vaadin.client.MouseEventDetailsBuilder;
import com.vaadin.client.ServerConnector;
import com.vaadin.client.TooltipInfo;
+import com.vaadin.client.WidgetUtil;
import com.vaadin.client.communication.StateChangeEvent;
import com.vaadin.client.communication.StateChangeEvent.StateChangeHandler;
import com.vaadin.client.connectors.RpcDataSourceConnector.DetailsListener;
@@ -1197,6 +1198,8 @@ public class GridConnector extends AbstractHasComponentsConnector implements
getRpcProxy(GridServerRpc.class).contextClick(eventCell.getRowIndex(),
rowKey, columnId, section, details);
+
+ WidgetUtil.clearTextSelection();
}
/**
diff --git a/client/src/com/vaadin/client/ui/AbstractComponentConnector.java b/client/src/com/vaadin/client/ui/AbstractComponentConnector.java
index 1b3f5de3b1..f1ed0caf10 100644
--- a/client/src/com/vaadin/client/ui/AbstractComponentConnector.java
+++ b/client/src/com/vaadin/client/ui/AbstractComponentConnector.java
@@ -45,6 +45,7 @@ import com.vaadin.client.TooltipInfo;
import com.vaadin.client.UIDL;
import com.vaadin.client.Util;
import com.vaadin.client.VConsole;
+import com.vaadin.client.WidgetUtil;
import com.vaadin.client.annotations.OnStateChange;
import com.vaadin.client.communication.StateChangeEvent;
import com.vaadin.client.metadata.NoDataException;
@@ -132,7 +133,6 @@ public abstract class AbstractComponentConnector extends AbstractConnector
// remove the touch handlers as well
unregisterTouchHandlers();
-
}
}
@@ -324,6 +324,8 @@ public abstract class AbstractComponentConnector extends AbstractConnector
// The default context click implementation only provides the mouse
// coordinates relative to root element of widget.
getRpcProxy(ContextClickRpc.class).contextClick(details);
+
+ WidgetUtil.clearTextSelection();
}
/**
diff --git a/client/src/com/vaadin/client/ui/table/TableConnector.java b/client/src/com/vaadin/client/ui/table/TableConnector.java
index 7e7995b5e1..cdd9397976 100644
--- a/client/src/com/vaadin/client/ui/table/TableConnector.java
+++ b/client/src/com/vaadin/client/ui/table/TableConnector.java
@@ -28,11 +28,11 @@ import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.user.client.ui.Widget;
import com.vaadin.client.ApplicationConnection;
import com.vaadin.client.BrowserInfo;
-import com.vaadin.client.HasChildMeasurementHintConnector;
import com.vaadin.client.ComponentConnector;
import com.vaadin.client.ConnectorHierarchyChangeEvent;
import com.vaadin.client.ConnectorHierarchyChangeEvent.ConnectorHierarchyChangeHandler;
import com.vaadin.client.DirectionalManagedLayout;
+import com.vaadin.client.HasChildMeasurementHintConnector;
import com.vaadin.client.HasComponentsConnector;
import com.vaadin.client.Paintable;
import com.vaadin.client.ServerConnector;
@@ -56,7 +56,8 @@ import com.vaadin.shared.ui.table.TableState;
@Connect(com.vaadin.ui.Table.class)
public class TableConnector extends AbstractFieldConnector implements
HasComponentsConnector, ConnectorHierarchyChangeHandler, Paintable,
- DirectionalManagedLayout, PostLayoutListener, HasChildMeasurementHintConnector {
+ DirectionalManagedLayout, PostLayoutListener,
+ HasChildMeasurementHintConnector {
private List<ComponentConnector> childComponents;
@@ -120,6 +121,8 @@ public class TableConnector extends AbstractFieldConnector implements
getRpcProxy(TableServerRpc.class).contextClick(rowKey, colKey, section,
details);
+
+ WidgetUtil.clearTextSelection();
}
protected VScrollTableRow getScrollTableRow(Element e) {
diff --git a/client/src/com/vaadin/client/ui/tree/TreeConnector.java b/client/src/com/vaadin/client/ui/tree/TreeConnector.java
index 6fec6b9f38..f49f44e802 100644
--- a/client/src/com/vaadin/client/ui/tree/TreeConnector.java
+++ b/client/src/com/vaadin/client/ui/tree/TreeConnector.java
@@ -394,5 +394,7 @@ public class TreeConnector extends AbstractComponentConnector implements
}
getRpcProxy(TreeServerRpc.class).contextClick(key, details);
+
+ WidgetUtil.clearTextSelection();
}
}
diff --git a/uitest/src/com/vaadin/tests/contextclick/BrowserContextMenuInSubComponent.java b/uitest/src/com/vaadin/tests/contextclick/BrowserContextMenuInSubComponent.java
new file mode 100644
index 0000000000..d3edf0ba43
--- /dev/null
+++ b/uitest/src/com/vaadin/tests/contextclick/BrowserContextMenuInSubComponent.java
@@ -0,0 +1,84 @@
+/*
+ * Copyright 2000-2014 Vaadin Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ * use this file except in compliance with the License. You may obtain a copy of
+ * the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+package com.vaadin.tests.contextclick;
+
+import com.vaadin.annotations.Widgetset;
+import com.vaadin.event.ContextClickEvent;
+import com.vaadin.event.ContextClickEvent.ContextClickListener;
+import com.vaadin.server.AbstractExtension;
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.tests.widgetset.TestingWidgetSet;
+import com.vaadin.ui.AbstractComponent;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.Button.ClickEvent;
+import com.vaadin.ui.Notification;
+import com.vaadin.ui.Panel;
+import com.vaadin.ui.TextArea;
+import com.vaadin.ui.VerticalLayout;
+
+@Widgetset(TestingWidgetSet.NAME)
+public class BrowserContextMenuInSubComponent extends AbstractTestUI {
+
+ @Override
+ protected void setup(VaadinRequest request) {
+ Panel panel = new Panel();
+
+ VerticalLayout layout = new VerticalLayout();
+ final TextArea textArea = new TextArea();
+ // Make TextArea show regular context menu instead of firing the
+ // server-side event.
+ BrowserContextMenuExtension.extend(textArea);
+ final Button button = new Button("Submit", new Button.ClickListener() {
+
+ @Override
+ public void buttonClick(ClickEvent event) {
+ Notification.show(textArea.getValue());
+ }
+ });
+
+ layout.addComponent(textArea);
+ layout.addComponent(button);
+
+ panel.setContent(layout);
+
+ panel.addContextClickListener(new ContextClickListener() {
+
+ @Override
+ public void contextClick(ContextClickEvent event) {
+ button.click();
+ }
+ });
+
+ addComponent(panel);
+ }
+
+ /**
+ * A simple extension for making extended component stop propagation of the
+ * context click events, so the browser will handle the context click and
+ * show its own context menu.
+ */
+ public static class BrowserContextMenuExtension extends AbstractExtension {
+ private BrowserContextMenuExtension(AbstractComponent c) {
+ super(c);
+ }
+
+ public static BrowserContextMenuExtension extend(AbstractComponent c) {
+ return new BrowserContextMenuExtension(c);
+ }
+ }
+
+}
diff --git a/uitest/src/com/vaadin/tests/widgetset/client/extension/BrowserContextMenuExtensionConnector.java b/uitest/src/com/vaadin/tests/widgetset/client/extension/BrowserContextMenuExtensionConnector.java
new file mode 100644
index 0000000000..9b05ff35d8
--- /dev/null
+++ b/uitest/src/com/vaadin/tests/widgetset/client/extension/BrowserContextMenuExtensionConnector.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2000-2014 Vaadin Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ * use this file except in compliance with the License. You may obtain a copy of
+ * the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+package com.vaadin.tests.widgetset.client.extension;
+
+import com.google.gwt.event.dom.client.ContextMenuEvent;
+import com.google.gwt.event.dom.client.ContextMenuHandler;
+import com.vaadin.client.ServerConnector;
+import com.vaadin.client.extensions.AbstractExtensionConnector;
+import com.vaadin.client.ui.AbstractComponentConnector;
+import com.vaadin.shared.ui.Connect;
+import com.vaadin.tests.contextclick.BrowserContextMenuInSubComponent.BrowserContextMenuExtension;
+
+/**
+ * Client-side connector of the {@link BrowserContextMenuExtension}.
+ */
+@Connect(BrowserContextMenuExtension.class)
+public class BrowserContextMenuExtensionConnector extends
+ AbstractExtensionConnector {
+
+ @Override
+ protected void extend(ServerConnector target) {
+ getParent().getWidget().addDomHandler(new ContextMenuHandler() {
+
+ @Override
+ public void onContextMenu(ContextMenuEvent event) {
+ // Stop context click events from propagating.
+ event.stopPropagation();
+ }
+ }, ContextMenuEvent.getType());
+ }
+
+ @Override
+ public AbstractComponentConnector getParent() {
+ return (AbstractComponentConnector) super.getParent();
+ }
+}