mirror of
https://github.com/electron/electron.git
synced 2026-02-19 03:14:51 -05:00
* refactor: remove unnecessary downcast in MenuViews::PopupAt() * refactor: pass a views::Widget as an arg to the ElectronDesktopWindowTreeHostLinux ctor * refactor: pass a views::Widget as an arg to the ElectronDesktopNativeWidgetAura ctor * refactor: pass a views::Widget as an arg to the ElectronDesktopWindowTreeHostWin ctor * refactor: create desktop_window_tree_host_ in the ElectronDesktopNativeWidgetAura constructor * fixup! refactor: create desktop_window_tree_host_ in the ElectronDesktopNativeWidgetAura constructor fix: tyop
73 lines
2.6 KiB
C++
73 lines
2.6 KiB
C++
// Copyright (c) 2017 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/ui/win/electron_desktop_native_widget_aura.h"
|
|
|
|
#include <utility>
|
|
|
|
#include "shell/browser/native_window_views.h"
|
|
#include "shell/browser/ui/win/electron_desktop_window_tree_host_win.h"
|
|
#include "ui/views/corewm/tooltip_controller.h"
|
|
#include "ui/wm/public/tooltip_client.h"
|
|
|
|
namespace electron {
|
|
|
|
ElectronDesktopNativeWidgetAura::ElectronDesktopNativeWidgetAura(
|
|
NativeWindowViews* native_window_view,
|
|
views::Widget* widget)
|
|
: views::DesktopNativeWidgetAura{widget},
|
|
native_window_view_{native_window_view},
|
|
desktop_window_tree_host_{new ElectronDesktopWindowTreeHostWin{
|
|
native_window_view, widget, this}} {
|
|
GetNativeWindow()->SetName("ElectronDesktopNativeWidgetAura");
|
|
// This is to enable the override of OnWindowActivated
|
|
wm::SetActivationChangeObserver(GetNativeWindow(), this);
|
|
}
|
|
|
|
void ElectronDesktopNativeWidgetAura::InitNativeWidget(
|
|
views::Widget::InitParams params) {
|
|
CHECK_EQ(params.native_widget, this);
|
|
params.desktop_window_tree_host = desktop_window_tree_host_;
|
|
views::DesktopNativeWidgetAura::InitNativeWidget(std::move(params));
|
|
}
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
void ElectronDesktopNativeWidgetAura::OnSizeConstraintsChanged() {
|
|
views::DesktopNativeWidgetAura::OnSizeConstraintsChanged();
|
|
|
|
// OnSizeConstraintsChanged can remove thick frame depending from
|
|
// resizable state, so add it if needed.
|
|
native_window_view_->UpdateThickFrame();
|
|
}
|
|
#endif
|
|
|
|
void ElectronDesktopNativeWidgetAura::Activate() {
|
|
// Activate can cause the focused window to be blurred so only
|
|
// call when the window being activated is visible. This prevents
|
|
// hidden windows from blurring the focused window when created.
|
|
if (IsVisible())
|
|
views::DesktopNativeWidgetAura::Activate();
|
|
}
|
|
|
|
void ElectronDesktopNativeWidgetAura::OnWindowActivated(
|
|
wm::ActivationChangeObserver::ActivationReason reason,
|
|
aura::Window* gained_active,
|
|
aura::Window* lost_active) {
|
|
views::DesktopNativeWidgetAura::OnWindowActivated(reason, gained_active,
|
|
lost_active);
|
|
if (lost_active != nullptr) {
|
|
auto* tooltip_controller = static_cast<views::corewm::TooltipController*>(
|
|
wm::GetTooltipClient(lost_active->GetRootWindow()));
|
|
|
|
// This will cause the tooltip to be hidden when a window is deactivated,
|
|
// as it should be.
|
|
// TODO(brenca): Remove this fix when the chromium issue is fixed.
|
|
// crbug.com/724538
|
|
if (tooltip_controller != nullptr)
|
|
tooltip_controller->OnCancelMode(nullptr);
|
|
}
|
|
}
|
|
|
|
} // namespace electron
|