2018-07-20 16:50:50 +02:00
|
|
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
|
|
|
|
|
|
|
const Meta = imports.gi.Meta;
|
|
|
|
|
|
|
|
const PanelMenu = imports.ui.panelMenu;
|
|
|
|
const PopupMenu = imports.ui.popupMenu;
|
|
|
|
|
2017-10-31 02:19:44 +01:00
|
|
|
var RemoteAccessApplet = class extends PanelMenu.SystemIndicator {
|
|
|
|
constructor() {
|
|
|
|
super();
|
2018-07-20 16:50:50 +02:00
|
|
|
|
|
|
|
let backend = Meta.get_backend();
|
|
|
|
let controller = backend.get_remote_access_controller();
|
|
|
|
|
|
|
|
if (!controller)
|
|
|
|
return;
|
|
|
|
|
|
|
|
// We can't possibly know about all types of screen sharing on X11, so
|
|
|
|
// showing these controls on X11 might give a false sense of security.
|
|
|
|
// Thus, only enable these controls when using Wayland, where we are
|
|
|
|
// in control of sharing.
|
|
|
|
if (!Meta.is_wayland_compositor())
|
|
|
|
return;
|
|
|
|
|
|
|
|
this._handles = new Set();
|
|
|
|
this._indicator = null;
|
|
|
|
this._menuSection = null;
|
|
|
|
|
|
|
|
controller.connect('new-handle', (controller, handle) => {
|
|
|
|
this._onNewHandle(handle);
|
|
|
|
});
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
2018-07-20 16:50:50 +02:00
|
|
|
|
|
|
|
_ensureControls() {
|
|
|
|
if (this._indicator)
|
|
|
|
return;
|
|
|
|
|
|
|
|
this._indicator = this._addIndicator();
|
|
|
|
this._indicator.icon_name = 'screen-shared-symbolic';
|
2018-07-27 18:07:52 +02:00
|
|
|
this._indicator.add_style_class_name('remote-access-indicator');
|
2018-07-20 16:50:50 +02:00
|
|
|
this._item =
|
|
|
|
new PopupMenu.PopupSubMenuMenuItem(_("Screen is Being Shared"),
|
|
|
|
true);
|
|
|
|
this._item.menu.addAction(_("Turn off"),
|
|
|
|
() => {
|
|
|
|
for (let handle of this._handles)
|
|
|
|
handle.stop();
|
|
|
|
});
|
|
|
|
this._item.icon.icon_name = 'screen-shared-symbolic';
|
|
|
|
this.menu.addMenuItem(this._item);
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
2018-07-20 16:50:50 +02:00
|
|
|
|
|
|
|
_sync() {
|
|
|
|
if (this._handles.size == 0) {
|
|
|
|
this._indicator.visible = false;
|
|
|
|
this._item.actor.visible = false;
|
|
|
|
} else {
|
|
|
|
this._indicator.visible = true;
|
|
|
|
this._item.actor.visible = true;
|
|
|
|
}
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
2018-07-20 16:50:50 +02:00
|
|
|
|
|
|
|
_onStopped(handle) {
|
|
|
|
this._handles.delete(handle);
|
|
|
|
this._sync();
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
2018-07-20 16:50:50 +02:00
|
|
|
|
|
|
|
_onNewHandle(handle) {
|
|
|
|
this._handles.add(handle);
|
|
|
|
handle.connect('stopped', this._onStopped.bind(this));
|
|
|
|
|
|
|
|
if (this._handles.size == 1) {
|
|
|
|
this._ensureControls();
|
|
|
|
this._sync();
|
|
|
|
}
|
2017-10-31 02:19:44 +01:00
|
|
|
}
|
|
|
|
};
|