diff options
Diffstat (limited to 'client')
15 files changed, 90 insertions, 43 deletions
diff --git a/client/src/com/vaadin/client/VCaption.java b/client/src/com/vaadin/client/VCaption.java index 769428e16b..58e0b847f0 100644 --- a/client/src/com/vaadin/client/VCaption.java +++ b/client/src/com/vaadin/client/VCaption.java @@ -23,6 +23,7 @@ import com.google.gwt.user.client.ui.HTML; import com.vaadin.client.ui.AbstractFieldConnector; import com.vaadin.client.ui.Icon; import com.vaadin.shared.AbstractFieldState; +import com.vaadin.shared.ComponentConstants; import com.vaadin.shared.ComponentState; public class VCaption extends HTML { @@ -119,7 +120,8 @@ public class VCaption extends HTML { } setStyleName(style); - boolean hasIcon = owner.getState().getIcon() != null; + boolean hasIcon = owner.getState().resources + .containsKey(ComponentConstants.ICON_RESOURCE); boolean showRequired = false; boolean showError = owner.getState().getErrorMessage() != null; if (owner.getState() instanceof AbstractFieldState) { @@ -143,7 +145,8 @@ public class VCaption extends HTML { // Icon forces the caption to be above the component placedAfterComponent = false; - icon.setUri(owner.getState().getIcon().getURL()); + icon.setUri(owner.getState().resources.get( + ComponentConstants.ICON_RESOURCE).getURL()); } else if (icon != null) { // Remove existing @@ -392,7 +395,7 @@ public class VCaption extends HTML { if (state.getCaption() != null) { return true; } - if (state.getIcon() != null) { + if (state.resources.containsKey(ComponentConstants.ICON_RESOURCE)) { return true; } if (state.getErrorMessage() != null) { diff --git a/client/src/com/vaadin/client/ui/AbstractComponentConnector.java b/client/src/com/vaadin/client/ui/AbstractComponentConnector.java index 8a875fe363..18c13b4b7f 100644 --- a/client/src/com/vaadin/client/ui/AbstractComponentConnector.java +++ b/client/src/com/vaadin/client/ui/AbstractComponentConnector.java @@ -39,6 +39,7 @@ import com.vaadin.client.metadata.Type; import com.vaadin.client.metadata.TypeData; import com.vaadin.client.ui.UI.UIConnector; import com.vaadin.client.ui.datefield.PopupDateFieldConnector; +import com.vaadin.shared.ComponentConstants; import com.vaadin.shared.ComponentState; import com.vaadin.shared.Connector; import com.vaadin.shared.ui.TabIndexState; @@ -248,9 +249,7 @@ public abstract class AbstractComponentConnector extends AbstractConnector /* * (non-Javadoc) * - * @see - * com.vaadin.client.ComponentConnector#delegateCaptionHandling - * () + * @see com.vaadin.client.ComponentConnector#delegateCaptionHandling () */ @Override public boolean delegateCaptionHandling() { @@ -421,8 +420,7 @@ public abstract class AbstractComponentConnector extends AbstractConnector /* * (non-Javadoc) * - * @see - * com.vaadin.client.ComponentConnector#getTooltipInfo(com. + * @see com.vaadin.client.ComponentConnector#getTooltipInfo(com. * google.gwt.dom.client.Element) */ @Override @@ -430,4 +428,14 @@ public abstract class AbstractComponentConnector extends AbstractConnector return new TooltipInfo(getState().getDescription(), getState() .getErrorMessage()); } + + /** + * Gets the icon set for this component. + * + * @return the URL of the icon, or <code>null</code> if no icon has been + * defined. + */ + protected String getIcon() { + return getResourceUrl(ComponentConstants.ICON_RESOURCE); + } } diff --git a/client/src/com/vaadin/client/ui/AbstractConnector.java b/client/src/com/vaadin/client/ui/AbstractConnector.java index a100f34130..989867d40e 100644 --- a/client/src/com/vaadin/client/ui/AbstractConnector.java +++ b/client/src/com/vaadin/client/ui/AbstractConnector.java @@ -36,6 +36,7 @@ import com.vaadin.client.metadata.Type; import com.vaadin.client.metadata.TypeData; import com.vaadin.shared.communication.ClientRpc; import com.vaadin.shared.communication.SharedState; +import com.vaadin.shared.communication.URLReference; /** * An abstract implementation of Connector. @@ -344,4 +345,29 @@ public abstract class AbstractConnector implements ServerConnector, c.updateEnabledState(c.isEnabled()); } } + + /** + * Gets the URL for a resource that has been added by the server-side + * connector using + * {@link com.vaadin.terminal.AbstractClientConnector#setResource(String, com.vaadin.terminal.Resource)} + * with the same key. <code>null</code> is returned if no corresponding + * resource is found. + * <p> + * To get an event when a resource changes, you can use + * {@link #addStateChangeHandler(String, StateChangeHandler)} with + * <code>resources.[key]</code> as the property name. + * + * @param key + * a string identifying the resource. + * @return the resource URL as a string, or <code>null</code> if no + * corresponding resource is found. + */ + public String getResourceUrl(String key) { + URLReference urlReference = getState().resources.get(key); + if (urlReference == null) { + return null; + } else { + return urlReference.getURL(); + } + } } diff --git a/client/src/com/vaadin/client/ui/button/ButtonConnector.java b/client/src/com/vaadin/client/ui/button/ButtonConnector.java index 103d0f5ae9..65acddb0a4 100644 --- a/client/src/com/vaadin/client/ui/button/ButtonConnector.java +++ b/client/src/com/vaadin/client/ui/button/ButtonConnector.java @@ -83,17 +83,17 @@ public class ButtonConnector extends AbstractComponentConnector implements } }); - addStateChangeHandler("icon", new StateChangeHandler() { + addStateChangeHandler("resources.icon", new StateChangeHandler() { @Override public void onStateChanged(StateChangeEvent stateChangeEvent) { - if (getState().getIcon() != null) { + if (getIcon() != null) { if (getWidget().icon == null) { getWidget().icon = new Icon(getConnection()); getWidget().wrapper.insertBefore( getWidget().icon.getElement(), getWidget().captionElement); } - getWidget().icon.setUri(getState().getIcon().getURL()); + getWidget().icon.setUri(getIcon()); } else { if (getWidget().icon != null) { getWidget().wrapper.removeChild(getWidget().icon diff --git a/client/src/com/vaadin/client/ui/checkbox/CheckBoxConnector.java b/client/src/com/vaadin/client/ui/checkbox/CheckBoxConnector.java index 8fb202ca9d..1a6547a85c 100644 --- a/client/src/com/vaadin/client/ui/checkbox/CheckBoxConnector.java +++ b/client/src/com/vaadin/client/ui/checkbox/CheckBoxConnector.java @@ -96,7 +96,7 @@ public class CheckBoxConnector extends AbstractFieldConnector implements getWidget().setEnabled(false); } - if (getState().getIcon() != null) { + if (getIcon() != null) { if (getWidget().icon == null) { getWidget().icon = new Icon(getConnection()); DOM.insertChild(getWidget().getElement(), @@ -104,7 +104,7 @@ public class CheckBoxConnector extends AbstractFieldConnector implements getWidget().icon.sinkEvents(VTooltip.TOOLTIP_EVENTS); getWidget().icon.sinkEvents(Event.ONCLICK); } - getWidget().icon.setUri(getState().getIcon().getURL()); + getWidget().icon.setUri(getIcon()); } else if (getWidget().icon != null) { // detach icon DOM.removeChild(getWidget().getElement(), diff --git a/client/src/com/vaadin/client/ui/embeddedbrowser/EmbeddedBrowserConnector.java b/client/src/com/vaadin/client/ui/embeddedbrowser/EmbeddedBrowserConnector.java index 6333cb2288..b0cd6d773d 100644 --- a/client/src/com/vaadin/client/ui/embeddedbrowser/EmbeddedBrowserConnector.java +++ b/client/src/com/vaadin/client/ui/embeddedbrowser/EmbeddedBrowserConnector.java @@ -2,6 +2,7 @@ package com.vaadin.client.ui.embeddedbrowser; import com.vaadin.client.communication.StateChangeEvent; import com.vaadin.client.ui.AbstractComponentConnector; +import com.vaadin.shared.ui.AbstractEmbeddedState; import com.vaadin.shared.ui.Connect; import com.vaadin.shared.ui.embeddedbrowser.EmbeddedBrowserState; @@ -30,8 +31,7 @@ public class EmbeddedBrowserConnector extends AbstractComponentConnector { getWidget().setAlternateText(getState().getAlternateText()); getWidget().setSource( - getState().getSource() != null ? getState().getSource() - .getURL() : null); + getResourceUrl(AbstractEmbeddedState.SOURCE_RESOURCE)); getWidget().setName(getConnectorId()); } diff --git a/client/src/com/vaadin/client/ui/flash/FlashConnector.java b/client/src/com/vaadin/client/ui/flash/FlashConnector.java index e6158aa558..cc5423dd20 100644 --- a/client/src/com/vaadin/client/ui/flash/FlashConnector.java +++ b/client/src/com/vaadin/client/ui/flash/FlashConnector.java @@ -2,6 +2,7 @@ package com.vaadin.client.ui.flash; import com.vaadin.client.communication.StateChangeEvent; import com.vaadin.client.ui.AbstractComponentConnector; +import com.vaadin.shared.ui.AbstractEmbeddedState; import com.vaadin.shared.ui.Connect; import com.vaadin.shared.ui.flash.FlashState; @@ -29,8 +30,7 @@ public class FlashConnector extends AbstractComponentConnector { super.onStateChanged(stateChangeEvent); getWidget().setSource( - getState().getSource() != null ? getState().getSource() - .getURL() : null); + getResourceUrl(AbstractEmbeddedState.SOURCE_RESOURCE)); getWidget().setArchive(getState().getArchive()); getWidget().setClassId(getState().getClassId()); getWidget().setCodebase(getState().getCodebase()); diff --git a/client/src/com/vaadin/client/ui/form/FormConnector.java b/client/src/com/vaadin/client/ui/form/FormConnector.java index 506813ef37..1b97bbc4cb 100644 --- a/client/src/com/vaadin/client/ui/form/FormConnector.java +++ b/client/src/com/vaadin/client/ui/form/FormConnector.java @@ -87,12 +87,12 @@ public class FormConnector extends AbstractComponentContainerConnector } else { getWidget().caption.setInnerText(""); } - if (getState().getIcon() != null) { + if (getIcon() != null) { if (getWidget().icon == null) { getWidget().icon = new Icon(client); getWidget().legend.insertFirst(getWidget().icon.getElement()); } - getWidget().icon.setUri(getState().getIcon().getURL()); + getWidget().icon.setUri(getIcon()); legendEmpty = false; } else { if (getWidget().icon != null) { diff --git a/client/src/com/vaadin/client/ui/formlayout/VFormLayout.java b/client/src/com/vaadin/client/ui/formlayout/VFormLayout.java index a178fe1cf5..890275dfe4 100644 --- a/client/src/com/vaadin/client/ui/formlayout/VFormLayout.java +++ b/client/src/com/vaadin/client/ui/formlayout/VFormLayout.java @@ -36,6 +36,7 @@ import com.vaadin.client.StyleConstants; import com.vaadin.client.VTooltip; import com.vaadin.client.ui.AbstractFieldConnector; import com.vaadin.client.ui.Icon; +import com.vaadin.shared.ComponentConstants; import com.vaadin.shared.ComponentState; import com.vaadin.shared.ui.MarginInfo; @@ -253,13 +254,14 @@ public class VFormLayout extends SimplePanel { boolean isEmpty = true; - if (state.getIcon() != null) { + if (state.resources.containsKey(ComponentConstants.ICON_RESOURCE)) { if (icon == null) { icon = new Icon(owner.getConnection()); DOM.insertChild(getElement(), icon.getElement(), 0); } - icon.setUri(state.getIcon().getURL()); + icon.setUri(state.resources.get( + ComponentConstants.ICON_RESOURCE).getURL()); isEmpty = false; } else { if (icon != null) { diff --git a/client/src/com/vaadin/client/ui/image/ImageConnector.java b/client/src/com/vaadin/client/ui/image/ImageConnector.java index ce92ec48dd..7c3eb973d2 100644 --- a/client/src/com/vaadin/client/ui/image/ImageConnector.java +++ b/client/src/com/vaadin/client/ui/image/ImageConnector.java @@ -8,6 +8,7 @@ import com.vaadin.client.communication.StateChangeEvent; import com.vaadin.client.ui.AbstractComponentConnector; import com.vaadin.client.ui.ClickEventHandler; import com.vaadin.shared.MouseEventDetails; +import com.vaadin.shared.ui.AbstractEmbeddedState; import com.vaadin.shared.ui.Connect; import com.vaadin.shared.ui.image.ImageServerRpc; import com.vaadin.shared.ui.image.ImageState; @@ -48,8 +49,7 @@ public class ImageConnector extends AbstractComponentConnector { clickEventHandler.handleEventHandlerRegistration(); getWidget().setUrl( - getState().getSource() != null ? getState().getSource() - .getURL() : null); + getResourceUrl(AbstractEmbeddedState.SOURCE_RESOURCE)); getWidget().setAltText(getState().getAlternateText()); } diff --git a/client/src/com/vaadin/client/ui/link/LinkConnector.java b/client/src/com/vaadin/client/ui/link/LinkConnector.java index 2b19a943b3..26e0e78654 100644 --- a/client/src/com/vaadin/client/ui/link/LinkConnector.java +++ b/client/src/com/vaadin/client/ui/link/LinkConnector.java @@ -20,10 +20,13 @@ import com.google.gwt.user.client.DOM; import com.vaadin.client.ApplicationConnection; import com.vaadin.client.Paintable; import com.vaadin.client.UIDL; +import com.vaadin.client.communication.StateChangeEvent; +import com.vaadin.client.communication.StateChangeEvent.StateChangeHandler; import com.vaadin.client.ui.AbstractComponentConnector; import com.vaadin.client.ui.Icon; import com.vaadin.shared.ui.BorderStyle; import com.vaadin.shared.ui.Connect; +import com.vaadin.shared.ui.link.LinkConstants; import com.vaadin.ui.Link; @Connect(Link.class) @@ -31,6 +34,21 @@ public class LinkConnector extends AbstractComponentConnector implements Paintable { @Override + protected void init() { + super.init(); + addStateChangeHandler("resources." + LinkConstants.HREF_RESOURCE, + new StateChangeHandler() { + @Override + public void onStateChanged(StateChangeEvent stateChangeEvent) { + getWidget().src = getResourceUrl(LinkConstants.HREF_RESOURCE); + getWidget().anchor + .setAttribute("href", getWidget().src); + + } + }); + } + + @Override public boolean delegateCaptionHandling() { return false; } @@ -50,11 +68,6 @@ public class LinkConnector extends AbstractComponentConnector implements getWidget().target = uidl.getStringAttribute("name"); getWidget().anchor.setAttribute("target", getWidget().target); } - if (uidl.hasAttribute("src")) { - getWidget().src = client.translateVaadinUri(uidl - .getStringAttribute("src")); - getWidget().anchor.setAttribute("href", getWidget().src); - } if (uidl.hasAttribute("border")) { if ("none".equals(uidl.getStringAttribute("border"))) { @@ -88,13 +101,13 @@ public class LinkConnector extends AbstractComponentConnector implements "none"); } - if (getState().getIcon() != null) { + if (getIcon() != null) { if (getWidget().icon == null) { getWidget().icon = new Icon(client); getWidget().anchor.insertBefore(getWidget().icon.getElement(), getWidget().captionElement); } - getWidget().icon.setUri(getState().getIcon().getURL()); + getWidget().icon.setUri(getIcon()); } } diff --git a/client/src/com/vaadin/client/ui/nativebutton/NativeButtonConnector.java b/client/src/com/vaadin/client/ui/nativebutton/NativeButtonConnector.java index 852be8e3cf..e821ae1422 100644 --- a/client/src/com/vaadin/client/ui/nativebutton/NativeButtonConnector.java +++ b/client/src/com/vaadin/client/ui/nativebutton/NativeButtonConnector.java @@ -91,14 +91,14 @@ public class NativeButtonConnector extends AbstractComponentConnector implements getWidget().errorIndicatorElement = null; } - if (getState().getIcon() != null) { + if (getIcon() != null) { if (getWidget().icon == null) { getWidget().icon = new Icon(getConnection()); getWidget().getElement().insertBefore( getWidget().icon.getElement(), getWidget().captionElement); } - getWidget().icon.setUri(getState().getIcon().getURL()); + getWidget().icon.setUri(getIcon()); } else { if (getWidget().icon != null) { getWidget().getElement().removeChild( diff --git a/client/src/com/vaadin/client/ui/panel/PanelConnector.java b/client/src/com/vaadin/client/ui/panel/PanelConnector.java index 740a92d7cd..f991d295b4 100644 --- a/client/src/com/vaadin/client/ui/panel/PanelConnector.java +++ b/client/src/com/vaadin/client/ui/panel/PanelConnector.java @@ -140,8 +140,8 @@ public class PanelConnector extends AbstractComponentContainerConnector getWidget().client = client; getWidget().id = uidl.getId(); - if (getState().getIcon() != null) { - getWidget().setIconUri(getState().getIcon().getURL(), client); + if (getIcon() != null) { + getWidget().setIconUri(getIcon(), client); } else { getWidget().setIconUri(null, client); } diff --git a/client/src/com/vaadin/client/ui/video/VideoConnector.java b/client/src/com/vaadin/client/ui/video/VideoConnector.java index ff40c74c3d..d2d9804f66 100644 --- a/client/src/com/vaadin/client/ui/video/VideoConnector.java +++ b/client/src/com/vaadin/client/ui/video/VideoConnector.java @@ -17,8 +17,8 @@ package com.vaadin.client.ui.video; import com.vaadin.client.communication.StateChangeEvent; import com.vaadin.client.ui.MediaBaseConnector; -import com.vaadin.shared.communication.URLReference; import com.vaadin.shared.ui.Connect; +import com.vaadin.shared.ui.video.VideoConstants; import com.vaadin.shared.ui.video.VideoState; import com.vaadin.ui.Video; @@ -33,12 +33,7 @@ public class VideoConnector extends MediaBaseConnector { @Override public void onStateChanged(StateChangeEvent stateChangeEvent) { super.onStateChanged(stateChangeEvent); - URLReference poster = getState().getPoster(); - if (poster != null) { - getWidget().setPoster(poster.getURL()); - } else { - getWidget().setPoster(null); - } + getWidget().setPoster(getResourceUrl(VideoConstants.POSTER_RESOURCE)); } @Override diff --git a/client/src/com/vaadin/client/ui/window/WindowConnector.java b/client/src/com/vaadin/client/ui/window/WindowConnector.java index f15866d602..b013bcaee0 100644 --- a/client/src/com/vaadin/client/ui/window/WindowConnector.java +++ b/client/src/com/vaadin/client/ui/window/WindowConnector.java @@ -115,8 +115,8 @@ SimpleManagedLayout, PostLayoutListener, MayScrollChildren { // Caption must be set before required header size is measured. If // the caption attribute is missing the caption should be cleared. String iconURL = null; - if (getState().getIcon() != null) { - iconURL = getState().getIcon().getURL(); + if (getIcon() != null) { + iconURL = getIcon(); } getWidget().setCaption(getState().getCaption(), iconURL); } |