OLD | NEW |
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_view.h" | 5 #include "chrome/browser/ui/views/bookmarks/bookmark_bar_view.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <limits> | 8 #include <limits> |
9 #include <set> | 9 #include <set> |
10 #include <vector> | 10 #include <vector> |
(...skipping 12 matching lines...) Expand all Loading... |
23 #include "chrome/browser/extensions/extension_service.h" | 23 #include "chrome/browser/extensions/extension_service.h" |
24 #include "chrome/browser/profiles/profile.h" | 24 #include "chrome/browser/profiles/profile.h" |
25 #include "chrome/browser/sync/profile_sync_service.h" | 25 #include "chrome/browser/sync/profile_sync_service.h" |
26 #include "chrome/browser/sync/profile_sync_service_factory.h" | 26 #include "chrome/browser/sync/profile_sync_service_factory.h" |
27 #include "chrome/browser/themes/theme_properties.h" | 27 #include "chrome/browser/themes/theme_properties.h" |
28 #include "chrome/browser/ui/bookmarks/bookmark_bar_constants.h" | 28 #include "chrome/browser/ui/bookmarks/bookmark_bar_constants.h" |
29 #include "chrome/browser/ui/bookmarks/bookmark_tab_helper.h" | 29 #include "chrome/browser/ui/bookmarks/bookmark_tab_helper.h" |
30 #include "chrome/browser/ui/bookmarks/bookmark_utils.h" | 30 #include "chrome/browser/ui/bookmarks/bookmark_utils.h" |
31 #include "chrome/browser/ui/browser.h" | 31 #include "chrome/browser/ui/browser.h" |
32 #include "chrome/browser/ui/chrome_pages.h" | 32 #include "chrome/browser/ui/chrome_pages.h" |
| 33 #include "chrome/browser/ui/search/search.h" |
33 #include "chrome/browser/ui/search/search_model.h" | 34 #include "chrome/browser/ui/search/search_model.h" |
34 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 35 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
35 #include "chrome/browser/ui/view_ids.h" | 36 #include "chrome/browser/ui/view_ids.h" |
36 #include "chrome/browser/ui/views/bookmarks/bookmark_bar_instructions_view.h" | 37 #include "chrome/browser/ui/views/bookmarks/bookmark_bar_instructions_view.h" |
37 #include "chrome/browser/ui/views/bookmarks/bookmark_context_menu.h" | 38 #include "chrome/browser/ui/views/bookmarks/bookmark_context_menu.h" |
38 #include "chrome/browser/ui/views/event_utils.h" | 39 #include "chrome/browser/ui/views/event_utils.h" |
39 #include "chrome/browser/ui/views/frame/browser_view.h" | 40 #include "chrome/browser/ui/views/frame/browser_view.h" |
40 #include "chrome/browser/ui/views/location_bar/location_bar_view.h" | 41 #include "chrome/browser/ui/views/location_bar/location_bar_view.h" |
41 #include "chrome/browser/ui/webui/ntp/app_launcher_handler.h" | 42 #include "chrome/browser/ui/webui/ntp/app_launcher_handler.h" |
42 #include "chrome/common/chrome_notification_types.h" | 43 #include "chrome/common/chrome_notification_types.h" |
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
140 // is only needed locally. | 141 // is only needed locally. |
141 static const int kSearchNewTabBookmarkBarHeight = 36; | 142 static const int kSearchNewTabBookmarkBarHeight = 36; |
142 | 143 |
143 // TODO(kuan): change BookmarkBarView::kNewtabHorizontalPadding and | 144 // TODO(kuan): change BookmarkBarView::kNewtabHorizontalPadding and |
144 // BookmarkBarView::kNewtabVerticalPadding to these new values when search_ntp | 145 // BookmarkBarView::kNewtabVerticalPadding to these new values when search_ntp |
145 // replaces ntp4; for now, while both versions exist, these new values are only | 146 // replaces ntp4; for now, while both versions exist, these new values are only |
146 // needed locally. | 147 // needed locally. |
147 static const int kSearchNewTabHorizontalPadding = 0; | 148 static const int kSearchNewTabHorizontalPadding = 0; |
148 static const int kSearchNewTabVerticalPadding = 0; | 149 static const int kSearchNewTabVerticalPadding = 0; |
149 | 150 |
| 151 // Tag for the 'Apps Shortcut' button. |
| 152 static const int kAppsShortcutButtonTag = 2; |
| 153 |
150 namespace { | 154 namespace { |
151 | 155 |
| 156 // BookmarkButtonBase ----------------------------------------------- |
| 157 |
| 158 // Base class for text buttons used on the bookmark bar. |
| 159 |
| 160 class BookmarkButtonBase : public views::TextButton { |
| 161 public: |
| 162 BookmarkButtonBase(views::ButtonListener* listener, |
| 163 const string16& title) |
| 164 : TextButton(listener, title) { |
| 165 show_animation_.reset(new ui::SlideAnimation(this)); |
| 166 if (bookmark_utils::IsBookmarkBarViewAnimationsDisabled()) { |
| 167 // For some reason during testing the events generated by anima |
| 168 // throw off the test. So, don't animate while testing. |
| 169 show_animation_->Reset(1); |
| 170 } else { |
| 171 show_animation_->Show(); |
| 172 } |
| 173 } |
| 174 |
| 175 virtual bool IsTriggerableEvent(const ui::Event& e) OVERRIDE { |
| 176 return e.type() == ui::ET_GESTURE_TAP || |
| 177 e.type() == ui::ET_GESTURE_TAP_DOWN || |
| 178 event_utils::IsPossibleDispositionEvent(e); |
| 179 } |
| 180 |
| 181 private: |
| 182 scoped_ptr<ui::SlideAnimation> show_animation_; |
| 183 |
| 184 DISALLOW_COPY_AND_ASSIGN(BookmarkButtonBase); |
| 185 }; |
| 186 |
152 // BookmarkButton ------------------------------------------------------------- | 187 // BookmarkButton ------------------------------------------------------------- |
153 | 188 |
154 // Buttons used for the bookmarks on the bookmark bar. | 189 // Buttons used for the bookmarks on the bookmark bar. |
155 | 190 |
156 class BookmarkButton : public views::TextButton { | 191 class BookmarkButton : public BookmarkButtonBase { |
157 public: | 192 public: |
158 // The internal view class name. | 193 // The internal view class name. |
159 static const char kViewClassName[]; | 194 static const char kViewClassName[]; |
160 | 195 |
161 BookmarkButton(views::ButtonListener* listener, | 196 BookmarkButton(views::ButtonListener* listener, |
162 const GURL& url, | 197 const GURL& url, |
163 const string16& title, | 198 const string16& title, |
164 Profile* profile) | 199 Profile* profile) |
165 : TextButton(listener, title), | 200 : BookmarkButtonBase(listener, title), |
166 url_(url), | 201 url_(url), |
167 profile_(profile) { | 202 profile_(profile) { |
168 show_animation_.reset(new ui::SlideAnimation(this)); | |
169 if (bookmark_utils::IsBookmarkBarViewAnimationsDisabled()) { | |
170 // For some reason during testing the events generated by animating | |
171 // throw off the test. So, don't animate while testing. | |
172 show_animation_->Reset(1); | |
173 } else { | |
174 show_animation_->Show(); | |
175 } | |
176 } | 203 } |
177 | 204 |
178 virtual bool GetTooltipText(const gfx::Point& p, | 205 virtual bool GetTooltipText(const gfx::Point& p, |
179 string16* tooltip) const OVERRIDE { | 206 string16* tooltip) const OVERRIDE { |
180 gfx::Point location(p); | 207 gfx::Point location(p); |
181 ConvertPointToScreen(this, &location); | 208 ConvertPointToScreen(this, &location); |
182 *tooltip = BookmarkBarView::CreateToolTipForURLAndTitle( | 209 *tooltip = BookmarkBarView::CreateToolTipForURLAndTitle( |
183 location, url_, text(), profile_, GetWidget()->GetNativeView()); | 210 location, url_, text(), profile_, GetWidget()->GetNativeView()); |
184 return !tooltip->empty(); | 211 return !tooltip->empty(); |
185 } | 212 } |
186 | 213 |
187 virtual bool IsTriggerableEvent(const ui::Event& e) OVERRIDE { | |
188 return e.type() == ui::ET_GESTURE_TAP || | |
189 e.type() == ui::ET_GESTURE_TAP_DOWN || | |
190 event_utils::IsPossibleDispositionEvent(e); | |
191 } | |
192 | |
193 virtual std::string GetClassName() const OVERRIDE { | 214 virtual std::string GetClassName() const OVERRIDE { |
194 return kViewClassName; | 215 return kViewClassName; |
195 } | 216 } |
196 | 217 |
197 private: | 218 private: |
198 const GURL& url_; | 219 const GURL& url_; |
199 Profile* profile_; | 220 Profile* profile_; |
200 scoped_ptr<ui::SlideAnimation> show_animation_; | |
201 | 221 |
202 DISALLOW_COPY_AND_ASSIGN(BookmarkButton); | 222 DISALLOW_COPY_AND_ASSIGN(BookmarkButton); |
203 }; | 223 }; |
204 | 224 |
205 // static for BookmarkButton | 225 // static for BookmarkButton |
206 const char BookmarkButton::kViewClassName[] = | 226 const char BookmarkButton::kViewClassName[] = |
207 "browser/ui/views/bookmarks/BookmarkButton"; | 227 "browser/ui/views/bookmarks/BookmarkButton"; |
208 | 228 |
| 229 // ShortcutButton ------------------------------------------------------------- |
| 230 |
| 231 // Buttons used for the shortcuts on the bookmark bar. |
| 232 |
| 233 class ShortcutButton : public BookmarkButtonBase { |
| 234 public: |
| 235 // The internal view class name. |
| 236 static const char kViewClassName[]; |
| 237 |
| 238 ShortcutButton(views::ButtonListener* listener, |
| 239 const string16& title) |
| 240 : BookmarkButtonBase(listener, title) { |
| 241 } |
| 242 |
| 243 virtual std::string GetClassName() const OVERRIDE { |
| 244 return kViewClassName; |
| 245 } |
| 246 |
| 247 private: |
| 248 |
| 249 DISALLOW_COPY_AND_ASSIGN(ShortcutButton); |
| 250 }; |
| 251 |
| 252 // static for ShortcutButton |
| 253 const char ShortcutButton::kViewClassName[] = |
| 254 "browser/ui/views/bookmarks/ShortcutButton"; |
| 255 |
209 // BookmarkFolderButton ------------------------------------------------------- | 256 // BookmarkFolderButton ------------------------------------------------------- |
210 | 257 |
211 // Buttons used for folders on the bookmark bar, including the 'other folders' | 258 // Buttons used for folders on the bookmark bar, including the 'other folders' |
212 // button. | 259 // button. |
213 class BookmarkFolderButton : public views::MenuButton { | 260 class BookmarkFolderButton : public views::MenuButton { |
214 public: | 261 public: |
215 BookmarkFolderButton(views::ButtonListener* listener, | 262 BookmarkFolderButton(views::ButtonListener* listener, |
216 const string16& title, | 263 const string16& title, |
217 views::MenuButtonListener* menu_button_listener, | 264 views::MenuButtonListener* menu_button_listener, |
218 bool show_menu_marker) | 265 bool show_menu_marker) |
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
399 } | 446 } |
400 return *kFolderIcon; | 447 return *kFolderIcon; |
401 } | 448 } |
402 | 449 |
403 BookmarkBarView::BookmarkBarView(Browser* browser, BrowserView* browser_view) | 450 BookmarkBarView::BookmarkBarView(Browser* browser, BrowserView* browser_view) |
404 : page_navigator_(NULL), | 451 : page_navigator_(NULL), |
405 model_(NULL), | 452 model_(NULL), |
406 bookmark_menu_(NULL), | 453 bookmark_menu_(NULL), |
407 bookmark_drop_menu_(NULL), | 454 bookmark_drop_menu_(NULL), |
408 other_bookmarked_button_(NULL), | 455 other_bookmarked_button_(NULL), |
| 456 apps_page_shortcut_(NULL), |
409 ALLOW_THIS_IN_INITIALIZER_LIST(show_folder_method_factory_(this)), | 457 ALLOW_THIS_IN_INITIALIZER_LIST(show_folder_method_factory_(this)), |
410 overflow_button_(NULL), | 458 overflow_button_(NULL), |
411 instructions_(NULL), | 459 instructions_(NULL), |
412 bookmarks_separator_view_(NULL), | 460 bookmarks_separator_view_(NULL), |
413 browser_(browser), | 461 browser_(browser), |
414 browser_view_(browser_view), | 462 browser_view_(browser_view), |
415 infobar_visible_(false), | 463 infobar_visible_(false), |
416 throbbing_view_(NULL), | 464 throbbing_view_(NULL), |
417 bookmark_bar_state_(BookmarkBar::SHOW), | 465 bookmark_bar_state_(BookmarkBar::SHOW), |
418 animating_detached_(false) { | 466 animating_detached_(false) { |
(...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
620 // button, by which one can access all the Bookmark Bar items, and the "Other | 668 // button, by which one can access all the Bookmark Bar items, and the "Other |
621 // Bookmarks" folder, along with appropriate margins and button padding. | 669 // Bookmarks" folder, along with appropriate margins and button padding. |
622 int width = kLeftMargin; | 670 int width = kLeftMargin; |
623 | 671 |
624 if (bookmark_bar_state_ == BookmarkBar::DETACHED) { | 672 if (bookmark_bar_state_ == BookmarkBar::DETACHED) { |
625 double current_state = 1 - size_animation_->GetCurrentValue(); | 673 double current_state = 1 - size_animation_->GetCurrentValue(); |
626 width += 2 * static_cast<int>(GetNewtabHorizontalPadding( | 674 width += 2 * static_cast<int>(GetNewtabHorizontalPadding( |
627 browser_->search_model()->mode()) * current_state); | 675 browser_->search_model()->mode()) * current_state); |
628 } | 676 } |
629 | 677 |
630 gfx::Size other_bookmarked_pref = | 678 gfx::Size other_bookmarked_pref; |
631 other_bookmarked_button_->GetPreferredSize(); | 679 if (other_bookmarked_button_->visible()) |
632 gfx::Size overflow_pref = overflow_button_->GetPreferredSize(); | 680 other_bookmarked_pref = other_bookmarked_button_->GetPreferredSize(); |
633 gfx::Size bookmarks_separator_pref = | 681 gfx::Size overflow_pref; |
634 bookmarks_separator_view_->GetPreferredSize(); | 682 if (overflow_button_->visible()) |
| 683 overflow_pref = overflow_button_->GetPreferredSize(); |
| 684 gfx::Size bookmarks_separator_pref; |
| 685 if (bookmarks_separator_view_->visible()) |
| 686 bookmarks_separator_pref = bookmarks_separator_view_->GetPreferredSize(); |
635 | 687 |
| 688 gfx::Size apps_page_shortcut_pref; |
| 689 if (apps_page_shortcut_->visible()) |
| 690 apps_page_shortcut_pref = apps_page_shortcut_->GetPreferredSize(); |
636 width += other_bookmarked_pref.width() + kButtonPadding + | 691 width += other_bookmarked_pref.width() + kButtonPadding + |
| 692 apps_page_shortcut_pref.width() + kButtonPadding + |
637 overflow_pref.width() + kButtonPadding + | 693 overflow_pref.width() + kButtonPadding + |
638 bookmarks_separator_pref.width(); | 694 bookmarks_separator_pref.width(); |
639 | 695 |
640 return gfx::Size(width, browser_defaults::kBookmarkBarHeight); | 696 return gfx::Size(width, browser_defaults::kBookmarkBarHeight); |
641 } | 697 } |
642 | 698 |
643 void BookmarkBarView::Layout() { | 699 void BookmarkBarView::Layout() { |
644 LayoutItems(false); | 700 LayoutItems(false); |
645 } | 701 } |
646 | 702 |
(...skipping 420 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1067 | 1123 |
1068 bookmark_utils::RecordBookmarkFolderOpen(GetBookmarkLaunchLocation()); | 1124 bookmark_utils::RecordBookmarkFolderOpen(GetBookmarkLaunchLocation()); |
1069 bookmark_menu_ = new BookmarkMenuController(browser_, | 1125 bookmark_menu_ = new BookmarkMenuController(browser_, |
1070 page_navigator_, GetWidget(), node, start_index); | 1126 page_navigator_, GetWidget(), node, start_index); |
1071 bookmark_menu_->set_observer(this); | 1127 bookmark_menu_->set_observer(this); |
1072 bookmark_menu_->RunMenuAt(this, false); | 1128 bookmark_menu_->RunMenuAt(this, false); |
1073 } | 1129 } |
1074 | 1130 |
1075 void BookmarkBarView::ButtonPressed(views::Button* sender, | 1131 void BookmarkBarView::ButtonPressed(views::Button* sender, |
1076 const ui::Event& event) { | 1132 const ui::Event& event) { |
| 1133 if (sender->tag() == kAppsShortcutButtonTag) { |
| 1134 chrome::ShowAppLauncherPage(browser_); |
| 1135 bookmark_utils::RecordAppsPageOpen(GetBookmarkLaunchLocation()); |
| 1136 return; |
| 1137 } |
| 1138 |
1077 const BookmarkNode* node; | 1139 const BookmarkNode* node; |
1078 if (sender->tag() == kOtherFolderButtonTag) { | 1140 if (sender->tag() == kOtherFolderButtonTag) { |
1079 node = model_->other_node(); | 1141 node = model_->other_node(); |
1080 } else { | 1142 } else { |
1081 int index = GetIndexOf(sender); | 1143 int index = GetIndexOf(sender); |
1082 DCHECK_NE(-1, index); | 1144 DCHECK_NE(-1, index); |
1083 node = model_->bookmark_bar_node()->GetChild(index); | 1145 node = model_->bookmark_bar_node()->GetChild(index); |
1084 } | 1146 } |
1085 DCHECK(page_navigator_); | 1147 DCHECK(page_navigator_); |
1086 | 1148 |
(...skipping 19 matching lines...) Expand all Loading... |
1106 if (!model_->IsLoaded()) { | 1168 if (!model_->IsLoaded()) { |
1107 // Don't do anything if the model isn't loaded. | 1169 // Don't do anything if the model isn't loaded. |
1108 return; | 1170 return; |
1109 } | 1171 } |
1110 | 1172 |
1111 const BookmarkNode* parent = NULL; | 1173 const BookmarkNode* parent = NULL; |
1112 std::vector<const BookmarkNode*> nodes; | 1174 std::vector<const BookmarkNode*> nodes; |
1113 if (source == other_bookmarked_button_) { | 1175 if (source == other_bookmarked_button_) { |
1114 parent = model_->other_node(); | 1176 parent = model_->other_node(); |
1115 // Do this so the user can open all bookmarks. BookmarkContextMenu makes | 1177 // Do this so the user can open all bookmarks. BookmarkContextMenu makes |
1116 // sure the user can edit/delete the node in this case. | 1178 // sure the user can't edit/delete the node in this case. |
1117 nodes.push_back(parent); | 1179 nodes.push_back(parent); |
1118 } else if (source != this) { | 1180 } else if (source != this && source != apps_page_shortcut_) { |
1119 // User clicked on one of the bookmark buttons, find which one they | 1181 // User clicked on one of the bookmark buttons, find which one they |
1120 // clicked on. | 1182 // clicked on, except for the apps page shortcut, which must behave as if |
| 1183 // the user clicked on the bookmark bar background. |
1121 int bookmark_button_index = GetIndexOf(source); | 1184 int bookmark_button_index = GetIndexOf(source); |
1122 DCHECK(bookmark_button_index != -1 && | 1185 DCHECK(bookmark_button_index != -1 && |
1123 bookmark_button_index < GetBookmarkButtonCount()); | 1186 bookmark_button_index < GetBookmarkButtonCount()); |
1124 const BookmarkNode* node = | 1187 const BookmarkNode* node = |
1125 model_->bookmark_bar_node()->GetChild(bookmark_button_index); | 1188 model_->bookmark_bar_node()->GetChild(bookmark_button_index); |
1126 nodes.push_back(node); | 1189 nodes.push_back(node); |
1127 parent = node->parent(); | 1190 parent = node->parent(); |
1128 } else { | 1191 } else { |
1129 parent = model_->bookmark_bar_node(); | 1192 parent = model_->bookmark_bar_node(); |
1130 nodes.push_back(parent); | 1193 nodes.push_back(parent); |
(...skipping 23 matching lines...) Expand all Loading... |
1154 // Child views are traversed in the order they are added. Make sure the order | 1217 // Child views are traversed in the order they are added. Make sure the order |
1155 // they are added matches the visual order. | 1218 // they are added matches the visual order. |
1156 overflow_button_ = CreateOverflowButton(); | 1219 overflow_button_ = CreateOverflowButton(); |
1157 AddChildView(overflow_button_); | 1220 AddChildView(overflow_button_); |
1158 | 1221 |
1159 other_bookmarked_button_ = CreateOtherBookmarkedButton(); | 1222 other_bookmarked_button_ = CreateOtherBookmarkedButton(); |
1160 // We'll re-enable when the model is loaded. | 1223 // We'll re-enable when the model is loaded. |
1161 other_bookmarked_button_->SetEnabled(false); | 1224 other_bookmarked_button_->SetEnabled(false); |
1162 AddChildView(other_bookmarked_button_); | 1225 AddChildView(other_bookmarked_button_); |
1163 | 1226 |
| 1227 apps_page_shortcut_ = CreateAppsPageShortcutButton(); |
| 1228 AddChildView(apps_page_shortcut_); |
| 1229 profile_pref_registrar_.Init(browser_->profile()->GetPrefs()); |
| 1230 profile_pref_registrar_.Add( |
| 1231 prefs::kShowAppsShortcutInBookmarkBar, |
| 1232 base::Bind(&BookmarkBarView::OnAppsPageShortcutVisibilityChanged, |
| 1233 base::Unretained(this))); |
| 1234 apps_page_shortcut_->SetVisible(ShouldShowAppsShortcut()); |
| 1235 |
1164 bookmarks_separator_view_ = new ButtonSeparatorView(); | 1236 bookmarks_separator_view_ = new ButtonSeparatorView(); |
1165 AddChildView(bookmarks_separator_view_); | 1237 AddChildView(bookmarks_separator_view_); |
1166 #if defined(USE_ASH) | 1238 UpdateBookmarksSeparatorVisibility(); |
1167 // Ash does not paint the bookmarks separator line because it looks odd on | |
1168 // the flat background. We keep it present for layout, but don't draw it. | |
1169 bookmarks_separator_view_->SetVisible(false); | |
1170 #endif | |
1171 | 1239 |
1172 instructions_ = new BookmarkBarInstructionsView(this); | 1240 instructions_ = new BookmarkBarInstructionsView(this); |
1173 AddChildView(instructions_); | 1241 AddChildView(instructions_); |
1174 | 1242 |
1175 set_context_menu_controller(this); | 1243 set_context_menu_controller(this); |
1176 | 1244 |
1177 size_animation_.reset(new ui::SlideAnimation(this)); | 1245 size_animation_.reset(new ui::SlideAnimation(this)); |
1178 | 1246 |
1179 model_ = BookmarkModelFactory::GetForProfile(browser_->profile()); | 1247 model_ = BookmarkModelFactory::GetForProfile(browser_->profile()); |
1180 if (model_) { | 1248 if (model_) { |
1181 model_->AddObserver(this); | 1249 model_->AddObserver(this); |
1182 if (model_->IsLoaded()) | 1250 if (model_->IsLoaded()) |
1183 Loaded(model_, false); | 1251 Loaded(model_, false); |
1184 // else case: we'll receive notification back from the BookmarkModel when | 1252 // else case: we'll receive notification back from the BookmarkModel when |
1185 // done loading, then we'll populate the bar. | 1253 // done loading, then we'll populate the bar. |
1186 } | 1254 } |
1187 } | 1255 } |
1188 | 1256 |
1189 int BookmarkBarView::GetBookmarkButtonCount() { | 1257 int BookmarkBarView::GetBookmarkButtonCount() { |
1190 // We contain four non-bookmark button views: other bookmarks, bookmarks | 1258 // We contain four non-bookmark button views: other bookmarks, bookmarks |
1191 // separator, chevrons (for overflow), and the instruction label. | 1259 // separator, chevrons (for overflow), apps page, and the instruction label. |
1192 return child_count() - 4; | 1260 return child_count() - 5; |
1193 } | 1261 } |
1194 | 1262 |
1195 views::TextButton* BookmarkBarView::GetBookmarkButton(int index) { | 1263 views::TextButton* BookmarkBarView::GetBookmarkButton(int index) { |
1196 DCHECK(index >= 0 && index < GetBookmarkButtonCount()); | 1264 DCHECK(index >= 0 && index < GetBookmarkButtonCount()); |
1197 return static_cast<views::TextButton*>(child_at(index)); | 1265 return static_cast<views::TextButton*>(child_at(index)); |
1198 } | 1266 } |
1199 | 1267 |
1200 bookmark_utils::BookmarkLaunchLocation | 1268 bookmark_utils::BookmarkLaunchLocation |
1201 BookmarkBarView::GetBookmarkLaunchLocation() const { | 1269 BookmarkBarView::GetBookmarkLaunchLocation() const { |
1202 return IsDetached() ? bookmark_utils::LAUNCH_DETACHED_BAR : | 1270 return IsDetached() ? bookmark_utils::LAUNCH_DETACHED_BAR : |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1252 return button; | 1320 return button; |
1253 } else { | 1321 } else { |
1254 views::MenuButton* button = new BookmarkFolderButton( | 1322 views::MenuButton* button = new BookmarkFolderButton( |
1255 this, node->GetTitle(), this, false); | 1323 this, node->GetTitle(), this, false); |
1256 button->SetIcon(GetFolderIcon()); | 1324 button->SetIcon(GetFolderIcon()); |
1257 ConfigureButton(node, button); | 1325 ConfigureButton(node, button); |
1258 return button; | 1326 return button; |
1259 } | 1327 } |
1260 } | 1328 } |
1261 | 1329 |
| 1330 views::TextButton* BookmarkBarView::CreateAppsPageShortcutButton() { |
| 1331 views::TextButton* button = new ShortcutButton( |
| 1332 this, l10n_util::GetStringUTF16(IDS_BOOKMARK_BAR_APPS_SHORTCUT_NAME)); |
| 1333 button->SetTooltipText(l10n_util::GetStringUTF16( |
| 1334 IDS_BOOKMARK_BAR_APPS_SHORTCUT_TOOLTIP)); |
| 1335 button->set_id(VIEW_ID_BOOKMARK_BAR_ELEMENT); |
| 1336 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
| 1337 button->SetIcon(*rb.GetImageSkiaNamed(IDR_WEBSTORE_ICON_16)); |
| 1338 button->set_context_menu_controller(this); |
| 1339 button->set_tag(kAppsShortcutButtonTag); |
| 1340 return button; |
| 1341 } |
| 1342 |
1262 void BookmarkBarView::ConfigureButton(const BookmarkNode* node, | 1343 void BookmarkBarView::ConfigureButton(const BookmarkNode* node, |
1263 views::TextButton* button) { | 1344 views::TextButton* button) { |
1264 button->SetText(node->GetTitle()); | 1345 button->SetText(node->GetTitle()); |
1265 button->SetAccessibleName(node->GetTitle()); | 1346 button->SetAccessibleName(node->GetTitle()); |
1266 button->set_id(VIEW_ID_BOOKMARK_BAR_ELEMENT); | 1347 button->set_id(VIEW_ID_BOOKMARK_BAR_ELEMENT); |
1267 // We don't always have a theme provider (ui tests, for example). | 1348 // We don't always have a theme provider (ui tests, for example). |
1268 if (GetThemeProvider()) { | 1349 if (GetThemeProvider()) { |
1269 button->SetEnabledColor(GetThemeProvider()->GetColor( | 1350 button->SetEnabledColor(GetThemeProvider()->GetColor( |
1270 ThemeProperties::COLOR_BOOKMARK_TEXT)); | 1351 ThemeProperties::COLOR_BOOKMARK_TEXT)); |
1271 } | 1352 } |
(...skipping 294 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1566 for (int i = 0; i < GetBookmarkButtonCount(); ++i) | 1647 for (int i = 0; i < GetBookmarkButtonCount(); ++i) |
1567 GetBookmarkButton(i)->SetEnabledColor(text_color); | 1648 GetBookmarkButton(i)->SetEnabledColor(text_color); |
1568 other_bookmarked_button()->SetEnabledColor(text_color); | 1649 other_bookmarked_button()->SetEnabledColor(text_color); |
1569 } | 1650 } |
1570 | 1651 |
1571 void BookmarkBarView::UpdateOtherBookmarksVisibility() { | 1652 void BookmarkBarView::UpdateOtherBookmarksVisibility() { |
1572 bool has_other_children = !model_->other_node()->empty(); | 1653 bool has_other_children = !model_->other_node()->empty(); |
1573 if (has_other_children == other_bookmarked_button_->visible()) | 1654 if (has_other_children == other_bookmarked_button_->visible()) |
1574 return; | 1655 return; |
1575 other_bookmarked_button_->SetVisible(has_other_children); | 1656 other_bookmarked_button_->SetVisible(has_other_children); |
1576 #if !defined(USE_ASH) | 1657 UpdateBookmarksSeparatorVisibility(); |
1577 bookmarks_separator_view_->SetVisible(has_other_children); | |
1578 #endif | |
1579 Layout(); | 1658 Layout(); |
1580 SchedulePaint(); | 1659 SchedulePaint(); |
1581 } | 1660 } |
1582 | 1661 |
| 1662 void BookmarkBarView::UpdateBookmarksSeparatorVisibility() { |
| 1663 // Ash does not paint the bookmarks separator line because it looks odd on |
| 1664 // the flat background. We keep it present for layout, but don't draw it. |
| 1665 bookmarks_separator_view_->SetVisible( |
| 1666 browser_->host_desktop_type() != chrome::HOST_DESKTOP_TYPE_ASH && |
| 1667 (other_bookmarked_button_->visible() || |
| 1668 apps_page_shortcut_->visible())); |
| 1669 } |
| 1670 |
1583 gfx::Size BookmarkBarView::LayoutItems(bool compute_bounds_only) { | 1671 gfx::Size BookmarkBarView::LayoutItems(bool compute_bounds_only) { |
1584 gfx::Size prefsize; | 1672 gfx::Size prefsize; |
1585 if (!parent() && !compute_bounds_only) | 1673 if (!parent() && !compute_bounds_only) |
1586 return prefsize; | 1674 return prefsize; |
1587 | 1675 |
1588 const chrome::search::Mode& mode = browser_->search_model()->mode(); | 1676 const chrome::search::Mode& mode = browser_->search_model()->mode(); |
1589 int x = kLeftMargin; | 1677 int x = kLeftMargin; |
1590 int top_margin = IsDetached() ? | 1678 int top_margin = IsDetached() ? |
1591 (mode.is_ntp() ? kSearchDetachedTopMargin : kDetachedTopMargin) : 0; | 1679 (mode.is_ntp() ? kSearchDetachedTopMargin : kDetachedTopMargin) : 0; |
1592 int y = top_margin; | 1680 int y = top_margin; |
(...skipping 15 matching lines...) Expand all Loading... |
1608 // also matches how we layout infobars. | 1696 // also matches how we layout infobars. |
1609 y += View::height() - browser_defaults::kBookmarkBarHeight; | 1697 y += View::height() - browser_defaults::kBookmarkBarHeight; |
1610 height += browser_defaults::kBookmarkBarHeight; | 1698 height += browser_defaults::kBookmarkBarHeight; |
1611 } | 1699 } |
1612 | 1700 |
1613 gfx::Size other_bookmarked_pref = other_bookmarked_button_->visible() ? | 1701 gfx::Size other_bookmarked_pref = other_bookmarked_button_->visible() ? |
1614 other_bookmarked_button_->GetPreferredSize() : gfx::Size(); | 1702 other_bookmarked_button_->GetPreferredSize() : gfx::Size(); |
1615 gfx::Size overflow_pref = overflow_button_->GetPreferredSize(); | 1703 gfx::Size overflow_pref = overflow_button_->GetPreferredSize(); |
1616 gfx::Size bookmarks_separator_pref = | 1704 gfx::Size bookmarks_separator_pref = |
1617 bookmarks_separator_view_->GetPreferredSize(); | 1705 bookmarks_separator_view_->GetPreferredSize(); |
| 1706 gfx::Size apps_page_shortcut_pref = apps_page_shortcut_->visible() ? |
| 1707 apps_page_shortcut_->GetPreferredSize() : gfx::Size(); |
1618 | 1708 |
1619 int max_x = width - overflow_pref.width() - kButtonPadding - | 1709 int max_x = width - overflow_pref.width() - kButtonPadding - |
1620 bookmarks_separator_pref.width(); | 1710 bookmarks_separator_pref.width(); |
1621 if (other_bookmarked_button_->visible()) | 1711 if (other_bookmarked_button_->visible()) |
1622 max_x -= other_bookmarked_pref.width() + kButtonPadding; | 1712 max_x -= other_bookmarked_pref.width() + kButtonPadding; |
| 1713 if (apps_page_shortcut_->visible()) |
| 1714 max_x -= apps_page_shortcut_pref.width() + kButtonPadding; |
1623 | 1715 |
1624 // Next, layout out the buttons. Any buttons that are placed beyond the | 1716 // Next, layout out the buttons. Any buttons that are placed beyond the |
1625 // visible region and made invisible. | 1717 // visible region and made invisible. |
1626 if (GetBookmarkButtonCount() == 0 && model_ && model_->IsLoaded()) { | 1718 if (GetBookmarkButtonCount() == 0 && model_ && model_->IsLoaded()) { |
1627 gfx::Size pref = instructions_->GetPreferredSize(); | 1719 gfx::Size pref = instructions_->GetPreferredSize(); |
1628 if (!compute_bounds_only) { | 1720 if (!compute_bounds_only) { |
1629 instructions_->SetBounds( | 1721 instructions_->SetBounds( |
1630 x + kInstructionsPadding, y, | 1722 x + kInstructionsPadding, y, |
1631 std::min(static_cast<int>(pref.width()), | 1723 std::min(static_cast<int>(pref.width()), |
1632 max_x - x), | 1724 max_x - x), |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1681 | 1773 |
1682 // The other bookmarks button. | 1774 // The other bookmarks button. |
1683 if (other_bookmarked_button_->visible()) { | 1775 if (other_bookmarked_button_->visible()) { |
1684 if (!compute_bounds_only) { | 1776 if (!compute_bounds_only) { |
1685 other_bookmarked_button_->SetBounds(x, y, other_bookmarked_pref.width(), | 1777 other_bookmarked_button_->SetBounds(x, y, other_bookmarked_pref.width(), |
1686 height); | 1778 height); |
1687 } | 1779 } |
1688 x += other_bookmarked_pref.width() + kButtonPadding; | 1780 x += other_bookmarked_pref.width() + kButtonPadding; |
1689 } | 1781 } |
1690 | 1782 |
| 1783 // The app page shortcut button. |
| 1784 if (apps_page_shortcut_->visible()) { |
| 1785 if (!compute_bounds_only) { |
| 1786 apps_page_shortcut_->SetBounds(x, y, apps_page_shortcut_pref.width(), |
| 1787 height); |
| 1788 } |
| 1789 x += apps_page_shortcut_pref.width() + kButtonPadding; |
| 1790 } |
| 1791 |
1691 // Set the preferred size computed so far. | 1792 // Set the preferred size computed so far. |
1692 if (compute_bounds_only) { | 1793 if (compute_bounds_only) { |
1693 x += kRightMargin; | 1794 x += kRightMargin; |
1694 prefsize.set_width(x); | 1795 prefsize.set_width(x); |
1695 if (IsDetached()) { | 1796 if (IsDetached()) { |
1696 x += static_cast<int>(GetNewtabHorizontalPadding(mode) * | 1797 x += static_cast<int>(GetNewtabHorizontalPadding(mode) * |
1697 (1 - size_animation_->GetCurrentValue())); | 1798 (1 - size_animation_->GetCurrentValue())); |
1698 int ntp_bookmark_bar_height = mode.is_ntp() ? | 1799 int ntp_bookmark_bar_height = mode.is_ntp() ? |
1699 kSearchNewTabBookmarkBarHeight : chrome::kNTPBookmarkBarHeight; | 1800 kSearchNewTabBookmarkBarHeight : chrome::kNTPBookmarkBarHeight; |
1700 prefsize.set_height( | 1801 prefsize.set_height( |
1701 browser_defaults::kBookmarkBarHeight + | 1802 browser_defaults::kBookmarkBarHeight + |
1702 static_cast<int>( | 1803 static_cast<int>( |
1703 (ntp_bookmark_bar_height - | 1804 (ntp_bookmark_bar_height - |
1704 browser_defaults::kBookmarkBarHeight) * | 1805 browser_defaults::kBookmarkBarHeight) * |
1705 (1 - size_animation_->GetCurrentValue()))); | 1806 (1 - size_animation_->GetCurrentValue()))); |
1706 } else { | 1807 } else { |
1707 prefsize.set_height( | 1808 prefsize.set_height( |
1708 static_cast<int>( | 1809 static_cast<int>( |
1709 browser_defaults::kBookmarkBarHeight * | 1810 browser_defaults::kBookmarkBarHeight * |
1710 size_animation_->GetCurrentValue())); | 1811 size_animation_->GetCurrentValue())); |
1711 } | 1812 } |
1712 } | 1813 } |
1713 return prefsize; | 1814 return prefsize; |
1714 } | 1815 } |
| 1816 |
| 1817 bool BookmarkBarView::ShouldShowAppsShortcut() const { |
| 1818 return chrome::search::IsInstantExtendedAPIEnabled(browser_->profile()) && |
| 1819 browser_->profile()->GetPrefs()->GetBoolean( |
| 1820 prefs::kShowAppsShortcutInBookmarkBar); |
| 1821 } |
| 1822 |
| 1823 void BookmarkBarView::OnAppsPageShortcutVisibilityChanged() { |
| 1824 DCHECK(apps_page_shortcut_); |
| 1825 apps_page_shortcut_->SetVisible(ShouldShowAppsShortcut()); |
| 1826 UpdateBookmarksSeparatorVisibility(); |
| 1827 Layout(); |
| 1828 } |
OLD | NEW |