@opengis/gis 0.2.92 → 0.2.93

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 (173) hide show
  1. package/README.md +5 -5
  2. package/dist/index.css +1 -1
  3. package/dist/index.js +7238 -6834
  4. package/dist/index.umd.cjs +66 -66
  5. package/module/cls.json +6 -6
  6. package/module/gis/card/gis.metadata.table/index.yml +22 -22
  7. package/module/gis/card/gis.metadata.table/main_info.hbs +20 -20
  8. package/module/gis/card/gis.metadata.table/metadata_info.hbs +27 -27
  9. package/module/gis/card/gis.metadata.table/other.hbs +25 -25
  10. package/module/gis/card/gis.rasters.table/index.yml +11 -11
  11. package/module/gis/card/gis.rasters.table/main_info.hbs +27 -27
  12. package/module/gis/card/gis.registers.table/cls.hbs +36 -36
  13. package/module/gis/card/gis.registers.table/columns.hbs +89 -89
  14. package/module/gis/card/gis.registers.table/filters.hbs +80 -80
  15. package/module/gis/card/gis.registers.table/index.yml +23 -23
  16. package/module/gis/card/gis.registers.table/main_info.hbs +35 -35
  17. package/module/gis/card/gis.registers.table/source.hbs +45 -45
  18. package/module/gis/card/gis.services.table/attributes.hbs +91 -91
  19. package/module/gis/card/gis.services.table/filters.hbs +83 -83
  20. package/module/gis/card/gis.services.table/index.yml +25 -25
  21. package/module/gis/card/gis.services.table/main_info.hbs +27 -27
  22. package/module/gis/card/gis.services.table/source.hbs +25 -25
  23. package/module/gis/cls/bool.yes_no.json +12 -12
  24. package/module/gis/cls/encoding.json +14 -14
  25. package/module/gis/cls/geom_type.json +14 -14
  26. package/module/gis/cls/gis.column_type.json +34 -34
  27. package/module/gis/cls/gis.column_view_type.json +26 -26
  28. package/module/gis/cls/gis.filter_type.json +22 -22
  29. package/module/gis/cls/language.json +10 -10
  30. package/module/gis/cls/meta.service_type.json +42 -42
  31. package/module/gis/cls/ogc.service.json +21 -21
  32. package/module/gis/cls/service_type.json +42 -42
  33. package/module/gis/cls/source_type.json +10 -10
  34. package/module/gis/cls/standarts.json +6 -6
  35. package/module/gis/cls/topic_category.json +106 -106
  36. package/module/gis/cls/update_frequency.json +29 -29
  37. package/module/gis/cls/view.json +21 -21
  38. package/module/gis/form/gis.cartocss.form.json +39 -39
  39. package/module/gis/form/gis.group_list.form.json +17 -17
  40. package/module/gis/form/gis.maps.form.json +61 -61
  41. package/module/gis/form/gis.metadata.form.json +240 -240
  42. package/module/gis/form/gis.ogc_service.form.json +45 -45
  43. package/module/gis/form/gis.rasters.form.json +76 -76
  44. package/module/gis/form/gis.registers.form.json +124 -124
  45. package/module/gis/form/gis.registers_column.form.json +84 -84
  46. package/module/gis/form/gis.registers_filter.form.json +65 -65
  47. package/module/gis/form/gis.services.form.json +111 -111
  48. package/module/gis/form/gis.services_attributes.form.json +75 -75
  49. package/module/gis/form/gis.services_filter.form.json +65 -65
  50. package/module/gis/menu.json +43 -43
  51. package/module/gis/select/admin.cls.name.sql +2 -2
  52. package/module/gis/select/pg.columns.parent.sql +6 -6
  53. package/module/gis/select/pg.table_name.sql +17 -17
  54. package/module/gis/select/service_id.sql +1 -1
  55. package/module/gis/table/gis.cartocss.table.json +74 -74
  56. package/module/gis/table/gis.group_list.table.json +58 -58
  57. package/module/gis/table/gis.maps.table.json +111 -111
  58. package/module/gis/table/gis.metadata.table.json +70 -70
  59. package/module/gis/table/gis.ogc_service.table.json +100 -100
  60. package/module/gis/table/gis.rasters.table.json +101 -101
  61. package/module/gis/table/gis.registers.table.json +144 -144
  62. package/module/gis/table/gis.services.table.json +121 -121
  63. package/module/gis/table/site.gis.registers.table.json +88 -88
  64. package/module/gis/table/site.gis.services.table.json +106 -106
  65. package/module/gis/templates/ISO19136_2017_gml_template.xml +330 -330
  66. package/module/gis/tokens.yml +5 -5
  67. package/module/permissions/form/permissions.users.form.json +151 -151
  68. package/module/permissions/table/gis.permissions.table.json +98 -98
  69. package/module/test/cls/bp_build_type.json +37 -37
  70. package/module/test/cls/ts.temp_status.json +18 -18
  71. package/module/test/cls/ts.temp_structure.ts_class.json +49 -49
  72. package/module/test/cls/ts.temp_type.json +9 -9
  73. package/module/test/layer/bp.json +59 -59
  74. package/module/test/layer/bp1.yml +33 -33
  75. package/module/test/layer/individual.yml +53 -53
  76. package/module/test/layer/ts.linking_passport.yml +55 -55
  77. package/module/test/layer/ts.temp_structure.yml +50 -50
  78. package/module/test/map/addr.yml +21 -21
  79. package/module/test/map/bp_myo.json +43 -43
  80. package/module/test/map/bpf.json +43 -43
  81. package/module/test/map/main.json +36 -36
  82. package/module/test/map/mbd.json +91 -91
  83. package/module/test/map/ts.json +52 -52
  84. package/module/test/select/address_id.json +2 -2
  85. package/module/test/select/address_id.sql +7 -7
  86. package/module/test/table/data_address.street.table.json +69 -69
  87. package/module/test/table/data_bp_myo.bp.table.json +122 -122
  88. package/package.json +76 -76
  89. package/plugin.js +49 -49
  90. package/server/migrations/array_intersect.sql +13 -13
  91. package/server/migrations/cartocss.sql +25 -25
  92. package/server/migrations/group_list.sql +74 -74
  93. package/server/migrations/maps.sql +30 -30
  94. package/server/migrations/metadata.sql +415 -415
  95. package/server/migrations/ogc.sql +106 -106
  96. package/server/migrations/rasters.sql +265 -265
  97. package/server/migrations/services.sql +247 -247
  98. package/server/migrations/services_users_rel.sql +22 -22
  99. package/server/migrations/widgets.sql +20 -20
  100. package/server/plugins/crons.js +21 -21
  101. package/server/plugins/mapnik/funcs/checkRasterFile.js +108 -108
  102. package/server/plugins/mapnik/funcs/mapnik.js +146 -146
  103. package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
  104. package/server/plugins/mapnik/map.proto +231 -231
  105. package/server/plugins/vite.js +75 -75
  106. package/server/routes/gis/cartocss/add.cartocss.js +39 -39
  107. package/server/routes/gis/cartocss/get.cartocss.js +49 -49
  108. package/server/routes/gis/checkXML.js +118 -118
  109. package/server/routes/gis/dashboard.js +29 -29
  110. package/server/routes/gis/index.mjs +87 -87
  111. package/server/routes/gis/metadata/editMetadata.js +34 -34
  112. package/server/routes/gis/metadata/metadataXML.js +13 -13
  113. package/server/routes/gis/ogc/map.info.point.js +124 -124
  114. package/server/routes/gis/registers/add.registry.js +35 -35
  115. package/server/routes/gis/registers/del.registry.js +14 -14
  116. package/server/routes/gis/registers/funcs/classifiers.js +100 -100
  117. package/server/routes/gis/registers/funcs/columns.js +4 -4
  118. package/server/routes/gis/registers/funcs/content.type.js +9 -9
  119. package/server/routes/gis/registers/funcs/get.info.js +89 -89
  120. package/server/routes/gis/registers/funcs/handleRegistryRequest.js +146 -146
  121. package/server/routes/gis/registers/gis.export.js +148 -148
  122. package/server/routes/gis/registers/gis.registry.js +64 -64
  123. package/server/routes/gis/registers/gis.registry.list.js +59 -59
  124. package/server/routes/gis/registers/insert.columns.js +107 -107
  125. package/server/routes/gis/registers/insert.filters.js +110 -110
  126. package/server/routes/gis/registers/map.registry.js +79 -79
  127. package/server/routes/gis/services/add.service.js +64 -64
  128. package/server/routes/gis/services/del.service.js +12 -12
  129. package/server/routes/gis/services/get.layer.geom.js +27 -27
  130. package/server/routes/gis/services/get.services.col.js +33 -33
  131. package/server/routes/gis/services/get.services.js +84 -84
  132. package/server/routes/gis/services/legend.auto.js +77 -77
  133. package/server/routes/map/controllers/geojson.js +187 -187
  134. package/server/routes/map/controllers/jsonData.js +205 -205
  135. package/server/routes/map/controllers/layerList.js +103 -103
  136. package/server/routes/map/controllers/map.js +123 -123
  137. package/server/routes/map/controllers/mapCatalog.js +72 -72
  138. package/server/routes/map/controllers/mapCatalogAttribute.js +55 -55
  139. package/server/routes/map/controllers/mapFeatures.js +128 -128
  140. package/server/routes/map/controllers/mapFormat.js +225 -225
  141. package/server/routes/map/controllers/mapTiles.js +152 -152
  142. package/server/routes/map/controllers/maps.js +15 -15
  143. package/server/routes/map/controllers/marker_icon.js +43 -43
  144. package/server/routes/map/controllers/vtile.js +172 -172
  145. package/server/routes/map/index.mjs +142 -142
  146. package/server/routes/map/maps/add.map.js +43 -43
  147. package/server/routes/map/maps/del.map.js +18 -18
  148. package/server/routes/map/maps/get.map.js +112 -112
  149. package/server/routes/map/vtile1.js +176 -176
  150. package/server/routes/map/widgets/add.widget.js +38 -38
  151. package/server/routes/map/widgets/del.widget.js +22 -22
  152. package/server/routes/map/widgets/get.widget.js +40 -40
  153. package/server/routes/mapnik/controllers/clearTiles.js +94 -94
  154. package/server/routes/mapnik/controllers/createXml.js +66 -66
  155. package/server/routes/mapnik/controllers/createXmlMulti.js +75 -75
  156. package/server/routes/mapnik/controllers/fileSearch.js +34 -34
  157. package/server/routes/mapnik/controllers/fileStat.js +27 -27
  158. package/server/routes/mapnik/controllers/mapnikLogger.js +29 -29
  159. package/server/routes/mapnik/controllers/mapnikStat.js +20 -20
  160. package/server/routes/mapnik/controllers/rasterInfo.js +50 -50
  161. package/server/routes/mapnik/controllers/readDir.js +19 -19
  162. package/server/routes/mapnik/controllers/rtile.js +122 -122
  163. package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
  164. package/server/routes/mapnik/functions/cartoBounds.js +23 -23
  165. package/server/routes/mapnik/functions/uploadXML.js +110 -110
  166. package/server/routes/mapnik/index.js +28 -28
  167. package/server/routes/permissions/controllers/catalog.permissions.edit.js +22 -22
  168. package/server/routes/permissions/controllers/catalog.permissions.js +7 -7
  169. package/server/routes/permissions/controllers/gis.catalog.js +80 -80
  170. package/server/routes/permissions/controllers/utils/get.permissions.js +43 -43
  171. package/server/routes/permissions/index.mjs +18 -18
  172. package/server/routes/root.mjs +3 -3
  173. package/utils.js +13 -13
@@ -1,80 +1,80 @@
1
- <div>
2
- <div class="flex justify-end items-center pb-[5px]">
3
-
4
- <div class="flex gap-[5px] items-center">
5
- {{#if this.filters.length}}
6
- {{{button this token=(token table="gis.registers" form="gis.registers_filter.form" id=register_id) edit=1 }}}
7
- {{^}}
8
- <button
9
- onclick="window.v3plugin.$api(
10
- {
11
- api: '/api/insert-filters/{{token id=register_id type="registers"}}',
12
- method:'put',
13
- confirm: {
14
- title:'Підтвердити операцію',
15
- text: 'Ви впевнені що хочете автоматично заповнити структуру?',
16
- cancel: 'Скасувати',
17
- confirm : 'Виконати'
18
- }
19
- })"
20
- class="px-2 py-1 inline-flex border-solid justify-center items-center gap-2 rounded-md font-semibold focus:outline-none text-sm transition-all border border-transparent hover:text-white ring-offset-white bg-orange-100 text-orange-500 hover:bg-orange-500 focus:ring-orange-500">
21
- Автозаповнити фільтри
22
- </button>
23
- {{{button this token=(token table="gis.registers" form="gis.registers_filter.form" id=register_id) edit=1 title="Додати"}}}
24
- {{/if}}
25
- </div>
26
- </div>
27
- {{#if this.filters.length}}
28
- <div class="overflow-x-auto">
29
- <table class="min-w-full relative divide-y-2 divide-gray-200 bg-white min-w-full overflow-auto divide-y-2 divide-gray-200 bg-white text-[12px] text-gray-600">
30
- <thead class="text-left font-medium text-gray-700">
31
- <tr>
32
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
33
- Назва колонки
34
- </th>
35
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
36
- Назва колонки українською
37
- </th>
38
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
39
- Тип колонки
40
- </th>
41
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
42
- Класифікатор
43
- </th>
44
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
45
- Відключити
46
- </th>
47
-
48
- </tr>
49
- </thead>
50
- <tbody class="divide-y divide-gray-200">
51
- {{#each this.filters}}
52
- <tr class="bg-white odd:bg-gray-50 ">
53
- <td class="py-2 pr-5 last:sticky last:right-0 ">
54
- {{id}}
55
- </td>
56
- <td class="py-2 pr-5 last:sticky last:right-0 ">
57
- {{label}}
58
- </td>
59
- <td class="py-2 pr-5 last:sticky last:right-0 ">
60
- {{sellect type data='gis.filter_type'}}
61
- </td>
62
- <td class="py-2 pr-5 last:sticky last:right-0 ">
63
- {{data}}
64
- </td>
65
- <td class="py-2 pr-5 last:sticky last:right-0 ">
66
- {{{badge disabled data='yes_no'}}}
67
- </td>
68
-
69
- </tr>
70
- {{/each}}
71
- </tbody>
72
- </table>
73
-
74
- </div>
75
- {{^}}
76
- <div class='bg-gray-200 text-center p-6 rounded-xl'>
77
- <h3 class='text-lg font-semibold'>Інформація відсутня</h3>
78
- </div>
79
- {{/if}}
80
- </div>
1
+ <div>
2
+ <div class="flex justify-end items-center pb-[5px]">
3
+
4
+ <div class="flex gap-[5px] items-center">
5
+ {{#if this.filters.length}}
6
+ {{{button this token=(token table="gis.registers" form="gis.registers_filter.form" id=register_id) edit=1 }}}
7
+ {{^}}
8
+ <button
9
+ onclick="window.v3plugin.$api(
10
+ {
11
+ api: '/api/insert-filters/{{token id=register_id type="registers"}}',
12
+ method:'put',
13
+ confirm: {
14
+ title:'Підтвердити операцію',
15
+ text: 'Ви впевнені що хочете автоматично заповнити структуру?',
16
+ cancel: 'Скасувати',
17
+ confirm : 'Виконати'
18
+ }
19
+ })"
20
+ class="px-2 py-1 inline-flex border-solid justify-center items-center gap-2 rounded-md font-semibold focus:outline-none text-sm transition-all border border-transparent hover:text-white ring-offset-white bg-orange-100 text-orange-500 hover:bg-orange-500 focus:ring-orange-500">
21
+ Автозаповнити фільтри
22
+ </button>
23
+ {{{button this token=(token table="gis.registers" form="gis.registers_filter.form" id=register_id) edit=1 title="Додати"}}}
24
+ {{/if}}
25
+ </div>
26
+ </div>
27
+ {{#if this.filters.length}}
28
+ <div class="overflow-x-auto">
29
+ <table class="min-w-full relative divide-y-2 divide-gray-200 bg-white min-w-full overflow-auto divide-y-2 divide-gray-200 bg-white text-[12px] text-gray-600">
30
+ <thead class="text-left font-medium text-gray-700">
31
+ <tr>
32
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
33
+ Назва колонки
34
+ </th>
35
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
36
+ Назва колонки українською
37
+ </th>
38
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
39
+ Тип колонки
40
+ </th>
41
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
42
+ Класифікатор
43
+ </th>
44
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
45
+ Відключити
46
+ </th>
47
+
48
+ </tr>
49
+ </thead>
50
+ <tbody class="divide-y divide-gray-200">
51
+ {{#each this.filters}}
52
+ <tr class="bg-white odd:bg-gray-50 ">
53
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
54
+ {{id}}
55
+ </td>
56
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
57
+ {{label}}
58
+ </td>
59
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
60
+ {{sellect type data='gis.filter_type'}}
61
+ </td>
62
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
63
+ {{data}}
64
+ </td>
65
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
66
+ {{{badge disabled data='yes_no'}}}
67
+ </td>
68
+
69
+ </tr>
70
+ {{/each}}
71
+ </tbody>
72
+ </table>
73
+
74
+ </div>
75
+ {{^}}
76
+ <div class='bg-gray-200 text-center p-6 rounded-xl'>
77
+ <h3 class='text-lg font-semibold'>Інформація відсутня</h3>
78
+ </div>
79
+ {{/if}}
80
+ </div>
@@ -1,24 +1,24 @@
1
- component: default
2
-
3
- tokens:
4
- edit: { table: gis.registers, form: gis.registers.form, id: '{{id}}', ignoreCheck: true }
5
-
6
- panels:
7
- - type: container # закріплений зліва container col, width як простіше
8
- col: 5
9
- items:
10
- - name: main_info
11
-
12
- - type: tabs
13
- col: 7
14
- items:
15
- - name: source
16
- title: Джерело даних
17
- - name: columns
18
- title: Колонки
19
- - name: filters
20
- title: Фільтри
21
- - name: cls
22
- title: Класифікатори
23
- - component: vs-widget-history
1
+ component: default
2
+
3
+ tokens:
4
+ edit: { table: gis.registers, form: gis.registers.form, id: '{{id}}', ignoreCheck: true }
5
+
6
+ panels:
7
+ - type: container # закріплений зліва container col, width як простіше
8
+ col: 5
9
+ items:
10
+ - name: main_info
11
+
12
+ - type: tabs
13
+ col: 7
14
+ items:
15
+ - name: source
16
+ title: Джерело даних
17
+ - name: columns
18
+ title: Колонки
19
+ - name: filters
20
+ title: Фільтри
21
+ - name: cls
22
+ title: Класифікатори
23
+ - component: vs-widget-history
24
24
  title: Історія редагування
@@ -1,35 +1,35 @@
1
- <div>
2
- <div class="flex justify-between items-center pb-[5px]">
3
- <div class="font-semibold text-[16px] dark:text-white">Загальна інформація</div>
4
- <div class="flex gap-[5px] items-center">
5
- {{{button this token=(token table="gis.registers.table" form="gis.registers.form" id=register_id) edit=1 }}}
6
- {{{button this token=(token table="gis.registers.table" id=register_id) del=1 }}}
7
- </div>
8
- </div>
9
- {{{descriptionList
10
- this
11
- comma=";"
12
- columns="
13
- Назва,name,
14
- Аліас реєстру,register_key,
15
- Шар на мапі,<a href='/card/gis.services.table/{{service_id}}' class='text-blue-500 cursor-pointer'>{{select service_id data='service_id'}}</a>,
16
- Опис,description,
17
- Утримувач,holder,
18
- Ключові слова,{{#each keywords}}<span class=\"bg-gray-200 px-1 py-0.5 rounded-lg\">{{this}}</span>{{/each}},
19
- Чи публічний реєстр?,{{{badge is_public data='yes_no'}}},
20
- Чи активний?,{{{badge is_active data='yes_no'}}},
21
- Фото,{{{buttonFilePreview image}}},
22
- Чи відображати віджет файлів?,{{{badge is_files data='yes_no'}}},
23
- Користувач; який створив запис, {{select created_by data='user_id'}},
24
- Дата створення, {{formatDate created_at}}
25
- "
26
- }}}
27
- {{#contentList table="(select count(*) as total from {{table_name}})"}}
28
- {{#with rows.[0]}}
29
- {{{descriptionList
30
- this
31
- columns="Кількість об'єктів в наборі,{{total}}"
32
- }}}
33
- {{/with}}
34
- {{/contentList}}
35
- </div>
1
+ <div>
2
+ <div class="flex justify-between items-center pb-[5px]">
3
+ <div class="font-semibold text-[16px] dark:text-white">Загальна інформація</div>
4
+ <div class="flex gap-[5px] items-center">
5
+ {{{button this token=(token table="gis.registers.table" form="gis.registers.form" id=register_id) edit=1 }}}
6
+ {{{button this token=(token table="gis.registers.table" id=register_id) del=1 }}}
7
+ </div>
8
+ </div>
9
+ {{{descriptionList
10
+ this
11
+ comma=";"
12
+ columns="
13
+ Назва,name,
14
+ Аліас реєстру,register_key,
15
+ Шар на мапі,<a href='/card/gis.services.table/{{service_id}}' class='text-blue-500 cursor-pointer'>{{select service_id data='service_id'}}</a>,
16
+ Опис,description,
17
+ Утримувач,holder,
18
+ Ключові слова,{{#each keywords}}<span class=\"bg-gray-200 px-1 py-0.5 rounded-lg\">{{this}}</span>{{/each}},
19
+ Чи публічний реєстр?,{{{badge is_public data='yes_no'}}},
20
+ Чи активний?,{{{badge is_active data='yes_no'}}},
21
+ Фото,{{{buttonFilePreview image}}},
22
+ Чи відображати віджет файлів?,{{{badge is_files data='yes_no'}}},
23
+ Користувач; який створив запис, {{select created_by data='user_id'}},
24
+ Дата створення, {{formatDate created_at}}
25
+ "
26
+ }}}
27
+ {{#contentList table="(select count(*) as total from {{table_name}})"}}
28
+ {{#with rows.[0]}}
29
+ {{{descriptionList
30
+ this
31
+ columns="Кількість об'єктів в наборі,{{total}}"
32
+ }}}
33
+ {{/with}}
34
+ {{/contentList}}
35
+ </div>
@@ -1,45 +1,45 @@
1
- <div>
2
- {{{descriptionList
3
- this
4
- comma=";"
5
- columns="
6
- Таблиця в базі даних,{{select table_name data='pg.table_name'}},
7
- Первиний ключ, pk,
8
- Умова для відображення, query,
9
- Сортування, order
10
- "
11
-
12
- }}}
13
- <div class="font-semibold text-[16px] dark:text-white my-2">Автоматично сформований запит</div>
14
- <div class="relative">
15
- {{!-- <button
16
- onclick="copySQL(this)"
17
- class="absolute top-2 right-2 bg-blue-600 hover:bg-blue-700 text-white text-xs px-2 py-1 rounded z-10">
18
- Копіювати
19
- </button>--}}
20
- <pre class="bg-gray-900 text-green-400 p-4 rounded-lg font-mono text-sm overflow-auto">
21
- <code id="sql-code">
22
- select "{{pk}}" as id, *
23
- from ( select * from {{table_name}} t ) t
24
- {{#if sql_list}}
25
- {{#each sql_list}}
26
- <span>left join lateral (
27
- {{sql}}
28
- ) {{alias}} on 1=1</span>
29
- {{/each}}
30
- {{/if}}
31
- where 1=1 {{#if query}}and {{query}}{{/if}}
32
- {{#if order}}order by {{order}} nulls last{{/if}}
33
- </code>
34
- </pre>
35
- </div>
36
- </div>
37
- {{!--<script>
38
- function copySQL(button) {
39
- const code = button.parentElement.querySelector('code').innerText;
40
- navigator.clipboard.writeText(code).then(() => {
41
- button.textContent = 'Скопійовано!';
42
- setTimeout(() => button.textContent = 'Копіювати', 2000);
43
- });
44
- }
45
- </script>--}}
1
+ <div>
2
+ {{{descriptionList
3
+ this
4
+ comma=";"
5
+ columns="
6
+ Таблиця в базі даних,{{select table_name data='pg.table_name'}},
7
+ Первиний ключ, pk,
8
+ Умова для відображення, query,
9
+ Сортування, order
10
+ "
11
+
12
+ }}}
13
+ <div class="font-semibold text-[16px] dark:text-white my-2">Автоматично сформований запит</div>
14
+ <div class="relative">
15
+ {{!-- <button
16
+ onclick="copySQL(this)"
17
+ class="absolute top-2 right-2 bg-blue-600 hover:bg-blue-700 text-white text-xs px-2 py-1 rounded z-10">
18
+ Копіювати
19
+ </button>--}}
20
+ <pre class="bg-gray-900 text-green-400 p-4 rounded-lg font-mono text-sm overflow-auto">
21
+ <code id="sql-code">
22
+ select "{{pk}}" as id, *
23
+ from ( select * from {{table_name}} t ) t
24
+ {{#if sql_list}}
25
+ {{#each sql_list}}
26
+ <span>left join lateral (
27
+ {{sql}}
28
+ ) {{alias}} on 1=1</span>
29
+ {{/each}}
30
+ {{/if}}
31
+ where 1=1 {{#if query}}and {{query}}{{/if}}
32
+ {{#if order}}order by {{order}} nulls last{{/if}}
33
+ </code>
34
+ </pre>
35
+ </div>
36
+ </div>
37
+ {{!--<script>
38
+ function copySQL(button) {
39
+ const code = button.parentElement.querySelector('code').innerText;
40
+ navigator.clipboard.writeText(code).then(() => {
41
+ button.textContent = 'Скопійовано!';
42
+ setTimeout(() => button.textContent = 'Копіювати', 2000);
43
+ });
44
+ }
45
+ </script>--}}
@@ -1,91 +1,91 @@
1
- <div>
2
- <div class="flex justify-end items-center pb-[5px]">
3
-
4
- <div class="flex gap-[5px] items-center">
5
- {{#ifCond source_type "==" 'database'}}
6
- {{#if attributes.length }}
7
- {{{button this token=(token table="gis.services" form="gis.services_attributes.form" id=service_id) edit=1 }}}
8
- {{^}}
9
- <button
10
- onclick="window.v3plugin.$api(
11
- {
12
- api: '/api/insert-columns/{{token id=service_id type="services"}}',
13
- method:'put',
14
- confirm: {
15
- title:'Підтвердити операцію',
16
- text: 'Ви впевнені що хочете автоматично заповнити структуру?',
17
- cancel: 'Скасувати',
18
- confirm : 'Виконати'
19
- }
20
- })"
21
- class="px-2 py-1 inline-flex border-solid justify-center items-center gap-2 rounded-md font-semibold focus:outline-none text-sm transition-all border border-transparent hover:text-white ring-offset-white bg-orange-100 text-orange-500 hover:bg-orange-500 focus:ring-orange-500">
22
- Автозаповнити колонки
23
- </button>
24
- {{{button this token=(token table="gis.services" form="gis.services_attributes.form" id=service_id) edit=1 title="Додати"}}}
25
- {{/if}}
26
- {{/ifCond}}
27
- </div>
28
- </div>
29
- {{#if attributes.length}}
30
- <div class="overflow-x-auto">
31
- <table class="min-w-full relative divide-y-2 divide-gray-200 bg-white min-w-full overflow-auto divide-y-2 divide-gray-200 bg-white text-[12px] text-gray-600">
32
- <thead class="text-left font-medium text-gray-700">
33
- <tr>
34
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
35
- Назва колонки
36
- </th>
37
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
38
- Назва колонки українською
39
- </th>
40
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
41
- Тип колонки
42
- </th>
43
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
44
- Класифікатор
45
- </th>
46
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
47
- Приховати поле в прев'ю
48
- </th>
49
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
50
- Приховати поле в карточці
51
- </th>
52
- <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
53
- Експорт даних колонки
54
- </th>
55
- </tr>
56
- </thead>
57
- <tbody class="divide-y divide-gray-200">
58
- {{#each attributes}}
59
- <tr class="bg-white odd:bg-gray-50 ">
60
- <td class="py-2 pr-5 last:sticky last:right-0 ">
61
- {{name}}
62
- </td>
63
- <td class="py-2 pr-5 last:sticky last:right-0 ">
64
- {{ua}}
65
- </td>
66
- <td class="py-2 pr-5 last:sticky last:right-0 ">
67
- {{sellect format data='gis.column_type'}}
68
- </td>
69
- <td class="py-2 pr-5 last:sticky last:right-0 ">
70
- {{data}}
71
- </td>
72
- <td class="py-2 pr-5 last:sticky last:right-0 ">
73
- {{{badge hidden_register data='yes_no'}}}
74
- </td>
75
- <td class="py-2 pr-5 last:sticky last:right-0 ">
76
- {{{badge hidden_card data='yes_no'}}}
77
- </td>
78
- <td class="py-2 pr-5 last:sticky last:right-0 ">
79
- {{{badge is_export data='yes_no'}}}
80
- </td>
81
- </tr>
82
- {{/each}}
83
- </tbody>
84
- </table>
85
- </div>
86
- {{^}}
87
- <div class='bg-gray-200 text-center p-6 rounded-xl'>
88
- <h3 class='text-lg font-semibold'>Інформація відсутня</h3>
89
- </div>
90
- {{/if}}
91
- </div>
1
+ <div>
2
+ <div class="flex justify-end items-center pb-[5px]">
3
+
4
+ <div class="flex gap-[5px] items-center">
5
+ {{#ifCond source_type "==" 'database'}}
6
+ {{#if attributes.length }}
7
+ {{{button this token=(token table="gis.services" form="gis.services_attributes.form" id=service_id) edit=1 }}}
8
+ {{^}}
9
+ <button
10
+ onclick="window.v3plugin.$api(
11
+ {
12
+ api: '/api/insert-columns/{{token id=service_id type="services"}}',
13
+ method:'put',
14
+ confirm: {
15
+ title:'Підтвердити операцію',
16
+ text: 'Ви впевнені що хочете автоматично заповнити структуру?',
17
+ cancel: 'Скасувати',
18
+ confirm : 'Виконати'
19
+ }
20
+ })"
21
+ class="px-2 py-1 inline-flex border-solid justify-center items-center gap-2 rounded-md font-semibold focus:outline-none text-sm transition-all border border-transparent hover:text-white ring-offset-white bg-orange-100 text-orange-500 hover:bg-orange-500 focus:ring-orange-500">
22
+ Автозаповнити колонки
23
+ </button>
24
+ {{{button this token=(token table="gis.services" form="gis.services_attributes.form" id=service_id) edit=1 title="Додати"}}}
25
+ {{/if}}
26
+ {{/ifCond}}
27
+ </div>
28
+ </div>
29
+ {{#if attributes.length}}
30
+ <div class="overflow-x-auto">
31
+ <table class="min-w-full relative divide-y-2 divide-gray-200 bg-white min-w-full overflow-auto divide-y-2 divide-gray-200 bg-white text-[12px] text-gray-600">
32
+ <thead class="text-left font-medium text-gray-700">
33
+ <tr>
34
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
35
+ Назва колонки
36
+ </th>
37
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
38
+ Назва колонки українською
39
+ </th>
40
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
41
+ Тип колонки
42
+ </th>
43
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
44
+ Класифікатор
45
+ </th>
46
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
47
+ Приховати поле в прев'ю
48
+ </th>
49
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
50
+ Приховати поле в карточці
51
+ </th>
52
+ <th class="py-2 last:min-w-[60px] last:max-w-[60px] last:bg-white last:sticky last:right-0">
53
+ Експорт даних колонки
54
+ </th>
55
+ </tr>
56
+ </thead>
57
+ <tbody class="divide-y divide-gray-200">
58
+ {{#each attributes}}
59
+ <tr class="bg-white odd:bg-gray-50 ">
60
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
61
+ {{name}}
62
+ </td>
63
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
64
+ {{ua}}
65
+ </td>
66
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
67
+ {{sellect format data='gis.column_type'}}
68
+ </td>
69
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
70
+ {{data}}
71
+ </td>
72
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
73
+ {{{badge hidden_register data='yes_no'}}}
74
+ </td>
75
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
76
+ {{{badge hidden_card data='yes_no'}}}
77
+ </td>
78
+ <td class="py-2 pr-5 last:sticky last:right-0 ">
79
+ {{{badge is_export data='yes_no'}}}
80
+ </td>
81
+ </tr>
82
+ {{/each}}
83
+ </tbody>
84
+ </table>
85
+ </div>
86
+ {{^}}
87
+ <div class='bg-gray-200 text-center p-6 rounded-xl'>
88
+ <h3 class='text-lg font-semibold'>Інформація відсутня</h3>
89
+ </div>
90
+ {{/if}}
91
+ </div>