diff options
author | Marc Englund <marc.englund@itmill.com> | 2009-05-19 08:17:54 +0000 |
---|---|---|
committer | Marc Englund <marc.englund@itmill.com> | 2009-05-19 08:17:54 +0000 |
commit | 13821cde67b4ec51d918cca58bf0b78d9c1b1130 (patch) | |
tree | 0edc824b5b8837e8b087e930563769ae5dc4146c /src/com | |
parent | 2f6310efadab44dedaf7801a9b6274d5c26acfa3 (diff) | |
download | vaadin-framework-13821cde67b4ec51d918cca58bf0b78d9c1b1130.tar.gz vaadin-framework-13821cde67b4ec51d918cca58bf0b78d9c1b1130.zip |
Theme select for #2972, still needs theme-resource update
svn changeset:7873/svn branch:6.0
Diffstat (limited to 'src/com')
-rw-r--r-- | src/com/vaadin/demo/sampler/SamplerApplication.java | 34 |
1 files changed, 32 insertions, 2 deletions
diff --git a/src/com/vaadin/demo/sampler/SamplerApplication.java b/src/com/vaadin/demo/sampler/SamplerApplication.java index ea35d986ac..2b2464e1a3 100644 --- a/src/com/vaadin/demo/sampler/SamplerApplication.java +++ b/src/com/vaadin/demo/sampler/SamplerApplication.java @@ -7,8 +7,10 @@ import java.util.HashMap; import java.util.Iterator; import com.vaadin.Application; +import com.vaadin.data.Item; import com.vaadin.data.Property; import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; import com.vaadin.data.util.HierarchicalContainer; import com.vaadin.data.util.ObjectProperty; import com.vaadin.demo.sampler.ActiveLink.LinkActivatedEvent; @@ -51,7 +53,8 @@ public class SamplerApplication extends Application { private static final HierarchicalContainer allFeatures = FeatureSet.FEATURES .getContainer(true); - // init() inits + // this actually differs from getTheme() - this is the 'base', the active + // theme extends this private static final String THEME_NAME = "sampler"; // used when trying to guess theme location @@ -59,7 +62,7 @@ public class SamplerApplication extends Application { @Override public void init() { - setTheme("sampler"); + setTheme("sampler-reindeer"); setMainWindow(new SamplerWindow()); APP_URL = getURL().toString(); } @@ -210,6 +213,33 @@ public class SamplerApplication extends Application { } }); + { // Theme select + final ComboBox themeSelect = new ComboBox(); + themeSelect.setWidth("120px"); + themeSelect.setStyleName("theme"); + themeSelect.setImmediate(true); + themeSelect.setNullSelectionAllowed(false); + themeSelect.addContainerProperty("name", String.class, null); + themeSelect.setItemCaptionPropertyId("name"); + Item item = themeSelect.addItem("sampler-reindeer"); + item.getItemProperty("name").setValue("Reindeer theme"); + item = themeSelect.addItem("sampler-runo"); + item.getItemProperty("name").setValue("Runo theme"); + themeSelect.setValue(SamplerApplication.this.getTheme()); + themeSelect.addListener(new ValueChangeListener() { + public void valueChange(ValueChangeEvent event) { + Object theme = themeSelect.getValue(); + if (theme != null + && !theme.equals(SamplerApplication.this + .getTheme())) { + SamplerApplication.this.setTheme((String) theme); + } + } + }); + nav.addComponent(themeSelect); + nav.setComponentAlignment(themeSelect, Alignment.MIDDLE_LEFT); + } + // Main left/right split; hidden menu tree mainSplit = new SplitPanel(SplitPanel.ORIENTATION_HORIZONTAL); mainSplit.setSizeFull(); |