Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/banners/app_banner_manager.h" | 5 #include "chrome/browser/banners/app_banner_manager.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/strings/string_number_conversions.h" | 12 #include "base/strings/string_number_conversions.h" |
| 13 #include "base/time/time.h" | 13 #include "base/time/time.h" |
| 14 #include "chrome/browser/banners/app_banner_metrics.h" | 14 #include "chrome/browser/banners/app_banner_metrics.h" |
| 15 #include "chrome/browser/banners/app_banner_settings_helper.h" | 15 #include "chrome/browser/banners/app_banner_settings_helper.h" |
| 16 #include "chrome/browser/browser_process.h" | 16 #include "chrome/browser/browser_process.h" |
| 17 #include "chrome/browser/engagement/site_engagement_service.h" | 17 #include "chrome/browser/engagement/site_engagement_service.h" |
| 18 #include "chrome/browser/profiles/profile.h" | 18 #include "chrome/browser/profiles/profile.h" |
| 19 #include "chrome/common/chrome_switches.h" | 19 #include "chrome/common/chrome_switches.h" |
| 20 #include "components/rappor/public/rappor_utils.h" | 20 #include "components/rappor/public/rappor_utils.h" |
| 21 #include "components/rappor/rappor_service_impl.h" | 21 #include "components/rappor/rappor_service_impl.h" |
| 22 #include "content/public/browser/navigation_handle.h" | 22 #include "content/public/browser/navigation_handle.h" |
| 23 #include "content/public/browser/render_frame_host.h" | 23 #include "content/public/browser/render_frame_host.h" |
| 24 #include "content/public/browser/web_contents.h" | 24 #include "content/public/browser/web_contents.h" |
| 25 #include "content/public/common/origin_util.h" | 25 #include "content/public/common/origin_util.h" |
| 26 #include "services/service_manager/public/cpp/interface_provider.h" | 26 #include "services/service_manager/public/cpp/interface_provider.h" |
| 27 #include "third_party/skia/include/core/SkBitmap.h" | 27 #include "third_party/skia/include/core/SkBitmap.h" |
| 28 #include "ui/display/display.h" | 28 #include "ui/display/display.h" |
|
dominickn
2016/12/19 06:23:32
Nit: remove display.h and screen.h includes.
| |
| 29 #include "ui/display/screen.h" | 29 #include "ui/display/screen.h" |
| 30 | 30 |
| 31 namespace { | 31 namespace { |
| 32 | 32 |
| 33 int gCurrentRequestID = -1; | 33 int gCurrentRequestID = -1; |
| 34 int gTimeDeltaInDaysForTesting = 0; | 34 int gTimeDeltaInDaysForTesting = 0; |
| 35 | 35 |
| 36 // Returns |size_in_px| in dp, i.e. divided by the current device scale factor. | |
| 37 int ConvertIconSizeFromPxToDp(int size_in_px) { | |
| 38 return size_in_px / | |
| 39 display::Screen::GetScreen()->GetPrimaryDisplay().device_scale_factor(); | |
| 40 } | |
| 41 | |
| 42 InstallableParams ParamsToGetManifest() { | 36 InstallableParams ParamsToGetManifest() { |
| 43 return InstallableParams(); | 37 return InstallableParams(); |
| 44 } | 38 } |
| 45 | 39 |
| 46 // Returns an InstallableParams object that requests all checks necessary for | 40 // Returns an InstallableParams object that requests all checks necessary for |
| 47 // a web app banner. | 41 // a web app banner. |
| 48 InstallableParams ParamsToPerformInstallableCheck(int ideal_icon_size_in_dp, | 42 InstallableParams ParamsToPerformInstallableCheck(int ideal_icon_size_in_px, |
| 49 int minimum_icon_size_in_dp) { | 43 int minimum_icon_size_in_px) { |
| 50 InstallableParams params; | 44 InstallableParams params; |
| 51 params.ideal_icon_size_in_dp = ideal_icon_size_in_dp; | 45 params.ideal_icon_size_in_px = ideal_icon_size_in_px; |
| 52 params.minimum_icon_size_in_dp = minimum_icon_size_in_dp; | 46 params.minimum_icon_size_in_px = minimum_icon_size_in_px; |
| 53 params.check_installable = true; | 47 params.check_installable = true; |
| 54 params.fetch_valid_icon = true; | 48 params.fetch_valid_icon = true; |
| 55 | 49 |
| 56 return params; | 50 return params; |
| 57 } | 51 } |
| 58 | 52 |
| 59 } // anonymous namespace | 53 } // anonymous namespace |
| 60 | 54 |
| 61 namespace banners { | 55 namespace banners { |
| 62 | 56 |
| (...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 185 } | 179 } |
| 186 | 180 |
| 187 std::string AppBannerManager::GetStatusParam(InstallableStatusCode code) { | 181 std::string AppBannerManager::GetStatusParam(InstallableStatusCode code) { |
| 188 if (code == NO_ACCEPTABLE_ICON || code == MANIFEST_MISSING_SUITABLE_ICON) { | 182 if (code == NO_ACCEPTABLE_ICON || code == MANIFEST_MISSING_SUITABLE_ICON) { |
| 189 return base::IntToString(InstallableManager::GetMinimumIconSizeInPx()); | 183 return base::IntToString(InstallableManager::GetMinimumIconSizeInPx()); |
| 190 } | 184 } |
| 191 | 185 |
| 192 return std::string(); | 186 return std::string(); |
| 193 } | 187 } |
| 194 | 188 |
| 195 int AppBannerManager::GetIdealIconSizeInDp() { | 189 int AppBannerManager::GetIdealIconSizeInPx() { |
| 196 return ConvertIconSizeFromPxToDp( | 190 return InstallableManager::GetMinimumIconSizeInPx(); |
| 197 InstallableManager::GetMinimumIconSizeInPx()); | |
| 198 } | 191 } |
| 199 | 192 |
| 200 int AppBannerManager::GetMinimumIconSizeInDp() { | 193 int AppBannerManager::GetMinimumIconSizeInPx() { |
| 201 return ConvertIconSizeFromPxToDp( | 194 return InstallableManager::GetMinimumIconSizeInPx(); |
| 202 InstallableManager::GetMinimumIconSizeInPx()); | |
| 203 } | 195 } |
| 204 | 196 |
| 205 base::WeakPtr<AppBannerManager> AppBannerManager::GetWeakPtr() { | 197 base::WeakPtr<AppBannerManager> AppBannerManager::GetWeakPtr() { |
| 206 return weak_factory_.GetWeakPtr(); | 198 return weak_factory_.GetWeakPtr(); |
| 207 } | 199 } |
| 208 | 200 |
| 209 bool AppBannerManager::IsDebugMode() const { | 201 bool AppBannerManager::IsDebugMode() const { |
| 210 return is_debug_mode_ || | 202 return is_debug_mode_ || |
| 211 base::CommandLine::ForCurrentProcess()->HasSwitch( | 203 base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 212 switches::kBypassAppBannerEngagementChecks); | 204 switches::kBypassAppBannerEngagementChecks); |
| (...skipping 30 matching lines...) Expand all Loading... | |
| 243 manifest_.start_url) && | 235 manifest_.start_url) && |
| 244 !IsDebugMode()) { | 236 !IsDebugMode()) { |
| 245 ReportStatus(web_contents(), ALREADY_INSTALLED); | 237 ReportStatus(web_contents(), ALREADY_INSTALLED); |
| 246 Stop(); | 238 Stop(); |
| 247 } | 239 } |
| 248 | 240 |
| 249 if (!is_active_) | 241 if (!is_active_) |
| 250 return; | 242 return; |
| 251 | 243 |
| 252 // Fetch and verify the other required information. | 244 // Fetch and verify the other required information. |
| 253 manager_->GetData(ParamsToPerformInstallableCheck(GetIdealIconSizeInDp(), | 245 manager_->GetData(ParamsToPerformInstallableCheck(GetIdealIconSizeInPx(), |
| 254 GetMinimumIconSizeInDp()), | 246 GetMinimumIconSizeInPx()), |
| 255 base::Bind(&AppBannerManager::OnDidPerformInstallableCheck, | 247 base::Bind(&AppBannerManager::OnDidPerformInstallableCheck, |
| 256 GetWeakPtr())); | 248 GetWeakPtr())); |
| 257 } | 249 } |
| 258 | 250 |
| 259 void AppBannerManager::OnDidPerformInstallableCheck( | 251 void AppBannerManager::OnDidPerformInstallableCheck( |
| 260 const InstallableData& data) { | 252 const InstallableData& data) { |
| 261 if (data.is_installable) | 253 if (data.is_installable) |
| 262 TrackDisplayEvent(DISPLAY_EVENT_WEB_APP_BANNER_REQUESTED); | 254 TrackDisplayEvent(DISPLAY_EVENT_WEB_APP_BANNER_REQUESTED); |
| 263 | 255 |
| 264 if (data.error_code != NO_ERROR_DETECTED) { | 256 if (data.error_code != NO_ERROR_DETECTED) { |
| (...skipping 270 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 535 // Simulate a non-canceled OnBannerPromptReply to show the delayed banner. | 527 // Simulate a non-canceled OnBannerPromptReply to show the delayed banner. |
| 536 // Don't reset |was_canceled_by_page_| yet for metrics purposes. | 528 // Don't reset |was_canceled_by_page_| yet for metrics purposes. |
| 537 OnBannerPromptReply(blink::mojom::AppBannerPromptReply::NONE, referrer_); | 529 OnBannerPromptReply(blink::mojom::AppBannerPromptReply::NONE, referrer_); |
| 538 } else { | 530 } else { |
| 539 // Log that the prompt request was made for when we get the prompt reply. | 531 // Log that the prompt request was made for when we get the prompt reply. |
| 540 page_requested_prompt_ = true; | 532 page_requested_prompt_ = true; |
| 541 } | 533 } |
| 542 } | 534 } |
| 543 | 535 |
| 544 } // namespace banners | 536 } // namespace banners |
| OLD | NEW |