[gnome-shell/hotplug: 11/21] mount-operation: implement ask-question



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]