@opengis/admin 0.3.110 → 0.3.112

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 (111) hide show
  1. package/README.md +97 -97
  2. package/config.js +4 -4
  3. package/dist/{add-page-DELwNBs9.js → add-page-HV2OuTP5.js} +1 -1
  4. package/dist/{admin-interface-ChLQ5JCd.js → admin-interface-CE8pRY0Y.js} +499 -660
  5. package/dist/{admin-view-DnD5gBsl.js → admin-view-CQeFRO-H.js} +3 -3
  6. package/dist/admin.js +1 -1
  7. package/dist/admin.umd.cjs +54 -54
  8. package/dist/assets/logo.svg +41 -41
  9. package/dist/{card-view-Cb3j5eXY.js → card-view-Cs1UdOX4.js} +1 -1
  10. package/dist/{edit-page-DGjs4jeh.js → edit-page-uoPbSNAg.js} +1 -1
  11. package/dist/{import-file-DIAYCDNH.js → import-file-4fPjufhm.js} +11952 -11752
  12. package/dist/{profile-page-CaQqFoqe.js → profile-page-DcpVHW8y.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/users.hbs +16 -16
  19. package/module/settings/cls/core.actions.json +17 -17
  20. package/module/settings/cls/core.scope.json +13 -13
  21. package/module/settings/cls/properties.site_status.json +13 -13
  22. package/module/settings/cls/properties.widget_status.json +13 -13
  23. package/module/settings/cls/yes_no.json +11 -11
  24. package/module/settings/form/admin.accounts.form.json +13 -13
  25. package/module/settings/form/admin.properties.form.json +15 -15
  26. package/module/settings/form/admin.roles.form.json +21 -21
  27. package/module/settings/form/admin.user_properties.form.json +15 -15
  28. package/module/settings/form/admin.user_roles_card.form.json +13 -13
  29. package/module/settings/interface/admin.properties.json +4 -4
  30. package/module/settings/interface/admin.roles.json +4 -4
  31. package/module/settings/interface/admin.routes.json +4 -4
  32. package/module/settings/interface/admin.users.json +4 -4
  33. package/module/settings/select/core.routes.sql +1 -1
  34. package/module/settings/select/core.user_mentioned.sql +1 -1
  35. package/module/settings/select/core.user_uid.sql +1 -1
  36. package/module/settings/table/admin.properties.table.json +39 -39
  37. package/module/settings/table/admin.user_properties.table.json +34 -34
  38. package/package.json +1 -1
  39. package/server/helpers/core/coalesce.js +7 -7
  40. package/server/helpers/core/select.js +48 -48
  41. package/server/helpers/core/token.js +18 -18
  42. package/server/helpers/list/buttonHelper.js +21 -21
  43. package/server/helpers/list/utils/button.js +5 -5
  44. package/server/helpers/temp/contentList.js +58 -58
  45. package/server/helpers/temp/ifCond.js +101 -101
  46. package/server/helpers/utils/button.js +5 -5
  47. package/server/helpers/utils/buttonDownload.js +1 -1
  48. package/server/helpers/utils/buttonPreview.js +1 -1
  49. package/server/helpers/utils/mdToHTML.js +17 -17
  50. package/server/plugins/access/index.mjs +6 -6
  51. package/server/plugins/adminHook.js +81 -81
  52. package/server/plugins/cron.js +10 -10
  53. package/server/plugins/docs.js +28 -28
  54. package/server/routes/access/controllers/access.group.js +29 -29
  55. package/server/routes/access/controllers/access.group.post.js +54 -54
  56. package/server/routes/access/index.mjs +11 -11
  57. package/server/routes/access/schema.mjs +67 -67
  58. package/server/routes/calendar/controllers/calendar.data.js +125 -125
  59. package/server/routes/calendar/index.mjs +7 -7
  60. package/server/routes/calendar/schema.js +21 -21
  61. package/server/routes/data/controllers/cardTabData.js +49 -49
  62. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  63. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  64. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  65. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  66. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  67. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  68. package/server/routes/data/controllers/tableDataId.js +27 -27
  69. package/server/routes/data/controllers/tokenInfo.js +9 -9
  70. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  71. package/server/routes/data/controllers/utils/conditions.js +20 -20
  72. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  73. package/server/routes/data/index.mjs +20 -20
  74. package/server/routes/data/schema.js +54 -54
  75. package/server/routes/notifications/controllers/readNotifications.js +18 -18
  76. package/server/routes/notifications/controllers/testEmail.js +35 -35
  77. package/server/routes/notifications/controllers/userNotifications.js +53 -53
  78. package/server/routes/notifications/hook/onWidgetSet.js +56 -56
  79. package/server/routes/notifications/index.mjs +26 -26
  80. package/server/routes/notifications/schema.js +16 -16
  81. package/server/routes/properties/schema.js +10 -10
  82. package/server/routes/report/controllers/list.js +23 -23
  83. package/server/routes/report/index.mjs +9 -9
  84. package/server/routes/report/utils/formatValue.js +179 -179
  85. package/server/routes/root.mjs +3 -3
  86. package/server/routes/templates/controllers/getTemplate.js +44 -44
  87. package/server/routes/templates/schema.js +8 -8
  88. package/server/routes/user/controllers/user.cls.id.js +14 -14
  89. package/server/routes/user/controllers/user.cls.js +72 -72
  90. package/server/routes/user/controllers/user.info.js +17 -17
  91. package/server/routes/user/schema.js +14 -14
  92. package/server/routes/util/controllers/code.generator.js +89 -89
  93. package/server/routes/widget/controllers/widget.del.js +80 -80
  94. package/server/routes/widget/controllers/widget.set.js +101 -101
  95. package/server/routes/widget/hook/onWidgetSet.js +12 -12
  96. package/server/routes/widget/index.mjs +20 -20
  97. package/server/routes/widget/schema.js +12 -12
  98. package/server/templates/cls/itree.recrzone_category.json +73 -73
  99. package/server/templates/cls/test.json +9 -9
  100. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  101. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  102. package/server/templates/form/form-user-pass.json +10 -10
  103. package/server/templates/form/form-user_group.json +39 -39
  104. package/server/templates/form/form-users.json +156 -156
  105. package/server/templates/form/user_group_access.form.json +22 -22
  106. package/server/templates/select/account_id.json +2 -2
  107. package/server/templates/table/gis.dataset.table.json +43 -43
  108. package/server/templates/table/management.user_group.table.json +112 -112
  109. package/server/templates/table/management.users.table.json +126 -126
  110. package/server/utils/addNotification.js +21 -21
  111. package/server/utils/sendNotification.js +89 -89
@@ -1,101 +1,101 @@
1
- import path from 'path';
2
-
3
- import {
4
- getMeta, dataInsert, dataUpdate, applyHook,
5
- } from '@opengis/fastify-table/utils.js';
6
-
7
- import { uploadMultiPart } from '@opengis/fastify-file/utils.js';
8
-
9
- const tableList = {
10
- comment: 'crm.communications',
11
- gallery: 'crm.files',
12
- checklist: 'crm.checklists',
13
- };
14
- const pkList = {
15
- comment: 'communication_id',
16
- checklist: 'checklist_id',
17
- gallery: 'file_id',
18
- };
19
-
20
- const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
21
-
22
- export default async function widgetSet(req, reply) {
23
- const {
24
- pg, params = {}, session = {}, headers = {}, body = {}, user = {}, unittest,
25
- } = req;
26
- const { type, id, objectid } = params;
27
-
28
- if (!['comment', 'checklist', 'file', 'gallery'].includes(type)) {
29
- return reply.status(400).send('param type not valid');
30
- }
31
-
32
- if (!objectid) {
33
- return reply.status(400).send('not enough params: id');
34
- }
35
-
36
- const table = tableList[type];
37
-
38
- // dsadasdad
39
- if (['gallery', 'file'].includes(type) && headers['content-type']?.split?.(';')?.shift?.() === "multipart/form-data") {
40
- const file = await uploadMultiPart(req);
41
- const extName = path.extname(file.filepath).slice(1).toLowerCase();
42
-
43
- const data = {
44
- uploaded_name: file?.originalFilename?.toLocaleLowerCase()?.replace(/'/g, '\'\''),
45
- file_path: file?.relativeFilepath?.replace(/\\/g, '/'),
46
- ext: extName,
47
- size: file?.size,
48
- file_status: 1,
49
- uid: user?.uid || 1,
50
- entity_id: objectid,
51
- };
52
-
53
- if (type === 'gallery' && !galleryExtList.includes(extName.toLowerCase())) {
54
- return reply.status(400).send('invalid file extension');
55
- }
56
-
57
- const { rows = [] } = await dataInsert({
58
- pg, table: 'crm.files', data, uid: user?.uid,
59
- });
60
-
61
- if (type === 'gallery') {
62
- await pg.query(`update crm.files set ismain=true
63
- where entity_id=$1
64
- and file_id=$2
65
- and (select count(*) = 0 from crm.files where entity_id=$1 and ismain)`, [objectid, rows[0]?.file_id]);
66
- }
67
-
68
- return {
69
- rowCount: 1, data: 'ok', command: 'UPLOAD', id: rows[0]?.file_id, entity_id: rows[0]?.entity_id,
70
- };
71
- }
72
- const { pk } = await getMeta({ pg, table });
73
-
74
- if (!pk) {
75
- return reply.status(404).send('table not found');
76
- }
77
-
78
- const data = { ...body, uid: user?.uid, entity_id: objectid };
79
-
80
- await applyHook('onWidgetSet', {
81
- pg,
82
- link: req.path,
83
- id,
84
- objectid,
85
- session,
86
- type,
87
- payload: data,
88
- });
89
-
90
- const result = id
91
- ? await dataUpdate({
92
- pg, table, data, id, uid: user?.uid,
93
- })
94
- : await dataInsert({
95
- pg, table, data, uid: user?.uid,
96
- });
97
-
98
- return {
99
- rowCount: result.rowCount, data: 'ok', command: result.command, id: result.rows?.[0]?.[pkList[type]] || result?.[pkList[type]],
100
- };
101
- }
1
+ import path from 'path';
2
+
3
+ import {
4
+ getMeta, dataInsert, dataUpdate, applyHook,
5
+ } from '@opengis/fastify-table/utils.js';
6
+
7
+ import { uploadMultiPart } from '@opengis/fastify-file/utils.js';
8
+
9
+ const tableList = {
10
+ comment: 'crm.communications',
11
+ gallery: 'crm.files',
12
+ checklist: 'crm.checklists',
13
+ };
14
+ const pkList = {
15
+ comment: 'communication_id',
16
+ checklist: 'checklist_id',
17
+ gallery: 'file_id',
18
+ };
19
+
20
+ const galleryExtList = ['png', 'svg', 'jpg', 'jpeg', 'gif', 'mp4', 'mov', 'avi'];
21
+
22
+ export default async function widgetSet(req, reply) {
23
+ const {
24
+ pg, params = {}, session = {}, headers = {}, body = {}, user = {}, unittest,
25
+ } = req;
26
+ const { type, id, objectid } = params;
27
+
28
+ if (!['comment', 'checklist', 'file', 'gallery'].includes(type)) {
29
+ return reply.status(400).send('param type not valid');
30
+ }
31
+
32
+ if (!objectid) {
33
+ return reply.status(400).send('not enough params: id');
34
+ }
35
+
36
+ const table = tableList[type];
37
+
38
+ // dsadasdad
39
+ if (['gallery', 'file'].includes(type) && headers['content-type']?.split?.(';')?.shift?.() === "multipart/form-data") {
40
+ const file = await uploadMultiPart(req);
41
+ const extName = path.extname(file.filepath).slice(1).toLowerCase();
42
+
43
+ const data = {
44
+ uploaded_name: file?.originalFilename?.toLocaleLowerCase()?.replace(/'/g, '\'\''),
45
+ file_path: file?.relativeFilepath?.replace(/\\/g, '/'),
46
+ ext: extName,
47
+ size: file?.size,
48
+ file_status: 1,
49
+ uid: user?.uid || 1,
50
+ entity_id: objectid,
51
+ };
52
+
53
+ if (type === 'gallery' && !galleryExtList.includes(extName.toLowerCase())) {
54
+ return reply.status(400).send('invalid file extension');
55
+ }
56
+
57
+ const { rows = [] } = await dataInsert({
58
+ pg, table: 'crm.files', data, uid: user?.uid,
59
+ });
60
+
61
+ if (type === 'gallery') {
62
+ await pg.query(`update crm.files set ismain=true
63
+ where entity_id=$1
64
+ and file_id=$2
65
+ and (select count(*) = 0 from crm.files where entity_id=$1 and ismain)`, [objectid, rows[0]?.file_id]);
66
+ }
67
+
68
+ return {
69
+ rowCount: 1, data: 'ok', command: 'UPLOAD', id: rows[0]?.file_id, entity_id: rows[0]?.entity_id,
70
+ };
71
+ }
72
+ const { pk } = await getMeta({ pg, table });
73
+
74
+ if (!pk) {
75
+ return reply.status(404).send('table not found');
76
+ }
77
+
78
+ const data = { ...body, uid: user?.uid, entity_id: objectid };
79
+
80
+ await applyHook('onWidgetSet', {
81
+ pg,
82
+ link: req.path,
83
+ id,
84
+ objectid,
85
+ session,
86
+ type,
87
+ payload: data,
88
+ });
89
+
90
+ const result = id
91
+ ? await dataUpdate({
92
+ pg, table, data, id, uid: user?.uid,
93
+ })
94
+ : await dataInsert({
95
+ pg, table, data, uid: user?.uid,
96
+ });
97
+
98
+ return {
99
+ rowCount: result.rowCount, data: 'ok', command: result.command, id: result.rows?.[0]?.[pkList[type]] || result?.[pkList[type]],
100
+ };
101
+ }
@@ -1,12 +1,12 @@
1
- import { pgClients } from '@opengis/fastify-table/utils.js';
2
-
3
- export default async function onWidgetSet({
4
- pg = pgClients.client, id, objectid, type, payload = {},
5
- }) {
6
- if (!id || !objectid || type !== 'gallery') {
7
- return null;
8
- }
9
- if (payload?.ismain) {
10
- await pg.query('update crm.files set ismain=false where entity_id=$1 and file_id<>$2', [objectid, id]);
11
- }
12
- }
1
+ import { pgClients } from '@opengis/fastify-table/utils.js';
2
+
3
+ export default async function onWidgetSet({
4
+ pg = pgClients.client, id, objectid, type, payload = {},
5
+ }) {
6
+ if (!id || !objectid || type !== 'gallery') {
7
+ return null;
8
+ }
9
+ if (payload?.ismain) {
10
+ await pg.query('update crm.files set ismain=false where entity_id=$1 and file_id<>$2', [objectid, id]);
11
+ }
12
+ }
@@ -1,20 +1,20 @@
1
- import { addHook } from '@opengis/fastify-table/utils.js';
2
-
3
- import widgetDel from './controllers/widget.del.js';
4
- import widgetSet from './controllers/widget.set.js';
5
- import widgetGet from './controllers/widget.get.js';
6
- import fileEdit from './controllers/file.edit.js';
7
-
8
- import onWidgetSet from './hook/onWidgetSet.js';
9
-
10
- import { tableSchema } from './schema.js';
11
-
12
- const policy = ['site'];
13
-
14
- export default async function route(fastify) {
15
- fastify.delete(`/widget/:type/:objectid/:id`, { config: { policy }, scheme: tableSchema }, widgetDel);
16
- fastify.post(`/widget/:type/:objectid/:id?`, { config: { policy }, scheme: tableSchema }, widgetSet);
17
- fastify.put(`/file-edit/:id`, { config: { policy }, scheme: tableSchema }, fileEdit);
18
- fastify.get(`/widget/:type/:objectid`, { config: { policy: ['public'] }, scheme: tableSchema }, widgetGet);
19
- addHook('onWidgetSet', onWidgetSet);
20
- }
1
+ import { addHook } from '@opengis/fastify-table/utils.js';
2
+
3
+ import widgetDel from './controllers/widget.del.js';
4
+ import widgetSet from './controllers/widget.set.js';
5
+ import widgetGet from './controllers/widget.get.js';
6
+ import fileEdit from './controllers/file.edit.js';
7
+
8
+ import onWidgetSet from './hook/onWidgetSet.js';
9
+
10
+ import { tableSchema } from './schema.js';
11
+
12
+ const policy = ['site'];
13
+
14
+ export default async function route(fastify) {
15
+ fastify.delete(`/widget/:type/:objectid/:id`, { config: { policy }, scheme: tableSchema }, widgetDel);
16
+ fastify.post(`/widget/:type/:objectid/:id?`, { config: { policy }, scheme: tableSchema }, widgetSet);
17
+ fastify.put(`/file-edit/:id`, { config: { policy }, scheme: tableSchema }, fileEdit);
18
+ fastify.get(`/widget/:type/:objectid`, { config: { policy: ['public'] }, scheme: tableSchema }, widgetGet);
19
+ addHook('onWidgetSet', onWidgetSet);
20
+ }
@@ -1,13 +1,13 @@
1
- const tableSchema = {
2
- params: {
3
- // type: { type: 'string', pattern: '^([\\d\\w]+)$' },
4
- objectid: { type: 'string', pattern: '^([\\d\\w]+)$' },
5
- id: { type: 'string', pattern: '^([\\d\\w]+)$' },
6
- },
7
- querystring: {
8
- debug: { type: 'string', pattern: '^(\\d+)$' },
9
- },
10
- };
11
-
12
- export default null;
1
+ const tableSchema = {
2
+ params: {
3
+ // type: { type: 'string', pattern: '^([\\d\\w]+)$' },
4
+ objectid: { type: 'string', pattern: '^([\\d\\w]+)$' },
5
+ id: { type: 'string', pattern: '^([\\d\\w]+)$' },
6
+ },
7
+ querystring: {
8
+ debug: { type: 'string', pattern: '^(\\d+)$' },
9
+ },
10
+ };
11
+
12
+ export default null;
13
13
  export { tableSchema }
@@ -1,74 +1,74 @@
1
- [
2
- {
3
- "id": "12",
4
- "text": "Розділювальна смуга",
5
- "color": "#85754e",
6
- "en": "Dividing line"
7
- },
8
- {
9
- "id": "6",
10
- "text": "Бульвар",
11
- "color": "#00703c",
12
- "en": "Boulevard"
13
- },
14
- {
15
- "id": "1",
16
- "text": "Вуличні насадження",
17
- "color": "#8fbc8f",
18
- "en": "Street plantings"
19
- },
20
- {
21
- "id": "2",
22
- "text": "Парк",
23
- "color": "#a2cd5a",
24
- "en": "Park"
25
- },
26
- {
27
- "id": "3",
28
- "text": "Сад",
29
- "color": "#5e8c31",
30
- "en": "Garden"
31
- },
32
- {
33
- "id": "4",
34
- "text": "Сквер",
35
- "color": "#00ced1",
36
- "en": "Square"
37
- },
38
- {
39
- "id": "9",
40
- "text": "Рекреаційна зона",
41
- "color": "#e1a95f",
42
- "en": "Recreational zone"
43
- },
44
- {
45
- "id": "10",
46
- "text": "Санітарно-захисна зона",
47
- "color": "#6e7b8b",
48
- "en": "Sanitary protection zone"
49
- },
50
- {
51
- "id": "11",
52
- "text": "Зелені насадження прибудинкової території",
53
- "color": "#ace1af",
54
- "en": "Green plantations in local areas"
55
- },
56
- {
57
- "id": "5",
58
- "text": "Прибережні зелені насадження",
59
- "color": "#698b69",
60
- "en": "Coastal green plantations"
61
- },
62
- {
63
- "id": "7",
64
- "text": "Лісопарк",
65
- "color": "#6e8b3d",
66
- "en": "Forest park"
67
- },
68
- {
69
- "id": "8",
70
- "text": "Міський ліс",
71
- "color": "#4a5d23",
72
- "en": "Urban forest"
73
- }
1
+ [
2
+ {
3
+ "id": "12",
4
+ "text": "Розділювальна смуга",
5
+ "color": "#85754e",
6
+ "en": "Dividing line"
7
+ },
8
+ {
9
+ "id": "6",
10
+ "text": "Бульвар",
11
+ "color": "#00703c",
12
+ "en": "Boulevard"
13
+ },
14
+ {
15
+ "id": "1",
16
+ "text": "Вуличні насадження",
17
+ "color": "#8fbc8f",
18
+ "en": "Street plantings"
19
+ },
20
+ {
21
+ "id": "2",
22
+ "text": "Парк",
23
+ "color": "#a2cd5a",
24
+ "en": "Park"
25
+ },
26
+ {
27
+ "id": "3",
28
+ "text": "Сад",
29
+ "color": "#5e8c31",
30
+ "en": "Garden"
31
+ },
32
+ {
33
+ "id": "4",
34
+ "text": "Сквер",
35
+ "color": "#00ced1",
36
+ "en": "Square"
37
+ },
38
+ {
39
+ "id": "9",
40
+ "text": "Рекреаційна зона",
41
+ "color": "#e1a95f",
42
+ "en": "Recreational zone"
43
+ },
44
+ {
45
+ "id": "10",
46
+ "text": "Санітарно-захисна зона",
47
+ "color": "#6e7b8b",
48
+ "en": "Sanitary protection zone"
49
+ },
50
+ {
51
+ "id": "11",
52
+ "text": "Зелені насадження прибудинкової території",
53
+ "color": "#ace1af",
54
+ "en": "Green plantations in local areas"
55
+ },
56
+ {
57
+ "id": "5",
58
+ "text": "Прибережні зелені насадження",
59
+ "color": "#698b69",
60
+ "en": "Coastal green plantations"
61
+ },
62
+ {
63
+ "id": "7",
64
+ "text": "Лісопарк",
65
+ "color": "#6e8b3d",
66
+ "en": "Forest park"
67
+ },
68
+ {
69
+ "id": "8",
70
+ "text": "Міський ліс",
71
+ "color": "#4a5d23",
72
+ "en": "Urban forest"
73
+ }
74
74
  ]
@@ -1,10 +1,10 @@
1
- [
2
- {
3
- "id": 1,
4
- "text": "test"
5
- },
6
- {
7
- "id": 2,
8
- "text": "test2"
9
- }
1
+ [
2
+ {
3
+ "id": 1,
4
+ "text": "test"
5
+ },
6
+ {
7
+ "id": 2,
8
+ "text": "test2"
9
+ }
10
10
  ]
@@ -1,50 +1,50 @@
1
- {
2
- "label_style": "vertical",
3
- "schema": {
4
- "code": {
5
- "type": "Text",
6
- "ua": "Код",
7
- "ru": "Код",
8
- "en": "Code",
9
- "placeholder": {
10
- "ua": "Код",
11
- "ru": "Код",
12
- "en": "Code"
13
- },
14
- "validators": [
15
- "required"
16
- ],
17
- "col": 6
18
- },
19
- "name": {
20
- "type": "Text",
21
- "ua": "Назва",
22
- "ru": "Название",
23
- "en": "Name",
24
- "placeholder": {
25
- "ua": "Назва",
26
- "ru": "Название",
27
- "en": "Name"
28
- },
29
- "validators": [
30
- "required"
31
- ],
32
- "col": 6
33
- },
34
- "icon": {
35
- "type": "File",
36
- "multi": false,
37
- "ua": "Іконка",
38
- "ru": "Иконка",
39
- "en": "Icon",
40
- "col": 6
41
- },
42
- "color": {
43
- "type": "ColorPicker",
44
- "ua": "Колір",
45
- "ru": "Цвет",
46
- "en": "Color",
47
- "col": 6
48
- }
49
- }
1
+ {
2
+ "label_style": "vertical",
3
+ "schema": {
4
+ "code": {
5
+ "type": "Text",
6
+ "ua": "Код",
7
+ "ru": "Код",
8
+ "en": "Code",
9
+ "placeholder": {
10
+ "ua": "Код",
11
+ "ru": "Код",
12
+ "en": "Code"
13
+ },
14
+ "validators": [
15
+ "required"
16
+ ],
17
+ "col": 6
18
+ },
19
+ "name": {
20
+ "type": "Text",
21
+ "ua": "Назва",
22
+ "ru": "Название",
23
+ "en": "Name",
24
+ "placeholder": {
25
+ "ua": "Назва",
26
+ "ru": "Название",
27
+ "en": "Name"
28
+ },
29
+ "validators": [
30
+ "required"
31
+ ],
32
+ "col": 6
33
+ },
34
+ "icon": {
35
+ "type": "File",
36
+ "multi": false,
37
+ "ua": "Іконка",
38
+ "ru": "Иконка",
39
+ "en": "Icon",
40
+ "col": 6
41
+ },
42
+ "color": {
43
+ "type": "ColorPicker",
44
+ "ua": "Колір",
45
+ "ru": "Цвет",
46
+ "en": "Color",
47
+ "col": 6
48
+ }
49
+ }
50
50
  }
@@ -1,22 +1,22 @@
1
- {
2
- "schema": {
3
- "user_uid": {
4
- "type": "Autocomplete",
5
- "data": "user_id",
6
- "ua": "Користувач",
7
- "validators": [
8
- "required"
9
- ]
10
- },
11
- "user_access": {
12
- "type": "Select2",
13
- "data": "user_access",
14
- "placeholder": "Згідно налаштувань інтерфейсів",
15
- "ua": "Доступ"
16
- },
17
- "expiration": {
18
- "type": "DatePicker",
19
- "ua": "Закінчення терміну дії доступу до групи"
20
- }
21
- }
1
+ {
2
+ "schema": {
3
+ "user_uid": {
4
+ "type": "Autocomplete",
5
+ "data": "user_id",
6
+ "ua": "Користувач",
7
+ "validators": [
8
+ "required"
9
+ ]
10
+ },
11
+ "user_access": {
12
+ "type": "Select2",
13
+ "data": "user_access",
14
+ "placeholder": "Згідно налаштувань інтерфейсів",
15
+ "ua": "Доступ"
16
+ },
17
+ "expiration": {
18
+ "type": "DatePicker",
19
+ "ua": "Закінчення терміну дії доступу до групи"
20
+ }
21
+ }
22
22
  }
@@ -1,11 +1,11 @@
1
- {
2
- "login":{"type":"Text","ua":"Логін","ru":"Логин"},
3
- "password":{"type":"Password","ua":"Пароль","ru":"Пароль","validators": [
4
- {
5
- "type": "regexp",
6
- "regexp": "^.{8,}$",
7
- "flags": "gm",
8
- "message": "Пароль повинен бути більше 8 символів"
9
- }
10
- ]}
1
+ {
2
+ "login":{"type":"Text","ua":"Логін","ru":"Логин"},
3
+ "password":{"type":"Password","ua":"Пароль","ru":"Пароль","validators": [
4
+ {
5
+ "type": "regexp",
6
+ "regexp": "^.{8,}$",
7
+ "flags": "gm",
8
+ "message": "Пароль повинен бути більше 8 символів"
9
+ }
10
+ ]}
11
11
  }