status/network: Override activate() for wireless
Wireless items represent a single adapter, but wireless connectivity is controlled globally under NetworkManager. So instead of delegating activation to items, bind the :checked property to the global :wireless-enabled property and toggle it on activate. As any wireless devices will change their state to UNAVAILABLE when wireless is disabled, don't remove corresponding items in that case to keep the section visible. We don't want to hide the button to turn Wi-Fi back on when toggled off :-) Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2408>
This commit is contained in:
parent
1cc07716fa
commit
791c65a5f9
@ -1699,9 +1699,32 @@ class NMWirelessSection extends NMDeviceSection {
|
|||||||
'gnome-wifi-panel.desktop');
|
'gnome-wifi-panel.desktop');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setClient(client) {
|
||||||
|
super.setClient(client);
|
||||||
|
|
||||||
|
this._client?.bind_property('wireless-enabled',
|
||||||
|
this, 'checked',
|
||||||
|
GObject.BindingFlags.SYNC_CREATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
activate() {
|
||||||
|
this._client.wireless_enabled = !this._client.wireless_enabled;
|
||||||
|
}
|
||||||
|
|
||||||
_createDeviceMenuItem(device) {
|
_createDeviceMenuItem(device) {
|
||||||
return new NMWirelessDeviceItem(this._client, device);
|
return new NMWirelessDeviceItem(this._client, device);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_updateChecked() {
|
||||||
|
// handled via a property binding
|
||||||
|
}
|
||||||
|
|
||||||
|
_shouldShowDevice(device) {
|
||||||
|
// don't disappear if wireless-enabled is false
|
||||||
|
if (device.state === NM.DeviceState.UNAVAILABLE)
|
||||||
|
return true;
|
||||||
|
return super._shouldShowDevice(device);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const NMWiredSection = GObject.registerClass(
|
const NMWiredSection = GObject.registerClass(
|
||||||
|
Loading…
Reference in New Issue
Block a user