@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.
- package/README.md +148 -148
- package/dist/{CardIcon-ODZgA2Pb.js → CardIcon-Dx_myDwM.js} +1 -1
- package/dist/{EntityCreatePage-Da8XgBKU.js → EntityCreatePage-Ch8NU_Yw.js} +14 -14
- package/dist/{EntityEditPage-QktKEAxz.js → EntityEditPage-CRRcW7FL.js} +27 -27
- package/dist/{EntityTablePage-UMttc2-F.js → EntityTablePage-DY9v1aWL.js} +32 -31
- package/dist/{ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DLAIOHJh.js → ExtentOutlineLayer.vue_vue_type_script_setup_true_lang-DgQHLSak.js} +1 -1
- package/dist/{HeaderActions.vue_vue_type_script_setup_true_lang-CTKkmXWD.js → HeaderActions.vue_vue_type_script_setup_true_lang-BQ32ioLC.js} +30 -30
- package/dist/{MapSettings-CbW0TfZl.js → MapSettings-CaGPr5uG.js} +33 -33
- package/dist/{RastersTablePage-CXqscX0i.js → RastersTablePage-CJyO2DoI.js} +41 -39
- package/dist/{cartocss-306ZE1Ha.js → cartocss-Bhat1m61.js} +296 -294
- package/dist/{import-utils-CHIDSKHz.js → import-utils-BxeYqcn7.js} +33 -33
- package/dist/index-Ba6SE4TN.js +10203 -0
- package/dist/index.css +1 -1
- package/dist/index.js +1 -1
- package/dist/index.umd.cjs +31 -31
- package/dist/{raster-Cn6l0xfZ.js → raster-Cbs1xR5Y.js} +120 -121
- package/dist/{register-4wblFcw2.js → register-D0AsH83v.js} +8 -8
- package/dist/{service-2uWyAfnR.js → service-C4nt_DBO.js} +10 -10
- package/dist/{vs-datatable-D_Xzh4qf.js → vs-datatable-QG5b0CCL.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/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/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
- package/dist/FileEdit-GikPLv1T.js +0 -37
- 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,
|
|
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
|
|
6
|
-
import { F as ge } from "./
|
|
7
|
-
import { _ as
|
|
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),
|
|
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
|
-
...
|
|
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 || [],
|
|
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
|
-
|
|
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,
|
|
108
|
-
...
|
|
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
|
-
|
|
131
|
-
...
|
|
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(
|
|
152
|
+
f(pe, { variant: "table" }, le({
|
|
154
153
|
title: w(() => [
|
|
155
|
-
|
|
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] =
|
|
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] =
|
|
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
|
-
|
|
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(
|
|
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(
|
|
196
|
+
f(c(me), {
|
|
198
197
|
schema: j.value,
|
|
199
|
-
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:
|
|
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(
|
|
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] =
|
|
254
|
+
t[4] || (t[4] = h(" Показано ", -1)),
|
|
254
255
|
r("span", Fe, x(O.value), 1),
|
|
255
|
-
t[5] || (t[5] =
|
|
256
|
+
t[5] || (t[5] = h(" - ", -1)),
|
|
256
257
|
r("span", Re, x(W.value), 1),
|
|
257
|
-
t[6] || (t[6] =
|
|
258
|
-
r("span", Ne, x(
|
|
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:
|
|
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
|
-
}),
|
|
279
|
+
}), De = /* @__PURE__ */ ge(je, [["__scopeId", "data-v-469c2953"]]);
|
|
279
280
|
export {
|
|
280
|
-
|
|
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-
|
|
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
|
|
2
|
-
import { _ as Ee } from "./index-
|
|
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
|
|
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"],
|
|
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) => (
|
|
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) => (
|
|
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
|
-
|
|
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) => (
|
|
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 ? (
|
|
457
|
-
(
|
|
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
|
-
])) : (
|
|
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 ? (
|
|
473
|
-
(
|
|
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
|
-
])) : (
|
|
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,
|
|
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
|
-
|
|
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 +
|
|
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 -
|
|
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) => (
|
|
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
|
-
(
|
|
692
|
-
p.value ? (
|
|
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 ? (
|
|
700
|
-
l.clearTilesHandler ? (
|
|
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
|
-
])) : (
|
|
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 ? (
|
|
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 ? (
|
|
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
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
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
|
|
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-
|
|
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
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(),
|
|
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(",") }),
|
|
421
|
-
if (!
|
|
422
|
-
const a = await
|
|
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
|
-
),
|
|
438
|
-
D.value =
|
|
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,
|
|
444
|
-
return t === void 0 ||
|
|
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((
|
|
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,
|
|
544
|
-
const e = (
|
|
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
|
|
582
|
-
return m(),
|
|
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(
|
|
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(),
|
|
621
|
+
d.value ? (m(), f("div", Ze, [...t[7] || (t[7] = [
|
|
622
622
|
o("p", { class: "text-gray-500" }, "Завантаження...", -1)
|
|
623
|
-
])])) : (m(),
|
|
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(
|
|
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-
|
|
669
|
+
}), yt = /* @__PURE__ */ pe(st, [["__scopeId", "data-v-49efd239"]]);
|
|
670
670
|
export {
|
|
671
671
|
yt as default
|
|
672
672
|
};
|