ui: utils: add property format string helpers from PVE
slightly adapted, i.e., the delete_if_default helper always sets the delete property to an array if not existing. Also, filtering out undefined values when printing properties. Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
This commit is contained in:
parent
ad53c1d6dd
commit
1d9d2f0f7c
75
www/Utils.js
75
www/Utils.js
@ -58,6 +58,81 @@ Ext.define('PBS.Utils', {
|
|||||||
return path.indexOf(PBS.Utils.dataStorePrefix) === 0;
|
return path.indexOf(PBS.Utils.dataStorePrefix) === 0;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
parsePropertyString: function(value, defaultKey) {
|
||||||
|
var res = {},
|
||||||
|
error;
|
||||||
|
|
||||||
|
if (typeof value !== 'string' || value === '') {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ext.Array.each(value.split(','), function(p) {
|
||||||
|
var kv = p.split('=', 2);
|
||||||
|
if (Ext.isDefined(kv[1])) {
|
||||||
|
res[kv[0]] = kv[1];
|
||||||
|
} else if (Ext.isDefined(defaultKey)) {
|
||||||
|
if (Ext.isDefined(res[defaultKey])) {
|
||||||
|
error = 'defaultKey may be only defined once in propertyString';
|
||||||
|
return false; // break
|
||||||
|
}
|
||||||
|
res[defaultKey] = kv[0];
|
||||||
|
} else {
|
||||||
|
error = 'invalid propertyString, not a key=value pair and no defaultKey defined';
|
||||||
|
return false; // break
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (error !== undefined) {
|
||||||
|
console.error(error);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
},
|
||||||
|
|
||||||
|
printPropertyString: function(data, defaultKey) {
|
||||||
|
var stringparts = [],
|
||||||
|
gotDefaultKeyVal = false,
|
||||||
|
defaultKeyVal;
|
||||||
|
|
||||||
|
Ext.Object.each(data, function(key, value) {
|
||||||
|
if (defaultKey !== undefined && key === defaultKey) {
|
||||||
|
gotDefaultKeyVal = true;
|
||||||
|
defaultKeyVal = value;
|
||||||
|
} else if (value !== '' && value !== undefined) {
|
||||||
|
stringparts.push(key + '=' + value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
stringparts = stringparts.sort();
|
||||||
|
if (gotDefaultKeyVal) {
|
||||||
|
stringparts.unshift(defaultKeyVal);
|
||||||
|
}
|
||||||
|
|
||||||
|
return stringparts.join(',');
|
||||||
|
},
|
||||||
|
|
||||||
|
// helper for deleting field which are set to there default values
|
||||||
|
delete_if_default: function(values, fieldname, default_val, create) {
|
||||||
|
if (values[fieldname] === '' || values[fieldname] === default_val) {
|
||||||
|
if (!create) {
|
||||||
|
if (values.delete) {
|
||||||
|
if (Ext.isArray(values.delete)) {
|
||||||
|
values.delete.push(fieldname);
|
||||||
|
} else {
|
||||||
|
values.delete += ',' + fieldname;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
values.delete = [fieldname];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delete values[fieldname];
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
render_datetime_utc: function(datetime) {
|
render_datetime_utc: function(datetime) {
|
||||||
let pad = (number) => number < 10 ? '0' + number : number;
|
let pad = (number) => number < 10 ? '0' + number : number;
|
||||||
return datetime.getUTCFullYear() +
|
return datetime.getUTCFullYear() +
|
||||||
|
Loading…
Reference in New Issue
Block a user