mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-02-20 11:48:31 -06:00
102 lines
3.0 KiB
JavaScript
102 lines
3.0 KiB
JavaScript
/***
|
|
* Contains pgAdmin4 related SlickGrid formatters.
|
|
*
|
|
* @module Formatters
|
|
* @namespace Slick
|
|
*/
|
|
|
|
(function ($) {
|
|
// register namespace
|
|
$.extend(true, window, {
|
|
"Slick": {
|
|
"Formatters": {
|
|
"JsonString": JsonFormatter,
|
|
"Numbers": NumbersFormatter,
|
|
"Checkmark": CheckmarkFormatter,
|
|
"Text": TextFormatter,
|
|
}
|
|
}
|
|
});
|
|
|
|
function JsonFormatter(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) || value === null)
|
|
) {
|
|
return "<span class='pull-left disabled_cell'>[null]</span>";
|
|
} else {
|
|
// Stringify only if it's json object
|
|
if (typeof value === "object" && !Array.isArray(value)) {
|
|
return _.escape(JSON.stringify(value));
|
|
} else if (Array.isArray(value)) {
|
|
var temp = [];
|
|
$.each(value, function(i, val) {
|
|
if (typeof val === "object") {
|
|
temp.push(JSON.stringify(val));
|
|
} else {
|
|
temp.push(val)
|
|
}
|
|
});
|
|
return _.escape("[" + temp.join() + "]")
|
|
} else {
|
|
return _.escape(value);
|
|
}
|
|
}
|
|
}
|
|
|
|
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 {
|
|
return "<span style='float:right'>" + _.escape(value) + "</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>";
|
|
}
|
|
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 {
|
|
return _.escape(value);
|
|
}
|
|
}
|
|
|
|
})(jQuery);
|