[Kimchi-devel] [PATCH] [Kimchi] Fixed "Add a Storage Device to VM" modal behavior when guest is running

sguimaraes943 at gmail.com sguimaraes943 at gmail.com
Thu Mar 10 19:23:49 UTC 2016


From: Samuel Guimarães <sguimaraes943 at gmail.com>

Signed-off-by: Samuel Guimarães <sguimaraes943 at gmail.com>
---
 ui/js/src/kimchi.guest_storage_add.main.js | 38 ++++++++++++++++--------------
 ui/pages/guest-storage-add.html.tmpl       |  2 +-
 2 files changed, 21 insertions(+), 19 deletions(-)

diff --git a/ui/js/src/kimchi.guest_storage_add.main.js b/ui/js/src/kimchi.guest_storage_add.main.js
index 3f416e7..3c72a79 100644
--- a/ui/js/src/kimchi.guest_storage_add.main.js
+++ b/ui/js/src/kimchi.guest_storage_add.main.js
@@ -83,12 +83,12 @@ kimchi.guest_storage_add_main = function() {
         }
         formatTextbox.empty();
         formatTextbox.append(selectFormatHTML);
-        $(formatTextbox).change();
+        $(formatTextbox).trigger('change');
         formatTextbox.selectpicker();
         $('.selectpicker').selectpicker('refresh');
     };
 
-    typeTextbox.change(function() {
+    typeTextbox.on('change',function() {
         var pathObject = {'cdrom': ".path-section", 'disk': '.volume-section'};
         selectType = $(this).val();
         $.each(pathObject, function(type, value) {
@@ -105,13 +105,13 @@ kimchi.guest_storage_add_main = function() {
             if ($('#new-disk').checked) {
                 $('#existing-disk-box').addClass('hidden');
                 $(newPoolTextbox).val('default');
-                $(newPoolTextbox).change();
+                $(newPoolTextbox).trigger('change');
                 $(formatTextbox).val('qcow2');
-                $(formatTextbox).change();
+                $(formatTextbox).trigger('change');
             } else if ($('#existing-disk').checked) {
                 $('#new-disk-box').addClass('hidden');
                 $(poolTextbox).val('default');
-                $(poolTextbox).change();
+                $(poolTextbox).trigger('change');
             } else {
                 //Goes here the first time since radiobuttons are undefined
                 if (rbExisting === 'true') {
@@ -119,7 +119,7 @@ kimchi.guest_storage_add_main = function() {
                 } else {
                     $('#existing-disk-box').addClass('hidden');
                     $(formatTextbox).val('qcow2');
-                    $(formatTextbox).change();
+                    $(formatTextbox).trigger('change');
                 }
             }
         } else {
@@ -159,7 +159,7 @@ kimchi.guest_storage_add_main = function() {
                 if (radioButton === 'existing') {
                     poolTextbox.empty();
                     poolTextbox.append(selectStoragePoolHTML);
-                    $(poolTextbox).change();
+                    $(poolTextbox).trigger('change');
 	            poolTextbox.selectpicker();
                     $('.selectpicker').selectpicker('refresh');
                 } else if (radioButton === 'new') { //new disk
@@ -176,7 +176,7 @@ kimchi.guest_storage_add_main = function() {
     //First time retrieving list of Storage Pools - defaulting to new disk
     getStoragePools('new');
 
-    poolTextbox.change(function() {
+    poolTextbox.on('change',function() {
         var options = [];
         selectStorageVolHTML = '';
         volTextbox.empty();
@@ -198,7 +198,7 @@ kimchi.guest_storage_add_main = function() {
                     }
                     volTextbox.append(selectStorageVolHTML);
                     $(volTextbox).val(options[0].value);
-                    $(volTextbox).change();
+                    $(volTextbox).trigger('change');
                     $(volTextbox).prop('disabled',false);
                 }else {
                     $(volTextbox).prop('disabled',true);
@@ -213,7 +213,7 @@ kimchi.guest_storage_add_main = function() {
         }, null, false);
     });
 
-    typeTextbox.change(function() {
+    typeTextbox.on('change',function() {
         var pathObject = {'cdrom': ".path-section", 'disk': '.volume-section'};
         var selectType = $(this).val();
         $.each(pathObject, function(type, value) {
@@ -226,7 +226,7 @@ kimchi.guest_storage_add_main = function() {
     });
 
     var currentPage = 'new-disk-box';
-    $('#existing-disk').change(function() {
+    $('#existing-disk').on('change',function() {
         if (this.checked) {
             rbExisting = 'true';
             if (currentPage === 'new-disk-box') {
@@ -246,10 +246,10 @@ kimchi.guest_storage_add_main = function() {
         }
     });
 
-    $('#new-disk').change(function() {
+    $('#new-disk').on('change',function() {
         if (this.checked) {
             $(formatTextbox).val("qcow2");
-            $(formatTextbox).change();
+            $(formatTextbox).trigger('change');
             rbExisting = 'false';
             if (currentPage === 'existing-disk-box') {
                 kimchi.switchPage(currentPage, 'new-disk-box', 'right');
@@ -268,19 +268,21 @@ kimchi.guest_storage_add_main = function() {
         }
     });
 
+    var selectType = $(typeTextbox).val();
     if (kimchi.thisVMState === 'running') {
-        types =typesRunning;
-        $(typeTextbox).val('disk');
-        typeTextbox.change();
-        poolTextbox.change();
+        types = typesRunning;
     }
-    var selectType = $(typeTextbox).val();
     for (var i = 0; i < types.length; i++) {
         selectStorageTypeHTML += '<option value="'+ types[i].value + '">' + types[i].label + '</option>';
     }
     typeTextbox.append(selectStorageTypeHTML);
     typeTextbox.find('option:first').attr('selected','selected');
     typeTextbox.selectpicker();
+    if (kimchi.thisVMState === 'running') {
+        $(typeTextbox).val('disk');
+        typeTextbox.trigger('change');
+        poolTextbox.trigger('change');
+    }
 
     var validateCDROM = function(settings) {
         if (/^((https|http|ftp|ftps|tftp|\/).*)+$/.test(settings['path'])){
diff --git a/ui/pages/guest-storage-add.html.tmpl b/ui/pages/guest-storage-add.html.tmpl
index 18da825..afc72c8 100644
--- a/ui/pages/guest-storage-add.html.tmpl
+++ b/ui/pages/guest-storage-add.html.tmpl
@@ -39,7 +39,7 @@
                     <label>$_("Device Type")</label>
                     <select id="guest-storage-type" class="selectpicker col-md-12 col-lg-12">
                     </select>
-                    <p class="help-block"><i class="fa fa-info-circle"></i> $_("The device type. Currently, \"cdrom\" and \"disk\" are supported.")</p>
+                    <p class="help-block"><i class="fa fa-info-circle"></i> $_("The device type. Currently, \"cdrom\" and \"disk\" are supported. If the guest is running, only \"disk\" is supported.")</p>
                 </div>
                 <div class="volume-section hidden form-group">
                     <div class="template-modal-container">
-- 
1.9.3




More information about the Kimchi-devel mailing list