diff options
author | Artur Signell <artur@vaadin.com> | 2012-08-30 17:24:36 +0300 |
---|---|---|
committer | Artur Signell <artur@vaadin.com> | 2012-08-30 17:24:36 +0300 |
commit | 7b25b3886ea95bc6495506fbe9472e45fcbde684 (patch) | |
tree | 0b93cb65dab437feb46720659a63b8f1ef48f7f4 /uitest/src/com/vaadin/tests/tickets/Ticket677.java | |
parent | 8941056349e302e687e40e94c13709e75f256d73 (diff) | |
download | vaadin-framework-7b25b3886ea95bc6495506fbe9472e45fcbde684.tar.gz vaadin-framework-7b25b3886ea95bc6495506fbe9472e45fcbde684.zip |
Renamed tests -> uitest and tests/testbench -> uitest/src (#9299)
Diffstat (limited to 'uitest/src/com/vaadin/tests/tickets/Ticket677.java')
-rw-r--r-- | uitest/src/com/vaadin/tests/tickets/Ticket677.java | 216 |
1 files changed, 216 insertions, 0 deletions
diff --git a/uitest/src/com/vaadin/tests/tickets/Ticket677.java b/uitest/src/com/vaadin/tests/tickets/Ticket677.java new file mode 100644 index 0000000000..1c66f67ca1 --- /dev/null +++ b/uitest/src/com/vaadin/tests/tickets/Ticket677.java @@ -0,0 +1,216 @@ +package com.vaadin.tests.tickets; + +import com.vaadin.Application; +import com.vaadin.data.Container; +import com.vaadin.data.Item; +import com.vaadin.data.Property; +import com.vaadin.data.util.BeanItem; +import com.vaadin.shared.ui.label.ContentMode; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Component; +import com.vaadin.ui.ComponentContainer; +import com.vaadin.ui.DefaultFieldFactory; +import com.vaadin.ui.Field; +import com.vaadin.ui.Form; +import com.vaadin.ui.GridLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.Panel; +import com.vaadin.ui.UI.LegacyWindow; +import com.vaadin.ui.Table; +import com.vaadin.ui.TextField; + +public class Ticket677 extends Application.LegacyApplication { + + private static final Label info = new Label( + "<li> keep debug window open to see variable changes" + + "<li> disable root panel w/ toggle button" + + "<li> toggle one of the subpanels" + + "<li> we attempt to focus the subpanels first textfield" + + "<li> focusing should fail (try tabbing as well) [worked previousy]" + + "<li> no variable changes should be sent from disabled fields [changed sent previously]" + + "<li> try further toggling and tabbing around", + ContentMode.RAW); + + Panel root = new Panel("Enabled"); + Panel one = new Panel("Enabled"); + Panel two = new Panel("Enabled"); + Form form; + Table table; + + @Override + public void init() { + LegacyWindow main = new LegacyWindow(); + setMainWindow(main); + + main.addComponent(info); + + HorizontalLayout l = new HorizontalLayout(); + main.addComponent(l); + + l.addComponent(new Button("Toggle root panel", + new Button.ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + toggle(root); + } + })); + l.addComponent(new Button("Toggle panel one", + new Button.ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + toggle(one); + } + })); + l.addComponent(new Button("Toggle panel two", + new Button.ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + toggle(two); + } + })); + l.addComponent(new Button("Toggle form", new Button.ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + toggle(form); + } + })); + l.addComponent(new Button("Toggle table", new Button.ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + toggle(table); + } + })); + + root.setContent(new GridLayout(2, 3)); + main.addComponent(root); + + TextField tf = new TextField("Enabled"); + tf.setImmediate(true); + root.addComponent(tf); + tf = new TextField("Disabled"); + tf.setImmediate(true); + tf.setEnabled(false); + root.addComponent(tf); + + root.addComponent(one); + tf = new TextField("Enabled"); + tf.setImmediate(true); + one.addComponent(tf); + tf = new TextField("Disabled"); + tf.setImmediate(true); + tf.setEnabled(false); + one.addComponent(tf); + + root.addComponent(two); + tf = new TextField("Enabled"); + tf.setImmediate(true); + two.addComponent(tf); + tf = new TextField("Disabled"); + tf.setImmediate(true); + tf.setEnabled(false); + two.addComponent(tf); + + form = new Form(); + form.setCaption("Enabled"); + form.setFormFieldFactory(new DefaultFieldFactory() { + + @Override + public Field<?> createField(Item item, Object propertyId, + Component uiContext) { + Field<?> f = super.createField(item, propertyId, uiContext); + f.setEnabled(!"disabled".equals(propertyId)); + return f; + } + + }); + form.setItemDataSource(new BeanItem<MyBean>(new MyBean())); + root.addComponent(form); + + table = new Table("Enabled"); + table.setPageLength(7); + table.addContainerProperty("Text", String.class, null); + for (int i = 0; i < 150; i++) { + Item item = table.addItem("Item" + i); + Property<?> p = item.getItemProperty("Text"); + p.setValue(i % 5 == 0 ? "enabled" : "disabled"); + } + + table.setTableFieldFactory(new DefaultFieldFactory() { + + @Override + public Field<?> createField(Container container, Object itemId, + Object propertyId, Component uiContext) { + Field<?> f = super.createField(container, itemId, propertyId, + uiContext); + Item item = container.getItem(itemId); + Property<?> p = item.getItemProperty(propertyId); + if ("disabled".equals(p.getValue())) { + f.setEnabled(false); + } + return f; + } + + }); + table.setEditable(true); + root.addComponent(table); + + } + + private void toggle(Component c) { + boolean enable = "Disabled".equals(c.getCaption()); + c.setEnabled(enable); + c.setCaption((enable ? "Enabled" : "Disabled")); + if (c instanceof ComponentContainer) { + TextField tf = (TextField) ((ComponentContainer) c) + .getComponentIterator().next(); + tf.focus(); + } + } + + class MyBean { + boolean on = false; + int number = 1; + String rw = "read/write"; + String r = "read"; + String disabled = "disabled"; + + public boolean isOn() { + return on; + } + + public void setOn(boolean on) { + this.on = on; + } + + public int getNumber() { + return number; + } + + public void setNumber(int number) { + this.number = number; + } + + public String getRw() { + return rw; + } + + public void setRw(String rw) { + this.rw = rw; + } + + public String getDisabled() { + return disabled; + } + + public void setDisabled(String disabled) { + this.disabled = disabled; + } + + public String getR() { + return r; + } + + } +} |