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

Side by Side Diff: chrome/browser/ui/webui/chromeos/login/eula_screen_handler.cc

Issue 755203002: Added usage of ScreenContext in EulaScreen. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed comments. Created 6 years 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 #include "chrome/browser/ui/webui/chromeos/login/eula_screen_handler.h" 5 #include "chrome/browser/ui/webui/chromeos/login/eula_screen_handler.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "chrome/browser/chromeos/login/help_app_launcher.h" 10 #include "chrome/browser/chromeos/login/help_app_launcher.h"
11 #include "chrome/browser/chromeos/login/helper.h" 11 #include "chrome/browser/chromeos/login/helper.h"
12 #include "chrome/browser/chromeos/login/screens/core_oobe_actor.h" 12 #include "chrome/browser/chromeos/login/screens/core_oobe_actor.h"
13 #include "chrome/browser/chromeos/login/screens/eula_model.h"
13 #include "chrome/browser/chromeos/login/ui/login_web_dialog.h" 14 #include "chrome/browser/chromeos/login/ui/login_web_dialog.h"
14 #include "chrome/browser/chromeos/login/ui/webui_login_display.h" 15 #include "chrome/browser/chromeos/login/ui/webui_login_display.h"
15 #include "chrome/browser/profiles/profile.h" 16 #include "chrome/browser/profiles/profile.h"
16 #include "chrome/browser/ui/webui/chromeos/login/oobe_ui.h" 17 #include "chrome/browser/ui/webui/chromeos/login/oobe_ui.h"
17 #include "chrome/common/url_constants.h" 18 #include "chrome/common/url_constants.h"
18 #include "chrome/grit/chromium_strings.h" 19 #include "chrome/grit/chromium_strings.h"
19 #include "chrome/grit/generated_resources.h" 20 #include "chrome/grit/generated_resources.h"
20 #include "chrome/grit/locale_settings.h" 21 #include "chrome/grit/locale_settings.h"
21 #include "content/public/browser/web_contents.h" 22 #include "content/public/browser/web_contents.h"
22 #include "ui/base/l10n/l10n_util.h" 23 #include "ui/base/l10n/l10n_util.h"
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
73 dialog->Show(); 74 dialog->Show();
74 // The dialog object will be deleted on dialog close. 75 // The dialog object will be deleted on dialog close.
75 } 76 }
76 77
77 } // namespace 78 } // namespace
78 79
79 namespace chromeos { 80 namespace chromeos {
80 81
81 EulaScreenHandler::EulaScreenHandler(CoreOobeActor* core_oobe_actor) 82 EulaScreenHandler::EulaScreenHandler(CoreOobeActor* core_oobe_actor)
82 : BaseScreenHandler(kJsScreenPath), 83 : BaseScreenHandler(kJsScreenPath),
83 delegate_(NULL), 84 model_(NULL),
84 core_oobe_actor_(core_oobe_actor), 85 core_oobe_actor_(core_oobe_actor),
85 show_on_init_(false) { 86 show_on_init_(false) {
86 } 87 }
87 88
88 EulaScreenHandler::~EulaScreenHandler() { 89 EulaScreenHandler::~EulaScreenHandler() {
89 if (delegate_) 90 if (model_)
90 delegate_->OnActorDestroyed(this); 91 model_->OnViewDestroyed(this);
91 } 92 }
92 93
93 void EulaScreenHandler::PrepareToShow() { 94 void EulaScreenHandler::PrepareToShow() {
94 } 95 }
95 96
96 void EulaScreenHandler::Show() { 97 void EulaScreenHandler::Show() {
97 if (!page_is_ready()) { 98 if (!page_is_ready()) {
98 show_on_init_ = true; 99 show_on_init_ = true;
99 return; 100 return;
100 } 101 }
101 ShowScreen(OobeUI::kScreenOobeEula, NULL); 102 ShowScreen(OobeUI::kScreenOobeEula, NULL);
102 } 103 }
103 104
104 void EulaScreenHandler::Hide() { 105 void EulaScreenHandler::Hide() {
105 } 106 }
106 107
107 void EulaScreenHandler::SetDelegate(Delegate* delegate) { 108 void EulaScreenHandler::SetModel(EulaModel* model) {
Denis Kuznetsov (DE-MUC) 2014/11/25 17:31:17 Could you rename this to Bind/Unbind?
ygorshenin1 2014/11/26 11:45:40 Done.
108 delegate_ = delegate; 109 model_ = model;
110 BaseScreenHandler::set_base_screen(model_);
109 if (page_is_ready()) 111 if (page_is_ready())
110 Initialize(); 112 Initialize();
111 } 113 }
112 114
113 void EulaScreenHandler::DeclareLocalizedValues( 115 void EulaScreenHandler::DeclareLocalizedValues(
114 LocalizedValuesBuilder* builder) { 116 LocalizedValuesBuilder* builder) {
115 builder->Add("eulaScreenTitle", IDS_EULA_SCREEN_TITLE); 117 builder->Add("eulaScreenTitle", IDS_EULA_SCREEN_TITLE);
116 builder->Add("eulaScreenAccessibleTitle", IDS_EULA_SCREEN_ACCESSIBLE_TITLE); 118 builder->Add("eulaScreenAccessibleTitle", IDS_EULA_SCREEN_ACCESSIBLE_TITLE);
117 builder->Add("checkboxLogging", IDS_EULA_CHECKBOX_ENABLE_LOGGING); 119 builder->Add("checkboxLogging", IDS_EULA_CHECKBOX_ENABLE_LOGGING);
118 builder->Add("back", IDS_EULA_BACK_BUTTON); 120 builder->Add("back", IDS_EULA_BACK_BUTTON);
(...skipping 13 matching lines...) Expand all
132 IDS_PRODUCT_NAME); 134 IDS_PRODUCT_NAME);
133 builder->AddF("eulaRlzEnable", 135 builder->AddF("eulaRlzEnable",
134 IDS_EULA_RLZ_ENABLE, 136 IDS_EULA_RLZ_ENABLE,
135 IDS_SHORT_PRODUCT_OS_NAME); 137 IDS_SHORT_PRODUCT_OS_NAME);
136 #endif 138 #endif
137 139
138 builder->Add("chromeCreditsLink", IDS_ABOUT_VERSION_LICENSE_EULA); 140 builder->Add("chromeCreditsLink", IDS_ABOUT_VERSION_LICENSE_EULA);
139 builder->Add("chromeosCreditsLink", IDS_ABOUT_CROS_VERSION_LICENSE_EULA); 141 builder->Add("chromeosCreditsLink", IDS_ABOUT_CROS_VERSION_LICENSE_EULA);
140 } 142 }
141 143
144 void EulaScreenHandler::DeclareJSCallbacks() {
145 AddCallback("eulaAcceptButtonClicked",
146 &EulaScreenHandler::HandleAcceptButtonClicked);
147 AddCallback("eulaBackButtonClicked",
148 &EulaScreenHandler::HandleBackButtonClicked);
149 AddCallback("eulaOnLearnMore", &EulaScreenHandler::HandleOnLearnMore);
150 AddCallback("eulaOnChromeOSCredits",
151 &EulaScreenHandler::HandleOnChromeOSCredits);
152 AddCallback("eulaOnChromeCredits", &EulaScreenHandler::HandleOnChromeCredits);
153 AddCallback("eulaOnLearnMore", &EulaScreenHandler::HandleOnLearnMore);
154 AddCallback("eulaOnInstallationSettingsPopupOpened",
155 &EulaScreenHandler::HandleOnInstallationSettingsPopupOpened);
156 }
157
142 void EulaScreenHandler::GetAdditionalParameters(base::DictionaryValue* dict) { 158 void EulaScreenHandler::GetAdditionalParameters(base::DictionaryValue* dict) {
143 #if defined(ENABLE_RLZ) 159 #if defined(ENABLE_RLZ)
144 dict->SetString("rlzEnabled", "enabled"); 160 dict->SetString("rlzEnabled", "enabled");
145 #else 161 #else
146 dict->SetString("rlzEnabled", "disabled"); 162 dict->SetString("rlzEnabled", "disabled");
147 #endif 163 #endif
148 } 164 }
149 165
150 void EulaScreenHandler::Initialize() { 166 void EulaScreenHandler::Initialize() {
151 if (!page_is_ready() || !delegate_) 167 if (!page_is_ready() || !model_)
152 return; 168 return;
153 169
154 core_oobe_actor_->SetUsageStats(delegate_->IsUsageStatsEnabled()); 170 core_oobe_actor_->SetUsageStats(model_->IsUsageStatsEnabled());
155 171
156 // This OEM EULA is a file:// URL which we're unable to load in iframe. 172 // This OEM EULA is a file:// URL which we're unable to load in iframe.
157 // Instead if it's defined we use chrome://terms/oem that will load same file. 173 // Instead if it's defined we use chrome://terms/oem that will load same file.
158 if (!delegate_->GetOemEulaUrl().is_empty()) 174 if (!model_->GetOemEulaUrl().is_empty())
159 core_oobe_actor_->SetOemEulaUrl(chrome::kChromeUITermsOemURL); 175 core_oobe_actor_->SetOemEulaUrl(chrome::kChromeUITermsOemURL);
160 176
161 if (show_on_init_) { 177 if (show_on_init_) {
162 Show(); 178 Show();
163 show_on_init_ = false; 179 show_on_init_ = false;
164 } 180 }
165 } 181 }
166 182
167 void EulaScreenHandler::RegisterMessages() {
168 AddCallback("eulaOnExit", &EulaScreenHandler::HandleOnExit);
169 AddCallback("eulaOnLearnMore", &EulaScreenHandler::HandleOnLearnMore);
170 AddCallback("eulaOnChromeOSCredits",
171 &EulaScreenHandler::HandleOnChromeOSCredits);
172 AddCallback("eulaOnChromeCredits",
173 &EulaScreenHandler::HandleOnChromeCredits);
174 AddCallback("eulaOnLearnMore", &EulaScreenHandler::HandleOnLearnMore);
175 AddCallback("eulaOnInstallationSettingsPopupOpened",
176 &EulaScreenHandler::HandleOnInstallationSettingsPopupOpened);
177 }
178
179 void EulaScreenHandler::OnPasswordFetched(const std::string& tpm_password) { 183 void EulaScreenHandler::OnPasswordFetched(const std::string& tpm_password) {
180 core_oobe_actor_->SetTpmPassword(tpm_password); 184 core_oobe_actor_->SetTpmPassword(tpm_password);
181 } 185 }
182 186
183 void EulaScreenHandler::HandleOnExit(bool accepted, bool usage_stats_enabled) { 187 void EulaScreenHandler::HandleAcceptButtonClicked() {
184 if (delegate_) 188 if (model_)
185 delegate_->OnExit(accepted, usage_stats_enabled); 189 model_->OnAcceptButtonClicked();
190 }
191
192 void EulaScreenHandler::HandleBackButtonClicked() {
193 if (model_)
194 model_->OnBackButtonClicked();
186 } 195 }
187 196
188 void EulaScreenHandler::HandleOnLearnMore() { 197 void EulaScreenHandler::HandleOnLearnMore() {
189 if (!help_app_.get()) 198 if (!help_app_.get())
190 help_app_ = new HelpAppLauncher(GetNativeWindow()); 199 help_app_ = new HelpAppLauncher(GetNativeWindow());
191 help_app_->ShowHelpTopic(HelpAppLauncher::HELP_STATS_USAGE); 200 help_app_->ShowHelpTopic(HelpAppLauncher::HELP_STATS_USAGE);
192 } 201 }
193 202
194 void EulaScreenHandler::HandleOnChromeOSCredits() { 203 void EulaScreenHandler::HandleOnChromeOSCredits() {
195 ShowCreditsDialog( 204 ShowCreditsDialog(
196 Profile::FromBrowserContext( 205 Profile::FromBrowserContext(
197 web_ui()->GetWebContents()->GetBrowserContext()), 206 web_ui()->GetWebContents()->GetBrowserContext()),
198 GetNativeWindow(), 207 GetNativeWindow(),
199 IDS_ABOUT_CROS_VERSION_LICENSE_EULA, 208 IDS_ABOUT_CROS_VERSION_LICENSE_EULA,
200 GURL(chrome::kChromeUIOSCreditsURL)); 209 GURL(chrome::kChromeUIOSCreditsURL));
201 } 210 }
202 211
203 void EulaScreenHandler::HandleOnChromeCredits() { 212 void EulaScreenHandler::HandleOnChromeCredits() {
204 ShowCreditsDialog( 213 ShowCreditsDialog(
205 Profile::FromBrowserContext( 214 Profile::FromBrowserContext(
206 web_ui()->GetWebContents()->GetBrowserContext()), 215 web_ui()->GetWebContents()->GetBrowserContext()),
207 GetNativeWindow(), 216 GetNativeWindow(),
208 IDS_ABOUT_VERSION_LICENSE_EULA, 217 IDS_ABOUT_VERSION_LICENSE_EULA,
209 GURL(chrome::kChromeUICreditsURL)); 218 GURL(chrome::kChromeUICreditsURL));
210 } 219 }
211 220
212 void EulaScreenHandler::HandleOnInstallationSettingsPopupOpened() { 221 void EulaScreenHandler::HandleOnInstallationSettingsPopupOpened() {
213 if (delegate_) 222 if (model_)
214 delegate_->InitiatePasswordFetch(); 223 model_->InitiatePasswordFetch();
215 } 224 }
216 225
217 } // namespace chromeos 226 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698