blob: 60151478bc773104c67714a62bfcd0d8936defc6 [file] [log] [blame]
// Copyright 2011 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_UI_VIEWS_BOOKMARKS_BOOKMARK_CONTEXT_MENU_H_
#define CHROME_BROWSER_UI_VIEWS_BOOKMARKS_BOOKMARK_CONTEXT_MENU_H_
#include "base/functional/callback_forward.h"
#include "base/memory/raw_ptr.h"
#include "chrome/browser/ui/bookmarks/bookmark_context_menu_controller.h"
#include "chrome/browser/ui/bookmarks/bookmark_stats.h"
#include "ui/base/mojom/menu_source_type.mojom-forward.h"
#include "ui/views/controls/menu/menu_delegate.h"
class Browser;
namespace views {
class MenuRunner;
class Widget;
} // namespace views
// Observer for the BookmarkContextMenu.
class BookmarkContextMenuObserver : public base::CheckedObserver {
public:
// Invoked before the specified items are removed from the bookmark model.
virtual void WillRemoveBookmarks(
const std::vector<raw_ptr<const bookmarks::BookmarkNode,
VectorExperimental>>& bookmarks) = 0;
// Invoked after the items have been removed from the model.
virtual void DidRemoveBookmarks() = 0;
// Invoked when the context menu is closed.
virtual void OnContextMenuClosed() = 0;
protected:
~BookmarkContextMenuObserver() override;
};
class BookmarkContextMenu : public BookmarkContextMenuControllerDelegate,
public views::MenuDelegate {
public:
// |browser| is used to open bookmarks as well as the bookmark manager, and
// is NULL in tests.
BookmarkContextMenu(views::Widget* parent_widget,
Browser* browser,
Profile* profile,
BookmarkLaunchLocation opened_from,
const std::vector<raw_ptr<const bookmarks::BookmarkNode,
VectorExperimental>>& selection,
bool close_on_remove);
BookmarkContextMenu(const BookmarkContextMenu&) = delete;
BookmarkContextMenu& operator=(const BookmarkContextMenu&) = delete;
~BookmarkContextMenu() override;
// Installs a callback to be run before the context menu is run. The callback
// runs only once, and only one such callback can be set at any time. Once the
// installed callback is run, another callback can be installed.
static void InstallPreRunCallback(base::OnceClosure callback);
// Shows the context menu at the specified point.
void RunMenuAt(const gfx::Point& point,
ui::mojom::MenuSourceType source_type);
views::MenuItemView* menu() const { return menu_; }
void AddObserver(BookmarkContextMenuObserver* observer);
void RemoveObserver(BookmarkContextMenuObserver* observer);
// Overridden from views::MenuDelegate:
void ExecuteCommand(int command_id, int event_flags) override;
bool IsItemChecked(int command_id) const override;
bool IsCommandEnabled(int command_id) const override;
bool IsCommandVisible(int command_id) const override;
bool ShouldCloseAllMenusOnExecute(int id) override;
void OnMenuClosed(views::MenuItemView* menu) override;
// Overridden from BookmarkContextMenuControllerDelegate:
void CloseMenu() override;
void WillExecuteCommand(
int command_id,
const std::vector<raw_ptr<const bookmarks::BookmarkNode,
VectorExperimental>>& bookmarks) override;
void DidExecuteCommand(int command_id) override;
private:
std::unique_ptr<BookmarkContextMenuController> controller_;
// The parent of dialog boxes opened from the context menu.
const raw_ptr<views::Widget> parent_widget_;
// Responsible for running the menu.
std::unique_ptr<views::MenuRunner> menu_runner_;
// The menu itself. This is owned by `menu_runner_`.
const raw_ptr<views::MenuItemView> menu_;
base::ObserverList<BookmarkContextMenuObserver> observers_;
// Should the menu close when a node is removed.
bool close_on_remove_;
};
#endif // CHROME_BROWSER_UI_VIEWS_BOOKMARKS_BOOKMARK_CONTEXT_MENU_H_