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
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.base.*;
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 AbstractSecurityDialogView<T> implements SecurityUserViewNames {
        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;
            Confirm.isNotNull( "OnSuccess", mOnSuccess = pOnSuccess );

            ClientContext zContext = ClientContext.get();

            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, mUserViewMetaData );

            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 ( Currently.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
955 Diff Diff GeorgeS picture GeorgeS Sun 22 Jun, 2014 18:11:25 +0000

Add Instance...

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

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