@opengis/filter 0.1.21 → 0.1.22
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.umd.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(function(T,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@opengis/core")):typeof define=="function"&&define.amd?define(["exports","vue","@opengis/core"],e):(T=typeof globalThis<"u"?globalThis:T||self,e(T.FilterLib={},T.Vue,T.OpenGISCore))})(this,function(T,e,Z){"use strict";const K=(f,o)=>{const p=f.__vccOpts||f;for(const[t,n]of o)p[t]=n;return p},ue={},pe={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 ye(f,o){return e.openBlock(),e.createElementBlock("svg",pe,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 ge=K(ue,[["render",ye]]),he={},be={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 ke(f,o){return e.openBlock(),e.createElementBlock("svg",be,o[0]||(o[0]=[e.createElementVNode("path",{d:"M20 6 9 17l-5-5"},null,-1)]))}const O=K(he,[["render",ke]]),xe={class:"flex items-center justify-between w-full text-sm"},we={class:"flex items-center cursor-pointer w-full"},Ve={key:0,width:"16",height:"auto",src:"data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTYgMTYnIGZpbGw9J3doaXRlJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnPjxwYXRoIGQ9J00xMi4yMDcgNC43OTNhMSAxIDAgMDEwIDEuNDE0bC01IDVhMSAxIDAgMDEtMS40MTQgMGwtMi0yYTEgMSAwIDAxMS40MTQtMS40MTRMNi41IDkuMDg2bDQuMjkzLTQuMjkzYTEgMSAwIDAxMS40MTQgMHonLz48L3N2Zz4="},Ce=["value"],Be={class:"flex flex-row items-center font-normal text-gray-800 gap-x-1"},Ee={key:0,class:"text-xs text-gray-500 dark:text-neutral-500 pr-1"},Ne={key:1,class:"absolute right-2 flex size-3.5 items-center justify-center"},W=e.defineComponent({__name:"list-item",props:{layout:{},count:{},type:{},label:{},value:{},isSelected:{type:Boolean},color:{},highlighted:{type:Boolean}},emits:["itemClick"],setup(f,{expose:o,emit:p}){const t=f,n=p;function l(){n("itemClick",t.value)}const y=e.ref(null),m=e.computed(()=>t.layout==="inline"&&t.type==="radio");return o({el:y}),(r,b)=>(e.openBlock(),e.createElementBlock("div",{class:"flex items-center w-full rounded-sm group hover:bg-gray-100",ref_key:"el",ref:y},[e.createElementVNode("div",xe,[e.createElementVNode("div",we,[e.createElementVNode("label",{for:"radio-9740",class:e.normalizeClass([["inline","popover"].includes(r.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":r.highlighted,relative:m.value}]),onClick:e.withModifiers(l,["stop","prevent"])},[m.value?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["w-[18px] h-[18px] border flex items-center justify-center",[r.type==="checkbox"?"rounded-[4px]":"rounded-full",r.color?`bg-[${r.color}] border-[#ffffff]`:r.isSelected?"bg-[#2563eb] border-[#ffffff]":"bg-[#ffffff] border-[#d9d9d9]"]])},[r.isSelected?(e.openBlock(),e.createElementBlock("img",Ve)):e.createCommentVNode("",!0)],2)),e.createElementVNode("input",{type:"checkbox",class:"hidden",id:"radio-9740",value:r.value},null,8,Ce),e.createElementVNode("div",{class:e.normalizeClass(["flex flex-1 flex-row items-center justify-between",m.value?"pl-1 pr-6":"w-[calc(100%-18px)] pl-[10px]"])},[e.createElementVNode("span",Be,e.toDisplayString(r.label??"Відсутні дані"),1),r.count?(e.openBlock(),e.createElementBlock("div",Ee," ("+e.toDisplayString(r.count)+") ",1)):e.createCommentVNode("",!0)],2),m.value&&r.isSelected?(e.openBlock(),e.createElementBlock("span",Ne,[e.createVNode(O)])):e.createCommentVNode("",!0)],2)])])],512))}});function q(f,o){const{options:p=[],limit:t=20}=f;function n(g){return Array.isArray(g)?g[0]:g}const l=e.ref(n(f.modelValue)),y=e.ref(""),m=e.ref(!1),r=e.ref([]),b=e.ref("id"),d=e.ref("text"),u=e.ref(!1),i=e.ref(f.layout!=="popover"&&p.length>t);function k(g){const h=g.find(Boolean)??{},_=["id","value","code","key"].find(V=>V in h)??"id",D=["text","label","name","title"].find(V=>V in h)??"text";return{autoValueKey:_,autoLabelKey:D}}if(p.length>0){const g=k(p);b.value=g.autoValueKey,d.value=g.autoLabelKey}const w=e.computed(()=>{const g=r.value;return f.layout==="popover"||u.value?g:g.slice(0,t)});e.watch(()=>f.modelValue,g=>{l.value=n(g)},{immediate:!0}),r.value=[...p].sort((g,h)=>f.sort==="count"?h.count&&g.count?h.count-g.count:0:f.sort==="name"?String(g[d.value]??"").localeCompare(String(h[d.value]??"")):0);function x(g){return l.value===g[b.value]}function c(g){l.value=g[b.value],o("update:modelValue",l.value),o("change",{name:f.name,value:l.value})}function a(){l.value=void 0,o("update:modelValue",l.value),o("clear",f.name)}function s(){u.value=!u.value}return{innerValue:l,searchTerm:y,filteredOptions:w,isSelected:x,selectItem:c,clear:a,toggleShowAll:s,isReqProc:m,showAll:u,isEnableShowAll:i,labelKey:d,valueKey:b,allOptions:r}}const Se={},_e={class:"w-48 mx-auto",viewBox:"0 0 178 90",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function De(f,o){return e.openBlock(),e.createElementBlock("svg",_e,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 Q=K(Se,[["render",De]]),$e={},Fe={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 Ae(f,o){return e.openBlock(),e.createElementBlock("svg",Fe,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 U=K($e,[["render",Ae]]),je={},Me={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 Re(f,o){return e.openBlock(),e.createElementBlock("svg",Me,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 H=K(je,[["render",Re]]),Te={key:0,class:"w-full"},Ke={class:"flex flex-col items-center justify-center p-5 text-center"},Le={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ze={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},Oe=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(f,{expose:o,emit:p}){const t=f,n=e.ref(null),l=p,{innerValue:y,filteredOptions:m,isSelected:r,selectItem:b,clear:d,toggleShowAll:u,isReqProc:i,showAll:k,isEnableShowAll:w,labelKey:x,valueKey:c,allOptions:a}=q({...t,modelValue:t.modelValue??t.default??""},l);return o({clear:d,inputTextRef:n}),e.watch(()=>t.modelValue,s=>{s===void 0&&(y.value=void 0)}),(s,g)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([s.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox"])},[e.createElementVNode("div",{class:e.normalizeClass([s.layout==="popover"?"flex-1 overflow-y-auto p-2":"",s.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(m),h=>(e.openBlock(),e.createBlock(W,{layout:s.layout,key:h[e.unref(c)],count:h.count,label:h[e.unref(x)],color:h.color,type:"radio",value:h[e.unref(c)],"is-selected":e.unref(r)(h),onItemClick:_=>e.unref(b)(h)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),128))],2),s.type==="select"&&e.unref(m).length===0&&!e.unref(i)?(e.openBlock(),e.createElementBlock("div",Te,[e.createElementVNode("div",Ke,[e.createVNode(Q),g[4]||(g[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),s.layout!=="popover"&&s.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(k)&&e.unref(w)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:g[0]||(g[0]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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"},[g[5]||(g[5]=e.createTextVNode(" Показати більше ",-1)),e.createVNode(U)])):e.createCommentVNode("",!0),e.unref(k)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:g[1]||(g[1]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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"},[g[6]||(g[6]=e.createTextVNode(" Показати менше ",-1)),e.createVNode(H)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),s.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[s.layout==="inline"?(e.openBlock(),e.createElementBlock("div",Le,[e.createTextVNode(e.toDisplayString(e.unref(y)||e.unref(y)===null?1:0)+" з "+e.toDisplayString(e.unref(a).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[2]||(g[2]=(...h)=>e.unref(d)&&e.unref(d)(...h))}," Очистити ",512),[[e.vShow,e.unref(y)!==""&&e.unref(y)!==void 0]])])):e.createCommentVNode("",!0),s.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ze,[e.createElementVNode("span",null,e.toDisplayString(e.unref(y)||e.unref(y)===null?1:0)+" з "+e.toDisplayString(e.unref(a).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[3]||(g[3]=(...h)=>e.unref(d)&&e.unref(d)(...h))}," Очистити ",512),[[e.vShow,e.unref(y)!==""&&e.unref(y)!==void 0]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}});function v(f,o){const{options:p=[],limit:t=20}=f;function n(g){return Array.isArray(g)?g:g?[g]:[]}const l=e.ref(n(f.modelValue)),y=e.ref(""),m=e.ref(!1),r=e.ref([]),b=e.ref("id"),d=e.ref("text"),u=e.ref(!1),i=e.ref(f.layout!=="popover"&&p.length>t);function k(g){const h=g.find(Boolean)??{},_=["id","value","code","key"].find(V=>V in h)??"id",D=["text","label","name","title"].find(V=>V in h)??"text";return{autoValueKey:_,autoLabelKey:D}}if(p.length>0){const g=k(p);b.value=g.autoValueKey,d.value=g.autoLabelKey}const w=e.computed(()=>{const g=r.value;return f.layout==="popover"||u.value?g:g.slice(0,t)});e.watch(()=>f.modelValue,g=>{l.value=n(g)},{immediate:!0}),r.value=[...p].sort((g,h)=>f.sort==="count"?h.count&&g.count?h.count-g.count:0:f.sort==="name"?String(g[d.value]).localeCompare(String(h[d.value])):0);function x(g){return l.value&&l.value.includes(g[b.value])}function c(g){const h=l.value.includes(g[b.value]);l.value=h?l.value.filter(_=>_!==g[b.value]):[...l.value,g[b.value]],o("update:modelValue",l.value),o("change",{name:f.name,value:l.value})}function a(){l.value=[],o("update:modelValue",l.value),o("clear",f.name)}function s(){u.value=!u.value}return{innerValue:l,searchTerm:y,filteredOptions:w,isSelected:x,selectItem:c,clear:a,toggleShowAll:s,isReqProc:m,showAll:u,isEnableShowAll:i,labelKey:d,valueKey:b,allOptions:r}}const ee={en:{apply:"Apply",search:"Search",more:"Show more",less:"Show less",selected:"selected",clear:"Clear",notfound:"Nothing found",period:"Period",today:"Today",week:"Week",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:"Тиждень",month:"Місяць",quarter:"Квартал",year:"Рік",alltime:"Весь час",prev:"Попередній період",next:"Настпуний період",selectFieldHelp:"Оберіть поле, щоб розпочати створення фільтра."}};function te(f){const o=f.split(".")[1],p=typeof window<"u"&&window.localStorage?localStorage.locale:null;return(ee[p||navigator.language]||ee.uk)[o]}function z(){const f=e.getCurrentInstance();if(!f.appContext.config.globalProperties.$i18n)return te;const o=f.appContext.config.globalProperties.$t;return p=>{const t=o(p);return t===p?te(p):t}}const Ie={key:0,class:"w-full"},Ue={class:"flex flex-col items-center justify-center p-5 text-center"},Pe={class:"max-w-sm mx-auto mt-6"},Ye={class:"font-medium text-gray-800 dark:text-neutral-200"},We={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},qe={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},le=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(f,{expose:o,emit:p}){const t=z(),n=f,l=p,{innerValue:y,filteredOptions:m,isSelected:r,selectItem:b,clear:d,toggleShowAll:u,isReqProc:i,showAll:k,isEnableShowAll:w,labelKey:x,valueKey:c,allOptions:a}=v({...n,modelValue:n.modelValue},l);return e.watch(()=>n.modelValue,s=>{s===void 0&&(y.value=[])}),o({clear:d}),(s,g)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([s.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",{class:e.normalizeClass([s.layout==="popover"?"flex-1 overflow-y-auto p-2":"",s.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(m),h=>(e.openBlock(),e.createBlock(W,{layout:s.layout,count:h.count,label:h[e.unref(x)],color:h.color,type:"checkbox",value:h[e.unref(c)],"is-selected":e.unref(r)(h),onItemClick:_=>e.unref(b)(h)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),256))],2),s.type==="select"&&e.unref(m).length===0&&!e.unref(i)?(e.openBlock(),e.createElementBlock("div",Ie,[e.createElementVNode("div",Ue,[e.createVNode(Q),e.createElementVNode("div",Pe,[e.createElementVNode("p",Ye,e.toDisplayString(e.unref(t)("filter.notfound")),1),g[4]||(g[4]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),s.layout!=="popover"&&s.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(k)&&e.unref(w)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:g[0]||(g[0]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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(t)("filter.more"))+" ",1),e.createVNode(U)])):e.createCommentVNode("",!0),e.unref(k)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:g[1]||(g[1]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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(t)("filter.less"))+" ",1),e.createVNode(H)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),s.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[s.layout==="inline"?(e.openBlock(),e.createElementBlock("div",We,[e.createTextVNode(e.toDisplayString(e.unref(y).length)+" / "+e.toDisplayString(e.unref(a).length)+" "+e.toDisplayString(e.unref(t)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[2]||(g[2]=(...h)=>e.unref(d)&&e.unref(d)(...h))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(y).length!==0]])])):e.createCommentVNode("",!0),s.layout==="popover"?(e.openBlock(),e.createElementBlock("div",qe,[e.createElementVNode("span",null,e.toDisplayString(e.unref(y).length)+" / "+e.toDisplayString(e.unref(a).length)+" "+e.toDisplayString(e.unref(t)("filter.selected")),1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[3]||(g[3]=(...h)=>e.unref(d)&&e.unref(d)(...h))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(y).length!==0]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}}),Qe={},He={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 Ge(f,o){return e.openBlock(),e.createElementBlock("svg",He,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 oe=K(Qe,[["render",Ge]]),Xe={},Je={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 Ze(f,o){return e.openBlock(),e.createElementBlock("svg",Je,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 G=K(Xe,[["render",Ze]]);class ne{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 ve={class:"absolute bottom-2/4 translate-y-2/4 cursor-pointer left-3"},et=["placeholder"],tt=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(f,{emit:o}){const p=f,t=e.ref((p.placeholder||p.label||p.title||p.name||"search").toString()),n=o,l=e.ref(p.modelValue?.toString()??"");e.watch(()=>p.modelValue,b=>{b!==l.value&&(l.value=b?.toString()??"")});let y=null;function m(){if(l.value=l.value.trimStart(),l.value.length===0){r();return}y&&clearTimeout(y),y=setTimeout(()=>{n("update:modelValue",l.value),n("change",{name:p.name,value:l.value})},300)}function r(){l.value="",n("update:modelValue",""),n("clear",p.name)}return(b,d)=>(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",b.layout==="inline"?e.unref(ne).getWidthClass(b.width):"mb-2"+(b.layout==="popover"?" m-2":"")])},[e.createElementVNode("div",ve,[e.createVNode(oe)]),l.value!==""?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:r,class:"absolute bottom-2/4 translate-y-2/4 right-3 cursor-pointer"},[e.createVNode(G)])):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"text","onUpdate:modelValue":d[0]||(d[0]=u=>l.value=u),onInput:m,placeholder:t.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,et),[[e.vModelText,l.value]])],2))}});function re(f={color:"blue"}){return e.computed(()=>{const p=`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-${f.color}-500 focus:border-transparent
|
|
2
|
-
text-gray-800 bg-white dark:text-neutral-300 dark:bg-neutral-800 dark:border-neutral-600`;return f?.size==="sm"?`${p}h-[32px]`:`${p}h-[38px]`})}function lt(){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 ot(){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 ae(f){return f==="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":f==="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 nt={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},rt=["placeholder","disabled"],at={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},st={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},it=["placeholder","disabled"],ct=["disabled"],no={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ro={key:1,class:"flex justify-end items-center text-xs text-gray-500 p-1 border-t"},dt=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(f,{expose:o,emit:p}){const t=re(),n=lt(),l=z(),y=f,m=e.ref(y.modelValue??y.default??[]),r=p,b=e.computed({get:()=>y.modelValue??m.value,set:i=>{y.modelValue!==void 0?r("update:modelValue",i):m.value=i}});function d(){r("change",{name:y.name,value:b.value||m.value})}function u(){m.value=[],b.value=m.value,r("clear",y.name)}return e.watch(()=>y.modelValue,i=>{i!==void 0&&y.layout!=="popover"?(m.value=i,r("update:modelValue",i)):m.value=[]}),o({clear:u,currentValue:b}),(i,k)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",null,[e.createElementVNode("div",{class:e.normalizeClass(i.layout==="vertical"?"inline-flex items-center gap-2":"space-y-3 p-2")},[e.createElementVNode("div",null,[i.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",nt,e.toDisplayString(e.unref(l)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(t)),placeholder:i.placeholder?.[0]??"min",step:"1",style:{outline:"none"},"onUpdate:modelValue":k[0]||(k[0]=w=>b.value[0]=w),disabled:i.disabled},null,10,rt),[[e.vModelText,b.value[0]]])]),i.layout==="vertical"?(e.openBlock(),e.createElementBlock("label",at," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",null,[i.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",st,e.toDisplayString(e.unref(l)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(t)),placeholder:i.placeholder?.[1]??"max",min:"0",max:"1000000000000000",step:"1",style:{outline:"none"},"onUpdate:modelValue":k[1]||(k[1]=w=>b.value[1]=w),disabled:i.disabled},null,10,it),[[e.vModelText,b.value[1]]])]),["popover","inline","vertical"].includes(i.layout)?(e.openBlock(),e.createElementBlock("button",{key:1,onClick:d,class:e.normalizeClass(e.unref(n)+(i.layout==="vertical"?" w-[50px]":" bg-blue-100 hover:bg-blue-200"))},e.toDisplayString(i.layout==="vertical"?"Ok":e.unref(l)("filter.apply")),3)):e.createCommentVNode("",!0),["popover","inline"].includes(i.layout)?(e.openBlock(),e.createElementBlock("button",{key:2,disabled:!(b.value[0]||b.value[1]),onClick:u,class:e.normalizeClass(e.unref(n)+" hover:bg-gray-100")},e.toDisplayString(e.unref(l)("filter.clear")),11,ct)):e.createCommentVNode("",!0)],2)]),(i.cleanable&&m.value.length,e.createCommentVNode("",!0))],64))}});class R{static format(o){const p=o.getFullYear(),t=(o.getMonth()+1).toString().padStart(2,"0"),n=o.getDate().toString().padStart(2,"0");return`${p}-${t}-${n}`}static getShiftedDay(o,p=0){const t=o?new Date(o):new Date;return t.setDate(t.getDate()+p),this.format(t)}static getLastWeekRange(o,p,t=0){if(o&&p){const b=new Date(o),d=new Date(p);return b.setDate(b.getDate()+t*7),d.setDate(d.getDate()+t*7),[this.format(b),this.format(d)]}const n=new Date,l=n.getDay(),y=l===0?13:l-1+7,m=new Date(n);m.setDate(n.getDate()-y+t*7);const r=new Date(m);return r.setDate(m.getDate()+6),[this.format(m),this.format(r)]}static getMonthRange(o,p,t=0){let n;o?n=new Date(o):n=new Date,n=new Date(n.getFullYear(),n.getMonth()+t,1);const l=n,y=new Date(n.getFullYear(),n.getMonth()+1,0);return[this.format(l),this.format(y)]}static getQuarterRange(o,p,t=0){const n=o||p,l=n?new Date(n):new Date;let y=Math.floor(l.getMonth()/3);y+=t;const m=(y%4+4)%4*3,r=l.getFullYear()+Math.floor(y/4),b=new Date(r,m,1),d=new Date(r,m+3,0);return[this.format(b),this.format(d)]}static getYear(o,p=0){let t;return o&&/^\d{4}$/.test(o)?t=parseInt(o,10):o?t=new Date(o).getFullYear():t=new Date().getFullYear(),String(t+p)}static getYearRange(o,p=0){let t;return o&&/^\d{4}$/.test(o)?t=parseInt(o,10):o?t=new Date(o).getFullYear():t=new Date().getFullYear(),[this.format(new Date(t+p,0,1)),this.format(new Date(t+p+1,0,0))]}static getRangeFromDaysBefore(o){const p=new Date,t=new Date(p.getTime());return t.setDate(p.getDate()-o),[this.format(t),this.format(p)]}}function se(f,o){const{popoverRef:p}=f,t=z(),n=e.ref(""),l=e.ref(f.modelValue??f.default??[]),y=e.ref(0);function m(){const a=R.getRangeFromDaysBefore(y.value);return l.value=[...a],o("change",{name:f.name,value:l.value}),o("update:modelValue",l.value),a}function r(a){n.value=a,p.value?.close();const s=[];switch(n.value){case"today":s.push(R.getShiftedDay()),s.push(R.getShiftedDay());break;case"week":s.push(...R.getLastWeekRange());break;case"month":s.push(...R.getMonthRange());break;case"quarter":s.push(...R.getQuarterRange());break;case"year":s.push(...R.getYearRange());break;case"last_7_days":y.value=7,m();break;case"range":y.value=7,s.push(...m());break}l.value=[...s],o("change",{name:f.name,value:l.value}),o("update:modelValue",l.value)}function b(){const a=[];switch(n.value){case"today":a.push(R.getShiftedDay(l.value[0],1));break;case"week":a.push(...R.getLastWeekRange(l.value[0],l.value[1],1));break;case"month":a.push(...R.getMonthRange(l.value[0],l.value[1],1));break;case"quarter":a.push(...R.getQuarterRange(l.value[0],l.value[1],1));break;case"year":a.push(...R.getYearRange(l.value[0],1));break}l.value=[...a],o("change",{name:f.name,value:l.value}),o("update:modelValue",l.value)}function d(){const a=[];switch(n.value){case"today":a.push(R.getShiftedDay(l.value[0],-1));break;case"week":a.push(...R.getLastWeekRange(l.value[0],l.value[1],-1));break;case"month":a.push(...R.getMonthRange(l.value[0],l.value[1],-1));break;case"quarter":a.push(...R.getQuarterRange(l.value[0],l.value[1],-1));break;case"year":a.push(...R.getYearRange(l.value[0],-1));break}l.value=[...a],o("change",{name:f.name,value:l.value}),o("update:modelValue",l.value)}const u=["Січень","Лютий","Березень","Квітень","Травень","Червень","Липень","Серпень","Вересень","Жовтень","Листопад","Грудень"];function i(a){const[s,g,h]=a.split("-");return`${h}.${g}.${s}`}function k(a,s="long"){const g=new Date(Date.UTC(2e3,a-1,1));return new Intl.DateTimeFormat(localStorage.locale,{month:s,timeZone:"UTC"}).format(g)}function w(a){const{value:s}=l;switch(a){case"today":return i(s[0]);case"range":return"Період";case"week":return s[0]&&s[1]?`${i(s[0])} – ${i(s[1])}`:"";case"quarter":if(s[0]){const g=new Date(s[0]),h=g.getFullYear(),_=g.getMonth();return`${Math.floor(_/3)+1} ${t("filter.quarter")} ${h}`}return"";case"month":if(s[0]){const[g,h]=s[0].split("-");return`${k(parseInt(h,10))} ${g}`}return"";case"year":return s[0]||"";case"last_7_days":return"За останні дні";default:return f.label??""}}const x=e.computed(()=>n.value?w(n.value):f.label??"");function c(){n.value="",l.value=[],o("update:modelValue",[]),o("clear",f.name)}return{activeMode:n,innerValue:l,daysBefore:y,onDaysBeforeChange:m,onSelectChange:r,nextClick:b,prevClick:d,ukMonths:u,formatDisplayDate:i,getModeLabel:w,currentLabel:x,clear:c}}const ft={key:0,class:"relative flex w-full h-auto gap-2 filter-date m-2 flex-wrap"},mt={key:0,class:"flex gap-1 !w-[75%] rounded-sm"},ut=["max","disabled"],pt=["min","disabled"],yt={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},gt=["max","disabled"],ht={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},bt={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},kt=["min","disabled"],xt={class:"flex gap-1 pt-2"},wt=["onClick"],ao={key:0,class:"flex justify-end items-center text-xs text-gray-500 p-1 border-t"},Vt=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(f,{expose:o,emit:p}){const t=f,n=re(),l=ot(),y=z(),m=p,r=e.ref(null),{activeMode:b,innerValue:d,onSelectChange:u,nextClick:i,prevClick:k,clear:w}=se({...t,popoverRef:r},m);return e.watch(()=>t.modelValue,x=>{x!==void 0?(d.value=x,m("update:modelValue",x)):(b.value="",d.value=[])}),o({clear:w,popoverRef:r}),(x,c)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[x.layout==="inline"?(e.openBlock(),e.createElementBlock("div",ft,[e.unref(b)!==""&&e.unref(b)==="range"?(e.openBlock(),e.createElementBlock("div",mt,[e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(d)[1],locale:"uk-UA","onUpdate:modelValue":c[0]||(c[0]=a=>e.unref(d)[0]=a),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:x.disabled},null,8,ut),[[e.vModelText,e.unref(d)[0]]]),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(d)[0],locale:"uk-UA","onUpdate:modelValue":c[1]||(c[1]=a=>e.unref(d)[1]=a),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:x.disabled},null,8,pt),[[e.vModelText,e.unref(d)[1]]])])):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(x.layout==="popover"?"space-y-3 p-2":"flex items-center gap-2")},[e.createElementVNode("div",{class:e.normalizeClass(x.layout!=="popover"?"w-[48%]":"")},[x.layout==="popover"?(e.openBlock(),e.createElementBlock("label",yt,e.toDisplayString(e.unref(y)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(d)[1],locale:"uk-UA","onUpdate:modelValue":c[2]||(c[2]=a=>e.unref(d)[0]=a),class:e.normalizeClass(e.unref(n)),disabled:x.disabled},null,10,gt),[[e.vModelText,e.unref(d)[0]]])],2),x.layout!=="popover"?(e.openBlock(),e.createElementBlock("label",ht," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(x.layout!=="popover"?"w-[48%]":"")},[x.layout==="popover"?(e.openBlock(),e.createElementBlock("label",bt,e.toDisplayString(e.unref(y)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(d)[0],locale:"uk-UA","onUpdate:modelValue":c[3]||(c[3]=a=>e.unref(d)[1]=a),class:e.normalizeClass(e.unref(n)),disabled:x.disabled},null,10,kt),[[e.vModelText,e.unref(d)[1]]])],2)],2),e.createElementVNode("div",xt,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["today","week","month","quarter","year"],a=>e.createElementVNode("button",{key:a,class:e.normalizeClass(e.unref(l)+(e.unref(b)===a?" bg-blue-100":"")),onClick:s=>e.unref(u)(a)},e.toDisplayString(e.unref(y)("filter."+a)),11,wt)),64)),e.createElementVNode("button",{class:e.normalizeClass(e.unref(l)),onClick:c[4]||(c[4]=(...a)=>e.unref(k)&&e.unref(k)(...a))}," <",2),e.createElementVNode("button",{class:e.normalizeClass(e.unref(l)),onClick:c[5]||(c[5]=(...a)=>e.unref(i)&&e.unref(i)(...a))}," >",2)]),(x.cleanable,e.createCommentVNode("",!0))],64))}});function Ct(f,o){const{api:p,options:t=[],limit:n=20,dataKey:l="data"}=f,y=f.multi;function m(B){return y?Array.isArray(B)?B:B?[B]:[]:Array.isArray(B)?B[0]:B}const r=e.ref(m(f.modelValue)),b=e.ref(""),d=e.ref(!1),u=e.ref(t),i=e.ref("id"),k=e.ref("text"),w=e.ref(!1),x=e.ref(f.layout!=="popover"&&t.length>n),c=e.ref([]),a=e.ref(0);function s(B){const $=B.find(Boolean)??{},j=["id","value","code","key"].find(I=>I in $)??"id",M=["text","label","name","title"].find(I=>I in $)??"text";return{autoValueKey:j,autoLabelKey:M}}if(t.length>0){const B=s(t);i.value=B.autoValueKey,k.value=B.autoLabelKey}const g=e.computed(()=>{if(p)return u.value;const B=u.value;if(f.layout==="popover")return B;if(!b.value)return w.value?B:B.slice(0,n);const $=b.value.toLowerCase();return B.filter(j=>j[k.value].toLowerCase().includes($))});let h=null;async function _(B){if(p){d.value=!0;try{const $=new URL(p,window.location.origin);$.searchParams.set("json","1"),$.searchParams.set("key",B),$.searchParams.set("limit",n.toString());const j=await fetch($.toString());if(!j.ok){Z.notify({type:"error",title:"Error",message:"Failed to fetch remote options"}),u.value=[];return}const M=await j.json();if(!M[l]){Z.notify({type:"error",title:"Error",message:M}),u.value=[];return}if(u.value=M[l],u.value.length>0){const I=s(u.value);i.value=I.autoValueKey,k.value=I.autoLabelKey}a.value=M.total}catch($){console.error("Failed to fetch remote options:",$)}finally{d.value=!1}}}e.watch(b,B=>{p&&(h&&clearTimeout(h),h=setTimeout(()=>{_(B)},200))}),e.watch(()=>f.modelValue,B=>{r.value=m(B)},{immediate:!0});function D(B){return y&&Array.isArray(r.value)?r.value.includes(B[i.value]):r.value&&r.value===B[i.value]}function V(B){if(y&&!Array.isArray(r.value)&&(r.value=[]),y&&Array.isArray(r.value)){const $=r.value.includes(B[i.value]);r.value=$?r.value.filter(j=>j!==B[i.value]):[...r.value,B[i.value]],c.value=$?c.value.filter(j=>j!==B[k.value]):[...c.value,B[k.value]]}else r.value=B[i.value],c.value=B[k.value];o("update:modelValue",r.value),o("change",{name:f.name,value:r.value})}function C(){y?(r.value=[],c.value=[]):(r.value=void 0,c.value=[]),o("update:modelValue",r.value),o("clear",f.name)}function S(){h&&clearTimeout(h),b.value="",w.value=!1}function E(){w.value=!w.value}e.onBeforeUnmount(()=>{h&&clearTimeout(h)});const N=e.ref(-1);e.watch(g,()=>{N.value=g.value.length>0?0:-1});function A(B){const $=g.value.length;if(B.key==="ArrowDown")B.preventDefault(),N.value=(N.value+1)%$;else if(B.key==="ArrowUp")B.preventDefault(),N.value=(N.value-1+$)%$;else if(B.key==="Enter"&&(B.preventDefault(),N.value>=0&&N.value<g.value.length)){const j=g.value[N.value];V(j)}}function F(){p&&u.value.length===0&&b.value.length===0&&_(b.value)}return{innerValue:r,searchTerm:b,filteredOptions:g,isSelected:D,selectItem:V,clear:C,resetSearch:S,toggleShowAll:E,isReqProc:d,showAll:w,isEnableShowAll:x,labelKey:k,valueKey:i,allOptions:u,highlightedIndex:N,onKeyDown:A,selectedLabels:c,totalCount:a,loadData:F}}const Bt={class:"h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relative justify-center"},Et=["placeholder"],Nt={key:0,class:"w-full"},St={class:"flex flex-col items-center justify-center p-5 text-center"},_t={class:"max-w-sm mx-auto mt-6"},Dt={class:"font-medium text-gray-800 dark:text-neutral-200"},$t={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},Ft={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},At=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(f,{expose:o,emit:p}){const t=z(),n=f,l=p,y=e.ref(null),{innerValue:m,filteredOptions:r,isSelected:b,selectItem:d,clear:u,resetSearch:i,toggleShowAll:k,isReqProc:w,showAll:x,isEnableShowAll:c,searchTerm:a,labelKey:s,valueKey:g,highlightedIndex:h,onKeyDown:_,selectedLabels:D,totalCount:V,loadData:C}=Ct({...n,modelValue:n.modelValue},l);e.onMounted(()=>{i(),n.layout!=="inline"&&(C(),y.value&&n.layout==="popover"&&y.value.focus())}),e.watch(()=>n.modelValue,E=>{E===void 0&&(n.multi?m.value=[]:m.value=void 0)});const S=e.ref([]);return e.watch(h,E=>{E>=0&&S.value[E]&&S.value[E]?.scrollIntoView({block:"nearest",behavior:"smooth"})}),e.watch(r,()=>{S.value=[]}),o({clear:u,inputTextRef:y,selectedLabels:D,loadData:C}),(E,N)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([E.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",Bt,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":N[0]||(N[0]=A=>e.isRef(a)?a.value=A:null),onKeydown:N[1]||(N[1]=(...A)=>e.unref(_)&&e.unref(_)(...A)),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(t)("filter.search"),type:"text",ref_key:"inputTextRef",ref:y},null,40,Et),[[e.vModelText,e.unref(a)]]),e.createVNode(oe,{class:"absolute text-gray-400 -translate-y-1/2 left-4 top-1/2"}),e.unref(a)!=""?(e.openBlock(),e.createBlock(G,{key:0,onClick:N[2]||(N[2]=A=>a.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([E.layout==="popover"?"flex-1 overflow-y-auto p-2":"",E.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(r),(A,F)=>(e.openBlock(),e.createBlock(W,{layout:E.layout,count:A.count,label:A[e.unref(s)],color:A.color,type:E.multi?"checkbox":"radio",value:A[e.unref(g)],"is-selected":e.unref(b)(A),highlighted:F===e.unref(h),onItemClick:B=>e.unref(d)(A),ref_for:!0,ref:B=>S.value[F]=B?.el},null,8,["layout","count","label","color","type","value","is-selected","highlighted","onItemClick"]))),256))],2),E.type==="select"&&e.unref(r).length===0&&!e.unref(w)?(e.openBlock(),e.createElementBlock("div",Nt,[e.createElementVNode("div",St,[e.createVNode(Q),e.createElementVNode("div",_t,[e.createElementVNode("p",Dt,e.toDisplayString(e.unref(t)("filter.notfound")),1),N[7]||(N[7]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),E.layout!=="popover"&&E.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(x)&&e.unref(c)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:N[3]||(N[3]=(...A)=>e.unref(k)&&e.unref(k)(...A)),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(t)("filter.more"))+" ",1),e.createVNode(U)])):e.createCommentVNode("",!0),e.unref(x)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:N[4]||(N[4]=(...A)=>e.unref(k)&&e.unref(k)(...A)),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(t)("filter.less"))+" ",1),e.createVNode(H)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),E.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[E.layout==="inline"?(e.openBlock(),e.createElementBlock("div",$t,[e.createTextVNode(e.toDisplayString(E.multi&&Array.isArray(e.unref(m))?e.unref(m)?.length:e.unref(m)!==void 0&&(e.unref(m)||e.unref(m)===null)?1:0)+" / "+e.toDisplayString(e.unref(V))+" "+e.toDisplayString(e.unref(t)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:N[5]||(N[5]=(...A)=>e.unref(u)&&e.unref(u)(...A))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(m)!==""&&e.unref(m)!==void 0||e.unref(m)]])])):e.createCommentVNode("",!0),E.layout==="popover"?(e.openBlock(),e.createElementBlock("div",Ft,[e.createElementVNode("span",null,e.toDisplayString(E.multi&&Array.isArray(e.unref(m))?e.unref(m)?.length:e.unref(m)!==void 0&&(e.unref(m)||e.unref(m)===null)?1:0)+" / "+e.toDisplayString(e.unref(V))+" "+e.toDisplayString(e.unref(t)("filter.selected")),1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:N[6]||(N[6]=(...A)=>e.unref(u)&&e.unref(u)(...A))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(m)!==""&&e.unref(m)!==void 0||e.unref(m)]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}}),jt=["for","onClick"],Mt=["id","name","value"],Rt={class:"block"},Tt={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},Kt={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},Lt=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(f,{expose:o,emit:p}){const t=f,n=p,{innerValue:l,isSelected:y,selectItem:m,clear:r,labelKey:b,valueKey:d,allOptions:u}=t.multi?v({...t,modelValue:t.modelValue??t.default??[]},n):q({...t,modelValue:t.modelValue!==void 0?t.modelValue:t.default??""},n);return o({clear:r}),e.watch(()=>t.modelValue,i=>{i===void 0&&(t.multi?l.value=[]:l.value=void 0)}),(i,k)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{class:e.normalizeClass(["grid grid-cols-3 gap-2 mx-[1px]",i.layout==="popover"?"m-1":"mb-1"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(u),w=>(e.openBlock(),e.createElementBlock("label",{key:`item-${w[e.unref(d)]}`,for:`item-${w[e.unref(d)]}`,onClick:e.withModifiers(x=>e.unref(m)(w),["stop","prevent"]),class:e.normalizeClass([e.unref(y)(w)?"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-${w[e.unref(d)]}`,class:"hidden w4poy border-gray-200 g41z1 g22e3 axcnw dark:text-indigo-500 dark:border-neutral-700 dark:focus:ring-neutral-900",name:`item-${w[e.unref(d)]}`,value:w[e.unref(d)]},null,8,Mt),e.createElementVNode("span",Rt,e.toDisplayString(w[e.unref(b)]),1)],10,jt))),128))],2),i.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[i.layout==="inline"?(e.openBlock(),e.createElementBlock("div",Tt,[e.createTextVNode(e.toDisplayString(i.multi&&Array.isArray(e.unref(l))?e.unref(l)?.length:e.unref(l)!==void 0&&(e.unref(l)||e.unref(l)===null)?1:0)+" з "+e.toDisplayString(e.unref(u).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:k[0]||(k[0]=(...w)=>e.unref(r)&&e.unref(r)(...w))}," Очистити ",512),[[e.vShow,e.unref(l)!==""&&e.unref(l)!==void 0||e.unref(l)]])])):e.createCommentVNode("",!0),i.layout==="popover"?(e.openBlock(),e.createElementBlock("div",Kt,[e.createElementVNode("span",null,e.toDisplayString(i.multi&&Array.isArray(e.unref(l))?e.unref(l)?.length:e.unref(l)!==void 0&&(e.unref(l)||e.unref(l)===null)?1:0)+" з "+e.toDisplayString(e.unref(u).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:k[1]||(k[1]=(...w)=>e.unref(r)&&e.unref(r)(...w))}," Очистити ",512),[[e.vShow,e.unref(l)!==void 0&&e.unref(l)!==""||e.unref(l)]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],64))}}),zt=["disabled","title"],Ot={class:"flex w-full items-center justify-between gap-1 overflow-hidden text-left"},It={class:"truncate text-ellipsis text-sm"},Ut={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"},Pt={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"},Yt={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"},X=e.defineComponent({__name:"popover-field",props:{disabled:{type:Boolean,default:!1},label:{},en:{},ua:{},uk:{},fr:{},de:{},es:{},currentValue:{},fieldRef:{},width:{},mode:{},layout:{}},setup(f,{expose:o}){const p=f,t=e.computed(()=>ae(p.mode)),n=e.ref(!1),l=e.ref({top:0,left:0}),y=e.ref(null),m=e.ref(null),r=e.ref(null);function b(){const h=m.value,_=r.value;if(!h||!_)return;const D=h.getBoundingClientRect(),V=_.offsetWidth,C=window.innerWidth,S=D.bottom+8;let{left:E}=D;E+V>C&&(E=Math.max(C-V-10,10)),l.value={top:S,left:E}}function d(){n.value=!n.value,n.value&&e.nextTick(()=>{b(),p.fieldRef?.inputTextRef&&p.fieldRef?.inputTextRef?.focus?.(),p.fieldRef?.loadData&&p.fieldRef?.loadData?.()})}function u(h){!y.value?.contains(h.target)&&!r.value?.contains(h.target)&&!m.value?.contains(h.target)&&(n.value=!1)}function i(h){h.key==="Escape"&&(n.value=!1)}const k=e.ref(!1),w=e.ref("ua"),x=h=>{h.detail.key==="locale"&&(w.value=h.detail.newValue)};e.onMounted(()=>{k.value=!0,w.value=localStorage.locale,window.addEventListener("storage",x),document.addEventListener("click",u,!0),document.addEventListener("keydown",i),window.addEventListener("scroll",b,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",x),document.removeEventListener("click",u,!0),document.removeEventListener("keydown",i),window.removeEventListener("scroll",b,!0)});function c(){n.value=!1}o({close:c});function a(h){return Array.isArray(h)?h.filter(_=>_!=null&&_!=="").length:h&&typeof h=="object"?Object.values(h).filter(_=>_!=null&&_!=="").length:typeof h=="string"?h.trim()===""?0:1:typeof h=="number"?Number.isNaN(h)?0:1:h===null||h!==void 0?1:0}const s=e.computed(()=>{const h=p.fieldRef?.selectedLabels,_=a(h);return _>0?_:a(p.currentValue)}),g=e.computed(()=>{const h=p.fieldRef?.selectedLabels;return!h||["inline"].includes(p.layout||"")?p[w.value]||(p.label??""):Array.isArray(h)?h.length>0?h.join(", "):p.label??"":String(h)});return(h,_)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("button",{onClick:d,disabled:h.disabled,ref_key:"triggerRef",ref:m,title:h.label,class:e.normalizeClass([t.value,h.width?e.unref(ne).getWidthClass(h.width):"w-full",h.layout==="inline"&&s.value>0?"border border-blue-400 bg-blue-50 text-blue-600":""]),type:"button"},[e.createElementVNode("span",Ot,[e.createElementVNode("span",It,e.toDisplayString(g.value),1),h.layout==="inline"&&s.value>0?(e.openBlock(),e.createElementBlock("span",Ut,e.toDisplayString(s.value),1)):e.createCommentVNode("",!0)]),e.createVNode(U,{class:"h-4 w-4 text-neutral-500"})],10,zt),k.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popperRef",ref:r,class:"vsTailwind vs-popover__content bottom-right w-fit fixed z-[1000]",style:e.normalizeStyle({top:`${l.value.top}px`,left:`${l.value.left}px`}),"data-inside-popover":""},[e.createElementVNode("div",Pt,[e.createElementVNode("div",Yt,[e.renderSlot(h.$slots,"default")])])],4),[[e.vShow,n.value]])])):e.createCommentVNode("",!0)]))}}),Wt={},qt={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 Qt(f,o){return e.openBlock(),e.createElementBlock("svg",qt,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 Ht=K(Wt,[["render",Qt]]),Gt={},Xt={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 Jt(f,o){return e.openBlock(),e.createElementBlock("svg",Xt,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 Zt=K(Gt,[["render",Jt]]),vt={class:"flex gap-1"},el={class:"mb-1"},tl={class:"mb-1"},ll={class:"inline-flex rounded-sm shrink-0 pl-1"},ol=["title"],nl={class:"inline-flex rounded-sm shrink-0 pl-1"},rl=["title"],al={key:1,class:"flex gap-1 !w-[75%] rounded-sm"},sl=["max","disabled"],il=["min","disabled"],so={key:0,class:"flex justify-end items-center text-xs text-gray-500 p-1 border-t"},cl=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(f,{expose:o,emit:p}){const t=z(),n=f,l=p,y=e.ref(null),{activeMode:m,innerValue:r,onSelectChange:b,nextClick:d,prevClick:u,currentLabel:i,clear:k}=se({...n,popoverRef:y},l);return e.watch(()=>n.modelValue,w=>{w!==void 0?(r.value=w,l("update:modelValue",w)):(m.value="",r.value=[])}),o({clear:k,popoverRef:y}),(w,x)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",vt,[e.createVNode(X,{ref_key:"popoverRef",ref:y,label:e.unref(i),"current-value":e.unref(r),mode:w.mode,width:typeof w.width=="number"&&e.unref(r).length?w.width-70:w.width,onClear:e.unref(k),layout:w.layout,class:e.normalizeClass(w.itemClass)},{default:e.withCtx(()=>[e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[0]||(x[0]=c=>e.unref(b)("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(t)("filter.period"))+" ",1),e.unref(m)==="range"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),x[12]||(x[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:x[1]||(x[1]=c=>e.unref(b)("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(t)("filter.today"))+" ",1),e.unref(m)==="today"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[2]||(x[2]=c=>e.unref(b)("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(t)("filter.week"))+" ",1),e.unref(m)==="week"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[3]||(x[3]=c=>e.unref(b)("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(t)("filter.month"))+" ",1),e.unref(m)==="month"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[4]||(x[4]=c=>e.unref(b)("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(t)("filter.quarter"))+" ",1),e.unref(m)==="quarter"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",el,[e.createElementVNode("button",{type:"button",onClick:x[5]||(x[5]=c=>e.unref(b)("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(t)("filter.year"))+" ",1),e.unref(m)==="year"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",tl,[e.createElementVNode("button",{type:"button",onClick:x[6]||(x[6]=c=>e.unref(k)()),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(t)("filter.alltime"))+" ",1),e.unref(r)[0]?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(O,{key:0}))])])]),_:1,__:[12]},8,["label","current-value","mode","width","onClear","layout","class"]),e.unref(m)!==""&&e.unref(m)!=="range"&&e.unref(m)!=="last_7_days"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",ll,[e.createElementVNode("button",{type:"button",title:e.unref(t)("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:x[7]||(x[7]=(...c)=>e.unref(u)&&e.unref(u)(...c))},[e.createVNode(Ht)],8,ol)]),e.createElementVNode("div",nl,[e.createElementVNode("button",{type:"button",title:e.unref(t)("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:x[8]||(x[8]=(...c)=>e.unref(d)&&e.unref(d)(...c))},[e.createVNode(Zt)],8,rl)])],64)):e.createCommentVNode("",!0),e.unref(m)!==""&&e.unref(m)==="range"?(e.openBlock(),e.createElementBlock("div",al,[e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(r)[1],locale:"uk-UA","onUpdate:modelValue":x[9]||(x[9]=c=>e.unref(r)[0]=c),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:w.disabled},null,8,sl),[[e.vModelText,e.unref(r)[0]]]),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(r)[0],locale:"uk-UA","onUpdate:modelValue":x[10]||(x[10]=c=>e.unref(r)[1]=c),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:w.disabled},null,8,il),[[e.vModelText,e.unref(r)[1]]])])):e.createCommentVNode("",!0)]),(w.cleanable,e.createCommentVNode("",!0))],64))}}),dl={class:"flex flex-wrap items-center gap-2"},fl=["disabled","onClick"],ml={key:0,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},ie={radio:Oe,checkbox:le,check:le,text:tt,range:dt,date:Vt,select:At,tag:Lt,button: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(f,{expose:o,emit:p}){const t=f,n=p,{innerValue:l,isSelected:y,selectItem:m,clear:r,labelKey:b,valueKey:d,allOptions:u}=q({...t,modelValue:t.modelValue??t.default??""},n),i=e.computed(()=>l.value!==void 0&&!(typeof l.value=="string"&&l.value==="")),k=e.computed(()=>i.value?1:0);function w(c){return y(c)?["bg-blue-600 text-white"].filter(a=>typeof a=="string"&&a.trim().length>0).join(" "):["text-gray-700 hover:bg-gray-200 bg-gray-50 "].filter(a=>typeof a=="string"&&a.trim().length>0).join(" ")}function x(c){t.disabled||m(c)}return o({clear:r}),e.watch(()=>t.modelValue,c=>{c===void 0&&(l.value=void 0)}),(c,a)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",dl,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(u),s=>(e.openBlock(),e.createElementBlock("button",{key:s[e.unref(d)],type:"button",class:e.normalizeClass(["px-3 py-2 text-sm font-medium rounded-md transition-colors",w(s)]),disabled:c.disabled,onClick:g=>x(s)},e.toDisplayString(s[e.unref(b)]),11,fl))),128))]),c.cleanable&&c.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ml,[e.createElementVNode("span",null,e.toDisplayString(k.value)+" з "+e.toDisplayString(e.unref(u).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:a[0]||(a[0]=(...s)=>e.unref(r)&&e.unref(r)(...s))}," Очистити ",512),[[e.vShow,i.value]])])):e.createCommentVNode("",!0)],64))}}),"date:inline":cl};function J(f,o){let p;switch(f.toLowerCase()){case"autocomplete":p="select";break;case"check":p="checkbox";break;default:p=f?.toString().toLowerCase()}return p==="date"&&o&&o==="inline"&&(p="date:inline"),{component:ie[p]||ie.text,type:p}}const ul={style:{display:"inline-flex",margin:"0px",width:"100%"}},pl={class:"relative w-full mb-2 p-4 bg-white rounded-lg shadow-sm"},yl={class:"block mb-3 text-sm font-medium text-gray-800 dark:text-neutral-200"},gl={class:"flex items-center"},hl={class:"text-sm font-medium max-w-[80%] text-gray-800 flex items-center gap-x-1"},bl={class:"filter-layout__body"},kl=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(f,{expose:o,emit:p}){const t=f,n=p,l=e.ref(),y=J(t.type,t.layout),m=e.computed({get:()=>t.modelValue,set:u=>n("update:modelValue",u)});function r(u){n("clear",u)}function b(u,i){n("change",{name:u,value:i}),t.modelValue!==void 0&&n("update:modelValue",i)}function d(){n("clear",t.name)}return e.watch(()=>t.default,u=>{m.value=u}),e.watch(()=>t.modelValue,u=>{m.value=u}),o({filterRef:l}),(u,i)=>(e.openBlock(),e.createElementBlock("div",ul,[e.createElementVNode("div",pl,[e.createElementVNode("div",yl,[e.createElementVNode("div",gl,[e.createElementVNode("span",hl,e.toDisplayString(u.label),1)]),typeof m.value=="string"&&m.value.trim()!==""||Array.isArray(m.value)&&m.value.length>0&&m.value.some(k=>k!==void 0)||m.value===null?(e.openBlock(),e.createBlock(ge,{key:0,onClick:d})):e.createCommentVNode("",!0)]),e.createElementVNode("div",bl,[e.unref(y)?.type!=="select"?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({key:0},t,{type:e.unref(y)?.type,class:t.itemClass,onChange:i[0]||(i[0]=k=>b(k.name,k.value)),onClear:i[1]||(i[1]=k=>r(k)),ref_key:"filterRef",ref:l}),null,16,["type","class"])):(e.openBlock(),e.createBlock(X,{key:1,"current-value":m.value,label:u.label,mode:u.mode,onClear:d,fieldRef:l.value,width:void 0,disabled:u.disabled,layout:"vertical"},{default:e.withCtx(()=>[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({ref_key:"filterRef",ref:l},t,{type:e.unref(y)?.type,class:t.itemClass,onChange:i[2]||(i[2]=k=>b(k.name,k.value)),onClear:i[3]||(i[3]=k=>r(k))}),null,16,["type","class"]))]),_:1},8,["current-value","label","mode","fieldRef","disabled"]))])])]))}}),ce=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(f,{expose:o,emit:p}){const t=f,n=p,l=e.ref(),y=J(t.type,t.layout),m=e.computed({get:()=>t.modelValue,set:d=>n("update:modelValue",d)});function r(d=t.name){n("clear",d)}function b(d,u){n("change",{name:d,value:u}),t.modelValue!==void 0&&n("update:modelValue",u)}return e.watch(()=>t.default,d=>{m.value=d}),e.watch(()=>t.modelValue,d=>{m.value=d}),o({filterRef:l}),(d,u)=>["text","date","button"].includes(d.type.toLocaleLowerCase())?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({key:0},t,{type:e.unref(y)?.type,class:d.itemClass,onChange:u[0]||(u[0]=i=>b(i.name,i.value)),onClear:u[1]||(u[1]=i=>r(i)),disabled:d.disabled,modelValue:m.value,"onUpdate:modelValue":u[2]||(u[2]=i=>m.value=i)}),null,16,["type","class","disabled","modelValue"])):(e.openBlock(),e.createBlock(X,{key:1,"current-value":m.value,label:d.label,mode:d.mode,onClear:r,fieldRef:l.value,width:t.width,disabled:d.disabled,layout:"inline"},{default:e.withCtx(()=>[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({ref_key:"filterRef",ref:l},t,{modelValue:m.value,"onUpdate:modelValue":u[3]||(u[3]=i=>m.value=i),type:e.unref(y)?.type,class:t.itemClass,onChange:u[4]||(u[4]=i=>b(i.name,i.value)),onClear:u[5]||(u[5]=i=>r(i))}),null,16,["modelValue","type","class"]))]),_:1},8,["current-value","label","mode","fieldRef","width","disabled"]))}}),xl=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(f,{expose:o,emit:p}){const t=f,n=p,l=e.ref(),y=e.ref(J(t.type,t.layout)),m=e.computed({get:()=>t.modelValue,set:d=>n("update:modelValue",d)});function r(d){n("clear",d)}function b(d,u){n("change",{name:d,value:u}),t.modelValue!==void 0&&n("update:modelValue",u)}return e.watch(()=>t.default,d=>{m.value=d}),e.watch(()=>t.modelValue,d=>{m.value=d}),e.watch(()=>t,d=>{m.value=d}),o({filterRef:l}),(d,u)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(y.value?.component),e.mergeProps(t,{type:y.value?.type,class:t.itemClass,modelValue:m.value,"onUpdate:modelValue":u[0]||(u[0]=i=>m.value=i),onChange:u[1]||(u[1]=i=>b(i.name,i.value)),onClear:u[2]||(u[2]=i=>r(i)),ref_key:"filterRef",ref:l}),null,16,["type","class","modelValue"]))}}),L=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(f,{expose:o,emit:p}){const t=f,n=p,l=e.ref(),y=e.computed({get:()=>t.modelValue,set:d=>n("update:modelValue",d)});function m(d){n("clear",d)}function r(d,u){n("change",{name:d,value:u}),t.modelValue!==void 0&&n("update:modelValue",u)}e.watch(()=>t.default,d=>{y.value=d}),e.watch(()=>t.modelValue,d=>{y.value=d}),o({filterRef:l});function b(){switch(t.layout){case"inline":return ce;case"vertical":return kl;case"popover":return xl;default:return ce}}return(d,u)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(b()),e.mergeProps(t,{onChange:u[0]||(u[0]=i=>r(i.name,i.value)),onClear:u[1]||(u[1]=i=>m(i)),modelValue:y.value,"onUpdate:modelValue":u[2]||(u[2]=i=>y.value=i)}),null,16,["modelValue"]))}});function P(f,o){const{slots:p}=f,t=a=>a?JSON.parse(JSON.stringify(e.toRaw(a))):{},n=e.ref(t(f.value));e.watch(()=>f.value,a=>{n.value=t(a)},{deep:!0,immediate:!0});const l=e.computed(()=>(e.toRaw(p?.default?.())??[]).flatMap(s=>Array.isArray(s.children)?s.children:[s]));function y(a){delete n.value[a],o("clear",{data:e.toRaw(n.value),name:a})}function m(a,s){s===void 0?y(a):n.value={...n.value,[a]:s},o("change",{data:e.toRaw(n.value),name:a,value:s})}const r=e.computed(()=>l.value.map(a=>{const s=a.props?.name;return e.cloneVNode(a,{...a.props,layout:f.view,showClean:!0,modelValue:n.value[s],"onUpdate:modelValue":g=>{m(s,g)},onClear:()=>y(s),class:[f.itemClass,a.props?.class],itemClass:[f.itemClass,a.props?.itemClass].filter(g=>typeof g=="string"&&g.trim().length>0).join(" ")||void 0})})),b=e.computed(()=>new Map(r.value.map(a=>{const s=a.props?.name;return s?[s,a]:null}).filter(a=>a!==null)));function d(a=!1){n.value={},a||o("clearAll",{data:e.toRaw(n.value),name:"ALL"})}const u=e.ref(""),i=e.computed(()=>f.schema?.value?Object.entries(n.value).filter(([a,s])=>f.schema&&!(a in f.schema.value)?!1:Array.isArray(s)?s.some(g=>g!==""&&g!==void 0):s!==""&&s!==void 0).length:0),k=e.ref();e.watch(u,async()=>{await e.nextTick(),k?.value?.filterRef?.inputTextRef&&k.value.filterRef.inputTextRef.focus()});const w=e.computed(()=>f.schema?.value?Object.fromEntries(Object.entries(f.schema?.value).slice(0,f.limit)):{}),x=e.computed(()=>{if(r.value.length===0)return[];let a=0;if(f.schema?.value){const s=Object.entries(f.schema.value).length;f.limit&&s<f.limit?a=f.limit-s:a=0}return r.value.slice(0,a)}),c=e.computed(()=>r.value.length===0?[]:f.view!=="inline"?r.value:r.value.slice(x.value.length));return{activeFilter:n,activeFilterCount:i,onFilterChange:m,clearFilter:y,clearAllFilters:d,limitedSchema:w,filtersSlot:r,limitedFiltersSlot:x,popoverFiltersSlot:c,vnodeMap:b,selectedFilter:u,filterRef:k}}const wl=e.defineComponent({__name:"popover",emits:["open","close"],setup(f,{emit:o}){const p=e.ref(!1),t=e.ref(null),n=e.ref(null),l=e.ref(null),y=e.ref({top:"0px",left:"0px",position:"absolute"});function m(){p.value=!p.value}function r(){const k=l.value,w=t.value;if(!k||!w)return;const x=k.getBoundingClientRect(),c=w.offsetWidth,a=window.innerWidth-x.left;let s=x.left+window.scrollX;c>a&&(s=window.innerWidth-c-8,s<8&&(s=8)),y.value={position:"absolute",top:`${x.bottom+window.scrollY+8}px`,left:`${s}px`}}const b=e.computed(()=>Object.entries(y.value).map(k=>k.join(":")).join(";"));function d(k){const w=k.target;!l.value?.contains(k.target)&&!t.value?.contains(k.target)&&!w.closest("[data-inside-popover]")&&(p.value=!1)}const u=e.ref(!1);e.onMounted(()=>{u.value=!0}),e.onMounted(()=>{l.value=n.value?.querySelector("[data-popover-trigger]")||null,l.value?.addEventListener("click",m),document.addEventListener("click",d),window.addEventListener("resize",r),window.addEventListener("scroll",r,!0)}),e.onBeforeUnmount(()=>{l.value?.removeEventListener("click",m),document.removeEventListener("click",d),window.removeEventListener("resize",r),window.removeEventListener("scroll",r,!0)});const i=o;return e.watch(p,async k=>{k?(i("open"),await e.nextTick(),r()):i("close")}),(k,w)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"wrapperRef",ref:n},[e.renderSlot(k.$slots,"trigger"),u.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popoverRef",ref:t,class:"absolute z-[50] w-[600px] rounded-md border bg-white shadow-md",style:e.normalizeStyle(b.value)},[e.renderSlot(k.$slots,"default")],4),[[e.vShow,p.value]])])):e.createCommentVNode("",!0)],512))}}),Vl={},Cl={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 Bl(f,o){return e.openBlock(),e.createElementBlock("svg",Cl,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 de=K(Vl,[["render",Bl]]),El={class:"flex items-center gap-2 overflow-hidden"},Nl={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"},Sl={class:"flex max-h-[400px]"},_l={class:"w-64 border-r border-gray-200 overflow-y-auto"},Dl={class:"p-4 border-b"},$l={class:"text-sm text-gray-600"},Fl={class:"p-2"},Al=["onClick"],jl={class:"flex items-center gap-2"},Ml={class:"text-sm font-medium"},Rl={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"},Tl=["onClick"],Kl={class:"flex items-center gap-2"},Ll={class:"text-sm font-medium"},zl={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"},Ol={key:0,class:"p-2 border-t"},Il={class:"flex-1 min-h-[300px] overflow-y-auto"},Ul={key:0,class:"flex items-center justify-center h-full text-gray-500"},Pl={class:"text-sm"},fe=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(f,{expose:o,emit:p}){const t=z(),n=f,l=ae(n.mode),y=e.useSlots(),m=p,r=e.ref({}),b=e.computed(()=>r?.value?n.view!=="inline"?r?.value:Object.fromEntries(Object.entries(r?.value).slice(n.limit)):{}),{activeFilter:d,activeFilterCount:u,onFilterChange:i,clearFilter:k,clearAllFilters:w,popoverFiltersSlot:x,selectedFilter:c,filterRef:a}=P({...n,schema:r,slots:y},m),s=e.computed(()=>n.badgeCount??u.value);function g(D){return Array.isArray(D)?D.filter(V=>V!=null&&V!=="").length:D&&typeof D=="object"?Object.values(D).filter(V=>V!=null&&V!=="").length:D===null||D!==void 0&&D!==""?1:0}function h(D){return d.value?g(d.value[D]):0}function _(){if(b.value){const[D]=Object.keys(b.value);c.value=D}else x.value.length>0?c.value=x.value[0].props.name:c.value=""}return e.watch(()=>n.schema,D=>{r.value=D??{}},{deep:!0,immediate:!0}),o({clearFilter:k,clearAllFilters:w}),(D,V)=>(e.openBlock(),e.createBlock(wl,{onOpen:_,onClose:V[5]||(V[5]=C=>c.value="")},{trigger:e.withCtx(()=>[e.createElementVNode("button",{"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([D.itemClass,e.unref(l),"flex items-center justify-between gap-2",s.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",El,[e.createVNode(de,{class:"h-4 w-4"}),V[6]||(V[6]=e.createElementVNode("span",{class:"text-sm font-medium"},"Фільтр",-1))]),s.value>0?(e.openBlock(),e.createElementBlock("span",Nl,e.toDisplayString(s.value),1)):e.createCommentVNode("",!0)],2)]),default:e.withCtx(()=>[e.createElementVNode("div",Sl,[e.createElementVNode("div",_l,[e.createElementVNode("div",Dl,[e.createElementVNode("p",$l,e.toDisplayString(e.unref(t)("filter.selectFieldHelp")),1)]),e.createElementVNode("div",Fl,[D.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(b.value),([C,S])=>(e.openBlock(),e.createElementBlock("button",{key:C,onClick:()=>{c.value=C},class:e.normalizeClass(["flex w-full items-center justify-between px-3 py-2 text-left transition-colors hover:bg-gray-50",e.unref(c)===C?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",jl,[e.createElementVNode("span",Ml,e.toDisplayString(S.label),1)]),h(C)>0?(e.openBlock(),e.createElementBlock("div",Rl,e.toDisplayString(h(C)),1)):e.createCommentVNode("",!0)],10,Al))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(x),(C,S)=>(e.openBlock(),e.createElementBlock("button",{key:"slot-"+S,onClick:E=>c.value=C.props.name,class:e.normalizeClass(["flex items-center justify-between px-3 py-2 text-left transition-colors hover:bg-gray-50",e.unref(c)===C.props.name?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",Kl,[e.createElementVNode("span",Ll,e.toDisplayString(C.props.label),1)]),h(C.props.name)>0?(e.openBlock(),e.createElementBlock("div",zl,e.toDisplayString(h(C.props.name)),1)):e.createCommentVNode("",!0)],10,Tl))),128))]),e.unref(u)>0?(e.openBlock(),e.createElementBlock("div",Ol,[e.createElementVNode("button",{class:e.normalizeClass([D.itemClass,"w-full px-3 py-2 text-left text-sm text-gray-600 hover:bg-gray-50 transition-colors"]),onClick:V[0]||(V[0]=C=>e.unref(w)()),"data-inside-popover":""}," Очистити всі ",2)])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Il,[e.unref(c)===""?(e.openBlock(),e.createElementBlock("div",Ul,[e.createElementVNode("p",Pl,e.toDisplayString(e.unref(t)("filter.selectFieldHelp")),1)])):e.createCommentVNode("",!0),e.unref(c)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[b.value?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(b.value),([C,S])=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.unref(c)===C?(e.openBlock(),e.createBlock(L,e.mergeProps({key:C,layout:"popover",ref_for:!0,ref_key:"filterRef",ref:a},{ref_for:!0},S,{class:[D.itemClass,S?.class],"item-class":[D.itemClass,S?.itemClass].filter(Boolean).join(" ")||void 0,onChange:V[1]||(V[1]=E=>e.unref(i)(E.name,E.value)),onClear:V[2]||(V[2]=E=>{e.unref(k)(E),e.unref(i)(E,void 0)}),modelValue:e.unref(d)[C],"onUpdate:modelValue":E=>e.unref(d)[C]=E,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(x),(C,S)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:"slot-"+S},[e.unref(c)===C.props.name?(e.openBlock(),e.createBlock(L,e.mergeProps({key:0,layout:"popover"},{ref_for:!0},C.props,{ref_for:!0,ref_key:"filterRef",ref:a,class:[D.itemClass,C.props?.class],"item-class":[D.itemClass,C.props?.itemClass].filter(Boolean).join(" ")||void 0,onChange:V[3]||(V[3]=E=>e.unref(i)(E.name,E.value)),onClear:V[4]||(V[4]=E=>{e.unref(k)(E),e.unref(i)(E,void 0)}),modelValue:e.unref(d)[C.props.name],"onUpdate:modelValue":E=>e.unref(d)[C.props.name]=E,cleanable:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])):e.createCommentVNode("",!0)],64))),128))],64)):e.createCommentVNode("",!0)])])]),_:1}))}}),Yl={class:"flex gap-1 items-center flex-wrap"},me=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(f,{expose:o,emit:p}){const t=z(),n=f,l=p,y=e.useSlots(),m=e.ref({}),r=e.computed(()=>Object.keys(n.schema).length>n.limit),{activeFilter:b,activeFilterCount:d,onFilterChange:u,clearFilter:i,clearAllFilters:k,limitedSchema:w,filtersSlot:x,limitedFiltersSlot:c}=P({...n,schema:m,slots:y},l);function a(V){return Array.isArray(V)?V.some(C=>C!==""&&C!==void 0&&C!==null):V===null?!0:V&&typeof V=="object"?Object.values(V).some(C=>C!==""&&C!==void 0&&C!==null):V!==""&&V!==void 0}const s=e.computed(()=>{const V=Object.keys(w.value??{}),C=c.value.map(S=>S.props?.name).filter(S=>typeof S=="string");return new Set([...V,...C])}),g=e.computed(()=>Object.entries(b.value??{}).filter(([V,C])=>s.value.has(V)&&a(C)).length),h=e.computed(()=>{const V=d.value??0,C=g.value??0;return Math.max(V-C,0)}),_=e.ref();function D(){_.value&&_.value.clearAllFilters(!0),k()}return e.watch(()=>n.schema,V=>{m.value=V},{deep:!0,immediate:!0}),o({clearFilter:i,clearAllFilters:k}),(V,C)=>(e.openBlock(),e.createElementBlock("div",Yl,[V.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(e.unref(w)),([S,E])=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:S,mode:V.mode,width:V.width?V.width:E?.width},{ref_for:!0},E,{class:[V.itemClass,E?.class],"item-class":[V.itemClass,E?.itemClass].filter(Boolean).join(" ")||void 0,onChange:C[0]||(C[0]=N=>e.unref(u)(N.name,N.value)),onClear:e.unref(i),layout:"inline",cleanable:!0,modelValue:e.unref(b)[S],"onUpdate:modelValue":N=>e.unref(b)[S]=N}),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(c),(S,E)=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:"slot-"+E,layout:"inline"},{ref_for:!0},S.props,{class:[V.itemClass,S.props?.class],"item-class":[V.itemClass,S.props?.itemClass].filter(Boolean).join(" ")||void 0,onChange:C[1]||(C[1]=N=>e.unref(u)(N.name,N.value)),onClear:C[2]||(C[2]=N=>{e.unref(i)(N),e.unref(u)(N,void 0)}),cleanable:!0,modelValue:e.unref(b)[S.props.name],"onUpdate:modelValue":N=>e.unref(b)[S.props.name]=N}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),128)),r.value?(e.openBlock(),e.createBlock(fe,e.mergeProps({key:1},n,{schema:V.schema,limit:V.limit,onChange:C[3]||(C[3]=S=>e.unref(u)(S.name,S.value)),onClearAll:C[4]||(C[4]=S=>e.unref(k)()),onClear:C[5]||(C[5]=S=>e.unref(i)(S.name)),mode:V.mode,ref_key:"popoverRef",ref:_,cleanable:!0,"badge-count":h.value}),{default:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(x),(S,E)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(S),e.mergeProps({key:"slot-"+E,layout:"popover"},{ref_for:!0},S.props,{cleanable:!0}),null,16))),128))]),_:1},16,["schema","limit","mode","badge-count"])):e.createCommentVNode("",!0),e.unref(d)>0?(e.openBlock(),e.createElementBlock("button",{key:2,onClick:D,class:e.normalizeClass([V.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(t)("filter.clear")),3)):e.createCommentVNode("",!0)]))}}),Wl={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"},ql={class:"flex items-center vst-filters vsTailwind flex-col w-full"},Ql=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(f,{expose:o,emit:p}){const t=f,n=p,l=e.useSlots(),{activeFilter:y,activeFilterCount:m,onFilterChange:r,clearFilter:b,clearAllFilters:d,filtersSlot:u}=P({...t,slots:l},n);return o({clearFilter:b,clearAllFilters:d}),(i,k)=>i.view==="vertical"?(e.openBlock(),e.createElementBlock("div",Wl,[e.createElementVNode("div",ql,[e.unref(m)>0?(e.openBlock(),e.createElementBlock("button",{key:0,onClick:k[0]||(k[0]=w=>e.unref(d)()),"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([i.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),i.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(Object.entries(i.schema),([w,x])=>(e.openBlock(),e.createBlock(L,e.mergeProps({layout:"vertical"},{ref_for:!0},x,{class:[i.itemClass,x?.class],"item-class":[i.itemClass,x?.itemClass].filter(Boolean).join(" ")||void 0,onChange:k[1]||(k[1]=c=>e.unref(r)(c.name,c.value)),onClear:k[2]||(k[2]=c=>{e.unref(b)(c),e.unref(r)(c,void 0)}),modelValue:e.unref(y)[w],"onUpdate:modelValue":c=>e.unref(y)[w]=c,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(u),(w,x)=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:"slot-"+x,layout:"vertical"},{ref_for:!0},w.props,{class:[i.itemClass,w.props?.class],"item-class":[i.itemClass,w.props?.itemClass].filter(Boolean).join(" ")||void 0,onChange:k[3]||(k[3]=c=>e.unref(r)(c.name,c.value)),onClear:k[4]||(k[4]=c=>{e.unref(b)(c),e.unref(r)(c,void 0)}),modelValue:e.unref(y)[w.props.name],"onUpdate:modelValue":c=>e.unref(y)[w.props.name]=c,showClean:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),128))])])):e.createCommentVNode("",!0)}}),Hl=["onKeydown"],Gl=["disabled"],Xl={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"},Jl={class:"rounded-2xl border border-slate-300/35 bg-white/95 p-4 shadow-2xl backdrop-blur-sm"},Zl={class:"mb-3 flex items-center justify-between"},vl={class:"text-[15px] font-semibold text-slate-800"},eo={"aria-hidden":"true"},to={class:"flex max-h-80 flex-col gap-1 overflow-y-auto"},lo={key:0,class:"mt-3 flex justify-end"},oo=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(f,{emit:o}){const p=z(),t=f,n=o,l=e.ref({}),y=e.useSlots(),{activeFilter:m,activeFilterCount:r,onFilterChange:b,clearFilter:d,clearAllFilters:u,filtersSlot:i}=P({...t,schema:l.value,slots:y},n),k=e.ref(null),w=e.ref(null),x=e.reactive({open:!1,top:0,left:0}),c=e.computed(()=>x.open),a=e.computed(()=>!!t.disabled),s=e.computed(()=>l.value||{}),g=e.computed(()=>t.title??"Фільтр"),h=e.computed(()=>!!y.trigger),_=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",a.value?"cursor-not-allowed opacity-60":"cursor-pointer"]),D=e.computed(()=>x.open?{position:"absolute",top:`${x.top}px`,left:`${x.left}px`,transform:"translateX(-50%)",zIndex:1e3}:{display:"none"});function V(){x.open=!1}function C(){if(!k.value)return;const F=k.value.getBoundingClientRect();x.top=F.bottom+window.scrollY+8,x.left=F.left+F.width/2+window.scrollX}function S(){x.open=!x.open,x.open&&e.nextTick(C)}function E(){a.value||S()}function N(){x.open&&C()}function A(){u()}return e.onMounted(()=>{window.addEventListener("resize",N),window.addEventListener("scroll",N,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",N),window.removeEventListener("scroll",N,!0)}),e.watch(()=>t.schema,F=>{if(!F){l.value={};return}if(Array.isArray(F)){const B=F.filter($=>$&&($.name||$.id)).map($=>{const j=$.name||$.id;return[j,{...$,name:j}]});l.value=Object.fromEntries(B);return}l.value=F},{deep:!0,immediate:!0}),e.watch(()=>t.disabled,F=>{F&&V()}),(F,B)=>(e.openBlock(),e.createElementBlock("div",{class:"relative inline-flex",ref_key:"anchor",ref:k},[h.value?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["inline-flex",a.value?"cursor-not-allowed opacity-60 pointer-events-none":"cursor-pointer"]),role:"button",tabindex:"0","data-popover-trigger":"",onClick:e.withModifiers(E,["prevent","stop"]),onKeydown:[e.withKeys(e.withModifiers(E,["prevent","stop"]),["enter"]),e.withKeys(e.withModifiers(E,["prevent","stop"]),["space"])]},[e.renderSlot(F.$slots,"trigger",{toggle:E,open:c.value,disabled:a.value,activeCount:e.unref(r)})],42,Hl)):(e.openBlock(),e.createElementBlock("button",{key:1,class:e.normalizeClass(_.value),type:"button",disabled:a.value,onClick:e.withModifiers(E,["prevent","stop"]),"data-popover-trigger":""},[e.createVNode(de,{class:"h-4 w-4"}),e.unref(r)>0?(e.openBlock(),e.createElementBlock("div",Xl,e.toDisplayString(e.unref(r)),1)):e.createCommentVNode("",!0)],10,Gl)),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[c.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["absolute",typeof F.width=="number"?`min-w-[${F.width+32+(Object.keys(s.value).length>7?20:0)}px]`:"min-w-[268px] "]),style:e.normalizeStyle(D.value),ref_key:"panel",ref:w,onClick:B[4]||(B[4]=e.withModifiers(()=>{},["stop"]))},[e.createElementVNode("div",Jl,[e.createElementVNode("div",Zl,[e.createElementVNode("h3",vl,e.toDisplayString(g.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:V},[e.createElementVNode("span",eo,[e.createVNode(G,{class:"h-4 w-4"})]),B[5]||(B[5]=e.createElementVNode("span",{class:"sr-only"},"Закрити",-1))])]),e.createElementVNode("div",to,[Object.keys(s.value).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(s.value),([$,j])=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:$},{ref_for:!0},{...j,layout:"inline"},{width:F.width?F.width:j?.width,class:[F.itemClass,j?.class],"item-class":[F.itemClass,j?.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(m)[$],"onUpdate:modelValue":M=>e.unref(m)[$]=M,onChange:B[0]||(B[0]=M=>e.unref(b)(M.name,M.value)),onClear:B[1]||(B[1]=M=>{e.unref(d)(M),e.unref(b)(M,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(i),($,j)=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:"slot-"+j,ref_for:!0},{...$.props,layout:"inline"},{class:[F.itemClass,$.props?.class],"item-class":[F.itemClass,$.props?.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(m)[$.props.name],"onUpdate:modelValue":M=>e.unref(m)[$.props.name]=M,onChange:B[2]||(B[2]=M=>e.unref(b)(M.name,M.value)),onClear:B[3]||(B[3]=M=>{e.unref(d)(M),e.unref(b)(M,void 0)})}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),128))]),e.unref(r)>0?(e.openBlock(),e.createElementBlock("div",lo,[e.createElementVNode("button",{type:"button",class:e.normalizeClass([F.itemClass,"text-sm font-semibold text-blue-600 transition-colors hover:text-blue-700 focus:outline-none"]),onClick:A},e.toDisplayString(e.unref(p)("filter.clear")),3)])):e.createCommentVNode("",!0)])],6)):e.createCommentVNode("",!0)]))],512))}}),Y=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(f,{expose:o,emit:p}){const t=f,n=e.ref(r(t.value??{}));e.watch(()=>t.value,async c=>{n.value=r(c??{}),(!c||Object.keys(c).length===0)&&(await e.nextTick(),y.value?.clearAllFilters?.(!0))},{deep:!0,immediate:!0});const l=p,y=e.ref(),m=e.useSlots();function r(c){if(Array.isArray(c))return c.map(a=>r(a));if(c!==null&&typeof c=="object"){const a=e.toRaw(c),s={};for(const g in a)s[g]=r(a[g]);return s}return c}function b(c,a){a!==void 0?n.value={...n.value,[c]:a}:delete n.value[c],l("change",{data:r(n.value),name:c,value:r(a)})}function d(c){delete n.value[c],l("clear",{data:r(n.value),name:c}),l("change",{data:r(n.value),name:c,value:null})}function u(){n.value={},l("clear",{data:r(n.value),name:"ALL"}),l("change",{data:r(n.value),name:"ALL",value:null})}const i=e.ref({});function k(){switch(t.view){case"inline":return me;case"vertical":return Ql;case"popover":return fe;case"popover-inline":return oo;default:return me}}e.watch(()=>t.schema,c=>{if(!c){i.value={};return}if(Array.isArray(c)&&!c.length){i.value={};return}Array.isArray(c)?i.value=c.filter(a=>a.type).reduce((a,s)=>(Object.assign(s,{name:s.id||s.name,type:{datepicker:"date"}[s.type.toLowerCase()]||s.type.toLowerCase(),label:s.label||s.ua}),a[s.name]=s,s.data&&!s.api&&!s.options&&Object.assign(s,{api:`/api/suggest/${s.data}`}),a),{}):(Object.entries(c).forEach(([a,s])=>{Object.assign(s,{name:a||s.name||s.id,type:s.type.toLowerCase()})}),i.value={...c})},{immediate:!0,deep:!0});function w(c){y.value.clearFilter(c),d(c)}function x(){y.value.clearAllFilters(),u()}return e.watch(()=>n.value,c=>{if(t.history){const a=new URL(window.location.href),s=new URLSearchParams(window.location.search);Object.keys(c).length>0?s.set("filter",Object.entries(c).filter(([,g])=>g).map(([g,h])=>`${g}=${h}`).join("|")):s.delete("filter"),a.search=decodeURI(s.toString()),window.history.pushState({},"",a)}}),o({clearAllFilters:x,clearFilter:w}),(c,a)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(k()),e.mergeProps(t,{schema:i.value,onChange:a[0]||(a[0]=s=>b(s.name,s.value)),onClear:a[1]||(a[1]=s=>d(s.name)),onClearAll:u,ref_key:"filterRef",ref:y}),e.createSlots({default:e.withCtx(()=>[e.renderSlot(c.$slots,"default")]),_:2},[e.unref(m).trigger?{name:"trigger",fn:e.withCtx(s=>[e.renderSlot(c.$slots,"trigger",e.normalizeProps(e.guardReactiveProps(s)))]),key:"0"}:void 0]),1040,["schema"]))}});Y.install=function(o){o.component("Filter",Y),o.component("FilterField",L)},T.Filter=Y,T.FilterField=L,T.default=Y,Object.defineProperties(T,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
|
|
1
|
+
(function(T,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@opengis/core")):typeof define=="function"&&define.amd?define(["exports","vue","@opengis/core"],e):(T=typeof globalThis<"u"?globalThis:T||self,e(T.FilterLib={},T.Vue,T.OpenGISCore))})(this,function(T,e,Z){"use strict";const K=(m,o)=>{const p=m.__vccOpts||m;for(const[t,n]of o)p[t]=n;return p},ue={},pe={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 ye(m,o){return e.openBlock(),e.createElementBlock("svg",pe,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 ge=K(ue,[["render",ye]]),he={},be={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 ke(m,o){return e.openBlock(),e.createElementBlock("svg",be,o[0]||(o[0]=[e.createElementVNode("path",{d:"M20 6 9 17l-5-5"},null,-1)]))}const O=K(he,[["render",ke]]),xe={class:"flex items-center justify-between w-full text-sm"},we={class:"flex items-center cursor-pointer w-full"},Ve={key:0,width:"16",height:"auto",src:"data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTYgMTYnIGZpbGw9J3doaXRlJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnPjxwYXRoIGQ9J00xMi4yMDcgNC43OTNhMSAxIDAgMDEwIDEuNDE0bC01IDVhMSAxIDAgMDEtMS40MTQgMGwtMi0yYTEgMSAwIDAxMS40MTQtMS40MTRMNi41IDkuMDg2bDQuMjkzLTQuMjkzYTEgMSAwIDAxMS40MTQgMHonLz48L3N2Zz4="},Ce=["value"],Be={class:"flex flex-row items-center font-normal text-gray-800 gap-x-1"},Ee={key:0,class:"text-xs text-gray-500 dark:text-neutral-500 pr-1"},Ne={key:1,class:"absolute right-2 flex size-3.5 items-center justify-center"},W=e.defineComponent({__name:"list-item",props:{layout:{},count:{},type:{},label:{},value:{},isSelected:{type:Boolean},color:{},highlighted:{type:Boolean}},emits:["itemClick"],setup(m,{expose:o,emit:p}){const t=m,n=p;function l(){n("itemClick",t.value)}const y=e.ref(null),f=e.computed(()=>t.layout==="inline"&&t.type==="radio");return o({el:y}),(r,b)=>(e.openBlock(),e.createElementBlock("div",{class:"flex items-center w-full rounded-sm group hover:bg-gray-100",ref_key:"el",ref:y},[e.createElementVNode("div",xe,[e.createElementVNode("div",we,[e.createElementVNode("label",{for:"radio-9740",class:e.normalizeClass([["inline","popover"].includes(r.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":r.highlighted,relative:f.value}]),onClick:e.withModifiers(l,["stop","prevent"])},[f.value?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["w-[18px] h-[18px] border flex items-center justify-center",[r.type==="checkbox"?"rounded-[4px]":"rounded-full",r.color?`bg-[${r.color}] border-[#ffffff]`:r.isSelected?"bg-[#2563eb] border-[#ffffff]":"bg-[#ffffff] border-[#d9d9d9]"]])},[r.isSelected?(e.openBlock(),e.createElementBlock("img",Ve)):e.createCommentVNode("",!0)],2)),e.createElementVNode("input",{type:"checkbox",class:"hidden",id:"radio-9740",value:r.value},null,8,Ce),e.createElementVNode("div",{class:e.normalizeClass(["flex flex-1 flex-row items-center justify-between",f.value?"pl-1 pr-6":"w-[calc(100%-18px)] pl-[10px]"])},[e.createElementVNode("span",Be,e.toDisplayString(r.label??"Відсутні дані"),1),r.count?(e.openBlock(),e.createElementBlock("div",Ee," ("+e.toDisplayString(r.count)+") ",1)):e.createCommentVNode("",!0)],2),f.value&&r.isSelected?(e.openBlock(),e.createElementBlock("span",Ne,[e.createVNode(O)])):e.createCommentVNode("",!0)],2)])])],512))}});function q(m,o){const{options:p=[],limit:t=20}=m;function n(g){return Array.isArray(g)?g[0]:g}const l=e.ref(n(m.modelValue)),y=e.ref(""),f=e.ref(!1),r=e.ref([]),b=e.ref("id"),i=e.ref("text"),u=e.ref(!1),c=e.ref(m.layout!=="popover"&&p.length>t);function k(g){const h=g.find(Boolean)??{},_=["id","value","code","key"].find(V=>V in h)??"id",D=["text","label","name","title"].find(V=>V in h)??"text";return{autoValueKey:_,autoLabelKey:D}}if(p.length>0){const g=k(p);b.value=g.autoValueKey,i.value=g.autoLabelKey}const w=e.computed(()=>{const g=r.value;return m.layout==="popover"||u.value?g:g.slice(0,t)});e.watch(()=>m.modelValue,g=>{l.value=n(g)},{immediate:!0}),r.value=[...p].sort((g,h)=>m.sort==="count"?h.count&&g.count?h.count-g.count:0:m.sort==="name"?String(g[i.value]??"").localeCompare(String(h[i.value]??"")):0);function x(g){return l.value===g[b.value]}function d(g){l.value=g[b.value],o("update:modelValue",l.value),o("change",{name:m.name,value:l.value})}function a(){l.value=void 0,o("update:modelValue",l.value),o("clear",m.name)}function s(){u.value=!u.value}return{innerValue:l,searchTerm:y,filteredOptions:w,isSelected:x,selectItem:d,clear:a,toggleShowAll:s,isReqProc:f,showAll:u,isEnableShowAll:c,labelKey:i,valueKey:b,allOptions:r}}const Se={},_e={class:"w-48 mx-auto",viewBox:"0 0 178 90",fill:"none",xmlns:"http://www.w3.org/2000/svg"};function De(m,o){return e.openBlock(),e.createElementBlock("svg",_e,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 Q=K(Se,[["render",De]]),$e={},Fe={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 Ae(m,o){return e.openBlock(),e.createElementBlock("svg",Fe,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 U=K($e,[["render",Ae]]),je={},Me={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 Re(m,o){return e.openBlock(),e.createElementBlock("svg",Me,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 H=K(je,[["render",Re]]),Te={key:0,class:"w-full"},Ke={class:"flex flex-col items-center justify-center p-5 text-center"},Le={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ze={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},Oe=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(m,{expose:o,emit:p}){const t=m,n=e.ref(null),l=p,{innerValue:y,filteredOptions:f,isSelected:r,selectItem:b,clear:i,toggleShowAll:u,isReqProc:c,showAll:k,isEnableShowAll:w,labelKey:x,valueKey:d,allOptions:a}=q({...t,modelValue:t.modelValue??t.default??""},l);return o({clear:i,inputTextRef:n}),e.watch(()=>t.modelValue,s=>{s===void 0&&(y.value=void 0)}),(s,g)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([s.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox"])},[e.createElementVNode("div",{class:e.normalizeClass([s.layout==="popover"?"flex-1 overflow-y-auto p-2":"",s.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(f),h=>(e.openBlock(),e.createBlock(W,{layout:s.layout,key:h[e.unref(d)],count:h.count,label:h[e.unref(x)],color:h.color,type:"radio",value:h[e.unref(d)],"is-selected":e.unref(r)(h),onItemClick:_=>e.unref(b)(h)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),128))],2),s.type==="select"&&e.unref(f).length===0&&!e.unref(c)?(e.openBlock(),e.createElementBlock("div",Te,[e.createElementVNode("div",Ke,[e.createVNode(Q),g[4]||(g[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),s.layout!=="popover"&&s.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(k)&&e.unref(w)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:g[0]||(g[0]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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"},[g[5]||(g[5]=e.createTextVNode(" Показати більше ",-1)),e.createVNode(U)])):e.createCommentVNode("",!0),e.unref(k)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:g[1]||(g[1]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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"},[g[6]||(g[6]=e.createTextVNode(" Показати менше ",-1)),e.createVNode(H)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),s.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[s.layout==="inline"?(e.openBlock(),e.createElementBlock("div",Le,[e.createTextVNode(e.toDisplayString(e.unref(y)||e.unref(y)===null?1:0)+" з "+e.toDisplayString(e.unref(a).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[2]||(g[2]=(...h)=>e.unref(i)&&e.unref(i)(...h))}," Очистити ",512),[[e.vShow,e.unref(y)!==""&&e.unref(y)!==void 0]])])):e.createCommentVNode("",!0),s.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ze,[e.createElementVNode("span",null,e.toDisplayString(e.unref(y)||e.unref(y)===null?1:0)+" з "+e.toDisplayString(e.unref(a).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[3]||(g[3]=(...h)=>e.unref(i)&&e.unref(i)(...h))}," Очистити ",512),[[e.vShow,e.unref(y)!==""&&e.unref(y)!==void 0]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}});function v(m,o){const{options:p=[],limit:t=20}=m;function n(g){return Array.isArray(g)?g:g?[g]:[]}const l=e.ref(n(m.modelValue)),y=e.ref(""),f=e.ref(!1),r=e.ref([]),b=e.ref("id"),i=e.ref("text"),u=e.ref(!1),c=e.ref(m.layout!=="popover"&&p.length>t);function k(g){const h=g.find(Boolean)??{},_=["id","value","code","key"].find(V=>V in h)??"id",D=["text","label","name","title"].find(V=>V in h)??"text";return{autoValueKey:_,autoLabelKey:D}}if(p.length>0){const g=k(p);b.value=g.autoValueKey,i.value=g.autoLabelKey}const w=e.computed(()=>{const g=r.value;return m.layout==="popover"||u.value?g:g.slice(0,t)});e.watch(()=>m.modelValue,g=>{l.value=n(g)},{immediate:!0}),r.value=[...p].sort((g,h)=>m.sort==="count"?h.count&&g.count?h.count-g.count:0:m.sort==="name"?String(g[i.value]).localeCompare(String(h[i.value])):0);function x(g){return l.value&&l.value.includes(g[b.value])}function d(g){const h=l.value.includes(g[b.value]);l.value=h?l.value.filter(_=>_!==g[b.value]):[...l.value,g[b.value]],o("update:modelValue",l.value),o("change",{name:m.name,value:l.value})}function a(){l.value=[],o("update:modelValue",l.value),o("clear",m.name)}function s(){u.value=!u.value}return{innerValue:l,searchTerm:y,filteredOptions:w,isSelected:x,selectItem:d,clear:a,toggleShowAll:s,isReqProc:f,showAll:u,isEnableShowAll:c,labelKey:i,valueKey:b,allOptions:r}}const ee={en:{apply:"Apply",search:"Search",more:"Show more",less:"Show less",selected:"selected",clear:"Clear",notfound:"Nothing found",period:"Period",today:"Today",week:"Week",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:"Тиждень",month:"Місяць",quarter:"Квартал",year:"Рік",alltime:"Весь час",prev:"Попередній період",next:"Настпуний період",selectFieldHelp:"Оберіть поле, щоб розпочати створення фільтра."}};function te(m){const o=m.split(".")[1],p=typeof window<"u"&&window.localStorage?localStorage.locale:null;return(ee[p||navigator.language]||ee.uk)[o]}function z(){const m=e.getCurrentInstance();if(!m.appContext.config.globalProperties.$i18n)return te;const o=m.appContext.config.globalProperties.$t;return p=>{const t=o(p);return t===p?te(p):t}}const Ie={key:0,class:"w-full"},Ue={class:"flex flex-col items-center justify-center p-5 text-center"},Pe={class:"max-w-sm mx-auto mt-6"},Ye={class:"font-medium text-gray-800 dark:text-neutral-200"},We={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},qe={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},le=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(m,{expose:o,emit:p}){const t=z(),n=m,l=p,{innerValue:y,filteredOptions:f,isSelected:r,selectItem:b,clear:i,toggleShowAll:u,isReqProc:c,showAll:k,isEnableShowAll:w,labelKey:x,valueKey:d,allOptions:a}=v({...n,modelValue:n.modelValue},l);return e.watch(()=>n.modelValue,s=>{s===void 0&&(y.value=[])}),o({clear:i}),(s,g)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([s.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",{class:e.normalizeClass([s.layout==="popover"?"flex-1 overflow-y-auto p-2":"",s.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(f),h=>(e.openBlock(),e.createBlock(W,{layout:s.layout,count:h.count,label:h[e.unref(x)],color:h.color,type:"checkbox",value:h[e.unref(d)],"is-selected":e.unref(r)(h),onItemClick:_=>e.unref(b)(h)},null,8,["layout","count","label","color","value","is-selected","onItemClick"]))),256))],2),s.type==="select"&&e.unref(f).length===0&&!e.unref(c)?(e.openBlock(),e.createElementBlock("div",Ie,[e.createElementVNode("div",Ue,[e.createVNode(Q),e.createElementVNode("div",Pe,[e.createElementVNode("p",Ye,e.toDisplayString(e.unref(t)("filter.notfound")),1),g[4]||(g[4]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),s.layout!=="popover"&&s.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(k)&&e.unref(w)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:g[0]||(g[0]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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(t)("filter.more"))+" ",1),e.createVNode(U)])):e.createCommentVNode("",!0),e.unref(k)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:g[1]||(g[1]=(...h)=>e.unref(u)&&e.unref(u)(...h)),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(t)("filter.less"))+" ",1),e.createVNode(H)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),s.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[s.layout==="inline"?(e.openBlock(),e.createElementBlock("div",We,[e.createTextVNode(e.toDisplayString(e.unref(y).length)+" / "+e.toDisplayString(e.unref(a).length)+" "+e.toDisplayString(e.unref(t)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[2]||(g[2]=(...h)=>e.unref(i)&&e.unref(i)(...h))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(y).length!==0]])])):e.createCommentVNode("",!0),s.layout==="popover"?(e.openBlock(),e.createElementBlock("div",qe,[e.createElementVNode("span",null,e.toDisplayString(e.unref(y).length)+" / "+e.toDisplayString(e.unref(a).length)+" "+e.toDisplayString(e.unref(t)("filter.selected")),1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:g[3]||(g[3]=(...h)=>e.unref(i)&&e.unref(i)(...h))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(y).length!==0]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}}),Qe={},He={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 Ge(m,o){return e.openBlock(),e.createElementBlock("svg",He,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 oe=K(Qe,[["render",Ge]]),Xe={},Je={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 Ze(m,o){return e.openBlock(),e.createElementBlock("svg",Je,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 G=K(Xe,[["render",Ze]]);class ne{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 ve={class:"absolute bottom-2/4 translate-y-2/4 cursor-pointer left-3"},et=["placeholder"],tt=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(m,{emit:o}){const p=m,t=e.ref((p.placeholder||p.label||p.title||p.name||"search").toString()),n=o,l=e.ref(p.modelValue?.toString()??"");e.watch(()=>p.modelValue,b=>{b!==l.value&&(l.value=b?.toString()??"")});let y=null;function f(){if(l.value=l.value.trimStart(),l.value.length===0){r();return}y&&clearTimeout(y),y=setTimeout(()=>{n("update:modelValue",l.value),n("change",{name:p.name,value:l.value})},300)}function r(){l.value="",n("update:modelValue",""),n("clear",p.name)}return(b,i)=>(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",b.layout==="inline"?e.unref(ne).getWidthClass(b.width):"mb-2"+(b.layout==="popover"?" m-2":"")])},[e.createElementVNode("div",ve,[e.createVNode(oe)]),l.value!==""?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:r,class:"absolute bottom-2/4 translate-y-2/4 right-3 cursor-pointer"},[e.createVNode(G)])):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"text","onUpdate:modelValue":i[0]||(i[0]=u=>l.value=u),onInput:f,placeholder:t.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,et),[[e.vModelText,l.value]])],2))}});function re(m={color:"blue"}){return e.computed(()=>{const p=`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-${m.color}-500 focus:border-transparent
|
|
2
|
+
text-gray-800 bg-white dark:text-neutral-300 dark:bg-neutral-800 dark:border-neutral-600`;return m?.size==="sm"?`${p}h-[32px]`:`${p}h-[38px]`})}function lt(){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 ot(){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 ae(m){return m==="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":m==="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 nt={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},rt=["placeholder","disabled"],at={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},st={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},it=["placeholder","disabled"],ct=["disabled"],no={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},ro={key:1,class:"flex justify-end items-center text-xs text-gray-500 p-1 border-t"},dt=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(m,{expose:o,emit:p}){const t=re(),n=lt(),l=z(),y=m,f=e.ref(y.modelValue??y.default??[]),r=p,b=e.computed({get:()=>y.modelValue??f.value,set:c=>{y.modelValue!==void 0?r("update:modelValue",c):f.value=c}});function i(){r("change",{name:y.name,value:b.value||f.value})}function u(){f.value=[],b.value=f.value,r("clear",y.name)}return e.watch(()=>y.modelValue,c=>{c!==void 0&&y.layout!=="popover"?(f.value=c,r("update:modelValue",c)):f.value=[]}),o({clear:u,currentValue:b}),(c,k)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",null,[e.createElementVNode("div",{class:e.normalizeClass(c.layout==="vertical"?"inline-flex items-center gap-2":"space-y-3 p-2")},[e.createElementVNode("div",null,[c.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",nt,e.toDisplayString(e.unref(l)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(t)),placeholder:c.placeholder?.[0]??"min",step:"1",style:{outline:"none"},"onUpdate:modelValue":k[0]||(k[0]=w=>b.value[0]=w),disabled:c.disabled},null,10,rt),[[e.vModelText,b.value[0]]])]),c.layout==="vertical"?(e.openBlock(),e.createElementBlock("label",at," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",null,[c.layout!=="vertical"?(e.openBlock(),e.createElementBlock("label",st,e.toDisplayString(e.unref(l)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"number",class:e.normalizeClass(e.unref(t)),placeholder:c.placeholder?.[1]??"max",min:"0",max:"1000000000000000",step:"1",style:{outline:"none"},"onUpdate:modelValue":k[1]||(k[1]=w=>b.value[1]=w),disabled:c.disabled},null,10,it),[[e.vModelText,b.value[1]]])]),["popover","inline","vertical"].includes(c.layout)?(e.openBlock(),e.createElementBlock("button",{key:1,onClick:i,class:e.normalizeClass(e.unref(n)+(c.layout==="vertical"?" w-[50px]":" bg-blue-100 hover:bg-blue-200"))},e.toDisplayString(c.layout==="vertical"?"Ok":e.unref(l)("filter.apply")),3)):e.createCommentVNode("",!0),["popover","inline"].includes(c.layout)?(e.openBlock(),e.createElementBlock("button",{key:2,disabled:!(b.value[0]||b.value[1]),onClick:u,class:e.normalizeClass(e.unref(n)+" hover:bg-gray-100")},e.toDisplayString(e.unref(l)("filter.clear")),11,ct)):e.createCommentVNode("",!0)],2)]),(c.cleanable&&f.value.length,e.createCommentVNode("",!0))],64))}});class R{static format(o){const p=o.getFullYear(),t=(o.getMonth()+1).toString().padStart(2,"0"),n=o.getDate().toString().padStart(2,"0");return`${p}-${t}-${n}`}static getShiftedDay(o,p=0){const t=o?new Date(o):new Date;return t.setDate(t.getDate()+p),this.format(t)}static getLastWeekRange(o,p,t=0){if(o&&p){const b=new Date(o),i=new Date(p);return b.setDate(b.getDate()+t*7),i.setDate(i.getDate()+t*7),[this.format(b),this.format(i)]}const n=new Date,l=n.getDay(),y=l===0?13:l-1+7,f=new Date(n);f.setDate(n.getDate()-y+t*7);const r=new Date(f);return r.setDate(f.getDate()+6),[this.format(f),this.format(r)]}static getMonthRange(o,p,t=0){let n;o?n=new Date(o):n=new Date,n=new Date(n.getFullYear(),n.getMonth()+t,1);const l=n,y=new Date(n.getFullYear(),n.getMonth()+1,0);return[this.format(l),this.format(y)]}static getQuarterRange(o,p,t=0){const n=o||p,l=n?new Date(n):new Date;let y=Math.floor(l.getMonth()/3);y+=t;const f=(y%4+4)%4*3,r=l.getFullYear()+Math.floor(y/4),b=new Date(r,f,1),i=new Date(r,f+3,0);return[this.format(b),this.format(i)]}static getYear(o,p=0){let t;return o&&/^\d{4}$/.test(o)?t=parseInt(o,10):o?t=new Date(o).getFullYear():t=new Date().getFullYear(),String(t+p)}static getYearRange(o,p=0){let t;return o&&/^\d{4}$/.test(o)?t=parseInt(o,10):o?t=new Date(o).getFullYear():t=new Date().getFullYear(),[this.format(new Date(t+p,0,1)),this.format(new Date(t+p+1,0,0))]}static getRangeFromDaysBefore(o){const p=new Date,t=new Date(p.getTime());return t.setDate(p.getDate()-o),[this.format(t),this.format(p)]}}function se(m,o){const{popoverRef:p}=m,t=z(),n=e.ref(""),l=e.ref(m.modelValue??m.default??[]),y=e.ref(0);function f(){const a=R.getRangeFromDaysBefore(y.value);return l.value=[...a],o("change",{name:m.name,value:l.value}),o("update:modelValue",l.value),a}function r(a){n.value=a,p.value?.close();const s=[];switch(n.value){case"today":s.push(R.getShiftedDay()),s.push(R.getShiftedDay());break;case"week":s.push(...R.getLastWeekRange());break;case"month":s.push(...R.getMonthRange());break;case"quarter":s.push(...R.getQuarterRange());break;case"year":s.push(...R.getYearRange());break;case"last_7_days":y.value=7,f();break;case"range":y.value=7,s.push(...f());break}l.value=[...s],o("change",{name:m.name,value:l.value}),o("update:modelValue",l.value)}function b(){const a=[];switch(n.value){case"today":a.push(R.getShiftedDay(l.value[0],1));break;case"week":a.push(...R.getLastWeekRange(l.value[0],l.value[1],1));break;case"month":a.push(...R.getMonthRange(l.value[0],l.value[1],1));break;case"quarter":a.push(...R.getQuarterRange(l.value[0],l.value[1],1));break;case"year":a.push(...R.getYearRange(l.value[0],1));break}l.value=[...a],o("change",{name:m.name,value:l.value}),o("update:modelValue",l.value)}function i(){const a=[];switch(n.value){case"today":a.push(R.getShiftedDay(l.value[0],-1));break;case"week":a.push(...R.getLastWeekRange(l.value[0],l.value[1],-1));break;case"month":a.push(...R.getMonthRange(l.value[0],l.value[1],-1));break;case"quarter":a.push(...R.getQuarterRange(l.value[0],l.value[1],-1));break;case"year":a.push(...R.getYearRange(l.value[0],-1));break}l.value=[...a],o("change",{name:m.name,value:l.value}),o("update:modelValue",l.value)}const u=["Січень","Лютий","Березень","Квітень","Травень","Червень","Липень","Серпень","Вересень","Жовтень","Листопад","Грудень"];function c(a){const[s,g,h]=a.split("-");return`${h}.${g}.${s}`}function k(a,s="long"){const g=new Date(Date.UTC(2e3,a-1,1));return new Intl.DateTimeFormat(localStorage.locale,{month:s,timeZone:"UTC"}).format(g)}function w(a){const{value:s}=l;switch(a){case"today":return c(s[0]);case"range":return"Період";case"week":return s[0]&&s[1]?`${c(s[0])} – ${c(s[1])}`:"";case"quarter":if(s[0]){const g=new Date(s[0]),h=g.getFullYear(),_=g.getMonth();return`${Math.floor(_/3)+1} ${t("filter.quarter")} ${h}`}return"";case"month":if(s[0]){const[g,h]=s[0].split("-");return`${k(parseInt(h,10))} ${g}`}return"";case"year":return s[0]||"";case"last_7_days":return"За останні дні";default:return m.label??""}}const x=e.computed(()=>n.value?w(n.value):m.label??"");function d(){n.value="",l.value=[],o("update:modelValue",[]),o("clear",m.name)}return{activeMode:n,innerValue:l,daysBefore:y,onDaysBeforeChange:f,onSelectChange:r,nextClick:b,prevClick:i,ukMonths:u,formatDisplayDate:c,getModeLabel:w,currentLabel:x,clear:d}}const ft={key:0,class:"relative flex w-full h-auto gap-2 filter-date m-2 flex-wrap"},mt={key:0,class:"flex gap-1 !w-[75%] rounded-sm"},ut=["max","disabled"],pt=["min","disabled"],yt={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},gt=["max","disabled"],ht={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},bt={key:0,class:"block text-xs font-medium text-gray-600 mb-1"},kt=["min","disabled"],xt={class:"flex gap-1 pt-2"},wt=["onClick"],ao={key:0,class:"flex justify-end items-center text-xs text-gray-500 p-1 border-t"},Vt=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(m,{expose:o,emit:p}){const t=m,n=re(),l=ot(),y=z(),f=p,r=e.ref(null),{activeMode:b,innerValue:i,onSelectChange:u,nextClick:c,prevClick:k,clear:w}=se({...t,popoverRef:r},f);return e.watch(()=>t.modelValue,x=>{x!==void 0?(i.value=x,f("update:modelValue",x)):(b.value="",i.value=[])}),e.watch(i,x=>{f("update:modelValue",x),f("change",{name:t.name,value:x})},{deep:!0}),o({clear:w,popoverRef:r}),(x,d)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[x.layout==="inline"?(e.openBlock(),e.createElementBlock("div",ft,[e.unref(b)!==""&&e.unref(b)==="range"?(e.openBlock(),e.createElementBlock("div",mt,[e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(i)[1],locale:"uk-UA","onUpdate:modelValue":d[0]||(d[0]=a=>e.unref(i)[0]=a),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:x.disabled},null,8,ut),[[e.vModelText,e.unref(i)[0]]]),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(i)[0],locale:"uk-UA","onUpdate:modelValue":d[1]||(d[1]=a=>e.unref(i)[1]=a),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:x.disabled},null,8,pt),[[e.vModelText,e.unref(i)[1]]])])):e.createCommentVNode("",!0)])):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(x.layout==="popover"?"space-y-3 p-2":"flex items-center gap-2")},[e.createElementVNode("div",{class:e.normalizeClass(x.layout!=="popover"?"w-[48%]":"")},[x.layout==="popover"?(e.openBlock(),e.createElementBlock("label",yt,e.toDisplayString(e.unref(y)("filter.from")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(i)[1],locale:"uk-UA","onUpdate:modelValue":d[2]||(d[2]=a=>e.unref(i)[0]=a),class:e.normalizeClass(e.unref(n)),disabled:x.disabled},null,10,gt),[[e.vModelText,e.unref(i)[0]]])],2),x.layout!=="popover"?(e.openBlock(),e.createElementBlock("label",ht," - ")):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass(x.layout!=="popover"?"w-[48%]":"")},[x.layout==="popover"?(e.openBlock(),e.createElementBlock("label",bt,e.toDisplayString(e.unref(y)("filter.to")),1)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(i)[0],locale:"uk-UA","onUpdate:modelValue":d[3]||(d[3]=a=>e.unref(i)[1]=a),class:e.normalizeClass(e.unref(n)),disabled:x.disabled},null,10,kt),[[e.vModelText,e.unref(i)[1]]])],2)],2),e.createElementVNode("div",xt,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(["today","week","month","quarter","year"],a=>e.createElementVNode("button",{key:a,class:e.normalizeClass(e.unref(l)+(e.unref(b)===a?" bg-blue-100":"")),onClick:s=>e.unref(u)(a)},e.toDisplayString(e.unref(y)("filter."+a)),11,wt)),64)),e.createElementVNode("button",{class:e.normalizeClass(e.unref(l)),onClick:d[4]||(d[4]=(...a)=>e.unref(k)&&e.unref(k)(...a))},"<",2),e.createElementVNode("button",{class:e.normalizeClass(e.unref(l)),onClick:d[5]||(d[5]=(...a)=>e.unref(c)&&e.unref(c)(...a))},">",2)]),(x.cleanable,e.createCommentVNode("",!0))],64))}});function Ct(m,o){const{api:p,options:t=[],limit:n=20,dataKey:l="data"}=m,y=m.multi;function f(B){return y?Array.isArray(B)?B:B?[B]:[]:Array.isArray(B)?B[0]:B}const r=e.ref(f(m.modelValue)),b=e.ref(""),i=e.ref(!1),u=e.ref(t),c=e.ref("id"),k=e.ref("text"),w=e.ref(!1),x=e.ref(m.layout!=="popover"&&t.length>n),d=e.ref([]),a=e.ref(0);function s(B){const $=B.find(Boolean)??{},j=["id","value","code","key"].find(I=>I in $)??"id",M=["text","label","name","title"].find(I=>I in $)??"text";return{autoValueKey:j,autoLabelKey:M}}if(t.length>0){const B=s(t);c.value=B.autoValueKey,k.value=B.autoLabelKey}const g=e.computed(()=>{if(p)return u.value;const B=u.value;if(m.layout==="popover")return B;if(!b.value)return w.value?B:B.slice(0,n);const $=b.value.toLowerCase();return B.filter(j=>j[k.value].toLowerCase().includes($))});let h=null;async function _(B){if(p){i.value=!0;try{const $=new URL(p,window.location.origin);$.searchParams.set("json","1"),$.searchParams.set("key",B),$.searchParams.set("limit",n.toString());const j=await fetch($.toString());if(!j.ok){Z.notify({type:"error",title:"Error",message:"Failed to fetch remote options"}),u.value=[];return}const M=await j.json();if(!M[l]){Z.notify({type:"error",title:"Error",message:M}),u.value=[];return}if(u.value=M[l],u.value.length>0){const I=s(u.value);c.value=I.autoValueKey,k.value=I.autoLabelKey}a.value=M.total}catch($){console.error("Failed to fetch remote options:",$)}finally{i.value=!1}}}e.watch(b,B=>{p&&(h&&clearTimeout(h),h=setTimeout(()=>{_(B)},200))}),e.watch(()=>m.modelValue,B=>{r.value=f(B)},{immediate:!0});function D(B){return y&&Array.isArray(r.value)?r.value.includes(B[c.value]):r.value&&r.value===B[c.value]}function V(B){if(y&&!Array.isArray(r.value)&&(r.value=[]),y&&Array.isArray(r.value)){const $=r.value.includes(B[c.value]);r.value=$?r.value.filter(j=>j!==B[c.value]):[...r.value,B[c.value]],d.value=$?d.value.filter(j=>j!==B[k.value]):[...d.value,B[k.value]]}else r.value=B[c.value],d.value=B[k.value];o("update:modelValue",r.value),o("change",{name:m.name,value:r.value})}function C(){y?(r.value=[],d.value=[]):(r.value=void 0,d.value=[]),o("update:modelValue",r.value),o("clear",m.name)}function S(){h&&clearTimeout(h),b.value="",w.value=!1}function E(){w.value=!w.value}e.onBeforeUnmount(()=>{h&&clearTimeout(h)});const N=e.ref(-1);e.watch(g,()=>{N.value=g.value.length>0?0:-1});function A(B){const $=g.value.length;if(B.key==="ArrowDown")B.preventDefault(),N.value=(N.value+1)%$;else if(B.key==="ArrowUp")B.preventDefault(),N.value=(N.value-1+$)%$;else if(B.key==="Enter"&&(B.preventDefault(),N.value>=0&&N.value<g.value.length)){const j=g.value[N.value];V(j)}}function F(){p&&u.value.length===0&&b.value.length===0&&_(b.value)}return{innerValue:r,searchTerm:b,filteredOptions:g,isSelected:D,selectItem:V,clear:C,resetSearch:S,toggleShowAll:E,isReqProc:i,showAll:w,isEnableShowAll:x,labelKey:k,valueKey:c,allOptions:u,highlightedIndex:N,onKeyDown:A,selectedLabels:d,totalCount:a,loadData:F}}const Bt={class:"h-[45px] shrink-0 px-[6px] py-[4px] flex items-center relative justify-center"},Et=["placeholder"],Nt={key:0,class:"w-full"},St={class:"flex flex-col items-center justify-center p-5 text-center"},_t={class:"max-w-sm mx-auto mt-6"},Dt={class:"font-medium text-gray-800 dark:text-neutral-200"},$t={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},Ft={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},At=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(m,{expose:o,emit:p}){const t=z(),n=m,l=p,y=e.ref(null),{innerValue:f,filteredOptions:r,isSelected:b,selectItem:i,clear:u,resetSearch:c,toggleShowAll:k,isReqProc:w,showAll:x,isEnableShowAll:d,searchTerm:a,labelKey:s,valueKey:g,highlightedIndex:h,onKeyDown:_,selectedLabels:D,totalCount:V,loadData:C}=Ct({...n,modelValue:n.modelValue},l);e.onMounted(()=>{c(),n.layout!=="inline"&&(C(),y.value&&n.layout==="popover"&&y.value.focus())}),e.watch(()=>n.modelValue,E=>{E===void 0&&(n.multi?f.value=[]:f.value=void 0)});const S=e.ref([]);return e.watch(h,E=>{E>=0&&S.value[E]&&S.value[E]?.scrollIntoView({block:"nearest",behavior:"smooth"})}),e.watch(r,()=>{S.value=[]}),o({clear:u,inputTextRef:y,selectedLabels:D,loadData:C}),(E,N)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass([E.layout==="popover"?"flex flex-col h-full":"flex flex-col vs-filter-checkbox space-y-0.5"])},[e.createElementVNode("div",Bt,[e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":N[0]||(N[0]=A=>e.isRef(a)?a.value=A:null),onKeydown:N[1]||(N[1]=(...A)=>e.unref(_)&&e.unref(_)(...A)),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(t)("filter.search"),type:"text",ref_key:"inputTextRef",ref:y},null,40,Et),[[e.vModelText,e.unref(a)]]),e.createVNode(oe,{class:"absolute text-gray-400 -translate-y-1/2 left-4 top-1/2"}),e.unref(a)!=""?(e.openBlock(),e.createBlock(G,{key:0,onClick:N[2]||(N[2]=A=>a.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([E.layout==="popover"?"flex-1 overflow-y-auto p-2":"",E.layout==="inline"?"flex-1 overflow-y-auto max-h-80":""])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(r),(A,F)=>(e.openBlock(),e.createBlock(W,{layout:E.layout,count:A.count,label:A[e.unref(s)],color:A.color,type:E.multi?"checkbox":"radio",value:A[e.unref(g)],"is-selected":e.unref(b)(A),highlighted:F===e.unref(h),onItemClick:B=>e.unref(i)(A),ref_for:!0,ref:B=>S.value[F]=B?.el},null,8,["layout","count","label","color","type","value","is-selected","highlighted","onItemClick"]))),256))],2),E.type==="select"&&e.unref(r).length===0&&!e.unref(w)?(e.openBlock(),e.createElementBlock("div",Nt,[e.createElementVNode("div",St,[e.createVNode(Q),e.createElementVNode("div",_t,[e.createElementVNode("p",Dt,e.toDisplayString(e.unref(t)("filter.notfound")),1),N[7]||(N[7]=e.createElementVNode("p",{class:"mt-2 text-sm text-gray-500 dark:text-neutral-500"},null,-1))])])])):e.createCommentVNode("",!0),E.layout!=="popover"&&E.type!=="select"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[!e.unref(x)&&e.unref(d)?(e.openBlock(),e.createElementBlock("div",{key:0,onClick:N[3]||(N[3]=(...A)=>e.unref(k)&&e.unref(k)(...A)),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(t)("filter.more"))+" ",1),e.createVNode(U)])):e.createCommentVNode("",!0),e.unref(x)?(e.openBlock(),e.createElementBlock("div",{key:1,onClick:N[4]||(N[4]=(...A)=>e.unref(k)&&e.unref(k)(...A)),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(t)("filter.less"))+" ",1),e.createVNode(H)])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0),E.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[E.layout==="inline"?(e.openBlock(),e.createElementBlock("div",$t,[e.createTextVNode(e.toDisplayString(E.multi&&Array.isArray(e.unref(f))?e.unref(f)?.length:e.unref(f)!==void 0&&(e.unref(f)||e.unref(f)===null)?1:0)+" / "+e.toDisplayString(e.unref(V))+" "+e.toDisplayString(e.unref(t)("filter.selected"))+" ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:N[5]||(N[5]=(...A)=>e.unref(u)&&e.unref(u)(...A))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(f)!==""&&e.unref(f)!==void 0||e.unref(f)]])])):e.createCommentVNode("",!0),E.layout==="popover"?(e.openBlock(),e.createElementBlock("div",Ft,[e.createElementVNode("span",null,e.toDisplayString(E.multi&&Array.isArray(e.unref(f))?e.unref(f)?.length:e.unref(f)!==void 0&&(e.unref(f)||e.unref(f)===null)?1:0)+" / "+e.toDisplayString(e.unref(V))+" "+e.toDisplayString(e.unref(t)("filter.selected")),1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:N[6]||(N[6]=(...A)=>e.unref(u)&&e.unref(u)(...A))},e.toDisplayString(e.unref(t)("filter.clear")),513),[[e.vShow,e.unref(f)!==""&&e.unref(f)!==void 0||e.unref(f)]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],2))}}),jt=["for","onClick"],Mt=["id","name","value"],Rt={class:"block"},Tt={key:0,class:"flex justify-between p-2 border-t bg-gray-50 text-xs text-gray-500"},Kt={key:1,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},Lt=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(m,{expose:o,emit:p}){const t=m,n=p,{innerValue:l,isSelected:y,selectItem:f,clear:r,labelKey:b,valueKey:i,allOptions:u}=t.multi?v({...t,modelValue:t.modelValue??t.default??[]},n):q({...t,modelValue:t.modelValue!==void 0?t.modelValue:t.default??""},n);return o({clear:r}),e.watch(()=>t.modelValue,c=>{c===void 0&&(t.multi?l.value=[]:l.value=void 0)}),(c,k)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{class:e.normalizeClass(["grid grid-cols-3 gap-2 mx-[1px]",c.layout==="popover"?"m-1":"mb-1"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(u),w=>(e.openBlock(),e.createElementBlock("label",{key:`item-${w[e.unref(i)]}`,for:`item-${w[e.unref(i)]}`,onClick:e.withModifiers(x=>e.unref(f)(w),["stop","prevent"]),class:e.normalizeClass([e.unref(y)(w)?"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-${w[e.unref(i)]}`,class:"hidden w4poy border-gray-200 g41z1 g22e3 axcnw dark:text-indigo-500 dark:border-neutral-700 dark:focus:ring-neutral-900",name:`item-${w[e.unref(i)]}`,value:w[e.unref(i)]},null,8,Mt),e.createElementVNode("span",Rt,e.toDisplayString(w[e.unref(b)]),1)],10,jt))),128))],2),c.cleanable?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[c.layout==="inline"?(e.openBlock(),e.createElementBlock("div",Tt,[e.createTextVNode(e.toDisplayString(c.multi&&Array.isArray(e.unref(l))?e.unref(l)?.length:e.unref(l)!==void 0&&(e.unref(l)||e.unref(l)===null)?1:0)+" з "+e.toDisplayString(e.unref(u).length)+" обрано ",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:k[0]||(k[0]=(...w)=>e.unref(r)&&e.unref(r)(...w))}," Очистити ",512),[[e.vShow,e.unref(l)!==""&&e.unref(l)!==void 0||e.unref(l)]])])):e.createCommentVNode("",!0),c.layout==="popover"?(e.openBlock(),e.createElementBlock("div",Kt,[e.createElementVNode("span",null,e.toDisplayString(c.multi&&Array.isArray(e.unref(l))?e.unref(l)?.length:e.unref(l)!==void 0&&(e.unref(l)||e.unref(l)===null)?1:0)+" з "+e.toDisplayString(e.unref(u).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:k[1]||(k[1]=(...w)=>e.unref(r)&&e.unref(r)(...w))}," Очистити ",512),[[e.vShow,e.unref(l)!==void 0&&e.unref(l)!==""||e.unref(l)]])])):e.createCommentVNode("",!0)],64)):e.createCommentVNode("",!0)],64))}}),zt=["disabled","title"],Ot={class:"flex w-full items-center justify-between gap-1 overflow-hidden text-left"},It={class:"truncate text-ellipsis text-sm"},Ut={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"},Pt={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"},Yt={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"},X=e.defineComponent({__name:"popover-field",props:{disabled:{type:Boolean,default:!1},label:{},en:{},ua:{},uk:{},fr:{},de:{},es:{},currentValue:{},fieldRef:{},width:{},mode:{},layout:{}},setup(m,{expose:o}){const p=m,t=e.computed(()=>ae(p.mode)),n=e.ref(!1),l=e.ref({top:0,left:0}),y=e.ref(null),f=e.ref(null),r=e.ref(null);function b(){const h=f.value,_=r.value;if(!h||!_)return;const D=h.getBoundingClientRect(),V=_.offsetWidth,C=window.innerWidth,S=D.bottom+8;let{left:E}=D;E+V>C&&(E=Math.max(C-V-10,10)),l.value={top:S,left:E}}function i(){n.value=!n.value,n.value&&e.nextTick(()=>{b(),p.fieldRef?.inputTextRef&&p.fieldRef?.inputTextRef?.focus?.(),p.fieldRef?.loadData&&p.fieldRef?.loadData?.()})}function u(h){!y.value?.contains(h.target)&&!r.value?.contains(h.target)&&!f.value?.contains(h.target)&&(n.value=!1)}function c(h){h.key==="Escape"&&(n.value=!1)}const k=e.ref(!1),w=e.ref("ua"),x=h=>{h.detail.key==="locale"&&(w.value=h.detail.newValue)};e.onMounted(()=>{k.value=!0,w.value=localStorage.locale,window.addEventListener("storage",x),document.addEventListener("click",u,!0),document.addEventListener("keydown",c),window.addEventListener("scroll",b,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",x),document.removeEventListener("click",u,!0),document.removeEventListener("keydown",c),window.removeEventListener("scroll",b,!0)});function d(){n.value=!1}o({close:d});function a(h){return Array.isArray(h)?h.filter(_=>_!=null&&_!=="").length:h&&typeof h=="object"?Object.values(h).filter(_=>_!=null&&_!=="").length:typeof h=="string"?h.trim()===""?0:1:typeof h=="number"?Number.isNaN(h)?0:1:h===null||h!==void 0?1:0}const s=e.computed(()=>{const h=p.fieldRef?.selectedLabels,_=a(h);return _>0?_:a(p.currentValue)}),g=e.computed(()=>{const h=p.fieldRef?.selectedLabels;return!h||["inline"].includes(p.layout||"")?p[w.value]||(p.label??""):Array.isArray(h)?h.length>0?h.join(", "):p.label??"":String(h)});return(h,_)=>(e.openBlock(),e.createElementBlock("div",null,[e.createElementVNode("button",{onClick:i,disabled:h.disabled,ref_key:"triggerRef",ref:f,title:h.label,class:e.normalizeClass([t.value,h.width?e.unref(ne).getWidthClass(h.width):"w-full",h.layout==="inline"&&s.value>0?"border border-blue-400 bg-blue-50 text-blue-600":""]),type:"button"},[e.createElementVNode("span",Ot,[e.createElementVNode("span",It,e.toDisplayString(g.value),1),h.layout==="inline"&&s.value>0?(e.openBlock(),e.createElementBlock("span",Ut,e.toDisplayString(s.value),1)):e.createCommentVNode("",!0)]),e.createVNode(U,{class:"h-4 w-4 text-neutral-500"})],10,zt),k.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popperRef",ref:r,class:"vsTailwind vs-popover__content bottom-right w-fit fixed z-[1000]",style:e.normalizeStyle({top:`${l.value.top}px`,left:`${l.value.left}px`}),"data-inside-popover":""},[e.createElementVNode("div",Pt,[e.createElementVNode("div",Yt,[e.renderSlot(h.$slots,"default")])])],4),[[e.vShow,n.value]])])):e.createCommentVNode("",!0)]))}}),Wt={},qt={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 Qt(m,o){return e.openBlock(),e.createElementBlock("svg",qt,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 Ht=K(Wt,[["render",Qt]]),Gt={},Xt={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 Jt(m,o){return e.openBlock(),e.createElementBlock("svg",Xt,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 Zt=K(Gt,[["render",Jt]]),vt={class:"flex gap-1"},el={class:"mb-1"},tl={class:"mb-1"},ll={class:"inline-flex rounded-sm shrink-0 pl-1"},ol=["title"],nl={class:"inline-flex rounded-sm shrink-0 pl-1"},rl=["title"],al={key:1,class:"flex gap-1 !w-[75%] rounded-sm"},sl=["max","disabled"],il=["min","disabled"],so={key:0,class:"flex justify-end items-center text-xs text-gray-500 p-1 border-t"},cl=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(m,{expose:o,emit:p}){const t=z(),n=m,l=p,y=e.ref(null),{activeMode:f,innerValue:r,onSelectChange:b,nextClick:i,prevClick:u,currentLabel:c,clear:k}=se({...n,popoverRef:y},l);return e.watch(()=>n.modelValue,w=>{w!==void 0?(r.value=w,l("update:modelValue",w)):(f.value="",r.value=[])}),e.watch(r,w=>{l("update:modelValue",w),l("change",{name:n.name,value:w})},{deep:!0}),o({clear:k,popoverRef:y}),(w,x)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",vt,[e.createVNode(X,{ref_key:"popoverRef",ref:y,label:e.unref(c),"current-value":e.unref(r),mode:w.mode,width:typeof w.width=="number"&&e.unref(r).length?w.width-70:w.width,onClear:e.unref(k),layout:w.layout,class:e.normalizeClass(w.itemClass)},{default:e.withCtx(()=>[e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[0]||(x[0]=d=>e.unref(b)("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(t)("filter.period"))+" ",1),e.unref(f)==="range"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),x[12]||(x[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:x[1]||(x[1]=d=>e.unref(b)("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(t)("filter.today"))+" ",1),e.unref(f)==="today"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[2]||(x[2]=d=>e.unref(b)("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(t)("filter.week"))+" ",1),e.unref(f)==="week"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[3]||(x[3]=d=>e.unref(b)("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(t)("filter.month"))+" ",1),e.unref(f)==="month"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",null,[e.createElementVNode("button",{type:"button",onClick:x[4]||(x[4]=d=>e.unref(b)("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(t)("filter.quarter"))+" ",1),e.unref(f)==="quarter"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",el,[e.createElementVNode("button",{type:"button",onClick:x[5]||(x[5]=d=>e.unref(b)("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(t)("filter.year"))+" ",1),e.unref(f)==="year"?(e.openBlock(),e.createBlock(O,{key:0})):e.createCommentVNode("",!0)])]),e.createElementVNode("div",tl,[e.createElementVNode("button",{type:"button",onClick:x[6]||(x[6]=d=>e.unref(k)()),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(t)("filter.alltime"))+" ",1),e.unref(r)[0]?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(O,{key:0}))])])]),_:1,__:[12]},8,["label","current-value","mode","width","onClear","layout","class"]),e.unref(f)!==""&&e.unref(f)!=="range"&&e.unref(f)!=="last_7_days"?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[e.createElementVNode("div",ll,[e.createElementVNode("button",{type:"button",title:e.unref(t)("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:x[7]||(x[7]=(...d)=>e.unref(u)&&e.unref(u)(...d))},[e.createVNode(Ht)],8,ol)]),e.createElementVNode("div",nl,[e.createElementVNode("button",{type:"button",title:e.unref(t)("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:x[8]||(x[8]=(...d)=>e.unref(i)&&e.unref(i)(...d))},[e.createVNode(Zt)],8,rl)])],64)):e.createCommentVNode("",!0),e.unref(f)!==""&&e.unref(f)==="range"?(e.openBlock(),e.createElementBlock("div",al,[e.withDirectives(e.createElementVNode("input",{type:"date",max:e.unref(r)[1],locale:"uk-UA","onUpdate:modelValue":x[9]||(x[9]=d=>e.unref(r)[0]=d),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600",disabled:w.disabled},null,8,sl),[[e.vModelText,e.unref(r)[0]]]),e.withDirectives(e.createElementVNode("input",{type:"date",min:e.unref(r)[0],locale:"uk-UA","onUpdate:modelValue":x[10]||(x[10]=d=>e.unref(r)[1]=d),class:"px-2 p-0 border text-[12px] max-w-[calc(50%-5px)] h-[38px] rounded-sm focus:outline-blue-600 appearance-auto",disabled:w.disabled},null,8,il),[[e.vModelText,e.unref(r)[1]]])])):e.createCommentVNode("",!0)]),(w.cleanable,e.createCommentVNode("",!0))],64))}}),dl={class:"flex flex-wrap items-center gap-2"},fl=["disabled","onClick"],ml={key:0,class:"flex justify-between items-center text-xs text-gray-500 p-1 border-t"},ie={radio:Oe,checkbox:le,check:le,text:tt,range:dt,date:Vt,select:At,tag:Lt,button: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(m,{expose:o,emit:p}){const t=m,n=p,{innerValue:l,isSelected:y,selectItem:f,clear:r,labelKey:b,valueKey:i,allOptions:u}=q({...t,modelValue:t.modelValue??t.default??""},n),c=e.computed(()=>l.value!==void 0&&!(typeof l.value=="string"&&l.value==="")),k=e.computed(()=>c.value?1:0);function w(d){return y(d)?["bg-blue-600 text-white"].filter(a=>typeof a=="string"&&a.trim().length>0).join(" "):["text-gray-700 hover:bg-gray-200 bg-gray-50 "].filter(a=>typeof a=="string"&&a.trim().length>0).join(" ")}function x(d){t.disabled||f(d)}return o({clear:r}),e.watch(()=>t.modelValue,d=>{d===void 0&&(l.value=void 0)}),(d,a)=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",dl,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(u),s=>(e.openBlock(),e.createElementBlock("button",{key:s[e.unref(i)],type:"button",class:e.normalizeClass(["px-3 py-2 text-sm font-medium rounded-md transition-colors",w(s)]),disabled:d.disabled,onClick:g=>x(s)},e.toDisplayString(s[e.unref(b)]),11,fl))),128))]),d.cleanable&&d.layout==="popover"?(e.openBlock(),e.createElementBlock("div",ml,[e.createElementVNode("span",null,e.toDisplayString(k.value)+" з "+e.toDisplayString(e.unref(u).length)+" обрано",1),e.withDirectives(e.createElementVNode("button",{class:"text-gray-600 hover:text-gray-800",onClick:a[0]||(a[0]=(...s)=>e.unref(r)&&e.unref(r)(...s))}," Очистити ",512),[[e.vShow,c.value]])])):e.createCommentVNode("",!0)],64))}}),"date:inline":cl};function J(m,o){let p;switch(m.toLowerCase()){case"autocomplete":p="select";break;case"check":p="checkbox";break;default:p=m?.toString().toLowerCase()}return p==="date"&&o&&o==="inline"&&(p="date:inline"),{component:ie[p]||ie.text,type:p}}const ul={style:{display:"inline-flex",margin:"0px",width:"100%"}},pl={class:"relative w-full mb-2 p-4 bg-white rounded-lg shadow-sm"},yl={class:"block mb-3 text-sm font-medium text-gray-800 dark:text-neutral-200"},gl={class:"flex items-center"},hl={class:"text-sm font-medium max-w-[80%] text-gray-800 flex items-center gap-x-1"},bl={class:"filter-layout__body"},kl=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(m,{expose:o,emit:p}){const t=m,n=p,l=e.ref(),y=J(t.type,t.layout),f=e.computed({get:()=>t.modelValue,set:u=>n("update:modelValue",u)});function r(u){n("clear",u)}function b(u,c){n("change",{name:u,value:c}),t.modelValue!==void 0&&n("update:modelValue",c)}function i(){n("clear",t.name)}return e.watch(()=>t.default,u=>{f.value=u}),e.watch(()=>t.modelValue,u=>{f.value=u}),o({filterRef:l}),(u,c)=>(e.openBlock(),e.createElementBlock("div",ul,[e.createElementVNode("div",pl,[e.createElementVNode("div",yl,[e.createElementVNode("div",gl,[e.createElementVNode("span",hl,e.toDisplayString(u.label),1)]),typeof f.value=="string"&&f.value.trim()!==""||Array.isArray(f.value)&&f.value.length>0&&f.value.some(k=>k!==void 0)||f.value===null?(e.openBlock(),e.createBlock(ge,{key:0,onClick:i})):e.createCommentVNode("",!0)]),e.createElementVNode("div",bl,[e.unref(y)?.type!=="select"?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({key:0},t,{type:e.unref(y)?.type,class:t.itemClass,onChange:c[0]||(c[0]=k=>b(k.name,k.value)),onClear:c[1]||(c[1]=k=>r(k)),ref_key:"filterRef",ref:l}),null,16,["type","class"])):(e.openBlock(),e.createBlock(X,{key:1,"current-value":f.value,label:u.label,mode:u.mode,onClear:i,fieldRef:l.value,width:void 0,disabled:u.disabled,layout:"vertical"},{default:e.withCtx(()=>[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({ref_key:"filterRef",ref:l},t,{type:e.unref(y)?.type,class:t.itemClass,onChange:c[2]||(c[2]=k=>b(k.name,k.value)),onClear:c[3]||(c[3]=k=>r(k))}),null,16,["type","class"]))]),_:1},8,["current-value","label","mode","fieldRef","disabled"]))])])]))}}),ce=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(m,{expose:o,emit:p}){const t=m,n=p,l=e.ref(),y=J(t.type,t.layout),f=e.computed({get:()=>t.modelValue,set:i=>n("update:modelValue",i)});function r(i=t.name){n("clear",i)}function b(i,u){n("change",{name:i,value:u}),t.modelValue!==void 0&&n("update:modelValue",u)}return e.watch(()=>t.default,i=>{f.value=i}),e.watch(()=>t.modelValue,i=>{f.value=i}),o({filterRef:l}),(i,u)=>["text","date","button"].includes(i.type.toLocaleLowerCase())?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({key:0},t,{type:e.unref(y)?.type,class:i.itemClass,onChange:u[0]||(u[0]=c=>b(c.name,c.value)),onClear:u[1]||(u[1]=c=>r(c)),disabled:i.disabled,modelValue:f.value,"onUpdate:modelValue":u[2]||(u[2]=c=>f.value=c)}),null,16,["type","class","disabled","modelValue"])):(e.openBlock(),e.createBlock(X,{key:1,"current-value":f.value,label:i.label,mode:i.mode,onClear:r,fieldRef:l.value,width:t.width,disabled:i.disabled,layout:"inline"},{default:e.withCtx(()=>[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(e.unref(y)?.component),e.mergeProps({ref_key:"filterRef",ref:l},t,{modelValue:f.value,"onUpdate:modelValue":u[3]||(u[3]=c=>f.value=c),type:e.unref(y)?.type,class:t.itemClass,onChange:u[4]||(u[4]=c=>b(c.name,c.value)),onClear:u[5]||(u[5]=c=>r(c))}),null,16,["modelValue","type","class"]))]),_:1},8,["current-value","label","mode","fieldRef","width","disabled"]))}}),xl=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(m,{expose:o,emit:p}){const t=m,n=p,l=e.ref(),y=e.ref(J(t.type,t.layout)),f=e.computed({get:()=>t.modelValue,set:i=>n("update:modelValue",i)});function r(i){n("clear",i)}function b(i,u){n("change",{name:i,value:u}),t.modelValue!==void 0&&n("update:modelValue",u)}return e.watch(()=>t.default,i=>{f.value=i}),e.watch(()=>t.modelValue,i=>{f.value=i}),e.watch(()=>t,i=>{f.value=i}),o({filterRef:l}),(i,u)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(y.value?.component),e.mergeProps(t,{type:y.value?.type,class:t.itemClass,modelValue:f.value,"onUpdate:modelValue":u[0]||(u[0]=c=>f.value=c),onChange:u[1]||(u[1]=c=>b(c.name,c.value)),onClear:u[2]||(u[2]=c=>r(c)),ref_key:"filterRef",ref:l}),null,16,["type","class","modelValue"]))}}),L=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(m,{expose:o,emit:p}){const t=m,n=p,l=e.ref(),y=e.computed({get:()=>t.modelValue,set:i=>n("update:modelValue",i)});function f(i){n("clear",i)}function r(i,u){n("change",{name:i,value:u}),t.modelValue!==void 0&&n("update:modelValue",u)}e.watch(()=>t.default,i=>{y.value=i}),e.watch(()=>t.modelValue,i=>{y.value=i}),o({filterRef:l});function b(){switch(t.layout){case"inline":return ce;case"vertical":return kl;case"popover":return xl;default:return ce}}return(i,u)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(b()),e.mergeProps(t,{onChange:u[0]||(u[0]=c=>r(c.name,c.value)),onClear:u[1]||(u[1]=c=>f(c)),modelValue:y.value,"onUpdate:modelValue":u[2]||(u[2]=c=>y.value=c)}),null,16,["modelValue"]))}});function P(m,o){const{slots:p}=m,t=a=>a?JSON.parse(JSON.stringify(e.toRaw(a))):{},n=e.ref(t(m.value));e.watch(()=>m.value,a=>{n.value=t(a)},{deep:!0,immediate:!0});const l=e.computed(()=>(e.toRaw(p?.default?.())??[]).flatMap(s=>Array.isArray(s.children)?s.children:[s]));function y(a){delete n.value[a],o("clear",{data:e.toRaw(n.value),name:a})}function f(a,s){s===void 0?y(a):n.value={...n.value,[a]:s},o("change",{data:e.toRaw(n.value),name:a,value:s})}const r=e.computed(()=>l.value.map(a=>{const s=a.props?.name;return e.cloneVNode(a,{...a.props,layout:m.view,showClean:!0,modelValue:n.value[s],"onUpdate:modelValue":g=>{f(s,g)},onClear:()=>y(s),class:[m.itemClass,a.props?.class],itemClass:[m.itemClass,a.props?.itemClass].filter(g=>typeof g=="string"&&g.trim().length>0).join(" ")||void 0})})),b=e.computed(()=>new Map(r.value.map(a=>{const s=a.props?.name;return s?[s,a]:null}).filter(a=>a!==null)));function i(a=!1){n.value={},a||o("clearAll",{data:e.toRaw(n.value),name:"ALL"})}const u=e.ref(""),c=e.computed(()=>m.schema?.value?Object.entries(n.value).filter(([a,s])=>m.schema&&!(a in m.schema.value)?!1:Array.isArray(s)?s.some(g=>g!==""&&g!==void 0):s!==""&&s!==void 0).length:0),k=e.ref();e.watch(u,async()=>{await e.nextTick(),k?.value?.filterRef?.inputTextRef&&k.value.filterRef.inputTextRef.focus()});const w=e.computed(()=>m.schema?.value?Object.fromEntries(Object.entries(m.schema?.value).slice(0,m.limit)):{}),x=e.computed(()=>{if(r.value.length===0)return[];let a=0;if(m.schema?.value){const s=Object.entries(m.schema.value).length;m.limit&&s<m.limit?a=m.limit-s:a=0}return r.value.slice(0,a)}),d=e.computed(()=>r.value.length===0?[]:m.view!=="inline"?r.value:r.value.slice(x.value.length));return{activeFilter:n,activeFilterCount:c,onFilterChange:f,clearFilter:y,clearAllFilters:i,limitedSchema:w,filtersSlot:r,limitedFiltersSlot:x,popoverFiltersSlot:d,vnodeMap:b,selectedFilter:u,filterRef:k}}const wl=e.defineComponent({__name:"popover",emits:["open","close"],setup(m,{emit:o}){const p=e.ref(!1),t=e.ref(null),n=e.ref(null),l=e.ref(null),y=e.ref({top:"0px",left:"0px",position:"absolute"});function f(){p.value=!p.value}function r(){const k=l.value,w=t.value;if(!k||!w)return;const x=k.getBoundingClientRect(),d=w.offsetWidth,a=window.innerWidth-x.left;let s=x.left+window.scrollX;d>a&&(s=window.innerWidth-d-8,s<8&&(s=8)),y.value={position:"absolute",top:`${x.bottom+window.scrollY+8}px`,left:`${s}px`}}const b=e.computed(()=>Object.entries(y.value).map(k=>k.join(":")).join(";"));function i(k){const w=k.target;!l.value?.contains(k.target)&&!t.value?.contains(k.target)&&!w.closest("[data-inside-popover]")&&(p.value=!1)}const u=e.ref(!1);e.onMounted(()=>{u.value=!0}),e.onMounted(()=>{l.value=n.value?.querySelector("[data-popover-trigger]")||null,l.value?.addEventListener("click",f),document.addEventListener("click",i),window.addEventListener("resize",r),window.addEventListener("scroll",r,!0)}),e.onBeforeUnmount(()=>{l.value?.removeEventListener("click",f),document.removeEventListener("click",i),window.removeEventListener("resize",r),window.removeEventListener("scroll",r,!0)});const c=o;return e.watch(p,async k=>{k?(c("open"),await e.nextTick(),r()):c("close")}),(k,w)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"wrapperRef",ref:n},[e.renderSlot(k.$slots,"trigger"),u.value?(e.openBlock(),e.createBlock(e.Teleport,{key:0,to:"body"},[e.withDirectives(e.createElementVNode("div",{ref_key:"popoverRef",ref:t,class:"absolute z-[50] w-[600px] rounded-md border bg-white shadow-md",style:e.normalizeStyle(b.value)},[e.renderSlot(k.$slots,"default")],4),[[e.vShow,p.value]])])):e.createCommentVNode("",!0)],512))}}),Vl={},Cl={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 Bl(m,o){return e.openBlock(),e.createElementBlock("svg",Cl,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 de=K(Vl,[["render",Bl]]),El={class:"flex items-center gap-2 overflow-hidden"},Nl={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"},Sl={class:"flex max-h-[400px]"},_l={class:"w-64 border-r border-gray-200 overflow-y-auto"},Dl={class:"p-4 border-b"},$l={class:"text-sm text-gray-600"},Fl={class:"p-2"},Al=["onClick"],jl={class:"flex items-center gap-2"},Ml={class:"text-sm font-medium"},Rl={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"},Tl=["onClick"],Kl={class:"flex items-center gap-2"},Ll={class:"text-sm font-medium"},zl={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"},Ol={key:0,class:"p-2 border-t"},Il={class:"flex-1 min-h-[300px] overflow-y-auto"},Ul={key:0,class:"flex items-center justify-center h-full text-gray-500"},Pl={class:"text-sm"},fe=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(m,{expose:o,emit:p}){const t=z(),n=m,l=ae(n.mode),y=e.useSlots(),f=p,r=e.ref({}),b=e.computed(()=>r?.value?n.view!=="inline"?r?.value:Object.fromEntries(Object.entries(r?.value).slice(n.limit)):{}),{activeFilter:i,activeFilterCount:u,onFilterChange:c,clearFilter:k,clearAllFilters:w,popoverFiltersSlot:x,selectedFilter:d,filterRef:a}=P({...n,schema:r,slots:y},f),s=e.computed(()=>n.badgeCount??u.value);function g(D){return Array.isArray(D)?D.filter(V=>V!=null&&V!=="").length:D&&typeof D=="object"?Object.values(D).filter(V=>V!=null&&V!=="").length:D===null||D!==void 0&&D!==""?1:0}function h(D){return i.value?g(i.value[D]):0}function _(){if(b.value){const[D]=Object.keys(b.value);d.value=D}else x.value.length>0?d.value=x.value[0].props.name:d.value=""}return e.watch(()=>n.schema,D=>{r.value=D??{}},{deep:!0,immediate:!0}),o({clearFilter:k,clearAllFilters:w}),(D,V)=>(e.openBlock(),e.createBlock(wl,{onOpen:_,onClose:V[5]||(V[5]=C=>d.value="")},{trigger:e.withCtx(()=>[e.createElementVNode("button",{"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([D.itemClass,e.unref(l),"flex items-center justify-between gap-2",s.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",El,[e.createVNode(de,{class:"h-4 w-4"}),V[6]||(V[6]=e.createElementVNode("span",{class:"text-sm font-medium"},"Фільтр",-1))]),s.value>0?(e.openBlock(),e.createElementBlock("span",Nl,e.toDisplayString(s.value),1)):e.createCommentVNode("",!0)],2)]),default:e.withCtx(()=>[e.createElementVNode("div",Sl,[e.createElementVNode("div",_l,[e.createElementVNode("div",Dl,[e.createElementVNode("p",$l,e.toDisplayString(e.unref(t)("filter.selectFieldHelp")),1)]),e.createElementVNode("div",Fl,[D.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(b.value),([C,S])=>(e.openBlock(),e.createElementBlock("button",{key:C,onClick:()=>{d.value=C},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)===C?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",jl,[e.createElementVNode("span",Ml,e.toDisplayString(S.label),1)]),h(C)>0?(e.openBlock(),e.createElementBlock("div",Rl,e.toDisplayString(h(C)),1)):e.createCommentVNode("",!0)],10,Al))),128)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(x),(C,S)=>(e.openBlock(),e.createElementBlock("button",{key:"slot-"+S,onClick:E=>d.value=C.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)===C.props.name?"bg-blue-50 text-blue-700 border-l-2 border-blue-500":"text-neutral-700"])},[e.createElementVNode("div",Kl,[e.createElementVNode("span",Ll,e.toDisplayString(C.props.label),1)]),h(C.props.name)>0?(e.openBlock(),e.createElementBlock("div",zl,e.toDisplayString(h(C.props.name)),1)):e.createCommentVNode("",!0)],10,Tl))),128))]),e.unref(u)>0?(e.openBlock(),e.createElementBlock("div",Ol,[e.createElementVNode("button",{class:e.normalizeClass([D.itemClass,"w-full px-3 py-2 text-left text-sm text-gray-600 hover:bg-gray-50 transition-colors"]),onClick:V[0]||(V[0]=C=>e.unref(w)()),"data-inside-popover":""}," Очистити всі ",2)])):e.createCommentVNode("",!0)]),e.createElementVNode("div",Il,[e.unref(d)===""?(e.openBlock(),e.createElementBlock("div",Ul,[e.createElementVNode("p",Pl,e.toDisplayString(e.unref(t)("filter.selectFieldHelp")),1)])):e.createCommentVNode("",!0),e.unref(d)?(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[b.value?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(b.value),([C,S])=>(e.openBlock(),e.createElementBlock(e.Fragment,null,[e.unref(d)===C?(e.openBlock(),e.createBlock(L,e.mergeProps({key:C,layout:"popover",ref_for:!0,ref_key:"filterRef",ref:a},{ref_for:!0},S,{class:[D.itemClass,S?.class],"item-class":[D.itemClass,S?.itemClass].filter(Boolean).join(" ")||void 0,onChange:V[1]||(V[1]=E=>e.unref(c)(E.name,E.value)),onClear:V[2]||(V[2]=E=>{e.unref(k)(E),e.unref(c)(E,void 0)}),modelValue:e.unref(i)[C],"onUpdate:modelValue":E=>e.unref(i)[C]=E,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(x),(C,S)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:"slot-"+S},[e.unref(d)===C.props.name?(e.openBlock(),e.createBlock(L,e.mergeProps({key:0,layout:"popover"},{ref_for:!0},C.props,{ref_for:!0,ref_key:"filterRef",ref:a,class:[D.itemClass,C.props?.class],"item-class":[D.itemClass,C.props?.itemClass].filter(Boolean).join(" ")||void 0,onChange:V[3]||(V[3]=E=>e.unref(c)(E.name,E.value)),onClear:V[4]||(V[4]=E=>{e.unref(k)(E),e.unref(c)(E,void 0)}),modelValue:e.unref(i)[C.props.name],"onUpdate:modelValue":E=>e.unref(i)[C.props.name]=E,cleanable:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"])):e.createCommentVNode("",!0)],64))),128))],64)):e.createCommentVNode("",!0)])])]),_:1}))}}),Yl={class:"flex gap-1 items-center flex-wrap"},me=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(m,{expose:o,emit:p}){const t=z(),n=m,l=p,y=e.useSlots(),f=e.ref({}),r=e.computed(()=>Object.keys(n.schema).length>n.limit),{activeFilter:b,activeFilterCount:i,onFilterChange:u,clearFilter:c,clearAllFilters:k,limitedSchema:w,filtersSlot:x,limitedFiltersSlot:d}=P({...n,schema:f,slots:y},l);function a(V){return Array.isArray(V)?V.some(C=>C!==""&&C!==void 0&&C!==null):V===null?!0:V&&typeof V=="object"?Object.values(V).some(C=>C!==""&&C!==void 0&&C!==null):V!==""&&V!==void 0}const s=e.computed(()=>{const V=Object.keys(w.value??{}),C=d.value.map(S=>S.props?.name).filter(S=>typeof S=="string");return new Set([...V,...C])}),g=e.computed(()=>Object.entries(b.value??{}).filter(([V,C])=>s.value.has(V)&&a(C)).length),h=e.computed(()=>{const V=i.value??0,C=g.value??0;return Math.max(V-C,0)}),_=e.ref();function D(){_.value&&_.value.clearAllFilters(!0),k()}return e.watch(()=>n.schema,V=>{f.value=V},{deep:!0,immediate:!0}),o({clearFilter:c,clearAllFilters:k}),(V,C)=>(e.openBlock(),e.createElementBlock("div",Yl,[V.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(e.unref(w)),([S,E])=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:S,mode:V.mode,width:V.width?V.width:E?.width},{ref_for:!0},E,{class:[V.itemClass,E?.class],"item-class":[V.itemClass,E?.itemClass].filter(Boolean).join(" ")||void 0,onChange:C[0]||(C[0]=N=>e.unref(u)(N.name,N.value)),onClear:e.unref(c),layout:"inline",cleanable:!0,modelValue:e.unref(b)[S],"onUpdate:modelValue":N=>e.unref(b)[S]=N}),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),(S,E)=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:"slot-"+E,layout:"inline"},{ref_for:!0},S.props,{class:[V.itemClass,S.props?.class],"item-class":[V.itemClass,S.props?.itemClass].filter(Boolean).join(" ")||void 0,onChange:C[1]||(C[1]=N=>e.unref(u)(N.name,N.value)),onClear:C[2]||(C[2]=N=>{e.unref(c)(N),e.unref(u)(N,void 0)}),cleanable:!0,modelValue:e.unref(b)[S.props.name],"onUpdate:modelValue":N=>e.unref(b)[S.props.name]=N}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),128)),r.value?(e.openBlock(),e.createBlock(fe,e.mergeProps({key:1},n,{schema:V.schema,limit:V.limit,onChange:C[3]||(C[3]=S=>e.unref(u)(S.name,S.value)),onClearAll:C[4]||(C[4]=S=>e.unref(k)()),onClear:C[5]||(C[5]=S=>e.unref(c)(S.name)),mode:V.mode,ref_key:"popoverRef",ref:_,cleanable:!0,"badge-count":h.value}),{default:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(x),(S,E)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(S),e.mergeProps({key:"slot-"+E,layout:"popover"},{ref_for:!0},S.props,{cleanable:!0}),null,16))),128))]),_:1},16,["schema","limit","mode","badge-count"])):e.createCommentVNode("",!0),e.unref(i)>0?(e.openBlock(),e.createElementBlock("button",{key:2,onClick:D,class:e.normalizeClass([V.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(t)("filter.clear")),3)):e.createCommentVNode("",!0)]))}}),Wl={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"},ql={class:"flex items-center vst-filters vsTailwind flex-col w-full"},Ql=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(m,{expose:o,emit:p}){const t=m,n=p,l=e.useSlots(),{activeFilter:y,activeFilterCount:f,onFilterChange:r,clearFilter:b,clearAllFilters:i,filtersSlot:u}=P({...t,slots:l},n);return o({clearFilter:b,clearAllFilters:i}),(c,k)=>c.view==="vertical"?(e.openBlock(),e.createElementBlock("div",Wl,[e.createElementVNode("div",ql,[e.unref(f)>0?(e.openBlock(),e.createElementBlock("button",{key:0,onClick:k[0]||(k[0]=w=>e.unref(i)()),"data-popover-trigger":"","aria-haspopup":"dialog","aria-expanded":"false",class:e.normalizeClass([c.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),c.schema?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:1},e.renderList(Object.entries(c.schema),([w,x])=>(e.openBlock(),e.createBlock(L,e.mergeProps({layout:"vertical"},{ref_for:!0},x,{class:[c.itemClass,x?.class],"item-class":[c.itemClass,x?.itemClass].filter(Boolean).join(" ")||void 0,onChange:k[1]||(k[1]=d=>e.unref(r)(d.name,d.value)),onClear:k[2]||(k[2]=d=>{e.unref(b)(d),e.unref(r)(d,void 0)}),modelValue:e.unref(y)[w],"onUpdate:modelValue":d=>e.unref(y)[w]=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(u),(w,x)=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:"slot-"+x,layout:"vertical"},{ref_for:!0},w.props,{class:[c.itemClass,w.props?.class],"item-class":[c.itemClass,w.props?.itemClass].filter(Boolean).join(" ")||void 0,onChange:k[3]||(k[3]=d=>e.unref(r)(d.name,d.value)),onClear:k[4]||(k[4]=d=>{e.unref(b)(d),e.unref(r)(d,void 0)}),modelValue:e.unref(y)[w.props.name],"onUpdate:modelValue":d=>e.unref(y)[w.props.name]=d,showClean:!0}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),128))])])):e.createCommentVNode("",!0)}}),Hl=["onKeydown"],Gl=["disabled"],Xl={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"},Jl={class:"rounded-2xl border border-slate-300/35 bg-white/95 p-4 shadow-2xl backdrop-blur-sm"},Zl={class:"mb-3 flex items-center justify-between"},vl={class:"text-[15px] font-semibold text-slate-800"},eo={"aria-hidden":"true"},to={class:"flex max-h-80 flex-col gap-1 overflow-y-auto"},lo={key:0,class:"mt-3 flex justify-end"},oo=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(m,{emit:o}){const p=z(),t=m,n=o,l=e.ref({}),y=e.useSlots(),{activeFilter:f,activeFilterCount:r,onFilterChange:b,clearFilter:i,clearAllFilters:u,filtersSlot:c}=P({...t,schema:l.value,slots:y},n),k=e.ref(null),w=e.ref(null),x=e.reactive({open:!1,top:0,left:0}),d=e.computed(()=>x.open),a=e.computed(()=>!!t.disabled),s=e.computed(()=>l.value||{}),g=e.computed(()=>t.title??"Фільтр"),h=e.computed(()=>!!y.trigger),_=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",a.value?"cursor-not-allowed opacity-60":"cursor-pointer"]),D=e.computed(()=>x.open?{position:"absolute",top:`${x.top}px`,left:`${x.left}px`,transform:"translateX(-50%)",zIndex:1e3}:{display:"none"});function V(){x.open=!1}function C(){if(!k.value)return;const F=k.value.getBoundingClientRect();x.top=F.bottom+window.scrollY+8,x.left=F.left+F.width/2+window.scrollX}function S(){x.open=!x.open,x.open&&e.nextTick(C)}function E(){a.value||S()}function N(){x.open&&C()}function A(){u()}return e.onMounted(()=>{window.addEventListener("resize",N),window.addEventListener("scroll",N,!0)}),e.onBeforeUnmount(()=>{window.removeEventListener("resize",N),window.removeEventListener("scroll",N,!0)}),e.watch(()=>t.schema,F=>{if(!F){l.value={};return}if(Array.isArray(F)){const B=F.filter($=>$&&($.name||$.id)).map($=>{const j=$.name||$.id;return[j,{...$,name:j}]});l.value=Object.fromEntries(B);return}l.value=F},{deep:!0,immediate:!0}),e.watch(()=>t.disabled,F=>{F&&V()}),(F,B)=>(e.openBlock(),e.createElementBlock("div",{class:"relative inline-flex",ref_key:"anchor",ref:k},[h.value?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["inline-flex",a.value?"cursor-not-allowed opacity-60 pointer-events-none":"cursor-pointer"]),role:"button",tabindex:"0","data-popover-trigger":"",onClick:e.withModifiers(E,["prevent","stop"]),onKeydown:[e.withKeys(e.withModifiers(E,["prevent","stop"]),["enter"]),e.withKeys(e.withModifiers(E,["prevent","stop"]),["space"])]},[e.renderSlot(F.$slots,"trigger",{toggle:E,open:d.value,disabled:a.value,activeCount:e.unref(r)})],42,Hl)):(e.openBlock(),e.createElementBlock("button",{key:1,class:e.normalizeClass(_.value),type:"button",disabled:a.value,onClick:e.withModifiers(E,["prevent","stop"]),"data-popover-trigger":""},[e.createVNode(de,{class:"h-4 w-4"}),e.unref(r)>0?(e.openBlock(),e.createElementBlock("div",Xl,e.toDisplayString(e.unref(r)),1)):e.createCommentVNode("",!0)],10,Gl)),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[d.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["absolute",typeof F.width=="number"?`min-w-[${F.width+32+(Object.keys(s.value).length>7?20:0)}px]`:"min-w-[268px] "]),style:e.normalizeStyle(D.value),ref_key:"panel",ref:w,onClick:B[4]||(B[4]=e.withModifiers(()=>{},["stop"]))},[e.createElementVNode("div",Jl,[e.createElementVNode("div",Zl,[e.createElementVNode("h3",vl,e.toDisplayString(g.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:V},[e.createElementVNode("span",eo,[e.createVNode(G,{class:"h-4 w-4"})]),B[5]||(B[5]=e.createElementVNode("span",{class:"sr-only"},"Закрити",-1))])]),e.createElementVNode("div",to,[Object.keys(s.value).length?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(Object.entries(s.value),([$,j])=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:$},{ref_for:!0},{...j,layout:"inline"},{width:F.width?F.width:j?.width,class:[F.itemClass,j?.class],"item-class":[F.itemClass,j?.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(f)[$],"onUpdate:modelValue":M=>e.unref(f)[$]=M,onChange:B[0]||(B[0]=M=>e.unref(b)(M.name,M.value)),onClear:B[1]||(B[1]=M=>{e.unref(i)(M),e.unref(b)(M,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(c),($,j)=>(e.openBlock(),e.createBlock(L,e.mergeProps({key:"slot-"+j,ref_for:!0},{...$.props,layout:"inline"},{class:[F.itemClass,$.props?.class],"item-class":[F.itemClass,$.props?.itemClass].filter(Boolean).join(" ")||void 0,cleanable:!0,modelValue:e.unref(f)[$.props.name],"onUpdate:modelValue":M=>e.unref(f)[$.props.name]=M,onChange:B[2]||(B[2]=M=>e.unref(b)(M.name,M.value)),onClear:B[3]||(B[3]=M=>{e.unref(i)(M),e.unref(b)(M,void 0)})}),null,16,["class","item-class","modelValue","onUpdate:modelValue"]))),128))]),e.unref(r)>0?(e.openBlock(),e.createElementBlock("div",lo,[e.createElementVNode("button",{type:"button",class:e.normalizeClass([F.itemClass,"text-sm font-semibold text-blue-600 transition-colors hover:text-blue-700 focus:outline-none"]),onClick:A},e.toDisplayString(e.unref(p)("filter.clear")),3)])):e.createCommentVNode("",!0)])],6)):e.createCommentVNode("",!0)]))],512))}}),Y=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(m,{expose:o,emit:p}){const t=m,n=e.ref(r(t.value??{}));e.watch(()=>t.value,async d=>{n.value=r(d??{}),(!d||Object.keys(d).length===0)&&(await e.nextTick(),y.value?.clearAllFilters?.(!0))},{deep:!0,immediate:!0});const l=p,y=e.ref(),f=e.useSlots();function r(d){if(Array.isArray(d))return d.map(a=>r(a));if(d!==null&&typeof d=="object"){const a=e.toRaw(d),s={};for(const g in a)s[g]=r(a[g]);return s}return d}function b(d,a){a!==void 0?n.value={...n.value,[d]:a}:delete n.value[d],l("change",{data:r(n.value),name:d,value:r(a)})}function i(d){delete n.value[d],l("clear",{data:r(n.value),name:d}),l("change",{data:r(n.value),name:d,value:null})}function u(){n.value={},l("clear",{data:r(n.value),name:"ALL"}),l("change",{data:r(n.value),name:"ALL",value:null})}const c=e.ref({});function k(){switch(t.view){case"inline":return me;case"vertical":return Ql;case"popover":return fe;case"popover-inline":return oo;default:return me}}e.watch(()=>t.schema,d=>{if(!d){c.value={};return}if(Array.isArray(d)&&!d.length){c.value={};return}Array.isArray(d)?c.value=d.filter(a=>a.type).reduce((a,s)=>(Object.assign(s,{name:s.id||s.name,type:{datepicker:"date"}[s.type.toLowerCase()]||s.type.toLowerCase(),label:s.label||s.ua}),a[s.name]=s,s.data&&!s.api&&!s.options&&Object.assign(s,{api:`/api/suggest/${s.data}`}),a),{}):(Object.entries(d).forEach(([a,s])=>{Object.assign(s,{name:a||s.name||s.id,type:s.type.toLowerCase()})}),c.value={...d})},{immediate:!0,deep:!0});function w(d){y.value.clearFilter(d),i(d)}function x(){y.value.clearAllFilters(),u()}return e.watch(()=>n.value,d=>{if(t.history){const a=new URL(window.location.href),s=new URLSearchParams(window.location.search);Object.keys(d).length>0?s.set("filter",Object.entries(d).filter(([,g])=>g).map(([g,h])=>`${g}=${h}`).join("|")):s.delete("filter"),a.search=decodeURI(s.toString()),window.history.pushState({},"",a)}}),o({clearAllFilters:x,clearFilter:w}),(d,a)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(k()),e.mergeProps(t,{schema:c.value,onChange:a[0]||(a[0]=s=>b(s.name,s.value)),onClear:a[1]||(a[1]=s=>i(s.name)),onClearAll:u,ref_key:"filterRef",ref:y}),e.createSlots({default:e.withCtx(()=>[e.renderSlot(d.$slots,"default")]),_:2},[e.unref(f).trigger?{name:"trigger",fn:e.withCtx(s=>[e.renderSlot(d.$slots,"trigger",e.normalizeProps(e.guardReactiveProps(s)))]),key:"0"}:void 0]),1040,["schema"]))}});Y.install=function(o){o.component("Filter",Y),o.component("FilterField",L)},T.Filter=Y,T.FilterField=L,T.default=Y,Object.defineProperties(T,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
|