2019-02-20 04:12:36 -05:00
|
|
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
2019-01-31 09:07:06 -05:00
|
|
|
/* exported LocatePointer */
|
2019-02-20 04:12:36 -05:00
|
|
|
|
2023-06-08 00:52:46 -04:00
|
|
|
const Gio = imports.gi.Gio;
|
2019-02-20 04:12:36 -05:00
|
|
|
const Ripples = imports.ui.ripples;
|
|
|
|
const Main = imports.ui.main;
|
|
|
|
|
|
|
|
const LOCATE_POINTER_KEY = "locate-pointer";
|
2019-01-28 20:18:52 -05:00
|
|
|
const LOCATE_POINTER_SCHEMA = "org.gnome.desktop.interface";
|
2019-02-20 04:12:36 -05:00
|
|
|
|
2019-06-29 08:30:23 -04:00
|
|
|
var LocatePointer = class {
|
2019-02-20 04:12:36 -05:00
|
|
|
constructor() {
|
2019-01-28 20:27:05 -05:00
|
|
|
this._settings = new Gio.Settings({ schema_id: LOCATE_POINTER_SCHEMA });
|
2019-08-30 19:57:12 -04:00
|
|
|
this._settings.connect(`changed::${LOCATE_POINTER_KEY}`, () => this._syncEnabled());
|
|
|
|
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;
|
|
|
|
}
|
2019-02-20 04:12:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
show() {
|
2019-08-30 19:57:12 -04:00
|
|
|
if (!this._ripples)
|
2019-02-20 04:12:36 -05:00
|
|
|
return;
|
|
|
|
|
2019-02-01 08:41:55 -05:00
|
|
|
let [x, y] = global.get_pointer();
|
2019-02-20 04:12:36 -05:00
|
|
|
this._ripples.playAnimation(x, y);
|
|
|
|
}
|
|
|
|
};
|