fix: html fullscreen when window not fullscreenable (#37348)

This commit is contained in:
Shelley Vohr 2023-02-21 12:11:34 +01:00 committed by GitHub
parent 868676aa5c
commit 32c60b29bb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 46 additions and 7 deletions

View file

@ -1307,7 +1307,10 @@ Profile* WebContents::GetProfile() {
} }
bool WebContents::IsFullscreen() const { bool WebContents::IsFullscreen() const {
return owner_window_ && owner_window_->IsFullscreen(); if (!owner_window())
return false;
return owner_window()->IsFullscreen() || is_html_fullscreen();
} }
void WebContents::EnterFullscreen(const GURL& url, void WebContents::EnterFullscreen(const GURL& url,
@ -1353,7 +1356,7 @@ void WebContents::OnEnterFullscreenModeForTab(
content::RenderFrameHost* requesting_frame, content::RenderFrameHost* requesting_frame,
const blink::mojom::FullscreenOptions& options, const blink::mojom::FullscreenOptions& options,
bool allowed) { bool allowed) {
if (!allowed || !owner_window_) if (!allowed || !owner_window())
return; return;
auto* source = content::WebContents::FromRenderFrameHost(requesting_frame); auto* source = content::WebContents::FromRenderFrameHost(requesting_frame);
@ -1377,7 +1380,7 @@ void WebContents::OnEnterFullscreenModeForTab(
} }
void WebContents::ExitFullscreenModeForTab(content::WebContents* source) { void WebContents::ExitFullscreenModeForTab(content::WebContents* source) {
if (!owner_window_) if (!owner_window())
return; return;
// This needs to be called before we exit fullscreen on the native window, // This needs to be called before we exit fullscreen on the native window,
@ -3657,14 +3660,14 @@ void WebContents::EnumerateDirectory(
bool WebContents::IsFullscreenForTabOrPending( bool WebContents::IsFullscreenForTabOrPending(
const content::WebContents* source) { const content::WebContents* source) {
if (!owner_window()) if (!owner_window())
return html_fullscreen_; return is_html_fullscreen();
bool in_transition = owner_window()->fullscreen_transition_state() != bool in_transition = owner_window()->fullscreen_transition_state() !=
NativeWindow::FullScreenTransitionState::NONE; NativeWindow::FullScreenTransitionState::NONE;
bool is_html_transition = owner_window()->fullscreen_transition_type() == bool is_html_transition = owner_window()->fullscreen_transition_type() ==
NativeWindow::FullScreenTransitionType::HTML; NativeWindow::FullScreenTransitionType::HTML;
return html_fullscreen_ || (in_transition && is_html_transition); return is_html_fullscreen() || (in_transition && is_html_transition);
} }
bool WebContents::TakeFocus(content::WebContents* source, bool reverse) { bool WebContents::TakeFocus(content::WebContents* source, bool reverse) {
@ -3954,7 +3957,7 @@ void WebContents::OnDevToolsSearchCompleted(
void WebContents::SetHtmlApiFullscreen(bool enter_fullscreen) { void WebContents::SetHtmlApiFullscreen(bool enter_fullscreen) {
// Window is already in fullscreen mode, save the state. // Window is already in fullscreen mode, save the state.
if (enter_fullscreen && owner_window_->IsFullscreen()) { if (enter_fullscreen && owner_window()->IsFullscreen()) {
native_fullscreen_ = true; native_fullscreen_ = true;
UpdateHtmlApiFullscreen(true); UpdateHtmlApiFullscreen(true);
return; return;

View file

@ -619,7 +619,7 @@ void NativeWindowMac::SetFullScreen(bool fullscreen) {
return; return;
} }
if (fullscreen == IsFullscreen()) if (fullscreen == IsFullscreen() || !IsFullScreenable())
return; return;
// Take note of the current window size // Take note of the current window size

View file

@ -5077,6 +5077,42 @@ describe('BrowserWindow module', () => {
await done; await done;
}); });
it('handles HTML fullscreen transitions when fullscreenable is false', async () => {
const w = new BrowserWindow({ fullscreenable: false });
await w.loadFile(path.join(fixtures, 'pages', 'a.html'));
expect(w.isFullScreen()).to.be.false('is fullscreen');
let enterCount = 0;
let exitCount = 0;
const done = new Promise<void>((resolve, reject) => {
const checkDone = () => {
if (enterCount === 2 && exitCount === 2) resolve();
};
w.webContents.on('enter-html-full-screen', async () => {
enterCount++;
if (w.isFullScreen()) reject(new Error('w.isFullScreen should be false'));
const isFS = await w.webContents.executeJavaScript('!!document.fullscreenElement');
if (!isFS) reject(new Error('Document should have fullscreen element'));
checkDone();
});
w.webContents.on('leave-html-full-screen', () => {
exitCount++;
if (w.isFullScreen()) reject(new Error('w.isFullScreen should be false'));
checkDone();
});
});
await w.webContents.executeJavaScript('document.getElementById("div").requestFullscreen()', true);
await w.webContents.executeJavaScript('document.exitFullscreen()');
await w.webContents.executeJavaScript('document.getElementById("div").requestFullscreen()', true);
await w.webContents.executeJavaScript('document.exitFullscreen()');
await expect(done).to.eventually.be.fulfilled();
});
it('does not crash when exiting simpleFullScreen (properties)', async () => { it('does not crash when exiting simpleFullScreen (properties)', async () => {
const w = new BrowserWindow(); const w = new BrowserWindow();
w.setSimpleFullScreen(true); w.setSimpleFullScreen(true);