diff options
-rw-r--r-- | src/com/itmill/toolkit/Application.java | 7 | ||||
-rw-r--r-- | src/com/itmill/toolkit/ui/AbstractField.java | 7 | ||||
-rw-r--r-- | src/com/itmill/toolkit/ui/Upload.java | 25 | ||||
-rw-r--r-- | src/com/itmill/toolkit/ui/Window.java | 28 |
4 files changed, 33 insertions, 34 deletions
diff --git a/src/com/itmill/toolkit/Application.java b/src/com/itmill/toolkit/Application.java index ec9c8f8b79..e5b44542d0 100644 --- a/src/com/itmill/toolkit/Application.java +++ b/src/com/itmill/toolkit/Application.java @@ -1068,6 +1068,11 @@ public abstract class Application implements URIHandler, Terminal.ErrorListener return context; } + /** + * @deprecated Call component's focus method instead. + * + * @param focusable + */ public void setFocusedComponent(Focusable focusable) { pendingFocus = focusable; } @@ -1075,6 +1080,8 @@ public abstract class Application implements URIHandler, Terminal.ErrorListener /** * Gets and nulls focused component in this window * + * @deprecated This method will be replaced with focus listener in the + * future releases. * @return Focused component or null if none is focused. */ public Component.Focusable consumeFocus() { diff --git a/src/com/itmill/toolkit/ui/AbstractField.java b/src/com/itmill/toolkit/ui/AbstractField.java index 9d926f0e7f..0b309ab562 100644 --- a/src/com/itmill/toolkit/ui/AbstractField.java +++ b/src/com/itmill/toolkit/ui/AbstractField.java @@ -11,6 +11,7 @@ import java.util.Date; import java.util.Iterator; import java.util.LinkedList; +import com.itmill.toolkit.Application; import com.itmill.toolkit.data.Buffered; import com.itmill.toolkit.data.Property; import com.itmill.toolkit.data.Validatable; @@ -848,9 +849,9 @@ public abstract class AbstractField extends AbstractComponent implements Field, * Asks the terminal to place the cursor to this field. */ public void focus() { - final Window w = getWindow(); - if (w != null) { - w.setFocusedComponent(this); + final Application app = getApplication(); + if (app != null) { + app.setFocusedComponent(this); } else { delayedFocus = true; } diff --git a/src/com/itmill/toolkit/ui/Upload.java b/src/com/itmill/toolkit/ui/Upload.java index 10123d3d5e..af5344c3cd 100644 --- a/src/com/itmill/toolkit/ui/Upload.java +++ b/src/com/itmill/toolkit/ui/Upload.java @@ -10,6 +10,7 @@ import java.io.OutputStream; import java.lang.reflect.Method; import java.util.Map; +import com.itmill.toolkit.Application; import com.itmill.toolkit.terminal.PaintException; import com.itmill.toolkit.terminal.PaintTarget; import com.itmill.toolkit.terminal.UploadStream; @@ -42,6 +43,8 @@ import com.itmill.toolkit.terminal.UploadStream; */ public class Upload extends AbstractComponent implements Component.Focusable { + private boolean delayedFocus; + /** * Upload buffer size. */ @@ -687,9 +690,11 @@ public class Upload extends AbstractComponent implements Component.Focusable { * @see com.itmill.toolkit.ui.Component.Focusable#focus() */ public void focus() { - final Window w = getWindow(); - if (w != null) { - w.setFocusedComponent(this); + final Application app = getApplication(); + if (app != null) { + app.setFocusedComponent(this); + } else { + delayedFocus = true; } } @@ -822,4 +827,18 @@ public class Upload extends AbstractComponent implements Component.Focusable { public void setButtonCaption(String buttonCaption) { this.buttonCaption = buttonCaption; } + + /** + * Notifies the component that it is connected to an application. + * + * @see com.itmill.toolkit.ui.Component#attach() + */ + public void attach() { + super.attach(); + if (delayedFocus) { + delayedFocus = false; + focus(); + } + } + } diff --git a/src/com/itmill/toolkit/ui/Window.java b/src/com/itmill/toolkit/ui/Window.java index a042a30776..416270f194 100644 --- a/src/com/itmill/toolkit/ui/Window.java +++ b/src/com/itmill/toolkit/ui/Window.java @@ -94,11 +94,6 @@ public class Window extends Panel implements URIHandler, ParameterHandler { private int border = BORDER_DEFAULT; /** - * Focused component. - */ - private Focusable focusedComponent; - - /** * Distance of Window top border in pixels from top border of the containing * (main window) or -1 if unspecified. */ @@ -872,29 +867,6 @@ public class Window extends Panel implements URIHandler, ParameterHandler { } /** - * Gets the currently focused component in this window. - * - * @return the Focused component or null if none is focused. - */ - public Component.Focusable getFocusedComponent() { - return focusedComponent; - } - - /** - * Sets the currently focused component in this window. - * - * @param focusable - * the Focused component or null if none is focused. - */ - public void setFocusedComponent(Component.Focusable focusable) { - final Application app = getApplication(); - if (app != null) { - app.setFocusedComponent(focusable); - focusedComponent = focusable; - } - } - - /** * Gets the distance of Window left border in pixels from left border of the * containing (main window). * |