From c2d50fe0f246e2d3dd9b1652c75147b6f924a59e Mon Sep 17 00:00:00 2001 From: anaximeno Date: Fri, 29 Dec 2023 22:14:13 -0100 Subject: [PATCH] chore: properly update on monitors changed --- .../transparent-panels@germanfr/extension.js | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/transparent-panels@germanfr/files/transparent-panels@germanfr/extension.js b/transparent-panels@germanfr/files/transparent-panels@germanfr/extension.js index a7c015d2..b3d0f643 100644 --- a/transparent-panels@germanfr/files/transparent-panels@germanfr/extension.js +++ b/transparent-panels@germanfr/files/transparent-panels@germanfr/extension.js @@ -76,8 +76,7 @@ MyExtension.prototype = { this.settings.bind("panel-bottom", "enable_position_bottom", this.on_settings_changed); this.settings.bind("panel-left", "enable_position_left", this.on_settings_changed); - this._signals.connect(Main.layoutManager, 'monitors-changed', () => this.on_state_change(-1), this); - + this._signals.connect(Main.layoutManager, 'monitors-changed', this.on_monitors_changed, this); this._classname = this.theme_defined ? this.transparency_type : this.transparency_type + INTERNAL_PREFIX; Gettext.bindtextdomain(meta.uuid, GLib.get_home_dir() + "/.local/share/locale"); @@ -162,6 +161,19 @@ MyExtension.prototype = { this.on_state_change(-1); }, + on_monitors_changed: function () { + Main.getPanels().forEach(panel => this.make_transparent(panel, false)); + + this._panel_status = new Array(Main.panelManager.panelCount); + for(let i = 0; i < this._panel_status.length; i++) + this._panel_status[i] = false; + + this.policy.disable(); + this.policy = new Policies.MaximizedPolicy(this); + this.policy.enable(); + this.on_state_change(-1); + }, + // This will be called only once, the first time the extension is loaded. // It's not worth it to create a separate class, so we build everything here. _show_startup_notification: function () {