aboutsummaryrefslogtreecommitdiffstats
path: root/uitest/src/main/java/com/vaadin/tests/widgetset/client/RunOverflowFixConnector.java
blob: 203e813a80a8607c7b64b2a79d572bcb3968794c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package com.vaadin.tests.widgetset.client;

import com.google.gwt.dom.client.Style;
import com.google.gwt.dom.client.Style.Unit;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.Element;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.HTML;
import com.google.gwt.user.client.ui.Panel;
import com.vaadin.client.ComponentConnector;
import com.vaadin.client.ConnectorHierarchyChangeEvent;
import com.vaadin.client.WidgetUtil;
import com.vaadin.client.ui.AbstractComponentContainerConnector;
import com.vaadin.client.ui.VVerticalLayout;
import com.vaadin.shared.ui.Connect;
import com.vaadin.shared.ui.orderedlayout.VerticalLayoutState;
import com.vaadin.tests.components.customlayout.OverflowAutoFix;

@SuppressWarnings("deprecation")
@Connect(OverflowAutoFix.RunOverflowFix.class)
public class RunOverflowFixConnector
        extends AbstractComponentContainerConnector {

    private static final String CONTENT1 = "Overflow:<br>Fix1 (scroll): Both scrollbars should be shown<br>Fix2 (visible): no scrollbars should be shown";
    private static final String CONTENT2 = "OverflowX:<br>Fix1 (hidden): Horizontal scrollbar should be hidden, vertical shown<br>Fix2 (scroll): Both scrollbars should be shown";
    private static final String CONTENT3 = "OverflowY:<br>Fix1 (hidden): Vertical scrollbar should be hidden, horizontal shown<br>Fix2 (auto): Both scrollbars should be shown";
    private static final String BACKGROUND = "#ddd";

    @Override
    public void init() {
        super.init();

        final Panel overflow = createScrollPanel(CONTENT1);
        overflow.addStyleName("first-scrollbar");
        final Panel overflowX = createScrollPanel(CONTENT2);
        overflowX.addStyleName("second-scrollbar");
        final Panel overflowY = createScrollPanel(CONTENT3);
        overflowY.addStyleName("third-scrollbar");

        Button runFix = new Button("Click to runWebkitOverflowAutoFix",
                (ClickHandler) event -> {
                    overflow.getElement().getStyle()
                            .setOverflow(Style.Overflow.SCROLL);
                    WidgetUtil.runWebkitOverflowAutoFix(overflow.getElement());

                    overflowX.getElement().getStyle()
                            .setOverflowX(Style.Overflow.HIDDEN);
                    WidgetUtil.runWebkitOverflowAutoFix(overflowX.getElement());

                    overflowY.getElement().getStyle()
                            .setOverflowY(Style.Overflow.HIDDEN);
                    WidgetUtil.runWebkitOverflowAutoFix(overflowY.getElement());
                });
        runFix.addStyleName("run-button-one");
        getWidget().add(runFix);

        Button runFix2 = new Button("Click to runWebkitOverflowAutoFix 2",
                (ClickHandler) event -> {
                    overflow.getElement().getStyle()
                            .setOverflow(Style.Overflow.VISIBLE);
                    WidgetUtil.runWebkitOverflowAutoFix(overflow.getElement());

                    overflowX.getElement().getStyle()
                            .setOverflowX(Style.Overflow.SCROLL);
                    WidgetUtil.runWebkitOverflowAutoFix(overflowX.getElement());

                    overflowY.getElement().getStyle()
                            .setOverflowY(Style.Overflow.AUTO);
                    WidgetUtil.runWebkitOverflowAutoFix(overflowY.getElement());
                });
        runFix2.addStyleName("run-button-two");
        getWidget().add(runFix2);

        addSpacer(10);
        getWidget().add(overflow);
        addSpacer(60);
        getWidget().add(overflowX);
        addSpacer(60);
        getWidget().add(overflowY);
    }

    private void addSpacer(double height) {
        Element spacer = DOM.createDiv();
        spacer.getStyle().setHeight(height, Unit.PX);
        spacer.getStyle().setWidth(10, Unit.PX);
        getWidget().getElement().appendChild(spacer);
    }

    private Panel createScrollPanel(String info) {
        FlowPanel outer = new FlowPanel();
        outer.setPixelSize(300, 200);
        getWidget().add(outer);

        HTML inner = new HTML(info);
        inner.setPixelSize(350, 250);
        inner.getElement().getStyle().setBackgroundColor(BACKGROUND);
        // for some reason theme sets size to 0
        inner.getElement().getStyle().setFontSize(12, Style.Unit.PX);
        outer.add(inner);

        return outer;
    }

    @Override
    public VVerticalLayout getWidget() {
        return (VVerticalLayout) super.getWidget();
    }

    @Override
    public VerticalLayoutState getState() {
        return (VerticalLayoutState) super.getState();
    }

    @Override
    public void updateCaption(ComponentConnector connector) {
    }

    @Override
    public void onConnectorHierarchyChange(
            ConnectorHierarchyChangeEvent connectorHierarchyChangeEvent) {
    }
}