Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/ui/startup/startup_tab_provider.h" | |
| 6 | |
| 7 #include "build/build_config.h" | |
| 8 #include "chrome/browser/first_run/first_run.h" | |
| 9 #include "chrome/browser/ui/chrome_pages.h" | |
| 10 #include "chrome/common/url_constants.h" | |
| 11 #include "chrome/grit/locale_settings.h" | |
| 12 #include "ui/base/l10n/l10n_util.h" | |
| 13 | |
| 14 #if defined(OS_WIN) | |
| 15 #include "base/win/windows_version.h" | |
| 16 #include "chrome/browser/profile_resetter/triggered_profile_resetter.h" | |
| 17 #include "chrome/browser/profile_resetter/triggered_profile_resetter_factory.h" | |
| 18 #endif | |
| 19 | |
| 20 namespace { | |
| 21 // Constants: Magic words used by Master Preferences files in place of a URL | |
| 22 // host to indicate that internal pages should appear on first run. | |
| 23 constexpr char kNewTabUrlHost[] = "new_tab_page"; | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Prefer to declare constants in the narrowest
| |
| 24 constexpr char kWelcomePageUrlHost[] = "welcome_page"; | |
|
Peter Kasting
2016/09/29 07:23:35
Oh dear... these are valid hostnames for intranets
tmartino
2016/09/30 20:55:02
I hate, hate, hate this too. I was horrified when
Peter Kasting
2016/09/30 21:50:03
That's something we can change over time. It woul
tmartino
2016/10/03 23:26:06
Added a line to the tech debt phase of my project
| |
| 25 } // namespace | |
| 26 | |
| 27 bool StartupTabProviderImpl::AddOnboardingTabs(StartupTabs* tabs) const { | |
| 28 #if defined(OS_WIN) | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: If it wouldn't add excessive indirection/boil
tmartino
2016/09/30 20:55:02
We discussed this quite a few patchsets ago (first
Peter Kasting
2016/09/30 21:50:03
I'm open to any working solution, and admittedly i
tmartino
2016/10/03 23:26:06
I think I'm OK with the second; for reasons of sco
| |
| 29 // Windows 10 has unique onboarding policies and content. | |
| 30 if (base::win::GetVersion() >= base::win::VERSION_WIN10) { | |
| 31 // TODO(tmartino): * Add a function, GetWin10SystemState, which gathers | |
| 32 // system state relevant to Win10 Onboarding and returns | |
| 33 // a struct. | |
| 34 // * Add a function, CheckWin10OnboardingTabPolicy, which | |
| 35 // takes such a struct as input and returns StartupTabs. | |
| 36 return false; | |
| 37 } | |
| 38 #endif | |
| 39 | |
| 40 return CheckStandardOnboardingTabPolicy(first_run::IsChromeFirstRun(), tabs); | |
| 41 } | |
| 42 | |
| 43 bool StartupTabProviderImpl::AddDistributionFirstRunTabs( | |
| 44 StartupBrowserCreator* browser_creator, | |
| 45 StartupTabs* tabs) const { | |
| 46 if (!browser_creator) | |
| 47 return false; | |
| 48 bool added_tabs = CheckMasterPrefsTabPolicy( | |
| 49 first_run::IsChromeFirstRun(), browser_creator->first_run_tabs_, tabs); | |
| 50 browser_creator->first_run_tabs_.clear(); | |
| 51 return added_tabs; | |
| 52 } | |
| 53 | |
| 54 bool StartupTabProviderImpl::AddResetTriggerTabs(Profile* profile, | |
| 55 StartupTabs* tabs) const { | |
| 56 bool has_reset_trigger = false; | |
| 57 #if defined(OS_WIN) | |
|
Peter Kasting
2016/09/29 07:23:35
Why does this code only run for Windows? it seems
| |
| 58 TriggeredProfileResetter* triggered_profile_resetter = | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Can this be const?
auto* might reduce redund
| |
| 59 TriggeredProfileResetterFactory::GetForBrowserContext(profile); | |
| 60 if (triggered_profile_resetter) | |
| 61 has_reset_trigger = triggered_profile_resetter->HasResetTrigger(); | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Or this. Not really different in this implem
| |
| 62 #endif // defined(OS_WIN) | |
| 63 return CheckResetTriggerTabPolicy(has_reset_trigger, tabs); | |
| 64 } | |
| 65 | |
| 66 bool StartupTabProviderImpl::AddPinnedTabs(StartupTabs* tabs) const { | |
| 67 // TODO(tmartino): Copy/clean up logic from | |
| 68 // StartupBrowserCreatorImpl::ProcessSpecifiedUrls. | |
| 69 return false; | |
| 70 } | |
| 71 | |
| 72 bool StartupTabProviderImpl::AddPreferencesTabs(StartupTabs* tabs) const { | |
| 73 // TODO(tmartino): Copy/clean up logic from | |
| 74 // StartupBrowserCreatorImpl::ProcessStartupUrls. | |
| 75 return false; | |
| 76 } | |
| 77 | |
| 78 // static | |
| 79 bool StartupTabProviderImpl::CheckStandardOnboardingTabPolicy( | |
| 80 bool is_first_run, | |
| 81 StartupTabs* tabs) { | |
| 82 if (is_first_run) { | |
| 83 tabs->push_back(StartupTab(GetWelcomePageUrl(), false)); | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Same emplace_back() comment applies in this f
| |
| 84 return true; | |
| 85 } | |
| 86 return false; | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Shorter:
if (is_first_run)
tabs->...
| |
| 87 } | |
| 88 | |
| 89 // static | |
| 90 bool StartupTabProviderImpl::CheckMasterPrefsTabPolicy( | |
| 91 bool is_first_run, | |
| 92 const std::vector<GURL>& first_run_tabs, | |
| 93 StartupTabs* tabs) { | |
| 94 size_t initial_size = tabs->size(); | |
| 95 if (is_first_run) { | |
| 96 tabs->reserve(initial_size + first_run_tabs.size()); | |
| 97 for (const GURL& url : first_run_tabs) { | |
| 98 if (url.host() == kNewTabUrlHost) { | |
| 99 tabs->push_back(StartupTab(GURL(chrome::kChromeUINewTabURL), false)); | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Rather than duplicate the construction of Sta
| |
| 100 } else if (url.host() == kWelcomePageUrlHost) { | |
| 101 tabs->push_back(StartupTab(GetWelcomePageUrl(), false)); | |
| 102 } else { | |
| 103 tabs->push_back(StartupTab(url, false)); | |
| 104 } | |
| 105 } | |
| 106 } | |
| 107 return tabs->size() > initial_size; | |
| 108 } | |
| 109 | |
| 110 // static | |
| 111 bool StartupTabProviderImpl::CheckResetTriggerTabPolicy( | |
| 112 bool profile_has_trigger, | |
| 113 StartupTabs* tabs) { | |
| 114 if (!profile_has_trigger) | |
| 115 return false; | |
| 116 tabs->push_back(StartupTab(GetTriggeredResetSettingsUrl(), false)); | |
| 117 return true; | |
|
Peter Kasting
2016/09/29 07:23:35
Nit: Shorter:
if (profile_has_trigger)
tabs
| |
| 118 } | |
| 119 | |
| 120 GURL GetWelcomePageUrl() { | |
| 121 return GURL(l10n_util::GetStringUTF8(IDS_WELCOME_PAGE_URL)); | |
| 122 } | |
| 123 | |
| 124 GURL GetTriggeredResetSettingsUrl() { | |
| 125 return GURL( | |
| 126 chrome::GetSettingsUrl(chrome::kTriggeredResetProfileSettingsSubPage)); | |
| 127 } | |
| OLD | NEW |