blob: 8a278037eee4ee789b3c10ed3e850a374a6e29ca [file] [log] [blame]
// Copyright 2019 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/extensions/extensions_menu_button.h"
#include "base/bind.h"
#include "base/metrics/user_metrics.h"
#include "base/metrics/user_metrics_action.h"
#include "chrome/browser/ui/toolbar/toolbar_action_view_controller.h"
#include "chrome/browser/ui/views/bubble_menu_item_factory.h"
#include "chrome/browser/ui/views/extensions/extensions_menu_item_view.h"
#include "chrome/browser/ui/views/extensions/extensions_menu_view.h"
#include "chrome/browser/ui/views/extensions/extensions_toolbar_button.h"
#include "chrome/browser/ui/views/frame/browser_view.h"
#include "chrome/browser/ui/views/hover_button.h"
#include "chrome/browser/ui/views/hover_button_controller.h"
#include "chrome/browser/ui/views/toolbar/toolbar_view.h"
#include "ui/base/metadata/metadata_impl_macros.h"
#include "ui/views/animation/ink_drop.h"
#include "ui/views/border.h"
#include "ui/views/controls/button/button.h"
#include "ui/views/style/typography.h"
ExtensionsMenuButton::ExtensionsMenuButton(
Browser* browser,
ToolbarActionViewController* controller)
: HoverButton(base::BindRepeating(&ExtensionsMenuButton::ButtonPressed,
base::Unretained(this)),
std::u16string()),
browser_(browser),
controller_(controller) {
controller_->SetDelegate(this);
// TODO(pbos): This currently inherits HoverButton, is this not a no-op?
// Also see call in OnThemeChanged() to
// views::InkDrop::Get(this)->SetBaseColor which tries to do the same thing.
views::InkDrop::Get(this)->SetBaseColorCallback(base::BindRepeating(
[](views::View* host) { return HoverButton::GetInkDropColor(host); },
this));
}
ExtensionsMenuButton::~ExtensionsMenuButton() = default;
void ExtensionsMenuButton::AddedToWidget() {
ConfigureBubbleMenuItem(this, 0);
UpdateState();
}
void ExtensionsMenuButton::OnThemeChanged() {
HoverButton::OnThemeChanged();
views::InkDrop::Get(this)->SetBaseColor(HoverButton::GetInkDropColor(this));
}
// ToolbarActionViewDelegateViews:
views::View* ExtensionsMenuButton::GetAsView() {
return this;
}
views::FocusManager* ExtensionsMenuButton::GetFocusManagerForAccelerator() {
return GetFocusManager();
}
views::Button* ExtensionsMenuButton::GetReferenceButtonForPopup() {
return BrowserView::GetBrowserViewForBrowser(browser_)
->toolbar()
->GetExtensionsButton();
}
content::WebContents* ExtensionsMenuButton::GetCurrentWebContents() const {
return browser_->tab_strip_model()->GetActiveWebContents();
}
void ExtensionsMenuButton::UpdateState() {
SetImage(Button::STATE_NORMAL,
controller_
->GetIcon(GetCurrentWebContents(),
InstalledExtensionMenuItemView::kIconSize)
.AsImageSkia());
SetText(controller_->GetActionName());
SetTooltipText(controller_->GetTooltip(GetCurrentWebContents()));
SetEnabled(controller_->IsEnabled(GetCurrentWebContents()));
// The horizontal insets reasonably align the extension icons with text inside
// the dialog. Note that |kIconSize| also contains space for badging, so we
// can't trivially use dialog-text insets (empty space inside the icon).
constexpr auto kBorderInsets =
gfx::Insets::VH((InstalledExtensionMenuItemView::kMenuItemHeightDp -
InstalledExtensionMenuItemView::kIconSize.height()) /
2,
12);
SetBorder(views::CreateEmptyBorder(kBorderInsets));
}
void ExtensionsMenuButton::ShowContextMenuAsFallback() {
// The items in the extensions menu are disabled and unclickable if the
// primary action cannot be taken; ShowContextMenuAsFallback() should never
// be called directly.
NOTREACHED();
}
void ExtensionsMenuButton::ButtonPressed() {
base::RecordAction(
base::UserMetricsAction("Extensions.Toolbar.ExtensionActivatedFromMenu"));
controller_->ExecuteUserAction(
ToolbarActionViewController::InvocationSource::kMenuEntry);
}
BEGIN_METADATA(ExtensionsMenuButton, views::LabelButton)
END_METADATA