2017-02-22 19:05:27 +01:00
|
|
|
// Copyright (c) 2017 The Chromium Embedded Framework Authors. All rights
|
|
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
|
|
// can be found in the LICENSE file.
|
|
|
|
|
|
|
|
#ifndef CEF_TESTS_CEFCLIENT_BROWSER_VIEWS_MENU_BAR_H_
|
|
|
|
#define CEF_TESTS_CEFCLIENT_BROWSER_VIEWS_MENU_BAR_H_
|
|
|
|
#pragma once
|
|
|
|
|
2017-02-23 21:24:45 +01:00
|
|
|
#include <map>
|
2017-02-22 19:05:27 +01:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "include/cef_menu_model.h"
|
|
|
|
#include "include/cef_menu_model_delegate.h"
|
|
|
|
#include "include/views/cef_menu_button.h"
|
|
|
|
#include "include/views/cef_menu_button_delegate.h"
|
|
|
|
#include "include/views/cef_panel.h"
|
|
|
|
|
|
|
|
namespace client {
|
|
|
|
|
|
|
|
// Implements a menu bar which is composed of CefMenuButtons positioned in a
|
|
|
|
// row with automatic switching between them via mouse/keyboard. All methods
|
|
|
|
// must be called on the browser process UI thread.
|
2017-05-17 11:29:28 +02:00
|
|
|
class ViewsMenuBar : public CefMenuButtonDelegate, public CefMenuModelDelegate {
|
2017-02-22 19:05:27 +01:00
|
|
|
public:
|
|
|
|
// Delegate methods will be called on the browser process UI thread.
|
|
|
|
class Delegate {
|
|
|
|
public:
|
|
|
|
// Called when a menu command is selected.
|
|
|
|
virtual void MenuBarExecuteCommand(CefRefPtr<CefMenuModel> menu_model,
|
|
|
|
int command_id,
|
2017-05-17 11:29:28 +02:00
|
|
|
cef_event_flags_t event_flags) = 0;
|
2017-02-22 19:05:27 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual ~Delegate() {}
|
|
|
|
};
|
|
|
|
|
|
|
|
// |delegate| must outlive this object.
|
|
|
|
// |menu_id_start| is the ID for the first CefMenuButton in the bar. An ID
|
|
|
|
// range starting with |menu_id_start| and extending for a reasonable distance
|
|
|
|
// should be reserved in the client for MenuBar usage.
|
2017-05-17 11:29:28 +02:00
|
|
|
ViewsMenuBar(Delegate* delegate, int menu_id_start);
|
2017-02-22 19:05:27 +01:00
|
|
|
|
|
|
|
// Returns true if |menu_id| exists in the menu bar.
|
|
|
|
bool HasMenuId(int menu_id) const;
|
|
|
|
|
|
|
|
// Returns the CefPanel that represents the menu bar.
|
|
|
|
CefRefPtr<CefPanel> GetMenuPanel();
|
|
|
|
|
2021-06-17 22:08:01 +02:00
|
|
|
// Create a new menu with the specified |label|. If |menu_id| is non-nullptr
|
|
|
|
// it will be populated with the new menu ID.
|
2017-05-17 11:29:28 +02:00
|
|
|
CefRefPtr<CefMenuModel> CreateMenuModel(const CefString& label, int* menu_id);
|
2017-02-22 19:05:27 +01:00
|
|
|
|
2021-06-17 22:08:01 +02:00
|
|
|
// Returns the menu with the specified |menu_id|, or nullptr if no such menu
|
2017-02-22 19:05:27 +01:00
|
|
|
// exists.
|
|
|
|
CefRefPtr<CefMenuModel> GetMenuModel(int menu_id) const;
|
|
|
|
|
|
|
|
// Assign or remove focus from the menu bar.
|
|
|
|
// Focus is assigned to the menu bar by ViewsWindow::OnKeyEvent when the ALT
|
|
|
|
// key is pressed. Focus is removed from the menu bar by ViewsWindow::OnFocus
|
|
|
|
// when a control not in the menu bar gains focus.
|
|
|
|
void SetMenuFocusable(bool focusable);
|
|
|
|
|
2017-02-23 21:24:45 +01:00
|
|
|
// Key events forwarded from ViewsWindow::OnKeyEvent when the menu bar has
|
|
|
|
// focus.
|
|
|
|
bool OnKeyEvent(const CefKeyEvent& event);
|
|
|
|
|
2017-02-22 19:05:27 +01:00
|
|
|
// Reset menu bar state.
|
|
|
|
void Reset();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// CefButtonDelegate methods:
|
2021-06-17 21:43:06 +02:00
|
|
|
void OnButtonPressed(CefRefPtr<CefButton> button) override {}
|
2017-02-22 19:05:27 +01:00
|
|
|
|
|
|
|
// CefMenuButtonDelegate methods:
|
2017-08-04 00:55:19 +02:00
|
|
|
void OnMenuButtonPressed(
|
|
|
|
CefRefPtr<CefMenuButton> menu_button,
|
|
|
|
const CefPoint& screen_point,
|
2021-06-17 21:43:06 +02:00
|
|
|
CefRefPtr<CefMenuButtonPressedLock> button_pressed_lock) override;
|
2017-02-22 19:05:27 +01:00
|
|
|
|
|
|
|
// CefMenuModelDelegate methods:
|
|
|
|
void ExecuteCommand(CefRefPtr<CefMenuModel> menu_model,
|
|
|
|
int command_id,
|
2021-06-17 21:43:06 +02:00
|
|
|
cef_event_flags_t event_flags) override;
|
2017-02-22 19:05:27 +01:00
|
|
|
void MouseOutsideMenu(CefRefPtr<CefMenuModel> menu_model,
|
2021-06-17 21:43:06 +02:00
|
|
|
const CefPoint& screen_point) override;
|
2017-02-22 19:05:27 +01:00
|
|
|
void UnhandledOpenSubmenu(CefRefPtr<CefMenuModel> menu_model,
|
2021-06-17 21:43:06 +02:00
|
|
|
bool is_rtl) override;
|
2017-02-22 19:05:27 +01:00
|
|
|
void UnhandledCloseSubmenu(CefRefPtr<CefMenuModel> menu_model,
|
2021-06-17 21:43:06 +02:00
|
|
|
bool is_rtl) override;
|
|
|
|
void MenuClosed(CefRefPtr<CefMenuModel> menu_model) override;
|
2017-02-22 19:05:27 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
// Creates the menu panel if it doesn't already exist.
|
|
|
|
void EnsureMenuPanel();
|
|
|
|
|
|
|
|
// Returns the ID for the currently active menu, or -1 if no menu is currently
|
|
|
|
// active.
|
|
|
|
int GetActiveMenuId();
|
|
|
|
|
|
|
|
// Triggers the menu at the specified |offset| from the currently active menu.
|
|
|
|
void TriggerNextMenu(int offset);
|
|
|
|
|
|
|
|
// Triggers the specified MenuButton |button|.
|
|
|
|
void TriggerMenuButton(CefRefPtr<CefView> button);
|
|
|
|
|
|
|
|
Delegate* delegate_; // Not owned by this object.
|
|
|
|
const int id_start_;
|
|
|
|
int id_next_;
|
|
|
|
CefRefPtr<CefPanel> panel_;
|
2017-05-17 11:29:28 +02:00
|
|
|
std::vector<CefRefPtr<CefMenuModel>> models_;
|
2017-02-22 19:05:27 +01:00
|
|
|
bool last_nav_with_keyboard_;
|
|
|
|
|
2017-02-23 21:24:45 +01:00
|
|
|
// Map of mnemonic to MenuButton ID.
|
2021-04-21 00:52:34 +02:00
|
|
|
typedef std::map<char16, int> MnemonicMap;
|
2017-02-23 21:24:45 +01:00
|
|
|
MnemonicMap mnemonics_;
|
|
|
|
|
2017-02-22 19:05:27 +01:00
|
|
|
IMPLEMENT_REFCOUNTING(ViewsMenuBar);
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(ViewsMenuBar);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace client
|
|
|
|
|
|
|
|
#endif // CEF_TESTS_CEFCLIENT_BROWSER_VIEWS_MENU_BAR_H_
|