@akshar-technosoft/ui 1.0.5 → 1.0.7

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.
@@ -1,3 +1,3 @@
1
1
  "use client"
2
- import{flexRender as ft,getCoreRowModel as Xo,getFilteredRowModel as Ko,getPaginationRowModel as Jo,getSortedRowModel as Qo,useReactTable as Yo}from"@tanstack/react-table";import{Loader2 as Ut,ChevronUp as bt,ChevronDown as vt,ChevronsUpDown as Zo,MoreHorizontal as ea,MoveRightIcon as ta,PinOffIcon as oa}from"lucide-react";import{Slot as bo}from"radix-ui";import{cva as vo}from"class-variance-authority";import{clsx as go}from"clsx";import{twMerge as fo}from"tailwind-merge";function o(...e){return fo(go(e))}import{jsx as xo}from"react/jsx-runtime";var Ie=vo("inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",{variants:{variant:{default:"bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",destructive:"bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",outline:"border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50",secondary:"bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80",ghost:"hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",link:"text-primary underline-offset-4 hover:underline"},size:{default:"h-9 px-4 py-2 has-[>svg]:px-3",sm:"h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",lg:"h-10 rounded-md px-6 has-[>svg]:px-4",icon:"size-9"}},defaultVariants:{variant:"default",size:"default"}});function b({className:e,variant:t,size:n,asChild:s=!1,...u}){let m=s?bo.Slot:"button";return xo(m,{"data-slot":"button",className:o(Ie({variant:t,size:n,className:e}),"transition-none"),...u})}import{jsx as te}from"react/jsx-runtime";function at({className:e,...t}){return te("div",{"data-slot":"table-container",className:"relative w-full overflow-auto max-h-full",children:te("table",{"data-slot":"table",className:o("w-full caption-bottom text-sm",e),...t})})}function Mt({className:e,...t}){return te("thead",{"data-slot":"table-header",className:o("[&_tr]:border-b",e),...t})}function It({className:e,...t}){return te("tbody",{"data-slot":"table-body",className:o("[&_tr:last-child]:border-0",e),...t})}function _t({className:e,...t}){return te("tfoot",{"data-slot":"table-footer",className:o("bg-muted/50 border-t font-medium [&>tr]:last:border-b-0",e),...t})}function Ce({className:e,...t}){return te("tr",{"data-slot":"table-row",className:o("hover:bg-muted/50 data-[state=selected]:bg-muted border-b transition-colors",e),...t})}function Vt({className:e,...t}){return te("th",{"data-slot":"table-head",className:o("text-foreground h-10 px-2 text-left align-middle font-medium whitespace-nowrap",e),...t})}function _e({className:e,...t}){return te("td",{"data-slot":"table-cell",className:o("p-2 align-middle whitespace-nowrap",e),...t})}import{jsx as Bt}from"react/jsx-runtime";function Ve({className:e,...t}){return Bt("div",{"data-slot":"card",className:o("bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm",e),...t})}function Be({className:e,...t}){return Bt("div",{"data-slot":"card-content",className:o("px-6",e),...t})}import{Tooltip as pe}from"radix-ui";import{jsx as ge,jsxs as ho}from"react/jsx-runtime";function ye({delayDuration:e=0,...t}){return ge(pe.Provider,{"data-slot":"tooltip-provider",delayDuration:e,...t})}function nt({...e}){return ge(ye,{children:ge(pe.Root,{"data-slot":"tooltip",...e})})}function rt({...e}){return ge(pe.Trigger,{"data-slot":"tooltip-trigger",...e})}function it({className:e,sideOffset:t=0,children:n,...s}){return ge(pe.Portal,{children:ho(pe.Content,{"data-slot":"tooltip-content",sideOffset:t,className:o("bg-primary text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance",e),...s,children:[n,ge(pe.Arrow,{className:"bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]"})]})})}import{Search as Ht,RefreshCw as Vo,Download as Bo,Settings2 as Fo,Filter as Ot,ArrowUpDown as Ao,PinOff as Lo,Pin as Go,ChevronDown as Ho}from"lucide-react";import{jsx as Co}from"react/jsx-runtime";function st({className:e,type:t,...n}){return Co("input",{type:t,"data-slot":"input",className:o("file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm","focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]","aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",e),...n})}import{Select as H}from"radix-ui";import{CheckIcon as yo,ChevronDownIcon as Ft,ChevronUpIcon as wo}from"lucide-react";import{jsx as M,jsxs as lt}from"react/jsx-runtime";function Fe({...e}){return M(H.Root,{"data-slot":"select",...e})}function Ae({...e}){return M(H.Value,{"data-slot":"select-value",...e})}function Le({className:e,size:t="default",children:n,...s}){return lt(H.Trigger,{"data-slot":"select-trigger","data-size":t,className:o("border-input data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 dark:hover:bg-input/50 flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...s,children:[n,M(H.Icon,{asChild:!0,children:M(Ft,{className:"size-4 opacity-50"})})]})}function Ge({className:e,children:t,position:n="popper",...s}){return M(H.Portal,{children:lt(H.Content,{"data-slot":"select-content",className:o("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md",n==="popper"&&"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",e),position:n,...s,children:[M(Po,{}),M(H.Viewport,{className:o("p-1",n==="popper"&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1"),children:t}),M(No,{})]})})}function we({className:e,children:t,...n}){return lt(H.Item,{"data-slot":"select-item",className:o("focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2",e),...n,children:[M("span",{className:"absolute right-2 flex size-3.5 items-center justify-center",children:M(H.ItemIndicator,{children:M(yo,{className:"size-4"})})}),M(H.ItemText,{children:t})]})}function Po({className:e,...t}){return M(H.ScrollUpButton,{"data-slot":"select-scroll-up-button",className:o("flex cursor-default items-center justify-center py-1",e),...t,children:M(wo,{className:"size-4"})})}function No({className:e,...t}){return M(H.ScrollDownButton,{"data-slot":"select-scroll-down-button",className:o("flex cursor-default items-center justify-center py-1",e),...t,children:M(Ft,{className:"size-4"})})}import{DropdownMenu as q}from"radix-ui";import{CheckIcon as Do,ChevronRightIcon as on,CircleIcon as an}from"lucide-react";import{jsx as E,jsxs as To}from"react/jsx-runtime";function W({...e}){return E(q.Root,{"data-slot":"dropdown-menu",...e})}function X({...e}){return E(q.Trigger,{"data-slot":"dropdown-menu-trigger",...e})}function K({className:e,sideOffset:t=4,...n}){return E(q.Portal,{children:E(q.Content,{"data-slot":"dropdown-menu-content",sideOffset:t,className:o("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) rounded-md border p-1 shadow-md",e),...n})})}function dt({...e}){return E(q.Group,{"data-slot":"dropdown-menu-group",...e})}function I({className:e,inset:t,variant:n="default",...s}){return E(q.Item,{"data-slot":"dropdown-menu-item","data-inset":t,"data-variant":n,className:o("cursor-pointer focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/20 data-[variant=destructive]:focus:text-destructive data-[variant=destructive]:*:[svg]:!text-destructive [&_svg:not([class*='text-'])]:text-muted-foreground relative flex items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...s})}function Pe({className:e,children:t,checked:n,...s}){return To(q.CheckboxItem,{"data-slot":"dropdown-menu-checkbox-item",className:o("focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),checked:n,...s,children:[E("span",{className:"pointer-events-none absolute left-2 flex size-3.5 items-center justify-center",children:E(q.ItemIndicator,{children:E(Do,{className:"size-4"})})}),t]})}function j({className:e,inset:t,...n}){return E(q.Label,{"data-slot":"dropdown-menu-label","data-inset":t,className:o("px-2 py-1.5 text-sm font-medium data-[inset]:pl-8",e),...n})}function U({className:e,...t}){return E(q.Separator,{"data-slot":"dropdown-menu-separator",className:o("bg-border -mx-1 my-1 h-px",e),...t})}import{useState as Oo}from"react";import{useEffect as Io,useState as ct}from"react";import{Calendar as _o}from"lucide-react";import{format as Ne}from"date-fns";import{Popover as He}from"radix-ui";import{jsx as Oe}from"react/jsx-runtime";function Ee({...e}){return Oe(He.Root,{"data-slot":"popover",...e})}function je({...e}){return Oe(He.Trigger,{"data-slot":"popover-trigger",...e})}function Ue({className:e,align:t="center",sideOffset:n=4,...s}){return Oe(He.Portal,{children:Oe(He.Content,{"data-slot":"popover-content",align:t,sideOffset:n,className:o("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border p-4 shadow-md outline-hidden",e),...s})})}import*as $e from"react";import{ChevronDownIcon as So,ChevronLeftIcon as ko,ChevronRightIcon as Ro}from"lucide-react";import{DayPicker as zo,getDefaultClassNames as At}from"react-day-picker";import{jsx as oe}from"react/jsx-runtime";function Lt({className:e,classNames:t,showOutsideDays:n=!0,captionLayout:s="label",buttonVariant:u="ghost",formatters:m,components:P,...R}){let p=At();return oe(zo,{showOutsideDays:n,className:o("bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent",String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,e),captionLayout:s,formatters:{formatMonthDropdown:h=>h.toLocaleString("default",{month:"short"}),...m},classNames:{root:o("w-fit",p.root),months:o("flex gap-4 flex-col md:flex-row relative",p.months),month:o("flex flex-col w-full gap-4",p.month),nav:o("flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between",p.nav),button_previous:o(Ie({variant:u}),"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",p.button_previous),button_next:o(Ie({variant:u}),"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",p.button_next),month_caption:o("flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)",p.month_caption),dropdowns:o("w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5",p.dropdowns),dropdown_root:o("relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md",p.dropdown_root),dropdown:o("absolute bg-popover inset-0 opacity-0",p.dropdown),caption_label:o("select-none font-medium",s==="label"?"text-sm":"rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5",p.caption_label),table:"w-full border-collapse",weekdays:o("flex",p.weekdays),weekday:o("text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none",p.weekday),week:o("flex w-full mt-2",p.week),week_number_header:o("select-none w-(--cell-size)",p.week_number_header),week_number:o("text-[0.8rem] select-none text-muted-foreground",p.week_number),day:o("relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none",p.day),range_start:o("rounded-l-md bg-accent",p.range_start),range_middle:o("rounded-none",p.range_middle),range_end:o("rounded-r-md bg-accent",p.range_end),today:o("bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none",p.today),outside:o("text-muted-foreground aria-selected:text-muted-foreground",p.outside),disabled:o("text-muted-foreground opacity-50",p.disabled),hidden:o("invisible",p.hidden),...t},components:{Root:({className:h,rootRef:N,...V})=>oe("div",{"data-slot":"calendar",ref:N,className:o(h),...V}),Chevron:({className:h,orientation:N,...V})=>N==="left"?oe(ko,{className:o("size-4",h),...V}):N==="right"?oe(Ro,{className:o("size-4",h),...V}):oe(So,{className:o("size-4",h),...V}),DayButton:Mo,WeekNumber:({children:h,...N})=>oe("td",{...N,children:oe("div",{className:"flex size-(--cell-size) items-center justify-center text-center",children:h})}),...P},...R})}function Mo({className:e,day:t,modifiers:n,...s}){let u=At(),m=$e.useRef(null);return $e.useEffect(()=>{n.focused&&m.current?.focus()},[n.focused]),oe(b,{ref:m,variant:"ghost",size:"icon","data-day":t.date.toLocaleDateString(),"data-selected-single":n.selected&&!n.range_start&&!n.range_end&&!n.range_middle,"data-range-start":n.range_start,"data-range-end":n.range_end,"data-range-middle":n.range_middle,className:o("data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70",u.day,e),...s})}import{jsx as se,jsxs as De}from"react/jsx-runtime";function Gt({value:e,onChange:t,placeholder:n,mode:s,externalSearch:u,onExternalChange:m,onlyExternal:P=!1}){let[R,p]=ct(!1),[h,N]=ct(e),[V,S]=ct(e);Io(()=>{P||S(e)},[e,P]);let J=()=>{P||t(h),S(h),u&&m&&m(h),p(!1)},Q=()=>{N(V),p(!1)},Y=()=>{let f=s==="single"?null:{from:null,to:null};N(f),P||t(f),S(f),u&&m&&m(f),p(!1)},Z=()=>{let f=P?V:e;return f?s==="single"?Ne(f,"PPP"):f.from&&f.to?`${Ne(f.from,"MMM dd")} - ${Ne(f.to,"MMM dd, yyyy")}`:f.from?`From ${Ne(f.from,"MMM dd, yyyy")}`:f.to?`To ${Ne(f.to,"MMM dd, yyyy")}`:n:n},F=f=>{N(s==="single"?f:f||{from:null,to:null})};return De(Ee,{open:R,onOpenChange:p,children:[se(je,{asChild:!0,children:De(b,{variant:"outline",className:o("w-full justify-start text-left font-normal h-9",!Z()&&"text-muted-foreground"),children:[se(_o,{className:"mr-2 h-4 w-4"}),Z()]})}),De(Ue,{className:"w-auto p-0",align:"start",children:[se("div",{className:"p-3",children:se(Lt,{mode:s,selected:h,onSelect:F,numberOfMonths:s==="range"?2:1,className:"rounded-md border",...s==="range"&&{required:!0}})}),De("div",{className:"flex items-center justify-between p-3 border-t",children:[se(b,{variant:"ghost",size:"sm",onClick:Y,children:"Clear"}),De("div",{className:"flex gap-2",children:[se(b,{variant:"outline",size:"sm",onClick:Q,children:"Cancel"}),se(b,{size:"sm",onClick:J,disabled:s==="range"&&(!h?.from||!h?.to),children:"Apply"})]})]})]})]})}import{Fragment as Eo,jsx as c,jsxs as w}from"react/jsx-runtime";function mt({table:e,filters:t=[],globalFilter:n,onGlobalFilterChange:s,enableGlobalFilter:u=!0,onExport:m,onRefresh:P,loading:R=!1,enableColumnVisibility:p=!0,data:h,onClearSorting:N,onClearFilters:V,enableColumnPinning:S=!1,onExternalSearch:J}){let[Q,Y]=Oo({}),Z=()=>e.getAllLeafColumns().filter(r=>r.getCanHide?.()!==!1),F=()=>e.getAllColumns().filter(r=>!e.getAllLeafColumns().includes(r)&&r.columns?.length&&r.columns.some(l=>l.getCanHide?.()!==!1)),f=()=>{let r=new Set(F().flatMap(l=>l.columns?.filter(A=>A.getCanHide?.()!==!1).map(A=>A.id)||[]));return Z().filter(l=>!r.has(l.id))},ke=(r,l)=>l&&r.startsWith(`${l}.`)?r.replace(`${l}.`,"").split("_").map(ze=>ze.slice(1)).join(" "):r.split("_").map(A=>A.charAt(0).toUpperCase()+A.slice(1)).join(" "),xe=(r,l)=>{let A={...Q,[r]:l};Y(A)},Re=()=>{J&&J(Q)},Ke=()=>{Y({}),V(),J&&J({})},ce=r=>e.getColumn(r)?.getFilterValue(),he=(r,l)=>{e.getColumn(r)?.setFilterValue(l)};return c("div",{className:"rounded-xl",children:c("div",{className:"px-2",children:c("div",{className:"flex flex-col gap-6",children:w("div",{className:"flex items-center justify-between",children:[c("div",{className:"flex items-center gap-3",children:t.length>0&&w("div",{className:"flex items-center gap-3 flex-wrap",children:[c("div",{className:"flex items-center gap-2 text-sm font-medium text-muted-foreground",children:c(Ot,{className:"h-4 w-4"})}),t.map(r=>c("div",{className:o("relative min-w-[150px]",r.width),children:r.type==="select"?w(Fe,{value:ce(r.key)??"",onValueChange:l=>{he(r.key,l==="all"?"":l),r.externalSearch&&xe(r.key,l==="all"?"":l)},children:[r.icon&&c("span",{children:c(r.icon,{className:"size-4 absolute left-3 top-1/2 -translate-y-1/2 text-muted-foreground"})}),c(Le,{className:o("h-9 rounded-lg w-full",r.icon&&"pl-9"),children:c(Ae,{placeholder:r.placeholder})}),w(Ge,{className:"rounded-lg",children:[c(we,{value:"all",children:"All"}),r.options?.map(l=>c(we,{value:l.value,children:l.label},l.label))]})]}):r.type==="date"?c(Gt,{value:ce(r.key),onChange:l=>{r.onlyExternal||he(r.key,l)},placeholder:r.placeholder,mode:r.dateMode||"single",externalSearch:r.externalSearch,onlyExternal:r.onlyExternal,onExternalChange:l=>xe(r.key,l)}):w("div",{className:"relative",children:[r.icon&&c("span",{children:c(r.icon,{className:"size-4 absolute left-3 top-1/2 -translate-y-1/2 text-muted-foreground"})}),c(st,{placeholder:r.placeholder,value:ce(r.key)??"",onChange:l=>{he(r.key,l.target.value),r.externalSearch&&xe(r.key,l.target.value)},className:o("h-9 rounded-lg",r.icon&&"pl-9"),type:r.type==="number"?"number":"text"})]})},r.key)),t.some(r=>r.externalSearch)&&w(b,{variant:"default",size:"sm",onClick:Re,className:"rounded-lg",children:[c(Ht,{className:"mr-2 h-4 w-4"}),t.find(r=>r.externalSearch)?.searchButtonText||"Search"]})]})}),w("div",{className:"flex items-center gap-2",children:[u&&w("div",{className:"relative",children:[c(Ht,{className:"absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground"}),c(st,{placeholder:"Global search...",value:n??"",onChange:r=>s(r.target.value),className:"pl-9 max-w-max"})]}),m&&w(b,{variant:"outline",size:"sm",onClick:()=>m(h),className:"rounded-lg",children:[c(Bo,{className:"mr-2 h-4 w-4"}),"Export"]}),p&&w(W,{children:[c(X,{asChild:!0,children:w(b,{variant:"outline",size:"sm",className:"rounded-lg gap-1",children:[c("span",{children:"Columns"}),c(Ho,{className:"h-4 w-4 opacity-50"})]})}),w(K,{align:"end",className:"w-[220px] rounded-lg max-h-[400px] overflow-y-auto",children:[c(j,{className:"px-4 py-2 text-sm font-medium",children:"Toggle Columns"}),c(U,{}),f().length>0&&w(dt,{children:[c(j,{className:"px-4 py-1.5 text-sm font-medium text-muted-foreground",children:"General"}),f().map(r=>c(Pe,{className:"text-sm",checked:r.getIsVisible(),onCheckedChange:l=>r.toggleVisibility(!!l),children:ke(r.id)},r.id))]}),F().map(r=>w(dt,{children:[c(U,{}),c(j,{className:"px-4 py-1.5 text-sm font-medium text-muted-foreground",children:r.id}),r.columns?.filter(l=>l.getCanHide?.()!==!1).map(l=>c(Pe,{className:"text-sm",checked:l.getIsVisible(),onCheckedChange:A=>l.toggleVisibility(!!A),children:ke(l.id,r.id)},l.id))]},r.id))]})]}),w(W,{children:[c(X,{asChild:!0,children:c(b,{variant:"outline",size:"sm",className:"rounded-lg",children:c(Fo,{className:"h-4 w-4"})})}),w(K,{align:"end",className:"w-[200px] rounded-lg",children:[c(j,{children:"Table Settings"}),c(U,{}),w(I,{onClick:N,children:[c(Ao,{className:"mr-2 h-4 w-4"}),"Clear All Sorting"]}),w(I,{onClick:Ke,children:[c(Ot,{className:"mr-2 h-4 w-4"}),"Clear All Filters"]}),S&&w(Eo,{children:[c(U,{}),c(j,{children:"Column Pinning"}),w(I,{onClick:()=>e.setColumnPinning({left:[],right:[]}),children:[c(Lo,{className:"mr-2 h-4 w-4"}),"Reset All Pinning"]}),w(I,{onClick:()=>{let r=Z().filter(l=>l.getCanPin?.()!==!1).map(l=>l.id);e.setColumnPinning({left:[],right:r})},children:[c(Go,{className:"mr-2 h-4 w-4 -rotate-90"}),"Pin All Right"]})]})]})]}),P&&c(b,{variant:"outline",size:"sm",onClick:P,disabled:R,className:"rounded-lg",children:c(Vo,{className:o("h-4 w-4",R&&"animate-spin")})})]})]})})})})}import{jsx as B,jsxs as fe}from"react/jsx-runtime";function ut({table:e,config:t}){return t.enabled?B("div",{className:"rounded-xl",children:B("div",{children:fe("div",{className:"flex items-center justify-between",children:[B("div",{className:"flex items-center gap-6 text-sm text-muted-foreground",children:t.showInfo!==!1&&fe("span",{children:["Showing ",e.getState().pagination.pageIndex*e.getState().pagination.pageSize+1," to"," ",Math.min((e.getState().pagination.pageIndex+1)*e.getState().pagination.pageSize,e.getFilteredRowModel().rows.length)," ","of ",e.getFilteredRowModel().rows.length," entries"]})}),fe("div",{className:"flex items-center gap-4",children:[t.pageSizeOptions&&fe("div",{className:"flex items-center gap-2",children:[B("span",{className:"text-sm font-medium",children:"Rows per page:"}),fe(Fe,{value:`${e.getState().pagination.pageSize}`,onValueChange:n=>e.setPageSize(Number(n)),children:[B(Le,{className:"h-9 w-[70px] rounded-lg",children:B(Ae,{})}),B(Ge,{side:"top",className:"rounded-lg",children:t.pageSizeOptions.map(n=>B(we,{value:`${n}`,children:n},n))})]})]}),fe("div",{className:"flex items-center gap-2",children:[B(b,{variant:"outline",size:"sm",onClick:()=>e.setPageIndex(0),disabled:!e.getCanPreviousPage(),className:"rounded-lg",children:"First"}),B(b,{variant:"outline",size:"sm",onClick:()=>e.previousPage(),disabled:!e.getCanPreviousPage(),className:"rounded-lg",children:"Previous"}),t.showPageNumbers&&B("div",{className:"flex items-center gap-1",children:Array.from({length:Math.min(5,e.getPageCount())},(n,s)=>{let u=e.getState().pagination.pageIndex,m=u+s;return m<1||m>e.getPageCount()?null:B(b,{variant:m===u+1?"default":"outline",size:"sm",className:"size-8 p-0 rounded-lg",onClick:()=>e.setPageIndex(m-1),children:m},m)})}),B(b,{variant:"outline",size:"sm",onClick:()=>e.nextPage(),disabled:!e.getCanNextPage(),className:"rounded-lg",children:"Next"}),B(b,{variant:"outline",size:"sm",onClick:()=>e.setPageIndex(e.getPageCount()-1),disabled:!e.getCanNextPage(),className:"rounded-lg",children:"Last"})]})]})]})})}):null}import{Toggle as jo}from"radix-ui";import{cva as Uo}from"class-variance-authority";import{jsx as qo}from"react/jsx-runtime";var $o=Uo("inline-flex cursor-pointer items-center justify-center gap-2 rounded-md text-sm font-medium hover:bg-muted hover:text-muted-foreground disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 [&_svg]:shrink-0 focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] outline-none transition-[color,box-shadow] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive whitespace-nowrap",{variants:{variant:{default:"bg-transparent",outline:"border border-input bg-transparent shadow-xs hover:bg-accent hover:text-accent-foreground"},size:{sm:"h-7 px-0 min-w-7",default:"h-8 px-1 min-w-8",lg:"h-9 px-2 min-w-10"},bg:{enabled:"data-[state=on]:bg-accent data-[state=on]:text-accent-foreground",disabled:""}},defaultVariants:{variant:"default",size:"default",bg:"enabled"}});function Et({className:e,variant:t,size:n,noBg:s,...u}){return qo(jo.Root,{"data-slot":"toggle",className:o($o({className:e,variant:t,size:n,bg:s?"disabled":"enabled"})),...u})}import{Checkbox as jt}from"radix-ui";import{CheckIcon as Wo}from"lucide-react";import{jsx as pt}from"react/jsx-runtime";function gt({className:e,...t}){return pt(jt.Root,{"data-slot":"checkbox",className:o("peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50",e),...t,children:pt(jt.Indicator,{"data-slot":"checkbox-indicator",className:"flex items-center justify-center text-current transition-none",children:pt(Wo,{className:"size-3.5"})})})}import{useCallback as xt,useEffect as qe,useMemo as aa,useState as le}from"react";import{Fragment as $t,jsx as i,jsxs as D}from"react/jsx-runtime";function na({data:e,columns:t,filters:n=[],pagination:s={enabled:!1},settings:u={},header:m,footer:P,className:R="",maxHeight:p="600px",loading:h=!1,error:N,emptyMessage:V="No data available",onRowSelectionChange:S,onExport:J,onRefresh:Q,onTableReady:Y,children:Z,isRowDisabled:F,isRowSelectable:f,onExternalSearch:ke}){let[xe,Re]=le([]),[Ke,ce]=le([]),[he,r]=le({}),[l,A]=le({}),[ze,Je]=le(""),[Zt,eo]=le([]),[Qe,to]=le(u.enableColumnPinning?{left:[],right:[]}:{}),{enableSorting:Ye=!0,enableFiltering:Ze=!0,enableGlobalFilter:wt=!0,enableColumnVisibility:et=!0,enableRowSelection:z=!0,stickyHeader:oo=!0,toolbar:ao=!1,showSerialNumbers:ie=!0,fixedCheckboxColumn:Me=!0,striped:no=!0,hoverable:ro=!0,compact:Pt=!0,bordered:Nt=!0,fullHeight:io=!1,enableColumnResizing:Dt=!1,enableColumnPinning:L=!0,hideHeader:so=!1,selectionMode:ee="multiple",checkboxColumnPosition:Tt=0}=u,tt=aa(()=>{let g=[...t],x=d=>d.map(v=>{if(v.id==="select"||v.id==="serialNumber")return v;let k={...v,enablePinning:!0};return v.columns&&(k.columns=x(v.columns)),k}),a=x(g),C={id:"select",header:({table:d})=>{if(ee==="single")return null;let v=d.getRowModel().rows.filter(G=>!F?.(G.original)&&(f?f(G.original):!0)),k=v.length>0&&v.every(G=>G.getIsSelected()),O=v.some(G=>G.getIsSelected());return i(gt,{checked:k||O&&"indeterminate",onCheckedChange:G=>{v.forEach(me=>me.toggleSelected(!!G))},"aria-label":"Select all selectable rows"})},cell:({row:d})=>{let v=F?F(d.original):!1,k=f?f(d.original):!0;return i("div",{className:o("flex items-center justify-center",v&&"opacity-50"),children:ee==="multiple"?i(gt,{checked:d.getIsSelected(),onCheckedChange:O=>k&&d.toggleSelected(!!O),"aria-label":"Select row",disabled:v||!k}):i("input",{type:"radio",checked:d.getIsSelected(),onChange:()=>k&&d.toggleSelected(!0),disabled:v||!k,className:"h-4 w-4 rounded-full border-primary text-primary focus:ring-primary"})})},enableSorting:!1,enableHiding:!1,enablePinning:!0,headerAlign:"center",size:ee==="multiple"?40:30};if(z){let d=Tt;d<0&&(d=a.length+d+1),d=Math.max(0,Math.min(d,a.length)),a.splice(d,0,C)}if(ie){let d={id:"serialNumber",header:"No.",cell:({row:v})=>i("div",{className:"text-center font-medium text-muted-foreground",children:v.index+1}),enableSorting:!0,enableHiding:!1,enablePinning:!0,size:60,headerAlign:"center"};a.unshift(d)}return a},[t,ie,z,Me,F,f,ee,Tt]),y=Yo({data:e,columns:tt,onSortingChange:Ye?Re:void 0,onColumnFiltersChange:Ze?ce:void 0,onGlobalFilterChange:wt?Je:void 0,getCoreRowModel:Xo(),getPaginationRowModel:s.enabled?Jo():void 0,getSortedRowModel:Ye?Qo():void 0,getFilteredRowModel:Ze?Ko():void 0,onColumnVisibilityChange:et?r:void 0,onRowSelectionChange:z?A:void 0,onColumnOrderChange:eo,onColumnPinningChange:L?to:void 0,state:{sorting:Ye?xe:void 0,columnFilters:Ze?Ke:void 0,columnVisibility:et?he:void 0,rowSelection:z?l:{},globalFilter:ze,columnOrder:Zt,columnPinning:L?Qe:{}},initialState:{pagination:s.enabled?{pageSize:s.pageSize||10}:void 0,columnPinning:L?{left:[...ie?["serialNumber"]:[],...z?["select"]:[]],right:[]}:void 0},enableRowSelection:z,enableColumnResizing:Dt,enableColumnPinning:L,columnResizeMode:"onChange"});qe(()=>{if(z&&S){let g=y.getFilteredSelectedRowModel().rows.filter(x=>!F?.(x.original)&&(f?f(x.original):!0)).map(x=>x.original);S(g)}},[l,z,S,y,F,f]);let lo=xt(g=>{ee==="single"?(y.resetRowSelection(),g.toggleSelected(!0)):g.toggleSelected()},[ee,y]);qe(()=>{Y&&Y(y)},[y,Y]),qe(()=>{if(z&&S){let g=y.getFilteredSelectedRowModel().rows.map(x=>x.original);S(g)}},[l,z,S,y]),qe(()=>{if(z&&S){let g=y.getFilteredSelectedRowModel().rows.filter(x=>!F?.(x.original)&&(f?f(x.original):!0)).map(x=>x.original);S(g)}},[l,z,S,y,F,f]);let co=xt(()=>{Re([])},[]),mo=xt(()=>{ce([]),Je("")},[]),St=(g,x)=>{if(!L)return;let a=[...ie?["serialNumber"]:[],...z&&Me?["select"]:[]],C={left:[...(Qe.left??[]).filter(d=>a.includes(d))],right:[...Qe.right??[]]};x===!1?(C.left=C.left.filter(d=>d!==g),C.right=C.right.filter(d=>d!==g)):x==="right"?(C.left=C.left.filter(d=>d!==g),C.right.includes(g)||C.right.push(g)):x==="left"&&(C.right=C.right.filter(d=>d!==g),!C.left.includes(g)&&!a.includes(g)&&C.left.push(g)),y.setColumnPinning(C)},uo=()=>i(Mt,{className:o(oo&&"sticky top-0 bg-sidebar z-20"),children:y.getHeaderGroups().map((g,x)=>i(Ce,{className:"hover:bg-transparent",children:g.headers.map((a,C)=>{let d=a.depth===0&&a.colSpan>1,v=L&&(a.column.getIsPinned()==="left"||a.column.id==="serialNumber"||a.column.id==="select"&&z),k=L&&a.column.getIsPinned()==="right",O=a.column.getCanSort(),G=L&&a.column.columnDef.enablePinning!==!1,me=a.column.id==="serialNumber",ot=a.column.id==="select",zt=me||ot&&Me,ue=a.column.columnDef.headerAlign||"left",po={left:"justify-start",center:"justify-center",right:"justify-end"}[ue];return D(Vt,{colSpan:a.colSpan,className:o("font-semibold text-foreground bg-sidebar group px-0",!Pt&&"py-2",Nt&&C<g.headers.length-1&&"border-r","relative",v&&"sticky left-0 z-15 bg-sidebar",k&&"sticky right-0 z-15 bg-sidebar",(me||ot)&&"sticky left-0 z-15 bg-sidebar",d?"text-center":"text-left"),style:{width:a.getSize()!==150?a.getSize():"auto",minWidth:a.getSize()!==150?a.getSize():"auto",...v&&{left:me?0:ot?ie&&y.getColumn("serialNumber")?.getSize()||0:kt(a.column)},...k&&{right:Rt(a.column)},...me&&{left:0}},children:[d?i("div",{className:"flex items-center justify-center",children:ft(a.column.columnDef.header,a.getContext())}):D("div",{className:o("relative flex items-center w-full px-2",po),children:[D("div",{className:"flex items-center gap-1",children:[O&&ue==="right"&&i("span",{className:"ml-1 order-2",children:a.column.getIsSorted()&&{asc:i(bt,{className:"h-4 w-4"}),desc:i(vt,{className:"h-4 w-4"})}[a.column.getIsSorted()]}),a.isPlaceholder?null:ft(a.column.columnDef.header,a.getContext()),O&&ue!=="right"&&a.column.getIsSorted()&&i("span",{className:"ml-1 order-2",children:a.column.getIsSorted()&&{asc:i(bt,{className:"h-4 w-4"}),desc:i(vt,{className:"h-4 w-4"})}[a.column.getIsSorted()]})]}),(O||G&&!zt)&&D(W,{children:[i(X,{asChild:!0,className:o("absolute",ue==="left"&&"right-1",ue==="center"&&"right-1",ue==="right"&&"left-1"),children:i(Et,{variant:"default",size:"sm",noBg:!0,tabIndex:-1,className:"opacity-0 group-hover:opacity-70 hover:opacity-100 data-[state=open]:opacity-100",children:i(ea,{className:"h-4 w-4"})})}),D(K,{align:"end",className:"w-48",children:[O&&D($t,{children:[i(j,{children:"Sorting"}),D(I,{onClick:()=>a.column.toggleSorting(!1),children:[i(bt,{className:"mr-2 h-4 w-4"}),"Sort Ascending"]}),D(I,{onClick:()=>a.column.toggleSorting(!0),children:[i(vt,{className:"mr-2 h-4 w-4"}),"Sort Descending"]}),D(I,{onClick:()=>a.column.clearSorting(),disabled:!a.column.getIsSorted(),children:[i(Zo,{className:"mr-2 h-4 w-4"}),"Clear Sort"]}),i(U,{})]}),G&&!zt&&D($t,{children:[i(j,{children:"Pin Column"}),D(I,{onClick:()=>St(a.column.id,"right"),disabled:a.column.getIsPinned()==="right",children:[i(ta,{}),"Pin Right"]}),D(I,{onClick:()=>St(a.column.id,!1),disabled:!a.column.getIsPinned(),children:[i(oa,{}),"Unpin"]})]})]})]})]}),Dt&&a.column.getCanResize()&&!d&&a.colSpan===1&&i("div",{className:"absolute right-0 top-0 h-full w-1 bg-border hover:bg-primary cursor-col-resize opacity-0 hover:opacity-100 transition-opacity",onMouseDown:a.getResizeHandler()})]},a.id)})},g.id))}),kt=g=>{if(!L)return;let x=0,a=y.getLeftHeaderGroups()[0]?.headers||[],C=[...ie?["serialNumber"]:[],...z?["select"]:[]];for(let d of a){if(d.id===g.id)break;if(C.includes(d.id)){let v=y.getColumn(d.id);v&&(x+=v.getSize())}}return x},Rt=g=>{if(!L)return;let x=y.getState().columnPinning.right||[],a=x.indexOf(g.id);if(a===-1)return;let C=0;for(let d=a+1;d<x.length;d++){let v=y.getColumn(x[d]);v&&(C+=v.getSize())}return C};return N?i(Ve,{className:"w-full rounded-xl shadow-sm",children:i(Be,{className:"flex items-center justify-center",children:D("div",{className:"text-center",children:[i("div",{className:"text-red-500 mb-3 text-2xl",children:"\u26A0\uFE0F"}),i("p",{className:"text-sm text-muted-foreground mb-4",children:N}),Q&&D(b,{variant:"outline",size:"sm",onClick:Q,className:"rounded-lg",children:[i(Ut,{className:"mr-2 h-4 w-4"}),"Try Again"]})]})})}):i(ye,{children:D("div",{className:o("w-full space-y-2 flex flex-col h-full",R),children:[m&&i(Ve,{className:"rounded-2xl py-2 sticky top-0 z-20",children:i(Be,{className:"px-2",children:m})}),ao&&i(mt,{table:y,filters:n,globalFilter:ze,onGlobalFilterChange:Je,enableGlobalFilter:wt,onExport:J,onRefresh:Q,loading:h,enableColumnVisibility:et,enableColumnPinning:L,data:e,onClearSorting:co,onClearFilters:mo,onExternalSearch:ke}),i(Ve,{className:o("shadow-sm overflow-auto py-0",io&&"flex-1"),children:i(Be,{className:"p-0 h-full",children:D("div",{className:"relative flex flex-col h-full justify-between",children:[h&&i("div",{className:"absolute inset-0 bg-background/80 backdrop-blur-sm z-50 flex items-center justify-center rounded-xl",children:D("div",{className:"flex items-center gap-3 bg-background/90 px-4 py-3 rounded-lg shadow-sm",children:[i(Ut,{className:"size-5 animate-spin text-primary"}),i("span",{className:"text-sm font-medium text-muted-foreground",children:"Loading..."})]})}),i("div",{className:"relative rounded-t-xl overflow-auto border-b",children:D(at,{className:"border-collapse w-full",children:[!so&&uo(),i(It,{children:y.getRowModel().rows?.length?y.getRowModel().rows.map((g,x)=>i(Ce,{"data-state":g.getIsSelected()&&"selected",className:o(ro&&"hover:bg-muted/50",no&&x%2===0&&"bg-muted/20",g.getIsSelected()&&"bg-muted","border-b last:border-b-0",ee==="single"&&"cursor-pointer"),onClick:()=>{ee==="single"&&lo(g)},children:g.getVisibleCells().map((a,C)=>{let d=L&&(a.column.getIsPinned()==="left"||a.column.id==="serialNumber"||a.column.id==="select"&&z),v=L&&a.column.getIsPinned()==="right",k=a.column.id==="serialNumber",O=a.column.id==="select",G=k||O&&Me;return i(_e,{className:o(Pt?"py-2":"py-4",Nt&&C<g.getVisibleCells().length&&"border-r",d&&"sticky left-0 z-10 bg-sidebar/97",v&&"sticky right-0 z-10 bg-sidebar/97",k&&"sticky left-0 z-10 bg-sidebar/97","p-1"),style:{width:a.column.getSize()!==150?a.column.getSize():"auto",minWidth:a.column.getSize()!==150?a.column.getSize():"auto",...d&&{left:k?0:O?ie&&y.getColumn("serialNumber")?.getSize()||0:kt(a.column)},...v&&{right:Rt(a.column)},...k&&{left:0}},children:ft(a.column.columnDef.cell,a.getContext())},a.id)})},g.id)):i(Ce,{children:i(_e,{colSpan:tt.length,className:"h-32 text-center border-0",children:D("div",{className:"flex flex-col items-center gap-3",children:[i("div",{className:"text-muted-foreground text-6xl",children:"\u{1F4CB}"}),i("p",{className:"text-muted-foreground font-medium",children:V})]})})})})]})}),P&&i("div",{className:"sticky bottom-0 bg-sidebar w-full z-20",style:{width:"100%",minWidth:"fit-content"},children:i(at,{children:i(_t,{children:i(Ce,{className:"bg-sidebar",children:i(_e,{colSpan:tt.length,className:"p-2",children:P})})})})})]})})}),i(ut,{table:y,config:s}),Z&&Z(y)]})})}import{Separator as ra}from"radix-ui";import{jsx as ia}from"react/jsx-runtime";function We({className:e,orientation:t="horizontal",decorative:n=!0,...s}){return ia(ra.Root,{"data-slot":"separator-root",decorative:n,orientation:t,className:o("bg-border shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px",e),...s})}import{Loader as sa,X as la}from"lucide-react";import{AnimatePresence as da,motion as ca}from"framer-motion";import*as ae from"react";import*as qt from"react-dom";import{jsx as _,jsxs as Te}from"react/jsx-runtime";function ma({table:e,visible:t,container:n,children:s,className:u,...m}){let[P,R]=ae.useState(!1);ae.useLayoutEffect(()=>{R(!0)},[]),ae.useEffect(()=>{function N(V){V.key==="Escape"&&e&&e.toggleAllRowsSelected(!1)}return window.addEventListener("keydown",N),()=>window.removeEventListener("keydown",N)},[e]);let p=n??(P?globalThis.document?.body:null);if(!p||!e)return null;let h=t??e.getFilteredSelectedRowModel().rows.length>0;return qt.createPortal(_(da,{children:h&&_(ca.div,{role:"toolbar","aria-orientation":"horizontal",initial:{opacity:0,y:20},animate:{opacity:1,y:0},exit:{opacity:0,y:20},transition:{duration:.3,ease:"easeInOut"},className:o("fixed inset-x-0 bottom-6 z-50 mx-auto flex w-fit flex-wrap items-center justify-center gap-2 rounded-xl border bg-primary/10 backdrop-blur-sm p-3 text-foreground ring-5 ring-primary/5",u),...m,children:_(ye,{children:s})})}),p)}function ua({size:e="sm",tooltip:t,isPending:n,disabled:s,className:u,children:m,...P}){let R=_(b,{variant:"secondary",size:e,className:o("gap-1.5 rounded-lg border border-secondary bg-secondary/50 hover:bg-secondary/70 transition-all duration-200",e==="icon"?"size-8":"h-8 px-3",u),disabled:s||n,...P,children:n?_(sa,{className:"animate-spin"}):m});return t?Te(nt,{children:[_(rt,{asChild:!0,children:R}),_(it,{sideOffset:8,className:"rounded-lg border font-semibold text-foreground bg-secondary [&>span]:hidden",children:_("p",{children:t})})]}):R}function pa({table:e}){let t=ae.useCallback(()=>{e&&e.toggleAllRowsSelected(!1)},[e]);return e?Te("div",{className:"flex h-8 items-center rounded-lg border bg-muted/50 pr-1 pl-3",children:[Te("span",{className:"whitespace-nowrap text-sm font-medium",children:[e.getFilteredSelectedRowModel().rows.length," selected"]}),_(We,{orientation:"vertical",className:"mr-2 ml-3 data-[orientation=vertical]:h-4"}),Te(nt,{children:[_(rt,{asChild:!0,children:_(b,{variant:"ghost",size:"icon",className:"size-6 rounded-md",onClick:t,children:_(la,{className:"size-3.5"})})}),Te(it,{sideOffset:10,className:"flex items-center gap-2 rounded-lg border px-3 py-2 font-semibold text-foregroun bg-secondary [&>span]:hidden",children:[_("p",{children:"Clear selection"}),_("kbd",{className:"select-none rounded border bg-primary/50 px-2 py-1 font-mono font-normal text-[0.7rem] text-foreground shadow-sm",children:_("abbr",{title:"Escape",className:"no-underline",children:"Esc"})})]})]})]}):null}import{ArrowUpDown as Se,EyeOff as ga}from"lucide-react";import{jsx as $,jsxs as be}from"react/jsx-runtime";function fa({column:e,title:t,className:n}){return e.getCanSort()?$("div",{className:o("flex items-center space-x-2",n),children:be(W,{children:[$(X,{asChild:!0,children:be(b,{variant:"ghost",size:"sm",className:"-ml-3 h-8 data-[state=open]:bg-accent",children:[$("span",{children:t}),e.getIsSorted()==="desc"?$(Se,{className:"ml-2 h-4 w-4"}):e.getIsSorted()==="asc"?$(Se,{className:"ml-2 h-4 w-4"}):$(Se,{className:"ml-2 h-4 w-4"})]})}),be(K,{align:"start",className:"rounded-lg",children:[be(I,{onClick:()=>e.toggleSorting(!1),children:[$(Se,{className:"mr-2 h-3.5 w-3.5 text-muted-foreground/70"}),"Asc"]}),be(I,{onClick:()=>e.toggleSorting(!0),children:[$(Se,{className:"mr-2 h-3.5 w-3.5 text-muted-foreground/70"}),"Desc"]}),$(U,{}),be(I,{onClick:()=>e.toggleVisibility(!1),children:[$(ga,{className:"mr-2 h-3.5 w-3.5 text-muted-foreground/70"}),"Hide"]})]})]})}):$("div",{className:o(n),children:t})}import{ChevronDown as ba,Eye as va}from"lucide-react";import{jsx as ve,jsxs as ht}from"react/jsx-runtime";function xa({table:e}){return ht(W,{children:[ve(X,{asChild:!0,children:ht(b,{variant:"outline",size:"sm",className:"rounded-lg",children:[ve(va,{className:"mr-2 h-4 w-4"}),"Columns ",ve(ba,{className:"ml-2 h-4 w-4"})]})}),ht(K,{align:"end",className:"w-[200px] rounded-lg",children:[ve(j,{children:"Toggle Columns"}),ve(U,{}),e.getAllColumns().filter(t=>typeof t.accessorFn<"u"&&t.getCanHide()).map(t=>ve(Pe,{className:"capitalize",checked:t.getIsVisible(),onCheckedChange:n=>t.toggleVisibility(!!n),children:t.id},t.id))]})]})}import{Slot as ha}from"radix-ui";import{cva as Ca}from"class-variance-authority";import{jsx as wa}from"react/jsx-runtime";var ya=Ca("inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-hidden",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90",secondary:"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90",destructive:"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",outline:"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground"}},defaultVariants:{variant:"default"}});function Xe({className:e,variant:t,asChild:n=!1,...s}){let u=n?ha.Slot:"span";return wa(u,{"data-slot":"badge",className:o(ya({variant:t}),e),...s})}import{Command as de}from"cmdk";import{SearchIcon as Pa}from"lucide-react";import{Dialog as Ur}from"radix-ui";import{XIcon as qr}from"lucide-react";import{jsx as Kr,jsxs as Jr}from"react/jsx-runtime";import{jsx as ne,jsxs as Na}from"react/jsx-runtime";function Wt({className:e,...t}){return ne(de,{"data-slot":"command",className:o("bg-popover text-popover-foreground flex h-full w-full flex-col overflow-hidden rounded-md",e),...t})}function Xt({className:e,...t}){return Na("div",{"data-slot":"command-input-wrapper",className:"flex h-9 items-center gap-2 border-b px-3",children:[ne(Pa,{className:"size-4 shrink-0 opacity-50"}),ne(de.Input,{"data-slot":"command-input",className:o("placeholder:text-muted-foreground flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-hidden disabled:cursor-not-allowed disabled:opacity-50",e),...t})]})}function Kt({className:e,...t}){return ne(de.List,{"data-slot":"command-list",className:o("max-h-[300px] scroll-py-1 overflow-x-hidden overflow-y-auto",e),...t})}function Jt({...e}){return ne(de.Empty,{"data-slot":"command-empty",className:"py-6 text-center text-sm",...e})}function Ct({className:e,...t}){return ne(de.Group,{"data-slot":"command-group",className:o("text-foreground [&_[cmdk-group-heading]]:text-muted-foreground overflow-hidden p-1 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium",e),...t})}function Qt({className:e,...t}){return ne(de.Separator,{"data-slot":"command-separator",className:o("bg-border -mx-1 h-px",e),...t})}function yt({className:e,...t}){return ne(de.Item,{"data-slot":"command-item",className:o("data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...t})}import{CheckIcon as Da,PlusCircleIcon as Ta}from"lucide-react";import{Fragment as Yt,jsx as T,jsxs as re}from"react/jsx-runtime";function Sa({column:e,title:t,options:n}){let s=e?.getFacetedUniqueValues(),u=new Set(e?.getFilterValue());return re(Ee,{children:[T(je,{asChild:!0,children:re(b,{variant:"outline",size:"sm",className:"h-9 border-dashed rounded-lg",children:[T(Ta,{className:"mr-2 h-4 w-4"}),t,u?.size>0&&re(Yt,{children:[T(We,{orientation:"vertical",className:"mx-2 h-4"}),T(Xe,{variant:"secondary",className:"rounded-sm px-1 font-normal lg:hidden",children:u.size}),T("div",{className:"hidden space-x-1 lg:flex",children:u.size>2?re(Xe,{variant:"secondary",className:"rounded-sm px-1 font-normal",children:[u.size," selected"]}):n.filter(m=>u.has(m.value)).map(m=>T(Xe,{variant:"secondary",className:"rounded-sm px-1 font-normal",children:m.label},m.value))})]})]})}),T(Ue,{className:"w-[200px] p-0 rounded-lg",align:"start",children:re(Wt,{className:"rounded-lg",children:[T(Xt,{placeholder:t}),re(Kt,{children:[T(Jt,{children:"No results found."}),T(Ct,{children:n.map(m=>{let P=u.has(m.value);return re(yt,{onSelect:()=>{P?u.delete(m.value):u.add(m.value);let R=Array.from(u);e?.setFilterValue(R.length?R:void 0)},children:[T("div",{className:o("mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary",P?"bg-primary text-primary-foreground":"opacity-50 [&_svg]:invisible"),children:T(Da,{className:o("h-4 w-4")})}),m.icon&&T(m.icon,{className:"mr-2 h-4 w-4 text-muted-foreground"}),T("span",{children:m.label}),s?.get(m.value)&&T("span",{className:"ml-auto flex h-4 w-4 items-center justify-center font-mono text-xs",children:s.get(m.value)})]},m.value)})}),u.size>0&&re(Yt,{children:[T(Qt,{}),T(Ct,{children:T(yt,{onSelect:()=>e?.setFilterValue(void 0),className:"justify-center text-center",children:"Clear filters"})})]})]})]})})]})}export{na as DataTable,ma as DataTableActionBar,ua as DataTableActionBarAction,pa as DataTableActionBarSelection,fa as DataTableColumnHeader,Sa as DataTableFacetedFilter,ut as DataTablePagination,mt as DataTableToolbar,xa as DataTableViewOptions};
2
+ import{flexRender as ht,getCoreRowModel as ta,getFilteredRowModel as oa,getPaginationRowModel as aa,getSortedRowModel as na,useReactTable as ra}from"@tanstack/react-table";import{Loader2 as Jt,ChevronUp as Ct,ChevronDown as yt,ChevronsUpDown as ia,MoreHorizontal as sa,MoveRightIcon as la,PinOffIcon as da}from"lucide-react";import{Slot as No}from"radix-ui";import{cva as Do}from"class-variance-authority";import{clsx as wo}from"clsx";import{twMerge as Po}from"tailwind-merge";function o(...e){return Po(wo(e))}import{jsx as To}from"react/jsx-runtime";var Be=Do("inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",{variants:{variant:{default:"bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",destructive:"bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",outline:"border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50",secondary:"bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80",ghost:"hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",link:"text-primary underline-offset-4 hover:underline"},size:{default:"h-9 px-4 py-2 has-[>svg]:px-3",sm:"h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",lg:"h-10 rounded-md px-6 has-[>svg]:px-4",icon:"size-9"}},defaultVariants:{variant:"default",size:"default"}});function h({className:e,variant:t,size:r,asChild:s=!1,...p}){let c=s?No.Slot:"button";return To(c,{"data-slot":"button",className:o(Be({variant:t,size:r,className:e}),"transition-none"),...p})}import{jsx as ae}from"react/jsx-runtime";function st({className:e,...t}){return ae("div",{"data-slot":"table-container",className:"relative w-full overflow-auto max-h-full",children:ae("table",{"data-slot":"table",className:o("w-full caption-bottom text-sm",e),...t})})}function Bt({className:e,...t}){return ae("thead",{"data-slot":"table-header",className:o("[&_tr]:border-b",e),...t})}function At({className:e,...t}){return ae("tbody",{"data-slot":"table-body",className:o("[&_tr:last-child]:border-0",e),...t})}function Lt({className:e,...t}){return ae("tfoot",{"data-slot":"table-footer",className:o("bg-muted/50 border-t font-medium [&>tr]:last:border-b-0",e),...t})}function Pe({className:e,...t}){return ae("tr",{"data-slot":"table-row",className:o("hover:bg-muted/50 data-[state=selected]:bg-muted border-b transition-colors",e),...t})}function Gt({className:e,...t}){return ae("th",{"data-slot":"table-head",className:o("text-foreground h-10 px-2 text-left align-middle font-medium whitespace-nowrap",e),...t})}function Ae({className:e,...t}){return ae("td",{"data-slot":"table-cell",className:o("p-2 align-middle whitespace-nowrap",e),...t})}import{jsx as Ot}from"react/jsx-runtime";function Le({className:e,...t}){return Ot("div",{"data-slot":"card",className:o("bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm",e),...t})}function Ge({className:e,...t}){return Ot("div",{"data-slot":"card-content",className:o("px-6",e),...t})}import{Tooltip as be}from"radix-ui";import{jsx as ve,jsxs as So}from"react/jsx-runtime";function Ne({delayDuration:e=0,...t}){return ve(be.Provider,{"data-slot":"tooltip-provider",delayDuration:e,...t})}function lt({...e}){return ve(Ne,{children:ve(be.Root,{"data-slot":"tooltip",...e})})}function dt({...e}){return ve(be.Trigger,{"data-slot":"tooltip-trigger",...e})}function ct({className:e,sideOffset:t=0,children:r,...s}){return ve(be.Portal,{children:So(be.Content,{"data-slot":"tooltip-content",sideOffset:t,className:o("bg-primary text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance",e),...s,children:[r,ve(be.Arrow,{className:"bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]"})]})})}import{Search as $t,RefreshCw as Eo,Download as jo,Settings2 as Uo,Filter as qt,ArrowUpDown as $o,PinOff as qo,Pin as Wo,ChevronDown as Xo}from"lucide-react";import{jsx as ko}from"react/jsx-runtime";function mt({className:e,type:t,...r}){return ko("input",{type:t,"data-slot":"input",className:o("file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm","focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]","aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",e),...r})}import{Select as O}from"radix-ui";import{CheckIcon as Ro,ChevronDownIcon as Ht,ChevronUpIcon as zo}from"lucide-react";import{jsx as I,jsxs as ut}from"react/jsx-runtime";function Oe({...e}){return I(O.Root,{"data-slot":"select",...e})}function He({...e}){return I(O.Value,{"data-slot":"select-value",...e})}function Ee({className:e,size:t="default",children:r,...s}){return ut(O.Trigger,{"data-slot":"select-trigger","data-size":t,className:o("border-input data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 dark:hover:bg-input/50 flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...s,children:[r,I(O.Icon,{asChild:!0,children:I(Ht,{className:"size-4 opacity-50"})})]})}function je({className:e,children:t,position:r="popper",...s}){return I(O.Portal,{children:ut(O.Content,{"data-slot":"select-content",className:o("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md",r==="popper"&&"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",e),position:r,...s,children:[I(Mo,{}),I(O.Viewport,{className:o("p-1",r==="popper"&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1"),children:t}),I(Io,{})]})})}function De({className:e,children:t,...r}){return ut(O.Item,{"data-slot":"select-item",className:o("focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2",e),...r,children:[I("span",{className:"absolute right-2 flex size-3.5 items-center justify-center",children:I(O.ItemIndicator,{children:I(Ro,{className:"size-4"})})}),I(O.ItemText,{children:t})]})}function Mo({className:e,...t}){return I(O.ScrollUpButton,{"data-slot":"select-scroll-up-button",className:o("flex cursor-default items-center justify-center py-1",e),...t,children:I(zo,{className:"size-4"})})}function Io({className:e,...t}){return I(O.ScrollDownButton,{"data-slot":"select-scroll-down-button",className:o("flex cursor-default items-center justify-center py-1",e),...t,children:I(Ht,{className:"size-4"})})}import{DropdownMenu as W}from"radix-ui";import{CheckIcon as _o,ChevronRightIcon as cn,CircleIcon as mn}from"lucide-react";import{jsx as E,jsxs as Fo}from"react/jsx-runtime";function K({...e}){return E(W.Root,{"data-slot":"dropdown-menu",...e})}function J({...e}){return E(W.Trigger,{"data-slot":"dropdown-menu-trigger",...e})}function Q({className:e,sideOffset:t=4,...r}){return E(W.Portal,{children:E(W.Content,{"data-slot":"dropdown-menu-content",sideOffset:t,className:o("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) rounded-md border p-1 shadow-md",e),...r})})}function pt({...e}){return E(W.Group,{"data-slot":"dropdown-menu-group",...e})}function _({className:e,inset:t,variant:r="default",...s}){return E(W.Item,{"data-slot":"dropdown-menu-item","data-inset":t,"data-variant":r,className:o("cursor-pointer focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/20 data-[variant=destructive]:focus:text-destructive data-[variant=destructive]:*:[svg]:!text-destructive [&_svg:not([class*='text-'])]:text-muted-foreground relative flex items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...s})}function Te({className:e,children:t,checked:r,...s}){return Fo(W.CheckboxItem,{"data-slot":"dropdown-menu-checkbox-item",className:o("focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),checked:r,...s,children:[E("span",{className:"pointer-events-none absolute left-2 flex size-3.5 items-center justify-center",children:E(W.ItemIndicator,{children:E(_o,{className:"size-4"})})}),t]})}function j({className:e,inset:t,...r}){return E(W.Label,{"data-slot":"dropdown-menu-label","data-inset":t,className:o("px-2 py-1.5 text-sm font-medium data-[inset]:pl-8",e),...r})}function U({className:e,...t}){return E(W.Separator,{"data-slot":"dropdown-menu-separator",className:o("bg-border -mx-1 my-1 h-px",e),...t})}import{useState as Wt}from"react";import{useEffect as Oo,useState as gt}from"react";import{Calendar as Ho}from"lucide-react";import{format as Se}from"date-fns";import{Popover as Ue}from"radix-ui";import{jsx as $e}from"react/jsx-runtime";function qe({...e}){return $e(Ue.Root,{"data-slot":"popover",...e})}function We({...e}){return $e(Ue.Trigger,{"data-slot":"popover-trigger",...e})}function Xe({className:e,align:t="center",sideOffset:r=4,...s}){return $e(Ue.Portal,{children:$e(Ue.Content,{"data-slot":"popover-content",align:t,sideOffset:r,className:o("bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border p-4 shadow-md outline-hidden",e),...s})})}import*as Ke from"react";import{ChevronDownIcon as Vo,ChevronLeftIcon as Bo,ChevronRightIcon as Ao}from"lucide-react";import{DayPicker as Lo,getDefaultClassNames as Et}from"react-day-picker";import{jsx as ne}from"react/jsx-runtime";function jt({className:e,classNames:t,showOutsideDays:r=!0,captionLayout:s="label",buttonVariant:p="ghost",formatters:c,components:N,...z}){let b=Et();return ne(Lo,{showOutsideDays:r,className:o("bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent",String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,e),captionLayout:s,formatters:{formatMonthDropdown:y=>y.toLocaleString("default",{month:"short"}),...c},classNames:{root:o("w-fit",b.root),months:o("flex gap-4 flex-col md:flex-row relative",b.months),month:o("flex flex-col w-full gap-4",b.month),nav:o("flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between",b.nav),button_previous:o(Be({variant:p}),"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",b.button_previous),button_next:o(Be({variant:p}),"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",b.button_next),month_caption:o("flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)",b.month_caption),dropdowns:o("w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5",b.dropdowns),dropdown_root:o("relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md",b.dropdown_root),dropdown:o("absolute bg-popover inset-0 opacity-0",b.dropdown),caption_label:o("select-none font-medium",s==="label"?"text-sm":"rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5",b.caption_label),table:"w-full border-collapse",weekdays:o("flex",b.weekdays),weekday:o("text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none",b.weekday),week:o("flex w-full mt-2",b.week),week_number_header:o("select-none w-(--cell-size)",b.week_number_header),week_number:o("text-[0.8rem] select-none text-muted-foreground",b.week_number),day:o("relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none",b.day),range_start:o("rounded-l-md bg-accent",b.range_start),range_middle:o("rounded-none",b.range_middle),range_end:o("rounded-r-md bg-accent",b.range_end),today:o("bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none",b.today),outside:o("text-muted-foreground aria-selected:text-muted-foreground",b.outside),disabled:o("text-muted-foreground opacity-50",b.disabled),hidden:o("invisible",b.hidden),...t},components:{Root:({className:y,rootRef:D,...V})=>ne("div",{"data-slot":"calendar",ref:D,className:o(y),...V}),Chevron:({className:y,orientation:D,...V})=>D==="left"?ne(Bo,{className:o("size-4",y),...V}):D==="right"?ne(Ao,{className:o("size-4",y),...V}):ne(Vo,{className:o("size-4",y),...V}),DayButton:Go,WeekNumber:({children:y,...D})=>ne("td",{...D,children:ne("div",{className:"flex size-(--cell-size) items-center justify-center text-center",children:y})}),...N},...z})}function Go({className:e,day:t,modifiers:r,...s}){let p=Et(),c=Ke.useRef(null);return Ke.useEffect(()=>{r.focused&&c.current?.focus()},[r.focused]),ne(h,{ref:c,variant:"ghost",size:"icon","data-day":t.date.toLocaleDateString(),"data-selected-single":r.selected&&!r.range_start&&!r.range_end&&!r.range_middle,"data-range-start":r.range_start,"data-range-end":r.range_end,"data-range-middle":r.range_middle,className:o("data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70",p.day,e),...s})}import{jsx as de,jsxs as ke}from"react/jsx-runtime";function Ut({value:e,onChange:t,placeholder:r,mode:s,externalSearch:p,onExternalChange:c,onlyExternal:N=!1}){let[z,b]=gt(!1),[y,D]=gt(e),[V,k]=gt(e);Oo(()=>{N||k(e)},[e,N]);let Z=()=>{N||t(y),k(y),p&&c&&c(y),b(!1)},q=()=>{D(V),b(!1)},ee=()=>{let v=s==="single"?null:{from:null,to:null};D(v),N||t(v),k(v),p&&c&&c(v),b(!1)},te=()=>{let v=N?V:e;return v?s==="single"?Se(v,"PPP"):v.from&&v.to?`${Se(v.from,"MMM dd")} - ${Se(v.to,"MMM dd, yyyy")}`:v.from?`From ${Se(v.from,"MMM dd, yyyy")}`:v.to?`To ${Se(v.to,"MMM dd, yyyy")}`:r:r},B=v=>{D(s==="single"?v:v||{from:null,to:null})};return ke(qe,{open:z,onOpenChange:b,children:[de(We,{asChild:!0,children:ke(h,{variant:"outline",className:o("w-full justify-start text-left font-normal h-9",!te()&&"text-muted-foreground"),children:[de(Ho,{className:"mr-2 h-4 w-4"}),te()]})}),ke(Xe,{className:"w-auto p-0",align:"start",children:[de("div",{className:"p-3",children:de(jt,{mode:s,selected:y,onSelect:B,numberOfMonths:s==="range"?2:1,className:"rounded-md border",...s==="range"&&{required:!0}})}),ke("div",{className:"flex items-center justify-between p-3 border-t",children:[de(h,{variant:"ghost",size:"sm",onClick:ee,children:"Clear"}),ke("div",{className:"flex gap-2",children:[de(h,{variant:"outline",size:"sm",onClick:q,children:"Cancel"}),de(h,{size:"sm",onClick:Z,disabled:s==="range"&&(!y?.from||!y?.to),children:"Apply"})]})]})]})]})}import{Fragment as Ko,jsx as d,jsxs as P}from"react/jsx-runtime";function ft({table:e,filters:t=[],globalFilter:r,onGlobalFilterChange:s,enableGlobalFilter:p=!0,onExport:c,onRefresh:N,loading:z=!1,enableColumnVisibility:b=!0,data:y,onClearSorting:D,onClearFilters:V,enableColumnPinning:k=!1,onExternalSearch:Z,onCustomFilterChange:q}){let[ee,te]=Wt({}),[B,v]=Wt({}),Ie=()=>e.getAllLeafColumns().filter(a=>a.getCanHide?.()!==!1),_e=()=>e.getAllColumns().filter(a=>!e.getAllLeafColumns().includes(a)&&a.columns?.length&&a.columns.some(g=>g.getCanHide?.()!==!1)),ye=()=>{let a=new Set(_e().flatMap(g=>g.columns?.filter(x=>x.getCanHide?.()!==!1).map(x=>x.id)||[]));return Ie().filter(g=>!a.has(g.id))},Fe=(a,g)=>g&&a.startsWith(`${g}.`)?a.replace(`${g}.`,"").split("_").map(X=>X.slice(1)).join(" "):a.split("_").map(x=>x.charAt(0).toUpperCase()+x.slice(1)).join(" "),me=(a,g)=>{let x={...ee,[a]:g};te(x)},Ze=(a,g)=>{let x={...B,[a]:g};v(x),q&&q(a,g),t.find(X=>X.key===a)?.externalSearch&&me(a,g)},et=()=>{Z&&Z(ee)},ue=()=>{te({}),v({}),V(),Z&&Z({}),q&&Object.keys(B).forEach(a=>{q(a,"")})},we=a=>t.find(x=>x.key===a)?.customFilter?B[a]??"":e.getColumn(a)?.getFilterValue(),pe=(a,g)=>{let x=t.find(X=>X.key===a);x?.customFilter?Ze(a,g):(e.getColumn(a)?.setFilterValue(g),x?.externalSearch&&me(a,g))};return d("div",{className:"rounded-xl",children:d("div",{className:"px-2",children:d("div",{className:"flex flex-col gap-6",children:P("div",{className:"flex items-center justify-between",children:[d("div",{className:"flex items-center gap-3",children:t.length>0&&P("div",{className:"flex items-center gap-3 flex-wrap",children:[d("div",{className:"flex items-center gap-2 text-sm font-medium text-muted-foreground",children:d(qt,{className:"h-4 w-4"})}),t.map(a=>!e.getColumn(a.key)&&!a.customFilter&&!a.externalSearch?null:d("div",{className:o("relative min-w-[150px]",a.width),children:a.type==="select"?P(Oe,{value:we(a.key)??"",onValueChange:x=>{pe(a.key,x==="all"?"":x)},children:[a.icon&&d("span",{children:d(a.icon,{className:"size-4 absolute left-3 top-1/2 -translate-y-1/2 text-muted-foreground"})}),d(Ee,{className:o("h-9 rounded-lg w-full",a.icon&&"pl-9"),children:d(He,{placeholder:a.placeholder})}),P(je,{className:"rounded-lg",children:[d(De,{value:"all",children:"All"}),a.options?.map(x=>d(De,{value:x.value,children:x.label},x.label))]})]}):a.type==="date"?d(Ut,{value:we(a.key),onChange:x=>{a.onlyExternal||pe(a.key,x)},placeholder:a.placeholder,mode:a.dateMode||"single",externalSearch:a.externalSearch,onlyExternal:a.onlyExternal,onExternalChange:x=>me(a.key,x)}):P("div",{className:"relative",children:[a.icon&&d("span",{children:d(a.icon,{className:"size-4 absolute left-3 top-1/2 -translate-y-1/2 text-muted-foreground"})}),d(mt,{placeholder:a.placeholder,value:we(a.key)??"",onChange:x=>{pe(a.key,x.target.value)},className:o("h-9 rounded-lg",a.icon&&"pl-9"),type:a.type==="number"?"number":"text"})]})},a.key)),(t.some(a=>a.externalSearch)||t.some(a=>a.customFilter))&&P(h,{variant:"default",size:"sm",onClick:et,className:"rounded-lg",children:[d($t,{className:"mr-2 h-4 w-4"}),t.find(a=>a.externalSearch||a.customFilter)?.searchButtonText||"Search"]})]})}),P("div",{className:"flex items-center gap-2",children:[p&&P("div",{className:"relative",children:[d($t,{className:"absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground"}),d(mt,{placeholder:"Global search...",value:r??"",onChange:a=>s(a.target.value),className:"pl-9 max-w-max"})]}),c&&P(h,{variant:"outline",size:"sm",onClick:()=>c(y),className:"rounded-lg",children:[d(jo,{className:"mr-2 h-4 w-4"}),"Export"]}),b&&P(K,{children:[d(J,{asChild:!0,children:P(h,{variant:"outline",size:"sm",className:"rounded-lg gap-1",children:[d("span",{children:"Columns"}),d(Xo,{className:"h-4 w-4 opacity-50"})]})}),P(Q,{align:"end",className:"w-[220px] rounded-lg max-h-[400px] overflow-y-auto",children:[d(j,{className:"px-4 py-2 text-sm font-medium",children:"Toggle Columns"}),d(U,{}),ye().length>0&&P(pt,{children:[d(j,{className:"px-4 py-1.5 text-sm font-medium text-muted-foreground",children:"General"}),ye().map(a=>d(Te,{className:"text-sm",checked:a.getIsVisible(),onCheckedChange:g=>a.toggleVisibility(!!g),children:Fe(a.id)},a.id))]}),_e().map(a=>P(pt,{children:[d(U,{}),d(j,{className:"px-4 py-1.5 text-sm font-medium text-muted-foreground",children:a.id}),a.columns?.filter(g=>g.getCanHide?.()!==!1).map(g=>d(Te,{className:"text-sm",checked:g.getIsVisible(),onCheckedChange:x=>g.toggleVisibility(!!x),children:Fe(g.id,a.id)},g.id))]},a.id))]})]}),P(K,{children:[d(J,{asChild:!0,children:d(h,{variant:"outline",size:"sm",className:"rounded-lg",children:d(Uo,{className:"h-4 w-4"})})}),P(Q,{align:"end",className:"w-[200px] rounded-lg",children:[d(j,{children:"Table Settings"}),d(U,{}),P(_,{onClick:D,children:[d($o,{className:"mr-2 h-4 w-4"}),"Clear All Sorting"]}),P(_,{onClick:ue,children:[d(qt,{className:"mr-2 h-4 w-4"}),"Clear All Filters"]}),k&&P(Ko,{children:[d(U,{}),d(j,{children:"Column Pinning"}),P(_,{onClick:()=>e.setColumnPinning({left:[],right:[]}),children:[d(qo,{className:"mr-2 h-4 w-4"}),"Reset All Pinning"]}),P(_,{onClick:()=>{let a=Ie().filter(g=>g.getCanPin?.()!==!1).map(g=>g.id);e.setColumnPinning({left:[],right:a})},children:[d(Wo,{className:"mr-2 h-4 w-4 -rotate-90"}),"Pin All Right"]})]})]})]}),N&&d(h,{variant:"outline",size:"sm",onClick:N,disabled:z,className:"rounded-lg",children:d(Eo,{className:o("h-4 w-4",z&&"animate-spin")})})]})]})})})})}import{jsx as A,jsxs as xe}from"react/jsx-runtime";function bt({table:e,config:t}){return t.enabled?A("div",{className:"rounded-xl",children:A("div",{children:xe("div",{className:"flex items-center justify-between",children:[A("div",{className:"flex items-center gap-6 text-sm text-muted-foreground",children:t.showInfo!==!1&&xe("span",{children:["Showing ",e.getState().pagination.pageIndex*e.getState().pagination.pageSize+1," to"," ",Math.min((e.getState().pagination.pageIndex+1)*e.getState().pagination.pageSize,e.getFilteredRowModel().rows.length)," ","of ",e.getFilteredRowModel().rows.length," entries"]})}),xe("div",{className:"flex items-center gap-4",children:[t.pageSizeOptions&&xe("div",{className:"flex items-center gap-2",children:[A("span",{className:"text-sm font-medium",children:"Rows per page:"}),xe(Oe,{value:`${e.getState().pagination.pageSize}`,onValueChange:r=>e.setPageSize(Number(r)),children:[A(Ee,{className:"h-9 w-[70px] rounded-lg",children:A(He,{})}),A(je,{side:"top",className:"rounded-lg",children:t.pageSizeOptions.map(r=>A(De,{value:`${r}`,children:r},r))})]})]}),xe("div",{className:"flex items-center gap-2",children:[A(h,{variant:"outline",size:"sm",onClick:()=>e.setPageIndex(0),disabled:!e.getCanPreviousPage(),className:"rounded-lg",children:"First"}),A(h,{variant:"outline",size:"sm",onClick:()=>e.previousPage(),disabled:!e.getCanPreviousPage(),className:"rounded-lg",children:"Previous"}),t.showPageNumbers&&A("div",{className:"flex items-center gap-1",children:Array.from({length:Math.min(5,e.getPageCount())},(r,s)=>{let p=e.getState().pagination.pageIndex,c=p+s;return c<1||c>e.getPageCount()?null:A(h,{variant:c===p+1?"default":"outline",size:"sm",className:"size-8 p-0 rounded-lg",onClick:()=>e.setPageIndex(c-1),children:c},c)})}),A(h,{variant:"outline",size:"sm",onClick:()=>e.nextPage(),disabled:!e.getCanNextPage(),className:"rounded-lg",children:"Next"}),A(h,{variant:"outline",size:"sm",onClick:()=>e.setPageIndex(e.getPageCount()-1),disabled:!e.getCanNextPage(),className:"rounded-lg",children:"Last"})]})]})]})})}):null}import{Toggle as Jo}from"radix-ui";import{cva as Qo}from"class-variance-authority";import{jsx as Zo}from"react/jsx-runtime";var Yo=Qo("inline-flex cursor-pointer items-center justify-center gap-2 rounded-md text-sm font-medium hover:bg-muted hover:text-muted-foreground disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 [&_svg]:shrink-0 focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] outline-none transition-[color,box-shadow] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive whitespace-nowrap",{variants:{variant:{default:"bg-transparent",outline:"border border-input bg-transparent shadow-xs hover:bg-accent hover:text-accent-foreground"},size:{sm:"h-7 px-0 min-w-7",default:"h-8 px-1 min-w-8",lg:"h-9 px-2 min-w-10"},bg:{enabled:"data-[state=on]:bg-accent data-[state=on]:text-accent-foreground",disabled:""}},defaultVariants:{variant:"default",size:"default",bg:"enabled"}});function Xt({className:e,variant:t,size:r,noBg:s,...p}){return Zo(Jo.Root,{"data-slot":"toggle",className:o(Yo({className:e,variant:t,size:r,bg:s?"disabled":"enabled"})),...p})}import{Checkbox as Kt}from"radix-ui";import{CheckIcon as ea}from"lucide-react";import{jsx as vt}from"react/jsx-runtime";function xt({className:e,...t}){return vt(Kt.Root,{"data-slot":"checkbox",className:o("peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50",e),...t,children:vt(Kt.Indicator,{"data-slot":"checkbox-indicator",className:"flex items-center justify-center text-current transition-none",children:vt(ea,{className:"size-3.5"})})})}import{useCallback as Je,useEffect as Re,useMemo as ca,useState as Y}from"react";import{Fragment as Qt,jsx as i,jsxs as T}from"react/jsx-runtime";function ma({data:e,columns:t,filters:r=[],pagination:s={enabled:!1},settings:p={},header:c,footer:N,className:z="",maxHeight:b="600px",loading:y=!1,error:D,emptyMessage:V="No data available",onRowSelectionChange:k,onExport:Z,onRefresh:q,onTableReady:ee,children:te,isRowDisabled:B,isRowSelectable:v,onExternalSearch:Ie}){let[_e,ye]=Y([]),[Fe,me]=Y([]),[Ze,et]=Y({}),[ue,we]=Y({}),[pe,a]=Y(""),[g,x]=Y([]),[X,ro]=Y(p.enableColumnPinning?{left:[],right:[]}:{}),[tt,io]=Y({}),[Dt,Tt]=Y(e),{enableSorting:ot=!0,enableFiltering:at=!0,enableGlobalFilter:St=!0,enableColumnVisibility:nt=!0,enableRowSelection:M=!0,stickyHeader:so=!0,toolbar:lo=!1,showSerialNumbers:le=!0,fixedCheckboxColumn:Ve=!0,striped:co=!0,hoverable:mo=!0,compact:kt=!0,bordered:Rt=!0,fullHeight:uo=!1,enableColumnResizing:zt=!1,enableColumnPinning:L=!0,hideHeader:po=!1,selectionMode:oe="multiple",showCheckBox:go=!0,checkboxColumnPosition:Mt=0}=p;Re(()=>{if(Object.keys(tt).length===0){Tt(e);return}let m=e.filter(u=>Object.entries(tt).every(([n,f])=>{if(!f||f==="")return!0;let l=fo(u,n);return typeof f=="string"?String(l).toLowerCase().includes(f.toLowerCase()):l===f}));Tt(m)},[e,tt]);let fo=(m,u)=>u.split(".").reduce((n,f)=>n&&n[f],m),bo=Je((m,u)=>{io(n=>{let f={...n};return u===""||u===null||u===void 0?delete f[m]:f[m]=u,f})},[]),rt=ca(()=>{let m=[...t],u=l=>l.map(C=>{if(C.id==="select"||C.id==="serialNumber")return C;let R={...C,enablePinning:!0};return C.columns&&(R.columns=u(C.columns)),R}),n=u(m),f={id:"select",header:({table:l})=>{if(oe==="single")return null;let C=l.getRowModel().rows.filter(G=>!B?.(G.original)&&(v?v(G.original):!0)),R=C.length>0&&C.every(G=>G.getIsSelected()),H=C.some(G=>G.getIsSelected());return i(xt,{checked:R||H&&"indeterminate",onCheckedChange:G=>{C.forEach(ge=>ge.toggleSelected(!!G))},"aria-label":"Select all selectable rows"})},cell:({row:l})=>{let C=B?B(l.original):!1,R=v?v(l.original):!0;return i("div",{className:o("flex items-center justify-center",C&&"opacity-50"),children:oe==="multiple"?i(xt,{checked:l.getIsSelected(),onCheckedChange:H=>R&&l.toggleSelected(!!H),"aria-label":"Select row",disabled:C||!R}):go?i("input",{type:"radio",checked:l.getIsSelected(),onChange:()=>R&&l.toggleSelected(!0),disabled:C||!R,className:"h-4 w-4 rounded-full border-primary text-primary focus:ring-primary"}):null})},enableSorting:!1,enableHiding:!1,enablePinning:!0,headerAlign:"center",size:oe==="multiple"?40:30};if(M){let l=Mt;l<0&&(l=n.length+l+1),l=Math.max(0,Math.min(l,n.length)),n.splice(l,0,f)}if(le){let l={id:"serialNumber",header:"No.",cell:({row:C})=>i("div",{className:"text-center font-medium text-muted-foreground",children:C.index+1}),enableSorting:!0,enableHiding:!1,enablePinning:!0,size:60,headerAlign:"center"};n.unshift(l)}return n},[t,le,M,Ve,B,v,oe,Mt]),w=ra({data:Dt,columns:rt,onSortingChange:ot?ye:void 0,onColumnFiltersChange:at?me:void 0,onGlobalFilterChange:St?a:void 0,getCoreRowModel:ta(),getPaginationRowModel:s.enabled?aa():void 0,getSortedRowModel:ot?na():void 0,getFilteredRowModel:at?oa():void 0,onColumnVisibilityChange:nt?et:void 0,onRowSelectionChange:M?we:void 0,onColumnOrderChange:x,onColumnPinningChange:L?ro:void 0,state:{sorting:ot?_e:void 0,columnFilters:at?Fe:void 0,columnVisibility:nt?Ze:void 0,rowSelection:M?ue:{},globalFilter:pe,columnOrder:g,columnPinning:L?X:{}},initialState:{pagination:s.enabled?{pageSize:s.pageSize||10}:void 0,columnPinning:L?{left:[...le?["serialNumber"]:[],...M?["select"]:[]],right:[]}:void 0},enableRowSelection:M,enableColumnResizing:zt,enableColumnPinning:L,columnResizeMode:"onChange"});Re(()=>{if(M&&k){let m=w.getFilteredSelectedRowModel().rows.filter(u=>!B?.(u.original)&&(v?v(u.original):!0)).map(u=>u.original);k(m)}},[ue,M,k,w,B,v]);let vo=Je(m=>{oe==="single"?(w.resetRowSelection(),m.toggleSelected(!0)):m.toggleSelected()},[oe,w]);Re(()=>{ee&&ee(w)},[w,ee]),Re(()=>{if(M&&k){let m=w.getFilteredSelectedRowModel().rows.map(u=>u.original);k(m)}},[ue,M,k,w]),Re(()=>{if(M&&k){let m=w.getFilteredSelectedRowModel().rows.filter(u=>!B?.(u.original)&&(v?v(u.original):!0)).map(u=>u.original);k(m)}},[ue,M,k,w,B,v]);let xo=Je(()=>{ye([])},[]),ho=Je(()=>{me([]),a("")},[]),It=(m,u)=>{if(!L)return;let n=[...le?["serialNumber"]:[],...M&&Ve?["select"]:[]],f={left:[...(X.left??[]).filter(l=>n.includes(l))],right:[...X.right??[]]};u===!1?(f.left=f.left.filter(l=>l!==m),f.right=f.right.filter(l=>l!==m)):u==="right"?(f.left=f.left.filter(l=>l!==m),f.right.includes(m)||f.right.push(m)):u==="left"&&(f.right=f.right.filter(l=>l!==m),!f.left.includes(m)&&!n.includes(m)&&f.left.push(m)),w.setColumnPinning(f)},Co=()=>i(Bt,{className:o(so&&"sticky top-0 bg-sidebar z-20"),children:w.getHeaderGroups().map((m,u)=>i(Pe,{className:"hover:bg-transparent",children:m.headers.map((n,f)=>{let l=n.depth===0&&n.colSpan>1,C=L&&(n.column.getIsPinned()==="left"||n.column.id==="serialNumber"||n.column.id==="select"&&M),R=L&&n.column.getIsPinned()==="right",H=n.column.getCanSort(),G=L&&n.column.columnDef.enablePinning!==!1,ge=n.column.id==="serialNumber",it=n.column.id==="select",Vt=ge||it&&Ve,fe=n.column.columnDef.headerAlign||"left",yo={left:"justify-start",center:"justify-center",right:"justify-end"}[fe];return T(Gt,{colSpan:n.colSpan,className:o("font-semibold text-foreground bg-sidebar group px-0",!kt&&"py-2",Rt&&f<m.headers.length-1&&"border-r","relative",C&&"sticky left-0 z-15 bg-sidebar",R&&"sticky right-0 z-15 bg-sidebar",(ge||it)&&"sticky left-0 z-15 bg-sidebar",l?"text-center":"text-left"),style:{width:n.getSize()!==150?n.getSize():"auto",minWidth:n.getSize()!==150?n.getSize():"auto",...C&&{left:ge?0:it?le&&w.getColumn("serialNumber")?.getSize()||0:_t(n.column)},...R&&{right:Ft(n.column)},...ge&&{left:0}},children:[l?i("div",{className:"flex items-center justify-center",children:ht(n.column.columnDef.header,n.getContext())}):T("div",{className:o("relative flex items-center w-full px-2",yo),children:[T("div",{className:"flex items-center gap-1",children:[H&&fe==="right"&&i("span",{className:"ml-1 order-2",children:n.column.getIsSorted()&&{asc:i(Ct,{className:"h-4 w-4"}),desc:i(yt,{className:"h-4 w-4"})}[n.column.getIsSorted()]}),n.isPlaceholder?null:ht(n.column.columnDef.header,n.getContext()),H&&fe!=="right"&&n.column.getIsSorted()&&i("span",{className:"ml-1 order-2",children:n.column.getIsSorted()&&{asc:i(Ct,{className:"h-4 w-4"}),desc:i(yt,{className:"h-4 w-4"})}[n.column.getIsSorted()]})]}),(H||G&&!Vt)&&T(K,{children:[i(J,{asChild:!0,className:o("absolute",fe==="left"&&"right-1",fe==="center"&&"right-1",fe==="right"&&"left-1"),children:i(Xt,{variant:"default",size:"sm",noBg:!0,tabIndex:-1,className:"opacity-0 group-hover:opacity-70 hover:opacity-100 data-[state=open]:opacity-100",children:i(sa,{className:"h-4 w-4"})})}),T(Q,{align:"end",className:"w-48",children:[H&&T(Qt,{children:[i(j,{children:"Sorting"}),T(_,{onClick:()=>n.column.toggleSorting(!1),children:[i(Ct,{className:"mr-2 h-4 w-4"}),"Sort Ascending"]}),T(_,{onClick:()=>n.column.toggleSorting(!0),children:[i(yt,{className:"mr-2 h-4 w-4"}),"Sort Descending"]}),T(_,{onClick:()=>n.column.clearSorting(),disabled:!n.column.getIsSorted(),children:[i(ia,{className:"mr-2 h-4 w-4"}),"Clear Sort"]}),i(U,{})]}),G&&!Vt&&T(Qt,{children:[i(j,{children:"Pin Column"}),T(_,{onClick:()=>It(n.column.id,"right"),disabled:n.column.getIsPinned()==="right",children:[i(la,{}),"Pin Right"]}),T(_,{onClick:()=>It(n.column.id,!1),disabled:!n.column.getIsPinned(),children:[i(da,{}),"Unpin"]})]})]})]})]}),zt&&n.column.getCanResize()&&!l&&n.colSpan===1&&i("div",{className:"absolute right-0 top-0 h-full w-1 bg-border hover:bg-primary cursor-col-resize opacity-0 hover:opacity-100 transition-opacity",onMouseDown:n.getResizeHandler()})]},n.id)})},m.id))}),_t=m=>{if(!L)return;let u=0,n=w.getLeftHeaderGroups()[0]?.headers||[],f=[...le?["serialNumber"]:[],...M?["select"]:[]];for(let l of n){if(l.id===m.id)break;if(f.includes(l.id)){let C=w.getColumn(l.id);C&&(u+=C.getSize())}}return u},Ft=m=>{if(!L)return;let u=w.getState().columnPinning.right||[],n=u.indexOf(m.id);if(n===-1)return;let f=0;for(let l=n+1;l<u.length;l++){let C=w.getColumn(u[l]);C&&(f+=C.getSize())}return f};return D?i(Le,{className:"w-full rounded-xl shadow-sm",children:i(Ge,{className:"flex items-center justify-center",children:T("div",{className:"text-center",children:[i("div",{className:"text-red-500 mb-3 text-2xl",children:"\u26A0\uFE0F"}),i("p",{className:"text-sm text-muted-foreground mb-4",children:D}),q&&T(h,{variant:"outline",size:"sm",onClick:q,className:"rounded-lg",children:[i(Jt,{className:"mr-2 h-4 w-4"}),"Try Again"]})]})})}):i(Ne,{children:T("div",{className:o("w-full space-y-2 flex flex-col h-full",z),children:[c&&i(Le,{className:"rounded-2xl py-2 sticky top-0 z-20",children:i(Ge,{className:"px-2",children:c})}),lo&&i(ft,{table:w,filters:r,globalFilter:pe,onGlobalFilterChange:a,enableGlobalFilter:St,onExport:Z,onRefresh:q,loading:y,enableColumnVisibility:nt,enableColumnPinning:L,data:Dt,onClearSorting:xo,onClearFilters:ho,onExternalSearch:Ie,onCustomFilterChange:bo}),i(Le,{className:o("shadow-sm overflow-auto py-0",uo&&"flex-1"),children:i(Ge,{className:"p-0 h-full",children:T("div",{className:"relative flex flex-col h-full justify-between",children:[y&&i("div",{className:"absolute inset-0 bg-background/80 backdrop-blur-sm z-50 flex items-center justify-center rounded-xl",children:T("div",{className:"flex items-center gap-3 bg-background/90 px-4 py-3 rounded-lg shadow-sm",children:[i(Jt,{className:"size-5 animate-spin text-primary"}),i("span",{className:"text-sm font-medium text-muted-foreground",children:"Loading..."})]})}),i("div",{className:"relative rounded-t-xl overflow-auto border-b",children:T(st,{className:"border-collapse w-full",children:[!po&&Co(),i(At,{children:w.getRowModel().rows?.length?w.getRowModel().rows.map((m,u)=>i(Pe,{"data-state":m.getIsSelected()&&"selected",className:o(mo&&"hover:bg-muted/50",co&&u%2===0&&"bg-muted/20",m.getIsSelected()&&"bg-muted","border-b last:border-b-0",oe==="single"&&"cursor-pointer"),onClick:()=>{oe==="single"&&vo(m)},children:m.getVisibleCells().map((n,f)=>{let l=L&&(n.column.getIsPinned()==="left"||n.column.id==="serialNumber"||n.column.id==="select"&&M),C=L&&n.column.getIsPinned()==="right",R=n.column.id==="serialNumber",H=n.column.id==="select",G=R||H&&Ve;return i(Ae,{className:o(kt?"py-2":"py-4",Rt&&f<m.getVisibleCells().length&&"border-r",l&&"sticky left-0 z-10 bg-sidebar/97",C&&"sticky right-0 z-10 bg-sidebar/97",R&&"sticky left-0 z-10 bg-sidebar/97","p-1"),style:{width:n.column.getSize()!==150?n.column.getSize():"auto",minWidth:n.column.getSize()!==150?n.column.getSize():"auto",...l&&{left:R?0:H?le&&w.getColumn("serialNumber")?.getSize()||0:_t(n.column)},...C&&{right:Ft(n.column)},...R&&{left:0}},children:ht(n.column.columnDef.cell,n.getContext())},n.id)})},m.id)):i(Pe,{children:i(Ae,{colSpan:rt.length,className:"h-32 text-center border-0",children:T("div",{className:"flex flex-col items-center gap-3",children:[i("div",{className:"text-muted-foreground text-6xl",children:"\u{1F4CB}"}),i("p",{className:"text-muted-foreground font-medium",children:V})]})})})})]})}),N&&i("div",{className:"sticky bottom-0 bg-sidebar w-full z-20",style:{width:"100%",minWidth:"fit-content"},children:i(st,{children:i(Lt,{children:i(Pe,{className:"bg-sidebar",children:i(Ae,{colSpan:rt.length,className:"p-2",children:N})})})})})]})})}),i(bt,{table:w,config:s}),te&&te(w)]})})}import{Separator as ua}from"radix-ui";import{jsx as pa}from"react/jsx-runtime";function Qe({className:e,orientation:t="horizontal",decorative:r=!0,...s}){return pa(ua.Root,{"data-slot":"separator-root",decorative:r,orientation:t,className:o("bg-border shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px",e),...s})}import{Loader as ga,X as fa}from"lucide-react";import{AnimatePresence as ba,motion as va}from"framer-motion";import*as re from"react";import*as Yt from"react-dom";import{jsx as F,jsxs as ze}from"react/jsx-runtime";function xa({table:e,visible:t,container:r,children:s,className:p,...c}){let[N,z]=re.useState(!1);re.useLayoutEffect(()=>{z(!0)},[]),re.useEffect(()=>{function D(V){V.key==="Escape"&&e&&e.toggleAllRowsSelected(!1)}return window.addEventListener("keydown",D),()=>window.removeEventListener("keydown",D)},[e]);let b=r??(N?globalThis.document?.body:null);if(!b||!e)return null;let y=t??e.getFilteredSelectedRowModel().rows.length>0;return Yt.createPortal(F(ba,{children:y&&F(va.div,{role:"toolbar","aria-orientation":"horizontal",initial:{opacity:0,y:20},animate:{opacity:1,y:0},exit:{opacity:0,y:20},transition:{duration:.3,ease:"easeInOut"},className:o("fixed inset-x-0 bottom-6 z-50 mx-auto flex w-fit flex-wrap items-center justify-center gap-2 rounded-xl border bg-primary/10 backdrop-blur-sm p-3 text-foreground ring-5 ring-primary/5",p),...c,children:F(Ne,{children:s})})}),b)}function ha({size:e="sm",tooltip:t,isPending:r,disabled:s,className:p,children:c,...N}){let z=F(h,{variant:"secondary",size:e,className:o("gap-1.5 rounded-lg border border-secondary bg-secondary/50 hover:bg-secondary/70 transition-all duration-200",e==="icon"?"size-8":"h-8 px-3",p),disabled:s||r,...N,children:r?F(ga,{className:"animate-spin"}):c});return t?ze(lt,{children:[F(dt,{asChild:!0,children:z}),F(ct,{sideOffset:8,className:"rounded-lg border font-semibold text-foreground bg-secondary [&>span]:hidden",children:F("p",{children:t})})]}):z}function Ca({table:e}){let t=re.useCallback(()=>{e&&e.toggleAllRowsSelected(!1)},[e]);return e?ze("div",{className:"flex h-8 items-center rounded-lg border bg-muted/50 pr-1 pl-3",children:[ze("span",{className:"whitespace-nowrap text-sm font-medium",children:[e.getFilteredSelectedRowModel().rows.length," selected"]}),F(Qe,{orientation:"vertical",className:"mr-2 ml-3 data-[orientation=vertical]:h-4"}),ze(lt,{children:[F(dt,{asChild:!0,children:F(h,{variant:"ghost",size:"icon",className:"size-6 rounded-md",onClick:t,children:F(fa,{className:"size-3.5"})})}),ze(ct,{sideOffset:10,className:"flex items-center gap-2 rounded-lg border px-3 py-2 font-semibold text-foregroun bg-secondary [&>span]:hidden",children:[F("p",{children:"Clear selection"}),F("kbd",{className:"select-none rounded border bg-primary/50 px-2 py-1 font-mono font-normal text-[0.7rem] text-foreground shadow-sm",children:F("abbr",{title:"Escape",className:"no-underline",children:"Esc"})})]})]})]}):null}import{ArrowUpDown as Me,EyeOff as ya}from"lucide-react";import{jsx as $,jsxs as he}from"react/jsx-runtime";function wa({column:e,title:t,className:r}){return e.getCanSort()?$("div",{className:o("flex items-center space-x-2",r),children:he(K,{children:[$(J,{asChild:!0,children:he(h,{variant:"ghost",size:"sm",className:"-ml-3 h-8 data-[state=open]:bg-accent",children:[$("span",{children:t}),e.getIsSorted()==="desc"?$(Me,{className:"ml-2 h-4 w-4"}):e.getIsSorted()==="asc"?$(Me,{className:"ml-2 h-4 w-4"}):$(Me,{className:"ml-2 h-4 w-4"})]})}),he(Q,{align:"start",className:"rounded-lg",children:[he(_,{onClick:()=>e.toggleSorting(!1),children:[$(Me,{className:"mr-2 h-3.5 w-3.5 text-muted-foreground/70"}),"Asc"]}),he(_,{onClick:()=>e.toggleSorting(!0),children:[$(Me,{className:"mr-2 h-3.5 w-3.5 text-muted-foreground/70"}),"Desc"]}),$(U,{}),he(_,{onClick:()=>e.toggleVisibility(!1),children:[$(ya,{className:"mr-2 h-3.5 w-3.5 text-muted-foreground/70"}),"Hide"]})]})]})}):$("div",{className:o(r),children:t})}import{ChevronDown as Pa,Eye as Na}from"lucide-react";import{jsx as Ce,jsxs as wt}from"react/jsx-runtime";function Da({table:e}){return wt(K,{children:[Ce(J,{asChild:!0,children:wt(h,{variant:"outline",size:"sm",className:"rounded-lg",children:[Ce(Na,{className:"mr-2 h-4 w-4"}),"Columns ",Ce(Pa,{className:"ml-2 h-4 w-4"})]})}),wt(Q,{align:"end",className:"w-[200px] rounded-lg",children:[Ce(j,{children:"Toggle Columns"}),Ce(U,{}),e.getAllColumns().filter(t=>typeof t.accessorFn<"u"&&t.getCanHide()).map(t=>Ce(Te,{className:"capitalize",checked:t.getIsVisible(),onCheckedChange:r=>t.toggleVisibility(!!r),children:t.id},t.id))]})]})}import{Slot as Ta}from"radix-ui";import{cva as Sa}from"class-variance-authority";import{jsx as Ra}from"react/jsx-runtime";var ka=Sa("inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-hidden",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90",secondary:"border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90",destructive:"border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",outline:"text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground"}},defaultVariants:{variant:"default"}});function Ye({className:e,variant:t,asChild:r=!1,...s}){let p=r?Ta.Slot:"span";return Ra(p,{"data-slot":"badge",className:o(ka({variant:t}),e),...s})}import{Command as ce}from"cmdk";import{SearchIcon as za}from"lucide-react";import{Dialog as Qr}from"radix-ui";import{XIcon as Zr}from"lucide-react";import{jsx as oi,jsxs as ai}from"react/jsx-runtime";import{jsx as ie,jsxs as Ma}from"react/jsx-runtime";function Zt({className:e,...t}){return ie(ce,{"data-slot":"command",className:o("bg-popover text-popover-foreground flex h-full w-full flex-col overflow-hidden rounded-md",e),...t})}function eo({className:e,...t}){return Ma("div",{"data-slot":"command-input-wrapper",className:"flex h-9 items-center gap-2 border-b px-3",children:[ie(za,{className:"size-4 shrink-0 opacity-50"}),ie(ce.Input,{"data-slot":"command-input",className:o("placeholder:text-muted-foreground flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-hidden disabled:cursor-not-allowed disabled:opacity-50",e),...t})]})}function to({className:e,...t}){return ie(ce.List,{"data-slot":"command-list",className:o("max-h-[300px] scroll-py-1 overflow-x-hidden overflow-y-auto",e),...t})}function oo({...e}){return ie(ce.Empty,{"data-slot":"command-empty",className:"py-6 text-center text-sm",...e})}function Pt({className:e,...t}){return ie(ce.Group,{"data-slot":"command-group",className:o("text-foreground [&_[cmdk-group-heading]]:text-muted-foreground overflow-hidden p-1 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium",e),...t})}function ao({className:e,...t}){return ie(ce.Separator,{"data-slot":"command-separator",className:o("bg-border -mx-1 h-px",e),...t})}function Nt({className:e,...t}){return ie(ce.Item,{"data-slot":"command-item",className:o("data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",e),...t})}import{CheckIcon as Ia,PlusCircleIcon as _a}from"lucide-react";import{Fragment as no,jsx as S,jsxs as se}from"react/jsx-runtime";function Fa({column:e,title:t,options:r}){let s=e?.getFacetedUniqueValues(),p=new Set(e?.getFilterValue());return se(qe,{children:[S(We,{asChild:!0,children:se(h,{variant:"outline",size:"sm",className:"h-9 border-dashed rounded-lg",children:[S(_a,{className:"mr-2 h-4 w-4"}),t,p?.size>0&&se(no,{children:[S(Qe,{orientation:"vertical",className:"mx-2 h-4"}),S(Ye,{variant:"secondary",className:"rounded-sm px-1 font-normal lg:hidden",children:p.size}),S("div",{className:"hidden space-x-1 lg:flex",children:p.size>2?se(Ye,{variant:"secondary",className:"rounded-sm px-1 font-normal",children:[p.size," selected"]}):r.filter(c=>p.has(c.value)).map(c=>S(Ye,{variant:"secondary",className:"rounded-sm px-1 font-normal",children:c.label},c.value))})]})]})}),S(Xe,{className:"w-[200px] p-0 rounded-lg",align:"start",children:se(Zt,{className:"rounded-lg",children:[S(eo,{placeholder:t}),se(to,{children:[S(oo,{children:"No results found."}),S(Pt,{children:r.map(c=>{let N=p.has(c.value);return se(Nt,{onSelect:()=>{N?p.delete(c.value):p.add(c.value);let z=Array.from(p);e?.setFilterValue(z.length?z:void 0)},children:[S("div",{className:o("mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary",N?"bg-primary text-primary-foreground":"opacity-50 [&_svg]:invisible"),children:S(Ia,{className:o("h-4 w-4")})}),c.icon&&S(c.icon,{className:"mr-2 h-4 w-4 text-muted-foreground"}),S("span",{children:c.label}),s?.get(c.value)&&S("span",{className:"ml-auto flex h-4 w-4 items-center justify-center font-mono text-xs",children:s.get(c.value)})]},c.value)})}),p.size>0&&se(no,{children:[S(ao,{}),S(Pt,{children:S(Nt,{onSelect:()=>e?.setFilterValue(void 0),className:"justify-center text-center",children:"Clear filters"})})]})]})]})})]})}export{ma as DataTable,xa as DataTableActionBar,ha as DataTableActionBarAction,Ca as DataTableActionBarSelection,wa as DataTableColumnHeader,Fa as DataTableFacetedFilter,bt as DataTablePagination,ft as DataTableToolbar,Da as DataTableViewOptions};
3
3
  //# sourceMappingURL=index.js.map