@opengis/gis 0.1.81 → 0.2.0
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/dist/index.css +1 -1
- package/dist/index.js +5752 -6487
- package/dist/index.umd.cjs +39 -55
- package/module/gis/table/gis.group_list.table.json +36 -0
- package/module/test/cls/ts.temp_structure.ts_class.json +50 -0
- package/module/test/layer/bp.json +60 -0
- package/module/test/map/address/addr.yml +6 -0
- package/module/test/map/address/index.yml +22 -0
- package/module/test/map/address/street.yml +16 -0
- package/module/test/map/address2/addr.json +9 -0
- package/module/test/map/address2/index.json +35 -0
- package/module/test/map/address2/street.json +19 -0
- package/module/test/map/address3.yml +52 -0
- package/module/test/map/address4.json +34 -0
- package/module/test/map/bp_myo.json +37 -0
- package/module/test/map/main.json +44 -0
- package/module/test/map/mbd.json +91 -0
- package/module/test/map/ts.json +20 -129
- package/module/test/table/data_address.street.table.json +70 -0
- package/package.json +13 -11
- package/server/migrations/services.sql +3 -0
- package/server/migrations/widgets.sql +21 -0
- package/server/plugins/mapnik/funcs/map.proto +241 -241
- package/server/routes/gis/index.mjs +2 -0
- package/server/routes/gis/registers/funcs/classifiers.js +18 -3
- package/server/routes/gis/registers/funcs/handleRegistryRequest.js +4 -2
- package/server/routes/gis/services/add.service.js +51 -16
- package/server/routes/gis/services/get.services.js +28 -5
- package/server/routes/gis/services/legend.auto.js +78 -0
- package/server/routes/map/controllers/mapFormat.js +19 -10
- package/server/routes/map/controllers/marker_icon.js +2 -1
- package/server/routes/map/index.mjs +36 -15
- package/server/routes/map/maps/add.map.js +42 -0
- package/server/routes/map/maps/del.map.js +19 -0
- package/server/routes/map/maps/get.map.js +65 -0
- package/server/routes/map/vtile1.js +13 -4
- package/server/routes/map/widgets/add.widget.js +39 -0
- package/server/routes/map/widgets/del.widget.js +23 -0
- package/server/routes/map/widgets/get.widget.js +41 -0
package/dist/index.umd.cjs
CHANGED
|
@@ -1,56 +1,9 @@
|
|
|
1
|
-
(function(W,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@opengis/core"),require("@opengis/filter"),require("vue-router")):typeof define=="function"&&define.amd?define(["exports","vue","@opengis/core","@opengis/filter","vue-router"],e):(W=typeof globalThis<"u"?globalThis:W||self,e(W.MapCustom={},W.Vue,W.openGIScore,W.openGISfilter,W.vueRouter))})(this,(function(W,e,Z,Re,ye){"use strict";const F=(t,o)=>{const n=t.__vccOpts||t;for(const[r,m]of o)n[r]=m;return n},He={key:0,class:"p-5 pb-0 flex justify-between items-center"},We={class:"inline-block font-semibold text-lg text-gray-800"},Ze={class:"flex flex-col gap-1 p-5"},Ye={class:"flex items-center justify-between w-full text-sm text-gray-800 ml-2"},Ge={key:0,class:"ms-2 text-xs text-gray-500"},Je=F({__name:"vs-legend-widget",props:{config:{type:Object,required:!0}},setup(t){const o=t,n=e.computed(()=>{var m;return((m=o.config)==null?void 0:m.items)||[]}),r=e.computed(()=>{var m;return((m=o.config)==null?void 0:m.title)||""});return(m,s)=>(e.openBlock(),e.createElementBlock("div",{class:"legend-widget flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative",style:e.normalizeStyle({width:t.config.width||"100%"})},[r.value?(e.openBlock(),e.createElementBlock("div",He,[e.createElementVNode("h2",We,e.toDisplayString(r.value),1)])):e.createCommentVNode("",!0),e.createElementVNode("div",Ze,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.value,i=>(e.openBlock(),e.createElementBlock("div",{class:"flex items-center",key:i.label},[e.createElementVNode("span",{class:e.normalizeClass(["shrink-0 size-2.5 inline-block me-2.5 h-[10px] w-[10px]",[i.shape==="square"?"rounded-sm":"",i.shape==="circle"?"rounded-full":"",i.shape==="line"?"w-6 h-0.5":"",i.shape==="dashed-line"?"w-6 h-0.5 dashed-line":""]]),style:e.normalizeStyle({backgroundColor:i.color})},null,6),e.createElementVNode("span",Ye,[e.createElementVNode("span",null,e.toDisplayString(i.label),1),i.count!==void 0?(e.openBlock(),e.createElementBlock("span",Ge," ("+e.toDisplayString(i.count)+") ",1)):e.createCommentVNode("",!0)])]))),128))])],4))}},[["__scopeId","data-v-dd12cf90"]]),Ke={class:"flex flex-row gap-x-3 z-10 relative"},Qe=["onClick"],Xe=["src","alt"],et={__name:"vs-basemaps-widget",props:{map:{type:Object,required:!0},config:{type:Object,default:()=>({})},position:{type:String,default:"bottom-left"}},setup(t){const o=t,n=e.ref("voyager"),r=e.computed(()=>{var f;if(!((f=o.config)!=null&&f.layers))return[];const p=o.config.layers.map(c=>({id:c.id,title:c.label||c.title,url:c.url,service:c.type,category:"Базові карти",attribution:c.attribution,image:c.image,enabled:!0,owner:c.owner||"Unknown"}));return p.push({id:"__none__",title:"Без підложки",url:"",service:"",category:"Базові карти",attribution:"",enabled:!0,owner:""}),p});function m(p){return{version:8,sources:{[p.id]:{type:"raster",tiles:[p.url],tileSize:256,attribution:p.attribution||""}},layers:[{id:p.id,type:"raster",source:p.id}]}}const s=p=>{if(!o.map)return;const f=o.map.getStyle(),c=r.value.map(h=>h.id),d=f.layers.filter(h=>!c.includes(h.id)),a={};for(const h in f.sources)c.includes(h)||(a[h]=f.sources[h]);if(p.id==="__none__"){const h={version:8,sources:{...a},layers:[...d]};o.map.setStyle(h);return}const l=m(p);o.map.setStyle(l),o.map.once("styledata",()=>{for(const[h,u]of Object.entries(a))o.map.getSource(h)||o.map.addSource(h,u);for(const h of d)o.map.getLayer(h.id)||o.map.addLayer(h)})},i=p=>{n.value=p;const f=r.value.find(c=>c.id===p);f&&o.map&&s(f)};return e.onMounted(()=>{var p;(p=o.config)!=null&&p.default&&(n.value=o.config.default),i(n.value)}),(p,f)=>{const c=e.resolveDirective("tooltip");return e.openBlock(),e.createElementBlock("div",Ke,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.value,d=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{trigger:"hover",placement:"top",key:d.id},[e.createElementVNode("div",{class:e.normalizeClass(["w-14 h-14 flex items-center justify-center bg-gray-200 rounded-xl shadow-2xs cursor-pointer transition-all border-4",n.value===d.id?"border-blue-400":"border-transparent"]),onClick:a=>i(d.id)},[d.image?(e.openBlock(),e.createElementBlock("img",{key:0,src:d.image,alt:d.title,class:e.normalizeClass(["object-cover rounded-lg",d.id==="__none__"?"w-10 h-10":"w-12 h-12"])},null,10,Xe)):e.createCommentVNode("",!0)],10,Qe)])),[[c,d.title]])),128))])}}};function ie(t){if(!t.attrType||!t.attribute||!t.rules)return t.color||"#ccc";const o=t.rules.map(n=>[["==",["get",t.attribute],n.id||n.value],n.color]);return o.push(t.color||"#ccc"),["case",...o.flat()]}function tt(t){if(!t.attrType||t.attrType!=="icon-by-attribute"||!t.attribute||!t.rules)return t.default_icon||null;const o=t.rules.map(n=>[["==",["get",t.attribute],n.value],n.icon]);return o.push(t.default_icon||"marker.svg"),["case",...o.flat()]}function Le(t){if(!t.attrType||t.attrType!=="attribute-pattern"||!t.attribute||!t.rules)return t.fillPattern||"";const o=t.rules.map(n=>[["==",["get",t.attribute],n.value],n.fillPattern||""]);return o.push(t.fillPattern||""),["case",...o.flat()]}function Q(t,o="stroke",n="#ccc"){return["case",["boolean",["feature-state","hovered"],!1],"#ff0000",["boolean",["feature-state","selected"],!1],"#ff0000",t[o]||n]}function ot(t){const o=[{type:"fill",minzoom:t.pointZoom||0,paint:{"fill-color":ie(t),"fill-outline-color":Q(t,"stroke","#ccc"),"fill-opacity":t.opacity||1,...t.attrType==="attribute-pattern"&&{"fill-pattern":Le(t)},...t.fillPattern&&!t.attrType&&{"fill-pattern":t.fillPattern}}},{type:"line",paint:{"line-color":Q(t,"stroke","#ccc"),"line-width":t.width||2,"line-opacity":t.lineOpacity||t.opacity||1}}];return t.pointZoom&&o.push({type:"circle",maxzoom:t.pointZoom,paint:{"circle-color":t.color||"#ccc","circle-stroke-color":Q(t,"stroke","#ccc"),"circle-stroke-width":t.width||2,"circle-opacity":t.opacity||1}}),o}function nt(t){return[{type:"line",paint:{"line-color":Q(t,"color",ie(t)),"line-width":t.width||2,"line-opacity":t.opacity||1,...t.dashArray&&{"line-dasharray":t.dashArray}},layout:{...t.lineCap&&{"line-cap":t.lineCap},...t.lineJoin&&{"line-join":t.lineJoin}}}]}function rt(t){const o=[{type:"circle",maxzoom:t.icon&&+t.iconZoom||22,paint:{"circle-radius":t.radius||6,"circle-stroke-color":Q(t,"stroke","#ccc"),"circle-stroke-width":t.width||2,"circle-color":ie(t),"circle-opacity":t.opacity||1}}];return t!=null&&t.clusterZoom?(o.push({type:"circle",filter:["has","point_count"],paint:{"circle-color":["step",["get","point_count"],"#51bbd6",100,"#f1f075",750,"#f28cb1"],"circle-radius":["step",["get","point_count"],20,100,30,750,40]}}),o.push({type:"symbol",filter:["has","point_count"],layout:{"text-field":["get","point_count"],"text-font":["Open Sans Regular"],"text-size":12}})):t.icon&&o.push({type:"symbol",minzoom:+t.iconZoom||16,layout:{"icon-image":t.icon,"icon-allow-overlap":!0}}),o}function lt(t,o,n){const r=t.type||"point";return r==="polygon"?[{type:"fill",...n!==void 0?{maxzoom:n}:{},paint:{"fill-color":ie(t),"fill-outline-color":Q(t,"stroke","#ccc"),"fill-opacity":t.opacity||1,...t.attrType==="attribute-pattern"&&{"fill-pattern":Le(t)},...t.fillPattern&&!t.attrType&&{"fill-pattern":t.fillPattern}}},{type:"line",...n!==void 0?{maxzoom:n}:{},paint:{"line-color":Q(t,"stroke","#ccc"),"line-width":t.width||2,"line-opacity":t.lineOpacity||t.opacity||1}}]:r==="line"?[{type:"line",...n!==void 0?{maxzoom:n}:{},paint:{"line-color":Q(t,"color",ie(t)),"line-width":t.width||2,"line-opacity":t.opacity||1,...t.dashArray&&{"line-dasharray":t.dashArray}},layout:{...t.lineCap&&{"line-cap":t.lineCap},...t.lineJoin&&{"line-join":t.lineJoin}}}]:[{type:"circle",...n!==void 0?{maxzoom:n}:{},paint:{"circle-radius":t.radius||6,"circle-stroke-color":Q(t,"stroke","#ccc"),"circle-stroke-width":t.width||2,"circle-color":ie(t),"circle-opacity":t.opacity||1}}]}function Se(t){var n,r;if(!t)return null;if(t.attrType==="icon-by-attribute"&&t.iconZoom){const m=tt(t),s=Array.isArray(m)&&m[0]==="case"?m:["case",["==",["get",t.attribute],((r=(n=t.rules)==null?void 0:n[0])==null?void 0:r.value)||""],m,m],i=lt(t,void 0,+t.iconZoom),p={type:"symbol",minzoom:+t.iconZoom,layout:{"icon-image":s,"icon-size":(t==null?void 0:t.icon_size)||1,"icon-allow-overlap":!0,"icon-anchor":(t==null?void 0:t.icon_anchor)||"bottom"},paint:{"icon-opacity":t.opacity||1}};return[...i,p]}const o=t.type||"point";return o==="polygon"?ot(t):o==="line"?nt(t):rt(t)}function at(t){return t.startsWith("http")?t:`${window.location.origin}${t}`}function st(t){const{id:o,sourceLayer:n,url:r,bounds:m,title:s,style:i,service:p,service_type:f,source_type:c,data:d}=t,a=at(r),l=f||p||c||"vector";switch(l){case"vtile":case"vector":return ct(o,n,a,m,s,i);case"raster":return dt(o,a,m,s,i);case"geojson":return mt(o,d||a,m,s,i);default:throw new Error(`Unsupported layer service type: ${l}`)}}function it(t){switch(t){case"polygon":return{type:"polygon",color:"#3388ff",opacity:.5};case"line":return{type:"line",color:"#3388ff",opacity:1};case"point":default:return{type:"point",color:"#3388ff",radius:6,opacity:1}}}function ct(t,o,n,r,m,s){const i=o||(n.match(/\/vtile\/([^/]+)/)||[])[1]||t,p={type:"vector",tiles:[n],...r&&{bounds:r}},d=Se(s||{}).map((a,l)=>({...a,id:`${t}-${l}`,"source-layer":i,source:t}));return{id:t,title:m,source:p,layers:d,visible:!0}}function dt(t,o,n,r,m){const s={type:"raster",tiles:[o],tileSize:256,...n&&{bounds:n}},i=m||{},p={id:t,type:"raster",source:t,layout:{visibility:"visible"},...i&&{paint:i}};return{id:t,title:r,source:s,layers:[p],visible:!0}}function mt(t,o,n,r,m){var d;const s={type:"geojson",data:o,...n&&{bounds:n}};let i="point";if(o&&o.features&&o.features.length>0){const a=(d=o.features[0].geometry)==null?void 0:d.type;a==="Polygon"||a==="MultiPolygon"?i="polygon":a==="LineString"||a==="MultiLineString"?i="line":i="point"}const p=m||it(i),c=Se(p).map((a,l)=>({...a,id:`${t}-${l}`,source:t}));return{id:t,title:r,source:s,layers:c,visible:!0}}function pt(t){if(!t||t.attrType!=="icon-by-attribute")return[];const o=new Set;return t.default_icon&&o.add(t.default_icon),Array.isArray(t.rules)&&t.rules.forEach(n=>{n.icon&&o.add(n.icon)}),Array.from(o).map(n=>({name:n,url:(t.icon_base_url||"")+n}))}function ft(t){const o=new Set;function n(r){typeof r=="string"?o.add(r):Array.isArray(r)&&r.forEach(n)}return t&&t["icon-image"]&&n(t["icon-image"]),Array.from(o)}async function Fe(t,o){const n=o.map(async({name:r,url:m})=>{const s=await t.loadImage(m);return{name:r,data:s.data}});try{const r=await Promise.all(n);for(const{name:m,data:s}of r)t.hasImage(m)||t.addImage(m,s)}catch(r){console.error("Failed to load icons:",r)}}function ut(t,o,n="/icons/"){const m=ft(o).map(s=>({name:s,url:n+s}));return Fe(t,m)}async function te(t,o){const n=st(o),r=pt(o.style);r.length>0&&await Fe(t,r),o.layout&&o.layout["icon-image"]&&await ut(t,o.layout),t.getSource(n.id)||t.addSource(n.id,n.source);for(const m of n.layers)o.visible!==void 0&&(m.layout={...m.layout,visibility:o.visible?"visible":"none"}),t.getLayer(m.id)?t.setLayoutProperty(m.id,"visibility",o.visible?"visible":"none"):await t.addLayer(m);return n}function ce(t,o){t.getStyle().layers.filter(m=>m.source===o).forEach(m=>{t.removeLayer(m.id)}),t.getSource(o)&&t.removeSource(o)}const gt={},ht={width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function yt(t,o){return e.openBlock(),e.createElementBlock("svg",ht,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M11 19C15.4183 19 19 15.4183 19 11C19 6.58172 15.4183 3 11 3C6.58172 3 3 6.58172 3 11C3 15.4183 6.58172 19 11 19Z",stroke:"black","stroke-linecap":"round","stroke-linejoin":"round"},null,-1),e.createElementVNode("path",{d:"M21.0002 21L16.7002 16.7",stroke:"black","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])])}const je=F(gt,[["render",yt]]),bt={class:"w-full flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative"},kt={class:"flex flex-col justify-between h-full pb-5 px-5"},xt={key:0,class:"relative mb-[10px]"},wt={key:1,class:"mb-4"},_t={class:""},Vt={class:"space-y-2"},Et={class:"flex items-center gap-[10px] text-gray-500"},Bt={class:"dataset-checkbox-container flex"},Nt=["onUpdate:modelValue","onChange"],Ct={class:"text-sm"},$t=["onClick"],Lt=["innerHTML"],St={key:0,class:"text-sm text-gray-500 text-center py-2"},Ft={__name:"vs-layers-widget",props:{map:{type:Object,required:!0},history:{type:Boolean,default:!1},config:{type:Object,default:()=>({layers:[],search:!1,allow_toggle_all:!1})},position:{type:String,default:"bottom-left"},hasFilters:{type:Boolean,default:!1}},emits:["set-filter-layer","update:enabledLayerIds"],setup(t,{emit:o}){const n=t,r=o,m=e.ref(""),s=e.ref([]);function i(){const u=new URLSearchParams(window.location.search).get("layers");return u?u.split(","):[]}function p(h){const u=new URLSearchParams(window.location.search);h.length>0?u.set("layers",h.join(",")):u.delete("layers");const y=`${window.location.pathname}?${u.toString()}`;window.history.replaceState({},"",y)}e.onMounted(()=>{let h=[];n.history&&(h=i()),h.length>0?s.value=n.config.layers.map(u=>({...u,visible:h.includes(String(u.id))})):s.value=n.config.layers.map(u=>({...u,visible:u.visible??!1})),s.value.forEach(u=>{u.visible&&te(n.map,u)}),r("update:enabledLayerIds",d())});const f=e.computed(()=>{if(!m.value)return s.value;const h=m.value.toLowerCase();return s.value.filter(u=>(u.title||u.name||u.label||"").toLowerCase().includes(h))}),c=e.computed(()=>s.value.every(h=>h.visible)),d=()=>s.value.filter(h=>h.visible).map(h=>h.id),a=h=>{h.visible?te(n.map,h):(ce(n.map,h.id),r("set-filter-layer",null)),n.map.getStyle().layers.filter(g=>g.source===h.id).forEach(g=>{n.map.setLayoutProperty(g.id,"visibility",h.visible?"visible":"none")}),r("update:enabledLayerIds",d())},l=()=>{const h=!c.value;s.value.forEach(u=>{u.visible=h,h?te(n.map,u):ce(n.map,u.id)}),h||r("set-filter-layer",null),r("update:enabledLayerIds",d())};return e.watch(()=>d(),h=>{n.history&&p(h)},{deep:!0}),(h,u)=>(e.openBlock(),e.createElementBlock("div",bt,[u[1]||(u[1]=e.createElementVNode("div",{class:"p-5 pb-3 flex justify-between items-center"},[e.createElementVNode("h2",{class:"inline-block font-semibold text-lg text-gray-800"},"Шари")],-1)),e.createElementVNode("div",kt,[t.config.search?(e.openBlock(),e.createElementBlock("div",xt,[e.withDirectives(e.createElementVNode("input",{type:"text","onUpdate:modelValue":u[0]||(u[0]=y=>m.value=y),placeholder:"Введіть назву шару...",class:"py-[7px] ps-8 pl-8 pe-8 block w-full bg-gray-100 border-transparent rounded-lg text-sm focus:bg-white focus:border-blue-500 focus:ring-blue-500 disabled:opacity-50 disabled:pointer-events-none"},null,512),[[e.vModelText,m.value]]),e.createVNode(je)])):e.createCommentVNode("",!0),t.config.allow_toggle_all?(e.openBlock(),e.createElementBlock("div",wt,[e.createElementVNode("button",{onClick:l,class:"w-full py-[7px] bg-blue-500 text-white rounded-lg hover:bg-blue-600 transition-colors"},e.toDisplayString(c.value?"Вимкнути всі":"Увімкнути всі"),1)])):e.createCommentVNode("",!0),e.createElementVNode("div",_t,[e.createElementVNode("ul",Vt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(f.value,y=>(e.openBlock(),e.createElementBlock("li",{key:y.id,class:"flex flex-wrap justify-between items-center gap-x-2"},[e.createElementVNode("label",Et,[e.createElementVNode("span",Bt,[e.withDirectives(e.createElementVNode("input",{class:"dataset-checkbox",type:"checkbox","onUpdate:modelValue":g=>y.visible=g,onChange:()=>a(y)},null,40,Nt),[[e.vModelCheckbox,y.visible]])]),e.createElementVNode("span",Ct,e.toDisplayString(y.title||y.name||y.label),1)]),y.actions&&y.visible?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(y.actions,g=>(e.openBlock(),e.createElementBlock("div",{key:g.id},[e.createElementVNode("button",{class:"text-sm text-gray-500",onClick:b=>h.$emit("show-widget",g.widget)},[e.createElementVNode("div",{innerHTML:g.icon},null,8,Lt)],8,$t)]))),128)):e.createCommentVNode("",!0)]))),128)),m.value&&f.value.length===0?(e.openBlock(),e.createElementBlock("li",St," Шарів не знайдено ")):e.createCommentVNode("",!0)])])])]))}},jt={class:"legend-widget flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative"},It={key:0,class:"p-5 pb-3 flex justify-between items-start gap-[30px]"},vt={class:"inline-block font-semibold text-lg text-gray-800 dark:text-neutral-200"},Dt={class:"flex flex-col gap-1"},At={class:"flex flex-col gap-1 p-5 pt-0"},Mt=["innerHTML"],Tt=F({__name:"vs-info-widget",props:{config:{type:Object,required:!0}},setup(t){const o=t,n=e.computed(()=>{var s;return((s=o.config)==null?void 0:s.title)||""}),r=e.computed(()=>{var s;return((s=o.config)==null?void 0:s.content)||""}),m=e.computed(()=>{var s;return((s=o.config)==null?void 0:s.goTo)||[]});return(s,i)=>{var f,c;const p=e.resolveComponent("router-link");return e.openBlock(),e.createElementBlock("div",jt,[n.value||(f=m.value)!=null&&f.length?(e.openBlock(),e.createElementBlock("div",It,[e.createElementVNode("h2",vt,e.toDisplayString(n.value),1),(c=m.value)!=null&&c.length?(e.openBlock(),e.createBlock(e.unref(Z.VsPopover),{key:0,placement:"bottom"},{reference:e.withCtx(()=>[e.createVNode(e.unref(Z.VsPopover),{trigger:"hover",placement:"right"},{reference:e.withCtx(()=>[...i[0]||(i[0]=[e.createElementVNode("div",{class:"flex items-center justify-center h-8 w-8 transition-colors rounded-full hover:bg-gray-100 cursor-pointer"},[e.createElementVNode("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},[e.createElementVNode("path",{d:"M4 12H20",stroke:"#000000","stroke-linecap":"round","stroke-linejoin":"round"}),e.createElementVNode("path",{d:"M4 6H20",stroke:"#000000","stroke-linecap":"round","stroke-linejoin":"round"}),e.createElementVNode("path",{d:"M4 18H20",stroke:"#000000","stroke-linecap":"round","stroke-linejoin":"round"})])],-1)])]),default:e.withCtx(()=>[i[1]||(i[1]=e.createTextVNode(" Перейти на карту ",-1))]),_:1})]),default:e.withCtx(()=>[e.createElementVNode("div",Dt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,d=>(e.openBlock(),e.createElementBlock("div",{key:d.label},[d.url?(e.openBlock(),e.createBlock(p,{key:0,to:d.url,class:"text-sm text-gray-800 dark:text-neutral-200 hover:bg-gray-100 hover:text-blue-600 transition-colors rounded px-2 py-1 block"},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(d.label),1)]),_:2},1032,["to"])):e.createCommentVNode("",!0)]))),128))])]),_:1})):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),e.createElementVNode("div",At,[e.createElementVNode("div",{innerHTML:r.value},null,8,Mt)])])}}},[["__scopeId","data-v-629caa82"]]),zt={class:"w-full flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative overflow-hidden"},Pt={key:0,class:"p-5 pb-3 flex justify-between items-center"},Ut={class:"inline-block font-semibold text-lg text-gray-800"},Ot={key:1,class:"flex"},qt={class:"flex items-center mx-[8px]"},Rt={class:"min-h-[34px] max-h-[34px] overflow-hidden min-w-[34px] flex justify-center items-center bg-stone-100 text-stone-800 py-2 px-3 text-sm rounded-lg"},Ht={class:"min-h-[34px] flex justify-center items-center text-stone-500 py-2 px-1.5 text-sm"},Wt={class:"flex flex-col justify-between pb-5 px-5 h-full overflow-y-auto flex-1 [&::-webkit-scrollbar]:h-1.5 [&::-webkit-scrollbar]:w-1.5 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-thumb]:bg-gray-300 [&::-webkit-scrollbar-track]:bg-transparent"},Zt={key:0,class:"text-center"},Yt={key:1,class:"text-red-500"},Gt={key:2},Jt=["innerHTML"],Kt={key:1,class:"flow-root"},Qt={class:"-my-3 divide-y divide-gray-100 text-sm"},Xt={class:"font-medium text-gray-900"},eo={class:"text-gray-700 sm:col-span-2"},to={key:2,class:"vs-map-card-info__nodata"},oo={key:3,class:"pt-4 flex justify-end"},no=["href"],Ie={__name:"vs-card-widget",props:{config:{type:Object,required:!0},cardValues:{type:Object,required:!0}},emits:["close","content-resize"],setup(t,{emit:o}){const n=t,r=o,m=e.computed(()=>{var b;return((b=n.config)==null?void 0:b.title)||""}),s=e.computed(()=>!!(typeof window.app=="object"&&window.app&&window.app.config)),i=e.ref([]),p=e.ref(!1),f=e.ref(null),c=e.ref(0),d=e.computed(()=>c.value+1),a=e.computed(()=>{var b;return((b=n.info)==null?void 0:b.length)||0}),l=e.computed(()=>i.value[c.value]),h=e.computed(()=>{if(!l.value)return{};const{rows:b,columns:k}=l.value;return!b||!k?{}:k.reduce((B,j)=>(!j.hide&&!["geom","geodata","id"].includes(j.name)&&(B[j.ua]=b[j.name]??"-"),B),{})});async function u(){var b,k,B,j,N,V;p.value=!0,f.value=null;try{const z={id:(b=n.cardValues)==null?void 0:b.id,layer:typeof((k=n.cardValues)==null?void 0:k.layer)=="object"?(j=(B=n.cardValues)==null?void 0:B.layer)==null?void 0:j.id:(N=n.cardValues)==null?void 0:N.layer,map:(V=n.cardValues)==null?void 0:V.map},O=await fetch("/api/map-format?"+new URLSearchParams(z)).then(Ne=>Ne.json());i.value[c.value]=O}catch(z){f.value=(z==null?void 0:z.message)||"Помилка запиту"}finally{p.value=!1,await e.nextTick(),r("content-resize")}}function y(){c.value<n.info.length-1&&(c.value+=1,i.value[c.value]||u())}function g(){c.value>0&&(c.value-=1,i.value[c.value]||u())}return e.onMounted(async()=>{await e.nextTick(),u()}),e.watch(()=>n.info,()=>{c.value=0,u(),r("content-resize")},{deep:!0}),e.watch([()=>n.cardValues,()=>n.config],async()=>{await e.nextTick(),u(),r("content-resize")}),(b,k)=>{var B,j;return e.openBlock(),e.createElementBlock("div",zt,[m.value?(e.openBlock(),e.createElementBlock("div",Pt,[e.createElementVNode("h2",Ut,e.toDisplayString(m.value),1),e.createElementVNode("button",{type:"button",class:"size-8 inline-flex justify-center items-center gap-x-2 rounded-full border border-transparent bg-gray-100 text-gray-800 hover:bg-gray-200 focus:outline-none focus:bg-gray-200 disabled:opacity-50 disabled:pointer-events-none dark:bg-neutral-700 dark:hover:bg-neutral-600 dark:text-neutral-400 dark:focus:bg-neutral-600 ml-2",onClick:k[0]||(k[0]=N=>r("close"))},[...k[1]||(k[1]=[e.createElementVNode("svg",{class:"shrink-0 size-4 cursor-pointer",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},[e.createElementVNode("path",{d:"M18 6 6 18"}),e.createElementVNode("path",{d:"m6 6 12 12"})],-1)])])])):e.createCommentVNode("",!0),a.value>1?(e.openBlock(),e.createElementBlock("div",Ot,[e.createElementVNode("button",{type:"button",class:e.normalizeClass([{"opacity-flex items-center justify-between border-b px-[16px] py-[8px]50 pointer-events-none":d.value===1},"min-h-[34px] min-w-[34px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 text-sm rounded-lg text-stone-800 hover:bg-stone-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100"]),onClick:g}," ◀ ",2),e.createElementVNode("div",qt,[e.createElementVNode("span",Rt,e.toDisplayString(d.value),1),k[2]||(k[2]=e.createElementVNode("span",{class:"min-h-[34px] flex justify-center items-center text-stone-500 py-2 px-1.5 text-sm"},"з",-1)),e.createElementVNode("span",Ht,e.toDisplayString(a.value),1)]),e.createElementVNode("button",{type:"button",onClick:y,class:e.normalizeClass([{"opacity-50 pointer-events-none":d.value===a.value},"min-h-[34px] min-w-[34px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 text-sm rounded-lg text-stone-800 hover:bg-stone-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100"])}," ▶ ",2)])):e.createCommentVNode("",!0),e.createElementVNode("div",Wt,[p.value?(e.openBlock(),e.createElementBlock("div",Zt,"Завантаження даних...")):f.value?(e.openBlock(),e.createElementBlock("div",Yt," Помилка завантаження даних ")):(e.openBlock(),e.createElementBlock("div",Gt,[(B=l.value)!=null&&B.html?(e.openBlock(),e.createElementBlock("div",{key:0,innerHTML:l.value.html,class:"custom-table-html border-b"},null,8,Jt)):Object.keys(h.value).length?(e.openBlock(),e.createElementBlock("div",Kt,[e.createElementVNode("dl",Qt,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(h.value,(N,V)=>(e.openBlock(),e.createElementBlock("div",{key:V,class:"grid grid-cols-1 gap-1 py-3 even:bg-gray-50 sm:grid-cols-3 sm:gap-4"},[e.createElementVNode("dt",Xt,e.toDisplayString(V),1),e.createElementVNode("dd",eo,e.toDisplayString(N),1)]))),128))])])):(e.openBlock(),e.createElementBlock("div",to,"Даних не знайдено."))])),(j=l.value)!=null&&j.cardInterface&&s.value?(e.openBlock(),e.createElementBlock("div",oo,[e.createElementVNode("a",{href:`/card/${l.value.cardInterface}/${l.value.id}`,target:"_blank",class:"w-full !cursor-pointer text-center gap-2 px-3 py-1.5 bg-blue-600 text-white rounded hover:bg-blue-700 transition text-sm font-medium"}," Перейти в реєстр ",8,no)])):e.createCommentVNode("",!0)])])}}},ro={class:"size-full flex flex-col bg-white border border-gray-200 shadow-2xs rounded-xl dark:bg-neutral-800 dark:border-neutral-700"},lo={key:0,class:"p-5 pb-0 items-center"},ao={class:"inline-block font-semibold text-lg text-gray-800 dark:text-neutral-200"},so={class:"h-full p-5"},io={class:"h-full flex flex-col justify-between space-y-4"},co={class:"space-y-4"},mo={key:0,class:"flex gap-x-1 w-full h-2.5 rounded-full overflow-hidden"},po=["aria-valuenow"],fo={class:"text-sm text-gray-500 px-2 w-full py-2 cursor-pointer !flex flex-row items-center rounded-lg group hover:bg-gray-100"},uo=["for"],go={key:0,width:"16",height:"auto",src:"data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTYgMTYnIGZpbGw9J3doaXRlJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnPjxwYXRoIGQ9J00xMi4yMDcgNC43OTNhMSAxIDAgMDEwIDEuNDE0bC01IDVhMSAxIDAgMDEtMS40MTQgMGwtMi0yYTEgMSAwIDAxMS40MTQtMS40MTRMNi41IDkuMDg2bDQuMjkzLTQuMjkzYTEgMSAwIDAxMS40MTQgMHonLz48L3N2Zz4="},ho=["id","onUpdate:modelValue"],yo={class:"ml-2 text-gray-800 dark:text-neutral-200"},bo={key:0,class:"ms-auto text-xs text-gray-500 dark:text-neutral-500"},ko={__name:"vs-attributre-widget",props:{config:{type:Object,required:!0},map:{type:Object,required:!0}},setup(t){const o=t,n=e.computed(()=>{var f;return((f=o.config)==null?void 0:f.title)||""}),r=e.ref([]),m=e.computed(()=>o.config.layer.style.rules.some(f=>f.count!==void 0)),s=e.computed(()=>o.config.layer.style.rules.reduce((f,c)=>f+(c.count||0),0)),i=f=>!f||s.value===0?0:Math.round(f/s.value*100),p=()=>{const c=o.config.layer.style.rules.filter((d,a)=>r.value[a]).map(d=>d.id||d.value).join(",");if(o.config.layer.id){const d=o.map.getSource(o.config.layer.id);if(d){const l=d.tiles[0].split("?filter=")[0],h=c?`${l}?filter=${o.config.layer.style.attribute}=${c}`:l;d.setTiles([h])}}};return e.onMounted(()=>{var f;(f=o.config)!=null&&f.layer&&(te(o.map,o.config.layer),r.value=new Array(o.config.layer.style.rules.length).fill(!1))}),(f,c)=>(e.openBlock(),e.createElementBlock("div",ro,[n.value?(e.openBlock(),e.createElementBlock("div",lo,[e.createElementVNode("div",null,[e.createElementVNode("h2",ao,e.toDisplayString(n.value),1)])])):e.createCommentVNode("",!0),e.createElementVNode("div",so,[e.createElementVNode("div",io,[e.createElementVNode("div",co,[m.value?(e.openBlock(),e.createElementBlock("div",mo,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.config.layer.style.rules,(d,a)=>(e.openBlock(),e.createElementBlock("div",{key:a,class:"flex flex-col justify-center overflow-hidden text-xs text-white text-center whitespace-nowrap",style:e.normalizeStyle({width:`${i(d.count)}%`,backgroundColor:d.color}),role:"progressbar","aria-valuenow":i(d.count),"aria-valuemin":"0","aria-valuemax":"100"},null,12,po))),128))])):e.createCommentVNode("",!0),e.createElementVNode("ul",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.config.layer.style.rules,(d,a)=>(e.openBlock(),e.createElementBlock("li",{key:a},[e.createElementVNode("div",fo,[e.createElementVNode("label",{for:`filter-${a}`,class:"flex items-center w-full cursor-pointer"},[e.createElementVNode("div",{class:"w-[18px] h-[18px] border rounded-[4px] flex items-center justify-center",style:e.normalizeStyle({background:r.value[a]?d.color||"#2563eb":"#fff",borderColor:r.value[a]?d.color||"#2563eb":d.color||"#d9d9d9"})},[r.value[a]?(e.openBlock(),e.createElementBlock("img",go)):e.createCommentVNode("",!0)],4),e.withDirectives(e.createElementVNode("input",{type:"checkbox",id:`filter-${a}`,"onUpdate:modelValue":l=>r.value[a]=l,onChange:p,class:"hidden",disabled:!1},null,40,ho),[[e.vModelCheckbox,r.value[a]]]),e.createElementVNode("span",yo,e.toDisplayString(d.label||d.text),1),m.value?(e.openBlock(),e.createElementBlock("span",bo,"("+e.toDisplayString(d.count)+")",1)):e.createCommentVNode("",!0)],8,uo)])]))),128))])])])])]))}},xo={},wo={class:"shrink-0 size-4",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"};function _o(t,o){return e.openBlock(),e.createElementBlock("svg",wo,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M18 6 6 18"},null,-1),e.createElementVNode("path",{d:"m6 6 12 12"},null,-1)])])}const ve=F(xo,[["render",_o]]),Vo={class:"hover:bg-gray-100 rounded-lg flex items-center ml-[20px] py-[8px] px-[8px]"},Eo=["for"],Bo={class:"custom-checkbox-wrapper"},No=["id","checked"],Co={class:"custom-checkbox"},$o={key:0,xmlns:"http://www.w3.org/2000/svg",width:"12",height:"8",viewBox:"0 0 12 8",fill:"none"},Lo={class:"flex items-center justify-between ml-2 w-full"},So=["title"],Fo={key:0,class:"text-xs opacity-60 text-[#4b5563]"},jo=F({__name:"vs-map-catalog-item",props:{layer:{type:Object,required:!0},map:{type:Object,default:()=>null},selectedLayers:{type:Array,default:()=>[]}},emits:["select","remove"],setup(t,{emit:o}){const n=t,r=o,m=e.computed(()=>n.selectedLayers.some(p=>p.id===n.layer.id)),s=p=>Intl.NumberFormat("uk",{notation:"compact"}).format(p),i=p=>{r(p?"select":"remove",n.layer)};return(p,f)=>{var c,d,a,l,h;return e.openBlock(),e.createElementBlock("div",Vo,[e.createElementVNode("label",{class:"flex items-center w-full cursor-pointer",for:t.layer.id},[e.createElementVNode("div",Bo,[e.createElementVNode("input",{id:t.layer.id,type:"checkbox",checked:m.value,onChange:f[0]||(f[0]=u=>i(u.target.checked)),class:"custom-checkbox-input"},null,40,No),e.createElementVNode("div",Co,[m.value?(e.openBlock(),e.createElementBlock("svg",$o,[...f[1]||(f[1]=[e.createElementVNode("path",{d:"M10.6663 1L4.24967 7.41667L1.33301 4.5",stroke:"#fff","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])])):e.createCommentVNode("",!0)])]),e.createElementVNode("div",Lo,[e.createElementVNode("div",{class:"whitespace-nowrap text text-ellipsis max-w-[260px] overflow-hidden text-[13px] text-[#4b5563]",title:(c=t.layer)==null?void 0:c.name},e.toDisplayString(((d=t.layer)==null?void 0:d.name)||((a=t.layer)==null?void 0:a.title)),9,So),isNaN(s((l=t.layer)==null?void 0:l.count))?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",Fo,e.toDisplayString(s((h=t.layer)==null?void 0:h.count)),1))])],8,Eo)])}}},[["__scopeId","data-v-b96f3537"]]),Io={},vo={xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-zoom-in"};function Do(t,o){return e.openBlock(),e.createElementBlock("svg",vo,[...o[0]||(o[0]=[e.createElementVNode("circle",{cx:"11",cy:"11",r:"8"},null,-1),e.createElementVNode("line",{x1:"21",x2:"16.65",y1:"21",y2:"16.65"},null,-1),e.createElementVNode("line",{x1:"11",x2:"11",y1:"8",y2:"14"},null,-1),e.createElementVNode("line",{x1:"8",x2:"14",y1:"11",y2:"11"},null,-1)])])}const Ao=F(Io,[["render",Do]]),Mo={},To={xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-info"};function zo(t,o){return e.openBlock(),e.createElementBlock("svg",To,[...o[0]||(o[0]=[e.createElementVNode("circle",{cx:"12",cy:"12",r:"10"},null,-1),e.createElementVNode("path",{d:"M12 16v-4"},null,-1),e.createElementVNode("path",{d:"M12 8h.01"},null,-1)])])}const Po=F(Mo,[["render",zo]]),Uo={},Oo={xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-table"};function qo(t,o){return e.openBlock(),e.createElementBlock("svg",Oo,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M12 3v18"},null,-1),e.createElementVNode("rect",{width:"18",height:"18",x:"3",y:"3",rx:"2"},null,-1),e.createElementVNode("path",{d:"M3 9h18"},null,-1),e.createElementVNode("path",{d:"M3 15h18"},null,-1)])])}const Ro=F(Uo,[["render",qo]]),Ho={},Wo={xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-trash2"};function Zo(t,o){return e.openBlock(),e.createElementBlock("svg",Wo,[...o[0]||(o[0]=[e.createStaticVNode('<path d="M3 6h18"></path><path d="M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6"></path><path d="M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2"></path><line x1="10" x2="10" y1="11" y2="17"></line><line x1="14" x2="14" y1="11" y2="17"></line>',5)])])}const Yo=F(Ho,[["render",Zo]]),Go={},Jo={xmlns:"http://www.w3.org/2000/svg",width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-more-vertical text-gray-600"};function Ko(t,o){return e.openBlock(),e.createElementBlock("svg",Jo,[...o[0]||(o[0]=[e.createElementVNode("circle",{cx:"12",cy:"12",r:"1"},null,-1),e.createElementVNode("circle",{cx:"12",cy:"5",r:"1"},null,-1),e.createElementVNode("circle",{cx:"12",cy:"19",r:"1"},null,-1)])])}const Qo=F(Go,[["render",Ko]]),Xo={},en={width:"6",height:"10",viewBox:"0 0 6 10",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function tn(t,o){return e.openBlock(),e.createElementBlock("svg",en,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M1 9L5 5L1 1",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])])}const on=F(Xo,[["render",tn]]),nn={},rn={width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function ln(t,o){return e.openBlock(),e.createElementBlock("svg",rn,[...o[0]||(o[0]=[e.createStaticVNode('<g clip-path="url(#clip0_231_103)"><path d="M12 20L9 21V12.5L4.52 7.572C4.18545 7.20393 4.00005 6.7244 4 6.227V4H20V6.172C19.9999 6.70239 19.7891 7.21101 19.414 7.586L15 12" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"></path><path d="M21.121 20.1209C21.5406 19.7014 21.8265 19.1668 21.9423 18.5849C22.0581 18.0029 21.9988 17.3997 21.7717 16.8514C21.5447 16.3032 21.1602 15.8346 20.6668 15.5049C20.1734 15.1752 19.5934 14.9993 19 14.9993C18.4066 14.9993 17.8266 15.1752 17.3332 15.5049C16.8398 15.8346 16.4553 16.3032 16.2283 16.8514C16.0012 17.3997 15.9419 18.0029 16.0577 18.5849C16.1735 19.1668 16.4594 19.7014 16.879 20.1209C17.297 20.5399 18.004 21.1659 19 21.9999C20.051 21.1099 20.759 20.4839 21.121 20.1209Z" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"></path><path d="M19 18V18.01" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"></path></g><defs><clipPath id="clip0_231_103"><rect width="24" height="24" fill="white"></rect></clipPath></defs>',2)])])}const an=F(nn,[["render",ln]]);function sn(){const o=new URLSearchParams(window.location.search).get("layers");return o?o.split(","):[]}function cn(t){const o=new URLSearchParams(window.location.search);t.length>0?o.set("layers",t.join(",")):o.delete("layers");const n=`${window.location.pathname}?${o.toString()}`;window.history.replaceState({},"",n)}const dn={components:{VsPopover:Z.VsPopover,VsLayersItem:jo,ZoomInIcon:Ao,InfoIcon:Po,TableIcon:Ro,TrashIcon:Yo,DotsIcon:Qo,ChevronRightIcon:on,FilterIcon:an,closeIcon:ve,searchIcon:je},props:{center:{type:Array,default:()=>[26.2516,50.6199]},zoom:{type:Number,default:12},map:{type:Object,default:()=>null},history:{type:Boolean,default:!1}},emits:["content-resize"],data(){return{layers:null,rawCatalog:null,categories:null,selectedCategory:"",search:"",activeView:"catalog",selectedLayers:[],mounted:!1,draggedLayerIndex:null,filterType:"",filterCategory:""}},computed:{searchedLayers(){return this.layers.filter(({name:t})=>t==null?void 0:t.toLowerCase().match(this.search.toLowerCase()))}},async mounted(){if(this.mounted=!0,await this.getLayers(),this.categories=this.layersCategories(),this.history){const t=sn();t.length>0&&this.layers&&(t.forEach(o=>{const n=this.layers.find(r=>String(r.id)===o);if(n&&!this.selectedLayers.find(r=>r.id===n.id)){const r={...n,visible:!0,opacity:100,showFilters:!1};this.selectedLayers.push(r),te(this.map,r)}}),this.activeView="selected")}this._resizeObserver=new window.ResizeObserver(()=>{this.$emit("content-resize")}),this.$nextTick(()=>{const t=this.$el;t&&this._resizeObserver.observe(t)})},beforeUnmount(){this._resizeObserver&&this._resizeObserver.disconnect()},watch:{selectedLayers:{handler(t){this.history&&cn(t.map(o=>o.id))},deep:!0}},methods:{async getLayers(){try{const t=await fetch("/api/map-catalog").then(n=>n.json()),o=(t.services||[]).filter(n=>n.service_type!=="other");this.layers=[...o,...t.rasters||[]],this.rawCatalog={...t,services:o}}catch(t){console.error("Помилка завантаження шарів:",t)}},layersCategories(){return this.rawCatalog?{Сервіси:this.rawCatalog.services||[],Растри:this.rawCatalog.rasters||[]}:{}},selectCategory(t){this.selectedCategory=this.selectedCategory===t?"":t},formatNumber(t){return Intl.NumberFormat("uk",{notation:"compact"}).format(t)},onEnter(){this.layers.filter(({name:t})=>t==null?void 0:t.toLowerCase().match(this.search.toLowerCase()))},clearSearch(){this.search=""},addToSelected(t){if(!this.selectedLayers.find(o=>o.id===t.id)){const o={...t,visible:!0,opacity:100,showFilters:!1};this.selectedLayers.unshift(o),te(this.map,o)}},deleteLayer(t){const o=this.selectedLayers.findIndex(n=>n.id===t.id);o!==-1&&this.selectedLayers.splice(o,1),ce(this.map,t.id)},async toggleLayerVisibility(t){try{t.visible?(await te(this.map,t),this.updateLayerOpacity(t)):await ce(this.map,t.id)}catch(o){console.error("Error toggling layer visibility:",o),t.visible=!t.visible}},onLayerOpacityChange(t){this.updateLayerOpacity(t)},updateLayerOpacity(t){if(this.map){const o=this.map.getStyle().layers.filter(r=>r.id.includes(t.id)),n=t.opacity/100;o.forEach(r=>{r.type==="fill"?(t.originalFillOpacity||(t.originalFillOpacity=this.map.getPaintProperty(r.id,"fill-opacity")||1),this.map.setPaintProperty(r.id,"fill-opacity",t.originalFillOpacity*n)):r.type==="raster"?this.map.setPaintProperty(r.id,"raster-opacity",n):r.type==="line"?this.map.setPaintProperty(r.id,"line-opacity",n):r.type==="circle"?(this.map.setPaintProperty(r.id,"circle-opacity",n),this.map.setPaintProperty(r.id,"circle-stroke-opacity",n)):r.type==="symbol"&&(this.map.setPaintProperty(r.id,"icon-opacity",n),this.map.setPaintProperty(r.id,"text-opacity",n))})}},async handleRemoveFromCatalog(t){const o=this.selectedLayers.find(n=>n.id===t.id);o!=null&&o.visible&&await ce(this.map,t.id),this.deleteLayer(t)},clearSelectedLayers(){this.selectedLayers.forEach(async t=>{t.visible&&await ce(this.map,t.id)}),this.selectedLayers=[]},zoomToLayer(t){this.fitBoundsByLayer(t)},showLayerInfo(t){},showLayerTable(t){},showLayerFilter(t){t.showFilters=!t.showFilters},fitBoundsByLayer(t){t&&t.bbox&&Array.isArray(t.bbox)&&t.bbox.length===4&&this.map&&this.map.fitBounds([[t.bbox[0],t.bbox[1]],[t.bbox[2],t.bbox[3]]],{padding:50,duration:0})},async handleFilterChange({url:t},o){const n=this.map.getSource(o.id);if(n){const m=n.tiles[0].split("?filter=")[0],s=t?`${m}?filter=${t}`:m;n.setTiles([s])}},popoverActions(t){return[{label:"Збільшити до шару",icon:"ZoomInIcon",class:Array.isArray(t.bbox)&&t.bbox.length===4?"text-gray-700 hover:bg-gray-100":"text-gray-700 hover:bg-gray-100 opacity-50 cursor-not-allowed",handler:"zoomToLayer"},{label:"Інформація про шар",icon:"InfoIcon",class:"text-gray-700 hover:bg-gray-100 opacity-50 cursor-not-allowed",handler:"showLayerInfo"},{label:"Таблиця шару",icon:"TableIcon",class:"text-gray-700 hover:bg-gray-100 opacity-50 cursor-not-allowed",handler:"showLayerTable"},{divider:!0},{label:"Видалити шар",icon:"TrashIcon",class:"text-red-600 hover:bg-red-50",handler:"deleteLayer"}]},onDragStart(t){this.draggedLayerIndex=t},onDragOver(t){},onDrop(t){if(this.draggedLayerIndex===null||this.draggedLayerIndex===t)return;const o=this.selectedLayers[this.draggedLayerIndex];if(this.selectedLayers.splice(this.draggedLayerIndex,1),this.selectedLayers.splice(t,0,o),this.draggedLayerIndex=null,this.map&&this.selectedLayers.length>1)for(let n=this.selectedLayers.length-1;n>=0;n--){const r=this.selectedLayers[n];r.visible&&this.map.getStyle().layers.find(m=>m.id.includes(r.id))&&this.map.getStyle().layers.forEach(m=>{m.id.includes(r.id)&&this.map.moveLayer(m.id)})}},onDragEnd(){this.draggedLayerIndex=null}}},mn={class:"w-full max-w-md mx-auto p-4 bg-white border border-gray-200 rounded-lg shadow-sm"},pn={class:"flex items-center justify-between mb-4"},fn={class:"flex items-center gap-2"},un={class:"text-lg font-semibold text-gray-800"},gn={key:0},hn={key:1},yn={class:"flex mb-4 border-b border-gray-200"},bn={key:0},kn={class:"mb-4"},xn={key:0,class:"space-y-2 max-h-[400px] overflow-y-auto pr-1 [&::-webkit-scrollbar]:h-1.5 [&::-webkit-scrollbar]:w-1.5 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-thumb]:bg-gray-300 [&::-webkit-scrollbar-track]:bg-transparent"},wn=["onDragstart","onDragover","onDrop"],_n={class:"flex items-center justify-between"},Vn={class:"flex items-center gap-2 cursor-move"},En=["onUpdate:modelValue","onChange"],Bn={class:"text-gray-800"},Nn={class:"flex items-center gap-2"},Cn={class:"relative"},$n={class:"flex items-center gap-2"},Ln=["onUpdate:modelValue","onInput"],Sn={class:"text-xs text-gray-600 whitespace-nowrap"},Fn=["onClick"],jn={class:"relative"},In={class:"w-48"},vn={key:0,class:"my-1 border-gray-200"},Dn=["disabled","onClick"],An={class:"p-1 rounded-full hover:bg-gray-100 transition-colors","aria-label":"Layer actions"},Mn={key:0,class:"bg-blue-50 rounded-md mt-2"},Tn={class:"px-2 pt-2 text-blue-600 hover:text-blue-700 transition-colors"},zn={key:0,class:"text-center text-[14px] text-[#4b5563]"},Pn={class:"relative mt-[10px]"},Un={key:0,class:"vs-layers-catalog__list flex-1 scrollable-container overflow-auto mt-2 catalog-list"},On={key:0,class:"text-center text-[14px] text-[#4b5563]"},qn={key:0,class:"text-center text-[14px] text-[#4b5563]"},Rn=["onClick"],Hn={class:"flex items-center gap-x-3"},Wn=["title"],Zn={class:"text-xs opacity-60 text-[#4b5563]"};function Yn(t,o,n,r,m,s){var h;const i=e.resolveComponent("VsPopover"),p=e.resolveComponent("DotsIcon"),f=e.resolveComponent("VsFilter"),c=e.resolveComponent("searchIcon"),d=e.resolveComponent("closeIcon"),a=e.resolveComponent("VsLayersItem"),l=e.resolveComponent("chevronRightIcon");return e.openBlock(),e.createElementBlock("div",mn,[e.createElementVNode("div",pn,[e.createElementVNode("div",fn,[o[7]||(o[7]=e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-layers text-blue-600"},[e.createElementVNode("path",{d:"m12.83 2.18a2 2 0 0 0-1.66 0L2.6 6.08a1 1 0 0 0 0 1.83l8.58 3.91a2 2 0 0 0 1.66 0l8.58-3.9a1 1 0 0 0 0-1.83Z"}),e.createElementVNode("path",{d:"m22 17.65-9.17 4.16a2 2 0 0 1-1.66 0L2 17.65"}),e.createElementVNode("path",{d:"m22 12.65-9.17 4.16a2 2 0 0 1-1.66 0L2 12.65"})],-1)),e.createElementVNode("h2",un,[e.createTextVNode(e.toDisplayString(m.activeView==="catalog"?"Каталог":"Вибрані шари")+" ",1),m.activeView==="catalog"?(e.openBlock(),e.createElementBlock("span",gn,"("+e.toDisplayString(((h=m.layers)==null?void 0:h.length)||0)+")",1)):(e.openBlock(),e.createElementBlock("span",hn,"("+e.toDisplayString(m.selectedLayers.length)+")",1))])]),e.createElementVNode("button",{class:"p-1 rounded-full hover:bg-gray-200 transition-colors","aria-label":"Reset layers",onClick:o[0]||(o[0]=(...u)=>s.clearSelectedLayers&&s.clearSelectedLayers(...u))},[...o[8]||(o[8]=[e.createStaticVNode('<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-refresh-cw text-gray-600" data-v-e9e7021a><path d="M3 12a9 9 0 0 1 9-9 9.75 9.75 0 0 1 6.74 2.74L21 8" data-v-e9e7021a></path><path d="M21 3v5h-5" data-v-e9e7021a></path><path d="M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16" data-v-e9e7021a></path><path d="M8 16H3v5" data-v-e9e7021a></path></svg>',1)])])]),e.createElementVNode("div",yn,[e.createElementVNode("button",{class:e.normalizeClass(["px-4 py-2 text-sm font-medium",m.activeView==="catalog"?"text-blue-600 border-b-2 border-blue-600":"text-gray-600 hover:text-gray-800"]),onClick:o[1]||(o[1]=u=>m.activeView="catalog")}," Каталог ",2),e.createElementVNode("button",{class:e.normalizeClass(["px-4 py-2 text-sm font-medium",m.activeView==="selected"?"text-blue-600 border-b-2 border-blue-600":"text-gray-600 hover:text-gray-800"]),onClick:o[2]||(o[2]=u=>m.activeView="selected")}," Вибрані шари ",2)]),m.activeView==="selected"?(e.openBlock(),e.createElementBlock("div",bn,[e.createElementVNode("div",kn,[e.createElementVNode("button",{class:"flex items-center gap-2 text-blue-600 hover:text-blue-700 transition-colors px-3 py-2 rounded-md bg-blue-50 hover:bg-blue-100 w-full justify-center",onClick:o[3]||(o[3]=u=>m.activeView="catalog")},[...o[9]||(o[9]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-plus"},[e.createElementVNode("path",{d:"M5 12h14"}),e.createElementVNode("path",{d:"M12 5v14"})],-1),e.createElementVNode("span",null,"Вибрати шар",-1)])])]),m.mounted?(e.openBlock(),e.createElementBlock("div",xn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.selectedLayers,(u,y)=>{var g,b;return e.openBlock(),e.createElementBlock("div",{key:u.id||y,class:e.normalizeClass(["border border-gray-200 rounded-md p-3 mb-2 bg-white shadow-sm text-[13px] text-[#4b5563]",{dragging:m.draggedLayerIndex===y}]),draggable:"true",onDragstart:k=>s.onDragStart(y),onDragover:e.withModifiers(k=>s.onDragOver(y),["prevent"]),onDrop:k=>s.onDrop(y),onDragend:o[4]||(o[4]=(...k)=>s.onDragEnd&&s.onDragEnd(...k))},[e.createElementVNode("div",_n,[e.createElementVNode("div",Vn,[o[10]||(o[10]=e.createStaticVNode('<svg width="16" height="16" fill="none" stroke="#9ca3af" stroke-width="2" viewBox="0 0 24 24" class="mr-1 shrink-0" data-v-e9e7021a><circle cx="5" cy="5" r="1.5" data-v-e9e7021a></circle><circle cx="5" cy="12" r="1.5" data-v-e9e7021a></circle><circle cx="5" cy="19" r="1.5" data-v-e9e7021a></circle><circle cx="12" cy="5" r="1.5" data-v-e9e7021a></circle><circle cx="12" cy="12" r="1.5" data-v-e9e7021a></circle><circle cx="12" cy="19" r="1.5" data-v-e9e7021a></circle><circle cx="19" cy="5" r="1.5" data-v-e9e7021a></circle><circle cx="19" cy="12" r="1.5" data-v-e9e7021a></circle><circle cx="19" cy="19" r="1.5" data-v-e9e7021a></circle></svg>',1)),e.withDirectives(e.createElementVNode("input",{type:"checkbox",class:"w-4 h-4 text-blue-600 rounded focus:ring-blue-500","onUpdate:modelValue":k=>u.visible=k,onChange:k=>s.toggleLayerVisibility(u)},null,40,En),[[e.vModelCheckbox,u.visible]]),e.createElementVNode("span",Bn,e.toDisplayString(u.name||u.title||u.label),1)]),e.createElementVNode("div",Nn,[e.createElementVNode("div",Cn,[e.createVNode(i,{placement:"bottom"},{reference:e.withCtx(()=>[e.createElementVNode("div",{class:"text-sm text-gray-600 hover:text-gray-800 transition-colors px-2 py-1 rounded hover:bg-gray-100 cursor-pointer",onClick:k=>s.updateLayerOpacity(u)},e.toDisplayString(u.opacity||100)+"% ",9,Fn)]),default:e.withCtx(()=>[e.createElementVNode("div",$n,[o[11]||(o[11]=e.createElementVNode("label",{class:"text-gray-600 whitespace-nowrap"},"Прозорість:",-1)),e.withDirectives(e.createElementVNode("input",{type:"range",min:"0",max:"100",step:"1","onUpdate:modelValue":k=>u.opacity=k,onInput:k=>s.onLayerOpacityChange(u),class:"h-2 w-full accent-blue-600 rounded-lg cursor-pointer bg-gray-200"},null,40,Ln),[[e.vModelText,u.opacity]]),e.createElementVNode("span",Sn,e.toDisplayString(Math.round(u.opacity))+"% ",1)])]),_:2},1024)]),e.createElementVNode("div",jn,[e.createVNode(i,{placement:"bottom"},{reference:e.withCtx(()=>[e.createElementVNode("div",An,[e.createVNode(p)])]),default:e.withCtx(()=>[e.createElementVNode("div",In,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.popoverActions(u),(k,B)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:B},[k.divider?(e.openBlock(),e.createElementBlock("hr",vn)):(e.openBlock(),e.createElementBlock("button",{key:1,class:e.normalizeClass("w-full p-2 text-left text-sm flex items-center gap-2 "+(k.class||"")),disabled:k.disabled,onClick:j=>!k.disabled&&t.$options.methods[k.handler].call(this,u)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(k.icon),{class:"lucide"})),e.createTextVNode(" "+e.toDisplayString(k.label),1)],10,Dn))],64))),128))])]),_:2},1024)])])]),u.showFilters?(e.openBlock(),e.createElementBlock("div",Mn,[e.createElementVNode("div",Tn," Фільтри для шару: "+e.toDisplayString(u.name||u.title||u.label),1),e.withDirectives(e.createVNode(f,{ref_for:!0,ref:"filter",scheme:u.filters,header:!1,urlSeparator:"true",view:"plain",name:"filter",onFilterChange:k=>s.handleFilterChange(k,u)},null,8,["scheme","onFilterChange"]),[[e.vShow,(g=u.filters)==null?void 0:g.length]]),e.withDirectives(e.createElementVNode("div",null,[...o[12]||(o[12]=[e.createElementVNode("div",{class:"px-2 text-[14px] text-[#4b5563]"}," Фільтри для шару відсутні ",-1)])],512),[[e.vShow,!((b=u.filters)!=null&&b.length)]])])):e.createCommentVNode("",!0)],42,wn)}),128)),m.selectedLayers.length===0?(e.openBlock(),e.createElementBlock("div",zn,[...o[13]||(o[13]=[e.createElementVNode("p",null,'Щоб додати шар, натисніть на кнопку "Вибрати шар".',-1)])])):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createElementVNode("div",Pn,[e.withDirectives(e.createElementVNode("input",{title:"value",placeholder:"Введіть назву шару...","onUpdate:modelValue":o[5]||(o[5]=u=>m.search=u),type:"text",class:"py-[7px] pl-8 pe-8 block w-full bg-gray-100 border-transparent rounded-lg text-sm focus:bg-white focus:border-blue-500 focus:ring-blue-500 disabled:opacity-50 disabled:pointer-events-none dark:bg-neutral-700 dark:border-transparent dark:text-neutral-400 dark:placeholder:text-neutral-400 dark:focus:bg-neutral-800 dark:focus:ring-neutral-600",onKeyup:o[6]||(o[6]=e.withKeys((...u)=>s.onEnter&&s.onEnter(...u),["enter"]))},null,544),[[e.vModelText,m.search]]),e.createVNode(c,{class:"absolute top-1/2 left-[8px] w-[16px] h-[16px]",style:{transform:"translate(0, -50%)"}}),m.search?(e.openBlock(),e.createBlock(d,{key:0,class:"absolute top-1/2 right-[10px] w-[16px] h-[16px] cursor-pointer",style:{transform:"translate(0, -50%)"},onClick:s.clearSearch},null,8,["onClick"])):e.createCommentVNode("",!0)]),m.categories?(e.openBlock(),e.createElementBlock("div",Un,[m.search?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.searchedLayers,(u,y)=>(e.openBlock(),e.createBlock(a,{key:y,layer:u,map:n.map,selectedLayers:m.selectedLayers,onSelect:s.addToSelected,onRemove:s.handleRemoveFromCatalog},null,8,["layer","map","selectedLayers","onSelect","onRemove"]))),128)),s.searchedLayers.length===0?(e.openBlock(),e.createElementBlock("div",On," Нічого не знайдено ")):e.createCommentVNode("",!0)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!m.categories||Object.keys(m.categories).length===0?(e.openBlock(),e.createElementBlock("div",qn," Каталог порожній ")):(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(Object.keys(m.categories),u=>(e.openBlock(),e.createElementBlock("div",{key:u},[e.createElementVNode("div",{class:"hover:bg-gray-100 focus:bg-gray-100 px-2.5 cursor-pointer p-[8px] rounded-lg flex justify-between items-center",onClick:y=>s.selectCategory(u)},[e.createElementVNode("div",Hn,[e.createVNode(l,{class:e.normalizeClass({"rotate-up":u===m.selectedCategory,"rotate-down":u!==m.selectedCategory})},null,8,["class"]),e.createElementVNode("div",{class:"max-w-[260px] text-[14px] text-[#4b5563]",title:u},e.toDisplayString(u),9,Wn)]),e.createElementVNode("div",Zn,e.toDisplayString(s.formatNumber(m.categories[u].length)),1)],8,Rn),e.withDirectives(e.createElementVNode("div",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.categories[u],(y,g)=>(e.openBlock(),e.createBlock(a,{key:g,layer:y,map:n.map,selectedLayers:m.selectedLayers,onSelect:s.addToSelected,onRemove:s.handleRemoveFromCatalog},null,8,["layer","map","selectedLayers","onSelect","onRemove"]))),128))],512),[[e.vShow,u===m.selectedCategory]])]))),128))],64))])):e.createCommentVNode("",!0)],64))])}const Gn=F(dn,[["render",Yn],["__scopeId","data-v-e9e7021a"]]),Jn={key:0,class:"w-full flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative widget"},Kn={key:0,class:"p-5 pb-3 flex justify-between items-center"},Qn={class:"inline-block font-semibold text-lg text-gray-800 dark:text-neutral-200"},Xn={class:"flex flex-col justify-between h-full"},er={__name:"vs-filters-widget",props:{config:{type:Object,required:!0},map:{type:Object,required:!0},enabledLayerIds:{type:Array,default:()=>[]}},setup(t){const o=t,n=e.computed(()=>{var i;return((i=o.config)==null?void 0:i.filters)||[]}),r=e.computed(()=>n.value),m=e.computed(()=>{var p;const i=(p=o.config)==null?void 0:p.conditions;return!i||!i.layers?!0:o.enabledLayerIds.some(f=>i.layers.includes(f))}),s=async({data:i})=>{var a;const p=Object.entries(i).map(l=>l.join("=")).join("|"),f=(a=o.config)==null?void 0:a.conditions,c=(f==null?void 0:f.layers)||[],d=o.enabledLayerIds.filter(l=>c.includes(l));d.length&&d.forEach(l=>{const h=o.map.getSource(l);if(h){const y=h.tiles[0].split("?filter=")[0],g=p?`${y}?filter=${p}`:y;h.setTiles([g])}})};return(i,p)=>m.value?(e.openBlock(),e.createElementBlock("div",Jn,[t.config.title?(e.openBlock(),e.createElementBlock("div",Kn,[e.createElementVNode("h2",Qn,e.toDisplayString(t.config.title),1)])):e.createCommentVNode("",!0),e.createElementVNode("div",Xn,[e.createVNode(e.unref(Re),{ref:"filter",schema:r.value,view:"vertical",onChange:s},null,8,["schema"])])])):e.createCommentVNode("",!0)}},tr={type:"button",class:"py-2 px-2.5 inline-flex items-center gap-x-1.5 text-sm font-medium rounded-lg bg-white text-gray-800 hover:bg-gray-50 focus:outline-none focus:bg-gray-49 h-[38px] shadow-md"},or={class:"flex gap-[5px] items-center"},nr={class:"text-gray-600"},rr={key:0,class:"w-[16px] h-[16px] font-medium bg-gray-800 text-white rounded-full flex items-center justify-center text-[10px]"},lr={__name:"vs-inline-filters-widget",props:{config:{type:Object,required:!0},map:{type:Object,required:!0},enabledLayerIds:{type:Array,default:()=>[]}},setup(t){const o=t,n=e.ref(0),r=e.ref(null),m=e.computed(()=>{var c;return((c=o.config)==null?void 0:c.filters)||[]}),s=e.computed(()=>m.value.map(c=>({...c,id:c.name}))),i=e.computed(()=>{var d;const c=(d=o.config)==null?void 0:d.conditions;return!c||!c.layers?!0:o.enabledLayerIds.some(a=>c.layers.includes(a))}),p=e.computed(()=>{var c;if(o.enabledLayerIds&&o.enabledLayerIds.length){const a=(((c=o.config)==null?void 0:c.layers)||[]).find(l=>l.id===o.enabledLayerIds[0]);return(a==null?void 0:a.title)||(a==null?void 0:a.name)||(a==null?void 0:a.label)||o.enabledLayerIds[0]}return""}),f=async({url:c})=>{var h,u;const d=(h=o.config)==null?void 0:h.conditions;if(!d){const y=(u=o.config)==null?void 0:u.layer_id;if(!y)return;const g=o.map.getSource(y);if(g){const k=g.tiles[0].split("?filter=")[0],B=c?`${k}?filter=${c}`:k;g.setTiles([B])}return}const a=(d==null?void 0:d.layers)||[],l=o.enabledLayerIds.filter(y=>a.includes(y));l.length&&l.forEach(y=>{const g=o.map.getSource(y);if(g){const k=g.tiles[0].split("?filter=")[0],B=c?`${k}?filter=${c}`:k;g.setTiles([B])}})};return e.watch(()=>o.enabledLayerIds,c=>{(!c||!c.length)&&r.value&&(r.value.activeFilters={},n.value=0)}),e.watch(()=>{var c;return(c=r.value)==null?void 0:c.activeFilters},c=>{n.value=Object.keys(c||{}).length},{deep:!0}),(c,d)=>{const a=e.resolveComponent("VsPopover"),l=e.resolveComponent("VsFilterList");return i.value&&s.value.length?(e.openBlock(),e.createBlock(l,{key:0,ref_key:"filter",ref:r,isDialog:t.config.dialog??!0,scheme:s.value,urlSeparator:"true",view:"plain",name:"filter",onFilterChange:f},{button:e.withCtx(({visible:h})=>[e.createVNode(a,{teleport:"body",trigger:"hover",placement:"bottom"},{reference:e.withCtx(()=>[e.createElementVNode("button",tr,[e.createElementVNode("div",or,[d[0]||(d[0]=e.createElementVNode("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},[e.createElementVNode("path",{d:"M12 20L9 21V12.5L4.52 7.572C4.18545 7.20393 4.00005 6.7244 4 6.227V4H20V6.172C19.9999 6.70239 19.7891 7.21101 19.414 7.586L15 12",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"}),e.createElementVNode("path",{d:"M21.121 20.1209C21.5406 19.7014 21.8265 19.1668 21.9423 18.5849C22.0581 18.0029 21.9988 17.3997 21.7717 16.8514C21.5447 16.3032 21.1602 15.8346 20.6668 15.5049C20.1734 15.1752 19.5934 14.9993 19 14.9993C18.4066 14.9993 17.8266 15.1752 17.3332 15.5049C16.8398 15.8346 16.4553 16.3032 16.2283 16.8514C16.0012 17.3997 15.9419 18.0029 16.0577 18.5849C16.1735 19.1668 16.4594 19.7014 16.879 20.1209C17.297 20.5399 18.004 21.1659 19 21.9999C20.051 21.1099 20.759 20.4839 21.121 20.1209Z",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"}),e.createElementVNode("path",{d:"M19 18V18.01",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"})],-1)),e.createElementVNode("span",nr,e.toDisplayString(p.value),1),n.value?(e.openBlock(),e.createElementBlock("span",rr,e.toDisplayString(n.value),1)):e.createCommentVNode("",!0)])])]),default:e.withCtx(()=>[d[1]||(d[1]=e.createTextVNode(" Відкрити бокову панель ",-1))]),_:1})]),_:1},8,["isDialog","scheme"])):e.createCommentVNode("",!0)}}},ar={name:"VsListWidget",props:{config:{type:Object,required:!0}},data(){return{items:[],total:0,currentPage:1,limit:16,rootEl:null,resizeObserver:null}},methods:{async fetchData(){const t={page:this.currentPage,limit:this.limit};try{const o=await fetch(this.config.api+"?"+new URLSearchParams(t)).then(n=>n.json());this.items=o.rows,this.total=o.total,this.$emit("content-resize")}catch(o){console.error("Error fetching data:",o)}},handlePageChange(t){this.currentPage=t,this.fetchData()},changeLimit(t){this.limit=t,this.currentPage=1,this.fetchData()}},mounted(){this.fetchData(),this.resizeObserver=new ResizeObserver(()=>{this.$emit("content-resize")}),this.$nextTick(()=>{this.$refs.rootEl&&this.resizeObserver.observe(this.$refs.rootEl)})},beforeUnmount(){this.resizeObserver&&this.$refs.rootEl&&(this.resizeObserver.unobserve(this.$refs.rootEl),this.resizeObserver.disconnect())}},sr={class:"bg-white p-4 rounded-lg h-full flex flex-col overflow-hidden",ref:"rootEl"},ir={key:0,class:"flex flex-col flex-1 overflow-hidden"},cr={class:"space-y-0 overflow-y-auto flex-1 [&::-webkit-scrollbar]:h-1.5 [&::-webkit-scrollbar]:w-1.5 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-thumb]:bg-gray-300 [&::-webkit-scrollbar-track]:bg-transparent"},dr=["onClick"],mr={class:"text-base font-medium"},pr={class:"mt-2 flex flex-wrap gap-2"},fr={key:1,class:"px-2 py-1 text-sm bg-gray-100 rounded-full"},ur={key:0,class:"my-5 pr-2"},gr={class:"paginationWrapper relative flex justify-center"},hr={key:1,class:"text-center text-slate-400"};function yr(t,o,n,r,m,s){var p;const i=e.resolveComponent("VsPagination");return e.openBlock(),e.createElementBlock("div",sr,[o[0]||(o[0]=e.createElementVNode("h2",{class:"text-xl font-semibold mb-4"},"Список",-1)),((p=m.items)==null?void 0:p.length)>0?(e.openBlock(),e.createElementBlock("div",ir,[e.createElementVNode("div",cr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.items,f=>(e.openBlock(),e.createElementBlock("div",{key:f.id,class:"py-4 border-b last:border-b-0 hover:bg-gray-50",onClick:c=>t.$emit("cardValuesId",f.id)},[e.createElementVNode("h3",mr,e.toDisplayString(f.name),1),e.createElementVNode("div",pr,[f.status_data?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["px-2 py-1 text-sm rounded-full",{"bg-green-100 text-green-800":f.status_data.color==="green","bg-red-100 text-red-800":f.status_data.color==="red"}])},e.toDisplayString(f.status_data.text),3)):e.createCommentVNode("",!0),f.class_mbd_id_data?(e.openBlock(),e.createElementBlock("span",fr,e.toDisplayString(f.class_mbd_id_data.text),1)):e.createCommentVNode("",!0)])],8,dr))),128))]),m.total>m.limit?(e.openBlock(),e.createElementBlock("div",ur,[e.createElementVNode("div",gr,[e.createVNode(i,{total:m.total,maxPages:4,defaultPage:m.currentPage,pageSize:m.limit,goTo:!1,size:"medium",onPageChange:s.handlePageChange,backgroundColor:"#e5e7eb",borderedCellSelected:!0,pageSizes:[16,32,48,64],onPageSizeChange:s.changeLimit},null,8,["total","defaultPage","pageSize","onPageChange","onPageSizeChange"])])])):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock("div",hr,"Немає даних"))],512)}const br=F(ar,[["render",yr]]),kr={class:"map-skeleton-loader"},xr=F({__name:"vs-skeleton-loader",setup(t){return(o,n)=>(e.openBlock(),e.createElementBlock("div",kr,[...n[0]||(n[0]=[e.createElementVNode("div",{class:"dot-pulse"},null,-1)])]))}},[["__scopeId","data-v-954c1e03"]]),wr={},_r={width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function Vr(t,o){return e.openBlock(),e.createElementBlock("svg",_r,[...o[0]||(o[0]=[e.createElementVNode("title",null,"Globe Icon",-1),e.createElementVNode("desc",null," A circular representation of a globe with horizontal and vertical lines ",-1),e.createElementVNode("path",{d:"M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22Z",stroke:"#1E40AF","stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,-1),e.createElementVNode("path",{d:"M2 12H22",stroke:"#1E40AF","stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,-1),e.createElementVNode("path",{d:"M12 2C14.5013 4.73835 15.9228 8.29203 16 12C15.9228 15.708 14.5013 19.2616 12 22C9.49872 19.2616 8.07725 15.708 8 12C8.07725 8.29203 9.49872 4.73835 12 2Z",stroke:"#1E40AF","stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])])}const Er={components:{homeIcon:F(wr,[["render",Vr]])},name:"vs-homezoom",props:{map:{type:Object},initialView:{type:Object,default:()=>({})}},methods:{homeZoom(){!this.map||!this.initialView||(this.initialView.bbox?this.map.fitBounds(this.initialView.bbox,{duration:0,padding:10}):this.initialView.center&&this.initialView.zoom!==void 0&&(this.map.setCenter(this.initialView.center),this.map.setZoom(this.initialView.zoom)),this.initialView.pitch!==void 0&&this.map.setPitch(this.initialView.pitch),this.initialView.bearing!==void 0&&this.map.setBearing(this.initialView.bearing))}},computed:{}};function Br(t,o,n,r,m,s){const i=e.resolveComponent("homeIcon"),p=e.resolveComponent("VsPopover");return e.openBlock(),e.createElementBlock("div",null,[e.createVNode(p,{trigger:"hover",placement:"left",teleport:"body",class:"flex"},{reference:e.withCtx(()=>[e.createVNode(i,{onClick:s.homeZoom,class:"w-full h-auto p-[9px] [transition:.3s] hover:[transition:.3s] text-[24px] hover:bg-[#DBEAFE] flex font-normal cursor-pointer text-[#1E40AF] bg-[#fff] rounded-[4px] border-[1px] border-solid border-[#E5E7EB]"},null,8,["onClick"])]),default:e.withCtx(()=>[o[0]||(o[0]=e.createElementVNode("div",null,"Повернутися до початкових налаштувань",-1))]),_:1})])}const Nr=F(Er,[["render",Br]]),Cr={},$r={width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function Lr(t,o){return e.openBlock(),e.createElementBlock("svg",$r,[...o[0]||(o[0]=[e.createElementVNode("title",null,"Document with Two Sections Icon",-1),e.createElementVNode("desc",null,"A document icon with a split design indicating two sections",-1),e.createElementVNode("path",{d:"M6 9V2H18V9",stroke:"#1E40AF","stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,-1),e.createElementVNode("path",{d:"M6 18H4C3.46957 18 2.96086 17.7893 2.58579 17.4142C2.21071 17.0391 2 16.5304 2 16V11C2 10.4696 2.21071 9.96086 2.58579 9.58579C2.96086 9.21071 3.46957 9 4 9H20C20.5304 9 21.0391 9.21071 21.4142 9.58579C21.7893 9.96086 22 10.4696 22 11V16C22 16.5304 21.7893 17.0391 21.4142 17.4142C21.0391 17.7893 20.5304 18 20 18H18",stroke:"#1E40AF","stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,-1),e.createElementVNode("path",{d:"M18 14H6V22H18V14Z",stroke:"#1E40AF","stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])])}const Sr={components:{printIcon:F(Cr,[["render",Lr]]),VsPopover:Z.VsPopover},props:{map:{type:Object},activeTool:String,setActiveTool:Function},data(){return{printVisible:!1,scriptElements:[],styleElements:[],resourcesLoaded:!1}},watch:{activeTool(t){t!=="print"?this.printVisible=!1:this.init()},async printVisible(t){!this.resourcesLoaded&&t?(await this.loadResources(),this.init(),this.simulateClick()):this.removeResources()},activeTool(t,o){t!=="print"&&o==="print"&&(this.closePrint&&this.closePrint(),this.printVisible=!1),t==="print"&&!this.printVisible&&(this.printVisible=!0,this.init())}},computed:{modalButtonClasses(){return{"!bg-[#DBEAFE]":this.printVisible,"bg-white":!this.printVisible}}},mounted(){document.addEventListener("click",t=>{const o=document.querySelector(".mapboxgl-export-list");if(o&&o.contains(t.target)){t.stopPropagation();return}!t.target.classList.contains("mapboxgl-export-list")&&!t.target.classList.contains("print-button")&&!t.target.classList.contains("mapboxgl-export-control")&&!t.target.id.includes("mapbox-gl-export")&&(this.printVisible=!1)})},methods:{addScript(t){return new Promise((o,n)=>{const r=document.createElement("script");r.src=t,r.async=!0,r.onload=o,r.onerror=n,document.head.appendChild(r),this.scriptElements.push(r)})},addStyle(t){return new Promise((o,n)=>{const r=document.createElement("link");r.href=t,r.rel="stylesheet",r.type="text/css",r.onload=o,r.onerror=n,document.head.appendChild(r),this.styleElements.push(r)})},async loadResources(){try{await this.addStyle("https://cdn.jsdelivr.net/npm/@watergis/mapbox-gl-export@3.5.4/dist/mapbox-gl-export.min.css"),await this.addScript("https://cdn.jsdelivr.net/npm/@watergis/mapbox-gl-export@3.5.4/dist/mapbox-gl-export.umd.min.js"),this.resourcesLoaded=!0}catch(t){console.error("Failed to load resources:",t)}},removeResources(){this.scriptElements.forEach(t=>{t.parentNode&&t.parentNode.removeChild(t)}),this.scriptElements=[],this.styleElements.forEach(t=>{t.parentNode&&t.parentNode.removeChild(t)}),this.styleElements=[],this.resourcesLoaded=!1},async toggleResources(){this.printVisible=!this.printVisible},init(){if(!window.MapboxExportControl){console.error("MapboxExportControl is not loaded.");return}window.mapboxgl.accessToken="pk.eyJ1Ijoia3Jpemhhbm92c2t5IiwiYSI6ImNsemkxNWtkODA5dDcycnNhMWZzYWM0MTAifQ.6fEpgfd_2mA4UYuflDewpQ";const{MapboxExportControl:t,Size:o,PageOrientation:n,Format:r,DPI:m}=window.MapboxExportControl;this.map.addControl(new t({PageSize:o.A3,PageOrientation:n.Portrait,Format:r.PNG,DPI:m[96],Crosshair:!0,PrintableArea:!0,Local:"uk"}))},simulateClick(){new Promise(o=>{const n=setTimeout(()=>{const r=document.querySelector(".mapboxgl-export-control");r&&(clearInterval(n),o(r))},100)}).then(o=>{o.click()}).catch(()=>{console.error("Print button not found.")})},togglePrint(){!this.activeTool||this.activeTool!=="print"?this.setActiveTool&&this.setActiveTool("print"):this.setActiveTool&&this.setActiveTool(null),this.printVisible=!this.printVisible,this.printVisible?this.init():this.removeResources()}}};function Fr(t,o,n,r,m,s){const i=e.resolveComponent("printIcon"),p=e.resolveComponent("VsPopover");return e.openBlock(),e.createBlock(p,{trigger:"hover",placement:"left",teleport:"body"},{reference:e.withCtx(()=>[e.createVNode(i,{onClick:s.togglePrint,class:e.normalizeClass([s.modalButtonClasses,"print-button w-full h-auto p-[9px] [transition:.3s] hover:[transition:.3s] text-[24px] hover:bg-[#DBEAFE] flex font-normal cursor-pointer text-[#1E40AF] bg-[#fff] rounded-[4px] border-[1px] border-solid border-[#E5E7EB]"])},null,8,["onClick","class"])]),default:e.withCtx(()=>[o[0]||(o[0]=e.createElementVNode("div",null,"Надрукувати",-1))]),_:1})}const jr=F(Sr,[["render",Fr]]),Ir={props:{map:{type:Object,required:!0}},data(){return{is3D:!1}},components:{VsPopover:Z.VsPopover},mounted(){this.map.on("move",this.updateViewStatus),this.updateViewStatus()},beforeUnmount(){this.map.off("move",this.updateViewStatus)},methods:{toggleView(){this.is3D?this.map.easeTo({pitch:0,bearing:0,duration:1e3}):this.map.easeTo({pitch:60,bearing:-29.6,duration:1e3})},updateViewStatus(){this.is3D=this.map.getPitch()!==0}}};function vr(t,o,n,r,m,s){const i=e.resolveComponent("VsPopover");return e.openBlock(),e.createBlock(i,{trigger:"hover",placement:"left",teleport:"body",class:"flex"},{reference:e.withCtx(()=>[e.createElementVNode("div",{class:"font-light w-full h-[44px] p-[9px] [transition:.3s] hover:[transition:.3s] text-[19px] hover:bg-[#DBEAFE] flex cursor-pointer text-[#1E40AF] bg-[#fff] rounded-[4px] border-[1px] border-solid border-[#E5E7EB]",onClick:o[0]||(o[0]=(...p)=>s.toggleView&&s.toggleView(...p))},e.toDisplayString(m.is3D?"2D":"3D"),1)]),default:e.withCtx(()=>[o[1]||(o[1]=e.createElementVNode("div",null,"Перемикач виду",-1))]),_:1})}const Dr=F(Ir,[["render",vr]]),Ar={props:{bgColor:{type:String,default:"#1E40AF"}}},Mr={width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},Tr=["stroke"],zr=["stroke"],Pr=["stroke"],Ur=["stroke"],Or=["stroke"],qr=["stroke"];function Rr(t,o,n,r,m,s){return e.openBlock(),e.createElementBlock("svg",Mr,[o[0]||(o[0]=e.createElementVNode("title",null,"Target Icon",-1)),o[1]||(o[1]=e.createElementVNode("desc",null,"A target icon with a circular pattern inside a rounded square",-1)),e.createElementVNode("path",{d:"M2 12H5",stroke:n.bgColor,"stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,8,Tr),e.createElementVNode("path",{d:"M19 12H22",stroke:n.bgColor,"stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,8,zr),e.createElementVNode("path",{d:"M12 2V5",stroke:n.bgColor,"stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,8,Pr),e.createElementVNode("path",{d:"M12 19V22",stroke:n.bgColor,"stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,8,Ur),e.createElementVNode("path",{d:"M12 19C15.866 19 19 15.866 19 12C19 8.13401 15.866 5 12 5C8.13401 5 5 8.13401 5 12C5 15.866 8.13401 19 12 19Z",stroke:n.bgColor,"stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,8,Or),e.createElementVNode("path",{d:"M12 15C13.6569 15 15 13.6569 15 12C15 10.3431 13.6569 9 12 9C10.3431 9 9 10.3431 9 12C9 13.6569 10.3431 15 12 15Z",stroke:n.bgColor,"stroke-width":"1","stroke-linecap":"round","stroke-linejoin":"round"},null,8,qr)])}const Hr={components:{geoIcon:F(Ar,[["render",Rr]]),VsPopover:Z.VsPopover,closeIcon:ve},data(){return{location:null,data:null,marker:null,showLocation:!1}},computed:{modalButtonClasses(){return{"!bg-[#DBEAFE]":this.showLocation,"bg-white":!this.showLocation}}},props:{map:{type:Object}},beforeUnmount(){var t;(t=this.marker)==null||t.remove()},watch:{activeControl(t,o){t!=="geolocation"&&o==="geolocation"&&(this.showLocation=!1,this.closeGeolocation())}},methods:{togleGeolocation(){this.showLocation=!this.showLocation,this.showLocation?this.getUserLocation():(this.closeGeolocation(),this.activeControl="no")},getUserLocation(){navigator.geolocation?navigator.geolocation.getCurrentPosition(this.onGeolocationSuccess,this.onGeolocationError):(this.showLocation=!1,this.activeControl="no",this.$notify({type:"error",title:"Помилка",message:"Цей браузер не підтримує геолокацію"}),this.$emit("close"))},async onGeolocationSuccess(t){this.location={latitude:t.coords.latitude,longitude:t.coords.longitude};const n=await(await fetch(`https://nominatim.openstreetmap.org/reverse?format=json&lat=${this.location.latitude}&lon=${this.location.longitude}`)).json();this.data=n.address;const r=[this.location.longitude,this.location.latitude],m=[[parseFloat(n.boundingbox[2]),parseFloat(n.boundingbox[0])],[parseFloat(n.boundingbox[3]),parseFloat(n.boundingbox[1])]];this.map.fitBounds(m,{padding:200,maxZoom:16}),this.marker||(this.marker=new Marker({color:"var(--primary)"})),this.marker.setLngLat(r).addTo(this.map),this.activeControl="geolocation"},closeGeolocation(){this.showLocation=!1,this.marker&&(this.marker.remove(),this.marker=null),this.location=null,this.data=null},onGeolocationError(){this.showLocation=!1,this.activeControl="no",this.$notify({type:"error",title:"Помилка",message:"Для визначення геолокації потрібен HTTPS протокол"}),this.$emit("close")}}},Wr={key:0,class:"max-w-[412px] absolute w-full top-[20px] right-[70px] bg-white border rounded-[15px] p-4 z-10"},Zr={class:"flex justify-between items-center border-b pb-[16px]"},Yr={class:"d-flex"},Gr={class:"pt-[16px]"};function Jr(t,o,n,r,m,s){var c,d,a,l,h,u;const i=e.resolveComponent("closeIcon"),p=e.resolveComponent("geoIcon"),f=e.resolveComponent("VsPopover");return e.openBlock(),e.createElementBlock("div",null,[(e.openBlock(),e.createBlock(e.Teleport,{to:"#maplibre-demo-map"},[m.location?(e.openBlock(),e.createElementBlock("div",Wr,[e.createElementVNode("div",Zr,[o[0]||(o[0]=e.createElementVNode("div",{class:"text-lg font-semibold"},"Ваша геолокація",-1)),e.createElementVNode("div",Yr,[e.createVNode(i,{onClick:s.closeGeolocation},null,8,["onClick"])])]),e.createElementVNode("div",Gr,[e.createElementVNode("div",null,[o[1]||(o[1]=e.createElementVNode("strong",null,"Широта:",-1)),e.createTextVNode(" "+e.toDisplayString((c=m.location)==null?void 0:c.latitude),1)]),e.createElementVNode("div",null,[o[2]||(o[2]=e.createElementVNode("strong",null,"Довгота:",-1)),e.createTextVNode(" "+e.toDisplayString((d=m.location)==null?void 0:d.longitude),1)]),e.createElementVNode("div",null,[o[3]||(o[3]=e.createElementVNode("strong",null,"КраЇна:",-1)),e.createTextVNode(" "+e.toDisplayString((a=m.data)==null?void 0:a.country),1)]),e.createElementVNode("div",null,[o[4]||(o[4]=e.createElementVNode("strong",null,"Код країни:",-1)),e.createTextVNode(" "+e.toDisplayString((l=m.data)==null?void 0:l.country_code),1)]),e.createElementVNode("div",null,[o[5]||(o[5]=e.createElementVNode("strong",null,"Місто:",-1)),e.createTextVNode(" "+e.toDisplayString((h=m.data)==null?void 0:h.city),1)]),e.createElementVNode("div",null,[o[6]||(o[6]=e.createElementVNode("strong",null,"Поштовий індекс:",-1)),e.createTextVNode(" "+e.toDisplayString((u=m.data)==null?void 0:u.postcode),1)])])])):e.createCommentVNode("",!0)])),e.createVNode(f,{trigger:"hover",placement:"left",teleport:"body",class:"flex"},{reference:e.withCtx(()=>[e.createVNode(p,{onClick:s.togleGeolocation,class:e.normalizeClass([s.modalButtonClasses,"w-full h-auto p-[9px] [transition:.3s] hover:[transition:.3s] text-[24px] hover:bg-[#DBEAFE] flex font-normal cursor-pointer text-[#1E40AF] bg-[#fff] rounded-[4px] border-[1px] border-solid border-[#E5E7EB]"])},null,8,["onClick","class"])]),default:e.withCtx(()=>[o[7]||(o[7]=e.createElementVNode("div",null,"Дізнатися геолокацію",-1))]),_:1})])}const Kr=F(Hr,[["render",Jr]]),be={__name:"vs-map-widget-column",props:{position:String,widgets:Array,map:Object,mapLoaded:Boolean,cardValues:Object,hasFilters:Boolean,currentFilterLayer:Object,enabledLayerIds:Array,getWidgetComponent:Function,getColumnWidth:Function,rightColumnOffset:[String,Number],maxHeight:Number,history:Boolean},emits:["set-filter-layer","update:enabledLayerIds","cardValuesId","closeCard","content-resize"],setup(t,{expose:o,emit:n}){const r=n,m=t,s=e.ref(m.widgets.map(c=>{var d;return{...c,config:{...c.config,visible:((d=c.config)==null?void 0:d.visible)!==!1}}}));e.watch(()=>m.widgets.map(c=>c.id||c.type).join(","),()=>{s.value=m.widgets.map(c=>{var d;return{...c,config:{...c.config,visible:((d=c.config)==null?void 0:d.visible)!==!1}}})});function i(c){const d=s.value.find(a=>a.id===c);d&&d.config&&(d.config.visible=!d.config.visible,setTimeout(()=>{r("content-resize")},30))}const p=e.ref(null);o({columnRef:p});let f=null;return e.onMounted(()=>{f=new MutationObserver(()=>{var c;clearTimeout((c=p.value)==null?void 0:c._resizeTimeout),p.value._resizeTimeout=setTimeout(()=>{r("content-resize")},30)}),p.value&&f.observe(p.value,{childList:!0,subtree:!0,characterData:!0})}),e.onUnmounted(()=>{f&&f.disconnect()}),(c,d)=>t.mapLoaded?(e.openBlock(),e.createElementBlock("div",{key:0,class:"widget-column",ref_key:"columnRef",ref:p,style:e.normalizeStyle({width:t.getColumnWidth(t.position),paddingRight:t.rightColumnOffset})},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,a=>{var l;return e.openBlock(),e.createElementBlock(e.Fragment,{key:a.id||a.type},[a.type!=="card"?e.withDirectives((e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.getWidgetComponent(a.type)),{key:0,map:t.map,config:a.config,hasFilters:t.hasFilters,currentLayer:t.currentFilterLayer,enabledLayerIds:t.enabledLayerIds,history:t.history,onSetFilterLayer:d[0]||(d[0]=h=>c.$emit("set-filter-layer",h)),"onUpdate:enabledLayerIds":d[1]||(d[1]=h=>c.$emit("update:enabledLayerIds",h)),onCardValuesId:d[2]||(d[2]=h=>c.$emit("cardValuesId",h)),onShowWidget:i,onCatalogLayers:d[3]||(d[3]=h=>c.$emit("catalog-layers",h)),class:"widget"},null,40,["map","config","hasFilters","currentLayer","enabledLayerIds","history"])),[[e.vShow,((l=a.config)==null?void 0:l.visible)!==!1]]):e.createCommentVNode("",!0),t.cardValues&&a.type==="card"?(e.openBlock(),e.createBlock(Ie,{key:1,config:a.config,cardValues:t.cardValues,class:"widget",onClose:d[4]||(d[4]=h=>c.$emit("closeCard"))},null,8,["config","cardValues"])):e.createCommentVNode("",!0)],64)}),128))],4)):e.createCommentVNode("",!0)}},Qr={class:"map-widgets-flex"},Xr={class:"widgets-left"},el={class:"widgets-top"},tl={class:"widgets-bottom"},ol={class:"widgets-right"},nl={class:"widgets-top"},rl={class:"widgets-bottom"},ll={class:"absolute top-[180px] right-2 z-10 flex flex-col gap-[5px]"},Be=F(e.defineComponent({__name:"vs-map",props:{table:{},name:{},height:{}},setup(t){const o=e.getCurrentInstance(),n=t,r=e.ref(null),m=e.ref(!1);let s=null;const i=e.ref(null),p=e.ref(null),f=e.ref([]),c=e.ref([]),d=e.ref(null),a=e.ref(null),l=e.ref(null),h=e.ref([]);let u=null;function y(w){return!l.value||!l.value.widgets?[]:w==="center"?[...l.value.widgets.filter(E=>(E.position||{})==="center")||[],...c.value.filter(E=>E.position==="center")]:l.value.widgets.filter(x=>(x.position||{})===w)||[]}const g=(w,x,E)=>x[w]||w,b=(w,x,E,$,_)=>{const C=g(w,$),I=x?g(x,$):"";let S="";return E!=null&&E.length&&(S=E.map(P=>{const D=g(P.value,$);return`
|
|
2
|
-
<tr class="flex justify-between items-center">
|
|
3
|
-
<td class="font-medium mr-1.5 flex items-center">${P.label}</td>
|
|
4
|
-
<td class="text-right">${D}</td>
|
|
5
|
-
</tr>
|
|
6
|
-
`}).join("")),`
|
|
7
|
-
<div class="absolute min-w-[250px] max-w-[350px] bg-white/90 border border-gray-200 rounded-lg shadow-md text-gray-800 pointer-events-none">
|
|
8
|
-
${C?`
|
|
9
|
-
<div class="font-semibold text-sm border-b border-solid border-gray-200 text-gray-800 rounded-t-lg px-2 py-1">
|
|
10
|
-
<h3>${C}</h3>
|
|
11
|
-
</div>
|
|
12
|
-
`:""}
|
|
13
|
-
${x?`<div class="text-sm px-2 py-1 break-words">${I}</div>`:""}
|
|
14
|
-
${E!=null&&E.length&&!x?`
|
|
15
|
-
<div class="text-xs px-2 py-0.5 text-gray-500">
|
|
16
|
-
<table class="w-full">
|
|
17
|
-
<tbody>${S}</tbody>
|
|
18
|
-
</table>
|
|
19
|
-
</div>
|
|
20
|
-
`:""}
|
|
21
|
-
</div>
|
|
22
|
-
`},k=w=>({legend:Je,basemaps:et,layers:Ft,info:Tt,attribute:ko,catalog:Gn,filters:er,"inline-filters":lr,list:br,card:Ie})[w],B=e.computed(()=>!!l.value&&Array.isArray(l.value.widgets)&&l.value.widgets.some(w=>w.type==="filters")),j=w=>{i.value=w};function N(){const w=new URLSearchParams(window.location.search),x=parseFloat(w.get("x")),E=parseFloat(w.get("y")),$=parseFloat(w.get("z")),_=parseFloat(w.get("bearing")),C=parseFloat(w.get("pitch"));return{center:isFinite(x)&&isFinite(E)?[x,E]:null,zoom:isFinite($)?$:null,bearing:isFinite(_)?_:null,pitch:isFinite(C)?C:null}}function V({center:w,zoom:x,bearing:E,pitch:$}){const _=new URLSearchParams(window.location.search);_.set("x",w[0].toFixed(5)),_.set("y",w[1].toFixed(5)),_.set("z",x.toFixed(2)),_.set("bearing",E.toFixed(2)),_.set("pitch",$.toFixed(2));const C=`${window.location.pathname}?${_.toString()}`;window.history.replaceState({},"",C)}const z=()=>{var I,S,P;if(!l.value||!l.value.map)return;const w={version:8,glyphs:"https://cdn.softpro.ua/data/fonts/{fontstack}/{range}.pbf",sources:{},layers:[]},x=(o==null?void 0:o.appContext.config.globalProperties.$settings)||{};let E=l.value.map.center||x.center||[50,30],$=l.value.map.zoom||x.zoom||10,_=l.value.map.bearing||0,C=l.value.map.pitch||0;if(l.value.history){const D=N();D.center&&(E=D.center),D.zoom!==null&&($=D.zoom),D.bearing!==null&&(_=D.bearing),D.pitch!==null&&(C=D.pitch)}r.value=new maplibregl.Map({container:"maplibre-demo-map",style:w,center:E,zoom:$,bearing:_,pitch:C,maxZoom:19,minZoom:5}),console.log({center:E,zoom:$}),(P=(S=(I=l==null?void 0:l.value)==null?void 0:I.interactions)==null?void 0:S.navigation)!=null&&P.enabled&&!u&&(u=new maplibregl.NavigationControl,r.value.addControl(u,"top-right")),r.value.on("load",async()=>{var ne,R,me,M;if(m.value=!0,await(async()=>{var T,L,G,Y,H;const U=((H=(Y=(G=(L=(T=l.value)==null?void 0:T.widgets)==null?void 0:L.find(v=>v.type==="layers"))==null?void 0:G.config)==null?void 0:Y.layers)==null?void 0:H.filter(v=>{var X;return((X=v.style)==null?void 0:X.attrType)==="icon-by-attribute"}))||[];for(const v of U){const{rules:X,default_icon:re,icon_base_url:le}=v.style,ae=[...X.map(J=>J.icon),re].filter(Boolean);for(const J of ae)try{const ee=`${le}${J}`,se=await r.value.loadImage(ee);r.value.hasImage(J)||r.value.addImage(J,se.data)}catch(ee){console.error(`Failed to load icon: ${J}`,ee)}}})(),(me=(R=(ne=l.value)==null?void 0:ne.interactions)==null?void 0:R.hover)!=null&&me.enabled&&(r.value.on("mousemove",U=>{var X,re,le,ae,J,ee,se,he,q,Ee;const T=r.value.queryRenderedFeatures(U.point);if(r.value&&r.value.getCanvas&&(r.value.getCanvas().style.cursor=T.length?"pointer":""),!T.length){if(p.value){const A=(X=r.value.getSource(p.value.source))==null?void 0:X.type;p.value.source,p.value.id,A==="vector"&&p.value.source,oe(r.value,p.value.source,p.value.id,{hovered:!1}),p.value=null}s&&(s.remove(),s=null);return}const L=T[0];if(!p.value||p.value.id!==L.id||p.value.source!==L.layer.source){if(p.value){const Ce=(re=r.value.getSource(p.value.source))==null?void 0:re.type;p.value.source,p.value.id,Ce==="vector"&&p.value.source,oe(r.value,p.value.source,p.value.id,{hovered:!1})}const A=(le=r.value.getSource(L.layer.source))==null?void 0:le.type;L.layer.source,L.id,A==="vector"&&L.layer.source,oe(r.value,L.layer.source,L.id,{hovered:!0}),p.value={source:L.layer.source,id:L.id}}const G=(J=(ae=l.value)==null?void 0:ae.widgets)==null?void 0:J.find(A=>A.type==="layers"),Y=(se=(ee=l.value)==null?void 0:ee.widgets)==null?void 0:se.find(A=>A.type==="attribute");let H=null;if(G&&(H=G.config.layers.find(A=>A.id===L.layer.source)),(q=(he=l.value)==null?void 0:he.widgets)==null?void 0:q.find(A=>A.type==="catalog")){if(!T.length){s&&(s.style.display="none");return}const A=T[0];s=md(A,U,s);return}if(!H&&Y&&Y.config.layer.id===L.layer.source&&(H=Y.config.layer),(Ee=H==null?void 0:H.style)!=null&&Ee.popup){const A=H.style.popup;let Ce=A.title,$e="";A.mode==="markdown"?$e=Array.isArray(A.content)?A.content.join(`
|
|
23
|
-
|
|
24
|
-
`):"":$e=Array.isArray(A.content)?A.content.join(""):"",s||(s=document.createElement("div"),r.value.getContainer().appendChild(s)),s.innerHTML=b(Ce,$e,A.fields,L.properties,A.mode),qe(s,U)}}),r.value.on("mouseleave",()=>{var U;if(s&&(s.remove(),s=null),p.value){const T=(U=r.value.getSource(p.value.source))==null?void 0:U.type;p.value.source,p.value.id,T==="vector"&&p.value.source,oe(r.value,p.value.source,p.value.id,{hovered:!1}),p.value=null}r.value&&r.value.getCanvas&&(r.value.getCanvas().style.cursor="")})),r.value.on("click",async U=>{var re,le,ae,J,ee,se,he;if(O(),["length","area","print"].includes(a.value))return;const T=r.value.queryRenderedFeatures(U.point);if(!T.length)return;const L=T[0],G=(le=(re=l.value)==null?void 0:re.widgets)==null?void 0:le.find(q=>q.type==="layers"),Y=(J=(ae=l.value)==null?void 0:ae.widgets)==null?void 0:J.find(q=>q.type==="attribute"),H=(se=(ee=l.value)==null?void 0:ee.widgets)==null?void 0:se.find(q=>q.type==="catalog");let v;if(H?v=L.layer.source:v=(Y==null?void 0:Y.config.layer)||(G==null?void 0:G.config.layers.find(q=>q.id===L.layer.source)),v!=null&&v.noCard)return;f.value.forEach(q=>{var A;const Ee=(A=r.value.getSource(q.source))==null?void 0:A.type;q.source,q.id,Ee==="vector"&&q.source,oe(r.value,q.source,q.id,{selected:!1})}),f.value=[];const X=(he=r.value.getSource(L.layer.source))==null?void 0:he.type;L.layer.source,L.id,X==="vector"&&L.layer.source,oe(r.value,L.layer.source,L.id,{selected:!0}),f.value.push({source:L.layer.source,id:L.id}),d.value={layer:(v==null?void 0:v.service_key)||v||"",map:(v==null?void 0:v.map_key)||"",id:L.properties.id,title:(v==null?void 0:v.title)||""}}),r.value.on("dblclick",U=>{var G,Y,H;if(O(),["length","area","print"].includes(a.value))return;sd([U.lngLat.lng,U.lngLat.lat]);const T=(Y=(G=l.value)==null?void 0:G.widgets)==null?void 0:Y.find(v=>v.type==="layers");let L=null;(H=T==null?void 0:T.config)!=null&&H.layers&&(L=T.config.layers.find(v=>v.visible!==!1&&["tms","wms","raster"].includes((v.service_type||v.service||"").toLowerCase()))),!(L!=null&&L.noCard)&&(d.value={layer:(L==null?void 0:L.map_key)||"",map:(L==null?void 0:L.service_key)||"",id:"",title:(L==null?void 0:L.title)||""})}),r.value.resize(),(M=l==null?void 0:l.value)!=null&&M.history){const U=()=>{const T=r.value.getCenter();V({center:[T.lng,T.lat],zoom:r.value.getZoom(),bearing:r.value.getBearing(),pitch:r.value.getPitch()})};r.value.on("moveend",U),r.value.on("rotate",U),r.value.on("pitch",U)}})},O=()=>{Ue(),f.value.forEach(w=>{r.value&&oe(r.value,w.source,w.id,{selected:!1})}),f.value=[],d.value=null};e.onMounted(async()=>{await nd(),await e.nextTick(),z();const w=document.getElementById("maplibre-demo-map");w&&w.addEventListener("mouseleave",()=>{s&&(s.remove(),s=null)})});const Ne=e.computed(()=>({height:(n==null?void 0:n.height)||"100vh",width:"100%"})),nd=async()=>{const w=await fetch(`/api/map/${n.name||n.table||"main"}`).then(x=>x.json());l.value=w},_e=w=>{if(!l.value||!l.value.widgets)return"400px";const x=l.value.widgets.find(E=>E.position===w);return(x==null?void 0:x.width)||"400px"},K=e.ref([]);e.watch(()=>l.value,w=>{w&&w.map&&(K.value=rd(),z())});const rd=()=>{var x;if(!l.value||!l.value.widgets)return[];const w=l.value.widgets.find(E=>E.type==="layers");return(x=w==null?void 0:w.config)!=null&&x.layers?w.config.layers.map(E=>({...E,visible:E.visible??!1})).filter(E=>E.visible).map(E=>E.id):[]};function oe(w,x,E,$){w.getStyle().layers.filter(C=>C.source===x).forEach(C=>{var S;const I={source:x,id:E};((S=w.getSource(x))==null?void 0:S.type)==="vector"&&C["source-layer"]&&(I.sourceLayer=C["source-layer"]),w.setFeatureState(I,$)})}const ld=e.computed(()=>!!l.value&&!!l.value.interactions&&!!l.value.interactions.navigation&&l.value.interactions.navigation.enabled),ad=e.computed(()=>!!l.value&&Array.isArray(l.value.tools)&&l.value.tools.length>0),Ve=e.computed(()=>ld.value||ad.value?"40px":"20px");function Ue(){r.value&&(r.value.getLayer("layer-with-pulsing-dot")&&r.value.removeLayer("layer-with-pulsing-dot"),r.value.getSource("dot-point")&&r.value.removeSource("dot-point"),r.value.hasImage&&r.value.hasImage("pulsing-dot")&&r.value.removeImage("pulsing-dot"))}function sd(w){var $,_,C,I;Ue();const x=80,E={width:x,height:x,data:new Uint8Array(x*x*4),onAdd(){const S=document.createElement("canvas");S.width=this.width,S.height=this.height,this.context=S.getContext("2d",{willReadFrequently:!0})},render(){var M;const P=performance.now()%2e3/2e3,D=x/2*.3,ne=x/2*.7*P+D,{context:R}=this;R.clearRect(0,0,this.width,this.height),R.beginPath(),R.arc(this.width/2,this.height/2,ne,0,Math.PI*2),R.fillStyle=`rgba(255, 100, 100, ${1-P})`,R.fill();const me=x/2*.7*(P-.5<0?P-.5+1:P-.5)+D;return R.beginPath(),R.arc(this.width/2,this.height/2,me,0,Math.PI*2),R.fillStyle=`rgba(255, 100, 100, ${1-(P-.5<0?P-.5+1:P-.5)})`,R.fill(),this.data=R.getImageData(0,0,this.width,this.height).data,(M=r.value)==null||M.triggerRepaint(),!0}};($=r.value)!=null&&$.hasImage("pulsing-dot")||(_=r.value)==null||_.addImage("pulsing-dot",E,{pixelRatio:2}),(C=r.value)==null||C.addSource("dot-point",{type:"geojson",data:{type:"Feature",geometry:{type:"Point",coordinates:w}}}),(I=r.value)==null||I.addLayer({id:"layer-with-pulsing-dot",type:"symbol",source:"dot-point",layout:{"icon-image":"pulsing-dot"},paint:{"icon-opacity":.6}})}const id=e.computed(()=>{var w,x,E,$,_,C,I,S,P,D;return{center:(x=(w=l==null?void 0:l.value)==null?void 0:w.map)==null?void 0:x.center,zoom:($=(E=l==null?void 0:l.value)==null?void 0:E.map)==null?void 0:$.zoom,pitch:((C=(_=l==null?void 0:l.value)==null?void 0:_.map)==null?void 0:C.pitch)||0,bearing:((S=(I=l==null?void 0:l.value)==null?void 0:I.map)==null?void 0:S.bearing)||0,bbox:((D=(P=l==null?void 0:l.value)==null?void 0:P.map)==null?void 0:D.bbox)||null}}),Oe={home:Nr,print:jr,geolocation:Kr,pitch:Dr},cd=w=>{a.value=w};function de(w){if(!l.value||!l.value.widgets)return;const x=l.value.widgets.find(_=>_.type==="list");if(!x||!x.config)return;const{map_key:E,service_key:$}=x.config;E&&$&&(d.value={id:w,map:E,layer:$})}const dd=e.computed(()=>l.value&&l.value.widgets?l.value.widgets.filter(w=>w.position==="absolute"):[]);function md(w,x,E){const $=w.properties,_=h.value.find(M=>String(M.id)===String(w.source)),C=Array.isArray(_==null?void 0:_.popup)?_.popup:[],S=C.filter(M=>M.meta==="image").map(M=>$==null?void 0:$[M.name]).filter(Boolean),P=S.length>0?`
|
|
25
|
-
<div class="popup-image-single overflow-hidden rounded-t-xl" style="width:260px;height:160px;margin:0 auto 0 auto;">
|
|
26
|
-
<img src="${S[0]}" style="width:100%;height:100%;object-fit:cover;border-radius:12px 12px 0 0;display:block;" />
|
|
27
|
-
</div>
|
|
28
|
-
`:"",D=C.find(M=>M.meta==="title"),ne=D?$==null?void 0:$[D.name]:"";let R=C.filter(M=>M.meta!=="title"&&M.meta!=="image").map(M=>{const U=$==null?void 0:$[M.name];let T=U??"-";switch(M.meta){case"badge":T=U?`<span class="inline-block rounded px-2 py-0.5 text-xs bg-yellow-100 text-yellow-800 ">${U}</span>`:"-";break}return`
|
|
29
|
-
<tr style="display: table-row;">
|
|
30
|
-
<td style="display: table-cell; padding: 2px 8px 2px 0; vertical-align: middle; font-weight: 500; width: 50%; text-align: left;">${M.ua||M.name}</td>
|
|
31
|
-
<td style="display: table-cell; padding: 2px 0 2px 8px; vertical-align: middle; width: 50%; text-align: right;">${T}</td>
|
|
32
|
-
</tr>
|
|
33
|
-
`}).join("");C.length||(R=Object.keys($).map(M=>`
|
|
34
|
-
<tr style="display: table-row;">
|
|
35
|
-
<td style="display: table-cell; padding: 2px 8px 2px 0; vertical-align: middle; font-weight: 500; width: 50%; text-align: left;">${M}</td>
|
|
36
|
-
<td style="display: table-cell; padding: 2px 0 2px 8px; vertical-align: middle; width: 50%; text-align: right;">${$[M]||"-"}</td>
|
|
37
|
-
</tr>
|
|
38
|
-
`).join(""));const me=`
|
|
39
|
-
<div class="absolute min-w-[250px] max-w-[300px] bg-white/90 border border-gray-200 rounded-lg shadow-md text-gray-800 pointer-events-none" style="display: flex; flex-direction: column; justify-content: center;">
|
|
40
|
-
${P}
|
|
41
|
-
${ne?`<div class="font-semibold text-sm border-b border-solid border-gray-200 text-gray-800 px-2 py-1">${ne}</div>`:""}
|
|
42
|
-
<div class="text-xs px-2 py-0.5 text-gray-500" style="display: flex; justify-content: center; align-items: center; flex: 1;">
|
|
43
|
-
<table class="w-full" style="border-collapse: collapse; border: none; margin: 0 auto;">
|
|
44
|
-
<tbody>${R}</tbody>
|
|
45
|
-
</table>
|
|
46
|
-
</div>
|
|
47
|
-
</div>
|
|
48
|
-
`;return E||(E=document.createElement("div"),E.className="custom-popup absolute z-50",document.body.appendChild(E)),E.innerHTML=me,qe(E,x),E}function qe(w,x){const E=w.offsetWidth,$=w.offsetHeight,_=document.getElementById("maplibre-demo-map"),C=_.getBoundingClientRect(),I=x.originalEvent.clientX-C.left,S=x.originalEvent.clientY-C.top;let P=I-E/2;P=Math.max(10,Math.min(P,C.width-E-10));let D;S-$-10>0?D=S-$-5:S+$+10<C.height?D=S+10:D=Math.max(10,C.height-$-10),w.style.position="absolute",w.style.left=`${P+20}px`,w.style.top=`${D+10}px`,w.parentNode!==_&&_.appendChild(w)}return(w,x)=>{var E,$;return e.openBlock(),e.createElementBlock("div",{class:"maplibre-demo-map-container",style:e.normalizeStyle(Ne.value)},[x[10]||(x[10]=e.createElementVNode("div",{id:"maplibre-demo-map"},null,-1)),m.value?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createElementVNode("div",Qr,[e.createElementVNode("div",Xr,[e.createElementVNode("div",el,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["top-left"],_=>{var C,I;return e.createVNode(be,{key:_,position:_,widgets:y(_),map:r.value,mapLoaded:m.value,cardValues:d.value,hasFilters:B.value,history:(I=(C=l.value)==null?void 0:C.value)==null?void 0:I.history,currentFilterLayer:i.value,enabledLayerIds:K.value,getWidgetComponent:k,getColumnWidth:_e,rightColumnOffset:_==="top-right"?Ve.value:void 0,onSetFilterLayer:j,"onUpdate:enabledLayerIds":x[0]||(x[0]=S=>K.value=S),onCardValuesId:de,onCloseCard:O,onCatalogLayers:x[1]||(x[1]=S=>h.value=S)},null,8,["position","widgets","map","mapLoaded","cardValues","hasFilters","history","currentFilterLayer","enabledLayerIds","rightColumnOffset"])}),64))]),e.createElementVNode("div",tl,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["bottom-left"],_=>{var C,I;return e.createVNode(be,{key:_,position:_,widgets:y(_),map:r.value,mapLoaded:m.value,cardValues:d.value,hasFilters:B.value,history:(I=(C=l.value)==null?void 0:C.value)==null?void 0:I.history,currentFilterLayer:i.value,enabledLayerIds:K.value,getWidgetComponent:k,getColumnWidth:_e,rightColumnOffset:_==="top-right"?Ve.value:void 0,onSetFilterLayer:j,"onUpdate:enabledLayerIds":x[2]||(x[2]=S=>K.value=S),onCardValuesId:de,onCloseCard:O,onCatalogLayers:x[3]||(x[3]=S=>h.value=S)},null,8,["position","widgets","map","mapLoaded","cardValues","hasFilters","history","currentFilterLayer","enabledLayerIds","rightColumnOffset"])}),64))])]),e.createElementVNode("div",ol,[e.createElementVNode("div",nl,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["top-right"],_=>{var C,I;return e.createVNode(be,{key:_,position:_,widgets:y(_),map:r.value,mapLoaded:m.value,cardValues:d.value,hasFilters:B.value,history:(I=(C=l.value)==null?void 0:C.value)==null?void 0:I.history,currentFilterLayer:i.value,enabledLayerIds:K.value,getWidgetComponent:k,getColumnWidth:_e,rightColumnOffset:_==="top-right"?Ve.value:void 0,onSetFilterLayer:j,"onUpdate:enabledLayerIds":x[4]||(x[4]=S=>K.value=S),onCardValuesId:de,onCloseCard:O,onCatalogLayers:x[5]||(x[5]=S=>h.value=S)},null,8,["position","widgets","map","mapLoaded","cardValues","hasFilters","history","currentFilterLayer","enabledLayerIds","rightColumnOffset"])}),64))]),e.createElementVNode("div",rl,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["bottom-right"],_=>{var C,I;return e.createVNode(be,{key:_,position:_,widgets:y(_),map:r.value,mapLoaded:m.value,cardValues:d.value,hasFilters:B.value,history:(I=(C=l.value)==null?void 0:C.value)==null?void 0:I.history,currentFilterLayer:i.value,enabledLayerIds:K.value,getWidgetComponent:k,getColumnWidth:_e,rightColumnOffset:_==="top-right"?Ve.value:void 0,onSetFilterLayer:j,"onUpdate:enabledLayerIds":x[6]||(x[6]=S=>K.value=S),onCardValuesId:de,onCloseCard:O,onCatalogLayers:x[7]||(x[7]=S=>h.value=S)},null,8,["position","widgets","map","mapLoaded","cardValues","hasFilters","history","currentFilterLayer","enabledLayerIds","rightColumnOffset"])}),64))])])]),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(dd.value,(_,C)=>(e.openBlock(),e.createElementBlock("div",{key:"abs-"+(_.id||_.type||C),class:"absolute z-20",style:e.normalizeStyle(_.style)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(k(_.type)),{map:r.value,config:_.config,hasFilters:B.value,currentFilterLayer:i.value,enabledLayerIds:K.value,cardValues:d.value,onSetFilterLayer:j,"onUpdate:enabledLayerIds":x[8]||(x[8]=I=>K.value=I),onCardValuesId:de,onCloseCard:O,onCatalogLayers:x[9]||(x[9]=I=>h.value=I)},null,40,["map","config","hasFilters","currentFilterLayer","enabledLayerIds","cardValues"]))],4))),128)),e.createElementVNode("div",ll,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(($=(E=l.value)==null?void 0:E.value)==null?void 0:$.tools,_=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:_},[m.value&&Oe[_]?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(Oe[_]),e.mergeProps({key:0,map:r.value,activeTool:a.value,setActiveTool:cd},{ref_for:!0},_==="home"?{initialView:id.value}:{},{onCardValuesId:de}),null,16,["map","activeTool"])):e.createCommentVNode("",!0)],64))),128))])],64)):(e.openBlock(),e.createBlock(xr,{key:0}))],4)}}}),[["__scopeId","data-v-22436345"]]);/**
|
|
1
|
+
(function(Y,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("vue-router"),require("@opengis/core")):typeof define=="function"&&define.amd?define(["exports","vue","vue-router","@opengis/core"],e):(Y=typeof globalThis<"u"?globalThis:Y||self,e(Y.MapCustom={},Y.Vue,Y.vueRouter,Y.openGIScore))})(this,(function(Y,e,pe,K){"use strict";/**
|
|
49
2
|
* @license lucide-vue-next v0.514.0 - ISC
|
|
50
3
|
*
|
|
51
4
|
* This source code is licensed under the ISC license.
|
|
52
5
|
* See the LICENSE file in the root directory of this source tree.
|
|
53
|
-
*/const
|
|
6
|
+
*/const Pe=t=>t.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase(),qt=t=>t.replace(/^([A-Z])|[\s-_]+(\w)/g,(n,r,l)=>l?l.toUpperCase():r.toLowerCase()),Ht=t=>{const n=qt(t);return n.charAt(0).toUpperCase()+n.slice(1)},Yt=(...t)=>t.filter((n,r,l)=>!!n&&n.trim()!==""&&l.indexOf(n)===r).join(" ").trim();/**
|
|
54
7
|
* @license lucide-vue-next v0.514.0 - ISC
|
|
55
8
|
*
|
|
56
9
|
* This source code is licensed under the ISC license.
|
|
@@ -60,21 +13,52 @@
|
|
|
60
13
|
*
|
|
61
14
|
* This source code is licensed under the ISC license.
|
|
62
15
|
* See the LICENSE file in the root directory of this source tree.
|
|
63
|
-
*/const
|
|
16
|
+
*/const Kt=({size:t,strokeWidth:n=2,absoluteStrokeWidth:r,color:l,iconNode:o,name:i,class:a,...s},{slots:d})=>e.h("svg",{...ke,width:t||ke.width,height:t||ke.height,stroke:l||ke.stroke,"stroke-width":r?Number(n)*24/Number(t):n,class:Yt("lucide",...i?[`lucide-${Pe(Ht(i))}-icon`,`lucide-${Pe(i)}`]:["lucide-icon"]),...s},[...o.map(c=>e.h(...c)),...d.default?[d.default()]:[]]);/**
|
|
64
17
|
* @license lucide-vue-next v0.514.0 - ISC
|
|
65
18
|
*
|
|
66
19
|
* This source code is licensed under the ISC license.
|
|
67
20
|
* See the LICENSE file in the root directory of this source tree.
|
|
68
|
-
*/const
|
|
21
|
+
*/const ze=(t,n)=>(r,{slots:l})=>e.h(Kt,{...r,iconNode:n,name:t},l);/**
|
|
69
22
|
* @license lucide-vue-next v0.514.0 - ISC
|
|
70
23
|
*
|
|
71
24
|
* This source code is licensed under the ISC license.
|
|
72
25
|
* See the LICENSE file in the root directory of this source tree.
|
|
73
|
-
*/const
|
|
26
|
+
*/const Wt=ze("square-pen",[["path",{d:"M12 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7",key:"1m0v6g"}],["path",{d:"M18.375 2.625a1 1 0 0 1 3 3l-9.013 9.014a2 2 0 0 1-.853.505l-2.873.84a.5.5 0 0 1-.62-.62l.84-2.873a2 2 0 0 1 .506-.852z",key:"ohrbg2"}]]);/**
|
|
74
27
|
* @license lucide-vue-next v0.514.0 - ISC
|
|
75
28
|
*
|
|
76
29
|
* This source code is licensed under the ISC license.
|
|
77
30
|
* See the LICENSE file in the root directory of this source tree.
|
|
78
|
-
*/const
|
|
79
|
-
`)});return}
|
|
80
|
-
`)});return}if(c.value===null)d.value=[...d.value,{...f.value}];else{const y=[...d.value];y[c.value]={...f.value},d.value=y}l()}return(u,y)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[u.addButton?(e.openBlock(),e.createElementBlock("div",bl,[e.createElementVNode("div",kl,[e.createElementVNode("button",{onClick:y[0]||(y[0]=g=>p.value=!0),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...y[5]||(y[5]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4 mr-2",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Додати поле ",-1)])])])])):e.createCommentVNode("",!0),e.createElementVNode("div",xl,[e.createElementVNode("div",wl,[e.createElementVNode("table",_l,[e.createElementVNode("colgroup",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,g=>(e.openBlock(),e.createElementBlock("col",{key:g.key,style:e.normalizeStyle(g.type==="main"?`width: ${u.mainColWidth}`:g.width?`width: ${g.width}`:"auto")},null,4))),128)),y[6]||(y[6]=e.createElementVNode("col",null,null,-1))]),e.createElementVNode("thead",null,[e.createElementVNode("tr",Vl,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,g=>(e.openBlock(),e.createElementBlock("th",{key:g.key,class:"px-6 py-4"},e.toDisplayString(g.label),1))),128)),y[7]||(y[7]=e.createElementVNode("th",{class:"px-6 py-4"},"Дії",-1))])]),d.value.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(d.value,(g,b)=>(e.openBlock(),e.createElementBlock("tr",El,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,k=>(e.openBlock(),e.createElementBlock("td",{key:k.key,class:"px-6 py-4 align-middle text-center"},[k.type==="main"?(e.openBlock(),e.createElementBlock("div",Bl,[y[8]||(y[8]=e.createElementVNode("span",{class:"drag-handle cursor-move mr-2 text-gray-400"},"☰",-1)),e.unref(fe)(g.format==="yes/no"?"check":g.format||g.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["flex items-center justify-center p-1 rounded",`bg-${e.unref(pe)(g.format==="yes/no"?"check":g.format||g.type)}-100`])},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(g.format==="yes/no"?"icon-check":`icon-${g.format||g.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",Nl,[e.withDirectives((e.openBlock(),e.createElementBlock("p",Cl,[e.createTextVNode(e.toDisplayString(g.name||g.id),1)])),[[e.unref(gl)]]),e.createElementVNode("p",$l,e.toDisplayString(g.ua||g.label),1)])])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[k.type==="color"?(e.openBlock(),e.createElementBlock("div",Ll,[e.createElementVNode("div",{class:e.normalizeClass(["w-4 h-4 rounded-full align-middle",`bg-[${g[k.key]}]`])},null,2)])):["format","type","meta"].includes(k.key)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[g[k.key]?(e.openBlock(),e.createElementBlock("span",Sl,e.toDisplayString(g[k.key]),1)):(e.openBlock(),e.createElementBlock("span",Fl,"Не вказано"))],64)):(e.openBlock(),e.createElementBlock("span",jl,e.toDisplayString(g[k.key]),1))],64))]))),128)),e.createElementVNode("td",Il,[e.createVNode(ul,{columns:d.value,"onUpdate:columns":y[1]||(y[1]=k=>d.value=k),data:g,index:b,scheme:u.formScheme},null,8,["columns","data","index","scheme"])])]))),256)):(e.openBlock(),e.createElementBlock("tr",vl,[e.createElementVNode("td",{colspan:a.value.length+1,class:"text-gray-500 text-center py-4"}," Поля не знайдені ",8,Dl)]))])])]),e.createVNode(e.unref(n),{title:"Створити поле",size:"lg",visible:p.value,"onUpdate:visible":y[4]||(y[4]=g=>p.value=g)},{footer:e.withCtx(()=>[e.createElementVNode("div",{class:"flex justify-end p-[20px] gap-[10px] border-t w-full"},[e.createElementVNode("button",{type:"button",onClick:l,class:"px-4 py-2 rounded bg-gray-100 text-gray-700"}," Скасувати "),e.createElementVNode("button",{type:"button",onClick:h,class:"px-4 py-2 rounded bg-blue-600 text-white"}," Зберегти1 ")])]),default:e.withCtx(()=>[e.createVNode(e.unref(r),{ref_key:"form",ref:i,modelValue:f.value,"onUpdate:modelValue":y[2]||(y[2]=g=>f.value=g),schema:u.formScheme,form:i.value,"onUpdate:form":y[3]||(y[3]=g=>i.value=g)},null,8,["modelValue","schema","form"])]),_:1},8,["visible"])],64))}}),[["__scopeId","data-v-51284468"]]),Al={class:"vs-form"},Ml={class:"vs-form__body auto-rows-max container"},Tl={class:"flex flex-wrap"},zl={class:"h-fit w-full mb-6 px-2"},Pl={class:"h-fit w-full flex flex-wrap"},Ul={class:"flex justify-end mb-3 gap-2 w-full"},Ol={class:"w-full"},ql={class:"p-4 text-[13px]"},Rl={class:"grid grid-cols-2 gap-x-6 gap-y-2"},Hl=["id","value"],Wl={class:"ml-2 flex-1 min-w-0 flex items-center gap-2"},Zl={class:"font-medium text-gray-900 truncate"},Yl={class:"text-xs text-gray-500"},Gl={class:"flex justify-end gap-2 p-4 border-t w-full"},Jl=e.defineComponent({__name:"list-tab",props:{data:{default:{}},dataModifiers:{}},emits:["update:data"],setup(t){const o=e.useModel(t,"data"),n=e.computed(()=>Array.isArray(o.value.fields)?o.value.fields:[]),r=e.defineAsyncComponent(()=>import("@opengis/form")),m=e.defineAsyncComponent(()=>import("@opengis/core").then(y=>y.VsModal)),s=e.ref(),i=e.ref(!1),p=e.ref([]),f=e.computed(()=>{var y,g;return((y=o.value)==null?void 0:y.token)||((g=o.value)==null?void 0:g.id)||"register-form"}),c=e.computed({get:()=>(o.value||(o.value={}),Array.isArray(o.value.columns)||(o.value.columns=[]),o.value.columns),set:y=>{o.value||(o.value={}),o.value.columns=Array.isArray(y)?y:[]}}),d=e.computed({get:()=>o.value||{},set:y=>{var b;const g=Array.isArray((b=o.value)==null?void 0:b.columns)?o.value.columns:[];o.value={...o.value,...y,columns:g}}});e.watch(i,y=>{if(y){const g=c.value.map(b=>b.name||b.id);p.value=[...g]}});const a=()=>{const y=new Set(p.value);c.value;const g=n.value.filter(b=>y.has(b.name));c.value=g,i.value=!1,p.value=[]},l={table_name:{type:"text",label:"Table",required:!0,placeholder:"Table",validators:["required"],col:6},name:{type:"text",label:"Name",required:!0,placeholder:"Name",validators:["required"],col:6},description:{type:"text",label:"Description",placeholder:"Description",col:12}},h=[{key:"name",label:"Name",type:"text"},{key:"ua",label:"UA",type:"text"},{key:"format",label:"Format",type:"text"},{key:"meta",label:"Мета",type:"text"},{key:"data",label:"Класифікатор",type:"text"}],u={name:{type:"text",label:"Name",required:!0},ua:{type:"text",label:"UA",required:!0},format:{type:"combobox",label:"Format",mode:"combo",required:!0,options:[{text:"Text",id:"text"},{text:"Number",id:"number"},{text:"Date",id:"date"},{text:"File",id:"file"},{text:"Select",id:"select"}]},meta:{type:"combobox",label:"Мета",mode:"combo",required:!0,options:[{text:"Title",id:"title"},{text:"Features",id:"features"},{text:"Status",id:"status"},{text:"Tags",id:"tags"},{text:"Category",id:"category"},{text:"Image",id:"image"}]},data:{type:"text",label:"Класифікатор"}};return(y,g)=>(e.openBlock(),e.createElementBlock("div",Al,[e.createElementVNode("div",Ml,[e.createElementVNode("div",Tl,[e.createElementVNode("div",zl,[(e.openBlock(),e.createBlock(e.unref(r),{ref_key:"formEl",ref:s,key:f.value,schema:l,modelValue:d.value,"onUpdate:modelValue":g[0]||(g[0]=b=>d.value=b)},null,8,["modelValue"]))]),e.createElementVNode("div",Pl,[e.createElementVNode("div",Ul,[e.createElementVNode("button",{onClick:g[1]||(g[1]=b=>i.value=!0),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...g[6]||(g[6]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])])]),e.createElementVNode("div",Ol,[e.createVNode(xe,{modelValue:c.value,"onUpdate:modelValue":g[2]||(g[2]=b=>c.value=b),"columns-scheme":h,"form-scheme":u,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])])])])]),e.createVNode(e.unref(m),{visible:i.value,"onUpdate:visible":g[5]||(g[5]=b=>i.value=b),title:"Імпорт колонок",size:"lg"},{footer:e.withCtx(()=>[e.createElementVNode("div",Gl,[e.createElementVNode("button",{onClick:g[4]||(g[4]=b=>i.value=!1),class:"px-4 py-2 rounded bg-gray-100 text-gray-700"}," Скасувати "),e.createElementVNode("button",{onClick:a,class:"px-4 py-2 rounded bg-blue-600 text-white"}," Імпортувати ")])]),default:e.withCtx(()=>[e.createElementVNode("div",ql,[e.createElementVNode("div",Rl,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.value,b=>(e.openBlock(),e.createElementBlock("label",{key:b.name,class:"flex items-center hover:bg-gray-100 rounded p-2 cursor-pointer"},[e.withDirectives(e.createElementVNode("input",{type:"checkbox",id:"import-"+b.name,"onUpdate:modelValue":g[3]||(g[3]=k=>p.value=k),value:b.name},null,8,Hl),[[e.vModelCheckbox,p.value]]),e.createElementVNode("div",Wl,[e.unref(fe)(b.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(`bg-${e.unref(pe)(b.type)}-100 p-1 rounded`)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(`icon-${b.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",null,[e.createElementVNode("p",Zl,e.toDisplayString(b.name),1),e.createElementVNode("p",Yl,e.toDisplayString(b.title||b.label),1)])])]))),128))])])]),_:1},8,["visible"])]))}}),Kl={class:"vs-form"},Ql={class:"vs-form__body auto-rows-max container"},Xl={class:"flex flex-wrap"},ea={class:"h-fit w-full flex flex-wrap"},ta={class:"flex justify-end mb-3 gap-2 w-full"},oa={class:"w-full"},na={class:"p-4 text-[13px]"},ra={class:"grid grid-cols-2 gap-x-6 gap-y-2"},la=["id","value"],aa={class:"flex-1 min-w-0 flex items-center gap-2"},sa={class:"font-medium text-gray-900 truncate"},ia={class:"text-xs text-gray-500"},ca={class:"flex justify-end gap-2 p-4 border-t w-full"},da=e.defineComponent({__name:"filter-tab",props:{data:{default:{}},dataModifiers:{}},emits:["update:data"],setup(t){const o=e.useModel(t,"data"),n=e.computed(()=>Array.isArray(o.value.fields)?o.value.fields:[]),r=e.defineAsyncComponent(()=>import("@opengis/core").then(d=>d.VsModal)),m=e.ref(!1),s=e.ref([]),i=e.computed({get:()=>(o.value||(o.value={}),Array.isArray(o.value.filters)||(o.value.filters=[]),o.value.filters),set:d=>{o.value||(o.value={}),o.value.filters=Array.isArray(d)?d:[]}});e.watch(m,d=>{if(d){const a=i.value.map(l=>l.id||l.name);s.value=[...a]}});const p=()=>{const d=new Set(s.value),a=n.value.filter(l=>d.has(l.name));i.value=a,m.value=!1,s.value=[]},f=[{key:"id",label:"Name",type:"text"},{key:"label",label:"UA",type:"text"},{key:"type",label:"Тип",type:"text"}],c={id:{type:"text",label:"Name",required:!0,disabled:!0},label:{type:"text",label:"UA",required:!0},type:{type:"combobox",label:"Тип",required:!0,mode:"combo",options:[{text:"Check",id:"check"},{text:"Range",id:"range"},{text:"Date",id:"date"},{text:"Text",id:"text"},{text:"Autocomplete",id:"autocomplete"}]}};return(d,a)=>(e.openBlock(),e.createElementBlock("div",Kl,[e.createElementVNode("div",Ql,[e.createElementVNode("div",Xl,[a[6]||(a[6]=e.createElementVNode("div",{class:"h-fit w-full flex flex-wrap mb-6 px-2"},[e.createElementVNode("p",{class:"text-sm text-gray-600"}," Налаштуйте фільтри реєстру. Оберіть поля для імпорту або редагуйте їх властивості нижче. ")],-1)),e.createElementVNode("div",ea,[e.createElementVNode("div",ta,[e.createElementVNode("button",{onClick:a[0]||(a[0]=l=>m.value=!0),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...a[5]||(a[5]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])])]),e.createElementVNode("div",oa,[e.createVNode(xe,{modelValue:i.value,"onUpdate:modelValue":a[1]||(a[1]=l=>i.value=l),"columns-scheme":f,"form-scheme":c,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])])])])]),e.createVNode(e.unref(r),{visible:m.value,"onUpdate:visible":a[4]||(a[4]=l=>m.value=l),title:"Імпорт фільтрів",size:"lg"},{footer:e.withCtx(()=>[e.createElementVNode("div",ca,[e.createElementVNode("button",{onClick:a[3]||(a[3]=l=>m.value=!1),class:"px-4 py-2 rounded bg-gray-100 text-gray-700"}," Скасувати "),e.createElementVNode("button",{onClick:p,class:"px-4 py-2 rounded bg-blue-600 text-white"}," Імпортувати ")])]),default:e.withCtx(()=>[e.createElementVNode("div",na,[e.createElementVNode("div",ra,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.value,l=>(e.openBlock(),e.createElementBlock("label",{key:l.name,class:"flex items-center hover:bg-gray-100 rounded p-2 cursor-pointer"},[e.withDirectives(e.createElementVNode("input",{type:"checkbox",id:"import-filter-"+l.name,"onUpdate:modelValue":a[2]||(a[2]=h=>s.value=h),value:l.name},null,8,la),[[e.vModelCheckbox,s.value]]),e.createElementVNode("div",aa,[e.unref(fe)(l.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(`bg-${e.unref(pe)(l.type)}-100 p-1 rounded`)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(`icon-${l.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",null,[e.createElementVNode("p",sa,e.toDisplayString(l.name),1),e.createElementVNode("p",ia,e.toDisplayString(l.title||l.label),1)])])]))),128))])])]),_:1},8,["visible"])]))}}),ma={class:"vs-form"},pa={class:"vs-form__body auto-rows-max container"},fa={class:"flex flex-wrap"},ua={class:"h-fit w-full flex flex-wrap"},ga={class:"flex justify-end mb-3 gap-2 w-full"},ha={class:"w-full"},ya={class:"p-4 text-[13px]"},ba={class:"grid grid-cols-2 gap-x-6 gap-y-2"},ka=["id","value"],xa={class:"flex-1 min-w-0 flex items-center gap-2"},wa={class:"font-medium text-gray-900 truncate"},_a={class:"text-xs text-gray-500"},Va={class:"flex justify-end gap-2 p-4 border-t w-full"},Ea=e.defineComponent({__name:"card-tab",props:{data:{default:{}},dataModifiers:{}},emits:["update:data"],setup(t){const o=e.useModel(t,"data"),n=e.computed(()=>Array.isArray(o.value.fields)?o.value.fields:[]),r=e.defineAsyncComponent(()=>import("@opengis/core").then(d=>d.VsModal)),m=e.ref(!1),s=e.ref([]),i=e.computed({get:()=>o.value.card,set:d=>{o.value||(o.value={}),o.value.card=Array.isArray(d)?d:[]}});e.watch(m,d=>{var a;if(d){const l=((a=i.value)==null?void 0:a.map(h=>h.name))||[];s.value=[...l]}});const p=()=>{const d=new Set(s.value),a=n.value.filter(l=>d.has(l.name));i.value=a,m.value=!1,s.value=[]},f=[{key:"name",label:"Name",type:"text"},{key:"ua",label:"UA",type:"text"},{key:"format",label:"Format",type:"text"},{key:"meta",label:"Мета",type:"text"}],c={name:{type:"text",label:"Name",required:!0,disabled:!0},ua:{type:"text",label:"UA",required:!0},format:{type:"combobox",label:"Format",mode:"combo",required:!0,options:[{text:"Text",id:"text"},{text:"Number",id:"number"},{text:"Date",id:"date"},{text:"File",id:"file"},{text:"Select",id:"select"}]},meta:{type:"combobox",label:"Мета",mode:"combo",required:!0,options:[{text:"Title",id:"title"},{text:"Features",id:"features"},{text:"Status",id:"status"},{text:"Tags",id:"tags"},{text:"Category",id:"category"},{text:"Image",id:"image"}]}};return(d,a)=>(e.openBlock(),e.createElementBlock("div",ma,[e.createElementVNode("div",pa,[e.createElementVNode("div",fa,[a[6]||(a[6]=e.createElementVNode("div",{class:"h-fit w-full flex flex-wrap mb-6 px-2"},[e.createElementVNode("p",{class:"text-sm text-gray-600"}," Налаштуйте відображення картки. Оберіть потрібні поля та відредагуйте їхні властивості. ")],-1)),e.createElementVNode("div",ua,[e.createElementVNode("div",ga,[e.createElementVNode("button",{onClick:a[0]||(a[0]=l=>m.value=!0),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...a[5]||(a[5]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])])]),e.createElementVNode("div",ha,[e.createVNode(xe,{modelValue:i.value,"onUpdate:modelValue":a[1]||(a[1]=l=>i.value=l),"columns-scheme":f,"form-scheme":c,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])])])])]),e.createVNode(e.unref(r),{visible:m.value,"onUpdate:visible":a[4]||(a[4]=l=>m.value=l),title:"Імпорт полів картки",size:"lg"},{footer:e.withCtx(()=>[e.createElementVNode("div",Va,[e.createElementVNode("button",{onClick:a[3]||(a[3]=l=>m.value=!1),class:"px-4 py-2 rounded bg-gray-100 text-gray-700"}," Скасувати "),e.createElementVNode("button",{onClick:p,class:"px-4 py-2 rounded bg-blue-600 text-white"}," Імпортувати ")])]),default:e.withCtx(()=>[e.createElementVNode("div",ya,[e.createElementVNode("div",ba,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.value,l=>(e.openBlock(),e.createElementBlock("label",{key:l.name,class:"flex items-center hover:bg-gray-100 rounded p-2 cursor-pointer"},[e.withDirectives(e.createElementVNode("input",{type:"checkbox",id:"import-card-"+l.name,"onUpdate:modelValue":a[2]||(a[2]=h=>s.value=h),value:l.name},null,8,ka),[[e.vModelCheckbox,s.value]]),e.createElementVNode("div",xa,[e.unref(fe)(l.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(`bg-${e.unref(pe)(l.type)}-100 p-1 rounded`)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(`icon-${l.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",null,[e.createElementVNode("p",wa,e.toDisplayString(l.name),1),e.createElementVNode("p",_a,e.toDisplayString(l.title||l.label),1)])])]))),128))])])]),_:1},8,["visible"])]))}}),Ba=["","січня","лютого","березня","квітня","травня","червня","липня","серпня","вересня","жовтня","листопада","грудня"];function ue(t){if(!t)return"";const[o,n]=t.split(" ");if(!o)return t;const[r,m,s]=o.split("-");if(!r||!m||!s)return t;const i=parseInt(m,10),p=Ba[i]||m;let f=`${parseInt(s,10)} ${p} ${r}`;if(n){const c=n.split(".")[0],[d,a,l]=c.split(":");d&&a&&l?f+=`, ${d}:${a}:${l}`:d&&a?f+=`, ${d}:${a}`:d&&(f+=`, ${d}`)}return f}const Na={name:"Template1",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{titleCol(){return this.columns.find(t=>t.meta==="title")},categoryCol(){return this.columns.filter(t=>t.meta==="category")},tagsCol(){return this.columns.filter(t=>t.meta==="tags")},featuresCols(){return this.columns.filter(t=>t.meta==="features")}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const n=this.query_params.map(r=>{const m=Object.keys(r)[0],s=r[m];return`${m}=${encodeURIComponent(t[s])}`}).join("&");return`${this.path}?${n}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const o=this.query_params.map(n=>{const r=Object.keys(n)[0],m=n[r];return`${r}=${encodeURIComponent(t[m])}`}).join("&");return`${this.path}/${t[this.id_key]}?${o}`},formatDate:ue}},Ca={class:"flex justify-between p-4 pb-2 bg-slate-50 gap-4"},$a={class:"flex items-center justify-between"},La={class:"text-lg font-bold line-clamp-2"},Sa={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 text-foreground ml-2 whitespace-nowrap","data-v0-t":"badge"},Fa={key:0,class:"flex"},ja={key:0,class:"h-fit inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 text-foreground ml-2 whitespace-nowrap"},Ia={class:"p-4 pt-2"},va={class:"grid grid-cols-2 gap-3 text-sm"},Da={class:"text-gray-500"},Aa={class:"font-medium"},Ma={class:"items-center p-3 bg-slate-50 flex justify-end"},Ta=["href"];function za(t,o,n,r,m,s){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.items,i=>{var p,f,c;return e.openBlock(),e.createElementBlock("div",{key:i.id,class:"rounded-lg border bg-card text-card-foreground overflow-hidden border-none shadow-md relative","data-v0-t":"card"},[e.createElementVNode("div",Ca,[e.createElementVNode("div",$a,[e.createElementVNode("h2",La,e.toDisplayString(i[`${(p=s.titleCol)==null?void 0:p.name}_text`]||i[(f=s.titleCol)==null?void 0:f.name]||i[(c=s.titleCol)==null?void 0:c.label]||"Не вказано"),1),Array.isArray(s.categoryCol)&&s.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(s.categoryCol,d=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:d.name},[i[d.name]?(e.openBlock(),e.createElementBlock("div",Sa,e.toDisplayString(i[`${d.name}_text`]||i[d.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0)]),Array.isArray(s.tagsCol)&&s.tagsCol.length?(e.openBlock(),e.createElementBlock("div",Fa,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tagsCol,d=>(e.openBlock(),e.createElementBlock("div",{key:d.name,class:"mt-2 flex flex-wrap gap-1"},[i[d.name]?(e.openBlock(),e.createElementBlock("span",ja,e.toDisplayString(i[`${d.name}_text`]||i[d.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Ia,[e.createElementVNode("div",va,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.featuresCols,d=>(e.openBlock(),e.createElementBlock("div",{key:d.name,class:"flex items-center gap-1.5"},[e.createElementVNode("span",Da,e.toDisplayString(d.ua||d.label)+": ",1),e.createElementVNode("span",Aa,[Array.isArray(i[d==null?void 0:d.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i[d==null?void 0:d.name],(a,l)=>(e.openBlock(),e.createElementBlock("span",{key:l,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(a),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[d.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(s.formatDate(i[d==null?void 0:d.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(i[d==null?void 0:d.name]||"Немає даних"),1)],64))],64))])]))),128))])]),e.createElementVNode("div",Ma,[e.createElementVNode("a",{href:s.getItemLink(i),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 border border-input bg-background hover:bg-accent hover:text-accent-foreground h-9 rounded-md px-3"},[...o[0]||(o[0]=[e.createTextVNode(" Детальніше ",-1),e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-arrow-right ml-1 h-3.5 w-3.5"},[e.createElementVNode("path",{d:"M5 12h14"}),e.createElementVNode("path",{d:"m12 5 7 7-7 7"})],-1)])],8,Ta)])])}),128)}const Pa=F(Na,[["render",za]]),Ua={name:"Template2",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{titleCol(){return this.columns.find(t=>t.meta==="title")},categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]},featuresCols(){return this.columns.filter(t=>t.meta==="features")}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const n=this.query_params.map(r=>{const m=Object.keys(r)[0],s=r[m];return`${m}=${encodeURIComponent(t[s])}`}).join("&");return`${this.path}?${n}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const o=this.query_params.map(n=>{const r=Object.keys(n)[0],m=n[r];return`${r}=${encodeURIComponent(t[m])}`}).join("&");return`${this.path}/${t[this.id_key]}?${o}`},formatDate:ue}},Oa={class:"p-0"},qa={class:"border-l-4 border-l-slate-400"},Ra={class:"p-4"},Ha={class:"flex flex-wrap items-center gap-2 mb-3"},Wa={class:"text-lg font-bold"},Za={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent bg-green-100 text-green-800 hover:bg-green-100","data-v0-t":"badge"},Ya={key:1,class:"flex"},Ga={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold border-transparent bg-gray-100 text-gray-800"},Ja={class:"grid grid-cols-1 sm:grid-cols-2 md:grid-cols-4 gap-3 text-sm border-t pt-3"},Ka={class:"text-xs text-gray-500 mb-1"},Qa={class:"font-medium"},Xa={class:"flex justify-end mt-3 border-t pt-3"},es=["href"];function ts(t,o,n,r,m,s){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.items,i=>{var p,f;return e.openBlock(),e.createElementBlock("div",{key:i.id,class:"rounded-lg border bg-card text-card-foreground shadow-sm overflow-hidden","data-v0-t":"card"},[e.createElementVNode("div",Oa,[e.createElementVNode("div",qa,[e.createElementVNode("div",Ra,[e.createElementVNode("div",Ha,[e.createElementVNode("h2",Wa,e.toDisplayString(i[`${(p=s.titleCol)==null?void 0:p.name}_text`]||i[(f=s.titleCol)==null?void 0:f.name]||"Не вказано"),1),Array.isArray(s.categoryCol)&&s.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(s.categoryCol,c=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c.name},[i[c.name]?(e.openBlock(),e.createElementBlock("div",Za,e.toDisplayString(i[`${c.name}_text`]||i[c.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0),Array.isArray(s.tagsCol)&&s.tagsCol.length?(e.openBlock(),e.createElementBlock("div",Ya,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tagsCol,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name,class:"flex flex-wrap gap-1 ml-2"},[i[c.name]?(e.openBlock(),e.createElementBlock("span",Ga,e.toDisplayString(i[`${c.name}_text`]||i[c.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Ja,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.featuresCols,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name},[e.createElementVNode("p",Ka,e.toDisplayString(c.ua),1),e.createElementVNode("p",Qa,[Array.isArray(i[c==null?void 0:c.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i[c==null?void 0:c.name],(d,a)=>(e.openBlock(),e.createElementBlock("span",{key:a,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(d),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[c.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(s.formatDate(i[c==null?void 0:c.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(i[c==null?void 0:c.name]||"Немає даних"),1)],64))],64))])]))),128))]),e.createElementVNode("div",Xa,[e.createElementVNode("a",{href:s.getItemLink(i),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 hover:bg-accent hover:text-accent-foreground h-9 rounded-md px-3"},[...o[0]||(o[0]=[e.createTextVNode(" Детальніше ",-1),e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-external-link ml-1 h-3.5 w-3.5"},[e.createElementVNode("path",{d:"M15 3h6v6"}),e.createElementVNode("path",{d:"M10 14 21 3"}),e.createElementVNode("path",{d:"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"})],-1)])],8,es)])])])])])}),128)}const os=F(Ua,[["render",ts]]),ns={name:"Template3",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]},featuresCols(){return this.columns.filter(t=>t.meta==="features")},colorClass(){return"bg-blue-500"},titleCol(){return this.columns.find(t=>t.meta==="title")}},methods:{featureColClass(t,o){return"col-span-2"},getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const n=this.query_params.map(r=>{const m=Object.keys(r)[0],s=r[m];return`${m}=${encodeURIComponent(t[s])}`}).join("&");return`${this.path}?${n}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const o=this.query_params.map(n=>{const r=Object.keys(n)[0],m=n[r];return`${r}=${encodeURIComponent(t[m])}`}).join("&");return`${this.path}/${t[this.id_key]}?${o}`},formatDate:ue}},rs={class:"space-y-4"},ls={class:"flex items-center py-2 px-3"},as={class:"flex-1"},ss={class:"grid grid-cols-12 gap-2 w-full text-xs"},is={class:"col-span-5"},cs={key:0,class:"inline-flex items-center rounded-full border transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80 mt-1 text-[10px] font-normal px-1.5 py-0","data-v0-t":"badge"},ds={key:1,class:"flex flex-wrap gap-1 mt-1"},ms={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold border-transparent bg-gray-100 text-gray-800"},ps={class:"col-span-7"},fs={class:"grid grid-cols-3 gap-3"},us={class:"text-[10px] text-gray-500 mb-1"},gs={class:"truncate font-medium"},hs=["href"];function ys(t,o,n,r,m,s){return e.openBlock(),e.createElementBlock("div",rs,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.items,i=>{var p,f;return e.openBlock(),e.createElementBlock("div",{key:i.id,class:"border-b border-slate-200 hover:bg-slate-50 transition-colors"},[e.createElementVNode("div",ls,[e.createElementVNode("div",{class:e.normalizeClass(["w-1 h-8 rounded-full mr-3",s.colorClass])},null,2),e.createElementVNode("div",as,[e.createElementVNode("div",ss,[e.createElementVNode("div",is,[e.createElementVNode("p",{class:e.normalizeClass(["font-bold text-sm text-left",{"w-full h-full flex items-center":!Array.isArray(s.tagsCol)||!s.tagsCol.length}])},e.toDisplayString(i[`${(p=s.titleCol)==null?void 0:p.name}_text`]||i[(f=s.titleCol)==null?void 0:f.name]||i[Object.keys(i)[0]]||"Не вказано"),3),Array.isArray(s.categoryCol)&&s.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(s.categoryCol,c=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c.name},[i[c.name]?(e.openBlock(),e.createElementBlock("div",cs,e.toDisplayString(i[`${c.name}_text`]||i[c.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0),Array.isArray(s.tagsCol)&&s.tagsCol.length?(e.openBlock(),e.createElementBlock("div",ds,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tagsCol,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name,class:"flex flex-wrap gap-1 mt-1"},[i[c.name]?(e.openBlock(),e.createElementBlock("span",ms,e.toDisplayString(i[`${c.name}_text`]||i[c.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",ps,[e.createElementVNode("div",fs,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.featuresCols,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name},[e.createElementVNode("p",us,e.toDisplayString(c.ua),1),e.createElementVNode("p",gs,[Array.isArray(i[c==null?void 0:c.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i[c==null?void 0:c.name],(d,a)=>(e.openBlock(),e.createElementBlock("span",{key:a,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(d),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[c.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(s.formatDate(i[c==null?void 0:c.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(i[c==null?void 0:c.name]||"Немає даних"),1)],64))],64))])]))),128))])])])]),e.createElementVNode("a",{href:s.getItemLink(i),class:"ml-auto flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 hover:bg-accent hover:text-accent-foreground rounded-md h-7 w-7 p-0",style:{"min-width":"2.5rem"}},[...o[0]||(o[0]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-chevron-right h-4 w-4"},[e.createElementVNode("path",{d:"m9 18 6-6-6-6"})],-1)])],8,hs)])])}),128))])}const bs=F(ns,[["render",ys]]),ks={name:"Template4",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{featuresCols(){return this.columns.filter(t=>t.meta==="features")},titleCol(){return this.columns.find(t=>t.meta==="title")},categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const n=this.query_params.map(r=>{const m=Object.keys(r)[0],s=r[m];return`${m}=${encodeURIComponent(t[s])}`}).join("&");return`${this.path}?${n}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const o=this.query_params.map(n=>{const r=Object.keys(n)[0],m=n[r];return`${r}=${encodeURIComponent(t[m])}`}).join("&");return`${this.path}/${t[this.id_key]}?${o}`},formatDate:ue}},xs={class:"flex flex-col space-y-1.5 p-6 pb-2"},ws={class:"flex items-center gap-2"},_s={class:"tracking-tight text-lg font-medium"},Vs={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent bg-blue-100 text-blue-800 ml-2","data-v0-t":"badge"},Es={key:1,class:"flex"},Bs={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold border-transparent bg-gray-100 text-gray-800"},Ns={class:"p-6 pt-0 pb-4"},Cs={class:"grid grid-cols-2 gap-4"},$s={class:"text-sm text-gray-500"},Ls={class:"font-medium"},Ss={class:"flex items-center p-6 pt-0"},Fs=["href"];function js(t,o,n,r,m,s){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.items,i=>{var p,f;return e.openBlock(),e.createElementBlock("div",{key:i.id,class:"rounded-lg border bg-card text-card-foreground shadow-sm border-l-4 border-l-blue-600","data-v0-t":"card"},[e.createElementVNode("div",xs,[e.createElementVNode("div",ws,[e.createElementVNode("h3",_s,e.toDisplayString(i[`${(p=s.titleCol)==null?void 0:p.name}_text`]||i[(f=s.titleCol)==null?void 0:f.name]||Object.keys(i)[0]||"Не вказано"),1),Array.isArray(s.categoryCol)&&s.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(s.categoryCol,c=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c.name},[i[c.name]?(e.openBlock(),e.createElementBlock("div",Vs,e.toDisplayString(i[`${c.name}_text`]||i[c.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0),Array.isArray(s.tagsCol)&&s.tagsCol.length?(e.openBlock(),e.createElementBlock("div",Es,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tagsCol,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name,class:"flex flex-wrap gap-1 ml-2"},[i[c.name]?(e.openBlock(),e.createElementBlock("span",Bs,e.toDisplayString(i[`${c.name}_text`]||i[c.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)])]),e.createElementVNode("div",Ns,[e.createElementVNode("div",Cs,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.featuresCols,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name},[e.createElementVNode("p",$s,e.toDisplayString(c.ua),1),e.createElementVNode("p",Ls,[Array.isArray(i[c==null?void 0:c.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i[c==null?void 0:c.name],(d,a)=>(e.openBlock(),e.createElementBlock("span",{key:a,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(d),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[c.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(s.formatDate(i[c==null?void 0:c.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(i[c==null?void 0:c.name]||"Немає даних"),1)],64))],64))])]))),128))])]),e.createElementVNode("div",Ss,[e.createElementVNode("a",{href:s.getItemLink(i),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 border bg-background h-10 px-4 py-2 rounded-md text-black border-black hover:bg-gray-100 hover:text-black"}," Детальніше ",8,Fs)])])}),128)}const Is=F(ks,[["render",js]]),vs={name:"Template5",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{imageCol(){return this.columns.find(t=>t.meta==="image")},descCol(){return this.columns.find(t=>t.meta==="desc")||this.columns.find(t=>t.name==="description")},categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]},featuresCols(){return this.columns.filter(t=>t.meta==="features")},titleCol(){return this.columns.find(t=>t.meta==="title")}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const n=this.query_params.map(r=>{const m=Object.keys(r)[0],s=r[m];return`${m}=${encodeURIComponent(t[s])}`}).join("&");return`${this.path}?${n}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const o=this.query_params.map(n=>{const r=Object.keys(n)[0],m=n[r];return`${r}=${encodeURIComponent(t[m])}`}).join("&");return`${this.path}/${t[this.id_key]}?${o}`},formatDate:ue}},Ds={class:"grid grid-cols-12 divide-x divide-gray-100"},As={key:0},Ms=["src"],Ts={key:1,class:"col-span-1 flex items-center justify-center"},zs={class:"col-span-7 p-4"},Ps={class:"flex items-center mb-1 col-span-7 p-4"},Us={class:"text-base font-bold text-gray-900 mr-2"},Os={key:0,class:"inline-flex items-center rounded-full px-2.5 py-0.5 font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent hover:bg-primary/80 bg-blue-100 text-blue-800 border-0 text-xs ml-2"},qs={class:"text-sm text-gray-600 line-clamp-1 mb-2"},Rs={class:"grid grid-cols-2 gap-x-4 gap-y-1 text-sm"},Hs={class:"text-gray-500 mr-1"},Ws=["innerHTML"],Zs={class:"text-gray-600 truncate"},Ys={class:"col-span-2 p-3 bg-gray-50 flex flex-col justify-center"},Gs={class:"text-xs text-gray-500 mb-1.5"},Js={key:0,class:"flex flex-wrap gap-1"},Ks={key:0,class:"inline-flex items-center rounded-full font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 hover:bg-secondary/80 bg-white border border-gray-200 text-gray-700 text-xs px-1.5 py-0"},Qs={class:"col-span-2 flex flex-col justify-center items-center bg-gray-50 border-l p-2"},Xs={class:"w-full space-y-2"},ei=["href"];function ti(t,o,n,r,m,s){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(n.items,i=>{var p,f,c,d,a;return e.openBlock(),e.createElementBlock("div",{key:i.id,class:"bg-white border border-gray-200 rounded-lg overflow-hidden transition-all duration-200 hover:shadow-md"},[e.createElementVNode("div",Ds,[s.imageCol?(e.openBlock(),e.createElementBlock("div",As,[i[(p=s.imageCol)==null?void 0:p.name]?(e.openBlock(),e.createElementBlock("img",{key:0,src:i[(f=s.imageCol)==null?void 0:f.name],alt:"image",class:"object-cover h-full"},null,8,Ms)):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock("div",Ts,[...o[0]||(o[0]=[e.createElementVNode("div",{class:"w-3 h-12 rounded-sm bg-blue-500",title:"Пріоритет: Високий","aria-hidden":"true"},null,-1)])])),e.createElementVNode("div",zs,[e.createElementVNode("div",Ps,[e.createElementVNode("h3",Us,e.toDisplayString(i[`${(c=s.titleCol)==null?void 0:c.name}_text`]||i[(d=s.titleCol)==null?void 0:d.name]||Object.keys(i)[0]||"Не вказано"),1),Array.isArray(s.categoryCol)&&s.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(s.categoryCol,l=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:l.name},[i[l.name]?(e.openBlock(),e.createElementBlock("div",Os,e.toDisplayString(i[`${l.name}_text`]||i[l.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0)]),e.createElementVNode("p",qs,e.toDisplayString(i[(a=s.descCol)==null?void 0:a.name]),1),e.createElementVNode("div",Rs,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.featuresCols,l=>(e.openBlock(),e.createElementBlock("div",{key:l.name,class:"flex items-center"},[e.createElementVNode("span",Hs,e.toDisplayString((l==null?void 0:l.ua)||l.label||l.name)+":",1),l.icon?(e.openBlock(),e.createElementBlock("span",{key:0,class:"mr-1 flex-shrink-0",innerHTML:l.icon},null,8,Ws)):e.createCommentVNode("",!0),e.createElementVNode("span",Zs,[Array.isArray(i[l==null?void 0:l.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i[l==null?void 0:l.name],(h,u)=>(e.openBlock(),e.createElementBlock("span",{key:u,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(h),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[l.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(s.formatDate(i[l==null?void 0:l.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(i[l==null?void 0:l.name]||"Немає даних"),1)],64))],64))])]))),128))])]),e.createElementVNode("div",Ys,[e.createElementVNode("p",Gs," Теги: "+e.toDisplayString(s.tagsCol.length&&i[s.tagsCol[0].name]?"":"відсутні"),1),Array.isArray(s.tagsCol)&&s.tagsCol.length?(e.openBlock(),e.createElementBlock("div",Js,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tagsCol,l=>(e.openBlock(),e.createElementBlock("div",{key:l.name,class:"flex flex-wrap gap-1"},[i[l.name]?(e.openBlock(),e.createElementBlock("span",Ks,e.toDisplayString(i[`${l.name}_text`]||i[l.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Qs,[e.createElementVNode("div",Xs,[e.createElementVNode("a",{href:s.getItemLink(i),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 rounded-md px-3 w-full bg-blue-600 hover:bg-blue-700 text-white text-xs h-8"}," Детальніше ",8,ei)])])])])}),128)}const Me={template1:Pa,template2:os,template3:bs,template4:Is,template5:F(vs,[["render",ti]])},oi={class:"space-y-4"},ni={class:"flex items-center gap-4 mb-2"},ri={class:"text-lg font-semibold mb-4"},li={key:1,class:"text-gray-400 text-center py-12"},ai={key:2,class:"text-gray-400 text-center py-12"},si=e.defineComponent({__name:"preview-tab",props:{data:{default:{}},dataModifiers:{}},emits:["update:data"],setup(t){const o=e.defineAsyncComponent(()=>import("@opengis/form")),n=e.useModel(t,"data"),r=[{text:"template1",id:"template1"},{text:"template2",id:"template2"},{text:"template3",id:"template3"},{text:"template4",id:"template4"},{text:"template5",id:"template5"}],m={view:{type:"select",label:"Вигляд",required:!0,options:r,col:12}},s=e.computed(()=>{var d;return Array.isArray((d=n.value)==null?void 0:d.columns)?n.value.columns:[]}),i=e.computed(()=>{var d;return console.log(n.value),((d=n.value)==null?void 0:d.view)||"template1"}),p=e.computed(()=>Me[i.value]||Me.template1),f=e.computed(()=>{var l;const d=(l=n.value)==null?void 0:l.view;if(!d)return"template1";const a=r.find(h=>h.id===d);return(a==null?void 0:a.text)||d}),c=e.computed(()=>(Array.isArray(n.value.rows)?n.value.rows:[]).slice(0,5));return(d,a)=>(e.openBlock(),e.createElementBlock("div",oi,[e.createElementVNode("div",ni,[e.createVNode(e.unref(o),{schema:m,modelValue:n.value,"onUpdate:modelValue":a[0]||(a[0]=l=>n.value=l),class:"w-[220px]"},null,8,["modelValue"])]),e.createElementVNode("h2",ri," Превʼю таблиці ("+e.toDisplayString(f.value)+") ",1),p.value&&c.value.length&&s.value.length?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(p.value),{items:c.value,columns:s.value,path:"#",id_key:"id",key:i.value},null,8,["items","columns"])):c.value.length?(e.openBlock(),e.createElementBlock("div",ai," Додайте колонки та виберіть вигляд для перегляду ")):(e.openBlock(),e.createElementBlock("div",li," Немає даних для превʼю "))]))}}),ii={class:"relative min-h-svh flex-1 flex-col flex gap-4 bg-white p-8 overflow-y-auto"},ci={class:"max-w-6xl mx-auto"},di={class:"flex items-center justify-between mb-6"},mi={class:"flex items-center gap-2"},pi=["href"],fi={class:"w-full"},ui={class:"flex items-center w-full h-10 max-w-md grid-cols-3 p-1 mb-6 bg-white border border-gray-200 rounded-md text-muted-foreground"},gi=["onClick"],hi={__name:"register",setup(t){const o=ye.useRoute(),n=ye.useRouter(),r=e.ref("list"),m=e.ref(""),s=[{name:"List",id:"list"},{name:"Filters",id:"filters"},{name:"Card",id:"card"},{name:"Preview",id:"preview"}],i={list:Jl,filters:da,card:Ea,preview:si},p=s.map(a=>a.id),f=e.ref({}),c=async()=>{console.log(f.value);try{const a=await fetch(`/api/gis-registry/${o.params.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(f.value)});if(!a.ok)throw new Error(`Failed to save content: ${a.status}`);Z.notify({type:"success",title:"Успіх",message:"Контент збережено"})}catch(a){Z.notify({type:"error",title:"Помилка",message:"Не вдалося зберегти контент"}),console.error(a)}},d=async()=>{try{const l=await(await fetch(`/api/gis-registry/${o.params.id}`)).json(),h=l;m.value=h.register_key||"",f.value=h,f.value.fields=Array.isArray(l==null?void 0:l.fields)?l.fields:[]}catch(a){console.error("Помилка завантаження даних:",a)}};return e.onMounted(async()=>{const a=o.query.tab;typeof a=="string"&&p.includes(a)&&(r.value=a),await d()}),e.watch(r,a=>{o.query.tab!==a&&n.replace({query:{...o.query,tab:a}})}),e.watch(()=>o.query.tab,a=>{typeof a=="string"&&p.includes(a)&&r.value!==a&&(r.value=a)}),(a,l)=>(e.openBlock(),e.createElementBlock("main",ii,[e.createElementVNode("div",null,[e.createElementVNode("div",ci,[e.createElementVNode("div",di,[l[1]||(l[1]=e.createElementVNode("div",null,[e.createElementVNode("h1",{class:"mb-2 text-2xl font-semibold text-gray-900"},"Створити контент"),e.createElementVNode("p",{class:"text-gray-600"},"Створити контент для вашого сайту")],-1)),e.createElementVNode("div",mi,[e.createElementVNode("a",{href:`/${e.unref(o).path.split("/")[1]}`,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 border bg-background hover:text-accent-foreground h-10 px-4 py-2 border-gray-300 text-gray-700 hover:bg-gray-50"}," Повернутися ",8,pi),e.createElementVNode("button",{onClick:c,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-white rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 text-primary-foreground h-10 px-4 py-2 bg-blue-600 hover:bg-blue-700"}," Зберегти ")])]),e.createElementVNode("div",fi,[e.createElementVNode("div",ui,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(s,h=>e.createElementVNode("button",{key:h.id,onClick:u=>r.value=h.id,class:e.normalizeClass(["inline-flex flex-1 items-center justify-center whitespace-nowrap rounded-sm px-3 py-1.5 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm data-[state=active]:bg-blue-50 data-[state=active]:text-blue-700 data-[state=active]:border-blue-200",h.id===r.value?"bg-blue-50 text-blue-700 border-blue-200":""])},e.toDisplayString(h.name),11,gi)),64))])]),(e.openBlock(),e.createBlock(e.resolveDynamicComponent(i[r.value]),{data:f.value,"onUpdate:data":l[0]||(l[0]=h=>f.value=h),key:r.value+"-"+(f.value.id||f.value.register_id||"")},null,40,["data"]))])])]))}},yi={},bi={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-settings"};function ki(t,o){return e.openBlock(),e.createElementBlock("svg",bi,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z"},null,-1),e.createElementVNode("circle",{cx:"12",cy:"12",r:"3"},null,-1)])])}const xi=F(yi,[["render",ki]]),wi={},_i={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-layers"};function Vi(t,o){return e.openBlock(),e.createElementBlock("svg",_i,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"m12.83 2.18a2 2 0 0 0-1.66 0L2.6 6.08a1 1 0 0 0 0 1.83l8.58 3.91a2 2 0 0 0 1.66 0l8.58-3.9a1 1 0 0 0 0-1.83Z"},null,-1),e.createElementVNode("path",{d:"m22 17.65-9.17 4.16a2 2 0 0 1-1.66 0L2 17.65"},null,-1),e.createElementVNode("path",{d:"m22 12.65-9.17 4.16a2 2 0 0 1-1.66 0L2 12.65"},null,-1)])])}const Ei=F(wi,[["render",Vi]]),Bi={},Ni={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-eye"};function Ci(t,o){return e.openBlock(),e.createElementBlock("svg",Ni,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M2 12s3-7 10-7 10 7 10 7-3 7-10 7-10-7-10-7Z"},null,-1),e.createElementVNode("circle",{cx:"12",cy:"12",r:"3"},null,-1)])])}const $i=F(Bi,[["render",Ci]]),Li={},Si={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-map"};function Fi(t,o){return e.openBlock(),e.createElementBlock("svg",Si,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M14.106 5.553a2 2 0 0 0 1.788 0l3.659-1.83A1 1 0 0 1 21 4.619v12.764a1 1 0 0 1-.553.894l-4.553 2.277a2 2 0 0 1-1.788 0l-4.212-2.106a2 2 0 0 0-1.788 0l-3.659 1.83A1 1 0 0 1 3 19.381V6.618a1 1 0 0 1 .553-.894l4.553-2.277a2 2 0 0 1 1.788 0z"},null,-1),e.createElementVNode("path",{d:"M15 5.764v15"},null,-1),e.createElementVNode("path",{d:"M9 3.236v15"},null,-1)])])}const ji=F(Li,[["render",Fi]]),Ii={},vi={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-filter"};function Di(t,o){return e.openBlock(),e.createElementBlock("svg",vi,[...o[0]||(o[0]=[e.createElementVNode("polygon",{points:"22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3"},null,-1)])])}const Ai=F(Ii,[["render",Di]]),Mi={class:"flex flex-col flex-1 overflow-hidden"},Ti={class:"flex flex-col flex-1 overflow-hidden"},zi={class:"bg-white rounded-xl border border-gray-200 shadow-sm overflow-hidden mt-3 flex flex-col flex-1"},Pi={class:"relative bg-gradient-to-br from-slate-50 to-white flex-1"},Ui=F(e.defineComponent({__name:"vs-tab-style",props:{token:{},styleYaml:{}},emits:["update:styleYaml","update"],setup(t,{emit:o}){const n=t,r=o;function m(u){if(!u)return"";if(typeof u=="string")return u;try{return jsyaml.dump(u)}catch(y){return console.warn("Failed to stringify style YAML",y),""}}const s=e.ref(m(n.styleYaml)),i=e.ref("vs-light"),p=e.ref(null);let f=null,c=null;function d(){const u=m(n.styleYaml);u!==s.value&&(s.value=u,f&&u!==f.getValue()&&f.setValue(u))}e.watch(()=>n.token,()=>{d()}),e.watch(s,u=>{try{const y=u?jsyaml.load(u):null;JSON.stringify(y)!==JSON.stringify(n.styleYaml)&&r("update:styleYaml",y)}catch(y){console.warn("Invalid YAML:",y)}});function a(){return new Promise((u,y)=>{if(c)return u(c);if(window.monaco)return c=window.monaco,u(c);const g=k=>{if(Array.from(document.styleSheets).some(N=>{var V;return(V=N==null?void 0:N.href)==null?void 0:V.includes(k)}))return;const j=document.createElement("link");j.rel="stylesheet",j.href=k,document.head.appendChild(j)},b=k=>new Promise((B,j)=>{const N=document.createElement("script");N.src=k,N.onload=()=>B(),N.onerror=j,document.body.appendChild(N)});g("https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.0/min/vs/editor/editor.main.min.css"),b("https://cdn.jsdelivr.net/npm/js-yaml@4.1.0/dist/js-yaml.min.js"),b("https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.0/min/vs/loader.min.js").then(()=>{window.require.config({paths:{vs:"https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.0/min/vs"}}),window.require(["vs/editor/editor.main"],()=>{c=window.monaco,u(c)})}).catch(y)})}function l(){!p.value||!c||(f&&f.dispose(),f=c.editor.create(p.value,{value:s.value,language:"yaml",theme:i.value,automaticLayout:!0,minimap:{enabled:!1}}),d(),f.onDidChangeModelContent(()=>{s.value=f.getValue()}))}e.onMounted(async()=>{await a(),l()});const h=async()=>{try{await fetch(`/api/gis-service/${n.token}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({style:s.value})}),r("update"),Z.notify({type:"success",title:"Успіх",message:"Стилі збережено"})}catch(u){Z.notify({type:"error",title:"Помилка",message:"Не вдалося зберегти стилі"}),console.log(u)}};return(u,y)=>(e.openBlock(),e.createElementBlock("div",Mi,[e.createElementVNode("div",{class:"flex justify-end"},[e.createElementVNode("button",{onClick:h,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 px-4 py-2 h-9 text-xs bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm transition-all duration-300 hover:shadow-md hover:scale-[1.02] relative overflow-hidden"},[...y[0]||(y[0]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-save h-3 w-3 mr-1"},[e.createElementVNode("path",{d:"M15.2 3a2 2 0 0 1 1.4.6l3.8 3.8a2 2 0 0 1 .6 1.4V19a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2z"}),e.createElementVNode("path",{d:"M17 21v-7a1 1 0 0 0-1-1H8a1 1 0 0 0-1 1v7"}),e.createElementVNode("path",{d:"M7 3v4a1 1 0 0 0 1 1h7"})],-1),e.createTextVNode(" Зберегти стилі ",-1)])])]),e.createElementVNode("div",Ti,[e.createElementVNode("div",zi,[y[1]||(y[1]=e.createElementVNode("div",{class:"bg-gradient-to-r from-gray-50 to-gray-100 px-4 py-2 border-b border-gray-200 flex items-center justify-between"},[e.createElementVNode("div",{class:"text-xs text-gray-400"},"YAML")],-1)),e.createElementVNode("div",Pi,[e.createElementVNode("div",{ref_key:"editorContainer",ref:p,class:"w-full h-full"},null,512)])])])]))}}),[["__scopeId","data-v-c9bb6aaa"]]),Oi={class:"space-y-3 bg-gradient-to-br from-sky-50 to-blue-50 p-4 rounded-xl border border-sky-100 shadow-sm"},qi={role:"radiogroup",class:"grid grid-cols-3 gap-2"},Ri=["onClick"],Hi=["aria-checked","value"],Wi={key:0},Zi=e.defineComponent({__name:"view-mode-toggle",props:{modelValue:{},options:{}},emits:["update:modelValue"],setup(t,{emit:o}){const n=t,r=o,m=i=>r("update:modelValue",i),s=n.options||[{value:"all",label:"All"},{value:"list",label:"List"},{value:"none",label:"None"}];return(i,p)=>(e.openBlock(),e.createElementBlock("div",Oi,[p[1]||(p[1]=e.createElementVNode("label",{class:"text-sm font-medium text-gray-600"},"Режим відображення",-1)),e.createElementVNode("div",qi,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(s),f=>(e.openBlock(),e.createElementBlock("div",{key:f.value,onClick:c=>m(f.value),class:e.normalizeClass(["flex items-center justify-center space-x-2 rounded-lg p-2 border transition-all duration-300 cursor-pointer",[i.modelValue===f.value?"bg-gradient-to-r from-sky-200 to-blue-200 border-transparent shadow-sm":"bg-white border-gray-100 hover:border-sky-200 hover:shadow-sm"]])},[e.createElementVNode("button",{type:"button",role:"radio","aria-checked":i.modelValue===f.value,value:f.value,class:"aspect-square rounded-full border border-primary h-4 w-4 flex items-center justify-center text-sky-500"},[i.modelValue===f.value?(e.openBlock(),e.createElementBlock("span",Wi,[...p[0]||(p[0]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-circle h-2.5 w-2.5 fill-current text-current"},[e.createElementVNode("circle",{cx:"12",cy:"12",r:"10"})],-1)])])):e.createCommentVNode("",!0)],8,Hi),e.createElementVNode("label",{class:e.normalizeClass(["text-xs font-medium cursor-pointer",i.modelValue===f.value?"text-gray-700":"text-gray-600"])},e.toDisplayString(f.label),3)],10,Ri))),128))])]))}}),Yi={class:"flex justify-between mb-3 gap-2"},Gi=["disabled"],Ji={class:"p-4 text-[13px]"},Ki={class:"grid grid-cols-2 gap-x-6 gap-y-2"},Qi=["id","value"],Xi={class:"flex-1 min-w-0 flex items-center gap-2"},ec={class:"font-medium text-gray-900 truncate"},tc={class:"text-xs text-gray-500"},oc={class:"flex justify-end gap-2 p-4 border-t w-full"},we=e.defineComponent({__name:"vs-tab-manager",props:{mapInfo:{},token:{},fields:{},sectionKey:{},columnsScheme:{},formScheme:{},dialogTitle:{},saveButtonLabel:{},importMapper:{type:Function},withViewMode:{type:Boolean}},emits:["update","update:columns"],setup(t,{emit:o}){const n=e.defineAsyncComponent(()=>import("@opengis/core").then(a=>a.VsModal)),r=e.ref("list"),m=t,s=o,i=e.ref([]),p=e.ref(!1),f=e.ref([]);e.watch(()=>{var a;return(a=m.mapInfo)==null?void 0:a[m.sectionKey]},a=>{i.value=Array.isArray(a)?[...a]:[],s("update:columns",i.value)},{immediate:!0}),e.watch(p,a=>{if(a){const l=i.value.map(h=>h.name||h.id);f.value=[...l]}});function c(){i.value=m.importMapper(m.fields,f.value,i.value),s("update:columns",i.value),p.value=!1,f.value=[]}async function d(){if(m.token)try{let a=[];if(r.value==="all"?a=[...m.fields]:r.value==="none"?a=[]:a=i.value,!(await fetch(`/api/table/${m.token}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({[m.sectionKey]:a})})).ok)throw new Error("Save failed");s("update"),Z.notify({type:"success",title:"Успіх",message:`${m.sectionKey} saved`})}catch(a){Z.notify({type:"error",title:"Помилка",message:`Failed to save ${m.sectionKey}`}),console.error(a)}}return(a,l)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",Yi,[e.createElementVNode("button",{onClick:l[0]||(l[0]=h=>p.value=!0),disabled:a.withViewMode&&r.value!=="list",class:e.normalizeClass([a.withViewMode&&r.value!=="list"?"":"hover:from-gray-600 hover:to-gray-500","inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium bg-gradient-to-r from-gray-500 to-gray-400 text-white h-9 px-4 py-2 disabled:bg-gray-300 disabled:text-gray-500 disabled:cursor-not-allowed disabled:opacity-70"])},[...l[6]||(l[6]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])],10,Gi),e.createElementVNode("button",{onClick:d,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm px-4 py-2 h-9 text-xs transition-all duration-300"},[l[7]||(l[7]=e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"h-3 w-3 mr-1"},[e.createElementVNode("path",{d:"M15.2 3a2 2 0 0 1 1.4.6l3.8 3.8a2 2 0 0 1 .6 1.4V19a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2z"}),e.createElementVNode("path",{d:"M17 21v-7a1 1 0 0 0-1-1H8a1 1 0 0 0-1 1v7"}),e.createElementVNode("path",{d:"M7 3v4a1 1 0 0 0 1 1h7"})],-1)),e.createTextVNode(" "+e.toDisplayString(a.saveButtonLabel),1)])]),a.withViewMode?(e.openBlock(),e.createBlock(Zi,{key:0,modelValue:r.value,"onUpdate:modelValue":l[1]||(l[1]=h=>r.value=h),class:"mb-2"},null,8,["modelValue"])):e.createCommentVNode("",!0),!a.withViewMode||r.value==="list"?(e.openBlock(),e.createBlock(xe,{key:1,modelValue:i.value,"onUpdate:modelValue":l[2]||(l[2]=h=>i.value=h),"columns-scheme":a.columnsScheme,"form-scheme":a.formScheme,"main-col-width":"250px","add-button":!1},null,8,["modelValue","columns-scheme","form-scheme"])):e.createCommentVNode("",!0),e.createVNode(e.unref(n),{visible:p.value,"onUpdate:visible":l[5]||(l[5]=h=>p.value=h),title:a.dialogTitle,size:"lg"},{footer:e.withCtx(()=>[e.createElementVNode("div",oc,[e.createElementVNode("button",{onClick:l[4]||(l[4]=h=>p.value=!1),class:"px-4 py-2 rounded bg-gray-100 text-gray-700"}," Скасувати "),e.createElementVNode("button",{onClick:c,class:"px-4 py-2 rounded bg-blue-600 text-white"}," Імпортувати ")])]),default:e.withCtx(()=>[e.createElementVNode("div",Ji,[e.createElementVNode("div",Ki,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.fields,h=>(e.openBlock(),e.createElementBlock("label",{key:h.name,class:"flex items-center hover:bg-gray-100 rounded p-2 cursor-pointer"},[e.withDirectives(e.createElementVNode("input",{type:"checkbox",id:"import-"+h.name,"onUpdate:modelValue":l[3]||(l[3]=u=>f.value=u),value:h.name},null,8,Qi),[[e.vModelCheckbox,f.value]]),e.createElementVNode("div",Xi,[e.unref(fe)(h.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(`bg-${e.unref(pe)(h.type)}-100 p-1 rounded`)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(`icon-${h.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",null,[e.createElementVNode("p",ec,e.toDisplayString(h.name),1),e.createElementVNode("p",tc,e.toDisplayString(h.title),1)])])]))),128))])])]),_:1},8,["visible","title"])],64))}}),nc=e.defineComponent({__name:"vs-tab-popup",props:{mapInfo:{},token:{},fields:{},filters:{},filterFields:{},styleYaml:{},popupFields:{},filterScheme:{}},emits:["update","update:styleYaml","update:popupFields","update:filterScheme","update:cardFields","update:legend"],setup(t,{emit:o}){const n=o,r=[{key:"name",label:"Name"},{key:"ua",label:"UA"},{key:"format",label:"Format"},{key:"meta",label:"Meta"}],m={name:{type:"text",label:"Name",disabled:!0,validators:["required"]},ua:{type:"text",label:"UA",validators:["required"]},format:{type:"text",label:"Format",disabled:!0},meta:{type:"combobox",label:"Meta",mode:"combo",options:[{text:"Title",id:"title"},{text:"Image",id:"image"},{text:"Badge",id:"badge"}]}};function s(i,p,f){return i.filter(c=>p.includes(c.name)).map(c=>{const d=f.find(a=>a.name===c.name);return{name:c.name,ua:c.title,format:c.format||"text",meta:(d==null?void 0:d.meta)||c.meta,...c}})}return(i,p)=>(e.openBlock(),e.createBlock(we,{"map-info":i.mapInfo,token:i.token,fields:i.fields,"section-key":"popup","columns-scheme":r,"form-scheme":m,"dialog-title":"Імпорт колонок","save-button-label":"Зберегти попап","import-mapper":s,onUpdate:p[0]||(p[0]=f=>n("update")),"onUpdate:columns":p[1]||(p[1]=f=>n("update:popupFields",f)),"with-view-mode":""},null,8,["map-info","token","fields"]))}}),rc=e.defineComponent({__name:"vs-tab-legend",props:{mapInfo:{},token:{},fields:{},filters:{},filterFields:{},styleYaml:{},popupFields:{},filterScheme:{}},emits:["update","update:styleYaml","update:popupFields","update:filterScheme","update:cardFields","update:legend"],setup(t,{emit:o}){const n=o;let r=[];const m=[{key:"name",label:"Назва"},{key:"color",label:"Колір",type:"color"}],s={name:{type:"text",label:"Назва",validators:["required"]},color:{type:"color",label:"Колір",validators:["required"]}};function i(p,f,c){return c}return(p,f)=>(e.openBlock(),e.createBlock(we,{"map-info":p.mapInfo,token:p.token,fields:[],"section-key":"legend","columns-scheme":m,"form-scheme":s,"dialog-title":"Імпорт легенди","save-button-label":"Зберегти легенду","import-mapper":i,onUpdate:f[0]||(f[0]=c=>n("update")),"onUpdate:columns":f[1]||(f[1]=c=>e.isRef(r)?r.value=c:r=c)},null,8,["map-info","token"]))}}),lc=e.defineComponent({__name:"vs-tab-card",props:{mapInfo:{},token:{},fields:{},filters:{},filterFields:{},styleYaml:{},popupFields:{},filterScheme:{}},emits:["update","update:styleYaml","update:popupFields","update:filterScheme","update:cardFields","update:legend"],setup(t,{emit:o}){const n=o;let r=[];const m=[{key:"name",label:"Name"},{key:"ua",label:"UA"},{key:"format",label:"Format"},{key:"meta",label:"Мета"}],s={name:{type:"text",label:"Name",validators:["required"],disabled:!0},ua:{type:"text",label:"UA",validators:["required"]},format:{type:"combobox",label:"Format",mode:"combo",validators:["required"],options:[{text:"Text",id:"text"},{text:"Number",id:"number"},{text:"Date",id:"date"},{text:"File",id:"file"},{text:"Select",id:"select"}]},meta:{type:"combobox",label:"Мета",validators:["required"],mode:"combo",options:[{text:"Title",id:"title"},{text:"Features",id:"features"},{text:"Status",id:"status"},{text:"Tags",id:"tags"},{text:"Category",id:"category"}]}};function i(p,f,c){return p.filter(d=>f.includes(d.name)).map(d=>({name:d.name,ua:d.title,format:d.format||"text",meta:d.meta||"title"}))}return(p,f)=>(e.openBlock(),e.createBlock(we,{"map-info":p.mapInfo,token:p.token,fields:p.fields,"section-key":"card","columns-scheme":m,"form-scheme":s,"dialog-title":"Імпорт полів картки","save-button-label":"Зберегти картку","import-mapper":i,onUpdate:f[0]||(f[0]=c=>n("update")),"onUpdate:columns":f[1]||(f[1]=c=>e.isRef(r)?r.value=c:r=c),"with-view-mode":""},null,8,["map-info","token","fields"]))}}),ac=e.defineComponent({__name:"vs-tab-filter",props:{mapInfo:{},token:{},fields:{},filters:{},filterFields:{},styleYaml:{},popupFields:{},filterScheme:{}},emits:["update","update:styleYaml","update:popupFields","update:filterScheme","update:cardFields","update:legend"],setup(t,{emit:o}){const n=o,r=[{key:"id",label:"Name"},{key:"label",label:"UA"},{key:"type",label:"Тип"}],m={id:{type:"text",label:"Name",disabled:!0,validators:["required"]},label:{type:"text",label:"UA",validators:["required"]},type:{type:"combobox",label:"Тип",validators:["required"],mode:"combo",options:[{text:"Check",id:"check"},{text:"Range",id:"range"},{text:"Date",id:"date"},{text:"Text",id:"text"},{text:"Autocomplete",id:"autocomplete"}]}};function s(i,p,f){return i.filter(c=>p.includes(c.name)).map(c=>({id:c.name,label:c.title,type:c.type||"text"}))}return(i,p)=>(e.openBlock(),e.createBlock(we,{"map-info":i.mapInfo,token:i.token,fields:i.fields,"section-key":"filters","columns-scheme":r,"form-scheme":m,"dialog-title":"Імпорт фільтрів","save-button-label":"Зберегти фільтри","import-mapper":s,onUpdate:p[0]||(p[0]=f=>n("update")),"onUpdate:columns":p[1]||(p[1]=f=>n("update:filterFields",f))},null,8,["map-info","token","fields"]))}}),Te=Symbol("MapContext");function sc(t){const o=e.shallowRef(null),n=e.ref(!1);let r=!1;const m=[],s=()=>{r=!0,m.length&&m.forEach(a=>a())},i=()=>{const a=t.container;return typeof a=="string"?document.getElementById(a):(a==null?void 0:a.value)!==void 0?a.value:a},p=()=>r?Promise.resolve():new Promise(a=>m.push(a)),f=async()=>{var l,h,u,y;if(typeof window>"u"||o.value)return;const a=i();if(!a)throw new Error("Map container not found");o.value=new maplibregl.Map({...t.mapOptions||{},center:[30,50],zoom:7,container:a}),(l=t.controls)!=null&&l.navigation&&o.value.addControl(new maplibregl.NavigationControl(typeof t.controls.navigation=="object"?t.controls.navigation:{}),"top-right"),(h=t.controls)!=null&&h.scale&&o.value.addControl(new maplibregl.ScaleControl(typeof t.controls.scale=="object"?t.controls.scale:{}),"bottom-left"),(u=t.controls)!=null&&u.fullscreen&&o.value.addControl(new maplibregl.FullscreenControl,"top-right"),(y=t.controls)!=null&&y.geolocate&&o.value.addControl(new maplibregl.GeolocateControl(typeof t.controls.geolocate=="object"?t.controls.geolocate:{}),"top-right"),o.value.once("load",()=>{n.value=!0,s()})},c=()=>{o.value&&(o.value.remove(),o.value=null,n.value=!1)};e.onMounted(f),e.onUnmounted(c);const d={map:o,ready:p,flyTo:a=>{var l;return(l=o.value)==null?void 0:l.flyTo(a)},fitBounds:(a,l)=>{var h;return(h=o.value)==null?void 0:h.fitBounds(a,l)},setCenter:a=>{var l;return(l=o.value)==null?void 0:l.setCenter(a)},setZoom:a=>{var l;return(l=o.value)==null?void 0:l.setZoom(a)},addControl:(a,l)=>{var h;return(h=o.value)==null?void 0:h.addControl(a,l)},removeControl:a=>{var l;return(l=o.value)==null?void 0:l.removeControl(a)},on:(a,l,h)=>{var u,y;return typeof l=="string"?((u=o.value)==null||u.on(a,l,h),()=>{var g;return(g=o.value)==null?void 0:g.off(a,l,h)}):((y=o.value)==null||y.on(a,l),()=>{var g;return(g=o.value)==null?void 0:g.off(a,l)})},off:(a,l,h)=>{var u,y;typeof l=="string"?(u=o.value)==null||u.off(a,l,h):(y=o.value)==null||y.off(a,l)},project:a=>{var l;return(l=o.value)==null?void 0:l.project(a)},unproject:a=>{var l;return(l=o.value)==null?void 0:l.unproject(a)}};return e.provide(Te,d),d}function ge(){const t=e.inject(Te);if(!t)throw new Error("useMap() called outside of a Map provider");return t}const ic=e.defineComponent({__name:"MapView",setup(t,{expose:o}){const n=e.ref(null),r=sc({container:n,mapOptions:{style:{version:8,sources:{},layers:[]},center:[30.5234,50.4501],zoom:9},controls:{navigation:!0,scale:!0}});return o({ctx:r}),(m,s)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{ref_key:"el",ref:n,class:"w-full h-full rounded-xl overflow-hidden"},null,512),e.renderSlot(m.$slots,"default")],64))}});function cc(t){const o=t.colorAttr&&t.colors?["match",["get",t.colorAttr],...Object.entries(t.colors).reduce((n,r)=>n.concat(r),[]),"#94a3b8"]:null;return{type:"circle",paint:{"circle-stroke-color":(t==null?void 0:t.stroke)||"#fff","circle-opacity":t.opacity||1,"circle-color":o||t.color,"circle-stroke-width":t.width,"circle-radius":t.radius||5}}}function dc(t){return{type:"fill",paint:{"fill-color":t.color,"fill-opacity":t.opacity||.3,"fill-outline-color":t.stroke}}}function mc(t){return{type:"line",paint:{"line-color":t.color,"line-opacity":t.opacity||.3,"line-width":t.width||1.5}}}function ze(t){return t?t.type==="polygon"?dc(t):t.type==="line"?mc(t):cc(t):{}}function Pe(t,o){const{map:n,ready:r,on:m}=ge(),s=o.layer.id||t,i=o.sourceId??(typeof o.layer.source=="string"?o.layer.source:t);o.source&&(!o.layer.source||typeof o.layer.source!="string")&&(o.layer.source=i);let p=!1,f=!1;const c=()=>{var N,V;if(!(f||!n.value)){if(o.source&&!n.value.getSource(i)&&n.value.addSource(i,o.source),!n.value.getLayer(s)){const z=o.beforeId===0?(V=(N=n.value.getStyle().layers)==null?void 0:N[0])==null?void 0:V.id:o.beforeId,O=ze(o.layer.style);Object.assign(o.layer,O),n.value.addLayer(o.layer,z)}p=!0}};r().then(c);const d=m("style.load",c);function a(N){n.value&&n.value.setLayoutProperty(s,"visibility",N?"visible":"none")}function l(N){var O;if(!n.value)return;const V=ze(N),z=(O=n.value.getLayer(s))==null?void 0:O.type;if(V.type!==z){n.value.removeLayer(s),n.value.addLayer({...o.layer,...V});return}V.paint&&h(V.paint)}function h(N){n.value&&Object.entries(N).forEach(([V,z])=>n.value.setPaintProperty(s,V,z))}function u(N){n.value&&Object.entries(N).forEach(([V,z])=>n.value.setLayoutProperty(s,V,z))}function y(N){n.value&&n.value.setFilter(s,N)}function g(N){if(!n.value)return;const V=n.value.getSource(i);V&&"setTiles"in V&&V.setTiles(N)}function b(N){if(!n.value)return;const V=n.value.getSource(i);V&&"setData"in V&&V.setData(N)}function k(N,V){n.value&&n.value.setFeatureState({source:i,...N},V)}function B(N,V){n.value&&n.value.removeFeatureState({source:i,...N},V?{key:V}:void 0)}function j(){!n.value||f||(n.value.getLayer(s)&&n.value.removeLayer(s),o.source&&n.value.getSource(i)&&n.value.removeSource(i),f=!0,d())}return e.onBeforeUnmount(j),{ids:{layerId:s,sourceId:i},isMounted:()=>{var N;return p&&!!((N=n.value)!=null&&N.getLayer(s))},setVisible:a,updatePaint:h,updateLayout:u,updateFilter:y,setData:b,setTiles:g,setStyle:l,setFeatureState:k,removeFeatureState:B,remove:j,getSource:()=>{var N;return(N=n.value)==null?void 0:N.getSource(i)},getLayer:()=>{var N;return(N=n.value)==null?void 0:N.getLayer(s)}}}const pc={class:"flex flex-row gap-x-3 z-10 relative widget"},fc=["onClick"],uc=["src","alt"],gc=e.defineComponent({__name:"MapLayersPanel",setup(t){const o={gki:{url:"https://data.gki.com.ua/api-user/rtile/voyager/ua/{z}/{x}/{y}.png",preview:"https://data.gki.com.ua/api-user/rtile/voyager/ua/12/2422/1400.png",title:"Базова карта (voyager)"},arcgisonline:{url:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}.png",preview:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/7/47/69.png",title:"ESRI Online Imagery(2022-2023)"},none:{}},n=e.ref("gki"),r=Pe("base",{source:{type:"raster",tiles:[o[n.value].url]},layer:{id:"base",type:"raster",source:"base"},beforeId:0});function m(s){if(n.value=s,!o[s].url)return r.setVisible(!1);r.setVisible(!0),r.setTiles([o[s].url])}return(s,i)=>(e.openBlock(),e.createElementBlock("div",pc,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(o,(p,f)=>e.createElementVNode("div",{key:f,onClick:c=>m(f)},[e.createElementVNode("div",{class:e.normalizeClass(["w-14 h-14 flex items-center justify-center bg-gray-200 rounded-xl shadow-2xs cursor-pointer transition-all border-4",n.value===f?"border-blue-500":"border-gray-200"])},[p.preview?(e.openBlock(),e.createElementBlock("img",{key:0,src:p.preview,alt:p.title,class:"object-cover rounded-lg w-12 h-12"},null,8,uc)):e.createCommentVNode("",!0)],2)],8,fc)),64))]))}}),hc={key:0,class:"legend-widget flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative widget",style:{width:"100%"}},yc={class:"flex flex-col gap-1 p-5"},bc={class:"flex items-center justify-between w-full text-sm text-gray-800 ml-2"},kc=e.defineComponent({__name:"MapLegend",props:{items:{}},setup(t){const o=t,{map:n,ready:r}=ge(),m=e.ref([]);let s=null;function i(d){return d?d.map((a,l)=>{var y;const h=(a==null?void 0:a.name)||(a==null?void 0:a.label)||(a==null?void 0:a.title)||(a==null?void 0:a.id)||`Layer ${l+1}`,u=(a==null?void 0:a.color)||(a==null?void 0:a.fill)||((y=a==null?void 0:a.paint)==null?void 0:y.color)||"#3388ff";return{id:`${h}-${l}`,label:h,color:u}}):[]}function p(d){return d!=null&&d.layers?d.layers.filter(a=>{const l=a.paint||{};return l["fill-color"]||l["line-color"]||l["circle-color"]}).map((a,l)=>{var y;const h=a.paint||{},u=h["fill-color"]||h["line-color"]||h["circle-color"]||"#3388ff";return{id:a.id||`layer-${l}`,label:((y=a.metadata)==null?void 0:y.title)||a.id||`Layer ${l+1}`,color:u}}):[]}async function f(){var l;await r();const d=n.value;if(!d)return;const a=(l=d.getStyle)==null?void 0:l.call(d);m.value=p(a)}function c(){const d=n.value;if(!d)return;s==null||s();const a=()=>f();d.on("styledata",a),s=()=>d.off("styledata",a)}return e.watch(()=>o.items,async d=>{d!=null?(m.value=i(d),s==null||s()):(await r(),c(),f())},{immediate:!0,deep:!0}),e.onMounted(async()=>{(o.items===void 0||o.items===null)&&(await r(),c(),f())}),e.onBeforeUnmount(()=>{s==null||s(),s=null}),(d,a)=>m.value.length?(e.openBlock(),e.createElementBlock("div",hc,[e.createElementVNode("div",yc,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,l=>(e.openBlock(),e.createElementBlock("div",{key:l.id,class:"flex items-center"},[e.createElementVNode("span",{class:"shrink-0 size-2.5 inline-block me-2.5 h-[10px] w-[10px] rounded-full",style:e.normalizeStyle({background:l.color})},null,4),e.createElementVNode("span",bc,[e.createElementVNode("span",null,e.toDisplayString(l.label),1)])]))),128))])])):e.createCommentVNode("",!0)}});function xc(){const{map:t,ready:o}=ge(),n=e.ref(null),r=e.ref(null),m=e.ref(null);let s=null,i=null,p=null;function f(u){return u.map(y=>{if(typeof y=="string")return{key:y,label:y};const g=(y==null?void 0:y.name)||(y==null?void 0:y.field);if(!g)return null;const b=(y==null?void 0:y.label)||(y==null?void 0:y.ua)||(y==null?void 0:y.title)||g;return{key:g,label:b}}).filter(y=>!!(y&&y.key))}function c(u,y){var b;const g=(b=u==null?void 0:u.getCanvas)==null?void 0:b.call(u);g&&(g.style.cursor=y??"")}function d(u){s&&(u==null||u.off("mousemove",s),s=null),i&&(u==null||u.off("mouseleave",i),u==null||u.off("mouseout",i),i=null),c(u,null)}function a(u){if(!u.length)return null;if(!p)return u[0];const y=g=>{var b;if(p!=null&&p.layerIds&&p.layerIds.length){const k=(b=g.layer)==null?void 0:b.id;if(!k||!p.layerIds.includes(String(k)))return!1}return!(p!=null&&p.sourceId&&String(g.source)!==p.sourceId)};return u.find(y)||null}async function l(u,y){var k;await o();const g=t.value;if(!g)return;const b=f(u);if(d(g),p=y?{...y,sourceId:y.sourceId!==void 0?String(y.sourceId):void 0,layerIds:(k=y.layerIds)==null?void 0:k.map(B=>String(B))}:null,!b.length){n.value=null,r.value=null;return}s=B=>{var z;if((z=B==null?void 0:B.originalEvent)!=null&&z.buttons)return;const j=g.queryRenderedFeatures(B.point),N=a(j);if(!N){n.value=null,r.value=null,m.value=null,c(g,null);return}const V=N.properties||{};r.value=[B.point.x,B.point.y],n.value=b.map(O=>({field:O.label,value:V[O.key]})),m.value=N,c(g,"default")},i=()=>{n.value=null,r.value=null,m.value=null,c(g,null)},g.on("mousemove",s),g.on("mouseleave",i),g.on("mouseout",i)}function h(){const u=t.value;u&&d(u),p=null,n.value=null,r.value=null,m.value=null}return{popupContent:n,popupCoords:r,popupFeature:m,enable:l,disable:h}}const wc={class:"popup-card relative w-full overflow-hidden rounded-2xl border border-blue-100 bg-white/95 shadow-2xl backdrop-blur-sm"},_c={key:0,class:"popup-image-single overflow-hidden"},Vc=["src"],Ec={key:1,class:"border-b border-gray-200 px-3 py-2 text-sm font-semibold text-gray-800"},Bc={class:"px-3 py-2 text-xs text-gray-600"},Nc={class:"w-full border-collapse"},Cc={class:"w-1/2 break-words pb-1 pr-2 font-medium text-gray-700"},$c={class:"w-1/2 break-words pb-1 pl-2 text-right"},Lc={key:0,class:"inline-block rounded px-2 py-0.5 text-xs font-semibold text-yellow-800",style:{"background-color":"rgba(250, 204, 21, 0.25)"}},Sc={key:1},Fc=F(e.defineComponent({__name:"MapPopup",props:{fields:{},sourceId:{}},setup(t){const o=t,{popupContent:n,popupCoords:r,popupFeature:m,enable:s,disable:i}=xc(),p=e.ref(null),f=e.ref({left:"-9999px",top:"-9999px"}),c=e.computed(()=>o.fields??[]),d=e.computed(()=>!!(n.value&&n.value.length)),a=e.computed(()=>{var g;return((g=m.value)==null?void 0:g.properties)??{}}),l=e.computed(()=>c.value.filter(g=>g.meta==="image").map(g=>{var b;return(b=a.value)==null?void 0:b[g.name||g.field||""]}).filter(g=>!!g)),h=e.computed(()=>{var B;const g=c.value.find(j=>j.meta==="title");if(!g)return"";const b=g.name||g.field;return(b?(B=a.value)==null?void 0:B[b]:void 0)??""}),u=e.computed(()=>c.value.filter(g=>g.meta!=="image").filter(g=>g.meta!=="title").map(g=>{var j;const b=g.name||g.field,B=(b?(j=a.value)==null?void 0:j[b]:void 0)??"—";return{key:b||String(g.label||g.ua||Math.random()),label:g.ua||g.label||g.title||b||"",display:B,meta:g.meta}}).filter(g=>g.label));function y(){if(!d.value||!r.value||!p.value){f.value={left:"-9999px",top:"-9999px"};return}const g=p.value;g.offsetWidth,g.offsetHeight;const b=r.value[0]+18,k=r.value[1]+18;f.value={left:`${b}px`,top:`${k}px`}}return e.watch(()=>({fields:o.fields,sourceId:o.sourceId}),({fields:g,sourceId:b})=>{const k=typeof b=="number"?String(b):b||void 0;g&&g.length?s(g,{sourceId:k}).catch(B=>console.error("Failed to enable popup",B)):i()},{immediate:!0,deep:!0}),e.watch([r,n],()=>{e.nextTick(()=>y())}),e.onBeforeUnmount(()=>{i()}),(g,b)=>d.value?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"popupRef",ref:p,class:"absolute z-30 w-[280px] pointer-events-none text-gray-800",style:e.normalizeStyle(f.value)},[e.createElementVNode("div",wc,[l.value.length?(e.openBlock(),e.createElementBlock("div",_c,[e.createElementVNode("img",{src:l.value[0],alt:"popup preview",class:"h-40 w-full object-cover"},null,8,Vc)])):e.createCommentVNode("",!0),h.value?(e.openBlock(),e.createElementBlock("div",Ec,e.toDisplayString(h.value),1)):e.createCommentVNode("",!0),e.createElementVNode("div",Bc,[e.createElementVNode("table",Nc,[e.createElementVNode("tbody",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(u.value,k=>(e.openBlock(),e.createElementBlock("tr",{key:k.key,class:"align-top"},[e.createElementVNode("td",Cc,e.toDisplayString(k.label),1),e.createElementVNode("td",$c,[k.meta==="badge"?(e.openBlock(),e.createElementBlock("span",Lc,e.toDisplayString(k.display),1)):(e.openBlock(),e.createElementBlock("span",Sc,e.toDisplayString(k.display),1))])]))),128))])])])])],4)):e.createCommentVNode("",!0)}}),[["__scopeId","data-v-fc0a86c1"]]),jc=e.defineComponent({__name:"MapDataLayer",props:{id:{},layer:{},styleYaml:{}},setup(t){var a;const{map:o,flyTo:n}=ge(),r=t,m=`${location.origin}/api/vtile/${r.id}/ua/{z}/{x}/{y}.vmt`,s=Pe("pois",{source:{type:"vector",tiles:[m],minzoom:0,maxzoom:14},layer:{id:"pois",source:"pois","source-layer":r.id,style:(a=r.layer)==null?void 0:a.style}});n({center:[34.4924,48.45658],animate:!1});let i=null;function p(){i&&clearTimeout(i),i=setTimeout(()=>{i=null,d().catch(l=>console.error("Failed to update map layer",l))},300)}async function f(l){return(await fetch(`/api/gis-service/${r.id}/${l}`).then(u=>u.json())).rows}const c=["#440154","#482878","#3e4989","#31688e","#26828e","#1f9e89","#35b779","#6ece58","#b5de2b","#fde725"];async function d(){if(o.value){if(r.styleYaml.colorAttr){const h=await f(r.styleYaml.colorAttr);r.styleYaml.colors=h.reduce((u,y,g)=>({...u,[y.id.toString()]:c[g]}),{})}s.setStyle(r.styleYaml)}}return e.watch(()=>r.styleYaml,p),e.onBeforeUnmount(()=>{s.remove()}),(l,h)=>null}});function Ic(t,o){return t||o||null}function vc(t){const{map:o,ready:n}=ge(),r=e.ref(""),m=e.computed(()=>typeof t=="function"?t()??null:t??null);async function s(f,c){return f.getSource(c)?f.getSource(c):new Promise(d=>{const a=l=>{if(l.sourceId===c){const h=f.getSource(c);h&&(f.off("sourcedata",a),d(h))}};f.on("sourcedata",a)})}async function i(f,c){var g,b,k;const d=Ic(c,m.value);if(!d)return;await n();const a=o.value;if(!a)return;const l=a.getSource(d)??await s(a,d);if(!l)return;const h=Array.isArray(l.tiles)?l.tiles:Array.isArray((g=l.options)==null?void 0:g.tiles)?l.options.tiles:void 0;if(!h||h.length===0)return;const u=String(h[0]).split("?filter=")[0];if(!u)return;const y=f?`${u}?filter=${encodeURIComponent(f)}`:u;typeof l.setTiles=="function"?l.setTiles([y]):Array.isArray(l.tiles)?l.tiles=[y]:Array.isArray((b=l.options)==null?void 0:b.tiles)&&(l.options.tiles=[y]),r.value=f,(k=a.triggerRepaint)==null||k.call(a)}async function p(f){await i("",f)}return{filter:r,setFilter:i,clearFilter:p}}const Dc=F(e.defineComponent({__name:"MapFilter",props:{layerId:{},position:{},class:{}},emits:["change"],setup(t,{expose:o,emit:n}){const r=t,m=n,s=e.computed(()=>r.position??"top-right"),i=e.computed(()=>{if(s.value==="custom")return"";const u="absolute pointer-events-none z-30";switch(s.value){case"top-left":return`${u} top-4 left-4`;case"bottom-left":return`${u} bottom-4 left-4`;case"bottom-right":return`${u} bottom-4 right-4`;default:return`${u} top-4 right-4`}}),p=e.computed(()=>[i.value,r.class].filter(Boolean).join(" ")),f=()=>r.layerId??null,{setFilter:c,clearFilter:d,filter:a}=vc(f);async function l(u){await c(u),m("change",u)}async function h(u){await d(u),m("change","")}return e.watch(()=>r.layerId,u=>{u&&(a.value?c(a.value,u):d(u))}),o({apply:l,clear:h,filter:a}),(u,y)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(p.value)},[e.renderSlot(u.$slots,"default",{applyFilter:l,clearFilter:h,filter:e.unref(a)})],2))}}),[["__scopeId","data-v-54fdbad9"]]),Ac={class:"flex h-screen bg-gradient-to-br from-slate-50 to-white"},Mc={class:"flex-1 relative overflow-hidden"},Tc={class:"absolute top-0 left-0 w-full z-20"},zc={class:"flex items-center justify-between bg-white/80 backdrop-blur border-b border-gray-200 px-6 py-3 shadow-sm gap-4"},Pc={class:"flex items-center gap-3"},Uc={class:"font-semibold text-lg text-gray-800 line-clamp-1"},Oc={class:"text-xs text-gray-500 truncate"},qc=["title"],Rc={class:"w-full h-full bg-gradient-to-br from-sky-50 via-white to-blue-50 flex items-center justify-center relative pt-[64px]"},Hc={class:"relative w-full h-full"},Wc={class:"absolute top-4 left-4 z-20"},Zc={class:"absolute bottom-4 left-4 z-20"},Yc={class:"w-[650px] bg-white border-l border-gray-100 flex flex-col overflow-hidden shadow-lg"},Gc={class:"flex-1 flex flex-col h-full"},Jc={class:"px-3 pt-3 pb-2 border-b border-gray-100"},Kc={class:"items-center justify-center text-muted-foreground grid w-full grid-cols-6 h-12 p-1 bg-gray-50 rounded-xl shadow-sm"},Qc=["aria-selected","aria-controls","id","tabindex","onClick"],Xc={class:"leading-none"},ed={class:"flex flex-col flex-1 overflow-y-hidden p-3"},td={__name:"service",setup(t){const o=ye.useRoute(),n=ye.useRouter(),r=o.params.id,m=e.ref(null),s=e.ref([]),i=e.ref(null),p=e.ref(""),f=e.ref([]),c=e.ref([]),d=e.computed(()=>{var g,b;return((g=i.value)==null?void 0:g.id)??((b=i.value)==null?void 0:b.service_id)??null}),a=[{key:"style",label:"Style",icon:xi},{key:"popup",label:"Popup",icon:ji},{key:"filter",label:"Filter",icon:Ai},{key:"legend",label:"Legend",icon:Ei},{key:"card",label:"Card",icon:$i}],l=a.map(g=>g.key),h=e.ref("style");e.onMounted(async()=>{const g=o.query.tab;g&&l.includes(g)&&(h.value=g),await u()}),e.watch(h,g=>{o.query.tab!==g&&n.replace({query:{...o.query,tab:g}})}),e.watch(()=>o.query.tab,g=>{g&&l.includes(g)&&h.value!==g&&(h.value=g)});const u=async()=>{var g,b;try{const k=await fetch(`/api/gis-service/${r}`);if(!k.ok)throw new Error(`${k.status}`);const B=await k.json();s.value=B||{},f.value=[...B.popup],m.value=((g=B==null?void 0:B.tokens)==null?void 0:g.edit)||null,i.value=B||null,p.value=B.style||"",f.value=Array.isArray((b=i.value)==null?void 0:b.popup)?[...i.value.popup]:[]}catch(k){console.error("Failed to fetch map info",k)}try{const B=await(await fetch(`/api/data/gis.services.table/${r}`)).json()}catch(k){console.error("Failed to fetch map info",k)}};e.watch(()=>{var g;return(g=i.value)==null?void 0:g.style},g=>{g?typeof g=="string"?p.value=g:p.value=JSON.parse(JSON.stringify(g)):p.value=""},{deep:!0});const y={style:Ui,popup:nc,legend:rc,card:lc,filter:ac};return(g,b)=>{var k,B,j,N;return e.openBlock(),e.createElementBlock("div",Ac,[e.createElementVNode("div",Mc,[e.createElementVNode("div",Tc,[e.createElementVNode("div",zc,[e.createElementVNode("div",Pc,[e.createElementVNode("button",{onClick:b[0]||(b[0]=V=>g.$router.back()),class:"inline-flex items-center px-3 py-1.5 rounded-md bg-sky-100 hover:bg-sky-200 text-sky-700 font-medium text-sm transition"},[...b[4]||(b[4]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4 mr-1",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 19l-7-7 7-7"})],-1),e.createTextVNode(" Назад ",-1)])]),e.createElementVNode("div",null,[e.createElementVNode("div",Uc,e.toDisplayString((k=i.value)==null?void 0:k.name),1),e.createElementVNode("div",Oc," Сервіс: "+e.toDisplayString((B=i.value)==null?void 0:B.service_key),1)])]),e.createElementVNode("div",{class:"max-w-xl text-xs text-gray-600 truncate",title:(j=i.value)==null?void 0:j.description},e.toDisplayString((N=i.value)==null?void 0:N.description),9,qc)])]),e.createElementVNode("div",Rc,[e.createElementVNode("div",Hc,[e.createVNode(ic,null,{default:e.withCtx(()=>{var V,z,O;return[(V=i.value)!=null&&V.service_id?(e.openBlock(),e.createBlock(jc,{key:0,id:(z=i.value)==null?void 0:z.service_id,layer:i.value,"style-yaml":p.value},null,8,["id","layer","style-yaml"])):e.createCommentVNode("",!0),d.value?(e.openBlock(),e.createBlock(Dc,{key:1,"layer-id":d.value},null,8,["layer-id"])):e.createCommentVNode("",!0),e.createElementVNode("div",Wc,[e.createVNode(gc)]),e.createElementVNode("div",Zc,[e.createVNode(kc,{items:((O=i.value)==null?void 0:O.legend)||null},null,8,["items"])]),e.createVNode(Fc,{fields:f.value,"source-id":d.value},null,8,["fields","source-id"])]}),_:1})])])]),e.createElementVNode("div",Yc,[e.createElementVNode("div",Gc,[e.createElementVNode("div",Jc,[e.createElementVNode("div",Kc,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(a,V=>e.createElementVNode("button",{key:V.key,type:"button",role:"tab","aria-selected":h.value===V.key,"aria-controls":`radix-r0-content-${V.key}`,id:`radix-r0-trigger-${V.key}`,class:e.normalizeClass(["whitespace-nowrap ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 flex flex-col items-center justify-center gap-0.5 py-1 px-1 text-[9px] font-medium transition-all duration-300 hover:bg-white/70 rounded-lg group",h.value===V.key?"bg-white shadow-sm text-gray-700":""]),tabindex:h.value===V.key?0:-1,onClick:z=>h.value=V.key},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(V.icon),{class:"h-3.5 w-3.5 mb-0.5"})),e.createElementVNode("span",Xc,e.toDisplayString(V.label),1)],10,Qc)),64))])]),e.createElementVNode("div",ed,[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(y[h.value]),{"map-info":i.value,token:d.value,fields:s.value.fields,"filter-fields":s.value.filters,"style-yaml":p.value,"onUpdate:styleYaml":b[1]||(b[1]=V=>p.value=V),"popup-fields":f.value,"onUpdate:popupFields":b[2]||(b[2]=V=>f.value=V),"filter-scheme":c.value,"onUpdate:filterScheme":b[3]||(b[3]=V=>c.value=V),onUpdate:u},null,40,["map-info","token","fields","filter-fields","style-yaml","popup-fields","filter-scheme"]))])])])])}}};function od(t){t.component("MapCustom",Be)}W.MapCustom=Be,W.Register=hi,W.Service=td,W.default=Be,W.install=od,Object.defineProperties(W,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}));
|
|
31
|
+
*/const Gt=ze("trash",[["path",{d:"M3 6h18",key:"d0wm0j"}],["path",{d:"M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6",key:"4alrt4"}],["path",{d:"M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2",key:"v07s0e"}]]),Zt={class:"flex items-center justify-end col-span-3 gap-2"},Qt={class:"flex justify-end p-[20px] gap-[10px] border-t w-full"},Xt=e.defineComponent({__name:"vs-datatable-controls",props:e.mergeModels({index:{},data:{},scheme:{}},{columns:{type:Array,default:()=>[]},columnsModifiers:{}}),emits:["update:columns"],setup(t){const n=e.defineAsyncComponent(()=>import("@opengis/form")),r=e.defineAsyncComponent(()=>import("@opengis/core").then(f=>f.VsModal)),l=t,o=e.useModel(t,"columns"),i=e.ref(!1),a=e.ref({}),s=e.ref({...l.data||{}}),d=()=>o.value=o.value.filter((f,m)=>m!==l.index),c=async()=>{const f=a.value.validate();if(f){K.notify({type:"warning",title:"Validation",message:Object.entries(f).map(([m,p])=>`${m}: ${p}`).join(`
|
|
32
|
+
`)});return}o.value[l.index]=s.value,i.value=!1};return(f,m)=>(e.openBlock(),e.createElementBlock("div",Zt,[e.createElementVNode("button",{onClick:m[0]||(m[0]=p=>{i.value=!0}),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 hover:text-accent-foreground h-8 w-8 rounded-full hover:bg-gray-100"},[e.createVNode(e.unref(Wt),{class:"w-4 h-4"})]),e.createElementVNode("button",{onClick:d,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 h-8 w-8 rounded-full hover:bg-red-100 text-red-600 hover:text-red-700"},[e.createVNode(e.unref(Gt),{class:"w-4 h-4"})]),e.createVNode(e.unref(r),{size:"lg",visible:i.value,"onUpdate:visible":m[4]||(m[4]=p=>i.value=p),title:"Редагувати поле"},{footer:e.withCtx(()=>[e.createElementVNode("div",Qt,[e.createElementVNode("button",{type:"button",class:"py-2 px-3 inline-flex items-center gap-x-2 text-sm whitespace-nowrap text-black border border-gray-200 rounded-lg hover:bg-gray-100 duration-300",onClick:m[3]||(m[3]=p=>i.value=!1)}," Скасувати "),e.createElementVNode("button",{class:"py-2 px-3 inline-flex items-center gap-x-2 text-sm whitespace-nowrap text-white bg-blue-500 rounded-lg !border-gray-200 hover:bg-blue-700 duration-300",onClick:c}," Зберегти ")])]),default:e.withCtx(()=>[e.createVNode(e.unref(n),{values:s.value,"onUpdate:values":m[1]||(m[1]=p=>s.value=p),schema:f.scheme,form:a.value,"onUpdate:form":m[2]||(m[2]=p=>a.value=p)},null,8,["values","schema","form"])]),_:1},8,["visible"])]))}}),Jt={mounted(t){setTimeout(()=>{t.scrollWidth>t.clientWidth?t.setAttribute("title",t.textContent):t.removeAttribute("title")})},updated(t){setTimeout(()=>{t.scrollWidth>t.clientWidth?t.setAttribute("title",t.textContent):t.removeAttribute("title")})}},en={array:"purple",boolean:"red",date:"red",datetime:"purple",number:"green",text:"blue",file:"yellow",select:"yellow",slug:"green",image:"blue",badge:"orange",title:"blue",features:"green",status:"red",tags:"yellow",category:"purple",check:"green",range:"orange",autocomplete:"yellow",other:"gray","yes/no":"green"},qe=t=>en[t==null?void 0:t.toLowerCase()]||"gray",tn=["array","boolean","date","datetime","number","text","file","select","slug","image","badge","title","features","status","tags","category","check","range","autocomplete"],He=t=>{var n;return tn.includes((n=t||"")==null?void 0:n.toLowerCase())},nn={key:0,class:"flex items-center justify-between mb-6"},rn={class:"flex justify-end w-full"},on={class:"overflow-hidden bg-white border border-gray-200 shadow-sm rounded-xl flex flex-col"},ln={class:"table-scroll-wrapper flex-1 overflow-y-auto"},an={class:"table-fixed w-full text-[13px]"},sn={class:"bg-gray-50 border-b border-gray-200"},cn={key:0},dn=["onDragstart","onDragover","onDrop"],mn={key:0,class:"flex w-fit items-center gap-2 text-left"},pn={class:"flex-1 min-w-0"},fn={class:"font-medium text-gray-900 truncate"},un={class:"text-xs text-gray-500"},gn={key:0,class:"flex items-center justify-center"},hn={key:0,class:"inline-flex items-center px-2 py-1 h-fit text-[13px] font-medium rounded-md ring-1 ring-inset ring-gray-500/10 bg-gray-100"},yn={key:1,class:"text-gray-500 text-sm"},xn={key:2},kn={class:"px-6 py-4"},bn={key:1},wn=["colspan"],_n=e.defineComponent({__name:"vs-datatable",props:e.mergeModels({columnsScheme:{},formScheme:{},addButton:{type:Boolean,default:!0},mainColWidth:{default:""}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(t,{expose:n}){const r=e.defineAsyncComponent(()=>import("@opengis/core").then(k=>k.VsModal)),l=e.defineAsyncComponent(()=>import("@opengis/form")),o=e.useModel(t,"modelValue");n({openCreateDialog:()=>{s.value=!0}});const i=t,a=e.ref({}),s=e.ref(!1),d=e.ref({}),c=e.ref(null),f=e.computed({get(){return Array.isArray(o.value)?o.value:o.value&&Array.isArray(o.value.columns)?o.value.columns:[]},set(k){Array.isArray(o.value)?o.value=k:o.value&&Array.isArray(o.value.columns)&&(o.value.columns=k)}}),m=e.computed(()=>{const k=i.columnsScheme.map(w=>w.key);return k.includes("name")&&k.includes("ua")||k.includes("id")&&k.includes("label")?[{key:"main",label:"Назва",type:"main",width:"100%"},...i.columnsScheme.filter(w=>!["name","ua","id","label"].includes(w.key))]:i.columnsScheme});function p(){s.value=!1,d.value={},c.value=null}async function g(){const k=a.value.validate();if(k){K.notify({type:"warning",title:"Validation",message:Object.entries(k).map(([w,b])=>`${w}: ${b}`).join(`
|
|
33
|
+
`)});return}if(c.value===null)f.value=[...f.value,{...d.value}];else{const w=[...f.value];w[c.value]={...d.value},f.value=w}p()}const u=e.ref(null),h=e.ref(null),x=k=>{u.value=k},E=k=>{h.value=k},y=k=>{if(u.value===null||u.value===k){u.value=null,h.value=null;return}const w=[...f.value],[b]=w.splice(u.value,1);w.splice(k,0,b),f.value=w,u.value=null,h.value=null};return(k,w)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[k.addButton?(e.openBlock(),e.createElementBlock("div",nn,[e.createElementVNode("div",rn,[e.createElementVNode("button",{onClick:w[0]||(w[0]=b=>s.value=!0),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...w[5]||(w[5]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4 mr-2",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Додати поле ",-1)])])])])):e.createCommentVNode("",!0),e.createElementVNode("div",on,[e.createElementVNode("div",ln,[e.createElementVNode("table",an,[e.createElementVNode("colgroup",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,b=>(e.openBlock(),e.createElementBlock("col",{key:b.key,style:e.normalizeStyle(b.type==="main"?`width: ${k.mainColWidth}`:b.width?`width: ${b.width}`:"auto")},null,4))),128)),w[6]||(w[6]=e.createElementVNode("col",null,null,-1))]),e.createElementVNode("thead",null,[e.createElementVNode("tr",sn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,b=>(e.openBlock(),e.createElementBlock("th",{key:b.key,class:"px-6 py-4"},e.toDisplayString(b.label),1))),128)),w[7]||(w[7]=e.createElementVNode("th",{class:"px-6 py-4"},"Дії",-1))])]),f.value.length?(e.openBlock(),e.createElementBlock("tbody",cn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(f.value,(b,v)=>(e.openBlock(),e.createElementBlock("tr",{key:b.id||b.name||v,class:e.normalizeClass(["transition-colors hover:bg-gray-50/50 cursor-move",{"opacity-50":u.value===v,"border-t-2 border-b-2 border-blue-500 bg-blue-50":h.value===v}]),draggable:"true",onDragstart:S=>x(v),onDragover:e.withModifiers(S=>E(v),["prevent"]),onDrop:S=>y(v)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,S=>(e.openBlock(),e.createElementBlock("td",{key:S.key,class:"px-6 py-4 align-middle text-center"},[S.type==="main"?(e.openBlock(),e.createElementBlock("div",mn,[w[8]||(w[8]=e.createElementVNode("span",{class:"drag-handle cursor-move mr-2 text-gray-400"},"☰",-1)),e.unref(He)(b.format==="yes/no"?"check":b.format||b.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["flex items-center justify-center p-1 rounded",`bg-${e.unref(qe)(b.format==="yes/no"?"check":b.format||b.type)}-100`])},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(b.format==="yes/no"?"icon-check":`icon-${b.format||b.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",pn,[e.withDirectives((e.openBlock(),e.createElementBlock("p",fn,[e.createTextVNode(e.toDisplayString(b.name||b.id),1)])),[[e.unref(Jt)]]),e.createElementVNode("p",un,e.toDisplayString(b.ua||b.label),1)])])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[S.type==="color"?(e.openBlock(),e.createElementBlock("div",gn,[e.createElementVNode("div",{class:e.normalizeClass(["w-4 h-4 rounded-full align-middle",`bg-[${b[S.key]}]`])},null,2)])):["format","type","meta"].includes(S.key)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[b[S.key]?(e.openBlock(),e.createElementBlock("span",hn,e.toDisplayString(b[S.key]),1)):(e.openBlock(),e.createElementBlock("span",yn,"Не вказано"))],64)):(e.openBlock(),e.createElementBlock("span",xn,e.toDisplayString(b[S.key]),1))],64))]))),128)),e.createElementVNode("td",kn,[e.createVNode(Xt,{columns:f.value,"onUpdate:columns":w[1]||(w[1]=S=>f.value=S),data:b,index:v,scheme:k.formScheme},null,8,["columns","data","index","scheme"])])],42,dn))),128))])):(e.openBlock(),e.createElementBlock("tr",bn,[e.createElementVNode("td",{colspan:m.value.length+1,class:"text-gray-500 text-center py-4"}," Поля не знайдені ",8,wn)]))])])]),e.createVNode(e.unref(r),{title:"Створити поле",size:"lg",visible:s.value,"onUpdate:visible":w[4]||(w[4]=b=>s.value=b)},{footer:e.withCtx(()=>[e.createElementVNode("div",{class:"flex justify-end p-[20px] gap-[10px] border-t w-full"},[e.createElementVNode("button",{type:"button",onClick:p,class:"px-4 py-2 rounded bg-gray-100 text-gray-700"}," Скасувати "),e.createElementVNode("button",{type:"button",onClick:g,class:"px-4 py-2 rounded bg-blue-600 text-white"}," Зберегти1 ")])]),default:e.withCtx(()=>[e.createVNode(e.unref(l),{ref_key:"form",ref:a,modelValue:d.value,"onUpdate:modelValue":w[2]||(w[2]=b=>d.value=b),schema:k.formScheme,form:a.value,"onUpdate:form":w[3]||(w[3]=b=>a.value=b)},null,8,["modelValue","schema","form"])]),_:1},8,["visible"])],64))}}),D=(t,n)=>{const r=t.__vccOpts||t;for(const[l,o]of n)r[l]=o;return r},te=D(_n,[["__scopeId","data-v-c5e2c5b4"]]),En={class:"p-4 text-[13px]"},Nn={class:"grid grid-cols-2 gap-x-6 gap-y-2"},Cn=["id","checked","onChange"],Bn={class:"ml-2 flex-1 min-w-0 flex items-center gap-2"},Vn={class:"font-medium text-gray-900 truncate"},An={class:"text-xs text-gray-500"},$n={class:"flex justify-end gap-2 p-4 border-t w-full"},oe=e.defineComponent({__name:"import-fields-dialog",props:e.mergeModels({fields:{default:()=>[]},title:{},idPrefix:{default:"import"},confirmText:{default:"Імпортувати"},cancelText:{default:"Скасувати"}},{visible:{type:Boolean,default:!1},visibleModifiers:{},selection:{default:[]},selectionModifiers:{}}),emits:e.mergeModels(["confirm","cancel"],["update:visible","update:selection"]),setup(t,{emit:n}){const r=e.useModel(t,"visible"),l=e.useModel(t,"selection"),o=t,i=n,a=e.defineAsyncComponent(()=>import("@opengis/core").then(y=>y.VsModal)),s=e.computed(()=>Array.isArray(o.fields)?o.fields.filter(Boolean):[]),d=y=>(y==null?void 0:y.name)??(y==null?void 0:y.id)??(y==null?void 0:y.key)??(y==null?void 0:y.code)??(y==null?void 0:y.field)??(y==null?void 0:y.value)??"",c=y=>String(d(y)??"").trim(),f=y=>(y==null?void 0:y.title)??(y==null?void 0:y.label)??c(y),m=e.computed(()=>new Set(l.value.map(y=>String(y??"").trim()))),p=y=>m.value.has(c(y)),g=y=>{const k=c(y);if(!k)return;const w=new Set(m.value);w.has(k)?w.delete(k):w.add(k),l.value=Array.from(w)},u=e.computed(()=>o.confirmText||"Імпортувати"),h=e.computed(()=>o.cancelText||"Скасувати"),x=()=>{r.value=!1,i("cancel")},E=()=>{i("confirm"),r.value=!1};return(y,k)=>(e.openBlock(),e.createBlock(e.unref(a),{visible:r.value,"onUpdate:visible":k[0]||(k[0]=w=>r.value=w),title:y.title,size:"lg"},{footer:e.withCtx(()=>[e.createElementVNode("div",$n,[e.createElementVNode("button",{onClick:x,class:"px-4 py-2 rounded bg-gray-100 text-gray-700"},e.toDisplayString(h.value),1),e.createElementVNode("button",{onClick:E,class:"px-4 py-2 rounded bg-blue-600 text-white"},e.toDisplayString(u.value),1)])]),default:e.withCtx(()=>[e.createElementVNode("div",En,[e.createElementVNode("div",Nn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,w=>(e.openBlock(),e.createElementBlock("label",{key:c(w),class:"flex items-center hover:bg-gray-100 rounded p-2 cursor-pointer"},[e.createElementVNode("input",{type:"checkbox",id:`${y.idPrefix}-${c(w)}`,checked:p(w),onChange:b=>g(w)},null,40,Cn),e.createElementVNode("div",Bn,[e.unref(He)(w.type)?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(`bg-${e.unref(qe)(w.type)}-100 p-1 rounded`)},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(`icon-${w.type}`),{class:"w-4 h-4"}))],2)):e.createCommentVNode("",!0),e.createElementVNode("div",null,[e.createElementVNode("p",Vn,e.toDisplayString(c(w)),1),e.createElementVNode("p",An,e.toDisplayString(f(w)),1)])])]))),128))])])]),_:1},8,["visible","title"]))}});function le(t){return t==null?"":String(t).trim()}function Q(t){return le((t==null?void 0:t.name)??(t==null?void 0:t.id)??(t==null?void 0:t.key)??(t==null?void 0:t.code)??(t==null?void 0:t.field)??(t==null?void 0:t.value)??"")}function ae(t,n,r){const l=Array.isArray(t)?[...t]:[],o=Array.isArray(n)?n:[],{selectedKeys:i,resolveKey:a}=r,s=new Set;for(const m of i){const p=le(m);p&&s.add(p)}if(s.size===0)return[];const d=m=>le(a(m)),c=[],f=new Set;for(const m of l){const p=d(m);!p||!s.has(p)||(c.push(m),f.add(p))}for(const m of o){const p=d(m);!p||f.has(p)||!s.has(p)||(c.push(m),f.add(p))}return c}const vn={class:"vs-form"},Sn={class:"vs-form__body auto-rows-max container"},Fn={class:"flex flex-wrap"},Ln={class:"h-fit w-full mb-6 px-2"},Tn={class:"h-fit w-full flex flex-wrap"},Mn={class:"w-full"},Dn=e.defineComponent({__name:"list-tab",props:e.mergeModels({fields:{}},{data:{default:{}},dataModifiers:{},form:{},formModifiers:{}}),emits:["update:data","update:form"],setup(t){const n=e.useModel(t,"data"),r=e.useModel(t,"form"),l=t,o=e.computed(()=>Array.isArray(l.fields)?l.fields:[]),i=y=>Q(y||{}),a=e.defineAsyncComponent(()=>import("@opengis/form")),s=e.ref(),d=e.ref(!1),c=e.ref([]),f=()=>{const y=p.value.map(k=>i(k)).filter(k=>k.length>0);c.value=[...y],d.value=!0},m=e.computed(()=>{var y,k;return((y=n.value)==null?void 0:y.token)||((k=n.value)==null?void 0:k.id)||"register-form"}),p=e.computed({get:()=>(n.value||(n.value={}),Array.isArray(n.value.columns)||(n.value.columns=[]),n.value.columns),set:y=>{n.value||(n.value={}),n.value.columns=Array.isArray(y)?y:[]}}),g=e.computed({get:()=>n.value||{},set:y=>{var w;const k=Array.isArray((w=n.value)==null?void 0:w.columns)?n.value.columns:[];n.value={...n.value,...y,columns:k}}});e.watch(()=>s.value,y=>{r.value=y||null},{immediate:!0}),e.watch(d,y=>{y||(c.value=[])});const u=()=>{const y=new Set(c.value.map(b=>le(b)).filter(b=>b.length>0)),k=Array.isArray(p.value)?[...p.value]:[],w=o.value.filter(b=>y.has(i(b))).map(b=>{const v=i(b);return{...b,name:v,ua:b.title??b.label??v,type:b.type||"text",meta:b.meta??"features"}});p.value=ae(k,w,{selectedKeys:c.value,resolveKey:i}),d.value=!1,c.value=[]},h={table_name:{type:"text",label:"Table",required:!0,placeholder:"Table",validators:["required"],col:6},name:{type:"text",label:"Name",required:!0,placeholder:"Name",validators:["required"],col:6},description:{type:"text",label:"Description",placeholder:"Description",col:12}},x=[{key:"name",label:"Name",type:"text"},{key:"ua",label:"UA",type:"text"},{key:"meta",label:"Мета",type:"text"}],E={name:{type:"text",label:"Name",required:!0},ua:{type:"text",label:"UA",required:!0},format:{type:"radio",label:"Format",position:"horizontal",required:!0,options:[{text:"Text",id:"text"},{text:"Number",id:"number"},{text:"Date",id:"date"},{text:"File",id:"file"},{text:"Select",id:"select"}]},meta:{type:"combobox",label:"Мета",mode:"combo",required:!0,options:[{text:"Title",id:"title"},{text:"Features",id:"features"},{text:"Status",id:"status"},{text:"Tags",id:"tags"},{text:"Category",id:"category"},{text:"Image",id:"image"}]},data:{type:"text",label:"Класифікатор"}};return e.onBeforeUnmount(()=>{r.value=null}),(y,k)=>(e.openBlock(),e.createElementBlock("div",vn,[e.createElementVNode("div",Sn,[e.createElementVNode("div",Fn,[e.createElementVNode("div",Ln,[(e.openBlock(),e.createBlock(e.unref(a),{ref_key:"formEl",ref:s,key:m.value,schema:h,modelValue:g.value,"onUpdate:modelValue":k[0]||(k[0]=w=>g.value=w)},null,8,["modelValue"]))]),e.createElementVNode("div",Tn,[e.createElementVNode("div",{class:"flex justify-end mb-3 gap-2 w-full"},[e.createElementVNode("button",{onClick:f,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...k[4]||(k[4]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])])]),e.createElementVNode("div",Mn,[e.createVNode(te,{modelValue:p.value,"onUpdate:modelValue":k[1]||(k[1]=w=>p.value=w),"columns-scheme":x,"form-scheme":E,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])])])])]),e.createVNode(oe,{visible:d.value,"onUpdate:visible":k[2]||(k[2]=w=>d.value=w),selection:c.value,"onUpdate:selection":k[3]||(k[3]=w=>c.value=w),fields:o.value,title:"Імпорт колонок","id-prefix":"import-column",onConfirm:u},null,8,["visible","selection","fields"])]))}}),In={class:"vs-form"},jn={class:"vs-form__body auto-rows-max container"},On={class:"flex flex-wrap"},Rn={class:"h-fit w-full flex flex-wrap"},Un={class:"w-full"},Pn=e.defineComponent({__name:"filter-tab",props:e.mergeModels({fields:{}},{data:{default:{}},dataModifiers:{},form:{},formModifiers:{}}),emits:["update:data","update:form"],setup(t){const n=e.useModel(t,"data"),r=e.useModel(t,"form"),l=t,o=e.computed(()=>Array.isArray(l.fields)?l.fields:[]),i=g=>Q(g||{}),a=e.ref(!1),s=e.ref([]),d=()=>{const g=c.value.map(u=>i(u)).filter(u=>u.length>0);s.value=[...g],a.value=!0},c=e.computed({get:()=>(n.value||(n.value={}),Array.isArray(n.value.filters)||(n.value.filters=[]),n.value.filters),set:g=>{n.value||(n.value={}),n.value.filters=Array.isArray(g)?g:[]}});e.watch(a,g=>{g||(s.value=[])});const f=()=>{const g=new Set(s.value.map(x=>le(x)).filter(x=>x.length>0)),u=Array.isArray(c.value)?[...c.value]:[],h=o.value.filter(x=>g.has(i(x))).map(x=>({name:i(x),label:x.title??x.label??i(x),type:x.type||"text"}));c.value=ae(u,h,{selectedKeys:s.value,resolveKey:i}),a.value=!1,s.value=[]},m=[{key:"name",label:"Name",type:"text"},{key:"label",label:"UA",type:"text"},{key:"type",label:"Тип",type:"text"},{key:"data",label:"Класифікатор",type:"text"}],p={name:{type:"text",label:"Name",required:!0,disabled:!0},label:{type:"text",label:"Label",required:!0},type:{type:"radio",label:"Тип",required:!0,position:"horizontal",options:[{text:"Check",id:"check"},{text:"Range",id:"range"},{text:"Date",id:"date"},{text:"Text",id:"text"},{text:"Autocomplete",id:"autocomplete"}]},data:{type:"text",label:"Класифікатор",conditions:["type","in",["autocomplete"]]}};return e.onBeforeUnmount(()=>{r.value=null}),(g,u)=>(e.openBlock(),e.createElementBlock("div",In,[e.createElementVNode("div",jn,[e.createElementVNode("div",On,[u[4]||(u[4]=e.createElementVNode("div",{class:"h-fit w-full flex flex-wrap mb-6 px-2"},[e.createElementVNode("p",{class:"text-sm text-gray-600"}," Налаштуйте фільтри реєстру. Оберіть поля для імпорту або відредагуйте властивості вручну. ")],-1)),e.createElementVNode("div",Rn,[e.createElementVNode("div",{class:"flex justify-end mb-3 gap-2 w-full"},[e.createElementVNode("button",{onClick:d,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...u[3]||(u[3]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])])]),e.createElementVNode("div",Un,[e.createVNode(te,{modelValue:c.value,"onUpdate:modelValue":u[0]||(u[0]=h=>c.value=h),"columns-scheme":m,"form-scheme":p,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])])])])]),e.createVNode(oe,{visible:a.value,"onUpdate:visible":u[1]||(u[1]=h=>a.value=h),selection:s.value,"onUpdate:selection":u[2]||(u[2]=h=>s.value=h),fields:o.value,title:"Імпорт фільтрів","id-prefix":"import-filter",onConfirm:f},null,8,["visible","selection","fields"])]))}}),zn={class:"vs-form"},qn={class:"vs-form__body auto-rows-max container"},Hn={class:"flex flex-wrap"},Yn={class:"h-fit w-full flex flex-wrap"},Kn={class:"w-full"},Wn=e.defineComponent({__name:"card-tab",props:e.mergeModels({fields:{}},{data:{default:{}},dataModifiers:{},form:{},formModifiers:{}}),emits:["update:data","update:form"],setup(t){const n=e.useModel(t,"data"),r=e.useModel(t,"form"),l=t,o=e.computed(()=>Array.isArray(l.fields)?l.fields:[]),i=g=>Q(g||{}),a=e.ref(!1),s=e.ref([]),d=()=>{const g=c.value.map(u=>i(u)).filter(u=>u.length>0);s.value=[...g],a.value=!0},c=e.computed({get:()=>n.value.card,set:g=>{n.value||(n.value={}),n.value.card=Array.isArray(g)?g:[]}});e.watch(a,g=>{var u;if(g){const h=((u=c.value)==null?void 0:u.map(x=>x.name))||[];s.value=[...h]}});const f=()=>{const g=new Set(s.value.map(x=>le(x)).filter(x=>x.length>0)),u=Array.isArray(c.value)?[...c.value]:[],h=o.value.filter(x=>g.has(i(x))).map(x=>{const E=i(x);return{...x,name:E,ua:x.title??x.label??E,format:x.format||x.type||"text",meta:x.meta||"title"}});c.value=ae(u,h,{selectedKeys:s.value,resolveKey:i}),a.value=!1,s.value=[]},m=[{key:"name",label:"Name",type:"text"},{key:"ua",label:"UA",type:"text"},{key:"format",label:"Format",type:"text"}],p={name:{type:"text",label:"Name",required:!0,disabled:!0},label:{type:"text",label:"Label",required:!0},format:{type:"radio",label:"Format",position:"horizontal",required:!0,options:[{text:"Text",id:"text"},{text:"Number",id:"number"},{text:"Date",id:"date"},{text:"File",id:"file"},{text:"Select",id:"select"}]},data:{type:"text",label:"Data"}};return e.onBeforeUnmount(()=>{r.value=null}),(g,u)=>(e.openBlock(),e.createElementBlock("div",zn,[e.createElementVNode("div",qn,[e.createElementVNode("div",Hn,[u[4]||(u[4]=e.createElementVNode("div",{class:"h-fit w-full flex flex-wrap mb-6 px-2"},[e.createElementVNode("p",{class:"text-sm text-gray-600"}," Налаштуйте відображення картки. Оберіть потрібні поля та відредагуйте їхні властивості. ")],-1)),e.createElementVNode("div",Yn,[e.createElementVNode("div",{class:"flex justify-end mb-3 gap-2 w-full"},[e.createElementVNode("button",{onClick:d,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 h-10 px-4 py-2 bg-gradient-to-r from-blue-600 to-blue-500 hover:from-blue-700 hover:to-blue-600 text-white"},[...u[3]||(u[3]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor","stroke-width":"2",class:"mr-1"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 4v16m8-8H4"})],-1),e.createTextVNode(" Імпорт ",-1)])])]),e.createElementVNode("div",Kn,[e.createVNode(te,{modelValue:c.value,"onUpdate:modelValue":u[0]||(u[0]=h=>c.value=h),"columns-scheme":m,"form-scheme":p,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])])])])]),e.createVNode(oe,{visible:a.value,"onUpdate:visible":u[1]||(u[1]=h=>a.value=h),selection:s.value,"onUpdate:selection":u[2]||(u[2]=h=>s.value=h),fields:o.value,title:"Імпорт полів картки","id-prefix":"import-card",onConfirm:f},null,8,["visible","selection","fields"])]))}}),Gn=["","січня","лютого","березня","квітня","травня","червня","липня","серпня","вересня","жовтня","листопада","грудня"];function fe(t){if(!t)return"";const[n,r]=t.split(" ");if(!n)return t;const[l,o,i]=n.split("-");if(!l||!o||!i)return t;const a=parseInt(o,10),s=Gn[a]||o;let d=`${parseInt(i,10)} ${s} ${l}`;if(r){const c=r.split(".")[0],[f,m,p]=c.split(":");f&&m&&p?d+=`, ${f}:${m}:${p}`:f&&m?d+=`, ${f}:${m}`:f&&(d+=`, ${f}`)}return d}const Zn={name:"Template1",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{titleCol(){return this.columns.find(t=>t.meta==="title")},categoryCol(){return this.columns.filter(t=>t.meta==="category")},tagsCol(){return this.columns.filter(t=>t.meta==="tags")},featuresCols(){return this.columns.filter(t=>t.meta==="features")}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const r=this.query_params.map(l=>{const o=Object.keys(l)[0],i=l[o];return`${o}=${encodeURIComponent(t[i])}`}).join("&");return`${this.path}?${r}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const n=this.query_params.map(r=>{const l=Object.keys(r)[0],o=r[l];return`${l}=${encodeURIComponent(t[o])}`}).join("&");return`${this.path}/${t[this.id_key]}?${n}`},formatDate:fe}},Qn={class:"flex justify-between p-4 pb-2 bg-slate-50 gap-4"},Xn={class:"flex items-center justify-between"},Jn={class:"text-lg font-bold line-clamp-2"},er={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 text-foreground ml-2 whitespace-nowrap","data-v0-t":"badge"},tr={key:0,class:"flex"},nr={key:0,class:"h-fit inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 text-foreground ml-2 whitespace-nowrap"},rr={class:"p-4 pt-2"},or={class:"grid grid-cols-2 gap-3 text-sm"},lr={class:"text-gray-500"},ar={class:"font-medium"},ir={class:"items-center p-3 bg-slate-50 flex justify-end"},sr=["href"];function cr(t,n,r,l,o,i){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.items,a=>{var s,d,c;return e.openBlock(),e.createElementBlock("div",{key:a.id,class:"rounded-lg border bg-card text-card-foreground overflow-hidden border-none shadow-md relative","data-v0-t":"card"},[e.createElementVNode("div",Qn,[e.createElementVNode("div",Xn,[e.createElementVNode("h2",Jn,e.toDisplayString(a[`${(s=i.titleCol)==null?void 0:s.name}_text`]||a[(d=i.titleCol)==null?void 0:d.name]||a[(c=i.titleCol)==null?void 0:c.label]||"Не вказано"),1),Array.isArray(i.categoryCol)&&i.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i.categoryCol,f=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:f.name},[a[f.name]?(e.openBlock(),e.createElementBlock("div",er,e.toDisplayString(a[`${f.name}_text`]||a[f.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0)]),Array.isArray(i.tagsCol)&&i.tagsCol.length?(e.openBlock(),e.createElementBlock("div",tr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.tagsCol,f=>(e.openBlock(),e.createElementBlock("div",{key:f.name,class:"mt-2 flex flex-wrap gap-1"},[a[f.name]?(e.openBlock(),e.createElementBlock("span",nr,e.toDisplayString(a[`${f.name}_text`]||a[f.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",rr,[e.createElementVNode("div",or,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.featuresCols,f=>(e.openBlock(),e.createElementBlock("div",{key:f.name,class:"flex items-center gap-1.5"},[e.createElementVNode("span",lr,e.toDisplayString(f.ua||f.label)+": ",1),e.createElementVNode("span",ar,[Array.isArray(a[f==null?void 0:f.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(a[f==null?void 0:f.name],(m,p)=>(e.openBlock(),e.createElementBlock("span",{key:p,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(m),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[f.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(i.formatDate(a[f==null?void 0:f.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(a[f==null?void 0:f.name]||"Немає даних"),1)],64))],64))])]))),128))])]),e.createElementVNode("div",ir,[e.createElementVNode("a",{href:i.getItemLink(a),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 border border-input bg-background hover:bg-accent hover:text-accent-foreground h-9 rounded-md px-3"},[...n[0]||(n[0]=[e.createTextVNode(" Детальніше ",-1),e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-arrow-right ml-1 h-3.5 w-3.5"},[e.createElementVNode("path",{d:"M5 12h14"}),e.createElementVNode("path",{d:"m12 5 7 7-7 7"})],-1)])],8,sr)])])}),128)}const dr=D(Zn,[["render",cr]]),mr={name:"Template2",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{titleCol(){return this.columns.find(t=>t.meta==="title")},categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]},featuresCols(){return this.columns.filter(t=>t.meta==="features")}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const r=this.query_params.map(l=>{const o=Object.keys(l)[0],i=l[o];return`${o}=${encodeURIComponent(t[i])}`}).join("&");return`${this.path}?${r}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const n=this.query_params.map(r=>{const l=Object.keys(r)[0],o=r[l];return`${l}=${encodeURIComponent(t[o])}`}).join("&");return`${this.path}/${t[this.id_key]}?${n}`},formatDate:fe}},pr={class:"p-0"},fr={class:"border-l-4 border-l-slate-400"},ur={class:"p-4"},gr={class:"flex flex-wrap items-center gap-2 mb-3"},hr={class:"text-lg font-bold"},yr={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent bg-green-100 text-green-800 hover:bg-green-100","data-v0-t":"badge"},xr={key:1,class:"flex"},kr={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold border-transparent bg-gray-100 text-gray-800"},br={class:"grid grid-cols-1 sm:grid-cols-2 md:grid-cols-4 gap-3 text-sm border-t pt-3"},wr={class:"text-xs text-gray-500 mb-1"},_r={class:"font-medium"},Er={class:"flex justify-end mt-3 border-t pt-3"},Nr=["href"];function Cr(t,n,r,l,o,i){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.items,a=>{var s,d;return e.openBlock(),e.createElementBlock("div",{key:a.id,class:"rounded-lg border bg-card text-card-foreground shadow-sm overflow-hidden","data-v0-t":"card"},[e.createElementVNode("div",pr,[e.createElementVNode("div",fr,[e.createElementVNode("div",ur,[e.createElementVNode("div",gr,[e.createElementVNode("h2",hr,e.toDisplayString(a[`${(s=i.titleCol)==null?void 0:s.name}_text`]||a[(d=i.titleCol)==null?void 0:d.name]||"Не вказано"),1),Array.isArray(i.categoryCol)&&i.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i.categoryCol,c=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c.name},[a[c.name]?(e.openBlock(),e.createElementBlock("div",yr,e.toDisplayString(a[`${c.name}_text`]||a[c.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0),Array.isArray(i.tagsCol)&&i.tagsCol.length?(e.openBlock(),e.createElementBlock("div",xr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.tagsCol,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name,class:"flex flex-wrap gap-1 ml-2"},[a[c.name]?(e.openBlock(),e.createElementBlock("span",kr,e.toDisplayString(a[`${c.name}_text`]||a[c.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",br,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.featuresCols,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name},[e.createElementVNode("p",wr,e.toDisplayString(c.ua),1),e.createElementVNode("p",_r,[Array.isArray(a[c==null?void 0:c.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(a[c==null?void 0:c.name],(f,m)=>(e.openBlock(),e.createElementBlock("span",{key:m,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(f),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[c.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(i.formatDate(a[c==null?void 0:c.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(a[c==null?void 0:c.name]||"Немає даних"),1)],64))],64))])]))),128))]),e.createElementVNode("div",Er,[e.createElementVNode("a",{href:i.getItemLink(a),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 hover:bg-accent hover:text-accent-foreground h-9 rounded-md px-3"},[...n[0]||(n[0]=[e.createTextVNode(" Детальніше ",-1),e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-external-link ml-1 h-3.5 w-3.5"},[e.createElementVNode("path",{d:"M15 3h6v6"}),e.createElementVNode("path",{d:"M10 14 21 3"}),e.createElementVNode("path",{d:"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"})],-1)])],8,Nr)])])])])])}),128)}const Br=D(mr,[["render",Cr]]),Vr={name:"Template3",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]},featuresCols(){return this.columns.filter(t=>t.meta==="features")},colorClass(){return"bg-blue-500"},titleCol(){return this.columns.find(t=>t.meta==="title")}},methods:{featureColClass(t,n){return"col-span-2"},getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const r=this.query_params.map(l=>{const o=Object.keys(l)[0],i=l[o];return`${o}=${encodeURIComponent(t[i])}`}).join("&");return`${this.path}?${r}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const n=this.query_params.map(r=>{const l=Object.keys(r)[0],o=r[l];return`${l}=${encodeURIComponent(t[o])}`}).join("&");return`${this.path}/${t[this.id_key]}?${n}`},formatDate:fe}},Ar={class:"space-y-4"},$r={class:"flex items-center py-2 px-3"},vr={class:"flex-1"},Sr={class:"grid grid-cols-12 gap-2 w-full text-xs"},Fr={class:"col-span-5"},Lr={key:0,class:"inline-flex items-center rounded-full border transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80 mt-1 text-[10px] font-normal px-1.5 py-0","data-v0-t":"badge"},Tr={key:1,class:"flex flex-wrap gap-1 mt-1"},Mr={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold border-transparent bg-gray-100 text-gray-800"},Dr={class:"col-span-7"},Ir={class:"grid grid-cols-3 gap-3"},jr={class:"text-[10px] text-gray-500 mb-1"},Or={class:"truncate font-medium"},Rr=["href"];function Ur(t,n,r,l,o,i){return e.openBlock(),e.createElementBlock("div",Ar,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.items,a=>{var s,d;return e.openBlock(),e.createElementBlock("div",{key:a.id,class:"border-b border-slate-200 hover:bg-slate-50 transition-colors"},[e.createElementVNode("div",$r,[e.createElementVNode("div",{class:e.normalizeClass(["w-1 h-8 rounded-full mr-3",i.colorClass])},null,2),e.createElementVNode("div",vr,[e.createElementVNode("div",Sr,[e.createElementVNode("div",Fr,[e.createElementVNode("p",{class:e.normalizeClass(["font-bold text-sm text-left",{"w-full h-full flex items-center":!Array.isArray(i.tagsCol)||!i.tagsCol.length}])},e.toDisplayString(a[`${(s=i.titleCol)==null?void 0:s.name}_text`]||a[(d=i.titleCol)==null?void 0:d.name]||a[Object.keys(a)[0]]||"Не вказано"),3),Array.isArray(i.categoryCol)&&i.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i.categoryCol,c=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c.name},[a[c.name]?(e.openBlock(),e.createElementBlock("div",Lr,e.toDisplayString(a[`${c.name}_text`]||a[c.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0),Array.isArray(i.tagsCol)&&i.tagsCol.length?(e.openBlock(),e.createElementBlock("div",Tr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.tagsCol,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name,class:"flex flex-wrap gap-1 mt-1"},[a[c.name]?(e.openBlock(),e.createElementBlock("span",Mr,e.toDisplayString(a[`${c.name}_text`]||a[c.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Dr,[e.createElementVNode("div",Ir,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.featuresCols,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name},[e.createElementVNode("p",jr,e.toDisplayString(c.ua),1),e.createElementVNode("p",Or,[Array.isArray(a[c==null?void 0:c.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(a[c==null?void 0:c.name],(f,m)=>(e.openBlock(),e.createElementBlock("span",{key:m,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(f),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[c.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(i.formatDate(a[c==null?void 0:c.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(a[c==null?void 0:c.name]||"Немає даних"),1)],64))],64))])]))),128))])])])]),e.createElementVNode("a",{href:i.getItemLink(a),class:"ml-auto flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 hover:bg-accent hover:text-accent-foreground rounded-md h-7 w-7 p-0",style:{"min-width":"2.5rem"}},[...n[0]||(n[0]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-chevron-right h-4 w-4"},[e.createElementVNode("path",{d:"m9 18 6-6-6-6"})],-1)])],8,Rr)])])}),128))])}const Pr=D(Vr,[["render",Ur]]),zr={name:"Template4",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{featuresCols(){return this.columns.filter(t=>t.meta==="features")},titleCol(){return this.columns.find(t=>t.meta==="title")},categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const r=this.query_params.map(l=>{const o=Object.keys(l)[0],i=l[o];return`${o}=${encodeURIComponent(t[i])}`}).join("&");return`${this.path}?${r}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const n=this.query_params.map(r=>{const l=Object.keys(r)[0],o=r[l];return`${l}=${encodeURIComponent(t[o])}`}).join("&");return`${this.path}/${t[this.id_key]}?${n}`},formatDate:fe}},qr={class:"flex flex-col space-y-1.5 p-6 pb-2"},Hr={class:"flex items-center gap-2"},Yr={class:"tracking-tight text-lg font-medium"},Kr={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent bg-blue-100 text-blue-800 ml-2","data-v0-t":"badge"},Wr={key:1,class:"flex"},Gr={key:0,class:"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold border-transparent bg-gray-100 text-gray-800"},Zr={class:"p-6 pt-0 pb-4"},Qr={class:"grid grid-cols-2 gap-4"},Xr={class:"text-sm text-gray-500"},Jr={class:"font-medium"},eo={class:"flex items-center p-6 pt-0"},to=["href"];function no(t,n,r,l,o,i){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.items,a=>{var s,d;return e.openBlock(),e.createElementBlock("div",{key:a.id,class:"rounded-lg border bg-card text-card-foreground shadow-sm border-l-4 border-l-blue-600","data-v0-t":"card"},[e.createElementVNode("div",qr,[e.createElementVNode("div",Hr,[e.createElementVNode("h3",Yr,e.toDisplayString(a[`${(s=i.titleCol)==null?void 0:s.name}_text`]||a[(d=i.titleCol)==null?void 0:d.name]||Object.keys(a)[0]||"Не вказано"),1),Array.isArray(i.categoryCol)&&i.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i.categoryCol,c=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:c.name},[a[c.name]?(e.openBlock(),e.createElementBlock("div",Kr,e.toDisplayString(a[`${c.name}_text`]||a[c.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0),Array.isArray(i.tagsCol)&&i.tagsCol.length?(e.openBlock(),e.createElementBlock("div",Wr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.tagsCol,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name,class:"flex flex-wrap gap-1 ml-2"},[a[c.name]?(e.openBlock(),e.createElementBlock("span",Gr,e.toDisplayString(a[`${c.name}_text`]||a[c.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)])]),e.createElementVNode("div",Zr,[e.createElementVNode("div",Qr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.featuresCols,c=>(e.openBlock(),e.createElementBlock("div",{key:c.name},[e.createElementVNode("p",Xr,e.toDisplayString(c.ua),1),e.createElementVNode("p",Jr,[Array.isArray(a[c==null?void 0:c.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(a[c==null?void 0:c.name],(f,m)=>(e.openBlock(),e.createElementBlock("span",{key:m,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(f),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[c.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(i.formatDate(a[c==null?void 0:c.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(a[c==null?void 0:c.name]||"Немає даних"),1)],64))],64))])]))),128))])]),e.createElementVNode("div",eo,[e.createElementVNode("a",{href:i.getItemLink(a),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 border bg-background h-10 px-4 py-2 rounded-md text-black border-black hover:bg-gray-100 hover:text-black"}," Детальніше ",8,to)])])}),128)}const ro=D(zr,[["render",no]]),oo={name:"Template5",props:{items:Array,columns:Array,path:String,id_key:String,query_params:{type:Array,default:()=>[]}},computed:{imageCol(){return this.columns.find(t=>t.meta==="image")},descCol(){return this.columns.find(t=>t.meta==="desc")||this.columns.find(t=>t.name==="description")},categoryCol(){return this.columns?this.columns.filter(t=>t.meta==="category"):[]},tagsCol(){return this.columns?this.columns.filter(t=>t.meta==="tags"):[]},featuresCols(){return this.columns.filter(t=>t.meta==="features")},titleCol(){return this.columns.find(t=>t.meta==="title")}},methods:{getItemLink(t){if(!this.id_key||!t[this.id_key]){if(!this.query_params||!this.query_params.length)return this.path;const r=this.query_params.map(l=>{const o=Object.keys(l)[0],i=l[o];return`${o}=${encodeURIComponent(t[i])}`}).join("&");return`${this.path}?${r}`}if(!this.query_params||!this.query_params.length)return`${this.path}/${t[this.id_key]}`;const n=this.query_params.map(r=>{const l=Object.keys(r)[0],o=r[l];return`${l}=${encodeURIComponent(t[o])}`}).join("&");return`${this.path}/${t[this.id_key]}?${n}`},formatDate:fe}},lo={class:"grid grid-cols-12 divide-x divide-gray-100"},ao={key:0},io=["src"],so={key:1,class:"col-span-1 flex items-center justify-center"},co={class:"col-span-7 p-4"},mo={class:"flex items-center mb-1 col-span-7 p-4"},po={class:"text-base font-bold text-gray-900 mr-2"},fo={key:0,class:"inline-flex items-center rounded-full px-2.5 py-0.5 font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 border-transparent hover:bg-primary/80 bg-blue-100 text-blue-800 border-0 text-xs ml-2"},uo={class:"text-sm text-gray-600 line-clamp-1 mb-2"},go={class:"grid grid-cols-2 gap-x-4 gap-y-1 text-sm"},ho={class:"text-gray-500 mr-1"},yo=["innerHTML"],xo={class:"text-gray-600 truncate"},ko={class:"col-span-2 p-3 bg-gray-50 flex flex-col justify-center"},bo={class:"text-xs text-gray-500 mb-1.5"},wo={key:0,class:"flex flex-wrap gap-1"},_o={key:0,class:"inline-flex items-center rounded-full font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 hover:bg-secondary/80 bg-white border border-gray-200 text-gray-700 text-xs px-1.5 py-0"},Eo={class:"col-span-2 flex flex-col justify-center items-center bg-gray-50 border-l p-2"},No={class:"w-full space-y-2"},Co=["href"];function Bo(t,n,r,l,o,i){return e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.items,a=>{var s,d,c,f,m;return e.openBlock(),e.createElementBlock("div",{key:a.id,class:"bg-white border border-gray-200 rounded-lg overflow-hidden transition-all duration-200 hover:shadow-md"},[e.createElementVNode("div",lo,[i.imageCol?(e.openBlock(),e.createElementBlock("div",ao,[a[(s=i.imageCol)==null?void 0:s.name]?(e.openBlock(),e.createElementBlock("img",{key:0,src:a[(d=i.imageCol)==null?void 0:d.name],alt:"image",class:"object-cover h-full"},null,8,io)):e.createCommentVNode("",!0)])):(e.openBlock(),e.createElementBlock("div",so,[...n[0]||(n[0]=[e.createElementVNode("div",{class:"w-3 h-12 rounded-sm bg-blue-500",title:"Пріоритет: Високий","aria-hidden":"true"},null,-1)])])),e.createElementVNode("div",co,[e.createElementVNode("div",mo,[e.createElementVNode("h3",po,e.toDisplayString(a[`${(c=i.titleCol)==null?void 0:c.name}_text`]||a[(f=i.titleCol)==null?void 0:f.name]||Object.keys(a)[0]||"Не вказано"),1),Array.isArray(i.categoryCol)&&i.categoryCol.length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(i.categoryCol,p=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:p.name},[a[p.name]?(e.openBlock(),e.createElementBlock("div",fo,e.toDisplayString(a[`${p.name}_text`]||a[p.name]),1)):e.createCommentVNode("",!0)],64))),128)):e.createCommentVNode("",!0)]),e.createElementVNode("p",uo,e.toDisplayString(a[(m=i.descCol)==null?void 0:m.name]),1),e.createElementVNode("div",go,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.featuresCols,p=>(e.openBlock(),e.createElementBlock("div",{key:p.name,class:"flex items-center"},[e.createElementVNode("span",ho,e.toDisplayString((p==null?void 0:p.ua)||p.label||p.name)+":",1),p.icon?(e.openBlock(),e.createElementBlock("span",{key:0,class:"mr-1 flex-shrink-0",innerHTML:p.icon},null,8,yo)):e.createCommentVNode("",!0),e.createElementVNode("span",xo,[Array.isArray(a[p==null?void 0:p.name])?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(a[p==null?void 0:p.name],(g,u)=>(e.openBlock(),e.createElementBlock("span",{key:u,class:"bg-gray-200 px-1 py-0.5 rounded-lg mr-1"},e.toDisplayString(g),1))),128)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[p.type==="date"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createTextVNode(e.toDisplayString(i.formatDate(a[p==null?void 0:p.name])||"Немає даних"),1)],64)):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(a[p==null?void 0:p.name]||"Немає даних"),1)],64))],64))])]))),128))])]),e.createElementVNode("div",ko,[e.createElementVNode("p",bo," Теги: "+e.toDisplayString(i.tagsCol.length&&a[i.tagsCol[0].name]?"":"відсутні"),1),Array.isArray(i.tagsCol)&&i.tagsCol.length?(e.openBlock(),e.createElementBlock("div",wo,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.tagsCol,p=>(e.openBlock(),e.createElementBlock("div",{key:p.name,class:"flex flex-wrap gap-1"},[a[p.name]?(e.openBlock(),e.createElementBlock("span",_o,e.toDisplayString(a[`${p.name}_text`]||a[p.name]),1)):e.createCommentVNode("",!0)]))),128))])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Eo,[e.createElementVNode("div",No,[e.createElementVNode("a",{href:i.getItemLink(a),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 rounded-md px-3 w-full bg-blue-600 hover:bg-blue-700 text-white text-xs h-8"}," Детальніше ",8,Co)])])])])}),128)}const Ye={template1:dr,template2:Br,template3:Pr,template4:ro,template5:D(oo,[["render",Bo]])},Vo={class:"space-y-4"},Ao={class:"flex items-center gap-4 mb-2"},$o={class:"text-lg font-semibold mb-4"},vo={key:1,class:"text-gray-400 text-center py-12"},So={key:2,class:"text-gray-400 text-center py-12"},Fo=e.defineComponent({__name:"preview-tab",props:{data:{default:{}},dataModifiers:{}},emits:["update:data"],setup(t){const n=e.defineAsyncComponent(()=>import("@opengis/form")),r=e.useModel(t,"data"),l=[{text:"template1",id:"template1"},{text:"template2",id:"template2"},{text:"template3",id:"template3"},{text:"template4",id:"template4"},{text:"template5",id:"template5"}],o={view:{type:"select",label:"Вигляд",required:!0,options:l,col:12}},i=e.computed(()=>{var f;return Array.isArray((f=r.value)==null?void 0:f.columns)?r.value.columns:[]}),a=e.computed(()=>{var f;return((f=r.value)==null?void 0:f.view)||"template1"}),s=e.computed(()=>Ye[a.value]||Ye.template1),d=e.computed(()=>{var p;const f=(p=r.value)==null?void 0:p.view;if(!f)return"template1";const m=l.find(g=>g.id===f);return(m==null?void 0:m.text)||f}),c=e.computed(()=>(Array.isArray(r.value.tableData)?r.value.tableData:[]).slice(0,5));return(f,m)=>(e.openBlock(),e.createElementBlock("div",Vo,[e.createElementVNode("div",Ao,[(e.openBlock(),e.createBlock(e.unref(n),{key:r.value.id,schema:o,modelValue:r.value,"onUpdate:modelValue":m[0]||(m[0]=p=>r.value=p),class:"w-[220px]"},null,8,["modelValue"]))]),e.createElementVNode("h2",$o," Превʼю таблиці ("+e.toDisplayString(d.value)+") ",1),s.value&&c.value.length&&i.value.length?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(s.value),{items:c.value,columns:i.value,path:"#",id_key:"id",key:a.value},null,8,["items","columns"])):c.value.length?(e.openBlock(),e.createElementBlock("div",So," Додайте колонки та виберіть вигляд для перегляду ")):(e.openBlock(),e.createElementBlock("div",vo," Немає даних для превʼю "))]))}}),Lo={class:"relative min-h-svh flex-1 flex-col flex gap-4 bg-white p-8 overflow-y-auto"},To={class:"max-w-6xl mx-auto"},Mo={class:"flex items-center justify-between mb-6"},Do={class:"flex items-center gap-2"},Io=["href"],jo={class:"w-full"},Oo={class:"flex items-center w-full h-10 max-w-md grid-cols-3 p-1 mb-6 bg-white border border-gray-200 rounded-md text-muted-foreground"},Ro=["onClick"],Uo=e.defineComponent({__name:"register",setup(t){const n=pe.useRoute(),r=pe.useRouter(),l=e.ref("list"),o=e.ref(""),i=[{name:"List",id:"list"},{name:"Filters",id:"filters"},{name:"Card",id:"card"},{name:"Preview",id:"preview"}],a={list:Dn,filters:Pn,card:Wn,preview:Fo},s=i.map(g=>g.id),d=e.ref({columns:[],filters:[],card:[],tableData:[]}),c=e.ref([]),f=async()=>{var u;if(!((u=d.value)==null?void 0:u.token)){K.notify({type:"error",title:"Помилка",message:"Відсутній токен для збереження"});return}try{const h=await fetch(`/api/gis-registry/${n.params.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(d.value)});if(!h.ok)throw new Error(`Failed to save content: ${h.status}`);K.notify({type:"success",title:"Успіх",message:"Контент збережено"})}catch(h){K.notify({type:"error",title:"Помилка",message:"Не вдалося зберегти контент"}),console.error(h)}},m=async g=>{try{const h=await(await fetch(`/api/gis-registry/${g}`)).json(),x=Array.isArray(h==null?void 0:h.rows)?h.rows:[];d.value.tableData=x.slice(0,3)}catch(u){console.error("Помилка завантаження превʼю:",u)}},p=async()=>{var g,u;try{const x=await(await fetch(`/api/data/gis.registers.table/${n.params.id}`)).json(),E=((g=x==null?void 0:x.rows)==null?void 0:g[0])||{};o.value=E.register_key||"",d.value={...E,columns:Array.isArray(E.columns)?E.columns:[],filters:Array.isArray(E.filters)?E.filters:[],card:Array.isArray(E.card)?E.card:[],tableData:Array.isArray(E.tableData)?E.tableData:[]},(u=x==null?void 0:x.tokens)!=null&&u.edit&&(d.value.token=x.tokens.edit),c.value=Array.isArray(x==null?void 0:x.fields)?x.fields:[]}catch(h){console.error("Помилка завантаження даних:",h)}};return e.onMounted(async()=>{const g=n.query.tab;typeof g=="string"&&s.includes(g)&&(l.value=g),await p(),o.value&&await m(o.value)}),e.watch(l,g=>{n.query.tab!==g&&r.replace({query:{...n.query,tab:g}})}),e.watch(()=>n.query.tab,g=>{typeof g=="string"&&s.includes(g)&&l.value!==g&&(l.value=g)}),(g,u)=>(e.openBlock(),e.createElementBlock("main",Lo,[e.createElementVNode("div",null,[e.createElementVNode("div",To,[e.createElementVNode("div",Mo,[u[1]||(u[1]=e.createElementVNode("div",null,[e.createElementVNode("h1",{class:"mb-2 text-2xl font-semibold text-gray-900"},"Створити контент"),e.createElementVNode("p",{class:"text-gray-600"},"Створити контент для вашого сайту")],-1)),e.createElementVNode("div",Do,[e.createElementVNode("a",{href:`/${e.unref(n).path.split("/")[1]}`,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 border bg-background hover:text-accent-foreground h-10 px-4 py-2 border-gray-300 text-gray-700 hover:bg-gray-50"}," Повернутися ",8,Io),e.createElementVNode("button",{onClick:f,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap text-white rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 text-primary-foreground h-10 px-4 py-2 bg-blue-600 hover:bg-blue-700"}," Зберегти ")])]),e.createElementVNode("div",jo,[e.createElementVNode("div",Oo,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(i,h=>e.createElementVNode("button",{key:h.id,onClick:x=>l.value=h.id,class:e.normalizeClass(["inline-flex flex-1 items-center justify-center whitespace-nowrap rounded-sm px-3 py-1.5 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm data-[state=active]:bg-blue-50 data-[state=active]:text-blue-700 data-[state=active]:border-blue-200",h.id===l.value?"bg-blue-50 text-blue-700 border-blue-200":""])},e.toDisplayString(h.name),11,Ro)),64))])]),(e.openBlock(),e.createBlock(e.resolveDynamicComponent(a[l.value]),{data:d.value,"onUpdate:data":u[0]||(u[0]=h=>d.value=h),fields:c.value,key:l.value},null,40,["data","fields"]))])])]))}}),Po={},zo={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-settings"};function qo(t,n){return e.openBlock(),e.createElementBlock("svg",zo,[...n[0]||(n[0]=[e.createElementVNode("path",{d:"M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z"},null,-1),e.createElementVNode("circle",{cx:"12",cy:"12",r:"3"},null,-1)])])}const Ho=D(Po,[["render",qo]]),Yo={},Ko={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-layers"};function Wo(t,n){return e.openBlock(),e.createElementBlock("svg",Ko,[...n[0]||(n[0]=[e.createElementVNode("path",{d:"m12.83 2.18a2 2 0 0 0-1.66 0L2.6 6.08a1 1 0 0 0 0 1.83l8.58 3.91a2 2 0 0 0 1.66 0l8.58-3.9a1 1 0 0 0 0-1.83Z"},null,-1),e.createElementVNode("path",{d:"m22 17.65-9.17 4.16a2 2 0 0 1-1.66 0L2 17.65"},null,-1),e.createElementVNode("path",{d:"m22 12.65-9.17 4.16a2 2 0 0 1-1.66 0L2 12.65"},null,-1)])])}const Go=D(Yo,[["render",Wo]]),Zo={},Qo={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-eye"};function Xo(t,n){return e.openBlock(),e.createElementBlock("svg",Qo,[...n[0]||(n[0]=[e.createElementVNode("path",{d:"M2 12s3-7 10-7 10 7 10 7-3 7-10 7-10-7-10-7Z"},null,-1),e.createElementVNode("circle",{cx:"12",cy:"12",r:"3"},null,-1)])])}const Jo=D(Zo,[["render",Xo]]),el={},tl={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-map"};function nl(t,n){return e.openBlock(),e.createElementBlock("svg",tl,[...n[0]||(n[0]=[e.createElementVNode("path",{d:"M14.106 5.553a2 2 0 0 0 1.788 0l3.659-1.83A1 1 0 0 1 21 4.619v12.764a1 1 0 0 1-.553.894l-4.553 2.277a2 2 0 0 1-1.788 0l-4.212-2.106a2 2 0 0 0-1.788 0l-3.659 1.83A1 1 0 0 1 3 19.381V6.618a1 1 0 0 1 .553-.894l4.553-2.277a2 2 0 0 1 1.788 0z"},null,-1),e.createElementVNode("path",{d:"M15 5.764v15"},null,-1),e.createElementVNode("path",{d:"M9 3.236v15"},null,-1)])])}const rl=D(el,[["render",nl]]),ol={},ll={xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-filter"};function al(t,n){return e.openBlock(),e.createElementBlock("svg",ll,[...n[0]||(n[0]=[e.createElementVNode("polygon",{points:"22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3"},null,-1)])])}const il=D(ol,[["render",al]]),Ke=e.defineComponent({__name:"MonacoEditor",props:{modelValue:{},language:{},theme:{}},emits:["update:modelValue","load"],setup(t,{emit:n}){const r=t,l=n,o=e.ref(null);let i=null,a=null,s=!1;function d(){return new Promise((f,m)=>{if(a)return f(a);if(window.monaco)return a=window.monaco,f(a);const p=u=>{if([...document.styleSheets].some(x=>{var E;return(E=x==null?void 0:x.href)==null?void 0:E.includes(u)}))return;const h=document.createElement("link");h.rel="stylesheet",h.href=u,document.head.appendChild(h)},g=u=>new Promise((h,x)=>{const E=document.createElement("script");E.src=u,E.onload=()=>h(!0),E.onerror=x,document.body.appendChild(E)});p("https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.0/min/vs/editor/editor.main.min.css"),g("https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.0/min/vs/loader.min.js").then(()=>{window.require.config({paths:{vs:"https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.0/min/vs"}}),window.require(["vs/editor/editor.main"],()=>{a=window.monaco,f(a)})}).catch(m)})}function c(){!o.value||!a||(i&&i.dispose(),i=a.editor.create(o.value,{value:r.modelValue||"",language:r.language||"yaml",theme:r.theme||"vs-light",automaticLayout:!0,minimap:{enabled:!1}}),i.onDidChangeModelContent(()=>{s||l("update:modelValue",i.getValue())}))}return e.watch(()=>r.modelValue,f=>{if(!i)return;const m=i.getValue();f!==m&&(s=!0,i.setValue(f||""),s=!1)}),e.watch(()=>r.language,f=>{i&&a&&a.editor.setModelLanguage(i.getModel(),f||"yaml")}),e.watch(()=>r.theme,f=>{i&&a&&a.editor.setTheme(f||"vs-light")}),e.onMounted(async()=>{await d(),c()}),e.onBeforeUnmount(()=>{i&&i.dispose()}),(f,m)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"editorContainer",ref:o,class:"w-full h-full"},null,512))}});/*! js-yaml 4.1.0 https://github.com/nodeca/js-yaml @license MIT */function We(t){return typeof t>"u"||t===null}function sl(t){return typeof t=="object"&&t!==null}function cl(t){return Array.isArray(t)?t:We(t)?[]:[t]}function dl(t,n){var r,l,o,i;if(n)for(i=Object.keys(n),r=0,l=i.length;r<l;r+=1)o=i[r],t[o]=n[o];return t}function ml(t,n){var r="",l;for(l=0;l<n;l+=1)r+=t;return r}function pl(t){return t===0&&Number.NEGATIVE_INFINITY===1/t}var fl=We,ul=sl,gl=cl,hl=ml,yl=pl,xl=dl,T={isNothing:fl,isObject:ul,toArray:gl,repeat:hl,isNegativeZero:yl,extend:xl};function Ge(t,n){var r="",l=t.reason||"(unknown reason)";return t.mark?(t.mark.name&&(r+='in "'+t.mark.name+'" '),r+="("+(t.mark.line+1)+":"+(t.mark.column+1)+")",!n&&t.mark.snippet&&(r+=`
|
|
34
|
+
|
|
35
|
+
`+t.mark.snippet),l+" "+r):l}function ue(t,n){Error.call(this),this.name="YAMLException",this.reason=t,this.mark=n,this.message=Ge(this,!1),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack||""}ue.prototype=Object.create(Error.prototype),ue.prototype.constructor=ue,ue.prototype.toString=function(n){return this.name+": "+Ge(this,n)};var P=ue;function Be(t,n,r,l,o){var i="",a="",s=Math.floor(o/2)-1;return l-n>s&&(i=" ... ",n=l-s+i.length),r-l>s&&(a=" ...",r=l+s-a.length),{str:i+t.slice(n,r).replace(/\t/g,"→")+a,pos:l-n+i.length}}function Ve(t,n){return T.repeat(" ",n-t.length)+t}function kl(t,n){if(n=Object.create(n||null),!t.buffer)return null;n.maxLength||(n.maxLength=79),typeof n.indent!="number"&&(n.indent=1),typeof n.linesBefore!="number"&&(n.linesBefore=3),typeof n.linesAfter!="number"&&(n.linesAfter=2);for(var r=/\r?\n|\r|\0/g,l=[0],o=[],i,a=-1;i=r.exec(t.buffer);)o.push(i.index),l.push(i.index+i[0].length),t.position<=i.index&&a<0&&(a=l.length-2);a<0&&(a=l.length-1);var s="",d,c,f=Math.min(t.line+n.linesAfter,o.length).toString().length,m=n.maxLength-(n.indent+f+3);for(d=1;d<=n.linesBefore&&!(a-d<0);d++)c=Be(t.buffer,l[a-d],o[a-d],t.position-(l[a]-l[a-d]),m),s=T.repeat(" ",n.indent)+Ve((t.line-d+1).toString(),f)+" | "+c.str+`
|
|
36
|
+
`+s;for(c=Be(t.buffer,l[a],o[a],t.position,m),s+=T.repeat(" ",n.indent)+Ve((t.line+1).toString(),f)+" | "+c.str+`
|
|
37
|
+
`,s+=T.repeat("-",n.indent+f+3+c.pos)+`^
|
|
38
|
+
`,d=1;d<=n.linesAfter&&!(a+d>=o.length);d++)c=Be(t.buffer,l[a+d],o[a+d],t.position-(l[a]-l[a+d]),m),s+=T.repeat(" ",n.indent)+Ve((t.line+d+1).toString(),f)+" | "+c.str+`
|
|
39
|
+
`;return s.replace(/\n$/,"")}var bl=kl,wl=["kind","multi","resolve","construct","instanceOf","predicate","represent","representName","defaultStyle","styleAliases"],_l=["scalar","sequence","mapping"];function El(t){var n={};return t!==null&&Object.keys(t).forEach(function(r){t[r].forEach(function(l){n[String(l)]=r})}),n}function Nl(t,n){if(n=n||{},Object.keys(n).forEach(function(r){if(wl.indexOf(r)===-1)throw new P('Unknown option "'+r+'" is met in definition of "'+t+'" YAML type.')}),this.options=n,this.tag=t,this.kind=n.kind||null,this.resolve=n.resolve||function(){return!0},this.construct=n.construct||function(r){return r},this.instanceOf=n.instanceOf||null,this.predicate=n.predicate||null,this.represent=n.represent||null,this.representName=n.representName||null,this.defaultStyle=n.defaultStyle||null,this.multi=n.multi||!1,this.styleAliases=El(n.styleAliases||null),_l.indexOf(this.kind)===-1)throw new P('Unknown kind "'+this.kind+'" is specified for "'+t+'" YAML type.')}var j=Nl;function Ze(t,n){var r=[];return t[n].forEach(function(l){var o=r.length;r.forEach(function(i,a){i.tag===l.tag&&i.kind===l.kind&&i.multi===l.multi&&(o=a)}),r[o]=l}),r}function Cl(){var t={scalar:{},sequence:{},mapping:{},fallback:{},multi:{scalar:[],sequence:[],mapping:[],fallback:[]}},n,r;function l(o){o.multi?(t.multi[o.kind].push(o),t.multi.fallback.push(o)):t[o.kind][o.tag]=t.fallback[o.tag]=o}for(n=0,r=arguments.length;n<r;n+=1)arguments[n].forEach(l);return t}function Ae(t){return this.extend(t)}Ae.prototype.extend=function(n){var r=[],l=[];if(n instanceof j)l.push(n);else if(Array.isArray(n))l=l.concat(n);else if(n&&(Array.isArray(n.implicit)||Array.isArray(n.explicit)))n.implicit&&(r=r.concat(n.implicit)),n.explicit&&(l=l.concat(n.explicit));else throw new P("Schema.extend argument should be a Type, [ Type ], or a schema definition ({ implicit: [...], explicit: [...] })");r.forEach(function(i){if(!(i instanceof j))throw new P("Specified list of YAML types (or a single Type object) contains a non-Type object.");if(i.loadKind&&i.loadKind!=="scalar")throw new P("There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.");if(i.multi)throw new P("There is a multi type in the implicit list of a schema. Multi tags can only be listed as explicit.")}),l.forEach(function(i){if(!(i instanceof j))throw new P("Specified list of YAML types (or a single Type object) contains a non-Type object.")});var o=Object.create(Ae.prototype);return o.implicit=(this.implicit||[]).concat(r),o.explicit=(this.explicit||[]).concat(l),o.compiledImplicit=Ze(o,"implicit"),o.compiledExplicit=Ze(o,"explicit"),o.compiledTypeMap=Cl(o.compiledImplicit,o.compiledExplicit),o};var Bl=Ae,Vl=new j("tag:yaml.org,2002:str",{kind:"scalar",construct:function(t){return t!==null?t:""}}),Al=new j("tag:yaml.org,2002:seq",{kind:"sequence",construct:function(t){return t!==null?t:[]}}),$l=new j("tag:yaml.org,2002:map",{kind:"mapping",construct:function(t){return t!==null?t:{}}}),vl=new Bl({explicit:[Vl,Al,$l]});function Sl(t){if(t===null)return!0;var n=t.length;return n===1&&t==="~"||n===4&&(t==="null"||t==="Null"||t==="NULL")}function Fl(){return null}function Ll(t){return t===null}var Tl=new j("tag:yaml.org,2002:null",{kind:"scalar",resolve:Sl,construct:Fl,predicate:Ll,represent:{canonical:function(){return"~"},lowercase:function(){return"null"},uppercase:function(){return"NULL"},camelcase:function(){return"Null"},empty:function(){return""}},defaultStyle:"lowercase"});function Ml(t){if(t===null)return!1;var n=t.length;return n===4&&(t==="true"||t==="True"||t==="TRUE")||n===5&&(t==="false"||t==="False"||t==="FALSE")}function Dl(t){return t==="true"||t==="True"||t==="TRUE"}function Il(t){return Object.prototype.toString.call(t)==="[object Boolean]"}var jl=new j("tag:yaml.org,2002:bool",{kind:"scalar",resolve:Ml,construct:Dl,predicate:Il,represent:{lowercase:function(t){return t?"true":"false"},uppercase:function(t){return t?"TRUE":"FALSE"},camelcase:function(t){return t?"True":"False"}},defaultStyle:"lowercase"});function Ol(t){return 48<=t&&t<=57||65<=t&&t<=70||97<=t&&t<=102}function Rl(t){return 48<=t&&t<=55}function Ul(t){return 48<=t&&t<=57}function Pl(t){if(t===null)return!1;var n=t.length,r=0,l=!1,o;if(!n)return!1;if(o=t[r],(o==="-"||o==="+")&&(o=t[++r]),o==="0"){if(r+1===n)return!0;if(o=t[++r],o==="b"){for(r++;r<n;r++)if(o=t[r],o!=="_"){if(o!=="0"&&o!=="1")return!1;l=!0}return l&&o!=="_"}if(o==="x"){for(r++;r<n;r++)if(o=t[r],o!=="_"){if(!Ol(t.charCodeAt(r)))return!1;l=!0}return l&&o!=="_"}if(o==="o"){for(r++;r<n;r++)if(o=t[r],o!=="_"){if(!Rl(t.charCodeAt(r)))return!1;l=!0}return l&&o!=="_"}}if(o==="_")return!1;for(;r<n;r++)if(o=t[r],o!=="_"){if(!Ul(t.charCodeAt(r)))return!1;l=!0}return!(!l||o==="_")}function zl(t){var n=t,r=1,l;if(n.indexOf("_")!==-1&&(n=n.replace(/_/g,"")),l=n[0],(l==="-"||l==="+")&&(l==="-"&&(r=-1),n=n.slice(1),l=n[0]),n==="0")return 0;if(l==="0"){if(n[1]==="b")return r*parseInt(n.slice(2),2);if(n[1]==="x")return r*parseInt(n.slice(2),16);if(n[1]==="o")return r*parseInt(n.slice(2),8)}return r*parseInt(n,10)}function ql(t){return Object.prototype.toString.call(t)==="[object Number]"&&t%1===0&&!T.isNegativeZero(t)}var Hl=new j("tag:yaml.org,2002:int",{kind:"scalar",resolve:Pl,construct:zl,predicate:ql,represent:{binary:function(t){return t>=0?"0b"+t.toString(2):"-0b"+t.toString(2).slice(1)},octal:function(t){return t>=0?"0o"+t.toString(8):"-0o"+t.toString(8).slice(1)},decimal:function(t){return t.toString(10)},hexadecimal:function(t){return t>=0?"0x"+t.toString(16).toUpperCase():"-0x"+t.toString(16).toUpperCase().slice(1)}},defaultStyle:"decimal",styleAliases:{binary:[2,"bin"],octal:[8,"oct"],decimal:[10,"dec"],hexadecimal:[16,"hex"]}}),Yl=new RegExp("^(?:[-+]?(?:[0-9][0-9_]*)(?:\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?|\\.[0-9_]+(?:[eE][-+]?[0-9]+)?|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$");function Kl(t){return!(t===null||!Yl.test(t)||t[t.length-1]==="_")}function Wl(t){var n,r;return n=t.replace(/_/g,"").toLowerCase(),r=n[0]==="-"?-1:1,"+-".indexOf(n[0])>=0&&(n=n.slice(1)),n===".inf"?r===1?Number.POSITIVE_INFINITY:Number.NEGATIVE_INFINITY:n===".nan"?NaN:r*parseFloat(n,10)}var Gl=/^[-+]?[0-9]+e/;function Zl(t,n){var r;if(isNaN(t))switch(n){case"lowercase":return".nan";case"uppercase":return".NAN";case"camelcase":return".NaN"}else if(Number.POSITIVE_INFINITY===t)switch(n){case"lowercase":return".inf";case"uppercase":return".INF";case"camelcase":return".Inf"}else if(Number.NEGATIVE_INFINITY===t)switch(n){case"lowercase":return"-.inf";case"uppercase":return"-.INF";case"camelcase":return"-.Inf"}else if(T.isNegativeZero(t))return"-0.0";return r=t.toString(10),Gl.test(r)?r.replace("e",".e"):r}function Ql(t){return Object.prototype.toString.call(t)==="[object Number]"&&(t%1!==0||T.isNegativeZero(t))}var Xl=new j("tag:yaml.org,2002:float",{kind:"scalar",resolve:Kl,construct:Wl,predicate:Ql,represent:Zl,defaultStyle:"lowercase"}),Jl=vl.extend({implicit:[Tl,jl,Hl,Xl]}),ea=Jl,Qe=new RegExp("^([0-9][0-9][0-9][0-9])-([0-9][0-9])-([0-9][0-9])$"),Xe=new RegExp("^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?$");function ta(t){return t===null?!1:Qe.exec(t)!==null||Xe.exec(t)!==null}function na(t){var n,r,l,o,i,a,s,d=0,c=null,f,m,p;if(n=Qe.exec(t),n===null&&(n=Xe.exec(t)),n===null)throw new Error("Date resolve error");if(r=+n[1],l=+n[2]-1,o=+n[3],!n[4])return new Date(Date.UTC(r,l,o));if(i=+n[4],a=+n[5],s=+n[6],n[7]){for(d=n[7].slice(0,3);d.length<3;)d+="0";d=+d}return n[9]&&(f=+n[10],m=+(n[11]||0),c=(f*60+m)*6e4,n[9]==="-"&&(c=-c)),p=new Date(Date.UTC(r,l,o,i,a,s,d)),c&&p.setTime(p.getTime()-c),p}function ra(t){return t.toISOString()}var oa=new j("tag:yaml.org,2002:timestamp",{kind:"scalar",resolve:ta,construct:na,instanceOf:Date,represent:ra});function la(t){return t==="<<"||t===null}var aa=new j("tag:yaml.org,2002:merge",{kind:"scalar",resolve:la}),$e=`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=
|
|
40
|
+
\r`;function ia(t){if(t===null)return!1;var n,r,l=0,o=t.length,i=$e;for(r=0;r<o;r++)if(n=i.indexOf(t.charAt(r)),!(n>64)){if(n<0)return!1;l+=6}return l%8===0}function sa(t){var n,r,l=t.replace(/[\r\n=]/g,""),o=l.length,i=$e,a=0,s=[];for(n=0;n<o;n++)n%4===0&&n&&(s.push(a>>16&255),s.push(a>>8&255),s.push(a&255)),a=a<<6|i.indexOf(l.charAt(n));return r=o%4*6,r===0?(s.push(a>>16&255),s.push(a>>8&255),s.push(a&255)):r===18?(s.push(a>>10&255),s.push(a>>2&255)):r===12&&s.push(a>>4&255),new Uint8Array(s)}function ca(t){var n="",r=0,l,o,i=t.length,a=$e;for(l=0;l<i;l++)l%3===0&&l&&(n+=a[r>>18&63],n+=a[r>>12&63],n+=a[r>>6&63],n+=a[r&63]),r=(r<<8)+t[l];return o=i%3,o===0?(n+=a[r>>18&63],n+=a[r>>12&63],n+=a[r>>6&63],n+=a[r&63]):o===2?(n+=a[r>>10&63],n+=a[r>>4&63],n+=a[r<<2&63],n+=a[64]):o===1&&(n+=a[r>>2&63],n+=a[r<<4&63],n+=a[64],n+=a[64]),n}function da(t){return Object.prototype.toString.call(t)==="[object Uint8Array]"}var ma=new j("tag:yaml.org,2002:binary",{kind:"scalar",resolve:ia,construct:sa,predicate:da,represent:ca}),pa=Object.prototype.hasOwnProperty,fa=Object.prototype.toString;function ua(t){if(t===null)return!0;var n=[],r,l,o,i,a,s=t;for(r=0,l=s.length;r<l;r+=1){if(o=s[r],a=!1,fa.call(o)!=="[object Object]")return!1;for(i in o)if(pa.call(o,i))if(!a)a=!0;else return!1;if(!a)return!1;if(n.indexOf(i)===-1)n.push(i);else return!1}return!0}function ga(t){return t!==null?t:[]}var ha=new j("tag:yaml.org,2002:omap",{kind:"sequence",resolve:ua,construct:ga}),ya=Object.prototype.toString;function xa(t){if(t===null)return!0;var n,r,l,o,i,a=t;for(i=new Array(a.length),n=0,r=a.length;n<r;n+=1){if(l=a[n],ya.call(l)!=="[object Object]"||(o=Object.keys(l),o.length!==1))return!1;i[n]=[o[0],l[o[0]]]}return!0}function ka(t){if(t===null)return[];var n,r,l,o,i,a=t;for(i=new Array(a.length),n=0,r=a.length;n<r;n+=1)l=a[n],o=Object.keys(l),i[n]=[o[0],l[o[0]]];return i}var ba=new j("tag:yaml.org,2002:pairs",{kind:"sequence",resolve:xa,construct:ka}),wa=Object.prototype.hasOwnProperty;function _a(t){if(t===null)return!0;var n,r=t;for(n in r)if(wa.call(r,n)&&r[n]!==null)return!1;return!0}function Ea(t){return t!==null?t:{}}var Na=new j("tag:yaml.org,2002:set",{kind:"mapping",resolve:_a,construct:Ea}),Je=ea.extend({implicit:[oa,aa],explicit:[ma,ha,ba,Na]}),X=Object.prototype.hasOwnProperty,be=1,et=2,tt=3,we=4,ve=1,Ca=2,nt=3,Ba=/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/,Va=/[\x85\u2028\u2029]/,Aa=/[,\[\]\{\}]/,rt=/^(?:!|!!|![a-z\-]+!)$/i,ot=/^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i;function lt(t){return Object.prototype.toString.call(t)}function W(t){return t===10||t===13}function ne(t){return t===9||t===32}function z(t){return t===9||t===32||t===10||t===13}function ie(t){return t===44||t===91||t===93||t===123||t===125}function $a(t){var n;return 48<=t&&t<=57?t-48:(n=t|32,97<=n&&n<=102?n-97+10:-1)}function va(t){return t===120?2:t===117?4:t===85?8:0}function Sa(t){return 48<=t&&t<=57?t-48:-1}function at(t){return t===48?"\0":t===97?"\x07":t===98?"\b":t===116||t===9?" ":t===110?`
|
|
41
|
+
`:t===118?"\v":t===102?"\f":t===114?"\r":t===101?"\x1B":t===32?" ":t===34?'"':t===47?"/":t===92?"\\":t===78?"
":t===95?" ":t===76?"\u2028":t===80?"\u2029":""}function Fa(t){return t<=65535?String.fromCharCode(t):String.fromCharCode((t-65536>>10)+55296,(t-65536&1023)+56320)}for(var it=new Array(256),st=new Array(256),se=0;se<256;se++)it[se]=at(se)?1:0,st[se]=at(se);function La(t,n){this.input=t,this.filename=n.filename||null,this.schema=n.schema||Je,this.onWarning=n.onWarning||null,this.legacy=n.legacy||!1,this.json=n.json||!1,this.listener=n.listener||null,this.implicitTypes=this.schema.compiledImplicit,this.typeMap=this.schema.compiledTypeMap,this.length=t.length,this.position=0,this.line=0,this.lineStart=0,this.lineIndent=0,this.firstTabInLine=-1,this.documents=[]}function ct(t,n){var r={name:t.filename,buffer:t.input.slice(0,-1),position:t.position,line:t.line,column:t.position-t.lineStart};return r.snippet=bl(r),new P(n,r)}function N(t,n){throw ct(t,n)}function _e(t,n){t.onWarning&&t.onWarning.call(null,ct(t,n))}var dt={YAML:function(n,r,l){var o,i,a;n.version!==null&&N(n,"duplication of %YAML directive"),l.length!==1&&N(n,"YAML directive accepts exactly one argument"),o=/^([0-9]+)\.([0-9]+)$/.exec(l[0]),o===null&&N(n,"ill-formed argument of the YAML directive"),i=parseInt(o[1],10),a=parseInt(o[2],10),i!==1&&N(n,"unacceptable YAML version of the document"),n.version=l[0],n.checkLineBreaks=a<2,a!==1&&a!==2&&_e(n,"unsupported YAML version of the document")},TAG:function(n,r,l){var o,i;l.length!==2&&N(n,"TAG directive accepts exactly two arguments"),o=l[0],i=l[1],rt.test(o)||N(n,"ill-formed tag handle (first argument) of the TAG directive"),X.call(n.tagMap,o)&&N(n,'there is a previously declared suffix for "'+o+'" tag handle'),ot.test(i)||N(n,"ill-formed tag prefix (second argument) of the TAG directive");try{i=decodeURIComponent(i)}catch{N(n,"tag prefix is malformed: "+i)}n.tagMap[o]=i}};function J(t,n,r,l){var o,i,a,s;if(n<r){if(s=t.input.slice(n,r),l)for(o=0,i=s.length;o<i;o+=1)a=s.charCodeAt(o),a===9||32<=a&&a<=1114111||N(t,"expected valid JSON character");else Ba.test(s)&&N(t,"the stream contains non-printable characters");t.result+=s}}function mt(t,n,r,l){var o,i,a,s;for(T.isObject(r)||N(t,"cannot merge mappings; the provided source object is unacceptable"),o=Object.keys(r),a=0,s=o.length;a<s;a+=1)i=o[a],X.call(n,i)||(n[i]=r[i],l[i]=!0)}function ce(t,n,r,l,o,i,a,s,d){var c,f;if(Array.isArray(o))for(o=Array.prototype.slice.call(o),c=0,f=o.length;c<f;c+=1)Array.isArray(o[c])&&N(t,"nested arrays are not supported inside keys"),typeof o=="object"&<(o[c])==="[object Object]"&&(o[c]="[object Object]");if(typeof o=="object"&<(o)==="[object Object]"&&(o="[object Object]"),o=String(o),n===null&&(n={}),l==="tag:yaml.org,2002:merge")if(Array.isArray(i))for(c=0,f=i.length;c<f;c+=1)mt(t,n,i[c],r);else mt(t,n,i,r);else!t.json&&!X.call(r,o)&&X.call(n,o)&&(t.line=a||t.line,t.lineStart=s||t.lineStart,t.position=d||t.position,N(t,"duplicated mapping key")),o==="__proto__"?Object.defineProperty(n,o,{configurable:!0,enumerable:!0,writable:!0,value:i}):n[o]=i,delete r[o];return n}function Se(t){var n;n=t.input.charCodeAt(t.position),n===10?t.position++:n===13?(t.position++,t.input.charCodeAt(t.position)===10&&t.position++):N(t,"a line break is expected"),t.line+=1,t.lineStart=t.position,t.firstTabInLine=-1}function F(t,n,r){for(var l=0,o=t.input.charCodeAt(t.position);o!==0;){for(;ne(o);)o===9&&t.firstTabInLine===-1&&(t.firstTabInLine=t.position),o=t.input.charCodeAt(++t.position);if(n&&o===35)do o=t.input.charCodeAt(++t.position);while(o!==10&&o!==13&&o!==0);if(W(o))for(Se(t),o=t.input.charCodeAt(t.position),l++,t.lineIndent=0;o===32;)t.lineIndent++,o=t.input.charCodeAt(++t.position);else break}return r!==-1&&l!==0&&t.lineIndent<r&&_e(t,"deficient indentation"),l}function Ee(t){var n=t.position,r;return r=t.input.charCodeAt(n),!!((r===45||r===46)&&r===t.input.charCodeAt(n+1)&&r===t.input.charCodeAt(n+2)&&(n+=3,r=t.input.charCodeAt(n),r===0||z(r)))}function Fe(t,n){n===1?t.result+=" ":n>1&&(t.result+=T.repeat(`
|
|
42
|
+
`,n-1))}function Ta(t,n,r){var l,o,i,a,s,d,c,f,m=t.kind,p=t.result,g;if(g=t.input.charCodeAt(t.position),z(g)||ie(g)||g===35||g===38||g===42||g===33||g===124||g===62||g===39||g===34||g===37||g===64||g===96||(g===63||g===45)&&(o=t.input.charCodeAt(t.position+1),z(o)||r&&ie(o)))return!1;for(t.kind="scalar",t.result="",i=a=t.position,s=!1;g!==0;){if(g===58){if(o=t.input.charCodeAt(t.position+1),z(o)||r&&ie(o))break}else if(g===35){if(l=t.input.charCodeAt(t.position-1),z(l))break}else{if(t.position===t.lineStart&&Ee(t)||r&&ie(g))break;if(W(g))if(d=t.line,c=t.lineStart,f=t.lineIndent,F(t,!1,-1),t.lineIndent>=n){s=!0,g=t.input.charCodeAt(t.position);continue}else{t.position=a,t.line=d,t.lineStart=c,t.lineIndent=f;break}}s&&(J(t,i,a,!1),Fe(t,t.line-d),i=a=t.position,s=!1),ne(g)||(a=t.position+1),g=t.input.charCodeAt(++t.position)}return J(t,i,a,!1),t.result?!0:(t.kind=m,t.result=p,!1)}function Ma(t,n){var r,l,o;if(r=t.input.charCodeAt(t.position),r!==39)return!1;for(t.kind="scalar",t.result="",t.position++,l=o=t.position;(r=t.input.charCodeAt(t.position))!==0;)if(r===39)if(J(t,l,t.position,!0),r=t.input.charCodeAt(++t.position),r===39)l=t.position,t.position++,o=t.position;else return!0;else W(r)?(J(t,l,o,!0),Fe(t,F(t,!1,n)),l=o=t.position):t.position===t.lineStart&&Ee(t)?N(t,"unexpected end of the document within a single quoted scalar"):(t.position++,o=t.position);N(t,"unexpected end of the stream within a single quoted scalar")}function Da(t,n){var r,l,o,i,a,s;if(s=t.input.charCodeAt(t.position),s!==34)return!1;for(t.kind="scalar",t.result="",t.position++,r=l=t.position;(s=t.input.charCodeAt(t.position))!==0;){if(s===34)return J(t,r,t.position,!0),t.position++,!0;if(s===92){if(J(t,r,t.position,!0),s=t.input.charCodeAt(++t.position),W(s))F(t,!1,n);else if(s<256&&it[s])t.result+=st[s],t.position++;else if((a=va(s))>0){for(o=a,i=0;o>0;o--)s=t.input.charCodeAt(++t.position),(a=$a(s))>=0?i=(i<<4)+a:N(t,"expected hexadecimal character");t.result+=Fa(i),t.position++}else N(t,"unknown escape sequence");r=l=t.position}else W(s)?(J(t,r,l,!0),Fe(t,F(t,!1,n)),r=l=t.position):t.position===t.lineStart&&Ee(t)?N(t,"unexpected end of the document within a double quoted scalar"):(t.position++,l=t.position)}N(t,"unexpected end of the stream within a double quoted scalar")}function Ia(t,n){var r=!0,l,o,i,a=t.tag,s,d=t.anchor,c,f,m,p,g,u=Object.create(null),h,x,E,y;if(y=t.input.charCodeAt(t.position),y===91)f=93,g=!1,s=[];else if(y===123)f=125,g=!0,s={};else return!1;for(t.anchor!==null&&(t.anchorMap[t.anchor]=s),y=t.input.charCodeAt(++t.position);y!==0;){if(F(t,!0,n),y=t.input.charCodeAt(t.position),y===f)return t.position++,t.tag=a,t.anchor=d,t.kind=g?"mapping":"sequence",t.result=s,!0;r?y===44&&N(t,"expected the node content, but found ','"):N(t,"missed comma between flow collection entries"),x=h=E=null,m=p=!1,y===63&&(c=t.input.charCodeAt(t.position+1),z(c)&&(m=p=!0,t.position++,F(t,!0,n))),l=t.line,o=t.lineStart,i=t.position,de(t,n,be,!1,!0),x=t.tag,h=t.result,F(t,!0,n),y=t.input.charCodeAt(t.position),(p||t.line===l)&&y===58&&(m=!0,y=t.input.charCodeAt(++t.position),F(t,!0,n),de(t,n,be,!1,!0),E=t.result),g?ce(t,s,u,x,h,E,l,o,i):m?s.push(ce(t,null,u,x,h,E,l,o,i)):s.push(h),F(t,!0,n),y=t.input.charCodeAt(t.position),y===44?(r=!0,y=t.input.charCodeAt(++t.position)):r=!1}N(t,"unexpected end of the stream within a flow collection")}function ja(t,n){var r,l,o=ve,i=!1,a=!1,s=n,d=0,c=!1,f,m;if(m=t.input.charCodeAt(t.position),m===124)l=!1;else if(m===62)l=!0;else return!1;for(t.kind="scalar",t.result="";m!==0;)if(m=t.input.charCodeAt(++t.position),m===43||m===45)ve===o?o=m===43?nt:Ca:N(t,"repeat of a chomping mode identifier");else if((f=Sa(m))>=0)f===0?N(t,"bad explicit indentation width of a block scalar; it cannot be less than one"):a?N(t,"repeat of an indentation width identifier"):(s=n+f-1,a=!0);else break;if(ne(m)){do m=t.input.charCodeAt(++t.position);while(ne(m));if(m===35)do m=t.input.charCodeAt(++t.position);while(!W(m)&&m!==0)}for(;m!==0;){for(Se(t),t.lineIndent=0,m=t.input.charCodeAt(t.position);(!a||t.lineIndent<s)&&m===32;)t.lineIndent++,m=t.input.charCodeAt(++t.position);if(!a&&t.lineIndent>s&&(s=t.lineIndent),W(m)){d++;continue}if(t.lineIndent<s){o===nt?t.result+=T.repeat(`
|
|
43
|
+
`,i?1+d:d):o===ve&&i&&(t.result+=`
|
|
44
|
+
`);break}for(l?ne(m)?(c=!0,t.result+=T.repeat(`
|
|
45
|
+
`,i?1+d:d)):c?(c=!1,t.result+=T.repeat(`
|
|
46
|
+
`,d+1)):d===0?i&&(t.result+=" "):t.result+=T.repeat(`
|
|
47
|
+
`,d):t.result+=T.repeat(`
|
|
48
|
+
`,i?1+d:d),i=!0,a=!0,d=0,r=t.position;!W(m)&&m!==0;)m=t.input.charCodeAt(++t.position);J(t,r,t.position,!1)}return!0}function pt(t,n){var r,l=t.tag,o=t.anchor,i=[],a,s=!1,d;if(t.firstTabInLine!==-1)return!1;for(t.anchor!==null&&(t.anchorMap[t.anchor]=i),d=t.input.charCodeAt(t.position);d!==0&&(t.firstTabInLine!==-1&&(t.position=t.firstTabInLine,N(t,"tab characters must not be used in indentation")),!(d!==45||(a=t.input.charCodeAt(t.position+1),!z(a))));){if(s=!0,t.position++,F(t,!0,-1)&&t.lineIndent<=n){i.push(null),d=t.input.charCodeAt(t.position);continue}if(r=t.line,de(t,n,tt,!1,!0),i.push(t.result),F(t,!0,-1),d=t.input.charCodeAt(t.position),(t.line===r||t.lineIndent>n)&&d!==0)N(t,"bad indentation of a sequence entry");else if(t.lineIndent<n)break}return s?(t.tag=l,t.anchor=o,t.kind="sequence",t.result=i,!0):!1}function Oa(t,n,r){var l,o,i,a,s,d,c=t.tag,f=t.anchor,m={},p=Object.create(null),g=null,u=null,h=null,x=!1,E=!1,y;if(t.firstTabInLine!==-1)return!1;for(t.anchor!==null&&(t.anchorMap[t.anchor]=m),y=t.input.charCodeAt(t.position);y!==0;){if(!x&&t.firstTabInLine!==-1&&(t.position=t.firstTabInLine,N(t,"tab characters must not be used in indentation")),l=t.input.charCodeAt(t.position+1),i=t.line,(y===63||y===58)&&z(l))y===63?(x&&(ce(t,m,p,g,u,null,a,s,d),g=u=h=null),E=!0,x=!0,o=!0):x?(x=!1,o=!0):N(t,"incomplete explicit mapping pair; a key node is missed; or followed by a non-tabulated empty line"),t.position+=1,y=l;else{if(a=t.line,s=t.lineStart,d=t.position,!de(t,r,et,!1,!0))break;if(t.line===i){for(y=t.input.charCodeAt(t.position);ne(y);)y=t.input.charCodeAt(++t.position);if(y===58)y=t.input.charCodeAt(++t.position),z(y)||N(t,"a whitespace character is expected after the key-value separator within a block mapping"),x&&(ce(t,m,p,g,u,null,a,s,d),g=u=h=null),E=!0,x=!1,o=!1,g=t.tag,u=t.result;else if(E)N(t,"can not read an implicit mapping pair; a colon is missed");else return t.tag=c,t.anchor=f,!0}else if(E)N(t,"can not read a block mapping entry; a multiline key may not be an implicit key");else return t.tag=c,t.anchor=f,!0}if((t.line===i||t.lineIndent>n)&&(x&&(a=t.line,s=t.lineStart,d=t.position),de(t,n,we,!0,o)&&(x?u=t.result:h=t.result),x||(ce(t,m,p,g,u,h,a,s,d),g=u=h=null),F(t,!0,-1),y=t.input.charCodeAt(t.position)),(t.line===i||t.lineIndent>n)&&y!==0)N(t,"bad indentation of a mapping entry");else if(t.lineIndent<n)break}return x&&ce(t,m,p,g,u,null,a,s,d),E&&(t.tag=c,t.anchor=f,t.kind="mapping",t.result=m),E}function Ra(t){var n,r=!1,l=!1,o,i,a;if(a=t.input.charCodeAt(t.position),a!==33)return!1;if(t.tag!==null&&N(t,"duplication of a tag property"),a=t.input.charCodeAt(++t.position),a===60?(r=!0,a=t.input.charCodeAt(++t.position)):a===33?(l=!0,o="!!",a=t.input.charCodeAt(++t.position)):o="!",n=t.position,r){do a=t.input.charCodeAt(++t.position);while(a!==0&&a!==62);t.position<t.length?(i=t.input.slice(n,t.position),a=t.input.charCodeAt(++t.position)):N(t,"unexpected end of the stream within a verbatim tag")}else{for(;a!==0&&!z(a);)a===33&&(l?N(t,"tag suffix cannot contain exclamation marks"):(o=t.input.slice(n-1,t.position+1),rt.test(o)||N(t,"named tag handle cannot contain such characters"),l=!0,n=t.position+1)),a=t.input.charCodeAt(++t.position);i=t.input.slice(n,t.position),Aa.test(i)&&N(t,"tag suffix cannot contain flow indicator characters")}i&&!ot.test(i)&&N(t,"tag name cannot contain such characters: "+i);try{i=decodeURIComponent(i)}catch{N(t,"tag name is malformed: "+i)}return r?t.tag=i:X.call(t.tagMap,o)?t.tag=t.tagMap[o]+i:o==="!"?t.tag="!"+i:o==="!!"?t.tag="tag:yaml.org,2002:"+i:N(t,'undeclared tag handle "'+o+'"'),!0}function Ua(t){var n,r;if(r=t.input.charCodeAt(t.position),r!==38)return!1;for(t.anchor!==null&&N(t,"duplication of an anchor property"),r=t.input.charCodeAt(++t.position),n=t.position;r!==0&&!z(r)&&!ie(r);)r=t.input.charCodeAt(++t.position);return t.position===n&&N(t,"name of an anchor node must contain at least one character"),t.anchor=t.input.slice(n,t.position),!0}function Pa(t){var n,r,l;if(l=t.input.charCodeAt(t.position),l!==42)return!1;for(l=t.input.charCodeAt(++t.position),n=t.position;l!==0&&!z(l)&&!ie(l);)l=t.input.charCodeAt(++t.position);return t.position===n&&N(t,"name of an alias node must contain at least one character"),r=t.input.slice(n,t.position),X.call(t.anchorMap,r)||N(t,'unidentified alias "'+r+'"'),t.result=t.anchorMap[r],F(t,!0,-1),!0}function de(t,n,r,l,o){var i,a,s,d=1,c=!1,f=!1,m,p,g,u,h,x;if(t.listener!==null&&t.listener("open",t),t.tag=null,t.anchor=null,t.kind=null,t.result=null,i=a=s=we===r||tt===r,l&&F(t,!0,-1)&&(c=!0,t.lineIndent>n?d=1:t.lineIndent===n?d=0:t.lineIndent<n&&(d=-1)),d===1)for(;Ra(t)||Ua(t);)F(t,!0,-1)?(c=!0,s=i,t.lineIndent>n?d=1:t.lineIndent===n?d=0:t.lineIndent<n&&(d=-1)):s=!1;if(s&&(s=c||o),(d===1||we===r)&&(be===r||et===r?h=n:h=n+1,x=t.position-t.lineStart,d===1?s&&(pt(t,x)||Oa(t,x,h))||Ia(t,h)?f=!0:(a&&ja(t,h)||Ma(t,h)||Da(t,h)?f=!0:Pa(t)?(f=!0,(t.tag!==null||t.anchor!==null)&&N(t,"alias node should not have any properties")):Ta(t,h,be===r)&&(f=!0,t.tag===null&&(t.tag="?")),t.anchor!==null&&(t.anchorMap[t.anchor]=t.result)):d===0&&(f=s&&pt(t,x))),t.tag===null)t.anchor!==null&&(t.anchorMap[t.anchor]=t.result);else if(t.tag==="?"){for(t.result!==null&&t.kind!=="scalar"&&N(t,'unacceptable node kind for !<?> tag; it should be "scalar", not "'+t.kind+'"'),m=0,p=t.implicitTypes.length;m<p;m+=1)if(u=t.implicitTypes[m],u.resolve(t.result)){t.result=u.construct(t.result),t.tag=u.tag,t.anchor!==null&&(t.anchorMap[t.anchor]=t.result);break}}else if(t.tag!=="!"){if(X.call(t.typeMap[t.kind||"fallback"],t.tag))u=t.typeMap[t.kind||"fallback"][t.tag];else for(u=null,g=t.typeMap.multi[t.kind||"fallback"],m=0,p=g.length;m<p;m+=1)if(t.tag.slice(0,g[m].tag.length)===g[m].tag){u=g[m];break}u||N(t,"unknown tag !<"+t.tag+">"),t.result!==null&&u.kind!==t.kind&&N(t,"unacceptable node kind for !<"+t.tag+'> tag; it should be "'+u.kind+'", not "'+t.kind+'"'),u.resolve(t.result,t.tag)?(t.result=u.construct(t.result,t.tag),t.anchor!==null&&(t.anchorMap[t.anchor]=t.result)):N(t,"cannot resolve a node with !<"+t.tag+"> explicit tag")}return t.listener!==null&&t.listener("close",t),t.tag!==null||t.anchor!==null||f}function za(t){var n=t.position,r,l,o,i=!1,a;for(t.version=null,t.checkLineBreaks=t.legacy,t.tagMap=Object.create(null),t.anchorMap=Object.create(null);(a=t.input.charCodeAt(t.position))!==0&&(F(t,!0,-1),a=t.input.charCodeAt(t.position),!(t.lineIndent>0||a!==37));){for(i=!0,a=t.input.charCodeAt(++t.position),r=t.position;a!==0&&!z(a);)a=t.input.charCodeAt(++t.position);for(l=t.input.slice(r,t.position),o=[],l.length<1&&N(t,"directive name must not be less than one character in length");a!==0;){for(;ne(a);)a=t.input.charCodeAt(++t.position);if(a===35){do a=t.input.charCodeAt(++t.position);while(a!==0&&!W(a));break}if(W(a))break;for(r=t.position;a!==0&&!z(a);)a=t.input.charCodeAt(++t.position);o.push(t.input.slice(r,t.position))}a!==0&&Se(t),X.call(dt,l)?dt[l](t,l,o):_e(t,'unknown document directive "'+l+'"')}if(F(t,!0,-1),t.lineIndent===0&&t.input.charCodeAt(t.position)===45&&t.input.charCodeAt(t.position+1)===45&&t.input.charCodeAt(t.position+2)===45?(t.position+=3,F(t,!0,-1)):i&&N(t,"directives end mark is expected"),de(t,t.lineIndent-1,we,!1,!0),F(t,!0,-1),t.checkLineBreaks&&Va.test(t.input.slice(n,t.position))&&_e(t,"non-ASCII line breaks are interpreted as content"),t.documents.push(t.result),t.position===t.lineStart&&Ee(t)){t.input.charCodeAt(t.position)===46&&(t.position+=3,F(t,!0,-1));return}if(t.position<t.length-1)N(t,"end of the stream or a document separator is expected");else return}function ft(t,n){t=String(t),n=n||{},t.length!==0&&(t.charCodeAt(t.length-1)!==10&&t.charCodeAt(t.length-1)!==13&&(t+=`
|
|
49
|
+
`),t.charCodeAt(0)===65279&&(t=t.slice(1)));var r=new La(t,n),l=t.indexOf("\0");for(l!==-1&&(r.position=l,N(r,"null byte is not allowed in input")),r.input+="\0";r.input.charCodeAt(r.position)===32;)r.lineIndent+=1,r.position+=1;for(;r.position<r.length-1;)za(r);return r.documents}function qa(t,n,r){n!==null&&typeof n=="object"&&typeof r>"u"&&(r=n,n=null);var l=ft(t,r);if(typeof n!="function")return l;for(var o=0,i=l.length;o<i;o+=1)n(l[o])}function Ha(t,n){var r=ft(t,n);if(r.length!==0){if(r.length===1)return r[0];throw new P("expected a single document in the stream, but found more")}}var Ya=qa,Ka=Ha,Wa={loadAll:Ya,load:Ka},ut=Object.prototype.toString,gt=Object.prototype.hasOwnProperty,Le=65279,Ga=9,ge=10,Za=13,Qa=32,Xa=33,Ja=34,Te=35,ei=37,ti=38,ni=39,ri=42,ht=44,oi=45,Ne=58,li=61,ai=62,ii=63,si=64,yt=91,xt=93,ci=96,kt=123,di=124,bt=125,O={};O[0]="\\0",O[7]="\\a",O[8]="\\b",O[9]="\\t",O[10]="\\n",O[11]="\\v",O[12]="\\f",O[13]="\\r",O[27]="\\e",O[34]='\\"',O[92]="\\\\",O[133]="\\N",O[160]="\\_",O[8232]="\\L",O[8233]="\\P";var mi=["y","Y","yes","Yes","YES","on","On","ON","n","N","no","No","NO","off","Off","OFF"],pi=/^[-+]?[0-9_]+(?::[0-9_]+)+(?:\.[0-9_]*)?$/;function fi(t,n){var r,l,o,i,a,s,d;if(n===null)return{};for(r={},l=Object.keys(n),o=0,i=l.length;o<i;o+=1)a=l[o],s=String(n[a]),a.slice(0,2)==="!!"&&(a="tag:yaml.org,2002:"+a.slice(2)),d=t.compiledTypeMap.fallback[a],d&>.call(d.styleAliases,s)&&(s=d.styleAliases[s]),r[a]=s;return r}function ui(t){var n,r,l;if(n=t.toString(16).toUpperCase(),t<=255)r="x",l=2;else if(t<=65535)r="u",l=4;else if(t<=4294967295)r="U",l=8;else throw new P("code point within a string may not be greater than 0xFFFFFFFF");return"\\"+r+T.repeat("0",l-n.length)+n}var gi=1,he=2;function hi(t){this.schema=t.schema||Je,this.indent=Math.max(1,t.indent||2),this.noArrayIndent=t.noArrayIndent||!1,this.skipInvalid=t.skipInvalid||!1,this.flowLevel=T.isNothing(t.flowLevel)?-1:t.flowLevel,this.styleMap=fi(this.schema,t.styles||null),this.sortKeys=t.sortKeys||!1,this.lineWidth=t.lineWidth||80,this.noRefs=t.noRefs||!1,this.noCompatMode=t.noCompatMode||!1,this.condenseFlow=t.condenseFlow||!1,this.quotingType=t.quotingType==='"'?he:gi,this.forceQuotes=t.forceQuotes||!1,this.replacer=typeof t.replacer=="function"?t.replacer:null,this.implicitTypes=this.schema.compiledImplicit,this.explicitTypes=this.schema.compiledExplicit,this.tag=null,this.result="",this.duplicates=[],this.usedDuplicates=null}function wt(t,n){for(var r=T.repeat(" ",n),l=0,o=-1,i="",a,s=t.length;l<s;)o=t.indexOf(`
|
|
50
|
+
`,l),o===-1?(a=t.slice(l),l=s):(a=t.slice(l,o+1),l=o+1),a.length&&a!==`
|
|
51
|
+
`&&(i+=r),i+=a;return i}function Me(t,n){return`
|
|
52
|
+
`+T.repeat(" ",t.indent*n)}function yi(t,n){var r,l,o;for(r=0,l=t.implicitTypes.length;r<l;r+=1)if(o=t.implicitTypes[r],o.resolve(n))return!0;return!1}function Ce(t){return t===Qa||t===Ga}function ye(t){return 32<=t&&t<=126||161<=t&&t<=55295&&t!==8232&&t!==8233||57344<=t&&t<=65533&&t!==Le||65536<=t&&t<=1114111}function _t(t){return ye(t)&&t!==Le&&t!==Za&&t!==ge}function Et(t,n,r){var l=_t(t),o=l&&!Ce(t);return(r?l:l&&t!==ht&&t!==yt&&t!==xt&&t!==kt&&t!==bt)&&t!==Te&&!(n===Ne&&!o)||_t(n)&&!Ce(n)&&t===Te||n===Ne&&o}function xi(t){return ye(t)&&t!==Le&&!Ce(t)&&t!==oi&&t!==ii&&t!==Ne&&t!==ht&&t!==yt&&t!==xt&&t!==kt&&t!==bt&&t!==Te&&t!==ti&&t!==ri&&t!==Xa&&t!==di&&t!==li&&t!==ai&&t!==ni&&t!==Ja&&t!==ei&&t!==si&&t!==ci}function ki(t){return!Ce(t)&&t!==Ne}function xe(t,n){var r=t.charCodeAt(n),l;return r>=55296&&r<=56319&&n+1<t.length&&(l=t.charCodeAt(n+1),l>=56320&&l<=57343)?(r-55296)*1024+l-56320+65536:r}function Nt(t){var n=/^\n* /;return n.test(t)}var Ct=1,De=2,Bt=3,Vt=4,me=5;function bi(t,n,r,l,o,i,a,s){var d,c=0,f=null,m=!1,p=!1,g=l!==-1,u=-1,h=xi(xe(t,0))&&ki(xe(t,t.length-1));if(n||a)for(d=0;d<t.length;c>=65536?d+=2:d++){if(c=xe(t,d),!ye(c))return me;h=h&&Et(c,f,s),f=c}else{for(d=0;d<t.length;c>=65536?d+=2:d++){if(c=xe(t,d),c===ge)m=!0,g&&(p=p||d-u-1>l&&t[u+1]!==" ",u=d);else if(!ye(c))return me;h=h&&Et(c,f,s),f=c}p=p||g&&d-u-1>l&&t[u+1]!==" "}return!m&&!p?h&&!a&&!o(t)?Ct:i===he?me:De:r>9&&Nt(t)?me:a?i===he?me:De:p?Vt:Bt}function wi(t,n,r,l,o){t.dump=(function(){if(n.length===0)return t.quotingType===he?'""':"''";if(!t.noCompatMode&&(mi.indexOf(n)!==-1||pi.test(n)))return t.quotingType===he?'"'+n+'"':"'"+n+"'";var i=t.indent*Math.max(1,r),a=t.lineWidth===-1?-1:Math.max(Math.min(t.lineWidth,40),t.lineWidth-i),s=l||t.flowLevel>-1&&r>=t.flowLevel;function d(c){return yi(t,c)}switch(bi(n,s,t.indent,a,d,t.quotingType,t.forceQuotes&&!l,o)){case Ct:return n;case De:return"'"+n.replace(/'/g,"''")+"'";case Bt:return"|"+At(n,t.indent)+$t(wt(n,i));case Vt:return">"+At(n,t.indent)+$t(wt(_i(n,a),i));case me:return'"'+Ei(n)+'"';default:throw new P("impossible error: invalid scalar style")}})()}function At(t,n){var r=Nt(t)?String(n):"",l=t[t.length-1]===`
|
|
53
|
+
`,o=l&&(t[t.length-2]===`
|
|
54
|
+
`||t===`
|
|
55
|
+
`),i=o?"+":l?"":"-";return r+i+`
|
|
56
|
+
`}function $t(t){return t[t.length-1]===`
|
|
57
|
+
`?t.slice(0,-1):t}function _i(t,n){for(var r=/(\n+)([^\n]*)/g,l=(function(){var c=t.indexOf(`
|
|
58
|
+
`);return c=c!==-1?c:t.length,r.lastIndex=c,vt(t.slice(0,c),n)})(),o=t[0]===`
|
|
59
|
+
`||t[0]===" ",i,a;a=r.exec(t);){var s=a[1],d=a[2];i=d[0]===" ",l+=s+(!o&&!i&&d!==""?`
|
|
60
|
+
`:"")+vt(d,n),o=i}return l}function vt(t,n){if(t===""||t[0]===" ")return t;for(var r=/ [^ ]/g,l,o=0,i,a=0,s=0,d="";l=r.exec(t);)s=l.index,s-o>n&&(i=a>o?a:s,d+=`
|
|
61
|
+
`+t.slice(o,i),o=i+1),a=s;return d+=`
|
|
62
|
+
`,t.length-o>n&&a>o?d+=t.slice(o,a)+`
|
|
63
|
+
`+t.slice(a+1):d+=t.slice(o),d.slice(1)}function Ei(t){for(var n="",r=0,l,o=0;o<t.length;r>=65536?o+=2:o++)r=xe(t,o),l=O[r],!l&&ye(r)?(n+=t[o],r>=65536&&(n+=t[o+1])):n+=l||ui(r);return n}function Ni(t,n,r){var l="",o=t.tag,i,a,s;for(i=0,a=r.length;i<a;i+=1)s=r[i],t.replacer&&(s=t.replacer.call(r,String(i),s)),(Z(t,n,s,!1,!1)||typeof s>"u"&&Z(t,n,null,!1,!1))&&(l!==""&&(l+=","+(t.condenseFlow?"":" ")),l+=t.dump);t.tag=o,t.dump="["+l+"]"}function St(t,n,r,l){var o="",i=t.tag,a,s,d;for(a=0,s=r.length;a<s;a+=1)d=r[a],t.replacer&&(d=t.replacer.call(r,String(a),d)),(Z(t,n+1,d,!0,!0,!1,!0)||typeof d>"u"&&Z(t,n+1,null,!0,!0,!1,!0))&&((!l||o!=="")&&(o+=Me(t,n)),t.dump&&ge===t.dump.charCodeAt(0)?o+="-":o+="- ",o+=t.dump);t.tag=i,t.dump=o||"[]"}function Ci(t,n,r){var l="",o=t.tag,i=Object.keys(r),a,s,d,c,f;for(a=0,s=i.length;a<s;a+=1)f="",l!==""&&(f+=", "),t.condenseFlow&&(f+='"'),d=i[a],c=r[d],t.replacer&&(c=t.replacer.call(r,d,c)),Z(t,n,d,!1,!1)&&(t.dump.length>1024&&(f+="? "),f+=t.dump+(t.condenseFlow?'"':"")+":"+(t.condenseFlow?"":" "),Z(t,n,c,!1,!1)&&(f+=t.dump,l+=f));t.tag=o,t.dump="{"+l+"}"}function Bi(t,n,r,l){var o="",i=t.tag,a=Object.keys(r),s,d,c,f,m,p;if(t.sortKeys===!0)a.sort();else if(typeof t.sortKeys=="function")a.sort(t.sortKeys);else if(t.sortKeys)throw new P("sortKeys must be a boolean or a function");for(s=0,d=a.length;s<d;s+=1)p="",(!l||o!=="")&&(p+=Me(t,n)),c=a[s],f=r[c],t.replacer&&(f=t.replacer.call(r,c,f)),Z(t,n+1,c,!0,!0,!0)&&(m=t.tag!==null&&t.tag!=="?"||t.dump&&t.dump.length>1024,m&&(t.dump&&ge===t.dump.charCodeAt(0)?p+="?":p+="? "),p+=t.dump,m&&(p+=Me(t,n)),Z(t,n+1,f,!0,m)&&(t.dump&&ge===t.dump.charCodeAt(0)?p+=":":p+=": ",p+=t.dump,o+=p));t.tag=i,t.dump=o||"{}"}function Ft(t,n,r){var l,o,i,a,s,d;for(o=r?t.explicitTypes:t.implicitTypes,i=0,a=o.length;i<a;i+=1)if(s=o[i],(s.instanceOf||s.predicate)&&(!s.instanceOf||typeof n=="object"&&n instanceof s.instanceOf)&&(!s.predicate||s.predicate(n))){if(r?s.multi&&s.representName?t.tag=s.representName(n):t.tag=s.tag:t.tag="?",s.represent){if(d=t.styleMap[s.tag]||s.defaultStyle,ut.call(s.represent)==="[object Function]")l=s.represent(n,d);else if(gt.call(s.represent,d))l=s.represent[d](n,d);else throw new P("!<"+s.tag+'> tag resolver accepts not "'+d+'" style');t.dump=l}return!0}return!1}function Z(t,n,r,l,o,i,a){t.tag=null,t.dump=r,Ft(t,r,!1)||Ft(t,r,!0);var s=ut.call(t.dump),d=l,c;l&&(l=t.flowLevel<0||t.flowLevel>n);var f=s==="[object Object]"||s==="[object Array]",m,p;if(f&&(m=t.duplicates.indexOf(r),p=m!==-1),(t.tag!==null&&t.tag!=="?"||p||t.indent!==2&&n>0)&&(o=!1),p&&t.usedDuplicates[m])t.dump="*ref_"+m;else{if(f&&p&&!t.usedDuplicates[m]&&(t.usedDuplicates[m]=!0),s==="[object Object]")l&&Object.keys(t.dump).length!==0?(Bi(t,n,t.dump,o),p&&(t.dump="&ref_"+m+t.dump)):(Ci(t,n,t.dump),p&&(t.dump="&ref_"+m+" "+t.dump));else if(s==="[object Array]")l&&t.dump.length!==0?(t.noArrayIndent&&!a&&n>0?St(t,n-1,t.dump,o):St(t,n,t.dump,o),p&&(t.dump="&ref_"+m+t.dump)):(Ni(t,n,t.dump),p&&(t.dump="&ref_"+m+" "+t.dump));else if(s==="[object String]")t.tag!=="?"&&wi(t,t.dump,n,i,d);else{if(s==="[object Undefined]")return!1;if(t.skipInvalid)return!1;throw new P("unacceptable kind of an object to dump "+s)}t.tag!==null&&t.tag!=="?"&&(c=encodeURI(t.tag[0]==="!"?t.tag.slice(1):t.tag).replace(/!/g,"%21"),t.tag[0]==="!"?c="!"+c:c.slice(0,18)==="tag:yaml.org,2002:"?c="!!"+c.slice(18):c="!<"+c+">",t.dump=c+" "+t.dump)}return!0}function Vi(t,n){var r=[],l=[],o,i;for(Ie(t,r,l),o=0,i=l.length;o<i;o+=1)n.duplicates.push(r[l[o]]);n.usedDuplicates=new Array(i)}function Ie(t,n,r){var l,o,i;if(t!==null&&typeof t=="object")if(o=n.indexOf(t),o!==-1)r.indexOf(o)===-1&&r.push(o);else if(n.push(t),Array.isArray(t))for(o=0,i=t.length;o<i;o+=1)Ie(t[o],n,r);else for(l=Object.keys(t),o=0,i=l.length;o<i;o+=1)Ie(t[l[o]],n,r)}function Ai(t,n){n=n||{};var r=new hi(n);r.noRefs||Vi(t,r);var l=t;return r.replacer&&(l=r.replacer.call({"":l},"",l)),Z(r,0,l,!0,!0)?r.dump+`
|
|
64
|
+
`:""}var $i=Ai,vi={dump:$i},Si=Wa.load,Lt=vi.dump;const Fi={class:"flex flex-col flex-1 overflow-hidden"},Li={class:"flex justify-end gap-2"},Ti={class:"w-20 gap-2 whitespace-nowrap rounded-md font-medium ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 px-4 py-2 h-9 text-xs bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm transition-all duration-300 hover:shadow-md hover:scale-[1.02] relative overflow-hidden"},Mi=["href"],Di={class:"flex flex-col flex-1 overflow-hidden"},Ii={class:"bg-white rounded-xl border border-gray-200 shadow-sm overflow-hidden mt-3 flex flex-col flex-1"},ji={class:"relative bg-gradient-to-br from-slate-50 to-white flex-1"},Oi=e.defineComponent({__name:"vs-tab-style",props:{token:{},styleYaml:{}},emits:["update:styleYaml","update"],setup(t,{emit:n}){const r=t,l=n,o=e.ref("");e.watch(()=>r.styleYaml,d=>{try{const c=d?Lt(d):"";!o.value&&c!==o.value&&(o.value=c)}catch{o.value=""}},{immediate:!0,deep:!0}),e.watch(o,async d=>{var c,f;try{const m=d?Si(d):null;if((c=m==null?void 0:m.colorAttr)!=null&&c.length&&((f=r.styleYaml)==null?void 0:f.colorAttr)!==m.colorAttr){const p=await i(m.colorAttr);m.colors=p.reduce((u,h,x)=>({...u,[h.id.toString()]:a[x]}),{});const g=Lt(m);g!==o.value&&(o.value=g)}JSON.stringify(m)!==JSON.stringify(r.styleYaml)&&l("update:styleYaml",m)}catch{}});async function i(d){return(await fetch(`/api/gis-service/${r.token}/${d}`).then(f=>f.json())).rows}const a=["#8dd3c7","#ffffb3","#bebada","#fb8072","#80b1d3","#fdb462","#b3de69","#fccde5","#d9d9d9","#bc80bd"],s=async()=>{try{await fetch(`/api/gis-service/${r.token}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({style:o.value})}),l("update"),K.notify({type:"success",title:"Успіх",message:"Стилі збережено"})}catch(d){K.notify({type:"error",title:"Помилка",message:"Не вдалося зберегти стилі"}),console.log(d)}};return(d,c)=>(e.openBlock(),e.createElementBlock("div",Fi,[e.createElementVNode("div",Li,[e.createElementVNode("button",Ti,[e.createElementVNode("a",{target:"_blank",href:"/api/gis-service/"+r.token+"/col"},"Attr",8,Mi)]),e.createElementVNode("button",{onClick:s,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 bg-primary hover:bg-primary/90 px-4 py-2 h-9 text-xs bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm transition-all duration-300 hover:shadow-md hover:scale-[1.02] relative overflow-hidden"},[...c[1]||(c[1]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-save h-3 w-3 mr-1"},[e.createElementVNode("path",{d:"M15.2 3a2 2 0 0 1 1.4.6l3.8 3.8a2 2 0 0 1 .6 1.4V19a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2z"}),e.createElementVNode("path",{d:"M17 21v-7a1 1 0 0 0-1-1H8a1 1 0 0 0-1 1v7"}),e.createElementVNode("path",{d:"M7 3v4a1 1 0 0 0 1 1h7"})],-1),e.createTextVNode(" Зберегти стилі ",-1)])])]),e.createElementVNode("div",Di,[e.createElementVNode("div",Ii,[c[2]||(c[2]=e.createElementVNode("div",{class:"bg-gradient-to-r from-gray-50 to-gray-100 px-4 py-2 border-b border-gray-200 flex items-center justify-between"},[e.createElementVNode("div",{class:"text-xs text-gray-400"},"YAML")],-1)),e.createElementVNode("div",ji,[e.createVNode(Ke,{modelValue:o.value,"onUpdate:modelValue":c[0]||(c[0]=f=>o.value=f),language:"yaml",theme:"vs-light"},null,8,["modelValue"])])])])]))}}),Tt=Symbol("MapContext");function Ri(t){const n=e.shallowRef(null),r=e.ref(!1);let l=!1;const o=[],i=()=>{l=!0,o.length&&o.forEach(m=>m())},a=()=>{const m=t.container;return typeof m=="string"?document.getElementById(m):(m==null?void 0:m.value)!==void 0?m.value:m},s=()=>l?Promise.resolve():new Promise(m=>o.push(m)),d=async()=>{var p,g,u,h;if(typeof window>"u"||n.value)return;const m=a();if(!m)throw new Error("Map container not found");n.value=new maplibregl.Map({...t.mapOptions||{},center:[30,50],zoom:7,container:m}),(p=t.controls)!=null&&p.navigation&&n.value.addControl(new maplibregl.NavigationControl(typeof t.controls.navigation=="object"?t.controls.navigation:{}),"top-right"),(g=t.controls)!=null&&g.scale&&n.value.addControl(new maplibregl.ScaleControl(typeof t.controls.scale=="object"?t.controls.scale:{}),"bottom-left"),(u=t.controls)!=null&&u.fullscreen&&n.value.addControl(new maplibregl.FullscreenControl,"top-right"),(h=t.controls)!=null&&h.geolocate&&n.value.addControl(new maplibregl.GeolocateControl(typeof t.controls.geolocate=="object"?t.controls.geolocate:{}),"top-right"),n.value.once("load",()=>{r.value=!0,i()})},c=()=>{n.value&&(n.value.remove(),n.value=null,r.value=!1)};e.onMounted(d),e.onUnmounted(c);const f={map:n,ready:s,flyTo:m=>{var p;return(p=n.value)==null?void 0:p.flyTo(m)},fitBounds:(m,p)=>{var g;return(g=n.value)==null?void 0:g.fitBounds(m,p)},setCenter:m=>{var p;return(p=n.value)==null?void 0:p.setCenter(m)},setZoom:m=>{var p;return(p=n.value)==null?void 0:p.setZoom(m)},addControl:(m,p)=>{var g;return(g=n.value)==null?void 0:g.addControl(m,p)},removeControl:m=>{var p;return(p=n.value)==null?void 0:p.removeControl(m)},on:(m,p,g)=>{var u,h;return typeof p=="string"?((u=n.value)==null||u.on(m,p,g),()=>{var x;return(x=n.value)==null?void 0:x.off(m,p,g)}):((h=n.value)==null||h.on(m,p),()=>{var x;return(x=n.value)==null?void 0:x.off(m,p)})},off:(m,p,g)=>{var u,h;typeof p=="string"?(u=n.value)==null||u.off(m,p,g):(h=n.value)==null||h.off(m,p)},project:m=>{var p;return(p=n.value)==null?void 0:p.project(m)},unproject:m=>{var p;return(p=n.value)==null?void 0:p.unproject(m)}};return e.provide(Tt,f),f}function re(t){if(t)return{map:t,flyTo:t.value.flyTo,fitBounds:t.value.fitBounds};const n=e.inject(Tt);if(!n)throw new Error("useMap() called outside of a Map provider");return n}const je=new Map;function Oe(t){return t.colorAttr&&t.colors?["match",["get",t.colorAttr],...Object.entries(t.colors).reduce((n,r)=>n.concat(r),[]),"#94a3b8"]:null}function Ui(t){var l;if(!t.icon||!t.colors)return null;const n=[],r=(l=t.icon)==null?void 0:l.split("+")[0];return Object.values(t.colors||{}).forEach(o=>{n.push(`${r}+${o.replace("#","")}.png`)}),["match",["get",t.colorAttr],...Object.entries(t.colors).reduce((o,i,a)=>o.concat([i[0],n[a]]),[]),t.icon]}async function Mt(t,n,r){const l=[n],o=n.split("+")[0];Object.values(r||{}).forEach(i=>{l.push(`${o}+${i.replace("#","")}.png`)});for(let i=0;i<l.length;i+=1){const a=l[i];if(t.getImage(a))continue;const s=await t.loadImage("/api/gis-icon/"+a);t.addImage(a,s.data)}}function Dt(t,n){const r=Oe(t);if(!(t.icon&&!t.iconZoom))return{type:"circle",maxzoom:n||t.iconZoom||22,paint:{"circle-stroke-color":(t==null?void 0:t.stroke)||"#fff","circle-opacity":t.opacity||1,"circle-color":r||t.color,"circle-stroke-width":t.width||1,"circle-radius":t.radius||5}}}function Pi(t){const n=Oe(t);return{type:"fill",minzoom:t.pointZoom||0,paint:{"fill-color":n||t.color,"fill-opacity":t.opacity||.3,"fill-outline-color":t.stroke}}}function zi(t){return{type:"line",paint:{"line-color":Oe(t)||t.color,"line-opacity":t.opacity||1,"line-width":t.width||1.5}}}function qi(t){const n=Ui(t);return{type:"symbol",minzoom:t.iconZoom||0,layout:{"icon-image":n||t.icon,"icon-size":1,"icon-allow-overlap":!0,"icon-ignore-placement":!0}}}function It(t){const n=[];return t?(t.icon&&n.push(qi(t)),t.pointZoom&&n.push(Dt(t,t.pointZoom)),t.type==="polygon"&&n.push(Pi(t)),t.type==="line"&&n.push(zi(t)),t.type==="point"&&n.push(Dt(t)),n.filter(r=>r)):[]}const Re={};function R(t,n,r){var M,I,G;if(!t)return Re;if(!n)return Re[t];const{map:l,ready:o=()=>Promise.resolve()}=re(r),i=t||n.layer.id,a=n.sourceId??t;!n.layer&&((M=n.source)==null?void 0:M.type)==="raster"&&(n.layer={id:a,type:"raster",source:a}),(I=n.layer)!=null&&I.source||(n.layer.source=a),!n.layer["source-layer"]&&((G=n.source)==null?void 0:G.type)==="vector"&&(n.layer["source-layer"]=a);let s=!1,d=!1;const c=()=>{var V,A,L;if(!(d||!l.value)){if(n.source&&!l.value.getSource(a)&&l.value.addSource(a,n.source),!l.value.getLayer(i)){const C=n.beforeId===0?(A=(V=l.value.getStyle().layers)==null?void 0:V[0])==null?void 0:A.id:n.beforeId;(L=n.layer.style)!=null&&L.icon&&Mt(l.value,n.layer.style.icon,n.layer.style.colors);const _=It(n.layer.style);if(!_.length)return l.value.addLayer(n.layer,C);_.forEach(($,U)=>{Object.assign($,{id:i+(U||"")}),["source","source-layer"].forEach(q=>{$[q]=n.layer[q]}),l.value.addLayer($,C)})}s=!0}};o().then(c);const f=(V,A)=>l.value?(l.value.on(V,i,A),()=>{var L;return(L=l.value)==null?void 0:L.off(V,i,A)}):()=>{};function m(V){l.value&&l.value.getStyle().layers.filter(A=>A.source==i).forEach(A=>{l.value.setLayoutProperty(A.id,"visibility",V?"visible":"none")})}async function p(V){if(!l.value)return;V.icon&&Mt(l.value,V.icon,V.colors);const A=It(V);b(!1),A.forEach((L,C)=>{L.id=i+C,["source","source-layer"].forEach(_=>{L[_]=n==null?void 0:n.layer[_]}),l.value.addLayer(L)})}function g(V){l.value&&Object.entries(V).forEach(([A,L])=>l.value.setPaintProperty(i,A,L))}function u(V){l.value&&Object.entries(V).forEach(([A,L])=>l.value.setLayoutProperty(i,A,L))}function h(V){l.value&&l.value.setFilter(i,V)}function x(V){if(!l.value)return;const A=l.value.getSource(a);if(A&&"setTiles"in A&&n.source.tiles[0]){const L=n.source.tiles[0];A.setTiles([L+"?filter="+V])}}function E(V){if(!l.value)return;const A=l.value.getSource(a);A&&"setTiles"in A&&A.setTiles(V)}function y(V){if(!l.value)return;const A=l.value.getSource(a);A&&"setData"in A&&A.setData(V)}function k(V,A){l.value&&l.value.setFeatureState({source:a,...V},A)}function w(V,A){l.value&&l.value.removeFeatureState({source:a,...V},A?{key:A}:void 0)}function b(V=!0){l.value&&(l.value.getStyle().layers.filter(A=>A.source==i).forEach(A=>{l.value.removeLayer(A.id)}),d=!0,n!=null&&n.source&&V&&l.value.getSource(a)&&l.value.removeSource(a))}const v={ids:{layerId:i,sourceId:a},isMounted:()=>{var V;return s&&!!((V=l.value)!=null&&V.getLayer(i))},setVisible:m,updatePaint:g,updateLayout:u,updateFilter:h,setData:y,setTiles:E,setStyle:p,setFilter:x,setFeatureState:k,removeFeatureState:w,remove:b,card:n.card,popup:n.popup,getSource:()=>{var V;return(V=l.value)==null?void 0:V.getSource(a)},getLayer:()=>{var V;return(V=l.value)==null?void 0:V.getLayer(i)},on:f};je.set(i,v);const S=()=>{je.get(i)===v&&je.delete(i)},B=v.remove;return v.remove=()=>{S(),B()},e.onBeforeUnmount(v.remove),Re[t]=v,v}const Hi={class:"flex flex-col flex-1"},Yi=e.defineComponent({__name:"vs-tab-popup",props:{token:{},fields:{},columns:{}},emits:["update:columns","save"],setup(t,{emit:n}){const r=t,l=n,o=e.ref(r.columns||[]);e.watch(()=>r.columns,u=>o.value=u||[],{immediate:!0}),e.watch(o,u=>{const h=R(r.token);h&&(h.popup=u),l("update:columns",u)});const i=e.ref("list"),a=e.ref(!1),s=e.ref([]),d=[{key:"name",label:"Name"},{key:"ua",label:"UA"},{key:"meta",label:"Meta"}],c={name:{type:"text",label:"Name",disabled:!0,validators:["required"]},label:{type:"text",label:"Label",validators:["required"]},meta:{type:"radio",label:"Meta",mode:"combo",options:[{text:"Title",id:"title"},{text:"Feature",id:"feature"},{text:"Badge",id:"badge"}]},data:{type:"text",label:"Data"}};function f(){s.value=o.value.map(u=>u.name||u.id),a.value=!0}function m(){var E;const u=[...o.value],h=((E=r.fields)==null?void 0:E.filter(y=>s.value.includes(y.name)))||[],x=ae(u,h,{selectedKeys:s.value,resolveKey:y=>Q(y)});o.value=x,a.value=!1,s.value=[]}function p(){a.value=!1,s.value=[]}function g(){let u=[];i.value==="all"?u=r.fields||[]:i.value==="none"?u=[]:u=o.value,u.filter(h=>!h.label).forEach(h=>h.label=h.ua),l("save",u)}return(u,h)=>(e.openBlock(),e.createElementBlock("div",Hi,[e.createElementVNode("div",{class:"flex justify-between mb-3 gap-2"},[e.createElementVNode("button",{onClick:f,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium bg-gradient-to-r from-gray-500 to-gray-400 text-white h-9 px-4 py-2 hover:from-gray-600 hover:to-gray-500"}," Імпорт "),e.createElementVNode("button",{onClick:g,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm px-4 py-2 h-9 text-xs transition-all duration-300"}," Зберегти popup ")]),i.value==="list"?(e.openBlock(),e.createBlock(te,{key:0,modelValue:o.value,"onUpdate:modelValue":h[0]||(h[0]=x=>o.value=x),"columns-scheme":d,"form-scheme":c,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])):e.createCommentVNode("",!0),e.createVNode(oe,{visible:a.value,"onUpdate:visible":h[1]||(h[1]=x=>a.value=x),selection:s.value,"onUpdate:selection":h[2]||(h[2]=x=>s.value=x),fields:u.fields,title:"Імпорт полів","id-prefix":"import-popup",onConfirm:m,onCancel:p},null,8,["visible","selection","fields"])]))}}),Ki={class:"flex flex-col flex-1"},Wi={class:"flex justify-between mb-3 gap-2"},Gi={class:"p-4 space-y-4 text-sm"},Zi={class:"space-y-1"},Qi={class:"space-y-1"},Xi={class:"flex items-center gap-3"},Ji={class:"flex justify-end gap-2 p-4 border-t"},es=e.defineComponent({__name:"vs-tab-legend",props:{mapInfo:{},token:{},columns:{}},emits:["update:columns","save"],setup(t,{emit:n}){const r=t,l=n,o=e.ref(r.columns||[]);e.watch(()=>r.columns,u=>{o.value=u||[]}),e.watch(o,u=>{l("update:columns",u)});const i=e.ref(!1),a=e.ref({name:"",color:"#2E86DE"}),s=e.defineAsyncComponent(()=>import("@opengis/core").then(u=>u.VsModal)),d=[{key:"name",label:"Назва"},{key:"color",label:"Колір",type:"color"}],c={name:{type:"text",label:"Назва",validators:["required"]},color:{type:"color",label:"Колір",validators:["required"]}};function f(u){u&&m(),i.value=u}function m(){a.value={name:"",color:"#2E86DE"}}function p(){var E,y;const u=(E=a.value.name)==null?void 0:E.trim();if(!u){K.notify({type:"warning",title:"Перевірка",message:"Вкажіть назву елементу легенди"});return}const h=((y=a.value.color)==null?void 0:y.trim())||"#2E86DE";if(o.value.some(k=>Q(k)===Q({name:u}))){K.notify({type:"warning",title:"Дубль",message:"Такий елемент легенди вже існує"});return}o.value=[...o.value,{name:u,color:h}],m(),i.value=!1}function g(){l("save",o.value)}return(u,h)=>(e.openBlock(),e.createElementBlock("div",Ki,[e.createElementVNode("div",Wi,[e.createElementVNode("button",{onClick:h[0]||(h[0]=x=>i.value=!0),class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium bg-gradient-to-r from-gray-500 to-gray-400 text-white h-9 px-4 py-2 hover:from-gray-600 hover:to-gray-500"}," Додати "),e.createElementVNode("button",{onClick:g,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm px-4 py-2 h-9 text-xs transition-all duration-300"}," Зберегти легенду ")]),e.createVNode(te,{modelValue:o.value,"onUpdate:modelValue":h[1]||(h[1]=x=>o.value=x),"columns-scheme":d,"form-scheme":c,"main-col-width":"250px","add-button":!1},null,8,["modelValue"]),e.createVNode(e.unref(s),{visible:i.value,title:"Новий елемент легенди","onUpdate:visible":f},{footer:e.withCtx(()=>[e.createElementVNode("div",Ji,[e.createElementVNode("button",{type:"button",class:"px-4 py-2 rounded bg-gray-100 text-gray-700",onClick:h[5]||(h[5]=x=>f(!1))}," Скасувати "),e.createElementVNode("button",{type:"button",class:"px-4 py-2 rounded bg-blue-600 text-white",onClick:p}," Додати ")])]),default:e.withCtx(()=>[e.createElementVNode("div",Gi,[e.createElementVNode("div",Zi,[h[6]||(h[6]=e.createElementVNode("label",{class:"block text-xs font-medium text-gray-500 uppercase tracking-wide"}," Назва ",-1)),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":h[2]||(h[2]=x=>a.value.name=x),type:"text",class:"w-full rounded-md border border-gray-300 px-3 py-2 text-sm focus:border-blue-500 focus:outline-none focus:ring-2 focus:ring-blue-200",placeholder:"Наприклад, Житлова зона"},null,512),[[e.vModelText,a.value.name]])]),e.createElementVNode("div",Qi,[h[7]||(h[7]=e.createElementVNode("label",{class:"block text-xs font-medium text-gray-500 uppercase tracking-wide"}," Колір ",-1)),e.createElementVNode("div",Xi,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":h[3]||(h[3]=x=>a.value.color=x),type:"color",class:"h-10 w-16 rounded border border-gray-300"},null,512),[[e.vModelText,a.value.color]]),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":h[4]||(h[4]=x=>a.value.color=x),type:"text",class:"flex-1 rounded-md border border-gray-300 px-3 py-2 text-sm focus:border-blue-500 focus:outline-none focus:ring-2 focus:ring-blue-200",placeholder:"#FFFFFF"},null,512),[[e.vModelText,a.value.color]])])])])]),_:1},8,["visible"])]))}}),ts={class:"space-y-3 bg-gradient-to-br from-sky-50 to-blue-50 p-4 rounded-xl border border-sky-100 shadow-sm"},ns=["onClick"],rs=["aria-checked","value"],os={key:0},ls=e.defineComponent({__name:"view-mode-toggle",props:{modelValue:{},options:{},showHtml:{type:Boolean}},emits:["update:modelValue"],setup(t,{emit:n}){const r=t,l=n,o=a=>l("update:modelValue",a),i=r.options||[{value:"all",label:"All"},{value:"list",label:"List"},{value:"none",label:"None"}];return(a,s)=>(e.openBlock(),e.createElementBlock("div",ts,[s[1]||(s[1]=e.createElementVNode("label",{class:"text-sm font-medium text-gray-600"},"Режим відображення",-1)),e.createElementVNode("div",{role:"radiogroup",class:e.normalizeClass(["grid gap-2",`grid-cols-${e.unref(i).length}`])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(i),d=>(e.openBlock(),e.createElementBlock("div",{key:d.value,onClick:c=>o(d.value),class:e.normalizeClass(["flex items-center justify-center space-x-2 rounded-lg p-2 border transition-all duration-300 cursor-pointer",[a.modelValue===d.value?"bg-gradient-to-r from-sky-200 to-blue-200 border-transparent shadow-sm":"bg-white border-gray-100 hover:border-sky-200 hover:shadow-sm"]])},[e.createElementVNode("button",{type:"button",role:"radio","aria-checked":a.modelValue===d.value,value:d.value,class:"aspect-square rounded-full border border-primary h-4 w-4 flex items-center justify-center text-sky-500"},[a.modelValue===d.value?(e.openBlock(),e.createElementBlock("span",os,[...s[0]||(s[0]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-circle h-2.5 w-2.5 fill-current text-current"},[e.createElementVNode("circle",{cx:"12",cy:"12",r:"10"})],-1)])])):e.createCommentVNode("",!0)],8,rs),e.createElementVNode("label",{class:e.normalizeClass(["text-xs font-medium cursor-pointer",a.modelValue===d.value?"text-gray-700":"text-gray-600"])},e.toDisplayString(d.label),3)],10,ns))),128))],2)]))}}),as={class:"flex flex-col flex-1"},is=e.defineComponent({__name:"vs-tab-card",props:{fields:{},columns:{}},emits:["update:columns","save"],setup(t,{emit:n}){const r=t,l=n,o=e.ref(r.columns||[]);e.watch(()=>r.columns,x=>o.value=x||[],{immediate:!0}),e.watch(o,x=>l("update:columns",x));const i=e.ref("list"),a=e.ref("<div>Hello HTML</div>"),s=e.ref(!1),d=e.ref([]),c=[{key:"name",label:"Name"},{key:"ua",label:"UA"},{key:"format",label:"Format"}],f={name:{type:"text",label:"Name",validators:["required"],disabled:!0},label:{type:"text",label:"Label",validators:["required"]},format:{type:"radio",label:"Format",mode:"inline",validators:["required"],options:[{text:"Text",id:"text"},{text:"Number",id:"number"},{text:"Date",id:"date"},{text:"File",id:"file"},{text:"Select",id:"select"}]},data:{type:"text",label:"Data"}};function m(){d.value=o.value.map(x=>x.name||x.id),s.value=!0}function p(){var k;const x=[...o.value],E=((k=r.fields)==null?void 0:k.filter(w=>d.value.includes(w.name)))||[],y=ae(x,E,{selectedKeys:d.value,resolveKey:w=>Q(w)});o.value=y,s.value=!1,d.value=[]}function g(){s.value=!1,d.value=[]}function u(){i.value==="html"?l("save","html",a.value):l("save","card",o.value)}const h=[{value:"all",label:"All"},{value:"list",label:"List"},{value:"none",label:"None"},{value:"html",label:"HTML"}];return(x,E)=>(e.openBlock(),e.createElementBlock("div",as,[e.createElementVNode("div",{class:"flex justify-between mb-3 gap-2"},[e.createElementVNode("button",{onClick:m,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium bg-gradient-to-r from-gray-500 to-gray-400 text-white h-9 px-4 py-2 hover:from-gray-600 hover:to-gray-500"}," Імпорт "),e.createElementVNode("button",{onClick:u,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm px-4 py-2 h-9 text-xs transition-all duration-300"}," Зберегти ")]),e.createVNode(ls,{modelValue:i.value,"onUpdate:modelValue":E[0]||(E[0]=y=>i.value=y),options:h},null,8,["modelValue"]),i.value==="list"?(e.openBlock(),e.createBlock(te,{key:0,modelValue:o.value,"onUpdate:modelValue":E[1]||(E[1]=y=>o.value=y),"columns-scheme":c,"form-scheme":f,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])):e.createCommentVNode("",!0),i.value==="html"?(e.openBlock(),e.createBlock(Ke,{key:1,modelValue:a.value,"onUpdate:modelValue":E[2]||(E[2]=y=>a.value=y),language:"html",theme:"vs-light"},null,8,["modelValue"])):e.createCommentVNode("",!0),e.createVNode(oe,{visible:s.value,"onUpdate:visible":E[3]||(E[3]=y=>s.value=y),selection:d.value,"onUpdate:selection":E[4]||(E[4]=y=>d.value=y),fields:x.fields,title:"Імпорт полів для картки","id-prefix":"import-card",onConfirm:p,onCancel:g},null,8,["visible","selection","fields"])]))}}),ss={class:"flex flex-col flex-1"},cs=e.defineComponent({__name:"vs-tab-filter",props:{fields:{},columns:{}},emits:["update:columns","save"],setup(t,{emit:n}){const r=t,l=n;console.log(r.columns);const o=e.ref(r.columns||[]);e.watch(()=>r.columns,u=>o.value=u||[],{immediate:!0}),e.watch(o,u=>l("update:columns",u));const i=e.ref("list"),a=e.ref(!1),s=e.ref([]),d=[{key:"id",label:"Name"},{key:"label",label:"UA"},{key:"type",label:"Тип"}],c={name:{type:"text",label:"Name",disabled:!0,validators:["required"]},label:{type:"text",label:"UA",validators:["required"]},type:{type:"radio",label:"Тип",validators:["required"],options:[{text:"Check",id:"check"},{text:"Range",id:"range"},{text:"Date",id:"date"},{text:"Text",id:"text"},{text:"Autocomplete",id:"autocomplete"}]},data:{type:"text",label:"Класифікатор",conditions:["type","in",["autocomplete"]],validators:["required"]}};function f(){s.value=o.value.map(u=>u.name||u.id),a.value=!0}function m(){var E;const u=[...o.value],h=((E=r.fields)==null?void 0:E.filter(y=>s.value.includes(y.name)))||[],x=ae(u,h,{selectedKeys:s.value,resolveKey:y=>Q(y)});o.value=x,a.value=!1,s.value=[]}function p(){a.value=!1,s.value=[]}function g(){let u=[];i.value==="all"?u=r.fields||[]:i.value==="none"?u=[]:u=o.value,l("save",u)}return(u,h)=>(e.openBlock(),e.createElementBlock("div",ss,[e.createElementVNode("div",{class:"flex justify-between mb-3 gap-2"},[e.createElementVNode("button",{onClick:f,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium bg-gradient-to-r from-gray-500 to-gray-400 text-white h-9 px-4 py-2 hover:from-gray-600 hover:to-gray-500"}," Імпорт "),e.createElementVNode("button",{onClick:g,class:"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium bg-gradient-to-r from-sky-400 to-blue-400 hover:from-sky-500 hover:to-blue-500 text-white shadow-sm px-4 py-2 h-9 text-xs transition-all duration-300"}," Зберегти фільтр ")]),i.value==="list"?(e.openBlock(),e.createBlock(te,{key:0,modelValue:o.value,"onUpdate:modelValue":h[0]||(h[0]=x=>o.value=x),"columns-scheme":d,"form-scheme":c,"main-col-width":"250px","add-button":!1},null,8,["modelValue"])):e.createCommentVNode("",!0),e.createVNode(oe,{visible:a.value,"onUpdate:visible":h[1]||(h[1]=x=>a.value=x),selection:s.value,"onUpdate:selection":h[2]||(h[2]=x=>s.value=x),fields:u.fields,title:"Імпорт полів","id-prefix":"import-filter",onConfirm:m,onCancel:p},null,8,["visible","selection","fields"])]))}}),jt=e.defineComponent({__name:"MapView",setup(t,{expose:n}){const r=e.ref(null),l=Ri({container:r,mapOptions:{style:{version:8,sources:{},layers:[]},center:[30.5234,50.4501],zoom:9},controls:{navigation:!0,scale:!0}});return n({ctx:l}),(o,i)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"el",ref:r,class:"w-full h-full rounded-xl overflow-hidden"},[e.renderSlot(o.$slots,"default")],512))}}),ds=e.defineComponent({__name:"MapDataLayer",props:{id:{},layer:{},styleYaml:{}},setup(t,{expose:n}){var p;const{map:r,flyTo:l}=re(),o=t,i=o.id,a=String(o.id),s=`${location.origin}/api/vtile/${o.id}/ua/{z}/{x}/{y}.vmt`,d=R(i,{sourceId:a,source:{type:"vector",tiles:[s],minzoom:0,maxzoom:14},popup:o.layer.popup,layer:{style:(p=o.layer)==null?void 0:p.style}});n({layerHandle:d}),l({center:[34.4924,48.45658],animate:!1});let c=null;function f(){c&&clearTimeout(c),c=setTimeout(()=>{c=null,m().catch(g=>console.error("Failed to update map layer",g))},300)}async function m(){r.value&&d.setStyle(o.styleYaml)}return e.watch(()=>o.styleYaml,f),e.onBeforeUnmount(()=>{d.remove()}),(g,u)=>null}}),ms={class:"map-filter"},ps={key:0,class:"map-filter__header"},fs={class:"map-filter__title"},Ot=D(e.defineComponent({__name:"MapFilterWidget",props:{filters:{},title:{},layerId:{}},setup(t){const n=e.defineAsyncComponent(()=>import("@opengis/filter")),r=e.ref({}),l=t;function o(i){const a=l.layerId,s=Object.entries(i).map(([c,f])=>`${c}=${f}`).join("|");R(a).setFilter(s)}return(i,a)=>(e.openBlock(),e.createElementBlock("div",ms,[i.title?(e.openBlock(),e.createElementBlock("div",ps,[e.createElementVNode("h3",fs,e.toDisplayString(i.title),1)])):e.createCommentVNode("",!0),e.createVNode(e.unref(n),{view:"inline",schema:i.filters,value:r.value,limit:5,onChange:a[0]||(a[0]=s=>o(s.data))},null,8,["schema","value"])]))}}),[["__scopeId","data-v-f7cd08a9"]]),us={class:"flex flex-row gap-x-3 z-10 relative widget"},gs=["onClick"],hs=["src","alt"],Rt=e.defineComponent({__name:"BaseMaps",setup(t){const n={gki:{url:"https://data.gki.com.ua/api-user/rtile/voyager/ua/{z}/{x}/{y}.png",preview:"https://data.gki.com.ua/api-user/rtile/voyager/ua/12/2422/1400.png",title:"Базова карта (voyager)"},arcgisonline:{url:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}.png",preview:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/7/47/69.png",title:"ESRI Online Imagery(2022-2023)"},none:{}},r=e.ref("gki"),l=R("base",{source:{type:"raster",tiles:[n[r.value].url]},beforeId:0});function o(i){if(r.value=i,!n[i].url)return l.setVisible(!1);l.setVisible(!0),l.setTiles([n[i].url])}return(i,a)=>(e.openBlock(),e.createElementBlock("div",us,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(n,(s,d)=>e.createElementVNode("div",{key:d,onClick:c=>o(d)},[e.createElementVNode("div",{class:e.normalizeClass(["w-14 h-14 flex items-center justify-center bg-gray-200 rounded-xl shadow-2xs cursor-pointer transition-all border-4",r.value===d?"border-blue-500":"border-gray-200"])},[s.preview?(e.openBlock(),e.createElementBlock("img",{key:0,src:s.preview,alt:s.title,class:"object-cover rounded-lg w-12 h-12"},null,8,hs)):e.createCommentVNode("",!0)],2)],8,gs)),64))]))}}),ys={key:0,class:"legend-widget flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative widget",style:{width:"100%"}},xs={class:"flex flex-col gap-1 p-5"},ks={class:"flex items-center justify-between w-full text-sm text-gray-800 ml-2"},Ut=e.defineComponent({__name:"MapLegendWidget",props:{items:{}},setup(t){const n=t,{map:r,ready:l}=re(),o=e.ref([]);let i=null;function a(f){return f?f.map((m,p)=>{var h;const g=(m==null?void 0:m.name)||(m==null?void 0:m.label)||(m==null?void 0:m.title)||(m==null?void 0:m.id)||`Layer ${p+1}`,u=(m==null?void 0:m.color)||(m==null?void 0:m.fill)||((h=m==null?void 0:m.paint)==null?void 0:h.color)||"#3388ff";return{id:`${g}-${p}`,label:g,color:u}}):[]}function s(f){return f!=null&&f.layers?f.layers.filter(m=>{const p=m.paint||{};return p["fill-color"]||p["line-color"]||p["circle-color"]}).map((m,p)=>{var h;const g=m.paint||{},u=g["fill-color"]||g["line-color"]||g["circle-color"]||"#3388ff";return{id:m.id||`layer-${p}`,label:((h=m.metadata)==null?void 0:h.title)||m.id||`Layer ${p+1}`,color:u}}):[]}async function d(){var p;await l();const f=r.value;if(!f)return;const m=(p=f.getStyle)==null?void 0:p.call(f);o.value=s(m)}function c(){const f=r.value;if(!f)return;i==null||i();const m=()=>d();f.on("styledata",m),i=()=>f.off("styledata",m)}return e.watch(()=>n.items,async f=>{f!=null?(o.value=a(f),i==null||i()):(await l(),c(),d())},{immediate:!0,deep:!0}),e.onMounted(async()=>{(n.items===void 0||n.items===null)&&(await l(),c(),d())}),e.onBeforeUnmount(()=>{i==null||i(),i=null}),(f,m)=>o.value.length?(e.openBlock(),e.createElementBlock("div",ys,[e.createElementVNode("div",xs,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(o.value,p=>(e.openBlock(),e.createElementBlock("div",{key:p.id,class:"flex items-center"},[e.createElementVNode("span",{class:"shrink-0 size-2.5 inline-block me-2.5 h-[10px] w-[10px] rounded-full",style:e.normalizeStyle({background:p.color})},null,4),e.createElementVNode("span",ks,[e.createElementVNode("span",null,e.toDisplayString(p.label),1)])]))),128))])])):e.createCommentVNode("",!0)}});function bs(){const{map:t,ready:n}=re(),r=e.ref(null),l=e.ref(null),o=e.ref(null),i=e.ref(null);let a=[];function s(){a.forEach(p=>p()),a=[]}const d=p=>{var h;r.value=[p.point.x,p.point.y];const g=t.value.queryRenderedFeatures(p.point);if(!(g!=null&&g.length)){c();return}const u=R(g[0].source)||R(g[0].layer.id);u!=null&&u.popup&&(l.value=((h=u.popup)==null?void 0:h.fields)||u.popup,i.value=g[0].properties)},c=()=>{l.value=null,i.value=null,r.value=null};async function f(){await n(),t.value&&(s(),t.value.on("mousemove",d),t.value.on("mouseleave",c))}function m(){s(),l.value=null,i.value=null,r.value=null}return n().then(f),{popupCoords:r,popupFields:l,popupValues:i,disable:m,title:o}}const ws={class:"popup-card relative w-full overflow-hidden rounded-2xl border border-blue-100 bg-white/95 shadow-2xl backdrop-blur-sm"},_s={key:0,class:"border-b border-gray-200 px-3 py-2 text-sm font-semibold text-gray-800"},Es={class:"px-3 py-2 text-xs text-gray-600"},Ns={class:"w-full border-collapse"},Cs={class:"w-1/2 break-words pb-1 pr-2 font-medium text-gray-700"},Bs={class:"w-1/2 break-words pb-1 pl-2 text-right"},Vs={key:0,class:"inline-block rounded px-2 py-0.5 text-xs font-semibold text-yellow-800",style:{"background-color":"rgba(250, 204, 21, 0.25)"}},As={key:1},Pt=D(e.defineComponent({__name:"MapPopup",setup(t){const{popupCoords:n,disable:r,popupFields:l,popupValues:o,title:i}=bs(),a=e.ref(null),s=e.ref({left:"-9999px",top:"-9999px"}),d=e.computed(()=>{var m;return((m=l.value)==null?void 0:m.length)>0&&Object.keys(o.value||{}).length>0}),c=e.computed(()=>{const m=l.value.find(p=>p.meta==="title");return o.value[m.name]});function f(){if(!d.value||!n.value||!a.value){s.value={left:"-9999px",top:"-9999px"};return}const[m,p]=n.value;a.value;const g=m+18,u=p+18;s.value={left:`${g}px`,top:`${u}px`}}return e.watch([n],()=>{e.nextTick(()=>f())}),e.onBeforeUnmount(()=>{r()}),(m,p)=>d.value?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"popupRef",ref:a,class:"absolute z-30 w-[280px] pointer-events-none text-gray-800",style:e.normalizeStyle(s.value)},[e.createElementVNode("div",ws,[c.value?(e.openBlock(),e.createElementBlock("div",_s,e.toDisplayString(c.value),1)):e.createCommentVNode("",!0),e.createElementVNode("div",Es,[e.createElementVNode("table",Ns,[e.createElementVNode("tbody",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(l).filter(g=>g.meta!=="title"),g=>(e.openBlock(),e.createElementBlock("tr",{key:g.value,class:"align-top"},[e.createElementVNode("td",Cs,e.toDisplayString(g.label||g.title),1),e.createElementVNode("td",Bs,[g.meta==="badge"?(e.openBlock(),e.createElementBlock("span",Vs,e.toDisplayString(e.unref(o)[g.name]),1)):(e.openBlock(),e.createElementBlock("span",As,e.toDisplayString(e.unref(o)[g.name]),1))])]))),128))])])])])],4)):e.createCommentVNode("",!0)}}),[["__scopeId","data-v-c630c3c0"]]);function $s(){const{map:t,ready:n}=re(),r=e.ref(null),l=e.ref(null),o=e.ref(null),i=e.ref(!1),a=e.computed(()=>i.value||!!r.value||!!o.value);let s=null;function d(){r.value=null,l.value=null,o.value=null,i.value=!1}function c(){if(s){try{s()}catch{}s=null}}async function f(){await n();const h=t.value;h&&(c(),d(),h.on("click",m),s=()=>h.off("click",m))}function m(h){const x=t.value;if(!x)return;const y=x.queryRenderedFeatures(h.point)[0];if(!y){d();return}const k=R(y.source);p(y,k==null?void 0:k.card)}async function p(h,x){var y,k;if(!((y=h==null?void 0:h.properties)!=null&&y.id))return;const E=new URLSearchParams;E.set("layer",h.source),E.set("id",String((k=h.properties)==null?void 0:k.id)),i.value=!0,o.value=null,r.value=null,l.value=h||null;try{const w=await fetch(`/api/map-format?${E.toString()}`);if(!w.ok)throw new Error(`Failed (${w.status})`);const b=await w.json();r.value={rows:b.rows||{},fields:x||[],html:b.html||null}}catch{o.value="Не вдалося завантажити дані",r.value=null,K.notify({type:"error",title:"Помилка",message:"Не вдалося завантажити дані"})}finally{i.value=!1}}function g(){d()}function u(){c(),d()}return n().then(f),e.onBeforeUnmount(()=>u()),{card:r,cardFeature:l,cardError:o,cardLoading:i,isOpen:a,close:g}}const vs={key:0,class:"absolute top-4 right-4 z-30 w-[320px] max-h-[80%] overflow-hidden rounded-2xl border border-slate-200 bg-white/95 shadow-2xl backdrop-blur-md flex flex-col"},Ss={class:"flex items-start justify-between gap-3 border-b border-slate-200 px-4 py-3"},Fs={class:"flex-1 overflow-y-auto px-4 py-3 space-y-3 text-sm text-slate-700"},Ls={key:0,class:"text-center text-xs text-slate-500"},Ts={key:1,class:"text-center text-xs text-red-500"},Ms=["innerHTML"],Ds={key:1,class:"space-y-2"},Is={class:"text-xs font-semibold text-slate-500 uppercase tracking-wide"},js={key:0,class:"inline-block rounded px-2 py-0.5 text-xs font-semibold text-yellow-800",style:{"background-color":"rgba(250,204,21,0.25)"}},Os={key:1,class:"text-sm text-right text-slate-800 whitespace-pre-wrap"},Rs={key:2,class:"text-center text-xs text-slate-400"},zt=D(e.defineComponent({__name:"MapCardWidget",setup(t){const{card:n,cardError:r,cardLoading:l,isOpen:o,close:i}=$s(),a=e.computed(()=>{var d,c;const s=((d=n.value)==null?void 0:d.rows)??{};return(((c=n.value)==null?void 0:c.fields)??[]).map(f=>({key:f.name,label:f.ua||f.label||f.title||f.name,value:(s==null?void 0:s[f.name])??"—",format:f.format||"text"}))});return(s,d)=>(e.openBlock(),e.createBlock(e.Transition,{name:"fade"},{default:e.withCtx(()=>[e.unref(o)?(e.openBlock(),e.createElementBlock("div",vs,[e.createElementVNode("div",Ss,[d[2]||(d[2]=e.createElementVNode("div",{class:"min-w-0"},[e.createElementVNode("p",{class:"text-base font-semibold text-slate-900 truncate"}," Інформація про об'єкт ")],-1)),e.createElementVNode("button",{type:"button",class:"inline-flex h-7 w-7 items-center justify-center rounded-full bg-slate-100 text-slate-500 hover:bg-slate-200 hover:text-slate-700",onClick:d[0]||(d[0]=(...c)=>e.unref(i)&&e.unref(i)(...c))},[...d[1]||(d[1]=[e.createElementVNode("span",{class:"sr-only"},"Close",-1),e.createTextVNode(" ✕ ",-1)])])]),e.createElementVNode("div",Fs,[e.unref(l)?(e.openBlock(),e.createElementBlock("div",Ls," Завантаження даних… ")):e.unref(r)?(e.openBlock(),e.createElementBlock("div",Ts,e.toDisplayString(e.unref(r)),1)):e.unref(n)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[e.unref(n).html?(e.openBlock(),e.createElementBlock("div",{key:0,class:"prose prose-sm max-w-none",innerHTML:e.unref(n).html},null,8,Ms)):a.value.length?(e.openBlock(),e.createElementBlock("div",Ds,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,c=>(e.openBlock(),e.createElementBlock("div",{key:c.key,class:"flex items-start justify-between gap-3 border-b border-slate-100 pb-2"},[e.createElementVNode("span",Is,e.toDisplayString(c.label),1),c.format==="badge"?(e.openBlock(),e.createElementBlock("span",js,e.toDisplayString(c.value),1)):(e.openBlock(),e.createElementBlock("span",Os,e.toDisplayString(c.value),1))]))),128))])):(e.openBlock(),e.createElementBlock("div",Rs,"Даних не знайдено."))],64)):e.createCommentVNode("",!0)])])):e.createCommentVNode("",!0)]),_:1}))}}),[["__scopeId","data-v-7264c08d"]]),Us={class:"flex h-screen bg-gradient-to-br from-slate-50 to-white"},Ps={class:"flex-1 relative overflow-hidden"},zs={class:"absolute top-0 left-0 w-full z-20"},qs={class:"flex items-center justify-between bg-white/80 backdrop-blur border-b border-gray-200 px-6 py-3 shadow-sm gap-4"},Hs={class:"flex items-center gap-3"},Ys={class:"font-semibold text-lg text-gray-800 line-clamp-1"},Ks={class:"text-xs text-gray-500 truncate"},Ws=["title"],Gs={class:"w-full h-full bg-gradient-to-br from-sky-50 via-white to-blue-50 flex items-center justify-center relative pt-[64px]"},Zs={class:"relative w-full h-full"},Qs={style:{top:"10px",left:"230px",position:"absolute","z-index":"1"}},Xs={class:"absolute top-4 left-4 z-20"},Js={class:"absolute bottom-4 left-4 z-20"},ec={class:"w-[650px] bg-white border-l border-gray-100 flex flex-col overflow-hidden shadow-lg"},tc={class:"flex-1 flex flex-col h-full"},nc={class:"px-3 pt-3 pb-2 border-b border-gray-100"},rc={class:"items-center justify-center text-muted-foreground grid w-full grid-cols-6 h-12 p-1 bg-gray-50 rounded-xl shadow-sm"},oc=["aria-selected","onClick"],lc={class:"leading-none"},ac={class:"flex flex-col flex-1 overflow-y-hidden p-3"},ic=e.defineComponent({__name:"service",setup(t){const n=pe.useRoute(),r=pe.useRouter(),l=n.params.id,o=e.ref(null),i=e.ref({}),a=e.ref(null),s=e.ref(""),d=e.ref([]),c=e.ref([]),f=e.ref([]),m=e.ref([]),p=e.computed(()=>{var y,k;return((y=a.value)==null?void 0:y.id)??((k=a.value)==null?void 0:k.service_id)??null}),g=[{key:"style",label:"Style",icon:Ho},{key:"popup",label:"Popup",icon:rl},{key:"filter",label:"Filter",icon:il},{key:"legend",label:"Legend",icon:Go},{key:"card",label:"Card",icon:Jo}],u=g.map(y=>y.key),h=e.ref("style");e.onMounted(async()=>{const y=n.query.tab;y&&u.includes(y)&&(h.value=y),await x()}),e.watch(h,y=>{n.query.tab!==y&&r.replace({query:{...n.query,tab:y}})}),e.watch(()=>n.query.tab,y=>{y&&u.includes(y)&&h.value!==y&&(h.value=y)});const x=async()=>{try{const y=await fetch(`/api/gis-service/${l}`);if(!y.ok)throw new Error(`${y.status}`);const k=await y.json();i.value=k||{},o.value=l,a.value=k||null,s.value=k.style||"",c.value=(k==null?void 0:k.popup)||[],f.value=(k==null?void 0:k.card)||[],d.value=(k==null?void 0:k.legend)||[],m.value=(k==null?void 0:k.filters)||[]}catch(y){console.error("Failed to fetch map info",y)}};e.watch(()=>{var y;return(y=a.value)==null?void 0:y.style},y=>{y?typeof y=="string"?s.value=y:s.value=JSON.parse(JSON.stringify(y)):s.value=""},{deep:!0});async function E(y,k){if(a[y]=k,!!p.value)try{if(!(await fetch(`/api/gis-service/${p.value}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({[y]:k})})).ok)throw new Error("Save failed");K.notify({type:"success",title:"Успіх",message:`${y} saved`}),await x()}catch(w){K.notify({type:"error",title:"Помилка",message:`Failed to save ${y}`}),console.error(w)}}return(y,k)=>{var w,b,v,S;return e.openBlock(),e.createElementBlock("div",Us,[e.createElementVNode("div",Ps,[e.createElementVNode("div",zs,[e.createElementVNode("div",qs,[e.createElementVNode("div",Hs,[e.createElementVNode("button",{onClick:k[0]||(k[0]=B=>y.$router.back()),class:"inline-flex items-center px-3 py-1.5 rounded-md bg-sky-100 hover:bg-sky-200 text-sky-700 font-medium text-sm transition"},[...k[11]||(k[11]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"h-4 w-4 mr-1",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 19l-7-7 7-7"})],-1),e.createTextVNode(" Назад ",-1)])]),e.createElementVNode("div",null,[e.createElementVNode("div",Ys,e.toDisplayString((w=a.value)==null?void 0:w.name),1),e.createElementVNode("div",Ks," Сервіс: "+e.toDisplayString((b=a.value)==null?void 0:b.service_key),1)])]),e.createElementVNode("div",{class:"max-w-xl text-xs text-gray-600 truncate",title:(v=a.value)==null?void 0:v.description},e.toDisplayString((S=a.value)==null?void 0:S.description),9,Ws)])]),e.createElementVNode("div",Gs,[e.createElementVNode("div",Zs,[e.createVNode(jt,null,{default:e.withCtx(()=>{var B,M,I;return[(B=a.value)!=null&&B.service_id?(e.openBlock(),e.createBlock(ds,{key:0,id:(M=a.value)==null?void 0:M.service_id,layer:a.value,"style-yaml":s.value},null,8,["id","layer","style-yaml"])):e.createCommentVNode("",!0),e.createElementVNode("div",Qs,[p.value?(e.openBlock(),e.createBlock(Ot,{key:0,"layer-id":p.value,filters:a.value.filters},null,8,["layer-id","filters"])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Xs,[e.createVNode(Rt)]),e.createElementVNode("div",Js,[e.createVNode(Ut,{items:((I=a.value)==null?void 0:I.legend)||null},null,8,["items"])]),e.createVNode(Pt),e.createVNode(zt)]}),_:1})])])]),e.createElementVNode("div",ec,[e.createElementVNode("div",tc,[e.createElementVNode("div",nc,[e.createElementVNode("div",rc,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(g,B=>e.createElementVNode("button",{key:B.key,type:"button",role:"tab","aria-selected":h.value===B.key,class:e.normalizeClass(["whitespace-nowrap flex flex-col items-center justify-center gap-0.5 py-1 px-1 text-[9px] font-medium transition-all duration-300 hover:bg-white/70 rounded-lg group",h.value===B.key?"bg-white shadow-sm text-gray-700":""]),onClick:M=>h.value=B.key},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(B.icon),{class:"h-3.5 w-3.5 mb-0.5"})),e.createElementVNode("span",lc,e.toDisplayString(B.label),1)],10,oc)),64))])]),e.createElementVNode("div",ac,[h.value==="style"?(e.openBlock(),e.createBlock(Oi,{key:0,token:p.value,"style-yaml":s.value,"onUpdate:styleYaml":k[1]||(k[1]=B=>s.value=B),onSave:k[2]||(k[2]=B=>E("style",B))},null,8,["token","style-yaml"])):h.value==="legend"?(e.openBlock(),e.createBlock(es,{key:1,token:p.value,columns:d.value,"onUpdate:columns":k[3]||(k[3]=B=>d.value=B),onSave:k[4]||(k[4]=B=>E("legend",B))},null,8,["token","columns"])):h.value==="popup"?(e.openBlock(),e.createBlock(Yi,{key:2,token:p.value,columns:c.value,fields:i.value.fields,"onUpdate:columns":k[5]||(k[5]=B=>c.value=B),onSave:k[6]||(k[6]=B=>E("popup",B))},null,8,["token","columns","fields"])):h.value==="card"?(e.openBlock(),e.createBlock(is,{key:3,token:p.value,columns:f.value,fields:i.value.fields,"onUpdate:columns":k[7]||(k[7]=B=>f.value=B),onSave:k[8]||(k[8]=(B,M)=>E(B,M))},null,8,["token","columns","fields"])):h.value==="filter"?(e.openBlock(),e.createBlock(cs,{key:4,token:p.value,fields:i.value.fields,columns:m.value,"onUpdate:columns":k[9]||(k[9]=B=>m.value=B),onSave:k[10]||(k[10]=B=>E("filters",B))},null,8,["token","fields","columns"])):e.createCommentVNode("",!0)])])])])}}}),sc={key:0,class:"map-info__header"},cc={key:0,class:"map-info__title"},dc={key:1,class:"map-info__menu"},mc=["href"],pc=["innerHTML"],fc=D(e.defineComponent({__name:"MapInfoWidget",props:{title:{},content:{},links:{}},setup(t){const n=t,r=e.ref(null),l=e.ref(!1),o=e.computed(()=>Array.isArray(n.links)?n.links.filter(s=>(s==null?void 0:s.label)&&(s==null?void 0:s.url)):[]);function i(s){s.stopPropagation(),l.value=!l.value}function a(s){if(!l.value)return;const d=r.value;if(!d){l.value=!1;return}d.contains(s.target)||(l.value=!1)}return e.onMounted(()=>{document.addEventListener("click",a,!0)}),e.onBeforeUnmount(()=>{document.removeEventListener("click",a,!0)}),(s,d)=>(e.openBlock(),e.createElementBlock("div",{class:"map-info legend-widget flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative widget",ref_key:"container",ref:r},[s.title||o.value.length?(e.openBlock(),e.createElementBlock("div",sc,[s.title?(e.openBlock(),e.createElementBlock("h2",cc,e.toDisplayString(s.title),1)):e.createCommentVNode("",!0),o.value.length?(e.openBlock(),e.createElementBlock("div",dc,[e.createElementVNode("button",{type:"button",class:"map-info__menu-button",onClick:i,"aria-label":"Показати посилання"},[...d[1]||(d[1]=[e.createElementVNode("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg"},[e.createElementVNode("path",{d:"M4 12H20",stroke:"#000000","stroke-linecap":"round","stroke-linejoin":"round"}),e.createElementVNode("path",{d:"M4 6H20",stroke:"#000000","stroke-linecap":"round","stroke-linejoin":"round"}),e.createElementVNode("path",{d:"M4 18H20",stroke:"#000000","stroke-linecap":"round","stroke-linejoin":"round"})],-1)])]),e.createElementVNode("div",{class:e.normalizeClass(["vsTailwind vs-popover__content right map-info__popover",{"map-info__popover--open":l.value}]),onClick:d[0]||(d[0]=e.withModifiers(()=>{},["stop"]))},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(o.value,c=>(e.openBlock(),e.createElementBlock("a",{key:c.url||c.label,class:"map-info__popover-link",href:c.url},e.toDisplayString(c.label),9,mc))),128))],2)])):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),s.content?(e.openBlock(),e.createElementBlock("div",{key:1,class:"map-info__content",innerHTML:s.content},null,8,pc)):e.createCommentVNode("",!0)],512))}}),[["__scopeId","data-v-e9128963"]]),uc={class:"layers-panel"},gc={key:0,class:"layers-panel__title"},hc={class:"layers-panel__label"},yc=["checked","onChange"],xc={key:0,class:"layers-panel__actions"},kc=["innerHTML","onClick"],bc=D(e.defineComponent({__name:"MapDataLayersWidget",props:{layers:{},title:{}},emits:["action"],setup(t,{emit:n}){const r=t,l=n,o=e.computed(()=>{if(typeof r.title=="string"){const s=r.title.trim();return s||null}return null});function i(){for(let s=0;s<r.layers.length;s++){const d=r.layers[s],c=d.id,f=`${location.origin}/api/vtile/${d.id}/ua/{z}/{x}/{y}.vmt`,m={sourceId:c,source:{type:"vector",tiles:[f],minzoom:0,maxzoom:14},layer:{id:c,source:c,"source-layer":c,style:d.style},card:d.card,popup:d.popup};R(d.id,m)}}e.onMounted(()=>{console.log("mount"),i()});function a(s,d){const c=R(s.id),f=d.target;c.setVisible(f.checked)}return(s,d)=>(e.openBlock(),e.createElementBlock("div",uc,[o.value?(e.openBlock(),e.createElementBlock("h3",gc,e.toDisplayString(o.value),1)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.layers,c=>{var f;return e.openBlock(),e.createElementBlock("div",{key:c.id,class:"layers-panel__item"},[e.createElementVNode("label",hc,[e.createElementVNode("input",{type:"checkbox",checked:c.visible,onChange:m=>a(c,m)},null,40,yc),e.createElementVNode("span",null,e.toDisplayString(c.name),1)]),(f=c.actions)!=null&&f.length?(e.openBlock(),e.createElementBlock("div",xc,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.actions,m=>(e.openBlock(),e.createElementBlock("button",{key:m.widget||m.id||m.icon,type:"button",class:"layers-panel__action",innerHTML:m.icon,onClick:p=>l("action",{layerId:m.widget})},null,8,kc))),128))])):e.createCommentVNode("",!0)])}),128))]))}}),[["__scopeId","data-v-3558e518"]]),wc={class:"relative mt-[10px]"},_c={width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",class:"absolute top-1/2 left-[8px] w-[16px] h-[16px]",style:{transform:"translate(0, -50%)"}},Ec={class:"mt-2"},Nc={class:"flex items-center gap-x-3"},Cc={class:"text-xs opacity-60 text-[#4b5563]"},Bc={class:"flex items-center w-full cursor-pointer gap-2"},Vc=["checked","onChange"],Ac={class:"text-[13px] text-gray-600 truncate max-w-[260px]"},$c={class:"mt-2"},vc={class:"flex items-center gap-x-3"},Sc={class:"text-xs opacity-60 text-[#4b5563]"},Fc={class:"flex items-center w-full cursor-pointer gap-2"},Lc=["checked","onChange"],Tc={class:"text-[13px] text-gray-600 truncate max-w-[260px]"},Mc=D(e.defineComponent({__name:"LayersCatalogTab",props:{catalog:{},selected:{}},emits:["toggle-layer"],setup(t,{emit:n}){const r=t,l=e.ref(!1),o=e.ref(!1),i=e.ref(""),a=e.computed(()=>i.value?r.catalog.services.filter(d=>d.name.toLowerCase().includes(i.value.toLowerCase())):r.catalog.services),s=e.computed(()=>i.value?r.catalog.rasters.filter(d=>d.name.toLowerCase().includes(i.value.toLowerCase())):r.catalog.rasters);return(d,c)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("div",wc,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":c[0]||(c[0]=f=>i.value=f),type:"text",placeholder:"Введіть назву шару...",class:"py-[7px] pl-8 pe-8 block w-full bg-gray-100 border-transparent rounded-lg text-sm focus:bg-white focus:border-blue-500 focus:ring-blue-500"},null,512),[[e.vModelText,i.value]]),(e.openBlock(),e.createElementBlock("svg",_c,[...c[3]||(c[3]=[e.createElementVNode("path",{d:"M11 19C15.4183 19 19 15.4183 19 11C19 6.5817 15.4183 3 11 3C6.5817 3 3 6.5817 3 11C3 15.4183 6.5817 19 11 19Z",stroke:"black","stroke-linecap":"round","stroke-linejoin":"round"},null,-1),e.createElementVNode("path",{d:"M21 21L16.7 16.7",stroke:"black","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])]))]),e.createElementVNode("div",Ec,[e.createElementVNode("div",{class:"hover:bg-gray-100 cursor-pointer p-[8px] rounded-lg flex justify-between items-center",onClick:c[1]||(c[1]=f=>l.value=!l.value)},[e.createElementVNode("div",Nc,[(e.openBlock(),e.createElementBlock("svg",{width:"6",height:"10",viewBox:"0 0 6 10",fill:"none",xmlns:"http://www.w3.org/2000/svg",class:e.normalizeClass(["transition-transform",l.value?"rotate-90":""])},[...c[4]||(c[4]=[e.createElementVNode("path",{d:"M1 9L5 5L1 1",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])],2)),c[5]||(c[5]=e.createElementVNode("div",{class:"max-w-[260px] text-[14px] text-[#4b5563]"},"Сервіси",-1))]),e.createElementVNode("div",Cc,e.toDisplayString(a.value.length),1)]),e.createVNode(e.Transition,{name:"out-in"},{default:e.withCtx(()=>[e.withDirectives(e.createElementVNode("div",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(a.value,f=>(e.openBlock(),e.createElementBlock("div",{key:f.id,class:"hover:bg-gray-100 rounded-lg flex items-center ml-[20px] py-[8px] px-[8px]"},[e.createElementVNode("label",Bc,[e.createElementVNode("input",{type:"checkbox",class:"peer hidden",checked:d.selected.includes(f.id),onChange:m=>d.$emit("toggle-layer",f.id,m.target.checked,f)},null,40,Vc),c[6]||(c[6]=e.createElementVNode("div",{class:"w-4 h-4 rounded border border-blue-800 flex items-center justify-center peer-checked:bg-blue-600 peer-checked:border-blue-600"},[e.createElementVNode("svg",{"data-v-b96f3537":"",xmlns:"http://www.w3.org/2000/svg",width:"12",height:"8",viewBox:"0 0 12 8",fill:"none"},[e.createElementVNode("path",{"data-v-b96f3537":"",d:"M10.6663 1L4.24967 7.41667L1.33301 4.5",stroke:"#fff","stroke-linecap":"round","stroke-linejoin":"round"})])],-1)),e.createElementVNode("span",Ac,e.toDisplayString(f.name),1)])]))),128))],512),[[e.vShow,l.value]])]),_:1})]),e.createElementVNode("div",$c,[e.createElementVNode("div",{class:"hover:bg-gray-100 cursor-pointer p-[8px] rounded-lg flex justify-between items-center",onClick:c[2]||(c[2]=f=>o.value=!o.value)},[e.createElementVNode("div",vc,[(e.openBlock(),e.createElementBlock("svg",{width:"6",height:"10",viewBox:"0 0 6 10",fill:"none",xmlns:"http://www.w3.org/2000/svg",class:e.normalizeClass(["transition-transform",o.value?"rotate-90":""])},[...c[7]||(c[7]=[e.createElementVNode("path",{d:"M1 9L5 5L1 1",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"},null,-1)])],2)),c[8]||(c[8]=e.createElementVNode("div",{class:"max-w-[260px] text-[14px] text-[#4b5563]"},"Растри",-1))]),e.createElementVNode("div",Sc,e.toDisplayString(s.value.length),1)]),e.createVNode(e.Transition,{name:"out-in"},{default:e.withCtx(()=>[e.withDirectives(e.createElementVNode("div",null,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,f=>(e.openBlock(),e.createElementBlock("div",{key:f.id,class:"hover:bg-gray-100 rounded-lg flex items-center ml-[20px] py-[8px] px-[8px]"},[e.createElementVNode("label",Fc,[e.createElementVNode("input",{type:"checkbox",class:"peer hidden",checked:d.selected.includes(f.id),onChange:m=>d.$emit("toggle-layer",f.id,m.target.checked,f)},null,40,Lc),c[9]||(c[9]=e.createElementVNode("div",{class:"w-4 h-4 rounded border border-blue-800 flex items-center justify-center peer-checked:bg-blue-600 peer-checked:border-blue-600"},[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"12",height:"8",viewBox:"0 0 12 8",fill:"none",class:"opacity-0 peer-checked:opacity-100 transition"},[e.createElementVNode("path",{d:"M10.6663 1L4.24967 7.41667L1.33301 4.5",stroke:"#fff","stroke-linecap":"round","stroke-linejoin":"round"})])],-1)),e.createElementVNode("span",Tc,e.toDisplayString(f.name),1)])]))),128))],512),[[e.vShow,o.value]])]),_:1})])]))}}),[["__scopeId","data-v-9c9e6edf"]]),Dc={class:"mb-4"},Ic={class:"space-y-2 max-h-[400px] overflow-y-auto pr-1 [&::-webkit-scrollbar]:h-1.5 [&::-webkit-scrollbar]:w-1.5 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-thumb]:bg-gray-300 [&::-webkit-scrollbar-track]:bg-transparent"},jc=["onDragstart","onDragover","onDrop"],Oc={class:"flex items-center justify-between"},Rc={class:"flex items-center gap-2 cursor-move"},Uc=["checked","onChange"],Pc={class:"text-gray-800"},zc={class:"flex items-center gap-2"},qc=["onClick"],Hc=["onClick"],Yc={class:"flex items-center gap-2"},Kc={class:"text-xs text-gray-600"},Wc={class:"w-48"},Gc=e.defineComponent({__name:"LayersSelectedTab",props:{catalog:{},selected:{}},emits:["selectLayer","reorder","remove"],setup(t,{emit:n}){const r=t,l=n,o=e.reactive({}),i=e.ref(null),a=e.ref(null),s=new Map,d=e.reactive({top:0,left:0}),c=e.ref(null),f=e.reactive({top:0,left:0}),m=e.ref(null),p=new Map,g=e.reactive({});e.watch(()=>r.selected,C=>{C.forEach(_=>{o[_]==null&&(o[_]=100)})},{immediate:!0});function u(C,_){_?s.set(C,_):s.delete(C)}function h(C){var q;const _=R(C);if(!_)return;const $=(o[C]??100)/100,U=(q=_.getLayer)==null?void 0:q.call(_);if(U)switch(U.type){case"raster":_.updatePaint({"raster-opacity":$});break;case"fill":_.updatePaint({"fill-opacity":$});break;case"line":_.updatePaint({"line-opacity":$});break;case"circle":_.updatePaint({"circle-opacity":$});break;case"symbol":_.updatePaint({"icon-opacity":$});break}}function x(){if(!i.value)return;const C=s.get(i.value);if(!C)return;const _=C.getBoundingClientRect();d.top=_.bottom+8+window.scrollY,d.left=_.left+window.scrollX}function E(C){i.value=i.value===C?null:C,i.value&&(o[C]==null&&(o[C]=100),e.nextTick(x))}e.watch(()=>r.selected,C=>{C.forEach(_=>{g[_]==null&&(g[_]=!0)})},{immediate:!0});function y(C,_){g[C]=_;const $=R(C);$&&$.setVisible(_)}function k(C,_){_?p.set(C,_):p.delete(C)}function w(C){c.value=c.value===C?null:C,c.value&&e.nextTick(()=>b(C))}function b(C){const _=p.get(C);if(!_)return;const $=_.getBoundingClientRect();f.top=$.bottom+6+window.scrollY,f.left=$.left+window.scrollX}function v(C){const _=R(C);_&&_.remove(),l("remove",C),c.value=null}function S(C){const _=C.target,$=i.value,U=c.value;if($){const q=a.value,ee=s.get($);if(q&&q.contains(_)||ee&&ee.contains(_))return;i.value=null}if(U){const q=m.value,ee=p.get(U);if(q&&q.contains(_)||ee&&ee.contains(_))return;c.value=null}}function B(){i.value&&x(),c.value&&b(c.value)}e.onMounted(()=>{document.addEventListener("click",S),window.addEventListener("resize",B),window.addEventListener("scroll",B,!0)}),e.onBeforeUnmount(()=>{document.removeEventListener("click",S),window.removeEventListener("resize",B),window.removeEventListener("scroll",B,!0)}),re();function M(C){var U;if(!C)return;const _=R(C);!_||!((U=_.getSource)!=null&&U.call(_))||(c.value=null)}const I=e.ref(null),G=e.ref(null);function V(C){I.value=C}function A(C){G.value=C}function L(C){if(I.value===null||I.value===C){I.value=null,G.value=null;return}const _=[...r.selected],[$]=_.splice(I.value,1);_.splice(C,0,$),l("reorder",_),I.value=null,G.value=null}return(C,_)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("div",Dc,[e.createElementVNode("button",{class:"flex items-center gap-2 text-blue-600 hover:text-blue-700 transition-colors px-3 py-2 rounded-md bg-blue-50 hover:bg-blue-100 w-full justify-center",onClick:_[0]||(_[0]=$=>l("selectLayer"))},[..._[5]||(_[5]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-plus"},[e.createElementVNode("path",{d:"M5 12h14"}),e.createElementVNode("path",{d:"M12 5v14"})],-1),e.createElementVNode("span",null,"Вибрати шар",-1)])])]),e.createElementVNode("div",Ic,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(C.selected,($,U)=>{var q,ee;return e.openBlock(),e.createElementBlock("div",{key:$,class:e.normalizeClass(["border border-gray-200 rounded-md p-3 bg-white shadow-sm text-[13px] text-[#4b5563] transition-colors hover:bg-gray-50/50 cursor-move",{"opacity-50":I.value===U,"border-t-2 border-b-2 border-blue-500 bg-blue-50":G.value===U}]),draggable:"true",onDragstart:H=>V(U),onDragover:e.withModifiers(H=>A(U),["prevent"]),onDrop:H=>L(U)},[e.createElementVNode("div",Oc,[e.createElementVNode("div",Rc,[_[6]||(_[6]=e.createElementVNode("span",{class:"drag-handle cursor-move mr-2 text-gray-400"},"☰",-1)),e.createElementVNode("input",{type:"checkbox",class:"w-4 h-4 text-blue-600 rounded focus:ring-blue-500",checked:g[$]??!0,onChange:H=>y($,H.target.checked)},null,40,Uc),e.createElementVNode("span",Pc,e.toDisplayString(((q=C.catalog.services.find(H=>H.id===$))==null?void 0:q.name)||((ee=C.catalog.rasters.find(H=>H.id===$))==null?void 0:ee.name)),1)]),e.createElementVNode("div",zc,[e.createElementVNode("div",{ref_for:!0,ref:H=>u($,H),onClick:e.withModifiers(H=>E($),["stop"]),class:"text-sm text-gray-600 hover:text-gray-800 transition-colors px-2 py-1 rounded hover:bg-gray-100 cursor-pointer"},e.toDisplayString(o[$]??100)+"% ",9,qc),e.createElementVNode("div",{ref_for:!0,ref:H=>k($,H),onClick:e.withModifiers(H=>w($),["stop"]),class:"p-1 rounded-full hover:bg-gray-100 transition-colors cursor-pointer"},[..._[7]||(_[7]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-more-vertical text-gray-600"},[e.createElementVNode("circle",{cx:"12",cy:"12",r:"1"}),e.createElementVNode("circle",{cx:"12",cy:"5",r:"1"}),e.createElementVNode("circle",{cx:"12",cy:"19",r:"1"})],-1)])],8,Hc)])])],42,jc)}),128))]),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[i.value?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"popoverEl",ref:a,class:"fixed z-[10002] py-2 px-3 w-56 text-sm bg-white shadow-lg rounded-lg",style:e.normalizeStyle({top:d.top+"px",left:d.left+"px"})},[e.createElementVNode("div",Yc,[_[8]||(_[8]=e.createElementVNode("label",{class:"text-gray-600 text-xs"},"Прозорість:",-1)),e.withDirectives(e.createElementVNode("input",{type:"range",min:"0",max:"100",step:"1","onUpdate:modelValue":_[1]||(_[1]=$=>o[i.value]=$),onInput:_[2]||(_[2]=$=>h(i.value)),class:"h-2 w-full accent-blue-600 rounded-lg cursor-pointer bg-gray-200"},null,544),[[e.vModelText,o[i.value]]]),e.createElementVNode("span",Kc,e.toDisplayString(o[i.value])+"%",1)])],4)):e.createCommentVNode("",!0)])),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[c.value?(e.openBlock(),e.createElementBlock("div",{key:0,ref_key:"menuEl",ref:m,class:"fixed z-[10002] py-2 px-4 w-full max-w-[14rem] text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg focus:outline-none focus:bg-stone-100 after:h-4 after:absolute after:-bottom-4 after:start-0 after:w-full before:h-4 before:absolute before:-top-4 before:start-0 before:w-full",style:e.normalizeStyle({top:f.top+"px",left:f.left+"px"})},[e.createElementVNode("div",Wc,[e.createElementVNode("button",{class:"w-full p-2 text-left text-sm flex items-center gap-2 text-gray-700 hover:bg-gray-100",onClick:_[3]||(_[3]=$=>M(c.value))},[..._[9]||(_[9]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-zoom-in"},[e.createElementVNode("circle",{cx:"11",cy:"11",r:"8"}),e.createElementVNode("line",{x1:"21",x2:"16.65",y1:"21",y2:"16.65"}),e.createElementVNode("line",{x1:"11",x2:"11",y1:"8",y2:"14"}),e.createElementVNode("line",{x1:"8",x2:"14",y1:"11",y2:"11"})],-1),e.createTextVNode(" Збільшити до шару ",-1)])]),_[11]||(_[11]=e.createElementVNode("button",{disabled:"",class:"w-full p-2 text-left text-sm flex items-center gap-2 text-gray-700 hover:bg-gray-100 opacity-50 cursor-not-allowed"},[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-info"},[e.createElementVNode("circle",{cx:"12",cy:"12",r:"10"}),e.createElementVNode("path",{d:"M12 16v-4"}),e.createElementVNode("path",{d:"M12 8h.01"})]),e.createTextVNode(" Інформація про шар ")],-1)),_[12]||(_[12]=e.createElementVNode("button",{disabled:"",class:"w-full p-2 text-left text-sm flex items-center gap-2 text-gray-700 hover:bg-gray-100 opacity-50 cursor-not-allowed"},[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-table"},[e.createElementVNode("path",{d:"M12 3v18"}),e.createElementVNode("rect",{width:"18",height:"18",x:"3",y:"3",rx:"2"}),e.createElementVNode("path",{d:"M3 9h18"}),e.createElementVNode("path",{d:"M3 15h18"})]),e.createTextVNode(" Таблиця шару ")],-1)),_[13]||(_[13]=e.createElementVNode("hr",{class:"my-1 border-gray-200"},null,-1)),e.createElementVNode("button",{onClick:_[4]||(_[4]=$=>v(c.value)),class:"w-full p-2 text-left text-sm flex items-center gap-2 text-red-600 hover:bg-red-50"},[..._[10]||(_[10]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-trash2"},[e.createElementVNode("path",{d:"M3 6h18"}),e.createElementVNode("path",{d:"M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6"}),e.createElementVNode("path",{d:"M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2"}),e.createElementVNode("line",{x1:"10",x2:"10",y1:"11",y2:"17"}),e.createElementVNode("line",{x1:"14",x2:"14",y1:"11",y2:"17"})],-1),e.createTextVNode(" Видалити шар ",-1)])])])],4)):e.createCommentVNode("",!0)]))]))}}),Zc={class:"w-full max-w-md mx-auto p-4 bg-white border border-gray-200 rounded-lg shadow-sm widget"},Qc={class:"flex items-center justify-between mb-4"},Xc={class:"flex items-center gap-2"},Jc={class:"text-lg font-semibold text-gray-800"},ed={class:"flex mb-4 border-b border-gray-200"},td=e.defineComponent({__name:"MapCatalogWidget",setup(t){const n=e.ref("catalog"),r=e.ref({services:[],rasters:[]}),l=e.ref([]),o=e.ref(""),{map:i}=re();async function a(){console.log("loadCatalog");const m=await fetch("/api/map-catalog");r.value=await m.json()}function s(m){return m.source_type==="raster"?{source:{type:"raster",tiles:[m.url],minzoom:0,maxzoom:20}}:{source:{type:"vector",tiles:[`${location.origin}/api/vtile/${m.id}/ua/{z}/{x}/{y}.vmt`],minzoom:0,maxzoom:14},layer:{style:m.style},card:m.card,popup:m.popup}}function d(m,p,g){var x;const u=s(g),h=R(g.id,u,i);if(h)if(h.setVisible(p),p){if(!l.value.includes(m)&&(l.value.push(m),(x=i.value)!=null&&x.getLayer(m)))try{i.value.moveLayer(m)}catch(E){console.warn("Cannot move new layer",m,E)}}else l.value=l.value.filter(E=>E!==m)}function c(){l.value.forEach(m=>{const p=R(m);p&&p.setVisible(!1)}),l.value=[]}function f(m){l.value=m,e.nextTick(()=>{var p;for(let g=m.length-1;g>=0;g--){const u=m[g];if((p=i.value)!=null&&p.getLayer(u))try{i.value.moveLayer(u)}catch(h){console.warn("Cannot move layer",u,h)}}})}return e.onMounted(a),(m,p)=>(e.openBlock(),e.createElementBlock("div",Zc,[e.createElementVNode("div",Qc,[e.createElementVNode("div",Xc,[p[5]||(p[5]=e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"lucide lucide-layers text-blue-600"},[e.createElementVNode("path",{d:"m12.83 2.18a2 2 0 0 0-1.66 0L2.6 6.08a1 1 0 0 0 0 1.83l8.58 3.91a2 2 0 0 0 1.66 0l8.58-3.9a1 1 0 0 0 0-1.83Z"}),e.createElementVNode("path",{d:"m22 17.65-9.17 4.16a2 2 0 0 1-1.66 0L2 17.65"}),e.createElementVNode("path",{d:"m22 12.65-9.17 4.16a2 2 0 0 1-1.66 0L2 12.65"})],-1)),e.createElementVNode("h2",Jc,[e.createTextVNode(e.toDisplayString(n.value==="catalog"?"Каталог":"Вибрані шари")+" ",1),e.createElementVNode("span",null," ("+e.toDisplayString(n.value==="catalog"?r.value.services.length+r.value.rasters.length:l.value.length)+") ",1)])]),e.createElementVNode("button",{onClick:c,class:"p-1 rounded-full hover:bg-gray-200 transition-colors","aria-label":"Reset layers"},[...p[6]||(p[6]=[e.createStaticVNode('<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-refresh-cw text-gray-600"><path d="M3 12a9 9 0 0 1 9-9 9.75 9.75 0 0 1 6.74 2.74L21 8"></path><path d="M21 3v5h-5"></path><path d="M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16"></path><path d="M8 16H3v5"></path></svg>',1)])])]),e.createElementVNode("div",ed,[e.createElementVNode("button",{onClick:p[0]||(p[0]=g=>n.value="catalog"),class:e.normalizeClass(["px-4 py-2 text-sm font-medium",n.value==="catalog"?"text-blue-600 border-b-2 border-blue-600":"text-gray-600 hover:text-gray-800"])}," Каталог ",2),e.createElementVNode("button",{onClick:p[1]||(p[1]=g=>n.value="selected"),class:e.normalizeClass(["px-4 py-2 text-sm font-medium",n.value==="selected"?"text-blue-600 border-b-2 border-blue-600":"text-gray-600 hover:text-gray-800"])}," Вибрані шари ",2)]),n.value==="catalog"?(e.openBlock(),e.createBlock(Mc,{key:0,catalog:r.value,selected:l.value,onToggleLayer:d,search:o.value,"onUpdate:search":p[2]||(p[2]=g=>o.value=g)},null,8,["catalog","selected","search"])):(e.openBlock(),e.createBlock(Gc,{key:1,catalog:r.value,selected:l.value,onToggleLayer:d,onSelectLayer:p[3]||(p[3]=g=>n.value="catalog"),onReorder:f,onRemove:p[4]||(p[4]=g=>l.value=l.value.filter(u=>u!==g))},null,8,["catalog","selected"]))]))}}),nd={key:1,class:"flex flex-col bg-white border border-stone-200 shadow-2xs rounded-xl z-10 relative widget"},rd={class:"flex items-center justify-between p-5 pb-3"},od={class:"flex gap-[6px]"},ld={class:"h-full px-5 pb-5 space-y-8"},ad={class:"text-4xl font-medium text-gray-800 dark:text-neutral-200"},id={class:"space-y-[14px]"},sd={class:"flex items-center gap-[10px] text-gray-500"},cd={class:"flex items-center justify-end text-end"},dd={class:"font-medium text-gray-800 dark:text-neutral-200"},md={class:"ms-3 min-w-[40px] font-medium inline-block text-[#3C3C4399] dark:text-neutral-400"},pd=e.defineComponent({__name:"MapAttributeWidget",props:{config:{}},setup(t){const n=t;function r(s){return{"data_bp_myo.bp":"3c95e341465d","data_bp_myo.myo":"dbcb186818e3","data_mbd.mbd":"9587e69d35fd"}[s]||"3c95e341465d"}const l=e.ref({}),o=e.ref(!0);e.onMounted(async()=>{var p;const s=n.config.layer,d=r(s.id),c=`${location.origin}/api/vtile/${d}/ua/{z}/{x}/{y}.vmt`;R(d,{sourceId:d,source:{type:"vector",tiles:[c],minzoom:0,maxzoom:14},layer:{id:d,source:d,"source-layer":d,style:s.style},card:s.style.card,popup:(p=s.style)==null?void 0:p.popup});const m=await(await fetch(`/api/gis-service/${d}/${s.style.attribute}`)).json();l.value=Object.fromEntries(m.rows.map(g=>[g.id,Number(g.count)]))});const i=e.computed(()=>n.config.layer.style.rules.map(s=>({...s,count:l.value[s.value]??0}))),a=e.computed(()=>i.value.reduce((s,d)=>s+d.count,0));return(s,d)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[o.value?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("button",{key:0,class:"py-2 px-2.5 max-h-[38px] inline-flex items-center gap-x-1.5 text-sm font-medium rounded-lg border border-gray-200 bg-white text-gray-800 shadow-sm hover:bg-gray-50",onClick:d[0]||(d[0]=c=>o.value=!0)}," Набори даних ")),o.value?(e.openBlock(),e.createElementBlock("div",nd,[e.createElementVNode("div",rd,[d[4]||(d[4]=e.createElementVNode("h2",{class:"inline-block text-xl font-semibold text-gray-800 dark:text-neutral-200"}," Набори даних ",-1)),e.createElementVNode("div",od,[d[3]||(d[3]=e.createElementVNode("button",{class:"flex justify-center items-center h-[36px] w-[36px] text-sm border border-gray-200 text-gray-600 hover:bg-gray-100 rounded-full"},[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"16",height:"14",viewBox:"0 0 16 14",fill:"none"},[e.createElementVNode("path",{d:"M2.04 0.58h11.92c.13.05.25.13.35.23.1.1.18.22.22.36.04.13.05.27.03.41a.9.9 0 0 1-.15.39L9.83 7v6.42L6.17 10.67V7L1.58 1.96a.9.9 0 0 1-.15-.39c-.02-.14 0-.28.04-.41.04-.14.12-.26.21-.36.1-.1.22-.18.36-.22Z",stroke:"currentColor","stroke-linecap":"round","stroke-linejoin":"round"})])],-1)),e.createElementVNode("button",{class:"flex justify-center items-center h-[36px] w-[36px] text-sm border border-gray-200 text-gray-600 hover:bg-gray-100 rounded-full",onClick:d[1]||(d[1]=c=>o.value=!1)},[...d[2]||(d[2]=[e.createElementVNode("svg",{class:"w-4 h-4",xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",viewBox:"0 0 24 24"},[e.createElementVNode("path",{d:"M18 6 6 18"}),e.createElementVNode("path",{d:"m6 6 12 12"})],-1)])])])]),e.createElementVNode("div",ld,[e.createElementVNode("h4",ad,e.toDisplayString(a.value),1),e.createElementVNode("ul",id,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(i.value,c=>(e.openBlock(),e.createElementBlock("li",{key:c.label,class:"flex flex-wrap items-center justify-between gap-x-2"},[e.createElementVNode("div",null,[e.createElementVNode("label",sd,[e.createElementVNode("div",{class:"w-[16px] h-[16px] rounded",style:e.normalizeStyle({backgroundColor:c.color})},null,4),e.createTextVNode(" "+e.toDisplayString(c.label),1)])]),e.createElementVNode("div",cd,[e.createElementVNode("span",dd,e.toDisplayString(c.count),1),e.createElementVNode("span",md,e.toDisplayString(a.value>0?(c.count/a.value*100).toFixed(2):"0.00")+"% ",1)])]))),128))])])])):e.createCommentVNode("",!0)],64))}}),fd={key:0,class:"map-widget__state"},ud={key:1,class:"map-widget__state map-widget__state--error"},Ue=D(e.defineComponent({__name:"MapWidget",props:{id:{},height:{}},setup(t){const n=t;pe.useRoute();const r=e.ref(null),l=e.ref({}),o=e.ref(!1),i=e.ref(null),a=e.ref(!1),s=e.computed(()=>n.id||"main"),d=e.computed(()=>{var y,k;return{height:((y=n.height)==null?void 0:y.trim())||((k=l.value)==null?void 0:k.height)||"calc(100vh - 65px)"}});function c(y){return typeof y=="string"&&y.trim()?y.trim().toLowerCase():"top-left"}const f=e.computed(()=>l.value.widgets||[]),m=e.computed(()=>{var k;const y=(k=l.value.widgets)==null?void 0:k.map(w=>w.position);return[...new Set(y)]});function p(y){const k={"top-left":"absolute top-4 left-4 z-20","top-right":"absolute top-4 right-4 z-20","bottom-left":"absolute bottom-4 left-4 z-20","bottom-right":"absolute bottom-4 right-4 z-20"},w=c(y);return k[w]||k["top-left"]}async function g(){a.value=!1,o.value=!0,i.value=null;const y=await fetch(`/api/gis-map/${encodeURIComponent(s.value)}`);if(!y.ok)throw new Error(`Помилка завантаження (${y.status})`);const k=await y.json();l.value=k,a.value=!0,o.value=!1,k.center&&r.value.ctx.setCenter(k.center,{animate:!1}),k.zoom&&r.value.ctx.setZoom(k.zoom,{animate:!1})}const u=e.computed(()=>{var b,v,S;const y=((b=l.value)==null?void 0:b.layers)||[],k=((S=(v=l.value)==null?void 0:v.widgets)==null?void 0:S.filter(B=>B.type==="layers").flatMap(B=>{var M;return((M=B.config)==null?void 0:M.layers)||[]}))||[],w=[];return y.forEach(B=>{const M=k.find(I=>I.id===B.id);M&&(B.actions=M.actions),w.push(B)}),w}),h=e.ref([]);function x(y){h.value.includes(y)?h.value=h.value.filter(k=>k!==y):h.value.push(y)}const E=e.computed(()=>y=>h.value.includes(y.id));return e.watch(s,()=>{g()}),e.onMounted(()=>{g()}),(y,k)=>(e.openBlock(),e.createElementBlock("div",{class:"map-widget",style:e.normalizeStyle(d.value)},[e.createVNode(jt,{ref_key:"mapViewRef",ref:r,class:"map-widget__view"},{default:e.withCtx(()=>[a.value?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,w=>(e.openBlock(),e.createElementBlock("div",{key:w,class:e.normalizeClass(["map-overlay overflow-y-auto",p(w)])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(f.value.filter(b=>b.position===w),b=>{var v,S,B,M,I,G,V,A,L,C;return e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:b.id||b.type,class:"map-overlay__item"},[b.type==="info"?(e.openBlock(),e.createBlock(fc,{key:0,title:((v=b.config)==null?void 0:v.title)||b.title||null,content:((S=b.config)==null?void 0:S.content)||"",links:((B=b.config)==null?void 0:B.goTo)||[]},null,8,["title","content","links"])):b.type==="catalog"?(e.openBlock(),e.createBlock(td,{key:1,api:((M=b.config)==null?void 0:M.api)||null},null,8,["api"])):b.type==="layers"?(e.openBlock(),e.createBlock(bc,{key:2,title:b.title||((I=b.config)==null?void 0:I.title)||"Шари",layers:u.value,onAction:k[0]||(k[0]=_=>x(_.layerId))},null,8,["title","layers"])):b.type==="basemaps"?(e.openBlock(),e.createBlock(Rt,{key:3,layers:((G=b.config)==null?void 0:G.layers)||null,"default-layer":((V=b.config)==null?void 0:V.default)||null,title:b.title||((A=b.config)==null?void 0:A.title)||null},null,8,["layers","default-layer","title"])):b.type==="legend"?(e.openBlock(),e.createBlock(Ut,{key:4,items:((L=b.config)==null?void 0:L.items)||[]},null,8,["items"])):b.type==="filters"&&E.value(b)?(e.openBlock(),e.createBlock(Ot,{key:5,"layer-id":(C=b.config)==null?void 0:C.layer,onClose:x},null,8,["layer-id"])):b.type==="attribute"?(e.openBlock(),e.createBlock(pd,{key:6,config:b.config},null,8,["config"])):e.createCommentVNode("",!0)])),[[e.vShow,b.visible!==!1]])}),128))],2))),128)),e.createVNode(Pt),e.createVNode(zt)],64)):e.createCommentVNode("",!0)]),_:1},512),o.value?(e.openBlock(),e.createElementBlock("div",fd,"Завантаження карти…")):i.value?(e.openBlock(),e.createElementBlock("div",ud,e.toDisplayString(i.value),1)):e.createCommentVNode("",!0)],4))}}),[["__scopeId","data-v-03a9fa12"]]);function gd(t){t.component("MapCustom",Ue)}Y.MapWidget=Ue,Y.Register=Uo,Y.Service=ic,Y.default=Ue,Y.install=gd,Object.defineProperties(Y,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}));
|