blob: da474af667bef9a84eee9c68c91bcde0d1e177dc [file] [log] [blame]
// Copyright 2025 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/devtools/devtools_window.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_finder.h"
#include "chrome/browser/ui/browser_window.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "components/input/native_web_keyboard_event.h"
#include "components/web_modal/web_contents_modal_dialog_host.h"
#include "components/web_modal/web_contents_modal_dialog_manager.h"
#include "content/public/browser/keyboard_event_processing_result.h"
#include "content/public/browser/render_process_host.h"
using content::WebContents;
// static
void DevToolsWindow::ToggleDevToolsWindow(Browser* browser,
const DevToolsToggleAction& action,
DevToolsOpenedByAction opened_by) {
if (action.type() == DevToolsToggleAction::kToggle &&
browser->is_type_devtools()) {
browser->tab_strip_model()->CloseAllTabs();
return;
}
ToggleDevToolsWindow(browser->tab_strip_model()->GetActiveWebContents(),
nullptr, action.type() == DevToolsToggleAction::kInspect,
action, "", opened_by);
}
// static
bool DevToolsWindow::HasFiredBeforeUnloadEventForDevToolsBrowser(
Browser* browser) {
DCHECK(browser->is_type_devtools());
// When FastUnloadController is used, devtools frontend will be detached
// from the browser window at this point which means we've already fired
// beforeunload.
if (browser->tab_strip_model()->empty()) {
return true;
}
DevToolsWindow* window = AsDevToolsWindow(browser);
if (!window) {
return false;
}
return window->intercepted_page_beforeunload_;
}
// static
DevToolsWindow* DevToolsWindow::AsDevToolsWindow(Browser* browser) {
DCHECK(browser->is_type_devtools());
if (browser->tab_strip_model()->empty()) {
return nullptr;
}
WebContents* contents = browser->tab_strip_model()->GetWebContentsAt(0);
return AsDevToolsWindow(contents);
}
content::KeyboardEventProcessingResult DevToolsWindow::PreHandleKeyboardEvent(
WebContents* source,
const input::NativeWebKeyboardEvent& event) {
BrowserWindow* inspected_window = GetInspectedBrowserWindow();
if (inspected_window) {
return inspected_window->PreHandleKeyboardEvent(event);
}
return content::KeyboardEventProcessingResult::NOT_HANDLED;
}
bool DevToolsWindow::HandleKeyboardEvent(
WebContents* source,
const input::NativeWebKeyboardEvent& event) {
if (event.windows_key_code == 0x08) {
// Do not navigate back in history on Windows (http://crbug.com/74156).
return true;
}
BrowserWindow* inspected_window = GetInspectedBrowserWindow();
return inspected_window && inspected_window->HandleKeyboardEvent(event);
}
std::unique_ptr<content::EyeDropper> DevToolsWindow::OpenEyeDropper(
content::RenderFrameHost* render_frame_host,
content::EyeDropperListener* listener) {
BrowserWindow* window = GetInspectedBrowserWindow();
if (window) {
return window->OpenEyeDropper(render_frame_host, listener);
}
return nullptr;
}
BrowserWindow* DevToolsWindow::GetInspectedBrowserWindow() {
content::WebContents* inspected_web_contents = GetInspectedWebContents();
if (!inspected_web_contents) {
return nullptr;
}
Browser* browser = chrome::FindBrowserWithTab(inspected_web_contents);
return browser ? browser->window() : nullptr;
}
void DevToolsWindow::UpdateBrowserToolbar() {
BrowserWindow* inspected_window = GetInspectedBrowserWindow();
if (inspected_window) {
inspected_window->UpdateToolbar(nullptr);
}
}
void DevToolsWindow::UpdateBrowserWindow() {
BrowserWindow* inspected_window = GetInspectedBrowserWindow();
if (inspected_window) {
inspected_window->UpdateDevTools(GetInspectedWebContents());
}
}
void DevToolsWindow::RegisterModalDialogManager(Browser* browser) {
web_modal::WebContentsModalDialogManager::CreateForWebContents(
main_web_contents_);
web_modal::WebContentsModalDialogManager::FromWebContents(main_web_contents_)
->SetDelegate(browser);
// Observer `browser` destruction/removal to reset `SetDelegate(nullptr)`
// before the dialog manager's `raw_ptr` becomes dangling.
if (!browser_list_observation_.IsObserving()) {
browser_list_observation_.Observe(BrowserList::GetInstance());
}
}