Subversion Repository Public Repository

litesoft

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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
// This Source Code is in the Public Domain per: http://unlicense.org
package org.litesoft.GWT.client.widgets.nonpublic;

import org.litesoft.GWT.client.widgets.*;
import org.litesoft.render.*;
import org.litesoft.uispecification.*;

import com.google.gwt.user.client.*;
import com.google.gwt.user.client.ui.*;

public abstract class AbstractSizableSimplePanel extends SimplePanel implements RenderableContainer,
                                                                                GwtRenderableRect,
                                                                                SingleWidgetContainer {
    private Element mStyleElement;
    private Element mContainerElement;

    private AbstractSizableSimplePanel( DIVconstrainer pDIVconstrainer, StyleSet pStyleSet, RenderContainmentApproach pContainmentApproachX,
                                        RenderContainmentApproach pContainmentApproachY ) {
        super( pDIVconstrainer.getOuterElement() );
        StyleContainerElements zSCEs = ContainerSupport.createSCEs( pDIVconstrainer.getInnerElement(), pStyleSet );
        mStyleElement = zSCEs.getStyleElement();
        Element zContainerParentElement = zSCEs.getContainerParentElement();

        pContainmentApproachX = RenderContainmentApproach.deNull( pContainmentApproachX );
        pContainmentApproachY = RenderContainmentApproach.deNull( pContainmentApproachY );

        Overflow zCombinedOverflow = ContainerSupport.getAppropriateCombinedOverflow( pContainmentApproachX, pContainmentApproachY );
        if ( zCombinedOverflow.isScrolledOrClipped() ) {
            mContainerElement = CommonElementHelper.appendToParent( DOM.createDiv(), zContainerParentElement );
            String zOverflowClass = CommonElementHelper.determineOverflowClass( zCombinedOverflow.isClipped() );
            CommonElementHelper.setStyleClass( mContainerElement, zOverflowClass );
        } else if ( zSCEs.hasStyleElement() ) {
            mContainerElement = CommonElementHelper.appendToParent( DOM.createDiv(), zContainerParentElement );
        } else {
            mContainerElement = zContainerParentElement; // Not Stylable & Overflow == _None
        }

        mRenderHelperX = new Gwt1dContainerRenderHelperX( this, pContainmentApproachX, RenderContainerChildrenPolicy.Propogate ) {
            @Override
            protected Object[] getChildObjects() {
                return getChildren();
            }
        };
        mRenderHelperY = new Gwt1dContainerRenderHelperY( this, pContainmentApproachY, RenderContainerChildrenPolicy.Propogate ) {
            @Override
            protected Object[] getChildObjects() {
                return getChildren();
            }
        };
    }

    protected AbstractSizableSimplePanel( StyleSet pStyleSet, RenderContainmentApproach pContainmentApproachX, RenderContainmentApproach pContainmentApproachY ) {
        this( CommonElementHelper.createDIVconstrainer(), pStyleSet, pContainmentApproachX, pContainmentApproachY );
    }

    protected AbstractSizableSimplePanel( StyleSet pStyleSet, RCApair pRCApair ) {
        this( pStyleSet, RCApair.deNull( pRCApair ).getRCA_X(), RCApair.deNull( pRCApair ).getRCA_Y() );
    }

    protected AbstractSizableSimplePanel( StyleSet pStyleSet, RenderContainmentApproach pContainmentApproach ) {
        this( pStyleSet, pContainmentApproach, pContainmentApproach );
    }

    protected final RenderContainerHelper mRenderHelperX;
    protected final RenderContainerHelper mRenderHelperY;

    private Widget[] getChildren() {
        Widget zWidget = getWidget();
        return (zWidget == null) ? NO_WIDGETS : new Widget[]{zWidget};
    }

    @Override
    protected Element getStyleElement() {
        return mStyleElement;
    }

    @Override
    protected Element getContainerElement() {
        return mContainerElement;
    }

    /**
     * This method is called to attach a widget browser's document (if there are any child widgets they are
     * also attached AFTER the attached flag is set).
     * <p/>
     * This method is normally overiden, and after a call to super, "renderingParticipationChanged()" is notified.
     *
     * @see Widget#onAttach()
     */
    @Override
    public void onAttach() {
        super.onAttach();
        renderingParticipationChanged();
    }

    /**
     * This method is called to detach the widget from the browser's document (if there are any child widgets
     * they are deattached BEFORE the attached flag is set).
     * <p/>
     * This method is normally overiden, and after a call to super, "renderingParticipationChanged()" is notified.
     *
     * @see Widget#onDetach()
     */
    @Override
    public void onDetach() {
        super.onDetach();
        renderingParticipationChanged();
    }

    /**
     * Sets whether this object is visible - normally overiden from "UIObject" so that "renderingParticipationChanged()" can be notified.
     *
     * @param pVisible <code>true</code> to show the object, <code>false</code>
     *                 to hide it
     */
    @Override
    public void setVisible( boolean pVisible ) {
        if ( isVisible() != pVisible ) {
            super.setVisible( pVisible );
            renderingParticipationChanged();
        }
    }

    /**
     * Sets the widget's width, overiding the method in "UIObject". Unlike the standard GWT "UIObject" method, the
     * pWidth is "assumed" to include ALL decorations (such as border, margin, and padding).  This means that a
     * subsequent call to "getOffsetWidth()" will "eventually" return the value "set"!
     * <p/>
     * This method is normally delegated to the 'X' RenderHelper
     *
     * @param pWidth the Widget's new width, in CSS px (e.g. "10")
     */
    @Override
    public void setWidth( String pWidth ) {
        Parse.andSetSize( getRenderHelperX(), pWidth );
    }

    /**
     * Sets the widget's width, unlike the standard GWT "UIObject" method, this pWidth is "assumed" to include ALL
     * decorations (such as border, margin, and padding).  This means that a subsequent call to "getOffsetWidth()"
     * will "eventually" return the value "set"!
     * <p/>
     * This method is used by the 'X' RenderHelper via the GwtRenderDimensionAdapterX to bypass the normal delegation
     * on "setWidth()" to the 'X' RenderHelper.
     *
     * @param pWidth the Widget's new width, in CSS px (e.g. "10")
     */
    @Override
    public void LLsetWidgetWidth( int pWidth ) {
        Size.set( this, GwtElementDimensionHelperX.INSTANCE, getContainerElement(), pWidth, getDecorationSizeX() );
    }

    /**
     * Remove the Widget's width, after this call subsequent calls to "getOffsetWidth()" will "eventually" return the
     * "natural" width of the Widget!
     */
    @Override
    public void clearWidth() {
        Size.clear( this, GwtElementDimensionHelperX.INSTANCE, getContainerElement() );
    }

    /**
     * Sets the widget's height, overiding the method in "UIObject". Unlike the standard GWT "UIObject" method, this
     * pHeight is "assumed" to include ALL decorations (such as border, margin, and padding).  This means that a
     * subsequent call to "getOffsetHeight()" will "eventually" return the value "set"!
     * <p/>
     * This method is normally delegated to the 'Y' RenderHelper
     *
     * @param pHeight the Widget's new height, in CSS px (e.g. "10")
     */
    @Override
    public void setHeight( String pHeight ) {
        Parse.andSetSize( getRenderHelperY(), pHeight );
    }

    /**
     * Sets the widget's height, unlike the standard GWT "UIObject" method, this pHeight is "assumed" to include ALL
     * decorations (such as border, margin, and padding).  This means that a subsequent call to "getOffsetHeight()"
     * will "eventually" return the value "set"!
     * <p/>
     * This method is used by the 'Y' RenderHelper via the GwtRenderDimensionAdapterY to bypass the normal delegation
     * on "setHeight()" to the 'Y' RenderHelper.
     *
     * @param pHeight the Widget's new height, in CSS px (e.g. "10")
     */
    @Override
    public void LLsetWidgetHeight( int pHeight ) {
        Size.set( this, GwtElementDimensionHelperY.INSTANCE, getContainerElement(), pHeight, getDecorationSizeY() );
    }

    /**
     * Remove the Widget's height, after this call subsequent calls to "getOffsetHeight()" will "eventually" return the
     * "natural" height of the Widget!
     */
    @Override
    public void clearHeight() {
        Size.clear( this, GwtElementDimensionHelperY.INSTANCE, getContainerElement() );
    }

    @Override
    public void renderingParticipationChanged() {
        RenderingParticipationChangedHelper.participationChanged( this, getWidget() );
    }

    @Override
    public RenderHelper getRenderHelperX() {
        return mRenderHelperX;
    }

    @Override
    public RenderHelper getRenderHelperY() {
        return mRenderHelperY;
    }

    /**
     * Get a Container's Decoration (or Overhead) Size in the 'X' dimension - the difference between the outside size and the inside size (what is available
     * for child widgets)
     * <p/>
     * Note: this will NOT be called until the Container is reporting proper sizes!
     */
    @Override
    public int getDecorationSizeX() {
        return DecorationSize.calculate( this, GwtElementDimensionHelperX.INSTANCE, //
                                         getElement(), getContainerElement() );
    }

    /**
     * Get a Container's Decoration (or Overhead) Size in the 'Y' dimension - the difference between the outside size and the inside size (what is available
     * for child widgets)
     * <p/>
     * Note: this will NOT be called until the Container is reporting proper sizes!
     */
    @Override
    public int getDecorationSizeY() {
        return DecorationSize.calculate( this, GwtElementDimensionHelperY.INSTANCE, //
                                         getElement(), getContainerElement() );
    }

    @Override
    public void relayout() {
        getRenderHelperX().layout();
        getRenderHelperY().layout();
    }
}

Commits for litesoft/trunk/Java/GWT/Client/src/org/litesoft/GWT/client/widgets/nonpublic/AbstractSizableSimplePanel.java

Diff revisions: vs.
Revision Author Commited Message
950 Diff Diff GeorgeS picture GeorgeS Thu 19 Jun, 2014 17:57:04 +0000

New Lines

948 Diff Diff GeorgeS picture GeorgeS Sat 07 Jun, 2014 23:42:39 +0000

Jusefuls Formatter Updated to New Code Format

947 Diff Diff GeorgeS picture GeorgeS Fri 06 Jun, 2014 23:36:56 +0000

Correct Spelling of package!

151 Diff Diff GeorgeS picture GeorgeS Thu 17 Mar, 2011 04:16:22 +0000
49 Diff Diff GeorgeS picture GeorgeS Mon 12 Apr, 2010 02:59:10 +0000

License Text

23 Diff Diff GeorgeS picture GeorgeS Wed 24 Feb, 2010 00:34:32 +0000
2 GeorgeS picture GeorgeS Sun 07 Feb, 2010 12:50:58 +0000