summaryrefslogtreecommitdiffstats
path: root/server/src/com/vaadin/ui/TabSheet.java
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2014-12-15 08:41:45 +0200
committerMatti Hosio <mhosio@vaadin.com>2014-12-15 16:35:54 +0200
commit8eafe7aee31b3e2f80c87b39c4e42e260a86a5eb (patch)
tree93bf9f429390e5643a55f503076a391469359ce2 /server/src/com/vaadin/ui/TabSheet.java
parent3b75f2b14833f78c00d0032cbd76b09fca058100 (diff)
downloadvaadin-framework-8eafe7aee31b3e2f80c87b39c4e42e260a86a5eb.tar.gz
vaadin-framework-8eafe7aee31b3e2f80c87b39c4e42e260a86a5eb.zip
Do not create default instances while reading designs (#7749)
Change-Id: I26cb6d8d43200d10ebf8c0ac22c538b4272f5ecd
Diffstat (limited to 'server/src/com/vaadin/ui/TabSheet.java')
-rw-r--r--server/src/com/vaadin/ui/TabSheet.java79
1 files changed, 52 insertions, 27 deletions
diff --git a/server/src/com/vaadin/ui/TabSheet.java b/server/src/com/vaadin/ui/TabSheet.java
index 94bcb80279..330acacfd0 100644
--- a/server/src/com/vaadin/ui/TabSheet.java
+++ b/server/src/com/vaadin/ui/TabSheet.java
@@ -1464,12 +1464,8 @@ public class TabSheet extends AbstractComponentContainer implements Focusable,
@Override
public void readDesign(Element design, DesignContext designContext) {
super.readDesign(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);
+ readTabIndex(design);
// clear old tabs
removeAllComponents();
// create new tabs
@@ -1482,6 +1478,15 @@ public class TabSheet extends AbstractComponentContainer implements Focusable,
}
}
+ private void readTabIndex(Element design) {
+ // Could be in AbstractComponent as if (this implements Focusable)
+ if (design.hasAttr("tabindex")) {
+ setTabIndex(DesignAttributeHandler.readAttribute("tabindex",
+ design.attributes(), Integer.class));
+ }
+
+ }
+
/**
* Reads the given tab element from design
*
@@ -1503,28 +1508,48 @@ public class TabSheet extends AbstractComponentContainer implements Focusable,
Element content = tabElement.child(0);
Component 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());
+ if (attr.hasKey("visible")) {
+ tab.setVisible(DesignAttributeHandler.readAttribute("visible",
+ attr, Boolean.class));
+ }
+ if (attr.hasKey("closable")) {
+ tab.setClosable(DesignAttributeHandler.readAttribute("closable",
+ attr, Boolean.class));
+ }
+ if (attr.hasKey("caption")) {
+ tab.setCaption(DesignAttributeHandler.readAttribute("caption",
+ attr, String.class));
+ }
+ if (attr.hasKey("enabled")) {
+ tab.setEnabled(DesignAttributeHandler.readAttribute("enabled",
+ attr, Boolean.class));
+ }
+ if (attr.hasKey("icon")) {
+ tab.setIcon(DesignAttributeHandler.readAttribute("icon", attr,
+ Resource.class));
+ }
+ if (attr.hasKey("icon-alt")) {
+ tab.setIconAlternateText(DesignAttributeHandler.readAttribute(
+ "icon-alt", attr, String.class));
+ }
+ if (attr.hasKey("description")) {
+ tab.setDescription(DesignAttributeHandler.readAttribute(
+ "description", attr, String.class));
+ }
+ if (attr.hasKey("style-name")) {
+ tab.setStyleName(DesignAttributeHandler.readAttribute("style-name",
+ attr, String.class));
+ }
+ if (attr.hasKey("id")) {
+ tab.setId(DesignAttributeHandler.readAttribute("id", attr,
+ String.class));
+ }
+ if (attr.hasKey("selected")) {
+ boolean selected = DesignAttributeHandler.readAttribute("selected",
+ attr, Boolean.class);
+ if (selected) {
+ this.setSelectedTab(tab.getComponent());
+ }
}
}