From 4afc756094b12ab7243abc09340168ee192f8de3 Mon Sep 17 00:00:00 2001 From: Milan Burda Date: Thu, 14 May 2020 15:11:45 +0200 Subject: [PATCH] feat: add contents.getBackgroundThrottling() + backgroundThrottling property (#21036) --- docs/api/modernization/property-updates.md | 1 + docs/api/web-contents.md | 10 ++++++ lib/browser/api/browser-window.js | 3 ++ lib/browser/api/web-contents.js | 5 +++ .../browser/api/electron_api_web_contents.cc | 6 ++++ shell/browser/api/electron_api_web_contents.h | 1 + spec-main/api-web-contents-spec.ts | 33 +++++++++++++++++++ 7 files changed, 59 insertions(+) diff --git a/docs/api/modernization/property-updates.md b/docs/api/modernization/property-updates.md index 7019982b6d5..cb542cc7c6e 100644 --- a/docs/api/modernization/property-updates.md +++ b/docs/api/modernization/property-updates.md @@ -34,6 +34,7 @@ The Electron team is currently undergoing an initiative to convert separate gett * `fullscreenable` * `movable` * `closable` + * `backgroundThrottling` * `NativeImage` * `isMacTemplateImage` * `SystemPreferences` module diff --git a/docs/api/web-contents.md b/docs/api/web-contents.md index 5854943adca..050012ee8b1 100644 --- a/docs/api/web-contents.md +++ b/docs/api/web-contents.md @@ -1812,6 +1812,11 @@ Returns `Promise` - Indicates whether the snapshot has been created succes Takes a V8 heap snapshot and saves it to `filePath`. +#### `contents.getBackgroundThrottling()` + +Returns `Boolean` - whether or not this WebContents will throttle animations and timers +when the page becomes backgrounded. This also affects the Page Visibility API. + #### `contents.setBackgroundThrottling(allowed)` * `allowed` Boolean @@ -1879,3 +1884,8 @@ A [`Debugger`](debugger.md) instance for this webContents. [event-emitter]: https://nodejs.org/api/events.html#events_class_eventemitter [SCA]: https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm [`postMessage`]: https://developer.mozilla.org/en-US/docs/Web/API/Window/postMessage + +#### `contents.backgroundThrottling` + +A `Boolean` property that determines whether or not this WebContents will throttle animations and timers +when the page becomes backgrounded. This also affects the Page Visibility API. diff --git a/lib/browser/api/browser-window.js b/lib/browser/api/browser-window.js index 3294cb28f58..7c3e8579831 100644 --- a/lib/browser/api/browser-window.js +++ b/lib/browser/api/browser-window.js @@ -157,6 +157,9 @@ Object.assign(BrowserWindow.prototype, { setTouchBar (touchBar) { electron.TouchBar._setOnWindow(touchBar, this); }, + getBackgroundThrottling () { + return this.webContents.getBackgroundThrottling(); + }, setBackgroundThrottling (allowed) { this.webContents.setBackgroundThrottling(allowed); } diff --git a/lib/browser/api/web-contents.js b/lib/browser/api/web-contents.js index 36083c92fc4..49eacd45ca1 100644 --- a/lib/browser/api/web-contents.js +++ b/lib/browser/api/web-contents.js @@ -587,6 +587,11 @@ WebContents.prototype._init = function () { get: () => this.getFrameRate(), set: (rate) => this.setFrameRate(rate) }); + + Object.defineProperty(this, 'backgroundThrottling', { + get: () => this.getBackgroundThrottling(), + set: (allowed) => this.setBackgroundThrottling(allowed) + }); }; // Public APIs. diff --git a/shell/browser/api/electron_api_web_contents.cc b/shell/browser/api/electron_api_web_contents.cc index 9eb4f1c55ca..82e4f779f49 100644 --- a/shell/browser/api/electron_api_web_contents.cc +++ b/shell/browser/api/electron_api_web_contents.cc @@ -1439,6 +1439,10 @@ void WebContents::NavigationEntryCommitted( details.is_same_document, details.did_replace_entry); } +bool WebContents::GetBackgroundThrottling() const { + return background_throttling_; +} + void WebContents::SetBackgroundThrottling(bool allowed) { background_throttling_ = allowed; @@ -2719,6 +2723,8 @@ void WebContents::BuildPrototype(v8::Isolate* isolate, prototype->SetClassName(gin::StringToV8(isolate, "WebContents")); gin_helper::Destroyable::MakeDestroyable(isolate, prototype); gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate()) + .SetMethod("getBackgroundThrottling", + &WebContents::GetBackgroundThrottling) .SetMethod("setBackgroundThrottling", &WebContents::SetBackgroundThrottling) .SetMethod("getProcessId", &WebContents::GetProcessID) diff --git a/shell/browser/api/electron_api_web_contents.h b/shell/browser/api/electron_api_web_contents.h index a0d13444952..e3b9faba5cb 100644 --- a/shell/browser/api/electron_api_web_contents.h +++ b/shell/browser/api/electron_api_web_contents.h @@ -187,6 +187,7 @@ class WebContents : public gin_helper::TrackableObject, // See https://github.com/electron/electron/issues/15133. void DestroyWebContents(bool async); + bool GetBackgroundThrottling() const; void SetBackgroundThrottling(bool allowed); int GetProcessID() const; base::ProcessId GetOSProcessID() const; diff --git a/spec-main/api-web-contents-spec.ts b/spec-main/api-web-contents-spec.ts index 3f5964e46ed..56eca4d57b5 100644 --- a/spec-main/api-web-contents-spec.ts +++ b/spec-main/api-web-contents-spec.ts @@ -1541,6 +1541,39 @@ describe('webContents module', () => { }); }); + describe('getBackgroundThrottling()', () => { + afterEach(closeAllWindows); + it('works via getter', () => { + const w = new BrowserWindow({ show: false }); + + w.webContents.setBackgroundThrottling(false); + expect(w.webContents.getBackgroundThrottling()).to.equal(false); + + w.webContents.setBackgroundThrottling(true); + expect(w.webContents.getBackgroundThrottling()).to.equal(true); + }); + + it('works via property', () => { + const w = new BrowserWindow({ show: false }); + + w.webContents.backgroundThrottling = false; + expect(w.webContents.backgroundThrottling).to.equal(false); + + w.webContents.backgroundThrottling = true; + expect(w.webContents.backgroundThrottling).to.equal(true); + }); + + it('works via BrowserWindow', () => { + const w = new BrowserWindow({ show: false }); + + (w as any).setBackgroundThrottling(false); + expect((w as any).getBackgroundThrottling()).to.equal(false); + + (w as any).setBackgroundThrottling(true); + expect((w as any).getBackgroundThrottling()).to.equal(true); + }); + }); + ifdescribe(features.isPrintingEnabled())('getPrinters()', () => { afterEach(closeAllWindows); it('can get printer list', async () => {