From f79949cc274a1fdbd865d800d567ad6d774197bd Mon Sep 17 00:00:00 2001 From: Mikael Grankvist Date: Tue, 13 Nov 2012 13:35:27 +0200 Subject: (#10180) Moved positioning from onStateChanged to onConnectorHierarchyChange. Added test. Change-Id: Iccd290a8e2be165207abe1b4805ec992d24bad0d --- .../ui/absolutelayout/AbsoluteLayoutConnector.java | 13 +++-- ...oluteLayoutCorrectPositioningOfHiddenField.html | 52 +++++++++++++++++++ ...oluteLayoutCorrectPositioningOfHiddenField.java | 59 ++++++++++++++++++++++ 3 files changed, 120 insertions(+), 4 deletions(-) create mode 100644 uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.html create mode 100644 uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.java diff --git a/client/src/com/vaadin/client/ui/absolutelayout/AbsoluteLayoutConnector.java b/client/src/com/vaadin/client/ui/absolutelayout/AbsoluteLayoutConnector.java index 106aee7ace..40830531b6 100644 --- a/client/src/com/vaadin/client/ui/absolutelayout/AbsoluteLayoutConnector.java +++ b/client/src/com/vaadin/client/ui/absolutelayout/AbsoluteLayoutConnector.java @@ -156,11 +156,15 @@ public class AbsoluteLayoutConnector extends // TODO Margin handling for (ComponentConnector child : getChildComponents()) { - getWidget().setWidgetPosition( - child.getWidget(), - getState().connectorToCssPosition.get(child - .getConnectorId())); + setChildWidgetPosition(child); } + } + + private void setChildWidgetPosition(ComponentConnector child) { + getWidget().setWidgetPosition( + child.getWidget(), + getState().connectorToCssPosition.get(child + .getConnectorId())); }; /* @@ -176,6 +180,7 @@ public class AbsoluteLayoutConnector extends if (!getWidget().contains(child.getWidget())) { getWidget().add(child.getWidget()); child.addStateChangeHandler(childStateChangeHandler); + setChildWidgetPosition(child); } } for (ComponentConnector oldChild : event.getOldChildren()) { diff --git a/uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.html b/uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.html new file mode 100644 index 0000000000..f00d6b15f9 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.html @@ -0,0 +1,52 @@ + + + + + + +AbsoluteLayoutCorrectPositioningOfHiddenField + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
AbsoluteLayoutCorrectPositioningOfHiddenField
open/run/com.vaadin.tests.components.absolutelayout.AbsoluteLayoutCorrectPositioningOfHiddenField?restartApplication
assertElementNotPresentvaadin=runcomvaadintestscomponentsabsolutelayoutAbsoluteLayoutCorrectPositioningOfHiddenField::PID_SpositionedLabel
clickvaadin=runcomvaadintestscomponentsabsolutelayoutAbsoluteLayoutCorrectPositioningOfHiddenField::PID_SactionButton
assertElementPresentvaadin=runcomvaadintestscomponentsabsolutelayoutAbsoluteLayoutCorrectPositioningOfHiddenField::PID_SpositionedLabel
screenCaptureAbsoluteLayoutLabelPositionNotOrigo
clickvaadin=runcomvaadintestscomponentsabsolutelayoutAbsoluteLayoutCorrectPositioningOfHiddenField::PID_SactionButton
screenCaptureAbsoluteLayoutLabelMovedDown
+ + diff --git a/uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.java b/uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.java new file mode 100644 index 0000000000..42ea6158fd --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/absolutelayout/AbsoluteLayoutCorrectPositioningOfHiddenField.java @@ -0,0 +1,59 @@ +package com.vaadin.tests.components.absolutelayout; + +import com.vaadin.tests.components.TestBase; +import com.vaadin.ui.AbsoluteLayout; +import com.vaadin.ui.AbsoluteLayout.ComponentPosition; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.Label; + +public class AbsoluteLayoutCorrectPositioningOfHiddenField extends TestBase { + + @Override + protected void setup() { + setTheme("tests-tickets"); + final AbsoluteLayout abs = new AbsoluteLayout(); + abs.setStyleName("borders"); + abs.setWidth("250px"); + abs.setHeight("100px"); + + final Label l = new Label("Top 20, Left 20"); + l.setSizeUndefined(); + l.setId("positionedLabel"); + l.setVisible(false); + abs.addComponent(l, "top:20px;left:20px"); + + final Button action = new Button("Set visible"); + action.addClickListener(new ClickListener() { + + @Override + public void buttonClick(ClickEvent event) { + if (l.isVisible()) { + l.setValue("Top 70, Left 20"); + ComponentPosition position = abs.getPosition(l); + position.setCSSString("top:70px;left:20px;"); + abs.setPosition(l, position); + } else { + l.setVisible(true); + action.setCaption("Move down"); + } + } + }); + action.setId("actionButton"); + abs.addComponent(action, "top: 70px;left: 150px;"); + + addComponent(abs); + } + + @Override + protected String getDescription() { + return "AbsoluteLayout should reposition invisible components when set to visible"; + } + + @Override + protected Integer getTicketNumber() { + return 10180; + } + +} -- cgit v1.2.3