Merge pull request #8399 from watilde/feature/fixes-8338

save a fullscreen state when Kiosk mode is called
This commit is contained in:
Kevin Sawicki 2017-01-17 13:03:51 -08:00 committed by GitHub
commit f7bdf5d04e
3 changed files with 41 additions and 1 deletions

View file

@ -162,6 +162,8 @@ class NativeWindowMac : public NativeWindow,
bool is_kiosk_; bool is_kiosk_;
bool was_fullscreen_;
bool zoom_to_page_width_; bool zoom_to_page_width_;
NSInteger attention_request_id_; // identifier from requestUserAttention NSInteger attention_request_id_; // identifier from requestUserAttention

View file

@ -619,6 +619,7 @@ NativeWindowMac::NativeWindowMac(
NativeWindow* parent) NativeWindow* parent)
: NativeWindow(web_contents, options, parent), : NativeWindow(web_contents, options, parent),
is_kiosk_(false), is_kiosk_(false),
was_fullscreen_(false),
zoom_to_page_width_(false), zoom_to_page_width_(false),
attention_request_id_(0), attention_request_id_(0),
title_bar_style_(NORMAL) { title_bar_style_(NORMAL) {
@ -1126,10 +1127,11 @@ void NativeWindowMac::SetKiosk(bool kiosk) {
NSApplicationPresentationDisableHideApplication; NSApplicationPresentationDisableHideApplication;
[NSApp setPresentationOptions:options]; [NSApp setPresentationOptions:options];
is_kiosk_ = true; is_kiosk_ = true;
was_fullscreen_ = IsFullscreen();
SetFullScreen(true); SetFullScreen(true);
} else if (!kiosk && is_kiosk_) { } else if (!kiosk && is_kiosk_) {
is_kiosk_ = false; is_kiosk_ = false;
SetFullScreen(false); if (!was_fullscreen_) SetFullScreen(false);
[NSApp setPresentationOptions:kiosk_options_]; [NSApp setPresentationOptions:kiosk_options_];
} }
} }

View file

@ -1417,6 +1417,42 @@ describe('BrowserWindow module', function () {
}) })
}) })
describe('kiosk state', function () {
// Only implemented on macOS.
if (process.platform !== 'darwin') return
it('can be changed with setKiosk method', function () {
w.destroy()
w = new BrowserWindow()
w.setKiosk(true)
assert.equal(w.isKiosk(), true)
w.setKiosk(false)
assert.equal(w.isKiosk(), false)
})
})
describe('fullscreen state', function () {
// Only implemented on macOS.
if (process.platform !== 'darwin') return
it('can be changed with setFullScreen method', function () {
w.destroy()
w = new BrowserWindow()
w.setFullScreen(true)
assert.equal(w.isFullScreen(), true)
w.setFullScreen(false)
assert.equal(w.isFullScreen(), false)
})
it('should not be changed by setKiosk method', function () {
w.setFullScreen(true)
assert.equal(w.isFullScreen(), true)
w.setKiosk(true)
w.setKiosk(false)
assert.equal(w.isFullScreen(), true)
})
})
describe('closable state', function () { describe('closable state', function () {
it('can be changed with closable option', function () { it('can be changed with closable option', function () {
w.destroy() w.destroy()