const dbTypes = [ 'int', 'integer', 'bigint', 'bigserial', 'char', 'int2', 'int4', 'int8', 'int4range', 'int8range', 'serial', 'serial2', 'serial8', 'character', 'bit', 'bool', 'boolean', 'date', 'double precision', 'event_trigger', 'fdw_handler', 'float4', 'float8', 'uuid', 'smallint', 'smallserial', 'character varying', 'text', 'real', 'time', 'time without time zone', 'timestamp', 'timestamp without time zone', 'timestamptz', 'timestamp with time zone', 'timetz', 'time with time zone', 'daterange', 'json', 'jsonb', 'gtsvector', 'index_am_handler', 'anyenum', 'anynonarray', 'anyrange', 'box', 'bpchar', 'bytea', 'cid', 'cidr', 'circle', 'cstring', 'inet', 'internal', 'interval', 'language_handler', 'line', 'lsec', 'macaddr', 'money', 'name', 'numeric', 'numrange', 'oid', 'opaque', 'path', 'pg_ddl_command', 'pg_lsn', 'pg_node_tree', 'point', 'polygon', 'record', 'refcursor', 'regclass', 'regconfig', 'regdictionary', 'regnamespace', 'regoper', 'regoperator', 'regproc', 'regpreocedure', 'regrole', 'regtype', 'reltime', 'smgr', 'tid', 'tinterval', 'trigger', 'tsm_handler', 'tsquery', 'tsrange', 'tstzrange', 'tsvector', 'txid_snapshot', 'unknown', 'void', 'xid', 'xml'] export class PgUi { static getNewTableColumns() { return [ { cn: 'id', dt: 'int4', dtx: 'integer', ct: 'int(11)', nrqd: false, rqd: true, ck: false, pk: true, un: false, ai: true, cdf: null, clen: null, np: 11, ns: 0, dtxp: '11', dtxs: '', altered: 1, uidt: 'ID', uip: '', uicn: '' }, { cn: 'title', dt: 'character varying', dtx: 'specificType', ct: 'varchar(45)', nrqd: true, rqd: false, ck: false, pk: false, un: false, ai: false, cdf: null, clen: 45, np: null, ns: null, dtxp: '45', dtxs: '', altered: 1, uidt: 'SingleLineText', uip: '', uicn: '' }, { cn: 'created_at', dt: 'timestamp', dtx: 'specificType', ct: 'varchar(45)', nrqd: true, rqd: false, ck: false, pk: false, un: false, ai: false, cdf: 'now()', clen: 45, np: null, ns: null, dtxp: '', dtxs: '', altered: 1, uidt: 'CreateTime', uip: '', uicn: '' }, { cn: 'updated_at', dt: 'timestamp', dtx: 'specificType', ct: 'varchar(45)', nrqd: true, rqd: false, ck: false, pk: false, un: false, ai: false, au: true, cdf: 'now()', clen: 45, np: null, ns: null, dtxp: '', dtxs: '', altered: 1, uidt: 'LastModifiedTime', uip: '', uicn: '' } ] } static getNewColumn(suffix) { return { cn: 'title' + suffix, dt: 'int4', dtx: 'specificType', ct: 'integer(11)', nrqd: true, rqd: false, ck: false, pk: false, un: false, ai: false, cdf: null, clen: 45, np: null, ns: null, // data_type_x_specific: ' ', dtxp: '11', dtxs: ' ', altered: 1, uidt: 'Number', uip: '', uicn: '' } } static getDefaultLengthForDatatype(type) { switch (type) { case 'int': return '' case 'tinyint': return '' case 'smallint': return '' case 'mediumint': return '' case 'bigint': return '' case 'bit': return '' case 'boolean': return '' case 'float': return '' case 'decimal': return '' case 'double': return '' case 'serial': return '' case 'date': return '' case 'datetime': case 'timestamp': return '' case 'time': return '' case 'year': return '' case 'char': return '' case 'varchar': return '' case 'nchar': return '' case 'text': return '' case 'tinytext': return '' case 'mediumtext': return '' case 'longtext': return '' case 'binary': return '' case 'varbinary': return '' case 'blob': return '' case 'tinyblob': return '' case 'mediumblob': return '' case 'longblob': return '' case 'enum': return '' case 'set': return '' case 'geometry': return '' case 'point': return '' case 'linestring': return '' case 'polygon': return '' case 'multipoint': return '' case 'multilinestring': return '' case 'multipolygon': return '' case 'json': return '' } } static getDefaultLengthIsDisabled(type) { switch (type) { case 'anyenum': case 'anynonarray': case 'anyrange': case 'bigint': case 'bigserial': case 'bit': case 'bool': case 'box': case 'bpchar': case 'bytea': case 'char': case 'character': case 'cid': case 'cidr': case 'circle': case 'cstring': case 'date': case 'daterange': case 'double precision': case 'event_trigger': case 'fdw_handler': case 'float4': case 'float8': case 'gtsvector': case 'index_am_handler': case 'inet': case 'int': case 'int2': case 'int4': case 'int8': case 'int4range': case 'int8range': case 'integer': case 'internal': case 'interval': case 'jsonb': case 'language_handler': case 'line': case 'lsec': case 'macaddr': case 'money': case 'name': case 'numeric': case 'numrange': case 'oid': case 'opaque': case 'path': case 'pg_ddl_command': case 'pg_lsn': case 'pg_node_tree': case 'real': case 'record': case 'refcursor': case 'regclass': case 'regconfig': case 'regdictionary': case 'regnamespace': case 'regoper': case 'regoperator': case 'regproc': case 'regpreocedure': case 'regrole': case 'regtype': case 'reltime': case 'serial': case 'serial2': case 'serial8': case 'smallint': case 'smallserial': case 'smgr': case 'text': case 'tid': case 'time': case 'time without time zone': case 'timestamp': case 'timestamp without time zone': case 'timestamptz': case 'timestamp with time zone': case 'timetz': case 'time with time zone': case 'tinterval': case 'trigger': case 'tsm_handler': case 'tsquery': case 'tsrange': case 'tstzrange': case 'tsvector': case 'txid_snapshot': case 'unknown': case 'void': case 'xid': case 'xml': case 'character varying': case 'tinyint': case 'mediumint': case 'float': case 'decimal': case 'double': case 'boolean': case 'datetime': case 'uuid': case 'year': case 'varchar': case 'nchar': case 'tinytext': case 'mediumtext': case 'longtext': case 'binary': case 'varbinary': case 'blob': case 'tinyblob': case 'mediumblob': case 'longblob': case 'enum': case 'set': case 'geometry': case 'point': case 'linestring': case 'polygon': case 'multipoint': case 'multilinestring': case 'multipolygon': case 'json': return true } } static getDefaultValueForDatatype(type) { switch (type) { case 'anyenum': return 'eg: ' case 'anynonarray': return 'eg: ' case 'anyrange': return 'eg: ' case 'bigint': return 'eg: ' case 'bigserial': return 'eg: ' case 'bit': return 'eg: ' case 'bool': return 'eg: ' case 'box': return 'eg: ' case 'bpchar': return 'eg: ' case 'bytea': return 'eg: ' case 'char': return "eg: 'T'" case 'character': return "eg: 'sample'" case 'cid': return 'eg: ' case 'cidr': return 'eg: ' case 'circle': return 'eg: ' case 'cstring': return 'eg: ' case 'date': return "eg: '2020-09-09'" case 'daterange': return 'eg: ' case 'double precision': return 'eg: 1.2' case 'event_trigger': return 'eg: ' case 'fdw_handler': return 'eg: ' case 'float4': return 'eg: 1.2' case 'float8': return 'eg: 1.2' case 'gtsvector': return 'eg: ' case 'index_am_handler': return 'eg: ' case 'inet': return 'eg: ' case 'int': return 'eg: ' case 'int2': return 'eg: ' case 'int4': return 'eg: ' case 'int8': return 'eg: ' case 'int4range': return 'eg: ' case 'int8range': return 'eg: ' case 'integer': return 'eg: ' case 'internal': return 'eg: ' case 'interval': return 'eg: ' case 'json': return 'eg: ' case 'jsonb': return 'eg: ' case 'language_handler': return 'eg: ' case 'line': return 'eg: ' case 'lsec': return 'eg: ' case 'macaddr': return 'eg: ' case 'money': return 'eg: ' case 'name': return 'eg: ' case 'numeric': return 'eg: ' case 'numrange': return 'eg: ' case 'oid': return 'eg: ' case 'opaque': return 'eg: ' case 'path': return 'eg: ' case 'pg_ddl_command': return 'eg: ' case 'pg_lsn': return 'eg: ' case 'pg_node_tree': return 'eg: ' case 'point': return 'eg: ' case 'polygon': return 'eg: ' case 'real': return 'eg: 1.2' case 'record': return 'eg: ' case 'refcursor': return 'eg: ' case 'regclass': return 'eg: ' case 'regconfig': return 'eg: ' case 'regdictionary': return 'eg: ' case 'regnamespace': return 'eg: ' case 'regoper': return 'eg: ' case 'regoperator': return 'eg: ' case 'regproc': return 'eg: ' case 'regpreocedure': return 'eg: ' case 'regrole': return 'eg: ' case 'regtype': return 'eg: ' case 'reltime': return 'eg: ' case 'serial': return 'eg: ' case 'serial2': return 'eg: ' case 'serial8': return 'eg: ' case 'smallint': return 'eg: ' case 'smallserial': return 'eg: ' case 'smgr': return 'eg: ' case 'text': return "eg: 'sample text'" case 'tid': return 'eg: ' case 'time': return "eg: now()\n\n'04:05:06.789'" case 'time without time zone': return "eg: now()\n\n'04:05:06.789'" case 'timestamp': return "eg: now()\n\n'2016-06-22 19:10:25-07'" case 'timestamp without time zone': return "eg: now()\n\n'2016-06-22 19:10:25-07'" case 'timestamptz': return "eg: timezone('America/New_York','2016-06-01 00:00')\n\nnow()\n\n'2016-06-22 19:10:25-07'" case 'timestamp with time zone': return "eg: now()\n\n'2016-06-22 19:10:25-07'" case 'timetz': return 'eg: now()' case 'time with time zone': return 'eg: now()' case 'tinterval': return 'eg: ' case 'trigger': return 'eg: ' case 'tsm_handler': return 'eg: ' case 'tsquery': return 'eg: ' case 'tsrange': return 'eg: ' case 'tstzrange': return 'eg: ' case 'tsvector': return 'eg: ' case 'txid_snapshot': return 'eg: ' case 'unknown': return 'eg: ' case 'void': return 'eg: ' case 'xid': return 'eg: ' case 'xml': return 'eg: ' case 'character varying': return "eg: 'sample text'" case 'tinyint': return 'eg: ' case 'mediumint': return 'eg: ' case 'float': return 'eg: ' case 'decimal': return 'eg: ' case 'double': return 'eg: 1.2' case 'boolean': return 'eg: true\n\nfalse' case 'datetime': return 'eg: ' case 'uuid': return 'eg: ' case 'year': return 'eg: ' case 'varchar': return 'eg: ' case 'nchar': return 'eg: ' case 'tinytext': return 'eg: ' case 'mediumtext': return 'eg: ' case 'longtext': return 'eg: ' case 'binary': return 'eg: ' case 'varbinary': return 'eg: ' case 'blob': return 'eg: ' case 'tinyblob': return 'eg: ' case 'mediumblob': return 'eg: ' case 'longblob': return 'eg: ' case 'enum': return 'eg: ' case 'set': return 'eg: ' case 'geometry': return 'eg: ' case 'linestring': return 'eg: ' case 'multipoint': return 'eg: ' case 'multilinestring': return 'eg: ' case 'multipolygon': return 'eg: ' } } static getDefaultScaleForDatatype(type) { switch (type) { case 'int': return ' ' case 'tinyint': return ' ' case 'smallint': return ' ' case 'mediumint': return ' ' case 'bigint': return ' ' case 'bit': return ' ' case 'boolean': return ' ' case 'float': return '2' case 'decimal': return '2' case 'double': return '2' case 'serial': return ' ' case 'date': case 'datetime': case 'timestamp': return ' ' case 'time': return ' ' case 'year': return ' ' case 'char': return ' ' case 'varchar': return ' ' case 'nchar': return ' ' case 'text': return ' ' case 'tinytext': return ' ' case 'mediumtext': return ' ' case 'longtext': return ' ' case 'binary': return ' ' case 'varbinary': return ' ' case 'blob': return ' ' case 'tinyblob': return ' ' case 'mediumblob': return ' ' case 'longblob': return ' ' case 'enum': return ' ' case 'set': return ' ' case 'geometry': return ' ' case 'point': return ' ' case 'linestring': return ' ' case 'polygon': return ' ' case 'multipoint': return ' ' case 'multilinestring': return ' ' case 'multipolygon': return ' ' case 'json': return ' ' } } static colPropAIDisabled(col, columns) { // console.log(col); if (col.dt === 'int4' || col.dt === 'integer' || col.dt === 'bigint' || col.dt === 'smallint') { for (let i = 0; i < columns.length; ++i) { if (columns[i].column_name !== col.column_name && columns[i].ai) { return true } } return false } else { return true } } static colPropUNDisabled(col) { // console.log(col); return true // if (col.dt === 'int' || // col.dt === 'tinyint' || // col.dt === 'smallint' || // col.dt === 'mediumint' || // col.dt === 'bigint') { // return false; // } else { // return true; // } } static onCheckboxChangeAI(col) { console.log(col) if (col.dt === 'int' || col.dt === 'bigint' || col.dt === 'smallint' || col.dt === 'tinyint') { col.altered = col.altered || 2 } // if (!col.ai) { // col.dtx = 'specificType' // } else { // col.dtx = '' // } } static onCheckboxChangeAU(col) { console.log(col) // if (1) { col.altered = col.altered || 2 // } if (col.au) { col.cdf = 'now()' } // if (!col.ai) { // col.dtx = 'specificType' // } else { // col.dtx = '' // } } static showScale(columnObj) { return false } static removeUnsigned(columns) { for (let i = 0; i < columns.length; ++i) { if (columns[i].altered === 1 && (!(columns[i].dt === 'int' || columns[i].dt === 'bigint' || columns[i].dt === 'tinyint' || columns[i].dt === 'smallint' || columns[i].dt === 'mediumint'))) { columns[i].un = false console.log('>> resetting unsigned value', columns[i].column_name) } } } static columnEditable(colObj) { return colObj.table_name !== '_evolutions' || colObj.table_name !== 'nc_evolutions' } static extractFunctionName(query) { const reg = /^\s*CREATE\s+(?:OR\s+REPLACE\s*)?\s*FUNCTION\s+(?:[\w\d_]+\.)?([\w_\d]+)/i const match = query.match(reg) return match && match[1] } static extractProcedureName(query) { const reg = /^\s*CREATE\s+(?:OR\s+REPLACE\s*)?\s*PROCEDURE\s+(?:[\w\d_]+\.)?([\w_\d]+)/i const match = query.match(reg) return match && match[1] } static handleRawOutput(result, headers) { if (['DELETE', 'INSERT', 'UPDATE'].includes(result.command.toUpperCase())) { headers.push({ text: 'Row count', value: 'rowCount', sortable: false }) result = [{ rowCount: result.rowCount }] } else { result = result.rows if (Array.isArray(result) && result[0]) { const keys = Object.keys(result[0]) // set headers before settings result for (let i = 0; i < keys.length; i++) { const text = keys[i] headers.push({ text, value: text, sortable: false }) } } } return result } static splitQueries(query) { /*** * we are splitting based on semicolon * there are mechanism to escape semicolon within single/double quotes(string) */ return query.match(/\b("[^"]*;[^"]*"|'[^']*;[^']*'|[^;])*;/g) } /** * if sql statement is SELECT - it limits to a number * @param args * @returns {string|*} */ sanitiseQuery(args) { let q = args.query.trim().split(';') if (q[0].startsWith('Select')) { q = q[0] + ` LIMIT 0,${args.limit ? args.limit : 100};` } else if (q[0].startsWith('select')) { q = q[0] + ` LIMIT 0,${args.limit ? args.limit : 100};` } else if (q[0].startsWith('SELECT')) { q = q[0] + ` LIMIT 0,${args.limit ? args.limit : 100};` } else { return args.query } return q } static getColumnsFromJson(json, tn) { const columns = [] try { if (typeof json === 'object' && !Array.isArray(json)) { const keys = Object.keys(json) for (let i = 0; i < keys.length; ++i) { const column = { dp: null, tn, cn: keys[i], cno: keys[i], np: 10, ns: 0, clen: null, cop: 1, pk: false, nrqd: false, rqd: false, un: false, ct: 'int(11) unsigned', ai: false, unique: false, cdf: null, cc: '', csn: null, dtx: 'specificType', dtxp: null, dtxs: 0, altered: 1 } switch (typeof json[keys[i]]) { case 'number': if (Number.isInteger(json[keys[i]])) { if (PgUi.isValidTimestamp(keys[i], json[keys[i]])) { Object.assign(column, { dt: 'timestamp' }) } else { Object.assign(column, { dt: 'int', np: 10, ns: 0 }) } } else { Object.assign(column, { dt: 'float4', np: null, ns: null, dtxp: null, dtxs: null }) } break case 'string': if (PgUi.isValidDate(json[keys[i]])) { Object.assign(column, { dt: 'date' }) } else if (json[keys[i]].length <= 255) { Object.assign(column, { dt: 'character varying', np: null, ns: 0, dtxp: null }) } else { Object.assign(column, { dt: 'text' }) } break case 'boolean': Object.assign(column, { dt: 'boolean', np: 3, ns: 0 }) break case 'object': Object.assign(column, { dt: 'json', np: 3, ns: 0 }) break default: break } columns.push(column) } } } catch (e) { console.log('Error in getColumnsFromJson', e) } return columns } static isValidTimestamp(key, value) { if (typeof value !== 'number') { return false } return new Date(value).getTime() > 0 && /(?:_|(?=A))[aA]t$/.test(key) } static isValidDate(value) { return new Date(value).getTime() > 0 } static colPropAuDisabled(col) { if (col.altered !== 1) { return true } switch (col.dt) { case 'time': case 'time without time zone': case 'timestamp': case 'timestamp without time zone': case 'timestamptz': case 'timestamp with time zone': case 'timetz': case 'time with time zone': return false default: return true } } static getAbstractType(col) { switch ((col.dt || col.dt).toLowerCase()) { case 'anyenum': return 'enum' case 'anynonarray': case 'anyrange': return 'string' case 'bit': return 'integer' case 'bigint': case 'bigserial': return 'string' case 'bool': return 'boolean' case 'box': case 'bpchar': case 'bytea': case 'char': case 'character': return 'string' case 'cid': case 'cidr': case 'circle': case 'cstring': return 'string' case 'date': return 'date' case 'daterange': return 'string' case 'double precision': return 'string' case 'event_trigger': case 'fdw_handler': return 'string' case 'float4': case 'float8': return 'float' case 'gtsvector': case 'index_am_handler': case 'inet': return 'string' case 'int': case 'int2': case 'int4': case 'int8': case 'integer': return 'integer' case 'int4range': case 'int8range': case 'internal': case 'interval': return 'string' case 'jsonb': return 'string' case 'language_handler': case 'line': case 'lsec': case 'macaddr': case 'money': case 'name': case 'numeric': case 'numrange': case 'oid': case 'opaque': case 'path': case 'pg_ddl_command': case 'pg_lsn': case 'pg_node_tree': case 'point': case 'polygon': return 'string' case 'real': return 'float' case 'record': case 'refcursor': case 'regclass': case 'regconfig': case 'regdictionary': case 'regnamespace': case 'regoper': case 'regoperator': case 'regproc': case 'regpreocedure': case 'regrole': case 'regtype': case 'reltime': return 'string' case 'serial': case 'serial2': case 'serial8': case 'smallint': case 'smallserial': return 'integer' case 'smgr': return 'string' case 'text': return 'text' case 'tid': return 'string' case 'time': case 'time without time zone': return 'time' case 'timestamp': case 'timestamp without time zone': case 'timestamptz': case 'timestamp with time zone': return 'datetime' case 'timetz': case 'time with time zone': return 'time' case 'tinterval': case 'trigger': case 'tsm_handler': case 'tsquery': case 'tsrange': case 'tstzrange': case 'tsvector': case 'txid_snapshot': case 'unknown': case 'void': case 'xid': case 'character varying': case 'xml': return 'string' case 'tinyint': case 'mediumint': return 'integer' case 'float': case 'decimal': case 'double': return 'float' case 'boolean': return 'boolean' case 'datetime': return 'datetime' case 'uuid': case 'year': case 'varchar': case 'nchar': return 'string' case 'tinytext': case 'mediumtext': case 'longtext': return 'text' case 'binary': case 'varbinary': return 'string' case 'blob': case 'tinyblob': case 'mediumblob': case 'longblob': return 'blob' case 'enum': return 'enum' case 'set': return 'set' case 'geometry': case 'linestring': case 'multipoint': case 'multilinestring': case 'multipolygon': return 'string' case 'json': return 'json' } } static getUIType(col) { switch (this.getAbstractType(col)) { case 'integer': return 'Number' case 'boolean': return 'Checkbox' case 'float': return 'Decimal' case 'date': return 'Date' case 'datetime': return 'CreateTime' case 'time': return 'Time' case 'year': return 'Year' case 'string': return 'SingleLineText' case 'text': return 'LongText' case 'blob': return 'Attachment' case 'enum': return 'SingleSelect' case 'set': return 'MultiSelect' case 'json': return 'LongText' } } static getDataTypeForUiType(col) { const colProp = {} switch (col.uidt) { case 'ID': colProp.dt = 'int4' colProp.pk = true colProp.un = true colProp.ai = true colProp.rqd = true break case 'ForeignKey': colProp.dt = 'character varying' break case 'SingleLineText': colProp.dt = 'character varying' break case 'LongText': colProp.dt = 'text' break case 'Attachment': colProp.dt = 'text' break case 'Checkbox': colProp.dt = 'bool' break case 'MultiSelect': colProp.dt = 'text' break case 'SingleSelect': colProp.dt = 'text' break case 'Collaborator': colProp.dt = 'character varying' break case 'Date': colProp.dt = 'date' break case 'Year': colProp.dt = 'int' break case 'Time': colProp.dt = 'time' break case 'PhoneNumber': colProp.dt = 'character varying' colProp.validate = { func: ['isMobilePhone'], args: [''], msg: ['Validation failed : Invalid Mobile Format'] } break case 'Email': colProp.dt = 'character varying' colProp.validate = { func: ['isEmail'], args: [''], msg: ['Validation failed : Invalid Email Format'] } break case 'URL': colProp.dt = 'character varying' colProp.validate = { func: ['isURL'], args: [''], msg: ['Validation failed : Invalid URL Format'] } break case 'Number': colProp.dt = 'int8' break case 'Decimal': colProp.dt = 'decimal' break case 'Currency': colProp.dt = 'decimal' colProp.validate = { func: ['isCurrency'], args: [''], msg: ['Validation failed : Invalid Currency Format'] } break case 'Percent': colProp.dt = 'float8' break case 'Duration': colProp.dt = 'int8' break case 'Rating': colProp.dt = 'float8' break case 'Formula': colProp.dt = 'character varying' break case 'Rollup': colProp.dt = 'character varying' break case 'Count': colProp.dt = 'int8' break case 'Lookup': colProp.dt = 'character varying' break case 'DateTime': colProp.dt = 'timestamp' break case 'CreateTime': colProp.dt = 'timestamp' break case 'LastModifiedTime': colProp.dt = 'timestamp' break case 'AutoNumber': colProp.dt = 'int' break case 'Barcode': colProp.dt = 'character varying' break case 'Button': colProp.dt = 'character varying' break case 'JSON': colProp.dt = 'json' break default: colProp.dt = 'character varying' break } return colProp } static getDataTypeListForUiType(col) { switch (col.uidt) { case 'ID': case 'ForeignKey': return dbTypes case 'SingleLineText': case 'LongText': case 'Collaborator': return [ 'char', 'character', 'character varying', 'text' ] case 'Attachment': return [ 'json', 'char', 'character', 'character varying', 'text' ] case 'JSON': return [ 'json', 'text' ] case 'Checkbox': return [ 'bit', 'bool', 'int2', 'int4', 'int8', 'boolean', 'smallint', 'int', 'integer', 'bigint', 'bigserial', 'char', 'int4range', 'int8range', 'serial', 'serial2', 'serial8' ] case 'MultiSelect': return [ 'text' ] case 'SingleSelect': return [ 'text' ] case 'Year': return ['int'] case 'Time': return ['time', 'time without time zone', 'timestamp', 'timestamp without time zone', 'timestamptz', 'timestamp with time zone', 'timetz', 'time with time zone'] case 'PhoneNumber': case 'Email': return [ 'character varying' ] case 'URL': return [ 'character varying', 'text' ] case 'Number': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'numeric', 'serial', 'serial2', 'serial8', 'double precision', 'float4', 'float8', 'smallint', 'smallserial' ] case 'Decimal': return [ 'double precision', 'numeric', 'float4', 'float8' ] case 'Currency': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'numeric', 'serial', 'serial2', 'serial8', 'double precision', 'money', 'float4', 'float8' ] case 'Percent': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'numeric', 'serial', 'serial2', 'serial8', 'double precision', 'float4', 'float8', 'smallint', 'smallserial' ] case 'Duration': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'numeric', 'serial', 'serial2', 'serial8', 'double precision', 'float4', 'float8', 'smallint', 'smallserial' ] case 'Rating': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'numeric', 'serial', 'serial2', 'serial8', 'double precision', 'float4', 'float8', 'smallint', 'smallserial' ] case 'Formula': return [ 'text', 'character varying' ] case 'Rollup': return [ 'character varying' ] case 'Count': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'serial', 'serial2', 'serial8', 'smallint', 'smallserial' ] case 'Lookup': return [ 'character varying' ] case 'Date': return [ 'date', 'timestamp', 'timestamp without time zone', 'timestamptz', 'timestamp with time zone' ] case 'DateTime': case 'CreateTime': case 'LastModifiedTime': return [ 'timestamp', 'timestamp without time zone', 'timestamptz', 'timestamp with time zone' ] case 'AutoNumber': return [ 'int', 'integer', 'bigint', 'bigserial', 'int2', 'int4', 'int8', 'serial', 'serial2', 'serial8', 'smallint', 'smallserial' ] case 'Barcode': return ['character varying'] case 'Geometry': return [ 'polygon', 'point', 'circle', 'box', 'line', 'lseg', 'path', 'circle' ] case 'Button': default: return dbTypes } } static getUnsupportedFnList() { return [] } } // module.exports = PgUiHelp; /** * @copyright Copyright (c) 2021, Xgene Cloud Ltd * * @author Naveen MR * @author Pranav C Balan * * @license GNU AGPL version 3 or any later version * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * */