From 386b0ffb03bfddb01c8a409505c1c10aa4aff45f Mon Sep 17 00:00:00 2001 From: phamt Date: Thu, 1 Dec 2011 05:58:22 +0000 Subject: [PATCH] Fixed add blade dialog. git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@11100 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- xCAT-UI/js/custom/blade.js | 309 ++++++++++++++++++++----------------- 1 file changed, 171 insertions(+), 138 deletions(-) diff --git a/xCAT-UI/js/custom/blade.js b/xCAT-UI/js/custom/blade.js index e20e09d1a..3881cc78c 100644 --- a/xCAT-UI/js/custom/blade.js +++ b/xCAT-UI/js/custom/blade.js @@ -203,50 +203,68 @@ bladePlugin.prototype.loadResources = function() { * @return Nothing */ bladePlugin.prototype.addNode = function() { - var nodeTypeSelectDia = $('
'); - nodeTypeSelectDia.append('
' + - '
'); + var addNodeForm = $('
'); + var info = createInfoBar('Add a BladeCenter node'); + addNodeForm.append(info); - nodeTypeSelectDia.find('#nodeTypeSelect').bind('change', function(){ - $('#nodeTypeSelectDia .ui-state-error').remove(); - var addmethod = $(this).val(); - var showstr = ''; - switch(addmethod){ + var typeFS = $('
'); + var typeLegend = $('Type'); + typeFS.append(typeLegend); + addNodeForm.append(typeFS); + + var nodeFS = $('
'); + var nodeLegend = $('Node'); + nodeFS.append(nodeLegend); + addNodeForm.append(nodeFS); + + typeFS.append('
' + + '' + + '' + + '
'); + + typeFS.find('#typeSelect').bind('change', function(){ + // Remove any existing warnings + $('#addBladeCenter .ui-state-error').remove(); + nodeFS.find('div').remove(); + + var addMethod = $(this).val(); + switch(addMethod){ case 'mm': - showstr = '

' + - '

' + - '

' + - ''; + nodeFS.append('
'); + nodeFS.append('
'); + nodeFS.append('
'); + nodeFS.append('
'); break; case 'blade': - showstr = '

' + - '

' + - '

' + - 'JSLS

' + - ''; + nodeFS.append('
'); + nodeFS.append('
'); + nodeFS.append('
'); + nodeFS.append('
JS LS
'); + nodeFS.append('
'); break; case 'scanmm': - showstr = ''; + nodeFS.append('
'); break; } - $('#bladeDiaInputDiv').html(showstr); - //change the dialog width + // Change dialog width if ($(this).val() == 'scanmm'){ - $('#nodeTypeSelectDia').dialog('option', 'width', '650'); + $('#addBladeCenter').dialog('option', 'width', '650'); }else{ - $('#nodeTypeSelectDia').dialog('option', 'width', '400'); + $('#addBladeCenter').dialog('option', 'width', '400'); } - //add mm node can return directly + // If MM node, return directly if ($(this).val() == 'mm'){ return; } - //get all mm nodes from the server side - $('#bladeDiaInputDiv').append(createLoader()); + // Get all MM nodes from server side + nodeFS.find('select:eq(0)').after(createLoader()); $.ajax({ url : 'lib/cmd.php', @@ -255,22 +273,23 @@ bladePlugin.prototype.addNode = function() { cmd : 'lsdef', tgt : '', args : '-t;node;-w;mgt==blade;-w;id==0', - msg : addmethod + msg : addMethod }, success : function(data){ var position = 0; var tempStr = ''; var options = ''; - //remove the loading image - $('#bladeDiaInputDiv img').remove(); + + // Remove the loading image + nodeFS.find('img').remove(); - //check return result - if (1 > data.rsp.length){ - $('#nodeTypeSelectDia').prepend(createWarnBar('Please define MM node first!')); + // Check return result + if (data.rsp.length < 1) { + $('#addBladeCenter').prepend(createWarnBar('Please define MM node first!')); return; } - //add all mm nodes to select + // Add all MM nodes to select for (var i in data.rsp){ tempStr = data.rsp[i]; position = tempStr.indexOf(' '); @@ -278,23 +297,24 @@ bladePlugin.prototype.addNode = function() { options += ''; } - $('#bladeDiaInputDiv select').append(options); + nodeFS.find('select:eq(0)').append(options); - //if add node by rscan, we should add the scan button - if (data.msg != 'scanmm'){ + // If adding node by rscan, we should add the scan button + if (data.msg != 'scanmm') { return; } - var scanbutton = createButton('Scan'); - scanbutton.bind('click', function(){ - var mmname = $('#bladeDiaInputDiv select').val(); - $('#bladeDiaInputDiv').append(createLoader()); - $('#bladeDiaInputDiv button').attr('disabled', 'disabled'); + + var scan = createButton('Scan'); + scan.bind('click', function(){ + var mmName = nodeFS.find('select:eq(0)').val(); + nodeFS.prepend(createLoader()); + $('#nodeAttrs button').attr('disabled', 'disabled'); $.ajax({ url : 'lib/cmd.php', dataType : 'json', data : { cmd : 'rscan', - tgt : mmname, + tgt : mmName, args : '', msg : '' }, @@ -304,32 +324,33 @@ bladePlugin.prototype.addNode = function() { } }); }); - $('#bladeDiaInputDiv').append(scanbutton); + + nodeFS.find('select:eq(0)').after(scan); } }); }); - nodeTypeSelectDia.dialog( { + addNodeForm.dialog( { modal : true, width : 400, title : 'Add node', open : function(event, ui) { $(".ui-dialog-titlebar-close").hide(); }, - close : function(){$(this).remove();}, + close : function(){ + $(this).remove(); + }, buttons : { 'Ok' : function() { - //remove all error bar - $('#nodeTypeSelectDia .ui-state-error').remove(); - var addMethod = $('#nodeTypeSelect').val(); + // Remove any existing warnings + $('#addBladeCenter .ui-state-error').remove(); + var addMethod = $('#typeSelect').val(); if (addMethod == "mm") { addMmNode(); - } - else if(addMethod == "blade") { + } else if(addMethod == "blade") { addBladeNode(); - } - else{ + } else{ addMmScanNode(); } }, @@ -339,7 +360,7 @@ bladePlugin.prototype.addNode = function() { } }); - nodeTypeSelectDia.find('#nodeTypeSelect').trigger('change'); + addNodeForm.find('#typeSelect').trigger('change'); }; @@ -350,24 +371,26 @@ bladePlugin.prototype.addNode = function() { */ function addMmNode(){ var argsTmp = ''; - var errorinfo = ''; + var errorMsg = ''; - $('#nodeTypeSelectDia input').each(function(){ - if (!$(this).val()){ - errorinfo = 'You are missing inputs.'; + $('#addBladeCenter input').each(function(){ + if (!$(this).val()) { + errorMsg = 'Please provide a value for each missing field.'; } + argsTmp += $(this).val() + ','; }); - if (errorinfo){ - //add warning message - $('#nodeTypeSelectDia').prepend(createWarnBar(errorinfo)); + if (errorMsg) { + // Add warning message + $('#addBladeCenter').prepend(createWarnBar(errorMsg)); return; } argsTmp = argsTmp.substring(0, argsTmp.length - 1); - //add the loader - $('#nodeTypeSelectDia').prepend(createLoader()); + + // Add the loader + $('#addBladeCenter').prepend(createLoader()); $('.ui-dialog-buttonpane .ui-button').attr('disabled', true); $.ajax( { url : 'lib/cmd.php', @@ -379,12 +402,12 @@ function addMmNode(){ msg : '' }, success : function(data) { - $('#nodeTypeSelectDia').find('img').remove(); - var info = createInfoBar('Add MM Node successful.'); - $('#nodeTypeSelectDia').prepend(info); - $('#nodeTypeSelectDia').dialog("option", "buttons", { - "close" : function() { - $('#nodeTypeSelectDia').dialog('close'); + $('#addBladeCenter').find('img').remove(); + var info = createInfoBar('Successfully added MM node.'); + $('#addBladeCenter').prepend(info); + $('#addBladeCenter').dialog("option", "buttons", { + "Close" : function() { + $('#addBladeCenter').dialog('close'); $('.selectgroup').trigger('click'); } }); @@ -398,11 +421,11 @@ function addMmNode(){ * @return Nothing */ function addBladeNode(){ - var name = $('#nodeTypeSelectDia #bladeName').val(); - var group = $('#nodeTypeSelectDia #bladeGroup').val(); - var id = $('#nodeTypeSelectDia #bladeId').val(); - var series = $("#nodeTypeSelectDia #bladeNode :checked").val(); - var mpa = $('#nodeTypeSelectDia #mpaSelect').val(); + var name = $('#addBladeCenter #bladeName').val(); + var group = $('#addBladeCenter #bladeGroup').val(); + var id = $('#addBladeCenter #bladeId').val(); + var series = $("#addBladeCenter #bladeNode :checked").val(); + var mpa = $('#addBladeCenter #mpaSelect').val(); var argsTmp = '-t;node;-o;' + name + ';id=' + id + ';nodetype=osi;groups=' + group + ';mgt=blade;mpa=' + mpa + ';serialflow=hard'; @@ -411,12 +434,12 @@ function addBladeNode(){ } if ((!name) || (!group) || (!id) || (!mpa)){ - $('#nodeTypeSelectDia').prepend(createWarnBar("Please provide a value for each missing field.")); + $('#addBladeCenter').prepend(createWarnBar("Please provide a value for each missing field.")); return; } - //add loader and disable buttons - $('#nodeTypeSelectDia').prepend(createLoader()); + // Add loader and disable buttons + $('#addBladeCenter').prepend(createLoader()); $('.ui-dialog-buttonpane .ui-button').attr('disabled', true); $.ajax( { url : 'lib/cmd.php', @@ -428,126 +451,136 @@ function addBladeNode(){ msg : '' }, success : function(data) { - $('#nodeTypeSelectDia').find('img').remove(); + $('#addBladeCenter').find('img').remove(); var messages = data.rsp; var notes = ""; - for ( var i = 0; i < messages.length; i++) { - notes += messages[i]; + for (var i = 0; i < messages.length; i++) { + notes += messages[i] + " "; } - $('#nodeTypeSelectDia').prepend(createInfoBar(notes)); - $('#nodeTypeSelectDia').dialog("option", "buttons", { - "close" : function() { - $('#nodeTypeSelectDia').remove(); + $('#addBladeCenter').prepend(createInfoBar(notes)); + $('#addBladeCenter').dialog("option", "buttons", { + "Close" : function() { + $('#addBladeCenter').remove(); } }); } }); } -function showScanMmResult(rscanresult){ - var resultDiv = $('
'); - var rscantable = $('
'); - var tempreg = /\S+/g; +/** + * Show rscan results + * + * @param rscanResults + * Results from rscan of blade MPA + * @return Nothing + */ +function showScanMmResult(rscanResults){ + var results = $('
'); + var rscanTable = $('
'); + var regex = /\S+/g; var line = ''; - var fields; - var colnum = 0; + var column = 0; - $('#bladeDiaInputDiv #scanresult').remove(); - $('#bladeDiaInputDiv img').remove(); - $('#bladeDiaInputDiv button').attr('disabled', ''); - if (!rscanresult){ + $('#nodeAttrs #scan_results').remove(); + $('#nodeAttrs img').remove(); + $('#nodeAttrs button').attr('disabled', ''); + if (!rscanResults){ return; } - var rows = rscanresult.split("\n"); + var rows = rscanResults.split("\n"); if (rows.length < 2){ - resultDiv.append(createWarnBar(rows[0])); - $('#bladeDiaInputDiv').append(resultDiv); + results.append(createWarnBar(rows[0])); + $('#nodeAttrs').append(results); return; } - //add the table header - fields = rows[0].match(tempreg); - colnum = fields.length; - temprow = ''; + // Add the table header + var fields = rows[0].match(regex); + column = fields.length; + row = ''; for(var i in fields){ - temprow += '' + fields[i] + ''; + row += '' + fields[i] + ''; } - rscantable.append(temprow); + rscanTable.append(row); - //add the tbody - for (var i = 1; i < rows.length; i++){ + // Add the tbody + for (var i=1; i'; + row = ''; - for(var j = 0; j < colnum; j++){ - temprow += ''; - if (fields[j]){ - if (j == 1){ - temprow += ''; - } - else{ - temprow += fields[j]; + for (var j=0; j'; + } else { + row += fields[j]; } } - temprow += ''; + + row += ''; } - temprow += ''; - rscantable.append(temprow); + row += ''; + rscanTable.append(row); } - resultDiv.append(rscantable); - - $('#bladeDiaInputDiv').append(resultDiv); + results.append(rscanTable); + $('#nodeAttrs').prepend(results); } function addMmScanNode(){ - //get the mm name - var mmname = $('#bladeDiaInputDiv select').val(); - var nodename = ''; - //get all need added node - $('#bladeDiaInputDiv :checked').each(function(){ - if ($(this).attr('name')){ - nodename += $(this).attr('name') + ','; - nodename += $(this).parents('tr').find('input').eq(1).val() + ','; + // Get the MM name + var mmName = $('#nodeAttrs select').val(); + var nodeName = ''; + + $('#nodeAttrs :checked').each(function() { + if ($(this).attr('name')) { + nodeName += $(this).attr('name') + ','; + nodeName += $(this).parents('tr').find('input').eq(1).val() + ','; } }); - if (!nodename){ + if (!nodeName) { alert('You should select nodes first!'); return; } - //disabled the button + + // Disabled the button $('.ui-dialog-buttonpane button').attr('disabled', 'disabled'); - nodename = nodename.substr(0, nodename.length - 1); - $('#bladeDiaInputDiv').append(createLoader()); - //send the add request + nodeName = nodeName.substr(0, nodeName.length - 1); + $('#nodeAttrs').append(createLoader()); + + // Send the add request $.ajax({ url : 'lib/cmd.php', dataType : 'json', data : { cmd : 'webrun', tgt : '', - args : 'addnode;node;' + mmname + ',' + nodename, + args : 'addnode;node;' + mmName + ',' + nodeName, msg : '' }, success : function(data){ - //refresh the area on the right side - $('#nodeTypeSelectDia').dialog('close'); + // Refresh the area on the right side + $('#addBladeCenter').dialog('close'); $('.selectgroup').trigger('click'); } }); } + /** * Create provision existing node division *