| 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/browser_action_view.h" | 5 #include "chrome/browser/ui/views/toolbar/browser_action_view.h" |
| 6 | 6 |
| 7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
| 8 #include "chrome/browser/chrome_notification_types.h" | 8 #include "chrome/browser/chrome_notification_types.h" |
| 9 #include "chrome/browser/extensions/api/commands/command_service.h" | 9 #include "chrome/browser/extensions/api/commands/command_service.h" |
| 10 #include "chrome/browser/extensions/extension_action.h" | 10 #include "chrome/browser/extensions/extension_action.h" |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 #include "ui/gfx/image/image_skia_operations.h" | 30 #include "ui/gfx/image/image_skia_operations.h" |
| 31 #include "ui/gfx/image/image_skia_source.h" | 31 #include "ui/gfx/image/image_skia_source.h" |
| 32 #include "ui/views/controls/menu/menu_item_view.h" | 32 #include "ui/views/controls/menu/menu_item_view.h" |
| 33 #include "ui/views/controls/menu/menu_runner.h" | 33 #include "ui/views/controls/menu/menu_runner.h" |
| 34 | 34 |
| 35 using extensions::Extension; | 35 using extensions::Extension; |
| 36 | 36 |
| 37 //////////////////////////////////////////////////////////////////////////////// | 37 //////////////////////////////////////////////////////////////////////////////// |
| 38 // BrowserActionView | 38 // BrowserActionView |
| 39 | 39 |
| 40 bool BrowserActionView::Delegate::NeedToShowMultipleIconStates() const { |
| 41 return true; |
| 42 } |
| 43 |
| 44 bool BrowserActionView::Delegate::NeedToShowTooltip() const { |
| 45 return true; |
| 46 } |
| 47 |
| 40 BrowserActionView::BrowserActionView(const Extension* extension, | 48 BrowserActionView::BrowserActionView(const Extension* extension, |
| 41 Browser* browser, | 49 Browser* browser, |
| 42 BrowserActionView::Delegate* delegate) | 50 BrowserActionView::Delegate* delegate) |
| 43 : browser_(browser), | 51 : browser_(browser), |
| 44 delegate_(delegate), | 52 delegate_(delegate), |
| 45 button_(NULL), | 53 button_(NULL), |
| 46 extension_(extension) { | 54 extension_(extension) { |
| 47 set_id(VIEW_ID_BROWSER_ACTION); | 55 set_id(VIEW_ID_BROWSER_ACTION); |
| 48 button_ = new BrowserActionButton(extension_, browser_, delegate_); | 56 button_ = new BrowserActionButton(extension_, browser_, delegate_); |
| 49 button_->set_drag_controller(delegate_); | 57 button_->set_drag_controller(delegate_); |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 95 browser_action_( | 103 browser_action_( |
| 96 extensions::ExtensionActionManager::Get(browser->profile())-> | 104 extensions::ExtensionActionManager::Get(browser->profile())-> |
| 97 GetBrowserAction(*extension)), | 105 GetBrowserAction(*extension)), |
| 98 extension_(extension), | 106 extension_(extension), |
| 99 icon_factory_(browser->profile(), extension, browser_action_, this), | 107 icon_factory_(browser->profile(), extension, browser_action_, this), |
| 100 delegate_(delegate), | 108 delegate_(delegate), |
| 101 context_menu_(NULL), | 109 context_menu_(NULL), |
| 102 called_registered_extension_command_(false), | 110 called_registered_extension_command_(false), |
| 103 icon_observer_(NULL) { | 111 icon_observer_(NULL) { |
| 104 SetBorder(views::Border::NullBorder()); | 112 SetBorder(views::Border::NullBorder()); |
| 105 SetHorizontalAlignment(gfx::ALIGN_CENTER); | 113 set_alignment(TextButton::ALIGN_CENTER); |
| 106 set_context_menu_controller(this); | 114 set_context_menu_controller(this); |
| 107 | 115 |
| 108 // No UpdateState() here because View hierarchy not setup yet. Our parent | 116 // No UpdateState() here because View hierarchy not setup yet. Our parent |
| 109 // should call UpdateState() after creation. | 117 // should call UpdateState() after creation. |
| 110 | 118 |
| 111 content::NotificationSource notification_source = | 119 content::NotificationSource notification_source = |
| 112 content::Source<Profile>(browser_->profile()->GetOriginalProfile()); | 120 content::Source<Profile>(browser_->profile()->GetOriginalProfile()); |
| 113 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_BROWSER_ACTION_UPDATED, | 121 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_BROWSER_ACTION_UPDATED, |
| 114 content::Source<ExtensionAction>(browser_action_)); | 122 content::Source<ExtensionAction>(browser_action_)); |
| 115 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_COMMAND_ADDED, | 123 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_COMMAND_ADDED, |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 196 menu_runner_.reset(); | 204 menu_runner_.reset(); |
| 197 SetButtonNotPushed(); | 205 SetButtonNotPushed(); |
| 198 context_menu_ = NULL; | 206 context_menu_ = NULL; |
| 199 } | 207 } |
| 200 | 208 |
| 201 void BrowserActionButton::UpdateState() { | 209 void BrowserActionButton::UpdateState() { |
| 202 int tab_id = delegate_->GetCurrentTabId(); | 210 int tab_id = delegate_->GetCurrentTabId(); |
| 203 if (tab_id < 0) | 211 if (tab_id < 0) |
| 204 return; | 212 return; |
| 205 | 213 |
| 214 SetShowMultipleIconStates(delegate_->NeedToShowMultipleIconStates()); |
| 215 |
| 206 if (!IsEnabled(tab_id)) { | 216 if (!IsEnabled(tab_id)) { |
| 207 SetState(views::CustomButton::STATE_DISABLED); | 217 SetState(views::CustomButton::STATE_DISABLED); |
| 208 } else { | 218 } else { |
| 209 SetState(menu_visible_ ? | 219 SetState(menu_visible_ ? |
| 210 views::CustomButton::STATE_PRESSED : | 220 views::CustomButton::STATE_PRESSED : |
| 211 views::CustomButton::STATE_NORMAL); | 221 views::CustomButton::STATE_NORMAL); |
| 212 } | 222 } |
| 213 | 223 |
| 214 gfx::ImageSkia icon = *icon_factory_.GetIcon(tab_id).ToImageSkia(); | 224 gfx::ImageSkia icon = *icon_factory_.GetIcon(tab_id).ToImageSkia(); |
| 215 | 225 |
| 216 if (!icon.isNull()) { | 226 if (!icon.isNull()) { |
| 217 if (!browser_action()->GetIsVisible(tab_id)) | 227 if (!browser_action()->GetIsVisible(tab_id)) |
| 218 icon = gfx::ImageSkiaOperations::CreateTransparentImage(icon, .25); | 228 icon = gfx::ImageSkiaOperations::CreateTransparentImage(icon, .25); |
| 219 | 229 |
| 220 ThemeService* theme = | 230 ThemeService* theme = |
| 221 ThemeServiceFactory::GetForProfile(browser_->profile()); | 231 ThemeServiceFactory::GetForProfile(browser_->profile()); |
| 222 | 232 |
| 223 gfx::ImageSkia bg = *theme->GetImageSkiaNamed(IDR_BROWSER_ACTION); | 233 gfx::ImageSkia bg = *theme->GetImageSkiaNamed(IDR_BROWSER_ACTION); |
| 224 SetImage(views::Button::STATE_NORMAL, | 234 SetIcon(gfx::ImageSkiaOperations::CreateSuperimposedImage(bg, icon)); |
| 225 gfx::ImageSkiaOperations::CreateSuperimposedImage(bg, icon)); | |
| 226 | 235 |
| 227 gfx::ImageSkia bg_h = *theme->GetImageSkiaNamed(IDR_BROWSER_ACTION_H); | 236 gfx::ImageSkia bg_h = *theme->GetImageSkiaNamed(IDR_BROWSER_ACTION_H); |
| 228 SetImage(views::Button::STATE_HOVERED, | 237 SetHoverIcon(gfx::ImageSkiaOperations::CreateSuperimposedImage(bg_h, icon)); |
| 229 gfx::ImageSkiaOperations::CreateSuperimposedImage(bg_h, icon)); | |
| 230 | 238 |
| 231 gfx::ImageSkia bg_p = *theme->GetImageSkiaNamed(IDR_BROWSER_ACTION_P); | 239 gfx::ImageSkia bg_p = *theme->GetImageSkiaNamed(IDR_BROWSER_ACTION_P); |
| 232 SetImage(views::Button::STATE_PRESSED, | 240 SetPushedIcon( |
| 233 gfx::ImageSkiaOperations::CreateSuperimposedImage(bg_p, icon)); | 241 gfx::ImageSkiaOperations::CreateSuperimposedImage(bg_p, icon)); |
| 234 } | 242 } |
| 235 | 243 |
| 236 // If the browser action name is empty, show the extension name instead. | 244 // If the browser action name is empty, show the extension name instead. |
| 237 std::string title = browser_action()->GetTitle(tab_id); | 245 std::string title = browser_action()->GetTitle(tab_id); |
| 238 base::string16 name = | 246 base::string16 name = |
| 239 base::UTF8ToUTF16(title.empty() ? extension()->name() : title); | 247 base::UTF8ToUTF16(title.empty() ? extension()->name() : title); |
| 240 SetTooltipText(name); | 248 SetTooltipText(delegate_->NeedToShowTooltip() ? name : base::string16()); |
| 241 SetAccessibleName(name); | 249 SetAccessibleName(name); |
| 242 | 250 |
| 243 parent()->SchedulePaint(); | 251 parent()->SchedulePaint(); |
| 244 } | 252 } |
| 245 | 253 |
| 246 bool BrowserActionButton::IsPopup() { | 254 bool BrowserActionButton::IsPopup() { |
| 247 int tab_id = delegate_->GetCurrentTabId(); | 255 int tab_id = delegate_->GetCurrentTabId(); |
| 248 return (tab_id < 0) ? false : browser_action_->HasPopup(tab_id); | 256 return (tab_id < 0) ? false : browser_action_->HasPopup(tab_id); |
| 249 } | 257 } |
| 250 | 258 |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 305 // The return value of this method is returned via OnMousePressed. | 313 // The return value of this method is returned via OnMousePressed. |
| 306 // We need to return false here since we're handing off focus to another | 314 // We need to return false here since we're handing off focus to another |
| 307 // widget/view, and true will grab it right back and try to send events | 315 // widget/view, and true will grab it right back and try to send events |
| 308 // to us. | 316 // to us. |
| 309 return false; | 317 return false; |
| 310 } | 318 } |
| 311 | 319 |
| 312 bool BrowserActionButton::OnMousePressed(const ui::MouseEvent& event) { | 320 bool BrowserActionButton::OnMousePressed(const ui::MouseEvent& event) { |
| 313 if (!event.IsRightMouseButton()) { | 321 if (!event.IsRightMouseButton()) { |
| 314 return IsPopup() ? MenuButton::OnMousePressed(event) : | 322 return IsPopup() ? MenuButton::OnMousePressed(event) : |
| 315 LabelButton::OnMousePressed(event); | 323 TextButton::OnMousePressed(event); |
| 316 } | 324 } |
| 317 | 325 |
| 318 if (!views::View::ShouldShowContextMenuOnMousePress()) { | 326 if (!views::View::ShouldShowContextMenuOnMousePress()) { |
| 319 // See comments in MenuButton::Activate() as to why this is needed. | 327 // See comments in MenuButton::Activate() as to why this is needed. |
| 320 SetMouseHandler(NULL); | 328 SetMouseHandler(NULL); |
| 321 | 329 |
| 322 ShowContextMenu(gfx::Point(), ui::MENU_SOURCE_MOUSE); | 330 ShowContextMenu(gfx::Point(), ui::MENU_SOURCE_MOUSE); |
| 323 } | 331 } |
| 324 return false; | 332 return false; |
| 325 } | 333 } |
| 326 | 334 |
| 327 void BrowserActionButton::OnMouseReleased(const ui::MouseEvent& event) { | 335 void BrowserActionButton::OnMouseReleased(const ui::MouseEvent& event) { |
| 328 if (IsPopup() || context_menu_) { | 336 if (IsPopup() || context_menu_) { |
| 329 // TODO(erikkay) this never actually gets called (probably because of the | 337 // TODO(erikkay) this never actually gets called (probably because of the |
| 330 // loss of focus). | 338 // loss of focus). |
| 331 MenuButton::OnMouseReleased(event); | 339 MenuButton::OnMouseReleased(event); |
| 332 } else { | 340 } else { |
| 333 LabelButton::OnMouseReleased(event); | 341 TextButton::OnMouseReleased(event); |
| 334 } | 342 } |
| 335 } | 343 } |
| 336 | 344 |
| 337 void BrowserActionButton::OnMouseExited(const ui::MouseEvent& event) { | 345 void BrowserActionButton::OnMouseExited(const ui::MouseEvent& event) { |
| 338 if (IsPopup() || context_menu_) | 346 if (IsPopup() || context_menu_) |
| 339 MenuButton::OnMouseExited(event); | 347 MenuButton::OnMouseExited(event); |
| 340 else | 348 else |
| 341 LabelButton::OnMouseExited(event); | 349 TextButton::OnMouseExited(event); |
| 342 } | 350 } |
| 343 | 351 |
| 344 bool BrowserActionButton::OnKeyReleased(const ui::KeyEvent& event) { | 352 bool BrowserActionButton::OnKeyReleased(const ui::KeyEvent& event) { |
| 345 return IsPopup() ? MenuButton::OnKeyReleased(event) : | 353 return IsPopup() ? MenuButton::OnKeyReleased(event) : |
| 346 LabelButton::OnKeyReleased(event); | 354 TextButton::OnKeyReleased(event); |
| 347 } | 355 } |
| 348 | 356 |
| 349 void BrowserActionButton::OnGestureEvent(ui::GestureEvent* event) { | 357 void BrowserActionButton::OnGestureEvent(ui::GestureEvent* event) { |
| 350 if (IsPopup()) | 358 if (IsPopup()) |
| 351 MenuButton::OnGestureEvent(event); | 359 MenuButton::OnGestureEvent(event); |
| 352 else | 360 else |
| 353 LabelButton::OnGestureEvent(event); | 361 TextButton::OnGestureEvent(event); |
| 354 } | 362 } |
| 355 | 363 |
| 356 bool BrowserActionButton::AcceleratorPressed( | 364 bool BrowserActionButton::AcceleratorPressed( |
| 357 const ui::Accelerator& accelerator) { | 365 const ui::Accelerator& accelerator) { |
| 358 delegate_->OnBrowserActionExecuted(this); | 366 delegate_->OnBrowserActionExecuted(this); |
| 359 return true; | 367 return true; |
| 360 } | 368 } |
| 361 | 369 |
| 362 void BrowserActionButton::SetButtonPushed() { | 370 void BrowserActionButton::SetButtonPushed() { |
| 363 SetState(views::CustomButton::STATE_PRESSED); | 371 SetState(views::CustomButton::STATE_PRESSED); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 376 gfx::ImageSkia BrowserActionButton::GetIconWithBadge() { | 384 gfx::ImageSkia BrowserActionButton::GetIconWithBadge() { |
| 377 int tab_id = delegate_->GetCurrentTabId(); | 385 int tab_id = delegate_->GetCurrentTabId(); |
| 378 gfx::Size spacing(0, ToolbarView::kVertSpacing); | 386 gfx::Size spacing(0, ToolbarView::kVertSpacing); |
| 379 gfx::ImageSkia icon = *icon_factory_.GetIcon(tab_id).ToImageSkia(); | 387 gfx::ImageSkia icon = *icon_factory_.GetIcon(tab_id).ToImageSkia(); |
| 380 if (!IsEnabled(tab_id)) | 388 if (!IsEnabled(tab_id)) |
| 381 icon = gfx::ImageSkiaOperations::CreateTransparentImage(icon, .25); | 389 icon = gfx::ImageSkiaOperations::CreateTransparentImage(icon, .25); |
| 382 return browser_action_->GetIconWithBadge(icon, tab_id, spacing); | 390 return browser_action_->GetIconWithBadge(icon, tab_id, spacing); |
| 383 } | 391 } |
| 384 | 392 |
| 385 gfx::ImageSkia BrowserActionButton::GetIconForTest() { | 393 gfx::ImageSkia BrowserActionButton::GetIconForTest() { |
| 386 return GetImage(views::Button::STATE_NORMAL); | 394 return icon(); |
| 387 } | 395 } |
| 388 | 396 |
| 389 BrowserActionButton::~BrowserActionButton() { | 397 BrowserActionButton::~BrowserActionButton() { |
| 390 } | 398 } |
| 391 | 399 |
| 392 void BrowserActionButton::MaybeRegisterExtensionCommand() { | 400 void BrowserActionButton::MaybeRegisterExtensionCommand() { |
| 393 extensions::CommandService* command_service = | 401 extensions::CommandService* command_service = |
| 394 extensions::CommandService::Get(browser_->profile()); | 402 extensions::CommandService::Get(browser_->profile()); |
| 395 extensions::Command browser_action_command; | 403 extensions::Command browser_action_command; |
| 396 if (command_service->GetBrowserActionCommand( | 404 if (command_service->GetBrowserActionCommand( |
| (...skipping 18 matching lines...) Expand all Loading... |
| 415 extensions::Command browser_action_command; | 423 extensions::Command browser_action_command; |
| 416 if (!only_if_active || !command_service->GetBrowserActionCommand( | 424 if (!only_if_active || !command_service->GetBrowserActionCommand( |
| 417 extension_->id(), | 425 extension_->id(), |
| 418 extensions::CommandService::ACTIVE_ONLY, | 426 extensions::CommandService::ACTIVE_ONLY, |
| 419 &browser_action_command, | 427 &browser_action_command, |
| 420 NULL)) { | 428 NULL)) { |
| 421 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); | 429 GetFocusManager()->UnregisterAccelerator(*keybinding_.get(), this); |
| 422 keybinding_.reset(NULL); | 430 keybinding_.reset(NULL); |
| 423 } | 431 } |
| 424 } | 432 } |
| OLD | NEW |