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 "mojo/public/cpp/bindings/interface_request.h" | 26 #include "mojo/public/cpp/bindings/interface_request.h" |
| 27 #include "services/service_manager/public/cpp/interface_provider.h" | 27 #include "services/service_manager/public/cpp/interface_provider.h" |
| 28 #include "third_party/WebKit/public/platform/modules/installation/installation.m ojom.h" | 28 #include "third_party/WebKit/public/platform/modules/installation/installation.m ojom.h" |
| 29 #include "third_party/skia/include/core/SkBitmap.h" | 29 #include "third_party/skia/include/core/SkBitmap.h" |
| 30 #include "ui/display/display.h" | 30 #include "ui/display/display.h" |
|
dominickn
2016/12/20 00:00:10
Remove display.h and screen.h includes.
pkotwicz
2016/12/20 00:28:14
Done.
| |
| 31 #include "ui/display/screen.h" | 31 #include "ui/display/screen.h" |
| 32 | 32 |
| 33 namespace { | 33 namespace { |
| 34 | 34 |
| 35 int gCurrentRequestID = -1; | 35 int gCurrentRequestID = -1; |
| 36 int gTimeDeltaInDaysForTesting = 0; | 36 int gTimeDeltaInDaysForTesting = 0; |
| 37 | 37 |
| 38 // Returns |size_in_px| in dp, i.e. divided by the current device scale factor. | |
| 39 int ConvertIconSizeFromPxToDp(int size_in_px) { | |
| 40 return size_in_px / | |
| 41 display::Screen::GetScreen()->GetPrimaryDisplay().device_scale_factor(); | |
| 42 } | |
| 43 | |
| 44 InstallableParams ParamsToGetManifest() { | 38 InstallableParams ParamsToGetManifest() { |
| 45 return InstallableParams(); | 39 return InstallableParams(); |
| 46 } | 40 } |
| 47 | 41 |
| 48 // Returns an InstallableParams object that requests all checks necessary for | 42 // Returns an InstallableParams object that requests all checks necessary for |
| 49 // a web app banner. | 43 // a web app banner. |
| 50 InstallableParams ParamsToPerformInstallableCheck(int ideal_icon_size_in_dp, | 44 InstallableParams ParamsToPerformInstallableCheck(int ideal_icon_size_in_px, |
| 51 int minimum_icon_size_in_dp) { | 45 int minimum_icon_size_in_px) { |
| 52 InstallableParams params; | 46 InstallableParams params; |
| 53 params.ideal_icon_size_in_dp = ideal_icon_size_in_dp; | 47 params.ideal_icon_size_in_px = ideal_icon_size_in_px; |
| 54 params.minimum_icon_size_in_dp = minimum_icon_size_in_dp; | 48 params.minimum_icon_size_in_px = minimum_icon_size_in_px; |
| 55 params.check_installable = true; | 49 params.check_installable = true; |
| 56 params.fetch_valid_icon = true; | 50 params.fetch_valid_icon = true; |
| 57 | 51 |
| 58 return params; | 52 return params; |
| 59 } | 53 } |
| 60 | 54 |
| 61 } // anonymous namespace | 55 } // anonymous namespace |
| 62 | 56 |
| 63 namespace banners { | 57 namespace banners { |
| 64 | 58 |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 195 } | 189 } |
| 196 | 190 |
| 197 std::string AppBannerManager::GetStatusParam(InstallableStatusCode code) { | 191 std::string AppBannerManager::GetStatusParam(InstallableStatusCode code) { |
| 198 if (code == NO_ACCEPTABLE_ICON || code == MANIFEST_MISSING_SUITABLE_ICON) { | 192 if (code == NO_ACCEPTABLE_ICON || code == MANIFEST_MISSING_SUITABLE_ICON) { |
| 199 return base::IntToString(InstallableManager::GetMinimumIconSizeInPx()); | 193 return base::IntToString(InstallableManager::GetMinimumIconSizeInPx()); |
| 200 } | 194 } |
| 201 | 195 |
| 202 return std::string(); | 196 return std::string(); |
| 203 } | 197 } |
| 204 | 198 |
| 205 int AppBannerManager::GetIdealIconSizeInDp() { | 199 int AppBannerManager::GetIdealIconSizeInPx() { |
| 206 return ConvertIconSizeFromPxToDp( | 200 return InstallableManager::GetMinimumIconSizeInPx(); |
| 207 InstallableManager::GetMinimumIconSizeInPx()); | |
| 208 } | 201 } |
| 209 | 202 |
| 210 int AppBannerManager::GetMinimumIconSizeInDp() { | 203 int AppBannerManager::GetMinimumIconSizeInPx() { |
| 211 return ConvertIconSizeFromPxToDp( | 204 return InstallableManager::GetMinimumIconSizeInPx(); |
| 212 InstallableManager::GetMinimumIconSizeInPx()); | |
| 213 } | 205 } |
| 214 | 206 |
| 215 base::WeakPtr<AppBannerManager> AppBannerManager::GetWeakPtr() { | 207 base::WeakPtr<AppBannerManager> AppBannerManager::GetWeakPtr() { |
| 216 return weak_factory_.GetWeakPtr(); | 208 return weak_factory_.GetWeakPtr(); |
| 217 } | 209 } |
| 218 | 210 |
| 219 bool AppBannerManager::IsDebugMode() const { | 211 bool AppBannerManager::IsDebugMode() const { |
| 220 return is_debug_mode_ || | 212 return is_debug_mode_ || |
| 221 base::CommandLine::ForCurrentProcess()->HasSwitch( | 213 base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 222 switches::kBypassAppBannerEngagementChecks); | 214 switches::kBypassAppBannerEngagementChecks); |
| (...skipping 30 matching lines...) Expand all Loading... | |
| 253 manifest_.start_url) && | 245 manifest_.start_url) && |
| 254 !IsDebugMode()) { | 246 !IsDebugMode()) { |
| 255 ReportStatus(web_contents(), ALREADY_INSTALLED); | 247 ReportStatus(web_contents(), ALREADY_INSTALLED); |
| 256 Stop(); | 248 Stop(); |
| 257 } | 249 } |
| 258 | 250 |
| 259 if (!is_active_) | 251 if (!is_active_) |
| 260 return; | 252 return; |
| 261 | 253 |
| 262 // Fetch and verify the other required information. | 254 // Fetch and verify the other required information. |
| 263 manager_->GetData(ParamsToPerformInstallableCheck(GetIdealIconSizeInDp(), | 255 manager_->GetData(ParamsToPerformInstallableCheck(GetIdealIconSizeInPx(), |
| 264 GetMinimumIconSizeInDp()), | 256 GetMinimumIconSizeInPx()), |
| 265 base::Bind(&AppBannerManager::OnDidPerformInstallableCheck, | 257 base::Bind(&AppBannerManager::OnDidPerformInstallableCheck, |
| 266 GetWeakPtr())); | 258 GetWeakPtr())); |
| 267 } | 259 } |
| 268 | 260 |
| 269 void AppBannerManager::OnDidPerformInstallableCheck( | 261 void AppBannerManager::OnDidPerformInstallableCheck( |
| 270 const InstallableData& data) { | 262 const InstallableData& data) { |
| 271 if (data.is_installable) | 263 if (data.is_installable) |
| 272 TrackDisplayEvent(DISPLAY_EVENT_WEB_APP_BANNER_REQUESTED); | 264 TrackDisplayEvent(DISPLAY_EVENT_WEB_APP_BANNER_REQUESTED); |
| 273 | 265 |
| 274 if (data.error_code != NO_ERROR_DETECTED) { | 266 if (data.error_code != NO_ERROR_DETECTED) { |
| (...skipping 270 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 545 // Simulate a non-canceled OnBannerPromptReply to show the delayed banner. | 537 // Simulate a non-canceled OnBannerPromptReply to show the delayed banner. |
| 546 // Don't reset |was_canceled_by_page_| yet for metrics purposes. | 538 // Don't reset |was_canceled_by_page_| yet for metrics purposes. |
| 547 OnBannerPromptReply(blink::mojom::AppBannerPromptReply::NONE, referrer_); | 539 OnBannerPromptReply(blink::mojom::AppBannerPromptReply::NONE, referrer_); |
| 548 } else { | 540 } else { |
| 549 // Log that the prompt request was made for when we get the prompt reply. | 541 // Log that the prompt request was made for when we get the prompt reply. |
| 550 page_requested_prompt_ = true; | 542 page_requested_prompt_ = true; |
| 551 } | 543 } |
| 552 } | 544 } |
| 553 | 545 |
| 554 } // namespace banners | 546 } // namespace banners |
| OLD | NEW |