Fixed code smell 'Update this function so that its implementation is not identical' reported by SonarQube.
parent
094129e2be
commit
0ce3434631
|
@ -29,6 +29,16 @@ export default class CastSchema extends BaseUISchema {
|
||||||
return 'oid';
|
return 'oid';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getCastName(state) {
|
||||||
|
var srctype = state.srctyp;
|
||||||
|
var trgtype = state.trgtyp;
|
||||||
|
if(srctype != undefined && srctype != '' &&
|
||||||
|
trgtype != undefined && trgtype != '')
|
||||||
|
return state.name = srctype+'->'+trgtype;
|
||||||
|
else
|
||||||
|
return state.name = '';
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -53,13 +63,7 @@ export default class CastSchema extends BaseUISchema {
|
||||||
* target type are set, if yes then fetch values from both
|
* target type are set, if yes then fetch values from both
|
||||||
* controls and generate cast name
|
* controls and generate cast name
|
||||||
*/
|
*/
|
||||||
var srctype = state.srctyp;
|
return obj.getCastName(state);
|
||||||
var trgtype = state.trgtyp;
|
|
||||||
if(srctype != undefined && srctype != '' &&
|
|
||||||
trgtype != undefined && trgtype != '')
|
|
||||||
return state.name = srctype+'->'+trgtype;
|
|
||||||
else
|
|
||||||
return state.name = '';
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -83,13 +87,7 @@ export default class CastSchema extends BaseUISchema {
|
||||||
* target type are set, if yes then fetch values from both
|
* target type are set, if yes then fetch values from both
|
||||||
* controls and generate cast name
|
* controls and generate cast name
|
||||||
*/
|
*/
|
||||||
var srctype = state.srctyp;
|
return obj.getCastName(state);
|
||||||
var trgtype = state.trgtyp;
|
|
||||||
if(srctype != undefined && srctype != '' &&
|
|
||||||
trgtype != undefined && trgtype != '')
|
|
||||||
return state.name = srctype+'->'+trgtype;
|
|
||||||
else
|
|
||||||
return state.name = '';
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -66,18 +66,7 @@ export default class FTSParserSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -93,18 +82,7 @@ export default class FTSParserSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -120,18 +98,7 @@ export default class FTSParserSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -147,18 +114,7 @@ export default class FTSParserSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -174,18 +130,7 @@ export default class FTSParserSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -66,18 +66,7 @@ export default class FTSTemplateSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -96,18 +85,7 @@ export default class FTSTemplateSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -147,6 +147,10 @@ export default class ColumnSchema extends BaseUISchema {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
attCell(state) {
|
||||||
|
return { cell: this.attlenRange(state) ? 'int' : '' };
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
|
|
||||||
|
@ -281,9 +285,7 @@ export default class ColumnSchema extends BaseUISchema {
|
||||||
id: 'attlen', label: gettext('Length/Precision'),
|
id: 'attlen', label: gettext('Length/Precision'),
|
||||||
deps: ['cltype'], type: 'int', group: gettext('Definition'), width: 120, disableResizing: true,
|
deps: ['cltype'], type: 'int', group: gettext('Definition'), width: 120, disableResizing: true,
|
||||||
cell: (state)=>{
|
cell: (state)=>{
|
||||||
return {
|
return obj.attCell(state);
|
||||||
cell: obj.attlenRange(state) ? 'int' : '',
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
depChange: (state)=>{
|
depChange: (state)=>{
|
||||||
let range = this.attlenRange(state);
|
let range = this.attlenRange(state);
|
||||||
|
@ -311,9 +313,7 @@ export default class ColumnSchema extends BaseUISchema {
|
||||||
id: 'attprecision', label: gettext('Scale'), width: 60, disableResizing: true,
|
id: 'attprecision', label: gettext('Scale'), width: 60, disableResizing: true,
|
||||||
deps: ['cltype'], type: 'int', group: gettext('Definition'),
|
deps: ['cltype'], type: 'int', group: gettext('Definition'),
|
||||||
cell: (state)=>{
|
cell: (state)=>{
|
||||||
return {
|
return obj.attCell(state);
|
||||||
cell: obj.attlenRange(state) ? 'int' : '',
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
depChange: (state)=>{
|
depChange: (state)=>{
|
||||||
let range = this.attprecisionRange(state);
|
let range = this.attprecisionRange(state);
|
||||||
|
|
|
@ -8,6 +8,16 @@ import { getNodeAjaxOptions, getNodeListByName } from '../../../../../../../../.
|
||||||
import TableSchema from '../../../../static/js/table.ui';
|
import TableSchema from '../../../../static/js/table.ui';
|
||||||
import Notify from '../../../../../../../../../../static/js/helpers/Notifier';
|
import Notify from '../../../../../../../../../../static/js/helpers/Notifier';
|
||||||
|
|
||||||
|
function getData(data) {
|
||||||
|
let res = [];
|
||||||
|
if (data && _.isArray(data)) {
|
||||||
|
_.each(data, function(d) {
|
||||||
|
res.push({label: d[0], value: d[1]});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
export function getNodeExclusionConstraintSchema(treeNodeInfo, itemNodeData, pgBrowser, noColumns=false) {
|
export function getNodeExclusionConstraintSchema(treeNodeInfo, itemNodeData, pgBrowser, noColumns=false) {
|
||||||
let tableNode = pgBrowser.Nodes['table'];
|
let tableNode = pgBrowser.Nodes['table'];
|
||||||
return new ExclusionConstraintSchema({
|
return new ExclusionConstraintSchema({
|
||||||
|
@ -17,22 +27,10 @@ export function getNodeExclusionConstraintSchema(treeNodeInfo, itemNodeData, pgB
|
||||||
return (m.label != 'pg_global');
|
return (m.label != 'pg_global');
|
||||||
}),
|
}),
|
||||||
getOperClass: (urlParams)=>getNodeAjaxOptions('get_oper_class', tableNode, treeNodeInfo, itemNodeData, {urlParams: urlParams, useCache:false}, (data)=>{
|
getOperClass: (urlParams)=>getNodeAjaxOptions('get_oper_class', tableNode, treeNodeInfo, itemNodeData, {urlParams: urlParams, useCache:false}, (data)=>{
|
||||||
let res = [];
|
return getData(data);
|
||||||
if (data && _.isArray(data)) {
|
|
||||||
_.each(data, function(d) {
|
|
||||||
res.push({label: d[0], value: d[1]});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}),
|
}),
|
||||||
getOperator: (urlParams)=>getNodeAjaxOptions('get_operator', tableNode, treeNodeInfo, itemNodeData, {urlParams: urlParams, useCache:false}, (data)=>{
|
getOperator: (urlParams)=>getNodeAjaxOptions('get_operator', tableNode, treeNodeInfo, itemNodeData, {urlParams: urlParams, useCache:false}, (data)=>{
|
||||||
let res = [];
|
return getData(data);
|
||||||
if (data && _.isArray(data)) {
|
|
||||||
_.each(data, function(d) {
|
|
||||||
res.push({label: d[0], value: d[1]});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}),
|
}),
|
||||||
}, treeNodeInfo);
|
}, treeNodeInfo);
|
||||||
}
|
}
|
||||||
|
|
|
@ -126,6 +126,49 @@ define('pgadmin.node.primary_key', [
|
||||||
include: [],
|
include: [],
|
||||||
},
|
},
|
||||||
|
|
||||||
|
genResetColOptions: function() {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
self.custom_options();
|
||||||
|
self.render.apply(self);
|
||||||
|
}, 50);
|
||||||
|
},
|
||||||
|
|
||||||
|
genCustomOptions: function() {
|
||||||
|
// We will add all the columns entered by user in table model
|
||||||
|
var columns = this.model.top.get('columns'),
|
||||||
|
added_columns_from_tables = [];
|
||||||
|
|
||||||
|
if (columns.length > 0) {
|
||||||
|
_.each(columns.models, function(m) {
|
||||||
|
var col = m.get('name');
|
||||||
|
if(!_.isUndefined(col) && !_.isNull(col)) {
|
||||||
|
added_columns_from_tables.push(
|
||||||
|
{label: col, value: col, image:'icon-column'}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// Set the values in to options so that user can select
|
||||||
|
this.field.set('options', added_columns_from_tables);
|
||||||
|
},
|
||||||
|
checkReadOnly(m) {
|
||||||
|
// If we are in table edit mode then
|
||||||
|
if (_.has(m, 'top') && !_.isUndefined(m.top)
|
||||||
|
&& !m.top.isNew()) {
|
||||||
|
// If OID is undefined then user is trying to add
|
||||||
|
// new constraint which should be allowed for Unique
|
||||||
|
return !_.isUndefined(m.get('oid'));
|
||||||
|
}
|
||||||
|
|
||||||
|
// We can't update columns of existing index constraint.
|
||||||
|
if (!m.isNew()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
},
|
||||||
// Define the schema for the index constraint node
|
// Define the schema for the index constraint node
|
||||||
schema: [{
|
schema: [{
|
||||||
id: 'name', label: gettext('Name'), type: 'text',
|
id: 'name', label: gettext('Name'), type: 'text',
|
||||||
|
@ -294,30 +337,10 @@ define('pgadmin.node.primary_key', [
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
resetColOptions: function() {
|
resetColOptions: function() {
|
||||||
var self = this;
|
this.genResetColOptions();
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
self.custom_options();
|
|
||||||
self.render.apply(self);
|
|
||||||
}, 50);
|
|
||||||
},
|
},
|
||||||
custom_options: function() {
|
custom_options: function() {
|
||||||
// We will add all the columns entered by user in table model
|
this.genCustomOptions();
|
||||||
var columns = this.model.top.get('columns'),
|
|
||||||
added_columns_from_tables = [];
|
|
||||||
|
|
||||||
if (columns.length > 0) {
|
|
||||||
_.each(columns.models, function(m) {
|
|
||||||
var col = m.get('name');
|
|
||||||
if(!_.isUndefined(col) && !_.isNull(col)) {
|
|
||||||
added_columns_from_tables.push(
|
|
||||||
{label: col, value: col, image:'icon-column'}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
// Set the values in to options so that user can select
|
|
||||||
this.field.set('options', added_columns_from_tables);
|
|
||||||
},
|
},
|
||||||
onChange: function() {
|
onChange: function() {
|
||||||
var self = this,
|
var self = this,
|
||||||
|
@ -412,18 +435,7 @@ define('pgadmin.node.primary_key', [
|
||||||
},
|
},
|
||||||
select2:{allowClear:false},
|
select2:{allowClear:false},
|
||||||
readonly: function(m) {
|
readonly: function(m) {
|
||||||
// If we are in table edit mode then
|
return this.checkReadOnly(m);
|
||||||
if (_.has(m, 'top') && !_.isUndefined(m.top)
|
|
||||||
&& !m.top.isNew()) {
|
|
||||||
// If OID is undefined then user is trying to add
|
|
||||||
// new constraint which should be allowed for Unique
|
|
||||||
return !_.isUndefined(m.get('oid'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// We can't update columns of existing index constraint.
|
|
||||||
if (!m.isNew()) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(m) {
|
disabled: function(m) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -477,46 +489,15 @@ define('pgadmin.node.primary_key', [
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
resetColOptions: function() {
|
resetColOptions: function() {
|
||||||
var self = this;
|
this.genResetColOptions();
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
self.custom_options();
|
|
||||||
self.render.apply(self);
|
|
||||||
}, 50);
|
|
||||||
},
|
},
|
||||||
custom_options: function() {
|
custom_options: function() {
|
||||||
// We will add all the columns entered by user in table model
|
this.genCustomOptions();
|
||||||
var columns = this.model.top.get('columns'),
|
|
||||||
added_columns_from_tables = [];
|
|
||||||
|
|
||||||
if (columns.length > 0) {
|
|
||||||
_.each(columns.models, function(m) {
|
|
||||||
var col = m.get('name');
|
|
||||||
if(!_.isUndefined(col) && !_.isNull(col)) {
|
|
||||||
added_columns_from_tables.push(
|
|
||||||
{label: col, value: col, image:'icon-column'}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
// Set the values in to options so that user can select
|
|
||||||
this.field.set('options', added_columns_from_tables);
|
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
deps: ['index'], node: 'column',
|
deps: ['index'], node: 'column',
|
||||||
readonly: function(m) {
|
readonly: function(m) {
|
||||||
// If we are in table edit mode then
|
return this.checkReadOnly(m);
|
||||||
if (_.has(m, 'top') && !_.isUndefined(m.top)
|
|
||||||
&& !m.top.isNew()) {
|
|
||||||
// If OID is undefined then user is trying to add
|
|
||||||
// new constraint which should be allowed for Unique
|
|
||||||
return !_.isUndefined(m.get('oid'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// We can't update columns of existing index constraint.
|
|
||||||
if (!m.isNew()) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(m) {
|
disabled: function(m) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -596,18 +577,7 @@ define('pgadmin.node.primary_key', [
|
||||||
id: 'condeferrable', label: gettext('Deferrable?'),
|
id: 'condeferrable', label: gettext('Deferrable?'),
|
||||||
type: 'switch', group: gettext('Definition'), deps: ['index'],
|
type: 'switch', group: gettext('Definition'), deps: ['index'],
|
||||||
readonly: function(m) {
|
readonly: function(m) {
|
||||||
// If we are in table edit mode then
|
return this.checkReadOnly(m);
|
||||||
if (_.has(m, 'top') && !_.isUndefined(m.top)
|
|
||||||
&& !m.top.isNew()) {
|
|
||||||
// If OID is undefined then user is trying to add
|
|
||||||
// new constraint which should allowed for Unique
|
|
||||||
return !_.isUndefined(m.get('oid'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// We can't update condeferrable of existing index constraint.
|
|
||||||
if (!m.isNew()) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(m) {
|
disabled: function(m) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -627,18 +597,7 @@ define('pgadmin.node.primary_key', [
|
||||||
type: 'switch', group: gettext('Definition'),
|
type: 'switch', group: gettext('Definition'),
|
||||||
deps: ['condeferrable'],
|
deps: ['condeferrable'],
|
||||||
readonly: function(m) {
|
readonly: function(m) {
|
||||||
// If we are in table edit mode then
|
return this.checkReadOnly(m);
|
||||||
if (_.has(m, 'top') && !_.isUndefined(m.top)
|
|
||||||
&& !m.top.isNew()) {
|
|
||||||
// If OID is undefined then user is trying to add
|
|
||||||
// new constraint which should allowed for Unique
|
|
||||||
return !_.isUndefined(m.get('oid'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// We can't update condeferred of existing index constraint.
|
|
||||||
if (!m.isNew()) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(m) {
|
disabled: function(m) {
|
||||||
// Disable if condeferred is false or unselected.
|
// Disable if condeferred is false or unselected.
|
||||||
|
|
|
@ -158,9 +158,7 @@ export default class PrimaryKeySchema extends BaseUISchema {
|
||||||
},
|
},
|
||||||
deps: ['index'],
|
deps: ['index'],
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -225,10 +223,7 @@ export default class PrimaryKeySchema extends BaseUISchema {
|
||||||
id: 'condeferrable', label: gettext('Deferrable?'),
|
id: 'condeferrable', label: gettext('Deferrable?'),
|
||||||
type: 'switch', group: gettext('Definition'), deps: ['index'],
|
type: 'switch', group: gettext('Definition'), deps: ['index'],
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -246,10 +241,7 @@ export default class PrimaryKeySchema extends BaseUISchema {
|
||||||
type: 'switch', group: gettext('Definition'),
|
type: 'switch', group: gettext('Definition'),
|
||||||
deps: ['condeferrable'],
|
deps: ['condeferrable'],
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
|
|
@ -130,9 +130,7 @@ export default class UniqueConstraintSchema extends BaseUISchema {
|
||||||
}), group: gettext('Definition'),
|
}), group: gettext('Definition'),
|
||||||
editable: false,
|
editable: false,
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -161,9 +159,7 @@ export default class UniqueConstraintSchema extends BaseUISchema {
|
||||||
},
|
},
|
||||||
deps: ['index'],
|
deps: ['index'],
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -228,10 +224,7 @@ export default class UniqueConstraintSchema extends BaseUISchema {
|
||||||
id: 'condeferrable', label: gettext('Deferrable?'),
|
id: 'condeferrable', label: gettext('Deferrable?'),
|
||||||
type: 'switch', group: gettext('Definition'), deps: ['index'],
|
type: 'switch', group: gettext('Definition'), deps: ['index'],
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
@ -249,10 +242,7 @@ export default class UniqueConstraintSchema extends BaseUISchema {
|
||||||
type: 'switch', group: gettext('Definition'),
|
type: 'switch', group: gettext('Definition'),
|
||||||
deps: ['condeferrable'],
|
deps: ['condeferrable'],
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(!obj.isNew(state)) {
|
return obj.isReadOnly(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
// Disable if index is selected.
|
// Disable if index is selected.
|
||||||
|
|
|
@ -75,6 +75,19 @@ export class ColumnSchema extends BaseUISchema {
|
||||||
this.op_class_types = options;
|
this.op_class_types = options;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isEditable(state) {
|
||||||
|
let topObj = this._top;
|
||||||
|
if(this.inSchemaWithModelCheck(state)) {
|
||||||
|
return false;
|
||||||
|
} else if (topObj._sessData && topObj._sessData.amname === 'btree') {
|
||||||
|
state.is_sort_nulls_applicable = true;
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
state.is_sort_nulls_applicable = false;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let columnSchemaObj = this;
|
let columnSchemaObj = this;
|
||||||
return [
|
return [
|
||||||
|
@ -161,31 +174,13 @@ export class ColumnSchema extends BaseUISchema {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
let topObj = columnSchemaObj._top;
|
return columnSchemaObj.isEditable(state);
|
||||||
if(columnSchemaObj.inSchemaWithModelCheck(state)) {
|
|
||||||
return false;
|
|
||||||
} else if (topObj._sessData && topObj._sessData.amname === 'btree') {
|
|
||||||
state.is_sort_nulls_applicable = true;
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
state.is_sort_nulls_applicable = false;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
deps: ['amname'],
|
deps: ['amname'],
|
||||||
},{
|
},{
|
||||||
id: 'nulls', label: gettext('NULLs'),
|
id: 'nulls', label: gettext('NULLs'),
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
let topObj = columnSchemaObj._top;
|
return columnSchemaObj.isEditable(state);
|
||||||
if(columnSchemaObj.inSchemaWithModelCheck(state)) {
|
|
||||||
return false;
|
|
||||||
} else if (topObj._sessData && topObj._sessData.amname === 'btree') {
|
|
||||||
state.is_sort_nulls_applicable = true;
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
state.is_sort_nulls_applicable = false;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
deps: ['amname', 'sort_order'],
|
deps: ['amname', 'sort_order'],
|
||||||
type:'select', cell: 'select',
|
type:'select', cell: 'select',
|
||||||
|
@ -237,6 +232,39 @@ export default class IndexSchema extends BaseUISchema {
|
||||||
return 'oid';
|
return 'oid';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getColumns() {
|
||||||
|
return {
|
||||||
|
type: 'select',
|
||||||
|
options: this.fieldOptions.columnList,
|
||||||
|
optionsLoaded: (options) => { this.fieldOptions.columnList = options; },
|
||||||
|
controlProps: {
|
||||||
|
allowClear: false,
|
||||||
|
multiple: true,
|
||||||
|
placeholder: gettext('Select the column(s)'),
|
||||||
|
width: 'style',
|
||||||
|
filter: (options) => {
|
||||||
|
let res = [];
|
||||||
|
if (options && _.isArray(options)) {
|
||||||
|
_.each(options, function(d) {
|
||||||
|
if(d.label != '')
|
||||||
|
res.push({label: d.label, value: d.value, image:'icon-column'});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
isVisible() {
|
||||||
|
if(!_.isUndefined(this.node_info) && !_.isUndefined(this.node_info.server)
|
||||||
|
&& !_.isUndefined(this.node_info.server.version) &&
|
||||||
|
this.node_info.server.version >= 110000)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let indexSchemaObj = this;
|
let indexSchemaObj = this;
|
||||||
return [
|
return [
|
||||||
|
@ -324,35 +352,10 @@ export default class IndexSchema extends BaseUISchema {
|
||||||
return !indexSchemaObj.isNew(state);
|
return !indexSchemaObj.isNew(state);
|
||||||
},
|
},
|
||||||
type: () => {
|
type: () => {
|
||||||
return {
|
return indexSchemaObj.getColumns();
|
||||||
type: 'select',
|
|
||||||
options: indexSchemaObj.fieldOptions.columnList,
|
|
||||||
optionsLoaded: (options) => { indexSchemaObj.fieldOptions.columnList = options; },
|
|
||||||
controlProps: {
|
|
||||||
allowClear: false,
|
|
||||||
multiple: true,
|
|
||||||
placeholder: gettext('Select the column(s)'),
|
|
||||||
width: 'style',
|
|
||||||
filter: (options) => {
|
|
||||||
let res = [];
|
|
||||||
if (options && _.isArray(options)) {
|
|
||||||
_.each(options, function(d) {
|
|
||||||
if(d.label != '')
|
|
||||||
res.push({label: d.label, value: d.value, image:'icon-column'});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
visible: function() {
|
visible: function() {
|
||||||
if(!_.isUndefined(this.node_info) && !_.isUndefined(this.node_info.server)
|
return indexSchemaObj.isVisible();
|
||||||
&& !_.isUndefined(this.node_info.server.version) &&
|
|
||||||
this.node_info.server.version >= 110000)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
node:'column',
|
node:'column',
|
||||||
},{
|
},{
|
||||||
|
@ -416,27 +419,7 @@ export default class IndexSchema extends BaseUISchema {
|
||||||
}, {
|
}, {
|
||||||
id: 'include', label: gettext('Include columns'),
|
id: 'include', label: gettext('Include columns'),
|
||||||
type: () => {
|
type: () => {
|
||||||
return {
|
return indexSchemaObj.getColumns();
|
||||||
type: 'select',
|
|
||||||
options: indexSchemaObj.fieldOptions.columnList,
|
|
||||||
optionsLoaded: (options) => { indexSchemaObj.fieldOptions.columnList = options; },
|
|
||||||
controlProps: {
|
|
||||||
allowClear: false,
|
|
||||||
multiple: true,
|
|
||||||
placeholder: gettext('Select the column(s)'),
|
|
||||||
width: 'style',
|
|
||||||
filter: (options) => {
|
|
||||||
let res = [];
|
|
||||||
if (options && _.isArray(options)) {
|
|
||||||
_.each(options, function(d) {
|
|
||||||
if(d.label != '')
|
|
||||||
res.push({label: d.label, value: d.value, image:'icon-column'});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
group: gettext('Definition'),
|
group: gettext('Definition'),
|
||||||
editable: false,
|
editable: false,
|
||||||
|
@ -446,12 +429,7 @@ export default class IndexSchema extends BaseUISchema {
|
||||||
return !indexSchemaObj.isNew(state);
|
return !indexSchemaObj.isNew(state);
|
||||||
},
|
},
|
||||||
visible: function() {
|
visible: function() {
|
||||||
if(!_.isUndefined(this.node_info) && !_.isUndefined(this.node_info.server)
|
return indexSchemaObj.isVisible();
|
||||||
&& !_.isUndefined(this.node_info.server.version) &&
|
|
||||||
this.node_info.server.version >= 110000)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
node:'column',
|
node:'column',
|
||||||
},{
|
},{
|
||||||
|
|
|
@ -127,6 +127,21 @@ function(
|
||||||
encodeURIComponent(info['partition']._id)
|
encodeURIComponent(info['partition']._id)
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
on_done: function(res, data, t, i) {
|
||||||
|
if (res.success == 1) {
|
||||||
|
Notify.success(res.info);
|
||||||
|
t.removeIcon(i);
|
||||||
|
data.icon = 'icon-partition';
|
||||||
|
t.addIcon(i, {icon: data.icon});
|
||||||
|
t.unload(i);
|
||||||
|
t.setInode(i);
|
||||||
|
t.deselect(i);
|
||||||
|
// Fetch updated data from server
|
||||||
|
setTimeout(function() {
|
||||||
|
t.select(i);
|
||||||
|
}, 10);
|
||||||
|
}
|
||||||
|
},
|
||||||
canDrop: SchemaChildTreeNode.isTreeItemOfChildOfSchema,
|
canDrop: SchemaChildTreeNode.isTreeItemOfChildOfSchema,
|
||||||
canDropCascade: SchemaChildTreeNode.isTreeItemOfChildOfSchema,
|
canDropCascade: SchemaChildTreeNode.isTreeItemOfChildOfSchema,
|
||||||
callbacks: {
|
callbacks: {
|
||||||
|
@ -197,35 +212,22 @@ function(
|
||||||
Notify.confirm(
|
Notify.confirm(
|
||||||
gettext('Truncate Table'),
|
gettext('Truncate Table'),
|
||||||
gettext('Are you sure you want to truncate table %s?', d.label),
|
gettext('Are you sure you want to truncate table %s?', d.label),
|
||||||
function (e) {
|
function () {
|
||||||
if (e) {
|
var data = d;
|
||||||
var data = d;
|
$.ajax({
|
||||||
$.ajax({
|
url: obj.generate_url(i, 'truncate' , d, true),
|
||||||
url: obj.generate_url(i, 'truncate' , d, true),
|
type:'PUT',
|
||||||
type:'PUT',
|
data: params,
|
||||||
data: params,
|
dataType: 'json',
|
||||||
dataType: 'json',
|
})
|
||||||
|
.done(function(res) {
|
||||||
|
obj.on_done(res, data, t, i);
|
||||||
})
|
})
|
||||||
.done(function(res) {
|
.fail(function(xhr, status, error) {
|
||||||
if (res.success == 1) {
|
Notify.pgRespErrorNotify(xhr, error);
|
||||||
Notify.success(res.info);
|
t.unload(i);
|
||||||
t.removeIcon(i);
|
});
|
||||||
data.icon = 'icon-partition';
|
},
|
||||||
t.addIcon(i, {icon: data.icon});
|
|
||||||
t.unload(i);
|
|
||||||
t.setInode(i);
|
|
||||||
t.deselect(i);
|
|
||||||
// Fetch updated data from server
|
|
||||||
setTimeout(function() {
|
|
||||||
t.select(i);
|
|
||||||
}, 10);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.fail(function(xhr, status, error) {
|
|
||||||
Notify.pgRespErrorNotify(xhr, error);
|
|
||||||
t.unload(i);
|
|
||||||
});
|
|
||||||
}},
|
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
reset_table_stats: function(args) {
|
reset_table_stats: function(args) {
|
||||||
|
@ -241,33 +243,19 @@ function(
|
||||||
Notify.confirm(
|
Notify.confirm(
|
||||||
gettext('Reset statistics'),
|
gettext('Reset statistics'),
|
||||||
gettext('Are you sure you want to reset the statistics for table "%s"?', d._label),
|
gettext('Are you sure you want to reset the statistics for table "%s"?', d._label),
|
||||||
function (e) {
|
function () {
|
||||||
if (e) {
|
var data = d;
|
||||||
var data = d;
|
$.ajax({
|
||||||
$.ajax({
|
url: obj.generate_url(i, 'reset' , d, true),
|
||||||
url: obj.generate_url(i, 'reset' , d, true),
|
type:'DELETE',
|
||||||
type:'DELETE',
|
})
|
||||||
|
.done(function(res) {
|
||||||
|
obj.on_done(res, data, t, i);
|
||||||
})
|
})
|
||||||
.done(function(res) {
|
.fail(function(xhr, status, error) {
|
||||||
if (res.success == 1) {
|
Notify.pgRespErrorNotify(xhr, error);
|
||||||
Notify.success(res.info);
|
t.unload(i);
|
||||||
t.removeIcon(i);
|
});
|
||||||
data.icon = 'icon-partition';
|
|
||||||
t.addIcon(i, {icon: data.icon});
|
|
||||||
t.unload(i);
|
|
||||||
t.setInode(i);
|
|
||||||
t.deselect(i);
|
|
||||||
// Fetch updated data from server
|
|
||||||
setTimeout(function() {
|
|
||||||
t.select(i);
|
|
||||||
}, 10);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.fail(function(xhr, status, error) {
|
|
||||||
Notify.pgRespErrorNotify(xhr, error);
|
|
||||||
t.unload(i);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
function() {/*This is intentional (SonarQube)*/}
|
function() {/*This is intentional (SonarQube)*/}
|
||||||
);
|
);
|
||||||
|
@ -285,32 +273,30 @@ function(
|
||||||
Notify.confirm(
|
Notify.confirm(
|
||||||
gettext('Detach Partition'),
|
gettext('Detach Partition'),
|
||||||
gettext('Are you sure you want to detach the partition %s?', d._label),
|
gettext('Are you sure you want to detach the partition %s?', d._label),
|
||||||
function (e) {
|
function () {
|
||||||
if (e) {
|
$.ajax({
|
||||||
$.ajax({
|
url: obj.generate_url(i, 'detach' , d, true),
|
||||||
url: obj.generate_url(i, 'detach' , d, true),
|
type:'PUT',
|
||||||
type:'PUT',
|
})
|
||||||
})
|
.done(function(res) {
|
||||||
.done(function(res) {
|
if (res.success == 1) {
|
||||||
if (res.success == 1) {
|
Notify.success(res.info);
|
||||||
Notify.success(res.info);
|
var n = t.next(i);
|
||||||
var n = t.next(i);
|
if (!n) {
|
||||||
|
n = t.prev(i);
|
||||||
if (!n) {
|
if (!n) {
|
||||||
n = t.prev(i);
|
n = t.parent(i);
|
||||||
if (!n) {
|
|
||||||
n = t.parent(i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
t.remove(i);
|
|
||||||
if (n) {
|
|
||||||
t.select(n);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
t.remove(i);
|
||||||
.fail(function(xhr, status, error) {
|
if (n) {
|
||||||
Notify.pgRespErrorNotify(xhr, error);
|
t.select(n);
|
||||||
});
|
}
|
||||||
}
|
}
|
||||||
|
})
|
||||||
|
.fail(function(xhr, status, error) {
|
||||||
|
Notify.pgRespErrorNotify(xhr, error);
|
||||||
|
});
|
||||||
},
|
},
|
||||||
function() {/*This is intentional (SonarQube)*/}
|
function() {/*This is intentional (SonarQube)*/}
|
||||||
);
|
);
|
||||||
|
|
|
@ -18,6 +18,13 @@ export class PartitionKeysSchema extends BaseUISchema {
|
||||||
this.columns = columns;
|
this.columns = columns;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isEditable(state) {
|
||||||
|
if(state.key_type == 'expression') {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -47,10 +54,7 @@ export class PartitionKeysSchema extends BaseUISchema {
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(state.key_type == 'expression') {
|
return obj.isEditable(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
},{
|
},{
|
||||||
id: 'expression', label: gettext('Expression'), type:'text',
|
id: 'expression', label: gettext('Expression'), type:'text',
|
||||||
|
@ -73,10 +77,7 @@ export class PartitionKeysSchema extends BaseUISchema {
|
||||||
type: 'select', group: gettext('partition'), deps:['key_type'],
|
type: 'select', group: gettext('partition'), deps:['key_type'],
|
||||||
options: obj.getCollations, mode: ['create', 'properties', 'edit'],
|
options: obj.getCollations, mode: ['create', 'properties', 'edit'],
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(state.key_type == 'expression') {
|
return obj.isEditable(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
disabled: ()=>{return !(obj.isNew()); },
|
disabled: ()=>{return !(obj.isNew()); },
|
||||||
},
|
},
|
||||||
|
@ -84,10 +85,7 @@ export class PartitionKeysSchema extends BaseUISchema {
|
||||||
id: 'op_class', label: gettext('Operator class'), cell: 'select',
|
id: 'op_class', label: gettext('Operator class'), cell: 'select',
|
||||||
type: 'select', group: gettext('partition'), deps:['key_type'],
|
type: 'select', group: gettext('partition'), deps:['key_type'],
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(state.key_type == 'expression') {
|
return obj.isEditable(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
disabled: ()=>{return !(obj.isNew()); },
|
disabled: ()=>{return !(obj.isNew()); },
|
||||||
options: obj.getOperatorClass, mode: ['create', 'properties', 'edit'],
|
options: obj.getOperatorClass, mode: ['create', 'properties', 'edit'],
|
||||||
|
@ -137,6 +135,22 @@ export class PartitionsSchema extends BaseUISchema {
|
||||||
this.subPartitionsObj.changeColumnOptions(columns);
|
this.subPartitionsObj.changeColumnOptions(columns);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isEditable(state, type) {
|
||||||
|
if(this.top && this.top.sessData.partition_type == type && this.isNew(state)
|
||||||
|
&& state.is_default !== true) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
isDisable(state, type) {
|
||||||
|
if(this.top && this.top.sessData.partition_type == type && this.isNew(state)
|
||||||
|
&& state.is_default !== true) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -223,68 +237,37 @@ export class PartitionsSchema extends BaseUISchema {
|
||||||
id: 'values_from', label: gettext('From'), type:'text', cell: 'text',
|
id: 'values_from', label: gettext('From'), type:'text', cell: 'text',
|
||||||
deps: ['is_default'],
|
deps: ['is_default'],
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'range' && obj.isNew(state)
|
return obj.isEditable(state, 'range');
|
||||||
&& state.is_default !== true) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'range' && obj.isNew(state)
|
return obj.isDisable(state, 'range');
|
||||||
&& state.is_default !== true) {
|
}
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'values_to', label: gettext('To'), type:'text', cell: 'text',
|
id: 'values_to', label: gettext('To'), type:'text', cell: 'text',
|
||||||
deps: ['is_default'],
|
deps: ['is_default'],
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'range' && obj.isNew(state)
|
return obj.isEditable(state, 'range');
|
||||||
&& state.is_default !== true) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'range' && obj.isNew(state)
|
return obj.isDisable(state, 'range');
|
||||||
&& state.is_default !== true) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
},{
|
},{
|
||||||
id: 'values_in', label: gettext('In'), type:'text', cell: 'text',
|
id: 'values_in', label: gettext('In'), type:'text', cell: 'text',
|
||||||
deps: ['is_default'],
|
deps: ['is_default'],
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'list' && obj.isNew(state)
|
return obj.isEditable(state, 'list');
|
||||||
&& state.is_default !== true) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
readonly: function(state) {
|
readonly: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'list' && obj.isNew(state)
|
return obj.isDisable(state, 'list');
|
||||||
&& state.is_default !== true) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
},{
|
},{
|
||||||
id: 'values_modulus', label: gettext('Modulus'), type:'int', cell: 'int',
|
id: 'values_modulus', label: gettext('Modulus'), type:'int', cell: 'int',
|
||||||
editable: function(state) {
|
editable: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'hash' && obj.isNew(state)) {
|
return obj.isEditable(state, 'hash');
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
if(obj.top && obj.top.sessData.partition_type == 'hash' && obj.isNew(state)
|
return obj.isDisable(state, 'hash');
|
||||||
&& state.is_default !== true) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
},{
|
},{
|
||||||
id: 'values_remainder', label: gettext('Remainder'), type:'int', cell: 'int',
|
id: 'values_remainder', label: gettext('Remainder'), type:'int', cell: 'int',
|
||||||
|
|
|
@ -97,6 +97,13 @@ export class ConstraintsSchema extends BaseUISchema {
|
||||||
return _.some(_.map(state.columns, 'name'));
|
return _.some(_.map(state.columns, 'name'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
canAdd(state) {
|
||||||
|
if (state.is_partitioned && this.top.getServerVersion() < 110000) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -108,10 +115,7 @@ export class ConstraintsSchema extends BaseUISchema {
|
||||||
columns : ['name', 'columns'],
|
columns : ['name', 'columns'],
|
||||||
disabled: this.inCatalog,
|
disabled: this.inCatalog,
|
||||||
canAdd: function(state) {
|
canAdd: function(state) {
|
||||||
if (state.is_partitioned && obj.top.getServerVersion() < 110000) {
|
return obj.canAdd(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
canAddRow: function(state) {
|
canAddRow: function(state) {
|
||||||
return ((state.primary_key||[]).length < 1 && obj.anyColumnAdded(state));
|
return ((state.primary_key||[]).length < 1 && obj.anyColumnAdded(state));
|
||||||
|
@ -137,10 +141,7 @@ export class ConstraintsSchema extends BaseUISchema {
|
||||||
group: gettext('Foreign Key'), mode: ['edit', 'create'],
|
group: gettext('Foreign Key'), mode: ['edit', 'create'],
|
||||||
canEdit: true, canDelete: true, deps:['is_partitioned', 'columns'],
|
canEdit: true, canDelete: true, deps:['is_partitioned', 'columns'],
|
||||||
canAdd: function(state) {
|
canAdd: function(state) {
|
||||||
if (state.is_partitioned && obj.top.getServerVersion() < 110000) {
|
return obj.canAdd(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
columns : ['name', 'columns','references_table_name'],
|
columns : ['name', 'columns','references_table_name'],
|
||||||
disabled: this.inCatalog,
|
disabled: this.inCatalog,
|
||||||
|
@ -172,10 +173,7 @@ export class ConstraintsSchema extends BaseUISchema {
|
||||||
columns : ['name', 'columns'],
|
columns : ['name', 'columns'],
|
||||||
disabled: this.inCatalog,
|
disabled: this.inCatalog,
|
||||||
canAdd: function(state) {
|
canAdd: function(state) {
|
||||||
if (state.is_partitioned && obj.top.getServerVersion() < 110000) {
|
return obj.canAdd(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
canAddRow: obj.anyColumnAdded,
|
canAddRow: obj.anyColumnAdded,
|
||||||
depChange: (state)=>{
|
depChange: (state)=>{
|
||||||
|
@ -194,10 +192,7 @@ export class ConstraintsSchema extends BaseUISchema {
|
||||||
columns : ['name', 'columns', 'constraint'],
|
columns : ['name', 'columns', 'constraint'],
|
||||||
disabled: this.inCatalog,
|
disabled: this.inCatalog,
|
||||||
canAdd: function(state) {
|
canAdd: function(state) {
|
||||||
if (state.is_partitioned && obj.top.getServerVersion() < 110000) {
|
return obj.canAdd(state);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
canAddRow: obj.anyColumnAdded,
|
canAddRow: obj.anyColumnAdded,
|
||||||
depChange: (state)=>{
|
depChange: (state)=>{
|
||||||
|
|
|
@ -188,6 +188,13 @@ export default class TriggerSchema extends BaseUISchema {
|
||||||
return flag;
|
return flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isDisable(state) {
|
||||||
|
if(!state.is_constraint_trigger) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -301,10 +308,7 @@ export default class TriggerSchema extends BaseUISchema {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
disabled: (state) => {
|
disabled: (state) => {
|
||||||
if(!state.is_constraint_trigger) {
|
return obj.isDisable(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
},{
|
},{
|
||||||
id: 'tginitdeferred', label: gettext('Deferred?'),
|
id: 'tginitdeferred', label: gettext('Deferred?'),
|
||||||
|
@ -331,10 +335,7 @@ export default class TriggerSchema extends BaseUISchema {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
disabled: (state) => {
|
disabled: (state) => {
|
||||||
if(!state.is_constraint_trigger) {
|
return obj.isDisable(state);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
},{
|
},{
|
||||||
id: 'tfunction', label: gettext('Trigger function'),
|
id: 'tfunction', label: gettext('Trigger function'),
|
||||||
|
|
|
@ -145,6 +145,13 @@ function getDataTypeSchema(nodeObj, treeNodeInfo, itemNodeData) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isVisible(state, type) {
|
||||||
|
if(state.typtype === type) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
class EnumerationSchema extends BaseUISchema {
|
class EnumerationSchema extends BaseUISchema {
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
|
@ -249,18 +256,7 @@ class RangeSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -277,18 +273,7 @@ class RangeSchema extends BaseUISchema {
|
||||||
placeholder: '',
|
placeholder: '',
|
||||||
width: '100%',
|
width: '100%',
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -336,18 +321,7 @@ class RangeSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -377,18 +351,7 @@ class RangeSchema extends BaseUISchema {
|
||||||
controlProps: {
|
controlProps: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.getFilterOptions(state, options);
|
||||||
if (state) {
|
|
||||||
options.forEach((option) => {
|
|
||||||
if(option && option.label == '') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
res.push({ label: option.label, value: option.value });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -479,6 +442,33 @@ class ExternalSchema extends BaseUISchema {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
filterFunctionOptions(state, options) {
|
||||||
|
let res = [];
|
||||||
|
if (state && this.isNew(state)) {
|
||||||
|
res = this.external_func_combo(options);
|
||||||
|
} else {
|
||||||
|
res = options;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
getFunctionType(state) {
|
||||||
|
let obj = this;
|
||||||
|
return {
|
||||||
|
type: 'select',
|
||||||
|
options: obj.fieldOptions.externalFunctionsList,
|
||||||
|
optionsLoaded: (options) => { obj.fieldOptions.externalFunctionsList = options; },
|
||||||
|
controlProps: {
|
||||||
|
allowClear: true,
|
||||||
|
placeholder: '',
|
||||||
|
width: '100%',
|
||||||
|
filter: (options) => {
|
||||||
|
return obj.filterFunctionOptions(state, options);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
var obj = this;
|
var obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -491,50 +481,14 @@ class ExternalSchema extends BaseUISchema {
|
||||||
return !obj.isNew(state);
|
return !obj.isNew(state);
|
||||||
},
|
},
|
||||||
type: (state) => {
|
type: (state) => {
|
||||||
return {
|
return obj.getFunctionType(state);
|
||||||
type: 'select',
|
|
||||||
options: obj.fieldOptions.externalFunctionsList,
|
|
||||||
optionsLoaded: (options) => { obj.fieldOptions.externalFunctionsList = options; },
|
|
||||||
controlProps: {
|
|
||||||
allowClear: true,
|
|
||||||
placeholder: '',
|
|
||||||
width: '100%',
|
|
||||||
filter: (options) => {
|
|
||||||
let res = [];
|
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
res = obj.external_func_combo(options);
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
id: 'typoutput', label: gettext('Output function'),
|
id: 'typoutput', label: gettext('Output function'),
|
||||||
mode: ['properties', 'create', 'edit'],
|
mode: ['properties', 'create', 'edit'],
|
||||||
group: gettext('Required'),
|
group: gettext('Required'),
|
||||||
type: (state) => {
|
type: (state) => {
|
||||||
return {
|
return obj.getFunctionType(state);
|
||||||
type: 'select',
|
|
||||||
options: obj.fieldOptions.externalFunctionsList,
|
|
||||||
optionsLoaded: (options) => { obj.fieldOptions.externalFunctionsList = options; },
|
|
||||||
controlProps: {
|
|
||||||
allowClear: true,
|
|
||||||
placeholder: '',
|
|
||||||
width: '100%',
|
|
||||||
filter: (options) => {
|
|
||||||
let res = [];
|
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
res = obj.external_func_combo(options);
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
readonly: function (state) {
|
readonly: function (state) {
|
||||||
return !obj.isNew(state);
|
return !obj.isNew(state);
|
||||||
|
@ -586,13 +540,7 @@ class ExternalSchema extends BaseUISchema {
|
||||||
placeholder: '',
|
placeholder: '',
|
||||||
width: '100%',
|
width: '100%',
|
||||||
filter: (options) => {
|
filter: (options) => {
|
||||||
let res = [];
|
return obj.filterFunctionOptions(state, options);
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
res = obj.external_func_combo(options);
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -705,25 +653,7 @@ class ExternalSchema extends BaseUISchema {
|
||||||
id: 'typanalyze', label: gettext('Analyze function'),
|
id: 'typanalyze', label: gettext('Analyze function'),
|
||||||
group: gettext('Optional-1'),
|
group: gettext('Optional-1'),
|
||||||
type: (state) => {
|
type: (state) => {
|
||||||
return {
|
return obj.getFunctionType(state);
|
||||||
type: 'select',
|
|
||||||
options: obj.fieldOptions.externalFunctionsList,
|
|
||||||
optionsLoaded: (options) => { obj.fieldOptions.externalFunctionsList = options; },
|
|
||||||
controlProps: {
|
|
||||||
allowClear: true,
|
|
||||||
placeholder: '',
|
|
||||||
width: '100%',
|
|
||||||
filter: (options) => {
|
|
||||||
let res = [];
|
|
||||||
if (state && obj.isNew(state)) {
|
|
||||||
res = obj.external_func_combo(options);
|
|
||||||
} else {
|
|
||||||
res = options;
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
},
|
},
|
||||||
mode: ['properties', 'create','edit'],
|
mode: ['properties', 'create','edit'],
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
|
@ -908,6 +838,14 @@ class CompositeSchema extends BaseUISchema {
|
||||||
return 'oid';
|
return 'oid';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onTypeChange(state, changeSource) {
|
||||||
|
if(_.isArray(changeSource) && changeSource[2] == 'type') {
|
||||||
|
return {...state
|
||||||
|
, value: null
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
var obj = this;
|
var obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -970,11 +908,7 @@ class CompositeSchema extends BaseUISchema {
|
||||||
id: 'precision', label: gettext('Scale'), deps: ['type'],
|
id: 'precision', label: gettext('Scale'), deps: ['type'],
|
||||||
type: 'text', disabled: false, cell: 'int',
|
type: 'text', disabled: false, cell: 'int',
|
||||||
depChange: (state, changeSource)=>{
|
depChange: (state, changeSource)=>{
|
||||||
if(_.isArray(changeSource) && changeSource[2] == 'type') {
|
return obj.onTypeChange(state, changeSource);
|
||||||
return {...state
|
|
||||||
, value: null
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
editable: (state) => {
|
editable: (state) => {
|
||||||
// We will store type from selected from combobox
|
// We will store type from selected from combobox
|
||||||
|
@ -1003,11 +937,7 @@ class CompositeSchema extends BaseUISchema {
|
||||||
}, {
|
}, {
|
||||||
id: 'collation', label: gettext('Collation'), type: 'text',
|
id: 'collation', label: gettext('Collation'), type: 'text',
|
||||||
depChange: (state, changeSource)=>{
|
depChange: (state, changeSource)=>{
|
||||||
if(_.isArray(changeSource) && changeSource[2] == 'type') {
|
return obj.onTypeChange(state, changeSource);
|
||||||
return {...state
|
|
||||||
, value: null
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
cell: ()=>({
|
cell: ()=>({
|
||||||
cell: 'select', options: obj.fieldOptions.collations,
|
cell: 'select', options: obj.fieldOptions.collations,
|
||||||
|
@ -1138,9 +1068,7 @@ class DataTypeSchema extends BaseUISchema {
|
||||||
readonly: function (state) {
|
readonly: function (state) {
|
||||||
return !dataTypeObj.isNew(state);
|
return !dataTypeObj.isNew(state);
|
||||||
},
|
},
|
||||||
visible: function (state) {
|
visible: (state) => isVisible(state, 'V'),
|
||||||
return state.typtype === 'V';
|
|
||||||
}
|
|
||||||
},{
|
},{
|
||||||
// Note: There are ambiguities in the PG catalogs and docs between
|
// Note: There are ambiguities in the PG catalogs and docs between
|
||||||
// precision and scale. In the UI, we try to follow the docs as
|
// precision and scale. In the UI, we try to follow the docs as
|
||||||
|
@ -1155,9 +1083,7 @@ class DataTypeSchema extends BaseUISchema {
|
||||||
readonly: function (state) {
|
readonly: function (state) {
|
||||||
return !dataTypeObj.isNew(state);
|
return !dataTypeObj.isNew(state);
|
||||||
},
|
},
|
||||||
visible: function (state) {
|
visible: (state) => isVisible(state, 'N'),
|
||||||
return state.typtype === 'N';
|
|
||||||
},
|
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
|
|
||||||
var of_type = state.type,
|
var of_type = state.type,
|
||||||
|
@ -1217,9 +1143,7 @@ class DataTypeSchema extends BaseUISchema {
|
||||||
return !dataTypeObj.isNew(state);
|
return !dataTypeObj.isNew(state);
|
||||||
},
|
},
|
||||||
cell: 'int',
|
cell: 'int',
|
||||||
visible: function (state) {
|
visible: (state) => isVisible(state, 'N'),
|
||||||
return state.typtype === 'N';
|
|
||||||
},
|
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
var of_type = state.type,
|
var of_type = state.type,
|
||||||
flag = true;
|
flag = true;
|
||||||
|
@ -1416,9 +1340,7 @@ export default class TypeSchema extends BaseUISchema {
|
||||||
state.composite.splice(0, state.composite.length);
|
state.composite.splice(0, state.composite.length);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
visible: (state) => {
|
visible: (state) => isVisible(state, 'c'),
|
||||||
return state.typtype === 'c';
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'enum', label: gettext('Enumeration type'),
|
id: 'enum', label: gettext('Enumeration type'),
|
||||||
|
@ -1437,9 +1359,7 @@ export default class TypeSchema extends BaseUISchema {
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
deps: ['typtype'],
|
deps: ['typtype'],
|
||||||
uniqueCol : ['label'],
|
uniqueCol : ['label'],
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'e'),
|
||||||
return state.typtype === 'e';
|
|
||||||
},
|
|
||||||
}, {
|
}, {
|
||||||
type: 'nested-fieldset',
|
type: 'nested-fieldset',
|
||||||
group: gettext('Definition'),
|
group: gettext('Definition'),
|
||||||
|
@ -1456,9 +1376,7 @@ export default class TypeSchema extends BaseUISchema {
|
||||||
group: gettext('Definition'),
|
group: gettext('Definition'),
|
||||||
label: '',
|
label: '',
|
||||||
mode: ['edit', 'create'],
|
mode: ['edit', 'create'],
|
||||||
visible: (state) => {
|
visible: (state) => isVisible(state, 'r'),
|
||||||
return state.typtype && state.typtype === 'r';
|
|
||||||
},
|
|
||||||
deps: ['typtype'],
|
deps: ['typtype'],
|
||||||
schema: obj.getRangeSchema(),
|
schema: obj.getRangeSchema(),
|
||||||
}, {
|
}, {
|
||||||
|
@ -1466,9 +1384,7 @@ export default class TypeSchema extends BaseUISchema {
|
||||||
group: gettext('Definition'),
|
group: gettext('Definition'),
|
||||||
label: gettext('External Type'), deps: ['typtype'],
|
label: gettext('External Type'), deps: ['typtype'],
|
||||||
mode: ['create', 'edit'], tabPanelExtraClasses:'inline-tab-panel-padded',
|
mode: ['create', 'edit'], tabPanelExtraClasses:'inline-tab-panel-padded',
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'b'),
|
||||||
return state.typtype === 'b';
|
|
||||||
},
|
|
||||||
schema: obj.getExternalSchema(),
|
schema: obj.getExternalSchema(),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -1480,99 +1396,54 @@ export default class TypeSchema extends BaseUISchema {
|
||||||
id: 'member_list', label: gettext('Members'), cell: 'string',
|
id: 'member_list', label: gettext('Members'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'c'),
|
||||||
if(state.typtype === 'c') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},{
|
},{
|
||||||
id: 'enum_list', label: gettext('Labels'), cell: 'string',
|
id: 'enum_list', label: gettext('Labels'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'e'),
|
||||||
if(state.typtype === 'e') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'typname', label: gettext('SubType'), cell: 'string',
|
id: 'typname', label: gettext('SubType'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'r'),
|
||||||
if(state.typtype === 'r') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'opcname', label: gettext('Subtype operator class'), cell: 'string',
|
id: 'opcname', label: gettext('Subtype operator class'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'r'),
|
||||||
if(state.typtype === 'r') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'collname', label: gettext('Collation'), cell: 'string',
|
id: 'collname', label: gettext('Collation'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'r'),
|
||||||
if(state.typtype === 'r') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'rngcanonical', label: gettext('Canonical function'), cell: 'string',
|
id: 'rngcanonical', label: gettext('Canonical function'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'r'),
|
||||||
if(state.typtype === 'r') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'rngsubdiff', label: gettext('Subtype diff function'), cell: 'string',
|
id: 'rngsubdiff', label: gettext('Subtype diff function'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'r'),
|
||||||
if(state.typtype === 'r') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'typinput', label: gettext('Input function'), cell: 'string',
|
id: 'typinput', label: gettext('Input function'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'b'),
|
||||||
if(state.typtype === 'b') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'typoutput', label: gettext('Output function'), cell: 'string',
|
id: 'typoutput', label: gettext('Output function'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'b'),
|
||||||
if(state.typtype === 'b') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'type', label: gettext('Data Type'), cell: 'string',
|
id: 'type', label: gettext('Data Type'), cell: 'string',
|
||||||
|
@ -1589,34 +1460,19 @@ export default class TypeSchema extends BaseUISchema {
|
||||||
id: 'tlength', label: gettext('Length/Precision'), cell: 'string',
|
id: 'tlength', label: gettext('Length/Precision'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'N'),
|
||||||
if(state.typtype === 'N') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'precision', label: gettext('Scale'), cell: 'string',
|
id: 'precision', label: gettext('Scale'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'N'),
|
||||||
if(state.typtype === 'N') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'maxsize', label: gettext('Size'), cell: 'string',
|
id: 'maxsize', label: gettext('Size'), cell: 'string',
|
||||||
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
type: 'text', mode: ['properties'], group: gettext('Definition'),
|
||||||
disabled: () => obj.inCatalog(),
|
disabled: () => obj.inCatalog(),
|
||||||
visible: function(state) {
|
visible: (state) => isVisible(state, 'V'),
|
||||||
if(state.typtype === 'V') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'type_acl', label: gettext('Privileges'), cell: 'string',
|
id: 'type_acl', label: gettext('Privileges'), cell: 'string',
|
||||||
|
|
|
@ -313,6 +313,10 @@ define('pgadmin.node.database', [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
getSchema: function(treeNodeInfo, itemNodeData) {
|
getSchema: function(treeNodeInfo, itemNodeData) {
|
||||||
|
let c_types = ()=>getNodeAjaxOptions('get_ctypes', this, treeNodeInfo, itemNodeData, {
|
||||||
|
cacheLevel: 'server',
|
||||||
|
});
|
||||||
|
|
||||||
return new DatabaseSchema(
|
return new DatabaseSchema(
|
||||||
()=>getNodeVariableSchema(this, treeNodeInfo, itemNodeData, false, true),
|
()=>getNodeVariableSchema(this, treeNodeInfo, itemNodeData, false, true),
|
||||||
(privileges)=>getNodePrivilegeRoleSchema(this, treeNodeInfo, itemNodeData, privileges),
|
(privileges)=>getNodePrivilegeRoleSchema(this, treeNodeInfo, itemNodeData, privileges),
|
||||||
|
@ -339,14 +343,8 @@ define('pgadmin.node.database', [
|
||||||
()=>getNodeListByName('tablespace', treeNodeInfo, itemNodeData, {}, (m)=>{
|
()=>getNodeListByName('tablespace', treeNodeInfo, itemNodeData, {}, (m)=>{
|
||||||
return (m.label != 'pg_global');
|
return (m.label != 'pg_global');
|
||||||
}),
|
}),
|
||||||
datcollate:
|
datcollate: c_types,
|
||||||
()=>getNodeAjaxOptions('get_ctypes', this, treeNodeInfo, itemNodeData, {
|
datctype: c_types,
|
||||||
cacheLevel: 'server',
|
|
||||||
}),
|
|
||||||
datctype:
|
|
||||||
()=>getNodeAjaxOptions('get_ctypes', this, treeNodeInfo, itemNodeData, {
|
|
||||||
cacheLevel: 'server',
|
|
||||||
}),
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
datowner: pgBrowser.serverInfo[treeNodeInfo.server._id].user.name,
|
datowner: pgBrowser.serverInfo[treeNodeInfo.server._id].user.name,
|
||||||
|
|
|
@ -584,6 +584,20 @@ define('pgadmin.node.server', [
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
on_done: function(res, t, i) {
|
||||||
|
if (res.success == 1) {
|
||||||
|
Notify.success(res.info);
|
||||||
|
t.itemData(i).wal_pause=res.data.wal_pause;
|
||||||
|
t.unload(i);
|
||||||
|
t.setInode(i);
|
||||||
|
t.deselect(i);
|
||||||
|
// Fetch updated data from server
|
||||||
|
setTimeout(function() {
|
||||||
|
t.select(i);
|
||||||
|
}, 10);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
/* Pause WAL Replay */
|
/* Pause WAL Replay */
|
||||||
pause_wal_replay: function(args) {
|
pause_wal_replay: function(args) {
|
||||||
var input = args || {},
|
var input = args || {},
|
||||||
|
@ -601,17 +615,7 @@ define('pgadmin.node.server', [
|
||||||
dataType: 'json',
|
dataType: 'json',
|
||||||
})
|
})
|
||||||
.done(function(res) {
|
.done(function(res) {
|
||||||
if (res.success == 1) {
|
obj.on_done(res, t, i);
|
||||||
Notify.success(res.info);
|
|
||||||
t.itemData(i).wal_pause=res.data.wal_pause;
|
|
||||||
t.unload(i);
|
|
||||||
t.setInode(i);
|
|
||||||
t.deselect(i);
|
|
||||||
// Fetch updated data from server
|
|
||||||
setTimeout(function() {
|
|
||||||
t.select(i);
|
|
||||||
}, 10);
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
.fail(function(xhr, status, error) {
|
.fail(function(xhr, status, error) {
|
||||||
Notify.pgRespErrorNotify(xhr, error);
|
Notify.pgRespErrorNotify(xhr, error);
|
||||||
|
@ -636,17 +640,7 @@ define('pgadmin.node.server', [
|
||||||
dataType: 'json',
|
dataType: 'json',
|
||||||
})
|
})
|
||||||
.done(function(res) {
|
.done(function(res) {
|
||||||
if (res.success == 1) {
|
obj.on_done(res, t, i);
|
||||||
Notify.success(res.info);
|
|
||||||
t.itemData(i).wal_pause=res.data.wal_pause;
|
|
||||||
t.unload(i);
|
|
||||||
t.setInode(i);
|
|
||||||
t.deselect(i);
|
|
||||||
// Fetch updated data from server
|
|
||||||
setTimeout(function() {
|
|
||||||
t.select(i);
|
|
||||||
}, 10);
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
.fail(function(xhr, status, error) {
|
.fail(function(xhr, status, error) {
|
||||||
Notify.pgRespErrorNotify(xhr, error);
|
Notify.pgRespErrorNotify(xhr, error);
|
||||||
|
|
|
@ -532,6 +532,22 @@ define('pgadmin.browser.node', [
|
||||||
|
|
||||||
return new_panel;
|
return new_panel;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onEventResizeEnded: function() {
|
||||||
|
var $container = this.$container.find('.obj_properties').first(),
|
||||||
|
v = $container.data('obj-view');
|
||||||
|
|
||||||
|
if (v && v.model && v.model) {
|
||||||
|
v.model.trigger(
|
||||||
|
'pg-browser-resized', {
|
||||||
|
'view': v,
|
||||||
|
'panel': this,
|
||||||
|
'container': $container,
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
registerUtilityPanel: function() {
|
registerUtilityPanel: function() {
|
||||||
var w = pgBrowser.docker,
|
var w = pgBrowser.docker,
|
||||||
p = w.findPanels('utility_props');
|
p = w.findPanels('utility_props');
|
||||||
|
@ -540,20 +556,7 @@ define('pgadmin.browser.node', [
|
||||||
return;
|
return;
|
||||||
|
|
||||||
var events = {};
|
var events = {};
|
||||||
events[wcDocker.EVENT.RESIZE_ENDED] = function() {
|
events[wcDocker.EVENT.RESIZE_ENDED] = this.onEventResizeEnded;
|
||||||
var $container = this.$container.find('.obj_properties').first(),
|
|
||||||
v = $container.data('obj-view');
|
|
||||||
|
|
||||||
if (v && v.model && v.model) {
|
|
||||||
v.model.trigger(
|
|
||||||
'pg-browser-resized', {
|
|
||||||
'view': v,
|
|
||||||
'panel': this,
|
|
||||||
'container': $container,
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
p = new pgBrowser.Panel({
|
p = new pgBrowser.Panel({
|
||||||
name: 'utility_props',
|
name: 'utility_props',
|
||||||
|
@ -579,20 +582,7 @@ define('pgadmin.browser.node', [
|
||||||
return;
|
return;
|
||||||
|
|
||||||
var events = {};
|
var events = {};
|
||||||
events[wcDocker.EVENT.RESIZE_ENDED] = function() {
|
events[wcDocker.EVENT.RESIZE_ENDED] = this.onEventResizeEnded;
|
||||||
var $container = this.$container.find('.obj_properties').first(),
|
|
||||||
v = $container.data('obj-view');
|
|
||||||
|
|
||||||
if (v && v.model && v.model) {
|
|
||||||
v.model.trigger(
|
|
||||||
'pg-browser-resized', {
|
|
||||||
'view': v,
|
|
||||||
'panel': this,
|
|
||||||
'container': $container,
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
p = new pgBrowser.Panel({
|
p = new pgBrowser.Panel({
|
||||||
name: 'node_props',
|
name: 'node_props',
|
||||||
|
|
|
@ -218,6 +218,30 @@ define([
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var filterRows = function(self, filter, rows, node) {
|
||||||
|
var res = [];
|
||||||
|
_.each(rows, function(r) {
|
||||||
|
if (filter(r)) {
|
||||||
|
var l = (_.isFunction(node['node_label']) ?
|
||||||
|
(node['node_label']).apply(node, [r, self.model, self]) :
|
||||||
|
r.label),
|
||||||
|
image = (_.isFunction(node['node_image']) ?
|
||||||
|
(node['node_image']).apply(
|
||||||
|
node, [r, self.model, self]
|
||||||
|
) :
|
||||||
|
(node['node_image'] || ('icon-' + node.type)));
|
||||||
|
|
||||||
|
res.push({
|
||||||
|
'value': r._id,
|
||||||
|
'image': image,
|
||||||
|
'label': l,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return res;
|
||||||
|
};
|
||||||
|
|
||||||
var NodeListByIdControl = Backform.NodeListByIdControl = NodeAjaxOptionsControl.extend({
|
var NodeListByIdControl = Backform.NodeListByIdControl = NodeAjaxOptionsControl.extend({
|
||||||
controlClassName: 'pgadmin-node-select form-control',
|
controlClassName: 'pgadmin-node-select form-control',
|
||||||
defaults: _.extend({}, NodeAjaxOptionsControl.prototype.defaults, {
|
defaults: _.extend({}, NodeAjaxOptionsControl.prototype.defaults, {
|
||||||
|
@ -226,33 +250,12 @@ define([
|
||||||
transform: function(rows) {
|
transform: function(rows) {
|
||||||
var self = this,
|
var self = this,
|
||||||
node = self.field.get('schema_node'),
|
node = self.field.get('schema_node'),
|
||||||
res = [],
|
|
||||||
filter = self.field.get('filter') || function() {
|
filter = self.field.get('filter') || function() {
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
filter = filter.bind(self);
|
filter = filter.bind(self);
|
||||||
|
return filterRows(self, filter, rows, node);
|
||||||
_.each(rows, function(r) {
|
|
||||||
if (filter(r)) {
|
|
||||||
var l = (_.isFunction(node['node_label']) ?
|
|
||||||
(node['node_label']).apply(node, [r, self.model, self]) :
|
|
||||||
r.label),
|
|
||||||
image = (_.isFunction(node['node_image']) ?
|
|
||||||
(node['node_image']).apply(
|
|
||||||
node, [r, self.model, self]
|
|
||||||
) :
|
|
||||||
(node['node_image'] || ('icon-' + node.type)));
|
|
||||||
|
|
||||||
res.push({
|
|
||||||
'value': r._id,
|
|
||||||
'image': image,
|
|
||||||
'label': l,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return res;
|
|
||||||
},
|
},
|
||||||
select2: {
|
select2: {
|
||||||
allowClear: true,
|
allowClear: true,
|
||||||
|
@ -473,42 +476,23 @@ define([
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var transformFunc = function(rows, control) {
|
||||||
|
var self = control || this,
|
||||||
|
node = self.column.get('schema_node'),
|
||||||
|
filter = self.column.get('filter') || function() {
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
filter = filter.bind(self);
|
||||||
|
return filterRows(self, filter, rows, node);
|
||||||
|
};
|
||||||
|
|
||||||
Backgrid.Extension.NodeListByIdCell = NodeAjaxOptionsCell.extend({
|
Backgrid.Extension.NodeListByIdCell = NodeAjaxOptionsCell.extend({
|
||||||
controlClassName: 'pgadmin-node-select backgrid-cell',
|
controlClassName: 'pgadmin-node-select backgrid-cell',
|
||||||
defaults: _.extend({}, NodeAjaxOptionsCell.prototype.defaults, {
|
defaults: _.extend({}, NodeAjaxOptionsCell.prototype.defaults, {
|
||||||
url: 'nodes',
|
url: 'nodes',
|
||||||
filter: undefined,
|
filter: undefined,
|
||||||
transform: function(rows, control) {
|
transform: transformFunc,
|
||||||
var self = control || this,
|
|
||||||
node = self.column.get('schema_node'),
|
|
||||||
res = [],
|
|
||||||
filter = self.column.get('filter') || function() {
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
|
|
||||||
filter = filter.bind(self);
|
|
||||||
|
|
||||||
_.each(rows, function(r) {
|
|
||||||
if (filter(r)) {
|
|
||||||
var l = (_.isFunction(node['node_label']) ?
|
|
||||||
(node['node_label']).apply(node, [r, self.model, self]) :
|
|
||||||
r.label),
|
|
||||||
image = (_.isFunction(node['node_image']) ?
|
|
||||||
(node['node_image']).apply(
|
|
||||||
node, [r, self.model, self]
|
|
||||||
) :
|
|
||||||
(node['node_image'] || ('icon-' + node.type)));
|
|
||||||
|
|
||||||
res.push({
|
|
||||||
'value': r._id,
|
|
||||||
'image': image,
|
|
||||||
'label': l,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return res;
|
|
||||||
},
|
|
||||||
select2: {
|
select2: {
|
||||||
placeholder: gettext('Select an item...'),
|
placeholder: gettext('Select an item...'),
|
||||||
width: 'style',
|
width: 'style',
|
||||||
|
@ -523,37 +507,7 @@ define([
|
||||||
defaults: _.extend({}, NodeAjaxOptionsCell.prototype.defaults, {
|
defaults: _.extend({}, NodeAjaxOptionsCell.prototype.defaults, {
|
||||||
url: 'nodes',
|
url: 'nodes',
|
||||||
filter: undefined,
|
filter: undefined,
|
||||||
transform: function(rows, control) {
|
transform: transformFunc,
|
||||||
var self = control || this,
|
|
||||||
node = self.column.get('schema_node'),
|
|
||||||
res = [],
|
|
||||||
filter = self.column.get('filter') || function() {
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
|
|
||||||
filter = filter.bind(self);
|
|
||||||
|
|
||||||
_.each(rows, function(r) {
|
|
||||||
if (filter(r)) {
|
|
||||||
var l = (_.isFunction(node['node_label']) ?
|
|
||||||
(node['node_label']).apply(node, [r, self.model, self]) :
|
|
||||||
r.label),
|
|
||||||
image = (_.isFunction(node['node_image']) ?
|
|
||||||
(node['node_image']).apply(
|
|
||||||
node, [r, self.model, self]
|
|
||||||
) :
|
|
||||||
(node['node_image'] || ('icon-' + node.type)));
|
|
||||||
|
|
||||||
res.push({
|
|
||||||
'value': r.label,
|
|
||||||
'image': image,
|
|
||||||
'label': l,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return res;
|
|
||||||
},
|
|
||||||
select2: {
|
select2: {
|
||||||
placeholder: gettext('Select an item...'),
|
placeholder: gettext('Select an item...'),
|
||||||
width: 'style',
|
width: 'style',
|
||||||
|
|
|
@ -35,6 +35,16 @@ export function getNodeView(nodeType, treeNodeInfo, actionType, itemNodeData, fo
|
||||||
let warnOnCloseFlag = true;
|
let warnOnCloseFlag = true;
|
||||||
const confirmOnCloseReset = pgAdmin.Browser.get_preferences_for_module('browser').confirm_on_properties_close;
|
const confirmOnCloseReset = pgAdmin.Browser.get_preferences_for_module('browser').confirm_on_properties_close;
|
||||||
|
|
||||||
|
let onError = (err)=> {
|
||||||
|
if(err.response){
|
||||||
|
console.error('error resp', err.response);
|
||||||
|
} else if(err.request){
|
||||||
|
console.error('error req', err.request);
|
||||||
|
} else if(err.message){
|
||||||
|
console.error('error msg', err.message);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
/* Called when dialog is opened in edit mode, promise required */
|
/* Called when dialog is opened in edit mode, promise required */
|
||||||
let initData = ()=>new Promise((resolve, reject)=>{
|
let initData = ()=>new Promise((resolve, reject)=>{
|
||||||
api.get(url(false))
|
api.get(url(false))
|
||||||
|
@ -42,13 +52,7 @@ export function getNodeView(nodeType, treeNodeInfo, actionType, itemNodeData, fo
|
||||||
resolve(res.data);
|
resolve(res.data);
|
||||||
})
|
})
|
||||||
.catch((err)=>{
|
.catch((err)=>{
|
||||||
if(err.response){
|
onError(err);
|
||||||
console.error('error resp', err.response);
|
|
||||||
} else if(err.request){
|
|
||||||
console.error('error req', err.request);
|
|
||||||
} else if(err.message){
|
|
||||||
console.error('error msg', err.message);
|
|
||||||
}
|
|
||||||
reject(err);
|
reject(err);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -80,13 +84,7 @@ export function getNodeView(nodeType, treeNodeInfo, actionType, itemNodeData, fo
|
||||||
}).then((res)=>{
|
}).then((res)=>{
|
||||||
resolve(res.data.data);
|
resolve(res.data.data);
|
||||||
}).catch((err)=>{
|
}).catch((err)=>{
|
||||||
if(err.response){
|
onError(err);
|
||||||
console.error('error resp', err.response);
|
|
||||||
} else if(err.request){
|
|
||||||
console.error('error req', err.request);
|
|
||||||
} else if(err.message){
|
|
||||||
console.error('error msg', err.message);
|
|
||||||
}
|
|
||||||
reject(err);
|
reject(err);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -133,7 +133,6 @@ define(
|
||||||
pgBrowser.Events.on('pgadmin-browser:tree:selected', () => {
|
pgBrowser.Events.on('pgadmin-browser:tree:selected', () => {
|
||||||
|
|
||||||
if(myPanel.isVisible()) {
|
if(myPanel.isVisible()) {
|
||||||
removePanelView($container[0]);
|
|
||||||
getPanelView(
|
getPanelView(
|
||||||
pgBrowser.tree,
|
pgBrowser.tree,
|
||||||
$container[0],
|
$container[0],
|
||||||
|
|
|
@ -239,19 +239,7 @@ define('pgadmin.dashboard', [
|
||||||
$(div).html(data);
|
$(div).html(data);
|
||||||
})
|
})
|
||||||
.fail(function(xhr, error) {
|
.fail(function(xhr, error) {
|
||||||
Notify.pgNotifier(
|
self.onFail(xhr, error, div, ajaxHook);
|
||||||
error, xhr,
|
|
||||||
gettext('An error occurred whilst loading the dashboard.'),
|
|
||||||
function(msg) {
|
|
||||||
if(msg === 'CRYPTKEY_SET') {
|
|
||||||
ajaxHook();
|
|
||||||
} else {
|
|
||||||
$(div).html(
|
|
||||||
'<div class="pg-panel-message" role="alert">' + gettext('An error occurred whilst loading the dashboard.') + '</div>'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
$(div).html(
|
$(div).html(
|
||||||
|
@ -266,6 +254,22 @@ define('pgadmin.dashboard', [
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onFail: function(xhr, error, div, ajaxHook) {
|
||||||
|
Notify.pgNotifier(
|
||||||
|
error, xhr,
|
||||||
|
gettext('An error occurred whilst loading the dashboard.'),
|
||||||
|
function(msg) {
|
||||||
|
if(msg === 'CRYPTKEY_SET') {
|
||||||
|
ajaxHook();
|
||||||
|
} else {
|
||||||
|
$(div).html(
|
||||||
|
'<div class="pg-panel-message" role="alert">' + gettext('An error occurred whilst loading the dashboard.') + '</div>'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
},
|
||||||
|
|
||||||
// Handle Server Disconnect
|
// Handle Server Disconnect
|
||||||
object_disconnected: function() {
|
object_disconnected: function() {
|
||||||
let item = pgBrowser.tree.selected(),
|
let item = pgBrowser.tree.selected(),
|
||||||
|
@ -358,19 +362,7 @@ define('pgadmin.dashboard', [
|
||||||
self.init_dashboard();
|
self.init_dashboard();
|
||||||
})
|
})
|
||||||
.fail(function(xhr, error) {
|
.fail(function(xhr, error) {
|
||||||
Notify.pgNotifier(
|
self.onFail(xhr, error, div, ajaxHook);
|
||||||
error, xhr,
|
|
||||||
gettext('An error occurred whilst loading the dashboard.'),
|
|
||||||
function(msg) {
|
|
||||||
if(msg === 'CRYPTKEY_SET') {
|
|
||||||
ajaxHook();
|
|
||||||
} else {
|
|
||||||
$(div).html(
|
|
||||||
'<div class="pg-panel-message" role="alert">' + gettext('An error occurred whilst loading the dashboard.') + '</div>'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
$(div).html(
|
$(div).html(
|
||||||
|
@ -631,6 +623,16 @@ define('pgadmin.dashboard', [
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
renderTab: function(e, tab_grid_map) {
|
||||||
|
let prevGrid = tab_grid_map[$(e.relatedTarget).attr('aria-controls')];
|
||||||
|
$(prevGrid).data('filtertext', $('#txtGridSearch').val());
|
||||||
|
|
||||||
|
let currGrid = tab_grid_map[$(e.target).attr('aria-controls')];
|
||||||
|
$('#txtGridSearch').val($(currGrid).data('filtertext'));
|
||||||
|
pgAdmin.Dashboard.render_grid_data(currGrid);
|
||||||
|
},
|
||||||
|
|
||||||
reflectPreferencesServer: function() {
|
reflectPreferencesServer: function() {
|
||||||
var self = this;
|
var self = this;
|
||||||
var $dashboardContainer = $('.dashboard-container');
|
var $dashboardContainer = $('.dashboard-container');
|
||||||
|
@ -895,12 +897,7 @@ define('pgadmin.dashboard', [
|
||||||
|
|
||||||
// (Re)render the appropriate tab
|
// (Re)render the appropriate tab
|
||||||
$('a[data-toggle="tab"]').on('shown.bs.tab', function(e) {
|
$('a[data-toggle="tab"]').on('shown.bs.tab', function(e) {
|
||||||
let prevGrid = tab_grid_map[$(e.relatedTarget).attr('aria-controls')];
|
self.renderTab(e, tab_grid_map);
|
||||||
$(prevGrid).data('filtertext', $('#txtGridSearch').val());
|
|
||||||
|
|
||||||
let currGrid = tab_grid_map[$(e.target).attr('aria-controls')];
|
|
||||||
$('#txtGridSearch').val($(currGrid).data('filtertext'));
|
|
||||||
pgAdmin.Dashboard.render_grid_data(currGrid);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#btn_refresh').off('click').on('click', () => {
|
$('#btn_refresh').off('click').on('click', () => {
|
||||||
|
@ -1123,12 +1120,7 @@ define('pgadmin.dashboard', [
|
||||||
|
|
||||||
// (Re)render the appropriate tab
|
// (Re)render the appropriate tab
|
||||||
$('a[data-toggle="tab"]').on('shown.bs.tab', function(e) {
|
$('a[data-toggle="tab"]').on('shown.bs.tab', function(e) {
|
||||||
let prevGrid = tab_grid_map[$(e.relatedTarget).attr('aria-controls')];
|
self.renderTab(e, tab_grid_map);
|
||||||
$(prevGrid).data('filtertext', $('#txtGridSearch').val());
|
|
||||||
|
|
||||||
let currGrid = tab_grid_map[$(e.target).attr('aria-controls')];
|
|
||||||
$('#txtGridSearch').val($(currGrid).data('filtertext'));
|
|
||||||
pgAdmin.Dashboard.render_grid_data(currGrid);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#btn_refresh').off('click').on('click', () => {
|
$('#btn_refresh').off('click').on('click', () => {
|
||||||
|
|
|
@ -19,8 +19,20 @@ let StatisticsModel = Backbone.Model.extend({
|
||||||
Summary: {},
|
Summary: {},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
explainToolTip: function(key, value, tooltip) {
|
||||||
|
key = _.escape(key);
|
||||||
|
value = _.escape(value);
|
||||||
|
tooltip.append(`
|
||||||
|
<tr>
|
||||||
|
<td class="label explain-tooltip"> ${key}</td>
|
||||||
|
<td class="label explain-tooltip-val">${value}</td>
|
||||||
|
</tr>
|
||||||
|
`);
|
||||||
|
},
|
||||||
|
|
||||||
set_statistics: function(toolTipContainer) {
|
set_statistics: function(toolTipContainer) {
|
||||||
var jit_stats = this.get('JIT'),
|
var self= this,
|
||||||
|
jit_stats = this.get('JIT'),
|
||||||
triggers_stats = this.get('Triggers'),
|
triggers_stats = this.get('Triggers'),
|
||||||
summary = this.get('Summary');
|
summary = this.get('Summary');
|
||||||
|
|
||||||
|
@ -40,14 +52,7 @@ let StatisticsModel = Backbone.Model.extend({
|
||||||
if (Object.keys(jit_stats).length > 0){
|
if (Object.keys(jit_stats).length > 0){
|
||||||
tooltip.append('<tr><td colspan="2" class="label explain-tooltip">' + gettext('JIT:') + '</td></tr>');
|
tooltip.append('<tr><td colspan="2" class="label explain-tooltip">' + gettext('JIT:') + '</td></tr>');
|
||||||
_.each(jit_stats, function(value, key) {
|
_.each(jit_stats, function(value, key) {
|
||||||
key = _.escape(key);
|
self.explainToolTip(key, value, tooltip);
|
||||||
value = _.escape(value);
|
|
||||||
tooltip.append(`
|
|
||||||
<tr>
|
|
||||||
<td class="label explain-tooltip"> ${key}</td>
|
|
||||||
<td class="label explain-tooltip-val">${value}</td>
|
|
||||||
</tr>
|
|
||||||
`);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,14 +98,7 @@ let StatisticsModel = Backbone.Model.extend({
|
||||||
if (Object.keys(summary).length > 0){
|
if (Object.keys(summary).length > 0){
|
||||||
tooltip.append('<tr><td colspan="2" class="label explain-tooltip">' + gettext('Summary:') + '</td></tr>');
|
tooltip.append('<tr><td colspan="2" class="label explain-tooltip">' + gettext('Summary:') + '</td></tr>');
|
||||||
_.each(summary, function(value, key) {
|
_.each(summary, function(value, key) {
|
||||||
key = _.escape(key);
|
self.explainToolTip(key, value, tooltip);
|
||||||
value = _.escape(value);
|
|
||||||
tooltip.append(`
|
|
||||||
<tr>
|
|
||||||
<td class="label explain-tooltip"> ${key}</td>
|
|
||||||
<td class="label explain-tooltip-val">${value}</td>
|
|
||||||
</tr>
|
|
||||||
`);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -355,7 +355,7 @@ export default function DataGridView({
|
||||||
disableResizing: false,
|
disableResizing: false,
|
||||||
sortable: true,
|
sortable: true,
|
||||||
...widthParms,
|
...widthParms,
|
||||||
Cell: ({cellValue, row, ...other}) => {
|
Cell: ({value, row, ...other}) => {
|
||||||
/* Make sure to take the latest field info from schema */
|
/* Make sure to take the latest field info from schema */
|
||||||
field = _.find(schemaRef.current.fields, (f)=>f.id==field.id) || field;
|
field = _.find(schemaRef.current.fields, (f)=>f.id==field.id) || field;
|
||||||
|
|
||||||
|
@ -365,7 +365,7 @@ export default function DataGridView({
|
||||||
console.error('cell is required ', field);
|
console.error('cell is required ', field);
|
||||||
}
|
}
|
||||||
|
|
||||||
return <MappedCellControl rowIndex={row.index} value={cellValue}
|
return <MappedCellControl rowIndex={row.index} value={value}
|
||||||
row={row.original} {...field}
|
row={row.original} {...field}
|
||||||
readonly={!editable}
|
readonly={!editable}
|
||||||
disabled={false}
|
disabled={false}
|
||||||
|
@ -385,7 +385,6 @@ export default function DataGridView({
|
||||||
colInfo.Cell.propTypes = {
|
colInfo.Cell.propTypes = {
|
||||||
row: PropTypes.object.isRequired,
|
row: PropTypes.object.isRequired,
|
||||||
value: PropTypes.any,
|
value: PropTypes.any,
|
||||||
cellValue: PropTypes.any,
|
|
||||||
onCellChange: PropTypes.func,
|
onCellChange: PropTypes.func,
|
||||||
};
|
};
|
||||||
return colInfo;
|
return colInfo;
|
||||||
|
|
|
@ -145,6 +145,14 @@ export default class BaseUISchema {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check readonly on the basis of new state */
|
||||||
|
isReadOnly(state) {
|
||||||
|
if(!this.isNew(state)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/* Get the server version */
|
/* Get the server version */
|
||||||
getServerVersion() {
|
getServerVersion() {
|
||||||
if(!_.isUndefined(this.nodeInfo) && !_.isUndefined(this.nodeInfo.server)
|
if(!_.isUndefined(this.nodeInfo) && !_.isUndefined(this.nodeInfo.server)
|
||||||
|
@ -152,4 +160,21 @@ export default class BaseUISchema {
|
||||||
return this.nodeInfo.server.version;
|
return this.nodeInfo.server.version;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Get the filter options */
|
||||||
|
getFilterOptions(state, options) {
|
||||||
|
// Function is used to populate the filter options.
|
||||||
|
let res = [];
|
||||||
|
if (state && this.isNew(state)) {
|
||||||
|
options.forEach((option) => {
|
||||||
|
if(option && option.label == '') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
res.push({ label: option.label, value: option.value });
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
res = options;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -426,11 +426,6 @@ export function registerDetachEvent(panel){
|
||||||
style: 'z-index: 1200'
|
style: 'z-index: 1200'
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
panel.on(wcDocker.EVENT.ORDER_CHANGED, function() {
|
|
||||||
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').attr({
|
|
||||||
style: 'z-index: 1200'
|
|
||||||
});
|
|
||||||
});
|
|
||||||
panel.on(wcDocker.EVENT.ORDER_CHANGED, function() {
|
panel.on(wcDocker.EVENT.ORDER_CHANGED, function() {
|
||||||
var docker = this.docker(this._panel);
|
var docker = this.docker(this._panel);
|
||||||
var dockerPos = docker.$container.offset();
|
var dockerPos = docker.$container.offset();
|
||||||
|
@ -442,5 +437,8 @@ export function registerDetachEvent(panel){
|
||||||
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').css('left', pos.left - dockerPos.left);
|
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').css('left', pos.left - dockerPos.left);
|
||||||
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').css('width', width);
|
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').css('width', width);
|
||||||
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').find('.wcIFrameFloating').css('height', height);
|
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').find('.wcIFrameFloating').css('height', height);
|
||||||
|
$((this.$container)[0].ownerDocument).find('.wcIFrameFloating').attr({
|
||||||
|
style: 'z-index: 1200'
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -193,6 +193,12 @@ export function getSaveOptSchema(fieldOptions) {
|
||||||
return new SaveOptSchema(fieldOptions);
|
return new SaveOptSchema(fieldOptions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isVisible () {
|
||||||
|
if (!_.isUndefined(this.backupType) && this.backupType === 'server')
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
export class QueryOptionSchema extends BaseUISchema {
|
export class QueryOptionSchema extends BaseUISchema {
|
||||||
constructor(fieldOptions={}, initValues={}) {
|
constructor(fieldOptions={}, initValues={}) {
|
||||||
super({
|
super({
|
||||||
|
@ -465,11 +471,7 @@ export default class BackupSchema extends BaseUISchema {
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
return (state.format === 'tar');
|
return (state.format === 'tar');
|
||||||
},
|
},
|
||||||
visible: function() {
|
visible: isVisible,
|
||||||
if (!_.isUndefined(obj.backupType) && obj.backupType === 'server')
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
}, {
|
}, {
|
||||||
id: 'encoding',
|
id: 'encoding',
|
||||||
label: gettext('Encoding'),
|
label: gettext('Encoding'),
|
||||||
|
@ -491,11 +493,7 @@ export default class BackupSchema extends BaseUISchema {
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
return (state.format !== 'directory');
|
return (state.format !== 'directory');
|
||||||
},
|
},
|
||||||
visible: function() {
|
visible: isVisible,
|
||||||
if (!_.isUndefined(obj.backupType) && obj.backupType === 'server')
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
}, {
|
}, {
|
||||||
id: 'role',
|
id: 'role',
|
||||||
label: gettext('Role name'),
|
label: gettext('Role name'),
|
||||||
|
@ -517,11 +515,7 @@ export default class BackupSchema extends BaseUISchema {
|
||||||
label: gettext('Sections'),
|
label: gettext('Sections'),
|
||||||
group: gettext('Data/Objects'),
|
group: gettext('Data/Objects'),
|
||||||
schema:new getSectionSchema(),
|
schema:new getSectionSchema(),
|
||||||
visible: function() {
|
visible: isVisible,
|
||||||
if (!_.isUndefined(obj.backupType) && obj.backupType === 'server')
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
},
|
|
||||||
}, {
|
}, {
|
||||||
type: 'nested-fieldset',
|
type: 'nested-fieldset',
|
||||||
label: gettext('Type of objects'),
|
label: gettext('Type of objects'),
|
||||||
|
|
|
@ -119,23 +119,23 @@ export function launchDataGrid(datagrid, transId, gridUrl, queryToolTitle, sURL)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function setPanelTitle(panel, value) {
|
||||||
|
if(value) {
|
||||||
|
$('#' + panel.$title.index() + ' div:first').addClass('wcPanelTab-dynamic');
|
||||||
|
} else {
|
||||||
|
$('#' + panel.$title.index() + ' div:first').removeClass('wcPanelTab-dynamic');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export function _set_dynamic_tab(pgBrowser, value){
|
export function _set_dynamic_tab(pgBrowser, value){
|
||||||
var datagrid_panels = pgBrowser.docker.findPanels('frm_datagrid');
|
var datagrid_panels = pgBrowser.docker.findPanels('frm_datagrid');
|
||||||
datagrid_panels.forEach(panel => {
|
datagrid_panels.forEach(panel => {
|
||||||
if(value) {
|
setPanelTitle(panel, value);
|
||||||
$('#' + panel.$title.index() + ' div:first').addClass('wcPanelTab-dynamic');
|
|
||||||
} else {
|
|
||||||
$('#' + panel.$title.index() + ' div:first').removeClass('wcPanelTab-dynamic');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
var debugger_panels = pgBrowser.docker.findPanels('frm_debugger');
|
var debugger_panels = pgBrowser.docker.findPanels('frm_debugger');
|
||||||
debugger_panels.forEach(panel => {
|
debugger_panels.forEach(panel => {
|
||||||
if(value) {
|
setPanelTitle(panel, value);
|
||||||
$('#' + panel.$title.index() + ' div:first').addClass('wcPanelTab-dynamic');
|
|
||||||
} else {
|
|
||||||
$('#' + panel.$title.index() + ' div:first').removeClass('wcPanelTab-dynamic');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -300,6 +300,17 @@ define([
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onFail: function(xhr) {
|
||||||
|
try {
|
||||||
|
var err = JSON.parse(xhr.responseText);
|
||||||
|
if (err.success == 0) {
|
||||||
|
Notify.alert(gettext('Debugger Error'), err.errormsg);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
console.warn(e.stack || e);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
check_func_debuggable: function(args, item) {
|
check_func_debuggable: function(args, item) {
|
||||||
var t = pgBrowser.tree,
|
var t = pgBrowser.tree,
|
||||||
i = item || t.selected(),
|
i = item || t.selected(),
|
||||||
|
@ -321,17 +332,28 @@ define([
|
||||||
self.start_global_debugger(args, item, res.data.trans_id);
|
self.start_global_debugger(args, item, res.data.trans_id);
|
||||||
})
|
})
|
||||||
.fail(function(xhr) {
|
.fail(function(xhr) {
|
||||||
try {
|
self.onFail(xhr);
|
||||||
var err = JSON.parse(xhr.responseText);
|
|
||||||
if (err.success == 0) {
|
|
||||||
Notify.alert(gettext('Debugger Error'), err.errormsg);
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
console.warn(e.stack || e);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
panel_rename_event: function(panel_data, panel, treeInfo) {
|
||||||
|
Alertify.prompt('', panel_data.$titleText[0].textContent,
|
||||||
|
// We will execute this function when user clicks on the OK button
|
||||||
|
function(evt, value) {
|
||||||
|
if(value) {
|
||||||
|
// Remove the leading and trailing white spaces.
|
||||||
|
value = value.trim();
|
||||||
|
let preferences = pgBrowser.get_preferences_for_module('browser');
|
||||||
|
var name = debuggerUtils.getAppropriateLabel(treeInfo);
|
||||||
|
debuggerUtils.setDebuggerTitle(panel, preferences, name, treeInfo.schema.label, treeInfo.database.label, value, pgBrowser);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// We will execute this function when user clicks on the Cancel
|
||||||
|
// button. Do nothing just close it.
|
||||||
|
function(evt) { evt.cancel = false; }
|
||||||
|
).set({'title': gettext('Rename Panel')});
|
||||||
|
},
|
||||||
|
|
||||||
//Callback function when user start the indirect debugging ( Listen to another session to invoke the target )
|
//Callback function when user start the indirect debugging ( Listen to another session to invoke the target )
|
||||||
start_global_debugger: function(args, item, trans_id) {
|
start_global_debugger: function(args, item, trans_id) {
|
||||||
// Initialize the target and create asynchronous connection and unique transaction ID
|
// Initialize the target and create asynchronous connection and unique transaction ID
|
||||||
|
@ -465,21 +487,7 @@ define([
|
||||||
|
|
||||||
// Panel Rename event
|
// Panel Rename event
|
||||||
panel.on(wcDocker.EVENT.RENAME, function(panel_data) {
|
panel.on(wcDocker.EVENT.RENAME, function(panel_data) {
|
||||||
Alertify.prompt('', panel_data.$titleText[0].textContent,
|
self.panel_rename_event(panel_data, panel, treeInfo);
|
||||||
// We will execute this function when user clicks on the OK button
|
|
||||||
function(evt, value) {
|
|
||||||
if(value) {
|
|
||||||
// Remove the leading and trailing white spaces.
|
|
||||||
value = value.trim();
|
|
||||||
let preferences = pgBrowser.get_preferences_for_module('browser');
|
|
||||||
var name = debuggerUtils.getAppropriateLabel(treeInfo);
|
|
||||||
debuggerUtils.setDebuggerTitle(panel, preferences, name, treeInfo.schema.label, treeInfo.database.label, value, pgBrowser);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
// We will execute this function when user clicks on the Cancel
|
|
||||||
// button. Do nothing just close it.
|
|
||||||
function(evt) { evt.cancel = false; }
|
|
||||||
).set({'title': gettext('Rename Panel')});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -639,21 +647,7 @@ define([
|
||||||
|
|
||||||
// Panel Rename event
|
// Panel Rename event
|
||||||
panel.on(wcDocker.EVENT.RENAME, function(panel_data) {
|
panel.on(wcDocker.EVENT.RENAME, function(panel_data) {
|
||||||
Alertify.prompt('', panel_data.$titleText[0].textContent,
|
self.panel_rename_event(panel_data, panel, treeInfo);
|
||||||
// We will execute this function when user clicks on the OK button
|
|
||||||
function(evt, value) {
|
|
||||||
if(value) {
|
|
||||||
// Remove the leading and trailing white spaces.
|
|
||||||
value = value.trim();
|
|
||||||
let preferences = pgBrowser.get_preferences_for_module('browser');
|
|
||||||
var name = debuggerUtils.getAppropriateLabel(treeInfo);
|
|
||||||
debuggerUtils.setDebuggerTitle(panel, preferences, name, treeInfo.schema.label, treeInfo.database.label, value, pgBrowser);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
// We will execute this function when user clicks on the Cancel
|
|
||||||
// button. Do nothing just close it.
|
|
||||||
function(evt) { evt.cancel = false; }
|
|
||||||
).set({'title': gettext('Rename Panel')});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -666,14 +660,7 @@ define([
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.fail(function(xhr) {
|
.fail(function(xhr) {
|
||||||
try {
|
self.onFail(xhr);
|
||||||
var err = JSON.parse(xhr.responseText);
|
|
||||||
if (err.success == 0) {
|
|
||||||
Notify.alert(gettext('Debugger Error'), err.errormsg);
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
console.warn(e.stack || e);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
|
@ -536,14 +536,7 @@ define([
|
||||||
// Execution completed so disable the buttons other than
|
// Execution completed so disable the buttons other than
|
||||||
// "Continue/Start" button because user can still
|
// "Continue/Start" button because user can still
|
||||||
// start the same execution again.
|
// start the same execution again.
|
||||||
setTimeout(function() {
|
setTimeout(self.disable_toolbar_buttons(), 500);
|
||||||
self.enable('stop', false);
|
|
||||||
self.enable('step_over', false);
|
|
||||||
self.enable('step_into', false);
|
|
||||||
self.enable('toggle_breakpoint', false);
|
|
||||||
self.enable('clear_all_breakpoints', false);
|
|
||||||
self.enable('continue', true);
|
|
||||||
}, 500);
|
|
||||||
|
|
||||||
// Stop further polling
|
// Stop further polling
|
||||||
pgTools.DirectDebug.is_polling_required = false;
|
pgTools.DirectDebug.is_polling_required = false;
|
||||||
|
@ -570,14 +563,7 @@ define([
|
||||||
// Execution completed so disable the buttons other than
|
// Execution completed so disable the buttons other than
|
||||||
// "Continue/Start" button because user can still
|
// "Continue/Start" button because user can still
|
||||||
// start the same execution again.
|
// start the same execution again.
|
||||||
setTimeout(function() {
|
setTimeout(self.disable_toolbar_buttons(), 500);
|
||||||
self.enable('stop', false);
|
|
||||||
self.enable('step_over', false);
|
|
||||||
self.enable('step_into', false);
|
|
||||||
self.enable('toggle_breakpoint', false);
|
|
||||||
self.enable('clear_all_breakpoints', false);
|
|
||||||
self.enable('continue', true);
|
|
||||||
}, 500);
|
|
||||||
|
|
||||||
// Stop further pooling
|
// Stop further pooling
|
||||||
pgTools.DirectDebug.is_polling_required = false;
|
pgTools.DirectDebug.is_polling_required = false;
|
||||||
|
|
|
@ -23,17 +23,22 @@ export class VacuumSchema extends BaseUISchema {
|
||||||
return 'op';
|
return 'op';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isDisabled(state) {
|
||||||
|
if(state?.op) {
|
||||||
|
return (state.op != 'VACUUM');
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
id: 'vacuum_full',
|
id: 'vacuum_full',
|
||||||
group: gettext('Vacuum'),
|
group: gettext('Vacuum'),
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
if(state?.op) {
|
return obj.isDisabled(state);
|
||||||
return (state.op != 'VACUUM');
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
type: 'switch',
|
type: 'switch',
|
||||||
label: gettext('FULL'),
|
label: gettext('FULL'),
|
||||||
|
@ -42,11 +47,7 @@ export class VacuumSchema extends BaseUISchema {
|
||||||
id: 'vacuum_freeze',
|
id: 'vacuum_freeze',
|
||||||
deps: ['op'],
|
deps: ['op'],
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
if(state?.op) {
|
return obj.isDisabled(state);
|
||||||
return (state.op != 'VACUUM');
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
type: 'switch',
|
type: 'switch',
|
||||||
label: gettext('FREEZE'),
|
label: gettext('FREEZE'),
|
||||||
|
@ -56,11 +57,7 @@ export class VacuumSchema extends BaseUISchema {
|
||||||
deps: ['op'],
|
deps: ['op'],
|
||||||
type: 'switch',
|
type: 'switch',
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
if(state?.op) {
|
return obj.isDisabled(state);
|
||||||
return (state.op != 'VACUUM');
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
label: gettext('ANALYZE'),
|
label: gettext('ANALYZE'),
|
||||||
group: gettext('Vacuum'),
|
group: gettext('Vacuum'),
|
||||||
|
|
|
@ -27,6 +27,14 @@ export class RestoreSectionSchema extends BaseUISchema {
|
||||||
return 'id';
|
return 'id';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isDisabled(state) {
|
||||||
|
return this.selectedNodeType !== 'function' &&
|
||||||
|
this.selectedNodeType !== 'table' &&
|
||||||
|
this.selectedNodeType !== 'trigger' &&
|
||||||
|
this.selectedNodeType !== 'trigger_function' &&
|
||||||
|
(state.only_data || state.only_schema);
|
||||||
|
}
|
||||||
|
|
||||||
get baseFields() {
|
get baseFields() {
|
||||||
let obj = this;
|
let obj = this;
|
||||||
return [{
|
return [{
|
||||||
|
@ -36,10 +44,7 @@ export class RestoreSectionSchema extends BaseUISchema {
|
||||||
group: gettext('Sections'),
|
group: gettext('Sections'),
|
||||||
deps: ['only_data', 'only_schema'],
|
deps: ['only_data', 'only_schema'],
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
return obj.selectedNodeType !== 'function' && obj.selectedNodeType !== 'table' &&
|
return obj.isDisabled(state);
|
||||||
obj.selectedNodeType !== 'trigger' &&
|
|
||||||
obj.selectedNodeType !== 'trigger_function' &&
|
|
||||||
(state.only_data || state.only_schema);
|
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
id: 'data',
|
id: 'data',
|
||||||
|
@ -48,11 +53,7 @@ export class RestoreSectionSchema extends BaseUISchema {
|
||||||
group: gettext('Sections'),
|
group: gettext('Sections'),
|
||||||
deps: ['only_data', 'only_schema'],
|
deps: ['only_data', 'only_schema'],
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
return obj.selectedNodeType !== 'function' &&
|
return obj.isDisabled(state);
|
||||||
obj.selectedNodeType !== 'table' &&
|
|
||||||
obj.selectedNodeType !== 'trigger' &&
|
|
||||||
obj.selectedNodeType !== 'trigger_function' &&
|
|
||||||
(state.only_data || state.only_schema);
|
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
id: 'post_data',
|
id: 'post_data',
|
||||||
|
@ -61,11 +62,7 @@ export class RestoreSectionSchema extends BaseUISchema {
|
||||||
group: gettext('Sections'),
|
group: gettext('Sections'),
|
||||||
deps: ['only_data', 'only_schema'],
|
deps: ['only_data', 'only_schema'],
|
||||||
disabled: function(state) {
|
disabled: function(state) {
|
||||||
return obj.selectedNodeType !== 'function' &&
|
return obj.isDisabled(state);
|
||||||
obj.selectedNodeType !== 'table' &&
|
|
||||||
obj.selectedNodeType !== 'trigger' &&
|
|
||||||
obj.selectedNodeType !== 'trigger_function' &&
|
|
||||||
(state.only_data || state.only_schema);
|
|
||||||
},
|
},
|
||||||
}];
|
}];
|
||||||
}
|
}
|
||||||
|
|
|
@ -632,6 +632,16 @@ export default class SchemaDiffUI {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
transformFunc(data) {
|
||||||
|
let group_template_options = [];
|
||||||
|
for (let key in data) {
|
||||||
|
if (data.hasOwnProperty(key)) {
|
||||||
|
group_template_options.push({'group': key, 'optval': data[key]});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return group_template_options;
|
||||||
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
let self = this;
|
let self = this;
|
||||||
let panel = self.docker.findPanels('schema_diff_header_panel')[0];
|
let panel = self.docker.findPanels('schema_diff_header_panel')[0];
|
||||||
|
@ -645,13 +655,7 @@ export default class SchemaDiffUI {
|
||||||
name: 'source_sid', label: false,
|
name: 'source_sid', label: false,
|
||||||
control: SchemaDiffSelect2Control,
|
control: SchemaDiffSelect2Control,
|
||||||
transform: function(data) {
|
transform: function(data) {
|
||||||
let group_template_options = [];
|
return self.transformFunc(data);
|
||||||
for (let key in data) {
|
|
||||||
if (data.hasOwnProperty(key)) {
|
|
||||||
group_template_options.push({'group': key, 'optval': data[key]});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return group_template_options;
|
|
||||||
},
|
},
|
||||||
url: url_for('schema_diff.servers'),
|
url: url_for('schema_diff.servers'),
|
||||||
select2: {
|
select2: {
|
||||||
|
@ -729,13 +733,7 @@ export default class SchemaDiffUI {
|
||||||
name: 'target_sid', label: false,
|
name: 'target_sid', label: false,
|
||||||
control: SchemaDiffSelect2Control,
|
control: SchemaDiffSelect2Control,
|
||||||
transform: function(data) {
|
transform: function(data) {
|
||||||
let group_template_options = [];
|
return self.transformFunc(data);
|
||||||
for (let key in data) {
|
|
||||||
if (data.hasOwnProperty(key)) {
|
|
||||||
group_template_options.push({'group': key, 'optval': data[key]});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return group_template_options;
|
|
||||||
},
|
},
|
||||||
group: 'target',
|
group: 'target',
|
||||||
url: url_for('schema_diff.servers'),
|
url: url_for('schema_diff.servers'),
|
||||||
|
|
|
@ -192,6 +192,13 @@ define([
|
||||||
alertify.PgaLogin(title, url).resizeTo(pgBrowser.stdW.md, pgBrowser.stdH.md);
|
alertify.PgaLogin(title, url).resizeTo(pgBrowser.stdW.md, pgBrowser.stdH.md);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
is_editable: function(m) {
|
||||||
|
if (m instanceof Backbone.Collection) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return (m.get('id') != userInfo['id']);
|
||||||
|
},
|
||||||
|
|
||||||
// Callback to draw User Management Dialog.
|
// Callback to draw User Management Dialog.
|
||||||
show_users: function() {
|
show_users: function() {
|
||||||
if (!userInfo['is_admin']) return;
|
if (!userInfo['is_admin']) return;
|
||||||
|
@ -310,10 +317,7 @@ define([
|
||||||
return options;
|
return options;
|
||||||
},
|
},
|
||||||
editable: function(m) {
|
editable: function(m) {
|
||||||
if (m instanceof Backbone.Collection) {
|
return self.is_editable(m);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return (m.get('id') != userInfo['id']);
|
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
id: 'active',
|
id: 'active',
|
||||||
|
@ -323,10 +327,7 @@ define([
|
||||||
cellHeaderClasses: 'width_percent_10',
|
cellHeaderClasses: 'width_percent_10',
|
||||||
sortable: false,
|
sortable: false,
|
||||||
editable: function(m) {
|
editable: function(m) {
|
||||||
if (m instanceof Backbone.Collection) {
|
return self.is_editable(m);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return (m.get('id') != userInfo['id']);
|
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
id: 'newPassword',
|
id: 'newPassword',
|
||||||
|
@ -519,29 +520,13 @@ define([
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!!this.get('username') && this.collection.nonFilter.where({
|
if (!!this.get('username') && (this.collection.nonFilter.where({
|
||||||
'username': this.get('username'), 'auth_source': LDAP,
|
'username': this.get('username'), 'auth_source': LDAP,
|
||||||
}).length > 1) {
|
}).length > 1) || (this.collection.nonFilter.where({
|
||||||
errmsg = gettext('The username %s already exists.',
|
|
||||||
this.get('username')
|
|
||||||
);
|
|
||||||
|
|
||||||
this.errorModel.set('username', errmsg);
|
|
||||||
return errmsg;
|
|
||||||
}
|
|
||||||
else if (!!this.get('username') && this.collection.nonFilter.where({
|
|
||||||
'username': this.get('username'), 'auth_source': KERBEROS,
|
'username': this.get('username'), 'auth_source': KERBEROS,
|
||||||
}).length > 1) {
|
}).length > 1) || (this.collection.nonFilter.where({
|
||||||
errmsg = gettext('The username %s already exists.',
|
|
||||||
this.get('username')
|
|
||||||
);
|
|
||||||
|
|
||||||
this.errorModel.set('username', errmsg);
|
|
||||||
return errmsg;
|
|
||||||
}
|
|
||||||
else if (!!this.get('username') && this.collection.nonFilter.where({
|
|
||||||
'username': this.get('username'), 'auth_source': OAUTH2,
|
'username': this.get('username'), 'auth_source': OAUTH2,
|
||||||
}).length > 1) {
|
}).length > 1)) {
|
||||||
errmsg = gettext('The username %s already exists.',
|
errmsg = gettext('The username %s already exists.',
|
||||||
this.get('username')
|
this.get('username')
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue