Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/views/toolbar/site_chip_view.h" | 5 #include "chrome/browser/ui/views/toolbar/site_chip_view.h" |
| 6 | 6 |
| 7 #include "base/files/file_path.h" | 7 #include "base/files/file_path.h" |
| 8 #include "base/metrics/histogram.h" | |
| 8 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
| 9 #include "base/strings/string_util.h" | 10 #include "base/strings/string_util.h" |
| 10 #include "base/strings/utf_string_conversions.h" | 11 #include "base/strings/utf_string_conversions.h" |
| 11 #include "chrome/browser/browser_process.h" | 12 #include "chrome/browser/browser_process.h" |
| 12 #include "chrome/browser/extensions/extension_icon_image.h" | 13 #include "chrome/browser/extensions/extension_icon_image.h" |
| 13 #include "chrome/browser/extensions/extension_service.h" | 14 #include "chrome/browser/extensions/extension_service.h" |
| 14 #include "chrome/browser/extensions/extension_system.h" | 15 #include "chrome/browser/extensions/extension_system.h" |
| 15 #include "chrome/browser/favicon/favicon_tab_helper.h" | 16 #include "chrome/browser/favicon/favicon_tab_helper.h" |
| 16 #include "chrome/browser/profiles/profile.h" | 17 #include "chrome/browser/profiles/profile.h" |
| 17 #include "chrome/browser/safe_browsing/client_side_detection_host.h" | 18 #include "chrome/browser/safe_browsing/client_side_detection_host.h" |
| 18 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 19 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 19 #include "chrome/browser/safe_browsing/safe_browsing_tab_observer.h" | 20 #include "chrome/browser/safe_browsing/safe_browsing_tab_observer.h" |
| 20 #include "chrome/browser/safe_browsing/ui_manager.h" | 21 #include "chrome/browser/safe_browsing/ui_manager.h" |
| 21 #include "chrome/browser/search/search.h" | 22 #include "chrome/browser/search/search.h" |
| 22 #include "chrome/browser/themes/theme_properties.h" | 23 #include "chrome/browser/themes/theme_properties.h" |
| 23 #include "chrome/browser/ui/browser.h" | 24 #include "chrome/browser/ui/browser.h" |
| 24 #include "chrome/browser/ui/omnibox/omnibox_view.h" | 25 #include "chrome/browser/ui/omnibox/omnibox_view.h" |
| 25 #include "chrome/browser/ui/toolbar/toolbar_model.h" | 26 #include "chrome/browser/ui/toolbar/toolbar_model.h" |
| 26 #include "chrome/browser/ui/views/location_bar/location_bar_view.h" | 27 #include "chrome/browser/ui/views/location_bar/location_bar_view.h" |
| 27 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" | 28 #include "chrome/browser/ui/views/toolbar/toolbar_view.h" |
| 28 #include "chrome/common/extensions/extension_constants.h" | 29 #include "chrome/common/extensions/extension_constants.h" |
| 29 #include "chrome/common/extensions/manifest_handlers/icons_handler.h" | 30 #include "chrome/common/extensions/manifest_handlers/icons_handler.h" |
| 30 #include "chrome/common/pref_names.h" | 31 #include "chrome/common/pref_names.h" |
| 31 #include "chrome/common/url_constants.h" | 32 #include "chrome/common/url_constants.h" |
| 33 #include "content/public/browser/user_metrics.h" | |
| 32 #include "content/public/browser/web_contents.h" | 34 #include "content/public/browser/web_contents.h" |
| 33 #include "content/public/common/url_constants.h" | 35 #include "content/public/common/url_constants.h" |
| 34 #include "extensions/common/constants.h" | 36 #include "extensions/common/constants.h" |
| 35 #include "grit/component_strings.h" | 37 #include "grit/component_strings.h" |
| 36 #include "grit/generated_resources.h" | 38 #include "grit/generated_resources.h" |
| 37 #include "grit/theme_resources.h" | 39 #include "grit/theme_resources.h" |
| 38 #include "net/base/net_util.h" | 40 #include "net/base/net_util.h" |
| 39 #include "ui/base/l10n/l10n_util.h" | 41 #include "ui/base/l10n/l10n_util.h" |
| 40 #include "ui/base/resource/resource_bundle.h" | 42 #include "ui/base/resource/resource_bundle.h" |
| 41 #include "ui/base/theme_provider.h" | 43 #include "ui/base/theme_provider.h" |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 94 if (icon_view_) | 96 if (icon_view_) |
| 95 icon_view_->SetImage(&icon_image_->image_skia()); | 97 icon_view_->SetImage(&icon_image_->image_skia()); |
| 96 } | 98 } |
| 97 | 99 |
| 98 | 100 |
| 99 // SiteChipView --------------------------------------------------------------- | 101 // SiteChipView --------------------------------------------------------------- |
| 100 | 102 |
| 101 namespace { | 103 namespace { |
| 102 | 104 |
| 103 const int kEdgeThickness = 5; | 105 const int kEdgeThickness = 5; |
| 104 const int k16x16IconLeadingSpacing = 3; | 106 const int k16x16IconLeadingSpacing = 1; |
| 105 const int k16x16IconTrailingSpacing = 3; | 107 const int k16x16IconTrailingSpacing = 2; |
| 106 const int kIconTextSpacing = 3; | 108 const int kIconTextSpacing = 3; |
| 107 const int kTrailingLabelMargin = 0; | 109 const int kTrailingLabelMargin = 0; |
| 108 | 110 |
| 111 const SkColor kEVBackgroundColor = SkColorSetRGB(163, 226, 120); | |
| 112 const SkColor kMalwareBackgroundColor = SkColorSetRGB(145, 0, 0); | |
| 113 const SkColor kBrokenSSLBackgroundColor = SkColorSetRGB(253, 196, 36); | |
|
Peter Kasting
2013/12/18 00:33:35
Do we want these colors on every possible toolbar
Greg Billock
2013/12/18 16:43:07
That's a good question. The images have a bit of t
Peter Kasting
2013/12/18 21:30:59
I think rather than hardcode these values (which m
| |
| 114 | |
| 109 // Detect client-side or SB malware/phishing hits. | 115 // Detect client-side or SB malware/phishing hits. |
| 110 bool IsMalware(const GURL& url, content::WebContents* tab) { | 116 bool IsMalware(const GURL& url, content::WebContents* tab) { |
| 111 if (tab->GetURL() != url) | 117 if (tab->GetURL() != url) |
| 112 return false; | 118 return false; |
| 113 | 119 |
| 114 safe_browsing::SafeBrowsingTabObserver* sb_observer = | 120 safe_browsing::SafeBrowsingTabObserver* sb_observer = |
| 115 safe_browsing::SafeBrowsingTabObserver::FromWebContents(tab); | 121 safe_browsing::SafeBrowsingTabObserver::FromWebContents(tab); |
| 116 return sb_observer && sb_observer->detection_host() && | 122 return sb_observer && sb_observer->detection_host() && |
| 117 sb_observer->detection_host()->DidPageReceiveSafeBrowsingMatch(); | 123 sb_observer->detection_host()->DidPageReceiveSafeBrowsingMatch(); |
| 118 } | 124 } |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 320 | 326 |
| 321 if ((url == url_displayed_) && | 327 if ((url == url_displayed_) && |
| 322 (security_level == security_level_) && | 328 (security_level == security_level_) && |
| 323 (url_malware == url_malware_)) | 329 (url_malware == url_malware_)) |
| 324 return; | 330 return; |
| 325 | 331 |
| 326 url_displayed_ = url; | 332 url_displayed_ = url; |
| 327 url_malware_ = url_malware; | 333 url_malware_ = url_malware; |
| 328 security_level_ = security_level; | 334 security_level_ = security_level; |
| 329 | 335 |
| 330 if (url_malware_) | 336 SkColor label_background = |
| 337 GetThemeProvider()->GetColor(ThemeProperties::COLOR_TOOLBAR); | |
| 338 if (url_malware_) { | |
| 331 painter_ = malware_background_painter_.get(); | 339 painter_ = malware_background_painter_.get(); |
| 332 else if (security_level_ == ToolbarModel::SECURITY_ERROR) | 340 label_background = kMalwareBackgroundColor; |
| 341 } else if (security_level_ == ToolbarModel::SECURITY_ERROR) { | |
| 333 painter_ = broken_ssl_background_painter_.get(); | 342 painter_ = broken_ssl_background_painter_.get(); |
| 334 else if (security_level_ == ToolbarModel::EV_SECURE) | 343 label_background = kBrokenSSLBackgroundColor; |
| 344 } else if (security_level_ == ToolbarModel::EV_SECURE) { | |
| 335 painter_ = ev_background_painter_.get(); | 345 painter_ = ev_background_painter_.get(); |
| 336 else | 346 label_background = kEVBackgroundColor; |
| 347 } else { | |
| 337 painter_ = NULL; | 348 painter_ = NULL; |
| 349 } | |
| 338 | 350 |
| 339 string16 host = SiteLabelFromURL(url_displayed_); | 351 string16 host = SiteLabelFromURL(url_displayed_); |
| 340 if (security_level_ == ToolbarModel::EV_SECURE) { | 352 if (security_level_ == ToolbarModel::EV_SECURE) { |
| 341 host = l10n_util::GetStringFUTF16(IDS_SITE_CHIP_EV_SSL_LABEL, | 353 host = l10n_util::GetStringFUTF16(IDS_SITE_CHIP_EV_SSL_LABEL, |
| 342 toolbar_view_->GetToolbarModel()->GetEVCertName(), | 354 toolbar_view_->GetToolbarModel()->GetEVCertName(), |
| 343 host); | 355 host); |
| 344 } | 356 } |
| 345 | 357 |
| 346 host_label_->SetText(host); | 358 host_label_->SetText(host); |
| 347 host_label_->SetTooltipText(host); | 359 host_label_->SetTooltipText(host); |
| 348 // TODO(gbillock): Instead of this, just set | 360 host_label_->SetBackgroundColor(label_background); |
|
Peter Kasting
2013/12/18 00:33:35
Hmm, maybe we should be using GetReadableColor() s
Greg Billock
2013/12/18 16:43:07
Michael helped me work this out -- that's what Lab
| |
| 349 // host_label_->SetBackgroundColor() to either the COLOR_TOOLBAR or | |
| 350 // the painter background color if we're using a background painter. | |
| 351 SkColor toolbar_background = | |
| 352 GetThemeProvider()->GetColor(ThemeProperties::COLOR_TOOLBAR); | |
| 353 host_label_->SetEnabledColor( | |
| 354 color_utils::GetReadableColor(SK_ColorBLACK, toolbar_background)); | |
| 355 | 361 |
| 356 int icon = toolbar_view_->GetToolbarModel()->GetIconForSecurityLevel( | 362 int icon = toolbar_view_->GetToolbarModel()->GetIconForSecurityLevel( |
| 357 security_level_); | 363 security_level_); |
| 358 showing_16x16_icon_ = false; | 364 showing_16x16_icon_ = false; |
| 359 | 365 |
| 360 if (url_displayed_.is_empty() || | 366 if (url_displayed_.is_empty() || |
| 361 url_displayed_.SchemeIs(chrome::kChromeUIScheme) || | 367 url_displayed_.SchemeIs(chrome::kChromeUIScheme) || |
| 362 url_displayed_.SchemeIs(chrome::kAboutScheme)) { | 368 url_displayed_.SchemeIs(chrome::kAboutScheme)) { |
| 363 icon = IDR_PRODUCT_LOGO_16; | 369 icon = IDR_PRODUCT_LOGO_16; |
| 364 showing_16x16_icon_ = true; | 370 showing_16x16_icon_ = true; |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 433 if (painter_) | 439 if (painter_) |
| 434 views::Painter::PaintPainterAt(canvas, painter_, rect); | 440 views::Painter::PaintPainterAt(canvas, painter_, rect); |
| 435 | 441 |
| 436 ToolbarButton::OnPaint(canvas); | 442 ToolbarButton::OnPaint(canvas); |
| 437 } | 443 } |
| 438 | 444 |
| 439 // TODO(gbillock): Make the LocationBarView or OmniboxView the listener for | 445 // TODO(gbillock): Make the LocationBarView or OmniboxView the listener for |
| 440 // this button. | 446 // this button. |
| 441 void SiteChipView::ButtonPressed(views::Button* sender, | 447 void SiteChipView::ButtonPressed(views::Button* sender, |
| 442 const ui::Event& event) { | 448 const ui::Event& event) { |
| 449 UMA_HISTOGRAM_COUNTS("SiteChip.Pressed", 1); | |
| 450 content::RecordAction(content::UserMetricsAction("SiteChipPress")); | |
| 451 | |
| 443 toolbar_view_->location_bar()->GetOmniboxView()->SetFocus(); | 452 toolbar_view_->location_bar()->GetOmniboxView()->SetFocus(); |
| 444 toolbar_view_->location_bar()->GetOmniboxView()->SelectAll(true); | |
| 445 toolbar_view_->location_bar()->GetOmniboxView()->model()-> | 453 toolbar_view_->location_bar()->GetOmniboxView()->model()-> |
| 446 SetCaretVisibility(true); | 454 SetCaretVisibility(true); |
| 455 toolbar_view_->location_bar()->GetOmniboxView()->ShowURL(); | |
| 447 } | 456 } |
| 448 | 457 |
| 449 void SiteChipView::WriteDragDataForView(View* sender, | 458 void SiteChipView::WriteDragDataForView(View* sender, |
| 450 const gfx::Point& press_pt, | 459 const gfx::Point& press_pt, |
| 451 OSExchangeData* data) { | 460 OSExchangeData* data) { |
| 452 // TODO(gbillock): Consolidate this with the identical logic in | 461 // TODO(gbillock): Consolidate this with the identical logic in |
| 453 // LocationBarView. | 462 // LocationBarView. |
| 454 content::WebContents* web_contents = toolbar_view_->GetWebContents(); | 463 content::WebContents* web_contents = toolbar_view_->GetWebContents(); |
| 455 FaviconTabHelper* favicon_tab_helper = | 464 FaviconTabHelper* favicon_tab_helper = |
| 456 FaviconTabHelper::FromWebContents(web_contents); | 465 FaviconTabHelper::FromWebContents(web_contents); |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 476 // Note: When OnSafeBrowsingHit would be called, OnSafeBrowsingMatch will | 485 // Note: When OnSafeBrowsingHit would be called, OnSafeBrowsingMatch will |
| 477 // have already been called. | 486 // have already been called. |
| 478 void SiteChipView::OnSafeBrowsingHit( | 487 void SiteChipView::OnSafeBrowsingHit( |
| 479 const SafeBrowsingUIManager::UnsafeResource& resource) {} | 488 const SafeBrowsingUIManager::UnsafeResource& resource) {} |
| 480 | 489 |
| 481 void SiteChipView::OnSafeBrowsingMatch( | 490 void SiteChipView::OnSafeBrowsingMatch( |
| 482 const SafeBrowsingUIManager::UnsafeResource& resource) { | 491 const SafeBrowsingUIManager::UnsafeResource& resource) { |
| 483 OnChanged(); | 492 OnChanged(); |
| 484 } | 493 } |
| 485 | 494 |
| OLD | NEW |