16
16
const UserButton = Lang.Class ({
17
17
Name: "UserButton",
18
Extends: Gtk.MenuButton,
20
/** @property user_avatar
20
23
"user_avatar": GObject.param_spec_object ("user_avatar",
22
25
"A Gtk.Image that is shown in the button",
24
27
GObject.ParamFlags.READABLE |
25
28
GObject.ParamFlags.WRITABLE),
30
/** @property user_name
27
33
"user_name": GObject.param_spec_string ("user_name",
29
35
"The text to be shown on the button",
30
"user name goes here",
31
37
GObject.ParamFlags.READABLE |
32
38
GObject.ParamFlags.WRITABLE),
40
/** @property show_avatar_only
34
43
"show_avatar_only": GObject.param_spec_boolean ("show_avatar_only",
35
44
"show only avatar",
36
45
"When set, only the avatar will be shown" +
44
53
_init: function (params) {
46
this.set_property ('always-show-image', true);
56
this.add (this.layout = new Gtk.Box ({
57
orientation: Gtk.Orientation.HORIZONTAL
61
if (params != undefined) {
63
if (params["user_avatar"] != undefined) {
64
this.user_avatar = params["user_avatar"];
66
this._user_avatar = Gtk.Image.new_from_icon_name (
67
"avatar-default-symbolic", null);
70
if (params["user_name"] != undefined) {
71
this._user_name = params["user_name"];
73
this._user_name = "Jone Deo";
76
if (params["show_avatar_only"] != undefined) {
77
this._show_avatar_only = params["show_avatar_only"];
79
this._show_avatar_only = false;
82
if (params["popover"] != undefined) {
83
this["popover"] = params["popover"];
87
this._user_avatar = Gtk.Image.new_from_icon_name (
88
"avatar-default-symbolic", null);
89
this._user_name = "Jone Deo";
90
this._show_avatar_only = false;
91
this["popover"] = null;
98
* Hack to re-build the button, cus we can not use references in JavaScript.
100
_rebuild: function () {
104
this.layout.foreach (function (widget) {
108
this.layout.pack_start (this._user_avatar, false, false, 3);
110
this.user_avatar["icon_size"] = 4;
113
if (this._show_avatar_only == false) {
115
this.layout.pack_start (new Gtk.Separator ({
116
orientation: Gtk.Orientation.VERTICAL
117
}), false, false, 5);
120
this.layout.pack_end (
121
this._user_name_widget = new Gtk.Label ({
122
label: this._user_name,
123
justify: Gtk.Justification.CENTER
49
130
get user_avatar () {
53
134
set user_avatar (avatar) {
135
if (avatar == undefined) {
137
this._user_avatar = Gtk.Image.new_from_icon_name (
138
"avatar-default-symbolic", null);
57
this.set_image (avatar);
140
print ("Not balls!");
58
141
this._user_avatar = avatar;
66
150
set user_name (name) {
67
151
this._user_name = name;
68
this.parent.set_property ("label", name);
71
155
get show_avatar_only () {
72
156
return _show_avatar_only;
75
set show_avatar_only (show_avatar) {
76
this._show_avatar_only = show_avatar;
159
set show_avatar_only (show_avatar_only) {
160
this._show_avatar_only = show_avatar_only;