[gnome-shell/hotplug: 11/21] mount-operation: implement ask-question
- From: Cosimo Cecchi <cosimoc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell/hotplug: 11/21] mount-operation: implement ask-question
- Date: Mon, 27 Jun 2011 19:52:53 +0000 (UTC)
commit 18b7a82dac600bb74df3bbc4bc2a5eaf62a158df
Author: Cosimo Cecchi <cosimoc gnome org>
Date: Wed Jun 22 17:22:20 2011 -0400
mount-operation: implement ask-question
data/theme/gnome-shell.css | 17 ++++--
js/ui/shellMountOperation.js | 131 +++++++++++++++++++++++++++++++++---------
2 files changed, 114 insertions(+), 34 deletions(-)
---
diff --git a/data/theme/gnome-shell.css b/data/theme/gnome-shell.css
index afc52c5..7f9d6ca 100644
--- a/data/theme/gnome-shell.css
+++ b/data/theme/gnome-shell.css
@@ -1656,16 +1656,18 @@ StTooltip StLabel {
color: #444444;
}
-/* Show Processes Dialog */
+/* ShellMountOperation Dialogs */
.shell-mount-operation-icon {
icon-size: 32px;
}
-.show-processes-dialog {
+.show-processes-dialog,
+.mount-question-dialog {
spacing: 24px;
}
-.show-processes-dialog-subject {
+.show-processes-dialog-subject,
+.mount-question-dialog-subject {
font-size: 12pt;
font-weight: bold;
color: #666666;
@@ -1674,19 +1676,22 @@ StTooltip StLabel {
padding-bottom: 6px;
}
-.show-processes-dialog-subject:rtl {
+.show-processes-dialog-subject:rtl,
+.mount-question-dialog-subject:rtl {
padding-left: 0px;
padding-right: 17px;
}
-.show-processes-dialog-description {
+.show-processes-dialog-description,
+.mount-question-dialog-description {
font-size: 10pt;
color: white;
padding-left: 17px;
width: 28em;
}
-.show-processes-dialog-description:rtl {
+.show-processes-dialog-description:rtl,
+.mount-question-dialog-description:rtl {
padding-right: 17px;
}
diff --git a/js/ui/shellMountOperation.js b/js/ui/shellMountOperation.js
index 900d13f..623894d 100644
--- a/js/ui/shellMountOperation.js
+++ b/js/ui/shellMountOperation.js
@@ -10,6 +10,8 @@ const Shell = imports.gi.Shell;
const ModalDialog = imports.ui.modalDialog;
+/* ------ Common Utils ------- */
+
function _setLabelText(label, text) {
if (text) {
label.set_text(text);
@@ -20,6 +22,30 @@ function _setLabelText(label, text) {
}
}
+function _setButtonsForChoices(dialog, choices) {
+ let buttons = [];
+
+ for (let idx = 0; idx < choices.length; idx++) {
+ let button = idx;
+ buttons.unshift({ label: choices[idx],
+ action: Lang.bind(dialog, function() {
+ dialog.emit('response', button);
+ })});
+ }
+
+ dialog.setButtons(buttons);
+}
+
+function _setLabelsForMessage(dialog, message) {
+ let labels = message.split('\n');
+
+ _setLabelText(dialog._subjectLabel, labels[0]);
+ if (labels.length > 1)
+ _setLabelText(dialog._descriptionLabel, labels[1]);
+}
+
+/* -------------------------------------------------------- */
+
function ListItem(app) {
this._init(app);
}
@@ -89,7 +115,20 @@ ShellMountOperation.prototype = {
},
_onAskQuestion: function(op, message, choices) {
- // TODO
+ let questionDialog = new ShellMountQuestionDialog(this._icon);
+ this._dialog = questionDialog;
+
+ questionDialog.connect('response',
+ Lang.bind(this, function(object, choice) {
+ this.mountOp.set_choice(choice);
+ this.mountOp.reply(Gio.MountOperationResult.HANDLED);
+
+ questionDialog.close(global.get_current_time());
+ delete this._dialog;
+ }));
+
+ questionDialog.update(message, choices);
+ questionDialog.open(global.get_current_time());
},
_onAskPassword: function(op, message, defaultUser, defaultDomain, flags) {
@@ -97,7 +136,11 @@ ShellMountOperation.prototype = {
},
_onAborted: function(op) {
- // TODO
+ if (!this._dialog)
+ return;
+
+ this._dialog.close(global.get_current_time());
+ delete this._dialog;
},
_onShowProcesses2: function(op) {
@@ -107,7 +150,9 @@ ShellMountOperation.prototype = {
if (!this._processesDialog) {
this._processesDialog = new ShellProcessesDialog(this._icon);
- this._processesDialog.connect('choice-chosen',
+ this._dialog = this._processesDialog;
+
+ this._processesDialog.connect('response',
Lang.bind(this, function(object, choice) {
if (choice == -1) {
this.mountOp.reply(Gio.MountOperationResult.ABORTED);
@@ -117,6 +162,7 @@ ShellMountOperation.prototype = {
}
this._processesDialog.close(global.get_current_time());
+ delete this._dialog;
}));
this._processesDialog.open(global.get_current_time());
}
@@ -125,6 +171,57 @@ ShellMountOperation.prototype = {
},
}
+function ShellMountQuestionDialog(icon) {
+ this._init(icon);
+}
+
+ShellMountQuestionDialog.prototype = {
+ __proto__: ModalDialog.ModalDialog.prototype,
+
+ _init: function(icon) {
+ ModalDialog.ModalDialog.prototype._init.call(this, { styleClass: 'mount-question-dialog' });
+
+ this._buildUI(icon)
+ },
+
+ _buildUI: function(icon) {
+ let mainContentLayout = new St.BoxLayout();
+ this.contentLayout.add(mainContentLayout, { x_fill: true,
+ y_fill: false });
+
+ this._iconBin = new St.Bin({ child: icon });
+ mainContentLayout.add(this._iconBin,
+ { x_fill: true,
+ y_fill: false,
+ x_align: St.Align.END,
+ y_align: St.Align.MIDDLE });
+
+ let messageLayout = new St.BoxLayout({ vertical: true });
+ mainContentLayout.add(messageLayout,
+ { y_align: St.Align.START });
+
+ this._subjectLabel = new St.Label({ style_class: 'mount-question-dialog-subject' });
+
+ messageLayout.add(this._subjectLabel,
+ { y_fill: false,
+ y_align: St.Align.START });
+
+ this._descriptionLabel = new St.Label({ style_class: 'mount-question-dialog-description' });
+ this._descriptionLabel.clutter_text.ellipsize = Pango.EllipsizeMode.NONE;
+ this._descriptionLabel.clutter_text.line_wrap = true;
+
+ messageLayout.add(this._descriptionLabel,
+ { y_fill: true,
+ y_align: St.Align.START });
+ },
+
+ update: function(message, choices) {
+ _setLabelsForMessage(this, message);
+ _setButtonsForChoices(this, choices);
+ }
+}
+Signals.addSignalMethods(ShellMountQuestionDialog.prototype);
+
function ShellProcessesDialog(icon) {
this._init(icon);
}
@@ -196,20 +293,6 @@ ShellProcessesDialog.prototype = {
}));
},
- _setButtonsForChoices: function(choices) {
- let buttons = [];
-
- for (let idx = 0; idx < choices.length; idx++) {
- let button = idx;
- buttons.unshift({ label: choices[idx],
- action: Lang.bind(this, function() {
- this.emit('choice-chosen', button);
- })});
- }
-
- this.setButtons(buttons);
- },
-
_setAppsForPids: function(pids) {
// remove all the items
this._applicationList.destroy_children();
@@ -227,23 +310,15 @@ ShellProcessesDialog.prototype = {
item.connect('activate',
Lang.bind(this, function() {
// use -1 to indicate Cancel
- this.emit('choice-chosen', -1);
+ this.emit('response', -1);
}));
}));
},
- _setLabelsForMessage: function(message) {
- let labels = message.split('\n');
-
- _setLabelText(this._subjectLabel, labels[0]);
- if (labels.length > 1)
- _setLabelText(this._descriptionLabel, labels[1]);
- },
-
update: function(message, processes, choices) {
- this._setLabelsForMessage(message);
this._setAppsForPids(processes);
- this._setButtonsForChoices(choices);
+ _setLabelsForMessage(this, message);
+ _setButtonsForChoices(this, choices);
}
}
Signals.addSignalMethods(ShellProcessesDialog.prototype);
\ No newline at end of file
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]