@opengis/partsmap 0.1.24 → 0.1.26
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.js +3299 -3031
- package/dist/index.umd.cjs +2 -2
- package/dist/style.css +1 -1
- package/package.json +1 -1
package/dist/index.umd.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(function(e,pe){typeof exports=="object"&&typeof module<"u"?module.exports=pe(require("vue")):typeof define=="function"&&define.amd?define(["vue"],pe):(e=typeof globalThis<"u"?globalThis:e||self,e.PartsMap=pe(e.Vue))})(this,function(e){"use strict";const pe=(c,o)=>{const l=c.__vccOpts||c;for(const[a,t]of o)l[a]=t;return l};e.defineComponent({props:{modelValue:{type:Boolean,default:()=>!1},title:{type:String,default:()=>""},disabled:{type:Boolean,default:()=>!1}},data(){return{}},mounted(){this.modelValue||this.$emit("update:modelValue",!1)},computed:{modelState:{get(){return this.modelValue},set(c){this.$emit("update:modelValue",c)}},labelCursorClasses(){return[{"cursor-not-allowed":this.disabled},{"cursor-pointer":!this.disabled}]}},methods:{handleEnterDown(c){const{keyCode:o}=c;o===13&&(this.modelState=!this.modelState)},addKeyHandler(){window.addEventListener("keydown",this.handleEnterDown)},removeKeyHandler(){window.removeEventListener("keydown",this.handleEnterDown)}}});const xt={},bt={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor",class:"size-6 text-green-600"};function kt(c,o){return e.openBlock(),e.createElementBlock("svg",bt,o[0]||(o[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z"},null,-1)]))}const wt=pe(xt,[["render",kt]]),Vt={},Ct={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"orange",class:"size-6 text-orange-600"};function Bt(c,o){return e.openBlock(),e.createElementBlock("svg",Ct,o[0]||(o[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 9v3m0 3h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"},null,-1)]))}const Et=pe(Vt,[["render",Bt]]),Nt={},_t={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor",class:"size-6 text-blue-600"};function St(c,o){return e.openBlock(),e.createElementBlock("svg",_t,o[0]||(o[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"m11.25 11.25.041-.02a.75.75 0 0 1 1.063.852l-.708 2.836a.75.75 0 0 0 1.063.853l.041-.021M21 12a9 9 0 1 1-18 0 9 9 0 0 1 18 0Zm-9-3.75h.008v.008H12V8.25Z"},null,-1)]))}const Mt=pe(Nt,[["render",St]]),Lt={},Dt={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"red",class:"size-6 text-red-600"};function $t(c,o){return e.openBlock(),e.createElementBlock("svg",Dt,o[0]||(o[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M6 18L18 6M6 6l12 12"},null,-1)]))}const zt=pe(Lt,[["render",$t]]),Pt={class:"rounded-md border border-gray-300 bg-white p-4 shadow-sm"},Ft={class:"flex items-start gap-4 opacity-100 scale-5 transition-all duration-300"},jt={class:"flex-1"},At={class:"font-medium text-gray-900"},Tt={class:"mt-0.5 text-sm text-gray-700"},Rt=e.defineComponent({__name:"vs-notify",props:{type:{},title:{},message:{}},setup(c){const o={success:wt,warning:Et,error:zt,info:Mt};return(l,a)=>(e.openBlock(),e.createElementBlock("div",Pt,[e.createElementVNode("div",Ft,[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(o[l.type]))),e.createElementVNode("div",jt,[e.createElementVNode("strong",At,e.toDisplayString(l.title),1),e.createElementVNode("p",Tt,e.toDisplayString(l.message),1)]),a[0]||(a[0]=e.createElementVNode("button",{class:"m-3 rounded-full p-1.5 text-gray-500 transition-colors hover:bg-gray-50 hover:text-gray-700",type:"button","aria-label":"Dismiss notify"},[e.createElementVNode("span",{class:"sr-only"},"Dismiss popup"),e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor",class:"size-5"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M6 18L18 6M6 6l12 12"})])],-1))])]))}});e.reactive({visible:!0});const Ce={top:"top-4 left-1/2 transform -translate-x-1/2","left-bottom":"bottom-4 left-4 transform","right-bottom":"bottom-4 right-4 transform",bottom:"bottom-4 left-1/2 transform -translate-x-1/2"},Re=c=>{var p;const{type:o="info",title:l,message:a,position:t="right-bottom"}=c||{};let r=document.querySelector("#notify-root");r||(r=document.createElement("div"),r.id="notify-root",r.className=`fixed z-[2000] flex flex-col gap-3 ${Ce[t]} p-6 max-w-md mx-auto font-sans antialiased`,document.body.appendChild(r)),r.className.includes(Ce[t])||(Object.values(Ce).forEach(w=>{r.classList.remove(...w.split(" "))}),r.classList.add(...Ce[t].split(" ")));const g=document.createElement("div");r.appendChild(g);const i=e.createApp({render(){return e.h(Rt,{type:o,title:l,message:a,onClose:()=>{i.unmount(),g.remove()}})}});i.mount(g),(p=g.querySelector("button"))==null||p.addEventListener("click",()=>{g.classList.add("opacity-0","scale-95","transition-all","duration-300"),setTimeout(()=>{i.unmount(),g.remove()},350)}),setTimeout(()=>{g.classList.add("opacity-0","scale-95","transition-all","duration-300"),setTimeout(()=>{i.unmount(),g.remove()},350)},3500)},ie=(c,o)=>{const l=c.__vccOpts||c;for(const[a,t]of o)l[a]=t;return l},Zt={},Ot={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-reload absolute inline mr-1 text-gray-800 transition-all cursor-pointer active:rotate-90 right-1 top-1 hover:text-blue-500"};function It(c,o){return e.openBlock(),e.createElementBlock("svg",Ot,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M19.933 13.041a8 8 0 1 1 -9.925 -8.788c3.899 -1 7.935 1.007 9.425 4.747"},null,-1),e.createElementVNode("path",{d:"M20 4v5h-5"},null,-1)]))}const Kt=ie(Zt,[["render",It]]),Ut={},vt={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:"text-blue-600 w-[16px] h-[16px]"};function Ht(c,o){return e.openBlock(),e.createElementBlock("svg",vt,o[0]||(o[0]=[e.createElementVNode("path",{d:"M20 6 9 17l-5-5"},null,-1)]))}const me=ie(Ut,[["render",Ht]]),Wt={class:"flex items-center justify-between w-full text-sm"},Gt={class:"flex items-center cursor-pointer w-full"},qt={key:0,width:"16",height:"auto",src:"data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTYgMTYnIGZpbGw9J3doaXRlJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnPjxwYXRoIGQ9J00xMi4yMDcgNC43OTNhMSAxIDAgMDEwIDEuNDE0bC01IDVhMSAxIDAgMDEtMS40MTQgMGwtMi0yYTEgMSAwIDAxMS40MTQtMS40MTRMNi41IDkuMDg2bDQuMjkzLTQuMjkzYTEgMSAwIDAxMS40MTQgMHonLz48L3N2Zz4="},Yt=["value"],Qt={class:"flex flex-row items-center font-normal text-gray-800 gap-x-1"},Xt={key:0,class:"text-xs text-gray-500 dark:text-neutral-500 pr-1"},Jt={key:1,class:"absolute right-2 flex size-3.5 items-center justify-center"},Se=e.defineComponent({__name:"list-item",props:{layout:{},count:{},type:{},label:{},value:{},isSelected:{type:Boolean},color:{},highlighted:{type:Boolean}},emits:["itemClick"],setup(c,{expose:o,emit:l}){const a=c,t=l;function r(){t("itemClick",a.value)}const g=e.ref(null),i=e.computed(()=>a.layout==="inline"&&a.type==="radio");return o({el:g}),(p,w)=>(e.openBlock(),e.createElementBlock("div",{class:"flex items-center w-full rounded-sm group hover:bg-gray-100",ref_key:"el",ref:g},[e.createElementVNode("div",Wt,[e.createElementVNode("div",Gt,[e.createElementVNode("label",{for:"radio-9740",class:e.normalizeClass([["inline","popover"].includes(p.layout)?"text-sm text-gray-500 px-2 w-full py-2 cursor-pointer !flex flex-row items-center":"flex flex-row items-center w-full px-2 py-2 text-sm text-gray-500 cursor-pointer",{"bg-blue-100":p.highlighted,relative:i.value}]),onClick:e.withModifiers(r,["stop","prevent"])},[i.value?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["w-[18px] h-[18px] border flex items-center justify-center",[p.type==="checkbox"?"rounded-[4px]":"rounded-full",p.color?`bg-[${p.color}] border-[#ffffff]`:p.isSelected?"bg-[#2563eb] border-[#ffffff]":"bg-[#ffffff] border-[#d9d9d9]"]])},[p.isSelected?(e.openBlock(),e.createElementBlock("img",qt)):e.createCommentVNode("",!0)],2)),e.createElementVNode("input",{type:"checkbox",class:"hidden",id:"radio-9740",value:p.value},null,8,Yt),e.createElementVNode("div",{class:e.normalizeClass(["flex flex-1 flex-row items-center justify-between",i.value?"pl-1 pr-6":"w-[calc(100%-18px)] pl-[10px]"])},[e.createElementVNode("span",Qt,e.toDisplayString(p.label??"Відсутні дані"),1),p.count?(e.openBlock(),e.createElementBlock("div",Xt," ("+e.toDisplayString(p.count)+") ",1)):e.createCommentVNode("",!0)],2),i.value&&p.isSelected?(e.openBlock(),e.createElementBlock("span",Jt,[e.createVNode(me)])):e.createCommentVNode("",!0)],2)])])],512))}});function Me(c,o){const{options:l=[],limit:a=20}=c;function t(m){return Array.isArray(m)?m[0]:m}const r=e.ref(t(c.modelValue)),g=e.ref(""),i=e.ref(!1),p=e.ref([]),w=e.ref("id"),f=e.ref("text"),h=e.ref(!1),u=e.ref(c.layout!=="popover"&&l.length>a);function x(m){const y=m.find(Boolean)??{},z=["id","value","code","key"].find(E=>E in y)??"id",L=["text","label","name","title"].find(E=>E in y)??"text";return{autoValueKey:z,autoLabelKey:L}}if(l.length>0){const m=x(l);w.value=m.autoValueKey,f.value=m.autoLabelKey}const b=e.computed(()=>{const m=p.value;return c.layout==="popover"||h.value?m:m.slice(0,a)});e.watch(()=>c.modelValue,m=>{r.value=t(m)},{immediate:!0}),p.value=[...l].sort((m,y)=>c.sort==="count"?y.count&&m.count?y.count-m.count:0:c.sort==="name"?String(m[f.value]??"").localeCompare(String(y[f.value]??"")):0);function k(m){return r.value===m[w.value]}function d(m){r.value=m[w.value],o("update:modelValue",r.value),o("change",{name:c.name,value:r.value})}function s(){r.value=void 0,o("update:modelValue",r.value),o("clear",c.name)}function n(){h.value=!h.value}return{innerValue:r,searchTerm:g,filteredOptions:b,isSelected:k,selectItem:d,clear:s,toggleShowAll:n,isReqProc:i,showAll:h,isEnableShowAll:u,labelKey:f,valueKey:w,allOptions:p}}const el={},tl={class:"w-48 mx-auto",viewBox:"0 0 178 90",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function ll(c,o){return e.openBlock(),e.createElementBlock("svg",tl,o[0]||(o[0]=[e.createStaticVNode('<rect x="27" y="50.5" width="124" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="27" y="50.5" width="124" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-50 dark:stroke-neutral-700/10"></rect><rect x="34.5" y="58" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="61" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="73" width="77" height="6" rx="3" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-100 dark:stroke-neutral-700/30"></rect><rect x="27" y="36" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><rect x="59" y="39" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><rect x="59" y="51" width="92" height="6" rx="3" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><g filter="url(#filter1)"><rect x="12" y="6" width="154" height="40" rx="8" fill="currentColor" class="fill-white dark:fill-neutral-800" shape-rendering="crispEdges"></rect><rect x="12.5" y="6.5" width="153" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-100 dark:stroke-neutral-700/60" shape-rendering="crispEdges"></rect><rect x="20" y="14" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect><rect x="52" y="17" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect><rect x="52" y="29" width="106" height="6" rx="3" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect></g><defs><filter id="filter1" x="0" y="0" width="178" height="64" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB"><feFlood flood-opacity="0" result="BackgroundImageFix"></feFlood><feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"></feColorMatrix><feOffset dy="6"></feOffset><feGaussianBlur stdDeviation="6"></feGaussianBlur><feComposite in2="hardAlpha" operator="out"></feComposite><feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0"></feColorMatrix><feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_1187_14810"></feBlend><feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_1187_14810" result="shape"></feBlend></filter></defs>',12)]))}const Le=ie(el,[["render",ll]]),ol={},nl={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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down w-[14px] rotate"};function rl(c,o){return e.openBlock(),e.createElementBlock("svg",nl,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)]))}const Be=ie(ol,[["render",rl]]),al={},il={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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down w-[14px] rotate-[180deg]"};function sl(c,o){return e.openBlock(),e.createElementBlock("svg",il,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)]))}const De=ie(al,[["render",sl]]),cl={key:0,class:"w-full"},dl={class:"flex flex-col items-center justify-center p-5 text-center"},pl={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ml={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},fl=e.defineComponent({__name:"radio",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=e.ref(null),r=l,{innerValue:g,filteredOptions:i,isSelected:p,selectItem:w,clear:f,toggleShowAll:h,isReqProc:u,showAll:x,isEnableShowAll:b,labelKey:k,valueKey:d,allOptions:s}=Me({...a,modelValue:a.modelValue??a.default??""},r);return o({clear:f,inputTextRef:t}),e.watch(()=>a.modelValue,n=>{n===void 0&&(g.value=void 0)}),(n,m)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([n.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox"])},[e.createElementVNode("div",{class:e.normalizeClass([n.layout==="popover"?"flex-1 overflow-y-auto p-2":"",n.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(i),y=>(e.openBlock(),e.createBlock(Se,{layout:n.layout,key:y[e.unref(d)],count:y.count,label:y[e.unref(k)],color:y.color,type:"radio",value:y[e.unref(d)],"is-selected":e.unref(p)(y),onItemClick:z=>e.unref(w)(y)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),128))],2),n.type==="select"&&e.unref(i).length===0&&!e.unref(u)?(e.openBlock(),e.createElementBlock("div",cl,[e.createElementVNode("div",dl,[e.createVNode(Le),m[4]||(m[4]=e.createElementVNode("div",{class:"max-w-sm mx-auto mt-6"},[e.createElementVNode("p",{class:"font-medium text-gray-800 dark:text-neutral-200"},"За вашим запитом нічого не знайдено"),e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"})],-1))])])):e.createCommentVNode("",!0),n.layout!=="popover"&&n.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(x)&&e.unref(b)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:m[0]||(m[0]=(...y)=>e.unref(h)&&e.unref(h)(...y)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[m[5]||(m[5]=e.createTextVNode(" Показати більше ",-1)),e.createVNode(Be)])):e.createCommentVNode("",!0),e.unref(x)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:m[1]||(m[1]=(...y)=>e.unref(h)&&e.unref(h)(...y)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[m[6]||(m[6]=e.createTextVNode(" Показати менше ",-1)),e.createVNode(De)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),n.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[n.layout==="inline"?(e.openBlock(),e.createElementBlock("div",pl,[e.createTextVNode(e.toDisplayString(e.unref(g)||e.unref(g)===null?1:0)+" з "+e.toDisplayString(e.unref(s).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:m[2]||(m[2]=(...y)=>e.unref(f)&&e.unref(f)(...y))}," Очистити ",512),[[e.vShow,e.unref(g)!==""&&e.unref(g)!==void 0]])])):e.createCommentVNode("",!0),n.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ml,[e.createElementVNode("span",null,e.toDisplayString(e.unref(g)||e.unref(g)===null?1:0)+" з "+e.toDisplayString(e.unref(s).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:m[3]||(m[3]=(...y)=>e.unref(f)&&e.unref(f)(...y))}," Очистити ",512),[[e.vShow,e.unref(g)!==""&&e.unref(g)!==void 0]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}});function Ze(c,o){const{options:l=[],limit:a=20}=c;function t(m){return Array.isArray(m)?m:m?[m]:[]}const r=e.ref(t(c.modelValue)),g=e.ref(""),i=e.ref(!1),p=e.ref([]),w=e.ref("id"),f=e.ref("text"),h=e.ref(!1),u=e.ref(c.layout!=="popover"&&l.length>a);function x(m){const y=m.find(Boolean)??{},z=["id","value","code","key"].find(E=>E in y)??"id",L=["text","label","name","title"].find(E=>E in y)??"text";return{autoValueKey:z,autoLabelKey:L}}if(l.length>0){const m=x(l);w.value=m.autoValueKey,f.value=m.autoLabelKey}const b=e.computed(()=>{const m=p.value;return c.layout==="popover"||h.value?m:m.slice(0,a)});e.watch(()=>c.modelValue,m=>{r.value=t(m)},{immediate:!0}),p.value=[...l].sort((m,y)=>c.sort==="count"?y.count&&m.count?y.count-m.count:0:c.sort==="name"?String(m[f.value]).localeCompare(String(y[f.value])):0);function k(m){return r.value&&r.value.includes(m[w.value])}function d(m){const y=r.value.includes(m[w.value]);r.value=y?r.value.filter(z=>z!==m[w.value]):[...r.value,m[w.value]],o("update:modelValue",r.value),o("change",{name:c.name,value:r.value})}function s(){r.value=[],o("update:modelValue",r.value),o("clear",c.name)}function n(){h.value=!h.value}return{innerValue:r,searchTerm:g,filteredOptions:b,isSelected:k,selectItem:d,clear:s,toggleShowAll:n,isReqProc:i,showAll:h,isEnableShowAll:u,labelKey:f,valueKey:w,allOptions:p}}const Oe={en:{apply:"Apply",search:"Search",more:"Show more",less:"Show less",selected:"selected",clear:"Clear",notfound:"Nothing found",period:"Period",today:"Today",week:"Week",max:"max",min:"min",month:"Month",quarter:"Quarter",year:"Year",alltime:"All Time",prev:"Prev",next:"Next",selectFieldHelp:"Select a field to start creating a filter."},uk:{apply:"Застосувати",search:"Пошук",more:"Показати більше",less:"Показати меньше",selected:"обрано",clear:"Очистити",notfound:"Нічого не знайдено",period:"Період",today:"Сьогодні",week:"Тиждень",max:"макс",min:"мін",month:"Місяць",quarter:"Квартал",year:"Рік",alltime:"Весь час",prev:"Попередній період",next:"Настпуний період",selectFieldHelp:"Оберіть поле, щоб розпочати створення фільтра."}};function Ie(c){const o=c.split(".")[1],l=typeof window<"u"&&window.localStorage?localStorage.locale:null;return(Oe[l||navigator.language]||Oe.uk)[o]}function ce(){const c=e.getCurrentInstance();if(!c.appContext.config.globalProperties.$i18n)return Ie;const o=c.appContext.config.globalProperties.$t;return l=>{const a=o(l);return a===l?Ie(l):a}}const ul={key:0,class:"w-full"},gl={class:"flex flex-col items-center justify-center p-5 text-center"},hl={class:"max-w-sm mx-auto mt-6"},yl={class:"font-medium text-gray-800 dark:text-neutral-200"},xl={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},bl={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},Ke=e.defineComponent({__name:"checkbox",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=ce(),t=c,r=l,{innerValue:g,filteredOptions:i,isSelected:p,selectItem:w,clear:f,toggleShowAll:h,isReqProc:u,showAll:x,isEnableShowAll:b,labelKey:k,valueKey:d,allOptions:s}=Ze({...t,modelValue:t.modelValue},r);return e.watch(()=>t.modelValue,n=>{n===void 0&&(g.value=[])}),o({clear:f}),(n,m)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([n.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",{class:e.normalizeClass([n.layout==="popover"?"flex-1 overflow-y-auto p-2":"",n.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(i),y=>(e.openBlock(),e.createBlock(Se,{layout:n.layout,count:y.count,label:y[e.unref(k)],color:y.color,type:"checkbox",value:y[e.unref(d)],"is-selected":e.unref(p)(y),onItemClick:z=>e.unref(w)(y)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),256))],2),n.type==="select"&&e.unref(i).length===0&&!e.unref(u)?(e.openBlock(),e.createElementBlock("div",ul,[e.createElementVNode("div",gl,[e.createVNode(Le),e.createElementVNode("div",hl,[e.createElementVNode("p",yl,e.toDisplayString(e.unref(a)("filter.notfound")),1),m[4]||(m[4]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),n.layout!=="popover"&&n.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(x)&&e.unref(b)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:m[0]||(m[0]=(...y)=>e.unref(h)&&e.unref(h)(...y)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.more"))+" ",1),e.createVNode(Be)])):e.createCommentVNode("",!0),e.unref(x)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:m[1]||(m[1]=(...y)=>e.unref(h)&&e.unref(h)(...y)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.less"))+" ",1),e.createVNode(De)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),n.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[n.layout==="inline"?(e.openBlock(),e.createElementBlock("div",xl,[e.createTextVNode(e.toDisplayString(e.unref(g).length)+" / "+e.toDisplayString(e.unref(s).length)+" "+e.toDisplayString(e.unref(a)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:m[2]||(m[2]=(...y)=>e.unref(f)&&e.unref(f)(...y))},e.toDisplayString(e.unref(a)("filter.clear")),513),[[e.vShow,e.unref(g).length!==0]])])):e.createCommentVNode("",!0),n.layout==="popover"?(e.openBlock(),e.createElementBlock("div",bl,[e.createElementVNode("span",null,e.toDisplayString(e.unref(g).length)+" / "+e.toDisplayString(e.unref(s).length)+" "+e.toDisplayString(e.unref(a)("filter.selected")),1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:m[3]||(m[3]=(...y)=>e.unref(f)&&e.unref(f)(...y))},e.toDisplayString(e.unref(a)("filter.clear")),513),[[e.vShow,e.unref(g).length!==0]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}}),kl={},wl={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"15px",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-search stroke-gray-500 transition-all"};function Vl(c,o){return e.openBlock(),e.createElementBlock("svg",wl,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0"},null,-1),e.createElementVNode("path",{d:"M21 21l-6 -6"},null,-1)]))}const Ue=ie(kl,[["render",Vl]]),Cl={},Bl={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:"icon icon-tabler icons-tabler-outline icon-tabler-x stroke-gray-500 hover:stroke-red-500 transition-all",width:"15px",height:"15px"};function El(c,o){return e.openBlock(),e.createElementBlock("svg",Bl,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M18 6l-12 12"},null,-1),e.createElementVNode("path",{d:"M6 6l12 12"},null,-1)]))}const $e=ie(Cl,[["render",El]]);class ve{static getWidthClass(o){return typeof o=="number"?`max-w-[${o}px] min-w-[${o}px]`:typeof o=="string"?o.endsWith("%")||o.endsWith("px")?`max-w-[${o}]`:`max-w-${o}`:"w-full"}}const Nl={class:"absolute bottom-2/4 translate-y-2/4 cursor-pointer left-3"},_l=["placeholder"],Sl=e.defineComponent({__name:"text-input",props:{id:{},name:{},title:{},type:{},label:{},width:{default:220},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{emit:o}){var w;const l=c,a=e.ref((l.placeholder||l.label||l.title||l.name||"search").toString()),t=o,r=e.ref(((w=l.modelValue)==null?void 0:w.toString())??"");e.watch(()=>l.modelValue,f=>{f!==r.value&&(r.value=(f==null?void 0:f.toString())??"")});let g=null;function i(){if(r.value=r.value.trimStart(),r.value.length===0){p();return}g&&clearTimeout(g),g=setTimeout(()=>{t("update:modelValue",r.value),t("change",{name:l.name,value:r.value})},300)}function p(){r.value="",t("update:modelValue",""),t("clear",l.name)}return(f,h)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["vs-form-text relative bg-white rounded-sm [&>input]:py-[7px] [&>input]:max-h-[38px] [&>input]:ps-10 [&>input]:pe-8 [&>input]:block [&>input]:w-full [&>input]:bg-gray-100 [&>input]:border-transparent [&>input]:rounded-sm [&>input]:text-sm [&>input]:focus:bg-white [&>input]:focus:border-blue-500 [&>input]:focus:ring-blue-500 [&>input]:disabled:opacity-50 [&>input]:disabled:pointer-events-none [&>input]:dark:bg-neutral-700 [&>input]:dark:border-transparent [&>input]:dark:text-neutral-400 [&>input]:dark:placeholder:text-neutral-400 dark:focus:bg-neutral-800 dark:focus:ring-neutral-600",f.layout==="inline"?e.unref(ve).getWidthClass(f.width):"mb-2"+(f.layout==="popover"?" m-2":"")])},[e.createElementVNode("div",Nl,[e.createVNode(Ue)]),r.value!==""?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:p,class:"absolute bottom-2/4 translate-y-2/4 right-3 cursor-pointer"},[e.createVNode($e)])):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"text","onUpdate:modelValue":h[0]||(h[0]=u=>r.value=u),onInput:i,placeholder:a.value,class:"!pr-7 !pl-8 bg-white h-[38px] min-w-[100px] text-sm py-2 px-3 block w-full border border-solid placeholder:text-nowrap border-stone-200 rounded-sm text-sm text-stone-800 placeholder:text-stone-400 focus:border-2 focus:z-10 focus:border-blue-500 focus:ring-blue-500 focus:outline-blue-500"},null,40,_l),[[e.vModelText,r.value]])],2))}});function He(c={color:"blue"}){return e.computed(()=>{const o=`w-full px-3 py-2 border-solid border text-black border-gray-300 text-sm rounded focus:outline-none focus:ring-2 focus:ring-${c.color}-500 focus:border-transparent
|
|
2
|
-
text-gray-800 bg-white dark:text-neutral-300 dark:bg-neutral-800 dark:border-neutral-600`;return(c==null?void 0:c.size)==="sm"?`${o}h-[32px]`:`${o}h-[38px]`})}function Ml(){return"rounded-md font-medium border-gray-200 border-solid disabled:pointer-events-none disabled:opacity-50 px-4 py-2 w-full bg-transparent border text-black text-sm h-[38px]"}function Ll(){return"font-medium border border-gray-200 border-solid disabled:pointer-events-none disabled:opacity-50 h-7 rounded-md text-xs px-2 py-1 text-gray-800 bg-white hover:bg-gray-100 dark:text-neutral-300 dark:bg-neutral-800 dark:hover:bg-neutral-700 dark:border-neutral-600"}function We(c){return c==="ghost"?"inline-flex relative py-2 px-4 items-center gap-x-2 text-sm font-medium rounded-sm border text-gray-600 hover:bg-blue-100 hover:text-gray-800 focus:outline-hidden focus:bg-gray-100 focus:text-gray-800 disabled:opacity-50 disabled:pointer-events-none dark:text-gray-500 dark:hover:bg-blue-800/30 dark:hover:text-blue-400 dark:focus:bg-blue-800/30 dark:focus:text-blue-400":c==="soft"?"inline-flex relative py-2 px-4 items-center gap-x-2 text-sm font-medium rounded-sm border bg-white-100 text-gray-800 hover:bg-gray-200 hover:bg-gray-200 focus:outline-hidden focus:bg-gray-200 disabled:opacity-50 disabled:pointer-events-none dark:text-blue-400 dark:hover:bg-blue-900 dark:focus:bg-blue-900":"relative border-solid border-gray-200 focus-visible:outline-hidden focus-visible:ring-ring inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border-input hover:bg-gray-100 border px-4 py-2 gap-1 bg-transparent h-[38px]"}const Dl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},$l=["placeholder","disabled"],zl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Pl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Fl=["placeholder","disabled"],jl=["disabled"],Al=e.defineComponent({__name:"range-input",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=He(),t=Ml(),r=ce(),g=c,i=e.ref(g.modelValue??g.default??[]),p=l,w=e.computed({get:()=>g.modelValue??i.value,set:u=>{g.modelValue!==void 0?p("update:modelValue",u):i.value=u}});function f(){p("change",{name:g.name,value:w.value||i.value})}function h(){i.value=[],w.value=i.value,p("clear",g.name)}return e.watch(()=>g.modelValue,u=>{u!==void 0&&g.layout!=="popover"?(i.value=u,p("update:modelValue",u)):i.value=[]}),o({clear:h,currentValue:w}),(u,x)=>{var b,k;return e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",null,[e.createElementVNode("div",{class:e.normalizeClass(u.layout==="vertical"?"inline-flex items-center gap-2":"space-y-3 p-2")},[e.createElementVNode("div",null,[u.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",Dl,e.toDisplayString(e.unref(r)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(a)),placeholder:((b=u.placeholder)==null?void 0:b[0])??e.unref(r)("filter.min"),step:"1",style:{outline:"none"},"onUpdate:modelValue":x[0]||(x[0]=d=>w.value[0]=d),disabled:u.disabled},null,10,$l),[[e.vModelText,w.value[0]]])]),u.layout==="vertical"?(e.openBlock(),e.createElementBlock("label",zl," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",null,[u.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",Pl,e.toDisplayString(e.unref(r)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(a)),placeholder:((k=u.placeholder)==null?void 0:k[1])??e.unref(r)("filter.max"),min:"0",max:"1000000000000000",step:"1",style:{outline:"none"},"onUpdate:modelValue":x[1]||(x[1]=d=>w.value[1]=d),disabled:u.disabled},null,10,Fl),[[e.vModelText,w.value[1]]])]),["popover","inline","vertical"].includes(u.layout)?(e.openBlock(),e.createElementBlock("button",{key:1,onClick:f,class:e.normalizeClass(e.unref(t)+(u.layout==="vertical"?" w-[50px]":" bg-blue-100 hover:bg-blue-200"))},e.toDisplayString(u.layout==="vertical"?"Ok":e.unref(r)("filter.apply")),3)):e.createCommentVNode("",!0),["popover","inline"].includes(u.layout)?(e.openBlock(),e.createElementBlock("button",{key:2,disabled:!(w.value[0]||w.value[1]),onClick:h,class:e.normalizeClass(e.unref(t)+" hover:bg-gray-100")},e.toDisplayString(e.unref(r)("filter.clear")),11,jl)):e.createCommentVNode("",!0)],2)]),(u.cleanable&&i.value.length,e.createCommentVNode("",!0))],64)}}});class Q{static format(o){const l=o.getFullYear(),a=(o.getMonth()+1).toString().padStart(2,"0"),t=o.getDate().toString().padStart(2,"0");return`${l}-${a}-${t}`}static getShiftedDay(o,l=0){const a=o?new Date(o):new Date;return a.setDate(a.getDate()+l),this.format(a)}static getLastWeekRange(o,l,a=0){if(o&&l){const w=new Date(o),f=new Date(l);return w.setDate(w.getDate()+a*7),f.setDate(f.getDate()+a*7),[this.format(w),this.format(f)]}const t=new Date,r=t.getDay(),g=r===0?13:r-1+7,i=new Date(t);i.setDate(t.getDate()-g+a*7);const p=new Date(i);return p.setDate(i.getDate()+6),[this.format(i),this.format(p)]}static getMonthRange(o,l,a=0){let t;o?t=new Date(o):t=new Date,t=new Date(t.getFullYear(),t.getMonth()+a,1);const r=t,g=new Date(t.getFullYear(),t.getMonth()+1,0);return[this.format(r),this.format(g)]}static getQuarterRange(o,l,a=0){const t=o||l,r=t?new Date(t):new Date;let g=Math.floor(r.getMonth()/3);g+=a;const i=(g%4+4)%4*3,p=r.getFullYear()+Math.floor(g/4),w=new Date(p,i,1),f=new Date(p,i+3,0);return[this.format(w),this.format(f)]}static getYear(o,l=0){let a;return o&&/^\d{4}$/.test(o)?a=parseInt(o,10):o?a=new Date(o).getFullYear():a=new Date().getFullYear(),String(a+l)}static getYearRange(o,l=0){let a;return o&&/^\d{4}$/.test(o)?a=parseInt(o,10):o?a=new Date(o).getFullYear():a=new Date().getFullYear(),[this.format(new Date(a+l,0,1)),this.format(new Date(a+l+1,0,0))]}static getRangeFromDaysBefore(o){const l=new Date,a=new Date(l.getTime());return a.setDate(l.getDate()-o),[this.format(a),this.format(l)]}}function Ge(c,o){const{popoverRef:l}=c,a=ce(),t=e.ref(""),r=e.ref(c.modelValue??c.default??[]),g=e.ref(0);function i(){const s=Q.getRangeFromDaysBefore(g.value);return r.value=[...s],o("change",{name:c.name,value:r.value}),o("update:modelValue",r.value),s}function p(s){var m;t.value=s,(m=l.value)==null||m.close();const n=[];switch(t.value){case"today":n.push(Q.getShiftedDay()),n.push(Q.getShiftedDay());break;case"week":n.push(...Q.getLastWeekRange());break;case"month":n.push(...Q.getMonthRange());break;case"quarter":n.push(...Q.getQuarterRange());break;case"year":n.push(...Q.getYearRange());break;case"last_7_days":g.value=7,i();break;case"range":g.value=7,n.push(...i());break}r.value=[...n],o("change",{name:c.name,value:r.value}),o("update:modelValue",r.value)}function w(){const s=[];switch(t.value){case"today":s.push(Q.getShiftedDay(r.value[0],1));break;case"week":s.push(...Q.getLastWeekRange(r.value[0],r.value[1],1));break;case"month":s.push(...Q.getMonthRange(r.value[0],r.value[1],1));break;case"quarter":s.push(...Q.getQuarterRange(r.value[0],r.value[1],1));break;case"year":s.push(...Q.getYearRange(r.value[0],1));break}r.value=[...s],o("change",{name:c.name,value:r.value}),o("update:modelValue",r.value)}function f(){const s=[];switch(t.value){case"today":s.push(Q.getShiftedDay(r.value[0],-1));break;case"week":s.push(...Q.getLastWeekRange(r.value[0],r.value[1],-1));break;case"month":s.push(...Q.getMonthRange(r.value[0],r.value[1],-1));break;case"quarter":s.push(...Q.getQuarterRange(r.value[0],r.value[1],-1));break;case"year":s.push(...Q.getYearRange(r.value[0],-1));break}r.value=[...s],o("change",{name:c.name,value:r.value}),o("update:modelValue",r.value)}const h=["Січень","Лютий","Березень","Квітень","Травень","Червень","Липень","Серпень","Вересень","Жовтень","Листопад","Грудень"];function u(s){const[n,m,y]=s.split("-");return`${y}.${m}.${n}`}function x(s,n="long"){const m=new Date(Date.UTC(2e3,s-1,1));return new Intl.DateTimeFormat(localStorage.locale,{month:n,timeZone:"UTC"}).format(m)}function b(s){const{value:n}=r;switch(s){case"today":return u(n[0]);case"range":return"Період";case"week":return n[0]&&n[1]?`${u(n[0])} – ${u(n[1])}`:"";case"quarter":if(n[0]){const m=new Date(n[0]),y=m.getFullYear(),z=m.getMonth();return`${Math.floor(z/3)+1} ${a("filter.quarter")} ${y}`}return"";case"month":if(n[0]){const[m,y]=n[0].split("-");return`${x(parseInt(y,10))} ${m}`}return"";case"year":return n[0]||"";case"last_7_days":return"За останні дні";default:return c.label??""}}const k=e.computed(()=>t.value?b(t.value):c.label??"");function d(){t.value="",r.value=[],o("update:modelValue",[]),o("clear",c.name)}return{activeMode:t,innerValue:r,daysBefore:g,onDaysBeforeChange:i,onSelectChange:p,nextClick:w,prevClick:f,ukMonths:h,formatDisplayDate:u,getModeLabel:b,currentLabel:k,clear:d}}const Tl={key:0,class:"relative flex w-full h-auto gap-2 filter-date m-2 flex-wrap"},Rl={key:0,class:"flex gap-1 !w-[75%] rounded-sm"},Zl=["max","disabled"],Ol=["min","disabled"],Il={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Kl=["max","disabled"],Ul={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},vl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Hl=["min","disabled"],Wl={class:"flex gap-1 pt-2"},Gl=["onClick"],ql=e.defineComponent({__name:"date-input",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=He(),r=Ll(),g=ce(),i=l,p=e.ref(null),{activeMode:w,innerValue:f,onSelectChange:h,nextClick:u,prevClick:x,clear:b}=Ge({...a,popoverRef:p},i);return e.watch(()=>a.modelValue,k=>{k!==void 0?(f.value=k,i("update:modelValue",k)):(w.value="",f.value=[])}),e.watch(f,k=>{i("update:modelValue",k),i("change",{name:a.name,value:k})},{deep:!0}),o({clear:b,popoverRef:p}),(k,d)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[k.layout==="inline"?(e.openBlock(),e.createElementBlock("div",Tl,[e.unref(w)!==""&&e.unref(w)==="range"?(e.openBlock(),e.createElementBlock("div",Rl,[d[7]||(d[7]=e.createTextVNode(" 1111 ",-1)),e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(f)[1],locale:"uk-UA","onUpdate:modelValue":d[0]||(d[0]=s=>e.unref(f)[0]=s),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:k.disabled},null,8,Zl),[[e.vModelText,e.unref(f)[0]]]),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(f)[0],locale:"uk-UA","onUpdate:modelValue":d[1]||(d[1]=s=>e.unref(f)[1]=s),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:k.disabled},null,8,Ol),[[e.vModelText,e.unref(f)[1]]])])):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(k.layout==="popover"?"space-y-3 p-2":"flex items-center gap-2")},[e.createElementVNode("div",{class:e.normalizeClass(k.layout!=="popover"?"w-[48%]":"")},[k.layout==="popover"?(e.openBlock(),e.createElementBlock("label",Il,e.toDisplayString(e.unref(g)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(f)[1],locale:"uk-UA","onUpdate:modelValue":d[2]||(d[2]=s=>e.unref(f)[0]=s),class:e.normalizeClass(e.unref(t)),disabled:k.disabled},null,10,Kl),[[e.vModelText,e.unref(f)[0]]])],2),k.layout!=="popover"?(e.openBlock(),e.createElementBlock("label",Ul," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(k.layout!=="popover"?"w-[48%]":"")},[k.layout==="popover"?(e.openBlock(),e.createElementBlock("label",vl,e.toDisplayString(e.unref(g)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(f)[0],locale:"uk-UA","onUpdate:modelValue":d[3]||(d[3]=s=>e.unref(f)[1]=s),class:e.normalizeClass(e.unref(t)),disabled:k.disabled},null,10,Hl),[[e.vModelText,e.unref(f)[1]]])],2)],2),e.createElementVNode("div",Wl,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["today","week","month","quarter","year"],s=>e.createElementVNode("button",{key:s,class:e.normalizeClass(e.unref(r)+(e.unref(w)===s?" bg-blue-100":"")),onClick:n=>e.unref(h)(s)},e.toDisplayString(e.unref(g)("filter."+s)),11,Gl)),64)),e.createElementVNode("button",{class:e.normalizeClass(e.unref(r)),onClick:d[4]||(d[4]=(...s)=>e.unref(x)&&e.unref(x)(...s))},"<",2),e.createElementVNode("button",{class:e.normalizeClass(e.unref(r)),onClick:d[5]||(d[5]=(...s)=>e.unref(u)&&e.unref(u)(...s))},">",2)]),(k.cleanable,e.createCommentVNode("",!0))],64))}});function Yl(c,o){const{api:l,options:a=[],limit:t=20,dataKey:r="data"}=c,g=c.multi;function i(N){return g?Array.isArray(N)?N:N?[N]:[]:Array.isArray(N)?N[0]:N}const p=e.ref(i(c.modelValue)),w=e.ref(""),f=e.ref(!1),h=e.ref(a),u=e.ref("id"),x=e.ref("text"),b=e.ref(!1),k=e.ref(c.layout!=="popover"&&a.length>t),d=e.ref([]),s=e.ref(0);function n(N){const F=N.find(Boolean)??{},T=["id","value","code","key"].find(K=>K in F)??"id",I=["text","label","name","title"].find(K=>K in F)??"text";return{autoValueKey:T,autoLabelKey:I}}if(a.length>0){const N=n(a);u.value=N.autoValueKey,x.value=N.autoLabelKey}const m=e.computed(()=>{if(l)return h.value;const N=h.value;if(c.layout==="popover")return N;if(!w.value)return b.value?N:N.slice(0,t);const F=w.value.toLowerCase();return N.filter(T=>T[x.value].toLowerCase().includes(F))});let y=null;async function z(N){if(l){f.value=!0;try{const F=new URL(l,window.location.origin);F.searchParams.set("json","1"),F.searchParams.set("key",N),F.searchParams.set("limit",t.toString());const T=await fetch(F.toString());if(!T.ok){Re({type:"error",title:"Error",message:"Failed to fetch remote options"}),h.value=[];return}const I=await T.json();if(!I[r]){Re({type:"error",title:"Error",message:I}),h.value=[];return}if(h.value=I[r],h.value.length>0){const K=n(h.value);u.value=K.autoValueKey,x.value=K.autoLabelKey}s.value=I.total}catch(F){console.error("Failed to fetch remote options:",F)}finally{f.value=!1}}}e.watch(w,N=>{l&&(y&&clearTimeout(y),y=setTimeout(()=>{z(N)},200))}),e.watch(()=>c.modelValue,N=>{p.value=i(N)},{immediate:!0});function L(N){return g&&Array.isArray(p.value)?p.value.includes(N[u.value]):p.value&&p.value===N[u.value]}function E(N){if(g&&!Array.isArray(p.value)&&(p.value=[]),g&&Array.isArray(p.value)){const F=p.value.includes(N[u.value]);p.value=F?p.value.filter(T=>T!==N[u.value]):[...p.value,N[u.value]],d.value=F?d.value.filter(T=>T!==N[x.value]):[...d.value,N[x.value]]}else p.value=N[u.value],d.value=N[x.value];o("update:modelValue",p.value),o("change",{name:c.name,value:p.value})}function S(){g?(p.value=[],d.value=[]):(p.value=void 0,d.value=[]),o("update:modelValue",p.value),o("clear",c.name)}function D(){y&&clearTimeout(y),w.value="",b.value=!1}function _(){b.value=!b.value}e.onBeforeUnmount(()=>{y&&clearTimeout(y)});const M=e.ref(-1);e.watch(m,()=>{M.value=m.value.length>0?0:-1});function Z(N){const F=m.value.length;if(N.key==="ArrowDown")N.preventDefault(),M.value=(M.value+1)%F;else if(N.key==="ArrowUp")N.preventDefault(),M.value=(M.value-1+F)%F;else if(N.key==="Enter"&&(N.preventDefault(),M.value>=0&&M.value<m.value.length)){const T=m.value[M.value];E(T)}}function A(){l&&h.value.length===0&&w.value.length===0&&z(w.value)}return{innerValue:p,searchTerm:w,filteredOptions:m,isSelected:L,selectItem:E,clear:S,resetSearch:D,toggleShowAll:_,isReqProc:f,showAll:b,isEnableShowAll:k,labelKey:x,valueKey:u,allOptions:h,highlightedIndex:M,onKeyDown:Z,selectedLabels:d,totalCount:s,loadData:A}}const Ql={class:"h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relative justify-center"},Xl=["placeholder"],Jl={key:0,class:"w-full"},eo={class:"flex flex-col items-center justify-center p-5 text-center"},to={class:"max-w-sm mx-auto mt-6"},lo={class:"font-medium text-gray-800 dark:text-neutral-200"},oo={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},no={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},ro=e.defineComponent({__name:"select",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=ce(),t=c,r=l,g=e.ref(null),{innerValue:i,filteredOptions:p,isSelected:w,selectItem:f,clear:h,resetSearch:u,toggleShowAll:x,isReqProc:b,showAll:k,isEnableShowAll:d,searchTerm:s,labelKey:n,valueKey:m,highlightedIndex:y,onKeyDown:z,selectedLabels:L,totalCount:E,loadData:S}=Yl({...t,modelValue:t.modelValue},r);e.onMounted(()=>{u(),t.layout!=="inline"&&(S(),g.value&&t.layout==="popover"&&g.value.focus())}),e.watch(()=>t.modelValue,_=>{_===void 0&&(t.multi?i.value=[]:i.value=void 0)});const D=e.ref([]);return e.watch(y,_=>{var M;_>=0&&D.value[_]&&((M=D.value[_])==null||M.scrollIntoView({block:"nearest",behavior:"smooth"}))}),e.watch(p,()=>{D.value=[]}),o({clear:h,inputTextRef:g,selectedLabels:L,loadData:S}),(_,M)=>{var Z,A;return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([_.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",Ql,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":M[0]||(M[0]=N=>e.isRef(s)?s.value=N:null),onKeydown:M[1]||(M[1]=(...N)=>e.unref(z)&&e.unref(z)(...N)),class:"w-full h-full text-[13px] px-4 border rounded-sm pl-9 focus:outline-none focus:ring-ring focus:ring-1 focus:ring-blue-500 text-gray-700",placeholder:e.unref(a)("filter.search"),type:"text",ref_key:"inputTextRef",ref:g},null,40,Xl),[[e.vModelText,e.unref(s)]]),e.createVNode(Ue,{class:"absolute text-gray-400 -translate-y-1/2 left-4 top-1/2"}),e.unref(s)!=""?(e.openBlock(),e.createBlock($e,{key:0,onClick:M[2]||(M[2]=N=>s.value=""),class:"absolute text-gray-400 -translate-y-1/2 cursor-pointer hover:text-red-500 right-4 top-1/2"})):e.createCommentVNode("",!0)]),e.createElementVNode("div",{class:e.normalizeClass([_.layout==="popover"?"flex-1 overflow-y-auto p-2":"",_.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(p),(N,F)=>(e.openBlock(),e.createBlock(Se,{layout:_.layout,count:N.count,label:N[e.unref(n)],color:N.color,type:_.multi?"checkbox":"radio",value:N[e.unref(m)],"is-selected":e.unref(w)(N),highlighted:F===e.unref(y),onItemClick:T=>e.unref(f)(N),ref_for:!0,ref:T=>D.value[F]=T==null?void 0:T.el},null,8,["layout","count","label","color","type","value","is-selected","highlighted","onItemClick"]))),256))],2),_.type==="select"&&e.unref(p).length===0&&!e.unref(b)?(e.openBlock(),e.createElementBlock("div",Jl,[e.createElementVNode("div",eo,[e.createVNode(Le),e.createElementVNode("div",to,[e.createElementVNode("p",lo,e.toDisplayString(e.unref(a)("filter.notfound")),1),M[7]||(M[7]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),_.layout!=="popover"&&_.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(k)&&e.unref(d)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:M[3]||(M[3]=(...N)=>e.unref(x)&&e.unref(x)(...N)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.more"))+" ",1),e.createVNode(Be)])):e.createCommentVNode("",!0),e.unref(k)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:M[4]||(M[4]=(...N)=>e.unref(x)&&e.unref(x)(...N)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.less"))+" ",1),e.createVNode(De)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),_.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[_.layout==="inline"?(e.openBlock(),e.createElementBlock("div",oo,[e.createTextVNode(e.toDisplayString(_.multi&&Array.isArray(e.unref(i))?(Z=e.unref(i))==null?void 0:Z.length:e.unref(i)!==void 0&&(e.unref(i)||e.unref(i)===null)?1:0)+" / "+e.toDisplayString(e.unref(E))+" "+e.toDisplayString(e.unref(a)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:M[5]||(M[5]=(...N)=>e.unref(h)&&e.unref(h)(...N))},e.toDisplayString(e.unref(a)("filter.clear")),513),[[e.vShow,e.unref(i)!==""&&e.unref(i)!==void 0||e.unref(i)]])])):e.createCommentVNode("",!0),_.layout==="popover"?(e.openBlock(),e.createElementBlock("div",no,[e.createElementVNode("span",null,e.toDisplayString(_.multi&&Array.isArray(e.unref(i))?(A=e.unref(i))==null?void 0:A.length:e.unref(i)!==void 0&&(e.unref(i)||e.unref(i)===null)?1:0)+" / "+e.toDisplayString(e.unref(E))+" "+e.toDisplayString(e.unref(a)("filter.selected")),1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:M[6]||(M[6]=(...N)=>e.unref(h)&&e.unref(h)(...N))},e.toDisplayString(e.unref(a)("filter.clear")),513),[[e.vShow,e.unref(i)!==""&&e.unref(i)!==void 0||e.unref(i)]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2)}}}),ao=["for","onClick"],io=["id","name","value"],so={class:"block"},co={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},po={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},mo=e.defineComponent({__name:"tag-field",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=l,{innerValue:r,isSelected:g,selectItem:i,clear:p,labelKey:w,valueKey:f,allOptions:h}=a.multi?Ze({...a,modelValue:a.modelValue??a.default??[]},t):Me({...a,modelValue:a.modelValue!==void 0?a.modelValue:a.default??""},t);return o({clear:p}),e.watch(()=>a.modelValue,u=>{u===void 0&&(a.multi?r.value=[]:r.value=void 0)}),(u,x)=>{var b,k;return e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{class:e.normalizeClass(["grid grid-cols-3 gap-2 mx-[1px]",u.layout==="popover"?"m-1":"mb-1"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(h),d=>(e.openBlock(),e.createElementBlock("label",{key:`item-${d[e.unref(f)]}`,for:`item-${d[e.unref(f)]}`,onClick:e.withModifiers(s=>e.unref(i)(d),["stop","prevent"]),class:e.normalizeClass([e.unref(g)(d)?"ring-2 ring-indigo-600":"","p-2.5 group relative flex justify-center items-center gap-x-12 text-center text-xs bg-white text-gray-800 border border-gray-200 cursor-pointer rounded-sm dark:bg-neutral-900 dark:border-neutral-700 dark:text-neutral-200 peer-checked:text-indigo-600 dark:has-checked:text-indigo-500 peer-checked:border-indigo-600 dark:has-checked:border-indigo-500 peer-checked:ring peer-checked:shadow focus:ring dark:has-checked:ring-indigo-500 has-disabled:pointer-events-none has-disabled:text-gray-200 dark:has-disabled:text-neutral-700 has-disabled:after:absolute has-disabled:after:inset-0 has-disabled:after:bg-[linear-gradient(to_right_bottom,transparent_calc(50%-1px),var(--color-gray-200)_calc(50%-1px),var(--color-gray-200)_50%,transparent_50%)] dark:has-disabled:after:bg-[linear-gradient(to_right_bottom,transparent_calc(50%-1px),var(--color-neutral-700)_calc(50%-1px),var(--color-neutral-700)_50%,transparent_50%)]"])},[e.createElementVNode("input",{type:"checkbox",id:`item-${d[e.unref(f)]}`,class:"hidden w4poy border-gray-200 g41z1 g22e3 axcnw dark:text-indigo-500 dark:border-neutral-700 dark:focus:ring-neutral-900",name:`item-${d[e.unref(f)]}`,value:d[e.unref(f)]},null,8,io),e.createElementVNode("span",so,e.toDisplayString(d[e.unref(w)]),1)],10,ao))),128))],2),u.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[u.layout==="inline"?(e.openBlock(),e.createElementBlock("div",co,[e.createTextVNode(e.toDisplayString(u.multi&&Array.isArray(e.unref(r))?(b=e.unref(r))==null?void 0:b.length:e.unref(r)!==void 0&&(e.unref(r)||e.unref(r)===null)?1:0)+" з "+e.toDisplayString(e.unref(h).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:x[0]||(x[0]=(...d)=>e.unref(p)&&e.unref(p)(...d))}," Очистити ",512),[[e.vShow,e.unref(r)!==""&&e.unref(r)!==void 0||e.unref(r)]])])):e.createCommentVNode("",!0),u.layout==="popover"?(e.openBlock(),e.createElementBlock("div",po,[e.createElementVNode("span",null,e.toDisplayString(u.multi&&Array.isArray(e.unref(r))?(k=e.unref(r))==null?void 0:k.length:e.unref(r)!==void 0&&(e.unref(r)||e.unref(r)===null)?1:0)+" з "+e.toDisplayString(e.unref(h).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:x[1]||(x[1]=(...d)=>e.unref(p)&&e.unref(p)(...d))}," Очистити ",512),[[e.vShow,e.unref(r)!==void 0&&e.unref(r)!==""||e.unref(r)]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],64)}}}),fo=["disabled","title"],uo={class:"flex w-full items-center justify-between gap-1 overflow-hidden text-left"},go={class:"truncate text-ellipsis text-sm"},ho={key:0,class:"inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-sm bg-blue-100 px-2 text-[11px] font-semibold text-blue-600"},yo={class:"w-full text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-sm 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"},xo={class:"w-[360px] max-h-[500px] overflow-auto [&::-webkit-scrollbar]:h-2 [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-stone-100 [&::-webkit-scrollbar-thumb]:bg-stone-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 before:w-full p-2"},ze=e.defineComponent({__name:"popover-field",props:{disabled:{type:Boolean,default:!1},label:{},en:{},ua:{},uk:{},fr:{},de:{},es:{},currentValue:{},fieldRef:{},width:{},mode:{},layout:{}},setup(c,{expose:o}){const l=c,a=e.computed(()=>We(l.mode)),t=e.ref(!1),r=e.ref({top:0,left:0}),g=e.ref(null),i=e.ref(null),p=e.ref(null);function w(){const y=i.value,z=p.value;if(!y||!z)return;const L=y.getBoundingClientRect(),E=z.offsetWidth,S=z.offsetHeight,D=window.innerWidth,_=window.innerHeight,M=8;let Z=L.bottom+M,{left:A}=L;const N=Math.max(D-E-10,10);if(A=Math.min(A,N),A=Math.max(A,10),Z+S>_-10){const F=L.top-S-M;Z=F>=10?F:Math.max(_-S-10,10)}Z<10&&(Z=10),r.value={top:Z,left:A}}function f(){t.value=!t.value,t.value&&e.nextTick(()=>{var y,z,L,E,S,D,_;w(),(y=l.fieldRef)!=null&&y.inputTextRef&&((E=(L=(z=l.fieldRef)==null?void 0:z.inputTextRef)==null?void 0:L.focus)==null||E.call(L)),(S=l.fieldRef)!=null&&S.loadData&&((_=(D=l.fieldRef)==null?void 0:D.loadData)==null||_.call(D))})}function h(y){var z,L,E;!((z=g.value)!=null&&z.contains(y.target))&&!((L=p.value)!=null&&L.contains(y.target))&&!((E=i.value)!=null&&E.contains(y.target))&&(t.value=!1)}function u(y){y.key==="Escape"&&(t.value=!1)}const x=e.ref(!1),b=e.ref("ua"),k=y=>{y.detail.key==="locale"&&(b.value=y.detail.newValue)};e.onMounted(()=>{x.value=!0,b.value=localStorage.locale,window.addEventListener("storage",k),document.addEventListener("click",h,!0),document.addEventListener("keydown",u),window.addEventListener("scroll",w,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",k),document.removeEventListener("click",h,!0),document.removeEventListener("keydown",u),window.removeEventListener("scroll",w,!0)});function d(){t.value=!1}o({close:d});function s(y){return Array.isArray(y)?y.filter(z=>z!=null&&z!=="").length:y&&typeof y=="object"?Object.values(y).filter(z=>z!=null&&z!=="").length:typeof y=="string"?y.trim()===""?0:1:typeof y=="number"?Number.isNaN(y)?0:1:y===null||y!==void 0?1:0}const n=e.computed(()=>{var L;const y=(L=l.fieldRef)==null?void 0:L.selectedLabels,z=s(y);return z>0?z:s(l.currentValue)}),m=e.computed(()=>{var z;const y=(z=l.fieldRef)==null?void 0:z.selectedLabels;return!y||["inline"].includes(l.layout||"")?l[b.value]||(l.label??""):Array.isArray(y)?y.length>0?y.join(", "):l.label??"":String(y)});return(y,z)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("button",{onClick:f,disabled:y.disabled,ref_key:"triggerRef",ref:i,title:y.label,class:e.normalizeClass([a.value,y.width?e.unref(ve).getWidthClass(y.width):"w-full",y.layout==="inline"&&n.value>0?"border border-blue-400 bg-blue-50 text-blue-600":""]),type:"button"},[e.createElementVNode("span",uo,[e.createElementVNode("span",go,e.toDisplayString(m.value),1),y.layout==="inline"&&n.value>0?(e.openBlock(),e.createElementBlock("span",ho,e.toDisplayString(n.value),1)):e.createCommentVNode("",!0)]),e.createVNode(Be,{class:"h-4 w-4 text-neutral-500"})],10,fo),x.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popperRef",ref:p,class:"vsTailwind vs-popover__content bottom-right w-fit fixed z-[1000]",style:e.normalizeStyle({top:`${r.value.top}px`,left:`${r.value.left}px`}),"data-inside-popover":""},[e.createElementVNode("div",yo,[e.createElementVNode("div",xo,[e.renderSlot(y.$slots,"default")])])],4),[[e.vShow,t.value]])])):e.createCommentVNode("",!0)]))}}),bo={},ko={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down text-gray-800 rotate-[90deg]"};function wo(c,o){return e.openBlock(),e.createElementBlock("svg",ko,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)]))}const Vo=ie(bo,[["render",wo]]),Co={},Bo={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down text-gray-800 rotate-[270deg]"};function Eo(c,o){return e.openBlock(),e.createElementBlock("svg",Bo,o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)]))}const No=ie(Co,[["render",Eo]]),_o={class:"flex gap-1"},So={class:"mb-1"},Mo={class:"mb-1"},Lo={class:"inline-flex rounded-sm shrink-0 pl-1"},Do=["title"],$o={class:"inline-flex rounded-sm shrink-0 pl-1"},zo=["title"],Po={key:1,class:"flex gap-1 !w-[75%] rounded-sm"},Fo=["max","value","disabled"],jo=["min","value","disabled"],Ao=e.defineComponent({__name:"date-input-inline",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=ce(),t=c,r=l,g=e.ref(null),{activeMode:i,innerValue:p,onSelectChange:w,nextClick:f,prevClick:h,currentLabel:u,clear:x}=Ge({...t,popoverRef:g},r);e.watch(()=>t.modelValue,d=>{d!==void 0?(p.value=d,r("update:modelValue",d)):(i.value="",p.value=[])}),e.watch(p,d=>{r("update:modelValue",d),r("change",{name:t.name,value:d})},{deep:!0});function b(d){const s=Array.isArray(p.value)?[...p.value]:[];p.value=[d,s[1]||""]}function k(d){const s=Array.isArray(p.value)?[...p.value]:[];p.value=[s[0]||"",d]}return o({clear:x,popoverRef:g}),(d,s)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",_o,[e.createVNode(ze,{ref_key:"popoverRef",ref:g,label:e.unref(u),"current-value":e.unref(p),mode:d.mode,width:typeof d.width=="number"&&e.unref(p).length?d.width-70:d.width,onClear:e.unref(x),layout:d.layout,class:e.normalizeClass(d.itemClass)},{default:e.withCtx(()=>[e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:s[0]||(s[0]=n=>e.unref(w)("range")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.period"))+" ",1),e.unref(i)==="range"?(e.openBlock(),e.createBlock(me,{key:0})):e.createCommentVNode("",!0)])]),s[12]||(s[12]=e.createElementVNode("div",null,[e.createElementVNode("div",{class:"pt-1 mt-1 border-t"})],-1)),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:s[1]||(s[1]=n=>e.unref(w)("today")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.today"))+" ",1),e.unref(i)==="today"?(e.openBlock(),e.createBlock(me,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:s[2]||(s[2]=n=>e.unref(w)("week")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.week"))+" ",1),e.unref(i)==="week"?(e.openBlock(),e.createBlock(me,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:s[3]||(s[3]=n=>e.unref(w)("month")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.month"))+" ",1),e.unref(i)==="month"?(e.openBlock(),e.createBlock(me,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:s[4]||(s[4]=n=>e.unref(w)("quarter")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.quarter"))+" ",1),e.unref(i)==="quarter"?(e.openBlock(),e.createBlock(me,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",So,[e.createElementVNode("button",{type:"button",onClick:s[5]||(s[5]=n=>e.unref(w)("year")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.year"))+" ",1),e.unref(i)==="year"?(e.openBlock(),e.createBlock(me,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",Mo,[e.createElementVNode("button",{type:"button",onClick:s[6]||(s[6]=n=>e.unref(x)()),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(a)("filter.alltime"))+" ",1),e.unref(p)[0]?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(me,{key:0}))])])]),_:1,__:[12]},8,["label","current-value","mode","width","onClear","layout","class"]),e.unref(i)!==""&&e.unref(i)!=="range"&&e.unref(i)!=="last_7_days"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",Lo,[e.createElementVNode("button",{type:"button",title:e.unref(a)("filter.prev"),class:"inline-flex h-[38px] items-center px-2 text-sm text-gray-800 bg-gray-100 gap-x-2 -ms-px first:rounded-s-lg first:ms-0 last:rounded-e-lg focus:z-10 hover:bg-gray-200 focus:bg-gray-200 duration-300",onClick:s[7]||(s[7]=(...n)=>e.unref(h)&&e.unref(h)(...n))},[e.createVNode(Vo)],8,Do)]),e.createElementVNode("div",$o,[e.createElementVNode("button",{type:"button",title:e.unref(a)("filter.next"),class:"inline-flex h-[38px] items-center px-2 text-sm text-gray-800 gap-x-2 bg-gray-100 -ms-px first:rounded-s-lg first:ms-0 last:rounded-e-lg focus:z-10 hover:bg-gray-200 focus:bg-gray-200 duration-300",onClick:s[8]||(s[8]=(...n)=>e.unref(f)&&e.unref(f)(...n))},[e.createVNode(No)],8,zo)])],64)):e.createCommentVNode("",!0),e.unref(i)!==""&&e.unref(i)==="range"?(e.openBlock(),e.createElementBlock("div",Po,[e.createElementVNode("input",{type:"date",max:e.unref(p)[1],locale:"uk-UA",value:e.unref(p)[0],onInput:s[9]||(s[9]=n=>b(n.target.value)),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:d.disabled},null,40,Fo),e.createElementVNode("input",{type:"date",min:e.unref(p)[0],locale:"uk-UA",value:e.unref(p)[1],onInput:s[10]||(s[10]=n=>k(n.target.value)),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:d.disabled},null,40,jo)])):e.createCommentVNode("",!0)]),(d.cleanable,e.createCommentVNode("",!0))],64))}}),To={class:"flex flex-wrap items-center gap-2"},Ro=["disabled","onClick"],Zo={key:0,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},Oo=e.defineComponent({__name:"button-field",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=l,{innerValue:r,isSelected:g,selectItem:i,clear:p,labelKey:w,valueKey:f,allOptions:h}=Me({...a,modelValue:a.modelValue??a.default??""},t),u=e.computed(()=>r.value!==void 0&&!(typeof r.value=="string"&&r.value==="")),x=e.computed(()=>u.value?1:0);function b(d){return g(d)?["bg-blue-600 text-white"].filter(s=>typeof s=="string"&&s.trim().length>0).join(" "):["text-gray-700 hover:bg-gray-200 bg-gray-50 "].filter(s=>typeof s=="string"&&s.trim().length>0).join(" ")}function k(d){a.disabled||i(d)}return o({clear:p}),e.watch(()=>a.modelValue,d=>{d===void 0&&(r.value=void 0)}),(d,s)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",To,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(h),n=>(e.openBlock(),e.createElementBlock("button",{key:n[e.unref(f)],type:"button",class:e.normalizeClass(["px-3 py-2 text-sm font-medium rounded-md transition-colors",b(n)]),disabled:d.disabled,onClick:m=>k(n)},e.toDisplayString(n[e.unref(w)]),11,Ro))),128))]),d.cleanable&&d.layout==="popover"?(e.openBlock(),e.createElementBlock("div",Zo,[e.createElementVNode("span",null,e.toDisplayString(x.value)+" з "+e.toDisplayString(e.unref(h).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:s[0]||(s[0]=(...n)=>e.unref(p)&&e.unref(p)(...n))}," Очистити ",512),[[e.vShow,u.value]])])):e.createCommentVNode("",!0)],64))}}),qe={radio:fl,checkbox:Ke,check:Ke,text:Sl,range:Al,date:ql,select:ro,tag:mo,button:Oo,"date:inline":Ao};function Pe(c,o){let l;switch(c.toLowerCase()){case"autocomplete":l="select";break;case"check":l="checkbox";break;default:l=c==null?void 0:c.toString().toLowerCase()}return l==="date"&&o&&o==="inline"&&(l="date:inline"),{component:qe[l]||qe.text,type:l}}const Io={style:{display:"inline-flex",margin:"0px",width:"100%"}},Ko={class:"relative w-full mb-2 p-4 bg-white rounded-lg shadow-sm"},Uo={class:"block mb-3 text-sm font-medium text-gray-800 dark:text-neutral-200"},vo={class:"flex items-center"},Ho={class:"text-sm font-medium max-w-[80%] text-gray-800 flex items-center gap-x-1"},Wo={class:"filter-layout__body"},Go=e.defineComponent({__name:"vertical-layout",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=l,r=e.ref(),g=e.computed(()=>Pe(a.type,a.layout)),i=e.computed({get:()=>a.modelValue,set:h=>t("update:modelValue",h)});function p(h){t("clear",h)}function w(h,u){t("change",{name:h,value:u}),a.modelValue!==void 0&&t("update:modelValue",u)}function f(){t("clear",a.name)}return e.watch(()=>a.default,h=>{i.value=h}),e.watch(()=>a.modelValue,h=>{i.value=h}),o({filterRef:r}),(h,u)=>{var x,b,k;return e.openBlock(),e.createElementBlock("div",Io,[e.createElementVNode("div",Ko,[e.createElementVNode("div",Uo,[e.createElementVNode("div",vo,[e.createElementVNode("span",Ho,e.toDisplayString(h.label),1)]),typeof i.value=="string"&&i.value.trim()!==""||Array.isArray(i.value)&&i.value.length>0&&i.value.some(d=>d!==void 0)||i.value===null?(e.openBlock(),e.createBlock(Kt,{key:0,onClick:f})):e.createCommentVNode("",!0)]),e.createElementVNode("div",Wo,[((x=g.value)==null?void 0:x.type)!=="select"?(e.openBlock(),e.createBlock(e.resolveDynamicComponent((b=g.value)==null?void 0:b.component),e.mergeProps({key:0},a,{type:(k=g.value)==null?void 0:k.type,class:a.itemClass,onChange:u[0]||(u[0]=d=>w(d.name,d.value)),onClear:u[1]||(u[1]=d=>p(d)),ref_key:"filterRef",ref:r}),null,16,["type","class"])):(e.openBlock(),e.createBlock(ze,{key:1,"current-value":i.value,label:h.label,mode:h.mode,onClear:f,fieldRef:r.value,width:void 0,disabled:h.disabled,layout:"vertical"},{default:e.withCtx(()=>{var d,s;return[(e.openBlock(),e.createBlock(e.resolveDynamicComponent((d=g.value)==null?void 0:d.component),e.mergeProps({ref_key:"filterRef",ref:r},a,{type:(s=g.value)==null?void 0:s.type,class:a.itemClass,onChange:u[2]||(u[2]=n=>w(n.name,n.value)),onClear:u[3]||(u[3]=n=>p(n))}),null,16,["type","class"]))]}),_:1},8,["current-value","label","mode","fieldRef","disabled"]))])])])}}}),Ye=e.defineComponent({__name:"inline-layout",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=l,r=e.ref(),g=e.computed(()=>Pe(a.type,a.layout)),i=e.computed({get:()=>a.modelValue,set:f=>t("update:modelValue",f)});function p(f=a.name){t("clear",f)}function w(f,h){t("change",{name:f,value:h}),a.modelValue!==void 0&&t("update:modelValue",h)}return e.watch(()=>a.default,f=>{i.value=f}),e.watch(()=>a.modelValue,f=>{i.value=f}),o({filterRef:r}),(f,h)=>{var u,x;return["text","date","button"].includes(f.type.toLocaleLowerCase())?(e.openBlock(),e.createBlock(e.resolveDynamicComponent((u=g.value)==null?void 0:u.component),e.mergeProps({key:0},a,{type:(x=g.value)==null?void 0:x.type,class:f.itemClass,onChange:h[0]||(h[0]=b=>w(b.name,b.value)),onClear:h[1]||(h[1]=b=>p(b)),disabled:f.disabled,modelValue:i.value,"onUpdate:modelValue":h[2]||(h[2]=b=>i.value=b)}),null,16,["type","class","disabled","modelValue"])):(e.openBlock(),e.createBlock(ze,{key:1,"current-value":i.value,label:f.label,mode:f.mode,onClear:p,fieldRef:r.value,width:a.width,disabled:f.disabled,layout:"inline"},{default:e.withCtx(()=>{var b,k;return[(e.openBlock(),e.createBlock(e.resolveDynamicComponent((b=g.value)==null?void 0:b.component),e.mergeProps({ref_key:"filterRef",ref:r},a,{modelValue:i.value,"onUpdate:modelValue":h[3]||(h[3]=d=>i.value=d),type:(k=g.value)==null?void 0:k.type,class:a.itemClass,onChange:h[4]||(h[4]=d=>w(d.name,d.value)),onClear:h[5]||(h[5]=d=>p(d))}),null,16,["modelValue","type","class"]))]}),_:1},8,["current-value","label","mode","fieldRef","width","disabled"]))}}}),qo=e.defineComponent({__name:"popover-layout",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=l,r=e.ref(),g=e.computed(()=>Pe(a.type,a.layout)),i=e.computed({get:()=>a.modelValue,set:f=>t("update:modelValue",f)});function p(f){t("clear",f)}function w(f,h){t("change",{name:f,value:h}),a.modelValue!==void 0&&t("update:modelValue",h)}return e.watch(()=>a.default,f=>{i.value=f}),e.watch(()=>a.modelValue,f=>{i.value=f}),e.watch(()=>a,f=>{i.value=f}),o({filterRef:r}),(f,h)=>{var u,x;return e.openBlock(),e.createBlock(e.resolveDynamicComponent((u=g.value)==null?void 0:u.component),e.mergeProps(a,{type:(x=g.value)==null?void 0:x.type,class:a.itemClass,modelValue:i.value,"onUpdate:modelValue":h[0]||(h[0]=b=>i.value=b),onChange:h[1]||(h[1]=b=>w(b.name,b.value)),onClear:h[2]||(h[2]=b=>p(b)),ref_key:"filterRef",ref:r}),null,16,["type","class","modelValue"])}}}),ae=e.defineComponent({__name:"filter-field",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean,default:!0},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{default:"name"},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(c,{expose:o,emit:l}){const a=c,t=l,r=e.ref(),g=e.computed({get:()=>a.modelValue,set:f=>t("update:modelValue",f)});function i(f){t("clear",f)}function p(f,h){t("change",{name:f,value:h}),a.modelValue!==void 0&&t("update:modelValue",h)}e.watch(()=>a.default,f=>{g.value=f}),e.watch(()=>a.modelValue,f=>{g.value=f}),o({filterRef:r});function w(){switch(a.layout){case"inline":return Ye;case"vertical":return Go;case"popover":return qo;default:return Ye}}return(f,h)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(w()),e.mergeProps(a,{onChange:h[0]||(h[0]=u=>p(u.name,u.value)),onClear:h[1]||(h[1]=u=>i(u)),modelValue:g.value,"onUpdate:modelValue":h[2]||(h[2]=u=>g.value=u)}),null,16,["modelValue"]))}});function Ee(c,o){const{slots:l}=c,a=s=>s?JSON.parse(JSON.stringify(e.toRaw(s))):{},t=e.ref(a(c.value));e.watch(()=>c.value,s=>{t.value=a(s)},{deep:!0,immediate:!0});const r=e.computed(()=>{var s;return(e.toRaw((s=l==null?void 0:l.default)==null?void 0:s.call(l))??[]).flatMap(n=>Array.isArray(n.children)?n.children:[n])});function g(s){delete t.value[s],o("clear",{data:e.toRaw(t.value),name:s})}function i(s,n){n===void 0?g(s):t.value={...t.value,[s]:n},o("change",{data:e.toRaw(t.value),name:s,value:n})}const p=e.computed(()=>r.value.map(s=>{var m,y,z;const n=(m=s.props)==null?void 0:m.name;return e.cloneVNode(s,{...s.props,layout:c.view,showClean:!0,modelValue:t.value[n],"onUpdate:modelValue":L=>{i(n,L)},onClear:()=>g(n),class:[c.itemClass,(y=s.props)==null?void 0:y.class],itemClass:[c.itemClass,(z=s.props)==null?void 0:z.itemClass].filter(L=>typeof L=="string"&&L.trim().length>0).join(" ")||void 0})})),w=e.computed(()=>new Map(p.value.map(s=>{var m;const n=(m=s.props)==null?void 0:m.name;return n?[n,s]:null}).filter(s=>s!==null)));function f(s=!1){t.value={},s||o("clearAll",{data:e.toRaw(t.value),name:"ALL"})}const h=e.ref(""),u=e.computed(()=>{var s;return(s=c.schema)!=null&&s.value?Object.entries(t.value).filter(([n,m])=>c.schema&&!(n in c.schema.value)?!1:Array.isArray(m)?m.some(y=>y!==""&&y!==void 0):m!==""&&m!==void 0).length:0}),x=e.ref();e.watch(h,async()=>{var s,n;await e.nextTick(),(n=(s=x==null?void 0:x.value)==null?void 0:s.filterRef)!=null&&n.inputTextRef&&x.value.filterRef.inputTextRef.focus()});const b=e.computed(()=>{var s,n;return(s=c.schema)!=null&&s.value?Object.fromEntries(Object.entries((n=c.schema)==null?void 0:n.value).slice(0,c.limit)):{}}),k=e.computed(()=>{var n;if(p.value.length===0)return[];let s=0;if((n=c.schema)!=null&&n.value){const m=Object.entries(c.schema.value).length;c.limit&&m<c.limit?s=c.limit-m:s=0}return p.value.slice(0,s)}),d=e.computed(()=>p.value.length===0?[]:c.view!=="inline"?p.value:p.value.slice(k.value.length));return{activeFilter:t,activeFilterCount:u,onFilterChange:i,clearFilter:g,clearAllFilters:f,limitedSchema:b,filtersSlot:p,limitedFiltersSlot:k,popoverFiltersSlot:d,vnodeMap:w,selectedFilter:h,filterRef:x}}const Yo=e.defineComponent({__name:"popover",emits:["open","close"],setup(c,{emit:o}){const l=e.ref(!1),a=e.ref(null),t=e.ref(null),r=e.ref(null),g=e.ref({top:"0px",left:"0px",position:"absolute"});function i(){l.value=!l.value}function p(){const x=r.value,b=a.value;if(!x||!b)return;const k=x.getBoundingClientRect(),d=b.offsetWidth,s=window.innerWidth-k.left;let n=k.left+window.scrollX;d>s&&(n=window.innerWidth-d-18,n<18&&(n=18)),g.value={position:"absolute",top:`${k.bottom+window.scrollY+18}px`,left:`${n}px`}}const w=e.computed(()=>Object.entries(g.value).map(x=>x.join(":")).join(";"));function f(x){var k,d;const b=x.target;!((k=r.value)!=null&&k.contains(x.target))&&!((d=a.value)!=null&&d.contains(x.target))&&!b.closest("[data-inside-popover]")&&(l.value=!1)}const h=e.ref(!1);e.onMounted(()=>{h.value=!0}),e.onMounted(()=>{var x,b;r.value=((x=t.value)==null?void 0:x.querySelector("[data-popover-trigger]"))||null,(b=r.value)==null||b.addEventListener("click",i),document.addEventListener("click",f),window.addEventListener("resize",p),window.addEventListener("scroll",p,!0)}),e.onBeforeUnmount(()=>{var x;(x=r.value)==null||x.removeEventListener("click",i),document.removeEventListener("click",f),window.removeEventListener("resize",p),window.removeEventListener("scroll",p,!0)});const u=o;return e.watch(l,async x=>{x?(u("open"),await e.nextTick(),p()):u("close")}),(x,b)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"wrapperRef",ref:t},[e.renderSlot(x.$slots,"trigger"),h.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popoverRef",ref:a,class:"absolute z-[50] w-[600px] rounded-md border bg-white shadow-md",style:e.normalizeStyle(w.value)},[e.renderSlot(x.$slots,"default")],4),[[e.vShow,l.value]])])):e.createCommentVNode("",!0)],512))}}),Qo={},Xo={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 h-4 w-4"};function Jo(c,o){return e.openBlock(),e.createElementBlock("svg",Xo,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 Qe=ie(Qo,[["render",Jo]]),en={class:"flex items-center gap-2 overflow-hidden"},tn={key:0,class:"inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-[4px] bg-blue-500 px-1 text-[11px] font-semibold text-white"},ln={class:"flex max-h-[400px]"},on={class:"w-64 border-r border-gray-200 overflow-y-auto"},nn={class:"p-4 border-b"},rn={class:"text-sm text-gray-600"},an={class:"p-2"},sn=["onClick"],cn={class:"flex items-center gap-2"},dn={class:"text-sm font-medium"},pn={key:0,class:"inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-[4px] bg-blue-100 px-1 text-[11px] font-semibold text-blue-600"},mn=["onClick"],fn={class:"flex items-center gap-2"},un={class:"text-sm font-medium"},gn={key:0,class:"inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-[4px] bg-blue-100 px-1 text-[11px] font-semibold text-blue-600"},hn={key:0,class:"p-2 border-t"},yn={class:"flex-1 min-h-[300px] overflow-y-auto"},xn={key:0,class:"flex items-center justify-center h-full text-gray-500"},bn={class:"text-sm"},Xe=e.defineComponent({__name:"popover-filter-layout",props:{badgeCount:{},schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{}},emits:["change","clear","clearAll"],setup(c,{expose:o,emit:l}){const a=ce(),t=c,r=We(t.mode),g=e.useSlots(),i=l,p=e.ref({}),w=e.computed(()=>p!=null&&p.value?t.view!=="inline"?p==null?void 0:p.value:Object.fromEntries(Object.entries(p==null?void 0:p.value).slice(t.limit)):{}),{activeFilter:f,activeFilterCount:h,onFilterChange:u,clearFilter:x,clearAllFilters:b,popoverFiltersSlot:k,selectedFilter:d,filterRef:s}=Ee({...t,schema:p,slots:g},i),n=e.computed(()=>t.badgeCount??h.value);function m(L){return Array.isArray(L)?L.filter(E=>E!=null&&E!=="").length:L&&typeof L=="object"?Object.values(L).filter(E=>E!=null&&E!=="").length:L===null||L!==void 0&&L!==""?1:0}function y(L){return f.value?m(f.value[L]):0}function z(){if(w.value){const[L]=Object.keys(w.value);d.value=L}else k.value.length>0?d.value=k.value[0].props.name:d.value=""}return e.watch(()=>t.schema,L=>{p.value=L??{}},{deep:!0,immediate:!0}),o({clearFilter:x,clearAllFilters:b}),(L,E)=>(e.openBlock(),e.createBlock(Yo,{onOpen:z,onClose:E[5]||(E[5]=S=>d.value="")},{trigger:e.withCtx(()=>[e.createElementVNode("button",{"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([L.itemClass,e.unref(r),"flex items-center justify-between gap-2",n.value>0?"border border-blue-400 bg-blue-50 text-blue-600 hover:border-blue-500":"text-neutral-700 hover:border-neutral-400"]),type:"button"},[e.createElementVNode("span",en,[e.createVNode(Qe,{class:"h-4 w-4"}),E[6]||(E[6]=e.createElementVNode("span",{class:"text-sm font-medium"},"Фільтр",-1))]),n.value>0?(e.openBlock(),e.createElementBlock("span",tn,e.toDisplayString(n.value),1)):e.createCommentVNode("",!0)],2)]),default:e.withCtx(()=>[e.createElementVNode("div",ln,[e.createElementVNode("div",on,[e.createElementVNode("div",nn,[e.createElementVNode("p",rn,e.toDisplayString(e.unref(a)("filter.selectFieldHelp")),1)]),e.createElementVNode("div",an,[L.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(w.value),([S,D])=>(e.openBlock(),e.createElementBlock("button",{key:S,onClick:()=>{d.value=S},class:e.normalizeClass(["flex w-full items-center justify-between px-3 py-2 text-left transition-colors hover:bg-gray-50",e.unref(d)===S?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",cn,[e.createElementVNode("span",dn,e.toDisplayString(D.label),1)]),y(S)>0?(e.openBlock(),e.createElementBlock("div",pn,e.toDisplayString(y(S)),1)):e.createCommentVNode("",!0)],10,sn))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(k),(S,D)=>(e.openBlock(),e.createElementBlock("button",{key:"slot-"+D,onClick:_=>d.value=S.props.name,class:e.normalizeClass(["flex items-center justify-between px-3 py-2 text-left transition-colors hover:bg-gray-50",e.unref(d)===S.props.name?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",fn,[e.createElementVNode("span",un,e.toDisplayString(S.props.label),1)]),y(S.props.name)>0?(e.openBlock(),e.createElementBlock("div",gn,e.toDisplayString(y(S.props.name)),1)):e.createCommentVNode("",!0)],10,mn))),128))]),e.unref(h)>0?(e.openBlock(),e.createElementBlock("div",hn,[e.createElementVNode("button",{class:e.normalizeClass([L.itemClass,"w-full px-3 py-2 text-left text-sm text-gray-600 hover:bg-gray-50 transition-colors"]),onClick:E[0]||(E[0]=S=>e.unref(b)()),"data-inside-popover":""}," Очистити всі ",2)])):e.createCommentVNode("",!0)]),e.createElementVNode("div",yn,[e.unref(d)===""?(e.openBlock(),e.createElementBlock("div",xn,[e.createElementVNode("p",bn,e.toDisplayString(e.unref(a)("filter.selectFieldHelp")),1)])):e.createCommentVNode("",!0),e.unref(d)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[w.value?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(w.value),([S,D])=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.unref(d)===S?(e.openBlock(),e.createBlock(ae,e.mergeProps({key:S,layout:"popover",ref_for:!0,ref_key:"filterRef",ref:s},{ref_for:!0},D,{class:[L.itemClass,D==null?void 0:D.class],"item-class":[L.itemClass,D==null?void 0:D.itemClass].filter(Boolean).join(" ")||void 0,onChange:E[1]||(E[1]=_=>e.unref(u)(_.name,_.value)),onClear:E[2]||(E[2]=_=>{e.unref(x)(_),e.unref(u)(_,void 0)}),modelValue:e.unref(f)[S],"onUpdate:modelValue":_=>e.unref(f)[S]=_,cleanable:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])):e.createCommentVNode("",!0)],64))),256)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(k),(S,D)=>{var _,M;return e.openBlock(),e.createElementBlock(e.Fragment,{key:"slot-"+D},[e.unref(d)===S.props.name?(e.openBlock(),e.createBlock(ae,e.mergeProps({key:0,layout:"popover"},{ref_for:!0},S.props,{ref_for:!0,ref_key:"filterRef",ref:s,class:[L.itemClass,(_=S.props)==null?void 0:_.class],"item-class":[L.itemClass,(M=S.props)==null?void 0:M.itemClass].filter(Boolean).join(" ")||void 0,onChange:E[3]||(E[3]=Z=>e.unref(u)(Z.name,Z.value)),onClear:E[4]||(E[4]=Z=>{e.unref(x)(Z),e.unref(u)(Z,void 0)}),modelValue:e.unref(f)[S.props.name],"onUpdate:modelValue":Z=>e.unref(f)[S.props.name]=Z,cleanable:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])):e.createCommentVNode("",!0)],64)}),128))],64)):e.createCommentVNode("",!0)])])]),_:1}))}}),kn={class:"flex gap-1 items-center flex-wrap"},Je=e.defineComponent({__name:"inline-filter-layout",props:{schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{}},emits:["change","clear","clearAll"],setup(c,{expose:o,emit:l}){const a=ce(),t=c,r=l,g=e.useSlots(),i=e.ref({}),p=e.computed(()=>Object.keys(t.schema).length>t.limit),{activeFilter:w,activeFilterCount:f,onFilterChange:h,clearFilter:u,clearAllFilters:x,limitedSchema:b,filtersSlot:k,limitedFiltersSlot:d}=Ee({...t,schema:i,slots:g},r);function s(E){return Array.isArray(E)?E.some(S=>S!==""&&S!==void 0&&S!==null):E===null?!0:E&&typeof E=="object"?Object.values(E).some(S=>S!==""&&S!==void 0&&S!==null):E!==""&&E!==void 0}const n=e.computed(()=>{const E=Object.keys(b.value??{}),S=d.value.map(D=>{var _;return(_=D.props)==null?void 0:_.name}).filter(D=>typeof D=="string");return new Set([...E,...S])}),m=e.computed(()=>Object.entries(w.value??{}).filter(([E,S])=>n.value.has(E)&&s(S)).length),y=e.computed(()=>{const E=f.value??0,S=m.value??0;return Math.max(E-S,0)}),z=e.ref();function L(){z.value&&z.value.clearAllFilters(!0),x()}return e.watch(()=>t.schema,E=>{i.value=E},{deep:!0,immediate:!0}),o({clearFilter:u,clearAllFilters:x}),(E,S)=>(e.openBlock(),e.createElementBlock("div",kn,[E.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(e.unref(b)),([D,_])=>(e.openBlock(),e.createBlock(ae,e.mergeProps({key:D,mode:E.mode,width:E.width?E.width:_==null?void 0:_.width},{ref_for:!0},_,{class:[E.itemClass,_==null?void 0:_.class],"item-class":[E.itemClass,_==null?void 0:_.itemClass].filter(Boolean).join(" ")||void 0,onChange:S[0]||(S[0]=M=>e.unref(h)(M.name,M.value)),onClear:e.unref(u),layout:"inline",cleanable:!0,modelValue:e.unref(w)[D],"onUpdate:modelValue":M=>e.unref(w)[D]=M}),null,16,["mode","width","class","item-class","onClear","modelValue","onUpdate:modelValue"]))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(d),(D,_)=>{var M,Z;return e.openBlock(),e.createBlock(ae,e.mergeProps({key:"slot-"+_,layout:"inline"},{ref_for:!0},D.props,{class:[E.itemClass,(M=D.props)==null?void 0:M.class],"item-class":[E.itemClass,(Z=D.props)==null?void 0:Z.itemClass].filter(Boolean).join(" ")||void 0,onChange:S[1]||(S[1]=A=>e.unref(h)(A.name,A.value)),onClear:S[2]||(S[2]=A=>{e.unref(u)(A),e.unref(h)(A,void 0)}),cleanable:!0,modelValue:e.unref(w)[D.props.name],"onUpdate:modelValue":A=>e.unref(w)[D.props.name]=A}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])}),128)),p.value?(e.openBlock(),e.createBlock(Xe,e.mergeProps({key:1},t,{schema:E.schema,limit:E.limit,onChange:S[3]||(S[3]=D=>e.unref(h)(D.name,D.value)),onClearAll:S[4]||(S[4]=D=>e.unref(x)()),onClear:S[5]||(S[5]=D=>e.unref(u)(D.name)),mode:E.mode,ref_key:"popoverRef",ref:z,cleanable:!0,"badge-count":y.value}),{default:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(k),(D,_)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(D),e.mergeProps({key:"slot-"+_,layout:"popover"},{ref_for:!0},D.props,{cleanable:!0}),null,16))),128))]),_:1},16,["schema","limit","mode","badge-count"])):e.createCommentVNode("",!0),e.unref(f)>0?(e.openBlock(),e.createElementBlock("button",{key:2,onClick:L,class:e.normalizeClass([E.itemClass,"relative py-2 px-3 inline-flex justify-center items-center gap-x-2 text-sm font-medium rounded-md bg-gray-50 border text-gray-800 hover:bg-gray-200 focus:bg-gray-200"])},e.toDisplayString(e.unref(a)("filter.clear")),3)):e.createCommentVNode("",!0)]))}}),wn={key:0,class:"p-2 overflow-y-auto overflow-hidden [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 dark:bg-neutral-800 max-h-[calc(100%-142px)] h-full bg-gray-100"},Vn={class:"flex items-center vst-filters vsTailwind flex-col w-full"},Cn=e.defineComponent({__name:"vertical-filter-layout",props:{schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{}},emits:["change","clear","clearAll"],setup(c,{expose:o,emit:l}){const a=c,t=l,r=e.useSlots(),{activeFilter:g,activeFilterCount:i,onFilterChange:p,clearFilter:w,clearAllFilters:f,filtersSlot:h}=Ee({...a,slots:r},t);return o({clearFilter:w,clearAllFilters:f}),(u,x)=>u.view==="vertical"?(e.openBlock(),e.createElementBlock("div",wn,[e.createElementVNode("div",Vn,[e.unref(i)>0?(e.openBlock(),e.createElementBlock("button",{key:0,onClick:x[0]||(x[0]=b=>e.unref(f)()),"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([u.itemClass,"w-full ring-offset-background focus-visible:outline-hidden focus-visible:ring-ring inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:ring-2 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 border h-10 px-4 py-2 gap-2 m-2 bg-white text-gray-800 hover:bg-gray-200 focus:bg-gray-200"]),type:"button"}," Очистити ",2)):e.createCommentVNode("",!0),u.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(Object.entries(u.schema),([b,k])=>(e.openBlock(),e.createBlock(ae,e.mergeProps({layout:"vertical"},{ref_for:!0},k,{class:[u.itemClass,k==null?void 0:k.class],"item-class":[u.itemClass,k==null?void 0:k.itemClass].filter(Boolean).join(" ")||void 0,onChange:x[1]||(x[1]=d=>e.unref(p)(d.name,d.value)),onClear:x[2]||(x[2]=d=>{e.unref(w)(d),e.unref(p)(d,void 0)}),modelValue:e.unref(g)[b],"onUpdate:modelValue":d=>e.unref(g)[b]=d,showClean:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),256)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(h),(b,k)=>{var d,s;return e.openBlock(),e.createBlock(ae,e.mergeProps({key:"slot-"+k,layout:"vertical"},{ref_for:!0},b.props,{class:[u.itemClass,(d=b.props)==null?void 0:d.class],"item-class":[u.itemClass,(s=b.props)==null?void 0:s.itemClass].filter(Boolean).join(" ")||void 0,onChange:x[3]||(x[3]=n=>e.unref(p)(n.name,n.value)),onClear:x[4]||(x[4]=n=>{e.unref(w)(n),e.unref(p)(n,void 0)}),modelValue:e.unref(g)[b.props.name],"onUpdate:modelValue":n=>e.unref(g)[b.props.name]=n,showClean:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])}),128))])])):e.createCommentVNode("",!0)}}),Bn=["onKeydown"],En=["disabled"],Nn={key:0,class:"ml-2 inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-full bg-blue-500 px-1.5 text-[11px] font-semibold text-white"},_n={class:"rounded-2xl border border-slate-300/35 bg-white/95 p-4 shadow-2xl backdrop-blur-sm"},Sn={class:"mb-3 flex items-center justify-between"},Mn={class:"text-[15px] font-semibold text-slate-800"},Ln={"aria-hidden":"true"},Dn={class:"flex max-h-80 flex-col gap-1 overflow-y-auto"},$n={key:0,class:"mt-3 flex justify-end"},zn=e.defineComponent({__name:"popover-inline-filter-layout",props:{schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:10},width:{default:220},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{}},emits:["change","clear","clearAll"],setup(c,{emit:o}){const l=ce(),a=c,t=o,r=e.ref({}),g=e.useSlots(),{activeFilter:i,activeFilterCount:p,onFilterChange:w,clearFilter:f,clearAllFilters:h,filtersSlot:u}=Ee({...a,schema:r.value,slots:g},t),x=e.ref(null),b=e.ref(null),k=e.reactive({open:!1,top:0,left:0}),d=e.computed(()=>k.open),s=e.computed(()=>!!a.disabled),n=e.computed(()=>r.value||{}),m=e.computed(()=>a.title??"Фільтр"),y=e.computed(()=>!!g.trigger),z=e.computed(()=>["inline-flex h-9 items-center justify-center gap-2 rounded-lg border border-transparent bg-slate-200/70 px-3 text-sm font-medium text-slate-700 transition-colors hover:bg-blue-100 hover:text-blue-600 focus:outline-none focus:ring-2 focus:ring-blue-200 disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:bg-slate-200/70 disabled:hover:text-slate-700",s.value?"cursor-not-allowed opacity-60":"cursor-pointer"]),L=e.computed(()=>k.open?{position:"absolute",top:`${k.top}px`,left:`${k.left}px`,transform:"translateX(-50%)",zIndex:1e3}:{display:"none"});function E(){k.open=!1}function S(){if(!x.value)return;const A=x.value.getBoundingClientRect();k.top=A.bottom+window.scrollY+8,k.left=A.left+A.width/2+window.scrollX}function D(){k.open=!k.open,k.open&&e.nextTick(S)}function _(){s.value||D()}function M(){k.open&&S()}function Z(){h()}return e.onMounted(()=>{window.addEventListener("resize",M),window.addEventListener("scroll",M,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",M),window.removeEventListener("scroll",M,!0)}),e.watch(()=>a.schema,A=>{if(!A){r.value={};return}if(Array.isArray(A)){const N=A.filter(F=>F&&(F.name||F.id)).map(F=>{const T=F.name||F.id;return[T,{...F,name:T}]});r.value=Object.fromEntries(N);return}r.value=A},{deep:!0,immediate:!0}),e.watch(()=>a.disabled,A=>{A&&E()}),(A,N)=>(e.openBlock(),e.createElementBlock("div",{class:"relative inline-flex",ref_key:"anchor",ref:x},[y.value?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["inline-flex",s.value?"cursor-not-allowed opacity-60 pointer-events-none":"cursor-pointer"]),role:"button",tabindex:"0","data-popover-trigger":"",onClick:e.withModifiers(_,["prevent","stop"]),onKeydown:[e.withKeys(e.withModifiers(_,["prevent","stop"]),["enter"]),e.withKeys(e.withModifiers(_,["prevent","stop"]),["space"])]},[e.renderSlot(A.$slots,"trigger",{toggle:_,open:d.value,disabled:s.value,activeCount:e.unref(p)})],42,Bn)):(e.openBlock(),e.createElementBlock("button",{key:1,class:e.normalizeClass(z.value),type:"button",disabled:s.value,onClick:e.withModifiers(_,["prevent","stop"]),"data-popover-trigger":""},[e.createVNode(Qe,{class:"h-4 w-4"}),e.unref(p)>0?(e.openBlock(),e.createElementBlock("div",Nn,e.toDisplayString(e.unref(p)),1)):e.createCommentVNode("",!0)],10,En)),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[d.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["absolute",typeof A.width=="number"?`min-w-[${A.width+32+(Object.keys(n.value).length>7?20:0)}px]`:"min-w-[268px] "]),style:e.normalizeStyle(L.value),ref_key:"panel",ref:b,onClick:N[4]||(N[4]=e.withModifiers(()=>{},["stop"]))},[e.createElementVNode("div",_n,[e.createElementVNode("div",Sn,[e.createElementVNode("h3",Mn,e.toDisplayString(m.value),1),e.createElementVNode("button",{type:"button",class:"inline-flex h-6 w-6 items-center justify-center rounded-full border-0 bg-slate-300/40 text-slate-600 transition-colors hover:bg-blue-200/60 hover:text-blue-600 focus:outline-none focus:ring-2 focus:ring-blue-200",onClick:E},[e.createElementVNode("span",Ln,[e.createVNode($e,{class:"h-4 w-4"})]),N[5]||(N[5]=e.createElementVNode("span",{class:"sr-only"},"Закрити",-1))])]),e.createElementVNode("div",Dn,[Object.keys(n.value).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(n.value),([F,T])=>(e.openBlock(),e.createBlock(ae,e.mergeProps({key:F},{ref_for:!0},{...T,layout:"inline"},{width:A.width?A.width:T==null?void 0:T.width,class:[A.itemClass,T==null?void 0:T.class],"item-class":[A.itemClass,T==null?void 0:T.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(i)[F],"onUpdate:modelValue":I=>e.unref(i)[F]=I,onChange:N[0]||(N[0]=I=>e.unref(w)(I.name,I.value)),onClear:N[1]||(N[1]=I=>{e.unref(f)(I),e.unref(w)(I,void 0)})}),null,16,["width","class","item-class","modelValue","onUpdate:modelValue"]))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(u),(F,T)=>{var I,K;return e.openBlock(),e.createBlock(ae,e.mergeProps({key:"slot-"+T,ref_for:!0},{...F.props,layout:"inline"},{class:[A.itemClass,(I=F.props)==null?void 0:I.class],"item-class":[A.itemClass,(K=F.props)==null?void 0:K.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(i)[F.props.name],"onUpdate:modelValue":J=>e.unref(i)[F.props.name]=J,onChange:N[2]||(N[2]=J=>e.unref(w)(J.name,J.value)),onClear:N[3]||(N[3]=J=>{e.unref(f)(J),e.unref(w)(J,void 0)})}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])}),128))]),e.unref(p)>0?(e.openBlock(),e.createElementBlock("div",$n,[e.createElementVNode("button",{type:"button",class:e.normalizeClass([A.itemClass,"text-sm font-semibold text-blue-600 transition-colors hover:text-blue-700 focus:outline-none"]),onClick:Z},e.toDisplayString(e.unref(l)("filter.clear")),3)])):e.createCommentVNode("",!0)])],6)):e.createCommentVNode("",!0)]))],512))}}),Ne=e.defineComponent({__name:"filter",props:{schema:{},view:{default:"inline"},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{}},emits:["change","clear","clearAll"],setup(c,{expose:o,emit:l}){const a=c,t=e.ref(p(a.value??{}));e.watch(()=>a.value,async d=>{var s,n;t.value=p(d??{}),(!d||Object.keys(d).length===0)&&(await e.nextTick(),(n=(s=g.value)==null?void 0:s.clearAllFilters)==null||n.call(s,!0))},{deep:!0,immediate:!0});const r=l,g=e.ref(),i=e.useSlots();function p(d){if(Array.isArray(d))return d.map(s=>p(s));if(d!==null&&typeof d=="object"){const s=e.toRaw(d),n={};for(const m in s)n[m]=p(s[m]);return n}return d}function w(d,s){s!==void 0?t.value={...t.value,[d]:s}:delete t.value[d],r("change",{data:p(t.value),name:d,value:p(s)})}function f(d){delete t.value[d],r("clear",{data:p(t.value),name:d}),r("change",{data:p(t.value),name:d,value:null})}function h(){t.value={},r("clear",{data:p(t.value),name:"ALL"}),r("change",{data:p(t.value),name:"ALL",value:null})}const u=e.ref({});function x(){switch(a.view){case"inline":return Je;case"vertical":return Cn;case"popover":return Xe;case"popover-inline":return zn;default:return Je}}e.watch(()=>a.schema,d=>{if(!d){u.value={};return}if(Array.isArray(d)&&!d.length){u.value={};return}Array.isArray(d)?u.value=d.filter(s=>s.type).reduce((s,n)=>(Object.assign(n,{name:n.id||n.name,type:{datepicker:"date"}[n.type.toLowerCase()]||n.type.toLowerCase(),label:n.label||n.ua}),s[n.name]=n,n.data&&!n.api&&!n.options&&Object.assign(n,{api:`/api/suggest/${n.data}`}),s),{}):(Object.entries(d).forEach(([s,n])=>{Object.assign(n,{name:s||n.name||n.id,type:n.type.toLowerCase()})}),u.value={...d})},{immediate:!0,deep:!0});function b(d){g.value.clearFilter(d),f(d)}function k(){g.value.clearAllFilters(),h()}return e.watch(()=>t.value,d=>{if(a.history){const s=new URL(window.location.href),n=new URLSearchParams(window.location.search);Object.keys(d).length>0?n.set("filter",Object.entries(d).filter(([,m])=>m).map(([m,y])=>`${m}=${y}`).join("|")):n.delete("filter"),s.search=decodeURI(n.toString()),window.history.pushState({},"",s)}}),o({clearAllFilters:k,clearFilter:b}),(d,s)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(x()),e.mergeProps(a,{schema:u.value,onChange:s[0]||(s[0]=n=>w(n.name,n.value)),onClear:s[1]||(s[1]=n=>f(n.name)),onClearAll:h,ref_key:"filterRef",ref:g}),e.createSlots({default:e.withCtx(()=>[e.renderSlot(d.$slots,"default")]),_:2},[e.unref(i).trigger?{name:"trigger",fn:e.withCtx(n=>[e.renderSlot(d.$slots,"trigger",e.normalizeProps(e.guardReactiveProps(n)))]),key:"0"}:void 0]),1040,["schema"]))}});Ne.install=function(c){c.component("Filter",Ne),c.component("FilterField",ae)};function Pn(c){const{page:o,id:l,filter:a,filterByView:t}=c,r=new URL(window.location.href),g=new URLSearchParams(window.location.search);o?g.set("page",o.toString()):g.delete("page"),l?g.set("id",l.toString()):g.delete("id"),a?g.set("filter",a):g.delete("filter"),typeof t=="boolean"?g.set("bbox",t?"1":"0"):g.delete("bbox"),r.search=decodeURI(g.toString()),window.history.pushState({},"",r)}const Fn={class:"flex items-center justify-between w-full gap-x-1"},jn={class:"flex items-center"},An=["disabled"],Tn={class:"flex items-center gap-x-1"},Rn=["onClick"],Zn=["disabled"],On={class:"flex justify-center items-center gap-x-5 ml-3"},In={class:"relative"},Kn={class:"hs-dropdown-menu z-50 bg-white shadow-md rounded-lg p-1 space-y-0.5 dark:bg-neutral-800 dark:border dark:border-neutral-700 right-0 dark:divide-neutral-700 absolute bottom-[100%]",role:"menu","aria-orientation":"vertical","aria-labelledby":"dropdown-button"},Un=["onClick"],vn={key:0,xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"4","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-check text-blue-600",width:"14",height:"14"},Fe=e.defineComponent({__name:"pagination",props:{total:{},currentPage:{},pageSize:{}},emits:["update:currentPage","update:pageSize","pageChange","pageSizeChange"],setup(c,{emit:o}){const l=c,a=o,t=e.ref(l.currentPage),r=e.ref(l.pageSize),g=e.ref(!1);e.watch(()=>l.pageSize,x=>{r.value=x});const i=e.computed(()=>Math.ceil(l.total/l.pageSize)),p=e.computed(()=>{const b=Math.floor(3.5);let k=t.value-b,d=t.value+b;k<1&&(d+=1-k,k=1),d>i.value&&(k-=d-i.value,d=i.value),k=Math.max(1,k);const s=[];for(let n=k;n<=d;n+=1)s.push(n);return s}),w=()=>{t.value>1&&h(t.value-1)},f=()=>{t.value<i.value&&h(t.value+1)},h=x=>{t.value=x,a("update:currentPage",x),a("pageChange",x)},u=(x=r.value)=>{r.value=x,g.value=!1,a("update:pageSize",r.value),a("update:currentPage",1),a("pageSizeChange",r.value)};return e.watch(()=>l.currentPage,x=>{t.value=x}),(x,b)=>(e.openBlock(),e.createElementBlock("nav",Fn,[e.createElementVNode("div",jn,[e.createElementVNode("button",{type:"button","aria-label":"Previous",onClick:w,disabled:t.value===1,class:"border-white last:rounded-e-lg text-base h-[38px] min-w-[38px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 border text-sm rounded-lg bg-white text-gray-800 hover:shadow-sm hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-50 dark:bg-neutral-700 dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-800 py-2"},[...b[1]||(b[1]=[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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down rotate-90",height:"16",width:"16"},[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"})],-1),e.createElementVNode("span",{"aria-hidden":"true",class:"sr-only"},"Previous",-1)])],8,An),e.createElementVNode("div",Tn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(p.value,k=>(e.openBlock(),e.createElementBlock("button",{type:"button",key:k,onClick:d=>h(k),class:e.normalizeClass(t.value===k?"flex justify-center items-center rounded-lg text-sm dark:text-neutral-300 py-2 px-3 focus:outline-none disabled:opacity-50 disabled:pointer-events-none bg-[#e5e7eb] dark:bg-[#242424] border border-gray-200 text-base h-[38px] min-w-[38px]":"flex justify-center items-center rounded-lg text-sm dark:text-neutral-400 hover:bg-gray-100 py-2 px-3 focus:outline-none focus:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none dark:hover:bg-neutral-800 dark:focus:bg-neutral-800 text-base h-[38px] min-w-[38px]")},e.toDisplayString(k),11,Rn))),128))]),e.createElementVNode("button",{type:"button","aria-label":"Next",onClick:f,disabled:t.value===i.value,class:"border-white last:rounded-e-lg text-base h-[38px] min-w-[38px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 border text-sm rounded-lg bg-white text-gray-800 hover:shadow-sm hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-50 dark:bg-neutral-700 dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-800 py-2"},[...b[2]||(b[2]=[e.createElementVNode("span",{"aria-hidden":"true",class:"sr-only"},"Next",-1),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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down -rotate-90",height:"16",width:"16"},[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"})],-1)])],8,Zn)]),e.createElementVNode("div",On,[e.createElementVNode("div",In,[e.withDirectives(e.createElementVNode("div",Kn,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList([10,20,30],k=>e.createElementVNode("button",{type:"button",key:k,onClick:d=>u(k),class:"w-full flex items-center gap-x-3.5 py-2 px-3 rounded-lg text-sm text-gray-800 hover:bg-gray-100 focus:outline-none focus:bg-gray-100 dark:text-neutral-400 dark:hover:bg-neutral-700 dark:hover:text-neutral-300 dark:focus:bg-neutral-700"},[e.createTextVNode(e.toDisplayString(k)+" ",1),r.value===k?(e.openBlock(),e.createElementBlock("svg",vn,[...b[3]||(b[3]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M5 12l5 5l10 -10"},null,-1)])])):e.createCommentVNode("",!0)],8,Un)),64))],512),[[e.vShow,g.value]]),e.createElementVNode("button",{type:"button",class:"py-3 px-3.5 inline-flex items-center gap-x-1 text-sm rounded-lg border border-gray-200 text-gray-800 shadow-sm hover:bg-gray-50 focus:outline-none focus:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-700 dark:focus:bg-neutral-700 text-base h-[38px] min-w-[38px]","aria-haspopup":"menu","aria-expanded":"false","aria-label":"Dropdown",onClick:b[0]||(b[0]=k=>g.value=!g.value)},[e.createTextVNode(e.toDisplayString(r.value)+" ",1),b[4]||(b[4]=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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down",height:"16",width:"16"},[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"})],-1))])])])]))}}),fe=(c,o)=>{const l=c.__vccOpts||c;for(const[a,t]of o)l[a]=t;return l},Hn={},Wn={class:"w-48 mx-auto mb-4",width:"178",height:"90",viewBox:"0 0 178 90",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function Gn(c,o){return e.openBlock(),e.createElementBlock("svg",Wn,[...o[0]||(o[0]=[e.createStaticVNode('<rect x="27" y="50.5" width="124" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="27" y="50.5" width="124" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-50 dark:stroke-neutral-700/10"></rect><rect x="34.5" y="58" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="61" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="73" width="77" height="6" rx="3" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-100 dark:stroke-neutral-700/30"></rect><rect x="27" y="36" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><rect x="59" y="39" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><rect x="59" y="51" width="92" height="6" rx="3" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><g filter="url(#filter2)"><rect x="12" y="6" width="154" height="40" rx="8" fill="currentColor" class="fill-white dark:fill-neutral-800" shape-rendering="crispEdges"></rect><rect x="12.5" y="6.5" width="153" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-100 dark:stroke-neutral-700/60" shape-rendering="crispEdges"></rect><rect x="20" y="14" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect><rect x="52" y="17" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect><rect x="52" y="29" width="106" height="6" rx="3" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect></g><defs><filter id="filter2" x="0" y="0" width="178" height="64" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB"><feFlood flood-opacity="0" result="BackgroundImageFix"></feFlood><feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"></feColorMatrix><feOffset dy="6"></feOffset><feGaussianBlur stdDeviation="6"></feGaussianBlur><feComposite in2="hardAlpha" operator="out"></feComposite><feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0"></feColorMatrix><feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_1187_14810"></feBlend><feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_1187_14810" result="shape"></feBlend></filter></defs>',12)])])}const je=fe(Hn,[["render",Gn]]),qn={},Yn={xmlns:"http://www.w3.org/2000/svg",width:"21",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-layout-sidebar-right-collapse"};function Qn(c,o){return e.openBlock(),e.createElementBlock("svg",Yn,[...o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M4 4m0 2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2z"},null,-1),e.createElementVNode("path",{d:"M15 4v16"},null,-1),e.createElementVNode("path",{d:"M9 10l2 2l-2 2"},null,-1)])])}const Xn=fe(qn,[["render",Qn]]),Jn={},er={xmlns:"http://www.w3.org/2000/svg",width:"21",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-layout-sidebar-right-expand"};function tr(c,o){return e.openBlock(),e.createElementBlock("svg",er,[...o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M4 4m0 2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2z"},null,-1),e.createElementVNode("path",{d:"M15 4v16"},null,-1),e.createElementVNode("path",{d:"M10 10l-2 2l2 2"},null,-1)])])}const lr=fe(Jn,[["render",tr]]),or={},nr={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:"icon icon-tabler icons-tabler-outline icon-tabler-map"};function rr(c,o){return e.openBlock(),e.createElementBlock("svg",nr,[...o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M3 7l6 -3l6 3l6 -3v13l-6 3l-6 -3l-6 3v-13"},null,-1),e.createElementVNode("path",{d:"M9 4v13"},null,-1),e.createElementVNode("path",{d:"M15 7v13"},null,-1)])])}const ar=fe(or,[["render",rr]]),ir={},sr={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:"icon icon-tabler icons-tabler-outline icon-tabler-table"};function cr(c,o){return e.openBlock(),e.createElementBlock("svg",sr,[...o[0]||(o[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M3 5a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v14a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-14z"},null,-1),e.createElementVNode("path",{d:"M3 10h18"},null,-1),e.createElementVNode("path",{d:"M10 3v18"},null,-1)])])}const dr=fe(ir,[["render",cr]]);function et(c,o){let l;return function(...a){clearTimeout(l),l=setTimeout(()=>c(...a),o)}}const pr={class:"fixed inset-0 z-50 pointer-events-none"},mr={key:0,class:"flex items-center justify-between gap-4 px-4 pb-3 border-b border-gray-200 shrink-0"},fr={class:"text-base font-semibold text-gray-900"},ur={class:"px-4 pb-3 min-h-0 shrink-0 overflow-hidden"},gr={class:"flex flex-col flex-1 min-h-0 overflow-hidden"},hr={class:"flex items-center justify-between gap-4 px-4 pb-3 border-b border-gray-200 shrink-0"},yr={class:"text-base font-semibold text-gray-900"},xr={class:"flex-1 min-h-0 overflow-auto p-4"},tt=152,lt=96,ot=270,nt=96,rt=56,ye=e.defineComponent({__name:"MobileModalShell",props:{open:{type:Boolean},title:{},topOffset:{},initialVariant:{},peekMode:{}},emits:["close","expand","collapse"],setup(c,{expose:o,emit:l}){const a=c,t=l,r=e.ref("full"),g=e.computed(()=>a.topOffset??"0px"),i=e.computed(()=>a.peekMode??"custom"),p=e.ref(0),w=e.ref(0);let f=null,h=0;const u=e.computed(()=>{if(r.value==="peek"){const n=i.value==="custom",m=n?tt:ot,y=n?lt:nt,z=n?40:60,L=Math.max(y,m+p.value-w.value);return{height:`min(${z}vh, ${L}px)`}}return{top:g.value}});e.watch(()=>a.open,n=>{n&&(r.value=a.initialVariant??"full"),p.value=0,w.value=0}),e.watch(()=>a.initialVariant,n=>{a.open&&n&&(r.value=n)});function x(){r.value!=="full"&&(r.value="full",t("expand")),p.value=0,w.value=0}function b(){r.value!=="peek"&&(r.value="peek",t("collapse")),p.value=0,w.value=0}function k(n){if(n.pointerId!==f)return;const m=n.clientY-h;if(r.value==="peek"){const y=i.value==="custom",E=Math.max(0,(y?tt:ot)-(y?lt:nt));m<0?(p.value=Math.max(0,-m),w.value=0):m>0&&(w.value=Math.min(m,E),p.value=0)}}function d(n){if(n.pointerId!==f)return;window.removeEventListener("pointermove",k),window.removeEventListener("pointerup",d),window.removeEventListener("pointercancel",d),f=null;const m=n.clientY-h;r.value==="full"?m>rt&&b():m<-rt&&x()}function s(n){var m,y;n.button!==0&&n.pointerType==="mouse"||(f=n.pointerId,h=n.clientY,p.value=0,w.value=0,(y=(m=n.currentTarget).setPointerCapture)==null||y.call(m,n.pointerId),window.addEventListener("pointermove",k),window.addEventListener("pointerup",d),window.addEventListener("pointercancel",d))}return e.onBeforeUnmount(()=>{window.removeEventListener("pointermove",k),window.removeEventListener("pointerup",d),window.removeEventListener("pointercancel",d)}),o({expand:x,collapseToPeek:b}),(n,m)=>e.withDirectives((e.openBlock(),e.createElementBlock("div",pr,[e.createElementVNode("div",{class:e.normalizeClass(["absolute inset-0 bg-black/40 transition-opacity duration-150",r.value==="peek"?"opacity-0 pointer-events-none":"opacity-100 pointer-events-auto"]),onClick:m[0]||(m[0]=e.withModifiers(y=>r.value!=="peek"&&t("close"),["self"]))},null,2),e.createElementVNode("div",{class:e.normalizeClass(["pointer-events-auto absolute left-0 right-0 bottom-0 flex flex-col overflow-hidden bg-white shadow-[0_-4px_24px_rgba(0,0,0,0.12)]",r.value==="peek"?"rounded-t-2xl":""]),style:e.normalizeStyle(u.value)},[e.createElementVNode("div",{class:"shrink-0 flex flex-col items-center pt-2 pb-1 cursor-grab active:cursor-grabbing touch-none select-none",onPointerdown:s},[...m[3]||(m[3]=[e.createElementVNode("div",{class:"h-1.5 w-10 rounded-full bg-stone-300","aria-hidden":"true"},null,-1)])],32),r.value==="peek"&&i.value==="custom"?(e.openBlock(),e.createElementBlock("div",mr,[e.createElementVNode("div",fr,e.toDisplayString(c.title),1),e.createElementVNode("button",{type:"button",class:"h-9 w-9 inline-flex items-center justify-center rounded-full border border-gray-200 text-gray-600 hover:bg-gray-50 relative z-[80]",onClick:m[1]||(m[1]=y=>t("close")),"aria-label":"Close"},[...m[4]||(m[4]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-5 h-5",width:"20",height:"20",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),e.withDirectives(e.createElementVNode("div",ur,[e.renderSlot(n.$slots,"peek",{expand:x,collapse:b},()=>[e.createElementVNode("button",{type:"button",class:"w-full text-left text-base font-semibold text-gray-900 py-2 rounded-lg hover:bg-stone-50",onClick:x},e.toDisplayString(c.title),1)])],512),[[e.vShow,r.value==="peek"&&i.value==="custom"]]),e.withDirectives(e.createElementVNode("div",gr,[e.createElementVNode("div",hr,[e.createElementVNode("div",yr,e.toDisplayString(c.title),1),e.createElementVNode("button",{type:"button",class:"h-9 w-9 inline-flex items-center justify-center rounded-full border border-gray-200 text-gray-600 hover:bg-gray-50 relative z-[80]",onClick:m[2]||(m[2]=y=>t("close")),"aria-label":"Close"},[...m[5]||(m[5]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-5 h-5",width:"20",height:"20",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.createElementVNode("div",xr,[e.renderSlot(n.$slots,"default")])],512),[[e.vShow,r.value==="full"||r.value==="peek"&&i.value==="clip-full"]])],6)],512)),[[e.vShow,c.open]])}}),br={class:"flex flex-col gap-2 pointer-events-auto self-end","data-peek-controls":"1"},kr=e.defineComponent({__name:"MapMobilePeekControlButtons",props:{onOpenLayers:{type:Function},onOpenLegend:{type:Function}},setup(c){return(o,l)=>(e.openBlock(),e.createElementBlock("div",br,[e.createElementVNode("button",{type:"button",class:"h-[28px] w-[28px] inline-flex items-center justify-center rounded-lg border border-gray-200 bg-white text-gray-800 shadow-md p-0 hover:bg-gray-50 cursor-pointer","aria-label":"Layers",onClick:l[0]||(l[0]=a=>c.onOpenLayers())},[...l[2]||(l[2]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.5","stroke-linecap":"round","stroke-linejoin":"round","aria-hidden":"true"},[e.createElementVNode("path",{d:"M12 2 2 7l10 5 10-5-10-5Z"}),e.createElementVNode("path",{d:"M2 17l10 5 10-5"}),e.createElementVNode("path",{d:"M2 12l10 5 10-5"})],-1)])]),e.createElementVNode("button",{type:"button",class:"h-[28px] w-[28px] inline-flex items-center justify-center rounded-lg border border-gray-200 bg-white text-gray-800 shadow-md p-0 hover:bg-gray-50 cursor-pointer","aria-label":"Legend",onClick:l[1]||(l[1]=a=>c.onOpenLegend())},[...l[3]||(l[3]=[e.createStaticVNode('<svg xmlns="http://www.w3.org/2000/svg" width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M8 6h13"></path><path d="M8 12h13"></path><path d="M8 18h13"></path><path d="M3 6h.01"></path><path d="M3 12h.01"></path><path d="M3 18h.01"></path></svg>',1)])])]))}});function at(c,o,l=12,a=12){const t=o??"";return`${window.location.origin}/api/vtile/${c}/ua/{z}/{x}/{y}.vmt?pointZoom=${a}&clusterZoom=${l}&filter=${t}`}function wr(c,o,l,a,t=12,r=12){if(!o)return;const g=at(c,a,t,r);o.addSource("vector",{type:"vector",tiles:[g],minzoom:0,maxzoom:12});const i=["coalesce",["get","point_count"],["get","pointCount"],["get","cluster_count"],["get","clusterCount"],0],p=[">",i,1],w=["<=",i,1],f=["in",["geometry-type"],["literal",["Point","MultiPoint"]]],h=["in",["geometry-type"],["literal",["Polygon","MultiPolygon"]]],u=["coalesce",["get","point_count_abbreviated"],["get","cluster_count_abbreviated"],["get","clusterCountAbbreviated"],i];o.addLayer({id:"vector-clusters",type:"circle",source:"vector","source-layer":c,filter:p,maxzoom:12,paint:{"circle-color":["step",i,"#51bbd6",100,"#f1f075",750,"#f28cb1"],"circle-radius":["step",i,18,100,26,750,32],"circle-opacity":.85}}),o.addLayer({id:"vector-cluster-count",type:"symbol",source:"vector","source-layer":c,filter:p,maxzoom:12,layout:{"text-field":["to-string",u],"text-font":["Noto Sans Regular"],"text-size":12},paint:{"text-color":"#1f2937"}}),o.addLayer({id:"vector-circle",type:"circle",maxzoom:12,source:"vector","source-layer":c,filter:["all",w,f],paint:{"circle-color":l,"circle-stroke-color":"#eee","circle-stroke-width":1,"circle-radius":["interpolate",["linear"],["zoom"],10,5,15,12]}}),o.addLayer({id:"vector-fill",type:"fill",minzoom:12,source:"vector","source-layer":c,filter:h,paint:{"fill-color":l,"fill-opacity":.6}})}const Vr=[{id:"voyager",name:"Базова карта (voyager)",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"},{id:"orto",name:"Ортофото 10К",url:"https://data.gki.com.ua/api-user/rtile/orto10/ua/{z}/{x}/{y}.png",preview:"https://data.gki.com.ua/api-user/rtile/orto10/ua/12/2422/1400.png"},{id:"esri",name:"Esri",url:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}",preview:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/12/2422/1400.png"},{id:"google",name:"Google",url:"https://mt1.google.com/vt/lyrs=s&x={x}&y={y}&z={z}",preview:"https://mt1.google.com/vt/lyrs=s&x=2422&y=1400&z=12"}],Cr={class:"relative w-auto h-full"},Br={class:"legend-panel__header flex items-center justify-between gap-2 py-[7px] pl-[10px] pr-[7px]"},Er={key:0,class:"text-[0.875rem] font-medium text-stone-700"},Nr=["aria-label"],_r={key:0,xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},Sr={key:1,xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},Mr={class:"flex justify-start items-center gap-2"},Lr={class:"flex-1 flex justify-between items-center min-w-0 ml-1"},Dr={class:"text-[0.875rem]"},$r={key:0,class:"text-[0.8rem] text-stone-500 shrink-0 ml-2"},zr={key:1,class:"p-[10px]"},Pr={class:"flex justify-start items-center gap-2"},Fr={class:"flex-1 flex justify-between items-center min-w-0 ml-1"},jr={class:"text-[0.875rem]"},Ar={key:0,class:"text-[0.8rem] text-stone-500 shrink-0 ml-2"},Tr={key:0,class:"vs-map-slot-layers z-10 select-none",style:{display:"flex"}},Rr=["title","onClick"],Zr=["src"],Or={class:"absolute py-2 px-4 text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg top-[-46px] hidden whitespace-nowrap left-1/2 -translate-x-1/2"},Ir={class:"vs-mobile-peek-controls px-3 pb-3"},Kr={class:"vs-map-slot-layers--peek z-10 select-none",style:{position:"static",display:"grid !important","grid-template-columns":"repeat(3, minmax(0, 1fr))",gap:"12px",width:"100%"}},Ur=["title","onClick"],vr=["src"],Hr={class:"absolute py-2 px-4 text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg top-[-46px] hidden whitespace-nowrap left-1/2 -translate-x-1/2"},Wr={class:"vs-mobile-peek-controls flex justify-center w-full"},Gr={class:"w-full"},qr={class:"legend-panel__header flex items-center justify-between gap-2 py-[7px] pl-[10px] pr-[7px] pb-[12px]"},Yr={class:"text-[0.875rem] font-medium text-stone-700"},Qr={class:"legend-panel__content overflow-hidden transition-all duration-200 ease-out"},Xr={class:"p-[10px] pt-0"},Jr={class:"flex justify-start items-center gap-2"},ea={class:"flex-1 flex justify-between items-center min-w-0 ml-1"},ta={class:"text-[0.875rem]"},la={key:0,class:"text-[0.8rem] text-stone-500 shrink-0 ml-2"},xe="vector-clusters",it=e.defineComponent({__name:"map",props:{table:{},center:{},colorAttr:{},filter:{},modelValue:{},zoom:{},minZoom:{},maxZoom:{},map:{},showPopup:{type:Boolean,default:!0},mobilePeekControls:{type:Boolean},layers:{},clusterZoom:{},pointZoom:{},isCollapsible:{type:Boolean},legendTitle:{},legendWidth:{},alwaysShowPolygon:{type:Boolean}},emits:["update:modelValue","update:map"],setup(c,{emit:o}){const l=c,a=o;let t,r=null;const g=e.getCurrentInstance(),i=e.ref(null),p=e.ref(!1),w=e.ref(!1),f=e.ref(!1),h=e.ref(!1);let u=null,x=null;const b=["vector-circle","vector-fill"],k=e.ref(!0),d=e.computed(()=>{var B,P;return((P=(B=g==null?void 0:g.appContext.config.globalProperties)==null?void 0:B.$settings)==null?void 0:P.basemaps)||[]}),s=e.computed(()=>(l.layers&&l.layers.length?l.layers:d.value.length?d.value:Vr).map((P,R)=>{var oe;const $=P.id||((oe=P.name)==null?void 0:oe.toString().toLowerCase().replace(/\s+/g,"-"))||`layer-${R}`,W=P.name||P.id||`layer-${R}`;return{...P,id:$,name:W}})),n=e.ref(""),m=e.computed(()=>s.value.find(B=>B.id===n.value)||s.value[0]);e.watch(s,B=>{var P;B.length&&(!n.value||!B.some(R=>R.id===n.value))&&(n.value=((P=B[0])==null?void 0:P.id)||"")},{immediate:!0});function y(B){return B?B.replace("{x}","2422").replace("{y}","1400").replace("{z}","12"):""}const z=e.ref(null),L=e.ref(null),E=e.computed(()=>l.showPopup!==!1),S=["#1F77B4","#FF7F0E","#2CA02C","#D62728","#9467BD","#8C564B","#E377C2","#7F7F7F","#17BECF","#BCBD22"];let D;const _=[30,48];let M=null,Z=[];function A(){if(typeof window>"u")return{zoom:null,center:null,hasQuery:!1};const B=new URLSearchParams(window.location.search),P=Number(B.get("z")),R=Number(B.get("y")),$=Number(B.get("x")),W=B.has("x")&&B.has("y"),oe=B.has("z");return{zoom:oe?P:null,center:W?[$,R]:null,hasQuery:W||oe}}function N(B,P){if(!B||typeof window>"u")return;const R=new URL(window.location.href);R.searchParams.set("z",P.toFixed(2)),R.searchParams.set("x",B[0].toFixed(6)),R.searchParams.set("y",B[1].toFixed(6)),window.history.replaceState({},"",R)}let F=!1;function T(){if(!t||!F)return;const B=t.getCenter();N([B.lng,B.lat],t.getZoom())}const I=()=>{F||(F=!0),T()};function K(B){return B?["==",["to-string",["get","id"]],B]:["==",["literal",1],0]}const J=["in",["geometry-type"],["literal",["Point","MultiPoint"]]],be=["in",["geometry-type"],["literal",["Polygon","MultiPolygon"]]];function le(){const B=K(l.modelValue),P=["all",B,J],R=["all",B,be];if(!t.getLayer("vector-highlight-circle")){const oe=(l.clusterZoom??12)-.01;t.addLayer({id:"vector-highlight-circle",type:"circle",maxzoom:oe,source:"vector","source-layer":l.table,paint:{"circle-color":"#ef4444","circle-opacity":.8,"circle-stroke-color":"#b91c1c","circle-stroke-width":0,"circle-radius":["interpolate",["linear"],["zoom"],10,10,12,11]}})}t.getLayer("vector-highlight-fill")||t.addLayer({id:"vector-highlight-fill",type:"line",minzoom:l.clusterZoom??12,source:"vector","source-layer":l.table,paint:{"line-color":"#b91c1c","line-width":3,"line-opacity":.8}}),t.setFilter("vector-highlight-circle",P),t.setFilter("vector-highlight-fill",R);const $=l.modelValue?"visible":"none";t.setLayoutProperty("vector-highlight-circle","visibility",$),t.setLayoutProperty("vector-highlight-fill","visibility",$),ke()}function te(B){if(!t||!Z.length)return;const P="#ef4444",R=B?["case",["all",["has","id"],["==",["to-string",["get","id"]],B]],P,Z]:Z;if(t.getLayer("vector-circle")&&t.setPaintProperty("vector-circle","circle-color",R),t.getLayer("vector-fill")){const $=B?["case",["all",["has","id"],["==",["to-string",["get","id"]],B]],P,Z]:Z;t.setPaintProperty("vector-fill","fill-color",$)}}function ke(){if(ue(),!l.modelValue)return;let B=!0;M=window.setInterval(()=>{B=!B;const P=B?.8:.2;t!=null&&t.getLayer("vector-highlight-circle")&&t.setPaintProperty("vector-highlight-circle","circle-opacity",P),t!=null&&t.getLayer("vector-highlight-fill")&&t.setPaintProperty("vector-highlight-fill","line-opacity",P)},600)}function ue(){M&&(clearInterval(M),M=null)}function we(){t&&(t.setCenter(l.center||_),t.setZoom(l.zoom||5))}function ge(){if(!(t!=null&&t.setLayerZoomRange))return;const B=l.minZoom??0,P=Math.min((l.maxZoom??18)+.01,24);if(l.alwaysShowPolygon)t.getLayer("vector-circle")&&t.setLayerZoomRange("vector-circle",B,0),t.getLayer("vector-highlight-circle")&&t.setLayerZoomRange("vector-highlight-circle",B,0),t.getLayer("vector-fill")&&t.setLayerZoomRange("vector-fill",B,P),t.getLayer("vector-highlight-fill")&&t.setLayerZoomRange("vector-highlight-fill",B,P),t.getLayer(xe)&&t.setLayerZoomRange(xe,B,0),t.getLayer("vector-cluster-count")&&t.setLayerZoomRange("vector-cluster-count",B,0);else{const R=l.clusterZoom??12,$=R-.01,W=k.value?$:P;t.getLayer("vector-circle")&&t.setLayerZoomRange("vector-circle",B,W),t.getLayer("vector-highlight-circle")&&t.setLayerZoomRange("vector-highlight-circle",B,W),t.getLayer("vector-fill")&&t.setLayerZoomRange("vector-fill",R,P),t.getLayer("vector-highlight-fill")&&t.setLayerZoomRange("vector-highlight-fill",R,P),t.getLayer(xe)&&t.setLayerZoomRange(xe,B,$),t.getLayer("vector-cluster-count")&&t.setLayerZoomRange("vector-cluster-count",B,$)}}function Te(){if(t!=null&&t.getSource("vector")){try{const P=t.querySourceFeatures("vector",{sourceLayerId:l.table}).some(R=>{var W;const $=(W=R.geometry)==null?void 0:W.type;return $==="Polygon"||$==="MultiPolygon"});k.value=P}catch{}ge()}}const ee=A();F=ee.hasQuery,e.onMounted(async()=>{D=(await fetch(`/api/data/${l.table}/${l.colorAttr}`).then(G=>G.json())).rows,D.forEach((G,v)=>{G.color||Object.assign(G,{color:S[v%10]})}),r=new maplibregl.Popup({closeButton:!1,closeOnClick:!1});const P=m.value;if(!P)return;const R=ee.center||l.center||_,$=ee.zoom||l.zoom||5;t=new maplibregl.Map({container:i.value,style:{version:8,sources:{[P.id]:{type:"raster",tiles:[P.url],tileSize:256}},layers:[{id:P.id,type:"raster",source:P.id,minzoom:0,maxzoom:19}]},center:R,zoom:$,minZoom:l.minZoom??3,maxZoom:l.maxZoom??18,attributionControl:!1}),a("update:map",t);const W=l.mobilePeekControls?"bottom-right":"top-right";if(t.addControl(new maplibregl.NavigationControl,W),l.mobilePeekControls){const G={onAdd:()=>{const v=document.createElement("div");return u=v,x=e.createApp(kr,{onOpenLayers:()=>{f.value=!0},onOpenLegend:()=>{h.value=!0}}),x.mount(v),v},onRemove:()=>{x==null||x.unmount(),x=null,u=null}};t.addControl(G,"bottom-right"),t.once("render",()=>{if(!u)return;const v=t.getContainer(),O=v.querySelector(".maplibregl-ctrl-bottom-right"),q=v.querySelector(".maplibregl-ctrl-zoom-in"),X=q==null?void 0:q.closest(".maplibregl-ctrl-group");!O||!X||u.parentElement===O&&(O.removeChild(u),O.insertBefore(u,X.nextSibling))})}t.on("zoom",()=>{}),t.on("moveend",I),t.on("zoomend",I),F&&T(),t.on("load",()=>{t==null||t.resize(),p.value=!0;const G=D.filter(O=>O.id).reduce((O,q)=>[q.id,q.color].concat(O),[]),v=["match",["get",l.colorAttr],...G,"#808080"];Z=v,wr(l.table,t,v,l.filter,l.clusterZoom,l.pointZoom??12),le(),te(l.modelValue),ge(),t.on("sourcedata",O=>{O.sourceId==="vector"&&O.isSourceLoaded&&t.getZoom()>=(l.clusterZoom??12)&&Te()})});const oe=G=>{var O,q;const v=(O=G.features)==null?void 0:O[0];(q=v==null?void 0:v.properties)!=null&&q.id&&a("update:modelValue",v.properties.id)};b.forEach(G=>{t.on("click",G,oe)}),t.on("click",xe,G=>{var de,se,Ve;const v=(de=G.features)==null?void 0:de[0];if(!v)return;const{geometry:O}=v,q=(O==null?void 0:O.type)==="Point"?O.coordinates:(Ve=(se=O==null?void 0:O.coordinates)==null?void 0:se[0])==null?void 0:Ve[0];if(!q)return;const X=Math.min(t.getZoom()+2,t.getMaxZoom());t.easeTo({center:q,zoom:X})}),[...b,xe].forEach(G=>{t.on("mouseenter",G,()=>{t.getCanvas().style.cursor="pointer"}),t.on("mouseleave",G,()=>{t.getCanvas().style.cursor=""})}),t.on("mousemove",G=>{var de,se;if(!E.value){(de=r==null?void 0:r.remove)==null||de.call(r);return}if(!r)return;const v=t.queryRenderedFeatures(G.point,{layers:b});if(!v||!v.length){r.remove();return}const O=v[0],{coordinates:q}=O.geometry,X=O.geometry.type==="Point"?q:q[0][0];L.value=O.properties,r.setLngLat(X).setHTML((se=z.value)==null?void 0:se.innerHTML).addTo(t)})}),e.watch(()=>l.center,B=>{t&&t.setCenter(B||_)}),e.watch(()=>l.zoom,B=>{t&&t.setZoom(B)}),e.watch(()=>l.minZoom,B=>{t&&(t.setMinZoom(B??3),ge())}),e.watch(()=>l.maxZoom,B=>{t&&(t.setMaxZoom(B??18),ge())});function he(B,P,R){if(!(t!=null&&t.getSource("vector")))return;const $=at(l.table,B??l.filter,P??l.clusterZoom??12,R??l.pointZoom??12);t.getSource("vector").setTiles([$])}return e.watch(()=>l.filter,B=>{he(B)}),e.watch(()=>l.clusterZoom,B=>{he(void 0,B),ge()}),e.watch(()=>l.pointZoom,B=>{he(void 0,void 0,B)}),e.watch(()=>l.alwaysShowPolygon,()=>{ge(),he()}),e.watch(()=>l.modelValue,B=>{if(!t)return;const P=K(B),R=["all",P,J],$=["all",P,be];if(t.getLayer("vector-highlight-circle")){t.setFilter("vector-highlight-circle",R);const W=B?"visible":"none";t.setLayoutProperty("vector-highlight-circle","visibility",W)}if(t.getLayer("vector-highlight-fill")){t.setFilter("vector-highlight-fill",$);const W=B?"visible":"none";t.setLayoutProperty("vector-highlight-fill","visibility",W)}te(B),B?ke():ue()}),e.watch(n,(B,P)=>{if(!t||!B)return;const R=s.value.find(W=>W.id===B);if(!R)return;t.getLayer(P)&&t.removeLayer(P),t.getSource(P)&&t.removeSource(P),t.addSource(B,{type:"raster",tiles:[R.url],tileSize:256});const $=t.getLayer("vector-clusters")?"vector-clusters":t.getLayer("vector-circle")?"vector-circle":void 0;t.addLayer({id:R.id,type:"raster",source:R.id,minzoom:0,maxzoom:19},$)}),e.onBeforeUnmount(()=>{ue(),t&&(t.off("moveend",I),t.off("zoomend",I),t.remove())}),(B,P)=>{const R=e.resolveDirective("tooltip");return e.withDirectives((e.openBlock(),e.createElementBlock("div",Cr,[e.createElementVNode("div",{ref_key:"mapContainer",ref:i,class:"map-container w-auto relative"},null,512),e.withDirectives((e.openBlock(),e.createElementBlock("button",{type:"button",class:"absolute top-25 right-2 z-20 h-8 w-8 flex items-center justify-center rounded-lg bg-white border border-gray-200 shadow-[0_8px_20px_rgba(0,0,0,0.08)] text-[18px] leading-none text-gray-700 hover:bg-gray-50",title:"Повернутися до базового вигляду",onClick:we},[...P[3]||(P[3]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},[e.createElementVNode("path",{d:"M3 11L12 3l9 8"}),e.createElementVNode("path",{d:"M5 9v10h4v-6h6v6h4V9"})],-1)])])),[[R,"Повернутися до базового вигляду"]]),e.createElementVNode("div",{class:e.normalizeClass(["absolute left-[20px] bottom-[74px] bg-white rounded-lg z-10 border legend-panel",{"legend-panel--has-header":l.legendTitle||l.isCollapsible}]),style:e.normalizeStyle(l.legendWidth?{width:l.legendWidth}:{maxWidth:"250px"})},[l.legendTitle||l.isCollapsible?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",Br,[l.legendTitle?(e.openBlock(),e.createElementBlock("span",Er,e.toDisplayString(l.legendTitle),1)):e.createCommentVNode("",!0),l.isCollapsible?(e.openBlock(),e.createElementBlock("button",{key:1,type:"button",class:"legend-panel__toggle ml-auto shrink-0 p-1.5 rounded-full hover:bg-stone-100 text-stone-600","aria-label":w.value?"Згорнути легенду":"Розгорнути легенду",onClick:P[0]||(P[0]=$=>w.value=!w.value)},[w.value?(e.openBlock(),e.createElementBlock("svg",_r,[...P[4]||(P[4]=[e.createElementVNode("path",{d:"M6 9l6 6 6-6"},null,-1)])])):(e.openBlock(),e.createElementBlock("svg",Sr,[...P[5]||(P[5]=[e.createElementVNode("path",{d:"m18 15-6-6-6 6"},null,-1)])]))],8,Nr)):e.createCommentVNode("",!0)]),e.createElementVNode("div",{class:"legend-panel__content overflow-hidden transition-all duration-200 ease-out",style:e.normalizeStyle(l.isCollapsible&&!w.value?{maxHeight:"0",padding:"0",margin:"0",opacity:"0"}:{})},[e.createElementVNode("div",{class:e.normalizeClass(["p-[10px]",w.value&&(e.unref(D)||[]).length?"pt-0":"pt-2"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(D)||[],$=>(e.openBlock(),e.createElementBlock("div",{class:"legend-item",key:$.id},[e.createElementVNode("div",Mr,[e.createElementVNode("div",{class:"w-[15px] h-[15px] rounded-[50%] min-w-[15px]",style:e.normalizeStyle("background-color:"+$.color)},null,4),e.createElementVNode("div",Lr,[e.createElementVNode("span",Dr,e.toDisplayString($.text),1),$.count!=null?(e.openBlock(),e.createElementBlock("span",$r,e.toDisplayString($.count),1)):e.createCommentVNode("",!0)])])]))),128))],2)],4)],64)):(e.openBlock(),e.createElementBlock("div",zr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(D)||[],$=>(e.openBlock(),e.createElementBlock("div",{class:"legend-item",key:$.id},[e.createElementVNode("div",Pr,[e.createElementVNode("div",{class:"w-[15px] h-[15px] rounded-[50%] min-w-[15px]",style:e.normalizeStyle("background-color:"+$.color)},null,4),e.createElementVNode("div",Fr,[e.createElementVNode("span",jr,e.toDisplayString($.text),1),$.count!=null?(e.openBlock(),e.createElementBlock("span",Ar,e.toDisplayString($.count),1)):e.createCommentVNode("",!0)])])]))),128))]))],6),e.createElementVNode("div",{ref_key:"popupDiv",ref:z,style:{display:"none"}},[e.renderSlot(B.$slots,"default",{hoverData:L.value})],512),l.mobilePeekControls?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",Tr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,$=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:$.id,title:$.name,class:e.normalizeClass(["vs-map-slot-layers__layer relative",{focused:n.value===$.id}]),onClick:W=>n.value=$.id},[e.createElementVNode("img",{src:$.preview||y($.url),class:"vs-map-slot-layers__image"},null,8,Zr),e.createElementVNode("div",Or,e.toDisplayString($.name),1)],10,Rr)),[[R,$.name]])),128))])),l.mobilePeekControls?(e.openBlock(),e.createBlock(ye,{key:1,open:f.value,title:"Шари","initial-variant":"peek","peek-mode":"clip-full","allow-expand":!1,onClose:P[1]||(P[1]=$=>f.value=!1)},{default:e.withCtx(()=>[e.createElementVNode("div",Ir,[e.createElementVNode("div",Kr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.value,$=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:$.id,title:$.name,class:e.normalizeClass(["vs-map-slot-layers__layer relative",{focused:n.value===$.id}]),onClick:W=>n.value=$.id},[e.createElementVNode("img",{src:$.preview||y($.url),class:"vs-map-slot-layers__image",style:{width:"100%",height:"100","object-fit":"cover",display:"block"}},null,8,vr),e.createElementVNode("div",Hr,e.toDisplayString($.name),1)],10,Ur)),[[R,$.name]])),128))])])]),_:1},8,["open"])):e.createCommentVNode("",!0),l.mobilePeekControls?(e.openBlock(),e.createBlock(ye,{key:2,open:h.value,title:"Легенда","initial-variant":"peek","peek-mode":"clip-full","peek-height-px":200,onClose:P[2]||(P[2]=$=>h.value=!1)},{default:e.withCtx(()=>[e.createElementVNode("div",Wr,[e.createElementVNode("div",Gr,[e.createElementVNode("div",qr,[e.createElementVNode("span",Yr,e.toDisplayString(l.legendTitle||"Легенда"),1)]),e.createElementVNode("div",Qr,[e.createElementVNode("div",Xr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(D)||[],$=>(e.openBlock(),e.createElementBlock("div",{class:"legend-item",key:$.id},[e.createElementVNode("div",Jr,[e.createElementVNode("div",{class:"w-[15px] h-[15px] rounded-[50%] min-w-[15px]",style:e.normalizeStyle("background-color:"+$.color)},null,4),e.createElementVNode("div",ea,[e.createElementVNode("span",ta,e.toDisplayString($.text),1),$.count!=null?(e.openBlock(),e.createElementBlock("span",la,e.toDisplayString($.count),1)):e.createCommentVNode("",!0)])])]))),128))])])])])]),_:1},8,["open"])):e.createCommentVNode("",!0)],512)),[[e.vShow,p.value]])}}}),st={mounted(c,o){if(typeof document>"u")return;let l=null;const a=()=>{l=document.createElement("div"),l.textContent=o.value,Object.assign(l.style,{position:"absolute",background:"#333",color:"#fff",padding:"4px 8px",borderRadius:"4px",fontSize:"12px",whiteSpace:"nowrap",pointerEvents:"none",zIndex:"9999"}),document.body.appendChild(l);const r=c.getBoundingClientRect();l.style.left=`${r.left+window.scrollX}px`,l.style.top=`${r.top+window.scrollY-l.offsetHeight-5}px`},t=()=>{l&&l.parentNode&&(l.parentNode.removeChild(l),l=null)};c.addEventListener("mouseenter",a),c.addEventListener("mouseleave",t),Object.assign(c,{tooltipHandlers:{showTooltip:a,hideTooltip:t}})},unmounted(c){if(typeof document>"u")return;const o=c.tooltipHandlers;o&&(c.removeEventListener("mouseenter",o.showTooltip),c.removeEventListener("mouseleave",o.hideTooltip))}},oa={},na={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-list-filter-icon lucide-list-filter"};function ra(c,o){return e.openBlock(),e.createElementBlock("svg",na,[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M2 5h20"},null,-1),e.createElementVNode("path",{d:"M6 12h12"},null,-1),e.createElementVNode("path",{d:"M9 19h6"},null,-1)])])}const aa=fe(oa,[["render",ra]]),ia={},sa={xmlns:"http://www.w3.org/2000/svg",class:"w-5 h-5 shrink-0",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"};function ca(c,o){return e.openBlock(),e.createElementBlock("svg",sa,[...o[0]||(o[0]=[e.createElementVNode("circle",{cx:"11",cy:"11",r:"8"},null,-1),e.createElementVNode("path",{d:"m21 21-4.35-4.35"},null,-1)])])}const da=fe(ia,[["render",ca]]),pa={},ma={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-table-icon lucide-table"};function fa(c,o){return e.openBlock(),e.createElementBlock("svg",ma,[...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 ua=fe(pa,[["render",fa]]),ga={class:"absolute inset-x-0 top-[12px] z-40 px-[12px] pointer-events-none"},ha={class:"flex flex-wrap gap-2"},ya=["disabled"],xa=e.defineComponent({__name:"MobileOverlayActions",props:{activeModal:{},filtersDisabled:{type:Boolean}},emits:["openSearch","openFilters","openTable"],setup(c){return(o,l)=>(e.openBlock(),e.createElementBlock("div",ga,[e.createElementVNode("div",ha,[e.createElementVNode("button",{type:"button",class:e.normalizeClass(["pointer-events-auto py-2 px-3 h-[44px] inline-flex items-center gap-x-2 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",{"bg-stone-50":c.activeModal==="search"}]),onClick:l[0]||(l[0]=a=>o.$emit("openSearch"))},[e.createVNode(da)],2),e.createElementVNode("button",{type:"button",class:e.normalizeClass(["pointer-events-auto py-2 px-3 h-[44px] inline-flex items-center gap-x-2 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",{"bg-stone-50":c.activeModal==="filters"}]),disabled:c.filtersDisabled,onClick:l[1]||(l[1]=a=>o.$emit("openFilters"))},[e.createVNode(aa,{"stroke-width":1,class:"text-gray-900"}),l[3]||(l[3]=e.createElementVNode("span",{class:"font-medium"},"Фільтри",-1))],10,ya),e.createElementVNode("button",{type:"button",class:e.normalizeClass(["pointer-events-auto py-2 px-3 h-[44px] inline-flex items-center gap-x-2 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",{"bg-stone-50":c.activeModal==="table"}]),onClick:l[2]||(l[2]=a=>o.$emit("openTable"))},[e.createVNode(ua,{"stroke-width":1,class:"text-gray-900"}),l[4]||(l[4]=e.createElementVNode("span",{class:"font-medium"},"Таблиця",-1))],2)])]))}}),ba={key:0,class:"relative w-full h-full vs-mobile-parts-map"},ka={class:"flex flex-col min-h-0 gap-4"},wa={class:"flex flex-col min-h-0 flex-1"},Va={key:1,class:"wrapperTable flex flex-col min-h-0"},Ca={key:1,class:"text-center py-8"},Ba={key:2,class:"mt-4 pt-4 border-t border-stone-200 shrink-0"},Ea={class:"flex flex-col flex-1 min-h-0 overflow-hidden"},Na={id:"active-filters"},_a={class:"flex-1 min-h-0"},Sa={key:1,class:"text-sm text-stone-500"},Ma={class:"wrapperTable flex flex-col min-h-0"},La={key:1,class:"text-center py-12"},Da={key:0,class:"mt-4 pt-4 border-t border-stone-200"},$a=["onClick"],za={class:"w-full gap-5 inline-flex mb-[6px] pr-3"},Pa={class:"flex items-center"},Fa=["title"],ja={class:"max-[1000px]:flex gap-2 min-[1001px]:hidden"},Aa={class:"flex"},Ta={key:0,class:"flex items-center py-[15px] pb-[24px] pl-2 pr-6 gap-4"},Ra={class:"font-bold text-2xl mr-[10px]"},Za={class:"text-sm text-stone-500 font-medium"},Oa={key:0,class:"inline-flex items-center gap-2 text-sm text-stone-700 select-none ml-auto mt-auto"},Ia={class:"wrapperTable flex flex-col",style:{height:"calc(100vh - 302px)"}},Ka={key:1,class:"text-center py-28"},Ua={key:1},va={key:2,class:"my-5 pr-2"},Ha={class:"flex justify-between"},Wa={class:"w-full lg:w-1/2 relative"},Ga={key:0,class:"absolute inset-0 z-20 flex flex-col items-center justify-center bg-black/40 backdrop-blur-[2px]"},ct="(max-width: 999px)",_e="0px",Ae=e.defineComponent({__name:"vs-parts-map",props:{title:{},table:{},map:{},rows:{},zoom:{},minZoom:{default:3},maxZoom:{default:18},center:{},initTotal:{},colorAttr:{},id:{},filters:{},history:{type:Boolean},layers:{},objectsInView:{type:Boolean,default:!0},clusterZoom:{default:12},isCollapsible:{type:Boolean},legendTitle:{},legendWidth:{},polygonFitBbox:{type:Boolean},alwaysShowPolygon:{type:Boolean},mobileFilterView:{},mobileFilterLimit:{}},emits:["change:filter","update:map"],setup(c,{emit:o}){var Ve,pt,mt,ft,ut,gt,ht;const l=e.getCurrentInstance();l&&!(l!=null&&l.appContext.directives.tooltip)&&(l.appContext.directives.tooltip=st);function a(V){return V?(V.type==="Point"?V.coordinates:null)||(V.type.includes("Multi")?V.coordinates[0][0][0]:V.coordinates[0][0]):null}function t(V){switch(V==null?void 0:V.type){case"Polygon":return V.coordinates[0];case"MultiPolygon":return V.coordinates.flatMap(C=>C[0]);case"LineString":return V.coordinates;case"MultiLineString":return V.coordinates.flat();default:return[]}}function r(V){if(!V||V.type==="Point"||V.type==="MultiPoint")return null;const C=t(V);if(!C.length)return null;let H=1/0,j=1/0,ne=-1/0,Y=-1/0;return C.forEach(([U,re])=>{U<H&&(H=U),re<j&&(j=re),U>ne&&(ne=U),re>Y&&(Y=re)}),[[H,j],[ne,Y]]}function g(V){return(V==null?void 0:V.type)==="Polygon"||(V==null?void 0:V.type)==="MultiPolygon"}const i=c,p=e.useSlots(),w=e.computed(()=>i.mobileFilterView??"vertical"),f=e.computed(()=>i.mobileFilterLimit!==void 0?{limit:i.mobileFilterLimit}:{}),h=o,u=e.ref(0);u.value=i.initTotal??((Ve=i.rows)==null?void 0:Ve.length)??0;const x=e.ref(""),b=e.ref(null),k=e.ref(!0),d=e.ref(((pt=i.rows)==null?void 0:pt.length)===1),s=e.ref(!1);let n=null;const m=e.ref(!1);typeof window<"u"&&(n=window.matchMedia(ct),m.value=n.matches,s.value=!0);const y=e.ref(i.rows),z=e.ref(1),L=e.ref(20),E=e.ref(i.filters||[]),S=e.ref(""),D=e.ref({}),_=e.ref(((mt=i.rows)==null?void 0:mt.length)===1?i.rows[0]:{}),M=e.ref(((ft=i.rows)==null?void 0:ft.length)===1?i.rows[0].id:""),Z=e.ref(((ut=i.rows)==null?void 0:ut.length)===1?a((gt=i.rows[0])==null?void 0:gt.geom):i.center||null),A=e.ref(((ht=i.rows)==null?void 0:ht.length)===1?14:i.zoom||5),N=e.ref(!1),F=e.ref(!1),T=e.ref("");let I=!1;const K=e.ref(null),J=e.ref(!1);function be(){if(!n)return;const V=m.value;m.value=n.matches,V!==m.value&&(K.value=null,e.nextTick(()=>{var C,H;(H=(C=b.value)==null?void 0:C.resize)==null||H.call(C)}))}const le=e.ref(null),te=e.ref(null),ke=e.computed(()=>{var V;return d.value&&!((V=_.value)!=null&&V.geom)}),ue=e.computed({get:()=>ke.value?"":M.value,set:V=>{M.value=V,m.value&&(V?(J.value=!0,K.value="details"):K.value==="details"&&(K.value=null))}});function we(){var Y,U,re;if(i.alwaysShowPolygon){le.value=null,te.value=null;return}if(!i.polygonFitBbox||!b.value||!((Y=_.value)!=null&&Y.geom)){le.value=null,te.value=null;return}const{geom:V}=_.value;if(!g(V)){le.value=null,te.value=null;return}const C=r(V);if(!C){le.value=null,te.value=null;return}const H=(re=(U=b.value).cameraForBounds)==null?void 0:re.call(U,C,{padding:20,maxZoom:16}),j=H==null?void 0:H.zoom,ne=i.clusterZoom??12;if(j!=null&&j<ne){const yt=Math.floor(j);le.value=yt,te.value=yt}else le.value=null,te.value=null}function ge(V){return Object.entries(V).filter(([,C])=>Array.isArray(C)?C.length:C).map(([C,H])=>`${C}=${H}`).join("|")}function Te(){var j,ne,Y,U;if(!b.value||!F.value)return;const V=(ne=(j=b.value).getBounds)==null?void 0:ne.call(j);if(!V)return;const C=(Y=V.getSouthWest)==null?void 0:Y.call(V),H=(U=V.getNorthEast)==null?void 0:U.call(V);!C||!H||(T.value=`${C.lng} ${C.lat},${H.lng} ${H.lat}`)}async function ee(V=!1){await e.nextTick();const C=ge(D.value);S.value=C,F.value?Te():T.value="";try{const H={search:x.value,limit:L.value.toString(),page:z.value.toString(),filter:C,...F.value&&T.value?{bbox:T.value}:{}},j=new URL(`/api/data/${i.table}`,window.location.origin)+(M.value?`/${M.value}`:""),ne=new URLSearchParams(H).toString(),Y=await fetch(`${j.toString()}?${ne}`).then(U=>U.json());if(M.value){let U;if(Y.rows.length>1?U=Y.rows.find(re=>re.id===M.value):[U]=Y.rows,_.value=U,!V&&(U!=null&&U.geom)){const re=i.polygonFitBbox?r(U.geom):null;re&&b.value?b.value.fitBounds(re,{padding:20,maxZoom:16,duration:500}):(Z.value=a(U.geom),A.value=14)}we(),d.value=!0}else le.value=null,te.value=null,d.value=!1,N.value||(A.value=i.zoom||5),y.value=Y==null?void 0:Y.rows;N.value=!1,u.value=Y.filtered,Pn({page:z.value,filter:C,id:M.value,filterByView:F.value})}catch(H){console.error(H.message)}}const he=et(()=>ee(),300),B=et(()=>ee(!0),400);function P(){!b.value||I||!F.value||(b.value.on("moveend",B),b.value.on("zoomend",B),I=!0)}function R(){!b.value||!I||(b.value.off("moveend",B),b.value.off("zoomend",B),I=!1)}function $(V){L.value=V,z.value=1,ee()}function W(V){z.value=V,ee()}function oe(V){D.value=V.data,z.value=1,M.value?M.value="":ee(),h("change:filter",V)}async function dt(){if(i.filters)return;const C=await(await fetch(`/api/filter/${i.table}`)).json();E.value=C.list}function G(){D.value={},x.value="",ee()}e.onMounted(async()=>{var H,j;n||(n=window.matchMedia(ct)),s.value||(m.value=n.matches,s.value=!0),n.addEventListener("change",be),m.value&&(k.value=!1);const V=new URLSearchParams(window.location.search);z.value=Number(V.get("page"))||1,L.value=Number(V.get("limit"))||L.value,M.value=V.get("id")||"",d.value=!!M.value,S.value=V.get("filter")||"";const C=V.get("bbox");C!==null?F.value=C!=="0":F.value=!1,(j=(H=V.get("filter"))==null?void 0:H.split("|"))==null||j.forEach(ne=>{const[Y,U]=ne.split("=");Y&&(D.value[Y]=U!=null&&U.includes(",")?U.split(","):[U])}),dt(),!y.value&&!M.value&&ee()}),e.onBeforeUnmount(()=>{n==null||n.removeEventListener("change",be),R()});function v(){N.value=!0,d.value=!1,_.value=null,M.value="",le.value=null,te.value=null}function O(V){K.value=V}function q(){K.value=null}async function X(){var V,C;await e.nextTick(),(C=(V=b.value)==null?void 0:V.resize)==null||C.call(V)}function de(){v(),q()}function se(V){if(J.value=!0,V!=null&&V.geom){const C=i.polygonFitBbox?r(V.geom):null;C&&b.value?b.value.fitBounds(C,{padding:20,maxZoom:16,duration:500}):(Z.value=a(V.geom),A.value=16)}_.value=V,M.value=V.id,we(),m.value&&(K.value="details")}return e.watch(K,async()=>{var V,C;await e.nextTick(),(C=(V=b.value)==null?void 0:V.resize)==null||C.call(V)}),e.watch(b,V=>{var C;h("update:map",V),V&&F.value&&P(),V&&i.polygonFitBbox&&((C=_.value)!=null&&C.geom)&&we()}),e.watch(x,V=>{V||ee()}),e.watch(M,()=>{ee()}),e.watch(F,()=>{F.value?P():R(),ee()}),(V,C)=>{var H;return s.value?(e.openBlock(),e.createElementBlock("section",{key:0,class:e.normalizeClass(m.value?"":"pt-[20px]")},[m.value?(e.openBlock(),e.createElementBlock("div",ba,[e.createVNode(it,{table:i.table,map:b.value,"onUpdate:map":C[0]||(C[0]=j=>b.value=j),zoom:A.value,minZoom:i.minZoom,maxZoom:i.maxZoom,colorAttr:i.colorAttr,filter:S.value,center:Z.value,clusterZoom:i.alwaysShowPolygon?0:le.value??i.clusterZoom,pointZoom:i.alwaysShowPolygon?0:te.value??12,alwaysShowPolygon:i.alwaysShowPolygon,modelValue:ue.value,"onUpdate:modelValue":C[1]||(C[1]=j=>ue.value=j),layers:i.layers,isCollapsible:i.isCollapsible,legendTitle:i.legendTitle,legendWidth:i.legendWidth,"show-popup":!1,"mobile-peek-controls":!0},{default:e.withCtx(({hoverData:j})=>[e.renderSlot(V.$slots,"popup",{data:j})]),_:3},8,["table","map","zoom","minZoom","maxZoom","colorAttr","filter","center","clusterZoom","pointZoom","alwaysShowPolygon","modelValue","layers","isCollapsible","legendTitle","legendWidth"]),e.createVNode(xa,{"active-modal":K.value,"filters-disabled":!E.value.length,onOpenSearch:C[2]||(C[2]=j=>O("search")),onOpenFilters:C[3]||(C[3]=j=>O("filters")),onOpenTable:C[4]||(C[4]=j=>O("table"))},null,8,["active-modal","filters-disabled"]),e.createVNode(ye,{open:K.value==="search",title:"Пошук","top-offset":_e,"initial-variant":"full","peek-mode":"clip-full",onClose:q,onExpand:X,onCollapse:X},{default:e.withCtx(()=>[e.createElementVNode("div",ka,[e.createVNode(e.unref(ae),{type:"text",modelValue:x.value,"onUpdate:modelValue":C[5]||(C[5]=j=>x.value=j),name:"search",label:"Пошук",onChange:e.unref(he)},null,8,["modelValue","onChange"]),e.createElementVNode("div",wa,[e.unref(p)["mobile-search-results"]?e.renderSlot(V.$slots,"mobile-search-results",{key:0,rows:y.value,selectRow:se,closeModal:q}):(e.openBlock(),e.createElementBlock("div",Va,[u.value>=1?e.renderSlot(V.$slots,"table",{key:0,rows:y.value,selectRow:se,isMapVisible:!1}):(e.openBlock(),e.createElementBlock("div",Ca,[e.createVNode(je),C[19]||(C[19]=e.createElementVNode("h2",{class:"font-medium text-base text-gray-500 rounded-xl"}," За вашим запитом даних не знайдено! ",-1)),C[20]||(C[20]=e.createElementVNode("p",{class:"font-normal text-sm text-gray-500 rounded-xl"}," Введіть, будь ласка, інші значення для пошуку. ",-1)),e.createElementVNode("button",{type:"button",class:"mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",onClick:G}," Очистити дані пошуку ")]))])),u.value>=1?(e.openBlock(),e.createElementBlock("div",Ba,[e.createVNode(Fe,{total:u.value,currentPage:z.value??1,pageSize:L.value,onPageChange:C[6]||(C[6]=j=>W(j)),onPageSizeChange:C[7]||(C[7]=j=>$(j))},null,8,["total","currentPage","pageSize"])])):e.createCommentVNode("",!0)])])]),_:3},8,["open"]),e.createVNode(ye,{open:K.value==="filters",title:"Фільтри","top-offset":_e,"initial-variant":"full","peek-mode":"clip-full",onClose:q,onExpand:X,onCollapse:X},{default:e.withCtx(()=>[e.createElementVNode("div",Ea,[e.withDirectives(e.createElementVNode("div",Na,null,512),[[e.vShow,K.value==="filters"]]),e.createElementVNode("div",_a,[E.value.length?(e.openBlock(),e.createBlock(e.unref(Ne),e.mergeProps({key:0,schema:E.value,view:w.value},f.value,{value:D.value,teleportActive:"#active-filters",onChange:oe}),null,16,["schema","view","value"])):(e.openBlock(),e.createElementBlock("p",Sa,"Фільтри недоступні для цього переліку."))])])]),_:1},8,["open"]),e.createVNode(ye,{open:K.value==="table",title:"Таблиця","top-offset":_e,"initial-variant":"full","peek-mode":"clip-full",onClose:q,onExpand:X,onCollapse:X},{default:e.withCtx(()=>[e.createElementVNode("div",Ma,[u.value>=1?e.renderSlot(V.$slots,"table",{key:0,rows:y.value,selectRow:se,isMapVisible:!1}):(e.openBlock(),e.createElementBlock("div",La,[e.createVNode(je),C[21]||(C[21]=e.createElementVNode("h2",{class:"font-medium text-base text-gray-500 rounded-xl"}," За вашим запитом даних не знайдено! ",-1)),C[22]||(C[22]=e.createElementVNode("p",{class:"font-normal text-sm text-gray-500 rounded-xl"}," Введіть, будь ласка, інші значення для пошуку. ",-1)),e.createElementVNode("button",{type:"button",class:"mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",onClick:G}," Очистити дані пошуку ")]))]),u.value>=1?(e.openBlock(),e.createElementBlock("div",Da,[e.createVNode(Fe,{total:u.value,currentPage:z.value??1,pageSize:L.value,onPageChange:C[8]||(C[8]=j=>W(j)),onPageSizeChange:C[9]||(C[9]=j=>$(j))},null,8,["total","currentPage","pageSize"])])):e.createCommentVNode("",!0)]),_:3},8,["open"]),e.createVNode(ye,{open:K.value==="details",title:"Об'єкт","top-offset":_e,"initial-variant":J.value?"peek":"full","peek-mode":"custom",onClose:de,onExpand:X,onCollapse:X},{peek:e.withCtx(({expand:j})=>[e.unref(p)["mobile-details-peek"]?e.renderSlot(V.$slots,"mobile-details-peek",{key:0,selectedRow:_.value,expand:j,close:de}):(e.openBlock(),e.createElementBlock("button",{key:1,type:"button",class:"w-full text-left text-base font-semibold text-gray-900 py-2 rounded-lg hover:bg-stone-50",onClick:j}," Деталі об'єкта ",8,$a))]),default:e.withCtx(()=>[e.renderSlot(V.$slots,"details",{table:i.table,selectedRow:_.value,closeObjCard:de})]),_:3},8,["open","initial-variant"]),e.renderSlot(V.$slots,"default",{table:i.table,map:b.value,selectedRow:_.value})])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(V.$slots,"header",{title:i.title,total:u.value}),e.createElementVNode("div",za,[e.createVNode(e.unref(ae),{type:"text",modelValue:x.value,"onUpdate:modelValue":C[10]||(C[10]=j=>x.value=j),name:"search",label:"Пошук",onChange:e.unref(he)},null,8,["modelValue","onChange"]),E.value.length?(e.openBlock(),e.createBlock(e.unref(Ne),{key:0,schema:E.value,view:"inline",onChange:oe,limit:5,value:D.value,ref:"filterRef"},null,8,["schema","value"])):e.createCommentVNode("",!0),e.createElementVNode("div",Pa,[e.createElementVNode("button",{type:"button",class:"map-visible-button py-2 px-2 hidden min-[1001px]:inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",title:k.value?"Приховати карту":"Показати карту",onClick:C[11]||(C[11]=j=>k.value=!k.value)},[k.value?(e.openBlock(),e.createBlock(Xn,{key:0})):(e.openBlock(),e.createBlock(lr,{key:1})),C[23]||(C[23]=e.createElementVNode("span",{class:"sr-only"},"Відкрити мапу",-1))],8,Fa),e.createElementVNode("div",ja,[e.createElementVNode("button",{onClick:C[12]||(C[12]=j=>k.value=!1),class:"py-2 px-2 h-[38px] inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"},[e.createVNode(dr)]),e.createElementVNode("button",{onClick:C[13]||(C[13]=j=>k.value=!0),class:"py-2 px-2 h-[38px] inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"},[e.createVNode(ar)])])])]),e.createElementVNode("div",Aa,[e.createElementVNode("div",{class:e.normalizeClass(["relative overflow-hidden shrink-0",k.value?"w-2/4 mr-0":"w-full mr-3",d.value?"hidden":""])},[(H=V.$slots)!=null&&H.header?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",Ta,[e.createElementVNode("div",null,[e.createElementVNode("span",Ra,e.toDisplayString(i.title),1),e.createElementVNode("span",Za,e.toDisplayString(u.value),1),C[24]||(C[24]=e.createElementVNode("span",{class:"text-sm text-stone-500 font-medium"}," об'єктів",-1))]),i.objectsInView?(e.openBlock(),e.createElementBlock("label",Oa,[e.withDirectives(e.createElementVNode("input",{type:"checkbox",class:"accent-blue-600 w-4 h-4","onUpdate:modelValue":C[14]||(C[14]=j=>F.value=j)},null,512),[[e.vModelCheckbox,F.value]]),C[25]||(C[25]=e.createElementVNode("span",null,"В межах видимої області",-1))])):e.createCommentVNode("",!0)])),e.createElementVNode("div",Ia,[u.value>=1?e.renderSlot(V.$slots,"table",{key:0,rows:y.value,selectRow:se}):(e.openBlock(),e.createElementBlock("div",Ka,[e.createVNode(je),C[26]||(C[26]=e.createElementVNode("h2",{class:"font-medium text-base text-gray-500 rounded-xl"}," За вашим запитом даних не знайдено! ",-1)),C[27]||(C[27]=e.createElementVNode("p",{class:"font-normal text-sm text-gray-500 rounded-xl"}," Введіть, будь ласка, інші значення для пошуку. ",-1)),e.createElementVNode("button",{type:"button",class:"mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",onClick:G}," Очистити дані пошуку ")]))]),u.value>=1?(e.openBlock(),e.createElementBlock("hr",Ua)):e.createCommentVNode("",!0),u.value>=1?(e.openBlock(),e.createElementBlock("div",va,[e.createElementVNode("div",Ha,[e.createVNode(Fe,{total:u.value,currentPage:z.value??1,pageSize:L.value,onPageChange:C[15]||(C[15]=j=>W(j)),onPageSizeChange:C[16]||(C[16]=j=>$(j))},null,8,["total","currentPage","pageSize"])])])):e.createCommentVNode("",!0)],2),d.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(k.value?"lg:static lg:w-1/2 mr-0 pb-5":"pb-5 mr-3"),style:{height:"calc(100vh - 152px)"}},[e.renderSlot(V.$slots,"details",{table:i.table,selectedRow:_.value,closeObjCard:v})],2)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("div",Wa,[e.createVNode(it,{table:i.table,map:b.value,"onUpdate:map":C[17]||(C[17]=j=>b.value=j),zoom:A.value,minZoom:i.minZoom,maxZoom:i.maxZoom,colorAttr:i.colorAttr,filter:S.value,center:Z.value,clusterZoom:i.alwaysShowPolygon?0:le.value??i.clusterZoom,pointZoom:i.alwaysShowPolygon?0:te.value??12,alwaysShowPolygon:i.alwaysShowPolygon,modelValue:ue.value,"onUpdate:modelValue":C[18]||(C[18]=j=>ue.value=j),layers:i.layers,isCollapsible:i.isCollapsible,legendTitle:i.legendTitle,legendWidth:i.legendWidth,"show-popup":!0},{default:e.withCtx(({hoverData:j})=>[e.renderSlot(V.$slots,"popup",{data:j})]),_:3},8,["table","map","zoom","minZoom","maxZoom","colorAttr","filter","center","clusterZoom","pointZoom","alwaysShowPolygon","modelValue","layers","isCollapsible","legendTitle","legendWidth"]),e.renderSlot(V.$slots,"default",{table:i.table,map:b.value,selectedRow:_.value}),ke.value?(e.openBlock(),e.createElementBlock("div",Ga,[...C[28]||(C[28]=[e.createStaticVNode('<svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="text-white/80"><path d="M12.75 7.09a3 3 0 0 1 2.16 2.16"></path><path d="M17.072 17.072c-1.634 2.17-3.527 3.912-4.471 4.727a1 1 0 0 1-1.202 0C9.539 20.193 4 14.993 4 10a8 8 0 0 1 1.432-4.568"></path><path d="m2 2 20 20"></path><path d="M8.475 2.818A8 8 0 0 1 20 10c0 1.183-.31 2.377-.81 3.533"></path><path d="M9.13 9.13a3 3 0 0 0 3.74 3.74"></path></svg><p class="mt-4 text-base font-[300] text-white">Геопросторові дані відсутні</p><p class="mt-2 max-w-xs text-center text-sm font-[200] text-white/70 leading-relaxed"> Координати або межі об'єкта не внесені до системи. Об'єкт відображається лише у текстовому форматі. </p>',3)])])):e.createCommentVNode("",!0)],512),[[e.vShow,k.value]])])],64))],2)):e.createCommentVNode("",!0)}}});return Ae.install=c=>{c.component("VsPartsMap",Ae),c._context.directives.tooltip||c.directive("tooltip",st)},Ae});
|
|
1
|
+
(function(e,fe){typeof exports=="object"&&typeof module<"u"?module.exports=fe(require("vue")):typeof define=="function"&&define.amd?define(["vue"],fe):(e=typeof globalThis<"u"?globalThis:e||self,e.PartsMap=fe(e.Vue))})(this,function(e){"use strict";const fe=(t,a)=>{const o=t.__vccOpts||t;for(const[r,l]of a)o[r]=l;return o};e.defineComponent({props:{modelValue:{type:Boolean,default:()=>!1},title:{type:String,default:()=>""},disabled:{type:Boolean,default:()=>!1}},data(){return{}},mounted(){this.modelValue||this.$emit("update:modelValue",!1)},computed:{modelState:{get(){return this.modelValue},set(t){this.$emit("update:modelValue",t)}},labelCursorClasses(){return[{"cursor-not-allowed":this.disabled},{"cursor-pointer":!this.disabled}]}},methods:{handleEnterDown(t){const{keyCode:a}=t;a===13&&(this.modelState=!this.modelState)},addKeyHandler(){window.addEventListener("keydown",this.handleEnterDown)},removeKeyHandler(){window.removeEventListener("keydown",this.handleEnterDown)}}});const yt={},bt={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor",class:"size-6 text-green-600"};function xt(t,a){return e.openBlock(),e.createElementBlock("svg",bt,a[0]||(a[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z"},null,-1)]))}const kt=fe(yt,[["render",xt]]),wt={},Vt={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"orange",class:"size-6 text-orange-600"};function Ct(t,a){return e.openBlock(),e.createElementBlock("svg",Vt,a[0]||(a[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M12 9v3m0 3h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"},null,-1)]))}const Bt=fe(wt,[["render",Ct]]),Et={},Nt={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor",class:"size-6 text-blue-600"};function St(t,a){return e.openBlock(),e.createElementBlock("svg",Nt,a[0]||(a[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"m11.25 11.25.041-.02a.75.75 0 0 1 1.063.852l-.708 2.836a.75.75 0 0 0 1.063.853l.041-.021M21 12a9 9 0 1 1-18 0 9 9 0 0 1 18 0Zm-9-3.75h.008v.008H12V8.25Z"},null,-1)]))}const _t=fe(Et,[["render",St]]),Mt={},Dt={xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"red",class:"size-6 text-red-600"};function zt(t,a){return e.openBlock(),e.createElementBlock("svg",Dt,a[0]||(a[0]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M6 18L18 6M6 6l12 12"},null,-1)]))}const Pt=fe(Mt,[["render",zt]]),$t={class:"rounded-md border border-gray-300 bg-white p-4 shadow-sm"},Lt={class:"flex items-start gap-4 opacity-100 scale-5 transition-all duration-300"},Ft={class:"flex-1"},At={class:"font-medium text-gray-900"},jt={class:"mt-0.5 text-sm text-gray-700"},Tt=e.defineComponent({__name:"vs-notify",props:{type:{},title:{},message:{}},setup(t){const a={success:kt,warning:Bt,error:Pt,info:_t};return(o,r)=>(e.openBlock(),e.createElementBlock("div",$t,[e.createElementVNode("div",Lt,[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(a[o.type]))),e.createElementVNode("div",Ft,[e.createElementVNode("strong",At,e.toDisplayString(o.title),1),e.createElementVNode("p",jt,e.toDisplayString(o.message),1)]),r[0]||(r[0]=e.createElementVNode("button",{class:"m-3 rounded-full p-1.5 text-gray-500 transition-colors hover:bg-gray-50 hover:text-gray-700",type:"button","aria-label":"Dismiss notify"},[e.createElementVNode("span",{class:"sr-only"},"Dismiss popup"),e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24","stroke-width":"1.5",stroke:"currentColor",class:"size-5"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round",d:"M6 18L18 6M6 6l12 12"})])],-1))])]))}});e.reactive({visible:!0});const Be={top:"top-4 left-1/2 transform -translate-x-1/2","left-bottom":"bottom-4 left-4 transform","right-bottom":"bottom-4 right-4 transform",bottom:"bottom-4 left-1/2 transform -translate-x-1/2"},be=t=>{var m;const{type:a="info",title:o,message:r,position:l="right-bottom"}=t||{};let s=document.querySelector("#notify-root");s||(s=document.createElement("div"),s.id="notify-root",s.className=`fixed z-[2000] flex flex-col gap-3 ${Be[l]} p-6 max-w-md mx-auto font-sans antialiased`,document.body.appendChild(s)),s.className.includes(Be[l])||(Object.values(Be).forEach(h=>{s.classList.remove(...h.split(" "))}),s.classList.add(...Be[l].split(" ")));const b=document.createElement("div");s.appendChild(b);const n=e.createApp({render(){return e.h(Tt,{type:a,title:o,message:r,onClose:()=>{n.unmount(),b.remove()}})}});n.mount(b),(m=b.querySelector("button"))==null||m.addEventListener("click",()=>{b.classList.add("opacity-0","scale-95","transition-all","duration-300"),setTimeout(()=>{n.unmount(),b.remove()},350)}),setTimeout(()=>{b.classList.add("opacity-0","scale-95","transition-all","duration-300"),setTimeout(()=>{n.unmount(),b.remove()},350)},3500)},de=(t,a)=>{const o=t.__vccOpts||t;for(const[r,l]of a)o[r]=l;return o},Ot={},vt={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-reload absolute inline mr-1 text-gray-800 transition-all cursor-pointer active:rotate-90 right-1 top-1 hover:text-blue-500"};function Rt(t,a){return e.openBlock(),e.createElementBlock("svg",vt,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M19.933 13.041a8 8 0 1 1 -9.925 -8.788c3.899 -1 7.935 1.007 9.425 4.747"},null,-1),e.createElementVNode("path",{d:"M20 4v5h-5"},null,-1)])])}const Zt=de(Ot,[["render",Rt]]),It={},Ut={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:"text-blue-600 w-[16px] h-[16px]"};function Kt(t,a){return e.openBlock(),e.createElementBlock("svg",Ut,[...a[0]||(a[0]=[e.createElementVNode("path",{d:"M20 6 9 17l-5-5"},null,-1)])])}const ge=de(It,[["render",Kt]]),Ht={class:"flex items-center cursor-pointer w-full"},Wt={key:0,width:"16",height:"auto",src:"data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTYgMTYnIGZpbGw9J3doaXRlJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnPjxwYXRoIGQ9J00xMi4yMDcgNC43OTNhMSAxIDAgMDEwIDEuNDE0bC01IDVhMSAxIDAgMDEtMS40MTQgMGwtMi0yYTEgMSAwIDAxMS40MTQtMS40MTRMNi41IDkuMDg2bDQuMjkzLTQuMjkzYTEgMSAwIDAxMS40MTQgMHonLz48L3N2Zz4="},qt=["value"],Yt={class:"flex flex-row items-center font-normal text-gray-800 gap-x-1"},Gt={key:0,class:"text-xs text-gray-500 dark:text-neutral-500 pr-1"},Qt={key:1,class:"absolute right-2 flex size-3.5 items-center justify-center"},De=e.defineComponent({__name:"list-item",props:{layout:{},count:{},type:{},label:{},value:{},isSelected:{type:Boolean},color:{},highlighted:{type:Boolean}},emits:["itemClick"],setup(t,{expose:a,emit:o}){const r=t,l=o;function s(){l("itemClick",r.value)}const b=e.ref(null),n=e.computed(()=>r.layout==="inline"&&r.type==="radio"),m=e.computed(()=>r.layout==="vertical"?"text-[13px]":"text-sm");return a({el:b}),(h,u)=>(e.openBlock(),e.createElementBlock("div",{class:"flex items-center w-full rounded-sm group hover:bg-gray-100",ref_key:"el",ref:b},[e.createElementVNode("div",{class:e.normalizeClass(["flex items-center justify-between w-full",m.value])},[e.createElementVNode("div",Ht,[e.createElementVNode("label",{for:"radio-9740",class:e.normalizeClass([["inline","popover"].includes(t.layout)?"text-gray-500 px-2 w-full py-2 cursor-pointer !flex flex-row items-center":"flex flex-row items-center w-full px-2 py-2 text-gray-500 cursor-pointer",{"bg-blue-100":t.highlighted,relative:n.value},m.value]),onClick:e.withModifiers(s,["stop","prevent"])},[n.value?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["w-[18px] h-[18px] border flex items-center justify-center",[t.type==="checkbox"?"rounded-[4px]":"rounded-full",t.color?`bg-[${t.color}] border-[#ffffff]`:t.isSelected?"bg-[#2563eb] border-[#ffffff]":"bg-[#ffffff] border-[#d9d9d9]"]])},[t.isSelected?(e.openBlock(),e.createElementBlock("img",Wt)):e.createCommentVNode("",!0)],2)),e.createElementVNode("input",{type:"checkbox",class:"hidden",id:"radio-9740",value:t.value},null,8,qt),e.createElementVNode("div",{class:e.normalizeClass(["flex flex-1 flex-row items-center justify-between",n.value?"pl-1 pr-6":"w-[calc(100%-18px)] pl-[10px]"])},[e.createElementVNode("span",Yt,e.toDisplayString(t.label??"Відсутні дані"),1),t.count?(e.openBlock(),e.createElementBlock("div",Gt," ("+e.toDisplayString(t.count)+") ",1)):e.createCommentVNode("",!0)],2),n.value&&t.isSelected?(e.openBlock(),e.createElementBlock("span",Qt,[e.createVNode(ge)])):e.createCommentVNode("",!0)],2)])],2)],512))}});function ze(t,a){const{api:o,options:r=[],limit:l=20,dataKey:s="data",data:b}=t,n=s??b??"data";function m(i){return Array.isArray(i)?i[0]:i}const h=e.ref(m(t.modelValue)),u=e.ref(""),f=e.ref(!1),y=e.ref([]),C=e.ref("id"),p=e.ref("text"),w=e.ref(!1),B=e.ref(t.layout!=="popover"&&r.length>l);function c(i){const V=i.find(Boolean)??{},g=["id","value","code","key"].find(F=>F in V)??"id",P=["text","label","name","title"].find(F=>F in V)??"text";return{autoValueKey:g,autoLabelKey:P}}function d(i){if(i.length>0){const g=c(i);C.value=g.autoValueKey,p.value=g.autoLabelKey}const V=[...i].sort((g,P)=>t.sort==="count"?P.count&&g.count?P.count-g.count:0:t.sort==="name"?String(g[p.value]??"").localeCompare(String(P[p.value]??"")):0);y.value=V}r.length>0&&d(r);const D=e.computed(()=>{const i=y.value;return t.layout==="popover"||w.value?i:i.slice(0,l)});async function L(){if(o){f.value=!0;try{const i=new URL(o,window.location.origin);i.searchParams.set("json","1"),i.searchParams.set("limit",l.toString());const V=await fetch(i.toString());if(!V.ok){be({type:"error",title:"Error",message:"Failed to fetch remote options"}),y.value=[];return}const g=await V.json();if(!g[n]){be({type:"error",title:"Error",message:g}),y.value=[];return}d(g[n])}catch(i){console.error("Failed to fetch remote options:",i)}finally{f.value=!1}}}function z(){o&&y.value.length===0&&L()}e.watch(()=>t.modelValue,i=>{h.value=m(i)},{immediate:!0}),o||d(r);function x(i){return h.value===i[C.value]}function k(i){h.value=i[C.value],a("update:modelValue",h.value),a("change",{name:t.name,value:h.value})}function M(){h.value=void 0,a("update:modelValue",h.value),a("clear",t.name)}function E(){w.value=!w.value}return{innerValue:h,searchTerm:u,filteredOptions:D,isSelected:x,selectItem:k,clear:M,toggleShowAll:E,isReqProc:f,showAll:w,isEnableShowAll:B,labelKey:p,valueKey:C,allOptions:y,loadData:z}}function Ze(t={color:"blue"}){return e.computed(()=>{const a=`w-full px-3 py-2 border-solid border text-black border-gray-300 text-sm rounded focus:outline-none focus:ring-2 focus:ring-${t.color}-500 focus:border-transparent
|
|
2
|
+
text-gray-800 bg-white dark:text-neutral-300 dark:bg-neutral-800 dark:border-neutral-600`;return(t==null?void 0:t.size)==="sm"?`${a}h-[32px]`:`${a}h-[38px]`})}function he(){return"rounded-md font-medium border-gray-200 border-solid disabled:pointer-events-none disabled:opacity-50 px-4 py-2 w-full bg-transparent border text-black text-sm h-[38px]"}function Xt(){return"font-medium border border-gray-200 border-solid disabled:pointer-events-none disabled:opacity-50 h-7 rounded-md text-xs px-2 py-1 text-gray-800 bg-white hover:bg-gray-100 dark:text-neutral-300 dark:bg-neutral-800 dark:hover:bg-neutral-700 dark:border-neutral-600"}function Ie(t){return t==="ghost"?"inline-flex relative py-2 px-4 items-center gap-x-2 text-sm font-medium rounded-sm border text-gray-600 hover:bg-blue-100 hover:text-gray-800 focus:outline-hidden focus:bg-gray-100 focus:text-gray-800 disabled:opacity-50 disabled:pointer-events-none dark:text-gray-500 dark:hover:bg-blue-800/30 dark:hover:text-blue-400 dark:focus:bg-blue-800/30 dark:focus:text-blue-400":t==="soft"?"inline-flex relative py-2 px-4 items-center gap-x-2 text-sm font-medium rounded-sm border bg-white-100 text-gray-800 hover:bg-gray-200 hover:bg-gray-200 focus:outline-hidden focus:bg-gray-200 disabled:opacity-50 disabled:pointer-events-none dark:text-blue-400 dark:hover:bg-blue-900 dark:focus:bg-blue-900":"relative border-solid border-gray-200 focus-visible:outline-hidden focus-visible:ring-ring inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border-input hover:bg-gray-100 border px-4 py-2 gap-1 bg-transparent h-[38px]"}const Ue={en:{apply:"Apply",search:"Search",more:"Show more",less:"Show less",selected:"selected",clear:"Clear",notfound:"Nothing found",period:"Period",today:"Today",week:"Week",max:"max",min:"min",month:"Month",quarter:"Quarter",year:"Year",alltime:"All Time",prev:"Prev",next:"Next",selectFieldHelp:"Select a field to start creating a filter."},uk:{apply:"Застосувати",search:"Пошук",more:"Показати більше",less:"Показати меньше",selected:"обрано",clear:"Очистити",notfound:"Нічого не знайдено",period:"Період",today:"Сьогодні",week:"Тиждень",max:"макс",min:"мін",month:"Місяць",quarter:"Квартал",year:"Рік",alltime:"Весь час",prev:"Попередній період",next:"Настпуний період",selectFieldHelp:"Оберіть поле, щоб розпочати створення фільтра."}};function Ke(t){const a=t.split(".")[1],o=typeof window<"u"&&window.localStorage?localStorage.locale:null;return(Ue[o||navigator.language]||Ue.uk)[a]}function ae(){const t=e.getCurrentInstance();if(!t.appContext.config.globalProperties.$i18n)return Ke;const a=t.appContext.config.globalProperties.$t;return o=>{const r=a(o);return r===o?Ke(o):r}}const Jt={},el={class:"w-48 mx-auto",viewBox:"0 0 178 90",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function tl(t,a){return e.openBlock(),e.createElementBlock("svg",el,[...a[0]||(a[0]=[e.createStaticVNode('<rect x="27" y="50.5" width="124" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="27" y="50.5" width="124" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-50 dark:stroke-neutral-700/10"></rect><rect x="34.5" y="58" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="61" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="73" width="77" height="6" rx="3" fill="currentColor" class="fill-gray-50 dark:fill-neutral-700/30"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-100 dark:stroke-neutral-700/30"></rect><rect x="27" y="36" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><rect x="59" y="39" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><rect x="59" y="51" width="92" height="6" rx="3" fill="currentColor" class="fill-gray-100 dark:fill-neutral-700/70"></rect><g filter="url(#filter1)"><rect x="12" y="6" width="154" height="40" rx="8" fill="currentColor" class="fill-white dark:fill-neutral-800" shape-rendering="crispEdges"></rect><rect x="12.5" y="6.5" width="153" height="39" rx="7.5" stroke="currentColor" class="stroke-gray-100 dark:stroke-neutral-700/60" shape-rendering="crispEdges"></rect><rect x="20" y="14" width="24" height="24" rx="4" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect><rect x="52" y="17" width="60" height="6" rx="3" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect><rect x="52" y="29" width="106" height="6" rx="3" fill="currentColor" class="fill-gray-200 dark:fill-neutral-700"></rect></g><defs><filter id="filter1" x="0" y="0" width="178" height="64" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB"><feFlood flood-opacity="0" result="BackgroundImageFix"></feFlood><feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"></feColorMatrix><feOffset dy="6"></feOffset><feGaussianBlur stdDeviation="6"></feGaussianBlur><feComposite in2="hardAlpha" operator="out"></feComposite><feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0"></feColorMatrix><feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_1187_14810"></feBlend><feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_1187_14810" result="shape"></feBlend></filter></defs>',12)])])}const Pe=de(Jt,[["render",tl]]),ll={},ol={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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down w-[14px] rotate"};function nl(t,a){return e.openBlock(),e.createElementBlock("svg",ol,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)])])}const Ee=de(ll,[["render",nl]]),al={},rl={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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down w-[14px] rotate-[180deg]"};function il(t,a){return e.openBlock(),e.createElementBlock("svg",rl,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)])])}const $e=de(al,[["render",il]]),sl={key:0,class:"w-full"},cl={class:"flex flex-col items-center justify-center p-5 text-center"},dl={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ml={key:1,class:"py-2 px-2"},pl=["disabled"],ul=e.defineComponent({__name:"radio",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=e.ref(null),s=he(),b=ae(),n=o,{innerValue:m,filteredOptions:h,isSelected:u,selectItem:f,clear:y,toggleShowAll:C,isReqProc:p,showAll:w,isEnableShowAll:B,labelKey:c,valueKey:d,allOptions:D,loadData:L}=ze({...r,modelValue:r.modelValue??r.default??""},n);return e.onMounted(()=>{r.api&&L()}),a({clear:y,inputTextRef:l}),e.watch(()=>r.modelValue,z=>{z===void 0&&(m.value=void 0)}),(z,x)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([t.layout==="popover"?"flex flex-col max-h-full":"flex flex-col vs-filter-checkbox"])},[e.createElementVNode("div",{class:e.normalizeClass([t.layout==="popover"?"flex-1 overflow-y-auto p-2":"",t.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(h),k=>(e.openBlock(),e.createBlock(De,{layout:t.layout,key:k[e.unref(d)],count:k.count,label:k[e.unref(c)],color:k.color,type:"radio",value:k[e.unref(d)],"is-selected":e.unref(u)(k),onItemClick:M=>e.unref(f)(k)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),128))],2),t.type==="select"&&e.unref(h).length===0&&!e.unref(p)?(e.openBlock(),e.createElementBlock("div",sl,[e.createElementVNode("div",cl,[e.createVNode(Pe),x[4]||(x[4]=e.createElementVNode("div",{class:"max-w-sm mx-auto mt-6"},[e.createElementVNode("p",{class:"font-medium text-gray-800 dark:text-neutral-200"},"За вашим запитом нічого не знайдено"),e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"})],-1))])])):e.createCommentVNode("",!0),t.layout!=="popover"&&t.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(w)&&e.unref(B)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:x[0]||(x[0]=(...k)=>e.unref(C)&&e.unref(C)(...k)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[x[5]||(x[5]=e.createTextVNode(" Показати більше ",-1)),e.createVNode(Ee)])):e.createCommentVNode("",!0),e.unref(w)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:x[1]||(x[1]=(...k)=>e.unref(C)&&e.unref(C)(...k)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[x[6]||(x[6]=e.createTextVNode(" Показати менше ",-1)),e.createVNode($e)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),t.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[t.layout==="inline"?(e.openBlock(),e.createElementBlock("div",dl,[e.createTextVNode(e.toDisplayString(e.unref(m)||e.unref(m)===null?1:0)+" з "+e.toDisplayString(e.unref(D).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:x[2]||(x[2]=(...k)=>e.unref(y)&&e.unref(y)(...k))}," Очистити ",512),[[e.vShow,e.unref(m)!==""&&e.unref(m)!==void 0]])])):e.createCommentVNode("",!0),t.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ml,[e.createElementVNode("button",{type:"button",disabled:!(e.unref(m)!==""&&e.unref(m)!==void 0),class:e.normalizeClass(e.unref(s)+" hover:bg-gray-100"),onClick:x[3]||(x[3]=(...k)=>e.unref(y)&&e.unref(y)(...k))},e.toDisplayString(e.unref(b)("filter.clear")),11,pl)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}});function He(t,a){const{api:o,options:r=[],limit:l=20,dataKey:s="data",data:b}=t,n=s??b??"data";function m(i){return Array.isArray(i)?i:i?[i]:[]}const h=e.ref(m(t.modelValue)),u=e.ref(""),f=e.ref(!1),y=e.ref([]),C=e.ref("id"),p=e.ref("text"),w=e.ref(!1),B=e.ref(t.layout!=="popover"&&r.length>l);function c(i){const V=i.find(Boolean)??{},g=["id","value","code","key"].find(F=>F in V)??"id",P=["text","label","name","title"].find(F=>F in V)??"text";return{autoValueKey:g,autoLabelKey:P}}function d(i){if(i.length>0){const g=c(i);C.value=g.autoValueKey,p.value=g.autoLabelKey}const V=[...i].sort((g,P)=>t.sort==="count"?P.count&&g.count?P.count-g.count:0:t.sort==="name"?String(g[p.value]).localeCompare(String(P[p.value])):0);y.value=V}r.length>0&&d(r);const D=e.computed(()=>{const i=y.value;return t.layout==="popover"||w.value?i:i.slice(0,l)});async function L(){if(o){f.value=!0;try{const i=new URL(o,window.location.origin);i.searchParams.set("json","1"),i.searchParams.set("limit",l.toString());const V=await fetch(i.toString());if(!V.ok){be({type:"error",title:"Error",message:"Failed to fetch remote options"}),y.value=[];return}const g=await V.json();if(!g[n]){be({type:"error",title:"Error",message:g}),y.value=[];return}d(g[n])}catch(i){console.error("Failed to fetch remote options:",i)}finally{f.value=!1}}}function z(){o&&y.value.length===0&&L()}e.watch(()=>t.modelValue,i=>{h.value=m(i)},{immediate:!0}),o||d(r);function x(i){return h.value&&h.value.includes(i[C.value])}function k(i){const V=h.value.includes(i[C.value]);h.value=V?h.value.filter(g=>g!==i[C.value]):[...h.value,i[C.value]],a("update:modelValue",h.value),a("change",{name:t.name,value:h.value})}function M(){h.value=[],a("update:modelValue",h.value),a("clear",t.name)}function E(){w.value=!w.value}return{innerValue:h,searchTerm:u,filteredOptions:D,isSelected:x,selectItem:k,clear:M,toggleShowAll:E,isReqProc:f,showAll:w,isEnableShowAll:B,labelKey:p,valueKey:C,allOptions:y,loadData:z}}const fl={key:0,class:"w-full"},gl={class:"flex flex-col items-center justify-center p-5 text-center"},hl={class:"max-w-sm mx-auto mt-6"},yl={class:"font-medium text-gray-800 dark:text-neutral-200"},bl={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},xl={key:1,class:"py-2 px-2 border-t"},kl=["disabled"],wl={class:"text-xs text-gray-500"},We=e.defineComponent({__name:"checkbox",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=ae(),l=he(),s=t,b=o,{innerValue:n,filteredOptions:m,isSelected:h,selectItem:u,clear:f,toggleShowAll:y,isReqProc:C,showAll:p,isEnableShowAll:w,labelKey:B,valueKey:c,allOptions:d,loadData:D}=He({...s,modelValue:s.modelValue},b);return e.onMounted(()=>{s.api&&D()}),e.watch(()=>s.modelValue,L=>{L===void 0&&(n.value=[])}),a({clear:f}),(L,z)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([t.layout==="popover"?"flex flex-col max-h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",{class:e.normalizeClass([t.layout==="popover"?"flex-1 overflow-y-auto p-2":"",t.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(m),x=>(e.openBlock(),e.createBlock(De,{layout:t.layout,count:x.count,label:x[e.unref(B)],color:x.color,type:"checkbox",value:x[e.unref(c)],"is-selected":e.unref(h)(x),onItemClick:k=>e.unref(u)(x)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),256))],2),t.type==="select"&&e.unref(m).length===0&&!e.unref(C)?(e.openBlock(),e.createElementBlock("div",fl,[e.createElementVNode("div",gl,[e.createVNode(Pe),e.createElementVNode("div",hl,[e.createElementVNode("p",yl,e.toDisplayString(e.unref(r)("filter.notfound")),1),z[4]||(z[4]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),t.layout!=="popover"&&t.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(p)&&e.unref(w)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:z[0]||(z[0]=(...x)=>e.unref(y)&&e.unref(y)(...x)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.more"))+" ",1),e.createVNode(Ee)])):e.createCommentVNode("",!0),e.unref(p)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:z[1]||(z[1]=(...x)=>e.unref(y)&&e.unref(y)(...x)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.less"))+" ",1),e.createVNode($e)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),t.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[t.layout==="inline"?(e.openBlock(),e.createElementBlock("div",bl,[e.createTextVNode(e.toDisplayString(e.unref(n).length)+" / "+e.toDisplayString(e.unref(d).length)+" "+e.toDisplayString(e.unref(r)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:z[2]||(z[2]=(...x)=>e.unref(f)&&e.unref(f)(...x))},e.toDisplayString(e.unref(r)("filter.clear")),513),[[e.vShow,e.unref(n).length!==0]])])):e.createCommentVNode("",!0),t.layout==="popover"?(e.openBlock(),e.createElementBlock("div",xl,[e.createElementVNode("button",{type:"button",disabled:e.unref(n).length===0,class:e.normalizeClass(e.unref(l)+" hover:bg-gray-100"),onClick:z[3]||(z[3]=(...x)=>e.unref(f)&&e.unref(f)(...x))},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.clear"))+" ",1),e.createElementVNode("span",wl,e.toDisplayString(e.unref(n).length)+" з "+e.toDisplayString(e.unref(d).length),1)],10,kl)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}}),Vl={},Cl={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"15px",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-search stroke-gray-500 transition-all"};function Bl(t,a){return e.openBlock(),e.createElementBlock("svg",Cl,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M10 10m-7 0a7 7 0 1 0 14 0a7 7 0 1 0 -14 0"},null,-1),e.createElementVNode("path",{d:"M21 21l-6 -6"},null,-1)])])}const qe=de(Vl,[["render",Bl]]),El={},Nl={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:"icon icon-tabler icons-tabler-outline icon-tabler-x stroke-gray-500 hover:stroke-red-500 transition-all",width:"15px",height:"15px"};function Sl(t,a){return e.openBlock(),e.createElementBlock("svg",Nl,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M18 6l-12 12"},null,-1),e.createElementVNode("path",{d:"M6 6l12 12"},null,-1)])])}const Le=de(El,[["render",Sl]]);class Ye{static getWidthClass(a){return typeof a=="number"?`max-w-[${a}px] min-w-[${a}px]`:typeof a=="string"?a.endsWith("%")||a.endsWith("px")?`max-w-[${a}]`:`max-w-${a}`:"w-full"}}const _l={class:"absolute bottom-2/4 translate-y-2/4 cursor-pointer left-3"},Ml=["placeholder"],Dl=e.defineComponent({__name:"text-input",props:{id:{},name:{},title:{},type:{},label:{},width:{default:220},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{emit:a}){var h;const o=t,r=e.ref((o.placeholder||o.label||o.title||o.name||"search").toString()),l=a,s=e.ref(((h=o.modelValue)==null?void 0:h.toString())??"");e.watch(()=>o.modelValue,u=>{u!==s.value&&(s.value=(u==null?void 0:u.toString())??"")});let b=null;function n(){if(s.value=s.value.trimStart(),s.value.length===0){m();return}b&&clearTimeout(b),b=setTimeout(()=>{l("update:modelValue",s.value),l("change",{name:o.name,value:s.value})},300)}function m(){s.value="",l("update:modelValue",""),l("clear",o.name)}return(u,f)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["vs-form-text relative bg-white [&>input]:py-[7px] [&>input]:max-h-[38px] [&>input]:ps-10 [&>input]:pe-8 [&>input]:block [&>input]:w-full [&>input]:bg-gray-100 [&>input]:border-transparent [&>input]:text-sm [&>input]:focus:bg-white [&>input]:focus:border-blue-500 [&>input]:focus:ring-blue-500 [&>input]:disabled:opacity-50 [&>input]:disabled:pointer-events-none [&>input]:dark:bg-neutral-700 [&>input]:dark:border-transparent [&>input]:dark:text-neutral-400 [&>input]:dark:placeholder:text-neutral-400 dark:focus:bg-neutral-800 dark:focus:ring-neutral-600",t.layout==="vertical"?"rounded-md":"rounded-sm",t.layout==="vertical"?"[&>input]:rounded-md":"[&>input]:rounded-sm",t.layout==="inline"?e.unref(Ye).getWidthClass(t.width):"mb-2"+(t.layout==="popover"?" m-2":"")])},[e.createElementVNode("div",_l,[e.createVNode(qe)]),s.value!==""?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:m,class:"absolute bottom-2/4 translate-y-2/4 right-3 cursor-pointer"},[e.createVNode(Le)])):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"text","onUpdate:modelValue":f[0]||(f[0]=y=>s.value=y),onInput:n,placeholder:r.value,class:e.normalizeClass(["!pr-7 !pl-8 bg-white h-[38px] min-w-[100px] text-sm py-2 px-3 block w-full border border-solid placeholder:text-nowrap border-stone-200 text-sm text-stone-800 placeholder:text-stone-400 focus:border-2 focus:z-10 focus:border-blue-500 focus:ring-blue-500 focus:outline-blue-500",t.layout==="vertical"?"rounded-md":"rounded-sm"])},null,42,Ml),[[e.vModelText,s.value]])],2))}}),zl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Pl=["placeholder","disabled"],$l={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Ll={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Fl=["placeholder","disabled"],Al=["disabled"],jl=e.defineComponent({__name:"range-input",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=Ze(),l=he(),s=ae(),b=t,n=e.ref(b.modelValue??b.default??[]),m=o,h=e.computed({get:()=>b.modelValue??n.value,set:y=>{b.modelValue!==void 0?m("update:modelValue",y):n.value=y}});function u(){m("change",{name:b.name,value:h.value||n.value})}function f(){n.value=[],h.value=n.value,m("clear",b.name)}return e.watch(()=>b.modelValue,y=>{y!==void 0&&b.layout!=="popover"?(n.value=y,m("update:modelValue",y)):n.value=[]}),a({clear:f,currentValue:h}),(y,C)=>{var p,w;return e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",null,[e.createElementVNode("div",{class:e.normalizeClass(t.layout==="vertical"?"inline-flex items-center gap-2":"space-y-3 p-2")},[e.createElementVNode("div",null,[t.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",zl,e.toDisplayString(e.unref(s)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(r)),placeholder:((p=t.placeholder)==null?void 0:p[0])??e.unref(s)("filter.min"),step:"1",style:{outline:"none"},"onUpdate:modelValue":C[0]||(C[0]=B=>h.value[0]=B),disabled:t.disabled},null,10,Pl),[[e.vModelText,h.value[0]]])]),t.layout==="vertical"?(e.openBlock(),e.createElementBlock("label",$l," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",null,[t.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",Ll,e.toDisplayString(e.unref(s)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(r)),placeholder:((w=t.placeholder)==null?void 0:w[1])??e.unref(s)("filter.max"),min:"0",max:"1000000000000000",step:"1",style:{outline:"none"},"onUpdate:modelValue":C[1]||(C[1]=B=>h.value[1]=B),disabled:t.disabled},null,10,Fl),[[e.vModelText,h.value[1]]])]),["popover","inline","vertical"].includes(t.layout)?(e.openBlock(),e.createElementBlock("button",{key:1,onClick:u,class:e.normalizeClass(e.unref(l)+(t.layout==="vertical"?" w-[50px]":" bg-blue-100 hover:bg-blue-200"))},e.toDisplayString(t.layout==="vertical"?"Ok":e.unref(s)("filter.apply")),3)):e.createCommentVNode("",!0),["popover","inline"].includes(t.layout)?(e.openBlock(),e.createElementBlock("button",{key:2,disabled:!(h.value[0]||h.value[1]),onClick:f,class:e.normalizeClass(e.unref(l)+" hover:bg-gray-100")},e.toDisplayString(e.unref(s)("filter.clear")),11,Al)):e.createCommentVNode("",!0)],2)]),(t.cleanable&&n.value.length,e.createCommentVNode("",!0))],64)}}});class X{static format(a){const o=a.getFullYear(),r=(a.getMonth()+1).toString().padStart(2,"0"),l=a.getDate().toString().padStart(2,"0");return`${o}-${r}-${l}`}static getShiftedDay(a,o=0){const r=a?new Date(a):new Date;return r.setDate(r.getDate()+o),this.format(r)}static getLastWeekRange(a,o,r=0){if(a&&o){const h=new Date(a),u=new Date(o);return h.setDate(h.getDate()+r*7),u.setDate(u.getDate()+r*7),[this.format(h),this.format(u)]}const l=new Date,s=l.getDay(),b=s===0?13:s-1+7,n=new Date(l);n.setDate(l.getDate()-b+r*7);const m=new Date(n);return m.setDate(n.getDate()+6),[this.format(n),this.format(m)]}static getMonthRange(a,o,r=0){let l;a?l=new Date(a):l=new Date,l=new Date(l.getFullYear(),l.getMonth()+r,1);const s=l,b=new Date(l.getFullYear(),l.getMonth()+1,0);return[this.format(s),this.format(b)]}static getQuarterRange(a,o,r=0){const l=a||o,s=l?new Date(l):new Date;let b=Math.floor(s.getMonth()/3);b+=r;const n=(b%4+4)%4*3,m=s.getFullYear()+Math.floor(b/4),h=new Date(m,n,1),u=new Date(m,n+3,0);return[this.format(h),this.format(u)]}static getYear(a,o=0){let r;return a&&/^\d{4}$/.test(a)?r=parseInt(a,10):a?r=new Date(a).getFullYear():r=new Date().getFullYear(),String(r+o)}static getYearRange(a,o=0){let r;return a&&/^\d{4}$/.test(a)?r=parseInt(a,10):a?r=new Date(a).getFullYear():r=new Date().getFullYear(),[this.format(new Date(r+o,0,1)),this.format(new Date(r+o+1,0,0))]}static getRangeFromDaysBefore(a){const o=new Date,r=new Date(o.getTime());return r.setDate(o.getDate()-a),[this.format(r),this.format(o)]}}function Ge(t,a){const{popoverRef:o}=t,r=ae(),l=e.ref(""),s=e.ref(t.modelValue??t.default??[]),b=e.ref(0);function n(){const c=X.getRangeFromDaysBefore(b.value);return s.value=[...c],a("change",{name:t.name,value:s.value}),a("update:modelValue",s.value),c}function m(c){var D;l.value=c,(D=o.value)==null||D.close();const d=[];switch(l.value){case"today":d.push(X.getShiftedDay()),d.push(X.getShiftedDay());break;case"week":d.push(...X.getLastWeekRange());break;case"month":d.push(...X.getMonthRange());break;case"quarter":d.push(...X.getQuarterRange());break;case"year":d.push(...X.getYearRange());break;case"last_7_days":b.value=7,n();break;case"range":b.value=7,d.push(...n());break}s.value=[...d],a("change",{name:t.name,value:s.value}),a("update:modelValue",s.value)}function h(){const c=[];switch(l.value){case"today":c.push(X.getShiftedDay(s.value[0],1));break;case"week":c.push(...X.getLastWeekRange(s.value[0],s.value[1],1));break;case"month":c.push(...X.getMonthRange(s.value[0],s.value[1],1));break;case"quarter":c.push(...X.getQuarterRange(s.value[0],s.value[1],1));break;case"year":c.push(...X.getYearRange(s.value[0],1));break}s.value=[...c],a("change",{name:t.name,value:s.value}),a("update:modelValue",s.value)}function u(){const c=[];switch(l.value){case"today":c.push(X.getShiftedDay(s.value[0],-1));break;case"week":c.push(...X.getLastWeekRange(s.value[0],s.value[1],-1));break;case"month":c.push(...X.getMonthRange(s.value[0],s.value[1],-1));break;case"quarter":c.push(...X.getQuarterRange(s.value[0],s.value[1],-1));break;case"year":c.push(...X.getYearRange(s.value[0],-1));break}s.value=[...c],a("change",{name:t.name,value:s.value}),a("update:modelValue",s.value)}const f=["Січень","Лютий","Березень","Квітень","Травень","Червень","Липень","Серпень","Вересень","Жовтень","Листопад","Грудень"];function y(c){const[d,D,L]=c.split("-");return`${L}.${D}.${d}`}function C(c,d="long"){const D=new Date(Date.UTC(2e3,c-1,1));return new Intl.DateTimeFormat(localStorage.locale,{month:d,timeZone:"UTC"}).format(D)}function p(c){const{value:d}=s;switch(c){case"today":return y(d[0]);case"range":return"Період";case"week":return d[0]&&d[1]?`${y(d[0])} – ${y(d[1])}`:"";case"quarter":if(d[0]){const D=new Date(d[0]),L=D.getFullYear(),z=D.getMonth();return`${Math.floor(z/3)+1} ${r("filter.quarter")} ${L}`}return"";case"month":if(d[0]){const[D,L]=d[0].split("-");return`${C(parseInt(L,10))} ${D}`}return"";case"year":return d[0]||"";case"last_7_days":return"За останні дні";default:return t.label??""}}const w=e.computed(()=>l.value?p(l.value):t.label??"");function B(){l.value="",s.value=[],a("update:modelValue",[]),a("clear",t.name)}return{activeMode:l,innerValue:s,daysBefore:b,onDaysBeforeChange:n,onSelectChange:m,nextClick:h,prevClick:u,ukMonths:f,formatDisplayDate:y,getModeLabel:p,currentLabel:w,clear:B}}const Tl={key:0,class:"relative flex w-full h-auto gap-2 filter-date m-2 flex-wrap"},Ol={key:0,class:"flex gap-1 !w-[75%] rounded-sm"},vl=["max","disabled"],Rl=["min","disabled"],Zl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Il=["max","disabled"],Ul={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Kl={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},Hl=["min","disabled"],Wl={class:"flex gap-1 px-2"},ql=["title","onClick"],Yl={class:"pt-2 px-2"},Gl=["disabled"],Ql=e.defineComponent({__name:"date-input",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=Ze(),s=he(),b=Xt(),n=ae(),m=o,h=e.ref(null),{activeMode:u,innerValue:f,onSelectChange:y,nextClick:C,prevClick:p,clear:w}=Ge({...r,popoverRef:h},m);e.watch(()=>r.modelValue,L=>{L!==void 0?(f.value=L,m("update:modelValue",L)):(u.value="",f.value=[])}),e.watch(f,L=>{m("update:modelValue",L),m("change",{name:r.name,value:L})},{deep:!0});const B=["today","week","month","quarter","year"],c={today:{label:"день",title:n("filter.today")},week:{label:"тиж.",title:n("filter.week")},month:{label:"міс.",title:n("filter.month")},quarter:{label:"кв.",title:n("filter.quarter")},year:{label:"рік",title:n("filter.year")}};function d(L){var z;return((z=c[L])==null?void 0:z.label)??n(`filter.${L}`)}function D(L){var z;return((z=c[L])==null?void 0:z.title)??n(`filter.${L}`)}return a({clear:w,popoverRef:h}),(L,z)=>{var x;return e.openBlock(),e.createElementBlock(e.Fragment,null,[t.layout==="inline"?(e.openBlock(),e.createElementBlock("div",Tl,[e.unref(u)!==""&&e.unref(u)==="range"?(e.openBlock(),e.createElementBlock("div",Ol,[z[7]||(z[7]=e.createTextVNode(" 1111 ",-1)),e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(f)[1],locale:"uk-UA","onUpdate:modelValue":z[0]||(z[0]=k=>e.unref(f)[0]=k),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:t.disabled},null,8,vl),[[e.vModelText,e.unref(f)[0]]]),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(f)[0],locale:"uk-UA","onUpdate:modelValue":z[1]||(z[1]=k=>e.unref(f)[1]=k),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:t.disabled},null,8,Rl),[[e.vModelText,e.unref(f)[1]]])])):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(t.layout==="popover"?"space-y-3 p-2":"flex items-center gap-2")},[e.createElementVNode("div",{class:e.normalizeClass(t.layout!=="popover"?"w-[48%]":"")},[t.layout==="popover"?(e.openBlock(),e.createElementBlock("label",Zl,e.toDisplayString(e.unref(n)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(f)[1],locale:"uk-UA","onUpdate:modelValue":z[2]||(z[2]=k=>e.unref(f)[0]=k),class:e.normalizeClass(e.unref(l)),disabled:t.disabled},null,10,Il),[[e.vModelText,e.unref(f)[0]]])],2),t.layout!=="popover"?(e.openBlock(),e.createElementBlock("label",Ul," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(t.layout!=="popover"?"w-[48%]":"")},[t.layout==="popover"?(e.openBlock(),e.createElementBlock("label",Kl,e.toDisplayString(e.unref(n)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(f)[0],locale:"uk-UA","onUpdate:modelValue":z[3]||(z[3]=k=>e.unref(f)[1]=k),class:e.normalizeClass(e.unref(l)),disabled:t.disabled},null,10,Hl),[[e.vModelText,e.unref(f)[1]]])],2)],2),e.createElementVNode("div",Wl,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(B,k=>e.createElementVNode("button",{key:k,class:e.normalizeClass(e.unref(b)+(e.unref(u)===k?" bg-blue-100":"")),title:D(k),onClick:M=>e.unref(y)(k)},e.toDisplayString(d(k)),11,ql)),64)),e.createElementVNode("button",{class:e.normalizeClass(e.unref(b)),onClick:z[4]||(z[4]=(...k)=>e.unref(p)&&e.unref(p)(...k))},"<",2),e.createElementVNode("button",{class:e.normalizeClass(e.unref(b)),onClick:z[5]||(z[5]=(...k)=>e.unref(C)&&e.unref(C)(...k))},">",2)]),e.createElementVNode("div",Yl,[["popover"].includes(t.layout)?(e.openBlock(),e.createElementBlock("button",{key:0,type:"button",disabled:!((x=e.unref(f))!=null&&x.length)||!e.unref(f)[0]&&!e.unref(f)[1],class:e.normalizeClass(e.unref(s)+"hover:bg-gray-100"),onClick:z[6]||(z[6]=(...k)=>e.unref(w)&&e.unref(w)(...k))},e.toDisplayString(e.unref(n)("filter.clear")),11,Gl)):e.createCommentVNode("",!0)])],64)}}});function Xl(t,a){const{api:o,options:r=[],limit:l=20,dataKey:s="data",data:b}=t,n=s??b??"data",m=t.multi;function h(_){return m?Array.isArray(_)?_:_?[_]:[]:Array.isArray(_)?_[0]:_}const u=e.ref(h(t.modelValue)),f=e.ref(""),y=e.ref(!1),C=e.ref(r),p=e.ref("id"),w=e.ref("text"),B=e.ref(!1),c=e.ref(t.layout!=="popover"&&r.length>l),d=e.ref([]),D=e.ref(0);function L(_){const v=_.find(Boolean)??{},U=["id","value","code","key"].find(te=>te in v)??"id",Z=["text","label","name","title"].find(te=>te in v)??"text";return{autoValueKey:U,autoLabelKey:Z}}if(r.length>0){const _=L(r);p.value=_.autoValueKey,w.value=_.autoLabelKey}const z=e.computed(()=>{if(o)return C.value;const _=C.value;if(t.layout==="popover")return _;if(!f.value)return B.value?_:_.slice(0,l);const v=f.value.toLowerCase();return _.filter(U=>U[w.value].toLowerCase().includes(v))});let x=null;async function k(_){if(o){y.value=!0;try{const v=new URL(o,window.location.origin);v.searchParams.set("json","1"),v.searchParams.set("key",_),v.searchParams.set("limit",l.toString());const U=await fetch(v.toString());if(!U.ok){be({type:"error",title:"Error",message:"Failed to fetch remote options"}),C.value=[];return}const Z=await U.json();if(!Z[n]){be({type:"error",title:"Error",message:Z}),C.value=[];return}if(C.value=Z[n],C.value.length>0){const te=L(C.value);p.value=te.autoValueKey,w.value=te.autoLabelKey}D.value=Z.total}catch(v){console.error("Failed to fetch remote options:",v)}finally{y.value=!1}}}e.watch(f,_=>{o&&(x&&clearTimeout(x),x=setTimeout(()=>{k(_)},200))}),e.watch(()=>t.modelValue,_=>{u.value=h(_)},{immediate:!0}),e.watch(u,_=>{m?(!Array.isArray(_)||_.length===0)&&(d.value=[]):(_==null||typeof _=="string"&&_==="")&&(d.value=[])});function M(_){return m&&Array.isArray(u.value)?u.value.includes(_[p.value]):u.value&&u.value===_[p.value]}function E(_){if(m&&!Array.isArray(u.value)&&(u.value=[]),m&&Array.isArray(u.value)){const v=u.value.includes(_[p.value]);u.value=v?u.value.filter(U=>U!==_[p.value]):[...u.value,_[p.value]],d.value=v?d.value.filter(U=>U!==_[w.value]):[...d.value,_[w.value]]}else u.value=_[p.value],d.value=_[w.value];a("update:modelValue",u.value),a("change",{name:t.name,value:u.value})}function i(){m?(u.value=[],d.value=[]):(u.value=void 0,d.value=[]),a("update:modelValue",u.value),a("clear",t.name)}function V(){x&&clearTimeout(x),f.value="",B.value=!1}function g(){B.value=!B.value}e.onBeforeUnmount(()=>{x&&clearTimeout(x)});const P=e.ref(-1);e.watch(z,()=>{P.value=z.value.length>0?0:-1});function F(_){const v=z.value.length;if(_.key==="ArrowDown")_.preventDefault(),P.value=(P.value+1)%v;else if(_.key==="ArrowUp")_.preventDefault(),P.value=(P.value-1+v)%v;else if(_.key==="Enter"&&(_.preventDefault(),P.value>=0&&P.value<z.value.length)){const U=z.value[P.value];E(U)}}function O(){o&&C.value.length===0&&f.value.length===0&&k(f.value)}return{innerValue:u,searchTerm:f,filteredOptions:z,isSelected:M,selectItem:E,clear:i,resetSearch:V,toggleShowAll:g,isReqProc:y,showAll:B,isEnableShowAll:c,labelKey:w,valueKey:p,allOptions:C,highlightedIndex:P,onKeyDown:F,selectedLabels:d,totalCount:D,loadData:O}}const Jl={class:"h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relative justify-center"},eo=["placeholder"],to={key:0,class:"w-full"},lo={class:"flex flex-col items-center justify-center p-5 text-center"},oo={class:"max-w-sm mx-auto mt-6"},no={class:"font-medium text-gray-800 dark:text-neutral-200"},ao={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ro={key:1,class:"py-2 px-2 border-t"},io=["disabled"],so={class:"text-xs text-gray-500"},co=e.defineComponent({__name:"select",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=ae(),l=he(),s=t,b=o,n=e.ref(null),{innerValue:m,filteredOptions:h,isSelected:u,selectItem:f,clear:y,resetSearch:C,toggleShowAll:p,isReqProc:w,showAll:B,isEnableShowAll:c,searchTerm:d,labelKey:D,valueKey:L,highlightedIndex:z,onKeyDown:x,selectedLabels:k,totalCount:M,loadData:E}=Xl({...s,modelValue:s.modelValue},b),i=e.computed(()=>s.multi?Array.isArray(m.value)&&m.value.length>0:m.value!=null&&m.value!==""),V=e.computed(()=>s.multi&&Array.isArray(m.value)?m.value.length:m.value!=null&&m.value!==""?1:0);e.onMounted(()=>{C(),s.layout!=="inline"&&(E(),n.value&&s.layout==="popover"&&n.value.focus())}),e.watch(()=>s.modelValue,P=>{P===void 0&&(s.multi?m.value=[]:m.value=void 0)});const g=e.ref([]);return e.watch(z,P=>{var F;P>=0&&g.value[P]&&((F=g.value[P])==null||F.scrollIntoView({block:"nearest",behavior:"smooth"}))}),e.watch(h,()=>{g.value=[]}),a({clear:y,inputTextRef:n,selectedLabels:k,loadData:E}),(P,F)=>{var O;return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([t.layout==="popover"?"flex flex-col max-h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",Jl,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":F[0]||(F[0]=_=>e.isRef(d)?d.value=_:null),onKeydown:F[1]||(F[1]=(..._)=>e.unref(x)&&e.unref(x)(..._)),class:"w-full h-full text-[13px] px-4 border rounded-sm pl-9 focus:outline-none focus:ring-ring focus:ring-1 focus:ring-blue-500 text-gray-700",placeholder:e.unref(r)("filter.search"),type:"text",ref_key:"inputTextRef",ref:n},null,40,eo),[[e.vModelText,e.unref(d)]]),e.createVNode(qe,{class:"absolute text-gray-400 -translate-y-1/2 left-4 top-1/2"}),e.unref(d)!=""?(e.openBlock(),e.createBlock(Le,{key:0,onClick:F[2]||(F[2]=_=>d.value=""),class:"absolute text-gray-400 -translate-y-1/2 cursor-pointer hover:text-red-500 right-4 top-1/2"})):e.createCommentVNode("",!0)]),e.createElementVNode("div",{class:e.normalizeClass([t.layout==="popover"?"flex-1 overflow-y-auto p-2":"",t.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(h),(_,v)=>(e.openBlock(),e.createBlock(De,{layout:t.layout,count:_.count,label:_[e.unref(D)],color:_.color,type:t.multi?"checkbox":"radio",value:_[e.unref(L)],"is-selected":e.unref(u)(_),highlighted:v===e.unref(z),onItemClick:U=>e.unref(f)(_),ref_for:!0,ref:U=>g.value[v]=U==null?void 0:U.el},null,8,["layout","count","label","color","type","value","is-selected","highlighted","onItemClick"]))),256))],2),t.type==="select"&&e.unref(h).length===0&&!e.unref(w)?(e.openBlock(),e.createElementBlock("div",to,[e.createElementVNode("div",lo,[e.createVNode(Pe),e.createElementVNode("div",oo,[e.createElementVNode("p",no,e.toDisplayString(e.unref(r)("filter.notfound")),1),F[7]||(F[7]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),t.layout!=="popover"&&t.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(B)&&e.unref(c)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:F[3]||(F[3]=(..._)=>e.unref(p)&&e.unref(p)(..._)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.more"))+" ",1),e.createVNode(Ee)])):e.createCommentVNode("",!0),e.unref(B)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:F[4]||(F[4]=(..._)=>e.unref(p)&&e.unref(p)(..._)),class:"inline-flex cursor-pointer items-center gap-x-1.5 text-[13px] text-gray-800 underline underline-offset-4 hover:text-blue-600 focus:outline-none focus:text-blue-600 mt-1 px-2"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.less"))+" ",1),e.createVNode($e)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),t.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[t.layout==="inline"?(e.openBlock(),e.createElementBlock("div",ao,[e.createTextVNode(e.toDisplayString(t.multi&&Array.isArray(e.unref(m))?(O=e.unref(m))==null?void 0:O.length:e.unref(m)!==void 0&&(e.unref(m)||e.unref(m)===null)?1:0)+" / "+e.toDisplayString(e.unref(M))+" "+e.toDisplayString(e.unref(r)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:F[5]||(F[5]=(..._)=>e.unref(y)&&e.unref(y)(..._))},e.toDisplayString(e.unref(r)("filter.clear")),513),[[e.vShow,i.value]])])):e.createCommentVNode("",!0),t.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ro,[e.createElementVNode("button",{type:"button",disabled:!i.value,class:e.normalizeClass(e.unref(l)+" hover:bg-gray-100"),onClick:F[6]||(F[6]=(..._)=>e.unref(y)&&e.unref(y)(..._))},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.clear"))+" ",1),e.createElementVNode("span",so,e.toDisplayString(V.value)+" з "+e.toDisplayString(e.unref(M)),1)],10,io)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2)}}}),mo=["for","onClick"],po=["id","name","value"],uo={class:"block"},fo={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},go={key:1,class:"pt-2 px-2 border-t"},ho=["disabled"],yo={class:"text-xs text-gray-500"},bo=e.defineComponent({__name:"tag-field",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=he(),b=ae(),{innerValue:n,isSelected:m,selectItem:h,clear:u,labelKey:f,valueKey:y,allOptions:C}=r.multi?He({...r,modelValue:r.modelValue??r.default??[]},l):ze({...r,modelValue:r.modelValue!==void 0?r.modelValue:r.default??""},l),p=e.computed(()=>r.multi?Array.isArray(n.value)&&n.value.length>0:n.value!=null&&n.value!==""),w=e.computed(()=>r.multi&&Array.isArray(n.value)?n.value.length:n.value!=null&&n.value!==""?1:0);return a({clear:u}),e.watch(()=>r.modelValue,B=>{B===void 0&&(r.multi?n.value=[]:n.value=void 0)}),(B,c)=>{var d;return e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{class:e.normalizeClass(["grid grid-cols-3 gap-2 mx-[1px]",t.layout==="popover"?"p-2 max-h-[calc(100%-55px)] overflow-y-auto":"mb-1"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(C),D=>(e.openBlock(),e.createElementBlock("label",{key:`item-${D[e.unref(y)]}`,for:`item-${D[e.unref(y)]}`,onClick:e.withModifiers(L=>e.unref(h)(D),["stop","prevent"]),class:e.normalizeClass([e.unref(m)(D)?"ring-2 ring-indigo-600":"","p-2.5 group relative flex justify-center items-center gap-x-12 text-center text-xs bg-white text-gray-800 border border-gray-200 cursor-pointer rounded-sm dark:bg-neutral-900 dark:border-neutral-700 dark:text-neutral-200 peer-checked:text-indigo-600 dark:has-checked:text-indigo-500 peer-checked:border-indigo-600 dark:has-checked:border-indigo-500 peer-checked:ring peer-checked:shadow focus:ring dark:has-checked:ring-indigo-500 has-disabled:pointer-events-none has-disabled:text-gray-200 dark:has-disabled:text-neutral-700 has-disabled:after:absolute has-disabled:after:inset-0 has-disabled:after:bg-[linear-gradient(to_right_bottom,transparent_calc(50%-1px),var(--color-gray-200)_calc(50%-1px),var(--color-gray-200)_50%,transparent_50%)] dark:has-disabled:after:bg-[linear-gradient(to_right_bottom,transparent_calc(50%-1px),var(--color-neutral-700)_calc(50%-1px),var(--color-neutral-700)_50%,transparent_50%)]"])},[e.createElementVNode("input",{type:"checkbox",id:`item-${D[e.unref(y)]}`,class:"hidden w4poy border-gray-200 g41z1 g22e3 axcnw dark:text-indigo-500 dark:border-neutral-700 dark:focus:ring-neutral-900",name:`item-${D[e.unref(y)]}`,value:D[e.unref(y)]},null,8,po),e.createElementVNode("span",uo,e.toDisplayString(D[e.unref(f)]),1)],10,mo))),128))],2),t.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.layout==="inline"?(e.openBlock(),e.createElementBlock("div",fo,[e.createTextVNode(e.toDisplayString(t.multi&&Array.isArray(e.unref(n))?(d=e.unref(n))==null?void 0:d.length:e.unref(n)!==void 0&&(e.unref(n)||e.unref(n)===null)?1:0)+" з "+e.toDisplayString(e.unref(C).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:c[0]||(c[0]=(...D)=>e.unref(u)&&e.unref(u)(...D))}," Очистити ",512),[[e.vShow,p.value]])])):e.createCommentVNode("",!0),t.layout==="popover"?(e.openBlock(),e.createElementBlock("div",go,[e.createElementVNode("button",{type:"button",disabled:!p.value,class:e.normalizeClass(e.unref(s)+" hover:bg-gray-100"),onClick:c[1]||(c[1]=(...D)=>e.unref(u)&&e.unref(u)(...D))},[e.createTextVNode(e.toDisplayString(e.unref(b)("filter.clear"))+" ",1),e.createElementVNode("span",yo,e.toDisplayString(w.value)+" з "+e.toDisplayString(e.unref(C).length),1)],10,ho)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],64)}}}),xo=["disabled","title"],ko={class:"flex w-full items-center justify-between gap-1 overflow-hidden text-left"},wo={class:"truncate text-ellipsis text-sm"},Vo={key:0,class:"inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-sm bg-blue-100 px-2 text-[11px] font-semibold text-blue-600"},Co={class:"w-full text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-sm 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"},Bo={class:"w-[360px] max-h-[500px] overflow-auto [&::-webkit-scrollbar]:h-2 [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-stone-100 [&::-webkit-scrollbar-thumb]:bg-stone-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 before:w-full p-2"},Fe=e.defineComponent({__name:"popover-field",props:{disabled:{type:Boolean,default:!1},label:{},en:{},ua:{},uk:{},fr:{},de:{},es:{},currentValue:{},fieldRef:{},width:{},mode:{},layout:{}},setup(t,{expose:a}){const o=t,r=e.computed(()=>Ie(o.mode)),l=e.ref(!1),s=e.ref({top:0,left:0}),b=e.ref(null),n=e.ref(null),m=e.ref(null);let h=null;function u(){const x=n.value,k=m.value;if(!x||!k)return;const M=x.getBoundingClientRect(),E=k.offsetWidth,i=k.offsetHeight,V=window.innerWidth,g=window.innerHeight,P=8;let F=M.bottom+P,{left:O}=M;const _=Math.max(V-E-10,10);if(O=Math.min(O,_),O=Math.max(O,10),F+i>g-10){const v=M.top-i-P;F=v>=10?v:Math.max(g-i-10,10)}F<10&&(F=10),s.value={top:F,left:O}}function f(){e.nextTick(()=>{u(),typeof window<"u"&&typeof window.requestAnimationFrame=="function"&&window.requestAnimationFrame(()=>u())})}function y(){l.value=!l.value,l.value&&(f(),e.nextTick(()=>{var x,k,M,E,i,V,g;(x=o.fieldRef)!=null&&x.inputTextRef&&((E=(M=(k=o.fieldRef)==null?void 0:k.inputTextRef)==null?void 0:M.focus)==null||E.call(M)),(i=o.fieldRef)!=null&&i.loadData&&Promise.resolve((g=(V=o.fieldRef)==null?void 0:V.loadData)==null?void 0:g.call(V)).finally(()=>{l.value&&f()})}))}function C(x){var k,M,E;!((k=b.value)!=null&&k.contains(x.target))&&!((M=m.value)!=null&&M.contains(x.target))&&!((E=n.value)!=null&&E.contains(x.target))&&(l.value=!1)}function p(x){x.key==="Escape"&&(l.value=!1)}const w=e.ref(!1),B=e.ref("ua"),c=x=>{x.detail.key==="locale"&&(B.value=x.detail.newValue)};e.onMounted(()=>{w.value=!0,B.value=localStorage.locale,window.addEventListener("storage",c),document.addEventListener("click",C,!0),document.addEventListener("keydown",p),window.addEventListener("scroll",u,!0),window.addEventListener("resize",u,!0),typeof ResizeObserver<"u"&&(h=new ResizeObserver(()=>{l.value&&f()}))}),e.onBeforeUnmount(()=>{window.removeEventListener("storage",c),document.removeEventListener("click",C,!0),document.removeEventListener("keydown",p),window.removeEventListener("scroll",u,!0),window.removeEventListener("resize",u,!0),h==null||h.disconnect(),h=null});function d(){l.value=!1}a({close:d}),e.watch([w,l,m],([x,k,M])=>{x&&k&&M&&(f(),h==null||h.observe(M))});function D(x){return Array.isArray(x)?x.filter(k=>k!=null&&k!=="").length:x&&typeof x=="object"?Object.values(x).filter(k=>k!=null&&k!=="").length:typeof x=="string"?x.trim()===""?0:1:typeof x=="number"?Number.isNaN(x)?0:1:x===null||x!==void 0?1:0}const L=e.computed(()=>{var M;const x=(M=o.fieldRef)==null?void 0:M.selectedLabels,k=D(x);return k>0?k:D(o.currentValue)}),z=e.computed(()=>{var k;const x=(k=o.fieldRef)==null?void 0:k.selectedLabels;return!x||["inline"].includes(o.layout||"")?o[B.value]||(o.label??""):Array.isArray(x)?x.length>0?x.join(", "):o.label??"":String(x)});return(x,k)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"wrapperRef",ref:b},[e.createElementVNode("button",{onClick:y,disabled:t.disabled,ref_key:"triggerRef",ref:n,title:t.label,class:e.normalizeClass([r.value,t.width?e.unref(Ye).getWidthClass(t.width):"w-full",t.layout==="inline"&&L.value>0?"border border-blue-400 bg-blue-50 text-blue-600":""]),type:"button"},[e.createElementVNode("span",ko,[e.createElementVNode("span",wo,e.toDisplayString(z.value),1),t.layout==="inline"&&L.value>0?(e.openBlock(),e.createElementBlock("span",Vo,e.toDisplayString(L.value),1)):e.createCommentVNode("",!0)]),e.createVNode(Ee,{class:"h-4 w-4 text-neutral-500"})],10,xo),w.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popperRef",ref:m,class:"vsTailwind vs-popover__content w-fit fixed z-[1000]",style:e.normalizeStyle({top:`${s.value.top}px`,left:`${s.value.left}px`}),"data-inside-popover":""},[e.createElementVNode("div",Co,[e.createElementVNode("div",Bo,[e.renderSlot(x.$slots,"default")])])],4),[[e.vShow,l.value]])])):e.createCommentVNode("",!0)],512))}}),Eo={},No={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down text-gray-800 rotate-[90deg]"};function So(t,a){return e.openBlock(),e.createElementBlock("svg",No,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)])])}const _o=de(Eo,[["render",So]]),Mo={},Do={xmlns:"http://www.w3.org/2000/svg",width:"15px",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down text-gray-800 rotate-[270deg]"};function zo(t,a){return e.openBlock(),e.createElementBlock("svg",Do,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"},null,-1)])])}const Po=de(Mo,[["render",zo]]),$o={class:"flex gap-1"},Lo={class:"mb-1"},Fo={class:"mb-1"},Ao={class:"inline-flex rounded-sm shrink-0 pl-1"},jo=["title"],To={class:"inline-flex rounded-sm shrink-0 pl-1"},Oo=["title"],vo={key:1,class:"flex gap-1 !w-[75%] rounded-sm"},Ro=["max","value","disabled"],Zo=["min","value","disabled"],Io=e.defineComponent({__name:"date-input-inline",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=ae(),l=t,s=o,b=e.ref(null),{activeMode:n,innerValue:m,onSelectChange:h,nextClick:u,prevClick:f,currentLabel:y,clear:C}=Ge({...l,popoverRef:b},s);e.watch(()=>l.modelValue,B=>{B!==void 0?(m.value=B,s("update:modelValue",B)):(n.value="",m.value=[])}),e.watch(m,B=>{s("update:modelValue",B),s("change",{name:l.name,value:B})},{deep:!0});function p(B){const c=Array.isArray(m.value)?[...m.value]:[];m.value=[B,c[1]||""]}function w(B){const c=Array.isArray(m.value)?[...m.value]:[];m.value=[c[0]||"",B]}return a({clear:C,popoverRef:b}),(B,c)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",$o,[e.createVNode(Fe,{ref_key:"popoverRef",ref:b,label:e.unref(y),"current-value":e.unref(m),mode:t.mode,width:typeof t.width=="number"&&e.unref(m).length?t.width-70:t.width,onClear:e.unref(C),layout:t.layout,class:e.normalizeClass(t.itemClass)},{default:e.withCtx(()=>[e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:c[0]||(c[0]=d=>e.unref(h)("range")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.period"))+" ",1),e.unref(n)==="range"?(e.openBlock(),e.createBlock(ge,{key:0})):e.createCommentVNode("",!0)])]),c[12]||(c[12]=e.createElementVNode("div",null,[e.createElementVNode("div",{class:"pt-1 mt-1 border-t"})],-1)),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:c[1]||(c[1]=d=>e.unref(h)("today")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.today"))+" ",1),e.unref(n)==="today"?(e.openBlock(),e.createBlock(ge,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:c[2]||(c[2]=d=>e.unref(h)("week")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.week"))+" ",1),e.unref(n)==="week"?(e.openBlock(),e.createBlock(ge,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:c[3]||(c[3]=d=>e.unref(h)("month")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.month"))+" ",1),e.unref(n)==="month"?(e.openBlock(),e.createBlock(ge,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:c[4]||(c[4]=d=>e.unref(h)("quarter")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.quarter"))+" ",1),e.unref(n)==="quarter"?(e.openBlock(),e.createBlock(ge,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",Lo,[e.createElementVNode("button",{type:"button",onClick:c[5]||(c[5]=d=>e.unref(h)("year")),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.year"))+" ",1),e.unref(n)==="year"?(e.openBlock(),e.createBlock(ge,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",Fo,[e.createElementVNode("button",{type:"button",onClick:c[6]||(c[6]=d=>e.unref(C)()),class:"flex items-center justify-between w-full px-4 py-2 text-sm text-left rounded-sm cursor-pointer filter-date__item hs-selected:bg-stone-100 text-stone-800 hover:bg-stone-100 focus:outline-none focus:bg-stone-100"},[e.createTextVNode(e.toDisplayString(e.unref(r)("filter.alltime"))+" ",1),e.unref(m)[0]?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(ge,{key:0}))])])]),_:1},8,["label","current-value","mode","width","onClear","layout","class"]),e.unref(n)!==""&&e.unref(n)!=="range"&&e.unref(n)!=="last_7_days"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",Ao,[e.createElementVNode("button",{type:"button",title:e.unref(r)("filter.prev"),class:"inline-flex h-[38px] items-center px-2 text-sm text-gray-800 bg-gray-100 gap-x-2 -ms-px first:rounded-s-lg first:ms-0 last:rounded-e-lg focus:z-10 hover:bg-gray-200 focus:bg-gray-200 duration-300",onClick:c[7]||(c[7]=(...d)=>e.unref(f)&&e.unref(f)(...d))},[e.createVNode(_o)],8,jo)]),e.createElementVNode("div",To,[e.createElementVNode("button",{type:"button",title:e.unref(r)("filter.next"),class:"inline-flex h-[38px] items-center px-2 text-sm text-gray-800 gap-x-2 bg-gray-100 -ms-px first:rounded-s-lg first:ms-0 last:rounded-e-lg focus:z-10 hover:bg-gray-200 focus:bg-gray-200 duration-300",onClick:c[8]||(c[8]=(...d)=>e.unref(u)&&e.unref(u)(...d))},[e.createVNode(Po)],8,Oo)])],64)):e.createCommentVNode("",!0),e.unref(n)!==""&&e.unref(n)==="range"?(e.openBlock(),e.createElementBlock("div",vo,[e.createElementVNode("input",{type:"date",max:e.unref(m)[1],locale:"uk-UA",value:e.unref(m)[0],onInput:c[9]||(c[9]=d=>p(d.target.value)),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:t.disabled},null,40,Ro),e.createElementVNode("input",{type:"date",min:e.unref(m)[0],locale:"uk-UA",value:e.unref(m)[1],onInput:c[10]||(c[10]=d=>w(d.target.value)),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:t.disabled},null,40,Zo)])):e.createCommentVNode("",!0)]),(t.cleanable,e.createCommentVNode("",!0))],64))}}),Uo=["disabled","onClick"],Ko={key:0,class:"pt-2 px-2 border-t"},Ho=["disabled"],Wo=e.defineComponent({__name:"button-field",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=he(),b=ae(),{innerValue:n,isSelected:m,selectItem:h,clear:u,labelKey:f,valueKey:y,allOptions:C}=ze({...r,modelValue:r.modelValue??r.default??""},l),p=e.computed(()=>n.value!==void 0&&!(typeof n.value=="string"&&n.value===""));function w(c){return m(c)?["bg-blue-600 text-white"].filter(d=>typeof d=="string"&&d.trim().length>0).join(" "):["text-gray-700 hover:bg-gray-200 bg-gray-50 "].filter(d=>typeof d=="string"&&d.trim().length>0).join(" ")}function B(c){r.disabled||h(c)}return a({clear:u}),e.watch(()=>r.modelValue,c=>{c===void 0&&(n.value=void 0)}),(c,d)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{class:e.normalizeClass(["flex flex-wrap items-center gap-2",t.layout==="popover"?"p-2 max-h-[calc(100%-55px)] overflow-y-auto":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(C),D=>(e.openBlock(),e.createElementBlock("button",{key:D[e.unref(y)],type:"button",class:e.normalizeClass(["px-3 py-2 text-sm font-medium rounded-md transition-colors",w(D)]),disabled:t.disabled,onClick:L=>B(D)},e.toDisplayString(D[e.unref(f)]),11,Uo))),128))],2),t.cleanable&&t.layout==="popover"?(e.openBlock(),e.createElementBlock("div",Ko,[e.createElementVNode("button",{type:"button",disabled:!p.value,class:e.normalizeClass(e.unref(s)+" hover:bg-gray-100"),onClick:d[0]||(d[0]=(...D)=>e.unref(u)&&e.unref(u)(...D))},e.toDisplayString(e.unref(b)("filter.clear")),11,Ho)])):e.createCommentVNode("",!0)],64))}}),Qe={radio:ul,checkbox:We,check:We,text:Dl,range:jl,date:Ql,select:co,tag:bo,button:Wo,"date:inline":Io};function Ae(t,a){let o;switch(t.toLowerCase()){case"autocomplete":o="select";break;case"check":o="checkbox";break;default:o=t==null?void 0:t.toString().toLowerCase()}return o==="date"&&a&&a==="inline"&&(o="date:inline"),{component:Qe[o]||Qe.text,type:o}}const qo={style:{display:"inline-flex",margin:"0px",width:"100%"}},Yo={class:"relative w-full mb-2 p-4 bg-white rounded-md shadow-sm"},Go={class:"block mb-3 text-sm font-medium text-gray-800 dark:text-neutral-200"},Qo={class:"flex items-center"},Xo={class:"text-sm font-medium max-w-[80%] text-gray-800 flex items-center gap-x-1"},Jo={class:"filter-layout__body"},en=e.defineComponent({__name:"vertical-layout",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=e.ref(),b=e.computed(()=>Ae(r.type,r.layout)),n=e.computed({get:()=>r.modelValue,set:f=>l("update:modelValue",f)});function m(f){l("clear",f)}function h(f,y){l("change",{name:f,value:y}),r.modelValue!==void 0&&l("update:modelValue",y)}function u(){var f,y;(y=(f=s.value)==null?void 0:f.clear)==null||y.call(f),l("clear",r.name)}return e.watch(()=>r.default,f=>{n.value=f}),e.watch(()=>r.modelValue,f=>{n.value=f}),a({filterRef:s}),(f,y)=>{var C,p,w;return e.openBlock(),e.createElementBlock("div",qo,[e.createElementVNode("div",Yo,[e.createElementVNode("div",Go,[e.createElementVNode("div",Qo,[e.createElementVNode("span",Xo,e.toDisplayString(t.label),1)]),typeof n.value=="string"&&n.value.trim()!==""||Array.isArray(n.value)&&n.value.length>0&&n.value.some(B=>B!==void 0)||n.value===null?(e.openBlock(),e.createBlock(Zt,{key:0,onClick:u})):e.createCommentVNode("",!0)]),e.createElementVNode("div",Jo,[((C=b.value)==null?void 0:C.type)!=="select"?(e.openBlock(),e.createBlock(e.resolveDynamicComponent((p=b.value)==null?void 0:p.component),e.mergeProps({key:0},r,{type:(w=b.value)==null?void 0:w.type,class:r.itemClass,onChange:y[0]||(y[0]=B=>h(B.name,B.value)),onClear:y[1]||(y[1]=B=>m(B)),ref_key:"filterRef",ref:s}),null,16,["type","class"])):(e.openBlock(),e.createBlock(Fe,{key:1,"current-value":n.value,label:t.label,mode:t.mode,onClear:u,fieldRef:s.value,width:void 0,disabled:t.disabled,layout:"vertical"},{default:e.withCtx(()=>{var B,c;return[(e.openBlock(),e.createBlock(e.resolveDynamicComponent((B=b.value)==null?void 0:B.component),e.mergeProps({ref_key:"filterRef",ref:s},r,{type:(c=b.value)==null?void 0:c.type,class:r.itemClass,onChange:y[2]||(y[2]=d=>h(d.name,d.value)),onClear:y[3]||(y[3]=d=>m(d))}),null,16,["type","class"]))]}),_:1},8,["current-value","label","mode","fieldRef","disabled"]))])])])}}}),Xe=e.defineComponent({__name:"inline-layout",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=e.ref(),b=e.computed(()=>Ae(r.type,r.layout)),n=e.computed({get:()=>r.modelValue,set:u=>l("update:modelValue",u)});function m(u=r.name){l("clear",u)}function h(u,f){l("change",{name:u,value:f}),r.modelValue!==void 0&&l("update:modelValue",f)}return e.watch(()=>r.default,u=>{n.value=u}),e.watch(()=>r.modelValue,u=>{n.value=u}),a({filterRef:s}),(u,f)=>{var y,C;return["text","date","button"].includes(t.type.toLocaleLowerCase())?(e.openBlock(),e.createBlock(e.resolveDynamicComponent((y=b.value)==null?void 0:y.component),e.mergeProps({key:0},r,{type:(C=b.value)==null?void 0:C.type,class:t.itemClass,onChange:f[0]||(f[0]=p=>h(p.name,p.value)),onClear:f[1]||(f[1]=p=>m(p)),disabled:t.disabled,modelValue:n.value,"onUpdate:modelValue":f[2]||(f[2]=p=>n.value=p)}),null,16,["type","class","disabled","modelValue"])):(e.openBlock(),e.createBlock(Fe,{key:1,"current-value":n.value,label:t.label,mode:t.mode,onClear:m,fieldRef:s.value,width:r.width,disabled:t.disabled,layout:"inline"},{default:e.withCtx(()=>{var p,w;return[(e.openBlock(),e.createBlock(e.resolveDynamicComponent((p=b.value)==null?void 0:p.component),e.mergeProps({ref_key:"filterRef",ref:s},r,{modelValue:n.value,"onUpdate:modelValue":f[3]||(f[3]=B=>n.value=B),type:(w=b.value)==null?void 0:w.type,class:r.itemClass,onChange:f[4]||(f[4]=B=>h(B.name,B.value)),onClear:f[5]||(f[5]=B=>m(B))}),null,16,["modelValue","type","class"]))]}),_:1},8,["current-value","label","mode","fieldRef","width","disabled"]))}}}),tn=e.defineComponent({__name:"popover-layout",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean},layout:{},cleanable:{type:Boolean},limit:{},multi:{type:Boolean},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=e.ref(),b=e.computed(()=>Ae(r.type,r.layout)),n=e.computed({get:()=>r.modelValue,set:u=>l("update:modelValue",u)});function m(u){l("clear",u)}function h(u,f){l("change",{name:u,value:f}),r.modelValue!==void 0&&l("update:modelValue",f)}return e.watch(()=>r.default,u=>{n.value=u}),e.watch(()=>r.modelValue,u=>{n.value=u}),e.watch(()=>r,u=>{n.value=u}),a({filterRef:s}),(u,f)=>{var y,C;return e.openBlock(),e.createBlock(e.resolveDynamicComponent((y=b.value)==null?void 0:y.component),e.mergeProps(r,{type:(C=b.value)==null?void 0:C.type,class:r.itemClass,modelValue:n.value,"onUpdate:modelValue":f[0]||(f[0]=p=>n.value=p),onChange:f[1]||(f[1]=p=>h(p.name,p.value)),onClear:f[2]||(f[2]=p=>m(p)),ref_key:"filterRef",ref:s}),null,16,["type","class","modelValue"])}}}),ce=e.defineComponent({__name:"filter-field",props:{id:{},name:{},title:{},type:{},label:{},width:{},options:{default:()=>[]},placeholder:{},api:{},data:{},default:{},modelValue:{},disabled:{type:Boolean,default:!1},layout:{default:"inline"},cleanable:{type:Boolean},limit:{default:10},multi:{type:Boolean,default:!0},dataKey:{},valueKey:{},mode:{},labelKey:{},sort:{default:"name"},ua:{},itemClass:{}},emits:["update:modelValue","change","clear"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=e.ref(),b=e.computed({get:()=>r.modelValue,set:u=>l("update:modelValue",u)});function n(u){l("clear",u)}function m(u,f){l("change",{name:u,value:f}),r.modelValue!==void 0&&l("update:modelValue",f)}e.watch(()=>r.default,u=>{b.value=u}),e.watch(()=>r.modelValue,u=>{b.value=u}),a({filterRef:s});function h(){switch(r.layout){case"inline":return Xe;case"vertical":return en;case"popover":return tn;default:return Xe}}return(u,f)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(h()),e.mergeProps(r,{onChange:f[0]||(f[0]=y=>m(y.name,y.value)),onClear:f[1]||(f[1]=y=>n(y)),modelValue:b.value,"onUpdate:modelValue":f[2]||(f[2]=y=>b.value=y)}),null,16,["modelValue"]))}});function Ne(t,a){const{slots:o}=t,r=c=>c?JSON.parse(JSON.stringify(e.toRaw(c))):{},l=e.ref(r(t.value));e.watch(()=>t.value,c=>{l.value=r(c)},{deep:!0,immediate:!0});const s=e.computed(()=>{var c;return(e.toRaw((c=o==null?void 0:o.default)==null?void 0:c.call(o))??[]).flatMap(d=>Array.isArray(d.children)?d.children:[d])});function b(c){delete l.value[c],a("clear",{data:e.toRaw(l.value),name:c})}function n(c,d){d===void 0?b(c):l.value={...l.value,[c]:d},a("change",{data:e.toRaw(l.value),name:c,value:d})}const m=e.computed(()=>s.value.map(c=>{var D,L,z;const d=(D=c.props)==null?void 0:D.name;return e.cloneVNode(c,{...c.props,layout:t.view,showClean:!0,modelValue:l.value[d],"onUpdate:modelValue":x=>{n(d,x)},onClear:()=>b(d),class:[t.itemClass,(L=c.props)==null?void 0:L.class],itemClass:[t.itemClass,(z=c.props)==null?void 0:z.itemClass].filter(x=>typeof x=="string"&&x.trim().length>0).join(" ")||void 0})})),h=e.computed(()=>new Map(m.value.map(c=>{var D;const d=(D=c.props)==null?void 0:D.name;return d?[d,c]:null}).filter(c=>c!==null)));function u(c=!1){l.value={},c||a("clearAll",{data:e.toRaw(l.value),name:"ALL"})}const f=e.ref(""),y=e.computed(()=>{var c;return(c=t.schema)!=null&&c.value?Object.entries(l.value).filter(([d,D])=>t.schema&&!(d in t.schema.value)?!1:Array.isArray(D)?D.some(L=>L!==""&&L!==void 0):D!==""&&D!==void 0).length:0}),C=e.ref();e.watch(f,async()=>{var c,d;await e.nextTick(),(d=(c=C==null?void 0:C.value)==null?void 0:c.filterRef)!=null&&d.inputTextRef&&C.value.filterRef.inputTextRef.focus()});const p=e.computed(()=>{var c,d;return(c=t.schema)!=null&&c.value?Object.fromEntries(Object.entries((d=t.schema)==null?void 0:d.value).slice(0,t.limit)):{}}),w=e.computed(()=>{var d;if(m.value.length===0)return[];let c=0;if((d=t.schema)!=null&&d.value){const D=Object.entries(t.schema.value).length;t.limit&&D<t.limit?c=t.limit-D:c=0}return m.value.slice(0,c)}),B=e.computed(()=>m.value.length===0?[]:t.view!=="inline"?m.value:m.value.slice(w.value.length));return{activeFilter:l,activeFilterCount:y,onFilterChange:n,clearFilter:b,clearAllFilters:u,limitedSchema:p,filtersSlot:m,limitedFiltersSlot:w,popoverFiltersSlot:B,vnodeMap:h,selectedFilter:f,filterRef:C}}const ln=e.defineComponent({__name:"popover",emits:["open","close"],setup(t,{emit:a}){const o=e.ref(!1),r=e.ref(null),l=e.ref(null),s=e.ref(null),b=e.ref({top:"0px",left:"0px",position:"absolute"}),n=e.ref(!1);function m(){o.value=!o.value}function h(){const p=s.value,w=r.value;if(!p||!w)return;const{left:B,bottom:c}=p.getBoundingClientRect();requestAnimationFrame(()=>{if(!w)return;const{width:d}=w.getBoundingClientRect(),D=w.offsetWidth||d,L=window.innerWidth||document.documentElement.clientWidth,z=L-B;let x=B;D>z&&(x=L-D-18),x<18&&(x=18);const k=L-D-18;x>k&&(x=Math.max(18,k)),b.value={position:"fixed",top:`${c+18}px`,left:`${x}px`},n.value=!0})}const u=e.computed(()=>Object.entries(b.value).map(p=>p.join(":")).join(";"));function f(p){var B,c;const w=p.target;!((B=s.value)!=null&&B.contains(p.target))&&!((c=r.value)!=null&&c.contains(p.target))&&!w.closest("[data-inside-popover]")&&(o.value=!1)}const y=e.ref(!1);e.onMounted(()=>{y.value=!0}),e.onMounted(()=>{var p,w;s.value=((p=l.value)==null?void 0:p.querySelector("[data-popover-trigger]"))||null,(w=s.value)==null||w.addEventListener("click",m),document.addEventListener("click",f),window.addEventListener("resize",h),window.addEventListener("scroll",h,!0)}),e.onBeforeUnmount(()=>{var p;(p=s.value)==null||p.removeEventListener("click",m),document.removeEventListener("click",f),window.removeEventListener("resize",h),window.removeEventListener("scroll",h,!0)});const C=a;return e.watch(o,async p=>{p?(n.value=!1,C("open"),await e.nextTick(),requestAnimationFrame(()=>{h()})):(C("close"),n.value=!1)}),(p,w)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"wrapperRef",ref:l},[e.renderSlot(p.$slots,"trigger"),y.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popoverRef",ref:r,class:"fixed z-[50] w-[calc(100vw-32px)] md:w-[600px] rounded-md border bg-white shadow-md transition-opacity duration-0",style:e.normalizeStyle([u.value,{visibility:n.value?"visible":"hidden",opacity:n.value?1:0}])},[e.renderSlot(p.$slots,"default")],4),[[e.vShow,o.value]])])):e.createCommentVNode("",!0)],512))}}),on={},nn={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 h-4 w-4"};function an(t,a){return e.openBlock(),e.createElementBlock("svg",nn,[...a[0]||(a[0]=[e.createElementVNode("polygon",{points:"22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3"},null,-1)])])}const Je=de(on,[["render",an]]),rn={class:"flex items-center gap-2 overflow-hidden"},sn={key:0,class:"inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-[4px] bg-blue-500 px-1 text-[11px] font-semibold text-white"},cn={class:"flex max-h-[400px] md:max-h-[400px]"},dn={class:"w-[150px] sm:w-[180px] md:w-64 border-r border-gray-200 overflow-y-auto"},mn={class:"p-2 md:p-4 border-b"},pn={class:"text-xs md:text-sm text-gray-600"},un={class:"p-1 md:p-2"},fn=["onClick"],gn={class:"flex items-center gap-1.5 md:gap-2"},hn={class:"text-xs md:text-sm font-medium line-clamp-3"},yn={key:0,class:"inline-flex min-h-[16px] md:min-h-[18px] min-w-[16px] md:min-w-[18px] items-center justify-center rounded-[4px] bg-blue-100 px-0.5 md:px-1 text-[10px] md:text-[11px] font-semibold text-blue-600 flex-shrink-0"},bn=["onClick"],xn={class:"flex items-center gap-1.5 md:gap-2"},kn={class:"text-xs md:text-sm font-medium truncate"},wn={key:0,class:"inline-flex min-h-[16px] md:min-h-[18px] min-w-[16px] md:min-w-[18px] items-center justify-center rounded-[4px] bg-blue-100 px-0.5 md:px-1 text-[10px] md:text-[11px] font-semibold text-blue-600 flex-shrink-0"},Vn={key:0,class:"p-1 md:p-2 border-t"},Cn={class:"flex-1 min-h-[250px] md:min-h-[300px] overflow-y-auto"},Bn={key:0,class:"flex items-center justify-center h-full text-gray-500"},En={class:"text-xs md:text-sm"},et=e.defineComponent({__name:"popover-filter-layout",props:{badgeCount:{},schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{},teleportActive:{}},emits:["change","clear","clearAll"],setup(t,{expose:a,emit:o}){const r=ae(),l=t,s=Ie(l.mode),b=e.useSlots(),n=o,m=e.ref({}),h=e.computed(()=>m!=null&&m.value?l.view!=="inline"?m==null?void 0:m.value:Object.fromEntries(Object.entries(m==null?void 0:m.value).slice(l.limit)):{}),{activeFilter:u,activeFilterCount:f,onFilterChange:y,clearFilter:C,clearAllFilters:p,popoverFiltersSlot:w,selectedFilter:B,filterRef:c}=Ne({...l,schema:m,slots:b},n),d=e.computed(()=>l.badgeCount??f.value);function D(x){return Array.isArray(x)?x.filter(k=>k!=null&&k!=="").length:x&&typeof x=="object"?Object.values(x).filter(k=>k!=null&&k!=="").length:x===null||x!==void 0&&x!==""?1:0}function L(x){return u.value?D(u.value[x]):0}function z(){if(h.value){const[x]=Object.keys(h.value);B.value=x}else w.value.length>0?B.value=w.value[0].props.name:B.value=""}return e.watch(()=>l.schema,x=>{m.value=x??{}},{deep:!0,immediate:!0}),a({clearFilter:C,clearAllFilters:p}),(x,k)=>(e.openBlock(),e.createBlock(ln,{onOpen:z,onClose:k[5]||(k[5]=M=>B.value="")},{trigger:e.withCtx(()=>[e.createElementVNode("button",{"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([t.itemClass,e.unref(s),"flex items-center justify-between gap-2",d.value>0?"border border-blue-400 bg-blue-50 text-blue-600 hover:border-blue-500":"text-neutral-700 hover:border-neutral-400"]),type:"button"},[e.createElementVNode("span",rn,[e.createVNode(Je,{class:"h-4 w-4"}),k[6]||(k[6]=e.createElementVNode("span",{class:"text-sm font-medium"},"Фільтр",-1))]),d.value>0?(e.openBlock(),e.createElementBlock("span",sn,e.toDisplayString(d.value),1)):e.createCommentVNode("",!0)],2)]),default:e.withCtx(()=>[e.createElementVNode("div",cn,[e.createElementVNode("div",dn,[e.createElementVNode("div",mn,[e.createElementVNode("p",pn,e.toDisplayString(e.unref(r)("filter.selectFieldHelp")),1)]),e.createElementVNode("div",un,[t.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(h.value),([M,E])=>(e.openBlock(),e.createElementBlock("button",{key:M,onClick:()=>{B.value=M},class:e.normalizeClass(["flex w-full items-center justify-between px-2 md:px-3 py-1.5 md:py-2 text-left transition-colors hover:bg-gray-50",e.unref(B)===M?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",gn,[e.createElementVNode("span",hn,e.toDisplayString(E.label),1)]),L(M)>0?(e.openBlock(),e.createElementBlock("div",yn,e.toDisplayString(L(M)),1)):e.createCommentVNode("",!0)],10,fn))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(w),(M,E)=>(e.openBlock(),e.createElementBlock("button",{key:"slot-"+E,onClick:i=>B.value=M.props.name,class:e.normalizeClass(["flex items-center justify-between px-2 md:px-3 py-1.5 md:py-2 text-left transition-colors hover:bg-gray-50",e.unref(B)===M.props.name?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",xn,[e.createElementVNode("span",kn,e.toDisplayString(M.props.label),1)]),L(M.props.name)>0?(e.openBlock(),e.createElementBlock("div",wn,e.toDisplayString(L(M.props.name)),1)):e.createCommentVNode("",!0)],10,bn))),128))]),e.unref(f)>0?(e.openBlock(),e.createElementBlock("div",Vn,[e.createElementVNode("button",{class:e.normalizeClass([t.itemClass,"w-full px-2 md:px-3 py-1.5 md:py-2 text-left text-xs md:text-sm text-gray-600 hover:bg-gray-50 transition-colors"]),onClick:k[0]||(k[0]=M=>e.unref(p)()),"data-inside-popover":""}," Очистити всі ",2)])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Cn,[e.unref(B)===""?(e.openBlock(),e.createElementBlock("div",Bn,[e.createElementVNode("p",En,e.toDisplayString(e.unref(r)("filter.selectFieldHelp")),1)])):e.createCommentVNode("",!0),e.unref(B)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[h.value?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(h.value),([M,E])=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.unref(B)===M?(e.openBlock(),e.createBlock(ce,e.mergeProps({key:M,layout:"popover",ref_for:!0,ref_key:"filterRef",ref:c},{ref_for:!0},E,{class:[t.itemClass,E==null?void 0:E.class],"item-class":[t.itemClass,E==null?void 0:E.itemClass].filter(Boolean).join(" ")||void 0,onChange:k[1]||(k[1]=i=>e.unref(y)(i.name,i.value)),onClear:k[2]||(k[2]=i=>{e.unref(C)(i),e.unref(y)(i,void 0)}),modelValue:e.unref(u)[M],"onUpdate:modelValue":i=>e.unref(u)[M]=i,cleanable:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])):e.createCommentVNode("",!0)],64))),256)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(w),(M,E)=>{var i,V;return e.openBlock(),e.createElementBlock(e.Fragment,{key:"slot-"+E},[e.unref(B)===M.props.name?(e.openBlock(),e.createBlock(ce,e.mergeProps({key:0,layout:"popover"},{ref_for:!0},M.props,{ref_for:!0,ref_key:"filterRef",ref:c,class:[t.itemClass,(i=M.props)==null?void 0:i.class],"item-class":[t.itemClass,(V=M.props)==null?void 0:V.itemClass].filter(Boolean).join(" ")||void 0,onChange:k[3]||(k[3]=g=>e.unref(y)(g.name,g.value)),onClear:k[4]||(k[4]=g=>{e.unref(C)(g),e.unref(y)(g,void 0)}),modelValue:e.unref(u)[M.props.name],"onUpdate:modelValue":g=>e.unref(u)[M.props.name]=g,cleanable:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])):e.createCommentVNode("",!0)],64)}),128))],64)):e.createCommentVNode("",!0)])])]),_:1}))}}),Nn={class:"flex gap-1 items-center flex-wrap"},tt=e.defineComponent({__name:"inline-filter-layout",props:{schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{},teleportActive:{}},emits:["change","clear","clearAll"],setup(t,{expose:a,emit:o}){const r=ae(),l=t,s=o,b=e.useSlots(),n=e.ref({}),m=e.computed(()=>Object.keys(l.schema).length>l.limit),{activeFilter:h,activeFilterCount:u,onFilterChange:f,clearFilter:y,clearAllFilters:C,limitedSchema:p,filtersSlot:w,limitedFiltersSlot:B}=Ne({...l,schema:n,slots:b},s);function c(k){return Array.isArray(k)?k.some(M=>M!==""&&M!==void 0&&M!==null):k===null?!0:k&&typeof k=="object"?Object.values(k).some(M=>M!==""&&M!==void 0&&M!==null):k!==""&&k!==void 0}const d=e.computed(()=>{const k=Object.keys(p.value??{}),M=B.value.map(E=>{var i;return(i=E.props)==null?void 0:i.name}).filter(E=>typeof E=="string");return new Set([...k,...M])}),D=e.computed(()=>Object.entries(h.value??{}).filter(([k,M])=>d.value.has(k)&&c(M)).length),L=e.computed(()=>{const k=u.value??0,M=D.value??0;return Math.max(k-M,0)}),z=e.ref();function x(){z.value&&z.value.clearAllFilters(!0),C()}return e.watch(()=>l.schema,k=>{n.value=k},{deep:!0,immediate:!0}),a({clearFilter:y,clearAllFilters:C}),(k,M)=>(e.openBlock(),e.createElementBlock("div",Nn,[t.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(e.unref(p)),([E,i])=>(e.openBlock(),e.createBlock(ce,e.mergeProps({key:E,mode:t.mode,width:t.width?t.width:i==null?void 0:i.width},{ref_for:!0},i,{class:[t.itemClass,i==null?void 0:i.class],"item-class":[t.itemClass,i==null?void 0:i.itemClass].filter(Boolean).join(" ")||void 0,onChange:M[0]||(M[0]=V=>e.unref(f)(V.name,V.value)),onClear:e.unref(y),layout:"inline",cleanable:!0,modelValue:e.unref(h)[E],"onUpdate:modelValue":V=>e.unref(h)[E]=V}),null,16,["mode","width","class","item-class","onClear","modelValue","onUpdate:modelValue"]))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(B),(E,i)=>{var V,g;return e.openBlock(),e.createBlock(ce,e.mergeProps({key:"slot-"+i,layout:"inline"},{ref_for:!0},E.props,{class:[t.itemClass,(V=E.props)==null?void 0:V.class],"item-class":[t.itemClass,(g=E.props)==null?void 0:g.itemClass].filter(Boolean).join(" ")||void 0,onChange:M[1]||(M[1]=P=>e.unref(f)(P.name,P.value)),onClear:M[2]||(M[2]=P=>{e.unref(y)(P),e.unref(f)(P,void 0)}),cleanable:!0,modelValue:e.unref(h)[E.props.name],"onUpdate:modelValue":P=>e.unref(h)[E.props.name]=P}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])}),128)),m.value?(e.openBlock(),e.createBlock(et,e.mergeProps({key:1},l,{schema:t.schema,limit:t.limit,onChange:M[3]||(M[3]=E=>e.unref(f)(E.name,E.value)),onClearAll:M[4]||(M[4]=E=>e.unref(C)()),onClear:M[5]||(M[5]=E=>e.unref(y)(E.name)),mode:t.mode,ref_key:"popoverRef",ref:z,cleanable:!0,"badge-count":L.value}),{default:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(w),(E,i)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(E),e.mergeProps({key:"slot-"+i,layout:"popover"},{ref_for:!0},E.props,{cleanable:!0}),null,16))),128))]),_:1},16,["schema","limit","mode","badge-count"])):e.createCommentVNode("",!0),e.unref(u)>0?(e.openBlock(),e.createElementBlock("button",{key:2,onClick:x,class:e.normalizeClass([t.itemClass,"relative py-2 px-3 inline-flex justify-center items-center gap-x-2 text-sm font-medium rounded-md bg-gray-50 border text-gray-800 hover:bg-gray-200 focus:bg-gray-200"])},e.toDisplayString(e.unref(r)("filter.clear")),3)):e.createCommentVNode("",!0)]))}}),Sn={key:0,class:"p-2 overflow-y-auto overflow-hidden [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500 dark:bg-neutral-800 max-h-[calc(100%-142px)] h-full bg-gray-100"},_n={class:"flex items-center vst-filters vsTailwind flex-col w-full"},Mn=e.defineComponent({__name:"vertical-filter-layout",props:{schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{},teleportActive:{}},emits:["change","clear","clearAll"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=e.useSlots(),{activeFilter:b,activeFilterCount:n,onFilterChange:m,clearFilter:h,clearAllFilters:u,filtersSlot:f}=Ne({...r,slots:s},l);return a({clearFilter:h,clearAllFilters:u}),(y,C)=>t.view==="vertical"?(e.openBlock(),e.createElementBlock("div",Sn,[e.createElementVNode("div",_n,[e.unref(n)>0?(e.openBlock(),e.createElementBlock("button",{key:0,onClick:C[0]||(C[0]=p=>e.unref(u)()),"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([t.itemClass,"w-full ring-offset-background focus-visible:outline-hidden focus-visible:ring-ring inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:ring-2 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 border h-10 px-4 py-2 gap-2 m-2 bg-white text-gray-800 hover:bg-gray-200 focus:bg-gray-200"]),type:"button"}," Очистити ",2)):e.createCommentVNode("",!0),t.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(Object.entries(t.schema),([p,w])=>(e.openBlock(),e.createBlock(ce,e.mergeProps({layout:"vertical"},{ref_for:!0},w,{class:[t.itemClass,w==null?void 0:w.class],"item-class":[t.itemClass,w==null?void 0:w.itemClass].filter(Boolean).join(" ")||void 0,onChange:C[1]||(C[1]=B=>e.unref(m)(B.name,B.value)),onClear:C[2]||(C[2]=B=>{e.unref(h)(B),e.unref(m)(B,void 0)}),modelValue:e.unref(b)[p],"onUpdate:modelValue":B=>e.unref(b)[p]=B,showClean:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),256)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(f),(p,w)=>{var B,c;return e.openBlock(),e.createBlock(ce,e.mergeProps({key:"slot-"+w,layout:"vertical"},{ref_for:!0},p.props,{class:[t.itemClass,(B=p.props)==null?void 0:B.class],"item-class":[t.itemClass,(c=p.props)==null?void 0:c.itemClass].filter(Boolean).join(" ")||void 0,onChange:C[3]||(C[3]=d=>e.unref(m)(d.name,d.value)),onClear:C[4]||(C[4]=d=>{e.unref(h)(d),e.unref(m)(d,void 0)}),modelValue:e.unref(b)[p.props.name],"onUpdate:modelValue":d=>e.unref(b)[p.props.name]=d,showClean:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])}),128))])])):e.createCommentVNode("",!0)}}),Dn=["onKeydown"],zn=["disabled"],Pn={key:0,class:"ml-2 inline-flex min-h-[18px] min-w-[18px] items-center justify-center rounded-full bg-blue-500 px-1.5 text-[11px] font-semibold text-white"},$n={class:"rounded-2xl border border-slate-300/35 bg-white/95 p-4 shadow-2xl backdrop-blur-sm"},Ln={class:"mb-3 flex items-center justify-between"},Fn={class:"text-[15px] font-semibold text-slate-800"},An={"aria-hidden":"true"},jn={class:"flex max-h-80 flex-col gap-1 overflow-y-auto"},Tn={key:0,class:"mt-3 flex justify-end"},On=e.defineComponent({__name:"popover-inline-filter-layout",props:{schema:{},view:{},value:{},history:{type:Boolean},mode:{},limit:{default:10},width:{default:220},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{},teleportActive:{}},emits:["change","clear","clearAll"],setup(t,{emit:a}){const o=ae(),r=t,l=a,s=e.ref({}),b=e.useSlots(),{activeFilter:n,activeFilterCount:m,onFilterChange:h,clearFilter:u,clearAllFilters:f,filtersSlot:y}=Ne({...r,schema:s.value,slots:b},l),C=e.ref(null),p=e.ref(null),w=e.reactive({open:!1,top:0,left:0}),B=e.computed(()=>w.open),c=e.computed(()=>!!r.disabled),d=e.computed(()=>s.value||{}),D=e.computed(()=>r.title??"Фільтр"),L=e.computed(()=>!!b.trigger),z=e.computed(()=>["inline-flex h-9 items-center justify-center gap-2 rounded-lg border border-transparent bg-slate-200/70 px-3 text-sm font-medium text-slate-700 transition-colors hover:bg-blue-100 hover:text-blue-600 focus:outline-none focus:ring-2 focus:ring-blue-200 disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:bg-slate-200/70 disabled:hover:text-slate-700",c.value?"cursor-not-allowed opacity-60":"cursor-pointer"]),x=e.computed(()=>w.open?{position:"absolute",top:`${w.top}px`,left:`${w.left}px`,transform:"translateX(-50%)",zIndex:1e3}:{display:"none"});function k(){w.open=!1}function M(){if(!C.value)return;const P=C.value.getBoundingClientRect();w.top=P.bottom+window.scrollY+8,w.left=P.left+P.width/2+window.scrollX}function E(){w.open=!w.open,w.open&&e.nextTick(M)}function i(){c.value||E()}function V(){w.open&&M()}function g(){f()}return e.onMounted(()=>{window.addEventListener("resize",V),window.addEventListener("scroll",V,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",V),window.removeEventListener("scroll",V,!0)}),e.watch(()=>r.schema,P=>{if(!P){s.value={};return}if(Array.isArray(P)){const F=P.filter(O=>O&&(O.name||O.id)).map(O=>{const _=O.name||O.id;return[_,{...O,name:_}]});s.value=Object.fromEntries(F);return}s.value=P},{deep:!0,immediate:!0}),e.watch(()=>r.disabled,P=>{P&&k()}),(P,F)=>(e.openBlock(),e.createElementBlock("div",{class:"relative inline-flex",ref_key:"anchor",ref:C},[L.value?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["inline-flex",c.value?"cursor-not-allowed opacity-60 pointer-events-none":"cursor-pointer"]),role:"button",tabindex:"0","data-popover-trigger":"",onClick:e.withModifiers(i,["prevent","stop"]),onKeydown:[e.withKeys(e.withModifiers(i,["prevent","stop"]),["enter"]),e.withKeys(e.withModifiers(i,["prevent","stop"]),["space"])]},[e.renderSlot(P.$slots,"trigger",{toggle:i,open:B.value,disabled:c.value,activeCount:e.unref(m)})],42,Dn)):(e.openBlock(),e.createElementBlock("button",{key:1,class:e.normalizeClass(z.value),type:"button",disabled:c.value,onClick:e.withModifiers(i,["prevent","stop"]),"data-popover-trigger":""},[e.createVNode(Je,{class:"h-4 w-4"}),e.unref(m)>0?(e.openBlock(),e.createElementBlock("div",Pn,e.toDisplayString(e.unref(m)),1)):e.createCommentVNode("",!0)],10,zn)),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[B.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["absolute",typeof t.width=="number"?`min-w-[${t.width+32+(Object.keys(d.value).length>7?20:0)}px]`:"min-w-[268px] "]),style:e.normalizeStyle(x.value),ref_key:"panel",ref:p,onClick:F[4]||(F[4]=e.withModifiers(()=>{},["stop"]))},[e.createElementVNode("div",$n,[e.createElementVNode("div",Ln,[e.createElementVNode("h3",Fn,e.toDisplayString(D.value),1),e.createElementVNode("button",{type:"button",class:"inline-flex h-6 w-6 items-center justify-center rounded-full border-0 bg-slate-300/40 text-slate-600 transition-colors hover:bg-blue-200/60 hover:text-blue-600 focus:outline-none focus:ring-2 focus:ring-blue-200",onClick:k},[e.createElementVNode("span",An,[e.createVNode(Le,{class:"h-4 w-4"})]),F[5]||(F[5]=e.createElementVNode("span",{class:"sr-only"},"Закрити",-1))])]),e.createElementVNode("div",jn,[Object.keys(d.value).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(d.value),([O,_])=>(e.openBlock(),e.createBlock(ce,e.mergeProps({key:O},{ref_for:!0},{..._,layout:"inline"},{width:t.width?t.width:_==null?void 0:_.width,class:[t.itemClass,_==null?void 0:_.class],"item-class":[t.itemClass,_==null?void 0:_.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(n)[O],"onUpdate:modelValue":v=>e.unref(n)[O]=v,onChange:F[0]||(F[0]=v=>e.unref(h)(v.name,v.value)),onClear:F[1]||(F[1]=v=>{e.unref(u)(v),e.unref(h)(v,void 0)})}),null,16,["width","class","item-class","modelValue","onUpdate:modelValue"]))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(y),(O,_)=>{var v,U;return e.openBlock(),e.createBlock(ce,e.mergeProps({key:"slot-"+_,ref_for:!0},{...O.props,layout:"inline"},{class:[t.itemClass,(v=O.props)==null?void 0:v.class],"item-class":[t.itemClass,(U=O.props)==null?void 0:U.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(n)[O.props.name],"onUpdate:modelValue":Z=>e.unref(n)[O.props.name]=Z,onChange:F[2]||(F[2]=Z=>e.unref(h)(Z.name,Z.value)),onClear:F[3]||(F[3]=Z=>{e.unref(u)(Z),e.unref(h)(Z,void 0)})}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])}),128))]),e.unref(m)>0?(e.openBlock(),e.createElementBlock("div",Tn,[e.createElementVNode("button",{type:"button",class:e.normalizeClass([t.itemClass,"text-sm font-semibold text-blue-600 transition-colors hover:text-blue-700 focus:outline-none"]),onClick:g},e.toDisplayString(e.unref(o)("filter.clear")),3)])):e.createCommentVNode("",!0)])],6)):e.createCommentVNode("",!0)]))],512))}}),vn={class:"mb-6 flex flex-wrap gap-2"},Rn=["onClick"],Zn={class:"mr-2 flex items-center gap-1"},In={class:"font-semibold"},Un={class:"text-xs text-gray-500"},Se=e.defineComponent({__name:"filter",props:{schema:{},view:{default:"inline"},value:{},history:{type:Boolean},mode:{},limit:{default:3},width:{},title:{},disabled:{type:Boolean},defaultPanelWidth:{},itemClass:{},teleportActive:{}},emits:["change","clear","clearAll"],setup(t,{expose:a,emit:o}){const r=t,l=e.useAttrs(),s=e.computed(()=>({...r,...l})),b=e.ref(u(r.value??{}));e.watch(()=>r.value,async i=>{var V,g;b.value=u(i??{}),(!i||Object.keys(i).length===0)&&(await e.nextTick(),(g=(V=m.value)==null?void 0:V.clearAllFilters)==null||g.call(V,!0))},{deep:!0,immediate:!0});const n=o,m=e.ref(),h=e.useSlots();function u(i){if(Array.isArray(i))return i.map(V=>u(V));if(i!==null&&typeof i=="object"){const V=e.toRaw(i),g={};for(const P in V)g[P]=u(V[P]);return g}return i}function f(i,V){V!==void 0?b.value={...b.value,[i]:V}:delete b.value[i],n("change",{data:u(b.value),name:i,value:u(V)})}function y(i){delete b.value[i],n("clear",{data:u(b.value),name:i}),n("change",{data:u(b.value),name:i,value:null})}function C(){b.value={},n("clear",{data:u(b.value),name:"ALL"}),n("change",{data:u(b.value),name:"ALL",value:null})}const p=e.ref({}),w=e.computed(()=>r.teleportActive);function B(){switch(r.view){case"inline":return tt;case"vertical":return Mn;case"popover":return et;case"popover-inline":return On;default:return tt}}e.watch(()=>r.schema,i=>{if(!i){p.value={};return}if(Array.isArray(i)&&!i.length){p.value={};return}Array.isArray(i)?p.value=i.filter(V=>V.type).reduce((V,g)=>(Object.assign(g,{name:g.id||g.name,type:{datepicker:"date"}[g.type.toLowerCase()]||g.type.toLowerCase(),label:g.label||g.ua}),V[g.name]=g,g.data&&!g.api&&!g.options&&Object.assign(g,{api:`/api/suggest/${g.data}`}),V),{}):(Object.entries(i).forEach(([V,g])=>{Object.assign(g,{name:V||g.name||g.id,type:g.type.toLowerCase()})}),p.value={...i})},{immediate:!0,deep:!0});function c(i){m.value.clearFilter(i),y(i)}function d(){m.value.clearAllFilters(),C()}const D=e.computed(()=>Object.entries(b.value).filter(([,i])=>i==null?!1:Array.isArray(i)?i.length>0:typeof i=="string"?i.trim().length>0:!0).map(([i,V])=>{const g=p.value[i],P=(g==null?void 0:g.label)||(g==null?void 0:g.title)||i,F=z(g,V);return{key:i,label:P,value:F}}));function L(i){c(i)}function z(i,V){if(!i||V===void 0||V===null)return"";const g=x(V);if(!g.length)return"";const P=k(i);return g.map(F=>P.get(F)??F).filter(Boolean).join(", ")}function x(i){return Array.isArray(i)?i.map(V=>{var g;return((g=V==null?void 0:V.toString)==null?void 0:g.call(V))??""}).filter(Boolean):typeof i=="string"?i.split(",").map(V=>V.trim()).filter(Boolean):[]}function k(i){const V=new Map,g=i.valueKey||"id",P=i.labelKey||"text";return(i.options??[]).forEach(F=>{const O=M(F,g),_=E(F,P);O&&V.set(O,_||O)}),V}function M(i,V){var g,P;return i?((P=(g=i[V]??i.id??i.value??i.key)==null?void 0:g.toString)==null?void 0:P.call(g))??"":""}function E(i,V){var g,P;return i?((P=(g=i[V]??i.text??i.label??i.value??i.id)==null?void 0:g.toString)==null?void 0:P.call(g))??"":""}return e.watch(()=>b.value,i=>{if(r.history){const V=new URL(window.location.href),g=new URLSearchParams(window.location.search);Object.keys(i).length>0?g.set("filter",Object.entries(i).filter(([,P])=>P).map(([P,F])=>`${P}=${F}`).join("|")):g.delete("filter"),V.search=decodeURI(g.toString()),window.history.pushState({},"",V)}}),a({clearAllFilters:d,clearFilter:c}),(i,V)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(B()),e.mergeProps(s.value,{schema:p.value,onChange:V[0]||(V[0]=g=>f(g.name,g.value)),onClear:V[1]||(V[1]=g=>y(g.name)),onClearAll:C,ref_key:"filterRef",ref:m}),e.createSlots({default:e.withCtx(()=>[e.renderSlot(i.$slots,"default")]),_:2},[e.unref(h).trigger?{name:"trigger",fn:e.withCtx(g=>[e.renderSlot(i.$slots,"trigger",e.normalizeProps(e.guardReactiveProps(g)))]),key:"0"}:void 0]),1040,["schema"])),w.value&&D.value.length?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:w.value},[e.createElementVNode("div",vn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(D.value,g=>(e.openBlock(),e.createElementBlock("button",{key:g.key,type:"button",class:"ga1u8 zw1wr sr4j9 flex items-center zu875 kew0r w9dei w4xo0 kghwt wz1vo focus:outline-hidden gugmw dark:bg-emerald-500 dark:hover:bg-emerald-600 dark:focus:bg-emerald-600 bg-white border border-gray-200 px-3 py-1 rounded-full text-sm text-gray-700",onClick:P=>L(g.key)},[e.createElementVNode("span",Zn,[e.createElementVNode("span",In,e.toDisplayString(g.label),1),e.createElementVNode("span",Un,"· "+e.toDisplayString(g.value),1)]),V[2]||(V[2]=e.createElementVNode("span",{class:"g424j flex flex-col jkwm1 items-center b9gop aqyoh ad7q2 kghwt t4363 q7nhl dark:text-emerald-500"},[e.createElementVNode("svg",{class:"e731n u28hb",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"3","stroke-linecap":"round","stroke-linejoin":"round"},[e.createElementVNode("path",{d:"M18 6 6 18"}),e.createElementVNode("path",{d:"m6 6 12 12"})])],-1))],8,Rn))),128))])],8,["to"])):e.createCommentVNode("",!0)],64))}});Se.install=function(t){t.component("Filter",Se),t.component("FilterField",ce)};function Kn(t){const{page:a,id:o,filter:r,filterByView:l}=t,s=new URL(window.location.href),b=new URLSearchParams(window.location.search);a?b.set("page",a.toString()):b.delete("page"),o?b.set("id",o.toString()):b.delete("id"),r?b.set("filter",r):b.delete("filter"),typeof l=="boolean"?b.set("bbox",l?"1":"0"):b.delete("bbox"),s.search=decodeURI(b.toString()),window.history.pushState({},"",s)}const Hn={class:"flex items-center justify-between w-full gap-x-1"},Wn={class:"flex items-center"},qn=["disabled"],Yn={class:"flex items-center gap-x-1"},Gn=["onClick"],Qn=["disabled"],Xn={class:"flex justify-center items-center gap-x-5 ml-3"},Jn={class:"relative"},ea={class:"hs-dropdown-menu z-50 bg-white shadow-md rounded-lg p-1 space-y-0.5 dark:bg-neutral-800 dark:border dark:border-neutral-700 right-0 dark:divide-neutral-700 absolute bottom-[100%]",role:"menu","aria-orientation":"vertical","aria-labelledby":"dropdown-button"},ta=["onClick"],la={key:0,xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"4","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-check text-blue-600",width:"14",height:"14"},je=e.defineComponent({__name:"pagination",props:{total:{},currentPage:{},pageSize:{}},emits:["update:currentPage","update:pageSize","pageChange","pageSizeChange"],setup(t,{emit:a}){const o=t,r=a,l=e.ref(o.currentPage),s=e.ref(o.pageSize),b=e.ref(!1);e.watch(()=>o.pageSize,C=>{s.value=C});const n=e.computed(()=>Math.ceil(o.total/o.pageSize)),m=e.computed(()=>{const p=Math.floor(3.5);let w=l.value-p,B=l.value+p;w<1&&(B+=1-w,w=1),B>n.value&&(w-=B-n.value,B=n.value),w=Math.max(1,w);const c=[];for(let d=w;d<=B;d+=1)c.push(d);return c}),h=()=>{l.value>1&&f(l.value-1)},u=()=>{l.value<n.value&&f(l.value+1)},f=C=>{l.value=C,r("update:currentPage",C),r("pageChange",C)},y=(C=s.value)=>{s.value=C,b.value=!1,r("update:pageSize",s.value),r("update:currentPage",1),r("pageSizeChange",s.value)};return e.watch(()=>o.currentPage,C=>{l.value=C}),(C,p)=>(e.openBlock(),e.createElementBlock("nav",Hn,[e.createElementVNode("div",Wn,[e.createElementVNode("button",{type:"button","aria-label":"Previous",onClick:h,disabled:l.value===1,class:"border-white last:rounded-e-lg text-base h-[38px] min-w-[38px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 border text-sm rounded-lg bg-white text-gray-800 hover:shadow-sm hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-50 dark:bg-neutral-700 dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-800 py-2"},[...p[1]||(p[1]=[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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down rotate-90",height:"16",width:"16"},[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"})],-1),e.createElementVNode("span",{"aria-hidden":"true",class:"sr-only"},"Previous",-1)])],8,qn),e.createElementVNode("div",Yn,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,w=>(e.openBlock(),e.createElementBlock("button",{type:"button",key:w,onClick:B=>f(w),class:e.normalizeClass(l.value===w?"flex justify-center items-center rounded-lg text-sm dark:text-neutral-300 py-2 px-3 focus:outline-none disabled:opacity-50 disabled:pointer-events-none bg-[#e5e7eb] dark:bg-[#242424] border border-gray-200 text-base h-[38px] min-w-[38px]":"flex justify-center items-center rounded-lg text-sm dark:text-neutral-400 hover:bg-gray-100 py-2 px-3 focus:outline-none focus:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none dark:hover:bg-neutral-800 dark:focus:bg-neutral-800 text-base h-[38px] min-w-[38px]")},e.toDisplayString(w),11,Gn))),128))]),e.createElementVNode("button",{type:"button","aria-label":"Next",onClick:u,disabled:l.value===n.value,class:"border-white last:rounded-e-lg text-base h-[38px] min-w-[38px] py-2 px-2.5 inline-flex justify-center items-center gap-x-2 border text-sm rounded-lg bg-white text-gray-800 hover:shadow-sm hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-50 dark:bg-neutral-700 dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-800 py-2"},[...p[2]||(p[2]=[e.createElementVNode("span",{"aria-hidden":"true",class:"sr-only"},"Next",-1),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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down -rotate-90",height:"16",width:"16"},[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"})],-1)])],8,Qn)]),e.createElementVNode("div",Xn,[e.createElementVNode("div",Jn,[e.withDirectives(e.createElementVNode("div",ea,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList([10,20,30],w=>e.createElementVNode("button",{type:"button",key:w,onClick:B=>y(w),class:"w-full flex items-center gap-x-3.5 py-2 px-3 rounded-lg text-sm text-gray-800 hover:bg-gray-100 focus:outline-none focus:bg-gray-100 dark:text-neutral-400 dark:hover:bg-neutral-700 dark:hover:text-neutral-300 dark:focus:bg-neutral-700"},[e.createTextVNode(e.toDisplayString(w)+" ",1),s.value===w?(e.openBlock(),e.createElementBlock("svg",la,[...p[3]||(p[3]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M5 12l5 5l10 -10"},null,-1)])])):e.createCommentVNode("",!0)],8,ta)),64))],512),[[e.vShow,b.value]]),e.createElementVNode("button",{type:"button",class:"py-3 px-3.5 inline-flex items-center gap-x-1 text-sm rounded-lg border border-gray-200 text-gray-800 shadow-sm hover:bg-gray-50 focus:outline-none focus:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none dark:border-neutral-700 dark:text-white dark:hover:bg-neutral-700 dark:focus:bg-neutral-700 text-base h-[38px] min-w-[38px]","aria-haspopup":"menu","aria-expanded":"false","aria-label":"Dropdown",onClick:p[0]||(p[0]=w=>b.value=!b.value)},[e.createTextVNode(e.toDisplayString(s.value)+" ",1),p[4]||(p[4]=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:"icon icon-tabler icons-tabler-outline icon-tabler-chevron-down",height:"16",width:"16"},[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"}),e.createElementVNode("path",{d:"M6 9l6 6l6 -6"})],-1))])])])]))}}),pe=(t,a)=>{const o=t.__vccOpts||t;for(const[r,l]of a)o[r]=l;return o},oa={},na={class:"w-48 mx-auto mb-4",width:"178",height:"90",viewBox:"0 0 178 90",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function aa(t,a){return e.openBlock(),e.createElementBlock("svg",na,[...a[0]||(a[0]=[e.createStaticVNode('<rect x="27" y="50.5" width="124" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="27" y="50.5" width="124" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-50 dark:stroke-neutral-700/10"></rect><rect x="34.5" y="58" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="61" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="66.5" y="73" width="77" height="6" rx="3" fill="currentColor" class="fill-stone-50 dark:fill-neutral-700/30"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" fill="currentColor" class="fill-white dark:fill-neutral-800"></rect><rect x="19.5" y="28.5" width="139" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-100 dark:stroke-neutral-700/30"></rect><rect x="27" y="36" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><rect x="59" y="39" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><rect x="59" y="51" width="92" height="6" rx="3" fill="currentColor" class="fill-stone-100 dark:fill-neutral-700/70"></rect><g filter="url(#filter2)"><rect x="12" y="6" width="154" height="40" rx="8" fill="currentColor" class="fill-white dark:fill-neutral-800" shape-rendering="crispEdges"></rect><rect x="12.5" y="6.5" width="153" height="39" rx="7.5" stroke="currentColor" class="stroke-stone-100 dark:stroke-neutral-700/60" shape-rendering="crispEdges"></rect><rect x="20" y="14" width="24" height="24" rx="4" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect><rect x="52" y="17" width="60" height="6" rx="3" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect><rect x="52" y="29" width="106" height="6" rx="3" fill="currentColor" class="fill-stone-200 dark:fill-neutral-700"></rect></g><defs><filter id="filter2" x="0" y="0" width="178" height="64" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB"><feFlood flood-opacity="0" result="BackgroundImageFix"></feFlood><feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"></feColorMatrix><feOffset dy="6"></feOffset><feGaussianBlur stdDeviation="6"></feGaussianBlur><feComposite in2="hardAlpha" operator="out"></feComposite><feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0"></feColorMatrix><feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_1187_14810"></feBlend><feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_1187_14810" result="shape"></feBlend></filter></defs>',12)])])}const Te=pe(oa,[["render",aa]]),ra={},ia={xmlns:"http://www.w3.org/2000/svg",width:"21",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-layout-sidebar-right-collapse"};function sa(t,a){return e.openBlock(),e.createElementBlock("svg",ia,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M4 4m0 2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2z"},null,-1),e.createElementVNode("path",{d:"M15 4v16"},null,-1),e.createElementVNode("path",{d:"M9 10l2 2l-2 2"},null,-1)])])}const ca=pe(ra,[["render",sa]]),da={},ma={xmlns:"http://www.w3.org/2000/svg",width:"21",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round",class:"icon icon-tabler icons-tabler-outline icon-tabler-layout-sidebar-right-expand"};function pa(t,a){return e.openBlock(),e.createElementBlock("svg",ma,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M4 4m0 2a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2z"},null,-1),e.createElementVNode("path",{d:"M15 4v16"},null,-1),e.createElementVNode("path",{d:"M10 10l-2 2l2 2"},null,-1)])])}const ua=pe(da,[["render",pa]]),fa={},ga={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:"icon icon-tabler icons-tabler-outline icon-tabler-map"};function ha(t,a){return e.openBlock(),e.createElementBlock("svg",ga,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M3 7l6 -3l6 3l6 -3v13l-6 3l-6 -3l-6 3v-13"},null,-1),e.createElementVNode("path",{d:"M9 4v13"},null,-1),e.createElementVNode("path",{d:"M15 7v13"},null,-1)])])}const ya=pe(fa,[["render",ha]]),ba={},xa={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:"icon icon-tabler icons-tabler-outline icon-tabler-table"};function ka(t,a){return e.openBlock(),e.createElementBlock("svg",xa,[...a[0]||(a[0]=[e.createElementVNode("path",{stroke:"none",d:"M0 0h24v24H0z",fill:"none"},null,-1),e.createElementVNode("path",{d:"M3 5a2 2 0 0 1 2 -2h14a2 2 0 0 1 2 2v14a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-14z"},null,-1),e.createElementVNode("path",{d:"M3 10h18"},null,-1),e.createElementVNode("path",{d:"M10 3v18"},null,-1)])])}const wa=pe(ba,[["render",ka]]);function lt(t,a){let o;return function(...r){clearTimeout(o),o=setTimeout(()=>t(...r),a)}}const Va={class:"fixed inset-0 z-50 pointer-events-none"},Ca={class:"text-base font-semibold text-gray-900"},Ba={class:"px-4 pb-3 min-h-0 shrink-0 overflow-hidden"},Ea={class:"flex flex-col flex-1 min-h-0 overflow-hidden"},Na={class:"text-base font-semibold text-gray-900"},Sa={class:"flex-1 min-h-0 overflow-auto p-4"},_a=152,ot=96,Ma=270,nt=96,xe=pe(e.defineComponent({__name:"MobileModalShell",props:{open:{type:Boolean},title:{},topOffset:{},initialVariant:{},peekMode:{}},emits:["close","expand","collapse"],setup(t,{expose:a,emit:o}){const r=t,l=o,s=e.ref("full"),b=e.computed(()=>r.topOffset??"0px"),n=e.computed(()=>r.peekMode??"custom"),m=e.ref(!1),h=e.ref(0);let u=null,f=0,y=0;function C(E,i,V){return Math.max(E,Math.min(V,i))}function p(E){if(!E)return 0;const i=Number.parseFloat(E);return Number.isFinite(i)?i:0}function w(){if(typeof window>"u")return 0;const E=p(b.value);return Math.max(0,window.innerHeight-E)}function B(){const E=n.value==="custom",i=E?_a:Ma,V=E?ot:nt,g=E?40:60;if(typeof window>"u")return Math.max(V,i);const P=window.innerHeight*(g/100);return C(V,i,P)}function c(){return n.value==="custom"?ot:nt}function d(E){const i=w(),V=B(),g=c(),P=s.value==="full"?i:V;return i<=0?Math.max(g,P):C(g,P-E,i)}const D=e.computed(()=>({height:`${d(h.value)}px`}));e.watch(()=>r.open,E=>{E&&(s.value=r.initialVariant??"full"),m.value=!1,h.value=0}),e.watch(()=>r.initialVariant,E=>{r.open&&E&&(s.value=E)});function L(){s.value!=="full"&&(s.value="full",l("expand")),m.value||(h.value=0)}function z(){s.value!=="peek"&&(s.value="peek",l("collapse")),m.value||(h.value=0)}function x(E){if(E.pointerId!==u)return;E.cancelable&&E.preventDefault();const i=E.clientY-f;h.value=y+i}function k(E){if(E.pointerId!==u)return;window.removeEventListener("pointermove",x),window.removeEventListener("pointerup",k),window.removeEventListener("pointercancel",k),u=null;const i=E.clientY-f,V=y+i;h.value=V;const g=d(V),F=(typeof window<"u"?window.innerHeight:0)*.6,O=F>0&&g>=F,_=F>0&&!O;if(!(s.value==="peek"&&O||s.value==="full"&&_)){m.value=!0;return}m.value=!1,h.value=0,s.value==="peek"&&O?L():s.value==="full"&&_&&z()}function M(E){var i,V;E.button!==0&&E.pointerType==="mouse"||(E.cancelable&&E.preventDefault(),u=E.pointerId,f=E.clientY,y=h.value,m.value=!0,(V=(i=E.currentTarget).setPointerCapture)==null||V.call(i,E.pointerId),window.addEventListener("pointermove",x,{passive:!1}),window.addEventListener("pointerup",k),window.addEventListener("pointercancel",k))}return e.onBeforeUnmount(()=>{window.removeEventListener("pointermove",x),window.removeEventListener("pointerup",k),window.removeEventListener("pointercancel",k)}),a({expand:L,collapseToPeek:z}),(E,i)=>e.withDirectives((e.openBlock(),e.createElementBlock("div",Va,[e.createElementVNode("div",{class:e.normalizeClass(["absolute inset-0 bg-black/40 transition-opacity duration-150",s.value==="peek"?"opacity-0 pointer-events-none":"opacity-100 pointer-events-auto"]),onClick:i[0]||(i[0]=e.withModifiers(V=>s.value!=="peek"&&l("close"),["self"]))},null,2),e.createElementVNode("div",{class:e.normalizeClass(["pointer-events-auto absolute left-0 right-0 bottom-0 flex flex-col overflow-hidden bg-white shadow-[0_-4px_24px_rgba(0,0,0,0.12)] vs-mobile-modal-shell__panel",[s.value==="peek"?"rounded-t-2xl":"",m.value?"vs-mobile-modal-shell__panel--dragging":""]]),style:e.normalizeStyle(D.value)},[e.createElementVNode("div",{class:"shrink-0 flex flex-col items-center pt-2 pb-1 cursor-grab active:cursor-grabbing touch-none select-none",onPointerdown:M},[...i[5]||(i[5]=[e.createElementVNode("div",{class:"h-1.5 w-10 rounded-full bg-stone-300","aria-hidden":"true"},null,-1)])],32),s.value==="peek"&&n.value==="custom"?(e.openBlock(),e.createElementBlock("div",{key:0,class:"flex items-center justify-between gap-4 px-4 pb-3 border-b border-gray-200 shrink-0 touch-none select-none cursor-grab active:cursor-grabbing",onPointerdown:M},[e.createElementVNode("div",Ca,e.toDisplayString(t.title),1),e.createElementVNode("button",{type:"button",class:"h-9 w-9 inline-flex items-center justify-center rounded-full border border-gray-200 text-gray-600 hover:bg-gray-50 relative z-[80]",onPointerdown:i[1]||(i[1]=e.withModifiers(()=>{},["stop"])),onClick:i[2]||(i[2]=V=>l("close")),"aria-label":"Close"},[...i[6]||(i[6]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-5 h-5",width:"20",height:"20",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)])],32)],32)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("div",Ba,[e.renderSlot(E.$slots,"peek",{expand:L,collapse:z},()=>[e.createElementVNode("button",{type:"button",class:"w-full text-left text-base font-semibold text-gray-900 py-2 rounded-lg hover:bg-stone-50",onClick:L},e.toDisplayString(t.title),1)],!0)],512),[[e.vShow,s.value==="peek"&&n.value==="custom"]]),e.withDirectives(e.createElementVNode("div",Ea,[e.createElementVNode("div",{class:"flex items-center justify-between gap-4 px-4 pb-3 border-b border-gray-200 shrink-0 touch-none select-none cursor-grab active:cursor-grabbing",onPointerdown:M},[e.createElementVNode("div",Na,e.toDisplayString(t.title),1),e.createElementVNode("button",{type:"button",class:"h-9 w-9 inline-flex items-center justify-center rounded-full border border-gray-200 text-gray-600 hover:bg-gray-50 relative z-[80]",onPointerdown:i[3]||(i[3]=e.withModifiers(()=>{},["stop"])),onClick:i[4]||(i[4]=V=>l("close")),"aria-label":"Close"},[...i[7]||(i[7]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-5 h-5",width:"20",height:"20",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)])],32)],32),e.createElementVNode("div",Sa,[e.renderSlot(E.$slots,"default",{},void 0,!0)])],512),[[e.vShow,s.value==="full"||s.value==="peek"&&n.value==="clip-full"]])],6)],512)),[[e.vShow,t.open]])}}),[["__scopeId","data-v-74c152ea"]]),Da={class:"flex flex-col gap-2 pointer-events-auto self-end","data-peek-controls":"1"},za=e.defineComponent({__name:"MapMobilePeekControlButtons",props:{onOpenLayers:{type:Function},onOpenLegend:{type:Function}},setup(t){return(a,o)=>(e.openBlock(),e.createElementBlock("div",Da,[e.createElementVNode("button",{type:"button",class:"h-[28px] w-[28px] inline-flex items-center justify-center rounded-lg border border-gray-200 bg-white text-gray-800 shadow-md p-0 hover:bg-gray-50 cursor-pointer","aria-label":"Layers",onClick:o[0]||(o[0]=r=>t.onOpenLayers())},[...o[2]||(o[2]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2.5","stroke-linecap":"round","stroke-linejoin":"round","aria-hidden":"true"},[e.createElementVNode("path",{d:"M12 2 2 7l10 5 10-5-10-5Z"}),e.createElementVNode("path",{d:"M2 17l10 5 10-5"}),e.createElementVNode("path",{d:"M2 12l10 5 10-5"})],-1)])]),e.createElementVNode("button",{type:"button",class:"h-[28px] w-[28px] inline-flex items-center justify-center rounded-lg border border-gray-200 bg-white text-gray-800 shadow-md p-0 hover:bg-gray-50 cursor-pointer","aria-label":"Legend",onClick:o[1]||(o[1]=r=>t.onOpenLegend())},[...o[3]||(o[3]=[e.createStaticVNode('<svg xmlns="http://www.w3.org/2000/svg" width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M8 6h13"></path><path d="M8 12h13"></path><path d="M8 18h13"></path><path d="M3 6h.01"></path><path d="M3 12h.01"></path><path d="M3 18h.01"></path></svg>',1)])])]))}});function at(t,a,o=12,r=12){const l=a??"";return`${window.location.origin}/api/vtile/${t}/ua/{z}/{x}/{y}.vmt?pointZoom=${r}&clusterZoom=${o}&filter=${l}`}function Pa(t,a,o,r,l=12,s=12){if(!a)return;const b=at(t,r,l,s);a.addSource("vector",{type:"vector",tiles:[b],minzoom:0,maxzoom:12});const n=["coalesce",["get","point_count"],["get","pointCount"],["get","cluster_count"],["get","clusterCount"],0],m=[">",n,1],h=["<=",n,1],u=["in",["geometry-type"],["literal",["Point","MultiPoint"]]],f=["in",["geometry-type"],["literal",["Polygon","MultiPolygon"]]],y=["coalesce",["get","point_count_abbreviated"],["get","cluster_count_abbreviated"],["get","clusterCountAbbreviated"],n];a.addLayer({id:"vector-clusters",type:"circle",source:"vector","source-layer":t,filter:m,maxzoom:12,paint:{"circle-color":["step",n,"#51bbd6",100,"#f1f075",750,"#f28cb1"],"circle-radius":["step",n,18,100,26,750,32],"circle-opacity":.85}}),a.addLayer({id:"vector-cluster-count",type:"symbol",source:"vector","source-layer":t,filter:m,maxzoom:12,layout:{"text-field":["to-string",y],"text-font":["Noto Sans Regular"],"text-size":12},paint:{"text-color":"#1f2937"}}),a.addLayer({id:"vector-circle",type:"circle",maxzoom:12,source:"vector","source-layer":t,filter:["all",h,u],paint:{"circle-color":o,"circle-stroke-color":"#eee","circle-stroke-width":1,"circle-radius":["interpolate",["linear"],["zoom"],10,5,15,12]}}),a.addLayer({id:"vector-fill",type:"fill",minzoom:12,source:"vector","source-layer":t,filter:f,paint:{"fill-color":o,"fill-opacity":.6}})}const $a=[{id:"voyager",name:"Базова карта (voyager)",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"},{id:"orto",name:"Ортофото 10К",url:"https://data.gki.com.ua/api-user/rtile/orto10/ua/{z}/{x}/{y}.png",preview:"https://data.gki.com.ua/api-user/rtile/orto10/ua/12/2422/1400.png"},{id:"esri",name:"Esri",url:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}",preview:"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/12/2422/1400.png"},{id:"google",name:"Google",url:"https://mt1.google.com/vt/lyrs=s&x={x}&y={y}&z={z}",preview:"https://mt1.google.com/vt/lyrs=s&x=2422&y=1400&z=12"}],La={class:"relative w-auto h-full"},Fa={class:"legend-panel__header flex items-center justify-between gap-2 py-[7px] pl-[10px] pr-[7px]"},Aa={key:0,class:"text-[0.875rem] font-medium text-stone-700"},ja=["aria-label"],Ta={key:0,xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},Oa={key:1,xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},va={class:"flex justify-start items-center gap-2"},Ra={class:"flex-1 flex justify-between items-center min-w-0 ml-1"},Za={class:"text-[0.875rem]"},Ia={key:0,class:"text-[0.8rem] text-stone-500 shrink-0 ml-2"},Ua={key:1,class:"p-[10px]"},Ka={class:"flex justify-start items-center gap-2"},Ha={class:"flex-1 flex justify-between items-center min-w-0 ml-1"},Wa={class:"text-[0.875rem]"},qa={key:0,class:"text-[0.8rem] text-stone-500 shrink-0 ml-2"},Ya={key:0,class:"vs-map-slot-layers z-10 select-none",style:{display:"flex"}},Ga=["title","onClick"],Qa=["src"],Xa={class:"absolute py-2 px-4 text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg top-[-46px] hidden whitespace-nowrap left-1/2 -translate-x-1/2"},Ja={class:"vs-mobile-peek-controls px-3 pb-3"},er={class:"vs-map-slot-layers--peek z-10 select-none",style:{position:"static",display:"grid !important","grid-template-columns":"repeat(3, minmax(0, 1fr))",gap:"12px",width:"100%"}},tr=["title","onClick"],lr=["src"],or={class:"absolute py-2 px-4 text-sm text-stone-800 bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)] rounded-lg top-[-46px] hidden whitespace-nowrap left-1/2 -translate-x-1/2"},nr={class:"vs-mobile-peek-controls flex justify-center w-full"},ar={class:"w-full"},rr={class:"legend-panel__header flex items-center justify-between gap-2 py-[7px] pl-[10px] pr-[7px] pb-[12px]"},ir={class:"text-[0.875rem] font-medium text-stone-700"},sr={class:"legend-panel__content overflow-hidden transition-all duration-200 ease-out"},cr={class:"p-[10px] pt-0"},dr={class:"flex justify-start items-center gap-2"},mr={class:"flex-1 flex justify-between items-center min-w-0 ml-1"},pr={class:"text-[0.875rem]"},ur={key:0,class:"text-[0.8rem] text-stone-500 shrink-0 ml-2"},ke="vector-clusters",rt=e.defineComponent({__name:"map",props:{table:{},center:{},colorAttr:{},filter:{},modelValue:{},zoom:{},minZoom:{},maxZoom:{},map:{},showPopup:{type:Boolean,default:!0},mobilePeekControls:{type:Boolean},layers:{},clusterZoom:{},pointZoom:{},isCollapsible:{type:Boolean},legendTitle:{},legendWidth:{},alwaysShowPolygon:{type:Boolean}},emits:["update:modelValue","update:map"],setup(t,{emit:a}){const o=t,r=a;let l,s=null;const b=e.getCurrentInstance(),n=e.ref(null),m=e.ref(!1),h=e.ref(!1),u=e.ref(!1),f=e.ref(!1);let y=null,C=null;const p=["vector-circle","vector-fill"],w=e.ref(!0),B=e.computed(()=>{var $,A;return((A=($=b==null?void 0:b.appContext.config.globalProperties)==null?void 0:$.$settings)==null?void 0:A.basemaps)||[]}),c=e.computed(()=>(o.layers&&o.layers.length?o.layers:B.value.length?B.value:$a).map((A,R)=>{var ne;const j=A.id||((ne=A.name)==null?void 0:ne.toString().toLowerCase().replace(/\s+/g,"-"))||`layer-${R}`,q=A.name||A.id||`layer-${R}`;return{...A,id:j,name:q}})),d=e.ref(""),D=e.computed(()=>c.value.find($=>$.id===d.value)||c.value[0]);e.watch(c,$=>{var A;$.length&&(!d.value||!$.some(R=>R.id===d.value))&&(d.value=((A=$[0])==null?void 0:A.id)||"")},{immediate:!0});function L($){return $?$.replace("{x}","2422").replace("{y}","1400").replace("{z}","12"):""}const z=e.ref(null),x=e.ref(null),k=e.computed(()=>o.showPopup!==!1),M=["#1F77B4","#FF7F0E","#2CA02C","#D62728","#9467BD","#8C564B","#E377C2","#7F7F7F","#17BECF","#BCBD22"];let E;const i=[30,48];let V=null,g=[];function P(){if(typeof window>"u")return{zoom:null,center:null,hasQuery:!1};const $=new URLSearchParams(window.location.search),A=Number($.get("z")),R=Number($.get("y")),j=Number($.get("x")),q=$.has("x")&&$.has("y"),ne=$.has("z");return{zoom:ne?A:null,center:q?[j,R]:null,hasQuery:q||ne}}function F($,A){if(!$||typeof window>"u")return;const R=new URL(window.location.href);R.searchParams.set("z",A.toFixed(2)),R.searchParams.set("x",$[0].toFixed(6)),R.searchParams.set("y",$[1].toFixed(6)),window.history.replaceState({},"",R)}let O=!1;function _(){if(!l||!O)return;const $=l.getCenter();F([$.lng,$.lat],l.getZoom())}const v=()=>{O||(O=!0),_()};function U($){return $?["==",["to-string",["get","id"]],$]:["==",["literal",1],0]}const Z=["in",["geometry-type"],["literal",["Point","MultiPoint"]]],te=["in",["geometry-type"],["literal",["Polygon","MultiPolygon"]]];function Me(){const $=U(o.modelValue),A=["all",$,Z],R=["all",$,te];if(!l.getLayer("vector-highlight-circle")){const ne=(o.clusterZoom??12)-.01;l.addLayer({id:"vector-highlight-circle",type:"circle",maxzoom:ne,source:"vector","source-layer":o.table,paint:{"circle-color":"#ef4444","circle-opacity":.8,"circle-stroke-color":"#b91c1c","circle-stroke-width":0,"circle-radius":["interpolate",["linear"],["zoom"],10,10,12,11]}})}l.getLayer("vector-highlight-fill")||l.addLayer({id:"vector-highlight-fill",type:"line",minzoom:o.clusterZoom??12,source:"vector","source-layer":o.table,paint:{"line-color":"#b91c1c","line-width":3,"line-opacity":.8}}),l.setFilter("vector-highlight-circle",A),l.setFilter("vector-highlight-fill",R);const j=o.modelValue?"visible":"none";l.setLayoutProperty("vector-highlight-circle","visibility",j),l.setLayoutProperty("vector-highlight-fill","visibility",j),oe()}function le($){if(!l||!g.length)return;const A="#ef4444",R=$?["case",["all",["has","id"],["==",["to-string",["get","id"]],$]],A,g]:g;if(l.getLayer("vector-circle")&&l.setPaintProperty("vector-circle","circle-color",R),l.getLayer("vector-fill")){const j=$?["case",["all",["has","id"],["==",["to-string",["get","id"]],$]],A,g]:g;l.setPaintProperty("vector-fill","fill-color",j)}}function oe(){if(we(),!o.modelValue)return;let $=!0;V=window.setInterval(()=>{$=!$;const A=$?.8:.2;l!=null&&l.getLayer("vector-highlight-circle")&&l.setPaintProperty("vector-highlight-circle","circle-opacity",A),l!=null&&l.getLayer("vector-highlight-fill")&&l.setPaintProperty("vector-highlight-fill","line-opacity",A)},600)}function we(){V&&(clearInterval(V),V=null)}function Ve(){l&&(l.setCenter(o.center||i),l.setZoom(o.zoom||5))}function me(){if(!(l!=null&&l.setLayerZoomRange))return;const $=o.minZoom??0,A=Math.min((o.maxZoom??18)+.01,24);if(o.alwaysShowPolygon)l.getLayer("vector-circle")&&l.setLayerZoomRange("vector-circle",$,0),l.getLayer("vector-highlight-circle")&&l.setLayerZoomRange("vector-highlight-circle",$,0),l.getLayer("vector-fill")&&l.setLayerZoomRange("vector-fill",$,A),l.getLayer("vector-highlight-fill")&&l.setLayerZoomRange("vector-highlight-fill",$,A),l.getLayer(ke)&&l.setLayerZoomRange(ke,$,0),l.getLayer("vector-cluster-count")&&l.setLayerZoomRange("vector-cluster-count",$,0);else{const R=o.clusterZoom??12,j=R-.01,q=w.value?j:A;l.getLayer("vector-circle")&&l.setLayerZoomRange("vector-circle",$,q),l.getLayer("vector-highlight-circle")&&l.setLayerZoomRange("vector-highlight-circle",$,q),l.getLayer("vector-fill")&&l.setLayerZoomRange("vector-fill",R,A),l.getLayer("vector-highlight-fill")&&l.setLayerZoomRange("vector-highlight-fill",R,A),l.getLayer(ke)&&l.setLayerZoomRange(ke,$,j),l.getLayer("vector-cluster-count")&&l.setLayerZoomRange("vector-cluster-count",$,j)}}function ve(){if(l!=null&&l.getSource("vector")){try{const A=l.querySourceFeatures("vector",{sourceLayerId:o.table}).some(R=>{var q;const j=(q=R.geometry)==null?void 0:q.type;return j==="Polygon"||j==="MultiPolygon"});w.value=A}catch{}me()}}const Ce=P();O=Ce.hasQuery,e.onMounted(async()=>{E=(await fetch(`/api/data/${o.table}/${o.colorAttr}`).then(Y=>Y.json())).rows,E.forEach((Y,K)=>{Y.color||Object.assign(Y,{color:M[K%10]})}),s=new maplibregl.Popup({closeButton:!1,closeOnClick:!1});const A=D.value;if(!A)return;const R=Ce.center||o.center||i,j=Ce.zoom||o.zoom||5;l=new maplibregl.Map({container:n.value,style:{version:8,sources:{[A.id]:{type:"raster",tiles:[A.url],tileSize:256}},layers:[{id:A.id,type:"raster",source:A.id,minzoom:0,maxzoom:19}]},center:R,zoom:j,minZoom:o.minZoom??3,maxZoom:o.maxZoom??18,attributionControl:!1}),r("update:map",l);const q=o.mobilePeekControls?"bottom-right":"top-right";if(l.addControl(new maplibregl.NavigationControl,q),o.mobilePeekControls){const Y={onAdd:()=>{const K=document.createElement("div");return y=K,C=e.createApp(za,{onOpenLayers:()=>{u.value=!0},onOpenLegend:()=>{f.value=!0}}),C.mount(K),K},onRemove:()=>{C==null||C.unmount(),C=null,y=null}};l.addControl(Y,"bottom-right"),l.once("render",()=>{if(!y)return;const K=l.getContainer(),I=K.querySelector(".maplibregl-ctrl-bottom-right"),Q=K.querySelector(".maplibregl-ctrl-zoom-in"),re=Q==null?void 0:Q.closest(".maplibregl-ctrl-group");!I||!re||y.parentElement===I&&(I.removeChild(y),I.insertBefore(y,re.nextSibling))})}l.on("zoom",()=>{}),l.on("moveend",v),l.on("zoomend",v),O&&_(),l.on("load",()=>{l==null||l.resize(),m.value=!0;const Y=E.filter(I=>I.id).reduce((I,Q)=>[Q.id,Q.color].concat(I),[]),K=["match",["get",o.colorAttr],...Y,"#808080"];g=K,Pa(o.table,l,K,o.filter,o.clusterZoom,o.pointZoom??12),Me(),le(o.modelValue),me(),l.on("sourcedata",I=>{I.sourceId==="vector"&&I.isSourceLoaded&&l.getZoom()>=(o.clusterZoom??12)&&ve()})});const ne=Y=>{var I,Q;const K=(I=Y.features)==null?void 0:I[0];(Q=K==null?void 0:K.properties)!=null&&Q.id&&r("update:modelValue",K.properties.id)};p.forEach(Y=>{l.on("click",Y,ne)}),l.on("click",ke,Y=>{var ee,ue,ye;const K=(ee=Y.features)==null?void 0:ee[0];if(!K)return;const{geometry:I}=K,Q=(I==null?void 0:I.type)==="Point"?I.coordinates:(ye=(ue=I==null?void 0:I.coordinates)==null?void 0:ue[0])==null?void 0:ye[0];if(!Q)return;const re=Math.min(l.getZoom()+2,l.getMaxZoom());l.easeTo({center:Q,zoom:re})}),[...p,ke].forEach(Y=>{l.on("mouseenter",Y,()=>{l.getCanvas().style.cursor="pointer"}),l.on("mouseleave",Y,()=>{l.getCanvas().style.cursor=""})}),l.on("mousemove",Y=>{var ee,ue;if(!k.value){(ee=s==null?void 0:s.remove)==null||ee.call(s);return}if(!s)return;const K=l.queryRenderedFeatures(Y.point,{layers:p});if(!K||!K.length){s.remove();return}const I=K[0],{coordinates:Q}=I.geometry,re=I.geometry.type==="Point"?Q:Q[0][0];x.value=I.properties,s.setLngLat(re).setHTML((ue=z.value)==null?void 0:ue.innerHTML).addTo(l)})}),e.watch(()=>o.center,$=>{l&&l.setCenter($||i)}),e.watch(()=>o.zoom,$=>{l&&l.setZoom($)}),e.watch(()=>o.minZoom,$=>{l&&(l.setMinZoom($??3),me())}),e.watch(()=>o.maxZoom,$=>{l&&(l.setMaxZoom($??18),me())});function J($,A,R){if(!(l!=null&&l.getSource("vector")))return;const j=at(o.table,$??o.filter,A??o.clusterZoom??12,R??o.pointZoom??12);l.getSource("vector").setTiles([j])}return e.watch(()=>o.filter,$=>{J($)}),e.watch(()=>o.clusterZoom,$=>{J(void 0,$),me()}),e.watch(()=>o.pointZoom,$=>{J(void 0,void 0,$)}),e.watch(()=>o.alwaysShowPolygon,()=>{me(),J()}),e.watch(()=>o.modelValue,$=>{if(!l)return;const A=U($),R=["all",A,Z],j=["all",A,te];if(l.getLayer("vector-highlight-circle")){l.setFilter("vector-highlight-circle",R);const q=$?"visible":"none";l.setLayoutProperty("vector-highlight-circle","visibility",q)}if(l.getLayer("vector-highlight-fill")){l.setFilter("vector-highlight-fill",j);const q=$?"visible":"none";l.setLayoutProperty("vector-highlight-fill","visibility",q)}le($),$?oe():we()}),e.watch(d,($,A)=>{if(!l||!$)return;const R=c.value.find(q=>q.id===$);if(!R)return;l.getLayer(A)&&l.removeLayer(A),l.getSource(A)&&l.removeSource(A),l.addSource($,{type:"raster",tiles:[R.url],tileSize:256});const j=l.getLayer("vector-clusters")?"vector-clusters":l.getLayer("vector-circle")?"vector-circle":void 0;l.addLayer({id:R.id,type:"raster",source:R.id,minzoom:0,maxzoom:19},j)}),e.onBeforeUnmount(()=>{we(),l&&(l.off("moveend",v),l.off("zoomend",v),l.remove())}),($,A)=>{const R=e.resolveDirective("tooltip");return e.withDirectives((e.openBlock(),e.createElementBlock("div",La,[e.createElementVNode("div",{ref_key:"mapContainer",ref:n,class:"map-container w-auto relative"},null,512),e.withDirectives((e.openBlock(),e.createElementBlock("button",{type:"button",class:"absolute top-25 right-2 z-20 h-8 w-8 flex items-center justify-center rounded-lg bg-white border border-gray-200 shadow-[0_8px_20px_rgba(0,0,0,0.08)] text-[18px] leading-none text-gray-700 hover:bg-gray-50",title:"Повернутися до базового вигляду",onClick:Ve},[...A[3]||(A[3]=[e.createElementVNode("svg",{xmlns:"http://www.w3.org/2000/svg",class:"w-4 h-4",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"},[e.createElementVNode("path",{d:"M3 11L12 3l9 8"}),e.createElementVNode("path",{d:"M5 9v10h4v-6h6v6h4V9"})],-1)])])),[[R,"Повернутися до базового вигляду"]]),e.createElementVNode("div",{class:e.normalizeClass(["absolute left-[20px] bottom-[74px] bg-white rounded-lg z-10 border legend-panel",{"legend-panel--has-header":o.legendTitle||o.isCollapsible}]),style:e.normalizeStyle(o.legendWidth?{width:o.legendWidth}:{maxWidth:"250px"})},[o.legendTitle||o.isCollapsible?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",Fa,[o.legendTitle?(e.openBlock(),e.createElementBlock("span",Aa,e.toDisplayString(o.legendTitle),1)):e.createCommentVNode("",!0),o.isCollapsible?(e.openBlock(),e.createElementBlock("button",{key:1,type:"button",class:"legend-panel__toggle ml-auto shrink-0 p-1.5 rounded-full hover:bg-stone-100 text-stone-600","aria-label":h.value?"Згорнути легенду":"Розгорнути легенду",onClick:A[0]||(A[0]=j=>h.value=!h.value)},[h.value?(e.openBlock(),e.createElementBlock("svg",Ta,[...A[4]||(A[4]=[e.createElementVNode("path",{d:"M6 9l6 6 6-6"},null,-1)])])):(e.openBlock(),e.createElementBlock("svg",Oa,[...A[5]||(A[5]=[e.createElementVNode("path",{d:"m18 15-6-6-6 6"},null,-1)])]))],8,ja)):e.createCommentVNode("",!0)]),e.createElementVNode("div",{class:"legend-panel__content overflow-hidden transition-all duration-200 ease-out",style:e.normalizeStyle(o.isCollapsible&&!h.value?{maxHeight:"0",padding:"0",margin:"0",opacity:"0"}:{})},[e.createElementVNode("div",{class:e.normalizeClass(["p-[10px]",h.value&&(e.unref(E)||[]).length?"pt-0":"pt-2"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(E)||[],j=>(e.openBlock(),e.createElementBlock("div",{class:"legend-item",key:j.id},[e.createElementVNode("div",va,[e.createElementVNode("div",{class:"w-[15px] h-[15px] rounded-[50%] min-w-[15px]",style:e.normalizeStyle("background-color:"+j.color)},null,4),e.createElementVNode("div",Ra,[e.createElementVNode("span",Za,e.toDisplayString(j.text),1),j.count!=null?(e.openBlock(),e.createElementBlock("span",Ia,e.toDisplayString(j.count),1)):e.createCommentVNode("",!0)])])]))),128))],2)],4)],64)):(e.openBlock(),e.createElementBlock("div",Ua,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(E)||[],j=>(e.openBlock(),e.createElementBlock("div",{class:"legend-item",key:j.id},[e.createElementVNode("div",Ka,[e.createElementVNode("div",{class:"w-[15px] h-[15px] rounded-[50%] min-w-[15px]",style:e.normalizeStyle("background-color:"+j.color)},null,4),e.createElementVNode("div",Ha,[e.createElementVNode("span",Wa,e.toDisplayString(j.text),1),j.count!=null?(e.openBlock(),e.createElementBlock("span",qa,e.toDisplayString(j.count),1)):e.createCommentVNode("",!0)])])]))),128))]))],6),e.createElementVNode("div",{ref_key:"popupDiv",ref:z,style:{display:"none"}},[e.renderSlot($.$slots,"default",{hoverData:x.value})],512),o.mobilePeekControls?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",Ya,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,j=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:j.id,title:j.name,class:e.normalizeClass(["vs-map-slot-layers__layer relative",{focused:d.value===j.id}]),onClick:q=>d.value=j.id},[e.createElementVNode("img",{src:j.preview||L(j.url),class:"vs-map-slot-layers__image"},null,8,Qa),e.createElementVNode("div",Xa,e.toDisplayString(j.name),1)],10,Ga)),[[R,j.name]])),128))])),o.mobilePeekControls?(e.openBlock(),e.createBlock(xe,{key:1,open:u.value,title:"Шари","initial-variant":"peek","peek-mode":"clip-full","allow-expand":!1,onClose:A[1]||(A[1]=j=>u.value=!1)},{default:e.withCtx(()=>[e.createElementVNode("div",Ja,[e.createElementVNode("div",er,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,j=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:j.id,title:j.name,class:e.normalizeClass(["vs-map-slot-layers__layer relative",{focused:d.value===j.id}]),onClick:q=>d.value=j.id},[e.createElementVNode("img",{src:j.preview||L(j.url),class:"vs-map-slot-layers__image",style:{width:"100%",height:"100","object-fit":"cover",display:"block"}},null,8,lr),e.createElementVNode("div",or,e.toDisplayString(j.name),1)],10,tr)),[[R,j.name]])),128))])])]),_:1},8,["open"])):e.createCommentVNode("",!0),o.mobilePeekControls?(e.openBlock(),e.createBlock(xe,{key:2,open:f.value,title:"Легенда","initial-variant":"peek","peek-mode":"clip-full","peek-height-px":200,onClose:A[2]||(A[2]=j=>f.value=!1)},{default:e.withCtx(()=>[e.createElementVNode("div",nr,[e.createElementVNode("div",ar,[e.createElementVNode("div",rr,[e.createElementVNode("span",ir,e.toDisplayString(o.legendTitle||"Легенда"),1)]),e.createElementVNode("div",sr,[e.createElementVNode("div",cr,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(E)||[],j=>(e.openBlock(),e.createElementBlock("div",{class:"legend-item",key:j.id},[e.createElementVNode("div",dr,[e.createElementVNode("div",{class:"w-[15px] h-[15px] rounded-[50%] min-w-[15px]",style:e.normalizeStyle("background-color:"+j.color)},null,4),e.createElementVNode("div",mr,[e.createElementVNode("span",pr,e.toDisplayString(j.text),1),j.count!=null?(e.openBlock(),e.createElementBlock("span",ur,e.toDisplayString(j.count),1)):e.createCommentVNode("",!0)])])]))),128))])])])])]),_:1},8,["open"])):e.createCommentVNode("",!0)],512)),[[e.vShow,m.value]])}}}),it={mounted(t,a){if(typeof document>"u")return;let o=null;const r=()=>{o=document.createElement("div"),o.textContent=a.value,Object.assign(o.style,{position:"absolute",background:"#333",color:"#fff",padding:"4px 8px",borderRadius:"4px",fontSize:"12px",whiteSpace:"nowrap",pointerEvents:"none",zIndex:"9999"}),document.body.appendChild(o);const s=t.getBoundingClientRect();o.style.left=`${s.left+window.scrollX}px`,o.style.top=`${s.top+window.scrollY-o.offsetHeight-5}px`},l=()=>{o&&o.parentNode&&(o.parentNode.removeChild(o),o=null)};t.addEventListener("mouseenter",r),t.addEventListener("mouseleave",l),Object.assign(t,{tooltipHandlers:{showTooltip:r,hideTooltip:l}})},unmounted(t){if(typeof document>"u")return;const a=t.tooltipHandlers;a&&(t.removeEventListener("mouseenter",a.showTooltip),t.removeEventListener("mouseleave",a.hideTooltip))}},fr={},gr={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-list-filter-icon lucide-list-filter"};function hr(t,a){return e.openBlock(),e.createElementBlock("svg",gr,[...a[0]||(a[0]=[e.createElementVNode("path",{d:"M2 5h20"},null,-1),e.createElementVNode("path",{d:"M6 12h12"},null,-1),e.createElementVNode("path",{d:"M9 19h6"},null,-1)])])}const yr=pe(fr,[["render",hr]]),br={},xr={xmlns:"http://www.w3.org/2000/svg",class:"w-5 h-5 shrink-0",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round","stroke-linejoin":"round"};function kr(t,a){return e.openBlock(),e.createElementBlock("svg",xr,[...a[0]||(a[0]=[e.createElementVNode("circle",{cx:"11",cy:"11",r:"8"},null,-1),e.createElementVNode("path",{d:"m21 21-4.35-4.35"},null,-1)])])}const wr=pe(br,[["render",kr]]),Vr={},Cr={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-table-icon lucide-table"};function Br(t,a){return e.openBlock(),e.createElementBlock("svg",Cr,[...a[0]||(a[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 Er=pe(Vr,[["render",Br]]),Nr={class:"absolute inset-x-0 top-[12px] z-40 px-[12px] pointer-events-none"},Sr={class:"flex flex-wrap gap-2"},_r=["disabled"],Mr={key:0,class:"pointer-events-none absolute top-1 right-0.5 h-3 w-3 rounded-full bg-blue-400","aria-hidden":"true"},Dr=e.defineComponent({__name:"MobileOverlayActions",props:{activeModal:{},filtersDisabled:{type:Boolean},hasActiveFilters:{type:Boolean}},emits:["openSearch","openFilters","openTable"],setup(t){return(a,o)=>(e.openBlock(),e.createElementBlock("div",Nr,[e.createElementVNode("div",Sr,[e.createElementVNode("button",{type:"button",class:e.normalizeClass(["pointer-events-auto py-2 px-3 h-[44px] inline-flex items-center gap-x-2 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",{"bg-stone-50":t.activeModal==="search"}]),onClick:o[0]||(o[0]=r=>a.$emit("openSearch"))},[e.createVNode(wr)],2),e.createElementVNode("button",{type:"button",class:e.normalizeClass(["pointer-events-auto relative py-2 px-3 h-[44px] inline-flex items-center gap-x-2 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",{"bg-stone-50":t.activeModal==="filters"}]),disabled:t.filtersDisabled,onClick:o[1]||(o[1]=r=>a.$emit("openFilters"))},[e.createVNode(yr,{"stroke-width":1,class:"text-gray-900"}),o[3]||(o[3]=e.createElementVNode("span",{class:"font-medium"},"Фільтри",-1)),t.hasActiveFilters&&!t.filtersDisabled?(e.openBlock(),e.createElementBlock("span",Mr)):e.createCommentVNode("",!0)],10,_r),e.createElementVNode("button",{type:"button",class:e.normalizeClass(["pointer-events-auto py-2 px-3 h-[44px] inline-flex items-center gap-x-2 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",{"bg-stone-50":t.activeModal==="table"}]),onClick:o[2]||(o[2]=r=>a.$emit("openTable"))},[e.createVNode(Er,{"stroke-width":1,class:"text-gray-900"}),o[4]||(o[4]=e.createElementVNode("span",{class:"font-medium"},"Таблиця",-1))],2)])]))}}),zr={key:0,class:"relative w-full h-full vs-mobile-parts-map"},Pr={class:"flex flex-col min-h-0 gap-4"},$r={class:"flex flex-col min-h-0 flex-1"},Lr={key:1,class:"wrapperTable flex flex-col min-h-0"},Fr={key:1,class:"text-center py-8"},Ar={key:2,class:"mt-4 pt-4 border-t border-stone-200 shrink-0"},jr={class:"flex flex-col flex-1 min-h-0 overflow-hidden"},Tr={id:"active-filters"},Or={class:"flex-1 min-h-0"},vr={key:1,class:"text-sm text-stone-500"},Rr={class:"wrapperTable flex flex-col min-h-0"},Zr={key:1,class:"text-center py-12"},Ir={key:0,class:"mt-4 pt-4 border-t border-stone-200"},Ur=["onClick"],Kr={class:"w-full gap-5 inline-flex mb-[6px] pr-3"},Hr={class:"flex items-center"},Wr=["title"],qr={class:"max-[1000px]:flex gap-2 min-[1001px]:hidden"},Yr={class:"flex"},Gr={key:0,class:"flex items-center py-[15px] pb-[24px] pl-2 pr-6 gap-4"},Qr={class:"font-bold text-2xl mr-[10px]"},Xr={class:"text-sm text-stone-500 font-medium"},Jr={key:0,class:"inline-flex items-center gap-2 text-sm text-stone-700 select-none ml-auto mt-auto"},ei={class:"wrapperTable flex flex-col",style:{height:"calc(100vh - 302px)"}},ti={key:1,class:"text-center py-28"},li={key:1},oi={key:2,class:"my-5 pr-2"},ni={class:"flex justify-between"},ai={class:"w-full lg:w-1/2 relative"},ri={key:0,class:"absolute inset-0 z-20 flex flex-col items-center justify-center bg-black/40 backdrop-blur-[2px]"},st="(max-width: 999px)",_e="0px",Oe=e.defineComponent({__name:"vs-parts-map",props:{title:{},table:{},map:{},rows:{},zoom:{},minZoom:{default:3},maxZoom:{default:18},center:{},initTotal:{},colorAttr:{},id:{},filters:{},history:{type:Boolean},layers:{},objectsInView:{type:Boolean,default:!0},clusterZoom:{default:12},isCollapsible:{type:Boolean},legendTitle:{},legendWidth:{},polygonFitBbox:{type:Boolean},alwaysShowPolygon:{type:Boolean},mobileFilterView:{},mobileFilterLimit:{}},emits:["change:filter","update:map"],setup(t,{emit:a}){var ct,dt,mt,pt,ut,ft,gt;const o=e.getCurrentInstance();o&&!(o!=null&&o.appContext.directives.tooltip)&&(o.appContext.directives.tooltip=it);function r(N){return N?(N.type==="Point"?N.coordinates:null)||(N.type.includes("Multi")?N.coordinates[0][0][0]:N.coordinates[0][0]):null}function l(N){switch(N==null?void 0:N.type){case"Polygon":return N.coordinates[0];case"MultiPolygon":return N.coordinates.flatMap(S=>S[0]);case"LineString":return N.coordinates;case"MultiLineString":return N.coordinates.flat();default:return[]}}function s(N){if(!N||N.type==="Point"||N.type==="MultiPoint")return null;const S=l(N);if(!S.length)return null;let W=1/0,T=1/0,ie=-1/0,G=-1/0;return S.forEach(([H,se])=>{H<W&&(W=H),se<T&&(T=se),H>ie&&(ie=H),se>G&&(G=se)}),[[W,T],[ie,G]]}function b(N){return(N==null?void 0:N.type)==="Polygon"||(N==null?void 0:N.type)==="MultiPolygon"}const n=t,m=e.useSlots(),h=e.computed(()=>n.mobileFilterView??"vertical"),u=e.computed(()=>n.mobileFilterLimit!==void 0?{limit:n.mobileFilterLimit}:{}),f=a,y=e.ref(0);y.value=n.initTotal??((ct=n.rows)==null?void 0:ct.length)??0;const C=e.ref(""),p=e.ref(null),w=e.ref(!0),B=e.ref(((dt=n.rows)==null?void 0:dt.length)===1),c=e.ref(!1);let d=null;const D=e.ref(!1);typeof window<"u"&&(d=window.matchMedia(st),D.value=d.matches,c.value=!0);const L=e.ref(n.rows),z=e.ref(1),x=e.ref(20),k=e.ref(n.filters||[]),M=e.ref(""),E=e.ref({}),i=e.computed(()=>Object.values(E.value).some(N=>Array.isArray(N)?N.some(S=>S!=null&&S!==""):N&&typeof N=="object"?Object.values(N).some(S=>S!=null&&S!==""):N===null?!0:N!==void 0&&N!=="")),V=e.ref(((mt=n.rows)==null?void 0:mt.length)===1?n.rows[0]:{}),g=e.ref(((pt=n.rows)==null?void 0:pt.length)===1?n.rows[0].id:""),P=e.ref(((ut=n.rows)==null?void 0:ut.length)===1?r((ft=n.rows[0])==null?void 0:ft.geom):n.center||null),F=e.ref(((gt=n.rows)==null?void 0:gt.length)===1?14:n.zoom||5),O=e.ref(!1),_=e.ref(!1),v=e.ref("");let U=!1;const Z=e.ref(null),te=e.ref(!1);function Me(){if(!d)return;const N=D.value;D.value=d.matches,N!==D.value&&(Z.value=null,e.nextTick(()=>{var S,W;(W=(S=p.value)==null?void 0:S.resize)==null||W.call(S)}))}const le=e.ref(null),oe=e.ref(null),we=e.computed(()=>{var N;return B.value&&!((N=V.value)!=null&&N.geom)}),Ve=e.computed({get:()=>we.value?"":g.value,set:N=>{g.value=N,D.value&&(N?(te.value=!0,Z.value="details"):Z.value==="details"&&(Z.value=null))}});function me(){var G,H,se;if(n.alwaysShowPolygon){le.value=null,oe.value=null;return}if(!n.polygonFitBbox||!p.value||!((G=V.value)!=null&&G.geom)){le.value=null,oe.value=null;return}const{geom:N}=V.value;if(!b(N)){le.value=null,oe.value=null;return}const S=s(N);if(!S){le.value=null,oe.value=null;return}const W=(se=(H=p.value).cameraForBounds)==null?void 0:se.call(H,S,{padding:20,maxZoom:16}),T=W==null?void 0:W.zoom,ie=n.clusterZoom??12;if(T!=null&&T<ie){const ht=Math.floor(T);le.value=ht,oe.value=ht}else le.value=null,oe.value=null}function ve(N){return Object.entries(N).filter(([,S])=>Array.isArray(S)?S.length:S).map(([S,W])=>`${S}=${W}`).join("|")}function Ce(){var T,ie,G,H;if(!p.value||!_.value)return;const N=(ie=(T=p.value).getBounds)==null?void 0:ie.call(T);if(!N)return;const S=(G=N.getSouthWest)==null?void 0:G.call(N),W=(H=N.getNorthEast)==null?void 0:H.call(N);!S||!W||(v.value=`${S.lng} ${S.lat},${W.lng} ${W.lat}`)}async function J(N=!1){await e.nextTick();const S=ve(E.value);M.value=S,_.value?Ce():v.value="";try{const W={search:C.value,limit:x.value.toString(),page:z.value.toString(),filter:S,..._.value&&v.value?{bbox:v.value}:{}},T=new URL(`/api/data/${n.table}`,window.location.origin)+(g.value?`/${g.value}`:""),ie=new URLSearchParams(W).toString(),G=await fetch(`${T.toString()}?${ie}`).then(H=>H.json());if(g.value){let H;if(G.rows.length>1?H=G.rows.find(se=>se.id===g.value):[H]=G.rows,V.value=H,!N&&(H!=null&&H.geom)){const se=n.polygonFitBbox?s(H.geom):null;se&&p.value?p.value.fitBounds(se,{padding:20,maxZoom:16,duration:500}):(P.value=r(H.geom),F.value=14)}me(),B.value=!0}else le.value=null,oe.value=null,B.value=!1,O.value||(F.value=n.zoom||5),L.value=G==null?void 0:G.rows;O.value=!1,y.value=G.filtered,Kn({page:z.value,filter:S,id:g.value,filterByView:_.value})}catch(W){console.error(W.message)}}const $=lt(()=>J(),300),A=lt(()=>J(!0),400);function R(){!p.value||U||!_.value||(p.value.on("moveend",A),p.value.on("zoomend",A),U=!0)}function j(){!p.value||!U||(p.value.off("moveend",A),p.value.off("zoomend",A),U=!1)}function q(N){x.value=N,z.value=1,J()}function ne(N){z.value=N,J()}function Re(N){E.value=N.data,z.value=1,g.value?g.value="":J(),f("change:filter",N)}async function Y(){if(n.filters)return;const S=await(await fetch(`/api/filter/${n.table}`)).json();k.value=S.list}function K(){E.value={},C.value="",J()}e.onMounted(async()=>{var W,T;d||(d=window.matchMedia(st)),c.value||(D.value=d.matches,c.value=!0),d.addEventListener("change",Me),D.value&&(w.value=!1);const N=new URLSearchParams(window.location.search);z.value=Number(N.get("page"))||1,x.value=Number(N.get("limit"))||x.value,g.value=N.get("id")||"",B.value=!!g.value,M.value=N.get("filter")||"";const S=N.get("bbox");S!==null?_.value=S!=="0":_.value=!1,(T=(W=N.get("filter"))==null?void 0:W.split("|"))==null||T.forEach(ie=>{const[G,H]=ie.split("=");G&&(E.value[G]=H!=null&&H.includes(",")?H.split(","):[H])}),Y(),!L.value&&!g.value&&J()}),e.onBeforeUnmount(()=>{d==null||d.removeEventListener("change",Me),j()});function I(){O.value=!0,B.value=!1,V.value=null,g.value="",le.value=null,oe.value=null}function Q(N){Z.value=N}function re(){Z.value=null}async function ee(){var N,S;await e.nextTick(),(S=(N=p.value)==null?void 0:N.resize)==null||S.call(N)}function ue(){I(),re()}function ye(N){if(te.value=!0,N!=null&&N.geom){const S=n.polygonFitBbox?s(N.geom):null;S&&p.value?p.value.fitBounds(S,{padding:20,maxZoom:16,duration:500}):(P.value=r(N.geom),F.value=16)}V.value=N,g.value=N.id,me(),D.value&&(Z.value="details")}return e.watch(Z,async()=>{var N,S;await e.nextTick(),(S=(N=p.value)==null?void 0:N.resize)==null||S.call(N)}),e.watch(p,N=>{var S;f("update:map",N),N&&_.value&&R(),N&&n.polygonFitBbox&&((S=V.value)!=null&&S.geom)&&me()}),e.watch(C,N=>{N||J()}),e.watch(g,()=>{J()}),e.watch(_,()=>{_.value?R():j(),J()}),(N,S)=>{var W;return c.value?(e.openBlock(),e.createElementBlock("section",{key:0,class:e.normalizeClass(D.value?"":"pt-[20px]")},[D.value?(e.openBlock(),e.createElementBlock("div",zr,[e.createVNode(rt,{table:n.table,map:p.value,"onUpdate:map":S[0]||(S[0]=T=>p.value=T),zoom:F.value,minZoom:n.minZoom,maxZoom:n.maxZoom,colorAttr:n.colorAttr,filter:M.value,center:P.value,clusterZoom:n.alwaysShowPolygon?0:le.value??n.clusterZoom,pointZoom:n.alwaysShowPolygon?0:oe.value??12,alwaysShowPolygon:n.alwaysShowPolygon,modelValue:Ve.value,"onUpdate:modelValue":S[1]||(S[1]=T=>Ve.value=T),layers:n.layers,isCollapsible:n.isCollapsible,legendTitle:n.legendTitle,legendWidth:n.legendWidth,"show-popup":!1,"mobile-peek-controls":!0},{default:e.withCtx(({hoverData:T})=>[e.renderSlot(N.$slots,"popup",{data:T})]),_:3},8,["table","map","zoom","minZoom","maxZoom","colorAttr","filter","center","clusterZoom","pointZoom","alwaysShowPolygon","modelValue","layers","isCollapsible","legendTitle","legendWidth"]),e.createVNode(Dr,{"active-modal":Z.value,"filters-disabled":!k.value.length,"has-active-filters":i.value,onOpenSearch:S[2]||(S[2]=T=>Q("search")),onOpenFilters:S[3]||(S[3]=T=>Q("filters")),onOpenTable:S[4]||(S[4]=T=>Q("table"))},null,8,["active-modal","filters-disabled","has-active-filters"]),e.createVNode(xe,{open:Z.value==="search",title:"Пошук","top-offset":_e,"initial-variant":"full","peek-mode":"clip-full",onClose:re,onExpand:ee,onCollapse:ee},{default:e.withCtx(()=>[e.createElementVNode("div",Pr,[e.createVNode(e.unref(ce),{type:"text",modelValue:C.value,"onUpdate:modelValue":S[5]||(S[5]=T=>C.value=T),name:"search",label:"Пошук",onChange:e.unref($)},null,8,["modelValue","onChange"]),e.createElementVNode("div",$r,[e.unref(m)["mobile-search-results"]?e.renderSlot(N.$slots,"mobile-search-results",{key:0,rows:L.value,selectRow:ye,closeModal:re}):(e.openBlock(),e.createElementBlock("div",Lr,[y.value>=1?e.renderSlot(N.$slots,"table",{key:0,rows:L.value,selectRow:ye,isMapVisible:!1}):(e.openBlock(),e.createElementBlock("div",Fr,[e.createVNode(Te),S[19]||(S[19]=e.createElementVNode("h2",{class:"font-medium text-base text-gray-500 rounded-xl"}," За вашим запитом даних не знайдено! ",-1)),S[20]||(S[20]=e.createElementVNode("p",{class:"font-normal text-sm text-gray-500 rounded-xl"}," Введіть, будь ласка, інші значення для пошуку. ",-1)),e.createElementVNode("button",{type:"button",class:"mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",onClick:K}," Очистити дані пошуку ")]))])),y.value>=1?(e.openBlock(),e.createElementBlock("div",Ar,[e.createVNode(je,{total:y.value,currentPage:z.value??1,pageSize:x.value,onPageChange:S[6]||(S[6]=T=>ne(T)),onPageSizeChange:S[7]||(S[7]=T=>q(T))},null,8,["total","currentPage","pageSize"])])):e.createCommentVNode("",!0)])])]),_:3},8,["open"]),e.createVNode(xe,{open:Z.value==="filters",title:"Фільтри","top-offset":_e,"initial-variant":"full","peek-mode":"clip-full",onClose:re,onExpand:ee,onCollapse:ee},{default:e.withCtx(()=>[e.createElementVNode("div",jr,[e.withDirectives(e.createElementVNode("div",Tr,null,512),[[e.vShow,Z.value==="filters"]]),e.createElementVNode("div",Or,[k.value.length?(e.openBlock(),e.createBlock(e.unref(Se),e.mergeProps({key:0,schema:k.value,view:h.value},u.value,{value:E.value,teleportActive:"#active-filters",onChange:Re}),null,16,["schema","view","value"])):(e.openBlock(),e.createElementBlock("p",vr,"Фільтри недоступні для цього переліку."))])])]),_:1},8,["open"]),e.createVNode(xe,{open:Z.value==="table",title:"Таблиця","top-offset":_e,"initial-variant":"full","peek-mode":"clip-full",onClose:re,onExpand:ee,onCollapse:ee},{default:e.withCtx(()=>[e.createElementVNode("div",Rr,[y.value>=1?e.renderSlot(N.$slots,"table",{key:0,rows:L.value,selectRow:ye,isMapVisible:!1}):(e.openBlock(),e.createElementBlock("div",Zr,[e.createVNode(Te),S[21]||(S[21]=e.createElementVNode("h2",{class:"font-medium text-base text-gray-500 rounded-xl"}," За вашим запитом даних не знайдено! ",-1)),S[22]||(S[22]=e.createElementVNode("p",{class:"font-normal text-sm text-gray-500 rounded-xl"}," Введіть, будь ласка, інші значення для пошуку. ",-1)),e.createElementVNode("button",{type:"button",class:"mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",onClick:K}," Очистити дані пошуку ")]))]),y.value>=1?(e.openBlock(),e.createElementBlock("div",Ir,[e.createVNode(je,{total:y.value,currentPage:z.value??1,pageSize:x.value,onPageChange:S[8]||(S[8]=T=>ne(T)),onPageSizeChange:S[9]||(S[9]=T=>q(T))},null,8,["total","currentPage","pageSize"])])):e.createCommentVNode("",!0)]),_:3},8,["open"]),e.createVNode(xe,{open:Z.value==="details",title:"Об'єкт","top-offset":_e,"initial-variant":te.value?"peek":"full","peek-mode":"custom",onClose:ue,onExpand:ee,onCollapse:ee},{peek:e.withCtx(({expand:T})=>[e.unref(m)["mobile-details-peek"]?e.renderSlot(N.$slots,"mobile-details-peek",{key:0,selectedRow:V.value,expand:T,close:ue}):(e.openBlock(),e.createElementBlock("button",{key:1,type:"button",class:"w-full text-left text-base font-semibold text-gray-900 py-2 rounded-lg hover:bg-stone-50",onClick:T}," Деталі об'єкта ",8,Ur))]),default:e.withCtx(()=>[e.renderSlot(N.$slots,"details",{table:n.table,selectedRow:V.value,closeObjCard:ue})]),_:3},8,["open","initial-variant"]),e.renderSlot(N.$slots,"default",{table:n.table,map:p.value,selectedRow:V.value})])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.renderSlot(N.$slots,"header",{title:n.title,total:y.value}),e.createElementVNode("div",Kr,[e.createVNode(e.unref(ce),{type:"text",modelValue:C.value,"onUpdate:modelValue":S[10]||(S[10]=T=>C.value=T),name:"search",label:"Пошук",onChange:e.unref($)},null,8,["modelValue","onChange"]),k.value.length?(e.openBlock(),e.createBlock(e.unref(Se),{key:0,schema:k.value,view:"inline",onChange:Re,limit:5,value:E.value,ref:"filterRef"},null,8,["schema","value"])):e.createCommentVNode("",!0),e.createElementVNode("div",Hr,[e.createElementVNode("button",{type:"button",class:"map-visible-button py-2 px-2 hidden min-[1001px]:inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100",title:w.value?"Приховати карту":"Показати карту",onClick:S[11]||(S[11]=T=>w.value=!w.value)},[w.value?(e.openBlock(),e.createBlock(ca,{key:0})):(e.openBlock(),e.createBlock(ua,{key:1})),S[23]||(S[23]=e.createElementVNode("span",{class:"sr-only"},"Відкрити мапу",-1))],8,Wr),e.createElementVNode("div",qr,[e.createElementVNode("button",{onClick:S[12]||(S[12]=T=>w.value=!1),class:"py-2 px-2 h-[38px] inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"},[e.createVNode(wa)]),e.createElementVNode("button",{onClick:S[13]||(S[13]=T=>w.value=!0),class:"py-2 px-2 h-[38px] inline-flex items-center gap-x-1.5 text-sm rounded-lg border border-gray-200 bg-white text-gray-600 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"},[e.createVNode(ya)])])])]),e.createElementVNode("div",Yr,[e.createElementVNode("div",{class:e.normalizeClass(["relative overflow-hidden shrink-0",w.value?"w-2/4 mr-0":"w-full mr-3",B.value?"hidden":""])},[(W=N.$slots)!=null&&W.header?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",Gr,[e.createElementVNode("div",null,[e.createElementVNode("span",Qr,e.toDisplayString(n.title),1),e.createElementVNode("span",Xr,e.toDisplayString(y.value),1),S[24]||(S[24]=e.createElementVNode("span",{class:"text-sm text-stone-500 font-medium"}," об'єктів",-1))]),n.objectsInView?(e.openBlock(),e.createElementBlock("label",Jr,[e.withDirectives(e.createElementVNode("input",{type:"checkbox",class:"accent-blue-600 w-4 h-4","onUpdate:modelValue":S[14]||(S[14]=T=>_.value=T)},null,512),[[e.vModelCheckbox,_.value]]),S[25]||(S[25]=e.createElementVNode("span",null,"В межах видимої області",-1))])):e.createCommentVNode("",!0)])),e.createElementVNode("div",ei,[y.value>=1?e.renderSlot(N.$slots,"table",{key:0,rows:L.value,selectRow:ye}):(e.openBlock(),e.createElementBlock("div",ti,[e.createVNode(Te),S[26]||(S[26]=e.createElementVNode("h2",{class:"font-medium text-base text-gray-500 rounded-xl"}," За вашим запитом даних не знайдено! ",-1)),S[27]||(S[27]=e.createElementVNode("p",{class:"font-normal text-sm text-gray-500 rounded-xl"}," Введіть, будь ласка, інші значення для пошуку. ",-1)),e.createElementVNode("button",{type:"button",class:"mt-[10px] py-2 px-2.5 inline-flex items-center gap-x-1.5 text-xs rounded-lg border border-stone-200 bg-white text-stone-800 shadow-sm hover:bg-stone-50 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-stone-100",onClick:K}," Очистити дані пошуку ")]))]),y.value>=1?(e.openBlock(),e.createElementBlock("hr",li)):e.createCommentVNode("",!0),y.value>=1?(e.openBlock(),e.createElementBlock("div",oi,[e.createElementVNode("div",ni,[e.createVNode(je,{total:y.value,currentPage:z.value??1,pageSize:x.value,onPageChange:S[15]||(S[15]=T=>ne(T)),onPageSizeChange:S[16]||(S[16]=T=>q(T))},null,8,["total","currentPage","pageSize"])])])):e.createCommentVNode("",!0)],2),B.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(w.value?"lg:static lg:w-1/2 mr-0 pb-5":"pb-5 mr-3"),style:{height:"calc(100vh - 152px)"}},[e.renderSlot(N.$slots,"details",{table:n.table,selectedRow:V.value,closeObjCard:I})],2)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("div",ai,[e.createVNode(rt,{table:n.table,map:p.value,"onUpdate:map":S[17]||(S[17]=T=>p.value=T),zoom:F.value,minZoom:n.minZoom,maxZoom:n.maxZoom,colorAttr:n.colorAttr,filter:M.value,center:P.value,clusterZoom:n.alwaysShowPolygon?0:le.value??n.clusterZoom,pointZoom:n.alwaysShowPolygon?0:oe.value??12,alwaysShowPolygon:n.alwaysShowPolygon,modelValue:Ve.value,"onUpdate:modelValue":S[18]||(S[18]=T=>Ve.value=T),layers:n.layers,isCollapsible:n.isCollapsible,legendTitle:n.legendTitle,legendWidth:n.legendWidth,"show-popup":!0},{default:e.withCtx(({hoverData:T})=>[e.renderSlot(N.$slots,"popup",{data:T})]),_:3},8,["table","map","zoom","minZoom","maxZoom","colorAttr","filter","center","clusterZoom","pointZoom","alwaysShowPolygon","modelValue","layers","isCollapsible","legendTitle","legendWidth"]),e.renderSlot(N.$slots,"default",{table:n.table,map:p.value,selectedRow:V.value}),we.value?(e.openBlock(),e.createElementBlock("div",ri,[...S[28]||(S[28]=[e.createStaticVNode('<svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="text-white/80"><path d="M12.75 7.09a3 3 0 0 1 2.16 2.16"></path><path d="M17.072 17.072c-1.634 2.17-3.527 3.912-4.471 4.727a1 1 0 0 1-1.202 0C9.539 20.193 4 14.993 4 10a8 8 0 0 1 1.432-4.568"></path><path d="m2 2 20 20"></path><path d="M8.475 2.818A8 8 0 0 1 20 10c0 1.183-.31 2.377-.81 3.533"></path><path d="M9.13 9.13a3 3 0 0 0 3.74 3.74"></path></svg><p class="mt-4 text-base font-[300] text-white">Геопросторові дані відсутні</p><p class="mt-2 max-w-xs text-center text-sm font-[200] text-white/70 leading-relaxed"> Координати або межі об'єкта не внесені до системи. Об'єкт відображається лише у текстовому форматі. </p>',3)])])):e.createCommentVNode("",!0)],512),[[e.vShow,w.value]])])],64))],2)):e.createCommentVNode("",!0)}}});return Oe.install=t=>{t.component("VsPartsMap",Oe),t._context.directives.tooltip||t.directive("tooltip",it)},Oe});
|