![electron-roller[bot]](/assets/img/avatar_default.png) 5261e08d0c
			
		
	
	
	
	
	5261e08d0c* chore: bump chromium in DEPS to 113.0.5657.0 * chore: bump chromium in DEPS to 113.0.5660.0 * chore: update patches printing.patch https://chromium-review.googlesource.com/c/chromium/src/+/4347664 https://chromium-review.googlesource.com/c/chromium/src/+/4347664 https://chromium-review.googlesource.com/c/chromium/src/+/4338810 https://chromium-review.googlesource.com/c/chromium/src/+/4339496 mas_disable_remote_layer.patch https://chromium-review.googlesource.com/c/chromium/src/+/4334544 https://chromium-review.googlesource.com/c/chromium/src/+/4335299 * Add API to verify `TOP_LEVEL_STORAGE_ACCESS` permission status https://chromium-review.googlesource.com/c/chromium/src/+/4306712 * Move os_crypt into a sync/ subdirectory. https://chromium-review.googlesource.com/c/chromium/src/+/4336304 * chore: generate libc++ headers --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: deepak1556 <hop2deep@gmail.com>
		
			
				
	
	
		
			37 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Cheng Zhao <zcbenz@gmail.com>
 | |
| Date: Thu, 4 Oct 2018 14:57:02 -0700
 | |
| Subject: fix: also propagate fullscreen state for outer frame
 | |
| 
 | |
| When entering fullscreen with Element.requestFullscreen in child frames,
 | |
| the parent frame should also enter fullscreen mode too. Chromium handles
 | |
| this for iframes, but not for webviews as they are essentially main
 | |
| frames instead of child frames.
 | |
| 
 | |
| This patch makes webviews propagate the fullscreen state to embedder.
 | |
| 
 | |
| Note that we also need to manually update embedder's
 | |
| `api::WebContents::IsFullscreenForTabOrPending` value.
 | |
| 
 | |
| diff --git a/content/browser/renderer_host/render_frame_host_impl.cc b/content/browser/renderer_host/render_frame_host_impl.cc
 | |
| index ecdc9ce92365c49c94267cfb85b4b56868b70376..49f36b5536f3e5f8c88e2b4bc95818dfebcb761f 100644
 | |
| --- a/content/browser/renderer_host/render_frame_host_impl.cc
 | |
| +++ b/content/browser/renderer_host/render_frame_host_impl.cc
 | |
| @@ -6862,6 +6862,17 @@ void RenderFrameHostImpl::EnterFullscreen(
 | |
|      }
 | |
|    }
 | |
|  
 | |
| +  // Entering fullscreen from webview should also notify its outer frame.
 | |
| +  if (frame_tree_node()->render_manager()->IsMainFrameForInnerDelegate()) {
 | |
| +    RenderFrameProxyHost* outer_proxy =
 | |
| +        frame_tree_node()->render_manager()->GetProxyToOuterDelegate();
 | |
| +    DCHECK(outer_proxy);
 | |
| +    if (outer_proxy->is_render_frame_proxy_live()) {
 | |
| +      outer_proxy->GetAssociatedRemoteFrame()->WillEnterFullscreen(
 | |
| +          options.Clone());
 | |
| +    }
 | |
| +  }
 | |
| +
 | |
|    // Focus the window if another frame may have delegated the capability.
 | |
|    if (had_fullscreen_token && !GetView()->HasFocus())
 | |
|      GetView()->Focus();
 |