/* *************************************************************************
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."
+ "
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."
+ "
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";
}
}