@opengis/gis 0.2.120 → 0.2.121

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-Dx_myDwM.js → CardIcon-Bu_mm6QX.js} +1 -1
  3. package/dist/{EntityCreatePage-Ch8NU_Yw.js → EntityCreatePage-Da8XgBKU.js} +14 -14
  4. package/dist/{EntityEditPage-CRRcW7FL.js → EntityEditPage-QktKEAxz.js} +27 -27
  5. package/dist/{EntityTablePage-DY9v1aWL.js → EntityTablePage-BQKMFYxV.js} +26 -26
  6. package/dist/{ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DgQHLSak.js → ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-CF1EEob3.js} +1 -1
  7. package/dist/{HeaderActions.vue_vue_type_script_setup_true_lang-BQ32ioLC.js → HeaderActions.vue_vue_type_script_setup_true_lang-B2ErIdAR.js} +30 -30
  8. package/dist/{MapSettings-CaGPr5uG.js → MapSettings-eE5rNSLf.js} +33 -33
  9. package/dist/{RastersTablePage-CJyO2DoI.js → RastersTablePage-B_vF9yl7.js} +29 -29
  10. package/dist/{cartocss-Bhat1m61.js → cartocss-DcepkzNt.js} +12 -12
  11. package/dist/{import-utils-BxeYqcn7.js → import-utils-CDIgsIUf.js} +33 -33
  12. package/dist/{index-Ba6SE4TN.js → index-CActL7Mw.js} +64 -64
  13. package/dist/index.css +1 -1
  14. package/dist/index.js +1 -1
  15. package/dist/index.umd.cjs +12 -12
  16. package/dist/{raster-Cbs1xR5Y.js → raster-BsBJMgM3.js} +101 -101
  17. package/dist/{register-D0AsH83v.js → register-BSlpAeRe.js} +8 -8
  18. package/dist/{service-C4nt_DBO.js → service-CbPCldfY.js} +11 -11
  19. package/dist/{vs-datatable-QG5b0CCL.js → vs-datatable-RkRQEa10.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/doc_status.json +31 -31
  92. package/module/test/cls/ts.temp_status.json +18 -18
  93. package/module/test/cls/ts.temp_structure.ts_class.json +49 -49
  94. package/module/test/cls/ts.temp_type.json +9 -9
  95. package/module/test/layer/bp.json +59 -59
  96. package/module/test/layer/bp1.yml +33 -33
  97. package/module/test/layer/individual.yml +53 -53
  98. package/module/test/layer/ts.linking_passport.yml +55 -55
  99. package/module/test/layer/ts.temp_structure.yml +50 -50
  100. package/module/test/map/addr.yml +21 -21
  101. package/module/test/map/bp_myo.json +43 -43
  102. package/module/test/map/bpf.json +43 -43
  103. package/module/test/map/main.json +37 -37
  104. package/module/test/map/mbd.json +92 -92
  105. package/module/test/map/ts.json +53 -53
  106. package/module/test/select/address_id.json +2 -2
  107. package/module/test/select/address_id.sql +7 -7
  108. package/module/test/select/core.user_uid.sql +1 -1
  109. package/module/test/table/data_address.street.table.json +69 -69
  110. package/module/test/table/data_bp_myo.bp.table.json +122 -122
  111. package/package.json +75 -75
  112. package/plugin.js +55 -55
  113. package/server/migrations/array_intersect.sql +13 -13
  114. package/server/migrations/cartocss.sql +27 -27
  115. package/server/migrations/group_list.sql +74 -74
  116. package/server/migrations/maps.sql +30 -30
  117. package/server/migrations/metadata.sql +415 -415
  118. package/server/migrations/ogc.sql +106 -106
  119. package/server/migrations/rasters.sql +265 -265
  120. package/server/migrations/services.sql +247 -247
  121. package/server/migrations/services_users_rel.sql +22 -22
  122. package/server/migrations/widgets.sql +20 -20
  123. package/server/plugins/crons.js +21 -21
  124. package/server/plugins/mapnik/funcs/checkRasterFile.js +109 -109
  125. package/server/plugins/mapnik/funcs/mapnik.js +146 -146
  126. package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
  127. package/server/plugins/mapnik/map.proto +234 -234
  128. package/server/plugins/vite.js +74 -74
  129. package/server/routes/gis/cartocss/add.cartocss.js +42 -42
  130. package/server/routes/gis/cartocss/get.cartocss.js +50 -50
  131. package/server/routes/gis/checkXML.js +118 -118
  132. package/server/routes/gis/dashboard.js +29 -29
  133. package/server/routes/gis/index.mjs +87 -87
  134. package/server/routes/gis/metadata/editMetadata.js +34 -34
  135. package/server/routes/gis/metadata/metadataXML.js +13 -13
  136. package/server/routes/gis/ogc/map.info.point.js +124 -124
  137. package/server/routes/gis/registers/add.registry.js +35 -35
  138. package/server/routes/gis/registers/del.registry.js +14 -14
  139. package/server/routes/gis/registers/funcs/classifiers.js +100 -100
  140. package/server/routes/gis/registers/funcs/columns.js +4 -4
  141. package/server/routes/gis/registers/funcs/content.type.js +9 -9
  142. package/server/routes/gis/registers/funcs/get.info.js +89 -89
  143. package/server/routes/gis/registers/funcs/handleRegistryRequest.js +146 -146
  144. package/server/routes/gis/registers/gis.export.js +153 -153
  145. package/server/routes/gis/registers/gis.registry.js +64 -64
  146. package/server/routes/gis/registers/gis.registry.list.js +59 -59
  147. package/server/routes/gis/registers/insert.columns.js +107 -107
  148. package/server/routes/gis/registers/insert.filters.js +110 -110
  149. package/server/routes/gis/registers/map.registry.js +79 -79
  150. package/server/routes/gis/services/add.service.js +64 -64
  151. package/server/routes/gis/services/del.service.js +12 -12
  152. package/server/routes/gis/services/get.layer.geom.js +27 -27
  153. package/server/routes/gis/services/get.services.col.js +33 -33
  154. package/server/routes/gis/services/get.services.js +84 -84
  155. package/server/routes/gis/services/legend.auto.js +77 -77
  156. package/server/routes/map/controllers/clearTiles.js +34 -34
  157. package/server/routes/map/controllers/geojson.js +187 -187
  158. package/server/routes/map/controllers/jsonData.js +205 -205
  159. package/server/routes/map/controllers/layerList.js +102 -102
  160. package/server/routes/map/controllers/map.js +123 -123
  161. package/server/routes/map/controllers/mapCatalog.js +72 -72
  162. package/server/routes/map/controllers/mapCatalogAttribute.js +55 -55
  163. package/server/routes/map/controllers/mapFeatures.js +128 -128
  164. package/server/routes/map/controllers/mapFormat.js +222 -222
  165. package/server/routes/map/controllers/mapTiles.js +152 -152
  166. package/server/routes/map/controllers/maps.js +15 -15
  167. package/server/routes/map/controllers/marker_icon.js +43 -43
  168. package/server/routes/map/controllers/vtile.js +172 -172
  169. package/server/routes/map/index.mjs +169 -169
  170. package/server/routes/map/maps/add.map.js +43 -43
  171. package/server/routes/map/maps/del.map.js +18 -18
  172. package/server/routes/map/maps/get.map.js +112 -112
  173. package/server/routes/map/vtile1.js +179 -179
  174. package/server/routes/map/widgets/add.widget.js +38 -38
  175. package/server/routes/map/widgets/del.widget.js +22 -22
  176. package/server/routes/map/widgets/get.widget.js +40 -40
  177. package/server/routes/mapnik/controllers/clearTiles.js +106 -106
  178. package/server/routes/mapnik/controllers/createXml.js +67 -67
  179. package/server/routes/mapnik/controllers/createXmlMulti.js +76 -76
  180. package/server/routes/mapnik/controllers/fileSearch.js +38 -38
  181. package/server/routes/mapnik/controllers/fileStat.js +28 -28
  182. package/server/routes/mapnik/controllers/mapnikLogger.js +29 -29
  183. package/server/routes/mapnik/controllers/mapnikStat.js +20 -20
  184. package/server/routes/mapnik/controllers/rasterInfo.js +54 -54
  185. package/server/routes/mapnik/controllers/readDir.js +22 -22
  186. package/server/routes/mapnik/controllers/rtile.js +150 -150
  187. package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
  188. package/server/routes/mapnik/functions/cartoBounds.js +28 -28
  189. package/server/routes/mapnik/functions/uploadXML.js +110 -110
  190. package/server/routes/mapnik/index.js +27 -27
  191. package/server/routes/permissions/controllers/catalog.permissions.edit.js +22 -22
  192. package/server/routes/permissions/controllers/catalog.permissions.js +7 -7
  193. package/server/routes/permissions/controllers/gis.catalog.js +80 -80
  194. package/server/routes/permissions/controllers/utils/get.permissions.js +59 -59
  195. package/server/routes/permissions/index.mjs +18 -18
  196. package/server/routes/root.mjs +3 -3
  197. package/utils.js +13 -13
@@ -1,9 +1,9 @@
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";
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";
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 ve, Filter as me } from "@opengis/filter";
6
- import { F as he, _ as ge } from "./index-Ba6SE4TN.js";
5
+ import { FilterField as me, Filter as he } from "@opengis/filter";
6
+ import { F as ge, _ as ve } from "./index-CActL7Mw.js";
7
7
  import { _ as pe } from "./TableFormHeader.vue_vue_type_script_setup_true_lang-Mci_tseM.js";
8
8
  const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-0 m-0" }, be = {
9
9
  key: 0,
@@ -44,7 +44,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
44
44
  }), K = i(() => {
45
45
  const e = String(S.value || "").trim();
46
46
  return e ? `Пошук ${e}...` : "Пошук...";
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);
47
+ }), 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);
48
48
  function G(e) {
49
49
  const t = new URLSearchParams();
50
50
  return Object.entries(e).forEach(([n, a]) => {
@@ -77,20 +77,20 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
77
77
  try {
78
78
  y.value = !0;
79
79
  const t = G({
80
- ...v.value,
80
+ ...m.value,
81
81
  page: o.value,
82
82
  limit: C.value
83
83
  }), n = await fetch(t ? `${e}?${t}` : e);
84
84
  if (!n.ok)
85
85
  throw new Error(`Rows fetch failed: ${n.status}`);
86
86
  const a = await n.json();
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}`));
87
+ 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}`));
88
88
  } catch {
89
89
  b.value = [], y.value = !1;
90
90
  }
91
91
  };
92
92
  function Y(e) {
93
- v.value = e, o.value = 1, F(), p();
93
+ m.value = e, o.value = 1, F(), p();
94
94
  }
95
95
  oe(() => {
96
96
  p(), document.title = S.value;
@@ -103,8 +103,8 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
103
103
  () => s.query,
104
104
  (e) => {
105
105
  const t = Math.max(1, Number(e.page) || 1), n = String(e.search ?? ""), a = t !== o.value, d = n !== l.value;
106
- !a && !d || (o.value = t, l.value = n, v.value = {
107
- ...v.value,
106
+ !a && !d || (o.value = t, l.value = n, m.value = {
107
+ ...m.value,
108
108
  search: n || void 0
109
109
  }, p());
110
110
  }
@@ -126,8 +126,8 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
126
126
  Q({ title: "Збережено", message: `Поле "${t}" оновлено` });
127
127
  }
128
128
  function B(e, t) {
129
- v.value = {
130
- ...v.value,
129
+ m.value = {
130
+ ...m.value,
131
131
  [e]: t
132
132
  }, o.value = 1, F(), p();
133
133
  }
@@ -151,19 +151,19 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
151
151
  return (e, t) => (P(), k("div", xe, [
152
152
  f(pe, { variant: "table" }, le({
153
153
  title: w(() => [
154
- h(x(S.value), 1)
154
+ g(x(S.value), 1)
155
155
  ]),
156
156
  actions: w(() => [
157
157
  c(s).name === "rasters" ? (P(), k("a", be, [
158
158
  f(c(ie), { size: 16 }),
159
- t[2] || (t[2] = h(" Оновити растри ", -1))
159
+ t[2] || (t[2] = g(" Оновити растри ", -1))
160
160
  ])) : R("", !0),
161
161
  r("a", {
162
162
  onClick: t[0] || (t[0] = (n) => c(_).push(H())),
163
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"
164
164
  }, [
165
165
  f(c(ue), { size: 16 }),
166
- t[3] || (t[3] = h(" Додати ", -1))
166
+ t[3] || (t[3] = g(" Додати ", -1))
167
167
  ])
168
168
  ]),
169
169
  _: 2
@@ -171,7 +171,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
171
171
  V.value ? {
172
172
  name: "description",
173
173
  fn: w(() => [
174
- h(x(V.value), 1)
174
+ g(x(V.value), 1)
175
175
  ]),
176
176
  key: "0"
177
177
  } : void 0
@@ -180,7 +180,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
180
180
  r("div", we, [
181
181
  r("div", _e, [
182
182
  r("div", $e, [
183
- f(c(ve), {
183
+ f(c(me), {
184
184
  modelValue: l.value,
185
185
  "onUpdate:modelValue": t[1] || (t[1] = (n) => l.value = n),
186
186
  name: "search",
@@ -193,9 +193,9 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
193
193
  onClear: te,
194
194
  placeholder: K.value
195
195
  }, null, 8, ["modelValue", "placeholder"]),
196
- f(c(me), {
196
+ f(c(he), {
197
197
  schema: j.value,
198
- value: v.value,
198
+ value: m.value,
199
199
  onChange: Y,
200
200
  layout: "inline",
201
201
  mode: "soft",
@@ -208,7 +208,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
208
208
  r("div", Se, [
209
209
  f(c(I), {
210
210
  rows: b.value,
211
- columns: g.value,
211
+ columns: v.value,
212
212
  loading: y.value,
213
213
  router: c(_),
214
214
  selectable: !1,
@@ -241,7 +241,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
241
241
  title: "Редагувати",
242
242
  "aria-label": "Редагувати"
243
243
  }, [
244
- f(he)
244
+ f(ge)
245
245
  ], 8, ke)
246
246
  ])) : R("", !0)
247
247
  ], !0)
@@ -251,16 +251,16 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
251
251
  ]),
252
252
  L.value ? (P(), k("div", Te, [
253
253
  r("div", Ee, [
254
- t[4] || (t[4] = h(" Показано ", -1)),
254
+ t[4] || (t[4] = g(" Показано ", -1)),
255
255
  r("span", Fe, x(O.value), 1),
256
- t[5] || (t[5] = h(" - ", -1)),
256
+ t[5] || (t[5] = g(" - ", -1)),
257
257
  r("span", Re, x(W.value), 1),
258
- t[6] || (t[6] = h(" з ", -1)),
259
- r("span", Ne, x(m.value), 1)
258
+ t[6] || (t[6] = g(" з ", -1)),
259
+ r("span", Ne, x(h.value), 1)
260
260
  ]),
261
261
  r("div", Ve, [
262
262
  f(c(fe), {
263
- total: m.value,
263
+ total: h.value,
264
264
  page: o.value,
265
265
  "page-size": C.value,
266
266
  showPageSizes: !1,
@@ -276,7 +276,7 @@ const xe = { class: "flex-1 flex flex-col bg-gray-50 h-screen overflow-hidden p-
276
276
  ])
277
277
  ]));
278
278
  }
279
- }), De = /* @__PURE__ */ ge(je, [["__scopeId", "data-v-469c2953"]]);
279
+ }), De = /* @__PURE__ */ ve(je, [["__scopeId", "data-v-821aeb35"]]);
280
280
  export {
281
281
  De as default
282
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-Ba6SE4TN.js";
2
+ import { f as b, u as _ } from "./index-CActL7Mw.js";
3
3
  const I = /* @__PURE__ */ y({
4
4
  __name: "ExtentOutlineLayer",
5
5
  props: {
@@ -1,5 +1,5 @@
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";
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-CActL7Mw.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 v(), m("svg", $e, [...h[0] || (h[0] = [
18
+ return m(), v("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"], mt = /* @__PURE__ */ J({
25
+ const je = /* @__PURE__ */ Ee(Se, [["render", Ue]]), Ie = ["aria-label"], vt = /* @__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"], mt = /
30
30
  },
31
31
  emits: ["toggle"],
32
32
  setup(l) {
33
- return (h, u) => (v(), m("button", {
33
+ return (h, u) => (m(), v("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"], mt = /
46
46
  }), pt = /* @__PURE__ */ J({
47
47
  __name: "SettingsIcon",
48
48
  setup(l) {
49
- return (h, u) => (v(), le(E(Me), {
49
+ return (h, u) => (m(), 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
- me(
297
+ ve(
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) => (v(), m("div", Fe, [
429
+ return (t, a) => (m(), v("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 ? (v(), m("div", Ne, [
457
- (v(!0), m(ae, null, ue(F.value, (n) => (v(), m("div", {
456
+ F.value.length ? (m(), v("div", Ne, [
457
+ (m(!0), v(ae, null, ue(F.value, (n) => (m(), v("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
- ])) : (v(), m("p", Oe, z(C)))
464
+ ])) : (m(), v("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 ? (v(), m("div", qe, [
473
- (v(!0), m(ae, null, ue(S.value, (n) => (v(), m("div", {
472
+ S.value.length ? (m(), v("div", qe, [
473
+ (m(!0), v(ae, null, ue(S.value, (n) => (m(), v("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
- ])) : (v(), m("p", Je, z(C)))
480
+ ])) : (m(), v("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, ve = 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, me = 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
- me(p, (o) => {
546
+ ve(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 + ve;
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;
581
581
  let se = re;
582
582
  if (ee && re + ee > c - P) {
583
- const de = o.top - ve - ee;
583
+ const de = o.top - me - 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) => (v(), m("div", {
663
+ return (o, s) => (m(), v("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
- (v(), le(Ve, { to: "body" }, [
692
- p.value ? (v(), m("div", {
691
+ (m(), le(Ve, { to: "body" }, [
692
+ p.value ? (m(), v("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 ? (v(), m(ae, { key: 0 }, [
700
- l.clearTilesHandler ? (v(), m("button", {
699
+ R.value || l.clearTilesHandler ? (m(), v(ae, { key: 0 }, [
700
+ l.clearTilesHandler ? (m(), v("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
- ])) : (v(), m("a", {
711
+ ])) : (m(), v("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 ? (v(), m("a", {
726
+ l.showXmlItem ? (m(), v("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 ? (v(), m("div", lt, " Завантаження форми редагування… ")) : w.value ? (v(), m("div", at, z(w.value), 1)) : (v(), le(E(H), {
777
+ $.value ? (m(), v("div", lt, " Завантаження форми редагування… ")) : w.value ? (m(), v("div", at, z(w.value), 1)) : (m(), 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
- pt as _,
793
- ft as a,
794
- mt as b,
795
- bt as c
792
+ ft as _,
793
+ vt as a,
794
+ bt as b,
795
+ pt as c
796
796
  };
@@ -1,13 +1,13 @@
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";
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";
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-Ba6SE4TN.js";
8
+ import { q as me, _ as pe } from "./index-CActL7Mw.js";
9
9
  import { _ as ye } from "./MonacoEditor.vue_vue_type_script_setup_true_lang-D3ZPeXMw.js";
10
- const ge = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)] p-6" }, fe = /* @__PURE__ */ I({
10
+ const fe = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)] p-6" }, ge = /* @__PURE__ */ I({
11
11
  __name: "GeneralSettings",
12
12
  props: {
13
13
  schema: {},
@@ -24,7 +24,7 @@ const ge = { 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(), f("section", ge, [
27
+ return (u, s) => (m(), g("section", fe, [
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 ge = { 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(), f("section", ve, [
51
+ return (n, l) => (m(), g("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 ge = { 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(), f("div", he, [
69
+ return (_, p) => (m(), g("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 ge = { 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(), f("div", {
136
+ return (s, r) => h.modelValue !== null ? (m(), g("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 ge = { 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(), f("div", ke, " Помилка JSON: " + O(n.value), 1)) : G("", !0),
151
+ n.value ? (m(), g("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 ge = { 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(), f("div", null, [
257
+ return m(), g("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 ge = { 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(), f("div", je, [
265
+ (j = s.value) != null && j.length ? (m(), g("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 ge = { 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), f(B, null, R(s.value, (c, k) => (m(), f("tr", {
277
+ (m(!0), g(B, null, R(s.value, (c, k) => (m(), g("tr", {
278
278
  key: k,
279
279
  class: "hover:bg-gray-50"
280
280
  }, [
@@ -284,7 +284,7 @@ const ge = { 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(), f(B, null, R(d, (e) => o("option", {
287
+ (m(), g(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 ge = { 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(), f(B, null, R(n, (e) => o("option", {
301
+ (m(), g(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 ge = { 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(), f("div", We, [
318
+ w(c.config) ? (m(), g("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 ge = { 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(), f("div", Pe, [
333
+ ])) : (m(), g("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 ge = { class: "rounded-lg border border-gray-200 bg-[rgba(252,252,252,0.8)
352
352
  ]))), 128))
353
353
  ])
354
354
  ])
355
- ])) : (m(), f("div", Se, " Немає віджетів. Додайте перший віджет. ")),
355
+ ])) : (m(), g("div", Se, " Немає віджетів. Додайте перший віджет. ")),
356
356
  v(Ne, {
357
357
  teleport: "#modal",
358
358
  modelValue: l.value,
@@ -417,9 +417,9 @@ const ge = { 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(",") }), 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 };
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 };
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 ge = { 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
- ), g = e.map((a) => t[a] ?? null).filter((a) => a != null);
438
- D.value = g;
437
+ ), f = e.map((a) => t[a] ?? null).filter((a) => a != null);
438
+ D.value = f;
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, 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)}`;
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)}`;
445
445
  }), b = C(() => {
446
446
  const e = y.value.zoom;
447
447
  if (e == null || e === "")
@@ -527,7 +527,7 @@ const ge = { 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((g) => g.id || g)
530
+ layers: (t.layers || []).map((f) => f.id || f)
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 ge = { 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, g;
544
- const e = (g = (t = l.value) == null ? void 0 : t.validate) == null ? void 0 : g.call(t);
543
+ var t, f;
544
+ const e = (f = (t = l.value) == null ? void 0 : t.validate) == null ? void 0 : f.call(t);
545
545
  if (e) {
546
546
  F({
547
547
  type: "warning",
@@ -578,14 +578,14 @@ const ge = { 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 g = oe("router-link");
582
- return m(), f("div", Xe, [
581
+ const f = oe("router-link");
582
+ return m(), g("div", Xe, [
583
583
  v(de, {
584
584
  variant: "form",
585
585
  title: y.value.name || "Налаштування карти"
586
586
  }, {
587
587
  breadcrumbs: L(() => [
588
- v(g, {
588
+ v(f, {
589
589
  to: "/gis.maps",
590
590
  class: "text-gray-500 hover:text-gray-700"
591
591
  }, {
@@ -618,16 +618,16 @@ const ge = { 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(), f("div", Ze, [...t[7] || (t[7] = [
621
+ d.value ? (m(), g("div", Ze, [...t[7] || (t[7] = [
622
622
  o("p", { class: "text-gray-500" }, "Завантаження...", -1)
623
- ])])) : (m(), f("div", et, [
623
+ ])])) : (m(), g("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(fe, {
630
+ v(ge, {
631
631
  schema: j,
632
632
  loading: d.value,
633
633
  modelValue: y.value,
@@ -666,7 +666,7 @@ const ge = { 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-49efd239"]]);
669
+ }), yt = /* @__PURE__ */ pe(st, [["__scopeId", "data-v-df90fbac"]]);
670
670
  export {
671
671
  yt as default
672
672
  };