diff options
Diffstat (limited to 'client')
-rw-r--r-- | client/src/main/java/com/vaadin/client/ui/ShortcutActionHandler.java | 42 |
1 files changed, 39 insertions, 3 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/ShortcutActionHandler.java b/client/src/main/java/com/vaadin/client/ui/ShortcutActionHandler.java index 7499779352..1c03a2719d 100644 --- a/client/src/main/java/com/vaadin/client/ui/ShortcutActionHandler.java +++ b/client/src/main/java/com/vaadin/client/ui/ShortcutActionHandler.java @@ -126,15 +126,31 @@ public class ShortcutActionHandler { target = Util.findPaintable(client, et); } final ComponentConnector finalTarget = target; - event.preventDefault(); - /* * The focused component might have unpublished changes, try to * synchronize them before firing shortcut action. */ client.flushActiveConnector(); - + /* + * Legacy components don't have built-in logic for flushing, they need a + * workaround with blur and focus to trigger the value change. + */ + ComponentConnector activeConnector = getActiveConnector(client); + if (activeConnector != null) { + Class<?> clz = activeConnector.getClass(); + while (clz != null) { + if (clz.getName().equals( + "com.vaadin.v7.client.ui.AbstractLegacyComponentConnector")) { + shakeTarget(et); + Scheduler.get().scheduleDeferred(() -> { + shakeTarget(et); + }); + break; + } + clz = clz.getSuperclass(); + } + } Scheduler.get().scheduleDeferred(() -> { if (finalTarget != null) { client.updateVariable(paintableId, "actiontarget", finalTarget, @@ -144,6 +160,26 @@ public class ShortcutActionHandler { }); } + /** + * We try to fire value change in the component the key combination was + * typed. E.g. TextField may contain newly typed text that is expected to be + * sent to server before the shortcut action is triggered. This is done by + * removing focus and then returning it immediately back to target element. + * <p> + * This is a hack copied over from V7 in order to keep the compatibility + * classes working. Main V8 classes don't require shaking. + */ + private static void shakeTarget(final Element e) { + blur(e); + focus(e); + } + + private static native ComponentConnector getActiveConnector( + ApplicationConnection ac) + /*-{ + return ac.@com.vaadin.client.ApplicationConnection::getActiveConnector()(); + }-*/; + private static native void blur(Element e) /*-{ if (e.blur) { |