Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(397)

Side by Side Diff: chrome/browser/ui/views/try_chrome_dialog_view.h

Issue 2904823002: Inactive toast ux changes (Closed)
Patch Set: minor rename (x -> horizontal) Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_UI_VIEWS_TRY_CHROME_DIALOG_VIEW_H_ 5 #ifndef CHROME_BROWSER_UI_VIEWS_TRY_CHROME_DIALOG_VIEW_H_
6 #define CHROME_BROWSER_UI_VIEWS_TRY_CHROME_DIALOG_VIEW_H_ 6 #define CHROME_BROWSER_UI_VIEWS_TRY_CHROME_DIALOG_VIEW_H_
7 7
8 #include <stddef.h> 8 #include <stddef.h>
9 9
10 #include "base/compiler_specific.h" 10 #include "base/compiler_specific.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/time/time.h"
13 #include "chrome/browser/ui/startup/startup_browser_creator.h"
14 #include "chrome/installer/util/experiment_storage.h"
15 #include "ui/gfx/font_list.h"
12 #include "ui/gfx/geometry/rect.h" 16 #include "ui/gfx/geometry/rect.h"
13 #include "ui/gfx/geometry/size.h" 17 #include "ui/gfx/geometry/size.h"
14 #include "ui/gfx/native_widget_types.h" 18 #include "ui/gfx/native_widget_types.h"
15 #include "ui/views/controls/button/button.h" 19 #include "ui/views/controls/button/button.h"
16 #include "ui/views/controls/link_listener.h" 20 #include "url/gurl.h"
grt (UTC plus 2) 2017/06/22 20:34:04 unused?
skare_ 2017/06/22 23:25:18 Done.
17 21
18 namespace views { 22 namespace views {
19 class RadioButton;
20 class Checkbox;
21 class Widget; 23 class Widget;
22 } 24 }
23 25
24 // This class displays a modal dialog using the views system. The dialog asks 26 // This class displays a modal dialog using the views system. The dialog asks
25 // the user to give chrome another try. This class only handles the UI so the 27 // the user to give Chrome another try. This class only handles the UI so the
26 // resulting actions are up to the caller. One flavor looks like this: 28 // resulting actions are up to the caller.
29 //
30 // The layout is as follows:
27 // 31 //
28 // +-----------------------------------------------+ 32 // +-----------------------------------------------+
29 // | |icon| There is a new, safer version [x] | 33 // | |icon| Header text. [x] |
30 // | |icon| of Google Chrome available | 34 // | |
31 // | [o] Try it out (already installed) | 35 // | Body text. |
32 // | [ ] Uninstall Google Chrome | 36 // | [ Open Chrome ] [No Thanks] |
33 // | [ OK ] [Don't bug me] |
34 // | _why_am_I_seeing this?_ |
35 // +-----------------------------------------------+ 37 // +-----------------------------------------------+
36 // 38 //
37 // Another flavor looks like: 39 // Some variants do not have body text, or only have one button.
38 // +-----------------------------------------------+ 40 class TryChromeDialogView : public views::ButtonListener {
39 // | |icon| There is a new, safer version [x] |
40 // | |icon| of Google Chrome available |
41 // | [o] Try it out (already installed) |
42 // | [ ] Don't bug me |
43 // | [ OK ] |
44 // +-----------------------------------------------+
45 //
46 // And the 2013 version looks like:
47 // +-----------------------------------------------+
48 // | |icon| There is a new version of [x] |
49 // | |icon| Google Chrome available |
50 // | [o] Try it out (already installed) |
51 // | [ ] Don't bug me |
52 // | --------------------------------------------- |
53 // | [x] Make it the default browser [ OK ] |
54 // +-----------------------------------------------+
55
56 class TryChromeDialogView : public views::ButtonListener,
57 public views::LinkListener {
58 public: 41 public:
59 // Receives a handle to the active modal dialog, or NULL when the active 42 // Receives a handle to the active modal dialog, or NULL when the active
60 // dialog is dismissed. 43 // dialog is dismissed.
61 typedef base::Callback<void(gfx::NativeWindow active_dialog)> 44 typedef base::Callback<void(gfx::NativeWindow active_dialog)>
62 ActiveModalDialogListener; 45 ActiveModalDialogListener;
63 46
64 enum Result { 47 enum Result {
65 TRY_CHROME, // Launch chrome right now. 48 OPEN_CHROME, // Launch chrome right now.
66 TRY_CHROME_AS_DEFAULT, // Launch chrome and make it the default. 49 NOT_NOW, // Don't launch chrome. Exit now.
67 NOT_NOW, // Don't launch chrome. Exit now. 50 DIALOG_ERROR, // An error occurred creating the dialog.
68 UNINSTALL_CHROME, // Initiate chrome uninstall and exit.
69 DIALOG_ERROR, // An error occurred creating the dialog.
70 COUNT 51 COUNT
71 }; 52 };
72 53
73 // Shows a modal dialog asking the user to give chrome another try. See 54 // Shows a modal dialog asking the user to give chrome another try. See
74 // above for the possible outcomes of the function. This is an experimental, 55 // above for the possible outcomes of the function. This is an experimental,
75 // non-localized dialog. 56 // non-localized dialog.
76 // |flavor| can be 0, 1, 2 or 3 and selects what strings to present. 57 // |flavor| selects what strings to present and what controls are shown.
grt (UTC plus 2) 2017/06/22 20:34:04 flavor -> group throughout for consistency with th
skare_ 2017/06/22 23:25:18 Done.
77 // |listener| will be notified when the dialog becomes active and when it is 58 // |listener| will be notified when the dialog becomes active and when it is
78 // dismissed. 59 // dismissed.
79 // Note that the dialog has no parent and it will position itself in a lower 60 // Note that the dialog has no parent and it will position itself in a lower
80 // corner of the screen. The dialog does not steal focus and does not have an 61 // corner of the screen or near the Chrome taskbar button.
81 // entry in the taskbar. 62 // The dialog does not steal focus and does not have an entry in the taskbar.
82 static Result Show(size_t flavor, 63 static Result Show(size_t flavor, const ActiveModalDialogListener& listener);
83 const ActiveModalDialogListener& listener); 64
65 // Obtains the Welcome Back page to launch for a given experime.
66 static StartupBrowserCreator::WelcomeBackPage GetWelcomePageForFlavor(
grt (UTC plus 2) 2017/06/22 20:34:04 wdyt of either having the WelcomeBackPage type bei
skare_ 2017/06/22 23:25:17 moved to being an out param and removed GetWelcome
67 size_t flavor);
68
84 private: 69 private:
85 // Indicates whether the dialog is modal 70 // Indicates whether the dialog is modal
86 enum class kDialogType { 71 enum class kDialogType {
87 MODAL, // Modal dialog. 72 MODAL, // Modal dialog.
88 MODELESS, // Modeless dialog. 73 MODELESS, // Modeless dialog.
89 }; 74 };
90 75
91 // Indicates the usage type. Chrome or tests. 76 // Indicates the usage type. Chrome or tests.
92 enum class kUsageType { 77 enum class kUsageType {
93 FOR_CHROME, 78 FOR_CHROME,
(...skipping 13 matching lines...) Expand all
107 kDialogType dialog_type, 92 kDialogType dialog_type,
108 kUsageType usage_type); 93 kUsageType usage_type);
109 94
110 // Returns a screen rectangle that is fit to show the window. In particular 95 // Returns a screen rectangle that is fit to show the window. In particular
111 // it has the following properties: a) is visible and b) is attached to the 96 // it has the following properties: a) is visible and b) is attached to the
112 // bottom of the working area. For LTR machines it returns a left side 97 // bottom of the working area. For LTR machines it returns a left side
113 // rectangle and for RTL it returns a right side rectangle so that the dialog 98 // rectangle and for RTL it returns a right side rectangle so that the dialog
114 // does not compete with the standard place of the start menu. 99 // does not compete with the standard place of the start menu.
115 gfx::Rect ComputeWindowPosition(const gfx::Size& size, bool is_RTL); 100 gfx::Rect ComputeWindowPosition(const gfx::Size& size, bool is_RTL);
116 101
117 // Create a windows region that looks like a toast of width |w| and height
118 // |h|. This is best effort, so we don't care much if the operation fails.
119 void SetToastRegion(HWND window, int w, int h);
120
121 // views::ButtonListener: 102 // views::ButtonListener:
122 // We have two buttons and according to what the user clicked we set |result_| 103 // We have two buttons and according to what the user clicked we set |result_|
123 // and we should always close and end the modal loop. 104 // and we should always close and end the modal loop.
124 void ButtonPressed(views::Button* sender, const ui::Event& event) override; 105 void ButtonPressed(views::Button* sender, const ui::Event& event) override;
125 106
126 // views::LinkListener:
127 // If the user selects the link we need to fire off the default browser that
128 // by some convoluted logic should not be chrome.
129 void LinkClicked(views::Link* source, int event_flags) override;
130
131 // Controls which flavor of the heading text to use. 107 // Controls which flavor of the heading text to use.
132 size_t flavor_; 108 size_t flavor_;
133 109
134 // We don't own any of these pointers. The |popup_| owns itself and owns the 110 // Font list used by text and buttons.
135 // other views. 111 gfx::FontList font_list_;
112
113 // Bounds for Chrome icon on taskbar if pinned. Empty if not pinned.
114 // TODO(skare): Pull from https://codereview.chromium.org/2900653002
115 gfx::Rect chrome_taskbar_rect_;
116
117 // Time when the toast was displayed.
118 base::Time time_shown_;
119
120 // Unowned; |popup_| owns itself.
136 views::Widget* popup_; 121 views::Widget* popup_;
137 views::RadioButton* try_chrome_; 122
138 views::RadioButton* kill_chrome_; 123 // Experiment feedback interface.
139 views::RadioButton* dont_try_chrome_; 124 installer::ExperimentStorage storage_;
140 views::Checkbox* make_default_; 125
126 // Result of displaying the dialog: accepted, dismissed, etc.
141 Result result_; 127 Result result_;
142 128
143 DISALLOW_COPY_AND_ASSIGN(TryChromeDialogView); 129 DISALLOW_COPY_AND_ASSIGN(TryChromeDialogView);
144 }; 130 };
145 131
146 #endif // CHROME_BROWSER_UI_VIEWS_TRY_CHROME_DIALOG_VIEW_H_ 132 #endif // CHROME_BROWSER_UI_VIEWS_TRY_CHROME_DIALOG_VIEW_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698