explicitly hide tooltip on window deactivation

This commit is contained in:
Heilig Benedek 2018-01-12 17:48:18 +01:00
parent ea1da93e5e
commit c6c618acdb
2 changed files with 26 additions and 0 deletions

View file

@ -3,12 +3,16 @@
// found in the LICENSE file. // found in the LICENSE file.
#include "atom/browser/ui/win/atom_desktop_native_widget_aura.h" #include "atom/browser/ui/win/atom_desktop_native_widget_aura.h"
#include "ui/views/corewm/tooltip_controller.h"
#include "ui/wm/public/tooltip_client.h"
namespace atom { namespace atom {
AtomDesktopNativeWidgetAura::AtomDesktopNativeWidgetAura( AtomDesktopNativeWidgetAura::AtomDesktopNativeWidgetAura(
views::internal::NativeWidgetDelegate* delegate) views::internal::NativeWidgetDelegate* delegate)
: views::DesktopNativeWidgetAura(delegate) { : views::DesktopNativeWidgetAura(delegate) {
// This is to enable the override of OnWindowActivated
aura::client::SetActivationChangeObserver(GetNativeWindow(), this);
} }
void AtomDesktopNativeWidgetAura::Activate() { void AtomDesktopNativeWidgetAura::Activate() {
@ -19,4 +23,22 @@ void AtomDesktopNativeWidgetAura::Activate() {
views::DesktopNativeWidgetAura::Activate(); views::DesktopNativeWidgetAura::Activate();
} }
void AtomDesktopNativeWidgetAura::OnWindowActivated(
aura::client::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*>(
aura::client::GetTooltipClient(lost_active->GetRootWindow())
);
// This will cause the tooltip to be hidden when a window is deactivated,
// as it should be. Remove this fix when the chromium issue is fixed.
// https://bugs.chromium.org/p/chromium/issues/detail?id=724538
tooltip_controller->OnCancelMode(nullptr);
}
}
} // namespace atom } // namespace atom

View file

@ -19,6 +19,10 @@ class AtomDesktopNativeWidgetAura : public views::DesktopNativeWidgetAura {
void Activate() override; void Activate() override;
private: private:
void OnWindowActivated(
aura::client::ActivationChangeObserver::ActivationReason reason,
aura::Window* gained_active,
aura::Window* lost_active) override;
DISALLOW_COPY_AND_ASSIGN(AtomDesktopNativeWidgetAura); DISALLOW_COPY_AND_ASSIGN(AtomDesktopNativeWidgetAura);
}; };