[gnome-shell] checkBox: Remove custom container implementation
- From: Florian Müllner <fmuellner src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell] checkBox: Remove custom container implementation
- Date: Tue, 20 Aug 2013 06:40:55 +0000 (UTC)
commit 777189d7bd755876eef809a35a7f3dbf68cd29e6
Author: Florian Müllner <fmuellner gnome org>
Date: Thu Jul 11 16:09:54 2013 +0200
checkBox: Remove custom container implementation
The only point of using a custom container here was to prevent StBoxLayout
from enforcing the wrong request mode based on the orientation. With that
issue fixed, we can simplify the checkbox widget significantly.
https://bugzilla.gnome.org/show_bug.cgi?id=703811
data/theme/gnome-shell.css | 2 +-
js/ui/checkBox.js | 87 +++++++-------------------------------------
2 files changed, 14 insertions(+), 75 deletions(-)
---
diff --git a/data/theme/gnome-shell.css b/data/theme/gnome-shell.css
index 4c905bd..ff242d5 100644
--- a/data/theme/gnome-shell.css
+++ b/data/theme/gnome-shell.css
@@ -101,7 +101,7 @@ StScrollBar StButton#vhandle:active {
/* Check Boxes */
-.check-box ShellGenericContainer {
+.check-box StBoxLayout {
spacing: .8em;
}
diff --git a/js/ui/checkBox.js b/js/ui/checkBox.js
index 097fe96..18960dc 100644
--- a/js/ui/checkBox.js
+++ b/js/ui/checkBox.js
@@ -1,101 +1,40 @@
const Clutter = imports.gi.Clutter;
const Pango = imports.gi.Pango;
-const Shell = imports.gi.Shell;
const St = imports.gi.St;
const Lang = imports.lang;
-const CheckBoxContainer = new Lang.Class({
- Name: 'CheckBoxContainer',
-
- _init: function() {
- this.actor = new Shell.GenericContainer();
- this.actor.connect('get-preferred-width',
- Lang.bind(this, this._getPreferredWidth));
- this.actor.connect('get-preferred-height',
- Lang.bind(this, this._getPreferredHeight));
- this.actor.connect('allocate',
- Lang.bind(this, this._allocate));
- this.actor.connect('style-changed', Lang.bind(this,
- function() {
- let node = this.actor.get_theme_node();
- this._spacing = node.get_length('spacing');
- }));
- this.actor.request_mode = Clutter.RequestMode.HEIGHT_FOR_WIDTH;
-
- this._box = new St.Bin();
- this.actor.add_actor(this._box);
-
- this.label = new St.Label();
- this.label.clutter_text.set_line_wrap(true);
- this.label.clutter_text.set_ellipsize(Pango.EllipsizeMode.NONE);
- this.actor.add_actor(this.label);
-
- this._spacing = 0;
- },
-
- _getPreferredWidth: function(actor, forHeight, alloc) {
- let [minWidth, natWidth] = this._box.get_preferred_width(forHeight);
-
- alloc.min_size = minWidth + this._spacing;
- alloc.natural_size = natWidth + this._spacing;
- },
-
- _getPreferredHeight: function(actor, forWidth, alloc) {
- let [minBoxHeight, natBoxHeight] =
- this._box.get_preferred_height(forWidth);
- let [minLabelHeight, natLabelHeight] =
- this.label.get_preferred_height(forWidth);
-
- alloc.min_size = Math.max(minBoxHeight, minLabelHeight);
- alloc.natural_size = Math.max(natBoxHeight, natLabelHeight);
- },
-
- _allocate: function(actor, box, flags) {
- let availWidth = box.x2 - box.x1;
- let availHeight = box.y2 - box.y1;
-
- let childBox = new Clutter.ActorBox();
- let [minBoxWidth, natBoxWidth] =
- this._box.get_preferred_width(-1);
- let [minBoxHeight, natBoxHeight] =
- this._box.get_preferred_height(-1);
- childBox.x1 = box.x1;
- childBox.x2 = box.x1 + natBoxWidth;
- childBox.y1 = box.y1;
- childBox.y2 = box.y1 + natBoxHeight;
- this._box.allocate(childBox, flags);
-
- childBox.x1 = box.x1 + natBoxWidth + this._spacing;
- childBox.x2 = availWidth - childBox.x1;
- childBox.y1 = box.y1;
- childBox.y2 = box.y2;
- this.label.allocate(childBox, flags);
- }
-});
-
const CheckBox = new Lang.Class({
Name: 'CheckBox',
_init: function(label) {
+ let container = new St.BoxLayout();
this.actor = new St.Button({ style_class: 'check-box',
+ child: container,
button_mask: St.ButtonMask.ONE,
toggle_mode: true,
can_focus: true,
x_fill: true,
y_fill: true });
- this._container = new CheckBoxContainer();
- this.actor.set_child(this._container.actor);
+
+ this._box = new St.Bin();
+ this._box.set_y_align(Clutter.ActorAlign.START);
+ container.add_actor(this._box);
+
+ this._label = new St.Label();
+ this._label.clutter_text.set_line_wrap(true);
+ this._label.clutter_text.set_ellipsize(Pango.EllipsizeMode.NONE);
+ container.add_actor(this._label);
if (label)
this.setLabel(label);
},
setLabel: function(label) {
- this._container.label.set_text(label);
+ this._label.set_text(label);
},
getLabelActor: function() {
- return this._container.label;
+ return this._label;
}
});
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]