2013-04-23 19:26:05 -04:00
|
|
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
2019-01-31 15:07:06 +01:00
|
|
|
/* exported Indicator */
|
2013-04-23 19:26:05 -04:00
|
|
|
|
2019-08-12 14:10:43 +02:00
|
|
|
const { Gio, GObject, St } = imports.gi;
|
2013-04-23 19:26:05 -04:00
|
|
|
|
|
|
|
const PanelMenu = imports.ui.panelMenu;
|
|
|
|
const PopupMenu = imports.ui.popupMenu;
|
|
|
|
const Slider = imports.ui.slider;
|
|
|
|
|
2018-09-06 02:55:20 +02:00
|
|
|
const { loadInterfaceXML } = imports.misc.fileUtils;
|
|
|
|
|
2013-04-23 19:26:05 -04:00
|
|
|
const BUS_NAME = 'org.gnome.SettingsDaemon.Power';
|
|
|
|
const OBJECT_PATH = '/org/gnome/SettingsDaemon/Power';
|
|
|
|
|
2018-09-06 02:55:20 +02:00
|
|
|
const BrightnessInterface = loadInterfaceXML('org.gnome.SettingsDaemon.Power.Screen');
|
2013-04-23 19:26:05 -04:00
|
|
|
const BrightnessProxy = Gio.DBusProxy.makeProxyWrapper(BrightnessInterface);
|
|
|
|
|
2017-10-31 02:19:44 +01:00
|
|
|
var Indicator = class extends PanelMenu.SystemIndicator {
|
|
|
|
constructor() {
|
|
|
|
super('display-brightness-symbolic');
|
2013-04-23 19:26:05 -04:00
|
|
|
this._proxy = new BrightnessProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
|
2017-10-31 01:38:18 +01:00
|
|
|
(proxy, error) => {
|
2013-04-23 19:26:05 -04:00
|
|
|
if (error) {
|
|
|
|
log(error.message);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-12-02 01:27:35 +01:00
|
|
|
this._proxy.connect('g-properties-changed', this._sync.bind(this));
|
2013-04-23 19:26:05 -04:00
|
|
|
this._sync();
|
2017-10-31 01:38:18 +01:00
|
|
|
});
|
2013-04-23 19:26:05 -04:00
|
|
|
|
|
|
|
this._item = new PopupMenu.PopupBaseMenuItem({ activate: false });
|
|
|
|
this.menu.addMenuItem(this._item);
|
|
|
|
|
|
|
|
this._slider = new Slider.Slider(0);
|
2019-08-12 14:10:43 +02:00
|
|
|
this._sliderChangedId = this._slider.connect('notify::value',
|
|
|
|
this._sliderChanged.bind(this));
|
2019-07-25 18:53:00 +02:00
|
|
|
this._slider.accessible_name = _("Brightness");
|
2013-04-23 19:26:05 -04:00
|
|
|
|
|
|
|
let icon = new St.Icon({ icon_name: 'display-brightness-symbolic',
|
|
|
|
style_class: 'popup-menu-icon' });
|
2019-04-12 16:00:49 -05:00
|
|
|
this._item.add(icon);
|
2019-07-25 18:53:00 +02:00
|
|
|
this._item.add(this._slider, { expand: true });
|
2019-04-12 16:00:49 -05:00
|
|
|
this._item.connect('button-press-event', (actor, event) => {
|
2013-11-29 18:17:34 +00:00
|
|
|
return this._slider.startDragging(event);
|
2017-10-31 01:38:18 +01:00
|
|
|
});
|
2019-04-12 16:00:49 -05:00
|
|
|
this._item.connect('key-press-event', (actor, event) => {
|
2013-08-22 13:15:00 +02:00
|
|
|
return this._slider.onKeyPressEvent(actor, event);
|
2017-10-31 01:38:18 +01:00
|
|
|
});
|
2013-08-22 13:15:00 +02:00
|
|
|
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
2013-04-23 19:26:05 -04:00
|
|
|
|
2019-07-25 18:53:00 +02:00
|
|
|
_sliderChanged() {
|
|
|
|
let percent = this._slider.value * 100;
|
2013-04-23 19:26:05 -04:00
|
|
|
this._proxy.Brightness = percent;
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
2013-04-23 19:26:05 -04:00
|
|
|
|
2019-08-12 14:10:43 +02:00
|
|
|
_changeSlider(value) {
|
|
|
|
GObject.signal_handler_block(this._slider, this._sliderChangedId);
|
|
|
|
this._slider.value = value;
|
|
|
|
GObject.signal_handler_unblock(this._slider, this._sliderChangedId);
|
|
|
|
}
|
|
|
|
|
2017-10-31 01:03:21 +01:00
|
|
|
_sync() {
|
2013-04-23 19:26:05 -04:00
|
|
|
let visible = this._proxy.Brightness >= 0;
|
2019-04-12 16:00:49 -05:00
|
|
|
this._item.visible = visible;
|
2013-04-23 19:26:05 -04:00
|
|
|
if (visible)
|
2019-08-12 14:10:43 +02:00
|
|
|
this._changeSlider(this._proxy.Brightness / 100.0);
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
|
|
|
};
|