@opengis/table 0.0.14 → 0.0.16
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.mjs +847 -0
- package/dist/index.umd.js +1 -0
- package/package.json +47 -4
- package/index.mjs +0 -864
- package/index.umd.js +0 -5
- /package/{index.css → dist/index.css} +0 -0
package/index.umd.js
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
(function(y,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(y=typeof globalThis<"u"?globalThis:y||self,e(y.filter={},y.Vue))})(this,function(y,e){"use strict";/*!
|
|
2
|
-
* vue-router v4.5.1
|
|
3
|
-
* (c) 2025 Eduardo San Martin Morote
|
|
4
|
-
* @license MIT
|
|
5
|
-
*/var U;(function(d){d.pop="pop",d.push="push"})(U||(U={}));var q;(function(d){d.back="back",d.forward="forward",d.unknown=""})(q||(q={})),Symbol(process.env.NODE_ENV!=="production"?"navigation failure":"");var J;(function(d){d[d.aborted=4]="aborted",d[d.cancelled=8]="cancelled",d[d.duplicated=16]="duplicated"})(J||(J={})),Symbol(process.env.NODE_ENV!=="production"?"router view location matched":""),Symbol(process.env.NODE_ENV!=="production"?"router view depth":"");const pe=Symbol(process.env.NODE_ENV!=="production"?"router":"");Symbol(process.env.NODE_ENV!=="production"?"route location":""),Symbol(process.env.NODE_ENV!=="production"?"router view location":"");function ue(){return e.inject(pe)}const K=e.defineComponent({name:"NumberFormat",__name:"NumberFormat",props:{value:{},row:{},column:{}},setup(d){const o=d,r=e.computed(()=>o.value===null||o.value===void 0?"":typeof o.value=="number"?o.value.toFixed(2):Intl.NumberFormat("uk-UA",{maximumFractionDigits:2}).format(Number(o.value)));return(t,s)=>(e.openBlock(),e.createElementBlock("span",null,e.toDisplayString(r.value),1))}}),G=e.defineComponent({name:"DateFormat",__name:"DateFormat",props:{value:{},row:{},column:{}},setup(d){const o=d,r=e.computed(()=>{if(!o.value)return"";try{return new Date(o.value).toLocaleDateString()}catch{return o.value}});return(t,s)=>(e.openBlock(),e.createElementBlock("span",null,e.toDisplayString(r.value),1))}}),Q=e.defineComponent({name:"TextFormat",__name:"TextFormat",props:{value:{},row:{},column:{}},setup(d){const o=d,{value:r}=o,t=e.computed(()=>Array.isArray(r)?r.map(s=>s.text||s).join(","):r?.text||r);return(s,i)=>(e.openBlock(),e.createElementBlock("span",null,e.toDisplayString(t.value),1))}}),X=((d,o)=>{const r=d.__vccOpts||d;for(const[t,s]of o)r[t]=s;return r})(e.defineComponent({name:"BadgeFormat",__name:"BadgeFormat",props:{value:{},row:{},column:{}},setup(d){const o=d,r=e.computed(()=>{const i=String(o.value||"").toLowerCase(),c="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium";return i.includes("success")||i.includes("active")||i.includes("completed")?`${c} bg-green-100 text-green-800`:i.includes("error")||i.includes("failed")||i.includes("inactive")?`${c} bg-red-100 text-red-800`:i.includes("warning")||i.includes("pending")?`${c} bg-yellow-100 text-yellow-800`:i.includes("info")||i.includes("processing")?`${c} bg-blue-100 text-blue-800`:o.value?.color&&!/^#([0-9a-f]{3}|[0-9a-f]{6})$/i.test(o.value.color)?`${c} bg-${o.value.color}-100 text-${o.value.color}-800`:`${c} bg-gray-100 text-gray-800`});function t(i,c=1){const h=parseInt(i.slice(1,3),16),_=parseInt(i.slice(3,5),16),C=parseInt(i.slice(5,7),16);return`rgba(${h}, ${_}, ${C}, ${c})`}const s=e.computed(()=>{const i={minWidth:"60px",textAlign:"center",display:"inline-block"};return/^#([0-9a-f]{3}|[0-9a-f]{6})$/i.test(o.value?.color)?{...i,backgroundColor:t(o.value.color,.1),color:t(o.value.color,.8)}:i});return(i,c)=>(e.openBlock(),e.createElementBlock("span",{class:e.normalizeClass(["badge",r.value]),style:e.normalizeStyle(s.value)},e.toDisplayString(i.value?.text||i.value),7))}}),[["__scopeId","data-v-28700c64"]]),fe={class:"flex flex-wrap gap-1"},Y=e.defineComponent({name:"ArrayFormat",__name:"ArrayFormat",props:{value:{},row:{},column:{}},setup(d){const o=d,r=e.computed(()=>o.value?Array.isArray(o.value)?o.value:[o.value]:[]),t=s=>s?typeof s=="object"&&s.name?s.name:typeof s=="string"||typeof s=="number"?String(s):JSON.stringify(s):"";return(s,i)=>(e.openBlock(),e.createElementBlock("div",fe,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(r.value,(c,h)=>(e.openBlock(),e.createElementBlock("span",{key:h,class:"inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-blue-100 text-blue-800 hover:bg-blue-200 transition-colors"},e.toDisplayString(t(c)),1))),128))]))}}),ge=["href","target"],Z=e.defineComponent({__name:"LinkFormat",props:{href:{default:""},target:{default:"_self"},onClick:{type:Function,default:void 0},value:{},row:{},column:{}},setup(d){const o=d,r=e.computed(()=>typeof o.value=="string"||typeof o.value=="number"?o.value:o.value?.text||o.value?.label||"Link"),t=e.computed(()=>o.href?o.href:typeof o.value=="object"&&o.value?.href?o.value.href:""),s=e.computed(()=>o.target?o.target:typeof o.value=="object"&&o.value?.target?o.value.target:"_self"),i=e.computed(()=>"text-blue-600 hover:text-blue-800 dark:text-blue-400 dark:hover:text-blue-300 underline cursor-pointer"),c=h=>{o.onClick&&o.row&&(h.preventDefault(),o.onClick(o.row,o.value))};return(h,_)=>t.value?(e.openBlock(),e.createElementBlock("a",{key:0,href:t.value,target:s.value,class:e.normalizeClass(i.value),onClick:c},e.toDisplayString(r.value),11,ge)):(e.openBlock(),e.createElementBlock("button",{key:1,type:"button",class:e.normalizeClass(i.value),onClick:c},e.toDisplayString(r.value),3))}}),ee=e.defineComponent({name:"TextFormat",__name:"SelectFormat",props:{value:{},row:{},column:{}},setup(d){const o=d,{value:r}=o,t=e.computed(()=>Array.isArray(r)?r.map(s=>s.text||s).filter((s,i)=>i<2).join(", ")+(r.length>2?` +${r.length-2}`:""):r?.text||r);return(s,i)=>(e.openBlock(),e.createElementBlock("span",null,e.toDisplayString(t.value),1))}}),j={number:K,date:G,text:Q,badge:X,array:Y,select:ee,link:Z},ye={class:"flex items-center space-x-4"},be={class:"font-medium"},he={class:"font-medium"},ke={class:"font-medium"},xe={class:"flex items-center space-x-2"},Ce=["disabled"],_e={class:"flex items-center space-x-1"},Be=["onClick"],we=["disabled"],A=e.defineComponent({name:"Pagination",__name:"Pagination",props:{page:{},limit:{},total:{},theme:{default:"light"},size:{default:"medium"}},emits:["update:page"],setup(d,{emit:o}){const r=d,t=e.computed(()=>({small:{text:"text-xs",button:"px-2 h-7 text-xs min-w-[28px] flex items-center justify-center",icon:"w-3.5 h-3.5"},medium:{text:"text-sm",button:"px-3 h-9 text-sm min-w-[36px] flex items-center justify-center",icon:"w-4 h-4"},large:{text:"text-base",button:"px-4 h-11 text-base min-w-[44px] flex items-center justify-center",icon:"w-5 h-5"}})[r.size]),s=e.computed(()=>{const{theme:u}=r;return u==="dark"?{container:"bg-gray-900 border-gray-700",text:"text-gray-300",button:"text-gray-300 bg-gray-800 border-gray-600 hover:bg-gray-700",buttonDisabled:"text-gray-500 bg-gray-800",buttonActive:"bg-blue-600 text-white",ellipsis:"text-gray-400"}:u==="light"?{container:"bg-white border-gray-200",text:"text-gray-700",button:"text-gray-700 bg-white border-gray-300 hover:bg-gray-50",buttonDisabled:"text-gray-400 bg-gray-100",buttonActive:"bg-blue-600 text-white",ellipsis:"text-gray-500"}:{container:"bg-white dark:bg-gray-900 border-gray-200 dark:border-gray-700",text:"text-gray-700 dark:text-gray-300",button:"text-gray-700 dark:text-gray-300 bg-white dark:bg-gray-800 border-gray-300 dark:border-gray-600 hover:bg-gray-50 dark:hover:bg-gray-700",buttonDisabled:"text-gray-400 dark:text-gray-500 bg-gray-100 dark:bg-gray-800",buttonActive:"bg-blue-600 text-white",ellipsis:"text-gray-500 dark:text-gray-400"}}),i=o,c=e.computed(()=>Math.ceil(r.total/r.limit)),h=e.computed(()=>r.total===0?0:(r.page-1)*r.limit+1),_=e.computed(()=>Math.min(r.page*r.limit,r.total)),C=e.computed(()=>{const u=[];if(c.value<=7)for(let g=1;g<=c.value;g+=1)u.push(g);else{u.push(1),r.page>4&&u.push("...");const g=Math.max(2,r.page-1),E=Math.min(c.value-1,r.page+1);for(let B=g;B<=E;B+=1)B!==1&&B!==c.value&&u.push(B);r.page<c.value-3&&u.push("..."),c.value>1&&u.push(c.value)}return u}),x=u=>{u>=1&&u<=c.value&&u!==r.page&&i("update:page",u)};return(u,f)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["flex items-center justify-between py-3 border-t",s.value.container])},[e.createElementVNode("div",ye,[e.createElementVNode("div",{class:e.normalizeClass(["flex items-center text-sm",s.value.text,t.value.text])},[e.createElementVNode("span",null,[f[2]||(f[2]=e.createTextVNode(" Показано ",-1)),e.createElementVNode("span",be,e.toDisplayString(h.value),1),f[3]||(f[3]=e.createTextVNode(" до ",-1)),e.createElementVNode("span",he,e.toDisplayString(_.value),1),f[4]||(f[4]=e.createTextVNode(" з ",-1)),e.createElementVNode("span",ke,e.toDisplayString(u.total),1),f[5]||(f[5]=e.createTextVNode(" результатів ",-1))])],2)]),e.createElementVNode("div",xe,[e.createElementVNode("button",{onClick:f[0]||(f[0]=g=>x(u.page-1)),disabled:u.page<=1,class:e.normalizeClass(["relative font-medium rounded-md",t.value.button,u.page<=1?s.value.buttonDisabled:s.value.button])},[(e.openBlock(),e.createElementBlock("svg",{class:e.normalizeClass(t.value.icon),fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},f[6]||(f[6]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M15 19l-7-7 7-7"},null,-1)]),2))],10,Ce),e.createElementVNode("div",_e,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(C.value,g=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:g},[g==="..."?(e.openBlock(),e.createElementBlock("span",{key:0,class:e.normalizeClass(["font-medium",t.value.button,s.value.ellipsis])}," ... ",2)):(e.openBlock(),e.createElementBlock("button",{key:1,onClick:E=>x(g),class:e.normalizeClass(["relative font-medium rounded-md",t.value.button,g===u.page?s.value.buttonActive:s.value.button])},e.toDisplayString(g),11,Be))],64))),128))]),e.createElementVNode("button",{onClick:f[1]||(f[1]=g=>x(u.page+1)),disabled:u.page>=c.value,class:e.normalizeClass(["relative font-medium rounded-md",t.value.button,u.page>=c.value?s.value.buttonDisabled:s.value.button])},[(e.openBlock(),e.createElementBlock("svg",{class:e.normalizeClass(t.value.icon),fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},f[7]||(f[7]=[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M9 5l7 7-7 7"},null,-1)]),2))],10,we)])],2))}}),Ee={key:0,class:"text-center py-8"},$e={class:"inline-flex items-center space-x-2"},Ne={key:2,class:"overflow-x-auto"},Ve=["checked","indeterminate"],Se=["onClick"],De={class:"flex items-center justify-between"},ve={key:0,class:"ml-1 text-xs"},ze={key:1},Fe=["onClick"],Te=["checked","onChange"],je=["onClick"],$=e.defineComponent({name:"DataTable",__name:"DataTable",props:{rows:{default:()=>[]},columns:{default:()=>[]},api:{},tableStyle:{default:"min-width: 50rem"},tableClass:{default:"min-w-full divide-y divide-gray-200 dark:divide-gray-700"},tableClassWrapper:{},size:{default:"medium"},theme:{default:"light"},loading:{type:Boolean,default:!1},classTr:{default:""},classTd:{default:""},classTh:{default:""},classLink:{default:""},selectable:{type:Boolean,default:!1},selectedRows:{default:()=>[]},limit:{default:10},page:{default:1},total:{default:0},showPagination:{type:Boolean,default:!0},sortable:{type:Boolean,default:!1},clickable:{type:Boolean,default:!1},getCellData:{type:Function,default:void 0}},emits:["update:page","update:selectedRows","row-click","sort"],setup(d,{emit:o}){const r=ue(),t=d,s=o,i=e.ref(t.selectedRows||[]),c=e.ref([]),h=e.ref([]),_=e.ref([]),C=e.ref(!1),x=e.ref(null),u=e.useSlots(),f=e.computed(()=>u.action),g=e.computed(()=>{if(t.api)return h.value;if(t.sortable&&c.value.length>0){const a=[...t.rows];return a.sort((m,n)=>{for(const p of c.value){if(!p.direction)return 0;const l=m[p.field],b=n[p.field];if(l==null)return 1;if(b==null)return-1;let w=0;typeof l=="string"&&typeof b=="string"?w=l.localeCompare(b):l<b?w=-1:l>b?w=1:w=0;const T=p.direction==="desc"?-w:w;if(T!==0)return T}return 0}),a}return t.rows});e.watch(()=>t.selectedRows,a=>{i.value=a||[]});const E=a=>i.value.some(m=>m===a),B=a=>{const m=i.value.findIndex(n=>n===a);m>-1?i.value.splice(m,1):i.value.push(a),s("update:selectedRows",[...i.value])},I=e.computed(()=>g.value.length>0&&i.value.length===g.value.length),ne=e.computed(()=>i.value.length>0&&i.value.length<g.value.length),N=()=>{I.value?i.value=[]:i.value=[...g.value],s("update:selectedRows",[...i.value])},L=a=>{if(!t.sortable)return;const m=c.value.findIndex(p=>p.field===a);if(m>=0){const p=c.value[m];p.direction==="asc"?p.direction="desc":p.direction==="desc"&&c.value.splice(m,1)}else c.value.unshift({field:a,direction:"asc"});const n=c.value.filter(p=>p.direction).map(p=>({name:p.field,asc:p.direction==="asc"}));s("sort",n),t.api&&v()},Ge=a=>c.value.find(n=>n.field===a)?.direction==="asc",Qe=a=>{const m=c.value.find(n=>n.field===a);if(!m)return"↑↓";switch(m.direction){case"asc":return"↑";case"desc":return"↓";default:return"↕️"}},R=a=>t.sortable&&a.sortable!==!1,Xe=a=>{t.clickable&&s("row-click",a)},V=(a,m)=>{const n=m[a.name];if(t.getCellData||a.getCellData){const p=a.getCellData||t.getCellData;if(p){const l={name:a.name,row:m,value:n};return p(l)}}return["_data","_text"].map(p=>{const l=`${a.name}${p}`;return m[l]?m[l]:null}).find(p=>p)||n},le=a=>a.width?a.width==="w-full"?"w-full":typeof a.width=="string"?a.width:typeof a.width=="number"?`w-${a.width}`:"":"",P=e.ref(t.page),re=e.ref(t.limit),M=e.ref(t.total),S=e.ref(1),O=e.ref(10),D=e.ref(0),se=e.computed(()=>t.api?S.value:P.value),ie=e.computed(()=>t.api?O.value:re.value),ce=e.computed(()=>t.api?D.value:M.value),k=e.computed(()=>{const{theme:a}=t;return a==="dark"?{container:"dark",loading:"text-gray-400",error:"text-red-400",thead:"bg-gray-800",th:"text-gray-300",thHover:"hover:bg-gray-700",tbody:"bg-gray-900 divide-gray-700",tr:"hover:bg-gray-800",td:"text-gray-300",empty:"text-gray-400",checkbox:"border-gray-600 bg-gray-700 text-blue-400"}:a==="light"?{container:"",loading:"text-gray-500",error:"text-red-500",thead:"bg-gray-50",th:"text-gray-500",thHover:"hover:bg-gray-100",tbody:"bg-white divide-gray-200",tr:"hover:bg-gray-50",td:"text-gray-900",empty:"text-gray-500",checkbox:"border-gray-300 bg-white text-blue-600"}:{container:"",loading:"text-gray-500 dark:text-gray-400",error:"text-red-500 dark:text-red-400",thead:"bg-gray-50 dark:bg-gray-800",th:"text-gray-500 dark:text-gray-300",thHover:"hover:bg-gray-100 dark:hover:bg-gray-700",tbody:"bg-white dark:bg-gray-900 divide-gray-200 dark:divide-gray-700",tr:"hover:bg-gray-50 dark:hover:bg-gray-800",td:"text-gray-900 dark:text-gray-300",empty:"text-gray-500 dark:text-gray-400",checkbox:"border-gray-300 dark:border-gray-600 bg-white dark:bg-gray-700 text-blue-600 dark:text-blue-400"}});e.watch(()=>t.page,a=>{P.value=a}),e.watch(()=>t.limit,a=>{re.value=a}),e.watch(()=>t.total,a=>{M.value=a});async function v(){if(t.api){C.value=!0,x.value=null;try{const a=new URL(t.api,window.location.origin);if(a.searchParams.set("page",se.value.toString()),a.searchParams.set("limit",ie.value.toString()),c.value.length>0){const p=c.value.filter(l=>l.direction).map(l=>`${l.field}:${l.direction}`).join(",");p&&a.searchParams.set("sort",p)}const m=await fetch(a.toString());if(!m.ok)throw new Error(`HTTP error! status: ${m.status}`);const n=await m.json();n.rows&&Array.isArray(n.rows)&&(h.value=n.rows),n.columns&&Array.isArray(n.columns)&&(_.value=n.columns),n.total!==void 0&&(t.api?D.value=n.total:M.value=n.total)}catch(a){x.value=a instanceof Error?a.message:"Failed to fetch data",console.error("Error fetching data:",a)}finally{C.value=!1}}}const Ye=a=>{t.api?S.value=a:(P.value=a,s("update:page",a)),t.api&&v()},Ze=e.computed(()=>t.showPagination&&ce.value>0),z=e.computed(()=>({small:{header:"px-3 py-2 text-xs",cell:"px-3 py-2 text-xs"},medium:{header:"px-6 py-3 text-xs",cell:"px-6 py-4 text-sm"},large:{header:"px-8 py-4 text-sm",cell:"px-8 py-6 text-base"}})[t.size]);e.onMounted(()=>{t.api&&(t.page&&(S.value=t.page),t.limit&&(O.value=t.limit),t.total&&(D.value=t.total),v())}),e.watch(()=>t.api,a=>{a&&(S.value=t.page||1,O.value=t.limit||10,D.value=t.total||0,v())});const et=e.computed(()=>t.api?_.value:t.columns),H=e.ref([]),F=e.ref({});e.provide("registerColumn",(a,m)=>{H.value.push(a),m&&a.slotName&&(F.value[a.name]=m)});const de=e.computed(()=>{const a=et.value||[],m=[],n=u.default?.();if(n){const p=n.filter(l=>l.type?.name==="Column"||l.type==="Column"||l.type&&typeof l.type=="object"&&l.type.name==="Column").map(l=>{const b=l.props||l.componentProps||{},w=b.field||b.name||"",T=b.header||b.label||"",me=l.children&&l.children.body,W={name:w,ua:T,format:b.format||"text",slotName:me?"body":void 0,...b};return me&&W.name&&(F.value[W.name]=l.children.body),W});m.push(...p)}if(H.value.length>0&&m.push(...H.value),m.length>0){const p=[],l=new Set(m.map(b=>b.name));return a.forEach(b=>{l.has(b.name)||p.push(b)}),p.push(...m),console.log("Combined columns:",{default:a.length,custom:m.length,combined:p.length}),p}return a.length>0?(console.log("Using default columns:",a.length),a):[]}),tt=(a="text")=>j[a]||j.text;return(a,m)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["w-full",k.value.container])},[C.value||t.loading?(e.openBlock(),e.createElementBlock("div",Ee,[e.createElementVNode("div",$e,[m[0]||(m[0]=e.createElementVNode("div",{class:"animate-spin rounded-full h-6 w-6 border-b-2 border-blue-600"},null,-1)),e.createElementVNode("span",{class:e.normalizeClass(k.value.loading)},"Loading...",2)])])):x.value?(e.openBlock(),e.createElementBlock("div",{key:1,class:e.normalizeClass(["text-center py-8",k.value.error])},e.toDisplayString(x.value),3)):!t.loading&&g.value.length>0?(e.openBlock(),e.createElementBlock("div",Ne,[e.createElementVNode("div",{class:e.normalizeClass(a.tableClassWrapper?a.tableClassWrapper:"relative w-full overflow-auto")},[e.createElementVNode("table",{class:e.normalizeClass(a.tableClass),style:e.normalizeStyle(a.tableStyle)},[e.createElementVNode("thead",{class:e.normalizeClass(k.value.thead)},[e.createElementVNode("tr",null,[a.selectable?(e.openBlock(),e.createElementBlock("th",{key:0,class:e.normalizeClass(["text-left font-medium uppercase tracking-wider",k.value.th,z.value.header,t.classTh,"w-12"])},[e.createElementVNode("input",{type:"checkbox",checked:I.value,indeterminate:ne.value,onChange:N,class:e.normalizeClass(["h-4 w-4 focus:ring-blue-500 rounded",k.value.checkbox])},null,42,Ve)],2)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(de.value.filter(n=>!n.hidden),n=>(e.openBlock(),e.createElementBlock("th",{key:n.name,class:e.normalizeClass(["text-left font-medium uppercase tracking-wider",k.value.th,z.value.header,t.classTh,n.align?`text-${n.align}`:"",R(n)?["cursor-pointer",k.value.thHover]:"",le(n)]),onClick:p=>R(n)?L(n.name):void 0},[e.createElementVNode("div",De,[e.createElementVNode("span",null,e.toDisplayString(n.ua||n.header||n.name),1),R(n)?(e.openBlock(),e.createElementBlock("span",ve,[e.renderSlot(a.$slots,"sort",{asc:Ge(n.name)},()=>[e.createTextVNode(e.toDisplayString(Qe(n.name)),1)])])):e.createCommentVNode("",!0)])],10,Se))),128)),f.value?(e.openBlock(),e.createElementBlock("th",ze,"Дії")):e.createCommentVNode("",!0)])],2),e.createElementVNode("tbody",{class:e.normalizeClass(k.value.tbody)},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(g.value,(n,p)=>(e.openBlock(),e.createElementBlock("tr",{key:p,class:e.normalizeClass([k.value.tr,t.classTr,t.clickable?"cursor-pointer":""]),onClick:l=>t.clickable?Xe(n):void 0},[a.selectable?(e.openBlock(),e.createElementBlock("td",{key:0,class:e.normalizeClass(["whitespace-nowrap",k.value.td,z.value.cell,t.classTd,"w-12"])},[e.createElementVNode("input",{type:"checkbox",checked:E(n),onChange:l=>B(n),class:e.normalizeClass(["h-4 w-4 focus:ring-blue-500 rounded",k.value.checkbox])},null,42,Te)],2)):e.createCommentVNode("",!0),(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(de.value.filter(l=>!l.hidden),l=>(e.openBlock(),e.createElementBlock("td",{key:l.name,class:e.normalizeClass(["whitespace-nowrap",k.value.td,z.value.cell,t.classTd,l.align?`text-${l.align}`:"",le(l)])},[l.action&&f.value?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(f.value),{key:0,row:n,value:V(l,n)},null,8,["row","value"])):l.slotName&&F.value[l.name]?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(F.value[l.name]),{key:1,data:n,value:V(l,n),row:n,column:l},null,8,["data","value","row","column"])):l.link?(e.openBlock(),e.createElementBlock("a",{key:2,class:e.normalizeClass(a.classLink||"hover:text-blue-900 cursor-pointer text-blue-700 hover:underline"),onClick:b=>e.unref(r).push(l.link.replace("{id}",n.id))},e.toDisplayString(V(l,n)),11,je)):(e.openBlock(),e.createBlock(e.resolveDynamicComponent(tt(l.format)),{key:3,value:V(l,n),row:n,column:l,href:l.link},null,8,["value","row","column","href"]))],2))),128)),e.createElementVNode("td",null,[f.value?(e.openBlock(),e.createBlock(e.resolveDynamicComponent(f.value),{key:0,row:n},null,8,["row"])):e.createCommentVNode("",!0)])],10,Fe))),128))],2)],6)],2)])):e.createCommentVNode("",!0),Ze.value&&!C.value&&!t.loading&&!x.value?(e.openBlock(),e.createBlock(A,{key:3,page:se.value,limit:ie.value,total:ce.value,theme:t.theme,size:t.size,"onUpdate:page":Ye},null,8,["page","limit","total","theme","size"])):e.createCommentVNode("",!0),!C.value&&!t.loading&&!x.value&&g.value.length===0?(e.openBlock(),e.createElementBlock("div",{key:4,class:e.normalizeClass(["text-center py-8",k.value.empty])}," Дані відсутні ",2)):e.createCommentVNode("",!0)],2))}}),Ae={style:{display:"none"}},te=e.defineComponent({name:"Column",__name:"Column",props:{field:{},name:{},header:{},label:{},format:{},hidden:{type:Boolean},sortable:{type:Boolean},width:{},align:{},slot:{},slotName:{},link:{},action:{type:Boolean},getCellData:{type:Function},suffix:{}},setup(d){const o=d,r=e.useSlots(),t=e.inject("registerColumn");return e.onMounted(()=>{if(t){const{field:s,name:i,header:c,label:h,format:_,slotName:C,link:x,action:u,getCellData:f,suffix:g,...E}=o,N={name:s||i||"",ua:c||h||"",format:_||"text",slotName:C||(r.body?"body":void 0),link:x,action:u,getCellData:f,suffix:g,...E};console.log("Registering column:",N);const L=r.body;t(N,L)}}),(s,i)=>(e.openBlock(),e.createElementBlock("div",Ae,[e.renderSlot(s.$slots,"body",{data:{}})]))}}),Ie={class:"mt-4"},Le={class:"text-sm text-gray-600 dark:text-gray-300"},ae=e.defineComponent({__name:"SelectionInfo",props:{selectedRows:{},totalCount:{}},setup(d){const o=d,r=e.computed(()=>o.selectedRows.length);return(t,s)=>(e.openBlock(),e.createElementBlock("div",Ie,[e.createElementVNode("div",Le," Обрано: "+e.toDisplayString(r.value)+" з "+e.toDisplayString(t.totalCount)+" записів ",1)]))}}),Re={class:"mt-4"},Pe={class:"border-b border-gray-200 dark:border-gray-700"},Me={class:"-mb-px flex space-x-8"},Oe=["onClick"],He={class:"mt-4"},We={class:"bg-gray-900 rounded-lg overflow-hidden"},Ue={class:"flex items-center justify-between px-4 py-2 bg-gray-800 border-b border-gray-700"},qe={class:"text-sm text-gray-300"},Je=["onClick"],Ke={class:"p-4 text-sm text-gray-100 overflow-x-auto"},oe=e.defineComponent({__name:"CodeTabs",props:{tabs:{},defaultTab:{default:void 0}},setup(d){const o=d,r=e.ref(o.defaultTab||o.tabs[0]?.id||""),t=async s=>{try{await navigator.clipboard.writeText(s),console.log("Код скопійовано!")}catch(i){console.error("Помилка копіювання:",i)}};return(s,i)=>(e.openBlock(),e.createElementBlock("div",Re,[e.createElementVNode("div",Pe,[e.createElementVNode("nav",Me,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tabs,c=>(e.openBlock(),e.createElementBlock("button",{key:c.id,onClick:h=>r.value=c.id,class:e.normalizeClass(["py-2 px-1 border-b-2 font-medium text-sm transition-colors",r.value===c.id?"border-blue-500 text-blue-600 dark:text-blue-400":"border-transparent text-gray-500 hover:text-gray-700 hover:border-gray-300 dark:text-gray-400 dark:hover:text-gray-300"])},e.toDisplayString(c.label),11,Oe))),128))])]),e.createElementVNode("div",He,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.tabs,c=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:c.id},[e.createElementVNode("div",We,[e.createElementVNode("div",Ue,[e.createElementVNode("span",qe,e.toDisplayString(c.label),1),e.createElementVNode("button",{onClick:h=>t(c.content),class:"text-gray-400 hover:text-white transition-colors",title:"Копіювати код"},i[0]||(i[0]=[e.createElementVNode("svg",{class:"w-4 h-4",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},[e.createElementVNode("path",{"stroke-linecap":"round","stroke-linejoin":"round","stroke-width":"2",d:"M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"})],-1)]),8,Je)]),e.createElementVNode("pre",Ke,[e.createElementVNode("code",null,e.toDisplayString(c.content),1)])])])),[[e.vShow,r.value===c.id]])),128))])]))}});$.install=function(o){o.component("DataTable",$),o.component("Column",te),o.component("Pagination",A),o.component("SelectionInfo",ae),o.component("CodeTabs",oe)},y.ArrayFormat=Y,y.BadgeFormat=X,y.CodeTabs=oe,y.Column=te,y.DataTable=$,y.DateFormat=G,y.LinkFormat=Z,y.NumberFormat=K,y.Pagination=A,y.SelectFormat=ee,y.SelectionInfo=ae,y.TextFormat=Q,y.default=$,y.formatComponents=j,Object.defineProperties(y,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
|
|
File without changes
|