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
|
// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_SYNC_SYNC_SETUP_WIZARD_H_
#define CHROME_BROWSER_SYNC_SYNC_SETUP_WIZARD_H_
#include "base/basictypes.h"
#include "gfx/native_widget_types.h"
class SyncSetupFlowContainer;
class ProfileSyncService;
class SyncSetupWizard {
public:
enum State {
// Show the Google Account login UI.
GAIA_LOGIN = 0,
// A login attempt succeeded. This will wait for an explicit transition
// (via Step) to the next state.
GAIA_SUCCESS,
// Show the screen that lets you click either "Keep everything synced" or
// "Choose which data types to sync", and checkboxes for each data type.
CHOOSE_DATA_TYPES,
// Show the screen that lets you create a passphrase (if you've never set
// one up before).
CREATE_PASSPHRASE,
// Show the screen that lets you enter the passphrase (if you've set one up
// on another machine).
ENTER_PASSPHRASE,
// Show the screen that lets you reset your passphrase (if you forgot it).
RESET_PASSPHRASE,
// The panic switch. Something went terribly wrong during setup and we
// can't recover.
FATAL_ERROR,
// The client can't set up sync at the moment due to a concurrent operation
// to clear cloud data being in progress on the server.
SETUP_ABORTED_BY_PENDING_CLEAR,
// A final state for when setup completes and it is possible it is the
// user's first time (globally speaking) as the cloud doesn't have any
// bookmarks. We show additional info in this case to explain setting up
// more computers.
DONE_FIRST_TIME,
// A catch-all done case for any setup process.
DONE
};
explicit SyncSetupWizard(ProfileSyncService* service);
~SyncSetupWizard();
// Advances the wizard to the specified state if possible, or opens a
// new dialog starting at |advance_state|. If the wizard has never ran
// through to completion, it will always attempt to do so. Otherwise, e.g
// for a transient auth failure, it will just run as far as is necessary
// based on |advance_state| (so for auth failure, up to GAIA_SUCCESS).
void Step(State advance_state);
// Whether or not a dialog is currently showing. Useful to determine
// if various buttons in the UI should be enabled or disabled.
bool IsVisible() const;
// Focus the dialog if it is already open. Does nothing if the dialog is
// not visible.
void Focus();
void SetParent(gfx::NativeWindow parent_window);
private:
// If we just need to pop open an individual dialog, say to collect
// gaia credentials in the event of a steady-state auth failure, this is
// a "discrete" run (as in not a continuous wizard flow). This returns
// the end state to pass to Run for a given |start_state|.
static State GetEndStateForDiscreteRun(State start_state);
// Helper to return whether |state| warrants starting a new flow.
static bool IsTerminalState(State state);
ProfileSyncService* service_;
SyncSetupFlowContainer* flow_container_;
gfx::NativeWindow parent_window_;
DISALLOW_COPY_AND_ASSIGN(SyncSetupWizard);
};
#endif // CHROME_BROWSER_SYNC_SYNC_SETUP_WIZARD_H_
|