diff --git a/docs/api/browser-window.md b/docs/api/browser-window.md index f67603a63930..25a7ccff8a71 100644 --- a/docs/api/browser-window.md +++ b/docs/api/browser-window.md @@ -807,6 +807,10 @@ hide it immediately. A `Boolean` property that determines whether the window is in simple (pre-Lion) fullscreen mode. +#### `win.fullScreen` + +A `Boolean` property that determines whether the window is in fullscreen mode. + #### `win.visibleOnAllWorkspaces` A `Boolean` property that determines whether the window is visible on all workspaces. diff --git a/lib/browser/api/top-level-window.js b/lib/browser/api/top-level-window.js index a4fd83698735..9a90887fcf25 100644 --- a/lib/browser/api/top-level-window.js +++ b/lib/browser/api/top-level-window.js @@ -29,6 +29,11 @@ Object.defineProperty(TopLevelWindow.prototype, 'visibleOnAllWorkspaces', { set: function (visible) { this.setVisibleOnAllWorkspaces(visible); } }); +Object.defineProperty(TopLevelWindow.prototype, 'fullScreen', { + get: function () { return this.isFullScreen(); }, + set: function (full) { this.setFullScreen(full); } +}); + Object.defineProperty(TopLevelWindow.prototype, 'simpleFullScreen', { get: function () { return this.isSimpleFullScreen(); }, set: function (simple) { this.setSimpleFullScreen(simple); } diff --git a/spec-main/api-browser-window-spec.ts b/spec-main/api-browser-window-spec.ts index a2f91f58d164..dd219a92b068 100644 --- a/spec-main/api-browser-window-spec.ts +++ b/spec-main/api-browser-window-spec.ts @@ -1010,27 +1010,78 @@ describe('BrowserWindow module', () => { }); ifdescribe(process.platform === 'win32')(`Fullscreen state`, () => { - it(`checks normal bounds when fullscreen'ed`, (done) => { - const bounds = w.getBounds(); - w.once('enter-full-screen', () => { - expectBoundsEqual(w.getNormalBounds(), bounds); - done(); + it('with properties', () => { + it('can be set with the fullscreen constructor option', () => { + w = new BrowserWindow({ fullscreen: true }); + expect(w.fullScreen).to.be.true(); + }); + + it('can be changed', () => { + w.fullScreen = false; + expect(w.fullScreen).to.be.false(); + w.fullScreen = true; + expect(w.fullScreen).to.be.true(); + }); + + it(`checks normal bounds when fullscreen'ed`, (done) => { + const bounds = w.getBounds(); + w.once('enter-full-screen', () => { + expectBoundsEqual(w.getNormalBounds(), bounds); + done(); + }); + w.show(); + w.fullScreen = true; + }); + + it(`checks normal bounds when unfullscreen'ed`, (done) => { + const bounds = w.getBounds(); + w.once('enter-full-screen', () => { + w.fullScreen = false; + }); + w.once('leave-full-screen', () => { + expectBoundsEqual(w.getNormalBounds(), bounds); + done(); + }); + w.show(); + w.fullScreen = true; }); - w.show(); - w.setFullScreen(true); }); - it(`checks normal bounds when unfullscreen'ed`, (done) => { - const bounds = w.getBounds(); - w.once('enter-full-screen', () => { + it('with functions', () => { + it('can be set with the fullscreen constructor option', () => { + w = new BrowserWindow({ fullscreen: true }); + expect(w.isFullScreen()).to.be.true(); + }); + + it('can be changed', () => { w.setFullScreen(false); + expect(w.isFullScreen()).to.be.false(); + w.setFullScreen(true); + expect(w.isFullScreen()).to.be.true(); }); - w.once('leave-full-screen', () => { - expectBoundsEqual(w.getNormalBounds(), bounds); - done(); + + it(`checks normal bounds when fullscreen'ed`, (done) => { + const bounds = w.getBounds(); + w.once('enter-full-screen', () => { + expectBoundsEqual(w.getNormalBounds(), bounds); + done(); + }); + w.show(); + w.setFullScreen(true); + }); + + it(`checks normal bounds when unfullscreen'ed`, (done) => { + const bounds = w.getBounds(); + w.once('enter-full-screen', () => { + w.setFullScreen(false); + }); + w.once('leave-full-screen', () => { + expectBoundsEqual(w.getNormalBounds(), bounds); + done(); + }); + w.show(); + w.setFullScreen(true); }); - w.show(); - w.setFullScreen(true); }); }); });