@opengis/gis 0.2.119 → 0.2.120

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 (197) hide show
  1. package/README.md +148 -148
  2. package/dist/{CardIcon-ODZgA2Pb.js → CardIcon-Dx_myDwM.js} +1 -1
  3. package/dist/{EntityCreatePage-Da8XgBKU.js → EntityCreatePage-Ch8NU_Yw.js} +14 -14
  4. package/dist/{EntityEditPage-QktKEAxz.js → EntityEditPage-CRRcW7FL.js} +27 -27
  5. package/dist/{EntityTablePage-UMttc2-F.js → EntityTablePage-DY9v1aWL.js} +32 -31
  6. package/dist/{ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DLAIOHJh.js → ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DgQHLSak.js} +1 -1
  7. package/dist/{HeaderActions.vue_vue_type_script_setup_true_lang-CTKkmXWD.js → HeaderActions.vue_vue_type_script_setup_true_lang-BQ32ioLC.js} +30 -30
  8. package/dist/{MapSettings-CbW0TfZl.js → MapSettings-CaGPr5uG.js} +33 -33
  9. package/dist/{RastersTablePage-CXqscX0i.js → RastersTablePage-CJyO2DoI.js} +41 -39
  10. package/dist/{cartocss-306ZE1Ha.js → cartocss-Bhat1m61.js} +296 -294
  11. package/dist/{import-utils-CHIDSKHz.js → import-utils-BxeYqcn7.js} +33 -33
  12. package/dist/index-Ba6SE4TN.js +10203 -0
  13. package/dist/index.css +1 -1
  14. package/dist/index.js +1 -1
  15. package/dist/index.umd.cjs +31 -31
  16. package/dist/{raster-Cn6l0xfZ.js → raster-Cbs1xR5Y.js} +120 -121
  17. package/dist/{register-4wblFcw2.js → register-D0AsH83v.js} +8 -8
  18. package/dist/{service-2uWyAfnR.js → service-C4nt_DBO.js} +10 -10
  19. package/dist/{vs-datatable-D_Xzh4qf.js → vs-datatable-QG5b0CCL.js} +28 -28
  20. package/module/cls.json +6 -6
  21. package/module/gis/card/gis.metadata.table/index.yml +22 -22
  22. package/module/gis/card/gis.metadata.table/main_info.hbs +20 -20
  23. package/module/gis/card/gis.metadata.table/metadata_info.hbs +27 -27
  24. package/module/gis/card/gis.metadata.table/other.hbs +25 -25
  25. package/module/gis/card/gis.rasters.table/index.yml +11 -11
  26. package/module/gis/card/gis.rasters.table/main_info.hbs +27 -27
  27. package/module/gis/card/gis.registers.table/cls.hbs +36 -36
  28. package/module/gis/card/gis.registers.table/columns.hbs +89 -89
  29. package/module/gis/card/gis.registers.table/filters.hbs +80 -80
  30. package/module/gis/card/gis.registers.table/index.yml +23 -23
  31. package/module/gis/card/gis.registers.table/main_info.hbs +35 -35
  32. package/module/gis/card/gis.registers.table/source.hbs +45 -45
  33. package/module/gis/card/gis.services.table/attributes.hbs +91 -91
  34. package/module/gis/card/gis.services.table/filters.hbs +83 -83
  35. package/module/gis/card/gis.services.table/index.yml +25 -25
  36. package/module/gis/card/gis.services.table/main_info.hbs +27 -27
  37. package/module/gis/card/gis.services.table/source.hbs +25 -25
  38. package/module/gis/cls/bool.yes_no.json +12 -12
  39. package/module/gis/cls/encoding.json +14 -14
  40. package/module/gis/cls/geom_type.json +14 -14
  41. package/module/gis/cls/gis.column_type.json +34 -34
  42. package/module/gis/cls/gis.column_view_type.json +26 -26
  43. package/module/gis/cls/gis.filter_type.json +22 -22
  44. package/module/gis/cls/language.json +10 -10
  45. package/module/gis/cls/meta.service_type.json +42 -42
  46. package/module/gis/cls/ogc.service.json +21 -21
  47. package/module/gis/cls/service_type.json +42 -42
  48. package/module/gis/cls/source_type.json +10 -10
  49. package/module/gis/cls/standarts.json +6 -6
  50. package/module/gis/cls/topic_category.json +106 -106
  51. package/module/gis/cls/update_frequency.json +29 -29
  52. package/module/gis/cls/view.json +21 -21
  53. package/module/gis/form/feedback.answer.form.json +10 -10
  54. package/module/gis/form/gis.cartocss.form.json +54 -54
  55. package/module/gis/form/gis.group_list.form.json +17 -17
  56. package/module/gis/form/gis.maps.form.json +61 -61
  57. package/module/gis/form/gis.metadata.form.json +240 -240
  58. package/module/gis/form/gis.metadata_new.form.json +195 -195
  59. package/module/gis/form/gis.ogc_service.form.json +51 -51
  60. package/module/gis/form/gis.rasters.form.json +76 -76
  61. package/module/gis/form/gis.registers.form.json +124 -124
  62. package/module/gis/form/gis.registers_column.form.json +84 -84
  63. package/module/gis/form/gis.registers_filter.form.json +65 -65
  64. package/module/gis/form/gis.services.form.json +111 -111
  65. package/module/gis/form/gis.services_attributes.form.json +75 -75
  66. package/module/gis/form/gis.services_filter.form.json +65 -65
  67. package/module/gis/menu.json +43 -43
  68. package/module/gis/select/admin.cls.name.sql +2 -2
  69. package/module/gis/select/layer_list.sql +7 -7
  70. package/module/gis/select/layer_list_text.sql +7 -7
  71. package/module/gis/select/pg.column_name.geometry.sql +12 -12
  72. package/module/gis/select/pg.columns.parent.sql +6 -6
  73. package/module/gis/select/pg.table_name.sql +17 -17
  74. package/module/gis/select/service_id.sql +1 -1
  75. package/module/gis/table/gis.cartocss.table.json +74 -74
  76. package/module/gis/table/gis.group_list.table.json +58 -58
  77. package/module/gis/table/gis.maps.table.json +110 -110
  78. package/module/gis/table/gis.metadata.table.json +70 -70
  79. package/module/gis/table/gis.metadata_new.table.json +137 -137
  80. package/module/gis/table/gis.ogc_service.table.json +100 -100
  81. package/module/gis/table/gis.rasters.table.json +101 -101
  82. package/module/gis/table/gis.registers.table.json +143 -143
  83. package/module/gis/table/gis.services.table.json +120 -120
  84. package/module/gis/table/site.gis.registers.table.json +88 -88
  85. package/module/gis/table/site.gis.services.table.json +106 -106
  86. package/module/gis/templates/ISO19136_2017_gml_template.xml +330 -330
  87. package/module/gis/tokens.yml +5 -5
  88. package/module/permissions/form/permissions.users.form.json +151 -151
  89. package/module/permissions/table/gis.permissions.table.json +97 -97
  90. package/module/test/cls/bp_build_type.json +37 -37
  91. package/module/test/cls/ts.temp_status.json +18 -18
  92. package/module/test/cls/ts.temp_structure.ts_class.json +49 -49
  93. package/module/test/cls/ts.temp_type.json +9 -9
  94. package/module/test/layer/bp.json +59 -59
  95. package/module/test/layer/bp1.yml +33 -33
  96. package/module/test/layer/individual.yml +53 -53
  97. package/module/test/layer/ts.linking_passport.yml +55 -55
  98. package/module/test/layer/ts.temp_structure.yml +50 -50
  99. package/module/test/map/addr.yml +21 -21
  100. package/module/test/map/bp_myo.json +43 -43
  101. package/module/test/map/bpf.json +43 -43
  102. package/module/test/map/main.json +37 -37
  103. package/module/test/map/mbd.json +92 -92
  104. package/module/test/map/ts.json +53 -53
  105. package/module/test/select/address_id.json +2 -2
  106. package/module/test/select/address_id.sql +7 -7
  107. package/module/test/table/data_address.street.table.json +69 -69
  108. package/module/test/table/data_bp_myo.bp.table.json +122 -122
  109. package/package.json +75 -75
  110. package/plugin.js +55 -55
  111. package/server/migrations/array_intersect.sql +13 -13
  112. package/server/migrations/cartocss.sql +27 -27
  113. package/server/migrations/group_list.sql +74 -74
  114. package/server/migrations/maps.sql +30 -30
  115. package/server/migrations/metadata.sql +415 -415
  116. package/server/migrations/ogc.sql +106 -106
  117. package/server/migrations/rasters.sql +265 -265
  118. package/server/migrations/services.sql +247 -247
  119. package/server/migrations/services_users_rel.sql +22 -22
  120. package/server/migrations/widgets.sql +20 -20
  121. package/server/plugins/crons.js +21 -21
  122. package/server/plugins/mapnik/funcs/checkRasterFile.js +109 -109
  123. package/server/plugins/mapnik/funcs/mapnik.js +146 -146
  124. package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
  125. package/server/plugins/mapnik/map.proto +234 -234
  126. package/server/plugins/vite.js +74 -74
  127. package/server/routes/gis/cartocss/add.cartocss.js +42 -42
  128. package/server/routes/gis/cartocss/get.cartocss.js +50 -50
  129. package/server/routes/gis/checkXML.js +118 -118
  130. package/server/routes/gis/dashboard.js +29 -29
  131. package/server/routes/gis/index.mjs +87 -87
  132. package/server/routes/gis/metadata/editMetadata.js +34 -34
  133. package/server/routes/gis/metadata/metadataXML.js +13 -13
  134. package/server/routes/gis/ogc/map.info.point.js +124 -124
  135. package/server/routes/gis/registers/add.registry.js +35 -35
  136. package/server/routes/gis/registers/del.registry.js +14 -14
  137. package/server/routes/gis/registers/funcs/classifiers.js +100 -100
  138. package/server/routes/gis/registers/funcs/columns.js +4 -4
  139. package/server/routes/gis/registers/funcs/content.type.js +9 -9
  140. package/server/routes/gis/registers/funcs/get.info.js +89 -89
  141. package/server/routes/gis/registers/funcs/handleRegistryRequest.js +146 -146
  142. package/server/routes/gis/registers/gis.export.js +153 -153
  143. package/server/routes/gis/registers/gis.registry.js +64 -64
  144. package/server/routes/gis/registers/gis.registry.list.js +59 -59
  145. package/server/routes/gis/registers/insert.columns.js +107 -107
  146. package/server/routes/gis/registers/insert.filters.js +110 -110
  147. package/server/routes/gis/registers/map.registry.js +79 -79
  148. package/server/routes/gis/services/add.service.js +64 -64
  149. package/server/routes/gis/services/del.service.js +12 -12
  150. package/server/routes/gis/services/get.layer.geom.js +27 -27
  151. package/server/routes/gis/services/get.services.col.js +33 -33
  152. package/server/routes/gis/services/get.services.js +84 -84
  153. package/server/routes/gis/services/legend.auto.js +77 -77
  154. package/server/routes/map/controllers/clearTiles.js +34 -34
  155. package/server/routes/map/controllers/geojson.js +187 -187
  156. package/server/routes/map/controllers/jsonData.js +205 -205
  157. package/server/routes/map/controllers/layerList.js +102 -102
  158. package/server/routes/map/controllers/map.js +123 -123
  159. package/server/routes/map/controllers/mapCatalog.js +72 -72
  160. package/server/routes/map/controllers/mapCatalogAttribute.js +55 -55
  161. package/server/routes/map/controllers/mapFeatures.js +128 -128
  162. package/server/routes/map/controllers/mapFormat.js +222 -222
  163. package/server/routes/map/controllers/mapTiles.js +152 -152
  164. package/server/routes/map/controllers/maps.js +15 -15
  165. package/server/routes/map/controllers/marker_icon.js +43 -43
  166. package/server/routes/map/controllers/vtile.js +172 -172
  167. package/server/routes/map/index.mjs +169 -169
  168. package/server/routes/map/maps/add.map.js +43 -43
  169. package/server/routes/map/maps/del.map.js +18 -18
  170. package/server/routes/map/maps/get.map.js +112 -112
  171. package/server/routes/map/vtile1.js +179 -179
  172. package/server/routes/map/widgets/add.widget.js +38 -38
  173. package/server/routes/map/widgets/del.widget.js +22 -22
  174. package/server/routes/map/widgets/get.widget.js +40 -40
  175. package/server/routes/mapnik/controllers/clearTiles.js +106 -106
  176. package/server/routes/mapnik/controllers/createXml.js +67 -67
  177. package/server/routes/mapnik/controllers/createXmlMulti.js +76 -76
  178. package/server/routes/mapnik/controllers/fileSearch.js +38 -38
  179. package/server/routes/mapnik/controllers/fileStat.js +28 -28
  180. package/server/routes/mapnik/controllers/mapnikLogger.js +29 -29
  181. package/server/routes/mapnik/controllers/mapnikStat.js +20 -20
  182. package/server/routes/mapnik/controllers/rasterInfo.js +54 -54
  183. package/server/routes/mapnik/controllers/readDir.js +22 -22
  184. package/server/routes/mapnik/controllers/rtile.js +150 -150
  185. package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
  186. package/server/routes/mapnik/functions/cartoBounds.js +28 -28
  187. package/server/routes/mapnik/functions/uploadXML.js +110 -110
  188. package/server/routes/mapnik/index.js +27 -27
  189. package/server/routes/permissions/controllers/catalog.permissions.edit.js +22 -22
  190. package/server/routes/permissions/controllers/catalog.permissions.js +7 -7
  191. package/server/routes/permissions/controllers/gis.catalog.js +80 -80
  192. package/server/routes/permissions/controllers/utils/get.permissions.js +59 -59
  193. package/server/routes/permissions/index.mjs +18 -18
  194. package/server/routes/root.mjs +3 -3
  195. package/utils.js +13 -13
  196. package/dist/FileEdit-GikPLv1T.js +0 -37
  197. package/dist/index-CbdZv1jy.js +0 -10123
@@ -1,11 +1,10 @@
1
- import { defineComponent as se, defineAsyncComponent as re, computed as i, ref as u, onMounted as oe, watch as U, openBlock as P, createElementBlock as k, createVNode as f, createSlots as le, withCtx as w, createTextVNode as g, toDisplayString as x, unref as c, createCommentVNode as R, createElementVNode as r, renderSlot as M } from "vue";
1
+ import { defineComponent as se, defineAsyncComponent as re, computed as i, ref as u, onMounted as oe, watch as U, openBlock as P, createElementBlock as k, createVNode as f, createSlots as le, withCtx as w, unref as c, createTextVNode as h, createCommentVNode as R, createElementVNode as r, toDisplayString as x, renderSlot as M } from "vue";
2
2
  import { RefreshCw as ie, Plus as ue } from "lucide-vue-next";
3
3
  import { useRoute as ce, useRouter as de } from "vue-router";
4
4
  import { VsPagination as fe, notify as Q } from "@opengis/core";
5
- import { FilterField as me, Filter as he } from "@opengis/filter";
6
- import { F as ge } from "./FileEdit-GikPLv1T.js";
7
- import { _ as ve } from "./TableFormHeader.vue_vue_type_script_setup_true_lang-Mci_tseM.js";
8
- import { _ as pe } from "./index-CbdZv1jy.js";
5
+ import { FilterField as ve, Filter as me } from "@opengis/filter";
6
+ import { F as he, _ as ge } from "./index-Ba6SE4TN.js";
7
+ import { _ as pe } from "./TableFormHeader.vue_vue_type_script_setup_true_lang-Mci_tseM.js";
9
8
  const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-0 m-0" }, be = {
10
9
  key: 0,
11
10
  href: "/api/gis-create-xml",
@@ -45,7 +44,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
45
44
  }), K = i(() => {
46
45
  const e = String(S.value || "").trim();
47
46
  return e ? `Пошук ${e}...` : "Пошук...";
48
- }), b = u([]), y = u(!0), v = u([]), j = u([]), m = u({}), z = u([]), l = u(String(s.query.search ?? "")), o = u(Math.max(1, Number(s.query.page) || 1)), C = u(15), h = u(0), L = i(() => h.value > 0), O = i(() => h.value ? (o.value - 1) * C.value + 1 : 0), W = i(() => h.value ? Math.min(o.value * C.value, h.value) : 0);
47
+ }), b = u([]), y = u(!0), g = u([]), j = u([]), v = u({}), z = u([]), l = u(String(s.query.search ?? "")), o = u(Math.max(1, Number(s.query.page) || 1)), C = u(15), m = u(0), L = i(() => m.value > 0), O = i(() => m.value ? (o.value - 1) * C.value + 1 : 0), W = i(() => m.value ? Math.min(o.value * C.value, m.value) : 0);
49
48
  function G(e) {
50
49
  const t = new URLSearchParams();
51
50
  return Object.entries(e).forEach(([n, a]) => {
@@ -78,20 +77,20 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
78
77
  try {
79
78
  y.value = !0;
80
79
  const t = G({
81
- ...m.value,
80
+ ...v.value,
82
81
  page: o.value,
83
82
  limit: C.value
84
83
  }), n = await fetch(t ? `${e}?${t}` : e);
85
84
  if (!n.ok)
86
85
  throw new Error(`Rows fetch failed: ${n.status}`);
87
86
  const a = await n.json();
88
- b.value = a.rows || [], h.value = Number(a.filtered ?? a.total ?? a.count ?? b.value.length) || 0, v.value = $.columnsConfig.length ? $.columnsConfig : a.columns || [], j.value = a.filters || [], y.value = !1, z.value = a.actions, a.card !== !1 && v.value.length && (E.value ? v.value[0].link = `${T.value}/{id}` : v.value[0].link || (v.value[0].link = `/${s.name}/{id}`));
87
+ b.value = a.rows || [], m.value = Number(a.filtered ?? a.total ?? a.count ?? b.value.length) || 0, g.value = $.columnsConfig.length ? $.columnsConfig : a.columns || [], j.value = a.filters || [], y.value = !1, z.value = a.actions, a.card !== !1 && g.value.length && (E.value ? g.value[0].link = `${T.value}/{id}` : g.value[0].link || (g.value[0].link = `/${s.name}/{id}`));
89
88
  } catch {
90
89
  b.value = [], y.value = !1;
91
90
  }
92
91
  };
93
92
  function Y(e) {
94
- m.value = e, o.value = 1, F(), p();
93
+ v.value = e, o.value = 1, F(), p();
95
94
  }
96
95
  oe(() => {
97
96
  p(), document.title = S.value;
@@ -104,8 +103,8 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
104
103
  () => s.query,
105
104
  (e) => {
106
105
  const t = Math.max(1, Number(e.page) || 1), n = String(e.search ?? ""), a = t !== o.value, d = n !== l.value;
107
- !a && !d || (o.value = t, l.value = n, m.value = {
108
- ...m.value,
106
+ !a && !d || (o.value = t, l.value = n, v.value = {
107
+ ...v.value,
109
108
  search: n || void 0
110
109
  }, p());
111
110
  }
@@ -127,8 +126,8 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
127
126
  Q({ title: "Збережено", message: `Поле "${t}" оновлено` });
128
127
  }
129
128
  function B(e, t) {
130
- m.value = {
131
- ...m.value,
129
+ v.value = {
130
+ ...v.value,
132
131
  [e]: t
133
132
  }, o.value = 1, F(), p();
134
133
  }
@@ -150,21 +149,21 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
150
149
  l.value || delete e.search, _.replace({ query: e });
151
150
  }
152
151
  return (e, t) => (P(), k("div", xe, [
153
- f(ve, { variant: "table" }, le({
152
+ f(pe, { variant: "table" }, le({
154
153
  title: w(() => [
155
- g(x(S.value), 1)
154
+ h(x(S.value), 1)
156
155
  ]),
157
156
  actions: w(() => [
158
157
  c(s).name === "rasters" ? (P(), k("a", be, [
159
158
  f(c(ie), { size: 16 }),
160
- t[2] || (t[2] = g(" Оновити растри ", -1))
159
+ t[2] || (t[2] = h(" Оновити растри ", -1))
161
160
  ])) : R("", !0),
162
161
  r("a", {
163
162
  onClick: t[0] || (t[0] = (n) => c(_).push(H())),
164
163
  class: "hover:cursor-pointer flex items-center gap-1.5 px-3 py-1.5 bg-blue-600 text-white rounded-md hover:bg-blue-700 transition-colors text-sm"
165
164
  }, [
166
165
  f(c(ue), { size: 16 }),
167
- t[3] || (t[3] = g(" Додати ", -1))
166
+ t[3] || (t[3] = h(" Додати ", -1))
168
167
  ])
169
168
  ]),
170
169
  _: 2
@@ -172,7 +171,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
172
171
  V.value ? {
173
172
  name: "description",
174
173
  fn: w(() => [
175
- g(x(V.value), 1)
174
+ h(x(V.value), 1)
176
175
  ]),
177
176
  key: "0"
178
177
  } : void 0
@@ -181,7 +180,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
181
180
  r("div", we, [
182
181
  r("div", _e, [
183
182
  r("div", $e, [
184
- f(c(me), {
183
+ f(c(ve), {
185
184
  modelValue: l.value,
186
185
  "onUpdate:modelValue": t[1] || (t[1] = (n) => l.value = n),
187
186
  name: "search",
@@ -194,9 +193,9 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
194
193
  onClear: te,
195
194
  placeholder: K.value
196
195
  }, null, 8, ["modelValue", "placeholder"]),
197
- f(c(he), {
196
+ f(c(me), {
198
197
  schema: j.value,
199
- value: m.value,
198
+ value: v.value,
200
199
  onChange: Y,
201
200
  layout: "inline",
202
201
  mode: "soft",
@@ -209,7 +208,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
209
208
  r("div", Se, [
210
209
  f(c(I), {
211
210
  rows: b.value,
212
- columns: v.value,
211
+ columns: g.value,
213
212
  loading: y.value,
214
213
  router: c(_),
215
214
  selectable: !1,
@@ -238,9 +237,11 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
238
237
  z.value.includes("add") ? (P(), k("div", Pe, [
239
238
  r("button", {
240
239
  onClick: (a) => c(_).push(X(n.id)),
241
- class: "inline-flex items-center justify-center bg-white border rounded-md size-7 gap-x-2 hover:bg-gray-100"
240
+ class: "inline-flex items-center justify-center bg-white border rounded-md size-7 gap-x-2 hover:bg-gray-100",
241
+ title: "Редагувати",
242
+ "aria-label": "Редагувати"
242
243
  }, [
243
- f(ge)
244
+ f(he)
244
245
  ], 8, ke)
245
246
  ])) : R("", !0)
246
247
  ], !0)
@@ -250,16 +251,16 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
250
251
  ]),
251
252
  L.value ? (P(), k("div", Te, [
252
253
  r("div", Ee, [
253
- t[4] || (t[4] = g(" Показано ", -1)),
254
+ t[4] || (t[4] = h(" Показано ", -1)),
254
255
  r("span", Fe, x(O.value), 1),
255
- t[5] || (t[5] = g(" - ", -1)),
256
+ t[5] || (t[5] = h(" - ", -1)),
256
257
  r("span", Re, x(W.value), 1),
257
- t[6] || (t[6] = g(" з ", -1)),
258
- r("span", Ne, x(h.value), 1)
258
+ t[6] || (t[6] = h(" з ", -1)),
259
+ r("span", Ne, x(m.value), 1)
259
260
  ]),
260
261
  r("div", Ve, [
261
262
  f(c(fe), {
262
- total: h.value,
263
+ total: m.value,
263
264
  page: o.value,
264
265
  "page-size": C.value,
265
266
  showPageSizes: !1,
@@ -275,7 +276,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
275
276
  ])
276
277
  ]));
277
278
  }
278
- }), Ie = /* @__PURE__ */ pe(je, [["__scopeId", "data-v-1061effc"]]);
279
+ }), De = /* @__PURE__ */ ge(je, [["__scopeId", "data-v-469c2953"]]);
279
280
  export {
280
- Ie as default
281
+ De as default
281
282
  };
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as y, computed as f, watch as d, createCommentVNode as x } from "vue";
2
- import { f as b, u as _ } from "./index-CbdZv1jy.js";
2
+ import { f as b, u as _ } from "./index-Ba6SE4TN.js";
3
3
  const I = /* @__PURE__ */ y({
4
4
  __name: "ExtentOutlineLayer",
5
5
  props: {
@@ -1,5 +1,5 @@
1
- import { openBlock as m, createElementBlock as v, createElementVNode as r, defineComponent as J, normalizeClass as he, createVNode as j, createBlock as le, unref as E, defineAsyncComponent as W, ref as b, watch as ve, computed as y, createTextVNode as _e, Fragment as ae, renderList as ue, toDisplayString as z, withCtx as X, nextTick as we, onMounted as ke, onUnmounted as xe, withModifiers as ze, Teleport as Ve, normalizeStyle as Ce, createCommentVNode as te } from "vue";
2
- import { _ as Ee } from "./index-CbdZv1jy.js";
1
+ import { openBlock as v, createElementBlock as m, createElementVNode as r, defineComponent as J, normalizeClass as he, createVNode as j, createBlock as le, unref as E, defineAsyncComponent as W, ref as b, watch as me, computed as y, createTextVNode as _e, Fragment as ae, renderList as ue, toDisplayString as z, withCtx as X, nextTick as we, onMounted as ke, onUnmounted as xe, withModifiers as ze, Teleport as Ve, normalizeStyle as Ce, createCommentVNode as te } from "vue";
2
+ import { _ as Ee } from "./index-Ba6SE4TN.js";
3
3
  import { Settings as Me, BrushCleaning as ce, SquareCode as Le, Pencil as Te } from "lucide-vue-next";
4
4
  import { notify as D } from "@opengis/core";
5
5
  const Se = {}, $e = {
@@ -15,14 +15,14 @@ const Se = {}, $e = {
15
15
  class: "inline-block shrink-0"
16
16
  };
17
17
  function Ue(l, h) {
18
- return m(), v("svg", $e, [...h[0] || (h[0] = [
18
+ return v(), m("svg", $e, [...h[0] || (h[0] = [
19
19
  r("path", { d: "M8 3 4 7l4 4" }, null, -1),
20
20
  r("path", { d: "M4 7h16" }, null, -1),
21
21
  r("path", { d: "m16 21 4-4-4-4" }, null, -1),
22
22
  r("path", { d: "M20 17H4" }, null, -1)
23
23
  ])]);
24
24
  }
25
- const je = /* @__PURE__ */ Ee(Se, [["render", Ue]]), Ie = ["aria-label"], vt = /* @__PURE__ */ J({
25
+ const je = /* @__PURE__ */ Ee(Se, [["render", Ue]]), Ie = ["aria-label"], mt = /* @__PURE__ */ J({
26
26
  __name: "PanelToggleButton",
27
27
  props: {
28
28
  open: { type: Boolean },
@@ -30,7 +30,7 @@ const je = /* @__PURE__ */ Ee(Se, [["render", Ue]]), Ie = ["aria-label"], vt = /
30
30
  },
31
31
  emits: ["toggle"],
32
32
  setup(l) {
33
- return (h, u) => (m(), v("button", {
33
+ return (h, u) => (v(), m("button", {
34
34
  type: "button",
35
35
  onClick: u[0] || (u[0] = (B) => h.$emit("toggle")),
36
36
  class: he([
@@ -46,7 +46,7 @@ const je = /* @__PURE__ */ Ee(Se, [["render", Ue]]), Ie = ["aria-label"], vt = /
46
46
  }), pt = /* @__PURE__ */ J({
47
47
  __name: "SettingsIcon",
48
48
  setup(l) {
49
- return (h, u) => (m(), le(E(Me), {
49
+ return (h, u) => (v(), le(E(Me), {
50
50
  size: 16,
51
51
  class: "lucide lucide-settings"
52
52
  }));
@@ -294,7 +294,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
294
294
  return null;
295
295
  }
296
296
  }
297
- ve(
297
+ me(
298
298
  () => f.data,
299
299
  async (t) => {
300
300
  if (p.value = null, (t == null ? void 0 : t.group_id) != null) {
@@ -426,7 +426,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
426
426
  }
427
427
  }
428
428
  }
429
- return (t, a) => (m(), v("div", Fe, [
429
+ return (t, a) => (v(), m("div", Fe, [
430
430
  r("div", Re, [
431
431
  r("div", Be, [
432
432
  r("div", { class: "flex items-center justify-between mb-3" }, [
@@ -453,15 +453,15 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
453
453
  _e(" Редагувати ", -1)
454
454
  ])])
455
455
  ]),
456
- F.value.length ? (m(), v("div", Ne, [
457
- (m(!0), v(ae, null, ue(F.value, (n) => (m(), v("div", {
456
+ F.value.length ? (v(), m("div", Ne, [
457
+ (v(!0), m(ae, null, ue(F.value, (n) => (v(), m("div", {
458
458
  key: n.label,
459
459
  class: "bg-gray-50 rounded-md p-2 border border-gray-100"
460
460
  }, [
461
461
  r("p", De, z(n.label), 1),
462
462
  r("p", He, z(n.value), 1)
463
463
  ]))), 128))
464
- ])) : (m(), v("p", Oe, z(C)))
464
+ ])) : (v(), m("p", Oe, z(C)))
465
465
  ]),
466
466
  r("div", Ge, [
467
467
  a[6] || (a[6] = r("h2", { class: "text-xs font-semibold text-gray-500 uppercase tracking-wider mb-3" }, " Повний опис ", -1)),
@@ -469,15 +469,15 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
469
469
  ]),
470
470
  r("div", Qe, [
471
471
  a[7] || (a[7] = r("h2", { class: "text-xs font-semibold text-gray-500 uppercase tracking-wider mb-3" }, " Метадані ", -1)),
472
- S.value.length ? (m(), v("div", qe, [
473
- (m(!0), v(ae, null, ue(S.value, (n) => (m(), v("div", {
472
+ S.value.length ? (v(), m("div", qe, [
473
+ (v(!0), m(ae, null, ue(S.value, (n) => (v(), m("div", {
474
474
  key: n.label,
475
475
  class: "bg-gray-50 rounded-md p-2 border border-gray-100"
476
476
  }, [
477
477
  r("p", We, z(n.label), 1),
478
478
  r("p", Xe, z(n.value), 1)
479
479
  ]))), 128))
480
- ])) : (m(), v("p", Je, z(C)))
480
+ ])) : (v(), m("p", Je, z(C)))
481
481
  ])
482
482
  ]),
483
483
  j(E(u), {
@@ -522,7 +522,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
522
522
  }, at = {
523
523
  key: 1,
524
524
  class: "py-6 px-4 text-sm text-red-600"
525
- }, nt = { class: "flex justify-end gap-2 px-4 py-3 border-t border-gray-100 w-full" }, ot = ["disabled"], rt = ["disabled"], st = 192, me = 8, P = 8, ft = /* @__PURE__ */ J({
525
+ }, nt = { class: "flex justify-end gap-2 px-4 py-3 border-t border-gray-100 w-full" }, ot = ["disabled"], rt = ["disabled"], st = 192, ve = 8, P = 8, ft = /* @__PURE__ */ J({
526
526
  __name: "HeaderActions",
527
527
  props: {
528
528
  entityId: {},
@@ -543,7 +543,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
543
543
  top: `${_.value.top}px`,
544
544
  left: `${_.value.left}px`
545
545
  } : {});
546
- ve(p, (o) => {
546
+ me(p, (o) => {
547
547
  o && we(K);
548
548
  });
549
549
  const A = b(!1), F = b(null), T = b({}), S = b(null), w = b(""), $ = b(!1), k = b(!1), x = b(null), d = y(() => u.entityId || ""), U = (o, s) => o ? typeof o == "function" ? o(s) : typeof o != "string" ? "" : o.includes(":id") ? s ? o.replace(":id", encodeURIComponent(s)) : "" : o : "", O = y(() => {
@@ -577,10 +577,10 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
577
577
  function K() {
578
578
  var ie;
579
579
  if (typeof window > "u" || !L.value) return;
580
- const o = L.value.getBoundingClientRect(), s = window.innerWidth, c = window.innerHeight, g = o.left, i = Math.max(s - st - P, P), Z = Math.min(Math.max(g, P), i), ee = ((ie = e.value) == null ? void 0 : ie.offsetHeight) ?? 0, re = o.bottom + me;
580
+ const o = L.value.getBoundingClientRect(), s = window.innerWidth, c = window.innerHeight, g = o.left, i = Math.max(s - st - P, P), Z = Math.min(Math.max(g, P), i), ee = ((ie = e.value) == null ? void 0 : ie.offsetHeight) ?? 0, re = o.bottom + ve;
581
581
  let se = re;
582
582
  if (ee && re + ee > c - P) {
583
- const de = o.top - me - ee;
583
+ const de = o.top - ve - ee;
584
584
  se = Math.max(de, P);
585
585
  }
586
586
  _.value = { top: se, left: Z };
@@ -660,7 +660,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
660
660
  }
661
661
  }
662
662
  }
663
- return (o, s) => (m(), v("div", {
663
+ return (o, s) => (v(), m("div", {
664
664
  ref_key: "root",
665
665
  ref: M,
666
666
  class: "relative flex items-center"
@@ -688,16 +688,16 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
688
688
  })
689
689
  ], -1)
690
690
  ])], 512),
691
- (m(), le(Ve, { to: "body" }, [
692
- p.value ? (m(), v("div", {
691
+ (v(), le(Ve, { to: "body" }, [
692
+ p.value ? (v(), m("div", {
693
693
  key: 0,
694
694
  ref_key: "menuContainer",
695
695
  ref: e,
696
696
  style: Ce(I.value),
697
697
  class: "absolute top-0 left-0 mt-2 w-48 rounded-xl border border-gray-200 bg-white shadow-lg text-sm z-[1000]"
698
698
  }, [
699
- R.value || l.clearTilesHandler ? (m(), v(ae, { key: 0 }, [
700
- l.clearTilesHandler ? (m(), v("button", {
699
+ R.value || l.clearTilesHandler ? (v(), m(ae, { key: 0 }, [
700
+ l.clearTilesHandler ? (v(), m("button", {
701
701
  key: 0,
702
702
  type: "button",
703
703
  class: "flex items-center gap-2 w-full px-4 py-2 text-left text-gray-700 hover:bg-slate-50 hover:rounded-t-xl",
@@ -708,7 +708,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
708
708
  class: "lucide lucide-brush-cleaning text-gray-500"
709
709
  }),
710
710
  s[4] || (s[4] = r("span", null, "Очистити тайли", -1))
711
- ])) : (m(), v("a", {
711
+ ])) : (v(), m("a", {
712
712
  key: 1,
713
713
  href: R.value,
714
714
  target: "_blank",
@@ -723,7 +723,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
723
723
  s[5] || (s[5] = r("span", null, "Очистити тайли", -1))
724
724
  ], 8, et))
725
725
  ], 64)) : te("", !0),
726
- l.showXmlItem ? (m(), v("a", {
726
+ l.showXmlItem ? (v(), m("a", {
727
727
  key: 1,
728
728
  href: V.value,
729
729
  target: "_blank",
@@ -774,7 +774,7 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
774
774
  ])
775
775
  ]),
776
776
  default: X(() => [
777
- $.value ? (m(), v("div", lt, " Завантаження форми редагування… ")) : w.value ? (m(), v("div", at, z(w.value), 1)) : (m(), le(E(H), {
777
+ $.value ? (v(), m("div", lt, " Завантаження форми редагування… ")) : w.value ? (v(), m("div", at, z(w.value), 1)) : (v(), le(E(H), {
778
778
  key: 2,
779
779
  values: T.value,
780
780
  "onUpdate:values": s[0] || (s[0] = (c) => T.value = c),
@@ -789,8 +789,8 @@ const Fe = { class: "flex-1 overflow-y-auto p-4" }, Re = { class: "space-y-4" },
789
789
  }
790
790
  });
791
791
  export {
792
- ft as _,
793
- vt as a,
794
- bt as b,
795
- pt as c
792
+ pt as _,
793
+ ft as a,
794
+ mt as b,
795
+ bt as c
796
796
  };
@@ -1,13 +1,13 @@
1
- import { defineComponent as I, defineAsyncComponent as Y, computed as C, openBlock as m, createElementBlock as g, createElementVNode as o, createBlock as Z, unref as $, createCommentVNode as G, createVNode as v, ref as V, watch as A, withModifiers as ee, toDisplayString as O, Fragment as B, renderList as R, withDirectives as U, vModelSelect as K, onMounted as te, resolveComponent as oe, withCtx as L, createTextVNode as X, vShow as W } from "vue";
1
+ import { defineComponent as I, defineAsyncComponent as Y, computed as C, openBlock as m, createElementBlock as f, createElementVNode as o, createBlock as Z, unref as $, createCommentVNode as G, createVNode as v, ref as V, watch as A, withModifiers as ee, toDisplayString as O, Fragment as B, renderList as R, withDirectives as U, vModelSelect as K, onMounted as te, resolveComponent as oe, withCtx as L, createTextVNode as X, vShow as W } from "vue";
2
2
  import { X as Q, Pen as ae, Plus as se, Trash2 as le, LucideChevronRight as ne } from "lucide-vue-next";
3
3
  import { useRouter as re, useRoute as ie } from "vue-router";
4
4
  import { confirm as H, notify as F } from "@opengis/core";
5
5
  import { _ as de } from "./TableFormHeader.vue_vue_type_script_setup_true_lang-Mci_tseM.js";
6
6
  import { _ as ue } from "./MapSettingsTabs.vue_vue_type_script_setup_true_lang-CKCK3NqY.js";
7
7
  import { VsInputArraySelect as ce } from "@opengis/form";
8
- import { q as me, _ as pe } from "./index-CbdZv1jy.js";
8
+ import { q as me, _ as pe } from "./index-Ba6SE4TN.js";
9
9
  import { _ as ye } from "./MonacoEditor.vue_vue_type_script_setup_true_lang-D3ZPeXMw.js";
10
- const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)] p-6" }, ge = /* @__PURE__ */ I({
10
+ const ge = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)] p-6" }, fe = /* @__PURE__ */ I({
11
11
  __name: "GeneralSettings",
12
12
  props: {
13
13
  schema: {},
@@ -24,7 +24,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
24
24
  get: () => x.form,
25
25
  set: (u) => d("update:form", u)
26
26
  });
27
- return (u, s) => (m(), g("section", fe, [
27
+ return (u, s) => (m(), f("section", ge, [
28
28
  s[2] || (s[2] = o("h2", { class: "text-lg font-semibold text-gray-800 mb-4" }, " Основна інформація ", -1)),
29
29
  h.loading ? G("", !0) : (m(), Z($(p), {
30
30
  key: 0,
@@ -48,7 +48,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
48
48
  get: () => p.layerIDs,
49
49
  set: (n) => x("update:layerIDs", n)
50
50
  });
51
- return (n, l) => (m(), g("section", ve, [
51
+ return (n, l) => (m(), f("section", ve, [
52
52
  l[1] || (l[1] = o("h2", { class: "text-lg font-semibold text-gray-800 mb-4" }, "Шари", -1)),
53
53
  l[2] || (l[2] = o("label", { class: "block text-sm font-medium text-gray-700 mb-2" }, "Доступні шари", -1)),
54
54
  v($(ce), {
@@ -66,7 +66,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
66
66
  id: {}
67
67
  },
68
68
  setup(h) {
69
- return (_, p) => (m(), g("div", he, [
69
+ return (_, p) => (m(), f("div", he, [
70
70
  v(me, {
71
71
  class: "w-full h-[calc(100vh-200px)]",
72
72
  height: "h-[calc(100vh-200px)]",
@@ -133,7 +133,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
133
133
  console.error("Failed to parse JSON", s);
134
134
  }
135
135
  }
136
- return (s, r) => h.modelValue !== null ? (m(), g("div", {
136
+ return (s, r) => h.modelValue !== null ? (m(), f("div", {
137
137
  key: 0,
138
138
  class: "fixed inset-0 flex items-center justify-center bg-black/50 backdrop-blur-sm",
139
139
  onClick: ee(l, ["self"])
@@ -148,7 +148,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
148
148
  v($(Q), { size: 20 })
149
149
  ])
150
150
  ]),
151
- n.value ? (m(), g("div", ke, " Помилка JSON: " + O(n.value), 1)) : G("", !0),
151
+ n.value ? (m(), f("div", ke, " Помилка JSON: " + O(n.value), 1)) : G("", !0),
152
152
  o("div", Ve, [
153
153
  v(ye, {
154
154
  modelValue: d.value,
@@ -254,7 +254,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
254
254
  }
255
255
  return (i, b) => {
256
256
  var j;
257
- return m(), g("div", null, [
257
+ return m(), f("div", null, [
258
258
  o("div", { class: "flex items-center justify-between mb-4" }, [
259
259
  b[1] || (b[1] = o("h2", { class: "text-lg font-semibold text-gray-800" }, "Віджети", -1)),
260
260
  o("button", {
@@ -262,7 +262,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
262
262
  class: "px-3 py-1.5 text-sm bg-blue-600 text-white rounded-md hover:bg-blue-700 transition-colors"
263
263
  }, " + Додати віджет ")
264
264
  ]),
265
- (j = s.value) != null && j.length ? (m(), g("div", je, [
265
+ (j = s.value) != null && j.length ? (m(), f("div", je, [
266
266
  o("table", Te, [
267
267
  b[2] || (b[2] = o("thead", { class: "bg-[rgba(252,252,252,0.8)] border-b border-gray-200" }, [
268
268
  o("tr", null, [
@@ -274,7 +274,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
274
274
  ])
275
275
  ], -1)),
276
276
  o("tbody", ze, [
277
- (m(!0), g(B, null, R(s.value, (c, k) => (m(), g("tr", {
277
+ (m(!0), f(B, null, R(s.value, (c, k) => (m(), f("tr", {
278
278
  key: k,
279
279
  class: "hover:bg-gray-50"
280
280
  }, [
@@ -284,7 +284,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
284
284
  onChange: (e) => S(k, "type", c.type),
285
285
  class: "w-full px-2 py-1.5 bg-white border border-gray-300 rounded focus:outline-none focus:ring-1 focus:ring-blue-500 text-gray-700"
286
286
  }, [
287
- (m(), g(B, null, R(d, (e) => o("option", {
287
+ (m(), f(B, null, R(d, (e) => o("option", {
288
288
  key: e,
289
289
  value: e
290
290
  }, O(e), 9, Ae)), 64))
@@ -298,7 +298,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
298
298
  onChange: (e) => S(k, "position", c.position),
299
299
  class: "w-full px-2 py-1.5 bg-white border border-gray-300 rounded focus:outline-none focus:ring-1 focus:ring-blue-500 text-gray-700"
300
300
  }, [
301
- (m(), g(B, null, R(n, (e) => o("option", {
301
+ (m(), f(B, null, R(n, (e) => o("option", {
302
302
  key: e,
303
303
  value: e
304
304
  }, O(e), 9, qe)), 64))
@@ -315,7 +315,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
315
315
  }, null, 40, Ee)
316
316
  ]),
317
317
  o("td", Le, [
318
- w(c.config) ? (m(), g("div", We, [
318
+ w(c.config) ? (m(), f("div", We, [
319
319
  o("button", {
320
320
  onClick: (e) => y(k, c.config),
321
321
  class: "p-1 text-blue-600 hover:text-blue-800 hover:bg-blue-50 rounded transition-colors",
@@ -330,7 +330,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
330
330
  }, [
331
331
  v($(Q), { size: 16 })
332
332
  ], 8, Je)
333
- ])) : (m(), g("div", Pe, [
333
+ ])) : (m(), f("div", Pe, [
334
334
  o("button", {
335
335
  onClick: (e) => D(k),
336
336
  class: "p-1 text-green-600 hover:text-green-800 hover:bg-green-50 rounded transition-colors",
@@ -352,7 +352,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
352
352
  ]))), 128))
353
353
  ])
354
354
  ])
355
- ])) : (m(), g("div", Se, " Немає віджетів. Додайте перший віджет. ")),
355
+ ])) : (m(), f("div", Se, " Немає віджетів. Додайте перший віджет. ")),
356
356
  v(Ne, {
357
357
  teleport: "#modal",
358
358
  modelValue: l.value,
@@ -417,9 +417,9 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
417
417
  return;
418
418
  }
419
419
  try {
420
- const t = new URLSearchParams({ json: "1", val: Array.from(new Set(e)).join(",") }), f = await fetch(`/api/suggest/layer_list?${t.toString()}`);
421
- if (!f.ok) return;
422
- const a = await f.json(), T = (a == null ? void 0 : a.data) ?? a ?? [], M = Array.isArray(T) ? T : [], z = { ...u.value };
420
+ const t = new URLSearchParams({ json: "1", val: Array.from(new Set(e)).join(",") }), g = await fetch(`/api/suggest/layer_list?${t.toString()}`);
421
+ if (!g.ok) return;
422
+ const a = await g.json(), T = (a == null ? void 0 : a.data) ?? a ?? [], M = Array.isArray(T) ? T : [], z = { ...u.value };
423
423
  M.forEach((E) => {
424
424
  const P = E.id != null ? String(E.id) : "";
425
425
  P && (z[P] = E.text ?? E.name ?? P);
@@ -434,14 +434,14 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
434
434
  const t = Object.entries(u.value).reduce(
435
435
  (a, [T, M]) => (a[M] = T, a),
436
436
  {}
437
- ), f = e.map((a) => t[a] ?? null).filter((a) => a != null);
438
- D.value = f;
437
+ ), g = e.map((a) => t[a] ?? null).filter((a) => a != null);
438
+ D.value = g;
439
439
  }
440
440
  }), i = C(() => {
441
441
  const e = y.value.center;
442
442
  if (!Array.isArray(e) || e.length < 2) return "Не задано";
443
- const [t, f] = e;
444
- return t === void 0 || f === void 0 || t === null || f === null || Number.isNaN(Number(t)) || Number.isNaN(Number(f)) ? "Не задано" : `Lng ${Number(t).toFixed(6)}, Lat ${Number(f).toFixed(6)}`;
443
+ const [t, g] = e;
444
+ return t === void 0 || g === void 0 || t === null || g === null || Number.isNaN(Number(t)) || Number.isNaN(Number(g)) ? "Не задано" : `Lng ${Number(t).toFixed(6)}, Lat ${Number(g).toFixed(6)}`;
445
445
  }), b = C(() => {
446
446
  const e = y.value.zoom;
447
447
  if (e == null || e === "")
@@ -527,7 +527,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
527
527
  keywords: t.keywords || [],
528
528
  center: t.center ?? null,
529
529
  widgets: Array.isArray(t.widgets) ? t.widgets : [],
530
- layers: (t.layers || []).map((f) => f.id || f)
530
+ layers: (t.layers || []).map((g) => g.id || g)
531
531
  }, await q(y.value.layers ?? []);
532
532
  } catch (e) {
533
533
  console.error("Failed to load map:", e), F({
@@ -540,8 +540,8 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
540
540
  }
541
541
  }
542
542
  async function k() {
543
- var t, f;
544
- const e = (f = (t = l.value) == null ? void 0 : t.validate) == null ? void 0 : f.call(t);
543
+ var t, g;
544
+ const e = (g = (t = l.value) == null ? void 0 : t.validate) == null ? void 0 : g.call(t);
545
545
  if (e) {
546
546
  F({
547
547
  type: "warning",
@@ -578,14 +578,14 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
578
578
  ), te(async () => {
579
579
  await c();
580
580
  }), (e, t) => {
581
- const f = oe("router-link");
582
- return m(), g("div", Xe, [
581
+ const g = oe("router-link");
582
+ return m(), f("div", Xe, [
583
583
  v(de, {
584
584
  variant: "form",
585
585
  title: y.value.name || "Налаштування карти"
586
586
  }, {
587
587
  breadcrumbs: L(() => [
588
- v(f, {
588
+ v(g, {
589
589
  to: "/gis.maps",
590
590
  class: "text-gray-500 hover:text-gray-700"
591
591
  }, {
@@ -618,16 +618,16 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
618
618
  ]),
619
619
  _: 1
620
620
  }, 8, ["title"]),
621
- d.value ? (m(), g("div", Ze, [...t[7] || (t[7] = [
621
+ d.value ? (m(), f("div", Ze, [...t[7] || (t[7] = [
622
622
  o("p", { class: "text-gray-500" }, "Завантаження...", -1)
623
- ])])) : (m(), g("div", et, [
623
+ ])])) : (m(), f("div", et, [
624
624
  v(ue, {
625
625
  tabs: s,
626
626
  activeTab: w.value,
627
627
  "onUpdate:activeTab": t[1] || (t[1] = (a) => w.value = a)
628
628
  }, null, 8, ["activeTab"]),
629
629
  U(o("div", tt, [
630
- v(ge, {
630
+ v(fe, {
631
631
  schema: j,
632
632
  loading: d.value,
633
633
  modelValue: y.value,
@@ -666,7 +666,7 @@ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
666
666
  ]);
667
667
  };
668
668
  }
669
- }), yt = /* @__PURE__ */ pe(st, [["__scopeId", "data-v-df90fbac"]]);
669
+ }), yt = /* @__PURE__ */ pe(st, [["__scopeId", "data-v-49efd239"]]);
670
670
  export {
671
671
  yt as default
672
672
  };