fix: isMaximized after minimize/fullscreen on macOS (#38291)

fix: isMaximized after isMinimized on macOS
This commit is contained in:
Shelley Vohr 2023-05-16 09:26:41 +02:00 committed by GitHub
parent e19500fa03
commit 042663e190
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 41 additions and 0 deletions

View file

@ -562,6 +562,11 @@ void NativeWindowMac::Unmaximize() {
} }
bool NativeWindowMac::IsMaximized() { bool NativeWindowMac::IsMaximized() {
// It's possible for [window_ isZoomed] to be true
// when the window is minimized or fullscreened.
if (IsMinimized() || IsFullscreen())
return false;
if (HasStyleMask(NSWindowStyleMaskResizable) != 0) if (HasStyleMask(NSWindowStyleMaskResizable) != 0)
return [window_ isZoomed]; return [window_ isZoomed];

View file

@ -1665,6 +1665,42 @@ describe('BrowserWindow module', () => {
expectBoundsEqual(w.getNormalBounds(), bounds); expectBoundsEqual(w.getNormalBounds(), bounds);
}); });
it('correctly reports maximized state after maximizing then minimizing', async () => {
w.destroy();
w = new BrowserWindow({ show: false });
w.show();
const maximize = once(w, 'maximize');
w.maximize();
await maximize;
const minimize = once(w, 'minimize');
w.minimize();
await minimize;
expect(w.isMaximized()).to.equal(false);
expect(w.isMinimized()).to.equal(true);
});
it('correctly reports maximized state after maximizing then fullscreening', async () => {
w.destroy();
w = new BrowserWindow({ show: false });
w.show();
const maximize = once(w, 'maximize');
w.maximize();
await maximize;
const enterFS = once(w, 'enter-full-screen');
w.setFullScreen(true);
await enterFS;
expect(w.isMaximized()).to.equal(false);
expect(w.isFullScreen()).to.equal(true);
});
it('does not change size for a frameless window with min size', async () => { it('does not change size for a frameless window with min size', async () => {
w.destroy(); w.destroy();
w = new BrowserWindow({ w = new BrowserWindow({