1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
|
// Copyright 2025 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_TABS_SPLIT_TAB_MENU_MODEL_H_
#define CHROME_BROWSER_UI_TABS_SPLIT_TAB_MENU_MODEL_H_
#include <cstddef>
#include <optional>
#include <string>
#include "chrome/browser/ui/tabs/existing_base_sub_menu_model.h"
#include "ui/base/interaction/element_identifier.h"
#include "ui/menus/simple_menu_model.h"
class TabStripModel;
namespace ui {
class ImageModel;
} // namespace ui
namespace gfx {
struct VectorIcon;
}
namespace split_tabs {
class SplitTabId;
enum class SplitTabActiveLocation;
enum class SplitTabLayout;
} // namespace split_tabs
class SplitTabMenuModel : public ui::SimpleMenuModel,
public ui::SimpleMenuModel::Delegate {
public:
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kReversePositionMenuItem);
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kCloseMenuItem);
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kCloseStartTabMenuItem);
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kCloseEndTabMenuItem);
DECLARE_CLASS_ELEMENT_IDENTIFIER_VALUE(kExitSplitMenuItem);
// These values are persisted to logs. Entries should not be renumbered and
// number values should never be reused.
// LINT.IfChange(SplitViewMenuEntry)
enum class CommandId {
kReversePosition = 0,
kCloseSpecifiedTab,
kCloseStartTab,
kCloseEndTab,
kExitSplit,
kMaxValue = kExitSplit,
};
// LINT.ThenChange(//tools/metrics/histograms/metadata/tab/enums.xml:SplitViewMenuEntry)
// Enum denoting where this menu is opening from. This is used to determine
// which close options to show and for logging.
enum class MenuSource {
kToolbarButton,
kMiniToolbar,
kTabContextMenu,
};
SplitTabMenuModel(TabStripModel* tab_strip_model,
MenuSource menu_source,
std::optional<int> split_tab_index = std::nullopt);
~SplitTabMenuModel() override;
// ui::SimpleMenuModel::Delegate override
bool IsItemForCommandIdDynamic(int command_id) const override;
std::u16string GetLabelForCommandId(int command_id) const override;
ui::ImageModel GetIconForCommandId(int command_id) const override;
void ExecuteCommand(int command_id, int event_flags) override;
private:
// Returns the split id for the split tabs that this menu is acting on.
split_tabs::SplitTabId GetSplitTabId() const;
const gfx::VectorIcon& GetReversePositionIcon(
split_tabs::SplitTabActiveLocation active_split_tab_location) const;
split_tabs::SplitTabLayout GetSplitLayout() const;
void CloseTabAtIndex(int index);
raw_ptr<TabStripModel> tab_strip_model_ = nullptr;
// This represents where the menu was opened from, for metrics logging
// purposes.
MenuSource menu_source_;
// This represents the tab that this menu model should be operating on. If
// nothing is provided, use the currently active tab.
std::optional<int> split_tab_index_;
};
#endif // CHROME_BROWSER_UI_TABS_SPLIT_TAB_MENU_MODEL_H_
|