diff options
author | Artur Signell <artur@vaadin.com> | 2014-12-15 08:41:45 +0200 |
---|---|---|
committer | Matti Hosio <mhosio@vaadin.com> | 2014-12-15 16:35:54 +0200 |
commit | 8eafe7aee31b3e2f80c87b39c4e42e260a86a5eb (patch) | |
tree | 93bf9f429390e5643a55f503076a391469359ce2 /server/src/com/vaadin/ui/TabSheet.java | |
parent | 3b75f2b14833f78c00d0032cbd76b09fca058100 (diff) | |
download | vaadin-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.java | 79 |
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()); + } } } |