]> git.proxmox.com Git - proxmox-widget-toolkit.git/blobdiff - window/TaskViewer.js
task view, progress: add taskDone callback
[proxmox-widget-toolkit.git] / window / TaskViewer.js
index 189268b9655e95c27372bad7c408c6dc506d4b2e..39f42ad39b5b1aab618d20a1b45c252877ba5d68 100644 (file)
@@ -2,6 +2,8 @@ Ext.define('Proxmox.window.TaskProgress', {
     extend: 'Ext.window.Window',
     alias: 'widget.proxmoxTaskProgress',
 
+    taskDone: Ext.emptyFn,
+
     initComponent: function() {
         var me = this;
 
@@ -44,6 +46,7 @@ Ext.define('Proxmox.window.TaskProgress', {
                    me.close();
                    Ext.Msg.alert('Task failed', exitstatus);
                }
+               me.taskDone(exitstatus == 'OK');
            }
        });
 
@@ -61,6 +64,7 @@ Ext.define('Proxmox.window.TaskProgress', {
                    text: gettext('Details'),
                    handler: function() {                       
                        var win = Ext.create('Proxmox.window.TaskViewer', { 
+                           taskDone: me.taskDone,
                            upid: me.upid
                        });
                        win.show();
@@ -85,6 +89,10 @@ Ext.define('Proxmox.window.TaskViewer', {
     extend: 'Ext.window.Window',
     alias: 'widget.proxmoxTaskViewer',
 
+    extraTitle: '', // string to prepend after the generic task title
+
+    taskDone: Ext.emptyFn,
+
     initComponent: function() {
         var me = this;
 
@@ -193,6 +201,7 @@ Ext.define('Proxmox.window.TaskViewer', {
                logView.requestUpdate(undefined, true);
                logView.scrollToEnd = false;
                statstore.stopUpdate();
+               me.taskDone(statgrid.getObjectValue('exitstatus') == 'OK');
            }
 
            stop_btn1.setDisabled(status !== 'running');
@@ -202,7 +211,7 @@ Ext.define('Proxmox.window.TaskViewer', {
        statstore.startUpdate();
 
        Ext.apply(me, {
-           title: "Task viewer: " + task.desc,
+           title: "Task viewer: " + task.desc + me.extraTitle,
            width: 800,
            height: 400,
            layout: 'fit',