fix: restore non-panel focus behavior (#42187)

Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com>
Co-authored-by: Samuel Attard <marshallofsound@electronjs.org>
This commit is contained in:
trop[bot] 2024-05-14 17:44:27 -07:00 committed by GitHub
parent 60f48e1753
commit 220166419f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -425,20 +425,7 @@ void NativeWindowMac::Focus(bool focus) {
// If we're a panel window, we do not want to activate the app, // If we're a panel window, we do not want to activate the app,
// which enables Electron-apps to build Spotlight-like experiences. // which enables Electron-apps to build Spotlight-like experiences.
if (!IsPanel()) { if (!IsPanel()) {
// On macOS < Sonoma, "activateIgnoringOtherApps:NO" would not [[NSApplication sharedApplication] activateIgnoringOtherApps:NO];
// activate apps if focusing a window that is inActive. That
// changed with macOS Sonoma, which also deprecated
// "activateIgnoringOtherApps".
//
// There's a slim chance we should have never called
// activateIgnoringOtherApps, but we tried that many years ago
// and saw weird focus bugs on other macOS versions. So, to make
// this safe, we're gating by versions.
if (@available(macOS 14.0, *)) {
[[NSApplication sharedApplication] activate];
} else {
[[NSApplication sharedApplication] activateIgnoringOtherApps:NO];
}
} }
[window_ makeKeyAndOrderFront:nil]; [window_ makeKeyAndOrderFront:nil];
} else { } else {