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
package org.litesoft.GWT.client.view;

import org.litesoft.GWT.client.*;
import org.litesoft.GWT.client.context.*;
import org.litesoft.GWT.client.widgets.*;
import org.litesoft.GWT.forms.client.*;
import org.litesoft.GWT.forms.client.components.*;
import org.litesoft.bo.views.*;
import org.litesoft.commonfoundation.typeutils.*;
import org.litesoft.core.*;
import org.litesoft.security.*;

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

import static org.litesoft.uispecification.FormWidgetCtrl.*;

public class LoginDialogFactory<T extends SecurityUserView<T>> implements LoginDialogViewFactory {
    @Override
    public DialogView createDialog( boolean pCancelable, Command pOnSuccess ) {
        return new LoginDialog<T>( pCancelable, pOnSuccess );
    }

    private static class LoginDialog<T extends SecurityUserView<T>> extends DialogView implements SecurityUserViewNames {
        private FormEngine mFE;

        private SecurityUserViewDataProvider<T> mDataProvider;
        private FormBinder<T> mFormBinder;
        private ButtonBase mSubmitButton;

        private boolean mCancelable;
        private Command mOnSuccess;

        public LoginDialog( boolean pCancelable, Command pOnSuccess ) {
            super( title( "Login" ), Opaqueness.Full );
            mCancelable = pCancelable;
            Objects.assertNotNull( "OnSuccess", mOnSuccess = pOnSuccess );

            ClientContext zContext = ClientContext.get();

            mDataProvider = zContext.get( SecurityUserViewDataProvider.class );
            SecurityUserViewMetaData<T> zUserViewMetaData = zContext.get( SecurityUserViewMetaData.class );

            WidgetCtrlMap zWidgetCtrlMap = new WidgetCtrlMap( VISIBLE_AND_ACTIVE_ENABLED );

            zWidgetCtrlMap.add( EDIT_ONLY.required(), aLogonEmail, aCurrentPassword );

            mFE = new FormEngine( zWidgetCtrlMap, FormEngine.Mode.EditRegular, null ) {
                @Override
                protected void changeOccurredOn( String pName, IFormComponent pComponent, boolean pChanged ) {
                    super.changeOccurredOn( pName, pComponent, pChanged );
                    setDialogErrorMessage( null );
                }

                @Override
                protected void enterPressedOn( String pName, IFormComponent pComponent, KeyboardKeyModifier pModifiers ) {
                    if ( pName.equals( aLogonEmail ) ) {
                        getNamedComponent( aCurrentPassword ).setFocus();
                    } else if ( pName.equals( aCurrentPassword ) && (mSubmitButton != null) && mSubmitButton.isEnabled() ) {
                        submitRequested();
                    } else {
                        super.enterPressedOn( pName, pComponent, pModifiers );
                    }
                }
            };
            mFormBinder = new FormBinder<T>( mFE, zUserViewMetaData );

            mContent.setHorizontalAlignment( HasHorizontalAlignment.ALIGN_CENTER );

            add( createLogonAndCurrentPassword() );
            add( new SizeableSpacer( 5 ).stretchable() );

            mFormBinder.setExistingObject( mDataProvider.createNew(), FormEngine.Mode.EditRegular );
        }

        @Override
        public boolean isCancelable() {
            return mCancelable;
        }

        private Widget createLogonAndCurrentPassword() {
            SizeableHorizontalPanel zPanel = new SizeableHorizontalPanel().stretchableHorizontally();
            zPanel.add( mFormBinder.add( aLogonEmail, 0, LOGON ) );
            zPanel.add( mFormBinder.add( aCurrentPassword, PASSWORD_LENGTH, PASSWORD ) );
            return zPanel;
        }

        @Override
        public Widget getBottomBar() {
            LeftCenterRightHorizontalPanel zActionPanel = new LeftCenterRightHorizontalPanel();
            if ( mCancelable ) {
                zActionPanel.addLeft( createCancelButton() );
            }
            zActionPanel.addRight( mFE.addEditSubmitButton( mSubmitButton = createSubmitButton() ) );
            return zActionPanel;
        }

        @Override
        public void aboutToShow() {
            super.aboutToShow();
            mFE.initialize();
        }

        @Override
        protected void justLoaded() {
            super.justLoaded();
            mFE.setFocus();
        }

        @Override
        protected void submitRequested() {
            mFormBinder.commitForm();
            final T zUserView = mFormBinder.getObject();
            mDataProvider.attemptLogin( zUserView, new SimpleDataProviderCallBack() {
                @Override
                public void error( String pError ) {
                    if ( Strings.isNotNullOrEmpty( pError ) ) {
                        setDialogErrorMessage( pError );
                    } else {
                        Scheduler.get().scheduleDeferred( mOnSuccess );
                        close();
                    }
                }
            } );
        }
    }
}

Commits for litesoft/trunk/Java/GWT/Client/src/org/litesoft/GWT/client/view/LoginDialogFactory.java

Diff revisions: vs.
Revision Author Commited Message
948 Diff Diff GeorgeS picture GeorgeS Sat 07 Jun, 2014 23:42:39 +0000

Jusefuls Formatter Updated to New Code Format

939 Diff Diff GeorgeS picture GeorgeS Mon 02 Jun, 2014 21:30:31 +0000

Extracting commonfoundation

804 Diff Diff GeorgeS picture GeorgeS Wed 15 Aug, 2012 12:48:51 +0000
802 Diff Diff GeorgeS picture GeorgeS Wed 15 Aug, 2012 04:04:47 +0000
487 Diff Diff GeorgeS picture GeorgeS Thu 08 Sep, 2011 12:06:30 +0000

More elimination of uniqueness

486 Diff Diff GeorgeS picture GeorgeS Tue 06 Sep, 2011 03:00:59 +0000
480 Diff Diff GeorgeS picture GeorgeS Sun 04 Sep, 2011 02:38:20 +0000

Progress on common User Support...

398 GeorgeS picture GeorgeS Mon 15 Aug, 2011 19:57:47 +0000