2010-06-22 21:02:26 +00:00
|
|
|
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
|
|
|
2010-10-07 18:15:51 +00:00
|
|
|
const Clutter = imports.gi.Clutter;
|
2010-06-22 21:02:26 +00:00
|
|
|
const St = imports.gi.St;
|
|
|
|
const Lang = imports.lang;
|
|
|
|
const PopupMenu = imports.ui.popupMenu;
|
|
|
|
const Main = imports.ui.main;
|
|
|
|
|
|
|
|
function Button(menuAlignment) {
|
|
|
|
this._init(menuAlignment);
|
|
|
|
}
|
|
|
|
|
|
|
|
Button.prototype = {
|
|
|
|
_init: function(menuAlignment) {
|
|
|
|
this.actor = new St.Bin({ style_class: 'panel-button',
|
|
|
|
reactive: true,
|
2010-10-07 18:15:51 +00:00
|
|
|
can_focus: true,
|
2010-06-22 21:02:26 +00:00
|
|
|
x_fill: true,
|
|
|
|
y_fill: false,
|
|
|
|
track_hover: true });
|
|
|
|
this.actor._delegate = this;
|
|
|
|
this.actor.connect('button-press-event', Lang.bind(this, this._onButtonPress));
|
2010-10-07 18:15:51 +00:00
|
|
|
this.actor.connect('key-press-event', Lang.bind(this, this._onKeyPress));
|
2010-06-22 21:02:26 +00:00
|
|
|
this.menu = new PopupMenu.PopupMenu(this.actor, menuAlignment, St.Side.TOP, /* FIXME */ 0);
|
|
|
|
this.menu.connect('open-state-changed', Lang.bind(this, this._onOpenStateChanged));
|
|
|
|
Main.chrome.addActor(this.menu.actor, { visibleInOverview: true,
|
|
|
|
affectsStruts: false });
|
|
|
|
this.menu.actor.hide();
|
|
|
|
},
|
|
|
|
|
|
|
|
_onButtonPress: function(actor, event) {
|
|
|
|
this.menu.toggle();
|
|
|
|
},
|
|
|
|
|
2010-10-07 18:15:51 +00:00
|
|
|
_onKeyPress: function(actor, event) {
|
|
|
|
let symbol = event.get_key_symbol();
|
|
|
|
if (symbol == Clutter.KEY_space || symbol == Clutter.KEY_Return) {
|
|
|
|
this.menu.toggle();
|
|
|
|
return true;
|
|
|
|
} else if (symbol == Clutter.KEY_Down) {
|
|
|
|
if (!this.menu.isOpen)
|
|
|
|
this.menu.toggle();
|
|
|
|
this.menu.activateFirst();
|
|
|
|
return true;
|
|
|
|
} else
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
|
2010-06-22 21:02:26 +00:00
|
|
|
_onOpenStateChanged: function(menu, open) {
|
2010-10-07 18:15:51 +00:00
|
|
|
if (open) {
|
2010-06-22 21:02:26 +00:00
|
|
|
this.actor.add_style_pseudo_class('pressed');
|
2010-10-07 18:15:51 +00:00
|
|
|
let focus = global.stage.get_key_focus();
|
2010-11-01 15:03:28 +00:00
|
|
|
if (!focus || (focus != this.actor && !menu.actor.contains(focus)))
|
2010-10-07 18:15:51 +00:00
|
|
|
this.actor.grab_key_focus();
|
|
|
|
} else
|
2010-06-22 21:02:26 +00:00
|
|
|
this.actor.remove_style_pseudo_class('pressed');
|
|
|
|
}
|
2010-06-22 21:06:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* SystemStatusButton:
|
|
|
|
*
|
|
|
|
* This class manages one System Status indicator (network, keyboard,
|
|
|
|
* volume, bluetooth...), which is just a PanelMenuButton with an
|
|
|
|
* icon and a tooltip
|
|
|
|
*/
|
|
|
|
function SystemStatusButton() {
|
|
|
|
this._init.apply(this, arguments);
|
|
|
|
}
|
|
|
|
|
|
|
|
SystemStatusButton.prototype = {
|
|
|
|
__proto__: Button.prototype,
|
|
|
|
|
|
|
|
_init: function(iconName,tooltipText) {
|
|
|
|
Button.prototype._init.call(this, St.Align.START);
|
2010-09-26 15:18:26 +00:00
|
|
|
this._iconActor = new St.Icon({ icon_name: iconName,
|
|
|
|
icon_type: St.IconType.SYMBOLIC,
|
|
|
|
style_class: 'system-status-icon' });
|
|
|
|
this.actor.set_child(this._iconActor);
|
2010-06-22 21:06:17 +00:00
|
|
|
this.setTooltip(tooltipText);
|
|
|
|
},
|
|
|
|
|
|
|
|
setIcon: function(iconName) {
|
2010-09-26 15:18:26 +00:00
|
|
|
this._iconActor.icon_name = iconName;
|
|
|
|
},
|
|
|
|
|
|
|
|
setGIcon: function(gicon) {
|
|
|
|
this._iconActor.gicon = gicon;
|
2010-06-22 21:06:17 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
setTooltip: function(text) {
|
|
|
|
if (text != null) {
|
|
|
|
this.tooltip = text;
|
|
|
|
this.actor.has_tooltip = true;
|
|
|
|
this.actor.tooltip_text = text;
|
|
|
|
} else {
|
|
|
|
this.actor.has_tooltip = false;
|
|
|
|
this.tooltip = null;
|
|
|
|
}
|
|
|
|
}
|
2010-09-26 15:18:26 +00:00
|
|
|
};
|