![electron-roller[bot]](/assets/img/avatar_default.png)
* chore: bump chromium in DEPS to 92.0.4512.6 * 2887336: [CaptureHandle][#2] Propagate CaptureHandleConfig in browser process2887336
* refactor: base::Optional -> absl::optional * chore: fixup patch indices * chore: bump chromium in DEPS to 92.0.4514.0 * 2899417: Make build work when enable_pdf is set to false.2899417
* 2904731: use BrowserContext instead of Profile in PreconnectManager2904731
* 2295749: fix: check IsSecureEventInputEnabled in constructor before setting SetPasswordInputEnabled to true2295749
* 2893803: Add a GetWebView to RenderFrame.2893803
* 2892345: Implement WebContents::ForEachRenderFrameHost2892345
* chore: fixup patch indices * 2892048: Real instance methods for BrowserContext: remaining 5 methods.2892048
* 2902821: [mojo] Don't require full header includes for referenced interfaces2902821
* 2496500: Remove last deprecated extension Event ctor.2496500
* chore: fixup malformed pepper support patch * chore: bump chromium in DEPS to 92.0.4515.0 * 2908461: Add CreateEmptyPrintPagesParamsPtr() inside print_view_manager_base.cc.2908461
* 2880838: viz: add optional HDRMetadata to TransferableResource2880838
* chore: fixup patch indices * chore: bump chromium in DEPS to 92.0.4515.5 * chore: update patches * chore: bump chromium in DEPS to 92.0.4515.7 * chore: bump chromium in DEPS to 92.0.4515.9 * chore: bump chromium in DEPS to 93.0.4522.0 * chore: bump chromium in DEPS to 93.0.4523.0 * chore: bump chromium in DEPS to 93.0.4524.0 * chore: update patches * chore: enable_pak_file_integrity_checks was reverted * chore: update patches * refactor: base/optional was replaced with absl::optional Refs:2910202
* refactor: replace all usages of base::nullopt with absl::nullopt Refs:2910202
* chore: add missing base::Contains include Refs:2910202
* refactor: replace all usages of base::make_optional with absl::make_optional Refs:2910202
* refactor: replace WorldScriptContext() with GetScriptContextFromWorldId Refs:2893213
* chore: clean up left over opening namespace Refs:95bfe6d08f
* chore: add missing base::Contains include Refs:2910202
* refactor: replace GetCurrentDisplayIterator with the hard checker GetCurrentDisplay This code looks suspicious but if the iterator was invalid before it will also be invalid now. Refs:2893191
* refactor: headers are now passed directly in extensions client Refs:2918906
* refactor: base::DictionaryValue::empty() has been removed Refs:2912424
* chore: add missing includes for network URLLoaderFactory Refs: unknown, probably a side effect of header changes * refactor: make convenience wrapper around AppendArg There is no converter FromV8 for base::StringPiece (apparently its not possible). So we now take in an std::string and use the construct for StringPiece to do implicit conversion. Refs:2905544
* chore: add patch * chore: bump chromium in DEPS to 93.0.4525.0 * chore: update patches * refactor: CanResize has been de-virtualized Refs:2485774
* chore: update resource integrity patch * chore: add character encoding idl patch * chore: bump chromium in DEPS to 93.0.4526.0 * chore: update patches * chore: bump chromium in DEPS to 93.0.4527.0 * chore: bump chromium in DEPS to 93.0.4528.0 * chore: update patches * chore: update idl encoding patch * chore: bump chromium in DEPS to 93.0.4529.0 * chore: update patches * chore: bump chromium in DEPS to 93.0.4530.0 * chore: update patches * fix: only SetCanResize after the widget has been initialized * chore: add patch for vr on windows gn gen * spec: fix focus related tests on linux due to delay in focus swap * chore: remove new usages of base::Optional from main Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <sattard@slack-corp.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com>
129 lines
3.8 KiB
C++
129 lines
3.8 KiB
C++
// Copyright (c) 2015 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef SHELL_BROWSER_UI_ELECTRON_MENU_MODEL_H_
|
|
#define SHELL_BROWSER_UI_ELECTRON_MENU_MODEL_H_
|
|
|
|
#include <map>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "base/files/file_path.h"
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "base/observer_list.h"
|
|
#include "base/observer_list_types.h"
|
|
#include "third_party/abseil-cpp/absl/types/optional.h"
|
|
#include "ui/base/models/simple_menu_model.h"
|
|
#include "url/gurl.h"
|
|
|
|
namespace electron {
|
|
|
|
class ElectronMenuModel : public ui::SimpleMenuModel {
|
|
public:
|
|
#if defined(OS_MAC)
|
|
struct SharingItem {
|
|
SharingItem();
|
|
SharingItem(SharingItem&&);
|
|
SharingItem(const SharingItem&) = delete;
|
|
~SharingItem();
|
|
|
|
absl::optional<std::vector<std::string>> texts;
|
|
absl::optional<std::vector<GURL>> urls;
|
|
absl::optional<std::vector<base::FilePath>> file_paths;
|
|
};
|
|
#endif
|
|
|
|
class Delegate : public ui::SimpleMenuModel::Delegate {
|
|
public:
|
|
~Delegate() override {}
|
|
|
|
virtual bool GetAcceleratorForCommandIdWithParams(
|
|
int command_id,
|
|
bool use_default_accelerator,
|
|
ui::Accelerator* accelerator) const = 0;
|
|
|
|
virtual bool ShouldRegisterAcceleratorForCommandId(
|
|
int command_id) const = 0;
|
|
|
|
virtual bool ShouldCommandIdWorkWhenHidden(int command_id) const = 0;
|
|
|
|
#if defined(OS_MAC)
|
|
virtual bool GetSharingItemForCommandId(int command_id,
|
|
SharingItem* item) const = 0;
|
|
#endif
|
|
|
|
private:
|
|
// ui::SimpleMenuModel::Delegate:
|
|
bool GetAcceleratorForCommandId(
|
|
int command_id,
|
|
ui::Accelerator* accelerator) const override;
|
|
};
|
|
|
|
class Observer : public base::CheckedObserver {
|
|
public:
|
|
~Observer() override {}
|
|
|
|
// Notifies the menu will open.
|
|
virtual void OnMenuWillShow() {}
|
|
|
|
// Notifies the menu has been closed.
|
|
virtual void OnMenuWillClose() {}
|
|
};
|
|
|
|
explicit ElectronMenuModel(Delegate* delegate);
|
|
~ElectronMenuModel() override;
|
|
|
|
void AddObserver(Observer* obs) { observers_.AddObserver(obs); }
|
|
void RemoveObserver(Observer* obs) { observers_.RemoveObserver(obs); }
|
|
|
|
void SetToolTip(int index, const std::u16string& toolTip);
|
|
std::u16string GetToolTipAt(int index);
|
|
void SetRole(int index, const std::u16string& role);
|
|
std::u16string GetRoleAt(int index);
|
|
void SetSecondaryLabel(int index, const std::u16string& sublabel);
|
|
std::u16string GetSecondaryLabelAt(int index) const override;
|
|
bool GetAcceleratorAtWithParams(int index,
|
|
bool use_default_accelerator,
|
|
ui::Accelerator* accelerator) const;
|
|
bool ShouldRegisterAcceleratorAt(int index) const;
|
|
bool WorksWhenHiddenAt(int index) const;
|
|
#if defined(OS_MAC)
|
|
// Return the SharingItem of menu item.
|
|
bool GetSharingItemAt(int index, SharingItem* item) const;
|
|
// Set/Get the SharingItem of this menu.
|
|
void SetSharingItem(SharingItem item);
|
|
const absl::optional<SharingItem>& GetSharingItem() const;
|
|
#endif
|
|
|
|
// ui::SimpleMenuModel:
|
|
void MenuWillClose() override;
|
|
void MenuWillShow() override;
|
|
|
|
base::WeakPtr<ElectronMenuModel> GetWeakPtr() {
|
|
return weak_factory_.GetWeakPtr();
|
|
}
|
|
|
|
using SimpleMenuModel::GetSubmenuModelAt;
|
|
ElectronMenuModel* GetSubmenuModelAt(int index);
|
|
|
|
private:
|
|
Delegate* delegate_; // weak ref.
|
|
|
|
#if defined(OS_MAC)
|
|
absl::optional<SharingItem> sharing_item_;
|
|
#endif
|
|
|
|
std::map<int, std::u16string> toolTips_; // command id -> tooltip
|
|
std::map<int, std::u16string> roles_; // command id -> role
|
|
std::map<int, std::u16string> sublabels_; // command id -> sublabel
|
|
base::ObserverList<Observer> observers_;
|
|
|
|
base::WeakPtrFactory<ElectronMenuModel> weak_factory_{this};
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(ElectronMenuModel);
|
|
};
|
|
|
|
} // namespace electron
|
|
|
|
#endif // SHELL_BROWSER_UI_ELECTRON_MENU_MODEL_H_
|