aboutsummaryrefslogtreecommitdiffstats
path: root/server/src
diff options
context:
space:
mode:
authorMatti Hosio <mhosio@vaadin.com>2014-12-11 16:22:41 +0200
committerMatti Hosio <mhosio@vaadin.com>2014-12-12 10:27:18 +0200
commitccb76e6608adbdf652748899779a458cd795ac3a (patch)
tree4aa5dd26c73441ba61cae2d9b595c535b8597b8a /server/src
parent64a029571955ee52b0c416b597fb718bc0a66c46 (diff)
downloadvaadin-framework-ccb76e6608adbdf652748899779a458cd795ac3a.tar.gz
vaadin-framework-ccb76e6608adbdf652748899779a458cd795ac3a.zip
Declarative support for TabSheet and Accordion (#7749)
Change-Id: Iee4689814f08ddbb852cfb3e51c9873fbe42d901
Diffstat (limited to 'server/src')
-rw-r--r--server/src/com/vaadin/ui/TabSheet.java167
-rw-r--r--server/src/com/vaadin/ui/declarative/DesignAttributeHandler.java4
2 files changed, 169 insertions, 2 deletions
diff --git a/server/src/com/vaadin/ui/TabSheet.java b/server/src/com/vaadin/ui/TabSheet.java
index d3410464a2..dd9beb07f0 100644
--- a/server/src/com/vaadin/ui/TabSheet.java
+++ b/server/src/com/vaadin/ui/TabSheet.java
@@ -19,11 +19,15 @@ package com.vaadin.ui;
import java.io.Serializable;
import java.lang.reflect.Method;
import java.util.ArrayList;
+import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
+import org.jsoup.nodes.Attributes;
+import org.jsoup.nodes.Element;
+
import com.vaadin.event.FieldEvents.BlurEvent;
import com.vaadin.event.FieldEvents.BlurListener;
import com.vaadin.event.FieldEvents.BlurNotifier;
@@ -40,6 +44,9 @@ import com.vaadin.shared.ui.tabsheet.TabsheetClientRpc;
import com.vaadin.shared.ui.tabsheet.TabsheetServerRpc;
import com.vaadin.shared.ui.tabsheet.TabsheetState;
import com.vaadin.ui.Component.Focusable;
+import com.vaadin.ui.declarative.DesignAttributeHandler;
+import com.vaadin.ui.declarative.DesignContext;
+import com.vaadin.ui.declarative.DesignException;
import com.vaadin.ui.themes.Reindeer;
import com.vaadin.ui.themes.Runo;
@@ -1447,4 +1454,164 @@ public class TabSheet extends AbstractComponentContainer implements Focusable,
protected TabsheetState getState() {
return (TabsheetState) super.getState();
}
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.vaadin.ui.AbstractComponent#synchronizeFromDesign(org.jsoup.nodes
+ * .Element, com.vaadin.ui.declarative.DesignContext)
+ */
+ @Override
+ public void synchronizeFromDesign(Element design,
+ DesignContext designContext) {
+ super.synchronizeFromDesign(design, designContext);
+ Attributes attr = design.attributes();
+ TabSheet def = designContext.getDefaultInstance(this.getClass());
+ // handle tab index
+ int tabIndex = DesignAttributeHandler.readAttribute("tabindex", attr,
+ def.getTabIndex(), Integer.class);
+ setTabIndex(tabIndex);
+ // clear old tabs
+ removeAllComponents();
+ // create new tabs
+ for (Element tab : design.children()) {
+ if (!tab.tagName().equals("tab")) {
+ throw new DesignException("Invalid tag name for tabsheet tab "
+ + tab.tagName());
+ }
+ readTabFromDesign(tab, designContext);
+ }
+ }
+
+ /**
+ * Reads the given tab element from design
+ *
+ * @since 7.4
+ *
+ * @param tabElement
+ * the element to be read
+ * @param designContext
+ * the design context
+ */
+ private void readTabFromDesign(Element tabElement,
+ DesignContext designContext) {
+ Attributes attr = tabElement.attributes();
+ if (tabElement.children().size() != 1) {
+ throw new DesignException(
+ "A tab must have exactly one child element");
+ }
+ // create the component that is in tab content
+ Element content = tabElement.child(0);
+ DesignSynchronizable child = designContext.createChild(content);
+ Tab tab = this.addTab(child);
+ tab.setVisible(DesignAttributeHandler.readAttribute("visible", attr,
+ tab.isVisible(), Boolean.class));
+ tab.setClosable(DesignAttributeHandler.readAttribute("closable", attr,
+ tab.isClosable(), Boolean.class));
+ tab.setCaption(DesignAttributeHandler.readAttribute("caption", attr,
+ tab.getCaption(), String.class));
+ tab.setEnabled(DesignAttributeHandler.readAttribute("enabled", attr,
+ tab.isEnabled(), Boolean.class));
+ tab.setIcon(DesignAttributeHandler.readAttribute("icon", attr,
+ tab.getIcon(), Resource.class));
+ tab.setIconAlternateText(DesignAttributeHandler.readAttribute(
+ "icon-alt", attr, tab.getIconAlternateText(), String.class));
+ tab.setDescription(DesignAttributeHandler.readAttribute("description",
+ attr, tab.getDescription(), String.class));
+ tab.setStyleName(DesignAttributeHandler.readAttribute("style-name",
+ attr, tab.getStyleName(), String.class));
+ tab.setId(DesignAttributeHandler.readAttribute("id", attr, tab.getId(),
+ String.class));
+ boolean selected = DesignAttributeHandler.readAttribute("selected",
+ attr, false, Boolean.class);
+ if (selected) {
+ this.setSelectedTab(tab.getComponent());
+ }
+ }
+
+ /**
+ * Writes the given tab to design
+ *
+ * @since 7.4
+ * @param design
+ * the design node for tabsheet
+ * @param designContext
+ * the design context
+ * @param tab
+ * the tab to be written
+ */
+ private void writeTabToDesign(Element design, DesignContext designContext,
+ Tab tab) {
+ // get default tab instance
+ Tab def = new TabSheetTabImpl(null, null, null);
+ // create element for tab
+ Element tabElement = design.appendElement("tab");
+ // add tab content
+ tabElement.appendChild(designContext
+ .createNode((DesignSynchronizable) tab.getComponent()));
+ Attributes attr = tabElement.attributes();
+ // write attributes
+ DesignAttributeHandler.writeAttribute("visible", attr, tab.isVisible(),
+ def.isVisible(), Boolean.class);
+ DesignAttributeHandler.writeAttribute("closable", attr,
+ tab.isClosable(), def.isClosable(), Boolean.class);
+ DesignAttributeHandler.writeAttribute("caption", attr,
+ tab.getCaption(), def.getCaption(), String.class);
+ DesignAttributeHandler.writeAttribute("enabled", attr, tab.isEnabled(),
+ def.isEnabled(), Boolean.class);
+ DesignAttributeHandler.writeAttribute("icon", attr, tab.getIcon(),
+ def.getIcon(), Resource.class);
+ DesignAttributeHandler.writeAttribute("icon-alt", attr,
+ tab.getIconAlternateText(), def.getIconAlternateText(),
+ String.class);
+ DesignAttributeHandler.writeAttribute("description", attr,
+ tab.getDescription(), def.getDescription(), String.class);
+ DesignAttributeHandler.writeAttribute("style-name", attr,
+ tab.getStyleName(), def.getStyleName(), String.class);
+ DesignAttributeHandler.writeAttribute("id", attr, tab.getId(),
+ def.getId(), String.class);
+ if (getSelectedTab() != null
+ && getSelectedTab().equals(tab.getComponent())) {
+ // use write attribute to get consistent handling for boolean
+ DesignAttributeHandler.writeAttribute("selected", attr, true,
+ false, boolean.class);
+ }
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.vaadin.ui.AbstractComponent#getCustomAttributes()
+ */
+ @Override
+ protected Collection<String> getCustomAttributes() {
+ Collection<String> attributes = super.getCustomAttributes();
+ attributes.add("tabindex");
+ // no need to list tab attributes since they are considered internal
+ return attributes;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.vaadin.ui.AbstractComponent#synchronizeToDesign(org.jsoup.nodes.Element
+ * , com.vaadin.ui.declarative.DesignContext)
+ */
+ @Override
+ public void synchronizeToDesign(Element design, DesignContext designContext) {
+ super.synchronizeToDesign(design, designContext);
+ TabSheet def = designContext.getDefaultInstance(this.getClass());
+ Attributes attr = design.attributes();
+ // handle tab index
+ DesignAttributeHandler.writeAttribute("tabindex", attr, getTabIndex(),
+ def.getTabIndex(), Integer.class);
+ // write tabs
+ for (Component component : this) {
+ Tab tab = this.getTab(component);
+ writeTabToDesign(design, designContext, tab);
+ }
+ }
+
}
diff --git a/server/src/com/vaadin/ui/declarative/DesignAttributeHandler.java b/server/src/com/vaadin/ui/declarative/DesignAttributeHandler.java
index 2992771521..0c370b8da7 100644
--- a/server/src/com/vaadin/ui/declarative/DesignAttributeHandler.java
+++ b/server/src/com/vaadin/ui/declarative/DesignAttributeHandler.java
@@ -295,7 +295,7 @@ public class DesignAttributeHandler implements Serializable {
+ inputType.getName() + " not supported");
}
if (!SharedUtil.equals(value, defaultValue)) {
- String attributeValue = toAttributeValue(value.getClass(), value);
+ String attributeValue = toAttributeValue(inputType, value);
attributes.put(attribute, attributeValue);
}
}
@@ -464,7 +464,7 @@ public class DesignAttributeHandler implements Serializable {
*/
private static Resource parseResource(String value) {
if (value.startsWith("http://")) {
- return new ExternalResource("value");
+ return new ExternalResource(value);
} else if (value.startsWith("theme://")) {
return new ThemeResource(value.substring(8));
} else if (value.startsWith("font://")) {