Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(506)

Side by Side Diff: chrome/browser/ui/views/bookmarks/bookmark_bar_instructions_view.cc

Issue 1408273002: Make some updates to BM bar for MD. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: also update detached bg Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/bookmarks/bookmark_bar_instructions_view.h" 5 #include "chrome/browser/ui/views/bookmarks/bookmark_bar_instructions_view.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "chrome/browser/defaults.h" 10 #include "chrome/browser/defaults.h"
11 #include "chrome/browser/themes/theme_properties.h" 11 #include "chrome/browser/themes/theme_properties.h"
12 #include "chrome/browser/ui/bookmarks/bookmark_bar_instructions_delegate.h" 12 #include "chrome/browser/ui/bookmarks/bookmark_bar_instructions_delegate.h"
13 #include "chrome/grit/generated_resources.h" 13 #include "chrome/grit/generated_resources.h"
14 #include "ui/accessibility/ax_view_state.h" 14 #include "ui/accessibility/ax_view_state.h"
15 #include "ui/base/l10n/l10n_util.h" 15 #include "ui/base/l10n/l10n_util.h"
16 #include "ui/base/resource/material_design/material_design_controller.h"
16 #include "ui/base/theme_provider.h" 17 #include "ui/base/theme_provider.h"
18 #include "ui/native_theme/native_theme.h"
17 #include "ui/views/controls/label.h" 19 #include "ui/views/controls/label.h"
18 #include "ui/views/controls/link.h" 20 #include "ui/views/controls/link.h"
19 21
20 namespace { 22 namespace {
21 23
22 // Horizontal padding, in pixels, between the link and label. 24 // Horizontal padding, in pixels, between the link and label.
23 const int kViewPadding = 6; 25 const int kViewPadding = 6;
24 26
25 } // namespace 27 } // namespace
26 28
27 BookmarkBarInstructionsView::BookmarkBarInstructionsView( 29 BookmarkBarInstructionsView::BookmarkBarInstructionsView(
28 BookmarkBarInstructionsDelegate* delegate) 30 BookmarkBarInstructionsDelegate* delegate)
29 : delegate_(delegate), 31 : delegate_(delegate),
30 instructions_(NULL), 32 instructions_(NULL),
31 import_link_(NULL), 33 import_link_(NULL),
32 baseline_(-1), 34 baseline_(-1),
33 updated_colors_(false) { 35 updated_colors_(false) {
34 instructions_ = new views::Label( 36 base::string16 instructions_text =
35 l10n_util::GetStringUTF16(IDS_BOOKMARKS_NO_ITEMS)); 37 l10n_util::GetStringUTF16(IDS_BOOKMARKS_NO_ITEMS);
38 if (ui::MaterialDesignController::IsModeMaterial())
39 instructions_text += base::ASCIIToUTF16(" ");
sky 2015/10/19 15:38:40 Why do you add a space for material? Might the spa
Evan Stade 2015/10/19 16:49:52 Previously this space was implemented with kViewPa
jungshik at Google 2015/10/23 06:30:19 Sorry for the late reply and thanks for testing in
40 instructions_ = new views::Label(instructions_text);
36 instructions_->SetAutoColorReadabilityEnabled(false); 41 instructions_->SetAutoColorReadabilityEnabled(false);
37 AddChildView(instructions_); 42 AddChildView(instructions_);
38 43
39 if (browser_defaults::kShowImportOnBookmarkBar) { 44 if (browser_defaults::kShowImportOnBookmarkBar) {
40 import_link_ = new views::Link( 45 import_link_ = new views::Link(
41 l10n_util::GetStringUTF16(IDS_BOOKMARK_BAR_IMPORT_LINK)); 46 l10n_util::GetStringUTF16(IDS_BOOKMARK_BAR_IMPORT_LINK));
42 // We don't want the link to alter tab navigation. 47 // We don't want the link to alter tab navigation.
43 import_link_->SetFocusable(false); 48 import_link_->SetFocusable(false);
44 import_link_->set_listener(this); 49 import_link_->set_listener(this);
45 import_link_->set_context_menu_controller(this); 50 import_link_->set_context_menu_controller(this);
46 import_link_->SetAutoColorReadabilityEnabled(false); 51 import_link_->SetAutoColorReadabilityEnabled(false);
47 AddChildView(import_link_); 52 AddChildView(import_link_);
48 } 53 }
49 } 54 }
50 55
51 gfx::Size BookmarkBarInstructionsView::GetPreferredSize() const { 56 gfx::Size BookmarkBarInstructionsView::GetPreferredSize() const {
52 int ascent = 0, descent = 0, height = 0, width = 0; 57 int ascent = 0, descent = 0, height = 0, width = 0;
53 for (int i = 0; i < child_count(); ++i) { 58 for (int i = 0; i < child_count(); ++i) {
54 const views::View* view = child_at(i); 59 const views::View* view = child_at(i);
55 gfx::Size pref = view->GetPreferredSize(); 60 gfx::Size pref = view->GetPreferredSize();
56 int baseline = view->GetBaseline(); 61 int baseline = view->GetBaseline();
57 if (baseline != -1) { 62 if (baseline != -1) {
58 ascent = std::max(ascent, baseline); 63 ascent = std::max(ascent, baseline);
59 descent = std::max(descent, pref.height() - baseline); 64 descent = std::max(descent, pref.height() - baseline);
60 } else { 65 } else {
61 height = std::max(pref.height(), height); 66 height = std::max(pref.height(), height);
62 } 67 }
63 width += pref.width(); 68 width += pref.width();
64 } 69 }
65 width += (child_count() - 1) * kViewPadding; 70 if (!ui::MaterialDesignController::IsModeMaterial())
71 width += (child_count() - 1) * kViewPadding;
66 if (ascent != 0) 72 if (ascent != 0)
67 height = std::max(ascent + descent, height); 73 height = std::max(ascent + descent, height);
68 return gfx::Size(width, height); 74 return gfx::Size(width, height);
69 } 75 }
70 76
71 void BookmarkBarInstructionsView::Layout() { 77 void BookmarkBarInstructionsView::Layout() {
72 int remaining_width = width(); 78 int remaining_width = width();
73 int x = 0; 79 int x = 0;
74 for (int i = 0; i < child_count(); ++i) { 80 for (int i = 0; i < child_count(); ++i) {
75 views::View* view = child_at(i); 81 views::View* view = child_at(i);
76 gfx::Size pref = view->GetPreferredSize(); 82 gfx::Size pref = view->GetPreferredSize();
77 int baseline = view->GetBaseline(); 83 int baseline = view->GetBaseline();
78 int y; 84 int y;
79 if (baseline != -1 && baseline_ != -1) 85 if (baseline != -1 && baseline_ != -1)
80 y = baseline_ - baseline; 86 y = baseline_ - baseline;
81 else 87 else
82 y = (height() - pref.height()) / 2; 88 y = (height() - pref.height()) / 2;
83 int view_width = std::min(remaining_width, pref.width()); 89 int view_width = std::min(remaining_width, pref.width());
84 view->SetBounds(x, y, view_width, pref.height()); 90 view->SetBounds(x, y, view_width, pref.height());
85 x += view_width + kViewPadding; 91 x += view_width;
92 if (!ui::MaterialDesignController::IsModeMaterial())
93 x += kViewPadding;
86 remaining_width = std::max(0, width() - x); 94 remaining_width = std::max(0, width() - x);
87 } 95 }
88 } 96 }
89 97
90 const char* BookmarkBarInstructionsView::GetClassName() const { 98 const char* BookmarkBarInstructionsView::GetClassName() const {
91 return "BookmarkBarInstructionsView"; 99 return "BookmarkBarInstructionsView";
92 } 100 }
93 101
94 void BookmarkBarInstructionsView::OnThemeChanged() { 102 void BookmarkBarInstructionsView::OnThemeChanged() {
95 UpdateColors(); 103 UpdateColors();
(...skipping 25 matching lines...) Expand all
121 129
122 void BookmarkBarInstructionsView::UpdateColors() { 130 void BookmarkBarInstructionsView::UpdateColors() {
123 // We don't always have a theme provider (ui tests, for example). 131 // We don't always have a theme provider (ui tests, for example).
124 const ui::ThemeProvider* theme_provider = GetThemeProvider(); 132 const ui::ThemeProvider* theme_provider = GetThemeProvider();
125 if (!theme_provider) 133 if (!theme_provider)
126 return; 134 return;
127 updated_colors_ = true; 135 updated_colors_ = true;
128 SkColor text_color = 136 SkColor text_color =
129 theme_provider->GetColor(ThemeProperties::COLOR_BOOKMARK_TEXT); 137 theme_provider->GetColor(ThemeProperties::COLOR_BOOKMARK_TEXT);
130 instructions_->SetEnabledColor(text_color); 138 instructions_->SetEnabledColor(text_color);
131 if (import_link_) 139 if (import_link_) {
varkha 2015/10/19 15:01:29 nit: could return early on !import_link to simplif
Evan Stade 2015/10/19 16:49:52 Done.
132 import_link_->SetEnabledColor(text_color); 140 if (!ui::MaterialDesignController::IsModeMaterial()) {
141 import_link_->SetEnabledColor(text_color);
142 } else {
143 // For MD, use the default link color if it provides enough contrast. If
144 // contrast is too low, fall back to the bookmark text color and use an
145 // underline to make it obvious it's a link. The default color readability
146 // code (which only adjusts luminance) doesn't work well in this case.
147 SkColor bg = theme_provider->GetColor(
148 ThemeProperties::ThemeProperties::COLOR_TOOLBAR);
149 SkColor link_color = GetNativeTheme()->GetSystemColor(
150 ui::NativeTheme::kColorId_LinkEnabled);
151 if (color_utils::GetContrastRatio(link_color, bg) >=
152 color_utils::kMinimumReadableContrastRatio) {
153 import_link_->SetUnderline(false);
154 import_link_->SetEnabledColor(link_color);
155 } else {
156 import_link_->SetUnderline(true);
157 import_link_->SetEnabledColor(text_color);
158 }
varkha 2015/10/19 15:01:29 nit: maybe shorten this similar to: bool enough_c
Evan Stade 2015/10/19 16:49:52 Done.
159 }
160 }
133 } 161 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/search/search_ui.cc ('k') | chrome/browser/ui/views/bookmarks/bookmark_bar_view.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698