2014-10-31 18:17:05 +00:00
|
|
|
// Copyright (c) 2013 GitHub, Inc.
|
2014-04-25 09:49:37 +00:00
|
|
|
// Use of this source code is governed by the MIT license that can be
|
2013-04-14 07:36:48 +00:00
|
|
|
// found in the LICENSE file.
|
|
|
|
|
2013-04-15 15:01:12 +00:00
|
|
|
#ifndef ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
|
|
|
#define ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
2013-04-14 07:36:48 +00:00
|
|
|
|
2015-10-27 12:00:08 +00:00
|
|
|
#include <map>
|
2016-06-17 07:57:03 +00:00
|
|
|
#include <memory>
|
2014-03-16 01:13:06 +00:00
|
|
|
#include <string>
|
2013-11-22 06:23:19 +00:00
|
|
|
#include <vector>
|
|
|
|
|
2015-06-24 08:37:48 +00:00
|
|
|
#include "atom/browser/api/trackable_object.h"
|
2015-08-05 14:26:18 +00:00
|
|
|
#include "atom/browser/native_window.h"
|
2014-03-16 00:30:26 +00:00
|
|
|
#include "atom/browser/native_window_observer.h"
|
2016-05-20 13:22:15 +00:00
|
|
|
#include "atom/common/api/atom_api_native_image.h"
|
2016-06-17 07:57:03 +00:00
|
|
|
#include "atom/common/key_weak_map.h"
|
2014-04-24 08:45:25 +00:00
|
|
|
#include "native_mate/handle.h"
|
2017-03-01 00:14:02 +00:00
|
|
|
#include "native_mate/persistent_dictionary.h"
|
2016-08-26 22:30:02 +00:00
|
|
|
#include "ui/gfx/image/image.h"
|
2014-04-22 15:07:21 +00:00
|
|
|
|
|
|
|
class GURL;
|
2013-04-15 16:25:08 +00:00
|
|
|
|
2015-05-01 10:50:53 +00:00
|
|
|
namespace gfx {
|
|
|
|
class Rect;
|
|
|
|
}
|
|
|
|
|
2014-04-22 15:07:21 +00:00
|
|
|
namespace mate {
|
|
|
|
class Arguments;
|
|
|
|
class Dictionary;
|
|
|
|
}
|
|
|
|
|
2013-04-14 07:36:48 +00:00
|
|
|
namespace atom {
|
|
|
|
|
2013-04-15 16:25:08 +00:00
|
|
|
class NativeWindow;
|
|
|
|
|
|
|
|
namespace api {
|
|
|
|
|
2014-04-24 08:45:25 +00:00
|
|
|
class WebContents;
|
|
|
|
|
2015-06-24 09:58:12 +00:00
|
|
|
class Window : public mate::TrackableObject<Window>,
|
2013-04-18 15:50:47 +00:00
|
|
|
public NativeWindowObserver {
|
2013-04-15 16:25:08 +00:00
|
|
|
public:
|
2016-08-02 06:15:40 +00:00
|
|
|
static mate::WrappableBase* New(mate::Arguments* args);
|
2013-04-15 16:25:08 +00:00
|
|
|
|
2014-04-22 15:07:21 +00:00
|
|
|
static void BuildPrototype(v8::Isolate* isolate,
|
2016-08-02 09:08:12 +00:00
|
|
|
v8::Local<v8::FunctionTemplate> prototype);
|
2013-04-15 16:25:08 +00:00
|
|
|
|
2015-10-01 05:45:59 +00:00
|
|
|
// Returns the BrowserWindow object from |native_window|.
|
|
|
|
static v8::Local<v8::Value> From(v8::Isolate* isolate,
|
|
|
|
NativeWindow* native_window);
|
|
|
|
|
2014-04-22 15:07:21 +00:00
|
|
|
NativeWindow* window() const { return window_.get(); }
|
2013-04-15 16:25:08 +00:00
|
|
|
|
2017-02-16 18:58:02 +00:00
|
|
|
int32_t ID() const;
|
|
|
|
|
2013-04-15 16:25:08 +00:00
|
|
|
protected:
|
2016-08-02 06:15:40 +00:00
|
|
|
Window(v8::Isolate* isolate, v8::Local<v8::Object> wrapper,
|
|
|
|
const mate::Dictionary& options);
|
2016-04-25 01:17:54 +00:00
|
|
|
~Window() override;
|
2013-04-15 16:25:08 +00:00
|
|
|
|
2014-11-25 04:43:25 +00:00
|
|
|
// NativeWindowObserver:
|
2014-10-27 08:58:35 +00:00
|
|
|
void WillCloseWindow(bool* prevent_default) override;
|
2016-08-25 18:24:16 +00:00
|
|
|
void WillDestroyNativeObject() override;
|
2014-10-27 08:58:35 +00:00
|
|
|
void OnWindowClosed() override;
|
2017-04-24 18:49:21 +00:00
|
|
|
void OnWindowEndSession() override;
|
2014-10-27 08:58:35 +00:00
|
|
|
void OnWindowBlur() override;
|
|
|
|
void OnWindowFocus() override;
|
2016-03-08 17:36:41 +00:00
|
|
|
void OnWindowShow() override;
|
|
|
|
void OnWindowHide() override;
|
2016-06-13 12:19:56 +00:00
|
|
|
void OnReadyToShow() override;
|
2014-11-25 04:43:25 +00:00
|
|
|
void OnWindowMaximize() override;
|
|
|
|
void OnWindowUnmaximize() override;
|
|
|
|
void OnWindowMinimize() override;
|
|
|
|
void OnWindowRestore() override;
|
2015-05-09 15:55:10 +00:00
|
|
|
void OnWindowResize() override;
|
|
|
|
void OnWindowMove() override;
|
2015-05-20 08:37:13 +00:00
|
|
|
void OnWindowMoved() override;
|
2016-01-22 00:31:09 +00:00
|
|
|
void OnWindowScrollTouchBegin() override;
|
|
|
|
void OnWindowScrollTouchEnd() override;
|
2016-09-17 14:29:32 +00:00
|
|
|
void OnWindowScrollTouchEdge() override;
|
2016-03-23 15:20:11 +00:00
|
|
|
void OnWindowSwipe(const std::string& direction) override;
|
2017-04-20 17:31:25 +00:00
|
|
|
void OnWindowSheetBegin() override;
|
|
|
|
void OnWindowSheetEnd() override;
|
2014-11-25 04:43:25 +00:00
|
|
|
void OnWindowEnterFullScreen() override;
|
|
|
|
void OnWindowLeaveFullScreen() override;
|
2015-05-16 21:01:30 +00:00
|
|
|
void OnWindowEnterHtmlFullScreen() override;
|
|
|
|
void OnWindowLeaveHtmlFullScreen() override;
|
2014-10-27 08:58:35 +00:00
|
|
|
void OnRendererUnresponsive() override;
|
|
|
|
void OnRendererResponsive() override;
|
2015-06-25 21:09:25 +00:00
|
|
|
void OnExecuteWindowsCommand(const std::string& command_name) override;
|
2017-02-28 23:37:15 +00:00
|
|
|
void OnTouchBarItemResult(const std::string& item_id,
|
|
|
|
const base::DictionaryValue& details) override;
|
2017-06-11 08:19:01 +00:00
|
|
|
void OnNewWindowForTab() override;
|
2013-04-18 15:50:47 +00:00
|
|
|
|
2015-10-27 01:12:01 +00:00
|
|
|
#if defined(OS_WIN)
|
2015-10-29 02:53:48 +00:00
|
|
|
void OnWindowMessage(UINT message, WPARAM w_param, LPARAM l_param) override;
|
2015-10-27 01:12:01 +00:00
|
|
|
#endif
|
|
|
|
|
2013-04-15 16:25:08 +00:00
|
|
|
private:
|
2016-08-15 23:58:07 +00:00
|
|
|
void Init(v8::Isolate* isolate,
|
|
|
|
v8::Local<v8::Object> wrapper,
|
|
|
|
const mate::Dictionary& options,
|
|
|
|
mate::Handle<class WebContents> web_contents);
|
2013-04-17 14:49:49 +00:00
|
|
|
// APIs for NativeWindow.
|
2014-04-22 15:07:21 +00:00
|
|
|
void Close();
|
|
|
|
void Focus();
|
2016-03-11 05:45:51 +00:00
|
|
|
void Blur();
|
2014-04-22 15:07:21 +00:00
|
|
|
bool IsFocused();
|
|
|
|
void Show();
|
2014-10-17 14:51:20 +00:00
|
|
|
void ShowInactive();
|
2014-04-22 15:07:21 +00:00
|
|
|
void Hide();
|
|
|
|
bool IsVisible();
|
2016-06-17 08:38:44 +00:00
|
|
|
bool IsEnabled();
|
2014-04-22 15:07:21 +00:00
|
|
|
void Maximize();
|
|
|
|
void Unmaximize();
|
2014-05-14 21:58:49 +00:00
|
|
|
bool IsMaximized();
|
2014-04-22 15:07:21 +00:00
|
|
|
void Minimize();
|
|
|
|
void Restore();
|
2014-07-26 05:58:26 +00:00
|
|
|
bool IsMinimized();
|
2014-11-25 06:34:14 +00:00
|
|
|
void SetFullScreen(bool fullscreen);
|
2014-04-22 15:07:21 +00:00
|
|
|
bool IsFullscreen();
|
2016-01-15 16:31:31 +00:00
|
|
|
void SetBounds(const gfx::Rect& bounds, mate::Arguments* args);
|
2015-05-01 10:50:53 +00:00
|
|
|
gfx::Rect GetBounds();
|
2016-01-15 16:31:31 +00:00
|
|
|
void SetSize(int width, int height, mate::Arguments* args);
|
2014-04-22 15:07:21 +00:00
|
|
|
std::vector<int> GetSize();
|
2016-01-15 16:31:31 +00:00
|
|
|
void SetContentSize(int width, int height, mate::Arguments* args);
|
2014-05-15 07:30:04 +00:00
|
|
|
std::vector<int> GetContentSize();
|
2016-08-04 19:02:24 +00:00
|
|
|
void SetContentBounds(const gfx::Rect& bounds, mate::Arguments* args);
|
2016-07-29 01:19:17 +00:00
|
|
|
gfx::Rect GetContentBounds();
|
2014-04-22 15:07:21 +00:00
|
|
|
void SetMinimumSize(int width, int height);
|
|
|
|
std::vector<int> GetMinimumSize();
|
|
|
|
void SetMaximumSize(int width, int height);
|
|
|
|
std::vector<int> GetMaximumSize();
|
2016-05-20 03:19:08 +00:00
|
|
|
void SetSheetOffset(double offsetY, mate::Arguments* args);
|
2014-04-22 15:07:21 +00:00
|
|
|
void SetResizable(bool resizable);
|
|
|
|
bool IsResizable();
|
2016-01-18 22:46:35 +00:00
|
|
|
void SetMovable(bool movable);
|
|
|
|
bool IsMovable();
|
|
|
|
void SetMinimizable(bool minimizable);
|
|
|
|
bool IsMinimizable();
|
2016-01-22 21:24:33 +00:00
|
|
|
void SetMaximizable(bool maximizable);
|
|
|
|
bool IsMaximizable();
|
2016-01-23 07:47:37 +00:00
|
|
|
void SetFullScreenable(bool fullscreenable);
|
|
|
|
bool IsFullScreenable();
|
2016-01-18 22:46:35 +00:00
|
|
|
void SetClosable(bool closable);
|
|
|
|
bool IsClosable();
|
2016-09-21 17:35:59 +00:00
|
|
|
void SetAlwaysOnTop(bool top, mate::Arguments* args);
|
2014-04-22 15:07:21 +00:00
|
|
|
bool IsAlwaysOnTop();
|
|
|
|
void Center();
|
2016-01-15 16:31:31 +00:00
|
|
|
void SetPosition(int x, int y, mate::Arguments* args);
|
2014-04-22 15:07:21 +00:00
|
|
|
std::vector<int> GetPosition();
|
|
|
|
void SetTitle(const std::string& title);
|
|
|
|
std::string GetTitle();
|
|
|
|
void FlashFrame(bool flash);
|
2014-06-16 02:29:51 +00:00
|
|
|
void SetSkipTaskbar(bool skip);
|
2014-04-22 15:07:21 +00:00
|
|
|
void SetKiosk(bool kiosk);
|
|
|
|
bool IsKiosk();
|
2015-10-23 03:35:33 +00:00
|
|
|
void SetBackgroundColor(const std::string& color_name);
|
2016-01-23 00:15:49 +00:00
|
|
|
void SetHasShadow(bool has_shadow);
|
|
|
|
bool HasShadow();
|
2014-04-22 15:07:21 +00:00
|
|
|
void FocusOnWebView();
|
|
|
|
void BlurWebView();
|
|
|
|
bool IsWebViewFocused();
|
2014-05-27 06:15:34 +00:00
|
|
|
void SetRepresentedFilename(const std::string& filename);
|
2014-07-18 13:42:26 +00:00
|
|
|
std::string GetRepresentedFilename();
|
2014-05-27 06:15:34 +00:00
|
|
|
void SetDocumentEdited(bool edited);
|
2014-07-24 07:48:33 +00:00
|
|
|
bool IsDocumentEdited();
|
2015-12-06 02:14:54 +00:00
|
|
|
void SetIgnoreMouseEvents(bool ignore);
|
2016-06-22 08:40:01 +00:00
|
|
|
void SetContentProtection(bool enable);
|
2016-06-13 08:10:28 +00:00
|
|
|
void SetFocusable(bool focusable);
|
2016-08-08 22:44:48 +00:00
|
|
|
void SetProgressBar(double progress, mate::Arguments* args);
|
2015-02-07 01:00:26 +00:00
|
|
|
void SetOverlayIcon(const gfx::Image& overlay,
|
2015-02-07 00:31:41 +00:00
|
|
|
const std::string& description);
|
2015-08-06 04:44:07 +00:00
|
|
|
bool SetThumbarButtons(mate::Arguments* args);
|
2015-06-24 11:51:11 +00:00
|
|
|
void SetMenu(v8::Isolate* isolate, v8::Local<v8::Value> menu);
|
2014-11-12 12:31:55 +00:00
|
|
|
void SetAutoHideMenuBar(bool auto_hide);
|
|
|
|
bool IsMenuBarAutoHide();
|
|
|
|
void SetMenuBarVisibility(bool visible);
|
|
|
|
bool IsMenuBarVisible();
|
2015-07-23 02:14:02 +00:00
|
|
|
void SetAspectRatio(double aspect_ratio, mate::Arguments* args);
|
2016-10-14 16:42:50 +00:00
|
|
|
void PreviewFile(const std::string& path, mate::Arguments* args);
|
2016-11-21 18:30:13 +00:00
|
|
|
void CloseFilePreview();
|
2016-06-17 07:57:03 +00:00
|
|
|
void SetParentWindow(v8::Local<v8::Value> value, mate::Arguments* args);
|
2016-06-18 00:42:18 +00:00
|
|
|
v8::Local<v8::Value> GetParentWindow() const;
|
|
|
|
std::vector<v8::Local<v8::Object>> GetChildWindows() const;
|
Implement initial, experimental BrowserView API
Right now, `<webview>` is the only way to embed additional content in a
`BrowserWindow`. Unfortunately `<webview>` suffers from a [number of
problems](https://github.com/electron/electron/issues?utf8=%E2%9C%93&q=is%3Aissue%20is%3Aopen%20label%3Awebview%20).
To make matters worse, many of these are upstream Chromium bugs instead
of Electron-specific bugs.
For us at [Figma](https://www.figma.com), the main issue is very slow
performance.
Despite the upstream improvements to `<webview>` through the OOPIF work, it is
probable that there will continue to be `<webview>`-specific bugs in the
future.
Therefore, this introduces a `<webview>` alternative to called `BrowserView`,
which...
- is a thin wrapper around `api::WebContents` (so bugs in `BrowserView` will
likely also be bugs in `BrowserWindow` web contents)
- is instantiated in the main process like `BrowserWindow` (and unlike
`<webview>`, which lives in the DOM of a `BrowserWindow` web contents)
- needs to be added to a `BrowserWindow` to display something on the screen
This implements the most basic API. The API is expected to evolve and change in
the near future and has consequently been marked as experimental. Please do not
use this API in production unless you are prepared to deal with breaking
changes.
In the future, we will want to change the API to support multiple
`BrowserView`s per window. We will also want to consider z-ordering
auto-resizing, and possibly even nested views.
2017-04-11 17:47:30 +00:00
|
|
|
v8::Local<v8::Value> GetBrowserView() const;
|
|
|
|
void SetBrowserView(v8::Local<v8::Value> value);
|
2017-06-21 23:21:28 +00:00
|
|
|
void ResetBrowserView();
|
2016-06-18 00:42:18 +00:00
|
|
|
bool IsModal() const;
|
2016-01-07 20:38:35 +00:00
|
|
|
v8::Local<v8::Value> GetNativeWindowHandle();
|
2013-04-15 16:25:08 +00:00
|
|
|
|
2015-10-27 12:00:08 +00:00
|
|
|
#if defined(OS_WIN)
|
2015-10-29 01:00:44 +00:00
|
|
|
typedef base::Callback<void(v8::Local<v8::Value>,
|
|
|
|
v8::Local<v8::Value>)> MessageCallback;
|
2015-10-27 12:00:08 +00:00
|
|
|
|
2015-10-29 02:53:48 +00:00
|
|
|
bool HookWindowMessage(UINT message, const MessageCallback& callback);
|
2015-10-27 12:00:08 +00:00
|
|
|
bool IsWindowMessageHooked(UINT message);
|
|
|
|
void UnhookWindowMessage(UINT message);
|
|
|
|
void UnhookAllWindowMessages();
|
2016-07-14 22:54:57 +00:00
|
|
|
bool SetThumbnailClip(const gfx::Rect& region);
|
2016-08-07 17:23:42 +00:00
|
|
|
bool SetThumbnailToolTip(const std::string& tooltip);
|
2016-11-12 16:21:31 +00:00
|
|
|
void SetAppDetails(const mate::Dictionary& options);
|
2015-10-27 12:00:08 +00:00
|
|
|
#endif
|
|
|
|
|
2016-05-20 13:22:15 +00:00
|
|
|
#if defined(TOOLKIT_VIEWS)
|
|
|
|
void SetIcon(mate::Handle<NativeImage> icon);
|
|
|
|
#endif
|
|
|
|
|
2015-03-26 06:18:37 +00:00
|
|
|
void SetVisibleOnAllWorkspaces(bool visible);
|
|
|
|
bool IsVisibleOnAllWorkspaces();
|
|
|
|
|
2016-11-28 19:38:40 +00:00
|
|
|
void SetAutoHideCursor(bool auto_hide);
|
|
|
|
|
2017-08-21 04:46:10 +00:00
|
|
|
void SelectPreviousTab();
|
|
|
|
void SelectNextTab();
|
|
|
|
void MergeAllWindows();
|
|
|
|
void MoveTabToNewWindow();
|
|
|
|
void ToggleTabBar();
|
|
|
|
|
2016-11-10 19:36:21 +00:00
|
|
|
void SetVibrancy(mate::Arguments* args);
|
2017-03-01 00:14:02 +00:00
|
|
|
void SetTouchBar(const std::vector<mate::PersistentDictionary>& items);
|
2017-03-01 00:08:12 +00:00
|
|
|
void RefreshTouchBarItem(const std::string& item_id);
|
2017-03-29 04:11:39 +00:00
|
|
|
void SetEscapeTouchBarItem(const mate::PersistentDictionary& item);
|
2016-11-07 20:22:41 +00:00
|
|
|
|
2015-06-05 09:01:17 +00:00
|
|
|
v8::Local<v8::Value> WebContents(v8::Isolate* isolate);
|
|
|
|
|
2016-06-18 00:42:18 +00:00
|
|
|
// Remove this window from parent window's |child_windows_|.
|
2016-06-17 07:57:03 +00:00
|
|
|
void RemoveFromParentChildWindows();
|
|
|
|
|
2015-10-29 02:53:48 +00:00
|
|
|
#if defined(OS_WIN)
|
|
|
|
typedef std::map<UINT, MessageCallback> MessageCallbackMap;
|
|
|
|
MessageCallbackMap messages_callback_map_;
|
|
|
|
#endif
|
|
|
|
|
Implement initial, experimental BrowserView API
Right now, `<webview>` is the only way to embed additional content in a
`BrowserWindow`. Unfortunately `<webview>` suffers from a [number of
problems](https://github.com/electron/electron/issues?utf8=%E2%9C%93&q=is%3Aissue%20is%3Aopen%20label%3Awebview%20).
To make matters worse, many of these are upstream Chromium bugs instead
of Electron-specific bugs.
For us at [Figma](https://www.figma.com), the main issue is very slow
performance.
Despite the upstream improvements to `<webview>` through the OOPIF work, it is
probable that there will continue to be `<webview>`-specific bugs in the
future.
Therefore, this introduces a `<webview>` alternative to called `BrowserView`,
which...
- is a thin wrapper around `api::WebContents` (so bugs in `BrowserView` will
likely also be bugs in `BrowserWindow` web contents)
- is instantiated in the main process like `BrowserWindow` (and unlike
`<webview>`, which lives in the DOM of a `BrowserWindow` web contents)
- needs to be added to a `BrowserWindow` to display something on the screen
This implements the most basic API. The API is expected to evolve and change in
the near future and has consequently been marked as experimental. Please do not
use this API in production unless you are prepared to deal with breaking
changes.
In the future, we will want to change the API to support multiple
`BrowserView`s per window. We will also want to consider z-ordering
auto-resizing, and possibly even nested views.
2017-04-11 17:47:30 +00:00
|
|
|
v8::Global<v8::Value> browser_view_;
|
2015-06-05 09:01:17 +00:00
|
|
|
v8::Global<v8::Value> web_contents_;
|
2015-06-24 11:51:11 +00:00
|
|
|
v8::Global<v8::Value> menu_;
|
2016-06-17 07:09:43 +00:00
|
|
|
v8::Global<v8::Value> parent_window_;
|
2016-06-17 07:57:03 +00:00
|
|
|
KeyWeakMap<int> child_windows_;
|
2013-04-18 07:09:53 +00:00
|
|
|
|
2015-06-25 03:07:23 +00:00
|
|
|
api::WebContents* api_web_contents_;
|
|
|
|
|
2016-05-23 01:59:39 +00:00
|
|
|
std::unique_ptr<NativeWindow> window_;
|
2013-04-15 16:25:08 +00:00
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(Window);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace api
|
|
|
|
|
2013-04-14 07:36:48 +00:00
|
|
|
} // namespace atom
|
|
|
|
|
2014-04-24 05:10:04 +00:00
|
|
|
|
|
|
|
namespace mate {
|
|
|
|
|
|
|
|
template<>
|
|
|
|
struct Converter<atom::NativeWindow*> {
|
2015-05-22 11:11:22 +00:00
|
|
|
static bool FromV8(v8::Isolate* isolate, v8::Local<v8::Value> val,
|
2014-04-24 05:10:04 +00:00
|
|
|
atom::NativeWindow** out) {
|
|
|
|
// null would be tranfered to NULL.
|
|
|
|
if (val->IsNull()) {
|
|
|
|
*out = NULL;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
atom::api::Window* window;
|
|
|
|
if (!Converter<atom::api::Window*>::FromV8(isolate, val, &window))
|
|
|
|
return false;
|
|
|
|
*out = window->window();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace mate
|
|
|
|
|
2013-04-15 15:01:12 +00:00
|
|
|
#endif // ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|