@opengis/admin 0.2.111 → 0.2.113

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/README.md +97 -97
  2. package/config.js +4 -4
  3. package/dist/{add-page-CJwzSjcW.js → add-page-BH6RXRcE.js} +1 -1
  4. package/dist/{admin-interface-BZFCowsT.js → admin-interface-crBtXD5Z.js} +2 -2
  5. package/dist/{admin-view-CCuPr8g1.js → admin-view-BlFQ5MAm.js} +2 -2
  6. package/dist/admin.js +1 -1
  7. package/dist/admin.umd.cjs +71 -71
  8. package/dist/assets/logo.svg +41 -41
  9. package/dist/{card-view-Cn_iP3q3.js → card-view-CQBLU6QA.js} +1 -1
  10. package/dist/{edit-page-CieGhQpW.js → edit-page-8HoFhOIT.js} +1 -1
  11. package/dist/{import-file-BwBdLE9n.js → import-file-BJbIy5cf.js} +7577 -7547
  12. package/dist/{profile-page-CWBKAVrP.js → profile-page-BYj-liZM.js} +1 -1
  13. package/dist/style.css +1 -1
  14. package/module/settings/card/admin.accounts.table/index.yml +7 -7
  15. package/module/settings/card/admin.accounts.table/rules.hbs +18 -18
  16. package/module/settings/card/admin.accounts.table/users.hbs +13 -13
  17. package/module/settings/card/admin.routes.table/groups.hbs +11 -11
  18. package/module/settings/card/admin.routes.table/index.yml +11 -11
  19. package/module/settings/card/admin.routes.table/users.hbs +16 -16
  20. package/module/settings/cls/core.actions.json +17 -17
  21. package/module/settings/cls/core.scope.json +13 -13
  22. package/module/settings/cls/properties.site_status.json +13 -13
  23. package/module/settings/cls/properties.widget_status.json +13 -13
  24. package/module/settings/cls/users.user_type.json +13 -13
  25. package/module/settings/cls/yes_no.json +11 -11
  26. package/module/settings/form/admin.accounts.form.json +13 -13
  27. package/module/settings/form/admin.properties.form.json +15 -15
  28. package/module/settings/form/admin.roles.form.json +21 -21
  29. package/module/settings/form/admin.user_properties.form.json +15 -15
  30. package/module/settings/form/admin.user_roles_card.form.json +13 -13
  31. package/module/settings/interface/admin.properties.json +4 -4
  32. package/module/settings/interface/admin.roles.json +4 -4
  33. package/module/settings/interface/admin.routes.json +4 -4
  34. package/module/settings/interface/admin.users.json +4 -4
  35. package/module/settings/select/core.routes.sql +1 -1
  36. package/module/settings/select/core.user_mentioned.sql +1 -1
  37. package/module/settings/select/core.user_uid.sql +1 -1
  38. package/module/settings/table/admin.properties.table.json +39 -39
  39. package/module/settings/table/admin.user_properties.table.json +34 -34
  40. package/package.json +2 -2
  41. package/plugin.js +29 -29
  42. package/server/helpers/core/badge.js +16 -16
  43. package/server/helpers/core/buttonHelper.js +21 -21
  44. package/server/helpers/core/select.js +48 -48
  45. package/server/helpers/core/token.js +18 -18
  46. package/server/helpers/index.js +31 -31
  47. package/server/helpers/list/buttonHelper.js +21 -21
  48. package/server/helpers/list/descriptionList.js +1 -1
  49. package/server/helpers/list/utils/button.js +5 -5
  50. package/server/helpers/temp/contentList.js +58 -58
  51. package/server/helpers/temp/ifCond.js +101 -101
  52. package/server/helpers/utils/button.js +5 -5
  53. package/server/plugins/access/index.mjs +6 -6
  54. package/server/plugins/adminHook.js +81 -81
  55. package/server/plugins/cron.js +10 -10
  56. package/server/plugins/docs.js +28 -28
  57. package/server/routes/access/controllers/access.group.js +29 -29
  58. package/server/routes/access/controllers/access.group.post.js +54 -54
  59. package/server/routes/access/index.mjs +11 -11
  60. package/server/routes/access/schema.mjs +67 -67
  61. package/server/routes/calendar/controllers/calendar.data.js +125 -125
  62. package/server/routes/calendar/index.mjs +7 -7
  63. package/server/routes/calendar/schema.js +21 -21
  64. package/server/routes/data/controllers/cardData.js +117 -117
  65. package/server/routes/data/controllers/cardTabData.js +49 -49
  66. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  67. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  68. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  69. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  70. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  71. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  72. package/server/routes/data/controllers/tableData.js +31 -31
  73. package/server/routes/data/controllers/tableDataId.js +27 -27
  74. package/server/routes/data/controllers/tableFilter.js +101 -101
  75. package/server/routes/data/controllers/tokenInfo.js +9 -9
  76. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  77. package/server/routes/data/controllers/utils/conditions.js +20 -20
  78. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  79. package/server/routes/data/index.mjs +20 -20
  80. package/server/routes/data/schema.js +54 -54
  81. package/server/routes/menu/index.mjs +5 -5
  82. package/server/routes/notifications/controllers/readNotifications.js +27 -27
  83. package/server/routes/notifications/controllers/testEmail.js +35 -35
  84. package/server/routes/notifications/controllers/userNotifications.js +53 -53
  85. package/server/routes/notifications/funcs/addNotification.js +21 -21
  86. package/server/routes/notifications/funcs/sendNotification.js +92 -92
  87. package/server/routes/notifications/hook/onWidgetSet.js +56 -56
  88. package/server/routes/notifications/index.mjs +26 -26
  89. package/server/routes/notifications/schema.js +16 -16
  90. package/server/routes/print/controllers/cardPrint.js +134 -134
  91. package/server/routes/properties/funcs/getSettings.js +56 -56
  92. package/server/routes/properties/schema.js +10 -10
  93. package/server/routes/root.mjs +3 -3
  94. package/server/routes/templates/controllers/getTemplate.js +49 -49
  95. package/server/routes/templates/index.mjs +16 -16
  96. package/server/routes/templates/schema.js +8 -8
  97. package/server/routes/user/controllers/user.cls.id.js +14 -14
  98. package/server/routes/user/controllers/user.cls.js +71 -71
  99. package/server/routes/user/controllers/user.info.js +17 -17
  100. package/server/routes/user/schema.js +14 -14
  101. package/server/routes/widget/controllers/widget.del.js +47 -47
  102. package/server/routes/widget/controllers/widget.set.js +84 -84
  103. package/server/routes/widget/hook/onWidgetSet.js +12 -12
  104. package/server/routes/widget/index.mjs +16 -16
  105. package/server/routes/widget/schema.js +12 -12
  106. package/server/templates/cls/itree.recrzone_category.json +73 -73
  107. package/server/templates/cls/test.json +9 -9
  108. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  109. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  110. package/server/templates/form/form-user-pass.json +10 -10
  111. package/server/templates/form/form-user_group.json +39 -39
  112. package/server/templates/form/form-users.json +156 -156
  113. package/server/templates/form/user_group_access.form.json +22 -22
  114. package/server/templates/select/account_id.json +2 -2
  115. package/server/templates/setting/test.json +5 -5
  116. package/server/templates/table/gis.dataset.table.json +43 -43
  117. package/server/templates/table/management.user_group.table.json +112 -112
  118. package/server/templates/table/management.users.table.json +126 -126
  119. package/utils.js +29 -29
@@ -1,118 +1,118 @@
1
- import path from 'node:path';
2
-
3
- import { getAccess, handlebars, setOpt, setToken, getTemplate, handlebarsSync, applyHook } from "@opengis/fastify-table/utils.js";
4
- //import { setOpt, setToken } from "../../../../../fastify-table/utils.js";
5
- // import yaml from 'js-yaml';
6
- import getTableData from "./tableData.js";
7
- import conditions from './utils/conditions.js';
8
-
9
- const components = {
10
- 'vs-widget-file': `select 'vs-widget-file' as component, count(*) from crm.files where entity_id=$1 and file_status<>3`,
11
- 'vs-widget-comments': `select 'vs-widget-comments' as component, count(*) from crm.communications where entity_id=$1`
12
- };
13
-
14
- export default async function getCardData(req) {
15
-
16
- const {
17
- pg, params = {}, session = {}, user
18
- } = req;
19
- const { table, id } = params;
20
- const uid = session.passport?.user?.uid;
21
-
22
- const res = await applyHook('cardData', { table, id, user });
23
- if (res) return res;
24
-
25
-
26
- const time = Date.now();
27
-
28
- const template = await getTemplate('card', table);
29
- const access = await getAccess({ table, user });
30
-
31
- const tableTemplate = await getTemplate('table', table);
32
-
33
- const index = template?.find(el => el[0] === 'index.yml')?.[1] || {};
34
-
35
- const { message, rows = [] } = index.table && index.query ? await pg.query(`select * from ${index.table} where ${handlebarsSync.compile(index.query)({ uid, user })}`) :
36
- await getTableData({ pg, params: { table, id }, session, user });
37
-
38
- if (message) return { message };
39
-
40
- // conditions
41
- index.panels?.filter(el => el.items).forEach(el => {
42
- el.items = el.items?.filter(el => conditions(el.conditions, rows[0]));
43
- })
44
-
45
- // title, count
46
- index.panels?.filter(el => el.items).forEach(async el => {
47
- const filtered = el.items.filter(el => el.count?.toLowerCase?.().includes('select'));
48
- const data = await Promise.all(filtered.map(el => pg.query(el.count).then(el => el.rows[0] || {})))
49
- filtered.forEach((el, i) => {
50
- Object.assign(el, data[i] || {}, data[i].count ? {} : { count: undefined })
51
- });
52
- const q = el.items.map((el) => el.component ? components[el.component] : null).filter(el => el).join(' union all ');
53
- const counts = q && id
54
- ? await pg.query(q, [id])
55
- .then(e => e.rows.reduce((acc, curr) => Object.assign(acc, { [curr.component]: curr.count }), {}))
56
- : {};
57
- el.items?.filter?.(item => item.component)?.forEach(item => Object.assign(item, { count: counts?.[item.component] }));
58
- })
59
-
60
-
61
- // tokens result
62
- const tokens = {};
63
- if (access.actions?.includes?.('edit') && index?.tokens && typeof index?.tokens === 'object' && !Array.isArray(index?.tokens)) {
64
- for (let key in index?.tokens) {
65
- const item = index?.tokens[key];
66
- Object.keys(item).filter(el => item[el]?.includes?.('{{')).forEach(el => {
67
- item[el] = handlebarsSync.compile(item[el])({ user, uid: user?.uid, id, data: rows[0] });
68
- });
69
-
70
- const token = item.form && item.table ? setToken({
71
- ids: [JSON.stringify(item)],
72
- uid,
73
- array: 1,
74
- })[0] : setOpt(item, user.uid);
75
- tokens[key] = token;
76
- }
77
- }
78
-
79
- // vue result
80
- const vue = template?.filter((el) => el[0].endsWith('.vue'))
81
- .reduce((acc, curr) => Object.assign(acc, { [path.parse(curr[0]).name]: curr[1].match(/<template[^>]*>([\s\S]*?)<\/template>/)[1].trim() }), {});
82
-
83
- // data result
84
- const data = {};
85
- if (index?.data && index?.data?.[0]?.name) {
86
- await Promise.all(index.data.filter((el) => el?.name && el?.sql).map(async (el) => {
87
- const q = handlebarsSync.compile(el.sql)({ data: rows[0], user, uid: user?.uid, id });
88
- const { rows: sqlData } = await pg.query(q);
89
- data[el.name] = sqlData;
90
- }));
91
- }
92
-
93
-
94
-
95
- // html result
96
- const html = {};
97
- if (template) {
98
- await Promise.all(template.filter(el => el[0].includes('.hbs')).map(async (el) => {
99
- const htmlContent = await handlebars.compile(el[1])({ ...rows[0], user, data, tokens });
100
- const name = el[0].substring(0, el[0].lastIndexOf('.'))
101
- html[name] = htmlContent;
102
- }));
103
- }
104
-
105
- return {
106
- time: Date.now() - time,
107
- ...index,
108
- tokens,
109
- vue,
110
- data,
111
- html,
112
- rows,
113
- columns: tableTemplate?.columns || tableTemplate?.colModel,
114
- table: undefined,
115
- query: undefined,
116
- };
117
-
1
+ import path from 'node:path';
2
+
3
+ import { getAccess, handlebars, setOpt, setToken, getTemplate, handlebarsSync, applyHook } from "@opengis/fastify-table/utils.js";
4
+ //import { setOpt, setToken } from "../../../../../fastify-table/utils.js";
5
+ // import yaml from 'js-yaml';
6
+ import getTableData from "./tableData.js";
7
+ import conditions from './utils/conditions.js';
8
+
9
+ const components = {
10
+ 'vs-widget-file': `select 'vs-widget-file' as component, count(*) from crm.files where entity_id=$1 and file_status<>3`,
11
+ 'vs-widget-comments': `select 'vs-widget-comments' as component, count(*) from crm.communications where entity_id=$1`
12
+ };
13
+
14
+ export default async function getCardData(req) {
15
+
16
+ const {
17
+ pg, params = {}, session = {}, user
18
+ } = req;
19
+ const { table, id } = params;
20
+ const uid = session.passport?.user?.uid;
21
+
22
+ const res = await applyHook('cardData', { table, id, user });
23
+ if (res) return res;
24
+
25
+
26
+ const time = Date.now();
27
+
28
+ const template = await getTemplate('card', table);
29
+ const access = await getAccess({ table, user });
30
+
31
+ const tableTemplate = await getTemplate('table', table);
32
+
33
+ const index = template?.find(el => el[0] === 'index.yml')?.[1] || {};
34
+
35
+ const { message, rows = [] } = index.table && index.query ? await pg.query(`select * from ${index.table} where ${handlebarsSync.compile(index.query)({ uid, user })}`) :
36
+ await getTableData({ pg, params: { table, id }, session, user });
37
+
38
+ if (message) return { message };
39
+
40
+ // conditions
41
+ index.panels?.filter(el => el.items).forEach(el => {
42
+ el.items = el.items?.filter(el => conditions(el.conditions, rows[0]));
43
+ })
44
+
45
+ // title, count
46
+ index.panels?.filter(el => el.items).forEach(async el => {
47
+ const filtered = el.items.filter(el => el.count?.toLowerCase?.().includes('select'));
48
+ const data = await Promise.all(filtered.map(el => pg.query(el.count).then(el => el.rows[0] || {})))
49
+ filtered.forEach((el, i) => {
50
+ Object.assign(el, data[i] || {}, data[i].count ? {} : { count: undefined })
51
+ });
52
+ const q = el.items.map((el) => el.component ? components[el.component] : null).filter(el => el).join(' union all ');
53
+ const counts = q && id
54
+ ? await pg.query(q, [id])
55
+ .then(e => e.rows.reduce((acc, curr) => Object.assign(acc, { [curr.component]: curr.count }), {}))
56
+ : {};
57
+ el.items?.filter?.(item => item.component)?.forEach(item => Object.assign(item, { count: counts?.[item.component] }));
58
+ })
59
+
60
+
61
+ // tokens result
62
+ const tokens = {};
63
+ if (access.actions?.includes?.('edit') && index?.tokens && typeof index?.tokens === 'object' && !Array.isArray(index?.tokens)) {
64
+ for (let key in index?.tokens) {
65
+ const item = index?.tokens[key];
66
+ Object.keys(item).filter(el => item[el]?.includes?.('{{')).forEach(el => {
67
+ item[el] = handlebarsSync.compile(item[el])({ user, uid: user?.uid, id, data: rows[0] });
68
+ });
69
+
70
+ const token = item.form && item.table ? setToken({
71
+ ids: [JSON.stringify(item)],
72
+ uid,
73
+ array: 1,
74
+ })[0] : setOpt(item, user.uid);
75
+ tokens[key] = token;
76
+ }
77
+ }
78
+
79
+ // vue result
80
+ const vue = template?.filter((el) => el[0].endsWith('.vue'))
81
+ .reduce((acc, curr) => Object.assign(acc, { [path.parse(curr[0]).name]: curr[1].match(/<template[^>]*>([\s\S]*?)<\/template>/)[1].trim() }), {});
82
+
83
+ // data result
84
+ const data = {};
85
+ if (index?.data && index?.data?.[0]?.name) {
86
+ await Promise.all(index.data.filter((el) => el?.name && el?.sql).map(async (el) => {
87
+ const q = handlebarsSync.compile(el.sql)({ data: rows[0], user, uid: user?.uid, id });
88
+ const { rows: sqlData } = await pg.query(q);
89
+ data[el.name] = sqlData;
90
+ }));
91
+ }
92
+
93
+
94
+
95
+ // html result
96
+ const html = {};
97
+ if (template) {
98
+ await Promise.all(template.filter(el => el[0].includes('.hbs')).map(async (el) => {
99
+ const htmlContent = await handlebars.compile(el[1])({ ...rows[0], user, data, tokens });
100
+ const name = el[0].substring(0, el[0].lastIndexOf('.'))
101
+ html[name] = htmlContent;
102
+ }));
103
+ }
104
+
105
+ return {
106
+ time: Date.now() - time,
107
+ ...index,
108
+ tokens,
109
+ vue,
110
+ data,
111
+ html,
112
+ rows,
113
+ columns: tableTemplate?.columns || tableTemplate?.colModel,
114
+ table: undefined,
115
+ query: undefined,
116
+ };
117
+
118
118
  }
@@ -1,50 +1,50 @@
1
- import { config, handlebars, getToken, getTemplate, getMeta } from "@opengis/fastify-table/utils.js";
2
-
3
- import getTableData from "./tableData.js";
4
-
5
- export default async function cardTabData({
6
- pg, query = {}, params = {}, session = {},
7
- }) {
8
- const { token } = params;
9
- const { sql } = query;
10
-
11
- if (!token) {
12
- return { message: 'not enough params: token', status: 400 };
13
- }
14
-
15
- const time = Date.now();
16
- const { uid } = config?.auth?.disable ? { uid: '1' } : (session.passport?.user || {});
17
-
18
- const props = await getToken({
19
- token,
20
- mode: 'w',
21
- uid,
22
- json: 1,
23
- });
24
-
25
- if (!props || !props?.table || !props) {
26
- return { message: { error: 'token is invalid', props }, status: 403 };
27
- }
28
-
29
- const tableTemplate = await getTemplate('table', props.table);
30
-
31
- const { columns = [] } = tableTemplate?.columns || tableTemplate?.colModel
32
- ? { columns: tableTemplate?.columns || tableTemplate?.colModel }
33
- : await getMeta({ table: props.table });
34
-
35
- const filter = await handlebars.compile(props.query.replace(/@id/g, '{{id}}'))(props);
36
- const { message, rows = [] } = await getTableData({ pg, params: { table: props.table }, session, query: { filter, sql } });
37
- if (message) return { message };
38
-
39
- if (props.columns?.length && rows?.length) {
40
- const allowList = ['id', 'token'].concat(props.columns).map((el) => [el, `${el}_text`]).flat();
41
- rows.forEach((row) => Object.keys(row).forEach((el) => { if (!allowList.includes(el)) delete row[el]; }));
42
-
43
- return {
44
- time: Date.now() - time,
45
- rows,
46
- columns: columns.filter((col) => props.columns.includes(col.name)),
47
- };
48
- }
49
- return { time: Date.now() - time, rows, columns };
1
+ import { config, handlebars, getToken, getTemplate, getMeta } from "@opengis/fastify-table/utils.js";
2
+
3
+ import getTableData from "./tableData.js";
4
+
5
+ export default async function cardTabData({
6
+ pg, query = {}, params = {}, session = {},
7
+ }) {
8
+ const { token } = params;
9
+ const { sql } = query;
10
+
11
+ if (!token) {
12
+ return { message: 'not enough params: token', status: 400 };
13
+ }
14
+
15
+ const time = Date.now();
16
+ const { uid } = config?.auth?.disable ? { uid: '1' } : (session.passport?.user || {});
17
+
18
+ const props = await getToken({
19
+ token,
20
+ mode: 'w',
21
+ uid,
22
+ json: 1,
23
+ });
24
+
25
+ if (!props || !props?.table || !props) {
26
+ return { message: { error: 'token is invalid', props }, status: 403 };
27
+ }
28
+
29
+ const tableTemplate = await getTemplate('table', props.table);
30
+
31
+ const { columns = [] } = tableTemplate?.columns || tableTemplate?.colModel
32
+ ? { columns: tableTemplate?.columns || tableTemplate?.colModel }
33
+ : await getMeta({ table: props.table });
34
+
35
+ const filter = await handlebars.compile(props.query.replace(/@id/g, '{{id}}'))(props);
36
+ const { message, rows = [] } = await getTableData({ pg, params: { table: props.table }, session, query: { filter, sql } });
37
+ if (message) return { message };
38
+
39
+ if (props.columns?.length && rows?.length) {
40
+ const allowList = ['id', 'token'].concat(props.columns).map((el) => [el, `${el}_text`]).flat();
41
+ rows.forEach((row) => Object.keys(row).forEach((el) => { if (!allowList.includes(el)) delete row[el]; }));
42
+
43
+ return {
44
+ time: Date.now() - time,
45
+ rows,
46
+ columns: columns.filter((col) => props.columns.includes(col.name)),
47
+ };
48
+ }
49
+ return { time: Date.now() - time, rows, columns };
50
50
  }
@@ -1,92 +1,92 @@
1
- import { getPG, getTemplate } from "@opengis/fastify-table/utils.js";
2
- // import pgClients from '@opengis/fastify-table/pg/funcs/pgClients.js';
3
-
4
- import getTableSql from './util/getTableSql.js';
5
- import getFilterQuery from './util/getFilterQuery.js';
6
- import getOptimizedQuery from './util/getOptimizedQuery.js';
7
-
8
- async function getFilterSQL({
9
- pg: pg1, table, filter, search, filterList, query, uid,
10
- }) {
11
- if (!table) return { error: 'param table is required', status: 400 };
12
-
13
- const pg = pg1 || getPG();
14
- const body = await getTemplate('table', table);
15
-
16
- const sqlList = body?.sql?.length
17
- ? body?.sql?.filter((el) => !el.disabled && el?.sql?.replace)
18
- .map((el, i) => {
19
- Object.assign(el, { name: el.name || `t${i + 1}` });
20
- return ` left join lateral (${el.filter ? el.sql.replace(/limit 1/ig, '') : el.sql}) as ${el.name} on 1=1 `;
21
- }).join(' ')
22
- : '';
23
- const fieldQuery = `select * from ${body?.table || table} ${sqlList ? ` t ${sqlList}` : ''} where 1=1 limit 0`;
24
- const { fields = [] } = await pg.query(fieldQuery);
25
-
26
- const { fields: fieldsModel } = pg.pk[body?.table] ? await pg.query(`select * from ${body.table} limit 0`) : {};
27
-
28
- const autoSearchColumn = fields?.filter((el) => pg.pgType?.[el.dataTypeID] === 'text')?.map((el) => el.name).join(',');
29
- const searchColumn = body?.search_column || autoSearchColumn;
30
- const fieldsList = (fieldsModel || fields)?.map((el) => el.name);
31
- try {
32
- const tableSQL = await getTableSql({
33
- pg, body, table, fields,
34
- });
35
- const sval = `ilike '%${decodeURIComponent(search).replace(/'/g, "''")}%'`;
36
- const searchQuery = search && searchColumn
37
- ? ` (${searchColumn.split(',')?.map((name) => {
38
- const { pk } = tableSQL.find((el) => el.name === name) || {};
39
- return pk && !fieldsList.includes(name) ? `${pk} in (select ${pk} from (${fieldQuery})q where ${name} ${sval})` : `${name} ${sval}`;
40
- }).join(' or ')} )` : '';
41
-
42
- // table_properties - user filter data
43
- const { rows: filterProperties = [] } = await pg.query(`select column_id, name, title, format, data from admin.custom_column where entity=$1 and uid=$2`, [table, uid]);
44
- const extraFilters = filterProperties.map((row) => ({ ua: row.title, name: row.name, type: row.format, data: row.data, extra: true }));
45
- const customFilters = [];
46
-
47
- const filterList1 = await Promise.all((filterList || (body?.filter_list || []).concat(body?.filterInline || []).concat(body?.filterCustom || []).concat(body?.filterState || []).concat(body?.filterList || []).concat(body?.filters || [])).concat(extraFilters || []).concat(customFilters || [])
48
-
49
- ?.map(async (el) => {
50
- if (!el?.data) return el;
51
- const cls = await getTemplate(['cls', 'select'], el.data);
52
- if (Array.isArray(cls) && cls?.length) {
53
- Object.assign(el, { options: cls });
54
- } else if (typeof (cls?.sql || cls) === 'string') {
55
- Object.assign(el, { sql: cls?.sql || cls });
56
- }
57
- return el;
58
- })
59
- );
60
- const filters = getFilterQuery({
61
- pg,
62
- filter,
63
- table: body?.table || table,
64
- tableSQL,
65
- fields,
66
- filterList: filterList1,
67
- });
68
-
69
- // filter
70
- const filterQuery = filters?.filter((el) => el.query)?.map((el) => `${el.query} `).join(' and ');
71
- const q = [body?.query, query, searchQuery, filterQuery].filter((el) => el).join(' and ');
72
-
73
- // table
74
- const modelQuery = body?.model || body?.table || table;
75
- const optimizedSQL = `select * from ${getOptimizedQuery({ body, table, q })} `;
76
- const tableCount = getOptimizedQuery({ body, table, q }, true);
77
- // console.log(optimizedSQL);
78
- return {
79
- filterList,
80
- q,
81
- optimizedSQL,
82
- tableCount,
83
- table: modelQuery,
84
- searchQuery,
85
- };
86
- }
87
- catch (err) {
88
- throw new Error(err.toString());
89
- }
90
- }
91
-
92
- export default getFilterSQL;
1
+ import { getPG, getTemplate } from "@opengis/fastify-table/utils.js";
2
+ // import pgClients from '@opengis/fastify-table/pg/funcs/pgClients.js';
3
+
4
+ import getTableSql from './util/getTableSql.js';
5
+ import getFilterQuery from './util/getFilterQuery.js';
6
+ import getOptimizedQuery from './util/getOptimizedQuery.js';
7
+
8
+ async function getFilterSQL({
9
+ pg: pg1, table, filter, search, filterList, query, uid,
10
+ }) {
11
+ if (!table) return { error: 'param table is required', status: 400 };
12
+
13
+ const pg = pg1 || getPG();
14
+ const body = await getTemplate('table', table);
15
+
16
+ const sqlList = body?.sql?.length
17
+ ? body?.sql?.filter((el) => !el.disabled && el?.sql?.replace)
18
+ .map((el, i) => {
19
+ Object.assign(el, { name: el.name || `t${i + 1}` });
20
+ return ` left join lateral (${el.filter ? el.sql.replace(/limit 1/ig, '') : el.sql}) as ${el.name} on 1=1 `;
21
+ }).join(' ')
22
+ : '';
23
+ const fieldQuery = `select * from ${body?.table || table} ${sqlList ? ` t ${sqlList}` : ''} where 1=1 limit 0`;
24
+ const { fields = [] } = await pg.query(fieldQuery);
25
+
26
+ const { fields: fieldsModel } = pg.pk[body?.table] ? await pg.query(`select * from ${body.table} limit 0`) : {};
27
+
28
+ const autoSearchColumn = fields?.filter((el) => pg.pgType?.[el.dataTypeID] === 'text')?.map((el) => el.name).join(',');
29
+ const searchColumn = body?.search_column || autoSearchColumn;
30
+ const fieldsList = (fieldsModel || fields)?.map((el) => el.name);
31
+ try {
32
+ const tableSQL = await getTableSql({
33
+ pg, body, table, fields,
34
+ });
35
+ const sval = `ilike '%${decodeURIComponent(search).replace(/'/g, "''")}%'`;
36
+ const searchQuery = search && searchColumn
37
+ ? ` (${searchColumn.split(',')?.map((name) => {
38
+ const { pk } = tableSQL.find((el) => el.name === name) || {};
39
+ return pk && !fieldsList.includes(name) ? `${pk} in (select ${pk} from (${fieldQuery})q where ${name} ${sval})` : `${name} ${sval}`;
40
+ }).join(' or ')} )` : '';
41
+
42
+ // table_properties - user filter data
43
+ const { rows: filterProperties = [] } = await pg.query(`select column_id, name, title, format, data from admin.custom_column where entity=$1 and uid=$2`, [table, uid]);
44
+ const extraFilters = filterProperties.map((row) => ({ ua: row.title, name: row.name, type: row.format, data: row.data, extra: true }));
45
+ const customFilters = [];
46
+
47
+ const filterList1 = await Promise.all((filterList || (body?.filter_list || []).concat(body?.filterInline || []).concat(body?.filterCustom || []).concat(body?.filterState || []).concat(body?.filterList || []).concat(body?.filters || [])).concat(extraFilters || []).concat(customFilters || [])
48
+
49
+ ?.map(async (el) => {
50
+ if (!el?.data) return el;
51
+ const cls = await getTemplate(['cls', 'select'], el.data);
52
+ if (Array.isArray(cls) && cls?.length) {
53
+ Object.assign(el, { options: cls });
54
+ } else if (typeof (cls?.sql || cls) === 'string') {
55
+ Object.assign(el, { sql: cls?.sql || cls });
56
+ }
57
+ return el;
58
+ })
59
+ );
60
+ const filters = getFilterQuery({
61
+ pg,
62
+ filter,
63
+ table: body?.table || table,
64
+ tableSQL,
65
+ fields,
66
+ filterList: filterList1,
67
+ });
68
+
69
+ // filter
70
+ const filterQuery = filters?.filter((el) => el.query)?.map((el) => `${el.query} `).join(' and ');
71
+ const q = [body?.query, query, searchQuery, filterQuery].filter((el) => el).join(' and ');
72
+
73
+ // table
74
+ const modelQuery = body?.model || body?.table || table;
75
+ const optimizedSQL = `select * from ${getOptimizedQuery({ body, table, q })} `;
76
+ const tableCount = getOptimizedQuery({ body, table, q }, true);
77
+ // console.log(optimizedSQL);
78
+ return {
79
+ filterList,
80
+ q,
81
+ optimizedSQL,
82
+ tableCount,
83
+ table: modelQuery,
84
+ searchQuery,
85
+ };
86
+ }
87
+ catch (err) {
88
+ throw new Error(err.toString());
89
+ }
90
+ }
91
+
92
+ export default getFilterSQL;