aboutsummaryrefslogtreecommitdiffstats
path: root/src/com/vaadin/tests/CustomLayoutDemo.java
diff options
context:
space:
mode:
authorArtur Signell <artur.signell@itmill.com>2009-10-27 07:57:12 +0000
committerArtur Signell <artur.signell@itmill.com>2009-10-27 07:57:12 +0000
commit6a3c715dae922edd723c9423b4308d5d7948b74e (patch)
tree46a007274681a9803afccf135ace5554f3e01e3a /src/com/vaadin/tests/CustomLayoutDemo.java
parent931d75fef69deb9b738fad97001cf5621de9f43e (diff)
downloadvaadin-framework-6a3c715dae922edd723c9423b4308d5d7948b74e.tar.gz
vaadin-framework-6a3c715dae922edd723c9423b4308d5d7948b74e.zip
Split demo and tests files to own source folders, for #3298
svn changeset:9390/svn branch:6.2
Diffstat (limited to 'src/com/vaadin/tests/CustomLayoutDemo.java')
-rw-r--r--src/com/vaadin/tests/CustomLayoutDemo.java140
1 files changed, 0 insertions, 140 deletions
diff --git a/src/com/vaadin/tests/CustomLayoutDemo.java b/src/com/vaadin/tests/CustomLayoutDemo.java
deleted file mode 100644
index ac0507332b..0000000000
--- a/src/com/vaadin/tests/CustomLayoutDemo.java
+++ /dev/null
@@ -1,140 +0,0 @@
-/*
-@ITMillApache2LicenseForJavaFiles@
- */
-
-package com.vaadin.tests;
-
-import com.vaadin.ui.Button;
-import com.vaadin.ui.CustomLayout;
-import com.vaadin.ui.Field;
-import com.vaadin.ui.Label;
-import com.vaadin.ui.Panel;
-import com.vaadin.ui.TextField;
-import com.vaadin.ui.Tree;
-import com.vaadin.ui.Window;
-import com.vaadin.ui.Component.Event;
-import com.vaadin.ui.Component.Listener;
-
-/**
- * This example demonstrates custom layout. All components created here are
- * placed using custom.html file. Custom layouts may be created with any web
- * designer tool such as Dreamweaver. To place Vaadin components into html page,
- * use divs with location tag as an identifier for Vaadin components, see html
- * page (themes/example/layout/custom.html) and source code below. Body panel
- * contents are changed when menu items are clicked. Contents are HTML pages
- * located at themes/example/layout directory.
- *
- * @author IT Mill Ltd.
- * @since 4.0.0
- *
- */
-public class CustomLayoutDemo extends com.vaadin.Application implements
- Listener {
-
- private CustomLayout mainLayout = null;
-
- private final Panel bodyPanel = new Panel();
-
- private final TextField username = new TextField("Username");
-
- private final TextField loginPwd = new TextField("Password");
-
- private final Button loginButton = new Button("Login", this, "loginClicked");
-
- private final Tree menu = new Tree();
-
- /**
- * Initialize Application. Demo components are added to main window.
- */
- @Override
- public void init() {
- final Window mainWindow = new Window("CustomLayout demo");
- setMainWindow(mainWindow);
-
- // set the application to use example -theme
- setTheme("example");
-
- // Create custom layout, themes/example/layout/mainLayout.html
- mainLayout = new CustomLayout("mainLayout");
- // wrap custom layout inside a panel
- final Panel customLayoutPanel = new Panel(
- "Panel containing custom layout (mainLayout.html)");
- customLayoutPanel.addComponent(mainLayout);
-
- // Login components
- loginPwd.setSecret(true);
- mainLayout.addComponent(username, "loginUser");
- mainLayout.addComponent(loginPwd, "loginPassword");
- mainLayout.addComponent(loginButton, "loginButton");
-
- // Menu component, when clicked bodyPanel is updated
- menu.addItem("Welcome");
- menu.addItem("Products");
- menu.addItem("Support");
- menu.addItem("News");
- menu.addItem("Developers");
- menu.addItem("Contact");
- // "this" handles all menu events, e.g. node clicked event
- menu.addListener(this);
- // Value changes are immediate
- menu.setImmediate(true);
- menu.setNullSelectionAllowed(false);
- mainLayout.addComponent(menu, "menu");
-
- // Body component
- mainLayout.addComponent(bodyPanel, "body");
-
- // Initial body are comes from Welcome.html
- setBody("Welcome");
-
- // Add heading label and custom layout panel to main window
- mainWindow.addComponent(new Label("<h3>Custom layout demo</h3>",
- Label.CONTENT_XHTML));
- mainWindow.addComponent(customLayoutPanel);
- }
-
- /**
- * Login button clicked. Hide login components and replace username
- * component with "Welcome user Username" message.
- *
- */
- public void loginClicked() {
- username.setVisible(false);
- loginPwd.setVisible(false);
- if (username.getValue().toString().length() < 1) {
- username.setValue("Anonymous");
- }
- mainLayout.replaceComponent(loginButton, new Label("Welcome user <em>"
- + username.getValue() + "</em>", Label.CONTENT_XHTML));
- }
-
- /**
- * Set body panel caption, remove all existing components and add given
- * custom layout in it.
- *
- */
- public void setBody(String customLayout) {
- bodyPanel.setCaption(customLayout + ".html");
- bodyPanel.removeAllComponents();
- bodyPanel.addComponent(new CustomLayout(customLayout));
- }
-
- /**
- * Handle all menu events. Updates body panel contents if menu item is
- * clicked.
- */
- public void componentEvent(Event event) {
- // Check if event occured at fsTree component
- if (event.getSource() == menu) {
- // Check if event is about changing value
- if (event.getClass() == Field.ValueChangeEvent.class) {
- // Update body area with selected item
- setBody(menu.getValue().toString());
- }
- // here we could check for other type of events for tree
- // component
- }
- // here we could check for other component's events
- }
-
-}