diff options
author | Henri Sara <hesara@vaadin.com> | 2013-01-11 07:58:20 +0000 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2013-01-11 07:58:20 +0000 |
commit | 34efc3b975686749baab2667939250e68a17baca (patch) | |
tree | b3e81805c266c3943d0184f5e672a3148cad4d73 | |
parent | 3298eb197ce94f493d14b57012abbf46c1da925b (diff) | |
parent | 9b2f258bdd7ae0a83d5b08e7a41b3e1c4d34b188 (diff) | |
download | vaadin-framework-34efc3b975686749baab2667939250e68a17baca.tar.gz vaadin-framework-34efc3b975686749baab2667939250e68a17baca.zip |
Merge "Changed CustomFieldConnector hierarchy to be consistent with server side (#8797)"
-rw-r--r-- | client/src/com/vaadin/client/ui/customfield/CustomFieldConnector.java | 107 |
1 files changed, 98 insertions, 9 deletions
diff --git a/client/src/com/vaadin/client/ui/customfield/CustomFieldConnector.java b/client/src/com/vaadin/client/ui/customfield/CustomFieldConnector.java index 541c3d6b62..c6e4b87b73 100644 --- a/client/src/com/vaadin/client/ui/customfield/CustomFieldConnector.java +++ b/client/src/com/vaadin/client/ui/customfield/CustomFieldConnector.java @@ -15,20 +15,109 @@ */ package com.vaadin.client.ui.customfield; -import com.google.gwt.core.client.GWT; -import com.vaadin.client.ui.customcomponent.CustomComponentConnector; -import com.vaadin.shared.AbstractFieldState; -import com.vaadin.shared.communication.SharedState; +import java.util.Collections; +import java.util.List; + +import com.google.gwt.event.shared.HandlerRegistration; +import com.google.gwt.user.client.ui.Widget; +import com.vaadin.client.ComponentConnector; +import com.vaadin.client.ConnectorHierarchyChangeEvent; +import com.vaadin.client.ConnectorHierarchyChangeEvent.ConnectorHierarchyChangeHandler; +import com.vaadin.client.HasComponentsConnector; +import com.vaadin.client.ui.AbstractFieldConnector; +import com.vaadin.client.ui.VCustomComponent; import com.vaadin.shared.ui.Connect; import com.vaadin.ui.CustomField; @Connect(value = CustomField.class) -public class CustomFieldConnector extends CustomComponentConnector { +public class CustomFieldConnector extends AbstractFieldConnector implements + HasComponentsConnector, ConnectorHierarchyChangeHandler { + + List<ComponentConnector> childComponents; + + /** + * Default constructor + */ + public CustomFieldConnector() { + addConnectorHierarchyChangeHandler(this); + } + @Override - protected SharedState createState() { - // Workaround as CustomFieldConnector does not extend - // AbstractFieldConnector. - return GWT.create(AbstractFieldState.class); + public VCustomComponent getWidget() { + return (VCustomComponent) super.getWidget(); + } + + @Override + public void updateCaption(ComponentConnector connector) { + // NOP, custom field does not render the caption of its content + } + + @Override + public void onConnectorHierarchyChange(ConnectorHierarchyChangeEvent event) { + // We always have 1 child, unless the child is hidden + getWidget().setWidget(getContentWidget()); + } + + /* + * (non-Javadoc) + * + * @see com.vaadin.client.HasComponentsConnector#getChildren() + */ + @Override + public List<ComponentConnector> getChildComponents() { + if (childComponents == null) { + return Collections.emptyList(); + } + + return childComponents; + } + + /* + * (non-Javadoc) + * + * @see com.vaadin.client.HasComponentsConnector#setChildren + * (java.util.Collection) + */ + @Override + public void setChildComponents(List<ComponentConnector> childComponents) { + this.childComponents = childComponents; + } + + @Override + public HandlerRegistration addConnectorHierarchyChangeHandler( + ConnectorHierarchyChangeHandler handler) { + return ensureHandlerManager().addHandler( + ConnectorHierarchyChangeEvent.TYPE, handler); + } + + /** + * Returns the content (only/first child) of the container. + * + * @return child connector or null if none (e.g. invisible or not set on + * server) + */ + protected ComponentConnector getContent() { + List<ComponentConnector> children = getChildComponents(); + if (children.isEmpty()) { + return null; + } else { + return children.get(0); + } + } + + /** + * Returns the widget (if any) of the content of the container. + * + * @return widget of the only/first connector of the container, null if no + * content or if there is no widget for the connector + */ + protected Widget getContentWidget() { + ComponentConnector content = getContent(); + if (null != content) { + return content.getWidget(); + } else { + return null; + } } } |