* chore: bump chromium in DEPS to 142.0.7432.2 * chore: bump chromium in DEPS to 142.0.7434.1 * chore: bump chromium in DEPS to 142.0.7436.1 * chore: bump chromium in DEPS to 142.0.7438.1 * chore: bump chromium in DEPS to 142.0.7440.1 * chore: bump chromium in DEPS to 142.0.7442.1 * chore: bump chromium in DEPS to 142.0.7444.1 * chore: bump chromium in DEPS to 142.0.7444.6 * chore: bump chromium in DEPS to 142.0.7444.3 * 6973697: Use type tags for data stored in V8 internal fields https://chromium-review.googlesource.com/c/chromium/src/+/6973697 * chore: update patches * chore: update filenames.libcxx.gni * fix: parse macOS SDK version across line break https://chromium-review.googlesource.com/c/chromium/src/+/6980166 (cherry picked from commit 2bcbb33de04fa13e7c923b2420f89c3846f5988b) * fix: replace v8::Object::SetPrototype() usage https://chromium-review.googlesource.com/c/v8/v8/+/6983465 https://github.com/nodejs/node/pull/55453 (cherry picked from commit c31b9ed5ac84bbd111c72273d9334af6c50ed374) * fix: replace additional usages of SetPrototype https://chromium-review.googlesource.com/c/v8/v8/+/6983465 (cherry picked from commit bf151e9d28520c7dd74cba62240acbcaaab5433d) * fixup! fix: replace additional usages of SetPrototype https://chromium-review.googlesource.com/c/v8/v8/+/6983465 (cherry picked from commit f4434755b82b098e4d83d42bab26f183b6824f99) * build: use macos 15 minimum https://chromium-review.googlesource.com/c/chromium/src/+/6980166 (cherry picked from commit 4d2b5d7b2cf9a1786cdb1a77bf73e4ad0d3e45d1) * fixup! build: use macos 15 minimum https://chromium-review.googlesource.com/c/chromium/src/+/6980166 (cherry picked from commit 94bb41a66330dcaf6b92c80cfefd72759405793d) * ci: ignore missing dir for strip_universal_deep (cherry picked from commit 634963f171bc5f6050151f76973e7ffbab0e00cf) * chore: update patches * chore: update patches * chore: bump chromium in DEPS to 142.0.7444.23 * fix: disable C++ modules in electron_lib builds https://chromium-review.googlesource.com/c/chromium/src/+/6950738 (cherry picked from commit 6207c79aecae04675b1e258ec14025c3ddfdf270) * Revert "build: use macos 15 minimum" This reverts commit 2fc12d6acc1b24f3cbd0adb03122bf6b21eb14b9. Initially this change was made to test if it fixes libcxx compilation issues. As that's now resolved by disabling libcxx modules, this can be reverted. (cherry picked from commit ad52007d5baffc3da65c0a994943f25da0c3f1c2) * fix: js2c compilation failure https://chromium-review.googlesource.com/c/chromium/src/+/6950738 See patch description explaining MacOS 26 SDK headers incompatibility. (cherry picked from commit 39e2470875cdbf20b86c30ee2c5caa8845465434) * fix: disable C++ modules in libnode builds (cherry picked from commit fd0a7b61a151c92729da41eba63fb7ee5b0beebc) * fixup! fix: replace v8::Object::SetPrototype() usage https://chromium-review.googlesource.com/c/v8/v8/+/6983465 https://github.com/nodejs/node/pull/55453 (cherry picked from commit 2f52159b71ee4aa779dfd3e3050f3b09c2664c36) * build: switch to macos-15 runner build/mac/find_sdk.py now requires macOS 15 SDK as a minimum version. The macos 15 runners default to an Xcode using the 15 SDK and removes older versions. (cherry picked from commit e368703f24577e73d904c684a0b4ae53bacfaef2) * chore: update patches * fix: partially revert is_headless_mode removal https://chromium-review.googlesource.com/c/chromium/src/+/6955633 This patch should likely be reworked. For now, this partially reverts the removal of a required class property to restore behavior. (cherry picked from commit aff3bf9a244608863bc96b3e2aef911158b29574) * 6938086: Rename native_widget_types.h -> native_ui_types.h | https://chromium-review.googlesource.com/c/chromium/src/+/6938086 (cherry picked from commit c95ac7bf2b1eda493167b8e36c59d70d86d51429) * 6973697: Use type tags for data stored in V8 internal fields https://chromium-review.googlesource.com/c/chromium/src/+/6973697 * fixup! fix: check new forced colors enum value https://chromium-review.googlesource.com/c/chromium/src/+/6944403 (cherry picked from commit 0829c74b2fbcdf03ca462b4b0b76efd727d3d891) * fix: check new forced colors enum value https://chromium-review.googlesource.com/c/chromium/src/+/6944403 (cherry picked from commit d5858798074719d19d041fa291c3fd1af8d17f5d) * feat: add new memory-eviction exit reason https://chromium-review.googlesource.com/c/chromium/src/+/6991933 (cherry picked from commit 6e63197a2292aece65cd52b7b849d3ff3d10bb90) * fix: views::NonClientFrameView -> views::FrameView https://chromium-review.googlesource.com/c/chromium/src/+/7005027 https://chromium-review.googlesource.com/c/chromium/src/+/6966937 (cherry picked from commit 1e86b6ddfb2d19b5bfe30e7539f0a377ffa907ab) * fix: migrate NetworkConditions -> MatchedNetworkConditions https://chromium-review.googlesource.com/c/chromium/src/+/6827307 (cherry picked from commit 97100ac1682053d3447e63ed5f03dc2d9938e6ca) * fix: provide DeviceEmulationCacheBehavior param https://chromium-review.googlesource.com/c/chromium/src/+/6965238 (cherry picked from commit f9a08c53846ab269c57c14eae6b1c03b163fb30c) * fix: add missing image_skia include https://chromium-review.googlesource.com/c/chromium/src/+/6986762 (cherry picked from commit dd5eaf03fd7fbfd49afbe3259c5bf036be566bd9) * fixup! fix: add missing image_skia include https://chromium-review.googlesource.com/c/chromium/src/+/6986762 (cherry picked from commit 249c4d4de1df4d1588d6fa6fcf5f33b43a6c0f62) * 6948286: [wasm-imported-strings] Drop feature flag https://chromium-review.googlesource.com/c/v8/v8/+/6948286 * fix: disable protocol handler DCHECK https://chromium-review.googlesource.com/c/chromium/src/+/6727594 Ignore the extension custom protocol handler registry DCHECK until we invest in supporting it. Replacing this DCHECK seems harmless and will unblock the roll. (cherry picked from commit 019d3f0b09aeff8aed7991d9669a4ba7f265808b) * 6986762: Remove some includes of //ui/gfx/image/image_skia.h https: //chromium-review.googlesource.com/c/chromium/src/+/6986762 * fixup! fix: migrate NetworkConditions -> MatchedNetworkConditions https://chromium-review.googlesource.com/c/chromium/src/+/6827307 (cherry picked from commit a8f67f1ac3f8b07354d9457be9addf242ff70000) * fixup: 6986762: Remove some includes of //ui/gfx/image/image_skia.h s * fix: replace deprecated usage of SetPrototype https://chromium-review.googlesource.com/c/v8/v8/+/6983465 (cherry picked from commit 5435d87b40c15316bc8828fbc197be647b39b7bb) * chore: restore electron embedder data tag patch Co-Authored-By: Sam Maddock <sam@samuelmaddock.com> * chore: update patches --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Samuel Maddock <smaddock@slack-corp.com> Co-authored-by: Alice Zhao <alicelovescake@anthropic.com> Co-authored-by: Sam Maddock <sam@samuelmaddock.com>
368 lines
13 KiB
C++
368 lines
13 KiB
C++
// Copyright (c) 2014 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef ELECTRON_SHELL_BROWSER_NATIVE_WINDOW_VIEWS_H_
|
|
#define ELECTRON_SHELL_BROWSER_NATIVE_WINDOW_VIEWS_H_
|
|
|
|
#include "shell/browser/native_window.h"
|
|
|
|
#include <memory>
|
|
#include <optional>
|
|
#include <string>
|
|
|
|
#include "base/memory/raw_ptr.h"
|
|
#include "base/no_destructor.h"
|
|
#include "shell/browser/ui/views/root_view.h"
|
|
#include "third_party/abseil-cpp/absl/container/flat_hash_set.h"
|
|
#include "ui/base/ozone_buildflags.h"
|
|
#include "ui/views/controls/webview/unhandled_keyboard_event_handler.h"
|
|
#include "ui/views/widget/widget_observer.h"
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
#include "base/win/scoped_gdi_object.h"
|
|
#include "content/public/browser/scoped_accessibility_mode.h"
|
|
#include "shell/browser/ui/win/taskbar_host.h"
|
|
#endif
|
|
|
|
namespace gin_helper {
|
|
class Arguments;
|
|
} // namespace gin_helper
|
|
|
|
namespace electron {
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
class ClientFrameViewLinux;
|
|
class GlobalMenuBarX11;
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_OZONE_X11)
|
|
class EventDisabler;
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
gfx::Rect ScreenToDIPRect(HWND hwnd, const gfx::Rect& pixel_bounds);
|
|
#endif
|
|
|
|
class NativeWindowViews : public NativeWindow,
|
|
private views::WidgetObserver,
|
|
private ui::EventHandler {
|
|
public:
|
|
NativeWindowViews(const gin_helper::Dictionary& options,
|
|
NativeWindow* parent);
|
|
~NativeWindowViews() override;
|
|
|
|
// NativeWindow:
|
|
void SetContentView(views::View* view) override;
|
|
void Close() override;
|
|
void CloseImmediately() override;
|
|
void Focus(bool focus) override;
|
|
bool IsFocused() const override;
|
|
void Show() override;
|
|
void ShowInactive() override;
|
|
void Hide() override;
|
|
bool IsVisible() const override;
|
|
bool IsEnabled() const override;
|
|
void SetEnabled(bool enable) override;
|
|
void Maximize() override;
|
|
void Unmaximize() override;
|
|
bool IsMaximized() const override;
|
|
void Minimize() override;
|
|
void Restore() override;
|
|
bool IsMinimized() const override;
|
|
void SetFullScreen(bool fullscreen) override;
|
|
bool IsFullscreen() const override;
|
|
void SetBounds(const gfx::Rect& bounds, bool animate) override;
|
|
gfx::Rect GetBounds() const override;
|
|
gfx::Rect GetContentBounds() const override;
|
|
gfx::Size GetContentSize() const override;
|
|
gfx::Rect GetNormalBounds() const override;
|
|
SkColor GetBackgroundColor() const override;
|
|
void SetContentSizeConstraints(
|
|
const extensions::SizeConstraints& size_constraints) override;
|
|
#if BUILDFLAG(IS_WIN)
|
|
extensions::SizeConstraints GetContentSizeConstraints() const override;
|
|
#endif
|
|
void SetResizable(bool resizable) override;
|
|
bool MoveAbove(const std::string& sourceId) override;
|
|
void MoveTop() override;
|
|
bool IsResizable() const override;
|
|
void SetAspectRatio(double aspect_ratio,
|
|
const gfx::Size& extra_size) override;
|
|
bool CanResize() const override;
|
|
void SetMovable(bool movable) override;
|
|
bool IsMovable() const override;
|
|
void SetMinimizable(bool minimizable) override;
|
|
bool IsMinimizable() const override;
|
|
void SetMaximizable(bool maximizable) override;
|
|
bool IsMaximizable() const override;
|
|
void SetFullScreenable(bool fullscreenable) override;
|
|
bool IsFullScreenable() const override;
|
|
void SetClosable(bool closable) override;
|
|
bool IsClosable() const override;
|
|
void SetAlwaysOnTop(ui::ZOrderLevel z_order,
|
|
const std::string& level,
|
|
int relativeLevel) override;
|
|
ui::ZOrderLevel GetZOrderLevel() const override;
|
|
void Center() override;
|
|
void Invalidate() override;
|
|
[[nodiscard]] bool IsActive() const override;
|
|
void FlashFrame(bool flash) override;
|
|
void SetSkipTaskbar(bool skip) override;
|
|
void SetExcludedFromShownWindowsMenu(bool excluded) override {}
|
|
bool IsExcludedFromShownWindowsMenu() const override;
|
|
void SetSimpleFullScreen(bool simple_fullscreen) override;
|
|
bool IsSimpleFullScreen() const override;
|
|
void SetKiosk(bool kiosk) override;
|
|
bool IsKiosk() const override;
|
|
bool IsTabletMode() const override;
|
|
void SetBackgroundColor(SkColor color) override;
|
|
void SetHasShadow(bool has_shadow) override;
|
|
bool HasShadow() const override;
|
|
void SetOpacity(const double opacity) override;
|
|
double GetOpacity() const override;
|
|
void SetIgnoreMouseEvents(bool ignore, bool forward) override;
|
|
void SetContentProtection(bool enable) override;
|
|
bool IsContentProtected() const override;
|
|
void SetFocusable(bool focusable) override;
|
|
bool IsFocusable() const override;
|
|
void SetMenu(ElectronMenuModel* menu_model) override;
|
|
void SetParentWindow(NativeWindow* parent) override;
|
|
gfx::NativeView GetNativeView() const override;
|
|
gfx::NativeWindow GetNativeWindow() const override;
|
|
void SetOverlayIcon(const gfx::Image& overlay,
|
|
const std::string& description) override;
|
|
void SetProgressBar(double progress, const ProgressState state) override;
|
|
void SetAutoHideMenuBar(bool auto_hide) override;
|
|
bool IsMenuBarAutoHide() const override;
|
|
void SetMenuBarVisibility(bool visible) override;
|
|
bool IsMenuBarVisible() const override;
|
|
bool IsSnapped() const override;
|
|
void SetBackgroundMaterial(const std::string& type) override;
|
|
|
|
void SetVisibleOnAllWorkspaces(bool visible,
|
|
bool visibleOnFullScreen,
|
|
bool skipTransformProcessType) override;
|
|
|
|
bool IsVisibleOnAllWorkspaces() const override;
|
|
|
|
void SetGTKDarkThemeEnabled(bool use_dark_theme) override;
|
|
|
|
content::DesktopMediaID GetDesktopMediaID() const override;
|
|
gfx::AcceleratedWidget GetAcceleratedWidget() const override;
|
|
NativeWindowHandle GetNativeWindowHandle() const override;
|
|
|
|
gfx::Rect ContentBoundsToWindowBounds(const gfx::Rect& bounds) const override;
|
|
gfx::Rect WindowBoundsToContentBounds(const gfx::Rect& bounds) const override;
|
|
|
|
void IncrementChildModals();
|
|
void DecrementChildModals();
|
|
|
|
void SetTitleBarOverlay(const gin_helper::Dictionary& options,
|
|
gin_helper::Arguments* args);
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
// Catch-all message handling and filtering. Called before
|
|
// HWNDMessageHandler's built-in handling, which may preempt some
|
|
// expectations in Views/Aura if messages are consumed. Returns true if the
|
|
// message was consumed by the delegate and should not be processed further
|
|
// by the HWNDMessageHandler. In this case, |result| is returned. |result| is
|
|
// not modified otherwise.
|
|
bool PreHandleMSG(UINT message,
|
|
WPARAM w_param,
|
|
LPARAM l_param,
|
|
LRESULT* result);
|
|
void SetIcon(HICON small_icon, HICON app_icon);
|
|
#elif BUILDFLAG(IS_LINUX)
|
|
void SetIcon(const gfx::ImageSkia& icon);
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
void SetAccentColor(
|
|
std::variant<std::monostate, bool, SkColor> accent_color) override;
|
|
std::variant<bool, std::string> GetAccentColor() const override;
|
|
void UpdateWindowAccentColor(bool active) override;
|
|
TaskbarHost& taskbar_host() { return taskbar_host_; }
|
|
void UpdateThickFrame();
|
|
void SetLayered();
|
|
#endif
|
|
|
|
SkColor overlay_button_color() const { return overlay_button_color_; }
|
|
SkColor overlay_symbol_color() const { return overlay_symbol_color_; }
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
// returns the ClientFrameViewLinux iff that is our FrameView type,
|
|
// nullptr otherwise.
|
|
ClientFrameViewLinux* GetClientFrameViewLinux();
|
|
#endif
|
|
|
|
private:
|
|
void set_overlay_button_color(SkColor color) {
|
|
overlay_button_color_ = color;
|
|
}
|
|
void set_overlay_symbol_color(SkColor color) {
|
|
overlay_symbol_color_ = color;
|
|
}
|
|
|
|
// views::WidgetObserver:
|
|
void OnWidgetActivationChanged(views::Widget* widget, bool active) override;
|
|
void OnWidgetBoundsChanged(views::Widget* widget,
|
|
const gfx::Rect& bounds) override;
|
|
void OnWidgetDestroying(views::Widget* widget) override;
|
|
void OnWidgetDestroyed(views::Widget* widget) override;
|
|
|
|
// views::WidgetDelegate:
|
|
views::View* GetInitiallyFocusedView() override;
|
|
bool CanMaximize() const override;
|
|
bool CanMinimize() const override;
|
|
views::View* GetContentsView() override;
|
|
bool ShouldDescendIntoChildForEventHandling(
|
|
gfx::NativeView child,
|
|
const gfx::Point& location) override;
|
|
views::ClientView* CreateClientView(views::Widget* widget) override;
|
|
std::unique_ptr<views::FrameView> CreateFrameView(
|
|
views::Widget* widget) override;
|
|
void OnWidgetMove() override;
|
|
#if BUILDFLAG(IS_WIN)
|
|
bool ExecuteWindowsCommand(int command_id) override;
|
|
void HandleSizeEvent(WPARAM w_param, LPARAM l_param);
|
|
void ResetWindowControls();
|
|
void SetRoundedCorners(bool rounded);
|
|
void SetForwardMouseMessages(bool forward);
|
|
static LRESULT CALLBACK SubclassProc(HWND hwnd,
|
|
UINT msg,
|
|
WPARAM w_param,
|
|
LPARAM l_param,
|
|
UINT_PTR subclass_id,
|
|
DWORD_PTR ref_data);
|
|
static LRESULT CALLBACK MouseHookProc(int n_code,
|
|
WPARAM w_param,
|
|
LPARAM l_param);
|
|
#endif
|
|
|
|
// Enable/disable:
|
|
bool ShouldBeEnabled() const;
|
|
void SetEnabledInternal(bool enabled);
|
|
|
|
// NativeWindow:
|
|
void HandleKeyboardEvent(content::WebContents*,
|
|
const input::NativeWebKeyboardEvent& event) override;
|
|
|
|
// ui::EventHandler:
|
|
void OnMouseEvent(ui::MouseEvent* event) override;
|
|
|
|
// Returns the restore state for the window.
|
|
ui::mojom::WindowShowState GetRestoredState();
|
|
|
|
// Maintain window placement.
|
|
void MoveBehindTaskBarIfNeeded();
|
|
|
|
RootView root_view_{this};
|
|
|
|
// The view should be focused by default.
|
|
raw_ptr<views::View> focused_view_ = nullptr;
|
|
|
|
// The "resizable" flag on Linux is implemented by setting size constraints,
|
|
// we need to make sure size constraints are restored when window becomes
|
|
// resizable again. This is also used on Windows, to keep taskbar resize
|
|
// events from resizing the window.
|
|
extensions::SizeConstraints old_size_constraints_;
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
std::unique_ptr<GlobalMenuBarX11> global_menu_bar_;
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_OZONE_X11)
|
|
// To disable the mouse events.
|
|
std::unique_ptr<EventDisabler> event_disabler_;
|
|
#endif
|
|
|
|
// The color to use as the theme and symbol colors respectively for WCO.
|
|
SkColor overlay_button_color_ = SkColor();
|
|
SkColor overlay_symbol_color_ = SkColor();
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
|
|
ui::mojom::WindowShowState last_window_state_;
|
|
|
|
gfx::Rect last_normal_placement_bounds_;
|
|
|
|
// In charge of running taskbar related APIs.
|
|
TaskbarHost taskbar_host_;
|
|
|
|
// Memoized version of a11y check
|
|
bool checked_for_a11y_support_ = false;
|
|
|
|
// Whether to show the WS_THICKFRAME style.
|
|
bool thick_frame_ = true;
|
|
|
|
// The bounds of window before maximize/fullscreen.
|
|
gfx::Rect restore_bounds_;
|
|
|
|
// The icons of window and taskbar.
|
|
base::win::ScopedGDIObject<HICON> window_icon_;
|
|
base::win::ScopedGDIObject<HICON> app_icon_;
|
|
|
|
// The set of windows currently forwarding mouse messages.
|
|
static inline base::NoDestructor<absl::flat_hash_set<NativeWindowViews*>>
|
|
forwarding_windows_;
|
|
static HHOOK mouse_hook_;
|
|
bool forwarding_mouse_messages_ = false;
|
|
HWND legacy_window_ = nullptr;
|
|
bool layered_ = false;
|
|
|
|
// This value is determined when the window is created.
|
|
bool rounded_corner_ = true;
|
|
|
|
// Set to true if the window is always on top and behind the task bar.
|
|
bool behind_task_bar_ = false;
|
|
|
|
// Whether we want to set window placement without side effect.
|
|
bool is_setting_window_placement_ = false;
|
|
|
|
// Whether the window is currently being resized.
|
|
bool is_resizing_ = false;
|
|
|
|
// Whether the window is currently being moved.
|
|
bool is_moving_ = false;
|
|
|
|
// Whether or not the window was previously snapped e.g. before minimizing.
|
|
bool was_snapped_ = false;
|
|
|
|
std::variant<std::monostate, bool, SkColor> accent_color_;
|
|
|
|
std::optional<gfx::Rect> pending_bounds_change_;
|
|
|
|
// The message ID of the "TaskbarCreated" message, sent to us when we need to
|
|
// reset our thumbar buttons.
|
|
UINT taskbar_created_message_ = 0;
|
|
|
|
std::unique_ptr<content::ScopedAccessibilityMode> scoped_accessibility_mode_;
|
|
#endif
|
|
|
|
// Handles unhandled keyboard messages coming back from the renderer process.
|
|
views::UnhandledKeyboardEventHandler keyboard_event_handler_;
|
|
|
|
// Whether the menubar is visible before the window enters fullscreen
|
|
bool menu_bar_visible_before_fullscreen_ = false;
|
|
|
|
// Whether the window should be enabled based on user calls to SetEnabled()
|
|
bool is_enabled_ = true;
|
|
// How many modal children this window has;
|
|
// used to determine enabled state
|
|
unsigned int num_modal_children_ = 0;
|
|
|
|
bool use_content_size_ = false;
|
|
bool movable_ = true;
|
|
bool resizable_ = true;
|
|
bool maximizable_ = true;
|
|
bool minimizable_ = true;
|
|
bool fullscreenable_ = true;
|
|
gfx::Size widget_size_;
|
|
double opacity_ = 1.0;
|
|
bool widget_destroyed_ = false;
|
|
};
|
|
|
|
} // namespace electron
|
|
|
|
#endif // ELECTRON_SHELL_BROWSER_NATIVE_WINDOW_VIEWS_H_
|