diff --git a/shell/browser/native_window_mac.mm b/shell/browser/native_window_mac.mm index c706a56a01f5..3e5ee7701028 100644 --- a/shell/browser/native_window_mac.mm +++ b/shell/browser/native_window_mac.mm @@ -1517,12 +1517,15 @@ void NativeWindowMac::SetVibrancy(const std::string& type) { void NativeWindowMac::SetWindowButtonVisibility(bool visible) { window_button_visibility_ = visible; - // The visibility of window buttons are managed by |buttons_proxy_| if the - // style is customButtonsOnHover. - if (title_bar_style_ == TitleBarStyle::kCustomButtonsOnHover) + if (buttons_proxy_) { + if (visible) + [buttons_proxy_ redraw]; [buttons_proxy_ setVisible:visible]; - else + } + + if (title_bar_style_ != TitleBarStyle::kCustomButtonsOnHover) InternalSetWindowButtonVisibility(visible); + NotifyLayoutWindowControlsOverlay(); } diff --git a/spec-main/api-browser-window-spec.ts b/spec-main/api-browser-window-spec.ts index 039bc17b31e0..f2682e70482a 100644 --- a/spec-main/api-browser-window-spec.ts +++ b/spec-main/api-browser-window-spec.ts @@ -1996,6 +1996,42 @@ describe('BrowserWindow module', () => { w.setWindowButtonVisibility(false); expect(w._getWindowButtonVisibility()).to.equal(false); }); + + it('correctly updates when entering/exiting fullscreen for hidden style', async () => { + const w = new BrowserWindow({ show: false, frame: false, titleBarStyle: 'hidden' }); + expect(w._getWindowButtonVisibility()).to.equal(true); + w.setWindowButtonVisibility(false); + expect(w._getWindowButtonVisibility()).to.equal(false); + + const enterFS = emittedOnce(w, 'enter-full-screen'); + w.setFullScreen(true); + await enterFS; + + const leaveFS = emittedOnce(w, 'leave-full-screen'); + w.setFullScreen(false); + await leaveFS; + + w.setWindowButtonVisibility(true); + expect(w._getWindowButtonVisibility()).to.equal(true); + }); + + it('correctly updates when entering/exiting fullscreen for hiddenInset style', async () => { + const w = new BrowserWindow({ show: false, frame: false, titleBarStyle: 'hiddenInset' }); + expect(w._getWindowButtonVisibility()).to.equal(true); + w.setWindowButtonVisibility(false); + expect(w._getWindowButtonVisibility()).to.equal(false); + + const enterFS = emittedOnce(w, 'enter-full-screen'); + w.setFullScreen(true); + await enterFS; + + const leaveFS = emittedOnce(w, 'leave-full-screen'); + w.setFullScreen(false); + await leaveFS; + + w.setWindowButtonVisibility(true); + expect(w._getWindowButtonVisibility()).to.equal(true); + }); }); ifdescribe(process.platform === 'darwin')('BrowserWindow.setVibrancy(type)', () => {