mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-02-25 18:55:31 -06:00
Changed array representation and formatting for the data types in Query Tool and View Data. Fixes #2671
This commit is contained in:
committed by
Akshay Joshi
parent
8150f93c06
commit
30e7016077
@@ -48,6 +48,10 @@
|
||||
return $buttons;
|
||||
}
|
||||
|
||||
function is_valid_array(val) {
|
||||
val = $.trim(val)
|
||||
return !(val != "" && (val.charAt(0) != '{' || val.charAt(val.length - 1) != '}'));
|
||||
}
|
||||
/*
|
||||
* This function handles the [default] and [null] values for cells
|
||||
* if row is copied, otherwise returns the editor value.
|
||||
@@ -189,15 +193,41 @@
|
||||
this.loadValue = function (item) {
|
||||
var col = args.column;
|
||||
|
||||
if (_.isUndefined(item[args.column.field]) && col.has_default_val) {
|
||||
$input.val(defaultValue = "");
|
||||
if (_.isUndefined(item[args.column.field]) || _.isNull(item[args.column.field])) {
|
||||
$input.val(defaultValue = "");
|
||||
return;
|
||||
}
|
||||
else if (item[args.column.field] === "") {
|
||||
$input.val(defaultValue = "''");
|
||||
}
|
||||
else {
|
||||
$input.val(defaultValue = item[args.column.field]);
|
||||
$input.select();
|
||||
|
||||
if (!args.column.is_array) {
|
||||
if (item[args.column.field] === "") {
|
||||
$input.val(defaultValue = "''");
|
||||
} else if (item[args.column.field] === "''") {
|
||||
$input.val(defaultValue = "\\'\\'");
|
||||
} else if (item[args.column.field] === '""') {
|
||||
$input.val(defaultValue = '\\"\\"');
|
||||
} else {
|
||||
$input.val(defaultValue = item[args.column.field]);
|
||||
$input.select();
|
||||
}
|
||||
} else {
|
||||
var data = [];
|
||||
for (var k in item[args.column.field]) {
|
||||
if (_.isUndefined(item[args.column.field][k]) || _.isNull(item[args.column.field][k])) {
|
||||
data.push('');
|
||||
} else if (item[args.column.field][k] === "") {
|
||||
data.push("''");
|
||||
} else if (item[args.column.field][k] === "''") {
|
||||
data.push("\\'\\'");
|
||||
} else if (item[args.column.field][k] === '""') {
|
||||
data.push('\\"\\"');
|
||||
} else {
|
||||
data.push(item[args.column.field][k]);
|
||||
$input.select();
|
||||
}
|
||||
}
|
||||
defaultValue = data;
|
||||
$input.val('{' + data.join() +'}');
|
||||
|
||||
}
|
||||
};
|
||||
|
||||
@@ -207,18 +237,43 @@
|
||||
if (value === "") {
|
||||
return null;
|
||||
}
|
||||
// single/double quotes represent an empty string
|
||||
// If found return ''
|
||||
else if (value === "''" || value === '""') {
|
||||
return '';
|
||||
}
|
||||
else {
|
||||
// If found string literals - \"\", \'\', \\'\\' and \\\\'\\\\'
|
||||
// then remove slashes.
|
||||
value = value.replace("\\'\\'", "''");
|
||||
value = value.replace('\\"\\"', '""');
|
||||
value = value = value.replace(/\\\\/g, '\\');
|
||||
return value;
|
||||
|
||||
if (!args.column.is_array) {
|
||||
if (value === "''" || value === '""') {
|
||||
return '';
|
||||
} else if (value === "\\'\\'") {
|
||||
return "''";
|
||||
} else if (value === '\\"\\"') {
|
||||
return '""';
|
||||
} else {
|
||||
return value;
|
||||
}
|
||||
} else {
|
||||
|
||||
// Remove leading { and trailing }.
|
||||
// Also remove leading and trailing whitespaces.
|
||||
var value = $.trim(value.slice(1, -1));
|
||||
|
||||
if(value == '') {
|
||||
return [];
|
||||
}
|
||||
|
||||
var data = [];
|
||||
value = value.split(',');
|
||||
for (var k in value) {
|
||||
if (value[k] == "") {
|
||||
data.push(null); //empty string from editor is null value.
|
||||
} else if (value[k] === "''" || value[k] === '""') {
|
||||
data.push(''); // double quote from editor is blank string;
|
||||
} else if (value[k] === "\\'\\'") {
|
||||
data.push("''");
|
||||
} else if (value[k] === '\\"\\"') {
|
||||
data.push('""');
|
||||
} else {
|
||||
data.push(value[k]);
|
||||
}
|
||||
}
|
||||
return data;
|
||||
}
|
||||
};
|
||||
|
||||
@@ -233,7 +288,7 @@
|
||||
return false;
|
||||
} else {
|
||||
return (!($input.val() == "" && _.isNull(defaultValue))) &&
|
||||
($input.val() != defaultValue);
|
||||
($input.val() !== defaultValue);
|
||||
}
|
||||
};
|
||||
|
||||
@@ -245,6 +300,13 @@
|
||||
}
|
||||
}
|
||||
|
||||
if (args.column.is_array && !is_valid_array($input.val())) {
|
||||
return {
|
||||
valid: false,
|
||||
msg: "Array must start with '{' and end with '}'"
|
||||
};
|
||||
}
|
||||
|
||||
return {
|
||||
valid: true,
|
||||
msg: null
|
||||
@@ -859,7 +921,13 @@
|
||||
|
||||
this.loadValue = function (item) {
|
||||
defaultValue = item[args.column.field];
|
||||
$input.val(defaultValue);
|
||||
|
||||
if(args.column.is_array && !_.isNull(defaultValue) && !_.isUndefined(defaultValue)) {
|
||||
$input.val('{' + defaultValue.join() +'}');
|
||||
} else {
|
||||
$input.val(defaultValue);
|
||||
}
|
||||
|
||||
$input[0].defaultValue = defaultValue;
|
||||
$input.select();
|
||||
};
|
||||
@@ -868,6 +936,24 @@
|
||||
if ($input.val() === "") {
|
||||
return null;
|
||||
}
|
||||
|
||||
if(args.column.is_array) {
|
||||
// Remove leading { and trailing }.
|
||||
// Also remove leading and trailing whitespaces.
|
||||
var val = $.trim($input.val().slice(1, -1));
|
||||
|
||||
if(val == '') {
|
||||
return [];
|
||||
}
|
||||
val = val.split(',');
|
||||
for (var k in val) {
|
||||
if (val[k] == "") {
|
||||
val[k] = null; //empty string from editor is null value.
|
||||
}
|
||||
}
|
||||
return val;
|
||||
}
|
||||
|
||||
return $input.val();
|
||||
};
|
||||
|
||||
@@ -887,20 +973,47 @@
|
||||
};
|
||||
|
||||
this.validate = function () {
|
||||
if (isNaN($input.val())) {
|
||||
var value = $input.val();
|
||||
if (!args.column.is_array && isNaN(value)) {
|
||||
return {
|
||||
valid: false,
|
||||
msg: "Please enter a valid integer"
|
||||
msg: "Please enter a valid number"
|
||||
};
|
||||
}
|
||||
|
||||
if (args.column.validator) {
|
||||
var validationResults = args.column.validator($input.val());
|
||||
var validationResults = args.column.validator(value);
|
||||
if (!validationResults.valid) {
|
||||
return validationResults;
|
||||
}
|
||||
}
|
||||
|
||||
if (args.column.is_array) {
|
||||
if (!is_valid_array(value)) {
|
||||
return {
|
||||
valid: false,
|
||||
msg: "Array must start with '{' and end with '}'"
|
||||
};
|
||||
}
|
||||
|
||||
var val = $.trim(value.slice(1, -1)),
|
||||
arr;
|
||||
|
||||
if(val == '') {
|
||||
arr = [];
|
||||
} else {
|
||||
var arr = val.split(',');
|
||||
}
|
||||
|
||||
for (var k in arr) {
|
||||
if (isNaN(arr[k])) {
|
||||
return {
|
||||
valid: false,
|
||||
msg: "Please enter a valid numbers"
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
valid: true,
|
||||
msg: null
|
||||
|
||||
@@ -14,20 +14,45 @@
|
||||
"Numbers": NumbersFormatter,
|
||||
"Checkmark": CheckmarkFormatter,
|
||||
"Text": TextFormatter,
|
||||
"Binary": BinaryFormatter,
|
||||
"JsonStringArray": JsonArrayFormatter,
|
||||
"NumbersArray": NumbersArrayFormatter,
|
||||
"TextArray": TextArrayFormatter,
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
function JsonFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
function NullAndDefaultFormatter(row, cell, value, columnDef, dataContext) {
|
||||
if (_.isUndefined(value) && columnDef.has_default_val) {
|
||||
return "<span class='pull-left disabled_cell'>[default]</span>";
|
||||
return "<span class='pull-left disabled_cell'>[default]</span>";
|
||||
}
|
||||
else if (
|
||||
(_.isUndefined(value) && columnDef.not_null) ||
|
||||
(_.isUndefined(value) || value === null)
|
||||
) {
|
||||
return "<span class='pull-left disabled_cell'>[null]</span>";
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
function NullAndDefaultNumberFormatter(row, cell, value, columnDef, dataContext) {
|
||||
if (_.isUndefined(value) && columnDef.has_default_val) {
|
||||
return "<span class='pull-right disabled_cell'>[default]</span>";
|
||||
}
|
||||
else if (
|
||||
(_.isUndefined(value) && columnDef.not_null) ||
|
||||
(_.isUndefined(value) || value === null)
|
||||
) {
|
||||
return "<span class='pull-right disabled_cell'>[null]</span>";
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
function JsonFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
var data = NullAndDefaultFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
// Stringify only if it's json object
|
||||
if (typeof value === "object" && !Array.isArray(value)) {
|
||||
@@ -48,57 +73,113 @@
|
||||
}
|
||||
}
|
||||
|
||||
function JsonArrayFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
var data = NullAndDefaultFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
var data = [];
|
||||
for (var k in value) {
|
||||
// Stringify only if it's json object
|
||||
var v = value[k];
|
||||
if (typeof v === "object" && !Array.isArray(v)) {
|
||||
return data.push(_.escape(JSON.stringify(v)));
|
||||
} else if (Array.isArray(v)) {
|
||||
var temp = [];
|
||||
$.each(v, function(i, val) {
|
||||
if (typeof val === "object") {
|
||||
temp.push(JSON.stringify(val));
|
||||
} else {
|
||||
temp.push(val)
|
||||
}
|
||||
});
|
||||
return data.push(_.escape("[" + temp.join() + "]"));
|
||||
} else {
|
||||
return data.push(_.escape(v));
|
||||
}
|
||||
}
|
||||
return '{' + data.join() + '}';
|
||||
}
|
||||
}
|
||||
|
||||
function NumbersFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
if (_.isUndefined(value) && columnDef.has_default_val) {
|
||||
return "<span class='pull-right disabled_cell'>[default]</span>";
|
||||
}
|
||||
else if (
|
||||
(_.isUndefined(value) || value === null || value === "") ||
|
||||
(_.isUndefined(value) && columnDef.not_null)
|
||||
) {
|
||||
return "<span class='pull-right disabled_cell'>[null]</span>";
|
||||
}
|
||||
else {
|
||||
var data = NullAndDefaultNumberFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
return "<span style='float:right'>" + _.escape(value) + "</span>";
|
||||
}
|
||||
}
|
||||
|
||||
function NumbersArrayFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
var data = NullAndDefaultNumberFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
data = [];
|
||||
for(var k in value) {
|
||||
if (value[k] == null) {
|
||||
data.push("<span class='disabled_cell'>[null]</span>");
|
||||
} else {
|
||||
data.push(_.escape(value[k]));
|
||||
}
|
||||
}
|
||||
return "<span style='float:right'>{" + data.join() + "}</span>";
|
||||
}
|
||||
}
|
||||
|
||||
function CheckmarkFormatter(row, cell, value, columnDef, dataContext) {
|
||||
/* Checkbox has 3 states
|
||||
* 1) checked=true
|
||||
* 2) unchecked=false
|
||||
* 3) indeterminate=null
|
||||
*/
|
||||
if (_.isUndefined(value) && columnDef.has_default_val) {
|
||||
return "<span class='pull-left disabled_cell'>[default]</span>";
|
||||
var data = NullAndDefaultFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
return value ? "true" : "false";
|
||||
}
|
||||
else if (
|
||||
(_.isUndefined(value) && columnDef.not_null) ||
|
||||
(value == null || value === "")
|
||||
) {
|
||||
return "<span class='pull-left disabled_cell'>[null]</span>";
|
||||
}
|
||||
return value ? "true" : "false";
|
||||
}
|
||||
|
||||
function TextFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
if (_.isUndefined(value) && columnDef.has_default_val) {
|
||||
return "<span class='pull-left disabled_cell'>[default]</span>";
|
||||
}
|
||||
else if (
|
||||
(_.isUndefined(value) && columnDef.not_null) ||
|
||||
(_.isUndefined(value) || _.isNull(value))
|
||||
) {
|
||||
return "<span class='pull-left disabled_cell'>[null]</span>";
|
||||
} else if(columnDef.column_type_internal == 'bytea' ||
|
||||
columnDef.column_type_internal == 'bytea[]') {
|
||||
return "<span class='pull-left disabled_cell'>[" + _.escape(value) + "]</span>";
|
||||
}
|
||||
else {
|
||||
var data = NullAndDefaultFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
return _.escape(value);
|
||||
}
|
||||
}
|
||||
|
||||
function TextArrayFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
var data = NullAndDefaultFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
data = [];
|
||||
for(var k in value) {
|
||||
if (value[k] === null) {
|
||||
data.push("<span class='disabled_cell'>[null]</span>");
|
||||
} else {
|
||||
data.push(_.escape(value[k]));
|
||||
}
|
||||
}
|
||||
return "{" + data.join() + "}";
|
||||
}
|
||||
}
|
||||
|
||||
function BinaryFormatter(row, cell, value, columnDef, dataContext) {
|
||||
// If column has default value, set placeholder
|
||||
var data = NullAndDefaultFormatter(row, cell, value, columnDef, dataContext);
|
||||
if (data) {
|
||||
return data;
|
||||
} else {
|
||||
return "<span class='pull-left disabled_cell'>[" + _.escape(value) + "]</span>";
|
||||
}
|
||||
}
|
||||
})(jQuery);
|
||||
|
||||
Reference in New Issue
Block a user