72a089262e
* chore: bump chromium in DEPS to a7249f73ae05d456c04487ef1693325f719556dd * chore: bump chromium in DEPS to 202466fa40b58f0bb9c9a76a037d1c50154c099e * chore: bump chromium in DEPS to 2dd1b25c8d794b50fb0dd911e0c4e909ff39f145 * Update patches * update patches * Revert "[printing] Mojofy PrintHostMsg_CheckForCancel" https://chromium-review.googlesource.com/c/chromium/src/+/2226002 * chore: bump chromium in DEPS to 8c1542e7dd36854fdf4abd1a8021eeb65a6a2e2b * chore: bump chromium in DEPS to 078bc6d796334fb403acd8975b99d1c8ecd028e8 * chore: bump chromium in DEPS to d96e9f16ae852ec9dbd15bf17df3d440402413bb * update patches * chore: update patches * Use ExtensionSystem::is_ready() instead of ExtensionService::is_ready() https://chromium-review.googlesource.com/c/chromium/src/+/2207499 * Remove WebImeTextSpan https://chromium-review.googlesource.com/c/chromium/src/+/2225240 * Remove PDFAnnotations flag altogether. https://chromium-review.googlesource.com/c/chromium/src/+/2229317 * Rework find-from-selection so it's synchronous -- fixes flaky tests https://chromium-review.googlesource.com/c/chromium/src/+/2181570 * fixup! Revert "[printing] Mojofy PrintHostMsg_CheckForCancel" * chore: bump chromium in DEPS to a8a280835830c65145ed8573a9a09f36d3920418 * update sysroots * update patches * update patches * Take RFH as a parameter for DidUpdateFavicon/ManifestURL https://chromium-review.googlesource.com/c/chromium/src/+/2224745 * chore: bump chromium in DEPS to b6149cb5a5e32caf8eab67b97ef3072b72521ca8 * Update patches * Rename net::cookie_util::StripStatuses to StripAccessResults https://chromium-review.googlesource.com/c/chromium/src/+/2212697 * use net::CookieAccessResultList instead of net::CookieAccessResultList * fix mas_no_private_api patch https://chromium-review.googlesource.com/c/chromium/src/+/2230281 * chore: bump chromium in DEPS to a27feee1643d952e48f77c92d8c03aedea14b720 * update patches * fix: add new navigation state REUSE_SITE_INSTANCE To fix the new set of state checks added in https://chromium-review.googlesource.com/c/chromium/src/+/2215141 * chore: bump chromium in DEPS to ff4559a4c13d20888202474e4ab9917dbdad8a9a * update patches * Cleanup usages of old mojo types and remove unused code https://chromium-review.googlesource.com/c/chromium/src/+/2235699 * chore: bump chromium in DEPS to 05279845f76eb22900a8b0d1a11d4fd339a8e53b * chore: bump chromium in DEPS to 821558279767cffec90e3b5b947865f90089fed3 * chore: bump chromium in DEPS to 1aef04e6486be337d3dd820b2d64d6320a1b9c13 * chore: bump chromium in DEPS to dc86386e8fdd796a0f7577e91e42a7f8b7e9bc78 * chore: bump chromium in DEPS to 64f2360794f14643764092ba3e58e2ed8f9fee12 * chore: update patches * refactor: MessageLoop, you are terminated \o/ Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2246173 * refactor: plumb DownloadSchedule to DownloadItem Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2242202 * chore: fix variable typo in IPC * chore: s/BindPipeAndPassReceiver/BindNewPipeAndPassReceiver * chore: update patches * chore: XEvent becomes x11::Event Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2240355 * fixup! refactor: MessageLoop, you are terminated \o/ * fixup! chore: XEvent becomes x11::Event * build: update v8 headers * chore: fix windows build * chore: disable SameSite-by-default changes https://chromium-review.googlesource.com/c/chromium/src/+/2231445 * update printing.patch * chore: bump chromium DEPS to 9ae03ef8f7d4f6ac663f725bcfe70311987652f3 * Convert WidgetHostMsg_SelectionBoundsChanged/TextInputStateChanged https://chromium-review.googlesource.com/c/chromium/src/+/2243531 * chore: update v8 patches * [XProto] Replace usages of XID and ::Window with x11::Window https://chromium-review.googlesource.com/c/chromium/src/+/2249389 * Update VideoFrameMetadata to use base::Optionals https://chromium-review.googlesource.com/c/chromium/src/+/2231706 https://chromium-review.googlesource.com/c/chromium/src/+/2238361 * --disable-dev-shm-usage for gpu process crash * [v8] Allow for 4GB TypedArrays https://chromium-review.googlesource.com/c/v8/v8/+/2249668 * update lib_src_switch_buffer_kmaxlength_to_size_t.patch * disable app.getGPUInfo spec on linux * update patches Co-authored-by: John Kleinschmidt <jkleinsc@github.com> Co-authored-by: Electron Bot <anonymous@electronjs.org> Co-authored-by: deepak1556 <hop2deep@gmail.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com>
64 lines
2.2 KiB
C++
64 lines
2.2 KiB
C++
// Copyright (c) 2014 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/x/window_state_watcher.h"
|
|
#include "ui/gfx/x/x11_atom_cache.h"
|
|
|
|
namespace electron {
|
|
|
|
WindowStateWatcher::WindowStateWatcher(NativeWindowViews* window)
|
|
: window_(window),
|
|
widget_(window->GetAcceleratedWidget()),
|
|
window_state_atom_(gfx::GetAtom("_NET_WM_STATE")) {
|
|
ui::X11EventSource::GetInstance()->AddXEventObserver(this);
|
|
}
|
|
|
|
WindowStateWatcher::~WindowStateWatcher() {
|
|
ui::X11EventSource::GetInstance()->RemoveXEventObserver(this);
|
|
}
|
|
|
|
void WindowStateWatcher::WillProcessXEvent(x11::Event* x11_event) {
|
|
if (IsWindowStateEvent(x11_event)) {
|
|
was_minimized_ = window_->IsMinimized();
|
|
was_maximized_ = window_->IsMaximized();
|
|
}
|
|
}
|
|
|
|
void WindowStateWatcher::DidProcessXEvent(x11::Event* x11_event) {
|
|
if (IsWindowStateEvent(x11_event)) {
|
|
bool is_minimized = window_->IsMinimized();
|
|
bool is_maximized = window_->IsMaximized();
|
|
bool is_fullscreen = window_->IsFullscreen();
|
|
if (is_minimized != was_minimized_) {
|
|
if (is_minimized)
|
|
window_->NotifyWindowMinimize();
|
|
else
|
|
window_->NotifyWindowRestore();
|
|
} else if (is_maximized != was_maximized_) {
|
|
if (is_maximized)
|
|
window_->NotifyWindowMaximize();
|
|
else
|
|
window_->NotifyWindowUnmaximize();
|
|
} else {
|
|
// If this is neither a "maximize" or "minimize" event, then we think it
|
|
// is a "fullscreen" event.
|
|
// The "IsFullscreen()" becomes true immediately before "WillProcessEvent"
|
|
// is called, so we can not handle this like "maximize" and "minimize" by
|
|
// watching whether they have changed.
|
|
if (is_fullscreen)
|
|
window_->NotifyWindowEnterFullScreen();
|
|
else
|
|
window_->NotifyWindowLeaveFullScreen();
|
|
}
|
|
}
|
|
}
|
|
|
|
bool WindowStateWatcher::IsWindowStateEvent(x11::Event* x11_event) const {
|
|
XEvent* xev = &x11_event->xlib_event();
|
|
return (static_cast<x11::Atom>(xev->xproperty.atom) == window_state_atom_ &&
|
|
xev->type == PropertyNotify &&
|
|
xev->xproperty.window == static_cast<uint32_t>(widget_));
|
|
}
|
|
|
|
} // namespace electron
|