locatePointer: Bind ripples creation to settings
Don't create ripples if locate pointer is not enabled, and bind creation to the relative desktop interface settings key. https://gitlab.gnome.org/GNOME/gnome-shell/merge_requests/700
This commit is contained in:
parent
eca98aee42
commit
a53b48de4c
@ -11,12 +11,26 @@ const LOCATE_POINTER_SCHEMA = "org.gnome.desktop.interface";
|
|||||||
var LocatePointer = class {
|
var LocatePointer = class {
|
||||||
constructor() {
|
constructor() {
|
||||||
this._settings = new Gio.Settings({ schema_id: LOCATE_POINTER_SCHEMA });
|
this._settings = new Gio.Settings({ schema_id: LOCATE_POINTER_SCHEMA });
|
||||||
this._ripples = new Ripples.Ripples(0.5, 0.5, 'ripple-pointer-location');
|
this._settings.connect(`changed::${LOCATE_POINTER_KEY}`, () => this._syncEnabled());
|
||||||
this._ripples.addTo(Main.uiGroup);
|
this._syncEnabled();
|
||||||
|
}
|
||||||
|
|
||||||
|
_syncEnabled() {
|
||||||
|
let enabled = this._settings.get_boolean(LOCATE_POINTER_KEY);
|
||||||
|
if (enabled == !!this._ripples)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (enabled) {
|
||||||
|
this._ripples = new Ripples.Ripples(0.5, 0.5, 'ripple-pointer-location');
|
||||||
|
this._ripples.addTo(Main.uiGroup);
|
||||||
|
} else {
|
||||||
|
this._ripples.destroy();
|
||||||
|
this._ripples = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
show() {
|
show() {
|
||||||
if (!this._settings.get_boolean(LOCATE_POINTER_KEY))
|
if (!this._ripples)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let [x, y] = global.get_pointer();
|
let [x, y] = global.get_pointer();
|
||||||
|
Loading…
Reference in New Issue
Block a user