Index: chrome/browser/ui/views/toolbar/site_chip_view.cc |
diff --git a/chrome/browser/ui/views/toolbar/site_chip_view.cc b/chrome/browser/ui/views/toolbar/site_chip_view.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..08886ed932eaa0fe4e3192243d6a3ae3c25ea9eb |
--- /dev/null |
+++ b/chrome/browser/ui/views/toolbar/site_chip_view.cc |
@@ -0,0 +1,106 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/ui/views/toolbar/site_chip_view.h" |
+ |
+#include "base/prefs/pref_service.h" |
+#include "base/strings/string_util.h" |
+#include "base/strings/utf_string_conversions.h" |
+#include "chrome/browser/profiles/profile.h" |
+#include "chrome/browser/search/search.h" |
+#include "chrome/browser/themes/theme_properties.h" |
+#include "chrome/browser/ui/browser.h" |
+#include "chrome/browser/ui/omnibox/omnibox_view.h" |
+#include "chrome/browser/ui/toolbar/toolbar_model.h" |
+#include "chrome/browser/ui/views/location_bar/location_bar_view.h" |
+#include "chrome/browser/ui/views/location_bar/location_icon_view.h" |
+#include "chrome/browser/ui/views/toolbar/toolbar_view.h" |
+#include "chrome/common/pref_names.h" |
+#include "content/public/browser/web_contents.h" |
+#include "grit/theme_resources.h" |
+#include "net/base/net_util.h" |
+#include "ui/base/theme_provider.h" |
+#include "ui/views/controls/button/label_button.h" |
+#include "ui/views/controls/button/label_button_border.h" |
+#include "ui/views/controls/label.h" |
+ |
+// use --force-fieldtrials=EmbeddedSearch/Group1 origin_chip:1/ to force |
Peter Kasting
2013/11/20 01:49:13
Nit: Comments should be complete sentences.
Does
Greg Billock
2013/11/21 19:29:34
No. I just have to look to remember it. :-)
|
+ |
+SiteChipView::SiteChipView(ToolbarView* toolbar_view) |
+ : ToolbarButton(this, NULL), |
+ toolbar_view_(toolbar_view) { |
+} |
+ |
+SiteChipView::~SiteChipView() { |
+} |
+ |
+void SiteChipView::ButtonPressed(views::Button* sender, |
+ const ui::Event& event) { |
+ toolbar_view_->location_bar()->GetLocationEntry()->SetFocus(); |
+ toolbar_view_->location_bar()->GetLocationEntry()->SelectAll(true); |
+ toolbar_view_->location_bar()->GetLocationEntry()->model()-> |
+ SetCaretVisibility(true); |
+} |
+ |
+void SiteChipView::Init() { |
+ ToolbarButton::Init(); |
+ |
+ // TODO(gbillock): Would be nice to just use stock LabelButton stuff here. |
+ location_icon_view_ = new LocationIconView(toolbar_view_->location_bar()); |
+ AddChildView(location_icon_view_); |
+ |
+ host_label_ = new views::Label(); |
+ AddChildView(host_label_); |
+ |
+ // temporary icon filler |
+ location_icon_view_->SetImage(GetThemeProvider()->GetImageSkiaNamed( |
+ IDR_LOCATION_BAR_HTTP)); |
+ location_icon_view_->ShowTooltip(true); |
+ |
+ // temporary filler text. |
+ host_label_->SetText(ASCIIToUTF16("Site Chip")); |
+} |
+ |
+void SiteChipView::Update(content::WebContents* tab) { |
+ Layout(); |
+ SchedulePaint(); |
+} |
+ |
+views::ImageView* SiteChipView::GetLocationIconView() { |
+ return location_icon_view_; |
+} |
+ |
+const views::ImageView* SiteChipView::GetLocationIconView() const { |
+ return location_icon_view_; |
+} |
+ |
+gfx::Size SiteChipView::GetPreferredSize() { |
+ gfx::Size label_size = host_label_->GetPreferredSize(); |
+ gfx::Size icon_size = location_icon_view_->GetPreferredSize(); |
+ |
+ // Add on two spacing widths before and aft, as well as one |
+ // between icon and label. |
+ return gfx::Size(icon_size.width() + label_size.width() + |
+ 2 * ToolbarView::kStandardSpacing + |
+ LocationBarView::GetItemPadding(), |
+ icon_size.height()); |
+} |
+ |
+void SiteChipView::Layout() { |
+ location_icon_view_->SetBounds( |
+ ToolbarView::kStandardSpacing, |
+ LocationBarView::kNormalEdgeThickness, |
+ location_icon_view_->GetPreferredSize().width(), |
+ height() - 2 * LocationBarView::kNormalEdgeThickness); |
+ |
+ int host_label_x = ToolbarView::kStandardSpacing + |
+ location_icon_view_->GetPreferredSize().width() + |
+ LocationBarView::GetItemPadding(); |
+ int host_label_width = width() - host_label_x - ToolbarView::kStandardSpacing; |
+ host_label_->SetBounds(host_label_x, |
+ LocationBarView::kNormalEdgeThickness, |
+ host_label_width, |
+ height() - LocationBarView::kNormalEdgeThickness*2); |
+} |
+ |