blob: 1cac66516bdc9a904983339870b3dd5d81e74693 (
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
/* *************************************************************************
IT Mill Toolkit
Development of Browser User Interfaces Made Easy
Copyright (C) 2000-2006 IT Mill Ltd
*************************************************************************
This product is distributed under commercial license that can be found
from the product package on license.pdf. Use of this product might
require purchasing a commercial license from IT Mill Ltd. For guidelines
on usage, see licensing-guidelines.html
*************************************************************************
For more information, contact:
IT Mill Ltd phone: +358 2 4802 7180
Ruukinkatu 2-4 fax: +358 2 4802 7181
20540, Turku email: info@itmill.com
Finland company www: www.itmill.com
Primary source for information and releases: www.itmill.com
********************************************************************** */
package com.itmill.toolkit.tests.featurebrowser;
import com.itmill.toolkit.ui.Component;
import com.itmill.toolkit.ui.Form;
import com.itmill.toolkit.ui.Label;
import com.itmill.toolkit.ui.OrderedLayout;
import com.itmill.toolkit.ui.Panel;
import com.itmill.toolkit.ui.Select;
public class FeatureCustomLayout extends Feature {
private static final String INTRO_TEXT = ""
+ "A container component with freely designed layout and style. The "
+ "container consists of items with textually represented locations. Each "
+ "item contains one sub-component. The adapter and theme are resposible "
+ "for rendering the layout with given style by placing the items on the "
+ "screen in defined locations."
+ "<br /><br />The definition of locations is not fixed - the each style can define its "
+ "locations in a way that is suitable for it. One typical example would be "
+ "to create visual design for a website as a custom layout: the visual design "
+ "could define locations for \"menu\", \"body\" and \"title\" for example. "
+ "The layout would then be implemented e.g. as plain HTML file."
+ "<br /><br />The default theme handles the styles that are not defined by just drawing "
+ "the subcomponents with flowlayout.";
protected Component getDemoComponent() {
OrderedLayout l = new OrderedLayout();
Panel panel = new Panel();
panel.setCaption("Custom Layout");
l.addComponent(panel);
Label label = new Label();
panel.addComponent(label);
label.setContentMode(Label.CONTENT_XHTML);
label.setValue(INTRO_TEXT);
// Properties
propertyPanel = new PropertyPanel(panel);
Form ap = propertyPanel.createBeanPropertySet(new String[] { "width",
"height" });
Select themes = (Select) propertyPanel.getField("style");
themes.addItem("light").getItemProperty(
themes.getItemCaptionPropertyId()).setValue("light");
themes.addItem("strong").getItemProperty(
themes.getItemCaptionPropertyId()).setValue("strong");
propertyPanel.addProperties("Panel Properties", ap);
setJavadocURL("ui/CustomLayout.html");
return l;
}
protected String getDescriptionXHTML() {
return null;
}
protected String getExampleSrc() {
return "CustomLayout c = new CustomLayout(\"mystyle\");\n"
+ "c.addComponent(new Label(\"Example description\"),\"label1-location\");\n"
+ "c.addComponent(new Button(\"Example action\"),\"example-action-location\");\n";
}
protected String getImage() {
return null;
}
protected String getTitle() {
return "Custom Layout";
}
}
|