123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544 |
- // Copyright (c) 2013 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_H_
- #define ELECTRON_SHELL_BROWSER_NATIVE_WINDOW_H_
- #include <list>
- #include <memory>
- #include <optional>
- #include <queue>
- #include <string>
- #include <vector>
- #include "base/memory/raw_ptr.h"
- #include "base/memory/weak_ptr.h"
- #include "base/observer_list.h"
- #include "base/supports_user_data.h"
- #include "content/public/browser/desktop_media_id.h"
- #include "content/public/browser/web_contents_user_data.h"
- #include "electron/shell/common/api/api.mojom.h"
- #include "extensions/browser/app_window/size_constraints.h"
- #include "shell/browser/native_window_observer.h"
- #include "ui/views/widget/widget_delegate.h"
- class SkRegion;
- class DraggableRegionProvider;
- namespace input {
- struct NativeWebKeyboardEvent;
- }
- namespace gfx {
- class Image;
- class Point;
- class Rect;
- enum class ResizeEdge;
- class Size;
- } // namespace gfx
- namespace gin_helper {
- class Dictionary;
- class PersistentDictionary;
- } // namespace gin_helper
- namespace electron {
- extern const char kElectronNativeWindowKey[];
- class ElectronMenuModel;
- class BackgroundThrottlingSource;
- namespace api {
- class BrowserView;
- }
- #if BUILDFLAG(IS_MAC)
- typedef NSView* NativeWindowHandle;
- #else
- typedef gfx::AcceleratedWidget NativeWindowHandle;
- #endif
- class NativeWindow : public base::SupportsUserData,
- public views::WidgetDelegate {
- public:
- ~NativeWindow() override;
- // disable copy
- NativeWindow(const NativeWindow&) = delete;
- NativeWindow& operator=(const NativeWindow&) = delete;
- // Create window with existing WebContents, the caller is responsible for
- // managing the window's live.
- static NativeWindow* Create(const gin_helper::Dictionary& options,
- NativeWindow* parent = nullptr);
- void InitFromOptions(const gin_helper::Dictionary& options);
- virtual void SetContentView(views::View* view) = 0;
- virtual void Close() = 0;
- virtual void CloseImmediately() = 0;
- virtual bool IsClosed() const;
- virtual void Focus(bool focus) = 0;
- virtual bool IsFocused() const = 0;
- virtual void Show() = 0;
- virtual void ShowInactive() = 0;
- virtual void Hide() = 0;
- virtual bool IsVisible() const = 0;
- virtual bool IsEnabled() const = 0;
- virtual void SetEnabled(bool enable) = 0;
- virtual void Maximize() = 0;
- virtual void Unmaximize() = 0;
- virtual bool IsMaximized() const = 0;
- virtual void Minimize() = 0;
- virtual void Restore() = 0;
- virtual bool IsMinimized() const = 0;
- virtual void SetFullScreen(bool fullscreen) = 0;
- virtual bool IsFullscreen() const = 0;
- virtual void SetBounds(const gfx::Rect& bounds, bool animate = false) = 0;
- virtual gfx::Rect GetBounds() const = 0;
- virtual void SetSize(const gfx::Size& size, bool animate = false);
- virtual gfx::Size GetSize() const;
- virtual void SetPosition(const gfx::Point& position, bool animate = false);
- virtual gfx::Point GetPosition() const;
- virtual void SetContentSize(const gfx::Size& size, bool animate = false);
- virtual gfx::Size GetContentSize() const;
- virtual void SetContentBounds(const gfx::Rect& bounds, bool animate = false);
- virtual gfx::Rect GetContentBounds() const;
- virtual bool IsNormal() const;
- virtual gfx::Rect GetNormalBounds() const = 0;
- virtual void SetSizeConstraints(
- const extensions::SizeConstraints& window_constraints);
- virtual extensions::SizeConstraints GetSizeConstraints() const;
- virtual void SetContentSizeConstraints(
- const extensions::SizeConstraints& size_constraints);
- virtual extensions::SizeConstraints GetContentSizeConstraints() const;
- virtual void SetMinimumSize(const gfx::Size& size);
- virtual gfx::Size GetMinimumSize() const;
- virtual void SetMaximumSize(const gfx::Size& size);
- virtual gfx::Size GetMaximumSize() const;
- virtual gfx::Size GetContentMinimumSize() const;
- virtual gfx::Size GetContentMaximumSize() const;
- virtual void SetSheetOffset(const double offsetX, const double offsetY);
- virtual double GetSheetOffsetX() const;
- virtual double GetSheetOffsetY() const;
- virtual void SetResizable(bool resizable) = 0;
- virtual bool MoveAbove(const std::string& sourceId) = 0;
- virtual void MoveTop() = 0;
- virtual bool IsResizable() const = 0;
- virtual void SetMovable(bool movable) = 0;
- virtual bool IsMovable() const = 0;
- virtual void SetMinimizable(bool minimizable) = 0;
- virtual bool IsMinimizable() const = 0;
- virtual void SetMaximizable(bool maximizable) = 0;
- virtual bool IsMaximizable() const = 0;
- virtual void SetFullScreenable(bool fullscreenable) = 0;
- virtual bool IsFullScreenable() const = 0;
- virtual void SetClosable(bool closable) = 0;
- virtual bool IsClosable() const = 0;
- virtual void SetAlwaysOnTop(ui::ZOrderLevel z_order,
- const std::string& level = "floating",
- int relativeLevel = 0) = 0;
- virtual ui::ZOrderLevel GetZOrderLevel() const = 0;
- virtual void Center() = 0;
- virtual void Invalidate() = 0;
- virtual void SetTitle(const std::string& title) = 0;
- virtual std::string GetTitle() const = 0;
- #if BUILDFLAG(IS_MAC)
- virtual std::string GetAlwaysOnTopLevel() const = 0;
- virtual void SetActive(bool is_key) = 0;
- virtual bool IsActive() const = 0;
- virtual void RemoveChildFromParentWindow() = 0;
- virtual void RemoveChildWindow(NativeWindow* child) = 0;
- virtual void AttachChildren() = 0;
- virtual void DetachChildren() = 0;
- #endif
- // Ability to augment the window title for the screen readers.
- void SetAccessibleTitle(const std::string& title);
- std::string GetAccessibleTitle();
- virtual void FlashFrame(bool flash) = 0;
- virtual void SetSkipTaskbar(bool skip) = 0;
- virtual void SetExcludedFromShownWindowsMenu(bool excluded) = 0;
- virtual bool IsExcludedFromShownWindowsMenu() const = 0;
- virtual void SetSimpleFullScreen(bool simple_fullscreen) = 0;
- virtual bool IsSimpleFullScreen() const = 0;
- virtual void SetKiosk(bool kiosk) = 0;
- virtual bool IsKiosk() const = 0;
- virtual bool IsTabletMode() const;
- virtual void SetBackgroundColor(SkColor color) = 0;
- virtual SkColor GetBackgroundColor() const = 0;
- virtual void InvalidateShadow();
- virtual void SetHasShadow(bool has_shadow) = 0;
- virtual bool HasShadow() const = 0;
- virtual void SetOpacity(const double opacity) = 0;
- virtual double GetOpacity() const = 0;
- virtual void SetRepresentedFilename(const std::string& filename);
- virtual std::string GetRepresentedFilename() const;
- virtual void SetDocumentEdited(bool edited);
- virtual bool IsDocumentEdited() const;
- virtual void SetIgnoreMouseEvents(bool ignore, bool forward) = 0;
- virtual void SetContentProtection(bool enable) = 0;
- virtual void SetFocusable(bool focusable);
- virtual bool IsFocusable() const;
- virtual void SetMenu(ElectronMenuModel* menu);
- virtual void SetParentWindow(NativeWindow* parent);
- virtual content::DesktopMediaID GetDesktopMediaID() const = 0;
- virtual gfx::NativeView GetNativeView() const = 0;
- virtual gfx::NativeWindow GetNativeWindow() const = 0;
- virtual gfx::AcceleratedWidget GetAcceleratedWidget() const = 0;
- virtual NativeWindowHandle GetNativeWindowHandle() const = 0;
- // Taskbar/Dock APIs.
- enum class ProgressState {
- kNone, // no progress, no marking
- kIndeterminate, // progress, indeterminate
- kError, // progress, errored (red)
- kPaused, // progress, paused (yellow)
- kNormal, // progress, not marked (green)
- };
- virtual void SetProgressBar(double progress, const ProgressState state) = 0;
- virtual void SetOverlayIcon(const gfx::Image& overlay,
- const std::string& description) = 0;
- // Workspace APIs.
- virtual void SetVisibleOnAllWorkspaces(
- bool visible,
- bool visibleOnFullScreen = false,
- bool skipTransformProcessType = false) = 0;
- virtual bool IsVisibleOnAllWorkspaces() const = 0;
- virtual void SetAutoHideCursor(bool auto_hide);
- // Vibrancy API
- const std::string& vibrancy() const { return vibrancy_; }
- virtual void SetVibrancy(const std::string& type);
- const std::string& background_material() const {
- return background_material_;
- }
- virtual void SetBackgroundMaterial(const std::string& type);
- // Traffic Light API
- #if BUILDFLAG(IS_MAC)
- virtual void SetWindowButtonVisibility(bool visible) = 0;
- virtual bool GetWindowButtonVisibility() const = 0;
- virtual void SetWindowButtonPosition(std::optional<gfx::Point> position) = 0;
- virtual std::optional<gfx::Point> GetWindowButtonPosition() const = 0;
- virtual void RedrawTrafficLights() = 0;
- virtual void UpdateFrame() = 0;
- #endif
- // whether windows should be ignored by mission control
- #if BUILDFLAG(IS_MAC)
- virtual bool IsHiddenInMissionControl() const = 0;
- virtual void SetHiddenInMissionControl(bool hidden) = 0;
- #endif
- // Touchbar API
- virtual void SetTouchBar(std::vector<gin_helper::PersistentDictionary> items);
- virtual void RefreshTouchBarItem(const std::string& item_id);
- virtual void SetEscapeTouchBarItem(gin_helper::PersistentDictionary item);
- // Native Tab API
- virtual void SelectPreviousTab();
- virtual void SelectNextTab();
- virtual void ShowAllTabs();
- virtual void MergeAllWindows();
- virtual void MoveTabToNewWindow();
- virtual void ToggleTabBar();
- virtual bool AddTabbedWindow(NativeWindow* window);
- virtual std::optional<std::string> GetTabbingIdentifier() const;
- // Toggle the menu bar.
- virtual void SetAutoHideMenuBar(bool auto_hide);
- virtual bool IsMenuBarAutoHide() const;
- virtual void SetMenuBarVisibility(bool visible);
- virtual bool IsMenuBarVisible() const;
- // Set the aspect ratio when resizing window.
- [[nodiscard]] double aspect_ratio() const { return aspect_ratio_; }
- [[nodiscard]] gfx::Size aspect_ratio_extra_size() const {
- return aspect_ratio_extraSize_;
- }
- virtual void SetAspectRatio(double aspect_ratio, const gfx::Size& extra_size);
- // File preview APIs.
- virtual void PreviewFile(const std::string& path,
- const std::string& display_name);
- virtual void CloseFilePreview();
- virtual void SetGTKDarkThemeEnabled(bool use_dark_theme) {}
- // Converts between content bounds and window bounds.
- virtual gfx::Rect ContentBoundsToWindowBounds(
- const gfx::Rect& bounds) const = 0;
- virtual gfx::Rect WindowBoundsToContentBounds(
- const gfx::Rect& bounds) const = 0;
- base::WeakPtr<NativeWindow> GetWeakPtr() {
- return weak_factory_.GetWeakPtr();
- }
- virtual std::optional<gfx::Rect> GetWindowControlsOverlayRect();
- virtual void SetWindowControlsOverlayRect(const gfx::Rect& overlay_rect);
- // Methods called by the WebContents.
- virtual void HandleKeyboardEvent(content::WebContents*,
- const input::NativeWebKeyboardEvent& event) {
- }
- // Public API used by platform-dependent delegates and observers to send UI
- // related notifications.
- void NotifyWindowRequestPreferredWidth(int* width);
- void NotifyWindowCloseButtonClicked();
- void NotifyWindowClosed();
- void NotifyWindowEndSession();
- void NotifyWindowBlur();
- void NotifyWindowFocus();
- void NotifyWindowShow();
- void NotifyWindowIsKeyChanged(bool is_key);
- void NotifyWindowHide();
- void NotifyWindowMaximize();
- void NotifyWindowUnmaximize();
- void NotifyWindowMinimize();
- void NotifyWindowRestore();
- void NotifyWindowMove();
- void NotifyWindowWillResize(const gfx::Rect& new_bounds,
- const gfx::ResizeEdge& edge,
- bool* prevent_default);
- void NotifyWindowResize();
- void NotifyWindowResized();
- void NotifyWindowWillMove(const gfx::Rect& new_bounds, bool* prevent_default);
- void NotifyWindowMoved();
- void NotifyWindowSwipe(const std::string& direction);
- void NotifyWindowRotateGesture(float rotation);
- void NotifyWindowSheetBegin();
- void NotifyWindowSheetEnd();
- virtual void NotifyWindowEnterFullScreen();
- virtual void NotifyWindowLeaveFullScreen();
- void NotifyWindowEnterHtmlFullScreen();
- void NotifyWindowLeaveHtmlFullScreen();
- void NotifyWindowAlwaysOnTopChanged();
- void NotifyWindowExecuteAppCommand(const std::string& command);
- void NotifyTouchBarItemInteraction(const std::string& item_id,
- base::Value::Dict details);
- void NotifyNewWindowForTab();
- void NotifyWindowSystemContextMenu(int x, int y, bool* prevent_default);
- void NotifyLayoutWindowControlsOverlay();
- #if BUILDFLAG(IS_WIN)
- void NotifyWindowMessage(UINT message, WPARAM w_param, LPARAM l_param);
- #endif
- void AddObserver(NativeWindowObserver* obs) { observers_.AddObserver(obs); }
- void RemoveObserver(NativeWindowObserver* obs) {
- observers_.RemoveObserver(obs);
- }
- // Handle fullscreen transitions.
- void HandlePendingFullscreenTransitions();
- enum class FullScreenTransitionState { kEntering, kExiting, kNone };
- void set_fullscreen_transition_state(FullScreenTransitionState state) {
- fullscreen_transition_state_ = state;
- }
- FullScreenTransitionState fullscreen_transition_state() const {
- return fullscreen_transition_state_;
- }
- enum class FullScreenTransitionType { kHTML, kNative, kNone };
- void set_fullscreen_transition_type(FullScreenTransitionType type) {
- fullscreen_transition_type_ = type;
- }
- FullScreenTransitionType fullscreen_transition_type() const {
- return fullscreen_transition_type_;
- }
- views::Widget* widget() const { return widget_.get(); }
- views::View* content_view() const { return content_view_; }
- enum class TitleBarStyle {
- kNormal,
- kHidden,
- kHiddenInset,
- kCustomButtonsOnHover,
- };
- TitleBarStyle title_bar_style() const { return title_bar_style_; }
- bool IsWindowControlsOverlayEnabled() const {
- bool valid_titlebar_style = title_bar_style() == TitleBarStyle::kHidden
- #if BUILDFLAG(IS_MAC)
- ||
- title_bar_style() == TitleBarStyle::kHiddenInset
- #endif
- ;
- return valid_titlebar_style && titlebar_overlay_;
- }
- int titlebar_overlay_height() const { return titlebar_overlay_height_; }
- void set_titlebar_overlay_height(int height) {
- titlebar_overlay_height_ = height;
- }
- bool has_frame() const { return has_frame_; }
- void set_has_frame(bool has_frame) { has_frame_ = has_frame; }
- bool has_client_frame() const { return has_client_frame_; }
- bool transparent() const { return transparent_; }
- bool enable_larger_than_screen() const { return enable_larger_than_screen_; }
- NativeWindow* parent() const { return parent_; }
- bool is_modal() const { return is_modal_; }
- int32_t window_id() const { return next_id_; }
- void add_child_window(NativeWindow* child) {
- child_windows_.push_back(child);
- }
- int NonClientHitTest(const gfx::Point& point);
- void AddDraggableRegionProvider(DraggableRegionProvider* provider);
- void RemoveDraggableRegionProvider(DraggableRegionProvider* provider);
- bool IsTranslucent() const;
- // Adds |source| to |background_throttling_sources_|, triggers update of
- // background throttling state.
- void AddBackgroundThrottlingSource(BackgroundThrottlingSource* source);
- // Removes |source| to |background_throttling_sources_|, triggers update of
- // background throttling state.
- void RemoveBackgroundThrottlingSource(BackgroundThrottlingSource* source);
- // Updates `ui::Compositor` background throttling state based on
- // |background_throttling_sources_|. If at least one of the sources disables
- // throttling, then throttling in the `ui::Compositor` will be disabled.
- void UpdateBackgroundThrottlingState();
- protected:
- friend class api::BrowserView;
- NativeWindow(const gin_helper::Dictionary& options, NativeWindow* parent);
- // views::WidgetDelegate:
- views::Widget* GetWidget() override;
- const views::Widget* GetWidget() const override;
- std::u16string GetAccessibleWindowTitle() const override;
- void set_content_view(views::View* view) { content_view_ = view; }
- // The boolean parsing of the "titleBarOverlay" option
- bool titlebar_overlay_ = false;
- // The custom height parsed from the "height" option in a Object
- // "titleBarOverlay"
- int titlebar_overlay_height_ = 0;
- // The "titleBarStyle" option.
- TitleBarStyle title_bar_style_ = TitleBarStyle::kNormal;
- // Minimum and maximum size.
- std::optional<extensions::SizeConstraints> size_constraints_;
- // Same as above but stored as content size, we are storing 2 types of size
- // constraints beacause converting between them will cause rounding errors
- // on HiDPI displays on some environments.
- std::optional<extensions::SizeConstraints> content_size_constraints_;
- std::queue<bool> pending_transitions_;
- FullScreenTransitionState fullscreen_transition_state_ =
- FullScreenTransitionState::kNone;
- FullScreenTransitionType fullscreen_transition_type_ =
- FullScreenTransitionType::kNone;
- std::list<NativeWindow*> child_windows_;
- private:
- std::unique_ptr<views::Widget> widget_;
- static int32_t next_id_;
- // The content view, weak ref.
- raw_ptr<views::View> content_view_ = nullptr;
- // Whether window has standard frame.
- bool has_frame_ = true;
- // Whether window has standard frame, but it's drawn by Electron (the client
- // application) instead of the OS. Currently only has meaning on Linux for
- // Wayland hosts.
- bool has_client_frame_ = false;
- // Whether window is transparent.
- bool transparent_ = false;
- // Whether window can be resized larger than screen.
- bool enable_larger_than_screen_ = false;
- // The windows has been closed.
- bool is_closed_ = false;
- // Used to display sheets at the appropriate horizontal and vertical offsets
- // on macOS.
- double sheet_offset_x_ = 0.0;
- double sheet_offset_y_ = 0.0;
- // Used to maintain the aspect ratio of a view which is inside of the
- // content view.
- double aspect_ratio_ = 0.0;
- gfx::Size aspect_ratio_extraSize_;
- // The parent window, it is guaranteed to be valid during this window's life.
- raw_ptr<NativeWindow> parent_ = nullptr;
- // Is this a modal window.
- bool is_modal_ = false;
- std::list<DraggableRegionProvider*> draggable_region_providers_;
- // Observers of this window.
- base::ObserverList<NativeWindowObserver> observers_;
- std::set<BackgroundThrottlingSource*> background_throttling_sources_;
- // Accessible title.
- std::u16string accessible_title_;
- std::string vibrancy_;
- std::string background_material_;
- gfx::Rect overlay_rect_;
- base::WeakPtrFactory<NativeWindow> weak_factory_{this};
- };
- // This class provides a hook to get a NativeWindow from a WebContents.
- class NativeWindowRelay
- : public content::WebContentsUserData<NativeWindowRelay> {
- public:
- static void CreateForWebContents(content::WebContents*,
- base::WeakPtr<NativeWindow>);
- ~NativeWindowRelay() override;
- NativeWindow* GetNativeWindow() const { return native_window_.get(); }
- WEB_CONTENTS_USER_DATA_KEY_DECL();
- private:
- friend class content::WebContentsUserData<NativeWindow>;
- explicit NativeWindowRelay(content::WebContents* web_contents,
- base::WeakPtr<NativeWindow> window);
- base::WeakPtr<NativeWindow> native_window_;
- };
- } // namespace electron
- #endif // ELECTRON_SHELL_BROWSER_NATIVE_WINDOW_H_
|