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