@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.
- package/README.md +148 -148
- package/dist/{CardIcon-Dx_myDwM.js → CardIcon-Bu_mm6QX.js} +1 -1
- package/dist/{EntityCreatePage-Ch8NU_Yw.js → EntityCreatePage-Da8XgBKU.js} +14 -14
- package/dist/{EntityEditPage-CRRcW7FL.js → EntityEditPage-QktKEAxz.js} +27 -27
- package/dist/{EntityTablePage-DY9v1aWL.js → EntityTablePage-BQKMFYxV.js} +26 -26
- package/dist/{ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DgQHLSak.js → ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-CF1EEob3.js} +1 -1
- package/dist/{HeaderActions.vue_vue_type_script_setup_true_lang-BQ32ioLC.js → HeaderActions.vue_vue_type_script_setup_true_lang-B2ErIdAR.js} +30 -30
- package/dist/{MapSettings-CaGPr5uG.js → MapSettings-eE5rNSLf.js} +33 -33
- package/dist/{RastersTablePage-CJyO2DoI.js → RastersTablePage-B_vF9yl7.js} +29 -29
- package/dist/{cartocss-Bhat1m61.js → cartocss-DcepkzNt.js} +12 -12
- package/dist/{import-utils-BxeYqcn7.js → import-utils-CDIgsIUf.js} +33 -33
- package/dist/{index-Ba6SE4TN.js → index-CActL7Mw.js} +64 -64
- package/dist/index.css +1 -1
- package/dist/index.js +1 -1
- package/dist/index.umd.cjs +12 -12
- package/dist/{raster-Cbs1xR5Y.js → raster-BsBJMgM3.js} +101 -101
- package/dist/{register-D0AsH83v.js → register-BSlpAeRe.js} +8 -8
- package/dist/{service-C4nt_DBO.js → service-CbPCldfY.js} +11 -11
- package/dist/{vs-datatable-QG5b0CCL.js → vs-datatable-RkRQEa10.js} +28 -28
- package/module/cls.json +6 -6
- package/module/gis/card/gis.metadata.table/index.yml +22 -22
- package/module/gis/card/gis.metadata.table/main_info.hbs +20 -20
- package/module/gis/card/gis.metadata.table/metadata_info.hbs +27 -27
- package/module/gis/card/gis.metadata.table/other.hbs +25 -25
- package/module/gis/card/gis.rasters.table/index.yml +11 -11
- package/module/gis/card/gis.rasters.table/main_info.hbs +27 -27
- package/module/gis/card/gis.registers.table/cls.hbs +36 -36
- package/module/gis/card/gis.registers.table/columns.hbs +89 -89
- package/module/gis/card/gis.registers.table/filters.hbs +80 -80
- package/module/gis/card/gis.registers.table/index.yml +23 -23
- package/module/gis/card/gis.registers.table/main_info.hbs +35 -35
- package/module/gis/card/gis.registers.table/source.hbs +45 -45
- package/module/gis/card/gis.services.table/attributes.hbs +91 -91
- package/module/gis/card/gis.services.table/filters.hbs +83 -83
- package/module/gis/card/gis.services.table/index.yml +25 -25
- package/module/gis/card/gis.services.table/main_info.hbs +27 -27
- package/module/gis/card/gis.services.table/source.hbs +25 -25
- package/module/gis/cls/bool.yes_no.json +12 -12
- package/module/gis/cls/encoding.json +14 -14
- package/module/gis/cls/geom_type.json +14 -14
- package/module/gis/cls/gis.column_type.json +34 -34
- package/module/gis/cls/gis.column_view_type.json +26 -26
- package/module/gis/cls/gis.filter_type.json +22 -22
- package/module/gis/cls/language.json +10 -10
- package/module/gis/cls/meta.service_type.json +42 -42
- package/module/gis/cls/ogc.service.json +21 -21
- package/module/gis/cls/service_type.json +42 -42
- package/module/gis/cls/source_type.json +10 -10
- package/module/gis/cls/standarts.json +6 -6
- package/module/gis/cls/topic_category.json +106 -106
- package/module/gis/cls/update_frequency.json +29 -29
- package/module/gis/cls/view.json +21 -21
- package/module/gis/form/feedback.answer.form.json +10 -10
- package/module/gis/form/gis.cartocss.form.json +54 -54
- package/module/gis/form/gis.group_list.form.json +17 -17
- package/module/gis/form/gis.maps.form.json +61 -61
- package/module/gis/form/gis.metadata.form.json +240 -240
- package/module/gis/form/gis.metadata_new.form.json +195 -195
- package/module/gis/form/gis.ogc_service.form.json +51 -51
- package/module/gis/form/gis.rasters.form.json +76 -76
- package/module/gis/form/gis.registers.form.json +124 -124
- package/module/gis/form/gis.registers_column.form.json +84 -84
- package/module/gis/form/gis.registers_filter.form.json +65 -65
- package/module/gis/form/gis.services.form.json +111 -111
- package/module/gis/form/gis.services_attributes.form.json +75 -75
- package/module/gis/form/gis.services_filter.form.json +65 -65
- package/module/gis/menu.json +43 -43
- package/module/gis/select/admin.cls.name.sql +2 -2
- package/module/gis/select/layer_list.sql +7 -7
- package/module/gis/select/layer_list_text.sql +7 -7
- package/module/gis/select/pg.column_name.geometry.sql +12 -12
- package/module/gis/select/pg.columns.parent.sql +6 -6
- package/module/gis/select/pg.table_name.sql +17 -17
- package/module/gis/select/service_id.sql +1 -1
- package/module/gis/table/gis.cartocss.table.json +74 -74
- package/module/gis/table/gis.group_list.table.json +58 -58
- package/module/gis/table/gis.maps.table.json +110 -110
- package/module/gis/table/gis.metadata.table.json +70 -70
- package/module/gis/table/gis.metadata_new.table.json +137 -137
- package/module/gis/table/gis.ogc_service.table.json +100 -100
- package/module/gis/table/gis.rasters.table.json +101 -101
- package/module/gis/table/gis.registers.table.json +143 -143
- package/module/gis/table/gis.services.table.json +120 -120
- package/module/gis/table/site.gis.registers.table.json +88 -88
- package/module/gis/table/site.gis.services.table.json +106 -106
- package/module/gis/templates/ISO19136_2017_gml_template.xml +330 -330
- package/module/gis/tokens.yml +5 -5
- package/module/permissions/form/permissions.users.form.json +151 -151
- package/module/permissions/table/gis.permissions.table.json +97 -97
- package/module/test/cls/bp_build_type.json +37 -37
- package/module/test/cls/doc_status.json +31 -31
- package/module/test/cls/ts.temp_status.json +18 -18
- package/module/test/cls/ts.temp_structure.ts_class.json +49 -49
- package/module/test/cls/ts.temp_type.json +9 -9
- package/module/test/layer/bp.json +59 -59
- package/module/test/layer/bp1.yml +33 -33
- package/module/test/layer/individual.yml +53 -53
- package/module/test/layer/ts.linking_passport.yml +55 -55
- package/module/test/layer/ts.temp_structure.yml +50 -50
- package/module/test/map/addr.yml +21 -21
- package/module/test/map/bp_myo.json +43 -43
- package/module/test/map/bpf.json +43 -43
- package/module/test/map/main.json +37 -37
- package/module/test/map/mbd.json +92 -92
- package/module/test/map/ts.json +53 -53
- package/module/test/select/address_id.json +2 -2
- package/module/test/select/address_id.sql +7 -7
- package/module/test/select/core.user_uid.sql +1 -1
- package/module/test/table/data_address.street.table.json +69 -69
- package/module/test/table/data_bp_myo.bp.table.json +122 -122
- package/package.json +75 -75
- package/plugin.js +55 -55
- package/server/migrations/array_intersect.sql +13 -13
- package/server/migrations/cartocss.sql +27 -27
- package/server/migrations/group_list.sql +74 -74
- package/server/migrations/maps.sql +30 -30
- package/server/migrations/metadata.sql +415 -415
- package/server/migrations/ogc.sql +106 -106
- package/server/migrations/rasters.sql +265 -265
- package/server/migrations/services.sql +247 -247
- package/server/migrations/services_users_rel.sql +22 -22
- package/server/migrations/widgets.sql +20 -20
- package/server/plugins/crons.js +21 -21
- package/server/plugins/mapnik/funcs/checkRasterFile.js +109 -109
- package/server/plugins/mapnik/funcs/mapnik.js +146 -146
- package/server/plugins/mapnik/funcs/rootFolder.mjs +8 -8
- package/server/plugins/mapnik/map.proto +234 -234
- package/server/plugins/vite.js +74 -74
- package/server/routes/gis/cartocss/add.cartocss.js +42 -42
- package/server/routes/gis/cartocss/get.cartocss.js +50 -50
- package/server/routes/gis/checkXML.js +118 -118
- package/server/routes/gis/dashboard.js +29 -29
- package/server/routes/gis/index.mjs +87 -87
- package/server/routes/gis/metadata/editMetadata.js +34 -34
- package/server/routes/gis/metadata/metadataXML.js +13 -13
- package/server/routes/gis/ogc/map.info.point.js +124 -124
- package/server/routes/gis/registers/add.registry.js +35 -35
- package/server/routes/gis/registers/del.registry.js +14 -14
- package/server/routes/gis/registers/funcs/classifiers.js +100 -100
- package/server/routes/gis/registers/funcs/columns.js +4 -4
- package/server/routes/gis/registers/funcs/content.type.js +9 -9
- package/server/routes/gis/registers/funcs/get.info.js +89 -89
- package/server/routes/gis/registers/funcs/handleRegistryRequest.js +146 -146
- package/server/routes/gis/registers/gis.export.js +153 -153
- package/server/routes/gis/registers/gis.registry.js +64 -64
- package/server/routes/gis/registers/gis.registry.list.js +59 -59
- package/server/routes/gis/registers/insert.columns.js +107 -107
- package/server/routes/gis/registers/insert.filters.js +110 -110
- package/server/routes/gis/registers/map.registry.js +79 -79
- package/server/routes/gis/services/add.service.js +64 -64
- package/server/routes/gis/services/del.service.js +12 -12
- package/server/routes/gis/services/get.layer.geom.js +27 -27
- package/server/routes/gis/services/get.services.col.js +33 -33
- package/server/routes/gis/services/get.services.js +84 -84
- package/server/routes/gis/services/legend.auto.js +77 -77
- package/server/routes/map/controllers/clearTiles.js +34 -34
- package/server/routes/map/controllers/geojson.js +187 -187
- package/server/routes/map/controllers/jsonData.js +205 -205
- package/server/routes/map/controllers/layerList.js +102 -102
- package/server/routes/map/controllers/map.js +123 -123
- package/server/routes/map/controllers/mapCatalog.js +72 -72
- package/server/routes/map/controllers/mapCatalogAttribute.js +55 -55
- package/server/routes/map/controllers/mapFeatures.js +128 -128
- package/server/routes/map/controllers/mapFormat.js +222 -222
- package/server/routes/map/controllers/mapTiles.js +152 -152
- package/server/routes/map/controllers/maps.js +15 -15
- package/server/routes/map/controllers/marker_icon.js +43 -43
- package/server/routes/map/controllers/vtile.js +172 -172
- package/server/routes/map/index.mjs +169 -169
- package/server/routes/map/maps/add.map.js +43 -43
- package/server/routes/map/maps/del.map.js +18 -18
- package/server/routes/map/maps/get.map.js +112 -112
- package/server/routes/map/vtile1.js +179 -179
- package/server/routes/map/widgets/add.widget.js +38 -38
- package/server/routes/map/widgets/del.widget.js +22 -22
- package/server/routes/map/widgets/get.widget.js +40 -40
- package/server/routes/mapnik/controllers/clearTiles.js +106 -106
- package/server/routes/mapnik/controllers/createXml.js +67 -67
- package/server/routes/mapnik/controllers/createXmlMulti.js +76 -76
- package/server/routes/mapnik/controllers/fileSearch.js +38 -38
- package/server/routes/mapnik/controllers/fileStat.js +28 -28
- package/server/routes/mapnik/controllers/mapnikLogger.js +29 -29
- package/server/routes/mapnik/controllers/mapnikStat.js +20 -20
- package/server/routes/mapnik/controllers/rasterInfo.js +54 -54
- package/server/routes/mapnik/controllers/readDir.js +22 -22
- package/server/routes/mapnik/controllers/rtile.js +150 -150
- package/server/routes/mapnik/controllers/uploadRaster.js +157 -157
- package/server/routes/mapnik/functions/cartoBounds.js +28 -28
- package/server/routes/mapnik/functions/uploadXML.js +110 -110
- package/server/routes/mapnik/index.js +27 -27
- package/server/routes/permissions/controllers/catalog.permissions.edit.js +22 -22
- package/server/routes/permissions/controllers/catalog.permissions.js +7 -7
- package/server/routes/permissions/controllers/gis.catalog.js +80 -80
- package/server/routes/permissions/controllers/utils/get.permissions.js +59 -59
- package/server/routes/permissions/index.mjs +18 -18
- package/server/routes/root.mjs +3 -3
- 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,
|
|
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
|
|
6
|
-
import { F as
|
|
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),
|
|
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
|
-
...
|
|
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 || [],
|
|
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
|
-
|
|
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,
|
|
107
|
-
...
|
|
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
|
-
|
|
130
|
-
...
|
|
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
|
-
|
|
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] =
|
|
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] =
|
|
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
|
-
|
|
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(
|
|
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(
|
|
196
|
+
f(c(he), {
|
|
197
197
|
schema: j.value,
|
|
198
|
-
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:
|
|
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(
|
|
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] =
|
|
254
|
+
t[4] || (t[4] = g(" Показано ", -1)),
|
|
255
255
|
r("span", Fe, x(O.value), 1),
|
|
256
|
-
t[5] || (t[5] =
|
|
256
|
+
t[5] || (t[5] = g(" - ", -1)),
|
|
257
257
|
r("span", Re, x(W.value), 1),
|
|
258
|
-
t[6] || (t[6] =
|
|
259
|
-
r("span", Ne, x(
|
|
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:
|
|
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__ */
|
|
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-
|
|
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
|
|
2
|
-
import { _ as Ee } from "./index-
|
|
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
|
|
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"],
|
|
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) => (
|
|
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) => (
|
|
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
|
-
|
|
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) => (
|
|
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 ? (
|
|
457
|
-
(
|
|
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
|
-
])) : (
|
|
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 ? (
|
|
473
|
-
(
|
|
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
|
-
])) : (
|
|
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,
|
|
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
|
-
|
|
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 +
|
|
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 -
|
|
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) => (
|
|
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
|
-
(
|
|
692
|
-
p.value ? (
|
|
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 ? (
|
|
700
|
-
l.clearTilesHandler ? (
|
|
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
|
-
])) : (
|
|
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 ? (
|
|
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 ? (
|
|
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
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
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
|
|
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-
|
|
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
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(",") }),
|
|
421
|
-
if (!
|
|
422
|
-
const a = await
|
|
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
|
-
),
|
|
438
|
-
D.value =
|
|
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,
|
|
444
|
-
return t === void 0 ||
|
|
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((
|
|
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,
|
|
544
|
-
const e = (
|
|
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
|
|
582
|
-
return m(),
|
|
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(
|
|
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(),
|
|
621
|
+
d.value ? (m(), g("div", Ze, [...t[7] || (t[7] = [
|
|
622
622
|
o("p", { class: "text-gray-500" }, "Завантаження...", -1)
|
|
623
|
-
])])) : (m(),
|
|
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(
|
|
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-
|
|
669
|
+
}), yt = /* @__PURE__ */ pe(st, [["__scopeId", "data-v-df90fbac"]]);
|
|
670
670
|
export {
|
|
671
671
|
yt as default
|
|
672
672
|
};
|