blob: ee87640213544e940ca190e096407f913ffad2ff (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
package com.vaadin.tests.tickets;
import com.vaadin.data.Item;
import com.vaadin.data.util.IndexedContainer;
import com.vaadin.ui.Button;
import com.vaadin.ui.Component;
import com.vaadin.ui.Label;
import com.vaadin.ui.Table;
import com.vaadin.ui.UI.LegacyWindow;
/**
*
* Toggling container with an empty one may result duplicate header cell in
* client.
*
*/
public class Ticket2126 extends com.vaadin.Application {
LegacyWindow main = new LegacyWindow();
Table table = new Table();
@Override
public void init() {
setMainWindow(main);
final IndexedContainer container1 = new IndexedContainer();
container1.addContainerProperty("text", Component.class, null);
final IndexedContainer container2 = new IndexedContainer();
// Case #2 Try to comment the following line for another type of strange
// behaviour
container2.addContainerProperty("text", Component.class, null);
for (int i = 0; i < 100; i++) {
Item item = container1.addItem(i);
item.getItemProperty("text").setValue(new Label("Test " + i));
}
table.setContainerDataSource(container1);
// workaround for case #2
// table.setWidth("300px");
// table.setHeight("300px");
Button refreshTable = new Button("Switch table container");
refreshTable.addListener(new Button.ClickListener() {
boolean full = true;
@Override
public void buttonClick(Button.ClickEvent e) {
if (full) {
table.setContainerDataSource(container2);
} else {
table.setContainerDataSource(container1);
}
full = !full;
}
});
main.addComponent(table);
main.addComponent(refreshTable);
}
}
|