2016-01-19 21:09:01 +01:00
|
|
|
// Copyright 2016 The Chromium Embedded Framework Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be found
|
|
|
|
// in the LICENSE file.
|
|
|
|
|
|
|
|
#include "libcef/browser/views/browser_view_impl.h"
|
|
|
|
|
2021-02-18 02:58:25 +01:00
|
|
|
#include "libcef/browser/browser_host_base.h"
|
2017-02-17 00:19:43 +01:00
|
|
|
#include "libcef/browser/browser_util.h"
|
2021-02-18 02:58:25 +01:00
|
|
|
#include "libcef/browser/chrome/views/chrome_browser_view.h"
|
2016-01-19 21:09:01 +01:00
|
|
|
#include "libcef/browser/context.h"
|
2021-04-15 01:28:22 +02:00
|
|
|
#include "libcef/browser/request_context_impl.h"
|
2016-01-19 21:09:01 +01:00
|
|
|
#include "libcef/browser/thread_util.h"
|
2017-05-17 11:29:28 +02:00
|
|
|
#include "libcef/browser/views/window_impl.h"
|
2016-01-19 21:09:01 +01:00
|
|
|
|
2023-09-15 21:51:43 +02:00
|
|
|
#include "content/public/common/input/native_web_keyboard_event.h"
|
2023-08-31 19:16:46 +02:00
|
|
|
#include "third_party/abseil-cpp/absl/types/optional.h"
|
2017-02-17 00:19:43 +01:00
|
|
|
#include "ui/content_accelerators/accelerator_util.h"
|
|
|
|
|
2023-08-31 19:16:46 +02:00
|
|
|
namespace {
|
|
|
|
|
|
|
|
absl::optional<cef_gesture_command_t> GetGestureCommand(
|
|
|
|
ui::GestureEvent* event) {
|
|
|
|
#if BUILDFLAG(IS_MAC)
|
|
|
|
if (event->details().type() == ui::ET_GESTURE_SWIPE) {
|
|
|
|
if (event->details().swipe_left()) {
|
|
|
|
return CEF_GESTURE_COMMAND_BACK;
|
|
|
|
} else if (event->details().swipe_right()) {
|
|
|
|
return CEF_GESTURE_COMMAND_FORWARD;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return absl::nullopt;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
// static
|
|
|
|
CefRefPtr<CefBrowserView> CefBrowserView::CreateBrowserView(
|
|
|
|
CefRefPtr<CefClient> client,
|
2017-05-17 11:29:28 +02:00
|
|
|
const CefString& url,
|
|
|
|
const CefBrowserSettings& settings,
|
2019-03-19 10:42:54 +01:00
|
|
|
CefRefPtr<CefDictionaryValue> extra_info,
|
2017-05-17 11:29:28 +02:00
|
|
|
CefRefPtr<CefRequestContext> request_context,
|
|
|
|
CefRefPtr<CefBrowserViewDelegate> delegate) {
|
2022-04-08 22:48:56 +02:00
|
|
|
return CefBrowserViewImpl::Create(CefWindowInfo(), client, url, settings,
|
|
|
|
extra_info, request_context, delegate);
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// static
|
|
|
|
CefRefPtr<CefBrowserView> CefBrowserView::GetForBrowser(
|
|
|
|
CefRefPtr<CefBrowser> browser) {
|
|
|
|
CEF_REQUIRE_UIT_RETURN(nullptr);
|
2020-09-25 03:40:47 +02:00
|
|
|
|
2021-02-18 02:58:25 +01:00
|
|
|
CefBrowserHostBase* browser_impl =
|
|
|
|
static_cast<CefBrowserHostBase*>(browser.get());
|
2023-01-02 23:59:03 +01:00
|
|
|
if (browser_impl && browser_impl->is_views_hosted()) {
|
2016-01-19 21:09:01 +01:00
|
|
|
return browser_impl->GetBrowserView();
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2016-01-19 21:09:01 +01:00
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
// static
|
|
|
|
CefRefPtr<CefBrowserViewImpl> CefBrowserViewImpl::Create(
|
2022-04-08 22:48:56 +02:00
|
|
|
const CefWindowInfo& window_info,
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefClient> client,
|
|
|
|
const CefString& url,
|
|
|
|
const CefBrowserSettings& settings,
|
2019-03-19 10:42:54 +01:00
|
|
|
CefRefPtr<CefDictionaryValue> extra_info,
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefRequestContext> request_context,
|
|
|
|
CefRefPtr<CefBrowserViewDelegate> delegate) {
|
|
|
|
CEF_REQUIRE_UIT_RETURN(nullptr);
|
2020-09-25 03:40:47 +02:00
|
|
|
|
2021-04-15 01:28:22 +02:00
|
|
|
if (!request_context) {
|
|
|
|
request_context = CefRequestContext::GetGlobalContext();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify that the browser context is valid. Do this here instead of risking
|
|
|
|
// potential browser creation failure when this view is added to the window.
|
|
|
|
auto request_context_impl =
|
|
|
|
static_cast<CefRequestContextImpl*>(request_context.get());
|
|
|
|
if (!request_context_impl->VerifyBrowserContext()) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefBrowserViewImpl> browser_view = new CefBrowserViewImpl(delegate);
|
2022-04-08 22:48:56 +02:00
|
|
|
browser_view->SetPendingBrowserCreateParams(
|
|
|
|
window_info, client, url, settings, extra_info, request_context);
|
2016-01-19 21:09:01 +01:00
|
|
|
browser_view->Initialize();
|
|
|
|
browser_view->SetDefaults(settings);
|
|
|
|
return browser_view;
|
|
|
|
}
|
|
|
|
|
|
|
|
// static
|
|
|
|
CefRefPtr<CefBrowserViewImpl> CefBrowserViewImpl::CreateForPopup(
|
|
|
|
const CefBrowserSettings& settings,
|
|
|
|
CefRefPtr<CefBrowserViewDelegate> delegate) {
|
|
|
|
CEF_REQUIRE_UIT_RETURN(nullptr);
|
2020-09-25 03:40:47 +02:00
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefBrowserViewImpl> browser_view = new CefBrowserViewImpl(delegate);
|
|
|
|
browser_view->Initialize();
|
|
|
|
browser_view->SetDefaults(settings);
|
|
|
|
return browser_view;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CefBrowserViewImpl::WebContentsCreated(
|
|
|
|
content::WebContents* web_contents) {
|
2023-01-02 23:59:03 +01:00
|
|
|
if (web_view()) {
|
2021-02-18 02:58:25 +01:00
|
|
|
web_view()->SetWebContents(web_contents);
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
2019-07-17 20:47:27 +02:00
|
|
|
void CefBrowserViewImpl::BrowserCreated(
|
2020-09-25 03:40:47 +02:00
|
|
|
CefBrowserHostBase* browser,
|
2019-07-17 20:47:27 +02:00
|
|
|
base::RepeatingClosure on_bounds_changed) {
|
2016-01-19 21:09:01 +01:00
|
|
|
browser_ = browser;
|
2019-07-17 20:47:27 +02:00
|
|
|
on_bounds_changed_ = on_bounds_changed;
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
2020-09-25 03:40:47 +02:00
|
|
|
void CefBrowserViewImpl::BrowserDestroyed(CefBrowserHostBase* browser) {
|
2016-01-19 21:09:01 +01:00
|
|
|
DCHECK_EQ(browser, browser_);
|
|
|
|
browser_ = nullptr;
|
|
|
|
|
2023-01-02 23:59:03 +01:00
|
|
|
if (web_view()) {
|
2021-02-18 02:58:25 +01:00
|
|
|
web_view()->SetWebContents(nullptr);
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
2018-11-03 02:15:09 +01:00
|
|
|
bool CefBrowserViewImpl::HandleKeyboardEvent(
|
2017-02-17 00:19:43 +01:00
|
|
|
const content::NativeWebKeyboardEvent& event) {
|
2023-01-02 23:59:03 +01:00
|
|
|
if (!root_view()) {
|
2018-11-03 02:15:09 +01:00
|
|
|
return false;
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2017-02-17 00:19:43 +01:00
|
|
|
|
|
|
|
views::FocusManager* focus_manager = root_view()->GetFocusManager();
|
2023-01-02 23:59:03 +01:00
|
|
|
if (!focus_manager) {
|
2018-11-03 02:15:09 +01:00
|
|
|
return false;
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2017-02-17 00:19:43 +01:00
|
|
|
|
2023-01-02 23:59:03 +01:00
|
|
|
if (HandleAccelerator(event, focus_manager)) {
|
2018-11-03 02:15:09 +01:00
|
|
|
return true;
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2017-02-17 00:19:43 +01:00
|
|
|
|
|
|
|
// Give the CefWindowDelegate a chance to handle the event.
|
2023-09-25 21:40:17 +02:00
|
|
|
if (auto* window_impl = cef_window()) {
|
2017-02-17 00:19:43 +01:00
|
|
|
CefKeyEvent cef_event;
|
|
|
|
if (browser_util::GetCefKeyEvent(event, cef_event) &&
|
|
|
|
window_impl->OnKeyEvent(cef_event)) {
|
2018-11-03 02:15:09 +01:00
|
|
|
return true;
|
2017-02-17 00:19:43 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Proceed with default native handling.
|
2018-11-03 02:15:09 +01:00
|
|
|
return unhandled_keyboard_event_handler_.HandleKeyboardEvent(event,
|
|
|
|
focus_manager);
|
2017-02-17 00:19:43 +01:00
|
|
|
}
|
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefBrowser> CefBrowserViewImpl::GetBrowser() {
|
|
|
|
CEF_REQUIRE_VALID_RETURN(nullptr);
|
|
|
|
return browser_;
|
|
|
|
}
|
|
|
|
|
2021-04-11 22:10:11 +02:00
|
|
|
CefRefPtr<CefView> CefBrowserViewImpl::GetChromeToolbar() {
|
|
|
|
CEF_REQUIRE_VALID_RETURN(nullptr);
|
|
|
|
if (cef::IsChromeRuntimeEnabled()) {
|
2023-09-07 19:28:27 +02:00
|
|
|
return chrome_browser_view()->cef_toolbar();
|
2021-04-11 22:10:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2017-02-17 00:19:43 +01:00
|
|
|
void CefBrowserViewImpl::SetPreferAccelerators(bool prefer_accelerators) {
|
|
|
|
CEF_REQUIRE_VALID_RETURN_VOID();
|
2023-01-02 23:59:03 +01:00
|
|
|
if (web_view()) {
|
2021-02-18 02:58:25 +01:00
|
|
|
web_view()->set_allow_accelerators(prefer_accelerators);
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2017-02-17 00:19:43 +01:00
|
|
|
}
|
|
|
|
|
2021-01-21 19:32:46 +01:00
|
|
|
void CefBrowserViewImpl::RequestFocus() {
|
|
|
|
CEF_REQUIRE_VALID_RETURN_VOID();
|
|
|
|
// Always execute asynchronously to work around issue #3040.
|
|
|
|
CEF_POST_TASK(CEF_UIT,
|
|
|
|
base::BindOnce(&CefBrowserViewImpl::RequestFocusInternal,
|
|
|
|
weak_ptr_factory_.GetWeakPtr()));
|
|
|
|
}
|
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
void CefBrowserViewImpl::SetBackgroundColor(cef_color_t color) {
|
|
|
|
CEF_REQUIRE_VALID_RETURN_VOID();
|
|
|
|
ParentClass::SetBackgroundColor(color);
|
2023-01-02 23:59:03 +01:00
|
|
|
if (web_view()) {
|
2021-02-18 02:58:25 +01:00
|
|
|
web_view()->SetResizeBackgroundColor(color);
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void CefBrowserViewImpl::Detach() {
|
|
|
|
ParentClass::Detach();
|
|
|
|
|
|
|
|
// root_view() will be nullptr now.
|
|
|
|
DCHECK(!root_view());
|
|
|
|
|
|
|
|
if (browser_) {
|
2021-02-18 02:58:25 +01:00
|
|
|
// With the Alloy runtime |browser_| will disappear when WindowDestroyed()
|
|
|
|
// indirectly calls BrowserDestroyed() so keep a reference.
|
2020-09-25 03:40:47 +02:00
|
|
|
CefRefPtr<CefBrowserHostBase> browser = browser_;
|
2016-01-19 21:09:01 +01:00
|
|
|
|
|
|
|
// Force the browser to be destroyed.
|
2021-02-18 02:58:25 +01:00
|
|
|
browser->WindowDestroyed();
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-30 22:42:40 +01:00
|
|
|
void CefBrowserViewImpl::GetDebugInfo(base::Value::Dict* info,
|
2016-01-19 21:09:01 +01:00
|
|
|
bool include_children) {
|
|
|
|
ParentClass::GetDebugInfo(info, include_children);
|
2023-01-02 23:59:03 +01:00
|
|
|
if (browser_) {
|
2023-01-30 22:42:40 +01:00
|
|
|
info->Set("url", browser_->GetMainFrame()->GetURL().ToString());
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void CefBrowserViewImpl::OnBrowserViewAdded() {
|
|
|
|
if (!browser_ && pending_browser_create_params_) {
|
|
|
|
// Top-level browsers will be created when this view is added to the views
|
|
|
|
// hierarchy.
|
|
|
|
pending_browser_create_params_->browser_view = this;
|
|
|
|
|
2021-02-18 02:58:25 +01:00
|
|
|
CefBrowserHostBase::Create(*pending_browser_create_params_);
|
2016-01-19 21:09:01 +01:00
|
|
|
DCHECK(browser_);
|
|
|
|
|
|
|
|
pending_browser_create_params_.reset(nullptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-17 20:47:27 +02:00
|
|
|
void CefBrowserViewImpl::OnBoundsChanged() {
|
2023-01-02 23:59:03 +01:00
|
|
|
if (!on_bounds_changed_.is_null()) {
|
2019-07-17 20:47:27 +02:00
|
|
|
on_bounds_changed_.Run();
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2019-07-17 20:47:27 +02:00
|
|
|
}
|
|
|
|
|
2023-08-31 19:16:46 +02:00
|
|
|
bool CefBrowserViewImpl::OnGestureEvent(ui::GestureEvent* event) {
|
|
|
|
if (auto command = GetGestureCommand(event)) {
|
|
|
|
if (delegate() && delegate()->OnGestureCommand(this, *command)) {
|
|
|
|
return true;
|
|
|
|
}
|
2023-05-26 11:05:33 +02:00
|
|
|
|
2023-08-31 19:16:46 +02:00
|
|
|
if (!cef::IsChromeRuntimeEnabled() && browser_) {
|
|
|
|
// Default handling for the Alloy runtime.
|
|
|
|
switch (*command) {
|
|
|
|
case CEF_GESTURE_COMMAND_BACK:
|
|
|
|
browser_->GoBack();
|
|
|
|
break;
|
|
|
|
case CEF_GESTURE_COMMAND_FORWARD:
|
|
|
|
browser_->GoForward();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return true;
|
2023-05-26 11:05:33 +02:00
|
|
|
}
|
|
|
|
}
|
2023-08-31 19:16:46 +02:00
|
|
|
|
|
|
|
return false;
|
2023-05-26 11:05:33 +02:00
|
|
|
}
|
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
CefBrowserViewImpl::CefBrowserViewImpl(
|
|
|
|
CefRefPtr<CefBrowserViewDelegate> delegate)
|
2021-01-21 19:32:46 +01:00
|
|
|
: ParentClass(delegate), weak_ptr_factory_(this) {}
|
2016-01-19 21:09:01 +01:00
|
|
|
|
|
|
|
void CefBrowserViewImpl::SetPendingBrowserCreateParams(
|
2022-04-08 22:48:56 +02:00
|
|
|
const CefWindowInfo& window_info,
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefClient> client,
|
|
|
|
const CefString& url,
|
|
|
|
const CefBrowserSettings& settings,
|
2019-03-19 10:42:54 +01:00
|
|
|
CefRefPtr<CefDictionaryValue> extra_info,
|
2016-01-19 21:09:01 +01:00
|
|
|
CefRefPtr<CefRequestContext> request_context) {
|
|
|
|
DCHECK(!pending_browser_create_params_);
|
2020-09-25 03:40:47 +02:00
|
|
|
pending_browser_create_params_.reset(new CefBrowserCreateParams());
|
2022-04-08 22:48:56 +02:00
|
|
|
pending_browser_create_params_->MaybeSetWindowInfo(window_info);
|
2016-01-19 21:09:01 +01:00
|
|
|
pending_browser_create_params_->client = client;
|
2021-04-15 01:28:22 +02:00
|
|
|
pending_browser_create_params_->url = url;
|
2016-01-19 21:09:01 +01:00
|
|
|
pending_browser_create_params_->settings = settings;
|
2019-03-19 10:42:54 +01:00
|
|
|
pending_browser_create_params_->extra_info = extra_info;
|
2016-01-19 21:09:01 +01:00
|
|
|
pending_browser_create_params_->request_context = request_context;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CefBrowserViewImpl::SetDefaults(const CefBrowserSettings& settings) {
|
2017-04-20 21:28:17 +02:00
|
|
|
SetBackgroundColor(
|
|
|
|
CefContext::Get()->GetBackgroundColor(&settings, STATE_DISABLED));
|
2016-01-19 21:09:01 +01:00
|
|
|
}
|
|
|
|
|
2021-02-18 02:58:25 +01:00
|
|
|
views::View* CefBrowserViewImpl::CreateRootView() {
|
|
|
|
if (cef::IsChromeRuntimeEnabled()) {
|
2023-09-07 19:28:27 +02:00
|
|
|
return new ChromeBrowserView(this);
|
2021-02-18 02:58:25 +01:00
|
|
|
}
|
|
|
|
|
2016-01-19 21:09:01 +01:00
|
|
|
return new CefBrowserViewView(delegate(), this);
|
|
|
|
}
|
2016-07-21 23:21:32 +02:00
|
|
|
|
|
|
|
void CefBrowserViewImpl::InitializeRootView() {
|
2021-02-18 02:58:25 +01:00
|
|
|
if (cef::IsChromeRuntimeEnabled()) {
|
2023-09-07 19:28:27 +02:00
|
|
|
chrome_browser_view()->Initialize();
|
2021-02-18 02:58:25 +01:00
|
|
|
} else {
|
|
|
|
static_cast<CefBrowserViewView*>(root_view())->Initialize();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
views::WebView* CefBrowserViewImpl::web_view() const {
|
2023-01-02 23:59:03 +01:00
|
|
|
if (!root_view()) {
|
2022-04-08 22:48:56 +02:00
|
|
|
return nullptr;
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2022-04-08 22:48:56 +02:00
|
|
|
|
2021-02-18 02:58:25 +01:00
|
|
|
if (cef::IsChromeRuntimeEnabled()) {
|
2023-09-07 19:28:27 +02:00
|
|
|
return chrome_browser_view()->contents_web_view();
|
2021-02-18 02:58:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return static_cast<CefBrowserViewView*>(root_view());
|
2016-07-21 23:21:32 +02:00
|
|
|
}
|
2017-02-17 00:19:43 +01:00
|
|
|
|
2023-09-07 19:28:27 +02:00
|
|
|
ChromeBrowserView* CefBrowserViewImpl::chrome_browser_view() const {
|
|
|
|
CHECK(cef::IsChromeRuntimeEnabled());
|
|
|
|
return static_cast<ChromeBrowserView*>(root_view());
|
|
|
|
}
|
|
|
|
|
2023-09-25 21:40:17 +02:00
|
|
|
CefWindowImpl* CefBrowserViewImpl::cef_window() const {
|
|
|
|
CefRefPtr<CefWindow> window =
|
|
|
|
view_util::GetWindowFor(root_view()->GetWidget());
|
|
|
|
return static_cast<CefWindowImpl*>(window.get());
|
|
|
|
}
|
|
|
|
|
2017-02-17 00:19:43 +01:00
|
|
|
bool CefBrowserViewImpl::HandleAccelerator(
|
|
|
|
const content::NativeWebKeyboardEvent& event,
|
|
|
|
views::FocusManager* focus_manager) {
|
|
|
|
// Previous calls to TranslateMessage can generate Char events as well as
|
|
|
|
// RawKeyDown events, even if the latter triggered an accelerator. In these
|
|
|
|
// cases, we discard the Char events.
|
2020-06-09 19:48:00 +02:00
|
|
|
if (event.GetType() == blink::WebInputEvent::Type::kChar &&
|
2017-04-20 21:28:17 +02:00
|
|
|
ignore_next_char_event_) {
|
2017-02-17 00:19:43 +01:00
|
|
|
ignore_next_char_event_ = false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// It's necessary to reset this flag, because a RawKeyDown event may not
|
|
|
|
// always generate a Char event.
|
|
|
|
ignore_next_char_event_ = false;
|
|
|
|
|
2020-06-09 19:48:00 +02:00
|
|
|
if (event.GetType() == blink::WebInputEvent::Type::kRawKeyDown) {
|
2017-02-17 00:19:43 +01:00
|
|
|
ui::Accelerator accelerator =
|
|
|
|
ui::GetAcceleratorFromNativeWebKeyboardEvent(event);
|
|
|
|
|
|
|
|
// This is tricky: we want to set ignore_next_char_event_ if
|
|
|
|
// ProcessAccelerator returns true. But ProcessAccelerator might delete
|
|
|
|
// |this| if the accelerator is a "close tab" one. So we speculatively
|
|
|
|
// set the flag and fix it if no event was handled.
|
|
|
|
ignore_next_char_event_ = true;
|
|
|
|
|
2023-01-02 23:59:03 +01:00
|
|
|
if (focus_manager->ProcessAccelerator(accelerator)) {
|
2017-02-17 00:19:43 +01:00
|
|
|
return true;
|
2023-01-02 23:59:03 +01:00
|
|
|
}
|
2017-02-17 00:19:43 +01:00
|
|
|
|
|
|
|
// ProcessAccelerator didn't handle the accelerator, so we know both
|
|
|
|
// that |this| is still valid, and that we didn't want to set the flag.
|
|
|
|
ignore_next_char_event_ = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2021-01-21 19:32:46 +01:00
|
|
|
|
|
|
|
void CefBrowserViewImpl::RequestFocusInternal() {
|
|
|
|
ParentClass::RequestFocus();
|
|
|
|
}
|