mirror of
https://github.com/Bismuth-Forge/bismuth.git
synced 2024-09-17 11:37:10 +03:00
This commit is contained in:
parent
49ac131044
commit
502f812081
@ -243,8 +243,11 @@ export class TilingController implements Controller {
|
|||||||
this.engine.arrange();
|
this.engine.arrange();
|
||||||
|
|
||||||
// Switch to next window if monocle with config.monocleMinimizeRest
|
// Switch to next window if monocle with config.monocleMinimizeRest
|
||||||
try {
|
if (
|
||||||
if (!this.currentWindow && this.engine.isLayoutMonocleAndMinimizeRest()) {
|
!window.window.isDialog &&
|
||||||
|
!this.currentWindow &&
|
||||||
|
this.engine.isLayoutMonocleAndMinimizeRest()
|
||||||
|
) {
|
||||||
this.engine.focusOrder(1, true);
|
this.engine.focusOrder(1, true);
|
||||||
/* HACK: force window to maximize if it isn't already
|
/* HACK: force window to maximize if it isn't already
|
||||||
* This is ultimately to trigger onWindowFocused() at the right time
|
* This is ultimately to trigger onWindowFocused() at the right time
|
||||||
@ -252,11 +255,6 @@ export class TilingController implements Controller {
|
|||||||
this.engine.focusOrder(1, true);
|
this.engine.focusOrder(1, true);
|
||||||
this.engine.focusOrder(-1, true);
|
this.engine.focusOrder(-1, true);
|
||||||
}
|
}
|
||||||
} catch {
|
|
||||||
/* HACK for the HACK: transient modals cause an error with the above workaround,
|
|
||||||
* so if we catch it here and ignore it, all is well */
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public onWindowMoveStart(_window: Window): void {
|
public onWindowMoveStart(_window: Window): void {
|
||||||
@ -352,6 +350,7 @@ export class TilingController implements Controller {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public onWindowFocused(window: Window): void {
|
public onWindowFocused(window: Window): void {
|
||||||
|
try {
|
||||||
window.timestamp = new Date().getTime();
|
window.timestamp = new Date().getTime();
|
||||||
this.currentWindow = window;
|
this.currentWindow = window;
|
||||||
// Minimize other windows if Monocle and config.monocleMinimizeRest
|
// Minimize other windows if Monocle and config.monocleMinimizeRest
|
||||||
@ -372,6 +371,9 @@ export class TilingController implements Controller {
|
|||||||
|
|
||||||
this.engine.minimizeOthers(window);
|
this.engine.minimizeOthers(window);
|
||||||
}
|
}
|
||||||
|
} catch {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public onWindowShadeChanged(win: Window): void {
|
public onWindowShadeChanged(win: Window): void {
|
||||||
|
@ -20,6 +20,7 @@ export interface DriverWindow {
|
|||||||
readonly shouldFloat: boolean;
|
readonly shouldFloat: boolean;
|
||||||
readonly screen: number;
|
readonly screen: number;
|
||||||
readonly active: boolean;
|
readonly active: boolean;
|
||||||
|
readonly isDialog: boolean;
|
||||||
surface: DriverSurface;
|
surface: DriverSurface;
|
||||||
minimized: boolean;
|
minimized: boolean;
|
||||||
shaded: boolean;
|
shaded: boolean;
|
||||||
@ -261,4 +262,8 @@ export class KWinWindow implements DriverWindow {
|
|||||||
|
|
||||||
return new Rect(geometry.x, geometry.y, width, height);
|
return new Rect(geometry.x, geometry.y, width, height);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public get isDialog(): boolean {
|
||||||
|
return this.client.dialog;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user