diff options
author | Artur Signell <artur@vaadin.com> | 2012-11-23 10:14:28 +0000 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2012-11-23 10:14:28 +0000 |
commit | 325f9e8310fae51591245b1cc373e22a43b4d9d2 (patch) | |
tree | 787ed47428391768ce93d64fbf28023299b92576 /server | |
parent | 384e57121472afe34b9acecc2ea742e0f6749f34 (diff) | |
parent | 9f97638b0f75b882b76eeb5d2b95f87bb5263a73 (diff) | |
download | vaadin-framework-325f9e8310fae51591245b1cc373e22a43b4d9d2.tar.gz vaadin-framework-325f9e8310fae51591245b1cc373e22a43b4d9d2.zip |
Merge "Refactor BrowserPopupOpener API (#10241)"
Diffstat (limited to 'server')
-rw-r--r-- | server/src/com/vaadin/server/BrowserPopupUIProvider.java | 50 | ||||
-rw-r--r-- | server/src/com/vaadin/server/BrowserWindowOpener.java (renamed from server/src/com/vaadin/server/BrowserPopupOpener.java) | 101 |
2 files changed, 66 insertions, 85 deletions
diff --git a/server/src/com/vaadin/server/BrowserPopupUIProvider.java b/server/src/com/vaadin/server/BrowserPopupUIProvider.java deleted file mode 100644 index 6259fb605d..0000000000 --- a/server/src/com/vaadin/server/BrowserPopupUIProvider.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright 2012 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.server; - -import com.vaadin.ui.UI; - -public class BrowserPopupUIProvider extends UIProvider { - - private final String path; - private final Class<? extends UI> uiClass; - - public BrowserPopupUIProvider(Class<? extends UI> uiClass, String path) { - this.path = ensureInitialSlash(path); - this.uiClass = uiClass; - } - - private static String ensureInitialSlash(String path) { - if (path == null) { - return null; - } else if (!path.startsWith("/")) { - return '/' + path; - } else { - return path; - } - } - - @Override - public Class<? extends UI> getUIClass(UIClassSelectionEvent event) { - String requestPathInfo = event.getRequest().getPathInfo(); - if (path.equals(requestPathInfo)) { - return uiClass; - } else { - return null; - } - } -} diff --git a/server/src/com/vaadin/server/BrowserPopupOpener.java b/server/src/com/vaadin/server/BrowserWindowOpener.java index c55fa65931..3ed039887c 100644 --- a/server/src/com/vaadin/server/BrowserPopupOpener.java +++ b/server/src/com/vaadin/server/BrowserWindowOpener.java @@ -17,7 +17,7 @@ package com.vaadin.server; import com.vaadin.shared.ApplicationConstants; -import com.vaadin.shared.ui.BrowserPopupExtensionState; +import com.vaadin.shared.ui.BrowserWindowOpenerState; import com.vaadin.ui.AbstractComponent; import com.vaadin.ui.UI; @@ -28,24 +28,55 @@ import com.vaadin.ui.UI; * @author Vaadin Ltd * @since 7.0.0 */ -public class BrowserPopupOpener extends AbstractExtension { +public class BrowserWindowOpener extends AbstractExtension { - private final BrowserPopupUIProvider uiProvider; + private static class BrowserWindowOpenerUIProvider extends UIProvider { + + private final String path; + private final Class<? extends UI> uiClass; + + public BrowserWindowOpenerUIProvider(Class<? extends UI> uiClass, String path) { + this.path = ensureInitialSlash(path); + this.uiClass = uiClass; + } + + private static String ensureInitialSlash(String path) { + if (path == null) { + return null; + } else if (!path.startsWith("/")) { + return '/' + path; + } else { + return path; + } + } + + @Override + public Class<? extends UI> getUIClass(UIClassSelectionEvent event) { + String requestPathInfo = event.getRequest().getPathInfo(); + if (path.equals(requestPathInfo)) { + return uiClass; + } else { + return null; + } + } + } + + private final BrowserWindowOpenerUIProvider uiProvider; /** - * Creates a popup opener that will open popups containing the provided UI + * Creates a window opener that will open windows containing the provided UI * class * * @param uiClass * the UI class that should be opened when the extended component * is clicked */ - public BrowserPopupOpener(Class<? extends UI> uiClass) { + public BrowserWindowOpener(Class<? extends UI> uiClass) { this(uiClass, generateUIClassUrl(uiClass)); } /** - * Creates a popup opener that will open popups containing the provided UI + * Creates a window opener that will open windows containing the provided UI * using the provided path * * @param uiClass @@ -54,36 +85,36 @@ public class BrowserPopupOpener extends AbstractExtension { * @param path * the path that the UI should be bound to */ - public BrowserPopupOpener(Class<? extends UI> uiClass, String path) { + public BrowserWindowOpener(Class<? extends UI> uiClass, String path) { // Create a Resource with a translated URL going to the VaadinService this(new ExternalResource(ApplicationConstants.APP_PROTOCOL_PREFIX - + path), new BrowserPopupUIProvider(uiClass, path)); + + path), new BrowserWindowOpenerUIProvider(uiClass, path)); } /** - * Creates a popup opener that will open popups to the provided URL + * Creates a window opener that will open windows to the provided URL * * @param url - * the URL to open in the popup + * the URL to open in the window */ - public BrowserPopupOpener(String url) { + public BrowserWindowOpener(String url) { this(new ExternalResource(url)); } /** - * Creates a popup opener that will open popups to the provided resource + * Creates a window opener that will open window to the provided resource * * @param resource - * the resource to open in the popup + * the resource to open in the window */ - public BrowserPopupOpener(Resource resource) { + public BrowserWindowOpener(Resource resource) { this(resource, null); } - private BrowserPopupOpener(Resource resource, - BrowserPopupUIProvider uiProvider) { + private BrowserWindowOpener(Resource resource, + BrowserWindowOpenerUIProvider uiProvider) { this.uiProvider = uiProvider; - setResource("popup", resource); + setResource(BrowserWindowOpenerState.locationResource, resource); } public void extend(AbstractComponent target) { @@ -91,38 +122,38 @@ public class BrowserPopupOpener extends AbstractExtension { } /** - * Sets the target window name that will be used when opening the popup. If - * a popup has already been opened with the same name, the contents of that - * window will be replaced instead of opening a new window. If the name is - * <code>null</code> or <code>"blank"</code>, the popup will always be - * opened in a new window. + * Sets the target window name that will be used. If a window has already + * been opened with the same name, the contents of that window will be + * replaced instead of opening a new window. If the name is + * <code>null</code> or <code>"_blank"</code>, a new window will always be + * opened. * - * @param popupName - * the target name for the popups + * @param windowName + * the target name for the window */ - public void setPopupName(String popupName) { - getState().target = popupName; + public void setWindowName(String windowName) { + getState().target = windowName; } /** - * Gets the popup target name. + * Gets the target window name. * - * @see #setPopupName(String) + * @see #setWindowName(String) * - * @return the popup target string + * @return the window target string */ - public String getPopupName() { + public String getWindowName() { return getState().target; } // Avoid breaking url to multiple lines // @formatter:off /** - * Sets the features for opening the popup. See e.g. + * Sets the features for opening the window. See e.g. * {@link https://developer.mozilla.org/en-US/docs/DOM/window.open#Position_and_size_features} * for a description of the commonly supported features. * - * @param features a string with popup features, or <code>null</code> to use the default features. + * @param features a string with window features, or <code>null</code> to use the default features. */ // @formatter:on public void setFeatures(String features) { @@ -130,7 +161,7 @@ public class BrowserPopupOpener extends AbstractExtension { } /** - * Gets the popup features. + * Gets the window features. * * @see #setFeatures(String) * @return @@ -140,8 +171,8 @@ public class BrowserPopupOpener extends AbstractExtension { } @Override - protected BrowserPopupExtensionState getState() { - return (BrowserPopupExtensionState) super.getState(); + protected BrowserWindowOpenerState getState() { + return (BrowserWindowOpenerState) super.getState(); } @Override |