blob: d2cb8a2ea385ab5ae70d17434a315223eb12c5df [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/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/views/controls/button/button.h"
#include "ui/views/style/typography.h"
const char ExtensionsMenuButton::kClassName[] = "ExtensionsMenuButton";
ExtensionsMenuButton::ExtensionsMenuButton(
Browser* browser,
ExtensionsMenuItemView* parent,
ToolbarActionViewController* controller,
bool allow_pinning)
: views::LabelButton(this),
browser_(browser),
parent_(parent),
controller_(controller),
allow_pinning_(allow_pinning) {
ConfigureBubbleMenuItem(this, 0);
SetButtonController(std::make_unique<HoverButtonController>(
this, this,
std::make_unique<views::Button::DefaultButtonControllerDelegate>(this)));
controller_->SetDelegate(this);
UpdateState();
}
ExtensionsMenuButton::~ExtensionsMenuButton() = default;
const char* ExtensionsMenuButton::GetClassName() const {
return kClassName;
}
SkColor ExtensionsMenuButton::GetInkDropBaseColor() const {
return HoverButton::GetInkDropColor(this);
}
bool ExtensionsMenuButton::CanShowIconInToolbar() const {
return allow_pinning_;
}
void ExtensionsMenuButton::ButtonPressed(Button* sender,
const ui::Event& event) {
base::RecordAction(
base::UserMetricsAction("Extensions.Toolbar.ExtensionActivatedFromMenu"));
controller_->ExecuteAction(
true, ToolbarActionViewController::InvocationSource::kMenuEntry);
}
// 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(), ExtensionsMenuItemView::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 gfx::Insets kBorderInsets =
gfx::Insets((ExtensionsMenuItemView::kMenuItemHeightDp -
ExtensionsMenuItemView::kIconSize.height()) /
2,
12);
SetBorder(views::CreateEmptyBorder(kBorderInsets));
}
bool ExtensionsMenuButton::IsMenuRunning() const {
return parent_->IsContextMenuRunning();
}