mirror of
https://github.com/electron/electron.git
synced 2026-02-26 03:01:17 -05:00
* chore: bump chromium in DEPS to 90.0.4430.19 * build: add 'use_rts' definition Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2694187 (cherry picked from commitb820b4078d) * chore: bump chromium in DEPS to 91.0.4441.0 * chore: update patches (cherry picked from commit55e50a0879) * chore: media_internal_resources becomes resources Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2699022 (cherry picked from commite715b9c921) * chore: update patches (cherry picked from commitc8148febfa) * refactor: extensions::ViewType moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2710351 (cherry picked from commit87df2766ba) * chore: might_have_observers has been removed Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2667839 (cherry picked from commite900271bea) * refactor: CertVerifier is not in the network namespace anymore Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2689805 (cherry picked from commiteccfa516c5) * refactor: ExtensionUserScriptManager is now UserScriptManager Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2657617 (cherry picked from commit2fed02556d) * refactor: content::SiteInstance::GetSiteForURL was removed Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2680274 (cherry picked from commit0d94e0d1d9) * refactor: MenuItemType was moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2071443 (cherry picked from commit1a296e59c2) * refactor: extensions::ViewType was moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2710351 (cherry picked from commitdc36e8e6fc) * refacotr: grit::ResourceMap replaced with webui::ResourcePath Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2685601 (cherry picked from commit59669e99cb) * refactor: blink::MenuItem::Type was moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2071443 (cherry picked from commitbe627568b2) * refactor: CreateDataPipe deprecated form was removed Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2698090 (cherry picked from commit77ad17b383) * refactor: DesktopMediaList::Type replaces content::DesktopMediaType_* Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2700637 (cherry picked from commit4e02d9407a) * chore: wire up activation_time in OSR Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2638372 (cherry picked from commitf51f427646) * chore: remove deleted file from chromium_src list (cherry picked from commit59432fe30a) * chore: fix lint (cherry picked from commit54cc68dd7a) * update patches (cherry picked from commite99e6a5a8a) * chore: update patches (cherry picked from commit1e16606524) * fixup gn check (cherry picked from commit8f4e362d8f) * update to xcode 12.4.0 Needed because of8008deb41c(cherry picked from commitfae4d87a5a) * 2752406: [LSC] Replace base::string16 with std::u16string in //ui https://chromium-review.googlesource.com/c/chromium/src/+/2752406 (cherry picked from commitd4bec23bde) * 2752406: [LSC] Replace base::string16 with std::u16string in //ui https://chromium-review.googlesource.com/c/chromium/src/+/2752406 (cherry picked from commit9e336f5d0c) * 2752932: Associate each AwProxyingURLLoaderFactory with a frame tree node id. https://chromium-review.googlesource.com/c/chromium/src/+/2752932 (cherry picked from commit08036802cb) * 2651385: Moving Profile::shared_cors_origin_access_list_ into //content layer. https://chromium-review.googlesource.com/c/chromium/src/+/2651385 (cherry picked from commit676f74f3dc) * 2734095: Introduce StoragePartitionId type to wrap current string representation. https://chromium-review.googlesource.com/c/chromium/src/+/2734095 (cherry picked from commit76538d2d38) * chore: bump chromium in DEPS to 90.0.4430.19 * chore: bump chromium in DEPS to 90.0.4430.30 * chore: bump chromium in DEPS to 90.0.4430.40 * chore: bump chromium in DEPS to 90.0.4430.51 * chore: bump chromium in DEPS to 91.0.4446.0 * chore: bump chromium in DEPS to 91.0.4448.0 (cherry picked from commit003dd6c16c) * Update patches (cherry picked from commit9f5e3f6685) * 2743594: Remove WebSize from blink. https://chromium-review.googlesource.com/c/chromium/src/+/2743594 (cherry picked from commitb15b820bca) * 2725403: Add URLLoaderClient::OnReceiveEarlyHints() https://chromium-review.googlesource.com/c/chromium/src/+/2725403 (cherry picked from commit185c343b22) * 2651385: Moving Profile::shared_cors_origin_access_list_ into //content layer. https://chromium-review.googlesource.com/c/chromium/src/+/2651385 (cherry picked from commit88bbe2a352) * 2721718: Move HostID to extensions::mojom::HostID https://chromium-review.googlesource.com/c/chromium/src/+/2721718 (cherry picked from commit3010dd93e3) * 2733070: Rename observer to URLLoaderNetworkServiceObserver https://chromium-review.googlesource.com/c/chromium/src/+/2733070 (cherry picked from commitd54bee03d0) * Use nogncheck for content/browser/site_instance_impl.h This is needed because //content/browser:browser is not a visible target (cherry picked from commit5fc298ee5f) * 2648046: Introduce alert notification helper .app https://chromium-review.googlesource.com/c/chromium/src/+/2648046 (cherry picked from commit2cd53eb46a) * 2752406: [LSC] Replace base::string16 with std::u16string in //ui https://chromium-review.googlesource.com/c/chromium/src/+/2752406 (cherry picked from commitf1bb6be4b9) * only include mac notifications on mac (cherry picked from commit3160e608e2) * add additional skipping of atk toolchain check (cherry picked from commit86d23cee40) * 2757472: Reland "Reland "[LSC] Remove base::string16 alias"" https://chromium-review.googlesource.com/c/chromium/src/+/2757472 (cherry picked from commit22d8f22cfb) * 2757472: Reland "Reland "[LSC] Remove base::string16 alias"" https://chromium-review.googlesource.com/c/chromium/src/+/2757472 (cherry picked from commitec893f8322) * 2720306: [api] Remove deprecated [Shared]ArrayBuffer API https://chromium-review.googlesource.com/c/v8/v8/+/2720306 (cherry picked from commitd0989802bd) * Fixup 2721718: Move HostID to extensions::mojom::HostID (cherry picked from commit29dfabadfd) * fixup 2651385: Moving Profile::shared_cors_origin_access_list_ into //content layer (cherry picked from commit97b6868e9c) * Fixup 2752406: [LSC] Replace base::string16 with std::u16string in //ui (cherry picked from commitb6d2ae0455) * Fixup 2725403: Add URLLoaderClient::OnReceiveEarlyHints() (cherry picked from commit7e961d8a37) * update node headers (cherry picked from commitc49bc282d5) * 2693008: Fix loading non-system cursors on Windows on browser_tests https://chromium-review.googlesource.com/c/chromium/src/+/2693008 (cherry picked from commit3b183854ff) * 2757472: Reland "Reland "[LSC] Remove base::string16 alias"" https://chromium-review.googlesource.com/c/chromium/src/+/2757472 (cherry picked from commit2d3c65beca) * undo changes to WebContentsPreferences::GetPreloadPath to fix mac build (cherry picked from commitdeeb2de14b) * fix StrCat issue (cherry picked from commit451e0931bf) * incantations for WebContentsPreferences::GetPreloadPath wide strings (cherry picked from commit205f572181) * bump nan (cherry picked from commit74318705c2) * fix GetAsString maybe? (cherry picked from commitea62ecd188) * windows build fixes (cherry picked from commit5b598037bb) * more windows build fix (cherry picked from commit61cf1abd4d) * SetAppUserModelID -> wstring (cherry picked from commit83d93bcbdc) * upgrade nan dep in tests (cherry picked from commit4f97b9303c) * update patch * wstrings are cross-platform (cherry picked from commit7f7b1f6c8a) * linter (cherry picked from commitaaf03765ed) * only bind setAppUserModelId on windows (cherry picked from commit640a145112) * well that was an odyssey (cherry picked from commitdd975328a0) * backport fcdf35e from v8 to fix nan crash (cherry picked from commit606fd87d1e) * disable typedarrays-test.js (cherry picked from commit01ca00ec82) * don't defer in NSWindow creation https://chromium-review.googlesource.com/c/chromium/src/+/2707696 (cherry picked from commit3122820e58) * use PartitionAllocator for ArrayBuffers in the main process (cherry picked from commit1f575ca3af) * fix patches (cherry picked from commit54e72fa8e3) * chore: omit some unnecessary conversions (cherry picked from commit0f3620099a) * refactor: make LoginItemSettings::path a wstring (cherry picked from commit9127cff58b) * refactor: make ShowTaskDialog take a wstr (cherry picked from commit1594c54933) * Revert "refactor: make LoginItemSettings::path a wstring" This reverts commit9127cff58b. (cherry picked from commit9684d85101) * fixup patches This reverts commit0cc08813a6. * update patches after merge Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: John Kleinschmidt <jkleinsc@github.com> Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: Charles Kerr <charles@charleskerr.com>
416 lines
14 KiB
C++
416 lines
14 KiB
C++
// 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 SHELL_BROWSER_NATIVE_WINDOW_H_
|
|
#define SHELL_BROWSER_NATIVE_WINDOW_H_
|
|
|
|
#include <list>
|
|
#include <map>
|
|
#include <memory>
|
|
#include <string>
|
|
#include <tuple>
|
|
#include <vector>
|
|
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "base/observer_list.h"
|
|
#include "base/optional.h"
|
|
#include "base/supports_user_data.h"
|
|
#include "base/values.h"
|
|
#include "content/public/browser/desktop_media_id.h"
|
|
#include "content/public/browser/web_contents_user_data.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;
|
|
|
|
namespace content {
|
|
struct NativeWebKeyboardEvent;
|
|
}
|
|
|
|
namespace gfx {
|
|
class Image;
|
|
class Point;
|
|
class Rect;
|
|
class RectF;
|
|
class Size;
|
|
} // namespace gfx
|
|
|
|
namespace gin_helper {
|
|
class Dictionary;
|
|
class PersistentDictionary;
|
|
} // namespace gin_helper
|
|
|
|
namespace electron {
|
|
|
|
class ElectronMenuModel;
|
|
class NativeBrowserView;
|
|
|
|
#if defined(OS_MAC)
|
|
typedef NSView* NativeWindowHandle;
|
|
#else
|
|
typedef gfx::AcceleratedWidget NativeWindowHandle;
|
|
#endif
|
|
|
|
class NativeWindow : public base::SupportsUserData,
|
|
public views::WidgetDelegate {
|
|
public:
|
|
~NativeWindow() override;
|
|
|
|
// 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() = 0;
|
|
virtual void Show() = 0;
|
|
virtual void ShowInactive() = 0;
|
|
virtual void Hide() = 0;
|
|
virtual bool IsVisible() = 0;
|
|
virtual bool IsEnabled() = 0;
|
|
virtual void SetEnabled(bool enable) = 0;
|
|
virtual void Maximize() = 0;
|
|
virtual void Unmaximize() = 0;
|
|
virtual bool IsMaximized() = 0;
|
|
virtual void Minimize() = 0;
|
|
virtual void Restore() = 0;
|
|
virtual bool IsMinimized() = 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() = 0;
|
|
virtual void SetSize(const gfx::Size& size, bool animate = false);
|
|
virtual gfx::Size GetSize();
|
|
virtual void SetPosition(const gfx::Point& position, bool animate = false);
|
|
virtual gfx::Point GetPosition();
|
|
virtual void SetContentSize(const gfx::Size& size, bool animate = false);
|
|
virtual gfx::Size GetContentSize();
|
|
virtual void SetContentBounds(const gfx::Rect& bounds, bool animate = false);
|
|
virtual gfx::Rect GetContentBounds();
|
|
virtual bool IsNormal();
|
|
virtual gfx::Rect GetNormalBounds() = 0;
|
|
virtual void SetSizeConstraints(
|
|
const extensions::SizeConstraints& size_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();
|
|
virtual double GetSheetOffsetY();
|
|
virtual void SetResizable(bool resizable) = 0;
|
|
virtual bool MoveAbove(const std::string& sourceId) = 0;
|
|
virtual void MoveTop() = 0;
|
|
virtual bool IsResizable() = 0;
|
|
virtual void SetMovable(bool movable) = 0;
|
|
virtual bool IsMovable() = 0;
|
|
virtual void SetMinimizable(bool minimizable) = 0;
|
|
virtual bool IsMinimizable() = 0;
|
|
virtual void SetMaximizable(bool maximizable) = 0;
|
|
virtual bool IsMaximizable() = 0;
|
|
virtual void SetFullScreenable(bool fullscreenable) = 0;
|
|
virtual bool IsFullScreenable() = 0;
|
|
virtual void SetClosable(bool closable) = 0;
|
|
virtual bool IsClosable() = 0;
|
|
virtual void SetAlwaysOnTop(ui::ZOrderLevel z_order,
|
|
const std::string& level = "floating",
|
|
int relativeLevel = 0) = 0;
|
|
virtual ui::ZOrderLevel GetZOrderLevel() = 0;
|
|
virtual void Center() = 0;
|
|
virtual void Invalidate() = 0;
|
|
virtual void SetTitle(const std::string& title) = 0;
|
|
virtual std::string GetTitle() = 0;
|
|
|
|
// 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() = 0;
|
|
virtual void SetSimpleFullScreen(bool simple_fullscreen) = 0;
|
|
virtual bool IsSimpleFullScreen() = 0;
|
|
virtual void SetKiosk(bool kiosk) = 0;
|
|
virtual bool IsKiosk() = 0;
|
|
virtual bool IsTabletMode() const;
|
|
virtual void SetBackgroundColor(SkColor color) = 0;
|
|
virtual SkColor GetBackgroundColor() = 0;
|
|
virtual void SetHasShadow(bool has_shadow) = 0;
|
|
virtual bool HasShadow() = 0;
|
|
virtual void SetOpacity(const double opacity) = 0;
|
|
virtual double GetOpacity() = 0;
|
|
virtual void SetRepresentedFilename(const std::string& filename);
|
|
virtual std::string GetRepresentedFilename();
|
|
virtual void SetDocumentEdited(bool edited);
|
|
virtual bool IsDocumentEdited();
|
|
virtual void SetIgnoreMouseEvents(bool ignore, bool forward) = 0;
|
|
virtual void SetContentProtection(bool enable) = 0;
|
|
virtual void SetFocusable(bool focusable);
|
|
virtual void SetMenu(ElectronMenuModel* menu);
|
|
virtual void SetParentWindow(NativeWindow* parent);
|
|
virtual void AddBrowserView(NativeBrowserView* browser_view) = 0;
|
|
virtual void RemoveBrowserView(NativeBrowserView* browser_view) = 0;
|
|
virtual void SetTopBrowserView(NativeBrowserView* browser_view) = 0;
|
|
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() = 0;
|
|
|
|
virtual void SetAutoHideCursor(bool auto_hide);
|
|
|
|
// Vibrancy API
|
|
virtual void SetVibrancy(const std::string& type);
|
|
|
|
// Traffic Light API
|
|
#if defined(OS_MAC)
|
|
virtual void SetWindowButtonVisibility(bool visible) = 0;
|
|
virtual bool GetWindowButtonVisibility() const = 0;
|
|
virtual void SetTrafficLightPosition(base::Optional<gfx::Point> position) = 0;
|
|
virtual base::Optional<gfx::Point> GetTrafficLightPosition() const = 0;
|
|
virtual void RedrawTrafficLights() = 0;
|
|
virtual void UpdateFrame() = 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 MergeAllWindows();
|
|
virtual void MoveTabToNewWindow();
|
|
virtual void ToggleTabBar();
|
|
virtual bool AddTabbedWindow(NativeWindow* window);
|
|
|
|
// Toggle the menu bar.
|
|
virtual void SetAutoHideMenuBar(bool auto_hide);
|
|
virtual bool IsMenuBarAutoHide();
|
|
virtual void SetMenuBarVisibility(bool visible);
|
|
virtual bool IsMenuBarVisible();
|
|
|
|
// Set the aspect ratio when resizing window.
|
|
double GetAspectRatio();
|
|
gfx::Size GetAspectRatioExtraSize();
|
|
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();
|
|
}
|
|
|
|
// Methods called by the WebContents.
|
|
virtual void HandleKeyboardEvent(
|
|
content::WebContents*,
|
|
const content::NativeWebKeyboardEvent& event) {}
|
|
|
|
// Public API used by platform-dependent delegates and observers to send UI
|
|
// related notifications.
|
|
void NotifyWindowRequestPreferredWith(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,
|
|
bool* prevent_default);
|
|
void NotifyWindowResize();
|
|
void NotifyWindowResized();
|
|
void NotifyWindowWillMove(const gfx::Rect& new_bounds, bool* prevent_default);
|
|
void NotifyWindowMoved();
|
|
void NotifyWindowScrollTouchBegin();
|
|
void NotifyWindowScrollTouchEnd();
|
|
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,
|
|
const base::DictionaryValue& details);
|
|
void NotifyNewWindowForTab();
|
|
void NotifyWindowSystemContextMenu(int x, int y, bool* prevent_default);
|
|
|
|
#if defined(OS_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);
|
|
}
|
|
|
|
views::Widget* widget() const { return widget_.get(); }
|
|
views::View* content_view() const { return content_view_; }
|
|
|
|
bool has_frame() const { return has_frame_; }
|
|
void set_has_frame(bool has_frame) { has_frame_ = has_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_; }
|
|
|
|
std::list<NativeBrowserView*> browser_views() const { return browser_views_; }
|
|
|
|
int32_t window_id() const { return next_id_; }
|
|
|
|
protected:
|
|
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; }
|
|
|
|
void add_browser_view(NativeBrowserView* browser_view) {
|
|
browser_views_.push_back(browser_view);
|
|
}
|
|
void remove_browser_view(NativeBrowserView* browser_view) {
|
|
browser_views_.remove_if(
|
|
[&browser_view](NativeBrowserView* n) { return (n == browser_view); });
|
|
}
|
|
|
|
private:
|
|
std::unique_ptr<views::Widget> widget_;
|
|
|
|
static int32_t next_id_;
|
|
|
|
// The content view, weak ref.
|
|
views::View* content_view_ = nullptr;
|
|
|
|
// Whether window has standard frame.
|
|
bool has_frame_ = true;
|
|
|
|
// Whether window is transparent.
|
|
bool transparent_ = false;
|
|
|
|
// Minimum and maximum size, stored as content size.
|
|
extensions::SizeConstraints size_constraints_;
|
|
|
|
// 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.
|
|
NativeWindow* parent_ = nullptr;
|
|
|
|
// Is this a modal window.
|
|
bool is_modal_ = false;
|
|
|
|
// The browser view layer.
|
|
std::list<NativeBrowserView*> browser_views_;
|
|
|
|
// Observers of this window.
|
|
base::ObserverList<NativeWindowObserver> observers_;
|
|
|
|
// Accessible title.
|
|
std::u16string accessible_title_;
|
|
|
|
base::WeakPtrFactory<NativeWindow> weak_factory_{this};
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(NativeWindow);
|
|
};
|
|
|
|
// 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(base::WeakPtr<NativeWindow> window);
|
|
|
|
base::WeakPtr<NativeWindow> native_window_;
|
|
};
|
|
|
|
} // namespace electron
|
|
|
|
#endif // SHELL_BROWSER_NATIVE_WINDOW_H_
|