AccountServerBaseFragment.java revision 6e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6
11a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler/*
21a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Copyright (C) 2010 The Android Open Source Project
31a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler *
41a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Licensed under the Apache License, Version 2.0 (the "License");
51a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * you may not use this file except in compliance with the License.
61a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * You may obtain a copy of the License at
71a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler *
81a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler *      http://www.apache.org/licenses/LICENSE-2.0
91a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler *
101a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Unless required by applicable law or agreed to in writing, software
111a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * distributed under the License is distributed on an "AS IS" BASIS,
121a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
131a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * See the License for the specific language governing permissions and
141a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * limitations under the License.
151a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler */
161a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
171a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadlerpackage com.android.email.activity.setup;
181a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
191a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadlerimport com.android.email.R;
208d22e85e459df3d94968389852859dacaf2baafeAndy Stadlerimport com.android.email.Utility;
218d22e85e459df3d94968389852859dacaf2baafeAndy Stadlerimport com.android.email.provider.EmailContent;
228d22e85e459df3d94968389852859dacaf2baafeAndy Stadlerimport com.android.email.provider.EmailContent.Account;
232731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadlerimport com.android.email.provider.EmailContent.HostAuth;
241a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
251a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadlerimport android.app.Activity;
261a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadlerimport android.app.Fragment;
271a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadlerimport android.content.Context;
288d22e85e459df3d94968389852859dacaf2baafeAndy Stadlerimport android.os.AsyncTask;
291a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadlerimport android.os.Bundle;
30112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadlerimport android.view.View;
31112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadlerimport android.view.View.OnClickListener;
32112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadlerimport android.widget.Button;
331a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
341a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler/**
351a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Common base class for server settings fragments, so they can be more easily manipulated by
361a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * AccountSettingsXL.  Provides the following common functionality:
371a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler *
381a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Activity-provided callbacks
391a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Activity callback during onAttach
401a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler * Present "Next" button and respond to its clicks
411a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler */
42fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadlerpublic abstract class AccountServerBaseFragment extends Fragment
43112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        implements AccountCheckSettingsFragment.Callbacks, OnClickListener {
44112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler
45112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    private final static String BUNDLE_KEY_SETTINGS = "AccountServerBaseFragment.settings";
461a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
471a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    protected Context mContext;
481a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    protected Callback mCallback = EmptyCallback.INSTANCE;
49112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    protected boolean mSettingsMode;
50112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    // This is null in the setup wizard screens, and non-null in AccountSettings mode
51112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    public Button mProceedButton;
528d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    // This is used to debounce multiple clicks on the proceed button (which does async work)
538d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    public boolean mProceedButtonPressed;
541a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
551a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
561a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     * Callback interface that owning activities must provide
571a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
581a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    public interface Callback {
591a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        /**
601a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler         * Called each time the user-entered input transitions between valid and invalid
611a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler         * @param enable true to enable proceed/next button, false to disable
621a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler         */
631a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        public void onEnableProceedButtons(boolean enable);
64fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler
651a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        /**
66fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler         * Called when user clicks "next".  Starts account checker.
671a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler         * @param checkMode values from {@link SetupData}
68fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler         * @param target the fragment that requested the check
691a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler         */
70fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler        public void onProceedNext(int checkMode, AccountServerBaseFragment target);
71fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler
72fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler        /**
732731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler         * Called when account checker completes.  Fragments are responsible for saving
74fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler         * own edited data;  This is primarily for the activity to do post-check navigation.
752731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler         * @param result check settings result code - success is CHECK_SETTINGS_OK
76fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler         * @param setupMode signals if we were editing or creating
77fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler         */
782731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler        public void onCheckSettingsComplete(int result, int setupMode);
791a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
801a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
811a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    private static class EmptyCallback implements Callback {
821a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        public static final Callback INSTANCE = new EmptyCallback();
831a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        @Override public void onEnableProceedButtons(boolean enable) { }
84fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler        @Override public void onProceedNext(int checkMode, AccountServerBaseFragment target) { }
852731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler        @Override public void onCheckSettingsComplete(int result, int setupMode) { }
861a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
871a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
881a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
89112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     * At constructor time, set the fragment arguments
901a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
91112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    protected void setSetupArguments(boolean settingsMode) {
92112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        Bundle b = new Bundle();
93112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        b.putBoolean(BUNDLE_KEY_SETTINGS, true);
94112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        setArguments(b);
951a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
961a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
971a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
98112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     * At onCreate time, read the fragment arguments
991a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
1001a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    @Override
1011a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    public void onCreate(Bundle savedInstanceState) {
1021a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        super.onCreate(savedInstanceState);
1031a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
104112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        // Get arguments, which modally switch us into "settings" mode (different appearance)
105112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        mSettingsMode = false;
106112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        if (getArguments() != null) {
107112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            mSettingsMode = getArguments().getBoolean(BUNDLE_KEY_SETTINGS);
108112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        }
1098d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
1108d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        mProceedButtonPressed = false;
1111a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
1121a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
113112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    /**
114112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     * Called from onCreateView, to do settings mode configuration
115112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     */
116112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    protected void onCreateViewSettingsMode(View view) {
117112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        if (mSettingsMode) {
118112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            view.findViewById(R.id.cancel).setOnClickListener(this);
119112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            mProceedButton = (Button) view.findViewById(R.id.done);
120112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            mProceedButton.setOnClickListener(this);
121112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            mProceedButton.setEnabled(false);
122e6c6587b04a589eeb04006f75759c09ea10811e0Andy Stadler        }
1231a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
1241a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
1251a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
126112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     * Called when a fragment is first attached to its activity.
127112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     * {@link #onCreate(Bundle)} will be called after this.
1281a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
1291a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    @Override
130112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    public void onAttach(Activity activity) {
131112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        super.onAttach(activity);
132112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        mContext = activity;
133112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler
134112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        // Notify the activity that we're here.
135112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        if (activity instanceof AccountSettingsXL) {
136112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            ((AccountSettingsXL)activity).onAttach(this);
137e6c6587b04a589eeb04006f75759c09ea10811e0Andy Stadler        }
1381a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
1391a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
1401a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
141112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler     * Implements OnClickListener
1421a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
1431a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    @Override
144112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler    public void onClick(View v) {
145112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        switch (v.getId()) {
146112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            case R.id.cancel:
147112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler                getActivity().onBackPressed();
148112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler                break;
149112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            case R.id.done:
1508d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                // Simple debounce - just ignore while checks are underway
1518d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                if (mProceedButtonPressed) {
1528d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                    return;
1538d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                }
1548d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                mProceedButtonPressed = true;
1551a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler                onNext();
156112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler                break;
1571a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        }
1581a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
1591a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
1601a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
1611a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     * Activity provides callbacks here.
1621a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
1631a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    public void setCallback(Callback callback) {
1641a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        mCallback = (callback == null) ? EmptyCallback.INSTANCE : callback;
1651a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        mContext = getActivity();
1661a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
1671a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
1681a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
1691a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     * Enable/disable the "next" button
1701a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
1711a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    public void enableNextButton(boolean enable) {
172112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        // If we are in settings "mode" we may be showing our own next button, and we'll
173112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        // enable it directly, here
174112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        if (mProceedButton != null) {
175112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler            mProceedButton.setEnabled(enable);
1761a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        }
1771a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
178112ed496f817ebeab6b1ee1d5117259ef80342b2Andy Stadler        // TODO: This supports the phone UX activities and will be removed
1791a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler        mCallback.onEnableProceedButtons(enable);
1801a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    }
1811a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
1821a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
1838d22e85e459df3d94968389852859dacaf2baafeAndy Stadler     * Performs async operations as part of saving changes to the settings.
1848d22e85e459df3d94968389852859dacaf2baafeAndy Stadler     *      Check for duplicate account
1858d22e85e459df3d94968389852859dacaf2baafeAndy Stadler     *      Display dialog if necessary
1868d22e85e459df3d94968389852859dacaf2baafeAndy Stadler     *      Else, proceed via mCallback.onProceedNext
1878d22e85e459df3d94968389852859dacaf2baafeAndy Stadler     */
1888d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    protected void startDuplicateTaskCheck(long accountId, String checkHost, String checkLogin,
1898d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            int checkSettingsMode) {
1908d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        new DuplicateCheckTask(accountId, checkHost, checkLogin, checkSettingsMode).execute();
1918d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    }
1928d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
1938d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    private class DuplicateCheckTask extends AsyncTask<Void, Void, Account> {
1948d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
1958d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        private final long mAccountId;
1968d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        private final String mCheckHost;
1978d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        private final String mCheckLogin;
1988d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        private final int mCheckSettingsMode;
1998d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
2008d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        public DuplicateCheckTask(long accountId, String checkHost, String checkLogin,
2018d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                int checkSettingsMode) {
2028d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            mAccountId = accountId;
2038d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            mCheckHost = checkHost;
2048d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            mCheckLogin = checkLogin;
2058d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            mCheckSettingsMode = checkSettingsMode;
2068d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        }
2078d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
2088d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        @Override
2098d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        protected Account doInBackground(Void... params) {
2108d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            EmailContent.Account account = Utility.findExistingAccount(mContext, mAccountId,
2118d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                    mCheckHost, mCheckLogin);
2128d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            return account;
2138d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        }
2148d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
2158d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        @Override
2168d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        protected void onPostExecute(Account duplicateAccount) {
2178d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            AccountServerBaseFragment fragment = AccountServerBaseFragment.this;
2188d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            if (duplicateAccount != null) {
2198d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                // Show duplicate account warning
2208d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                DuplicateAccountDialogFragment dialogFragment =
2218d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                    DuplicateAccountDialogFragment.newInstance(duplicateAccount.mDisplayName);
2228d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                dialogFragment.show(fragment.getFragmentManager(),
2238d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                        DuplicateAccountDialogFragment.TAG);
2248d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            } else {
2258d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                // Otherwise, proceed with the save/check
2268d22e85e459df3d94968389852859dacaf2baafeAndy Stadler                mCallback.onProceedNext(mCheckSettingsMode, fragment);
2278d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            }
2288d22e85e459df3d94968389852859dacaf2baafeAndy Stadler            mProceedButtonPressed = false;
2298d22e85e459df3d94968389852859dacaf2baafeAndy Stadler        }
2308d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    }
2318d22e85e459df3d94968389852859dacaf2baafeAndy Stadler
2328d22e85e459df3d94968389852859dacaf2baafeAndy Stadler    /**
233fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler     * Implements AccountCheckSettingsFragment.Callbacks
234fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler     *
2356e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler     * Handle OK or error result from check settings.  Save settings (async), and then
2366e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler     * exit to previous fragment.
23755110ca1ad8ce48a5429f9f351d013691c10b806Andrew Stadler     */
238fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler    @Override
2396e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler    public void onCheckSettingsComplete(final int settingsResult) {
2406e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler        new AsyncTask<Void, Void, Void>() {
2416e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler            @Override
2426e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler            protected Void doInBackground(Void... params) {
2436e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                if (settingsResult == AccountCheckSettingsFragment.CHECK_SETTINGS_OK) {
2446e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                    if (SetupData.getFlowMode() == SetupData.FLOW_MODE_EDIT) {
2456e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                        saveSettingsAfterEdit();
2466e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                    } else {
2476e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                        saveSettingsAfterSetup();
2486e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                    }
2496e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                }
2506e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                return null;
2512731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler            }
2526e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler
2536e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler            @Override
2546e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler            protected void onPostExecute(Void result) {
2556e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                // Signal to owning activity that a settings check completed
2566e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler                mCallback.onCheckSettingsComplete(settingsResult, SetupData.getFlowMode());
2576e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler            }
2586e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler        }.execute();
2592731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler    }
2602731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler
2612731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler    /**
2622731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler     * Implements AccountCheckSettingsFragment.Callbacks
2632731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler     * This is overridden only by AccountSetupExchange
2642731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler     */
2652731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler    @Override
2662731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler    public void onAutoDiscoverComplete(int result, HostAuth hostAuth) {
2672731aef45c6f2f9792ae698ebf7d65ca6338a02cAndrew Stadler        throw new IllegalStateException();
26855110ca1ad8ce48a5429f9f351d013691c10b806Andrew Stadler    }
26955110ca1ad8ce48a5429f9f351d013691c10b806Andrew Stadler
27055110ca1ad8ce48a5429f9f351d013691c10b806Andrew Stadler    /**
2711a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     * Save settings after "OK" result from checker.  Concrete classes must implement.
2726e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler     * This is called from a worker thread and is allowed to perform DB operations.
2731a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
2741a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    public abstract void saveSettingsAfterEdit();
2751a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler
2761a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    /**
277fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler     * Save settings after "OK" result from checker.  Concrete classes must implement.
2786e71978ec38add2edf3ac5f3dd1f9abeea9c1ab6Andy Stadler     * This is called from a worker thread and is allowed to perform DB operations.
279fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler     */
280fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler    public abstract void saveSettingsAfterSetup();
281fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler
282fd14496c494a0d38c35c3788c9cc55f1984592e4Andrew Stadler    /**
2831a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     * Respond to a click of the "Next" button.  Concrete classes must implement.
2841a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler     */
2851a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler    public abstract void onNext();
2861a5e1e159352f6e21bde878eebca3e3a1896045cAndrew Stadler}
287