Commit e3d91b30 authored by Boris Kocherov's avatar Boris Kocherov

use html attribute data-origin-value for save original value parts of document

i need it for workaround `data side errors` in tests
parent 8116ef49
...@@ -617,6 +617,7 @@ ...@@ -617,6 +617,7 @@
error_message, error_message,
input, input,
first_path, first_path,
type_changed,
queue = RSVP.Queue(); queue = RSVP.Queue();
if (json_field instanceof Array) { if (json_field instanceof Array) {
...@@ -645,15 +646,11 @@ ...@@ -645,15 +646,11 @@
type = getDocumentType(default_value); type = getDocumentType(default_value);
} }
// XXX bad peace of code if (typeof type === "string") {
// i do not sure that type can be computed so // it's only for simple types so we not use
// but our schema in slapos bad // complex type detection
if (!type) { type_changed = default_value !== undefined &&
if (json_field.properties && typeof default_value !== type;
json_field.required &&
json_field.required.length > 0) {
type = "object";
}
} }
div = document.createElement("div"); div = document.createElement("div");
...@@ -708,6 +705,8 @@ ...@@ -708,6 +705,8 @@
if (json_field.enum !== undefined) { if (json_field.enum !== undefined) {
input = render_enum(json_field, default_value); input = render_enum(json_field, default_value);
// XXX take in account existing type with enum
type_changed = false;
} }
if (type === "boolean") { if (type === "boolean") {
...@@ -721,10 +720,11 @@ ...@@ -721,10 +720,11 @@
input = document.createElement("input"); input = document.createElement("input");
if (default_value !== undefined) { if (default_value !== undefined) {
if (typeof default_value === "object") { if (typeof default_value === "object") {
default_value = JSON.stringify(default_value); input.value = JSON.stringify(default_value);
} } else {
input.value = default_value; input.value = default_value;
} }
}
if (type === "integer" || type === "number") { if (type === "integer" || type === "number") {
if (default_value === undefined && typeof json_field.default === "number") { if (default_value === undefined && typeof json_field.default === "number") {
...@@ -732,8 +732,16 @@ ...@@ -732,8 +732,16 @@
} }
input.type = "number"; input.type = "number";
input.setAttribute("data-json-type", type); input.setAttribute("data-json-type", type);
type_changed = default_value !== undefined &&
typeof default_value !== "number";
if (type === "integer") { if (type === "integer") {
input.setAttribute("step", "1"); input.setAttribute("step", "1");
if (default_value !== undefined &&
parseInt(default_value, 10) !== default_value) {
// original json_document contain float schema
// limit integer we can save original document
type_changed = true;
}
} }
if (type === "number") { if (type === "number") {
input.setAttribute("step", "any"); input.setAttribute("step", "any");
...@@ -786,6 +794,9 @@ ...@@ -786,6 +794,9 @@
gadget.props.inputs.push(input); gadget.props.inputs.push(input);
input.name = first_path; input.name = first_path;
input.required = options.required; input.required = options.required;
if (type_changed) {
input.setAttribute('data-origin-value', JSON.stringify(default_value));
}
// XXX for gui // XXX for gui
//input.setAttribute("class", "slapos-parameter"); //input.setAttribute("class", "slapos-parameter");
div_input.appendChild(input); div_input.appendChild(input);
...@@ -1291,6 +1302,9 @@ ...@@ -1291,6 +1302,9 @@
var json_dict = {}, var json_dict = {},
k; k;
g.props.inputs.forEach(function (input) { g.props.inputs.forEach(function (input) {
if (input.hasAttribute('data-origin-value')) {
json_dict[input.name] = JSON.parse(input.getAttribute('data-origin-value'));
} else {
if (input.required || input.value !== "") { if (input.required || input.value !== "") {
var type = input.getAttribute('data-json-type'); var type = input.getAttribute('data-json-type');
if (type === 'number') { if (type === 'number') {
...@@ -1313,6 +1327,7 @@ ...@@ -1313,6 +1327,7 @@
json_dict[input.name] = input.value; json_dict[input.name] = input.value;
} }
} }
}
}); });
for (k in json_dict) { for (k in json_dict) {
if (json_dict.hasOwnProperty(k)) { if (json_dict.hasOwnProperty(k)) {
...@@ -1578,10 +1593,15 @@ ...@@ -1578,10 +1593,15 @@
var gadget = this, var gadget = this,
field_list = this.props.inputs, field_list = this.props.inputs,
i, i,
input,
changed = false; changed = false;
// on form data field // on form data field
for (i = 0; i < field_list.length; i = i + 1) { for (i = 0; i < field_list.length; i = i + 1) {
if (evt.target === field_list[i]) { if (evt.target === field_list[i]) {
input = evt.target;
if (input.hasAttribute('data-origin-value')) {
input.removeAttribute('data-origin-value');
}
changed = true; changed = true;
} }
} }
......
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