2010-06-16 18:21:58 +00:00
/ * *
* Global variables
* /
var configTabs ; // Config tabs
2010-07-19 18:28:31 +00:00
var configDatatables = new Object ( ) ; // Datatables on the config page
2010-06-16 18:21:58 +00:00
/ * *
* Set the datatable
*
* @ param id
* The ID of the datatable
* @ param obj
* Datatable object
* @ return Nothing
* /
function setConfigDatatable ( id , obj ) {
2010-07-19 18:28:31 +00:00
configDatatables [ id ] = obj ;
2010-06-16 18:21:58 +00:00
}
/ * *
* Get the datatable with the given ID
*
* @ param id
* The ID of the datatable
* @ return Datatable object
* /
function getConfigDatatable ( id ) {
2010-07-19 18:28:31 +00:00
return configDatatables [ id ] ;
2010-06-16 18:21:58 +00:00
}
/ * *
* Set the configure tab
*
* @ param obj
* Tab object
* @ return Nothing
* /
function setConfigTab ( obj ) {
configTabs = obj ;
}
/ * *
* Get the configure tab
*
* @ param Nothing
* @ return Tab object
* /
function getConfigTab ( ) {
return configTabs ;
}
/ * *
* Load configure page
*
* @ return Nothing
* /
function loadConfigPage ( ) {
// If the configure page has already been loaded
2010-07-14 20:11:07 +00:00
if ( $ ( '#content' ) . children ( ) . length ) {
2010-06-16 18:21:58 +00:00
// Do not reload configure page
return ;
}
// Create configure tab
var tab = new Tab ( ) ;
setConfigTab ( tab ) ;
tab . init ( ) ;
2010-07-14 20:11:07 +00:00
$ ( '#content' ) . append ( tab . object ( ) ) ;
2010-06-16 18:21:58 +00:00
// Create loader
2011-01-19 15:56:43 +00:00
var loader = $ ( '<center></center>' ) . append ( createLoader ( ) ) ;
2010-06-16 18:21:58 +00:00
2011-01-19 15:56:43 +00:00
// Add tab to configure xCAT tables
2010-08-03 14:58:08 +00:00
tab . add ( 'configTablesTab' , 'Tables' , loader , false ) ;
2010-06-16 18:21:58 +00:00
2010-07-21 03:35:31 +00:00
// Add the update tab
2010-08-03 14:58:08 +00:00
tab . add ( 'updateTab' , 'Update' , '' , false ) ;
2010-12-03 03:25:33 +00:00
// Add the discover tab
tab . add ( 'discoverTab' , 'Discover' , '' , false ) ;
2010-07-21 03:35:31 +00:00
2010-06-16 18:21:58 +00:00
// Get list of tables and their descriptions
$ . ajax ( {
url : 'lib/cmd.php' ,
dataType : 'json' ,
data : {
cmd : 'tabdump' ,
tgt : '' ,
args : '-d' ,
msg : ''
} ,
success : loadTableNames
} ) ;
2010-07-21 03:35:31 +00:00
loadUpdatePage ( ) ;
2010-12-03 03:25:33 +00:00
loadDiscoverPage ( ) ;
2010-06-16 18:21:58 +00:00
}
/ * *
2010-07-19 18:28:31 +00:00
* Load xCAT database table names and their descriptions
2010-06-16 18:21:58 +00:00
*
* @ param data
* Data returned from HTTP request
* @ return Nothing
* /
function loadTableNames ( data ) {
// Get output
var tables = data . rsp ;
// Remove loader
var tabId = 'configTablesTab' ;
$ ( '#' + tabId ) . find ( 'img' ) . hide ( ) ;
// Create a groups division
2010-07-19 18:28:31 +00:00
var tablesDIV = $ ( '<div id="configTable"></div>' ) ;
2010-06-16 18:21:58 +00:00
$ ( '#' + tabId ) . append ( tablesDIV ) ;
// Create info bar
2010-12-03 22:09:36 +00:00
var infoBar = createInfoBar ( 'Select a table to view or edit.' ) ;
2010-06-16 18:21:58 +00:00
tablesDIV . append ( infoBar ) ;
// Create a list for the tables
var list = $ ( '<ul></ul>' ) ;
// Loop through each table
for ( var i = 0 ; i < tables . length ; i ++ ) {
// Create a link for each table
var args = tables [ i ] . split ( ':' ) ;
2011-09-28 21:38:12 +00:00
var link = $ ( '<a style="color: blue;" id="' + args [ 0 ] + '">' + args [ 0 ] + '</a>' ) ;
2010-06-16 18:21:58 +00:00
// Open table on click
link . bind ( 'click' , function ( e ) {
// Get table ID that was clicked
var id = ( e . target ) ? e . target . id : e . srcElement . id ;
// Create loader
2011-01-19 15:56:43 +00:00
var loader = $ ( '<center></center>' ) . append ( createLoader ( ) ) ;
2010-06-16 18:21:58 +00:00
// Add a new tab for this table
var configTab = getConfigTab ( ) ;
if ( ! $ ( '#' + id + 'Tab' ) . length ) {
2010-08-03 14:58:08 +00:00
configTab . add ( id + 'Tab' , id , loader , true ) ;
2010-06-16 18:21:58 +00:00
// Get contents of selected table
$ . ajax ( {
url : 'lib/cmd.php' ,
dataType : 'json' ,
data : {
cmd : 'tabdump' ,
tgt : '' ,
args : id ,
msg : id
} ,
success : loadTable
} ) ;
}
// Select new tab
configTab . select ( id + 'Tab' ) ;
} ) ;
var item = $ ( '<li></li>' ) ;
item . append ( link ) ;
// Append the table description
item . append ( ': ' + args [ 1 ] ) ;
// Append item to list
list . append ( item ) ;
}
tablesDIV . append ( list ) ;
}
/ * *
2010-07-19 18:28:31 +00:00
* Load a given database table
2010-06-16 18:21:58 +00:00
*
* @ param data
* Data returned from HTTP request
* @ return Nothing
* /
function loadTable ( data ) {
// Get response
var rsp = data . rsp ;
// Get table ID
var id = data . msg ;
// Remove loader
var tabId = id + 'Tab' ;
$ ( '#' + tabId ) . find ( 'img' ) . remove ( ) ;
// Create info bar
2011-10-27 15:00:36 +00:00
var infoBar = createInfoBar ( 'Click on a cell to edit. Click outside the table to write to the cell. Once you are satisfied with how the table looks, click on Save.' ) ;
2010-06-16 18:21:58 +00:00
$ ( '#' + tabId ) . append ( infoBar ) ;
// Create action bar
var actionBar = $ ( '<div></div>' ) ;
$ ( '#' + tabId ) . append ( actionBar ) ;
// Get table headers
var args = rsp [ 0 ] . replace ( '#' , '' ) ;
var headers = args . split ( ',' ) ;
// Create container for original table contents
var origCont = new Array ( ) ; // Original table content
origCont [ 0 ] = rsp [ 0 ] . split ( ',' ) ; // Headers
// Create container for new table contents
var newCont = new Object ( ) ;
var tmp = new Object ( ) ;
tmp [ 0 ] = '#' + headers [ 0 ] ; // Put a # in front of the header
for ( var i = 1 ; i < headers . length ; i ++ ) {
tmp [ i ] = headers [ i ] ;
}
newCont [ 0 ] = tmp ;
// Create a new datatable
2010-07-19 18:28:31 +00:00
var tableId = id + 'Datatable' ;
2010-06-16 18:21:58 +00:00
var table = new DataTable ( tableId ) ;
2010-07-19 18:28:31 +00:00
// Add column for the remove row button
2010-06-16 18:21:58 +00:00
headers . unshift ( '' ) ;
table . init ( headers ) ;
headers . shift ( ) ;
// Append datatable to tab
$ ( '#' + tabId ) . append ( table . object ( ) ) ;
// Data table
var dTable ;
// Add table rows
// Start with the 2nd row (1st row is the headers)
for ( var i = 1 ; i < rsp . length ; i ++ ) {
// Split into columns
var cols = rsp [ i ] . split ( ',' ) ;
// Go through each column
for ( var j = 0 ; j < cols . length ; j ++ ) {
// If the column is not complete
if ( cols [ j ] . count ( '"' ) == 1 ) {
while ( cols [ j ] . count ( '"' ) != 2 ) {
// Merge this column with the adjacent one
cols [ j ] = cols [ j ] + "," + cols [ j + 1 ] ;
// Remove merged row
cols . splice ( j + 1 , 1 ) ;
}
}
// Replace quote
cols [ j ] = cols [ j ] . replace ( new RegExp ( '"' , 'g' ) , '' ) ;
}
// Add remove button
2010-07-19 18:28:31 +00:00
cols . unshift ( '<span class="ui-icon ui-icon-close" onclick="deleteRow(this)"></span>' ) ;
2010-06-16 18:21:58 +00:00
// Add row
table . add ( cols ) ;
// Save original table content
origCont [ i ] = cols ;
}
/ * *
* Enable editable columns
* /
// Do not make 1st column editable
$ ( '#' + tableId + ' td:not(td:nth-child(1))' ) . editable (
function ( value , settings ) {
// Get column index
var colPos = this . cellIndex ;
// Get row index
var rowPos = dTable . fnGetPosition ( this . parentNode ) ;
// Update datatable
dTable . fnUpdate ( value , rowPos , colPos ) ;
return ( value ) ;
} , {
2010-07-19 18:28:31 +00:00
onblur : 'submit' , // Clicking outside editable area submits changes
2010-06-16 18:21:58 +00:00
type : 'textarea' ,
2010-07-30 12:37:14 +00:00
placeholder : ' ' ,
2010-06-16 18:21:58 +00:00
height : '30px' // The height of the text area
} ) ;
// Turn table into datatable
2011-09-09 19:34:05 +00:00
dTable = $ ( '#' + id + 'Datatable' ) . dataTable ( {
'iDisplayLength' : 50 ,
'bLengthChange' : false ,
"sScrollX" : "100%" ,
2011-09-09 21:56:30 +00:00
"bAutoWidth" : true
2010-07-19 18:28:31 +00:00
} ) ;
2010-06-16 18:21:58 +00:00
2011-09-09 19:34:05 +00:00
// Create action bar
var actionBar = $ ( '<div class="actionBar"></div>' ) ;
var saveLnk = $ ( '<a>Save</a>' ) ;
saveLnk . click ( function ( ) {
// Get table ID and name
var tableId = $ ( this ) . parents ( '.dataTables_wrapper' ) . attr ( 'id' ) . replace ( '_wrapper' , '' ) ;
var tableName = tableId . replace ( 'Datatable' , '' ) ;
2010-06-16 18:21:58 +00:00
// Get datatable
2011-09-09 19:34:05 +00:00
var dTable = $ ( '#' + tableId ) . dataTable ( ) ;
2010-06-16 18:21:58 +00:00
// Get the nodes from the table
var dRows = dTable . fnGetNodes ( ) ;
// Go through each row
for ( var i = 0 ; i < dRows . length ; i ++ ) {
// If there is row with values
if ( dRows [ i ] ) {
// Go through each column
// Ignore the 1st column because it is a button
var cols = dRows [ i ] . childNodes ;
var vals = new Object ( ) ;
for ( var j = 1 ; j < cols . length ; j ++ ) {
var val = cols . item ( j ) . firstChild . nodeValue ;
2010-07-30 12:37:14 +00:00
2010-06-16 18:21:58 +00:00
// Insert quotes
2010-07-30 12:37:14 +00:00
if ( val == ' ' ) {
2010-06-16 18:21:58 +00:00
vals [ j - 1 ] = '' ;
} else {
vals [ j - 1 ] = val ;
}
}
// Save row
newCont [ i + 1 ] = vals ;
}
}
2010-07-30 12:37:14 +00:00
2010-06-16 18:21:58 +00:00
// Update xCAT table
$ . ajax ( {
type : 'POST' ,
url : 'lib/tabRestore.php' ,
dataType : 'json' ,
data : {
table : tableName ,
cont : newCont
} ,
success : function ( data ) {
2012-04-02 04:08:30 +00:00
// Create info message
var dialog = $ ( '<div></div>' ) . append ( createInfoBar ( 'Changes saved!' ) ) ;
// Open dialog
dialog . dialog ( {
modal : true ,
title : 'Info' ,
width : 400 ,
buttons : {
"Ok" : function ( ) {
$ ( this ) . dialog ( "close" ) ;
}
}
} ) ;
2010-06-16 18:21:58 +00:00
}
} ) ;
} ) ;
2011-09-09 19:34:05 +00:00
var undoLnk = $ ( '<a>Undo</a>' ) ;
undoLnk . click ( function ( ) {
2010-06-16 18:21:58 +00:00
// Get table ID
2011-09-09 19:34:05 +00:00
var tableId = $ ( this ) . parents ( '.dataTables_wrapper' ) . attr ( 'id' ) . replace ( '_wrapper' , '' ) ;
2010-06-16 18:21:58 +00:00
// Get datatable
2011-09-09 19:34:05 +00:00
var dTable = $ ( '#' + tableId ) . dataTable ( ) ;
2010-06-16 18:21:58 +00:00
// Clear entire datatable
dTable . fnClearTable ( ) ;
// Add original content back into datatable
for ( var i = 1 ; i < origCont . length ; i ++ ) {
dTable . fnAddData ( origCont [ i ] , true ) ;
}
// Enable editable columns (again)
// Do not make 1st column editable
$ ( '#' + tableId + ' td:not(td:nth-child(1))' ) . editable (
function ( value , settings ) {
// Get column index
var colPos = this . cellIndex ;
// Get row index
var rowPos = dTable . fnGetPosition ( this . parentNode ) ;
// Update datatable
dTable . fnUpdate ( value , rowPos , colPos ) ;
return ( value ) ;
} , {
2010-07-30 12:37:14 +00:00
onblur : 'submit' , // Clicking outside editable area submits changes
2010-06-16 18:21:58 +00:00
type : 'textarea' ,
2010-07-30 12:37:14 +00:00
placeholder : ' ' ,
2010-06-16 18:21:58 +00:00
height : '30px' // The height of the text area
} ) ;
} ) ;
2011-09-09 19:34:05 +00:00
var addLnk = $ ( '<a>Add row</a>' ) ;
addLnk . click ( function ( ) {
// Create an empty row
var row = new Array ( ) ;
/ * *
* Remove button
* /
row . push ( '<span class="ui-icon ui-icon-close" onclick="deleteRow(this)"></span>' ) ;
for ( var i = 0 ; i < headers . length ; i ++ ) {
row . push ( '' ) ;
}
// Get table ID and name
var tableId = $ ( this ) . parents ( '.dataTables_wrapper' ) . attr ( 'id' ) . replace ( '_wrapper' , '' ) ;
var tableName = tableId . replace ( 'Datatable' , '' ) ;
// Get datatable
var dTable = $ ( '#' + tableId ) . dataTable ( ) ;
// Add the row to the data table
dTable . fnAddData ( row ) ;
// Enable editable columns (again)
// Do not make 1st column editable
$ ( '#' + tableId + ' td:not(td:nth-child(1))' ) . editable (
function ( value , settings ) {
// Get column index
var colPos = this . cellIndex ;
// Get row index
var rowPos = dTable . fnGetPosition ( this . parentNode ) ;
// Update datatable
dTable . fnUpdate ( value , rowPos , colPos ) ;
return ( value ) ;
} , {
onblur : 'submit' , // Clicking outside editable area submits changes
type : 'textarea' ,
placeholder : ' ' ,
height : '30px' // The height of the text area
} ) ;
} ) ;
// Create an action menu
2012-04-02 04:08:30 +00:00
var actionsMenu = createMenu ( [ saveLnk , undoLnk , addLnk ] ) ;
2011-09-09 19:34:05 +00:00
actionsMenu . superfish ( ) ;
actionsMenu . css ( 'display' , 'inline-block' ) ;
actionBar . append ( actionsMenu ) ;
2011-09-28 21:38:12 +00:00
// Set correct theme for action menu
actionsMenu . find ( 'li' ) . hover ( function ( ) {
setMenu2Theme ( $ ( this ) ) ;
} , function ( ) {
setMenu2Normal ( $ ( this ) ) ;
} ) ;
2011-09-09 19:34:05 +00:00
// Create a division to hold actions menu
var menuDiv = $ ( '<div id="' + id + 'Datatable_menuDiv" class="menuDiv"></div>' ) ;
$ ( '#' + id + 'Datatable_wrapper' ) . prepend ( menuDiv ) ;
menuDiv . append ( actionBar ) ;
$ ( '#' + id + 'Datatable_filter' ) . appendTo ( menuDiv ) ;
2010-06-16 18:21:58 +00:00
}
/ * *
* Delete a row in the data table
*
* @ param obj
* The object that was clicked
* @ return Nothing
* /
function deleteRow ( obj ) {
// Get table ID
2011-09-09 19:34:05 +00:00
var tableId = $ ( obj ) . parents ( 'table' ) . attr ( 'id' ) ;
2010-06-16 18:21:58 +00:00
// Get datatable
2011-09-09 19:34:05 +00:00
var dTable = $ ( '#' + tableId ) . dataTable ( ) ;
2010-06-16 18:21:58 +00:00
// Get all nodes within the datatable
var rows = dTable . fnGetNodes ( ) ;
// Get target row
var tgtRow = $ ( obj ) . parent ( ) . parent ( ) . get ( 0 ) ;
// Find the target row in the datatable
for ( var i in rows ) {
// If the row matches the target row
if ( rows [ i ] == tgtRow ) {
// Remove row
dTable . fnDeleteRow ( i , null , true ) ;
break ;
}
}
}
/ * *
* Count the number of occurrences of a specific character in a string
*
2011-02-17 15:17:00 +00:00
* @ param c
2010-06-16 18:21:58 +00:00
* Character to count
* @ return The number of occurrences
* /
2011-02-17 15:17:00 +00:00
String . prototype . count = function ( c ) {
return ( this . length - this . replace ( new RegExp ( c , 'g' ) , '' ) . length ) / c . length ;
2010-06-16 18:21:58 +00:00
} ;