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

import org.litesoft.GWT.client.widgets.*;
import org.litesoft.bo.views.*;
import org.litesoft.commonfoundation.base.*;
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 final Command mOnSuccess;

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

            centerContent();

            initializeFormInfrastructure( null )
                    .add( EDIT_ONLY.required(), aLogonEmail, aCurrentPassword );

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

            setEditUser( mDataProvider.createNew() );
        }

        @Override
        protected boolean processEnterPressedOn( String pName ) {
            if ( pName.equals( aLogonEmail ) ) {
                mFE.getNamedComponent( aCurrentPassword ).setFocus();
                return false;
            }
            if ( pName.equals( aCurrentPassword ) && (mSubmitButton != null) && mSubmitButton.isEnabled() ) {
                submitRequested();
                return false;
            }
            return true;
        }

        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
        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
957 Diff Diff GeorgeS picture GeorgeS Tue 24 Jun, 2014 12:30:01 +0000

Dialog Code Shareing

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 GeorgeS picture GeorgeS Sun 04 Sep, 2011 02:38:20 +0000

Progress on common User Support...