mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			77 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff --git third_party/WebKit/Source/core/exported/WebViewImpl.cpp third_party/WebKit/Source/core/exported/WebViewImpl.cpp
 | |
| index 827581a9cb57..318e5181545a 100644
 | |
| --- third_party/WebKit/Source/core/exported/WebViewImpl.cpp
 | |
| +++ third_party/WebKit/Source/core/exported/WebViewImpl.cpp
 | |
| @@ -247,8 +247,13 @@ void WebView::SetUseExternalPopupMenus(bool use_external_popup_menus) {
 | |
|    g_should_use_external_popup_menus = use_external_popup_menus;
 | |
|  }
 | |
|  
 | |
| -bool WebViewImpl::UseExternalPopupMenus() {
 | |
| -  return g_should_use_external_popup_menus;
 | |
| +void WebViewImpl::SetUseExternalPopupMenusThisInstance(
 | |
| +    bool use_external_popup_menus) {
 | |
| +  should_use_external_popup_menus_ = use_external_popup_menus;
 | |
| +}
 | |
| +
 | |
| +bool WebViewImpl::UseExternalPopupMenus() const {
 | |
| +  return should_use_external_popup_menus_;
 | |
|  }
 | |
|  
 | |
|  namespace {
 | |
| @@ -342,6 +347,7 @@ WebViewImpl::WebViewImpl(WebViewClient* client,
 | |
|        enable_fake_page_scale_animation_for_testing_(false),
 | |
|        fake_page_scale_animation_page_scale_factor_(0),
 | |
|        fake_page_scale_animation_use_anchor_(false),
 | |
| +      should_use_external_popup_menus_(g_should_use_external_popup_menus),
 | |
|        compositor_device_scale_factor_override_(0),
 | |
|        suppress_next_keypress_event_(false),
 | |
|        ime_accept_events_(true),
 | |
| diff --git third_party/WebKit/Source/core/exported/WebViewImpl.h third_party/WebKit/Source/core/exported/WebViewImpl.h
 | |
| index 7ea90b01b4c6..30e54df93efc 100644
 | |
| --- third_party/WebKit/Source/core/exported/WebViewImpl.h
 | |
| +++ third_party/WebKit/Source/core/exported/WebViewImpl.h
 | |
| @@ -108,7 +108,8 @@ class CORE_EXPORT WebViewImpl final
 | |
|    static const WebInputEvent* CurrentInputEvent();
 | |
|    // Returns true if popup menus should be rendered by the browser, false if
 | |
|    // they should be rendered by WebKit (which is the default).
 | |
| -  static bool UseExternalPopupMenus();
 | |
| +  void SetUseExternalPopupMenusThisInstance(bool);
 | |
| +  bool UseExternalPopupMenus() const;
 | |
|  
 | |
|    // WebWidget methods:
 | |
|    void Close() override;
 | |
| @@ -615,6 +616,8 @@ class CORE_EXPORT WebViewImpl final
 | |
|    float fake_page_scale_animation_page_scale_factor_;
 | |
|    bool fake_page_scale_animation_use_anchor_;
 | |
|  
 | |
| +  bool should_use_external_popup_menus_;
 | |
| +
 | |
|    float compositor_device_scale_factor_override_;
 | |
|    TransformationMatrix device_emulation_transform_;
 | |
|  
 | |
| diff --git third_party/WebKit/Source/core/page/ChromeClientImpl.cpp third_party/WebKit/Source/core/page/ChromeClientImpl.cpp
 | |
| index f29df35de114..11a980f1be27 100644
 | |
| --- third_party/WebKit/Source/core/page/ChromeClientImpl.cpp
 | |
| +++ third_party/WebKit/Source/core/page/ChromeClientImpl.cpp
 | |
| @@ -776,7 +776,7 @@ PopupMenu* ChromeClientImpl::OpenPopupMenu(LocalFrame& frame,
 | |
|      return nullptr;
 | |
|  
 | |
|    NotifyPopupOpeningObservers();
 | |
| -  if (WebViewImpl::UseExternalPopupMenus())
 | |
| +  if (web_view_->UseExternalPopupMenus())
 | |
|      return new ExternalPopupMenu(frame, select, *web_view_);
 | |
|  
 | |
|    DCHECK(RuntimeEnabledFeatures::PagePopupEnabled());
 | |
| diff --git third_party/WebKit/public/web/WebView.h third_party/WebKit/public/web/WebView.h
 | |
| index 729c1ceabb91..a11ad9e6c86e 100644
 | |
| --- third_party/WebKit/public/web/WebView.h
 | |
| +++ third_party/WebKit/public/web/WebView.h
 | |
| @@ -374,6 +374,7 @@ class WebView : protected WebWidget {
 | |
|  
 | |
|    // Sets whether select popup menus should be rendered by the browser.
 | |
|    BLINK_EXPORT static void SetUseExternalPopupMenus(bool);
 | |
| +  virtual void SetUseExternalPopupMenusThisInstance(bool) = 0;
 | |
|  
 | |
|    // Hides any popup (suggestions, selects...) that might be showing.
 | |
|    virtual void HidePopups() = 0;
 |