Commit 36be2857 authored by Dietmar Maurer's avatar Dietmar Maurer

cleanup json object reader

Try to make it a generic usable class.
parent 019434e5
...@@ -19,7 +19,7 @@ Ext.define('PVE.data.PendingObjectStore', { ...@@ -19,7 +19,7 @@ Ext.define('PVE.data.PendingObjectStore', {
reader: { reader: {
type: 'jsonobject', type: 'jsonobject',
rows: config.rows, rows: config.rows,
pending: 1 readArray: true
} }
} }
}); });
......
/* A reader to store a single JSON Object (hash) into a storage. /* A reader to store a single JSON Object (hash) into a storage.
* Also accepts an array containing a single hash. * Also accepts an array containing a single hash.
*
* So it can read: * So it can read:
* *
* example1: { data: "xyz" } * example1: {data1: "xyz", data2: "abc"}
* example2: [ { data: "xyz" } ] * returns [{key: "data1", value: "xyz"}, {key: "data2", value: "abc"}]
*
* example2: [ {data1: "xyz", data2: "abc"} ]
* returns [{key: "data1", value: "xyz"}, {key: "data2", value: "abc"}]
*
* If you set 'readArray', the reader expexts the object as array:
*
* example3: [ { key: "data1", value: "xyz", p2: "cde" }, { key: "data2", value: "abc", p2: "efg" }]
* returns [{key: "data1", value: "xyz", p2: "cde}, {key: "data2", value: "abc", p2: "efg"}]
*
* Note: The records can contain additional properties (like 'p2' above) when you use 'readArray'
*
* Additional feature: specify allowed properties with default values with 'rows' object
*
* var rows = {
* memory: {
* required: true,
* defaultValue: 512
* }
* }
*
*/ */
Ext.define('PVE.data.reader.JsonObject', { Ext.define('PVE.data.reader.JsonObject', {
...@@ -12,6 +33,10 @@ Ext.define('PVE.data.reader.JsonObject', { ...@@ -12,6 +33,10 @@ Ext.define('PVE.data.reader.JsonObject', {
root: 'data', root: 'data',
readArray: false,
rows: undefined,
constructor: function(config) { constructor: function(config) {
var me = this; var me = this;
...@@ -27,40 +52,50 @@ Ext.define('PVE.data.reader.JsonObject', { ...@@ -27,40 +52,50 @@ Ext.define('PVE.data.reader.JsonObject', {
try { try {
var result = Ext.decode(response.responseText); var result = Ext.decode(response.responseText);
var root = me.getRoot(result); var root = me.getRoot(result);
var org_root = root;
if (Ext.isArray(org_root)) { if (me.readArray) {
if (org_root.length == 1) {
root = org_root[0];
} else {
root = {};
}
}
if (me.pending) { var rec_hash = {};
Ext.Array.each(root, function(rec) {
if (Ext.isDefined(rec.key)) {
rec_hash[rec.key] = rec;
}
});
if (me.rows) { if (me.rows) {
Ext.Object.each(me.rows, function(key, rowdef) { Ext.Object.each(me.rows, function(key, rowdef) {
if (Ext.isDefined(root[key])) { var rec = rec_hash[key];
if(Ext.isDefined(root[key]["value"])){ if (Ext.isDefined(rec)) {
data.push({key: key, value: root[key]["value"], pending: root[key]["pending"], delete: root[key]["delete"]}); if (!Ext.isDefined(rec.value)) {
}else if(Ext.isDefined(rowdef.defaultValue)){ rec.value = rowdef.defaultValue;
data.push({key: key, value: rowdef.defaultValue, pending: root[key]["pending"], delete: root[key]["delete"]});
} }
data.push(rec);
} else if (Ext.isDefined(rowdef.defaultValue)) { } else if (Ext.isDefined(rowdef.defaultValue)) {
data.push({key: key, value: rowdef.defaultValue, pending: undefined, delete: undefined}); data.push({key: key, value: rowdef.defaultValue} );
} else if (rowdef.required) { } else if (rowdef.required) {
data.push({key: key, value: undefined, pending: undefined, delete: undefined}); data.push({key: key, value: undefined });
} }
}); });
} else { } else {
Ext.Object.each(root, function(key, value) { Ext.Array.each(root, function(rec) {
data.push({key: key, value: root[key]["value"], pending: root[key]["pending"], delete: root[key]["delete"]}); if (Ext.isDefined(rec.key)) {
data.push(rec);
}
}); });
} }
} else { } else {
var org_root = root;
if (Ext.isArray(org_root)) {
if (root.length == 1) {
root = org_root[0];
} else {
root = {};
}
}
if (me.rows) { if (me.rows) {
Ext.Object.each(me.rows, function(key, rowdef) { Ext.Object.each(me.rows, function(key, rowdef) {
if (Ext.isDefined(root[key])) { if (Ext.isDefined(root[key])) {
...@@ -77,7 +112,6 @@ Ext.define('PVE.data.reader.JsonObject', { ...@@ -77,7 +112,6 @@ Ext.define('PVE.data.reader.JsonObject', {
}); });
} }
} }
} }
catch (ex) { catch (ex) {
Ext.Error.raise({ Ext.Error.raise({
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment