diff options
author | Henri Sara <hesara@vaadin.com> | 2014-06-30 13:33:16 +0300 |
---|---|---|
committer | Henri Sara <hesara@vaadin.com> | 2014-06-30 13:59:10 +0300 |
commit | 31800c977efcb024f197ae5d8f39265050fd9777 (patch) | |
tree | 9e100cafc4792e5789a52ee8a58c3233561e2471 /uitest | |
parent | 0b2280432cc25168999cd30ecd1f0a46e9b96410 (diff) | |
parent | 00594db377d6c6935d445d42fef691b97e5c84f3 (diff) | |
download | vaadin-framework-31800c977efcb024f197ae5d8f39265050fd9777.tar.gz vaadin-framework-31800c977efcb024f197ae5d8f39265050fd9777.zip |
Merge branch 'valo' to master
Updated release notes to the form previously used in master.
The ticket list link needs to be updated separately in the
7.3 branch.
Change-Id: I7b7d09a1281261d3a1b8793cfff9ba8951a07798
Diffstat (limited to 'uitest')
25 files changed, 5674 insertions, 0 deletions
diff --git a/uitest/src/com/vaadin/tests/themes/valo/Accordions.java b/uitest/src/com/vaadin/tests/themes/valo/Accordions.java new file mode 100644 index 0000000000..b401451271 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Accordions.java @@ -0,0 +1,86 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.ui.Accordion; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.VerticalLayout; + +public class Accordions extends VerticalLayout implements View { + public Accordions() { + setMargin(true); + + Label h1 = new Label("Accordions"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.setSpacing(true); + row.setWidth("100%"); + addComponent(row); + + row.addComponent(getAccordion("Normal")); + + Accordion ac = getAccordion("Borderless"); + ac.addStyleName("borderless"); + row.addComponent(ac); + + } + + Accordion getAccordion(String caption) { + Accordion ac = new Accordion(); + ac.setCaption(caption); + ac.addTab(new VerticalLayout() { + { + setMargin(true); + addComponent(new Label( + "Fabio vel iudice vincam, sunt in culpa qui officia. Ut enim ad minim veniam, quis nostrud exercitation.")); + } + }, "First Caption", TestIcon.get()); + ac.addTab(new VerticalLayout() { + { + setMargin(true); + addComponent(new Label( + "Gallia est omnis divisa in partes tres, quarum.")); + } + }, "Second Caption", TestIcon.get()); + ac.addTab(new VerticalLayout() { + { + setMargin(true); + addComponent(new Label( + "Nihil hic munitissimus habendi senatus locus, nihil horum? Sed haec quis possit intrepidus aestimare tellus.")); + } + }, "Third Caption", TestIcon.get()); + ac.addTab(new VerticalLayout() { + { + setMargin(true); + addComponent(new Label( + "Inmensae subtilitatis, obscuris et malesuada fames. Quisque ut dolor gravida, placerat libero vel, euismod.")); + } + }, "Custom Caption Style", TestIcon.get()).setStyleName("color1"); + return ac; + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/ButtonsAndLinks.java b/uitest/src/com/vaadin/tests/themes/valo/ButtonsAndLinks.java new file mode 100644 index 0000000000..ce08d9ba08 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/ButtonsAndLinks.java @@ -0,0 +1,180 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.ExternalResource; +import com.vaadin.ui.Button; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.Link; +import com.vaadin.ui.NativeButton; +import com.vaadin.ui.VerticalLayout; + +/** + * + * @since + * @author Vaadin Ltd + */ +public class ButtonsAndLinks extends VerticalLayout implements View { + /** + * + */ + public ButtonsAndLinks() { + setMargin(true); + + Label h1 = new Label("Buttons"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + Button button = new Button("Normal"); + row.addComponent(button); + + button = new Button("Disabled"); + button.setEnabled(false); + row.addComponent(button); + + button = new Button("Primary"); + button.addStyleName("primary"); + row.addComponent(button); + + button = new Button("Friendly"); + button.addStyleName("friendly"); + row.addComponent(button); + + button = new Button("Danger"); + button.addStyleName("danger"); + row.addComponent(button); + + button = new Button("Small"); + button.addStyleName("small"); + button.setIcon(TestIcon.get()); + row.addComponent(button); + + button = new Button("Large"); + button.addStyleName("large"); + button.setIcon(TestIcon.get()); + row.addComponent(button); + + button = new Button("Top"); + button.addStyleName("icon-align-top"); + button.setIcon(TestIcon.get()); + row.addComponent(button); + + button = new Button("Image icon"); + button.setIcon(TestIcon.get(true, 16)); + row.addComponent(button); + + button = new Button("Image icon"); + button.addStyleName("icon-align-right"); + button.setIcon(TestIcon.get(true)); + row.addComponent(button); + + button = new Button("Photos"); + button.setIcon(TestIcon.get()); + row.addComponent(button); + + button = new Button(); + button.setIcon(TestIcon.get()); + button.addStyleName("icon-only"); + row.addComponent(button); + + button = new Button("Borderless"); + button.setIcon(TestIcon.get()); + button.addStyleName("borderless"); + row.addComponent(button); + + button = new Button("Borderless, colored"); + button.setIcon(TestIcon.get()); + button.addStyleName("borderless-colored"); + row.addComponent(button); + + button = new Button("Quiet"); + button.setIcon(TestIcon.get()); + button.addStyleName("quiet"); + row.addComponent(button); + + button = new Button("Link style"); + button.setIcon(TestIcon.get()); + button.addStyleName("link"); + row.addComponent(button); + + button = new Button("Icon on right"); + button.setIcon(TestIcon.get()); + button.addStyleName("icon-align-right"); + row.addComponent(button); + + CssLayout group = new CssLayout(); + group.addStyleName("v-component-group"); + row.addComponent(group); + + button = new Button("One"); + group.addComponent(button); + button = new Button("Two"); + group.addComponent(button); + button = new Button("Three"); + group.addComponent(button); + + NativeButton nbutton = new NativeButton("Native"); + row.addComponent(nbutton); + + h1 = new Label("Links"); + h1.addStyleName("h1"); + addComponent(h1); + + row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + Link link = new Link("vaadin.com", new ExternalResource( + "https://vaadin.com")); + row.addComponent(link); + + link = new Link("Link with icon", new ExternalResource( + "https://vaadin.com")); + link.addStyleName("color3"); + link.setIcon(TestIcon.get()); + row.addComponent(link); + + link = new Link("Small", new ExternalResource("https://vaadin.com")); + link.addStyleName("small"); + row.addComponent(link); + + link = new Link("Large", new ExternalResource("https://vaadin.com")); + link.addStyleName("large"); + row.addComponent(link); + + link = new Link(null, new ExternalResource("https://vaadin.com")); + link.setIcon(TestIcon.get()); + link.addStyleName("large"); + row.addComponent(link); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/CalendarTest.java b/uitest/src/com/vaadin/tests/themes/valo/CalendarTest.java new file mode 100644 index 0000000000..17dfd6cb67 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/CalendarTest.java @@ -0,0 +1,1278 @@ +package com.vaadin.tests.themes.valo; + +import java.text.DateFormatSymbols; +import java.util.Date; +import java.util.GregorianCalendar; +import java.util.Locale; +import java.util.Map; +import java.util.TimeZone; + +import com.vaadin.annotations.Theme; +import com.vaadin.data.Item; +import com.vaadin.data.Property; +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.data.fieldgroup.FieldGroup; +import com.vaadin.data.fieldgroup.FieldGroup.CommitException; +import com.vaadin.data.util.BeanItem; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.combobox.FilteringMode; +import com.vaadin.shared.ui.datefield.Resolution; +import com.vaadin.tests.components.calendar.CalendarTestEvent; +import com.vaadin.ui.Alignment; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.Calendar; +import com.vaadin.ui.Calendar.TimeFormat; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.ComboBox; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.DateField; +import com.vaadin.ui.FormLayout; +import com.vaadin.ui.GridLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.Layout; +import com.vaadin.ui.TextArea; +import com.vaadin.ui.TextField; +import com.vaadin.ui.VerticalLayout; +import com.vaadin.ui.Window; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.DateClickEvent; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.EventClick; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.EventClickHandler; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.RangeSelectEvent; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.RangeSelectHandler; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.WeekClick; +import com.vaadin.ui.components.calendar.CalendarComponentEvents.WeekClickHandler; +import com.vaadin.ui.components.calendar.event.BasicEvent; +import com.vaadin.ui.components.calendar.event.BasicEventProvider; +import com.vaadin.ui.components.calendar.event.CalendarEvent; +import com.vaadin.ui.components.calendar.handler.BasicDateClickHandler; +import com.vaadin.ui.components.calendar.handler.BasicWeekClickHandler; + +/** Calendar component test application */ +@Theme("valo-test") +public class CalendarTest extends GridLayout implements View { + + private static final long serialVersionUID = -5436777475398410597L; + + private static final String DEFAULT_ITEMID = "DEFAULT"; + + private enum Mode { + MONTH, WEEK, DAY; + } + + /** + * This Gregorian calendar is used to control dates and time inside of this + * test application. + */ + private GregorianCalendar calendar; + + /** Target calendar component that this test application is made for. */ + private Calendar calendarComponent; + + private Date currentMonthsFirstDate; + + private final Label captionLabel = new Label(""); + + private Button monthButton; + + private Button weekButton; + + private Button dayButton; + + private Button nextButton; + + private Button prevButton; + + private ComboBox timeZoneSelect; + + private ComboBox formatSelect; + + private ComboBox localeSelect; + + private CheckBox hideWeekendsButton; + + private CheckBox readOnlyButton; + + private TextField captionField; + + private Window scheduleEventPopup; + + private final FormLayout scheduleEventFieldLayout = new FormLayout(); + private FieldGroup scheduleEventFieldGroup = new FieldGroup(); + + private Button deleteEventButton; + + private Button applyEventButton; + + private Mode viewMode = Mode.MONTH; + + private BasicEventProvider dataSource; + + private Button addNewEvent; + + /* + * When testBench is set to true, CalendarTest will have static content that + * is more suitable for Vaadin TestBench testing. Calendar will use a static + * date Mon 10 Jan 2000. Enable by starting the application with a + * "testBench" parameter in the URL. + */ + private boolean testBench = false; + + private String calendarHeight = null; + + private String calendarWidth = null; + + private CheckBox disabledButton; + + private Integer firstHour; + + private Integer lastHour; + + private Integer firstDay; + + private Integer lastDay; + + private Locale defaultLocale = Locale.US; + + private boolean showWeeklyView; + + private boolean useSecondResolution; + + private DateField startDateField; + private DateField endDateField; + + public CalendarTest() { + setSizeFull(); + setHeight("1000px"); + setMargin(true); + setSpacing(true); + + // handleURLParams(request.getParameterMap()); + + initContent(); + } + + private void handleURLParams(Map<String, String[]> parameters) { + testBench = parameters.containsKey("testBench") + || parameters.containsKey("?testBench"); + + if (parameters.containsKey("width")) { + calendarWidth = parameters.get("width")[0]; + } + + if (parameters.containsKey("height")) { + calendarHeight = parameters.get("height")[0]; + } + + if (parameters.containsKey("firstDay")) { + firstDay = Integer.parseInt(parameters.get("firstDay")[0]); + } + + if (parameters.containsKey("lastDay")) { + lastDay = Integer.parseInt(parameters.get("lastDay")[0]); + } + + if (parameters.containsKey("firstHour")) { + firstHour = Integer.parseInt(parameters.get("firstHour")[0]); + } + + if (parameters.containsKey("lastHour")) { + lastHour = Integer.parseInt(parameters.get("lastHour")[0]); + } + + if (parameters.containsKey("locale")) { + String localeArray[] = parameters.get("locale")[0].split("_"); + defaultLocale = new Locale(localeArray[0], localeArray[1]); + setLocale(defaultLocale); + } + + if (parameters.containsKey(("secondsResolution"))) { + useSecondResolution = true; + } + + showWeeklyView = parameters.containsKey("weekly"); + + } + + public void initContent() { + // Set default Locale for this application + if (testBench) { + setLocale(defaultLocale); + + } else { + setLocale(Locale.getDefault()); + } + + // Initialize locale, timezone and timeformat selects. + localeSelect = createLocaleSelect(); + timeZoneSelect = createTimeZoneSelect(); + formatSelect = createCalendarFormatSelect(); + + initCalendar(); + initLayoutContent(); + addInitialEvents(); + } + + private Date resolveFirstDateOfWeek(Date today, + java.util.Calendar currentCalendar) { + int firstDayOfWeek = currentCalendar.getFirstDayOfWeek(); + currentCalendar.setTime(today); + while (firstDayOfWeek != currentCalendar + .get(java.util.Calendar.DAY_OF_WEEK)) { + currentCalendar.add(java.util.Calendar.DATE, -1); + } + return currentCalendar.getTime(); + } + + private Date resolveLastDateOfWeek(Date today, + java.util.Calendar currentCalendar) { + currentCalendar.setTime(today); + currentCalendar.add(java.util.Calendar.DATE, 1); + int firstDayOfWeek = currentCalendar.getFirstDayOfWeek(); + // Roll to weeks last day using firstdayofweek. Roll until FDofW is + // found and then roll back one day. + while (firstDayOfWeek != currentCalendar + .get(java.util.Calendar.DAY_OF_WEEK)) { + currentCalendar.add(java.util.Calendar.DATE, 1); + } + currentCalendar.add(java.util.Calendar.DATE, -1); + return currentCalendar.getTime(); + } + + private void addInitialEvents() { + Date originalDate = calendar.getTime(); + Date today = getToday(); + + // Add a event that last a whole week + + Date start = resolveFirstDateOfWeek(today, calendar); + Date end = resolveLastDateOfWeek(today, calendar); + CalendarTestEvent event = getNewEvent("Whole week event", start, end); + event.setAllDay(true); + event.setStyleName("color4"); + event.setDescription("Description for the whole week event."); + dataSource.addEvent(event); + + // Add a allday event + calendar.setTime(start); + calendar.add(GregorianCalendar.DATE, 3); + start = calendar.getTime(); + end = start; + event = getNewEvent("All-day event", start, end); + event.setAllDay(true); + event.setDescription("Some description."); + event.setStyleName("color3"); + dataSource.addEvent(event); + + // Add a second allday event + calendar.add(GregorianCalendar.DATE, 1); + start = calendar.getTime(); + end = start; + event = getNewEvent("Second all-day event", start, end); + event.setAllDay(true); + event.setDescription("Some description."); + event.setStyleName("color2"); + dataSource.addEvent(event); + + calendar.add(GregorianCalendar.DATE, -3); + calendar.set(GregorianCalendar.HOUR_OF_DAY, 9); + calendar.set(GregorianCalendar.MINUTE, 30); + start = calendar.getTime(); + calendar.add(GregorianCalendar.HOUR_OF_DAY, 5); + calendar.set(GregorianCalendar.MINUTE, 0); + end = calendar.getTime(); + event = getNewEvent("Appointment", start, end); + event.setWhere("Office"); + event.setStyleName("color1"); + event.setDescription("A longer description, which should display correctly."); + dataSource.addEvent(event); + + calendar.add(GregorianCalendar.DATE, 1); + calendar.set(GregorianCalendar.HOUR_OF_DAY, 11); + calendar.set(GregorianCalendar.MINUTE, 0); + start = calendar.getTime(); + calendar.add(GregorianCalendar.HOUR_OF_DAY, 8); + end = calendar.getTime(); + event = getNewEvent("Training", start, end); + event.setStyleName("color2"); + dataSource.addEvent(event); + + calendar.add(GregorianCalendar.DATE, 4); + calendar.set(GregorianCalendar.HOUR_OF_DAY, 9); + calendar.set(GregorianCalendar.MINUTE, 0); + start = calendar.getTime(); + calendar.add(GregorianCalendar.HOUR_OF_DAY, 9); + end = calendar.getTime(); + event = getNewEvent("Free time", start, end); + dataSource.addEvent(event); + + calendar.setTime(originalDate); + } + + private void initLayoutContent() { + initNavigationButtons(); + initHideWeekEndButton(); + initReadOnlyButton(); + initDisabledButton(); + initAddNewEventButton(); + + HorizontalLayout hl = new HorizontalLayout(); + hl.setWidth("100%"); + hl.setSpacing(true); + hl.addComponent(prevButton); + hl.addComponent(captionLabel); + + CssLayout group = new CssLayout(); + group.addStyleName("v-component-group"); + group.addComponent(dayButton); + group.addComponent(weekButton); + group.addComponent(monthButton); + hl.addComponent(group); + + hl.addComponent(nextButton); + hl.setComponentAlignment(prevButton, Alignment.MIDDLE_LEFT); + hl.setComponentAlignment(captionLabel, Alignment.MIDDLE_CENTER); + hl.setComponentAlignment(group, Alignment.MIDDLE_CENTER); + hl.setComponentAlignment(nextButton, Alignment.MIDDLE_RIGHT); + + // monthButton.setVisible(viewMode == Mode.WEEK); + // weekButton.setVisible(viewMode == Mode.DAY); + + HorizontalLayout controlPanel = new HorizontalLayout(); + controlPanel.setSpacing(true); + controlPanel.setWidth("100%"); + controlPanel.addComponent(localeSelect); + controlPanel.addComponent(timeZoneSelect); + controlPanel.addComponent(formatSelect); + controlPanel.addComponent(hideWeekendsButton); + controlPanel.addComponent(readOnlyButton); + controlPanel.addComponent(disabledButton); + controlPanel.addComponent(addNewEvent); + + controlPanel.setComponentAlignment(timeZoneSelect, + Alignment.MIDDLE_LEFT); + controlPanel.setComponentAlignment(formatSelect, Alignment.MIDDLE_LEFT); + controlPanel.setComponentAlignment(localeSelect, Alignment.MIDDLE_LEFT); + controlPanel.setComponentAlignment(hideWeekendsButton, + Alignment.MIDDLE_LEFT); + controlPanel.setComponentAlignment(readOnlyButton, + Alignment.MIDDLE_LEFT); + controlPanel.setComponentAlignment(disabledButton, + Alignment.MIDDLE_LEFT); + controlPanel.setComponentAlignment(addNewEvent, Alignment.MIDDLE_LEFT); + + addComponent(controlPanel); + addComponent(hl); + addComponent(calendarComponent); + setRowExpandRatio(getRows() - 1, 1.0f); + } + + private void initNavigationButtons() { + monthButton = new Button("Month", new ClickListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + switchToMonthView(); + } + }); + + weekButton = new Button("Week", new ClickListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + // simulate week click + WeekClickHandler handler = (WeekClickHandler) calendarComponent + .getHandler(WeekClick.EVENT_ID); + handler.weekClick(new WeekClick(calendarComponent, calendar + .get(GregorianCalendar.WEEK_OF_YEAR), calendar + .get(GregorianCalendar.YEAR))); + } + }); + + dayButton = new Button("Day", new ClickListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + // simulate day click + BasicDateClickHandler handler = (BasicDateClickHandler) calendarComponent + .getHandler(DateClickEvent.EVENT_ID); + handler.dateClick(new DateClickEvent(calendarComponent, + calendar.getTime())); + } + }); + + nextButton = new Button("Next", new Button.ClickListener() { + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + handleNextButtonClick(); + } + }); + + prevButton = new Button("Prev", new Button.ClickListener() { + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + handlePreviousButtonClick(); + } + }); + } + + private void initHideWeekEndButton() { + hideWeekendsButton = new CheckBox("Hide weekends"); + hideWeekendsButton.setImmediate(true); + hideWeekendsButton + .addValueChangeListener(new Property.ValueChangeListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void valueChange(ValueChangeEvent event) { + setWeekendsHidden(hideWeekendsButton.getValue()); + } + }); + } + + private void setWeekendsHidden(boolean weekendsHidden) { + if (weekendsHidden) { + int firstToShow = (GregorianCalendar.MONDAY - calendar + .getFirstDayOfWeek()) % 7; + calendarComponent.setFirstVisibleDayOfWeek(firstToShow + 1); + calendarComponent.setLastVisibleDayOfWeek(firstToShow + 5); + } else { + calendarComponent.setFirstVisibleDayOfWeek(1); + calendarComponent.setLastVisibleDayOfWeek(7); + } + + } + + private void initReadOnlyButton() { + readOnlyButton = new CheckBox("Read-only mode"); + readOnlyButton.setImmediate(true); + readOnlyButton + .addValueChangeListener(new Property.ValueChangeListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void valueChange(ValueChangeEvent event) { + calendarComponent.setReadOnly(readOnlyButton.getValue()); + } + }); + } + + private void initDisabledButton() { + disabledButton = new CheckBox("Disabled"); + disabledButton.setImmediate(true); + disabledButton + .addValueChangeListener(new Property.ValueChangeListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void valueChange(ValueChangeEvent event) { + calendarComponent.setEnabled(!disabledButton.getValue()); + } + }); + } + + public void initAddNewEventButton() { + addNewEvent = new Button("Add new event"); + addNewEvent.addClickListener(new Button.ClickListener() { + + private static final long serialVersionUID = -8307244759142541067L; + + @Override + public void buttonClick(ClickEvent event) { + Date start = getToday(); + start.setHours(0); + start.setMinutes(0); + start.setSeconds(0); + + Date end = getEndOfDay(calendar, start); + + showEventPopup(createNewEvent(start, end), true); + } + }); + } + + private void initFormFields(Layout formLayout, + Class<? extends CalendarEvent> eventClass) { + + startDateField = createDateField("Start date"); + endDateField = createDateField("End date"); + + final CheckBox allDayField = createCheckBox("All-day"); + allDayField.addValueChangeListener(new Property.ValueChangeListener() { + + private static final long serialVersionUID = -7104996493482558021L; + + @Override + public void valueChange(ValueChangeEvent event) { + Object value = event.getProperty().getValue(); + if (value instanceof Boolean && Boolean.TRUE.equals(value)) { + setFormDateResolution(Resolution.DAY); + + } else { + setFormDateResolution(Resolution.MINUTE); + } + } + + }); + + captionField = createTextField("Caption"); + captionField.setInputPrompt("Event name"); + captionField.setRequired(true); + final TextField whereField = createTextField("Where"); + whereField.setInputPrompt("Address or location"); + final TextArea descriptionField = createTextArea("Description"); + descriptionField.setInputPrompt("Describe the event"); + descriptionField.setRows(3); + // descriptionField.setRequired(true); + + final ComboBox styleNameField = createStyleNameComboBox(); + styleNameField.setInputPrompt("Choose calendar"); + styleNameField.setTextInputAllowed(false); + + formLayout.addComponent(startDateField); + // startDateField.setRequired(true); + formLayout.addComponent(endDateField); + formLayout.addComponent(allDayField); + formLayout.addComponent(captionField); + // captionField.setComponentError(new UserError("Testing error")); + if (eventClass == CalendarTestEvent.class) { + formLayout.addComponent(whereField); + } + formLayout.addComponent(descriptionField); + formLayout.addComponent(styleNameField); + + scheduleEventFieldGroup.bind(startDateField, "start"); + scheduleEventFieldGroup.bind(endDateField, "end"); + scheduleEventFieldGroup.bind(captionField, "caption"); + scheduleEventFieldGroup.bind(descriptionField, "description"); + if (eventClass == CalendarTestEvent.class) { + scheduleEventFieldGroup.bind(whereField, "where"); + } + scheduleEventFieldGroup.bind(styleNameField, "styleName"); + scheduleEventFieldGroup.bind(allDayField, "allDay"); + } + + private CheckBox createCheckBox(String caption) { + CheckBox cb = new CheckBox(caption); + cb.setImmediate(true); + return cb; + } + + private TextField createTextField(String caption) { + TextField f = new TextField(caption); + f.setNullRepresentation(""); + return f; + } + + private TextArea createTextArea(String caption) { + TextArea f = new TextArea(caption); + f.setNullRepresentation(""); + return f; + } + + private DateField createDateField(String caption) { + DateField f = new DateField(caption); + if (useSecondResolution) { + f.setResolution(Resolution.SECOND); + } else { + f.setResolution(Resolution.MINUTE); + } + return f; + } + + private ComboBox createStyleNameComboBox() { + ComboBox s = new ComboBox("Calendar"); + s.addContainerProperty("c", String.class, ""); + s.setItemCaptionPropertyId("c"); + Item i = s.addItem("color1"); + i.getItemProperty("c").setValue("Work"); + i = s.addItem("color2"); + i.getItemProperty("c").setValue("Personal"); + i = s.addItem("color3"); + i.getItemProperty("c").setValue("Family"); + i = s.addItem("color4"); + i.getItemProperty("c").setValue("Hobbies"); + return s; + } + + private void initCalendar() { + dataSource = new BasicEventProvider(); + + calendarComponent = new Calendar(dataSource); + calendarComponent.setLocale(getLocale()); + calendarComponent.setImmediate(true); + + if (calendarWidth != null || calendarHeight != null) { + if (calendarHeight != null) { + calendarComponent.setHeight(calendarHeight); + } + if (calendarWidth != null) { + calendarComponent.setWidth(calendarWidth); + } + } else { + calendarComponent.setSizeFull(); + } + + if (firstHour != null && lastHour != null) { + calendarComponent.setFirstVisibleHourOfDay(firstHour); + calendarComponent.setLastVisibleHourOfDay(lastHour); + } + + if (firstDay != null && lastDay != null) { + calendarComponent.setFirstVisibleDayOfWeek(firstDay); + calendarComponent.setLastVisibleDayOfWeek(lastDay); + } + + Date today = getToday(); + calendar = new GregorianCalendar(getLocale()); + calendar.setTime(today); + calendarComponent.getInternalCalendar().setTime(today); + + int rollAmount = calendar.get(GregorianCalendar.DAY_OF_MONTH) - 1; + calendar.add(GregorianCalendar.DAY_OF_MONTH, -rollAmount); + currentMonthsFirstDate = calendar.getTime(); + + updateCaptionLabel(); + + if (!showWeeklyView) { + // resetTime(false); + // currentMonthsFirstDate = calendar.getTime(); + // calendarComponent.setStartDate(currentMonthsFirstDate); + // calendar.add(GregorianCalendar.MONTH, 1); + // calendar.add(GregorianCalendar.DATE, -1); + // calendarComponent.setEndDate(calendar.getTime()); + } + + addCalendarEventListeners(); + } + + private Date getToday() { + if (testBench) { + GregorianCalendar testDate = new GregorianCalendar(); + testDate.set(GregorianCalendar.YEAR, 2000); + testDate.set(GregorianCalendar.MONTH, 0); + testDate.set(GregorianCalendar.DATE, 10); + testDate.set(GregorianCalendar.HOUR_OF_DAY, 0); + testDate.set(GregorianCalendar.MINUTE, 0); + testDate.set(GregorianCalendar.SECOND, 0); + testDate.set(GregorianCalendar.MILLISECOND, 0); + return testDate.getTime(); + } + return new Date(); + } + + @SuppressWarnings("serial") + private void addCalendarEventListeners() { + // Register week clicks by changing the schedules start and end dates. + calendarComponent.setHandler(new BasicWeekClickHandler() { + + @Override + public void weekClick(WeekClick event) { + // let BasicWeekClickHandler handle calendar dates, and update + // only the other parts of UI here + super.weekClick(event); + updateCaptionLabel(); + switchToWeekView(); + } + }); + + calendarComponent.setHandler(new EventClickHandler() { + + @Override + public void eventClick(EventClick event) { + showEventPopup(event.getCalendarEvent(), false); + } + }); + + calendarComponent.setHandler(new BasicDateClickHandler() { + + @Override + public void dateClick(DateClickEvent event) { + // let BasicDateClickHandler handle calendar dates, and update + // only the other parts of UI here + super.dateClick(event); + switchToDayView(); + } + }); + + calendarComponent.setHandler(new RangeSelectHandler() { + + @Override + public void rangeSelect(RangeSelectEvent event) { + handleRangeSelect(event); + } + }); + } + + private ComboBox createTimeZoneSelect() { + ComboBox s = new ComboBox("Timezone"); + s.addContainerProperty("caption", String.class, ""); + s.setItemCaptionPropertyId("caption"); + s.setFilteringMode(FilteringMode.CONTAINS); + + Item i = s.addItem(DEFAULT_ITEMID); + i.getItemProperty("caption").setValue( + "Default (" + TimeZone.getDefault().getID() + ")"); + for (String id : TimeZone.getAvailableIDs()) { + if (!s.containsId(id)) { + i = s.addItem(id); + i.getItemProperty("caption").setValue(id); + } + } + + if (testBench) { + s.select("America/New_York"); + } else { + s.select(DEFAULT_ITEMID); + } + s.setImmediate(true); + s.addValueChangeListener(new ValueChangeListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void valueChange(ValueChangeEvent event) { + + updateCalendarTimeZone(event.getProperty().getValue()); + } + }); + + return s; + } + + private ComboBox createCalendarFormatSelect() { + ComboBox s = new ComboBox("Calendar format"); + s.addContainerProperty("caption", String.class, ""); + s.setItemCaptionPropertyId("caption"); + + Item i = s.addItem(DEFAULT_ITEMID); + i.getItemProperty("caption").setValue("Default by locale"); + i = s.addItem(TimeFormat.Format12H); + i.getItemProperty("caption").setValue("12H"); + i = s.addItem(TimeFormat.Format24H); + i.getItemProperty("caption").setValue("24H"); + + s.select(DEFAULT_ITEMID); + s.setImmediate(true); + s.addValueChangeListener(new ValueChangeListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void valueChange(ValueChangeEvent event) { + updateCalendarFormat(event.getProperty().getValue()); + } + }); + + return s; + } + + private ComboBox createLocaleSelect() { + ComboBox s = new ComboBox("Locale"); + s.addContainerProperty("caption", String.class, ""); + s.setItemCaptionPropertyId("caption"); + s.setFilteringMode(FilteringMode.CONTAINS); + + for (Locale l : Locale.getAvailableLocales()) { + if (!s.containsId(l)) { + Item i = s.addItem(l); + i.getItemProperty("caption").setValue(getLocaleItemCaption(l)); + } + } + + s.select(getLocale()); + s.setImmediate(true); + s.addValueChangeListener(new ValueChangeListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void valueChange(ValueChangeEvent event) { + updateCalendarLocale((Locale) event.getProperty().getValue()); + } + }); + + return s; + } + + private void updateCalendarTimeZone(Object timezoneId) { + TimeZone tz = null; + if (!DEFAULT_ITEMID.equals(timezoneId)) { + tz = TimeZone.getTimeZone((String) timezoneId); + } + + // remember the week that was showing, so we can re-set it later + Date startDate = calendarComponent.getStartDate(); + calendar.setTime(startDate); + int weekNumber = calendar.get(java.util.Calendar.WEEK_OF_YEAR); + calendarComponent.setTimeZone(tz); + calendar.setTimeZone(calendarComponent.getTimeZone()); + + if (viewMode == Mode.WEEK) { + calendar.set(java.util.Calendar.WEEK_OF_YEAR, weekNumber); + calendar.set(java.util.Calendar.DAY_OF_WEEK, + calendar.getFirstDayOfWeek()); + + calendarComponent.setStartDate(calendar.getTime()); + calendar.add(java.util.Calendar.DATE, 6); + calendarComponent.setEndDate(calendar.getTime()); + } + } + + private void updateCalendarFormat(Object format) { + TimeFormat calFormat = null; + if (format instanceof TimeFormat) { + calFormat = (TimeFormat) format; + } + + calendarComponent.setTimeFormat(calFormat); + } + + private String getLocaleItemCaption(Locale l) { + String country = l.getDisplayCountry(getLocale()); + String language = l.getDisplayLanguage(getLocale()); + StringBuilder caption = new StringBuilder(country); + if (caption.length() != 0) { + caption.append(", "); + } + caption.append(language); + return caption.toString(); + } + + private void updateCalendarLocale(Locale l) { + int oldFirstDayOfWeek = calendar.getFirstDayOfWeek(); + setLocale(l); + calendarComponent.setLocale(l); + calendar = new GregorianCalendar(l); + int newFirstDayOfWeek = calendar.getFirstDayOfWeek(); + + // we are showing 1 week, and the first day of the week has changed + // update start and end dates so that the same week is showing + if (viewMode == Mode.WEEK && oldFirstDayOfWeek != newFirstDayOfWeek) { + calendar.setTime(calendarComponent.getStartDate()); + calendar.add(java.util.Calendar.DAY_OF_WEEK, 2); + // starting at the beginning of the week + calendar.set(GregorianCalendar.DAY_OF_WEEK, newFirstDayOfWeek); + Date start = calendar.getTime(); + + // ending at the end of the week + calendar.add(GregorianCalendar.DATE, 6); + Date end = calendar.getTime(); + + calendarComponent.setStartDate(start); + calendarComponent.setEndDate(end); + + // Week days depend on locale so this must be refreshed + setWeekendsHidden(hideWeekendsButton.getValue()); + } + + } + + private void handleNextButtonClick() { + switch (viewMode) { + case MONTH: + nextMonth(); + break; + case WEEK: + nextWeek(); + break; + case DAY: + nextDay(); + break; + } + } + + private void handlePreviousButtonClick() { + switch (viewMode) { + case MONTH: + previousMonth(); + break; + case WEEK: + previousWeek(); + break; + case DAY: + previousDay(); + break; + } + } + + private void handleRangeSelect(RangeSelectEvent event) { + Date start = event.getStart(); + Date end = event.getEnd(); + + /* + * If a range of dates is selected in monthly mode, we want it to end at + * the end of the last day. + */ + if (event.isMonthlyMode()) { + end = getEndOfDay(calendar, end); + } + + showEventPopup(createNewEvent(start, end), true); + } + + private void showEventPopup(CalendarEvent event, boolean newEvent) { + if (event == null) { + return; + } + + updateCalendarEventPopup(newEvent); + updateCalendarEventForm(event); + // TODO this only works the first time + captionField.focus(); + + if (!getUI().getWindows().contains(scheduleEventPopup)) { + getUI().addWindow(scheduleEventPopup); + } + + } + + /* Initializes a modal window to edit schedule event. */ + private void createCalendarEventPopup() { + VerticalLayout layout = new VerticalLayout(); + // layout.setMargin(true); + layout.setSpacing(true); + + scheduleEventPopup = new Window(null, layout); + scheduleEventPopup.setWidth("300px"); + scheduleEventPopup.setModal(true); + scheduleEventPopup.center(); + + scheduleEventFieldLayout.addStyleName("light"); + scheduleEventFieldLayout.setMargin(false); + layout.addComponent(scheduleEventFieldLayout); + + applyEventButton = new Button("Apply", new ClickListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + try { + commitCalendarEvent(); + } catch (CommitException e) { + e.printStackTrace(); + } + } + }); + applyEventButton.addStyleName("primary"); + Button cancel = new Button("Cancel", new ClickListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + discardCalendarEvent(); + } + }); + deleteEventButton = new Button("Delete", new ClickListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void buttonClick(ClickEvent event) { + deleteCalendarEvent(); + } + }); + deleteEventButton.addStyleName("borderless"); + scheduleEventPopup.addCloseListener(new Window.CloseListener() { + + private static final long serialVersionUID = 1L; + + @Override + public void windowClose(Window.CloseEvent e) { + discardCalendarEvent(); + } + }); + + HorizontalLayout buttons = new HorizontalLayout(); + buttons.addStyleName("v-window-bottom-toolbar"); + buttons.setWidth("100%"); + buttons.setSpacing(true); + buttons.addComponent(deleteEventButton); + buttons.addComponent(applyEventButton); + buttons.setExpandRatio(applyEventButton, 1); + buttons.setComponentAlignment(applyEventButton, Alignment.TOP_RIGHT); + buttons.addComponent(cancel); + layout.addComponent(buttons); + + } + + private void updateCalendarEventPopup(boolean newEvent) { + if (scheduleEventPopup == null) { + createCalendarEventPopup(); + } + + if (newEvent) { + scheduleEventPopup.setCaption("New event"); + } else { + scheduleEventPopup.setCaption("Edit event"); + } + + deleteEventButton.setVisible(!newEvent); + deleteEventButton.setEnabled(!calendarComponent.isReadOnly()); + applyEventButton.setEnabled(!calendarComponent.isReadOnly()); + } + + private void updateCalendarEventForm(CalendarEvent event) { + BeanItem<CalendarEvent> item = new BeanItem<CalendarEvent>(event); + scheduleEventFieldLayout.removeAllComponents(); + scheduleEventFieldGroup = new FieldGroup(); + initFormFields(scheduleEventFieldLayout, event.getClass()); + scheduleEventFieldGroup.setBuffered(true); + scheduleEventFieldGroup.setItemDataSource(item); + } + + private void setFormDateResolution(Resolution resolution) { + if (startDateField != null && endDateField != null) { + startDateField.setResolution(resolution); + endDateField.setResolution(resolution); + } + } + + private CalendarEvent createNewEvent(Date startDate, Date endDate) { + BasicEvent event = new BasicEvent(); + event.setCaption(""); + event.setStart(startDate); + event.setEnd(endDate); + event.setStyleName("color1"); + return event; + } + + /* Removes the event from the data source and fires change event. */ + private void deleteCalendarEvent() { + BasicEvent event = getFormCalendarEvent(); + if (dataSource.containsEvent(event)) { + dataSource.removeEvent(event); + } + getUI().removeWindow(scheduleEventPopup); + } + + /* Adds/updates the event in the data source and fires change event. */ + private void commitCalendarEvent() throws CommitException { + scheduleEventFieldGroup.commit(); + BasicEvent event = getFormCalendarEvent(); + if (event.getEnd() == null) { + event.setEnd(event.getStart()); + } + if (!dataSource.containsEvent(event)) { + dataSource.addEvent(event); + } + + getUI().removeWindow(scheduleEventPopup); + } + + private void discardCalendarEvent() { + scheduleEventFieldGroup.discard(); + getUI().removeWindow(scheduleEventPopup); + } + + @SuppressWarnings("unchecked") + private BasicEvent getFormCalendarEvent() { + BeanItem<CalendarEvent> item = (BeanItem<CalendarEvent>) scheduleEventFieldGroup + .getItemDataSource(); + CalendarEvent event = item.getBean(); + return (BasicEvent) event; + } + + private void nextMonth() { + rollMonth(1); + } + + private void previousMonth() { + rollMonth(-1); + } + + private void nextWeek() { + rollWeek(1); + } + + private void previousWeek() { + rollWeek(-1); + } + + private void nextDay() { + rollDate(1); + } + + private void previousDay() { + rollDate(-1); + } + + private void rollMonth(int direction) { + calendar.setTime(currentMonthsFirstDate); + calendar.add(GregorianCalendar.MONTH, direction); + resetTime(false); + currentMonthsFirstDate = calendar.getTime(); + calendarComponent.setStartDate(currentMonthsFirstDate); + + updateCaptionLabel(); + + calendar.add(GregorianCalendar.MONTH, 1); + calendar.add(GregorianCalendar.DATE, -1); + resetCalendarTime(true); + } + + private void rollWeek(int direction) { + calendar.add(GregorianCalendar.WEEK_OF_YEAR, direction); + calendar.set(GregorianCalendar.DAY_OF_WEEK, + calendar.getFirstDayOfWeek()); + resetCalendarTime(false); + resetTime(true); + calendar.add(GregorianCalendar.DATE, 6); + calendarComponent.setEndDate(calendar.getTime()); + } + + private void rollDate(int direction) { + calendar.add(GregorianCalendar.DATE, direction); + resetCalendarTime(false); + resetCalendarTime(true); + } + + private void updateCaptionLabel() { + DateFormatSymbols s = new DateFormatSymbols(getLocale()); + String month = s.getShortMonths()[calendar.get(GregorianCalendar.MONTH)]; + captionLabel.setValue(month + " " + + calendar.get(GregorianCalendar.YEAR)); + } + + private CalendarTestEvent getNewEvent(String caption, Date start, Date end) { + CalendarTestEvent event = new CalendarTestEvent(); + event.setCaption(caption); + event.setStart(start); + event.setEnd(end); + + return event; + } + + /* + * Switch the view to week view. + */ + public void switchToWeekView() { + viewMode = Mode.WEEK; + // weekButton.setVisible(false); + // monthButton.setVisible(true); + } + + /* + * Switch the Calendar component's start and end date range to the target + * month only. (sample range: 01.01.2010 00:00.000 - 31.01.2010 23:59.999) + */ + public void switchToMonthView() { + viewMode = Mode.MONTH; + // monthButton.setVisible(false); + // weekButton.setVisible(false); + + int rollAmount = calendar.get(GregorianCalendar.DAY_OF_MONTH) - 1; + calendar.add(GregorianCalendar.DAY_OF_MONTH, -rollAmount); + + calendarComponent.setStartDate(calendar.getTime()); + + updateCaptionLabel(); + + calendar.add(GregorianCalendar.MONTH, 1); + calendar.add(GregorianCalendar.DATE, -1); + + calendarComponent.setEndDate(calendar.getTime()); + + calendar.setTime(getToday()); + // resetCalendarTime(true); + } + + /* + * Switch to day view (week view with a single day visible). + */ + public void switchToDayView() { + viewMode = Mode.DAY; + // monthButton.setVisible(true); + // weekButton.setVisible(true); + } + + private void resetCalendarTime(boolean resetEndTime) { + resetTime(resetEndTime); + if (resetEndTime) { + calendarComponent.setEndDate(calendar.getTime()); + } else { + calendarComponent.setStartDate(calendar.getTime()); + updateCaptionLabel(); + } + } + + /* + * Resets the calendar time (hour, minute second and millisecond) either to + * zero or maximum value. + */ + private void resetTime(boolean max) { + if (max) { + calendar.set(GregorianCalendar.HOUR_OF_DAY, + calendar.getMaximum(GregorianCalendar.HOUR_OF_DAY)); + calendar.set(GregorianCalendar.MINUTE, + calendar.getMaximum(GregorianCalendar.MINUTE)); + calendar.set(GregorianCalendar.SECOND, + calendar.getMaximum(GregorianCalendar.SECOND)); + calendar.set(GregorianCalendar.MILLISECOND, + calendar.getMaximum(GregorianCalendar.MILLISECOND)); + } else { + calendar.set(GregorianCalendar.HOUR_OF_DAY, 0); + calendar.set(GregorianCalendar.MINUTE, 0); + calendar.set(GregorianCalendar.SECOND, 0); + calendar.set(GregorianCalendar.MILLISECOND, 0); + } + } + + private static Date getEndOfDay(java.util.Calendar calendar, Date date) { + java.util.Calendar calendarClone = (java.util.Calendar) calendar + .clone(); + + calendarClone.setTime(date); + calendarClone.set(java.util.Calendar.MILLISECOND, + calendarClone.getActualMaximum(java.util.Calendar.MILLISECOND)); + calendarClone.set(java.util.Calendar.SECOND, + calendarClone.getActualMaximum(java.util.Calendar.SECOND)); + calendarClone.set(java.util.Calendar.MINUTE, + calendarClone.getActualMaximum(java.util.Calendar.MINUTE)); + calendarClone.set(java.util.Calendar.HOUR, + calendarClone.getActualMaximum(java.util.Calendar.HOUR)); + calendarClone.set(java.util.Calendar.HOUR_OF_DAY, + calendarClone.getActualMaximum(java.util.Calendar.HOUR_OF_DAY)); + + return calendarClone.getTime(); + } + + private static Date getStartOfDay(java.util.Calendar calendar, Date date) { + java.util.Calendar calendarClone = (java.util.Calendar) calendar + .clone(); + + calendarClone.setTime(date); + calendarClone.set(java.util.Calendar.MILLISECOND, 0); + calendarClone.set(java.util.Calendar.SECOND, 0); + calendarClone.set(java.util.Calendar.MINUTE, 0); + calendarClone.set(java.util.Calendar.HOUR, 0); + calendarClone.set(java.util.Calendar.HOUR_OF_DAY, 0); + + return calendarClone.getTime(); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } +}
\ No newline at end of file diff --git a/uitest/src/com/vaadin/tests/themes/valo/CheckBoxes.java b/uitest/src/com/vaadin/tests/themes/valo/CheckBoxes.java new file mode 100644 index 0000000000..a2daeff2f8 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/CheckBoxes.java @@ -0,0 +1,194 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.data.Item; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.OptionGroup; +import com.vaadin.ui.VerticalLayout; + +public class CheckBoxes extends VerticalLayout implements View { + public CheckBoxes() { + setMargin(true); + + Label h1 = new Label("Check Boxes"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + CheckBox check = new CheckBox("Checked", true); + row.addComponent(check); + + check = new CheckBox( + "Checked, explicit width, so that the caption should wrap", + true); + row.addComponent(check); + check.setWidth("150px"); + + check = new CheckBox("Not checked"); + row.addComponent(check); + + check = new CheckBox(null, true); + check.setDescription("No caption"); + row.addComponent(check); + + check = new CheckBox("Custom color", true); + check.addStyleName("color1"); + row.addComponent(check); + + check = new CheckBox("Custom color", true); + check.addStyleName("color2"); + check.setIcon(TestIcon.get()); + row.addComponent(check); + + check = new CheckBox("With Icon", true); + check.setIcon(TestIcon.get()); + row.addComponent(check); + + check = new CheckBox(); + check.setIcon(TestIcon.get(true)); + row.addComponent(check); + + check = new CheckBox("Small", true); + check.addStyleName("small"); + row.addComponent(check); + + check = new CheckBox("Large", true); + check.addStyleName("large"); + row.addComponent(check); + + h1 = new Label("Option Groups"); + h1.addStyleName("h1"); + addComponent(h1); + + row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + OptionGroup options = new OptionGroup("Choose one, explicit width"); + options.setWidth("200px"); + options.addItem("Option One"); + Item two = options + .addItem("Option Two, with a longer caption that should wrap when the components width is explicitly set."); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon(two, TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get(true)); + row.addComponent(options); + + options = new OptionGroup("Choose many, explicit width"); + options.setMultiSelect(true); + options.setWidth("200px"); + options.addItem("Option One"); + two = options + .addItem("Option Two, with a longer caption that should wrap when the components width is explicitly set."); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon(two, TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get(true)); + row.addComponent(options); + + options = new OptionGroup("Choose one, small"); + options.addStyleName("small"); + options.setMultiSelect(false); + options.addItem("Option One"); + options.addItem("Option Two"); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon("Option Two", TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get(true)); + row.addComponent(options); + + options = new OptionGroup("Choose many, small"); + options.addStyleName("small"); + options.setMultiSelect(true); + options.addItem("Option One"); + options.addItem("Option Two"); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon("Option Two", TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get(true)); + row.addComponent(options); + + options = new OptionGroup("Choose one, large"); + options.addStyleName("large"); + options.setMultiSelect(false); + options.addItem("Option One"); + options.addItem("Option Two"); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon("Option Two", TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get(true)); + row.addComponent(options); + + options = new OptionGroup("Choose many, large"); + options.addStyleName("large"); + options.setMultiSelect(true); + options.addItem("Option One"); + options.addItem("Option Two"); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon("Option Two", TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get(true)); + row.addComponent(options); + + options = new OptionGroup("Horizontal items"); + options.addStyleName("horizontal"); + options.addItem("Option One"); + two = options.addItem("Option Two, with a longer caption"); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon(two, TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get()); + row.addComponent(options); + + options = new OptionGroup("Horizontal items, explicit width"); + options.setMultiSelect(true); + options.setWidth("500px"); + options.addStyleName("horizontal"); + options.addItem("Option One"); + two = options.addItem("Option Two, with a longer caption"); + options.addItem("Option Three"); + options.select("Option One"); + options.setItemIcon("Option One", TestIcon.get()); + options.setItemIcon(two, TestIcon.get()); + options.setItemIcon("Option Three", TestIcon.get()); + row.addComponent(options); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/ColorPickers.java b/uitest/src/com/vaadin/tests/themes/valo/ColorPickers.java new file mode 100644 index 0000000000..b841b0b116 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/ColorPickers.java @@ -0,0 +1,58 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.colorpicker.Color; +import com.vaadin.ui.AbstractColorPicker.PopupStyle; +import com.vaadin.ui.ColorPicker; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.VerticalLayout; + +public class ColorPickers extends VerticalLayout implements View { + public ColorPickers() { + setMargin(true); + + Label h1 = new Label("Color Pickers"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + ColorPicker cp = new ColorPicker(); + cp.setDefaultCaptionEnabled(true); + cp.setIcon(TestIcon.get()); + cp.setColor(new Color(138, 73, 115)); + row.addComponent(cp); + + cp = new ColorPicker(); + cp.setPopupStyle(PopupStyle.POPUP_SIMPLE); + cp.setTextfieldVisibility(true); + row.addComponent(cp); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/ComboBoxes.java b/uitest/src/com/vaadin/tests/themes/valo/ComboBoxes.java new file mode 100644 index 0000000000..cafdfe37e0 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/ComboBoxes.java @@ -0,0 +1,176 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.data.Container; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.ThemeResource; +import com.vaadin.server.UserError; +import com.vaadin.ui.Button; +import com.vaadin.ui.ComboBox; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.VerticalLayout; + +public class ComboBoxes extends VerticalLayout implements View { + public ComboBoxes() { + setMargin(true); + + Label h1 = new Label("Combo Boxes"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + Container generatedContainer = ValoThemeTest.generateContainer(200, + false); + ComboBox combo = new ComboBox("Normal"); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setNullSelectionAllowed(false); + combo.select(generatedContainer.getItemIds().iterator().next()); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.setItemIcon(combo.getItemIds().iterator().next(), + new ThemeResource("../runo/icons/16/document.png")); + row.addComponent(combo); + + CssLayout group = new CssLayout(); + group.setCaption("Grouped with a Button"); + group.addStyleName("v-component-group"); + row.addComponent(group); + + combo = new ComboBox(); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setNullSelectionAllowed(false); + combo.select(generatedContainer.getItemIds().iterator().next()); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.setWidth("240px"); + group.addComponent(combo); + Button today = new Button("Do It"); + group.addComponent(today); + + combo = new ComboBox("Explicit size"); + combo.setInputPrompt("You can type here"); + combo.addItem("Option One"); + combo.addItem("Option Two"); + combo.addItem("Option Three"); + combo.setWidth("260px"); + combo.setHeight("60px"); + row.addComponent(combo); + + combo = new ComboBox("No text input allowed"); + combo.setInputPrompt("You can click here"); + combo.addItem("Option One"); + combo.addItem("Option Two"); + combo.addItem("Option Three"); + combo.setTextInputAllowed(false); + combo.setNullSelectionAllowed(false); + combo.select("Option One"); + row.addComponent(combo); + + combo = new ComboBox("Error"); + combo.setInputPrompt("You can type here"); + combo.addItem("Option One"); + combo.addItem("Option Two"); + combo.addItem("Option Three"); + combo.setNullSelectionAllowed(false); + combo.select("Option One"); + combo.setComponentError(new UserError("Fix it, now!")); + row.addComponent(combo); + + combo = new ComboBox("Error, borderless"); + combo.setInputPrompt("You can type here"); + combo.addItem("Option One"); + combo.addItem("Option Two"); + combo.addItem("Option Three"); + combo.setNullSelectionAllowed(false); + combo.select("Option One"); + combo.setComponentError(new UserError("Fix it, now!")); + combo.addStyleName("borderless"); + row.addComponent(combo); + + combo = new ComboBox("Disabled"); + combo.setInputPrompt("You can't type here"); + combo.addItem("Option One"); + combo.addItem("Option Two"); + combo.addItem("Option Three"); + combo.setEnabled(false); + row.addComponent(combo); + + combo = new ComboBox("Custom color"); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.addStyleName("color1"); + row.addComponent(combo); + + combo = new ComboBox("Custom color"); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.addStyleName("color2"); + row.addComponent(combo); + + combo = new ComboBox("Custom color"); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.addStyleName("color3"); + row.addComponent(combo); + + combo = new ComboBox("Small"); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.addStyleName("small"); + row.addComponent(combo); + + combo = new ComboBox("Large"); + combo.setInputPrompt("You can type here"); + combo.setContainerDataSource(generatedContainer); + combo.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + combo.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + combo.addStyleName("large"); + row.addComponent(combo); + + combo = new ComboBox("Borderless"); + combo.setInputPrompt("You can type here"); + combo.addItem("Option One"); + combo.addItem("Option Two"); + combo.addItem("Option Three"); + combo.addStyleName("borderless"); + row.addComponent(combo); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/CommonParts.java b/uitest/src/com/vaadin/tests/themes/valo/CommonParts.java new file mode 100644 index 0000000000..75d51ed2a6 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/CommonParts.java @@ -0,0 +1,714 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.event.ShortcutAction.KeyCode; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.AbstractErrorMessage; +import com.vaadin.server.ErrorMessage.ErrorLevel; +import com.vaadin.server.FontAwesome; +import com.vaadin.server.Page; +import com.vaadin.server.UserError; +import com.vaadin.shared.Position; +import com.vaadin.shared.ui.label.ContentMode; +import com.vaadin.ui.Alignment; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.Component; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.GridLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.MenuBar; +import com.vaadin.ui.MenuBar.Command; +import com.vaadin.ui.MenuBar.MenuItem; +import com.vaadin.ui.Notification; +import com.vaadin.ui.Panel; +import com.vaadin.ui.TabSheet; +import com.vaadin.ui.TabSheet.SelectedTabChangeEvent; +import com.vaadin.ui.TabSheet.SelectedTabChangeListener; +import com.vaadin.ui.TextArea; +import com.vaadin.ui.TextField; +import com.vaadin.ui.VerticalLayout; +import com.vaadin.ui.Window; +import com.vaadin.ui.Window.CloseEvent; +import com.vaadin.ui.Window.CloseListener; + +public class CommonParts extends VerticalLayout implements View { + public CommonParts() { + setMargin(true); + + Label h1 = new Label("Common UI Elements"); + h1.addStyleName("h1"); + addComponent(h1); + + GridLayout row = new GridLayout(2, 3); + row.setWidth("100%"); + row.setSpacing(true); + addComponent(row); + + row.addComponent(loadingIndicators()); + row.addComponent(notifications(), 1, 0, 1, 2); + row.addComponent(windows()); + row.addComponent(tooltips()); + + } + + Panel loadingIndicators() { + Panel p = new Panel("Loading Indicator"); + VerticalLayout content = new VerticalLayout(); + p.setContent(content); + content.setSpacing(true); + content.setMargin(true); + content.addComponent(new Label( + "You can test the loading indicator by pressing the buttons.")); + + CssLayout group = new CssLayout(); + group.setCaption("Show the loading indicator for…"); + group.addStyleName("v-component-group"); + content.addComponent(group); + Button loading = new Button("0.8"); + loading.addClickListener(new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + try { + Thread.sleep(800); + } catch (InterruptedException e) { + } + } + }); + group.addComponent(loading); + + Button delay = new Button("3"); + delay.addClickListener(new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + try { + Thread.sleep(3000); + } catch (InterruptedException e) { + } + } + }); + group.addComponent(delay); + + Button wait = new Button("15"); + wait.addClickListener(new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + try { + Thread.sleep(15000); + } catch (InterruptedException e) { + } + } + }); + wait.addStyleName("last"); + group.addComponent(wait); + Label label = new Label(" seconds", ContentMode.HTML); + label.setSizeUndefined(); + group.addComponent(label); + + Label spinnerDesc = new Label( + "The theme also provides a mixin that you can use to include a spinner anywhere in your application. Below is a Label with a custom style name, for which the spinner mixin is added."); + spinnerDesc.addStyleName("small"); + spinnerDesc.setCaption("Spinner"); + content.addComponent(spinnerDesc); + + Label spinner = new Label(); + spinner.addStyleName("spinner"); + content.addComponent(spinner); + + return p; + } + + Panel notifications() { + Panel p = new Panel("Notifications"); + VerticalLayout content = new VerticalLayout() { + Notification notification = new Notification(""); + TextField title = new TextField("Title"); + TextArea description = new TextArea("Description"); + MenuBar style = new MenuBar(); + MenuBar type = new MenuBar(); + String typeString = ""; + String styleString = ""; + TextField delay = new TextField(); + { + setSpacing(true); + setMargin(true); + + title.setInputPrompt("Title for the notification"); + title.addValueChangeListener(new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + if (title.getValue() == null + || title.getValue().length() == 0) { + notification.setCaption(null); + } else { + notification.setCaption(title.getValue()); + } + } + }); + title.setValue("Notification Title"); + title.setWidth("100%"); + addComponent(title); + + description.setInputPrompt("Description for the notification"); + description.addStyleName("small"); + description.addValueChangeListener(new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + if (description.getValue() == null + || description.getValue().length() == 0) { + notification.setDescription(null); + } else { + notification.setDescription(description.getValue()); + } + } + }); + description + .setValue("A more informative message about what has happened. Nihil hic munitissimus habendi senatus locus, nihil horum? Inmensae subtilitatis, obscuris et malesuada fames. Hi omnes lingua, institutis, legibus inter se differunt."); + description.setWidth("100%"); + addComponent(description); + + Command typeCommand = new Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + if (selectedItem.getText().equals("Humanized")) { + typeString = ""; + notification.setStyleName(styleString.trim()); + } else { + typeString = selectedItem.getText().toLowerCase(); + notification + .setStyleName((typeString + " " + styleString + .trim()).trim()); + } + for (MenuItem item : type.getItems()) { + item.setChecked(false); + } + selectedItem.setChecked(true); + } + }; + + type.setCaption("Type"); + MenuItem humanized = type.addItem("Humanized", typeCommand); + humanized.setCheckable(true); + humanized.setChecked(true); + type.addItem("Tray", typeCommand).setCheckable(true); + type.addItem("Warning", typeCommand).setCheckable(true); + type.addItem("Error", typeCommand).setCheckable(true); + type.addItem("System", typeCommand).setCheckable(true); + addComponent(type); + type.addStyleName("small"); + + Command styleCommand = new Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + styleString = ""; + for (MenuItem item : style.getItems()) { + if (item.isChecked()) { + styleString += " " + + item.getText().toLowerCase(); + } + } + if (styleString.trim().length() > 0) { + notification + .setStyleName((typeString + " " + styleString + .trim()).trim()); + } else if (typeString.length() > 0) { + notification.setStyleName(typeString.trim()); + } else { + notification.setStyleName(null); + } + } + }; + + style.setCaption("Additional style"); + style.addItem("Success", styleCommand).setCheckable(true); + style.addItem("Failure", styleCommand).setCheckable(true); + style.addItem("Bar", styleCommand).setCheckable(true); + style.addItem("Small", styleCommand).setCheckable(true); + style.addItem("Closable", styleCommand).setCheckable(true); + addComponent(style); + style.addStyleName("small"); + + CssLayout group = new CssLayout(); + group.setCaption("Fade delay"); + group.addStyleName("v-component-group"); + addComponent(group); + + delay.setInputPrompt("Infinite"); + delay.addStyleName("align-right"); + delay.addStyleName("small"); + delay.setWidth("7em"); + delay.addValueChangeListener(new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + try { + notification.setDelayMsec(Integer.parseInt(delay + .getValue())); + } catch (Exception e) { + notification.setDelayMsec(-1); + delay.setValue(""); + } + + } + }); + delay.setValue("1000"); + group.addComponent(delay); + + Button clear = new Button(null, new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + delay.setValue(""); + } + }); + clear.setIcon(FontAwesome.TIMES_CIRCLE); + clear.addStyleName("last"); + clear.addStyleName("small"); + clear.addStyleName("icon-only"); + group.addComponent(clear); + group.addComponent(new Label(" msec", ContentMode.HTML)); + + GridLayout grid = new GridLayout(3, 3); + grid.setCaption("Show in position"); + addComponent(grid); + grid.setSpacing(true); + + Button pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.TOP_LEFT); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.TOP_CENTER); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.TOP_RIGHT); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.MIDDLE_LEFT); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.MIDDLE_CENTER); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.MIDDLE_RIGHT); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.BOTTOM_LEFT); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.BOTTOM_CENTER); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + pos = new Button("", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + notification.setPosition(Position.BOTTOM_RIGHT); + notification.show(Page.getCurrent()); + } + }); + pos.addStyleName("small"); + grid.addComponent(pos); + + } + }; + p.setContent(content); + + return p; + } + + Panel tooltips() { + Panel p = new Panel("Tooltips"); + HorizontalLayout content = new HorizontalLayout() { + { + setSpacing(true); + setMargin(true); + addStyleName("wrapping"); + + addComponent(new Label( + "Try out different tooltips/descriptions by hovering over the labels.")); + + Label label = new Label("Simple"); + label.addStyleName("bold"); + label.setDescription("Simple tooltip message"); + addComponent(label); + + label = new Label("Long"); + label.addStyleName("bold"); + label.setDescription("Long tooltip message. Inmensae subtilitatis, obscuris et malesuada fames. Salutantibus vitae elit libero, a pharetra augue."); + addComponent(label); + + label = new Label("HTML tooltip"); + label.addStyleName("bold"); + label.setDescription("<div><h1>Ut enim ad minim veniam, quis nostrud exercitation</h1><p><span>Morbi fringilla convallis sapien, id pulvinar odio volutpat.</span> <span>Vivamus sagittis lacus vel augue laoreet rutrum faucibus.</span> <span>Donec sed odio operae, eu vulputate felis rhoncus.</span> <span>At nos hinc posthac, sitientis piros Afros.</span> <span>Tu quoque, Brute, fili mi, nihil timor populi, nihil!</span></p><p><span>Gallia est omnis divisa in partes tres, quarum.</span> <span>Praeterea iter est quasdam res quas ex communi.</span> <span>Cum ceteris in veneratione tui montes, nascetur mus.</span> <span>Quam temere in vitiis, legem sancimus haerentia.</span> <span>Idque Caesaris facere voluntate liceret: sese habere.</span></p></div>"); + addComponent(label); + + label = new Label("With an error message"); + label.addStyleName("bold"); + label.setDescription("Simple tooltip message"); + label.setComponentError(new UserError( + "Something terrible has happened")); + addComponent(label); + + label = new Label("With a long error message"); + label.addStyleName("bold"); + label.setDescription("Simple tooltip message"); + label.setComponentError(new UserError( + "<h2>Contra legem facit qui id facit quod lex prohibet <span>Tityre, tu patulae recubans sub tegmine fagi dolor.</span> <span>Tityre, tu patulae recubans sub tegmine fagi dolor.</span> <span>Prima luce, cum quibus mons aliud consensu ab eo.</span> <span>Quid securi etiam tamquam eu fugiat nulla pariatur.</span> <span>Fabio vel iudice vincam, sunt in culpa qui officia.</span> <span>Nihil hic munitissimus habendi senatus locus, nihil horum?</span></p><p><span>Plura mihi bona sunt, inclinet, amari petere vellent.</span> <span>Integer legentibus erat a ante historiarum dapibus.</span> <span>Quam diu etiam furor iste tuus nos eludet?</span> <span>Nec dubitamus multa iter quae et nos invenerat.</span> <span>Quisque ut dolor gravida, placerat libero vel, euismod.</span> <span>Quae vero auctorem tractata ab fiducia dicuntur.</span></h2>", + AbstractErrorMessage.ContentMode.HTML, + ErrorLevel.CRITICAL)); + addComponent(label); + + label = new Label("Error message only"); + label.addStyleName("bold"); + label.setComponentError(new UserError( + "Something terrible has happened")); + addComponent(label); + } + }; + p.setContent(content); + return p; + + } + + Panel windows() { + Panel p = new Panel("Dialogs"); + VerticalLayout content = new VerticalLayout() { + final Window win = new Window("Window Caption"); + String prevHeight = "300px"; + boolean footerVisible = true; + boolean autoHeight = false; + boolean tabsVisible = false; + boolean toolbarVisible = false; + boolean footerToolbar = false; + boolean toolbarLayout = false; + String toolbarStyle = null; + + VerticalLayout windowContent() { + VerticalLayout root = new VerticalLayout(); + + if (toolbarVisible) { + MenuBar menuBar = MenuBars.getToolBar(); + menuBar.setSizeUndefined(); + menuBar.setStyleName(toolbarStyle); + Component toolbar = menuBar; + if (toolbarLayout) { + menuBar.setWidth(null); + HorizontalLayout toolbarLayout = new HorizontalLayout(); + toolbarLayout.setWidth("100%"); + toolbarLayout.setSpacing(true); + Label label = new Label("Tools"); + label.setSizeUndefined(); + toolbarLayout.addComponents(label, menuBar); + toolbarLayout.setExpandRatio(menuBar, 1); + toolbarLayout.setComponentAlignment(menuBar, + Alignment.TOP_RIGHT); + toolbar = toolbarLayout; + } + toolbar.addStyleName("v-window-top-toolbar"); + root.addComponent(toolbar); + } + + Component content = null; + + if (tabsVisible) { + TabSheet tabs = new TabSheet(); + tabs.setSizeFull(); + VerticalLayout l = new VerticalLayout(); + l.addComponent(new Label( + "<h2>Subtitle</h2><p>Normal type for plain text. Etiam at risus et justo dignissim congue. Phasellus laoreet lorem vel dolor tempus vehicula.</p><p>Quisque ut dolor gravida, placerat libero vel, euismod. Etiam habebis sem dicantur magna mollis euismod. Nihil hic munitissimus habendi senatus locus, nihil horum? Curabitur est gravida et libero vitae dictum. Ullamco laboris nisi ut aliquid ex ea commodi consequat. Morbi odio eros, volutpat ut pharetra vitae, lobortis sed nibh.</p>", + ContentMode.HTML)); + l.setMargin(true); + tabs.addTab(l, "Selected"); + tabs.addTab(new Label(" ", ContentMode.HTML), + "Another"); + tabs.addTab(new Label(" ", ContentMode.HTML), + "One more"); + tabs.addStyleName("padded-tabbar"); + tabs.addSelectedTabChangeListener(new SelectedTabChangeListener() { + @Override + public void selectedTabChange( + SelectedTabChangeEvent event) { + try { + Thread.sleep(600); + } catch (InterruptedException e) { + e.printStackTrace(); + } + } + }); + content = tabs; + } else if (!autoHeight) { + Panel p = new Panel(); + p.setSizeFull(); + p.addStyleName("borderless"); + if (!toolbarVisible || !toolbarLayout) { + p.addStyleName("scroll-divider"); + } + VerticalLayout l = new VerticalLayout(); + l.addComponent(new Label( + "<h2>Subtitle</h2><p>Normal type for plain text. Etiam at risus et justo dignissim congue. Phasellus laoreet lorem vel dolor tempus vehicula.</p><p>Quisque ut dolor gravida, placerat libero vel, euismod. Etiam habebis sem dicantur magna mollis euismod. Nihil hic munitissimus habendi senatus locus, nihil horum? Curabitur est gravida et libero vitae dictum. Ullamco laboris nisi ut aliquid ex ea commodi consequat. Morbi odio eros, volutpat ut pharetra vitae, lobortis sed nibh.</p>", + ContentMode.HTML)); + l.setMargin(true); + p.setContent(l); + content = p; + } else { + content = new Label( + "<h2>Subtitle</h2><p>Normal type for plain text. Etiam at risus et justo dignissim congue. Phasellus laoreet lorem vel dolor tempus vehicula.</p><p>Quisque ut dolor gravida, placerat libero vel, euismod. Etiam habebis sem dicantur magna mollis euismod. Nihil hic munitissimus habendi senatus locus, nihil horum? Curabitur est gravida et libero vitae dictum. Ullamco laboris nisi ut aliquid ex ea commodi consequat. Morbi odio eros, volutpat ut pharetra vitae, lobortis sed nibh.</p>", + ContentMode.HTML); + root.setMargin(true); + } + + root.addComponent(content); + + if (footerVisible) { + HorizontalLayout footer = new HorizontalLayout(); + footer.setWidth("100%"); + footer.setSpacing(true); + footer.addStyleName("v-window-bottom-toolbar"); + + Label footerText = new Label("Footer text"); + footerText.setSizeUndefined(); + + Button ok = new Button("OK"); + ok.addStyleName("primary"); + + Button cancel = new Button("Cancel"); + + footer.addComponents(footerText, ok, cancel); + footer.setExpandRatio(footerText, 1); + + if (footerToolbar) { + MenuBar menuBar = MenuBars.getToolBar(); + menuBar.setStyleName(toolbarStyle); + menuBar.setWidth(null); + footer.removeAllComponents(); + footer.addComponent(menuBar); + } + + root.addComponent(footer); + } + + if (!autoHeight) { + root.setSizeFull(); + root.setExpandRatio(content, 1); + } + + return root; + } + + { + setSpacing(true); + setMargin(true); + win.setWidth("380px"); + win.setHeight(prevHeight); + win.setClosable(false); + win.setResizable(false); + win.setContent(windowContent()); + win.setCloseShortcut(KeyCode.ESCAPE, null); + + Command optionsCommand = new Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + if (selectedItem.getText().equals("Footer")) { + footerVisible = selectedItem.isChecked(); + } + if (selectedItem.getText().equals("Auto Height")) { + autoHeight = selectedItem.isChecked(); + if (!autoHeight) { + win.setHeight(prevHeight); + } else { + prevHeight = win.getHeight() + + win.getHeightUnits().toString(); + win.setHeight(null); + } + } + if (selectedItem.getText().equals("Tabs")) { + tabsVisible = selectedItem.isChecked(); + } + + if (selectedItem.getText().equals("Top Toolbar")) { + toolbarVisible = selectedItem.isChecked(); + } + + if (selectedItem.getText().equals("Footer Toolbar")) { + footerToolbar = selectedItem.isChecked(); + } + + if (selectedItem.getText().equals("Top Toolbar layout")) { + toolbarLayout = selectedItem.isChecked(); + } + + if (selectedItem.getText() + .equals("Borderless Toolbars")) { + toolbarStyle = selectedItem.isChecked() ? "borderless" + : null; + } + + win.setContent(windowContent()); + } + }; + + MenuBar options = new MenuBar(); + options.setCaption("Content"); + options.addItem("Auto Height", optionsCommand).setCheckable( + true); + options.addItem("Tabs", optionsCommand).setCheckable(true); + MenuItem option = options.addItem("Footer", optionsCommand); + option.setCheckable(true); + option.setChecked(true); + options.addStyleName("small"); + addComponent(options); + + options = new MenuBar(); + options.setCaption("Toolbars"); + options.addItem("Footer Toolbar", optionsCommand).setCheckable( + true); + options.addItem("Top Toolbar", optionsCommand).setCheckable( + true); + options.addItem("Top Toolbar layout", optionsCommand) + .setCheckable(true); + options.addItem("Borderless Toolbars", optionsCommand) + .setCheckable(true); + options.addStyleName("small"); + addComponent(options); + + Command optionsCommand2 = new Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + if (selectedItem.getText().equals("Caption")) { + win.setCaption(selectedItem.isChecked() ? "Window Caption" + : null); + } else if (selectedItem.getText().equals("Closable")) { + win.setClosable(selectedItem.isChecked()); + } else if (selectedItem.getText().equals("Resizable")) { + win.setResizable(selectedItem.isChecked()); + } else if (selectedItem.getText().equals("Modal")) { + win.setModal(selectedItem.isChecked()); + } + } + }; + + options = new MenuBar(); + options.setCaption("Options"); + MenuItem caption = options.addItem("Caption", optionsCommand2); + caption.setCheckable(true); + caption.setChecked(true); + options.addItem("Closable", optionsCommand2).setCheckable(true); + options.addItem("Resizable", optionsCommand2) + .setCheckable(true); + options.addItem("Modal", optionsCommand2).setCheckable(true); + options.addStyleName("small"); + addComponent(options); + + final Button show = new Button("Open Window", + new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + getUI().addWindow(win); + win.center(); + win.focus(); + event.getButton().setEnabled(false); + } + }); + show.addStyleName("primary"); + addComponent(show); + + final CheckBox hidden = new CheckBox("Hidden"); + hidden.addValueChangeListener(new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + win.setVisible(!hidden.getValue()); + } + }); + addComponent(hidden); + + win.addCloseListener(new CloseListener() { + @Override + public void windowClose(CloseEvent e) { + show.setEnabled(true); + } + }); + } + }; + p.setContent(content); + return p; + + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/DateFields.java b/uitest/src/com/vaadin/tests/themes/valo/DateFields.java new file mode 100644 index 0000000000..ae520e07c2 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/DateFields.java @@ -0,0 +1,190 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import java.util.Date; +import java.util.Locale; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.UserError; +import com.vaadin.shared.ui.datefield.Resolution; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.DateField; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.InlineDateField; +import com.vaadin.ui.Label; +import com.vaadin.ui.VerticalLayout; + +public class DateFields extends VerticalLayout implements View { + public DateFields() { + setMargin(true); + + Label h1 = new Label("Date Fields"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + DateField date = new DateField("Default resolution"); + date.setValue(new Date()); + row.addComponent(date); + + date = new DateField("Error"); + date.setValue(new Date()); + date.setComponentError(new UserError("Fix it, now!")); + row.addComponent(date); + + date = new DateField("Error, borderless"); + date.setValue(new Date()); + date.setComponentError(new UserError("Fix it, now!")); + date.addStyleName("borderless"); + row.addComponent(date); + + CssLayout group = new CssLayout(); + group.setCaption("Grouped with a Button"); + group.addStyleName("v-component-group"); + row.addComponent(group); + + final DateField date2 = new DateField(); + group.addComponent(date2); + + Button today = new Button("Today", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + date2.setValue(new Date()); + } + }); + group.addComponent(today); + + date = new DateField("Default resolution, explicit size"); + date.setValue(new Date()); + row.addComponent(date); + date.setWidth("260px"); + date.setHeight("60px"); + + date = new DateField("Second resolution"); + date.setValue(new Date()); + date.setResolution(Resolution.SECOND); + row.addComponent(date); + + date = new DateField("Minute resolution"); + date.setValue(new Date()); + date.setResolution(Resolution.MINUTE); + row.addComponent(date); + + date = new DateField("Hour resolution"); + date.setValue(new Date()); + date.setResolution(Resolution.HOUR); + row.addComponent(date); + + date = new DateField("Disabled"); + date.setValue(new Date()); + date.setResolution(Resolution.HOUR); + date.setEnabled(false); + row.addComponent(date); + + date = new DateField("Day resolution"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + row.addComponent(date); + + date = new DateField("Month resolution"); + date.setValue(new Date()); + date.setResolution(Resolution.MONTH); + row.addComponent(date); + + date = new DateField("Year resolution"); + date.setValue(new Date()); + date.setResolution(Resolution.YEAR); + row.addComponent(date); + + date = new DateField("Custom color"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.addStyleName("color1"); + row.addComponent(date); + + date = new DateField("Custom color"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.addStyleName("color2"); + row.addComponent(date); + + date = new DateField("Custom color"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.addStyleName("color3"); + row.addComponent(date); + + date = new DateField("Small"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.addStyleName("small"); + row.addComponent(date); + + date = new DateField("Large"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.addStyleName("large"); + row.addComponent(date); + + date = new DateField("Borderless"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.addStyleName("borderless"); + row.addComponent(date); + + date = new DateField("Week numbers"); + date.setValue(new Date()); + date.setResolution(Resolution.DAY); + date.setLocale(new Locale("fi", "fi")); + date.setShowISOWeekNumbers(true); + row.addComponent(date); + + date = new DateField("US locale"); + date.setValue(new Date()); + date.setResolution(Resolution.SECOND); + date.setLocale(new Locale("en", "US")); + row.addComponent(date); + + date = new DateField("Custom format"); + date.setValue(new Date()); + date.setDateFormat("E dd/MM/yyyy"); + row.addComponent(date); + + date = new InlineDateField("Date picker"); + row.addComponent(date); + + date = new InlineDateField("Date picker with week numbers"); + date.setLocale(new Locale("fi", "fi")); + date.setShowISOWeekNumbers(true); + row.addComponent(date); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Dragging.java b/uitest/src/com/vaadin/tests/themes/valo/Dragging.java new file mode 100644 index 0000000000..27bdea7d8a --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Dragging.java @@ -0,0 +1,273 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; + +import com.vaadin.event.Transferable; +import com.vaadin.event.dd.DragAndDropEvent; +import com.vaadin.event.dd.DropHandler; +import com.vaadin.event.dd.DropTarget; +import com.vaadin.event.dd.TargetDetails; +import com.vaadin.event.dd.acceptcriteria.AcceptCriterion; +import com.vaadin.event.dd.acceptcriteria.Not; +import com.vaadin.event.dd.acceptcriteria.SourceIsTarget; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.ThemeResource; +import com.vaadin.shared.ui.dd.HorizontalDropLocation; +import com.vaadin.ui.AbstractOrderedLayout; +import com.vaadin.ui.Alignment; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Component; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.CustomComponent; +import com.vaadin.ui.DragAndDropWrapper; +import com.vaadin.ui.Embedded; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.MenuBar; +import com.vaadin.ui.MenuBar.MenuItem; +import com.vaadin.ui.Notification; +import com.vaadin.ui.VerticalLayout; + +/** + * + * @since + * @author Vaadin Ltd + */ +public class Dragging extends VerticalLayout implements View { + + SortableLayout sample; + + public Dragging() { + setMargin(true); + setSpacing(true); + + Label h1 = new Label("Dragging Components"); + h1.addStyleName("h1"); + addComponent(h1); + + MenuBar options = new MenuBar(); + options.setCaption("Drop Hints"); + addComponent(options); + + // Use these styles to hide irrelevant drag hints + // Can be used either on a parent or directly on the DnDWrapper + MenuItem opt = options.addItem("Vertical", new MenuBar.Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + if (selectedItem.isChecked()) { + sample.removeStyleName("no-vertical-drag-hints"); + } else { + sample.addStyleName("no-vertical-drag-hints"); + } + } + }); + opt.setCheckable(true); + opt.setChecked(true); + + opt = options.addItem("Horizontal", new MenuBar.Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + if (selectedItem.isChecked()) { + sample.removeStyleName("no-horizontal-drag-hints"); + } else { + sample.addStyleName("no-horizontal-drag-hints"); + } + } + }); + opt.setCheckable(true); + opt.setChecked(true); + + opt = options.addItem("Box", new MenuBar.Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + if (selectedItem.isChecked()) { + sample.removeStyleName("no-box-drag-hints"); + } else { + sample.addStyleName("no-box-drag-hints"); + } + } + }); + opt.setCheckable(true); + opt.setChecked(true); + + sample = new SortableLayout(); + sample.setSizeUndefined(); + sample.setHeight("100px"); + + for (final Component component : createComponents()) { + sample.addComponent(component); + } + + addComponent(sample); + + } + + private List<Component> createComponents() { + final List<Component> components = new ArrayList<Component>(); + + final Label label = new Label( + "This is a long text block that will wrap."); + label.setWidth("120px"); + components.add(label); + + final Embedded image = new Embedded("", new ThemeResource( + "../runo/icons/64/document.png")); + components.add(image); + + final CssLayout documentLayout = new CssLayout(); + documentLayout.setWidth("19px"); + for (int i = 0; i < 5; ++i) { + final Embedded e = new Embedded(null, new ThemeResource( + "../runo/icons/16/document.png")); + e.setHeight("16px"); + e.setWidth("16px"); + documentLayout.addComponent(e); + } + components.add(documentLayout); + + final VerticalLayout buttonLayout = new VerticalLayout(); + final Button button = new Button("Button"); + button.addClickListener(new Button.ClickListener() { + @Override + public void buttonClick(final ClickEvent event) { + Notification.show("Button clicked"); + } + }); + buttonLayout.addComponent(button); + buttonLayout.setComponentAlignment(button, Alignment.MIDDLE_CENTER); + components.add(buttonLayout); + + return components; + } + + private static class ReorderLayoutDropHandler implements DropHandler { + + private final AbstractOrderedLayout layout; + + public ReorderLayoutDropHandler(final AbstractOrderedLayout layout) { + this.layout = layout; + } + + @Override + public AcceptCriterion getAcceptCriterion() { + return new Not(SourceIsTarget.get()); + } + + @Override + public void drop(final DragAndDropEvent dropEvent) { + final Transferable transferable = dropEvent.getTransferable(); + final Component sourceComponent = transferable.getSourceComponent(); + if (sourceComponent instanceof WrappedComponent) { + final TargetDetails dropTargetData = dropEvent + .getTargetDetails(); + final DropTarget target = dropTargetData.getTarget(); + + // find the location where to move the dragged component + boolean sourceWasAfterTarget = true; + int index = 0; + final Iterator<Component> componentIterator = layout + .getComponentIterator(); + Component next = null; + while (next != target && componentIterator.hasNext()) { + next = componentIterator.next(); + if (next != sourceComponent) { + index++; + } else { + sourceWasAfterTarget = false; + } + } + if (next == null || next != target) { + // component not found - if dragging from another layout + return; + } + + // drop on top of target? + if (dropTargetData.getData("horizontalLocation").equals( + HorizontalDropLocation.CENTER.toString())) { + if (sourceWasAfterTarget) { + index--; + } + } + + // drop before the target? + else if (dropTargetData.getData("horizontalLocation").equals( + HorizontalDropLocation.LEFT.toString())) { + index--; + if (index < 0) { + index = 0; + } + } + + // move component within the layout + layout.removeComponent(sourceComponent); + layout.addComponent(sourceComponent, index); + } + } + } + + private static class SortableLayout extends CustomComponent { + private final AbstractOrderedLayout layout; + private final DropHandler dropHandler; + + public SortableLayout() { + layout = new HorizontalLayout(); + layout.setMargin(true); + dropHandler = new ReorderLayoutDropHandler(layout); + + // final DragAndDropWrapper pane = new DragAndDropWrapper(layout); + setCompositionRoot(layout); + } + + public void addComponent(final Component component) { + final WrappedComponent wrapper = new WrappedComponent(component, + dropHandler); + wrapper.setSizeUndefined(); + component.setHeight("100%"); + wrapper.setHeight("100%"); + layout.addComponent(wrapper); + } + } + + private static class WrappedComponent extends DragAndDropWrapper { + + private final DropHandler dropHandler; + + public WrappedComponent(final Component content, + final DropHandler dropHandler) { + super(content); + this.dropHandler = dropHandler; + setDragStartMode(DragStartMode.WRAPPER); + } + + @Override + public DropHandler getDropHandler() { + return dropHandler; + } + + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Forms.java b/uitest/src/com/vaadin/tests/themes/valo/Forms.java new file mode 100644 index 0000000000..9451b5c5d3 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Forms.java @@ -0,0 +1,188 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import java.util.Date; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.UserError; +import com.vaadin.shared.ui.MarginInfo; +import com.vaadin.ui.Alignment; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.ComboBox; +import com.vaadin.ui.DateField; +import com.vaadin.ui.FormLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.OptionGroup; +import com.vaadin.ui.RichTextArea; +import com.vaadin.ui.TextArea; +import com.vaadin.ui.TextField; +import com.vaadin.ui.VerticalLayout; + +/** + * + * @since + * @author Vaadin Ltd + */ +public class Forms extends VerticalLayout implements View { + public Forms() { + setSpacing(true); + setMargin(true); + + Label title = new Label("Form"); + title.addStyleName("h1"); + addComponent(title); + + final FormLayout form = new FormLayout(); + form.setMargin(false); + form.setWidth("800px"); + form.addStyleName("light"); + addComponent(form); + + Label section = new Label("Personal Info"); + section.addStyleName("h2"); + form.addComponent(section); + + TextField name = new TextField("Name"); + name.setValue(ValoThemeTest.nextString(true) + " " + + ValoThemeTest.nextString(true)); + name.setWidth("50%"); + form.addComponent(name); + + DateField birthday = new DateField("Birthday"); + birthday.setValue(new Date(80, 0, 31)); + form.addComponent(birthday); + + TextField username = new TextField("Username"); + username.setValue(ValoThemeTest.nextString(false) + + ValoThemeTest.nextString(false)); + username.setRequired(true); + form.addComponent(username); + + OptionGroup sex = new OptionGroup("Sex"); + sex.addItem("Female"); + sex.addItem("Male"); + sex.select("Male"); + sex.addStyleName("horizontal"); + form.addComponent(sex); + + section = new Label("Contact Info"); + section.addStyleName("h3"); + form.addComponent(section); + + TextField email = new TextField("Email"); + email.setValue(ValoThemeTest.nextString(false) + "@" + + ValoThemeTest.nextString(false) + ".com"); + email.setWidth("50%"); + email.setRequired(true); + form.addComponent(email); + + TextField location = new TextField("Location"); + location.setValue(ValoThemeTest.nextString(true) + ", " + + ValoThemeTest.nextString(true)); + location.setWidth("50%"); + location.setComponentError(new UserError("This address doesn't exist")); + form.addComponent(location); + + TextField phone = new TextField("Phone"); + phone.setWidth("50%"); + form.addComponent(phone); + + HorizontalLayout wrap = new HorizontalLayout(); + wrap.setSpacing(true); + wrap.setDefaultComponentAlignment(Alignment.MIDDLE_LEFT); + wrap.setCaption("Newsletter"); + CheckBox newsletter = new CheckBox("Subscribe to newsletter", true); + wrap.addComponent(newsletter); + + ComboBox period = new ComboBox(); + period.setTextInputAllowed(false); + period.addItem("Daily"); + period.addItem("Weekly"); + period.addItem("Montly"); + period.setNullSelectionAllowed(false); + period.select("Weekly"); + period.addStyleName("small"); + period.setWidth("10em"); + wrap.addComponent(period); + form.addComponent(wrap); + + section = new Label("Additional Info"); + section.addStyleName("h4"); + form.addComponent(section); + + TextField website = new TextField("Website"); + website.setInputPrompt("http://"); + website.setWidth("100%"); + form.addComponent(website); + + TextArea shortbio = new TextArea("Short Bio"); + shortbio.setValue("Quis aute iure reprehenderit in voluptate velit esse. Cras mattis iudicium purus sit amet fermentum."); + shortbio.setWidth("100%"); + shortbio.setRows(2); + form.addComponent(shortbio); + + final RichTextArea bio = new RichTextArea("Bio"); + bio.setWidth("100%"); + bio.setValue("<div><p><span>Integer legentibus erat a ante historiarum dapibus.</span> <span>Vivamus sagittis lacus vel augue laoreet rutrum faucibus.</span> <span>A communi observantia non est recedendum.</span> <span>Morbi fringilla convallis sapien, id pulvinar odio volutpat.</span> <span>Ab illo tempore, ab est sed immemorabili.</span> <span>Quam temere in vitiis, legem sancimus haerentia.</span></p><p><span>Morbi odio eros, volutpat ut pharetra vitae, lobortis sed nibh.</span> <span>Quam diu etiam furor iste tuus nos eludet?</span> <span>Cum sociis natoque penatibus et magnis dis parturient.</span> <span>Quam diu etiam furor iste tuus nos eludet?</span> <span>Tityre, tu patulae recubans sub tegmine fagi dolor.</span></p><p><span>Curabitur blandit tempus ardua ridiculus sed magna.</span> <span>Phasellus laoreet lorem vel dolor tempus vehicula.</span> <span>Etiam habebis sem dicantur magna mollis euismod.</span> <span>Hi omnes lingua, institutis, legibus inter se differunt.</span></p></div>"); + form.addComponent(bio); + + form.setReadOnly(true); + bio.setReadOnly(true); + + Button edit = new Button("Edit", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + boolean readOnly = form.isReadOnly(); + if (readOnly) { + bio.setReadOnly(false); + form.setReadOnly(false); + form.removeStyleName("light"); + event.getButton().setCaption("Save"); + event.getButton().addStyleName("primary"); + } else { + bio.setReadOnly(true); + form.setReadOnly(true); + form.addStyleName("light"); + event.getButton().setCaption("Edit"); + event.getButton().removeStyleName("primary"); + } + } + }); + + HorizontalLayout footer = new HorizontalLayout(); + footer.setMargin(new MarginInfo(true, false, true, false)); + footer.setSpacing(true); + footer.setDefaultComponentAlignment(Alignment.MIDDLE_LEFT); + form.addComponent(footer); + footer.addComponent(edit); + + Label lastModified = new Label("Last modified by you a minute ago"); + lastModified.addStyleName("light"); + footer.addComponent(lastModified); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Labels.java b/uitest/src/com/vaadin/tests/themes/valo/Labels.java new file mode 100644 index 0000000000..08378ad9e6 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Labels.java @@ -0,0 +1,112 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.MarginInfo; +import com.vaadin.shared.ui.label.ContentMode; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.Panel; +import com.vaadin.ui.VerticalLayout; + +/** + * + * @since + * @author Vaadin Ltd + */ +public class Labels extends VerticalLayout implements View { + public Labels() { + setMargin(true); + + Label h1 = new Label("Labels"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout split = new HorizontalLayout(); + split.setWidth("100%"); + addComponent(split); + + VerticalLayout left = new VerticalLayout(); + left.setMargin(new MarginInfo(false, true, false, false)); + split.addComponent(left); + + Label large = new Label( + "Large type for introductory text. Etiam at risus et justo dignissim congue. Donec congue lacinia dui, a porttitor lectus condimentum laoreet. Nunc eu."); + large.addStyleName("large"); + left.addComponent(large); + + Label h2 = new Label("Subtitle"); + h2.addStyleName("h2"); + left.addComponent(h2); + + Label normal = new Label( + "Normal type for plain text, with a <a href=\"https://vaadin.com\">regular link</a>. Etiam at risus et justo dignissim congue. Donec congue lacinia dui, a porttitor lectus condimentum laoreet. Nunc eu.", + ContentMode.HTML); + left.addComponent(normal); + + Label h3 = new Label("Small Title"); + h3.addStyleName("h3"); + left.addComponent(h3); + + Label small = new Label( + "Small type for additional text. Etiam at risus et justo dignissim congue. Donec congue lacinia dui, a porttitor lectus condimentum laoreet. Nunc eu."); + small.addStyleName("small"); + left.addComponent(small); + + Label h4 = new Label("Section Title"); + h4.addStyleName("h4"); + left.addComponent(h4); + + normal = new Label( + "Normal type for plain text. Etiam at risus et justo dignissim congue. Donec congue lacinia dui, a porttitor lectus condimentum laoreet. Nunc eu."); + left.addComponent(normal); + + Panel p = new Panel("Additional Label Styles"); + split.addComponent(p); + + VerticalLayout right = new VerticalLayout(); + right.setSpacing(true); + right.setMargin(true); + p.setContent(right); + + Label label = new Label( + "Bold type for prominent text. Etiam at risus et justo dignissim congue. Donec congue lacinia dui, a porttitor lectus condimentum laoreet. Nunc eu."); + label.addStyleName("bold"); + right.addComponent(label); + + label = new Label( + "Light type for subtle text. Etiam at risus et justo dignissim congue. Donec congue lacinia dui, a porttitor lectus condimentum laoreet. Nunc eu."); + label.addStyleName("light"); + right.addComponent(label); + + label = new Label("A label for success"); + label.addStyleName("success"); + right.addComponent(label); + + label = new Label("A label for failure"); + label.addStyleName("failure"); + right.addComponent(label); + + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/MenuBars.java b/uitest/src/com/vaadin/tests/themes/valo/MenuBars.java new file mode 100644 index 0000000000..f15f43254a --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/MenuBars.java @@ -0,0 +1,187 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.FontAwesome; +import com.vaadin.ui.Label; +import com.vaadin.ui.MenuBar; +import com.vaadin.ui.MenuBar.Command; +import com.vaadin.ui.MenuBar.MenuItem; +import com.vaadin.ui.Notification; +import com.vaadin.ui.VerticalLayout; + +public class MenuBars extends VerticalLayout implements View { + public MenuBars() { + setMargin(true); + setSpacing(true); + + Label h1 = new Label("Menu Bars"); + h1.addStyleName("h1"); + addComponent(h1); + + MenuBar menuBar = getMenuBar(); + menuBar.setCaption("Normal style"); + addComponent(menuBar); + + menuBar = getMenuBar(); + menuBar.setCaption("Small style"); + menuBar.addStyleName("small"); + addComponent(menuBar); + + menuBar = getMenuBar(); + menuBar.setCaption("Borderless style"); + menuBar.addStyleName("borderless"); + addComponent(menuBar); + + menuBar = getMenuBar(); + menuBar.setCaption("Small borderless style"); + menuBar.addStyleName("borderless"); + menuBar.addStyleName("small"); + addComponent(menuBar); + } + + static MenuBar getMenuBar() { + Command click = new Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + Notification.show("Clicked " + selectedItem.getText()); + } + }; + + MenuBar menubar = new MenuBar(); + menubar.setWidth("100%"); + final MenuBar.MenuItem file = menubar.addItem("File", null); + final MenuBar.MenuItem newItem = file.addItem("New", null); + file.addItem("Open file...", click); + file.addSeparator(); + + newItem.addItem("File", click); + newItem.addItem("Folder", click); + newItem.addItem("Project...", click); + + file.addItem("Close", click); + file.addItem("Close All", click); + file.addSeparator(); + + file.addItem("Save", click); + file.addItem("Save As...", click); + file.addItem("Save All", click); + + final MenuBar.MenuItem edit = menubar.addItem("Edit", null); + edit.addItem("Undo", click); + edit.addItem("Redo", click).setEnabled(false); + edit.addSeparator(); + + edit.addItem("Cut", click); + edit.addItem("Copy", click); + edit.addItem("Paste", click); + edit.addSeparator(); + + final MenuBar.MenuItem find = edit.addItem("Find/Replace", null); + + find.addItem("Google Search", click); + find.addSeparator(); + find.addItem("Find/Replace...", click); + find.addItem("Find Next", click); + find.addItem("Find Previous", click); + + Command check = new Command() { + @Override + public void menuSelected(MenuItem selectedItem) { + Notification.show(selectedItem.isChecked() ? "Checked" + : "Unchecked"); + } + }; + + final MenuBar.MenuItem view = menubar.addItem("View", null); + view.addItem("Show Status Bar", check).setCheckable(true); + MenuItem title = view.addItem("Show Title Bar", check); + title.setCheckable(true); + title.setChecked(true); + view.addItem("Customize Toolbar...", click); + view.addSeparator(); + + view.addItem("Actual Size", click); + view.addItem("Zoom In", click); + view.addItem("Zoom Out", click); + + MenuItem fav = menubar.addItem("", check); + fav.setIcon(TestIcon.get()); + fav.setStyleName("icon-only"); + fav.setCheckable(true); + fav.setChecked(true); + + fav = menubar.addItem("", check); + fav.setIcon(TestIcon.get()); + fav.setStyleName("icon-only"); + fav.setCheckable(true); + fav.setCheckable(true); + + menubar.addItem("Attach", click).setIcon(FontAwesome.PAPERCLIP); + menubar.addItem("Undo", click).setIcon(FontAwesome.UNDO); + MenuItem redo = menubar.addItem("Redo", click); + redo.setIcon(FontAwesome.REPEAT); + redo.setEnabled(false); + menubar.addItem("Upload", click).setIcon(FontAwesome.UPLOAD); + + return menubar; + } + + static MenuBar getToolBar() { + MenuBar menubar = new MenuBar(); + menubar.setWidth("100%"); + + MenuItem fav = menubar.addItem("", null); + fav.setIcon(FontAwesome.ALIGN_LEFT); + fav.setStyleName("icon-only"); + fav.setCheckable(true); + // fav.setChecked(true); + + fav = menubar.addItem("", null); + fav.setIcon(FontAwesome.ALIGN_CENTER); + fav.setStyleName("icon-only"); + fav.setCheckable(true); + + fav = menubar.addItem("", null); + fav.setIcon(FontAwesome.ALIGN_RIGHT); + fav.setStyleName("icon-only"); + fav.setCheckable(true); + + MenuItem clip = menubar.addItem("", null); + clip.setIcon(FontAwesome.PAPERCLIP); + clip.setStyleName("icon-only"); + + MenuItem undo = menubar.addItem("", null); + undo.setIcon(FontAwesome.UNDO); + undo.setStyleName("icon-only"); + + MenuItem redo = menubar.addItem("", null); + redo.setIcon(FontAwesome.REPEAT); + redo.setEnabled(false); + redo.setStyleName("icon-only"); + + return menubar; + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/NativeSelects.java b/uitest/src/com/vaadin/tests/themes/valo/NativeSelects.java new file mode 100644 index 0000000000..284f7c8d6e --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/NativeSelects.java @@ -0,0 +1,75 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.ListSelect; +import com.vaadin.ui.NativeSelect; +import com.vaadin.ui.TwinColSelect; +import com.vaadin.ui.VerticalLayout; + +public class NativeSelects extends VerticalLayout implements View { + public NativeSelects() { + setMargin(true); + + Label h1 = new Label("Selects"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + NativeSelect select = new NativeSelect("Drop Down Select"); + row.addComponent(select); + + ListSelect list = new ListSelect("List Select"); + list.setNewItemsAllowed(true); + row.addComponent(list); + + TwinColSelect tcs = new TwinColSelect("TwinCol Select"); + tcs.setLeftColumnCaption("Left Column"); + tcs.setRightColumnCaption("Right Column"); + tcs.setNewItemsAllowed(true); + row.addComponent(tcs); + + TwinColSelect tcs2 = new TwinColSelect("Sized TwinCol Select"); + tcs2.setLeftColumnCaption("Left Column"); + tcs2.setRightColumnCaption("Right Column"); + tcs2.setNewItemsAllowed(true); + tcs2.setWidth("280px"); + tcs2.setHeight("200px"); + row.addComponent(tcs2); + + for (int i = 1; i <= 10; i++) { + select.addItem("Option " + i); + list.addItem("Option " + i); + tcs.addItem("Option " + i); + tcs2.addItem("Option " + i); + } + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Panels.java b/uitest/src/com/vaadin/tests/themes/valo/Panels.java new file mode 100644 index 0000000000..74baef066b --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Panels.java @@ -0,0 +1,175 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.FontAwesome; +import com.vaadin.ui.Button; +import com.vaadin.ui.Component; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.MenuBar; +import com.vaadin.ui.MenuBar.MenuItem; +import com.vaadin.ui.Panel; +import com.vaadin.ui.VerticalLayout; + +public class Panels extends VerticalLayout implements View { + public Panels() { + setMargin(true); + + Label h1 = new Label("Panels & Layout panels"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + Panel panel = new Panel("Normal"); + panel.setIcon(TestIcon.get()); + panel.setContent(panelContent()); + row.addComponent(panel); + + panel = new Panel("Sized"); + panel.setIcon(TestIcon.get()); + panel.setWidth("10em"); + panel.setHeight("250px"); + panel.setContent(panelContent()); + row.addComponent(panel); + + panel = new Panel("Custom Caption"); + panel.setIcon(TestIcon.get()); + panel.addStyleName("color1"); + panel.setContent(panelContent()); + row.addComponent(panel); + + panel = new Panel("Custom Caption"); + panel.setIcon(TestIcon.get()); + panel.addStyleName("color2"); + panel.setContent(panelContent()); + row.addComponent(panel); + + panel = new Panel("Custom Caption"); + panel.setIcon(TestIcon.get()); + panel.addStyleName("color3"); + panel.setContent(panelContent()); + row.addComponent(panel); + + panel = new Panel("Borderless style"); + panel.setIcon(TestIcon.get()); + panel.addStyleName("borderless"); + panel.setContent(panelContent()); + row.addComponent(panel); + + panel = new Panel("Borderless + scroll divider"); + panel.setIcon(TestIcon.get()); + panel.addStyleName("borderless"); + panel.addStyleName("scroll-divider"); + panel.setContent(panelContentScroll()); + panel.setHeight("17em"); + row.addComponent(panel); + + panel = new Panel("Well style"); + panel.setIcon(TestIcon.get()); + panel.addStyleName("well"); + panel.setContent(panelContent()); + row.addComponent(panel); + + CssLayout layout = new CssLayout(); + layout.setIcon(TestIcon.get()); + layout.setCaption("Panel style layout"); + layout.addStyleName("card"); + layout.addComponent(panelContent()); + row.addComponent(layout); + + layout = new CssLayout(); + layout.addStyleName("card"); + row.addComponent(layout); + HorizontalLayout panelCaption = new HorizontalLayout(); + panelCaption.addStyleName("v-panel-caption"); + panelCaption.setWidth("100%"); + // panelCaption.setDefaultComponentAlignment(Alignment.MIDDLE_LEFT); + Label label = new Label("Panel style layout"); + panelCaption.addComponent(label); + panelCaption.setExpandRatio(label, 1); + + Button action = new Button(); + action.setIcon(FontAwesome.PENCIL); + action.addStyleName("borderless-colored"); + action.addStyleName("small"); + action.addStyleName("icon-only"); + panelCaption.addComponent(action); + MenuBar dropdown = new MenuBar(); + dropdown.addStyleName("borderless"); + dropdown.addStyleName("small"); + MenuItem addItem = dropdown.addItem("", FontAwesome.CHEVRON_DOWN, null); + addItem.setStyleName("icon-only"); + addItem.addItem("Settings", null); + addItem.addItem("Preferences", null); + addItem.addSeparator(); + addItem.addItem("Sign Out", null); + panelCaption.addComponent(dropdown); + + layout.addComponent(panelCaption); + layout.addComponent(panelContent()); + layout.setWidth("14em"); + + layout = new CssLayout(); + layout.setIcon(TestIcon.get()); + layout.setCaption("Well style layout"); + layout.addStyleName("well"); + layout.addComponent(panelContent()); + row.addComponent(layout); + } + + Component panelContent() { + VerticalLayout layout = new VerticalLayout(); + layout.setSizeFull(); + layout.setMargin(true); + layout.setSpacing(true); + Label content = new Label( + "Suspendisse dictum feugiat nisl ut dapibus. Mauris iaculis porttitor posuere. Praesent id metus massa, ut blandit odio."); + content.setWidth("10em"); + layout.addComponent(content); + Button button = new Button("Button"); + button.setSizeFull(); + layout.addComponent(button); + return layout; + } + + Component panelContentScroll() { + VerticalLayout layout = new VerticalLayout(); + layout.setMargin(true); + layout.setSpacing(true); + Label content = new Label( + "Suspendisse dictum feugiat nisl ut dapibus. Mauris iaculis porttitor posuere. Praesent id metus massa, ut blandit odio. Suspendisse dictum feugiat nisl ut dapibus. Mauris iaculis porttitor posuere. Praesent id metus massa, ut blandit odio."); + content.setWidth("10em"); + layout.addComponent(content); + Button button = new Button("Button"); + layout.addComponent(button); + return layout; + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/PopupViews.java b/uitest/src/com/vaadin/tests/themes/valo/PopupViews.java new file mode 100644 index 0000000000..c15270400c --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/PopupViews.java @@ -0,0 +1,101 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.label.ContentMode; +import com.vaadin.ui.Component; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.PopupView; +import com.vaadin.ui.PopupView.Content; +import com.vaadin.ui.VerticalLayout; + +public class PopupViews extends VerticalLayout implements View { + public PopupViews() { + setMargin(true); + + Label h1 = new Label("Popup Views"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + PopupView pv = new PopupView(new Content() { + @Override + public Component getPopupComponent() { + return new VerticalLayout() { + { + setMargin(true); + setWidth("300px"); + addComponent(new Label( + "Fictum, deserunt mollit anim laborum astutumque! Magna pars studiorum, prodita quaerimus.")); + } + }; + } + + @Override + public String getMinimizedValueAsHTML() { + return "Click to view"; + } + }); + row.addComponent(pv); + pv.setHideOnMouseOut(true); + pv.setCaption("Hide on mouse-out"); + + pv = new PopupView(new Content() { + int count = 0; + + @Override + public Component getPopupComponent() { + try { + Thread.sleep(1000); + } catch (InterruptedException e) { + + } + return new VerticalLayout() { + { + setMargin(true); + addComponent(new Label( + "<h3>Thanks for waiting!</h3><p>You've opened this popup <b>" + + ++count + " time" + + (count > 1 ? "s" : " only") + + "</b>.</p>", ContentMode.HTML)); + } + }; + } + + @Override + public String getMinimizedValueAsHTML() { + return "Show slow loading content"; + } + }); + row.addComponent(pv); + pv.setHideOnMouseOut(false); + pv.setCaption("Hide on click-outside"); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Sliders.java b/uitest/src/com/vaadin/tests/themes/valo/Sliders.java new file mode 100644 index 0000000000..363c698c32 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Sliders.java @@ -0,0 +1,210 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.slider.SliderOrientation; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.ProgressBar; +import com.vaadin.ui.Slider; +import com.vaadin.ui.VerticalLayout; + +public class Sliders extends VerticalLayout implements View { + public Sliders() { + setMargin(true); + + Label h1 = new Label("Sliders"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + Slider slider = new Slider("Horizontal"); + slider.setValue(50.0); + row.addComponent(slider); + + slider = new Slider("Horizontal, sized"); + slider.setValue(50.0); + slider.setWidth("200px"); + row.addComponent(slider); + + slider = new Slider("Custom handle"); + slider.setValue(50.0); + slider.setWidth("200px"); + slider.addStyleName("color1"); + row.addComponent(slider); + + slider = new Slider("Custom track"); + slider.setValue(50.0); + slider.setWidth("200px"); + slider.addStyleName("color2"); + row.addComponent(slider); + + slider = new Slider("Custom indicator"); + slider.setValue(50.0); + slider.setWidth("200px"); + slider.addStyleName("color3"); + row.addComponent(slider); + + slider = new Slider("No indicator"); + slider.setValue(50.0); + slider.setWidth("200px"); + slider.addStyleName("no-indicator"); + row.addComponent(slider); + + slider = new Slider("With ticks (not in IE8 & IE9)"); + slider.setValue(3.0); + slider.setWidth("200px"); + slider.setMax(4); + slider.addStyleName("ticks"); + row.addComponent(slider); + + slider = new Slider("Toggle imitation"); + slider.setWidth("50px"); + slider.setResolution(0); + slider.setMin(0); + slider.setMax(1); + row.addComponent(slider); + + slider = new Slider("Vertical"); + slider.setValue(50.0); + slider.setOrientation(SliderOrientation.VERTICAL); + row.addComponent(slider); + + slider = new Slider("Vertical, sized"); + slider.setValue(50.0); + slider.setOrientation(SliderOrientation.VERTICAL); + slider.setHeight("200px"); + row.addComponent(slider); + + slider = new Slider("Custom handle"); + slider.setValue(50.0); + slider.setHeight("200px"); + slider.addStyleName("color1"); + slider.setOrientation(SliderOrientation.VERTICAL); + row.addComponent(slider); + + slider = new Slider("Custom track"); + slider.setValue(50.0); + slider.setHeight("200px"); + slider.addStyleName("color2"); + slider.setOrientation(SliderOrientation.VERTICAL); + row.addComponent(slider); + + slider = new Slider("Custom indicator"); + slider.setValue(50.0); + slider.setHeight("200px"); + slider.addStyleName("color3"); + slider.setOrientation(SliderOrientation.VERTICAL); + row.addComponent(slider); + + slider = new Slider("No indicator"); + slider.setValue(50.0); + slider.setHeight("200px"); + slider.addStyleName("no-indicator"); + slider.setOrientation(SliderOrientation.VERTICAL); + row.addComponent(slider); + + slider = new Slider("With ticks"); + slider.setValue(3.0); + slider.setHeight("200px"); + slider.setMax(4); + slider.addStyleName("ticks"); + slider.setOrientation(SliderOrientation.VERTICAL); + row.addComponent(slider); + + slider = new Slider("Disabled"); + slider.setValue(50.0); + slider.setEnabled(false); + row.addComponent(slider); + + h1 = new Label("Progress Bars"); + h1.addStyleName("h1"); + addComponent(h1); + + row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + pb = new ProgressBar(); + pb.setCaption("Default"); + pb.setWidth("300px"); + // pb.setValue(0.6f); + row.addComponent(pb); + + pb2 = new ProgressBar(); + pb2.setCaption("Point style"); + pb2.setWidth("300px"); + pb2.addStyleName("point"); + // pb2.setValue(0.6f); + row.addComponent(pb2); + + ProgressBar pb3 = new ProgressBar(); + pb3.setIndeterminate(true); + pb3.setCaption("Indeterminate"); + row.addComponent(pb3); + + } + + float progress = 0; + + Thread update = new Thread() { + @Override + public void run() { + while (true) { + try { + Thread.sleep(1000); + getUI().access(new Runnable() { + @Override + public void run() { + pb.setValue(progress); + pb2.setValue(progress); + if (progress > 1) { + progress = 0; + } else { + progress += 0.2 * Math.random(); + } + } + }); + } catch (InterruptedException e) { + break; + } + } + }; + }; + private ProgressBar pb; + private ProgressBar pb2; + + @Override + public void enter(ViewChangeEvent event) { + getUI().setPollInterval(1000); + update.start(); + } + + @Override + public void detach() { + getUI().setPollInterval(-1); + update.interrupt(); + super.detach(); + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/SplitPanels.java b/uitest/src/com/vaadin/tests/themes/valo/SplitPanels.java new file mode 100644 index 0000000000..9a6d86ae04 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/SplitPanels.java @@ -0,0 +1,95 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.MarginInfo; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.HorizontalSplitPanel; +import com.vaadin.ui.Label; +import com.vaadin.ui.VerticalLayout; +import com.vaadin.ui.VerticalSplitPanel; + +public class SplitPanels extends VerticalLayout implements View { + public SplitPanels() { + setMargin(true); + + Label h1 = new Label("Split Panels"); + h1.addStyleName("h1"); + addComponent(h1); + + addComponent(new Label( + "Outlines are just to show the areas of the SplitPanels. They are not part of the actual component style.")); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + row.setMargin(new MarginInfo(true, false, false, false)); + addComponent(row); + + HorizontalSplitPanel sp = new HorizontalSplitPanel(); + sp.setCaption("Default style"); + sp.setWidth("400px"); + sp.setHeight(null); + sp.setFirstComponent(getContent()); + sp.setSecondComponent(getContent()); + row.addComponent(sp); + + VerticalSplitPanel sp2 = new VerticalSplitPanel(); + sp2.setCaption("Default style"); + sp2.setWidth("300px"); + sp2.setHeight("200px"); + sp2.setFirstComponent(getContent()); + sp2.setSecondComponent(getContent()); + row.addComponent(sp2); + + sp = new HorizontalSplitPanel(); + sp.setCaption("Large style"); + sp.setWidth("300px"); + sp.setHeight("200px"); + sp.addStyleName("large"); + sp.setFirstComponent(getContent()); + sp.setSecondComponent(getContent()); + row.addComponent(sp); + + sp2 = new VerticalSplitPanel(); + sp2.setCaption("Large style"); + sp2.setWidth("300px"); + sp2.setHeight("200px"); + sp2.addStyleName("large"); + sp2.setFirstComponent(getContent()); + sp2.setSecondComponent(getContent()); + row.addComponent(sp2); + } + + VerticalLayout getContent() { + return new VerticalLayout() { + { + setMargin(true); + addComponent(new Label( + "Fictum, deserunt mollit anim laborum astutumque!")); + } + }; + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Tables.java b/uitest/src/com/vaadin/tests/themes/valo/Tables.java new file mode 100644 index 0000000000..6aa02a7f74 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Tables.java @@ -0,0 +1,284 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.data.Container; +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.event.dd.DragAndDropEvent; +import com.vaadin.event.dd.DropHandler; +import com.vaadin.event.dd.acceptcriteria.AcceptAll; +import com.vaadin.event.dd.acceptcriteria.AcceptCriterion; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.ui.Button; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.Notification; +import com.vaadin.ui.Table; +import com.vaadin.ui.Table.Align; +import com.vaadin.ui.Table.ColumnGenerator; +import com.vaadin.ui.Table.RowHeaderMode; +import com.vaadin.ui.Table.TableDragMode; +import com.vaadin.ui.TextField; +import com.vaadin.ui.TreeTable; +import com.vaadin.ui.VerticalLayout; + +public class Tables extends VerticalLayout implements View { + + static final Container normalContainer = ValoThemeTest.generateContainer( + 200, false); + static final Container hierarchicalContainer = ValoThemeTest + .generateContainer(200, true); + + CheckBox hierarchical = new CheckBox("Hierarchical"); + CheckBox footer = new CheckBox("Footer", true); + CheckBox sized = new CheckBox("Sized"); + CheckBox expandRatios = new CheckBox("Expand ratios"); + CheckBox stripes = new CheckBox("Sripes", true); + CheckBox verticalLines = new CheckBox("Vertical lines", true); + CheckBox horizontalLines = new CheckBox("Horizontal lines", true); + CheckBox borderless = new CheckBox("Borderless"); + CheckBox headers = new CheckBox("Header", true); + CheckBox compact = new CheckBox("Compact"); + CheckBox small = new CheckBox("Small"); + CheckBox rowIndex = new CheckBox("Row index", false); + CheckBox rowIcon = new CheckBox("Row icon", true); + CheckBox rowCaption = new CheckBox("Row caption", false); + + Table table; + + public Tables() { + setMargin(true); + setSpacing(true); + + Label h1 = new Label("Tables"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout wrap = new HorizontalLayout(); + wrap.addStyleName("wrapping"); + wrap.setSpacing(true); + addComponent(wrap); + + wrap.addComponents(hierarchical, footer, sized, expandRatios, stripes, + verticalLines, horizontalLines, borderless, headers, compact, + small, rowIndex, rowCaption, rowIcon); + + ValueChangeListener update = new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + if (table == null) { + table = new Table(); + table.setContainerDataSource(normalContainer); + addComponent(table); + } + if (hierarchical.getValue() && table instanceof Table) { + removeComponent(table); + table = new TreeTable(); + table.setContainerDataSource(hierarchicalContainer); + addComponent(table); + } else if (!hierarchical.getValue() + && table instanceof TreeTable) { + removeComponent(table); + table = new Table(); + table.setContainerDataSource(normalContainer); + addComponent(table); + } + + configure(table, footer.getValue(), sized.getValue(), + expandRatios.getValue(), stripes.getValue(), + verticalLines.getValue(), horizontalLines.getValue(), + borderless.getValue(), headers.getValue(), + compact.getValue(), small.getValue(), + rowIndex.getValue(), rowCaption.getValue(), + rowIcon.getValue()); + } + }; + + hierarchical.addValueChangeListener(update); + footer.addValueChangeListener(update); + sized.addValueChangeListener(update); + expandRatios.addValueChangeListener(update); + stripes.addValueChangeListener(update); + verticalLines.addValueChangeListener(update); + horizontalLines.addValueChangeListener(update); + borderless.addValueChangeListener(update); + headers.addValueChangeListener(update); + compact.addValueChangeListener(update); + small.addValueChangeListener(update); + rowIndex.addValueChangeListener(update); + rowCaption.addValueChangeListener(update); + rowIcon.addValueChangeListener(update); + + footer.setValue(false); + + } + + static void configure(Table table, boolean footer, boolean sized, + boolean expandRatios, boolean stripes, boolean verticalLines, + boolean horizontalLines, boolean borderless, boolean headers, + boolean compact, boolean small, boolean rowIndex, + boolean rowCaption, boolean rowIcon) { + table.setSelectable(true); + table.setMultiSelect(true); + table.setSortEnabled(true); + table.setColumnCollapsingAllowed(true); + table.setColumnReorderingAllowed(true); + table.setPageLength(6); + table.addActionHandler(ValoThemeTest.getActionHandler()); + table.setDragMode(TableDragMode.MULTIROW); + table.setDropHandler(new DropHandler() { + @Override + public AcceptCriterion getAcceptCriterion() { + return AcceptAll.get(); + } + + @Override + public void drop(DragAndDropEvent event) { + Notification.show(event.getTransferable().toString()); + } + }); + table.setColumnAlignment(ValoThemeTest.DESCRIPTION_PROPERTY, + Align.RIGHT); + table.setColumnAlignment(ValoThemeTest.INDEX_PROPERTY, Align.CENTER); + + table.removeContainerProperty("textfield"); + table.addContainerProperty("textfield", TextField.class, null); + + table.removeGeneratedColumn("textfield"); + table.addGeneratedColumn("textfield", new ColumnGenerator() { + @Override + public Object generateCell(Table source, Object itemId, + Object columnId) { + TextField tf = new TextField(); + tf.setInputPrompt("Type here…"); + return tf; + } + }); + + table.removeContainerProperty("button"); + table.addContainerProperty("button", Button.class, null); + + table.removeGeneratedColumn("button"); + table.addGeneratedColumn("button", new ColumnGenerator() { + @Override + public Object generateCell(Table source, Object itemId, + Object columnId) { + Button b = new Button("Button"); + return b; + } + }); + + table.setFooterVisible(footer); + if (footer) { + table.setColumnFooter(ValoThemeTest.CAPTION_PROPERTY, "caption"); + table.setColumnFooter(ValoThemeTest.DESCRIPTION_PROPERTY, + "description"); + table.setColumnFooter(ValoThemeTest.ICON_PROPERTY, "icon"); + table.setColumnFooter(ValoThemeTest.INDEX_PROPERTY, "index"); + } + + if (sized) { + table.setWidth("400px"); + table.setHeight("300px"); + } else { + table.setSizeUndefined(); + } + + if (expandRatios) { + if (!sized) { + table.setWidth("100%"); + } + } + table.setColumnExpandRatio(ValoThemeTest.CAPTION_PROPERTY, + expandRatios ? 1.0f : 0); + table.setColumnExpandRatio(ValoThemeTest.DESCRIPTION_PROPERTY, + expandRatios ? 1.0f : 0); + + if (!stripes) { + table.addStyleName("no-stripes"); + } else { + table.removeStyleName("no-stripes"); + } + + if (!verticalLines) { + table.addStyleName("no-vertical-lines"); + } else { + table.removeStyleName("no-vertical-lines"); + } + + if (!horizontalLines) { + table.addStyleName("no-horizontal-lines"); + } else { + table.removeStyleName("no-horizontal-lines"); + } + + if (borderless) { + table.addStyleName("borderless"); + } else { + table.removeStyleName("borderless"); + } + + if (!headers) { + table.addStyleName("no-header"); + } else { + table.removeStyleName("no-header"); + } + + if (compact) { + table.addStyleName("compact"); + } else { + table.removeStyleName("compact"); + } + + if (small) { + table.addStyleName("small"); + } else { + table.removeStyleName("small"); + } + + if (!rowIndex && !rowCaption && rowIcon) { + table.setRowHeaderMode(RowHeaderMode.HIDDEN); + } + + if (rowIndex) { + table.setRowHeaderMode(RowHeaderMode.INDEX); + } + + if (rowCaption) { + table.setRowHeaderMode(RowHeaderMode.PROPERTY); + table.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + } else { + table.setItemCaptionPropertyId(null); + } + + if (rowIcon) { + table.setRowHeaderMode(RowHeaderMode.ICON_ONLY); + table.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + } else { + table.setItemIconPropertyId(null); + } + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Tabsheets.java b/uitest/src/com/vaadin/tests/themes/valo/Tabsheets.java new file mode 100644 index 0000000000..24a249d90e --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Tabsheets.java @@ -0,0 +1,201 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.shared.ui.MarginInfo; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.TabSheet; +import com.vaadin.ui.TabSheet.SelectedTabChangeEvent; +import com.vaadin.ui.TabSheet.SelectedTabChangeListener; +import com.vaadin.ui.TabSheet.Tab; +import com.vaadin.ui.VerticalLayout; + +public class Tabsheets extends VerticalLayout implements View { + + TabSheet tabs; + + public Tabsheets() { + setMargin(true); + + Label h1 = new Label("Tabs"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout wrap = new HorizontalLayout(); + wrap.setSpacing(true); + wrap.addStyleName("wrapping"); + addComponent(wrap); + + final CheckBox closable = new CheckBox("Closable"); + closable.setImmediate(true); + wrap.addComponent(closable); + + final CheckBox overflow = new CheckBox("Overflow"); + overflow.setImmediate(true); + wrap.addComponent(overflow); + + final CheckBox caption = new CheckBox("Captions", true); + caption.setImmediate(true); + wrap.addComponent(caption); + + final CheckBox icon = new CheckBox("Icons"); + icon.setImmediate(true); + wrap.addComponent(icon); + + final CheckBox disable = new CheckBox("Disable tabs"); + disable.setImmediate(true); + wrap.addComponent(disable); + + Label h3 = new Label("Additional Styles"); + h3.addStyleName("h3"); + addComponent(h3); + + wrap = new HorizontalLayout(); + wrap.setSpacing(true); + wrap.addStyleName("wrapping"); + wrap.setMargin(new MarginInfo(false, false, true, false)); + addComponent(wrap); + + final CheckBox framed = new CheckBox("Framed", true); + framed.setImmediate(true); + wrap.addComponent(framed); + + final CheckBox centered = new CheckBox("Centered tabs"); + centered.setImmediate(true); + wrap.addComponent(centered); + + final CheckBox rightAlign = new CheckBox("Right-aligned tabs"); + rightAlign.setImmediate(true); + wrap.addComponent(rightAlign); + + final CheckBox equal = new CheckBox("Equal-width tabs"); + equal.setImmediate(true); + wrap.addComponent(equal); + + final CheckBox padded = new CheckBox("Padded tabbar"); + padded.setImmediate(true); + wrap.addComponent(padded); + + final CheckBox compact = new CheckBox("Compact"); + compact.setImmediate(true); + wrap.addComponent(compact); + + final CheckBox iconsOnTop = new CheckBox("Icons on top"); + iconsOnTop.setImmediate(true); + wrap.addComponent(iconsOnTop); + + final CheckBox selectedOnly = new CheckBox("Selected tab closable"); + selectedOnly.setImmediate(true); + wrap.addComponent(selectedOnly); + + ValueChangeListener update = new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + String style = framed.getValue() ? "framed " : ""; + style += centered.getValue() ? " centered-tabs" : ""; + style += rightAlign.getValue() ? " right-aligned-tabs" : ""; + style += equal.getValue() ? " equal-width-tabs" : ""; + style += padded.getValue() ? " padded-tabbar" : ""; + style += compact.getValue() ? " compact-tabbar" : ""; + style += iconsOnTop.getValue() ? " icons-on-top" : ""; + style += selectedOnly.getValue() ? " only-selected-closable" + : ""; + + if (tabs != null) { + removeComponent(tabs); + } + tabs = getTabSheet(caption.getValue(), style.trim(), + closable.getValue(), overflow.getValue(), + icon.getValue(), disable.getValue()); + addComponent(tabs); + } + }; + closable.addValueChangeListener(update); + overflow.addValueChangeListener(update); + caption.addValueChangeListener(update); + icon.addValueChangeListener(update); + disable.addValueChangeListener(update); + framed.addValueChangeListener(update); + centered.addValueChangeListener(update); + rightAlign.addValueChangeListener(update); + equal.addValueChangeListener(update); + padded.addValueChangeListener(update); + compact.addValueChangeListener(update); + iconsOnTop.addValueChangeListener(update); + selectedOnly.addValueChangeListener(update); + + // Generate initial view + icon.setValue(true); + } + + static TabSheet getTabSheet(boolean caption, String style, + boolean closable, boolean scrolling, boolean icon, boolean disable) { + TabSheet ts = new TabSheet(); + ts.addStyleName(style); + + for (int i = 1; i <= (scrolling ? 10 : 3); i++) { + String tabcaption = caption ? ValoThemeTest.nextString(true) + " " + + ValoThemeTest.nextString(false) : null; + + VerticalLayout content = new VerticalLayout(); + content.setMargin(true); + content.setSpacing(true); + content.addComponent(new Label("Content for tab " + i)); + if (i == 2) { + content.addComponent(new Label( + "Excepteur sint obcaecat cupiditat non proident culpa. Magna pars studiorum, prodita quaerimus.")); + } + Tab t = ts.addTab(content, tabcaption); + t.setClosable(closable); + t.setEnabled(!disable); + + // First tab is always enabled + if (i == 1) { + t.setEnabled(true); + } + + if (icon) { + t.setIcon(TestIcon.get(false)); + } + } + + ts.addSelectedTabChangeListener(new SelectedTabChangeListener() { + @Override + public void selectedTabChange(SelectedTabChangeEvent event) { + try { + Thread.sleep(1000); + } catch (InterruptedException e) { + e.printStackTrace(); + } + } + }); + + return ts; + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/TestIcon.java b/uitest/src/com/vaadin/tests/themes/valo/TestIcon.java new file mode 100644 index 0000000000..18b834f1bf --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/TestIcon.java @@ -0,0 +1,55 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import java.util.Arrays; +import java.util.Collections; +import java.util.List; + +import com.vaadin.server.FontAwesome; +import com.vaadin.server.Resource; +import com.vaadin.server.ThemeResource; + +/** + * + * @since + * @author Vaadin Ltd + */ +public class TestIcon { + + public static Resource get() { + return get(false, 32); + } + + public static Resource get(boolean isImage) { + return get(isImage, 32); + } + + public static Resource get(boolean isImage, int imageSize) { + if (!isImage) { + if (++iconCount >= ICONS.size()) { + iconCount = 0; + } + return ICONS.get(iconCount); + } + return new ThemeResource("../runo/icons/" + imageSize + "/document.png"); + } + + static List<FontAwesome> ICONS = Collections.unmodifiableList(Arrays + .asList(FontAwesome.values())); + + static int iconCount = 0; +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/TextFields.java b/uitest/src/com/vaadin/tests/themes/valo/TextFields.java new file mode 100644 index 0000000000..cbe7a8a0b3 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/TextFields.java @@ -0,0 +1,259 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.server.FontAwesome; +import com.vaadin.server.UserError; +import com.vaadin.ui.Button; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.PasswordField; +import com.vaadin.ui.RichTextArea; +import com.vaadin.ui.TextArea; +import com.vaadin.ui.TextField; +import com.vaadin.ui.VerticalLayout; + +public class TextFields extends VerticalLayout implements View { + public TextFields() { + setMargin(true); + + Label h1 = new Label("Text Fields"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + TextField tf = new TextField("Normal"); + tf.setInputPrompt("First name"); + tf.setIcon(TestIcon.get()); + row.addComponent(tf); + + tf = new TextField("Custom color"); + tf.setInputPrompt("Email"); + tf.addStyleName("color1"); + row.addComponent(tf); + + tf = new TextField("User Color"); + tf.setInputPrompt("Gender"); + tf.addStyleName("color2"); + row.addComponent(tf); + + tf = new TextField("Themed"); + tf.setInputPrompt("Age"); + tf.addStyleName("color3"); + row.addComponent(tf); + + tf = new TextField("Error"); + tf.setValue("Something’s wrong"); + tf.setComponentError(new UserError("Fix it, now!")); + row.addComponent(tf); + + tf = new TextField("Error, borderless"); + tf.setValue("Something’s wrong"); + tf.setComponentError(new UserError("Fix it, now!")); + tf.addStyleName("borderless"); + row.addComponent(tf); + + tf = new TextField("Read-only"); + tf.setInputPrompt("Nationality"); + tf.setValue("Finnish"); + tf.setReadOnly(true); + row.addComponent(tf); + + tf = new TextField("Small"); + tf.setValue("Field value"); + tf.addStyleName("small"); + row.addComponent(tf); + + tf = new TextField("Large"); + tf.setValue("Field value"); + tf.addStyleName("large"); + tf.setIcon(TestIcon.get(true)); + row.addComponent(tf); + + tf = new TextField("Icon inside"); + tf.setInputPrompt("Ooh, an icon"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get()); + row.addComponent(tf); + + tf = new TextField("Large, Icon inside"); + tf.setInputPrompt("Ooh, an icon"); + tf.addStyleName("large"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get()); + row.addComponent(tf); + + tf = new TextField("Small, Icon inside"); + tf.setInputPrompt("Ooh, an icon"); + tf.addStyleName("small"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get()); + row.addComponent(tf); + + tf = new TextField("16px supported by default"); + tf.setInputPrompt("Image icon"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get(true, 16)); + row.addComponent(tf); + + tf = new TextField(); + tf.setValue("Font, no caption"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get()); + row.addComponent(tf); + + tf = new TextField(); + tf.setValue("Image, no caption"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get(true, 16)); + row.addComponent(tf); + + CssLayout group = new CssLayout(); + group.addStyleName("v-component-group"); + row.addComponent(group); + + tf = new TextField(); + tf.setInputPrompt("Grouped with a button"); + tf.addStyleName("inline-icon"); + tf.setIcon(TestIcon.get()); + tf.setWidth("260px"); + group.addComponent(tf); + + Button button = new Button("Do It"); + // button.addStyleName("primary"); + group.addComponent(button); + + tf = new TextField("Borderless"); + tf.setInputPrompt("Write here…"); + tf.addStyleName("inline-icon"); + tf.addStyleName("borderless"); + tf.setIcon(TestIcon.get()); + row.addComponent(tf); + + tf = new TextField("Right-aligned"); + tf.setValue("1,234"); + tf.addStyleName("align-right"); + row.addComponent(tf); + + tf = new TextField("Centered"); + tf.setInputPrompt("Guess what?"); + tf.addStyleName("align-center"); + row.addComponent(tf); + + PasswordField pwf = new PasswordField("Password"); + pwf.setInputPrompt("Secret words"); + pwf.addStyleName("inline-icon"); + pwf.setIcon(FontAwesome.LOCK); + row.addComponent(pwf); + + pwf = new PasswordField("Password, right-aligned"); + pwf.setInputPrompt("Secret words"); + pwf.addStyleName("inline-icon"); + pwf.addStyleName("align-right"); + pwf.setIcon(FontAwesome.LOCK); + row.addComponent(pwf); + + pwf = new PasswordField("Password, centered"); + pwf.setInputPrompt("Secret words"); + pwf.addStyleName("inline-icon"); + pwf.addStyleName("align-center"); + pwf.setIcon(FontAwesome.LOCK); + row.addComponent(pwf); + + h1 = new Label("Text Areas"); + h1.addStyleName("h1"); + addComponent(h1); + + row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + TextArea ta = new TextArea("Normal"); + ta.setInputPrompt("Write your comment…"); + row.addComponent(ta); + + ta = new TextArea("Inline icon"); + ta.setInputPrompt("Inline icon not really working"); + ta.addStyleName("inline-icon"); + ta.setIcon(TestIcon.get()); + row.addComponent(ta); + + ta = new TextArea("Custom color"); + ta.addStyleName("color1"); + ta.setInputPrompt("Write your comment…"); + row.addComponent(ta); + + ta = new TextArea("Custom color, read-only"); + ta.addStyleName("color2"); + ta.setValue("Field value, spanning multiple lines of text"); + ta.setReadOnly(true); + row.addComponent(ta); + + ta = new TextArea("Custom color"); + ta.addStyleName("color3"); + ta.setValue("Field value, spanning multiple lines of text"); + row.addComponent(ta); + + ta = new TextArea("Small"); + ta.addStyleName("small"); + ta.setInputPrompt("Write your comment…"); + row.addComponent(ta); + + ta = new TextArea("Large"); + ta.addStyleName("large"); + ta.setInputPrompt("Write your comment…"); + row.addComponent(ta); + + ta = new TextArea("Borderless"); + ta.addStyleName("borderless"); + ta.setInputPrompt("Write your comment…"); + row.addComponent(ta); + + ta = new TextArea("Right-aligned"); + ta.addStyleName("align-right"); + ta.setValue("Field value, spanning multiple lines of text"); + row.addComponent(ta); + + ta = new TextArea("Centered"); + ta.addStyleName("align-center"); + ta.setValue("Field value, spanning multiple lines of text"); + row.addComponent(ta); + + RichTextArea rta = new RichTextArea(); + rta.setValue("<b>Some</b> <i>rich</i> content"); + row.addComponent(rta); + + rta = new RichTextArea("Read-only"); + rta.setValue("<b>Some</b> <i>rich</i> content"); + rta.setReadOnly(true); + row.addComponent(rta); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/Trees.java b/uitest/src/com/vaadin/tests/themes/valo/Trees.java new file mode 100644 index 0000000000..bb406e4f39 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/Trees.java @@ -0,0 +1,78 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.data.Container; +import com.vaadin.event.dd.DragAndDropEvent; +import com.vaadin.event.dd.DropHandler; +import com.vaadin.event.dd.acceptcriteria.AcceptAll; +import com.vaadin.event.dd.acceptcriteria.AcceptCriterion; +import com.vaadin.navigator.View; +import com.vaadin.navigator.ViewChangeListener.ViewChangeEvent; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.Notification; +import com.vaadin.ui.Tree; +import com.vaadin.ui.Tree.TreeDragMode; +import com.vaadin.ui.VerticalLayout; + +public class Trees extends VerticalLayout implements View { + public Trees() { + setMargin(true); + + Label h1 = new Label("Trees"); + h1.addStyleName("h1"); + addComponent(h1); + + HorizontalLayout row = new HorizontalLayout(); + row.addStyleName("wrapping"); + row.setSpacing(true); + addComponent(row); + + Tree tree = new Tree(); + tree.setSelectable(true); + tree.setMultiSelect(true); + Container generateContainer = ValoThemeTest.generateContainer(10, true); + tree.setContainerDataSource(generateContainer); + tree.setDragMode(TreeDragMode.NODE); + row.addComponent(tree); + tree.setItemCaptionPropertyId(ValoThemeTest.CAPTION_PROPERTY); + tree.setItemIconPropertyId(ValoThemeTest.ICON_PROPERTY); + tree.expandItem(generateContainer.getItemIds().iterator().next()); + + tree.setDropHandler(new DropHandler() { + @Override + public AcceptCriterion getAcceptCriterion() { + return AcceptAll.get(); + } + + @Override + public void drop(DragAndDropEvent event) { + Notification.show(event.getTransferable().toString()); + } + }); + + // Add actions (context menu) + tree.addActionHandler(ValoThemeTest.getActionHandler()); + } + + @Override + public void enter(ViewChangeEvent event) { + // TODO Auto-generated method stub + + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/ValoMenuLayout.java b/uitest/src/com/vaadin/tests/themes/valo/ValoMenuLayout.java new file mode 100644 index 0000000000..3a3baa686c --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/ValoMenuLayout.java @@ -0,0 +1,56 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.ui.Component; +import com.vaadin.ui.ComponentContainer; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.HorizontalLayout; + +/** + * + * @since + * @author Vaadin Ltd + */ +public class ValoMenuLayout extends HorizontalLayout { + + CssLayout contentArea = new CssLayout(); + + CssLayout menuArea = new CssLayout(); + + public ValoMenuLayout() { + setSizeFull(); + + menuArea.setPrimaryStyleName("valo-menu"); + + contentArea.setPrimaryStyleName("valo-content"); + contentArea.addStyleName("v-scrollable"); + contentArea.setSizeFull(); + + addComponents(menuArea, contentArea); + setExpandRatio(contentArea, 1); + } + + public ComponentContainer getContentContainer() { + return contentArea; + } + + public void addMenu(Component menu) { + menu.addStyleName("valo-menu-part"); + menuArea.addComponent(menu); + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/ValoMiscTests.java b/uitest/src/com/vaadin/tests/themes/valo/ValoMiscTests.java new file mode 100644 index 0000000000..222dd90e49 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/ValoMiscTests.java @@ -0,0 +1,85 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import com.vaadin.server.VaadinRequest; +import com.vaadin.ui.Alignment; +import com.vaadin.ui.Button; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.InlineDateField; +import com.vaadin.ui.Panel; +import com.vaadin.ui.TreeTable; +import com.vaadin.ui.UI; +import com.vaadin.ui.VerticalLayout; + +public class ValoMiscTests extends UI { + + VerticalLayout layout = new VerticalLayout(); + + public ValoMiscTests() { + layout.setMargin(true); + + Panel p = new Panel(); + // layout.addComponent(p); + + HorizontalLayout row = new HorizontalLayout(); + p.setHeight("300px"); + // row.setSpacing(true); + // row.setMargin(true); + row.setDefaultComponentAlignment(Alignment.BOTTOM_CENTER); + row.setWidth("100%"); + // row.setHeight("248px"); + row.setSizeFull(); + + Button button = new Button("Boo"); + button.setWidth("100%"); + Button button2 = new Button("Abc"); + button2.setWidth("100%"); + row.addComponents(button, new InlineDateField(), new CheckBox("Far")); + + p.setContent(row); + + p = new Panel(); + // layout.addComponent(p); + p.setHeight("400px"); + + VerticalLayout col = new VerticalLayout(); + col.setSizeFull(); + col.setSpacing(true); + // row.setMargin(true); + col.setDefaultComponentAlignment(Alignment.BOTTOM_CENTER); + + col.addComponents(new Button("Boo"), new InlineDateField(), + new CheckBox("Far"), new Button("Abc")); + + p.setContent(col); + + TreeTable table = new TreeTable(); + table.setWidth("100%"); + table.setContainerDataSource(Tables.hierarchicalContainer); + Tables.configure(table, true, false, false, true, true, true, false, + true, false, false, false, false, false); + layout.addComponent(table); + + } + + @Override + protected void init(VaadinRequest request) { + setContent(layout); + } + +} diff --git a/uitest/src/com/vaadin/tests/themes/valo/ValoThemeTest.java b/uitest/src/com/vaadin/tests/themes/valo/ValoThemeTest.java new file mode 100644 index 0000000000..014b1acac8 --- /dev/null +++ b/uitest/src/com/vaadin/tests/themes/valo/ValoThemeTest.java @@ -0,0 +1,364 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.themes.valo; + +import java.util.Iterator; +import java.util.LinkedHashMap; +import java.util.Map.Entry; + +import com.vaadin.annotations.PreserveOnRefresh; +import com.vaadin.annotations.Theme; +import com.vaadin.annotations.Title; +import com.vaadin.data.Container; +import com.vaadin.data.Container.Hierarchical; +import com.vaadin.data.Item; +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.data.util.HierarchicalContainer; +import com.vaadin.data.util.IndexedContainer; +import com.vaadin.event.Action; +import com.vaadin.event.Action.Handler; +import com.vaadin.navigator.Navigator; +import com.vaadin.navigator.ViewChangeListener; +import com.vaadin.server.FontAwesome; +import com.vaadin.server.Page; +import com.vaadin.server.Resource; +import com.vaadin.server.VaadinRequest; +import com.vaadin.shared.ui.label.ContentMode; +import com.vaadin.ui.Alignment; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.Component; +import com.vaadin.ui.ComponentContainer; +import com.vaadin.ui.CssLayout; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Label; +import com.vaadin.ui.MenuBar; +import com.vaadin.ui.MenuBar.MenuItem; +import com.vaadin.ui.Notification; +import com.vaadin.ui.UI; + +@Theme("tests-valo") +@Title("Valo Theme Test") +@PreserveOnRefresh +public class ValoThemeTest extends UI { + + ValoMenuLayout root = new ValoMenuLayout(); + ComponentContainer viewDisplay = root.getContentContainer(); + CssLayout menu = new CssLayout(); + private Navigator navigator; + private LinkedHashMap<String, String> menuItems = new LinkedHashMap<String, String>(); + + @Override + protected void init(VaadinRequest request) { + // Show .v-app-loading valo-menu-badge + // try { + // Thread.sleep(2000); + // } catch (InterruptedException e) { + // e.printStackTrace(); + // } + + getPage().setTitle("Valo Theme Test"); + setContent(root); + root.setWidth("100%"); + + root.addMenu(buildTestMenu()); + root.addMenu(buildMenu()); + + navigator = new Navigator(this, viewDisplay); + + navigator.addView("common", CommonParts.class); + navigator.addView("labels", Labels.class); + navigator.addView("buttons-and-links", ButtonsAndLinks.class); + navigator.addView("textfields", TextFields.class); + navigator.addView("datefields", DateFields.class); + navigator.addView("comboboxes", ComboBoxes.class); + navigator.addView("checkboxes", CheckBoxes.class); + navigator.addView("sliders", Sliders.class); + navigator.addView("menubars", MenuBars.class); + navigator.addView("panels", Panels.class); + navigator.addView("trees", Trees.class); + navigator.addView("tables", Tables.class); + navigator.addView("splitpanels", SplitPanels.class); + navigator.addView("tabs", Tabsheets.class); + navigator.addView("accordions", Accordions.class); + navigator.addView("colorpickers", ColorPickers.class); + navigator.addView("selects", NativeSelects.class); + navigator.addView("calendar", CalendarTest.class); + navigator.addView("forms", Forms.class); + navigator.addView("popupviews", PopupViews.class); + navigator.addView("dragging", Dragging.class); + + String f = Page.getCurrent().getUriFragment(); + if (f == null || f.equals("")) { + navigator.navigateTo("common"); + } + + navigator.addViewChangeListener(new ViewChangeListener() { + + @Override + public boolean beforeViewChange(ViewChangeEvent event) { + return true; + } + + @Override + public void afterViewChange(ViewChangeEvent event) { + for (Iterator<Component> it = menu.iterator(); it.hasNext();) { + it.next().removeStyleName("selected"); + } + for (Entry<String, String> item : menuItems.entrySet()) { + if (event.getViewName().equals(item.getKey())) { + for (Iterator<Component> it = menu.iterator(); it + .hasNext();) { + Component c = it.next(); + if (c.getCaption() != null + && c.getCaption().startsWith( + item.getValue())) { + c.addStyleName("selected"); + break; + } + } + break; + } + } + } + }); + + } + + Component buildTestMenu() { + CssLayout menu = new CssLayout(); + menu.addStyleName("large-icons"); + + Label logo = new Label("Va"); + logo.setSizeUndefined(); + logo.setPrimaryStyleName("valo-menu-logo"); + menu.addComponent(logo); + + Button b = new Button( + "Reference <span class=\"valo-menu-badge\">3</span>"); + b.setIcon(FontAwesome.TH_LIST); + b.setPrimaryStyleName("valo-menu-item"); + b.addStyleName("selected"); + b.setHtmlContentAllowed(true); + menu.addComponent(b); + + b = new Button("API"); + b.setIcon(FontAwesome.BOOK); + b.setPrimaryStyleName("valo-menu-item"); + menu.addComponent(b); + + b = new Button("Examples <span class=\"valo-menu-badge\">12</span>"); + b.setIcon(FontAwesome.TABLE); + b.setPrimaryStyleName("valo-menu-item"); + b.setHtmlContentAllowed(true); + menu.addComponent(b); + + return menu; + } + + CssLayout buildMenu() { + // Add items + menuItems.put("common", "Common UI Elements"); + menuItems.put("labels", "Labels"); + menuItems.put("buttons-and-links", "Buttons & Links"); + menuItems.put("textfields", "Text Fields"); + menuItems.put("datefields", "Date Fields"); + menuItems.put("comboboxes", "Combo Boxes"); + menuItems.put("selects", "Selects"); + menuItems.put("checkboxes", "Check Boxes & Option Groups"); + menuItems.put("sliders", "Sliders & Progress Bars"); + menuItems.put("colorpickers", "Color Pickers"); + menuItems.put("menubars", "Menu Bars"); + menuItems.put("trees", "Trees"); + menuItems.put("tables", "Tables"); + menuItems.put("dragging", "Drag and Drop"); + menuItems.put("panels", "Panels"); + menuItems.put("splitpanels", "Split Panels"); + menuItems.put("tabs", "Tabs"); + menuItems.put("accordions", "Accordions"); + menuItems.put("popupviews", "Popup Views"); + menuItems.put("calendar", "Calendar"); + menuItems.put("forms", "Forms"); + + HorizontalLayout top = new HorizontalLayout(); + top.setWidth("100%"); + top.setDefaultComponentAlignment(Alignment.MIDDLE_LEFT); + top.addStyleName("valo-menu-title"); + menu.addComponent(top); + + Label title = new Label("Vaadin<br><strong>Valo Theme Styles</strong>", + ContentMode.HTML); + title.setSizeUndefined(); + top.addComponent(title); + top.setExpandRatio(title, 1); + + MenuBar settings = new MenuBar(); + MenuItem settingsItem = settings.addItem("", FontAwesome.COG, null); + settingsItem.setStyleName("icon-only"); + settingsItem.addItem("Edit Profile", null); + settingsItem.addItem("Preferences", null); + settingsItem.addSeparator(); + settingsItem.addItem("Sign Out", null); + top.addComponent(settings); + + final CheckBox enabled = new CheckBox("Enabled", true); + enabled.setDescription("Enable or disable the components on the right side"); + menu.addComponent(enabled); + enabled.addValueChangeListener(new ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + viewDisplay.setEnabled(enabled.getValue()); + } + }); + + Label label = null; + int count = -1; + for (final Entry<String, String> item : menuItems.entrySet()) { + if (item.getKey().equals("labels")) { + label = new Label("Components", ContentMode.HTML); + label.setPrimaryStyleName("valo-menu-subtitle"); + label.addStyleName("h4"); + label.setSizeUndefined(); + menu.addComponent(label); + } + if (item.getKey().equals("panels")) { + label.setValue(label.getValue() + + " <span class=\"valo-menu-badge\">" + count + + "</span>"); + count = 0; + label = new Label("Containers", ContentMode.HTML); + label.setPrimaryStyleName("valo-menu-subtitle"); + label.addStyleName("h4"); + label.setSizeUndefined(); + menu.addComponent(label); + } + if (item.getKey().equals("calendar")) { + label.setValue(label.getValue() + + " <span class=\"valo-menu-badge\">" + count + + "</span>"); + count = 0; + label = new Label("Other", ContentMode.HTML); + label.setPrimaryStyleName("valo-menu-subtitle"); + label.addStyleName("h4"); + label.setSizeUndefined(); + menu.addComponent(label); + } + Button b = new Button(item.getValue(), new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + navigator.navigateTo(item.getKey()); + } + }); + if (count == 2) { + b.setCaption(b.getCaption() + + " <span class=\"valo-menu-badge\">123</span>"); + } + b.setHtmlContentAllowed(true); + b.setPrimaryStyleName("valo-menu-item"); + b.setIcon(TestIcon.get()); + menu.addComponent(b); + count++; + } + label.setValue(label.getValue() + " <span class=\"valo-menu-badge\">" + + count + "</span>"); + + return menu; + } + + static String[] strings = new String[] { "lorem", "ipsum", "dolor", "sit", + "amet", "consectetur", "quid", "securi", "etiam", "tamquam", "eu", + "fugiat", "nulla", "pariatur" }; + static int stringCount = -1; + + static String nextString(boolean capitalize) { + if (++stringCount >= strings.length) { + stringCount = 0; + } + return capitalize ? strings[stringCount].substring(0, 1).toUpperCase() + + strings[stringCount].substring(1) : strings[stringCount]; + } + + static Handler actionHandler = new Handler() { + private final Action ACTION_ONE = new Action("Action One"); + private final Action ACTION_TWO = new Action("Action Two"); + private final Action ACTION_THREE = new Action("Action Three"); + private final Action[] ACTIONS = new Action[] { ACTION_ONE, ACTION_TWO, + ACTION_THREE }; + + @Override + public void handleAction(Action action, Object sender, Object target) { + Notification.show(action.getCaption()); + } + + @Override + public Action[] getActions(Object target, Object sender) { + return ACTIONS; + } + }; + + static Handler getActionHandler() { + return actionHandler; + } + + static final String CAPTION_PROPERTY = "caption"; + static final String DESCRIPTION_PROPERTY = "description"; + static final String ICON_PROPERTY = "icon"; + static final String INDEX_PROPERTY = "index"; + + @SuppressWarnings("unchecked") + static Container generateContainer(final int size, + final boolean hierarchical) { + IndexedContainer container = hierarchical ? new HierarchicalContainer() + : new IndexedContainer(); + + container.addContainerProperty(CAPTION_PROPERTY, String.class, null); + container.addContainerProperty(ICON_PROPERTY, Resource.class, null); + container.addContainerProperty(INDEX_PROPERTY, Integer.class, null); + container + .addContainerProperty(DESCRIPTION_PROPERTY, String.class, null); + for (int i = 1; i < size + 1; i++) { + Item item = container.addItem(i); + item.getItemProperty(CAPTION_PROPERTY).setValue( + nextString(true) + " " + nextString(false)); + item.getItemProperty(INDEX_PROPERTY).setValue(i); + item.getItemProperty(DESCRIPTION_PROPERTY).setValue( + nextString(true) + " " + nextString(false) + " " + + nextString(false)); + item.getItemProperty(ICON_PROPERTY).setValue(TestIcon.get()); + } + container.getItem(container.getIdByIndex(0)) + .getItemProperty(ICON_PROPERTY).setValue(TestIcon.get()); + + if (hierarchical) { + for (int i = 1; i < size + 1; i++) { + for (int j = 1; j < 5; j++) { + String id = i + " -> " + j; + Item child = container.addItem(id); + child.getItemProperty(CAPTION_PROPERTY).setValue( + nextString(true) + " " + nextString(false)); + child.getItemProperty(ICON_PROPERTY).setValue( + TestIcon.get()); + ((Hierarchical) container).setChildrenAllowed(id, false); + ((Hierarchical) container).setParent(id, i); + } + } + } + return container; + } +}
\ No newline at end of file |