diff --git a/packages/theme/dist/index.js b/packages/theme/dist/index.js index 2e4c0ab..528e673 100644 --- a/packages/theme/dist/index.js +++ b/packages/theme/dist/index.js @@ -1 +1 @@ -"use strict";var e,r=Object.create,a=Object.defineProperty,t=Object.getOwnPropertyDescriptor,s=Object.getOwnPropertyNames,i=Object.getPrototypeOf,l=Object.prototype.hasOwnProperty,n=(e,r)=>a(e,"name",{value:r,configurable:!0}),o=(e,r,i,n)=>{if(r&&"object"==typeof r||"function"==typeof r)for(let o of s(r))!l.call(e,o)&&o!==i&&a(e,o,{get:()=>r[o],enumerable:!(n=t(r,o))||n.enumerable});return e},d=(e,t,s)=>(s=null!=e?r(i(e)):{},o(!t&&e&&e.__esModule?s:a(s,"default",{value:e,enumerable:!0}),e)),c={};((e,r)=>{for(var t in r)a(e,t,{get:r[t],enumerable:!0})})(c,{Breadcrumbs:()=>ee,CloneButton:()=>k,Combobox:()=>Xa,ConfirmDialog:()=>et,CreateButton:()=>D,CreatePage:()=>ss,DefaultLayout:()=>As,DeleteActionModal:()=>ri,DeleteButton:()=>wt,DeleteContext:()=>ai,DeleteProvider:()=>ti,EditButton:()=>kt,EditPage:()=>os,ExportButton:()=>Tt,Field:()=>tt,Form:()=>nt,ImportButton:()=>At,Link:()=>J,ListButton:()=>Vt,ListPage:()=>ms,ModeToggle:()=>ut,PageHeader:()=>xt,RefreshButton:()=>Ut,SaveButton:()=>Xt,Select:()=>ht,ShowButton:()=>es,ShowPage:()=>js,Sidebar:()=>Nt,Table:()=>Yi,notificationProvider:()=>Os,useNotificationProvider:()=>Es}),module.exports=(e=c,o(a({},"__esModule",{value:!0}),e));var u=require("@radix-ui/react-slot"),m=require("class-variance-authority"),x=d(require("react")),f=require("clsx"),p=require("tailwind-merge");function h(...e){return(0,p.twMerge)((0,f.clsx)(e))}n(h,"cn");var g=require("lucide-react"),j=d(require("react")),b=require("react/jsx-runtime"),v=j.default.forwardRef((({className:e,...r},a)=>(0,b.jsx)(g.RefreshCwIcon,{ref:a,className:h("h-4 w-4 animate-spin",e),...r}))),N=require("react/jsx-runtime"),y=(0,m.cva)("inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50",{variants:{variant:{default:"bg-primary text-primary-foreground shadow hover:bg-primary/90",destructive:"bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90",outline:"border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground",secondary:"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80",ghost:"hover:bg-accent hover:text-accent-foreground",link:"text-primary underline-offset-4 hover:underline"},size:{default:"h-9 px-4 py-2",sm:"h-8 rounded-md px-3 text-xs",lg:"h-10 rounded-md px-8",icon:"h-9 w-9"}},defaultVariants:{variant:"default",size:"default"}}),w=x.forwardRef((({className:e,variant:r,size:a,icon:t=null,loading:s=!1,asChild:i=!1,children:l,disabled:n,...o},d)=>{n=n||s;let c=x.useMemo((()=>x.isValidElement(t)?t:s?(0,N.jsx)(v,{className:"mr-2"}):null),[t,s]);return(0,N.jsx)(i?u.Slot:"button",{className:h(y({variant:r,size:a,className:e})),ref:d,disabled:n,...o,children:"icon"===a?s?(0,N.jsx)(v,{}):l:(0,N.jsxs)(N.Fragment,{children:[c,l]})})}));w.displayName="Button";var C=require("@refinedev/core"),q=require("lucide-react"),S=require("react/jsx-runtime"),k=n((({resource:e,recordItemId:r,hideText:a=!1,accessControl:t,meta:s,onClick:i,children:l,...n})=>{let{to:o,LinkComponent:d,label:c,disabled:u,hidden:m,title:x}=(0,C.useCloneButton)({id:r,resource:e,accessControl:t,meta:s});return m?null:(0,S.jsx)(d,{to:o,replace:!1,onClick:e=>{u?e.preventDefault():i&&(e.preventDefault(),i(e))},children:(0,S.jsx)(w,{disabled:u,title:x,icon:(0,S.jsx)(q.CopyPlus,{className:"mr-2 w-4 h-4"}),...n,children:!a&&(l??c)})})}),"CloneButton");k.displayName="CloneButton";var R=require("@refinedev/core"),I=require("lucide-react"),z=require("react/jsx-runtime"),D=n((({resource:e,hideText:r=!1,accessControl:a,meta:t,onClick:s,children:i,...l})=>{let{hidden:n,disabled:o,label:d,title:c,LinkComponent:u,to:m}=(0,R.useCreateButton)({resource:e,accessControl:a,meta:t});return n?null:(0,z.jsx)(u,{to:m,replace:!1,onClick:e=>{o?e.preventDefault():s&&(e.preventDefault(),s(e))},children:(0,z.jsx)(w,{disabled:o,title:c,icon:(0,z.jsx)(I.SquarePlusIcon,{className:"mr-2 w-4 h-4"}),...l,children:!r&&(i??d)})})}),"CreateButton");D.displayName="CreateButton";var T=require("@refinedev/core"),B=require("lucide-react"),F=d(require("react")),P=require("@radix-ui/react-icons"),L=require("@radix-ui/react-slot"),A=require("react/jsx-runtime"),M=F.forwardRef((({...e},r)=>(0,A.jsx)("nav",{ref:r,"aria-label":"breadcrumb",...e})));M.displayName="Breadcrumb";var O=F.forwardRef((({className:e,...r},a)=>(0,A.jsx)("ol",{ref:a,className:h("flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5",e),...r})));O.displayName="BreadcrumbList";var E=F.forwardRef((({className:e,...r},a)=>(0,A.jsx)("li",{ref:a,className:h("inline-flex items-center gap-1.5",e),...r})));E.displayName="BreadcrumbItem";var V=F.forwardRef((({asChild:e,className:r,...a},t)=>(0,A.jsx)(e?L.Slot:"a",{ref:t,className:h("transition-colors hover:text-foreground",r),...a})));V.displayName="BreadcrumbLink";var _=F.forwardRef((({className:e,...r},a)=>(0,A.jsx)("span",{ref:a,role:"link","aria-disabled":"true","aria-current":"page",className:h("font-normal text-foreground",e),...r})));_.displayName="BreadcrumbPage";var H=n((({children:e,className:r,...a})=>(0,A.jsx)("li",{role:"presentation","aria-hidden":"true",className:h("[&>svg]:size-3.5",r),...a,children:e??(0,A.jsx)(P.ChevronRightIcon,{})})),"BreadcrumbSeparator");H.displayName="BreadcrumbSeparator";var $=n((({className:e,...r})=>(0,A.jsxs)("span",{role:"presentation","aria-hidden":"true",className:h("flex h-9 w-9 items-center justify-center",e),...r,children:[(0,A.jsx)(P.DotsHorizontalIcon,{className:"h-4 w-4"}),(0,A.jsx)("span",{className:"sr-only",children:"More"})]})),"BreadcrumbEllipsis");$.displayName="BreadcrumbElipssis";var U=require("@refinedev/core"),Q=require("react"),G=require("@radix-ui/react-slot"),W=require("@refinedev/core"),K=require("react"),X=require("react/jsx-runtime"),J=(0,K.forwardRef)((({children:e,href:r,title:a,className:t,asChild:s},i)=>{let{Link:l}=(0,W.useRouterContext)(),n=(0,W.useRouterType)(),o=(0,W.useLink)();return(0,X.jsx)(s?G.Slot:"legacy"===n?l:o,{ref:i,to:r,className:t,title:a,children:e})}));J.displayName="Link";var Y=require("lucide-react"),Z=require("react/jsx-runtime"),ee=n((({showHome:e=!0,meta:r})=>{let{breadcrumbs:a}=(0,U.useBreadcrumb)({meta:r}),{hasDashboard:t}=(0,U.useRefineContext)(),{resources:s}=(0,U.useResource)(),i=s[0],l=(0,U.matchResourceFromRoute)("/",s),n=a.map((({label:e,href:r},t)=>(0,Z.jsxs)(Q.Fragment,{children:[(0,Z.jsx)(E,{children:r?(0,Z.jsx)(V,{asChild:!0,href:"#x",children:(0,Z.jsx)(J,{href:r,children:e})}):(0,Z.jsx)(_,{children:e})}),t(0,se.jsx)(ae.Overlay,{className:h("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...r,ref:a})));oe.displayName=ae.Overlay.displayName;var de=te.forwardRef((({className:e,...r},a)=>(0,se.jsxs)(ne,{children:[(0,se.jsx)(oe,{}),(0,se.jsx)(ae.Content,{ref:a,className:h("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",e),...r})]})));de.displayName=ae.Content.displayName;var ce=n((({className:e,...r})=>(0,se.jsx)("div",{className:h("flex flex-col space-y-2 text-center sm:text-left",e),...r})),"AlertDialogHeader");ce.displayName="AlertDialogHeader";var ue=n((({className:e,...r})=>(0,se.jsx)("div",{className:h("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...r})),"AlertDialogFooter");ue.displayName="AlertDialogFooter";var me=te.forwardRef((({className:e,...r},a)=>(0,se.jsx)(ae.Title,{ref:a,className:h("text-lg font-semibold",e),...r})));me.displayName=ae.Title.displayName;var xe=te.forwardRef((({className:e,...r},a)=>(0,se.jsx)(ae.Description,{ref:a,className:h("text-sm text-muted-foreground",e),...r})));xe.displayName=ae.Description.displayName;var fe=te.forwardRef((({className:e,variant:r="default",size:a="default",...t},s)=>(0,se.jsx)(ae.Action,{ref:s,className:h(y({variant:r,size:a}),e),...t})));fe.displayName=ae.Action.displayName;var pe=te.forwardRef((({className:e,variant:r="outline",size:a="default",...t},s)=>(0,se.jsx)(ae.Cancel,{ref:s,className:h(y({variant:r,size:a}),"mt-2 sm:mt-0",e),...t})));pe.displayName=ae.Cancel.displayName;var he=require("class-variance-authority"),ge=require("react/jsx-runtime"),je=(0,he.cva)("inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80",secondary:"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",destructive:"border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80",outline:"text-foreground"}},defaultVariants:{variant:"default"}});function be({className:e,variant:r,...a}){return(0,ge.jsx)("div",{className:h(je({variant:r}),e),...a})}n(be,"Badge");var ve=require("@radix-ui/react-icons"),Ne=require("react-day-picker"),ye=require("react/jsx-runtime");function we({className:e,classNames:r,showOutsideDays:a=!0,...t}){return(0,ye.jsx)(Ne.DayPicker,{showOutsideDays:a,className:h("p-3",e),classNames:{months:"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0",month:"space-y-4",caption:"flex justify-center pt-1 relative items-center",caption_label:"text-sm font-medium",nav:"space-x-1 flex items-center",nav_button:h(y({variant:"outline"}),"h-7 w-7 bg-transparent p-0 opacity-50 hover:opacity-100"),nav_button_previous:"absolute left-1",nav_button_next:"absolute right-1",table:"w-full border-collapse space-y-1",head_row:"flex",head_cell:"text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]",row:"flex w-full mt-2",cell:h("relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected].day-range-end)]:rounded-r-md","range"===t.mode?"[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md":"[&:has([aria-selected])]:rounded-md"),day:h(y({variant:"ghost"}),"h-8 w-8 p-0 font-normal aria-selected:opacity-100"),day_range_start:"day-range-start",day_range_end:"day-range-end",day_selected:"bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground",day_today:"bg-accent text-accent-foreground",day_outside:"day-outside text-muted-foreground opacity-50 aria-selected:bg-accent/50 aria-selected:text-muted-foreground aria-selected:opacity-30",day_disabled:"text-muted-foreground opacity-50",day_range_middle:"aria-selected:bg-accent aria-selected:text-accent-foreground",day_hidden:"invisible",...r},components:{IconLeft:n((()=>(0,ye.jsx)(ve.ChevronLeftIcon,{className:"h-4 w-4"})),"IconLeft"),IconRight:n((()=>(0,ye.jsx)(ve.ChevronRightIcon,{className:"h-4 w-4"})),"IconRight")},...t})}n(we,"Calendar"),we.displayName="Calendar";var Ce=d(require("react")),qe=require("react/jsx-runtime"),Se=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("rounded-xl border bg-card text-card-foreground shadow",e),...r})));Se.displayName="Card";var ke=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("flex flex-col space-y-1.5 p-6",e),...r})));ke.displayName="CardHeader";var Re=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("h3",{ref:a,className:h("font-semibold leading-none tracking-tight",e),...r})));Re.displayName="CardTitle";var Ie=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("p",{ref:a,className:h("text-sm text-muted-foreground",e),...r})));Ie.displayName="CardDescription";var ze=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("p-6 pt-0",e),...r})));ze.displayName="CardContent";var De=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("flex items-center p-6 pt-0",e),...r})));De.displayName="CardFooter";var Te=d(require("react")),Be=d(require("@radix-ui/react-checkbox")),Fe=require("@radix-ui/react-icons"),Pe=require("react/jsx-runtime"),Le=Te.forwardRef((({className:e,...r},a)=>(0,Pe.jsx)(Be.Root,{ref:a,className:h("peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground",e),...r,children:(0,Pe.jsx)(Be.Indicator,{className:h("flex items-center justify-center text-current"),children:(0,Pe.jsx)(Fe.CheckIcon,{className:"h-4 w-4"})})})));Le.displayName=Be.Root.displayName;var Ae=d(require("react")),Me=require("@radix-ui/react-icons"),Oe=require("cmdk"),Ee=d(require("react")),Ve=d(require("@radix-ui/react-dialog")),_e=require("@radix-ui/react-icons"),He=require("react/jsx-runtime"),$e=Ve.Portal,Ue=Ee.forwardRef((({className:e,...r},a)=>(0,He.jsx)(Ve.Overlay,{ref:a,className:h("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...r})));Ue.displayName=Ve.Overlay.displayName;var Qe=Ee.forwardRef((({className:e,children:r,...a},t)=>(0,He.jsxs)($e,{children:[(0,He.jsx)(Ue,{}),(0,He.jsxs)(Ve.Content,{ref:t,className:h("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",e),...a,children:[r,(0,He.jsxs)(Ve.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground",children:[(0,He.jsx)(_e.Cross2Icon,{className:"h-4 w-4"}),(0,He.jsx)("span",{className:"sr-only",children:"Close"})]})]})]})));Qe.displayName=Ve.Content.displayName;var Ge=n((({className:e,...r})=>(0,He.jsx)("div",{className:h("flex flex-col space-y-1.5 text-center sm:text-left",e),...r})),"DialogHeader");Ge.displayName="DialogHeader";var We=n((({className:e,...r})=>(0,He.jsx)("div",{className:h("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...r})),"DialogFooter");We.displayName="DialogFooter";var Ke=Ee.forwardRef((({className:e,...r},a)=>(0,He.jsx)(Ve.Title,{ref:a,className:h("text-lg font-semibold leading-none tracking-tight",e),...r})));Ke.displayName=Ve.Title.displayName;var Xe=Ee.forwardRef((({className:e,...r},a)=>(0,He.jsx)(Ve.Description,{ref:a,className:h("text-sm text-muted-foreground",e),...r})));Xe.displayName=Ve.Description.displayName;var Je=require("react/jsx-runtime"),Ye=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command,{ref:a,className:h("flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",e),...r})));Ye.displayName=Oe.Command.displayName;var Ze=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsxs)("div",{className:"flex items-center border-b px-3","cmdk-input-wrapper":"",children:[(0,Je.jsx)(Me.MagnifyingGlassIcon,{className:"mr-2 h-4 w-4 shrink-0 opacity-50"}),(0,Je.jsx)(Oe.Command.Input,{ref:a,className:h("flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50",e),...r})]})));Ze.displayName=Oe.Command.Input.displayName;var er=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.List,{ref:a,className:h("max-h-[300px] overflow-y-auto overflow-x-hidden",e),...r})));er.displayName=Oe.Command.List.displayName;var rr=Ae.forwardRef(((e,r)=>(0,Je.jsx)(Oe.Command.Empty,{ref:r,className:"py-6 text-center text-sm",...e})));rr.displayName=Oe.Command.Empty.displayName;var ar=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.Group,{ref:a,className:h("overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",e),...r})));ar.displayName=Oe.Command.Group.displayName;var tr=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.Separator,{ref:a,className:h("-mx-1 h-px bg-border",e),...r})));tr.displayName=Oe.Command.Separator.displayName;var sr=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.Item,{ref:a,className:h("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50",e),...r})));sr.displayName=Oe.Command.Item.displayName;var ir=n((({className:e,...r})=>(0,Je.jsx)("span",{className:h("ml-auto text-xs tracking-widest text-muted-foreground",e),...r})),"CommandShortcut");ir.displayName="CommandShortcut";var lr=d(require("react")),nr=d(require("@radix-ui/react-dropdown-menu")),or=require("@radix-ui/react-icons"),dr=require("react/jsx-runtime"),cr=nr.Root,ur=nr.Trigger,mr=lr.forwardRef((({className:e,inset:r,children:a,...t},s)=>(0,dr.jsxs)(nr.SubTrigger,{ref:s,className:h("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent",r&&"pl-8",e),...t,children:[a,(0,dr.jsx)(or.ChevronRightIcon,{className:"ml-auto h-4 w-4"})]})));mr.displayName=nr.SubTrigger.displayName;var xr=lr.forwardRef((({className:e,...r},a)=>(0,dr.jsx)(nr.SubContent,{ref:a,className:h("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg 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",e),...r})));xr.displayName=nr.SubContent.displayName;var fr=lr.forwardRef((({className:e,sideOffset:r=4,...a},t)=>(0,dr.jsx)(nr.Portal,{children:(0,dr.jsx)(nr.Content,{ref:t,sideOffset:r,className:h("z-50 min-w-[8rem] overflow-hidden rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md","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",e),...a})})));fr.displayName=nr.Content.displayName;var pr=lr.forwardRef((({className:e,inset:r,...a},t)=>(0,dr.jsx)(nr.Item,{ref:t,className:h("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",r&&"pl-8",e),...a})));pr.displayName=nr.Item.displayName;var hr=lr.forwardRef((({className:e,children:r,checked:a,...t},s)=>(0,dr.jsxs)(nr.CheckboxItem,{ref:s,className:h("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:a,...t,children:[(0,dr.jsx)("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:(0,dr.jsx)(nr.ItemIndicator,{children:(0,dr.jsx)(or.CheckIcon,{className:"h-4 w-4"})})}),r]})));hr.displayName=nr.CheckboxItem.displayName;var gr=lr.forwardRef((({className:e,children:r,...a},t)=>(0,dr.jsxs)(nr.RadioItem,{ref:t,className:h("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...a,children:[(0,dr.jsx)("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:(0,dr.jsx)(nr.ItemIndicator,{children:(0,dr.jsx)(or.DotFilledIcon,{className:"h-4 w-4 fill-current"})})}),r]})));gr.displayName=nr.RadioItem.displayName;var jr=lr.forwardRef((({className:e,inset:r,...a},t)=>(0,dr.jsx)(nr.Label,{ref:t,className:h("px-2 py-1.5 text-sm font-semibold",r&&"pl-8",e),...a})));jr.displayName=nr.Label.displayName;var br=lr.forwardRef((({className:e,...r},a)=>(0,dr.jsx)(nr.Separator,{ref:a,className:h("-mx-1 my-1 h-px bg-muted",e),...r})));br.displayName=nr.Separator.displayName;var vr=n((({className:e,...r})=>(0,dr.jsx)("span",{className:h("ml-auto text-xs tracking-widest opacity-60",e),...r})),"DropdownMenuShortcut");vr.displayName="DropdownMenuShortcut";var Nr=d(require("react")),yr=require("@radix-ui/react-slot"),wr=require("react-hook-form"),Cr=d(require("react")),qr=d(require("@radix-ui/react-label")),Sr=require("class-variance-authority"),kr=require("react/jsx-runtime"),Rr=(0,Sr.cva)("text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"),Ir=Cr.forwardRef((({className:e,...r},a)=>(0,kr.jsx)(qr.Root,{ref:a,className:h(Rr(),e),...r})));Ir.displayName=qr.Root.displayName;var zr=require("react/jsx-runtime"),Dr=wr.FormProvider,Tr=Nr.createContext({}),Br=n((({...e})=>(0,zr.jsx)(Tr.Provider,{value:{name:e.name},children:(0,zr.jsx)(wr.Controller,{...e})})),"FormField"),Fr=n((()=>{let e=Nr.useContext(Tr),r=Nr.useContext(Pr),{getFieldState:a,formState:t}=(0,wr.useFormContext)(),s=a(e.name,t);if(!e)throw new Error("useFormField should be used within ");let{id:i}=r;return{id:i,name:e.name,formItemId:`${i}-form-item`,formDescriptionId:`${i}-form-item-description`,formMessageId:`${i}-form-item-message`,...s}}),"useFormField"),Pr=Nr.createContext({}),Lr=Nr.forwardRef((({className:e,...r},a)=>{let t=Nr.useId();return(0,zr.jsx)(Pr.Provider,{value:{id:t},children:(0,zr.jsx)("div",{ref:a,className:h("space-y-2",e),...r})})}));Lr.displayName="FormItem";var Ar=Nr.forwardRef((({className:e,...r},a)=>{let{error:t,formItemId:s}=Fr();return(0,zr.jsx)(Ir,{ref:a,className:h(t&&"text-destructive",e),htmlFor:s,...r})}));Ar.displayName="FormLabel";var Mr=Nr.forwardRef((({...e},r)=>{let{error:a,formItemId:t,formDescriptionId:s,formMessageId:i}=Fr();return(0,zr.jsx)(yr.Slot,{ref:r,id:t,"aria-describedby":a?`${s} ${i}`:`${s}`,"aria-invalid":!!a,...e})}));Mr.displayName="FormControl";var Or=Nr.forwardRef((({className:e,...r},a)=>{let{formDescriptionId:t}=Fr();return(0,zr.jsx)("p",{ref:a,id:t,className:h("text-[0.8rem] text-muted-foreground",e),...r})}));Or.displayName="FormDescription";var Er=Nr.forwardRef((({className:e,children:r,...a},t)=>{let{error:s,formMessageId:i}=Fr(),l=s?String(s?.message):r;return l?(0,zr.jsx)("p",{ref:t,id:i,className:h("text-[0.8rem] font-medium text-destructive",e),...a,children:l}):null}));Er.displayName="FormMessage";var Vr=d(require("react")),_r=require("react/jsx-runtime"),Hr=Vr.forwardRef((({className:e,type:r,...a},t)=>(0,_r.jsx)("input",{type:r,className:h("flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",e),ref:t,...a})));Hr.displayName="Input";var $r=d(require("react")),Ur=d(require("@radix-ui/react-popover")),Qr=require("react/jsx-runtime"),Gr=Ur.Root,Wr=Ur.Trigger,Kr=$r.forwardRef((({className:e,align:r="center",sideOffset:a=4,...t},s)=>(0,Qr.jsx)(Ur.Portal,{children:(0,Qr.jsx)(Ur.Content,{ref:s,align:r,sideOffset:a,className:h("z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none 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",e),...t})})));Kr.displayName=Ur.Content.displayName;var Xr=require("@radix-ui/react-icons"),Jr=d(require("react-resizable-panels")),Yr=require("react/jsx-runtime"),Zr=n((({className:e,...r})=>(0,Yr.jsx)(Jr.PanelGroup,{className:h("flex h-full w-full data-[panel-group-direction=vertical]:flex-col",e),...r})),"ResizablePanelGroup"),ea=Jr.Panel,ra=n((({withHandle:e,className:r,...a})=>(0,Yr.jsx)(Jr.PanelResizeHandle,{className:h("relative flex w-px items-center justify-center bg-border after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring focus-visible:ring-offset-1 data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:-translate-y-1/2 data-[panel-group-direction=vertical]:after:translate-x-0 [&[data-panel-group-direction=vertical]>div]:rotate-90",r),...a,children:e&&(0,Yr.jsx)("div",{className:"z-10 flex h-4 w-3 items-center justify-center rounded-sm border bg-border",children:(0,Yr.jsx)(Xr.DragHandleDots2Icon,{className:"h-2.5 w-2.5"})})})),"ResizableHandle"),aa=d(require("react")),ta=d(require("@radix-ui/react-scroll-area")),sa=require("react/jsx-runtime"),ia=aa.forwardRef((({className:e,children:r,...a},t)=>(0,sa.jsxs)(ta.Root,{ref:t,className:h("relative overflow-hidden",e),...a,children:[(0,sa.jsx)(ta.Viewport,{className:"h-full w-full rounded-[inherit]",children:r}),(0,sa.jsx)(la,{}),(0,sa.jsx)(ta.Corner,{})]})));ia.displayName=ta.Root.displayName;var la=aa.forwardRef((({className:e,orientation:r="vertical",...a},t)=>(0,sa.jsx)(ta.ScrollAreaScrollbar,{ref:t,orientation:r,className:h("flex touch-none select-none transition-colors","vertical"===r&&"h-full w-2.5 border-l border-l-transparent p-[1px]","horizontal"===r&&"h-2.5 flex-col border-t border-t-transparent p-[1px]",e),...a,children:(0,sa.jsx)(ta.ScrollAreaThumb,{className:"relative flex-1 rounded-full bg-border"})})));la.displayName=ta.ScrollAreaScrollbar.displayName;var na=d(require("react")),oa=require("@radix-ui/react-icons"),da=d(require("@radix-ui/react-select")),ca=require("react/jsx-runtime"),ua=da.Root,ma=da.Value,xa=na.forwardRef((({className:e,children:r,...a},t)=>(0,ca.jsxs)(da.Trigger,{ref:t,className:h("flex h-9 w-full items-center justify-between whitespace-nowrap rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-1 focus:ring-ring disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1",e),...a,children:[r,(0,ca.jsx)(da.Icon,{asChild:!0,children:(0,ca.jsx)(oa.CaretSortIcon,{className:"h-4 w-4 opacity-50"})})]})));xa.displayName=da.Trigger.displayName;var fa=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.ScrollUpButton,{ref:a,className:h("flex cursor-default items-center justify-center py-1",e),...r,children:(0,ca.jsx)(oa.ChevronUpIcon,{})})));fa.displayName=da.ScrollUpButton.displayName;var pa=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.ScrollDownButton,{ref:a,className:h("flex cursor-default items-center justify-center py-1",e),...r,children:(0,ca.jsx)(oa.ChevronDownIcon,{})})));pa.displayName=da.ScrollDownButton.displayName;var ha=na.forwardRef((({className:e,children:r,position:a="popper",...t},s)=>(0,ca.jsx)(da.Portal,{children:(0,ca.jsxs)(da.Content,{ref:s,className:h("relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md 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","popper"===a&&"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,...t,children:[(0,ca.jsx)(fa,{}),(0,ca.jsx)(da.Viewport,{className:h("p-1","popper"===a&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]"),children:r}),(0,ca.jsx)(pa,{})]})})));ha.displayName=da.Content.displayName;var ga=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.Label,{ref:a,className:h("px-2 py-1.5 text-sm font-semibold",e),...r})));ga.displayName=da.Label.displayName;var ja=na.forwardRef((({className:e,children:r,...a},t)=>(0,ca.jsxs)(da.Item,{ref:t,className:h("relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...a,children:[(0,ca.jsx)("span",{className:"absolute right-2 flex h-3.5 w-3.5 items-center justify-center",children:(0,ca.jsx)(da.ItemIndicator,{children:(0,ca.jsx)(oa.CheckIcon,{className:"h-4 w-4"})})}),(0,ca.jsx)(da.ItemText,{children:r})]})));ja.displayName=da.Item.displayName;var ba=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.Separator,{ref:a,className:h("-mx-1 my-1 h-px bg-muted",e),...r})));ba.displayName=da.Separator.displayName;var va=d(require("react")),Na=d(require("@radix-ui/react-separator")),ya=require("react/jsx-runtime"),wa=va.forwardRef((({className:e,orientation:r="horizontal",decorative:a=!0,...t},s)=>(0,ya.jsx)(Na.Root,{ref:s,decorative:a,orientation:r,className:h("shrink-0 bg-border","horizontal"===r?"h-[1px] w-full":"h-full w-[1px]",e),...t})));wa.displayName=Na.Root.displayName;var Ca=require("next-themes"),qa=require("sonner"),Sa=require("react/jsx-runtime"),ka=n((({...e})=>{let{theme:r="system"}=(0,Ca.useTheme)();return(0,Sa.jsx)(qa.Toaster,{theme:r,className:"toaster group",toastOptions:{classNames:{toast:"group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg",description:"group-[.toast]:text-muted-foreground",actionButton:"group-[.toast]:bg-primary group-[.toast]:text-primary-foreground",cancelButton:"group-[.toast]:bg-muted group-[.toast]:text-muted-foreground"}},...e})}),"Toaster"),Ra=d(require("react")),Ia=require("react/jsx-runtime"),za=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("div",{className:"relative w-full overflow-auto",children:(0,Ia.jsx)("table",{ref:a,className:h("w-full caption-bottom text-sm",e),...r})})));za.displayName="Table";var Da=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("thead",{ref:a,className:h("[&_tr]:border-b",e),...r})));Da.displayName="TableHeader";var Ta=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("tbody",{ref:a,className:h("[&_tr:last-child]:border-0",e),...r})));Ta.displayName="TableBody";var Ba=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("tfoot",{ref:a,className:h("border-t bg-muted/50 font-medium [&>tr]:last:border-b-0",e),...r})));Ba.displayName="TableFooter";var Fa=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("tr",{ref:a,className:h("border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted",e),...r})));Fa.displayName="TableRow";var Pa=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("th",{ref:a,className:h("h-10 px-2 text-left align-middle font-medium text-muted-foreground [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",e),...r})));Pa.displayName="TableHead";var La=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("td",{ref:a,className:h("p-2 align-middle [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",e),...r})));La.displayName="TableCell";var Aa=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("caption",{ref:a,className:h("mt-4 text-sm text-muted-foreground",e),...r})));Aa.displayName="TableCaption";var Ma=d(require("react")),Oa=require("react/jsx-runtime"),Ea=Ma.forwardRef((({className:e,...r},a)=>(0,Oa.jsx)("textarea",{className:h("flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",e),ref:a,...r})));Ea.displayName="Textarea";var Va=d(require("react")),_a=d(require("@radix-ui/react-tooltip")),Ha=require("react/jsx-runtime"),$a=_a.Provider,Ua=_a.Root,Qa=_a.Trigger,Ga=Va.forwardRef((({className:e,sideOffset:r=4,...a},t)=>(0,Ha.jsx)(_a.Content,{ref:t,sideOffset:r,className:h("z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs 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",e),...a})));Ga.displayName=_a.Content.displayName;var Wa=require("react"),Ka=require("react/jsx-runtime"),Xa=(0,Wa.forwardRef)((({...e},r)=>{let[a,t]=(0,Wa.useState)(!1),s=n((()=>"object"==typeof e.value&&"id"in e.value?e.value.id:e.value),"value");return(0,Ka.jsxs)(Gr,{open:a,onOpenChange:t,children:[(0,Ka.jsx)(Wr,{asChild:!0,children:(0,Ka.jsx)(Mr,{children:(0,Ka.jsxs)(w,{disabled:e.disabled,variant:"outline",role:"combobox","aria-expanded":a,className:h("w-full sm:w-[250px] flex justify-between",!s()&&"text-muted-foreground"),children:[s()?e.options?.find((e=>e.value===s()))?.label:e.placeholder??"Select",(0,Ka.jsx)(re.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})})}),(0,Ka.jsx)(Kr,{className:"w-full max-w-full sm:w-[250px] p-0",children:(0,Ka.jsxs)(Ye,{className:"rounded-lg border shadow-md",ref:r,children:[(0,Ka.jsx)(Ze,{placeholder:"Type a command or search..."}),(0,Ka.jsxs)(er,{children:[(0,Ka.jsx)(rr,{children:"No results found."}),(0,Ka.jsx)(ar,{heading:"Suggestions",children:(0,Ka.jsx)(ia,{className:"max-h-52 overflow-y-auto",children:e.options?.map((r=>(0,Ka.jsxs)(sr,{value:r.label,onSelect:()=>{e.onChange?.(r.value),t(!1)},children:[r.label,(0,Ka.jsx)(re.CheckIcon,{className:h("ml-auto h-4 w-4",r.value===s()?"opacity-100":"opacity-0")})]},r.value)))})})]})]})})]})}));Xa.displayName="Combobox";var Ja=require("lucide-react"),Ya=require("react"),Za=require("react/jsx-runtime"),et=n((({children:e,title:r="Are you sure?",description:a="This action cannot be undone.",okText:t="Ok",cancelText:s="Cancel",okButtonSize:i="default",cancelButtonSize:l="default",okButtonVariant:n="default",cancelButtonVariant:o="outline",loading:d=!1,okIconSide:c="left",cancelIconSide:u="left",onConfirm:m,okIcon:x,cancelIcon:f,open:p,onOpenChange:h,defaultOpen:g})=>{let j=(0,Ya.useMemo)((()=>(0,Ya.isValidElement)(f)?f:(0,Za.jsx)(Ja.XIcon,{className:"mr-2 h-4 w-4"})),[f]),b=(0,Ya.useMemo)((()=>d?(0,Za.jsx)(v,{className:"mr-2"}):(0,Ya.isValidElement)(x)?x:(0,Za.jsx)(Ja.CheckIcon,{className:"mr-2 h-4 w-4"})),[x,d]);return(0,Za.jsxs)(ie,{open:p,onOpenChange:h,defaultOpen:g,children:[(0,Za.jsx)(le,{asChild:!0,children:e}),(0,Za.jsxs)(de,{children:[(0,Za.jsxs)(ce,{children:[(0,Za.jsx)(me,{children:r}),(0,Za.jsx)(xe,{children:a})]}),(0,Za.jsxs)(ue,{children:[(0,Za.jsxs)(pe,{variant:o,size:l,disabled:d,children:["left"===u&&j,s,"right"===u&&j]}),(0,Za.jsxs)(fe,{variant:n,size:i,disabled:d,onClick:m,children:["left"===c&&b,t,"right"===c&&b]})]})]})]})}),"ConfirmDialog");et.displayName="ConfirmDialog";var rt=require("react"),at=require("react/jsx-runtime"),tt=n((e=>(0,at.jsx)(Br,{control:e.control,name:e.name,render:({field:r})=>(0,at.jsxs)(Lr,{className:h(e.className,e.isCheckbox?"flex flex-row items-center space-x-3 space-y-0":""),children:[!e.isCheckbox&&(0,at.jsx)(Ar,{children:e.label}),(0,at.jsx)(Mr,{children:(0,rt.cloneElement)(e.children,{...r,...e.children.props})}),e.isCheckbox&&(0,at.jsx)(Ar,{className:"text-sm font-normal",children:e.label}),e.description&&(0,at.jsx)(Or,{children:e.description}),(0,at.jsx)(Er,{})]})})),"Field"),st=require("@refinedev/core"),it=require("react"),lt=require("react/jsx-runtime"),nt=n((({formProps:e,isWatchable:r,saveButtonProps:a,...t})=>{let s=(0,it.useRef)(!1),{resource:i,action:l}=(0,st.useParsed)(),n=(0,st.useRouterType)(),o=(0,st.useBack)(),{goBack:d}=(0,st.useNavigation)(),c="list"!==l||typeof l<"u"?"legacy"===n?d:o:void 0;r&&!s.current&&(s.current=!0,t.watch());let u=t.handleSubmit((e=>{t.refineCore.onFinish(t.getValues()).then()}));return(0,lt.jsx)(Dr,{...t,children:(0,lt.jsx)("form",{...e,onSubmit:u,children:(0,lt.jsxs)(Se,{className:"border-border/40 shadow-sm",children:[(0,lt.jsx)(ze,{className:"pt-6 space-y-4",children:t.children}),(0,lt.jsxs)(De,{className:"flex justify-end gap-x-4",children:[(0,lt.jsx)(w,{type:"button",onClick:c,disabled:t.refineCore.formLoading,variant:"outline",children:"Cancel"}),(0,lt.jsx)(Xt,{type:"submit",loading:t.refineCore.formLoading,...a})]})]})})})}),"Form"),ot=require("next-themes"),dt=require("@radix-ui/react-icons"),ct=require("react/jsx-runtime"),ut=n((()=>{let{setTheme:e}=(0,ot.useTheme)();return(0,ct.jsxs)(cr,{children:[(0,ct.jsx)(ur,{asChild:!0,children:(0,ct.jsxs)(w,{variant:"ghost",size:"icon",children:[(0,ct.jsx)(dt.SunIcon,{className:"h-[1.2rem] w-[1.2rem] rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0"}),(0,ct.jsx)(dt.MoonIcon,{className:"absolute h-[1.2rem] w-[1.2rem] rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100"}),(0,ct.jsx)("span",{className:"sr-only",children:"Toggle theme"})]})}),(0,ct.jsxs)(fr,{align:"end",children:[(0,ct.jsx)(pr,{onClick:()=>e("light"),children:"Light"}),(0,ct.jsx)(pr,{onClick:()=>e("dark"),children:"Dark"}),(0,ct.jsx)(pr,{onClick:()=>e("system"),children:"System"})]})]})}),"ModeToggle"),mt=require("react/jsx-runtime"),xt=n((({extra:e,...r})=>(0,mt.jsx)("div",{className:"w-full",children:(0,mt.jsxs)("div",{className:h("flex h-20 items-end lg:justify-between",r.className,!r.breadcrumb&&"h-auto"),children:[(0,mt.jsxs)("div",{className:"min-w-0 flex-1",children:[r.breadcrumb,(0,mt.jsx)("div",{className:"inline-flex flex-row items-center gap-x-4 mt-3",children:(0,mt.jsxs)("div",{className:"inline-flex flex-col",children:[(0,mt.jsx)("h2",{className:"text-2xl font-bold leading-7 text-black dark:text-white sm:truncate sm:text-3xl sm:tracking-tight",children:r.title}),r.subTitle&&(0,mt.jsx)("div",{className:"mt-2 flex items-center text-sm text-gray-300",children:r.subTitle})]})})]}),(0,mt.jsx)("div",{className:"flex lg:ml-4 lg:mt-0",children:e})]})})),"PageHeader"),ft=d(require("react")),pt=require("react/jsx-runtime"),ht=(0,ft.forwardRef)((({...e},r)=>{let a=ft.default.useRef(null);return(0,pt.jsxs)(ua,{disabled:e.disabled||0===e.options?.length,onValueChange:e.onChange,defaultValue:e.value,value:e.value,children:[(0,pt.jsx)(Mr,{children:(0,pt.jsx)(xa,{ref:a,children:(0,pt.jsx)(ma,{placeholder:e.placeholder??"Select"})})}),(0,pt.jsx)(ha,{style:{width:a.current?.offsetWidth},ref:r,children:e.options?.map(((e,r)=>(0,pt.jsx)(ja,{value:e.value,children:e.label},r)))})]})}));ht.displayName="Select";var gt=require("@refinedev/core"),jt=require("react-use"),bt=d(require("react")),vt=require("react/jsx-runtime"),Nt=n((({isCollapsed:e})=>{let{menuItems:r}=(0,gt.useMenu)(),a=(0,gt.useResourceParams)(),{pathname:t}=(0,jt.useLocation)(),s=String(t),i=n((e=>{let r=e.meta?.icon;return bt.default.isValidElement(r)?bt.default.cloneElement(r,{className:"mr-2 w-4 h-4"}):null}),"GetIcon");return(0,vt.jsx)("div",{"data-collapsed":e,className:"group flex flex-col gap-4 py-2 justify-between h-[94dvh] xl:h-[84dvh] data-[collapsed=true]:py-2",children:(0,vt.jsx)("nav",{className:"grid gap-1 px-2 group-[[data-collapsed=true]]:justify-center group-[[data-collapsed=true]]:px-2",children:r.filter((e=>!e.meta?.hide)).map(((r,t)=>{let l=[r.list?.toString(),r.create?.toString(),r.edit?.toString()?.replace(":id",a.id),r.show?.toString()?.replace(":id",a.id)].filter(Boolean),n=l.includes(s)||l.some((e=>e?.startsWith(s)||s.startsWith(e)));return e?(0,vt.jsxs)(Ua,{delayDuration:0,children:[(0,vt.jsx)(Qa,{asChild:!0,children:(0,vt.jsxs)(J,{href:r.list?.toString()??"/#",title:r.meta?.title??r.name,className:h(y({variant:"ghost"}),"justify-start",n?"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground":""),children:[r.meta?.icon,(0,vt.jsxs)("span",{className:"sr-only",children:[r.meta?.title??r.label," ",r.list?"List":"Create"]})]},t)}),(0,vt.jsxs)(Ga,{side:"right",className:"flex items-center gap-4",children:[r.label,r.meta?.label&&(0,vt.jsx)("span",{className:"ml-auto text-muted-foreground",children:r.meta?.label})]})]},t):(0,vt.jsxs)(J,{href:r.list?.toString()??"/#",title:r.meta?.title??r.name,className:h(y({variant:"ghost"}),"justify-start",n?"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground":""),children:[i(r),r.meta?.title??r.name]},t)}))})})}),"Sidebar");Nt.displayName="Sidebar";var yt=require("react/jsx-runtime"),wt=n((({resource:e,recordItemId:r,onSuccess:a,mutationMode:t,confirmTitle:s,confirmDescription:i,successNotification:l,errorNotification:n,hideText:o=!1,accessControl:d,meta:c,dataProviderName:u,confirmOkText:m,confirmCancelText:x,invalidates:f,children:p,...h})=>{let{title:g,label:j,hidden:b,disabled:v,loading:N,confirmTitle:y,confirmOkLabel:C,cancelLabel:q,onConfirm:S}=(0,T.useDeleteButton)({resource:e,id:r,dataProviderName:u,invalidates:f,meta:c,onSuccess:a,mutationMode:t,errorNotification:n,successNotification:l,accessControl:d});return b?null:(0,yt.jsx)(et,{okText:m??C,cancelText:x??q,okButtonVariant:"destructive",cancelButtonVariant:"outline",title:s??y,description:i,loading:N,onConfirm:S,children:(0,yt.jsx)(w,{disabled:v,title:g,loading:N,icon:(0,yt.jsx)(B.Trash2Icon,{className:"mr-2 w-4 h-4"}),...h,children:!o&&(p??j)})})}),"DeleteButton");wt.displayName="DeleteButton";var Ct=require("@refinedev/core"),qt=require("lucide-react"),St=require("react/jsx-runtime"),kt=n((({resource:e,recordItemId:r,hideText:a=!1,accessControl:t,meta:s,onClick:i,children:l,...n})=>{let{hidden:o,disabled:d,label:c,title:u,LinkComponent:m,to:x}=(0,Ct.useEditButton)({resource:e,id:r,accessControl:t,meta:s});return o?null:(0,St.jsx)(m,{to:x,replace:!1,onClick:e=>{d?e.preventDefault():i&&(e.preventDefault(),i(e))},children:(0,St.jsx)(w,{disabled:d,title:u,icon:(0,St.jsx)(qt.SquarePenIcon,{className:"mr-2 w-4 h-4"}),...n,children:!a&&(l??c)})})}),"EditButton");kt.displayName="EditButton";var Rt=require("@radix-ui/react-slot"),It=require("@refinedev/core"),zt=require("lucide-react"),Dt=require("react/jsx-runtime"),Tt=n((({hideText:e=!1,resource:r,recordItemId:a,accessControl:t,access:s,children:i,...l})=>{let{label:n}=(0,It.useExportButton)(),o=t?.enabled?It.CanAccess:Rt.Slot;return t?.hideIfUnauthorized&&t.enabled?null:(0,Dt.jsx)(o,{params:{id:a},resource:r,action:"export",...s,children:(0,Dt.jsx)(w,{icon:(0,Dt.jsx)(zt.ShareIcon,{className:"mr-2 w-4 h-4"}),...l,children:!e&&(i??n)})})}),"ExportButton");Tt.displayName="ExportButton";var Bt=require("@radix-ui/react-slot"),Ft=require("@refinedev/core"),Pt=require("lucide-react"),Lt=require("react/jsx-runtime"),At=n((({hideText:e=!1,resource:r,onChange:a,accept:t="image/*,application/*",recordItemId:s,accessControl:i,access:l,children:o,...d})=>{let{label:c}=(0,Ft.useImportButton)(),u=i?.enabled?Ft.CanAccess:Bt.Slot,m=n((()=>{let e=document.createElement("input");e.type="file",e.accept=t,e.onchange=r=>{r.target instanceof HTMLInputElement&&(a(Array.from(r.target.files??[])),e.remove())},e.click()}),"onClick");return i?.hideIfUnauthorized&&i.enabled?null:(0,Lt.jsx)(u,{params:{id:s},resource:r,action:"import",...l,children:(0,Lt.jsx)(w,{onClick:m,icon:(0,Lt.jsx)(Pt.ImportIcon,{className:"mr-2 w-4 h-4"}),...d,children:!e&&(o??c)})})}),"ImportButton");At.displayName="ImportButton";var Mt=require("@refinedev/core"),Ot=require("lucide-react"),Et=require("react/jsx-runtime"),Vt=n((({resource:e,hideText:r=!1,accessControl:a,meta:t,children:s,onClick:i,...l})=>{let{hidden:n,disabled:o,label:d,title:c,LinkComponent:u,to:m}=(0,Mt.useListButton)({resource:e,accessControl:a,meta:t});return n?null:(0,Et.jsx)(u,{to:m,replace:!1,onClick:e=>{o?e.preventDefault():i&&(e.preventDefault(),i(e))},children:(0,Et.jsx)(w,{disabled:o,title:c,icon:(0,Et.jsx)(Ot.ListIcon,{className:"mr-2 w-4 h-4"}),...l,children:!r&&(s??d)})})}),"ListButton");Vt.displayName="ListButton";var _t=require("@refinedev/core"),Ht=require("lucide-react"),$t=require("react/jsx-runtime"),Ut=n((({resource:e,recordItemId:r,hideText:a=!1,dataProviderName:t,children:s,...i})=>{let{onClick:l,label:n,loading:o}=(0,_t.useRefreshButton)({resource:e,id:r,dataProviderName:t});return(0,$t.jsx)(w,{onClick:l,loading:o,icon:(0,$t.jsx)(Ht.RefreshCwIcon,{className:"mr-2 w-4 h-4"}),...i,children:!a&&(s??n)})}),"RefreshButton");Ut.displayName="RefreshButton";var Qt=require("@radix-ui/react-slot"),Gt=require("@refinedev/core"),Wt=require("lucide-react"),Kt=require("react/jsx-runtime"),Xt=n((({hideText:e=!1,children:r,accessControl:a,access:t,resource:s,recordItemId:i,...l})=>{let{label:n}=(0,Gt.useSaveButton)(),o=a?.enabled?Gt.CanAccess:Qt.Slot;return a?.hideIfUnauthorized&&a.enabled?null:(0,Kt.jsx)(o,{params:{id:i},resource:s,action:"save",...t,children:(0,Kt.jsx)(w,{icon:(0,Kt.jsx)(Wt.SaveIcon,{className:"mr-2 w-4 h-4"}),...l,children:!e&&(r??n)})})}),"SaveButton");Xt.displayName="SaveButton";var Jt=require("@refinedev/core"),Yt=require("lucide-react"),Zt=require("react/jsx-runtime"),es=n((({resource:e,recordItemId:r,hideText:a=!1,accessControl:t,meta:s,children:i,onClick:l,...n})=>{let{to:o,label:d,title:c,hidden:u,disabled:m,LinkComponent:x}=(0,Jt.useShowButton)({resource:e,id:r,accessControl:t,meta:s});return u?null:(0,Zt.jsx)(x,{to:o,replace:!1,onClick:e=>{m?e.preventDefault():l&&(e.preventDefault(),l(e))},children:(0,Zt.jsx)(w,{icon:(0,Zt.jsx)(Yt.EyeIcon,{className:"mr-2 w-4 h-4"}),title:c,disabled:m,...n,children:!a&&(i??d)})})}),"ShowButton");es.displayName="ShowButton";var rs=require("@refinedev/core"),as=require("react"),ts=require("react/jsx-runtime"),ss=n((({title:e,resource:r,breadcrumb:a,extra:t,children:s})=>{let i=(0,rs.useTranslate)(),{options:{breadcrumb:l}={}}=(0,rs.useRefineContext)(),n=(0,rs.useUserFriendlyName)(),{resource:o,identifier:d}=(0,rs.useResource)(r),c=typeof a>"u"?l:a;return(0,ts.jsxs)(ts.Fragment,{children:[(0,ts.jsx)(xt,{title:e??i(`${d}.titles.List`,`Create ${n(o?.meta?.label??d,"singular")}`),isBack:!0,breadcrumb:(0,as.isValidElement)(c)?c:(0,ts.jsx)(ee,{}),extra:t??(0,ts.jsx)(ts.Fragment,{children:(0,ts.jsx)(Vt,{resource:r})})}),(0,ts.jsx)("div",{className:"pt-4 !mt-0",children:s})]})}),"CreatePage");ss.displayName="CreatePage";var is=require("@refinedev/core"),ls=require("react"),ns=require("react/jsx-runtime"),os=n((({title:e,resource:r,extra:a,breadcrumb:t,children:s})=>{let i=(0,is.useTranslate)(),{options:{breadcrumb:l}={}}=(0,is.useRefineContext)(),{list:n}=(0,is.useNavigation)(),o=(0,is.useUserFriendlyName)(),{resource:d,identifier:c}=(0,is.useResource)(r),u=typeof t>"u"?l:t;return(0,ns.jsxs)(ns.Fragment,{children:[(0,ns.jsx)(xt,{title:e??i(`${c}.titles.List`,`Edit ${o(d?.meta?.label??c,"plural")}`),isBack:!0,breadcrumb:(0,ls.isValidElement)(u)?u:(0,ns.jsx)(ee,{}),extra:a??(0,ns.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-2",children:[(0,ns.jsx)(es,{resource:r}),(0,ns.jsx)(wt,{resource:r,onSuccess:()=>{n(d?.name)}})]})}),(0,ns.jsx)("div",{className:"pt-4",children:s})]})}),"EditPage");os.displayName="EditPage";var ds=require("@refinedev/core"),cs=require("react"),us=require("react/jsx-runtime"),ms=n((({title:e,resource:r,breadcrumb:a,createButtonProps:t,className:s,isCreate:i=!0,extra:l,children:n})=>{let o=(0,ds.useTranslate)(),{options:{breadcrumb:d}={}}=(0,ds.useRefineContext)(),c=(0,ds.useUserFriendlyName)(),{resource:u,identifier:m}=(0,ds.useResource)(r),x=typeof a>"u"?d:a;return(0,us.jsxs)(us.Fragment,{children:[(0,us.jsx)(xt,{title:e??o(`${m}.titles.List`,`List ${c(u?.meta?.label??m,"plural")}`),breadcrumb:(0,cs.isValidElement)(x)?x:(0,us.jsx)(ee,{}),extra:l??(0,us.jsx)(us.Fragment,{children:(0,us.jsx)("div",{className:"inline-flex flex-row gap-4",children:i&&(0,us.jsx)(D,{...t,resource:t?.resource??m})})})}),(0,us.jsx)("div",{className:h("pt-2 sm:pt-4 !mt-0",s),children:n})]})}),"ListPage");ms.displayName="ListPage";var xs=require("@refinedev/core"),fs=require("react"),ps=require("react/jsx-runtime"),hs=n((({title:e,children:r})=>(0,ps.jsx)(ps.Fragment,{children:(0,ps.jsx)("dl",{className:"flex flex-wrap",children:(0,ps.jsxs)("div",{className:"flex-auto pt-4",children:[(0,ps.jsx)("dt",{className:"scroll-m-20 text-xs font-semibold tracking-tight",children:e}),(0,ps.jsx)("dd",{className:"mt-1 text-base font-normal text-foreground leading-7",children:r})]})})})),"Row"),gs=require("react/jsx-runtime"),js=n((({title:e,resource:r,breadcrumb:a,isEdit:t=!0,isDelete:s=!0,extra:i,children:l})=>{let n=(0,xs.useTranslate)(),{options:{breadcrumb:o}={}}=(0,xs.useRefineContext)(),d=(0,xs.useUserFriendlyName)(),{resource:c,identifier:u}=(0,xs.useResource)(r),{list:m}=(0,xs.useNavigation)(),x=typeof a>"u"?o:a;return(0,gs.jsxs)(gs.Fragment,{children:[(0,gs.jsx)(xt,{title:e??n(`${u}.titles.List`,`Show ${d(c?.meta?.label??u,"singular")}`),breadcrumb:(0,fs.isValidElement)(x)?x:(0,gs.jsx)(ee,{}),isBack:!0,extra:i??(0,gs.jsxs)("div",{className:"inline-flex items-center gap-x-2",children:[t&&(0,gs.jsx)(kt,{resource:r}),s&&(0,gs.jsx)(wt,{resource:r,onSuccess:()=>{m(c?.name)}})]})}),(0,gs.jsx)("div",{className:"relative pt-4 !mt-0",children:l})]})}),"ShowPage");js.Row=hs,js.displayName="ShowPage";var bs=require("next-themes"),vs=require("react/jsx-runtime");function Ns({children:e,...r}){return(0,vs.jsx)(bs.ThemeProvider,{...r,children:e})}n(Ns,"ThemeProvider");var ys=require("react/jsx-runtime"),ws=n((({attribute:e,defaultTheme:r,enableSystem:a,disableTransitionOnChange:t,enableColorScheme:s,forcedTheme:i,nonce:l,storageKey:n,themes:o,value:d,children:c})=>(0,ys.jsx)(Ns,{attribute:e??"class",defaultTheme:r??"system",enableSystem:a??!0,disableTransitionOnChange:t??!1,enableColorScheme:s??!0,forcedTheme:i,nonce:l,storageKey:n,themes:o,value:d,children:(0,ys.jsxs)($a,{delayDuration:0,skipDelayDuration:0,disableHoverableContent:!0,children:[c,(0,ys.jsx)(ka,{})]})})),"BaseLayout");ws.displayName="BaseLayout";var Cs=ws,qs=d(require("react"));function Ss(e,r){if(r===e)return!1;let a=Object.values(r),t=Object.values(e);if(a.length!==t.length||a.some(((e,r)=>e!==t[r])))return!0;let s=Object.keys(e);return Object.keys(r).some(((e,r)=>e!==s[r]))}function ks(e,r){return e.matches[r]=!1,e.mediaQueries[r]={},e}function Rs(e){let r=Object.keys(e);return typeof window>"u"?r.reduce(ks,{mediaQueries:{},matches:{}}):r.reduce(((r,a)=>{let t=window.matchMedia(e[a]);return r.mediaQueries[a]=t,r.matches[a]=t.matches,r}),{mediaQueries:{},matches:{}})}function Is(e,r){function a(r,a){return r[a]=e.mediaQueries[a].matches,r}switch(n(a,"_ref2"),r.type){case"updateMatches":return{matches:Object.keys(e.mediaQueries).reduce(a,{}),mediaQueries:e.mediaQueries};case"setQueries":return Rs(r.queries)}}function zs(e){let r=qs.useRef(e),[a,t]=qs.useReducer(Is,e,Rs);function s(){return t({type:"updateMatches"})}function i(e){let r=s;return typeof e.addListener<"u"?e.addListener(r):e.addEventListener("change",r),r}qs.useEffect((()=>{Ss(e,r.current)&&(t({type:"setQueries",queries:e}),r.current=e)}),[e]),n(s,"_ref3"),n(i,"_ref4"),qs.useEffect((()=>{let e=Object.values(a.mediaQueries),r=e.map(i);function t(e,a){typeof e.addListener<"u"?e.removeListener(r[a]):e.removeEventListener("change",r[a])}return n(t,"_ref5"),()=>{e.forEach(t)}}),[a.mediaQueries]);let{matches:l}=a,o=qs.useMemo((()=>Object.values(l)),[l]);return{matches:l,matchesAny:o.some(Boolean),matchesAll:o.length>0&&o.every(Boolean)}}function Ds(e){return zs(Bs(e)).matchesAll}n(Ss,"queriesDidChange"),n(ks,"_ref"),n(Rs,"init"),n(Is,"reducer"),n(zs,"useMediaQueries"),n(Ds,"useMediaQuery");var Ts={};function Bs(e){return void 0===Ts[e]&&(Ts[e]={default:e}),Ts[e]}n(Bs,"getObj");var Fs=require("react"),Ps=require("@refinedev/core"),Ls=require("react/jsx-runtime"),As=n((({children:e,defaultLayout:r,defaultCollapsed:a=!1,navCollapsedSize:t,navbar:s,footer:i,logo:l,attribute:n,defaultTheme:o,enableSystem:d,disableTransitionOnChange:c,enableColorScheme:u,forcedTheme:m,nonce:x,storageKey:f,themes:p,value:g})=>{let{resources:j}=(0,Ps.useResource)(),b=j?.[0],v=Ds("only screen and (max-width: 579.999px)"),N=Ds("only screen and (min-width: 640px) and (max-width: 767.999px)"),y=Ds("only screen and (min-width: 768px) and (max-width: 1023.999px)"),w=Ds("only screen and (min-width: 1024px)"),[C,q]=(0,Fs.useState)(v??a),S=(0,Fs.useMemo)((()=>r||(v?[15,85]:N?[20,80]:y?[25,75]:[15,85])),[r,v,N,y]),k=(0,Fs.useMemo)((()=>w?{minSize:11,maxSize:15}:y?{minSize:15,maxSize:25}:N?{minSize:20,maxSize:30}:{minSize:15,maxSize:15}),[N,y,w]),R=(0,Fs.useMemo)((()=>C||v||N||y),[C,y,N,v]),I=(0,Fs.useMemo)((()=>{if(!l)return null;if(!R&&(0,Fs.isValidElement)(l.default))return(0,Fs.cloneElement)(l.default,{className:"w-auto h-8"});let e=R?l.collapsed:l.default;return(0,Fs.isValidElement)(e)?(0,Fs.cloneElement)(e,{className:"w-auto h-8"}):null}),[l,r,R]);return(0,Ls.jsx)(Ls.Fragment,{children:(0,Ls.jsx)(Cs,{attribute:n,defaultTheme:o,enableSystem:d,disableTransitionOnChange:c,enableColorScheme:u,forcedTheme:m,nonce:x,storageKey:f,themes:p,value:g,children:(0,Ls.jsxs)(Zr,{direction:"horizontal",onLayout:e=>{document.cookie=`react-resizable-panels:layout=${JSON.stringify(e)}`},className:"h-full items-stretch",children:[(0,Ls.jsxs)(ea,{defaultSize:S[0],collapsedSize:t,collapsible:!0,minSize:k.minSize,maxSize:k.maxSize,onExpand:()=>{let e=v;q(e),document.cookie=`react-resizable-panels:collapsed=${JSON.stringify(e)}`},onCollapse:()=>{q(!0),document.cookie=`react-resizable-panels:collapsed=${JSON.stringify(!0)}`},className:h(R&&"min-w-[50px] transition-all duration-300 ease-in-out"),children:[(0,Ls.jsx)("div",{className:h("flex py-1.5 max-h-14 items-center border-b border-border/40 justify-center",R&&"px-2"),children:(0,Ls.jsx)(J,{href:b.list?.toString()??"/",className:"inline-flex items-center justify-center",title:b.meta?.label??b.name,children:I})}),(0,Ls.jsx)(Nt,{isCollapsed:R})]}),(0,Ls.jsx)(ra,{withHandle:!0,className:"bg-border/40"}),(0,Ls.jsxs)(ea,{defaultSize:S[1],minSize:25,className:"xl:max-h-dvh h-full !overflow-y-auto flex flex-col overflow-x-hidden",children:[(0,Ls.jsxs)("header",{className:h("sticky top-0 z-50 py-2 h-14 px-4 flex justify-end items-center border-b border-border/40 bg-background/95 backdrop-blur supports-[backdrop-filter]:bg-background/60",s?.rightSide&&"justify-between"),children:[s?.leftSide&&(0,Ls.jsx)("div",{className:"flex items-center justify-start flex-1",children:s?.leftSide}),s?.rightSide?(0,Ls.jsxs)("div",{className:"flex items-center justify-end flex-1",children:[(0,Ls.jsx)(ut,{}),s?.rightSide]}):(0,Ls.jsx)(ut,{})]}),(0,Ls.jsx)("main",{className:"grow px-6 py-4",children:e}),i&&(0,Ls.jsx)("footer",{className:"px-6 py-4 border-t border-border/40 sticky bottom-0 bg-background text-primary flex flex-row items-center",children:(0,Ls.jsx)("div",{className:"w-full",children:i})})]})]})})})}),"DefaultLayout");As.displayName="DefaultLayout";var Ms=require("sonner"),Os={open:n((({key:e,message:r,description:a,type:t})=>{"success"===t&&Ms.toast.success(r,{description:a,id:e}),"error"===t&&Ms.toast.error(r,{description:a,id:e}),"progress"===t&&Ms.toast.loading(r,{description:a,id:e})}),"open"),close:n((e=>Ms.toast.dismiss(e)),"close")},Es=n((()=>Os),"useNotificationProvider"),Vs=require("@refinedev/core"),_s=require("react"),Hs=n(((e,r,a)=>{let t=(0,_s.useContext)(Vs.AccessControlContext),s=t.options.buttons.enableAccessControl,i=t.options.buttons.hideIfUnauthorized,{editUrl:l}=(0,Vs.useNavigation)(),{id:o,resource:d}=(0,Vs.useResource)(e),{data:c}=(0,Vs.useCan)({resource:e,action:"edit",params:{id:r,resource:d},queryOptions:{enabled:s}}),u=(0,Vs.useTranslate)(),m=n((()=>c?.can?"":c?.reason?c.reason:u("buttons.notAccessTitle","You don't have permission to access")),"reason"),x=e&&(r??o)?l(e,r??o,a):"";return{can:!(s&&i&&!c?.can),reason:m(),url:x}}),"useGetEditUrl"),$s=require("@refinedev/core"),Us=require("react"),Qs=n(((e,r,a)=>{let t=(0,Us.useContext)($s.AccessControlContext),s=t.options.buttons.enableAccessControl,i=t.options.buttons.hideIfUnauthorized,{showUrl:l}=(0,$s.useNavigation)(),{id:o,resource:d}=(0,$s.useResource)(e),{data:c}=(0,$s.useCan)({resource:e,action:"show",params:{id:r,resource:d},queryOptions:{enabled:s}}),u=(0,$s.useTranslate)(),m=n((()=>c?.can?"":c?.reason?c.reason:u("buttons.notAccessTitle","You don't have permission to access")),"reason"),x=e&&(r||o)?l(e,r??o,a):"";return{can:!(s&&i&&!c?.can),reason:m(),url:x}}),"useGetShowUrl"),Gs=require("@refinedev/core"),Ws=require("react"),Ks=n(((e,r,a)=>{let t=(0,Ws.useContext)(Gs.AccessControlContext),s=t.options.buttons.enableAccessControl,i=t.options.buttons.hideIfUnauthorized,l=(0,Gs.useTranslate)(),o=(0,Gs.useResourceParams)(),{resource:d,identifier:c}=(0,Gs.useResource)(e),{mutationMode:u}=(0,Gs.useMutationMode)(),{mutate:m,isLoading:x}=(0,Gs.useDelete)(),{data:f}=(0,Gs.useCan)({resource:d?.name,action:"delete",params:{id:r??o,resource:d},queryOptions:{enabled:s}}),p=n((()=>f?.can?"":f?.reason?f.reason:l("You don't have permission to access")),"reason"),{setWarnWhen:h}=(0,Gs.useWarnAboutChange)(),g=n((e=>{if((!s||!i||f?.can)&&(r??o)&&c)return h(!1),m({id:r??o??"",resource:c,mutationMode:u,meta:(0,Gs.pickNotDeprecated)(a),metaData:(0,Gs.pickNotDeprecated)(a)},e)}),"onDeleteMutate");return{can:!(s&&i&&!f?.can),reason:p(),mutate:g,isLoading:x}}),"useDeleteHelper"),Xs=require("@refinedev/core"),Js=n((()=>{let e=(0,Xs.useRouterType)(),r=(0,Xs.useBack)(),{goBack:a}=(0,Xs.useNavigation)(),{action:t}=(0,Xs.useResource)();return"list"!==t||typeof t<"u"?"legacy"===e?a:r:void 0}),"useOnBack"),Ys=require("@refinedev/core"),Zs=require("react"),ei=require("react/jsx-runtime");function ri(e){let r=Js(),{can:a,isLoading:t,mutate:s}=Ks(e.data?.resource,e.data?.row?.id),i=(0,Ys.useTranslate)(),l=(0,Zs.useCallback)((()=>{if(a)return s({onSuccess(){let a=e?.data?.redirectBack??!1,t=e?.data?.onAfterHandle;e?.updateData({toogle:!1,row:void 0,resource:"",redirectBack:!1,onAfterHandle:void 0}),a&&r?.(),t&&t()}})}),[a,s,e,r]);return(0,ei.jsx)(et,{open:a&&e?.data?.toogle,loading:t,title:i("Are you sure?"),description:i("This action cannot be undone."),okText:i("Delete"),cancelText:i("Cancel"),okButtonVariant:"destructive",onOpenChange:()=>{t||e?.updateData({toogle:!1,row:void 0,resource:""})},onConfirm:l})}n(ri,"DeleteActionModal");var ai=(0,Zs.createContext)(void 0),ti=n((({children:e})=>{let[r,a]=(0,Zs.useState)({row:void 0,resource:"",toogle:!1,onAfterHandle:void 0}),t=n((e=>{a(e)}),"updateData");return(0,ei.jsxs)(ai.Provider,{value:{data:r,updateData:t},children:[e,(0,ei.jsx)(ri,{data:r,updateData:t})]})}),"DeleteProvider"),si=require("react"),ii=require("react/jsx-runtime"),li=(0,si.forwardRef)((({className:e,...r},a)=>(0,ii.jsxs)("svg",{ref:a,xmlns:"http://www.w3.org/2000/svg",className:h("mx-auto inline",e),viewBox:"0 0 120 30",fill:"currentColor",...r,children:[(0,ii.jsxs)("circle",{cx:"15",cy:"15",r:"15",children:[(0,ii.jsx)("animate",{attributeName:"r",begin:"0s",calcMode:"linear",dur:"0.8s",from:"15",repeatCount:"indefinite",to:"15",values:"15;9;15"}),(0,ii.jsx)("animate",{attributeName:"fill-opacity",begin:"0s",calcMode:"linear",dur:"0.8s",from:"1",repeatCount:"indefinite",to:"1",values:"1;.5;1"})]}),(0,ii.jsxs)("circle",{cx:"60",cy:"15",r:"9",fillOpacity:"0.3",children:[(0,ii.jsx)("animate",{attributeName:"r",begin:"0s",calcMode:"linear",dur:"0.8s",from:"9",repeatCount:"indefinite",to:"9",values:"9;15;9"}),(0,ii.jsx)("animate",{attributeName:"fill-opacity",begin:"0s",calcMode:"linear",dur:"0.8s",from:"0.5",repeatCount:"indefinite",to:"0.5",values:".5;1;.5"})]}),(0,ii.jsxs)("circle",{cx:"105",cy:"15",r:"15",children:[(0,ii.jsx)("animate",{attributeName:"r",begin:"0s",calcMode:"linear",dur:"0.8s",from:"15",repeatCount:"indefinite",to:"15",values:"15;9;15"}),(0,ii.jsx)("animate",{attributeName:"fill-opacity",begin:"0s",calcMode:"linear",dur:"0.8s",from:"1",repeatCount:"indefinite",to:"1",values:"1;.5;1"})]})]}))),ni=li,oi=require("@refinedev/react-table"),di=require("@tanstack/react-table"),ci=require("react"),ui=require("@radix-ui/react-icons"),mi=require("react/jsx-runtime"),xi=n((e=>(0,mi.jsx)(pr,{disabled:e.disabled,asChild:!(!e.to||!e.to&&!e.children),onClick:e.onClick,children:e.asChild?e.children:e.to?(0,mi.jsxs)(J,{href:e.to,title:e.title,children:[e.icon?(0,mi.jsx)("span",{className:"mr-2",children:e.icon}):null,e.title]}):(0,mi.jsxs)(mi.Fragment,{children:[e.icon?(0,mi.jsx)("span",{className:"mr-2",children:e.icon}):null,e.title]})})),"RowAction");function fi({children:e}){return(0,mi.jsxs)(cr,{children:[(0,mi.jsx)(ur,{asChild:!0,children:(0,mi.jsxs)(w,{variant:"ghost",size:"icon",children:[(0,mi.jsx)(ui.DotsHorizontalIcon,{className:"h-4 w-4"}),(0,mi.jsx)("span",{className:"sr-only",children:"Open menu"})]})}),(0,mi.jsx)(fr,{align:"end",className:"w-[160px]",children:e})]})}xi.displayName="RowAction",n(fi,"RowActions");var pi=require("react/jsx-runtime");function hi({row:e,resource:r,title:a,disabled:t,...s}){let i=Hs(r,e.id);return(0,pi.jsx)(xi,{...s,disabled:!i.can||t,title:i?.can?a:i?.reason,to:i.url})}n(hi,"EditAction"),hi.displayName="EditAction";var gi=require("react/jsx-runtime");function ji({row:e,resource:r,title:a,disabled:t,...s}){let i=Qs(r,e.id);return(0,gi.jsx)(xi,{...s,disabled:!i.can||t,title:i?.can?a:i?.reason,to:i.url})}n(ji,"ShowAction"),ji.displayName="ShowAction";var bi=require("date-fns"),vi=require("lucide-react"),Ni=require("react"),yi=require("react/jsx-runtime");function wi({column:e,title:r,numberOfMonths:a=2,align:t="start"}){let[s,i]=(0,Ni.useState)({from:void 0,to:void 0}),l=new Set(e?.getFilterValue());return(0,Ni.useEffect)((()=>{if(s){let r=Object.values(s).filter(Boolean);r.length&&e?.setFilterValue(r.map((e=>e?(0,bi.format)(e,"yyyy-MM-dd").toString():"")))}}),[e,s]),(0,yi.jsxs)(Gr,{children:[(0,yi.jsx)(Wr,{asChild:!0,children:(0,yi.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-0.5",children:[(0,yi.jsxs)(w,{title:r,variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",children:[(0,yi.jsx)(vi.FilterIcon,{className:h("h-3.5 w-3.5")}),s?.from?(0,yi.jsxs)(yi.Fragment,{children:[(0,yi.jsx)(wa,{orientation:"vertical",className:"mx-2 h-4"}),(0,yi.jsx)(be,{variant:"secondary",className:"rounded-sm p-1 h-3.5 text-xs font-normal",children:s.to?(0,yi.jsx)(yi.Fragment,{children:[(0,bi.format)(s.from,"LLL dd, y"),(0,bi.format)(s.to,"LLL dd, y")].join(" ")}):(0,bi.format)(s.from,"LLL dd, y")})]}):null]}),l.size>0&&(0,yi.jsx)(w,{variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",onClick:r=>{r.preventDefault(),e?.setFilterValue(void 0),i({from:void 0,to:void 0})},children:(0,yi.jsx)(vi.FilterX,{className:h("h-3.5 w-3.5")})})]})}),(0,yi.jsxs)(Kr,{className:"w-auto p-0",align:t,children:[(0,yi.jsx)(we,{initialFocus:!0,mode:"range",defaultMonth:new Date,selected:s,onSelect:i,numberOfMonths:a}),l.size>0&&(0,yi.jsxs)(yi.Fragment,{children:[(0,yi.jsx)(wa,{}),(0,yi.jsx)("div",{className:"flex flex-row items-center justify-center py-3",children:(0,yi.jsxs)(w,{variant:"outline",size:"sm",className:"h-8 border-dashed px-2",onClick:()=>{e?.setFilterValue(void 0),i({from:void 0,to:void 0})},children:[(0,yi.jsx)(vi.FilterX,{size:16,className:"mr-2"}),"Clear"]})})]})]})]})}n(wi,"TableFilterDateRangePickerFilter");var Ci=require("@radix-ui/react-icons"),qi=require("lucide-react"),Si=require("react/jsx-runtime");function ki({column:e,title:r,options:a,align:t="start"}){let s=e?.getFacetedUniqueValues(),i=new Set(e?.getFilterValue());return(0,Si.jsxs)(Gr,{children:[(0,Si.jsx)(Wr,{asChild:!0,children:(0,Si.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-0.5",children:[(0,Si.jsxs)(w,{title:r,variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",children:[(0,Si.jsx)(qi.FilterIcon,{className:h("h-3.5 w-3.5")}),i?.size>0&&(0,Si.jsxs)(Si.Fragment,{children:[(0,Si.jsx)(wa,{orientation:"vertical",className:"mx-2 h-4"}),(0,Si.jsx)(be,{variant:"secondary",className:"rounded-sm p-1 h-3.5 text-xs font-normal lg:hidden",children:i.size}),(0,Si.jsx)("div",{className:"hidden space-x-1 lg:flex",children:i.size>2?(0,Si.jsxs)(be,{variant:"secondary",className:"rounded-sm p-1 text-xs h-3.5 font-normal",children:[i.size," selected"]}):a?.filter((e=>i.has(e.value))).map((e=>(0,Si.jsx)(be,{variant:"secondary",className:"rounded-sm p-1 text-xs h-3.5 font-normal",children:e.label},e.value)))})]})]}),i.size>0&&(0,Si.jsx)(w,{variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",onClick:r=>{r.preventDefault(),e?.setFilterValue(void 0)},children:(0,Si.jsx)(qi.FilterX,{className:h("h-3.5 w-3.5")})})]})}),(0,Si.jsx)(Kr,{className:"w-[200px] p-0",align:t,children:(0,Si.jsxs)(Ye,{children:[(0,Si.jsx)(Ze,{placeholder:r}),(0,Si.jsxs)(er,{children:[(0,Si.jsx)(rr,{children:"No results found."}),(0,Si.jsx)(ar,{children:a?.map((r=>{let a=i.has(r.value);return(0,Si.jsxs)(sr,{onSelect:()=>{a?i.delete(r.value):i.add(r.value);let t=Array.from(i);e?.setFilterValue(t.length?t:void 0)},children:[(0,Si.jsx)("div",{className:h("mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary",a?"bg-primary text-primary-foreground":"opacity-50 [&_svg]:invisible"),children:(0,Si.jsx)(Ci.CheckIcon,{className:h("h-4 w-4")})}),r.icon&&(0,Si.jsx)(r.icon,{className:"mr-2 h-4 w-4 text-muted-foreground"}),(0,Si.jsx)("span",{children:r.label}),s?.get(r.value)&&(0,Si.jsx)("span",{className:"ml-auto flex h-4 w-4 items-center justify-center font-mono text-xs",children:s.get(r.value)})]},r.value)}))}),i.size>0&&(0,Si.jsxs)(Si.Fragment,{children:[(0,Si.jsx)(tr,{}),(0,Si.jsx)(ar,{children:(0,Si.jsx)(sr,{onSelect:()=>e?.setFilterValue(void 0),className:"justify-center text-center",children:"Clear filters"})})]})]})]})})]})}n(ki,"TableFilterDropdown");var Ri=require("lucide-react"),Ii=require("react/jsx-runtime");function zi({column:e,title:r,align:a="start"}){let t=e?.getFilterValue();return(0,Ii.jsxs)(Gr,{children:[(0,Ii.jsx)(Wr,{asChild:!0,children:(0,Ii.jsx)("div",{className:"inline-flex flex-row items-center gap-x-0.5",children:t?(0,Ii.jsx)(w,{variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",onClick:r=>{r.preventDefault(),e?.setFilterValue(void 0)},children:(0,Ii.jsx)(Ri.FilterX,{className:h("h-3.5 w-3.5")})}):(0,Ii.jsx)(w,{title:r,variant:"outline",size:"sm",className:"h-4 border-dashed px-1 py-2.5",children:(0,Ii.jsx)(Ri.FilterIcon,{className:h("h-3.5 w-3.5")})})})}),(0,Ii.jsx)(Kr,{className:"w-[200px] p-0 overflow-hidden border-0 ring-0",align:a,children:(0,Ii.jsxs)("div",{className:"relative",children:[(0,Ii.jsxs)("div",{className:"flex flex-row items-center px-3 text-popover-foreground bg-popover",children:[(0,Ii.jsx)("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"mr-2 h-4 w-4 shrink-0 opacity-50",children:(0,Ii.jsx)("path",{d:"M10 6.5C10 8.433 8.433 10 6.5 10C4.567 10 3 8.433 3 6.5C3 4.567 4.567 3 6.5 3C8.433 3 10 4.567 10 6.5ZM9.30884 10.0159C8.53901 10.6318 7.56251 11 6.5 11C4.01472 11 2 8.98528 2 6.5C2 4.01472 4.01472 2 6.5 2C8.98528 2 11 4.01472 11 6.5C11 7.56251 10.6318 8.53901 10.0159 9.30884L12.8536 12.1464C13.0488 12.3417 13.0488 12.6583 12.8536 12.8536C12.6583 13.0488 12.3417 13.0488 12.1464 12.8536L9.30884 10.0159Z",fill:"currentColor",fillRule:"evenodd",clipRule:"evenodd"})}),(0,Ii.jsx)(Hr,{defaultValue:t??"",onChange:r=>{e?.setFilterValue(r.target.value)},className:h("h-10 border-0 focus-visible:ring-0 ring-0 rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground shadow-none disabled:cursor-not-allowed disabled:opacity-50"),placeholder:r})]}),t&&(0,Ii.jsxs)(Ii.Fragment,{children:[(0,Ii.jsx)(wa,{}),(0,Ii.jsx)("div",{className:"flex flex-row items-center justify-center py-3",children:(0,Ii.jsxs)(w,{variant:"outline",size:"sm",className:"h-8 border-dashed px-2",onClick:()=>{e?.setFilterValue(void 0)},children:[(0,Ii.jsx)(Ri.FilterX,{size:16,className:"mr-2"}),"Clear"]})})]})]})})]})}n(zi,"TableFilterSearchColumn");var Di=require("@radix-ui/react-icons"),Ti=require("react"),Bi=require("react/jsx-runtime"),Fi=(0,Ti.forwardRef)((({table:e,children:r,options:a},t)=>(0,Bi.jsxs)(Bi.Fragment,{children:[(0,Bi.jsx)(Le,{ref:t,checked:e.getIsSomeRowsSelected()?"indeterminate":e.getIsAllPageRowsSelected(),onCheckedChange:r=>e.toggleAllPageRowsSelected(!!r),className:"translate-y-[2px]","aria-label":"Select all"}),r||Array.isArray(a)&&a.length&&(0,Bi.jsxs)(cr,{children:[(0,Bi.jsx)(ur,{asChild:!0,children:(0,Bi.jsx)(w,{disabled:!(e.getIsSomeRowsSelected()||e.getIsAllPageRowsSelected()),size:"icon",variant:"ghost",className:"px-0 w-5",children:(0,Bi.jsx)(Di.DotsVerticalIcon,{className:"w-4 h-4"})})}),(0,Bi.jsxs)(fr,{align:"start",children:[(0,Bi.jsx)(jr,{children:"Bulk Actions"}),(0,Bi.jsx)(br,{}),!r&&Array.isArray(a)&&a?.length>0?a.map(((e,r)=>(0,Bi.jsx)(pr,{onSelect:e.onClick,children:e.label},r))):r]})]})]})));Fi.displayName="CheckAll";var Pi=require("@radix-ui/react-icons"),Li=require("react/jsx-runtime"),Ai=n((({table:e})=>(0,Li.jsxs)("div",{className:"flex flex-col sm:flex-row gap-y-4 sm-gap-y-0 items-center justify-between",children:[(0,Li.jsxs)("div",{className:"flex-1 text-sm text-muted-foreground",children:[e.getFilteredSelectedRowModel().rows.length," of"," ",e.getFilteredRowModel().rows.length," row(s) selected."]}),(0,Li.jsxs)("div",{className:"flex relative flex-col-reverse gap-y-4 sm:gap-y-0 sm:flex-row items-center space-x-6 lg:space-x-8",children:[(0,Li.jsxs)("div",{className:"flex items-center space-x-2",children:[(0,Li.jsx)("p",{className:"text-sm font-medium",children:"Rows per page"}),(0,Li.jsxs)(ua,{value:`${e.getState().pagination.pageSize}`,onValueChange:r=>{e.setPageSize(Number(r))},children:[(0,Li.jsx)(xa,{className:"h-8 w-[70px]",children:(0,Li.jsx)(ma,{placeholder:e.getState().pagination.pageSize})}),(0,Li.jsx)(ha,{children:[10,20,30,40,50].map((e=>(0,Li.jsx)(ja,{value:`${e}`,children:e},e)))})]})]}),(0,Li.jsxs)("div",{className:"flex w-fit items-center justify-center text-sm font-medium",children:["Page ",e.getState().pagination.pageIndex+1," of"," ",e.getPageCount()]}),(0,Li.jsxs)("div",{className:"flex items-center space-x-2",children:[(0,Li.jsxs)(w,{variant:"outline",className:"hidden h-8 w-8 p-0 lg:flex",onClick:()=>e.setPageIndex(0),disabled:!e.getCanPreviousPage(),children:[(0,Li.jsx)("span",{className:"sr-only",children:"Go to first page"}),(0,Li.jsx)(Pi.DoubleArrowLeftIcon,{className:"h-4 w-4"})]}),(0,Li.jsxs)(w,{variant:"outline",className:"h-8 w-8 p-0",onClick:()=>e.previousPage(),disabled:!e.getCanPreviousPage(),children:[(0,Li.jsx)("span",{className:"sr-only",children:"Go to previous page"}),(0,Li.jsx)(Pi.ChevronLeftIcon,{className:"h-4 w-4"})]}),(0,Li.jsxs)(w,{variant:"outline",className:"h-8 w-8 p-0",onClick:()=>e.nextPage(),disabled:!e.getCanNextPage(),children:[(0,Li.jsx)("span",{className:"sr-only",children:"Go to next page"}),(0,Li.jsx)(Pi.ChevronRightIcon,{className:"h-4 w-4"})]}),(0,Li.jsxs)(w,{variant:"outline",className:"hidden h-8 w-8 p-0 lg:flex",onClick:()=>e.setPageIndex(e.getPageCount()-1),disabled:!e.getCanNextPage(),children:[(0,Li.jsx)("span",{className:"sr-only",children:"Go to last page"}),(0,Li.jsx)(Pi.DoubleArrowRightIcon,{className:"h-4 w-4"})]})]})]})]})),"Pagination");Ai.displayName="Pagination";var Mi=require("@radix-ui/react-icons"),Oi=require("react/jsx-runtime"),Ei=n((({column:e})=>(0,Oi.jsx)("div",{className:"cursor-pointer",onClick:()=>{e?.toggleSorting("asc"===e?.getIsSorted())},children:(0,Oi.jsxs)("div",{className:"inline-flex flex-col",children:[(0,Oi.jsx)(Mi.CaretUpIcon,{className:h("-mb-1.5 w-5 h-5","asc"===e?.getIsSorted()?"text-foreground":"text-input")}),(0,Oi.jsx)(Mi.CaretDownIcon,{className:h("-mt-1.5 w-5 h-5","desc"===e?.getIsSorted()?"text-foreground":"text-input")})]})})),"SortAction"),Vi=require("@radix-ui/react-dropdown-menu"),_i=require("@radix-ui/react-icons"),Hi=require("react"),$i=require("react/jsx-runtime"),Ui=n((({table:e})=>{let r=(0,Hi.useMemo)((()=>e.getAllColumns().filter((e=>typeof e.accessorFn<"u"&&e.getCanHide()))),[e]);return(0,$i.jsxs)(cr,{children:[(0,$i.jsx)(Vi.DropdownMenuTrigger,{asChild:!0,children:(0,$i.jsxs)(w,{variant:"outline",size:"sm",className:"ml-auto hidden h-8 lg:flex",children:[(0,$i.jsx)(_i.MixerHorizontalIcon,{className:"mr-2 h-4 w-4"}),"View"]})}),(0,$i.jsxs)(fr,{align:"end",className:"w-[150px]",children:[(0,$i.jsx)(jr,{children:"Toggle columns"}),(0,$i.jsx)(br,{}),r.map((e=>(0,$i.jsx)(hr,{className:"capitalize",checked:e.getIsVisible(),onCheckedChange:r=>e.toggleVisibility(r),children:e.id},e.id)))]})]})}),"DataTableViewOptions");Ui.displayName="DataTableViewOptions";var Qi=require("react/jsx-runtime");function Gi({table:e}){return(0,Qi.jsxs)("div",{className:"flex items-center justify-between",children:[(0,Qi.jsx)("div",{className:"flex flex-1 items-center space-x-2"}),(0,Qi.jsx)(Ui,{table:e})]})}n(Gi,"DataTableToolbar");var Wi=require("react"),Ki=require("react/jsx-runtime");function Xi({row:e,resource:r,title:a,disabled:t,onAfterHandle:s,...i}){let{can:l,reason:n}=Ks(r,e.id),o=(0,Wi.useContext)(ai);return(0,Ki.jsx)(xi,{...i,disabled:!l||t,title:l?a:n,onClick:()=>o?.updateData({row:e,resource:r,toogle:!0,onAfterHandle:s})})}n(Xi,"DeleteAction"),Xi.displayName="DeleteAction";var Ji=require("react/jsx-runtime");function Yi({children:e,showHeader:r=!0,columns:a=[],...t}){let s=(0,ci.useCallback)((({id:e,accessorKey:r,header:a,enableSorting:t,enableHiding:s,filter:i,cell:l})=>{let n={id:e,header:a,accessorKey:r,enableSorting:t??!1,enableHiding:s??!1,enableColumnFilter:!0,enableResizing:!0,filter:i};return l&&(n.cell=l),n}),[]);a=(0,ci.useMemo)((()=>Array.isArray(e)?e.map((e=>e.props)).map(s):[]),[e,s]);let i=(0,oi.useTable)({columns:a,...t}),l=(0,ci.useMemo)((()=>i.options),[i]),n=(0,ci.useMemo)((()=>!(!l.enableColumnFilters&&!l?.enableFilters)),[l]);return(0,Ji.jsx)(ti,{children:(0,Ji.jsxs)("div",{className:"space-y-4",children:[(0,Ji.jsx)(Gi,{table:i}),(0,Ji.jsx)("div",{className:"rounded-md border border-border",children:(0,Ji.jsxs)(za,{children:[r&&(0,Ji.jsx)(Da,{children:i.getHeaderGroups().map((e=>(0,Ji.jsx)(Fa,{children:e.headers.map((e=>{let r=e.column.columnDef;return(0,Ji.jsx)(Pa,{children:(0,Ji.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-2.5",children:[e.isPlaceholder?null:(0,di.flexRender)(e.column.columnDef.header,e.getContext()),l.enableSorting&&r.enableSorting&&(0,Ji.jsx)(Ei,{column:e.column}),n&&r?.filter&&r.filter({column:e.column,title:`${r.header} Filter`})]})},e.id)}))},e.id)))}),(0,Ji.jsx)(Ta,{children:i.refineCore.tableQuery.isLoading?(0,Ji.jsx)(Fa,{children:(0,Ji.jsx)(La,{colSpan:a.length,className:"h-24 text-center text-nowrap",children:(0,Ji.jsx)("div",{className:"flex items-center justify-center flex-row",children:(0,Ji.jsx)(ni,{className:"h-4 text-primary"})})})}):i.getRowModel().rows?.length?i.getRowModel().rows.map((e=>(0,Ji.jsx)(Fa,{"data-state":e.getIsSelected()&&"selected",children:e.getVisibleCells().map((e=>(0,Ji.jsx)(La,{className:"text-nowrap",children:(0,di.flexRender)(e.column.columnDef.cell,e.getContext())},e.id)))},e.id))):(0,Ji.jsx)(Fa,{children:(0,Ji.jsx)(La,{colSpan:a.length,className:"h-24 text-center",children:"No results."})})})]})}),(0,Ji.jsx)(Ai,{table:i})]})})}n(Yi,"Table");var Zi=n((e=>e.children),"TableColumn");Yi.Column=Zi,Yi.CheckAll=Fi,Yi.Actions=fi,Yi.Action=xi,Yi.EditAction=hi,Yi.ShowAction=ji,Yi.DeleteAction=Xi,Yi.Filter={DateRangePicker:wi,Dropdown:ki,Search:zi},Yi.displayName="Table";//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/ui/button.tsx", "../src/lib/utils.ts", "../src/ui/loading.tsx", "../src/buttons/clone.tsx", "../src/buttons/create.tsx", "../src/buttons/delete.tsx", "../src/ui/breadcrumb.tsx", "../src/components/breadcrumbs.tsx", "../src/components/link.tsx", "../src/components/combobox.tsx", "../src/ui/alert-dialog.tsx", "../src/ui/badge.tsx", "../src/ui/calendar.tsx", "../src/ui/card.tsx", "../src/ui/checkbox.tsx", "../src/ui/command.tsx", "../src/ui/dialog.tsx", "../src/ui/dropdown-menu.tsx", "../src/ui/form.tsx", "../src/ui/label.tsx", "../src/ui/input.tsx", "../src/ui/popover.tsx", "../src/ui/resizable.tsx", "../src/ui/scroll-area.tsx", "../src/ui/select.tsx", "../src/ui/separator.tsx", "../src/ui/sonner.tsx", "../src/ui/table.tsx", "../src/ui/textarea.tsx", "../src/ui/tooltip.tsx", "../src/components/confirm.tsx", "../src/components/field.tsx", "../src/components/form.tsx", "../src/components/modeToggle.tsx", "../src/components/pageHeader.tsx", "../src/components/select.tsx", "../src/components/sidebar.tsx", "../src/buttons/edit.tsx", "../src/buttons/export.tsx", "../src/buttons/import.tsx", "../src/buttons/list.tsx", "../src/buttons/refresh.tsx", "../src/buttons/save.tsx", "../src/buttons/show.tsx", "../src/curds/create.tsx", "../src/curds/edit.tsx", "../src/curds/list.tsx", "../src/curds/show/index.tsx", "../src/curds/show/row.tsx", "../src/providers/theme-provider.tsx", "../src/layouts/base.tsx", "../../../node_modules/@react-hook/media-query/dist/module/index.js", "../src/layouts/default.tsx", "../src/providers/notificationProvider.ts", "../src/hooks/useGetEditUrl.tsx", "../src/hooks/useGetShowUrl.tsx", "../src/hooks/useDeleteHelper.tsx", "../src/hooks/useOnBack.tsx", "../src/providers/deleteProvider.tsx", "../src/components/loader.tsx", "../src/table/index.tsx", "../src/table/actions/index.tsx", "../src/table/actions/edit.tsx", "../src/table/actions/show.tsx", "../src/table/fields/table-filter-date-range-picker.tsx", "../src/table/fields/table-filter-dropdown.tsx", "../src/table/fields/table-filter-search-column.tsx", "../src/table/fields/checkall.tsx", "../src/table/fields/pagination.tsx", "../src/table/fields/sort.tsx", "../src/table/toolbar/table-view-options-dropdown.tsx", "../src/table/toolbar/index.tsx", "../src/table/actions/delete.tsx"],
  "sourcesContent": ["export * from \"./buttons\";\nexport * from \"./components\";\nexport * from \"./curds\";\nexport * from \"./layouts\";\nexport * from \"./providers\";\nexport * from \"./table\";\n", "import { Slot } from \"@radix-ui/react-slot\";\nimport { cva, VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\nimport { LoadingIcon } from \"./loading\";\n\nconst buttonVariants = cva(\n    \"inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50\",\n    {\n        variants: {\n            variant: {\n                default:\n                    \"bg-primary text-primary-foreground shadow hover:bg-primary/90\",\n                destructive:\n                    \"bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90\",\n                outline:\n                    \"border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground\",\n                secondary:\n                    \"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80\",\n                ghost: \"hover:bg-accent hover:text-accent-foreground\",\n                link: \"text-primary underline-offset-4 hover:underline\",\n            },\n            size: {\n                default: \"h-9 px-4 py-2\",\n                sm: \"h-8 rounded-md px-3 text-xs\",\n                lg: \"h-10 rounded-md px-8\",\n                icon: \"h-9 w-9\",\n            },\n        },\n        defaultVariants: {\n            variant: \"default\",\n            size: \"default\",\n        },\n    },\n);\n\nexport interface ButtonProps\n    extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n        VariantProps<typeof buttonVariants> {\n    asChild?: boolean;\n    loading?: boolean;\n    icon?: React.ReactElement<SVGSVGElement>;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n    (\n        {\n            className,\n            variant,\n            size,\n            icon = null,\n            loading = false,\n            asChild = false,\n            children,\n            disabled,\n            ...props\n        },\n        ref,\n    ) => {\n        disabled = disabled || loading;\n        const Icon = React.useMemo(() => {\n            if (React.isValidElement(icon)) {\n                return icon;\n            }\n            return loading ? <LoadingIcon className=\"mr-2\" /> : null;\n        }, [icon, loading]);\n        const Comp = asChild ? Slot : \"button\";\n        return (\n            <Comp\n                className={cn(buttonVariants({ variant, size, className }))}\n                ref={ref}\n                disabled={disabled}\n                {...props}\n            >\n                {size === \"icon\" ? (\n                    loading ? (\n                        <LoadingIcon />\n                    ) : (\n                        children\n                    )\n                ) : (\n                    <>\n                        {Icon}\n                        {children}\n                    </>\n                )}\n            </Comp>\n        );\n    },\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n", "import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n    return twMerge(clsx(inputs));\n}\n", "import { cn } from \"@/lib/utils\";\nimport { LucideProps, RefreshCwIcon } from \"lucide-react\";\nimport React from \"react\";\n\nexport const LoadingIcon = React.forwardRef<SVGSVGElement, LucideProps>(\n    ({ className, ...props }, ref) => {\n        return (\n            <RefreshCwIcon\n                ref={ref}\n                className={cn(\"h-4 w-4 animate-spin\", className)}\n                {...props}\n            />\n        );\n    },\n);\n", "import { CloneButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useCloneButton } from \"@refinedev/core\";\nimport { CopyPlus } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const CloneButton: FC<CloneButtonProps> = ({\n    resource,\n    recordItemId,\n    hideText = false,\n    accessControl,\n    meta,\n    onClick,\n    children,\n    ...props\n}) => {\n    const { to, LinkComponent, label, disabled, hidden, title } =\n        useCloneButton({\n            id: recordItemId,\n            resource: resource,\n            accessControl: accessControl,\n            meta: meta,\n        });\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<CopyPlus className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nCloneButton.displayName = \"CloneButton\";\n", "import { CreateButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useCreateButton } from \"@refinedev/core\";\nimport { SquarePlusIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const CreateButton: FC<CreateButtonProps> = ({\n    resource,\n    hideText = false,\n    accessControl,\n    meta,\n    onClick,\n    children,\n    ...props\n}) => {\n    const { hidden, disabled, label, title, LinkComponent, to } =\n        useCreateButton({\n            resource,\n            accessControl,\n            meta,\n        });\n\n    if (hidden) return null;\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<SquarePlusIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nCreateButton.displayName = \"CreateButton\";\n", "import { DeleteButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useDeleteButton } from \"@refinedev/core\";\nimport { Trash2Icon } from \"lucide-react\";\nimport type { FC } from \"react\";\nimport { ConfirmDialog } from \"@/components\";\n\nexport const DeleteButton: FC<DeleteButtonProps> = ({\n    resource,\n    recordItemId,\n    onSuccess,\n    mutationMode: mutationModeProp,\n    confirmTitle,\n    confirmDescription,\n    successNotification,\n    errorNotification,\n    hideText = false,\n    accessControl,\n    meta,\n    dataProviderName,\n    confirmOkText,\n    confirmCancelText,\n    invalidates,\n    children,\n    ...props\n}) => {\n    const {\n        title,\n        label,\n        hidden,\n        disabled,\n        loading,\n        confirmTitle: defaultConfirmTitle,\n        confirmOkLabel: defaultConfirmOkLabel,\n        cancelLabel: defaultCancelLabel,\n        onConfirm,\n    } = useDeleteButton({\n        resource,\n        id: recordItemId,\n        dataProviderName,\n        invalidates,\n        meta,\n        onSuccess,\n        mutationMode: mutationModeProp,\n        errorNotification,\n        successNotification,\n        accessControl,\n    });\n\n    if (hidden) return null;\n\n    return (\n        <ConfirmDialog\n            okText={confirmOkText ?? defaultConfirmOkLabel}\n            cancelText={confirmCancelText ?? defaultCancelLabel}\n            okButtonVariant={\"destructive\"}\n            cancelButtonVariant={\"outline\"}\n            title={confirmTitle ?? defaultConfirmTitle}\n            description={confirmDescription}\n            loading={loading}\n            onConfirm={onConfirm}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                loading={loading}\n                icon={<Trash2Icon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </ConfirmDialog>\n    );\n};\n\nDeleteButton.displayName = \"DeleteButton\";\n", "import * as React from \"react\"\nimport { ChevronRightIcon, DotsHorizontalIcon } from \"@radix-ui/react-icons\"\nimport { Slot } from \"@radix-ui/react-slot\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Breadcrumb = React.forwardRef<\n  HTMLElement,\n  React.ComponentPropsWithoutRef<\"nav\"> & {\n    separator?: React.ReactNode\n  }\n>(({ ...props }, ref) => <nav ref={ref} aria-label=\"breadcrumb\" {...props} />)\nBreadcrumb.displayName = \"Breadcrumb\"\n\nconst BreadcrumbList = React.forwardRef<\n  HTMLOListElement,\n  React.ComponentPropsWithoutRef<\"ol\">\n>(({ className, ...props }, ref) => (\n  <ol\n    ref={ref}\n    className={cn(\n      \"flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5\",\n      className\n    )}\n    {...props}\n  />\n))\nBreadcrumbList.displayName = \"BreadcrumbList\"\n\nconst BreadcrumbItem = React.forwardRef<\n  HTMLLIElement,\n  React.ComponentPropsWithoutRef<\"li\">\n>(({ className, ...props }, ref) => (\n  <li\n    ref={ref}\n    className={cn(\"inline-flex items-center gap-1.5\", className)}\n    {...props}\n  />\n))\nBreadcrumbItem.displayName = \"BreadcrumbItem\"\n\nconst BreadcrumbLink = React.forwardRef<\n  HTMLAnchorElement,\n  React.ComponentPropsWithoutRef<\"a\"> & {\n    asChild?: boolean\n  }\n>(({ asChild, className, ...props }, ref) => {\n  const Comp = asChild ? Slot : \"a\"\n\n  return (\n    <Comp\n      ref={ref}\n      className={cn(\"transition-colors hover:text-foreground\", className)}\n      {...props}\n    />\n  )\n})\nBreadcrumbLink.displayName = \"BreadcrumbLink\"\n\nconst BreadcrumbPage = React.forwardRef<\n  HTMLSpanElement,\n  React.ComponentPropsWithoutRef<\"span\">\n>(({ className, ...props }, ref) => (\n  <span\n    ref={ref}\n    role=\"link\"\n    aria-disabled=\"true\"\n    aria-current=\"page\"\n    className={cn(\"font-normal text-foreground\", className)}\n    {...props}\n  />\n))\nBreadcrumbPage.displayName = \"BreadcrumbPage\"\n\nconst BreadcrumbSeparator = ({\n  children,\n  className,\n  ...props\n}: React.ComponentProps<\"li\">) => (\n  <li\n    role=\"presentation\"\n    aria-hidden=\"true\"\n    className={cn(\"[&>svg]:size-3.5\", className)}\n    {...props}\n  >\n    {children ?? <ChevronRightIcon />}\n  </li>\n)\nBreadcrumbSeparator.displayName = \"BreadcrumbSeparator\"\n\nconst BreadcrumbEllipsis = ({\n  className,\n  ...props\n}: React.ComponentProps<\"span\">) => (\n  <span\n    role=\"presentation\"\n    aria-hidden=\"true\"\n    className={cn(\"flex h-9 w-9 items-center justify-center\", className)}\n    {...props}\n  >\n    <DotsHorizontalIcon className=\"h-4 w-4\" />\n    <span className=\"sr-only\">More</span>\n  </span>\n)\nBreadcrumbEllipsis.displayName = \"BreadcrumbElipssis\"\n\nexport {\n  Breadcrumb,\n  BreadcrumbList,\n  BreadcrumbItem,\n  BreadcrumbLink,\n  BreadcrumbPage,\n  BreadcrumbSeparator,\n  BreadcrumbEllipsis,\n}\n", "import {\n    Breadcrumb,\n    BreadcrumbItem,\n    BreadcrumbLink,\n    BreadcrumbList,\n    BreadcrumbPage,\n    BreadcrumbSeparator,\n} from \"@/ui/breadcrumb\";\nimport {\n    matchResourceFromRoute,\n    useBreadcrumb,\n    useRefineContext,\n    useResource,\n} from \"@refinedev/core\";\nimport { RefineBreadcrumbProps } from \"@refinedev/ui-types\";\nimport { FC, Fragment } from \"react\";\nimport { Link } from \"./link\";\nimport { HomeIcon } from \"lucide-react\";\nexport type BreadcrumbProps = RefineBreadcrumbProps;\n\nexport const Breadcrumbs: FC<BreadcrumbProps> = ({ showHome = true, meta }) => {\n    const { breadcrumbs } = useBreadcrumb({\n        meta,\n    });\n\n    const { hasDashboard } = useRefineContext();\n\n    const { resources } = useResource();\n\n    const dashboardResource = resources[0];\n\n    const rootRouteResource = matchResourceFromRoute(\"/\", resources);\n\n    const BreadCrumbItems = breadcrumbs.map(({ label, href }, key) => (\n        <Fragment key={key}>\n            <BreadcrumbItem>\n                {href ? (\n                    <BreadcrumbLink asChild href={`#x`}>\n                        <Link href={href}>{label}</Link>\n                    </BreadcrumbLink>\n                ) : (\n                    <BreadcrumbPage>{label}</BreadcrumbPage>\n                )}\n            </BreadcrumbItem>\n            {key < breadcrumbs.length - 1 && <BreadcrumbSeparator />}\n        </Fragment>\n    ));\n\n    return (\n        <Breadcrumb>\n            <BreadcrumbList>\n                {showHome || hasDashboard || rootRouteResource.found ? (\n                    <>\n                        <BreadcrumbItem>\n                            <BreadcrumbLink\n                                href={dashboardResource.list?.toString()}\n                                asChild\n                                title={\n                                    dashboardResource?.meta?.title ??\n                                    dashboardResource.name ??\n                                    \"Dashboard\"\n                                }\n                            >\n                                <Link\n                                    href={dashboardResource.list?.toString()}\n                                    title={\n                                        dashboardResource?.meta?.title ??\n                                        dashboardResource.name ??\n                                        \"Dashboard\"\n                                    }\n                                >\n                                    {dashboardResource?.meta?.icon ?? (\n                                        <HomeIcon className=\"h-4 w-4\" />\n                                    )}\n                                </Link>\n                            </BreadcrumbLink>\n                        </BreadcrumbItem>\n                        <BreadcrumbSeparator />\n                    </>\n                ) : null}\n                {BreadCrumbItems}\n            </BreadcrumbList>\n        </Breadcrumb>\n    );\n};\n", "import { LayoutResource } from \"@/types\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { useLink, useRouterContext, useRouterType } from \"@refinedev/core\";\nimport { forwardRef } from \"react\";\n\ntype LinkProps = LayoutResource[\"link\"] & {\n    asChild?: boolean;\n};\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(\n    ({ children, href, title, className, asChild }, ref) => {\n        const { Link: LegacyLink } = useRouterContext();\n        const routerType = useRouterType();\n        const Link = useLink();\n\n        const ActiveLink = routerType === \"legacy\" ? LegacyLink : Link;\n        const Comp = asChild ? Slot : ActiveLink;\n\n        return (\n            <Comp ref={ref} to={href} className={className} title={title}>\n                {children}\n            </Comp>\n        );\n    },\n);\n\nLink.displayName = \"Link\";\n", "\"use client\";\n\nimport {\n    CalendarIcon,\n    EnvelopeClosedIcon,\n    FaceIcon,\n    GearIcon,\n    PersonIcon,\n    RocketIcon,\n} from \"@radix-ui/react-icons\";\nimport { CaretSortIcon, CheckIcon } from \"@radix-ui/react-icons\";\n\nimport { cn } from \"@/lib/utils\";\nimport {\n    Button,\n    Command,\n    CommandEmpty,\n    CommandGroup,\n    CommandInput,\n    CommandItem,\n    CommandList,\n    CommandSeparator,\n    CommandShortcut,\n    FormControl,\n    Popover,\n    PopoverContent,\n    PopoverTrigger,\n    ScrollArea,\n} from \"@/ui\";\nimport { BaseOption, BaseRecord, UseSelectReturnType } from \"@refinedev/core\";\nimport {\n    ComponentPropsWithoutRef,\n    forwardRef,\n    useState,\n    type ElementRef,\n} from \"react\";\n\ntype ComboboxProps = ComponentPropsWithoutRef<typeof Command> &\n    Pick<UseSelectReturnType<BaseOption, any>, \"options\"> & {\n        placeholder?: string;\n        emptyMessage?: string;\n        onChange?: (value: string | number) => void;\n        value?: string | number | BaseRecord;\n        disabled?: boolean;\n    };\n\nexport const Combobox = forwardRef<ElementRef<typeof Command>, ComboboxProps>(\n    ({ ...props }, ref) => {\n        const [open, setOpen] = useState(false);\n\n        const value = () => {\n            if (typeof props.value === \"object\" && \"id\" in props.value) {\n                return (props.value as BaseRecord).id;\n            }\n\n            return props.value;\n        };\n\n        return (\n            <Popover open={open} onOpenChange={setOpen}>\n                <PopoverTrigger asChild>\n                    <FormControl>\n                        <Button\n                            disabled={props.disabled}\n                            variant=\"outline\"\n                            role=\"combobox\"\n                            aria-expanded={open}\n                            className={cn(\n                                \"w-full sm:w-[250px] flex justify-between\",\n                                !value() && \"text-muted-foreground\",\n                            )}\n                        >\n                            {value()\n                                ? props.options?.find(\n                                      (option) => option.value === value(),\n                                  )?.label\n                                : props.placeholder ?? \"Select\"}\n                            <CaretSortIcon className=\"ml-2 h-4 w-4 shrink-0 opacity-50\" />\n                        </Button>\n                    </FormControl>\n                </PopoverTrigger>\n                <PopoverContent className=\"w-full max-w-full sm:w-[250px] p-0\">\n                    <Command className=\"rounded-lg border shadow-md\" ref={ref}>\n                        <CommandInput placeholder=\"Type a command or search...\" />\n                        <CommandList>\n                            <CommandEmpty>No results found.</CommandEmpty>\n                            <CommandGroup heading=\"Suggestions\">\n                                <ScrollArea className=\"max-h-52 overflow-y-auto\">\n                                    {props.options?.map((option) => (\n                                        <CommandItem\n                                            value={option.label}\n                                            key={option.value}\n                                            onSelect={() => {\n                                                props.onChange?.(option.value);\n                                                setOpen(false);\n                                            }}\n                                        >\n                                            {option.label}\n                                            <CheckIcon\n                                                className={cn(\n                                                    \"ml-auto h-4 w-4\",\n                                                    option.value === value()\n                                                        ? \"opacity-100\"\n                                                        : \"opacity-0\",\n                                                )}\n                                            />\n                                        </CommandItem>\n                                    ))}\n                                </ScrollArea>\n                            </CommandGroup>\n                        </CommandList>\n                    </Command>\n                </PopoverContent>\n            </Popover>\n        );\n    },\n);\n\nCombobox.displayName = \"Combobox\";\n", "\"use client\";\n\nimport { cn } from \"@/lib/utils\";\nimport * as AlertDialogPrimitive from \"@radix-ui/react-alert-dialog\";\nimport { VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { buttonVariants } from \"src/ui/button\";\n\nconst AlertDialog = AlertDialogPrimitive.Root;\n\nconst AlertDialogTrigger = AlertDialogPrimitive.Trigger;\n\nconst AlertDialogPortal = AlertDialogPrimitive.Portal;\n\nconst AlertDialogOverlay = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Overlay>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPrimitive.Overlay\n        className={cn(\n            \"fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n            className,\n        )}\n        {...props}\n        ref={ref}\n    />\n));\nAlertDialogOverlay.displayName = AlertDialogPrimitive.Overlay.displayName;\n\nconst AlertDialogContent = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Content>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPortal>\n        <AlertDialogOverlay />\n        <AlertDialogPrimitive.Content\n            ref={ref}\n            className={cn(\n                \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg\",\n                className,\n            )}\n            {...props}\n        />\n    </AlertDialogPortal>\n));\nAlertDialogContent.displayName = AlertDialogPrimitive.Content.displayName;\n\nconst AlertDialogHeader = ({\n    className,\n    ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n    <div\n        className={cn(\n            \"flex flex-col space-y-2 text-center sm:text-left\",\n            className,\n        )}\n        {...props}\n    />\n);\nAlertDialogHeader.displayName = \"AlertDialogHeader\";\n\nconst AlertDialogFooter = ({\n    className,\n    ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n    <div\n        className={cn(\n            \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n            className,\n        )}\n        {...props}\n    />\n);\nAlertDialogFooter.displayName = \"AlertDialogFooter\";\n\nconst AlertDialogTitle = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Title>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPrimitive.Title\n        ref={ref}\n        className={cn(\"text-lg font-semibold\", className)}\n        {...props}\n    />\n));\nAlertDialogTitle.displayName = AlertDialogPrimitive.Title.displayName;\n\nconst AlertDialogDescription = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Description>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPrimitive.Description\n        ref={ref}\n        className={cn(\"text-sm text-muted-foreground\", className)}\n        {...props}\n    />\n));\nAlertDialogDescription.displayName =\n    AlertDialogPrimitive.Description.displayName;\n\nconst AlertDialogAction = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Action> &\n        VariantProps<typeof buttonVariants>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Action> &\n        VariantProps<typeof buttonVariants>\n>(({ className, variant = \"default\", size = \"default\", ...props }, ref) => (\n    <AlertDialogPrimitive.Action\n        ref={ref}\n        className={cn(\n            buttonVariants({\n                variant,\n                size,\n            }),\n            className,\n        )}\n        {...props}\n    />\n));\nAlertDialogAction.displayName = AlertDialogPrimitive.Action.displayName;\n\nconst AlertDialogCancel = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Cancel> &\n        VariantProps<typeof buttonVariants>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Cancel> &\n        VariantProps<typeof buttonVariants>\n>(({ className, variant = \"outline\", size = \"default\", ...props }, ref) => (\n    <AlertDialogPrimitive.Cancel\n        ref={ref}\n        className={cn(\n            buttonVariants({ variant, size }),\n            \"mt-2 sm:mt-0\",\n            className,\n        )}\n        {...props}\n    />\n));\nAlertDialogCancel.displayName = AlertDialogPrimitive.Cancel.displayName;\n\nexport {\n    AlertDialog,\n    AlertDialogAction,\n    AlertDialogCancel,\n    AlertDialogContent,\n    AlertDialogDescription,\n    AlertDialogFooter,\n    AlertDialogHeader,\n    AlertDialogOverlay,\n    AlertDialogPortal,\n    AlertDialogTitle,\n    AlertDialogTrigger,\n};\n", "import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst badgeVariants = cva(\n  \"inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2\",\n  {\n    variants: {\n      variant: {\n        default:\n          \"border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80\",\n        secondary:\n          \"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n        destructive:\n          \"border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80\",\n        outline: \"text-foreground\",\n      },\n    },\n    defaultVariants: {\n      variant: \"default\",\n    },\n  }\n)\n\nexport interface BadgeProps\n  extends React.HTMLAttributes<HTMLDivElement>,\n    VariantProps<typeof badgeVariants> {}\n\nfunction Badge({ className, variant, ...props }: BadgeProps) {\n  return (\n    <div className={cn(badgeVariants({ variant }), className)} {...props} />\n  )\n}\n\nexport { Badge, badgeVariants }\n", "\"use client\";\n\nimport * as React from \"react\";\nimport { ChevronLeftIcon, ChevronRightIcon } from \"@radix-ui/react-icons\";\nimport { DayPicker } from \"react-day-picker\";\n\nimport { cn } from \"@/lib/utils\";\nimport { buttonVariants } from \"src/ui/button\";\n\nexport type CalendarProps = React.ComponentProps<typeof DayPicker>;\n\nfunction Calendar({\n    className,\n    classNames,\n    showOutsideDays = true,\n    ...props\n}: CalendarProps) {\n    return (\n        <DayPicker\n            showOutsideDays={showOutsideDays}\n            className={cn(\"p-3\", className)}\n            classNames={{\n                months: \"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0\",\n                month: \"space-y-4\",\n                caption: \"flex justify-center pt-1 relative items-center\",\n                caption_label: \"text-sm font-medium\",\n                nav: \"space-x-1 flex items-center\",\n                nav_button: cn(\n                    buttonVariants({ variant: \"outline\" }),\n                    \"h-7 w-7 bg-transparent p-0 opacity-50 hover:opacity-100\",\n                ),\n                nav_button_previous: \"absolute left-1\",\n                nav_button_next: \"absolute right-1\",\n                table: \"w-full border-collapse space-y-1\",\n                head_row: \"flex\",\n                head_cell:\n                    \"text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]\",\n                row: \"flex w-full mt-2\",\n                cell: cn(\n                    \"relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected].day-range-end)]:rounded-r-md\",\n                    props.mode === \"range\"\n                        ? \"[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md\"\n                        : \"[&:has([aria-selected])]:rounded-md\",\n                ),\n                day: cn(\n                    buttonVariants({ variant: \"ghost\" }),\n                    \"h-8 w-8 p-0 font-normal aria-selected:opacity-100\",\n                ),\n                day_range_start: \"day-range-start\",\n                day_range_end: \"day-range-end\",\n                day_selected:\n                    \"bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground\",\n                day_today: \"bg-accent text-accent-foreground\",\n                day_outside:\n                    \"day-outside text-muted-foreground opacity-50  aria-selected:bg-accent/50 aria-selected:text-muted-foreground aria-selected:opacity-30\",\n                day_disabled: \"text-muted-foreground opacity-50\",\n                day_range_middle:\n                    \"aria-selected:bg-accent aria-selected:text-accent-foreground\",\n                day_hidden: \"invisible\",\n                ...classNames,\n            }}\n            components={{\n                IconLeft: () => <ChevronLeftIcon className=\"h-4 w-4\" />,\n                IconRight: () => <ChevronRightIcon className=\"h-4 w-4\" />,\n            }}\n            {...props}\n        />\n    );\n}\nCalendar.displayName = \"Calendar\";\n\nexport { Calendar };\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Card = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div\n    ref={ref}\n    className={cn(\n      \"rounded-xl border bg-card text-card-foreground shadow\",\n      className\n    )}\n    {...props}\n  />\n))\nCard.displayName = \"Card\"\n\nconst CardHeader = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div\n    ref={ref}\n    className={cn(\"flex flex-col space-y-1.5 p-6\", className)}\n    {...props}\n  />\n))\nCardHeader.displayName = \"CardHeader\"\n\nconst CardTitle = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLHeadingElement>\n>(({ className, ...props }, ref) => (\n  <h3\n    ref={ref}\n    className={cn(\"font-semibold leading-none tracking-tight\", className)}\n    {...props}\n  />\n))\nCardTitle.displayName = \"CardTitle\"\n\nconst CardDescription = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, ...props }, ref) => (\n  <p\n    ref={ref}\n    className={cn(\"text-sm text-muted-foreground\", className)}\n    {...props}\n  />\n))\nCardDescription.displayName = \"CardDescription\"\n\nconst CardContent = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div ref={ref} className={cn(\"p-6 pt-0\", className)} {...props} />\n))\nCardContent.displayName = \"CardContent\"\n\nconst CardFooter = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div\n    ref={ref}\n    className={cn(\"flex items-center p-6 pt-0\", className)}\n    {...props}\n  />\n))\nCardFooter.displayName = \"CardFooter\"\n\nexport { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent }\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as CheckboxPrimitive from \"@radix-ui/react-checkbox\"\nimport { CheckIcon } from \"@radix-ui/react-icons\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Checkbox = React.forwardRef<\n  React.ElementRef<typeof CheckboxPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>\n>(({ className, ...props }, ref) => (\n  <CheckboxPrimitive.Root\n    ref={ref}\n    className={cn(\n      \"peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground\",\n      className\n    )}\n    {...props}\n  >\n    <CheckboxPrimitive.Indicator\n      className={cn(\"flex items-center justify-center text-current\")}\n    >\n      <CheckIcon className=\"h-4 w-4\" />\n    </CheckboxPrimitive.Indicator>\n  </CheckboxPrimitive.Root>\n))\nCheckbox.displayName = CheckboxPrimitive.Root.displayName\n\nexport { Checkbox }\n", "\"use client\"\n\nimport * as React from \"react\"\nimport { type DialogProps } from \"@radix-ui/react-dialog\"\nimport { MagnifyingGlassIcon } from \"@radix-ui/react-icons\"\nimport { Command as CommandPrimitive } from \"cmdk\"\n\nimport { cn } from \"@/lib/utils\"\nimport { Dialog, DialogContent } from \"src/ui/dialog\"\n\nconst Command = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive\n    ref={ref}\n    className={cn(\n      \"flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground\",\n      className\n    )}\n    {...props}\n  />\n))\nCommand.displayName = CommandPrimitive.displayName\n\ninterface CommandDialogProps extends DialogProps {}\n\nconst CommandDialog = ({ children, ...props }: CommandDialogProps) => {\n  return (\n    <Dialog {...props}>\n      <DialogContent className=\"overflow-hidden p-0\">\n        <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n          {children}\n        </Command>\n      </DialogContent>\n    </Dialog>\n  )\n}\n\nconst CommandInput = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Input>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>\n>(({ className, ...props }, ref) => (\n  <div className=\"flex items-center border-b px-3\" cmdk-input-wrapper=\"\">\n    <MagnifyingGlassIcon className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n    <CommandPrimitive.Input\n      ref={ref}\n      className={cn(\n        \"flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50\",\n        className\n      )}\n      {...props}\n    />\n  </div>\n))\n\nCommandInput.displayName = CommandPrimitive.Input.displayName\n\nconst CommandList = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.List>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.List\n    ref={ref}\n    className={cn(\"max-h-[300px] overflow-y-auto overflow-x-hidden\", className)}\n    {...props}\n  />\n))\n\nCommandList.displayName = CommandPrimitive.List.displayName\n\nconst CommandEmpty = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Empty>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => (\n  <CommandPrimitive.Empty\n    ref={ref}\n    className=\"py-6 text-center text-sm\"\n    {...props}\n  />\n))\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName\n\nconst CommandGroup = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Group>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.Group\n    ref={ref}\n    className={cn(\n      \"overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground\",\n      className\n    )}\n    {...props}\n  />\n))\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName\n\nconst CommandSeparator = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Separator>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.Separator\n    ref={ref}\n    className={cn(\"-mx-1 h-px bg-border\", className)}\n    {...props}\n  />\n))\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName\n\nconst CommandItem = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Item>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.Item\n    ref={ref}\n    className={cn(\n      \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50\",\n      className\n    )}\n    {...props}\n  />\n))\n\nCommandItem.displayName = CommandPrimitive.Item.displayName\n\nconst CommandShortcut = ({\n  className,\n  ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n  return (\n    <span\n      className={cn(\n        \"ml-auto text-xs tracking-widest text-muted-foreground\",\n        className\n      )}\n      {...props}\n    />\n  )\n}\nCommandShortcut.displayName = \"CommandShortcut\"\n\nexport {\n  Command,\n  CommandDialog,\n  CommandInput,\n  CommandList,\n  CommandEmpty,\n  CommandGroup,\n  CommandItem,\n  CommandShortcut,\n  CommandSeparator,\n}\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\"\nimport { Cross2Icon } from \"@radix-ui/react-icons\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Dialog = DialogPrimitive.Root\n\nconst DialogTrigger = DialogPrimitive.Trigger\n\nconst DialogPortal = DialogPrimitive.Portal\n\nconst DialogClose = DialogPrimitive.Close\n\nconst DialogOverlay = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Overlay>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n  <DialogPrimitive.Overlay\n    ref={ref}\n    className={cn(\n      \"fixed inset-0 z-50 bg-black/80  data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n      className\n    )}\n    {...props}\n  />\n))\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName\n\nconst DialogContent = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Content>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n  <DialogPortal>\n    <DialogOverlay />\n    <DialogPrimitive.Content\n      ref={ref}\n      className={cn(\n        \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg\",\n        className\n      )}\n      {...props}\n    >\n      {children}\n      <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n        <Cross2Icon className=\"h-4 w-4\" />\n        <span className=\"sr-only\">Close</span>\n      </DialogPrimitive.Close>\n    </DialogPrimitive.Content>\n  </DialogPortal>\n))\nDialogContent.displayName = DialogPrimitive.Content.displayName\n\nconst DialogHeader = ({\n  className,\n  ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n  <div\n    className={cn(\n      \"flex flex-col space-y-1.5 text-center sm:text-left\",\n      className\n    )}\n    {...props}\n  />\n)\nDialogHeader.displayName = \"DialogHeader\"\n\nconst DialogFooter = ({\n  className,\n  ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n  <div\n    className={cn(\n      \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n      className\n    )}\n    {...props}\n  />\n)\nDialogFooter.displayName = \"DialogFooter\"\n\nconst DialogTitle = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Title>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n  <DialogPrimitive.Title\n    ref={ref}\n    className={cn(\n      \"text-lg font-semibold leading-none tracking-tight\",\n      className\n    )}\n    {...props}\n  />\n))\nDialogTitle.displayName = DialogPrimitive.Title.displayName\n\nconst DialogDescription = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Description>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n  <DialogPrimitive.Description\n    ref={ref}\n    className={cn(\"text-sm text-muted-foreground\", className)}\n    {...props}\n  />\n))\nDialogDescription.displayName = DialogPrimitive.Description.displayName\n\nexport {\n  Dialog,\n  DialogPortal,\n  DialogOverlay,\n  DialogTrigger,\n  DialogClose,\n  DialogContent,\n  DialogHeader,\n  DialogFooter,\n  DialogTitle,\n  DialogDescription,\n}\n", "\"use client\";\n\nimport * as React from \"react\";\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\";\nimport {\n    CheckIcon,\n    ChevronRightIcon,\n    DotFilledIcon,\n} from \"@radix-ui/react-icons\";\n\nimport { cn } from \"../lib/utils\";\n\nconst DropdownMenu = DropdownMenuPrimitive.Root;\n\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger;\n\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group;\n\nconst DropdownMenuPortal = DropdownMenuPrimitive.Portal;\n\nconst DropdownMenuSub = DropdownMenuPrimitive.Sub;\n\nconst DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup;\n\nconst DropdownMenuSubTrigger = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.SubTrigger>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> & {\n        inset?: boolean;\n    }\n>(({ className, inset, children, ...props }, ref) => (\n    <DropdownMenuPrimitive.SubTrigger\n        ref={ref}\n        className={cn(\n            \"flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent\",\n            inset && \"pl-8\",\n            className,\n        )}\n        {...props}\n    >\n        {children}\n        <ChevronRightIcon className=\"ml-auto h-4 w-4\" />\n    </DropdownMenuPrimitive.SubTrigger>\n));\nDropdownMenuSubTrigger.displayName =\n    DropdownMenuPrimitive.SubTrigger.displayName;\n\nconst DropdownMenuSubContent = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.SubContent>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n    <DropdownMenuPrimitive.SubContent\n        ref={ref}\n        className={cn(\n            \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg 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\",\n            className,\n        )}\n        {...props}\n    />\n));\nDropdownMenuSubContent.displayName =\n    DropdownMenuPrimitive.SubContent.displayName;\n\nconst DropdownMenuContent = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n    <DropdownMenuPrimitive.Portal>\n        <DropdownMenuPrimitive.Content\n            ref={ref}\n            sideOffset={sideOffset}\n            className={cn(\n                \"z-50 min-w-[8rem] overflow-hidden rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md\",\n                \"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\",\n                className,\n            )}\n            {...props}\n        />\n    </DropdownMenuPrimitive.Portal>\n));\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName;\n\nconst DropdownMenuItem = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> & {\n        inset?: boolean;\n    }\n>(({ className, inset, ...props }, ref) => (\n    <DropdownMenuPrimitive.Item\n        ref={ref}\n        className={cn(\n            \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            inset && \"pl-8\",\n            className,\n        )}\n        {...props}\n    />\n));\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName;\n\nconst DropdownMenuCheckboxItem = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.CheckboxItem>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n    <DropdownMenuPrimitive.CheckboxItem\n        ref={ref}\n        className={cn(\n            \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            className,\n        )}\n        checked={checked}\n        {...props}\n    >\n        <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n            <DropdownMenuPrimitive.ItemIndicator>\n                <CheckIcon className=\"h-4 w-4\" />\n            </DropdownMenuPrimitive.ItemIndicator>\n        </span>\n        {children}\n    </DropdownMenuPrimitive.CheckboxItem>\n));\nDropdownMenuCheckboxItem.displayName =\n    DropdownMenuPrimitive.CheckboxItem.displayName;\n\nconst DropdownMenuRadioItem = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.RadioItem>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n    <DropdownMenuPrimitive.RadioItem\n        ref={ref}\n        className={cn(\n            \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            className,\n        )}\n        {...props}\n    >\n        <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n            <DropdownMenuPrimitive.ItemIndicator>\n                <DotFilledIcon className=\"h-4 w-4 fill-current\" />\n            </DropdownMenuPrimitive.ItemIndicator>\n        </span>\n        {children}\n    </DropdownMenuPrimitive.RadioItem>\n));\nDropdownMenuRadioItem.displayName = DropdownMenuPrimitive.RadioItem.displayName;\n\nconst DropdownMenuLabel = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Label>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> & {\n        inset?: boolean;\n    }\n>(({ className, inset, ...props }, ref) => (\n    <DropdownMenuPrimitive.Label\n        ref={ref}\n        className={cn(\n            \"px-2 py-1.5 text-sm font-semibold\",\n            inset && \"pl-8\",\n            className,\n        )}\n        {...props}\n    />\n));\nDropdownMenuLabel.displayName = DropdownMenuPrimitive.Label.displayName;\n\nconst DropdownMenuSeparator = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Separator>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n    <DropdownMenuPrimitive.Separator\n        ref={ref}\n        className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\n        {...props}\n    />\n));\nDropdownMenuSeparator.displayName = DropdownMenuPrimitive.Separator.displayName;\n\nconst DropdownMenuShortcut = ({\n    className,\n    ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n    return (\n        <span\n            className={cn(\n                \"ml-auto text-xs tracking-widest opacity-60\",\n                className,\n            )}\n            {...props}\n        />\n    );\n};\nDropdownMenuShortcut.displayName = \"DropdownMenuShortcut\";\n\nexport {\n    DropdownMenu,\n    DropdownMenuTrigger,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuCheckboxItem,\n    DropdownMenuRadioItem,\n    DropdownMenuLabel,\n    DropdownMenuSeparator,\n    DropdownMenuShortcut,\n    DropdownMenuGroup,\n    DropdownMenuPortal,\n    DropdownMenuSub,\n    DropdownMenuSubContent,\n    DropdownMenuSubTrigger,\n    DropdownMenuRadioGroup,\n};\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport {\n  Controller,\n  ControllerProps,\n  FieldPath,\n  FieldValues,\n  FormProvider,\n  useFormContext,\n} from \"react-hook-form\"\n\nimport { cn } from \"@/lib/utils\"\nimport { Label } from \"src/ui/label\"\n\nconst Form = FormProvider\n\ntype FormFieldContextValue<\n  TFieldValues extends FieldValues = FieldValues,\n  TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> = {\n  name: TName\n}\n\nconst FormFieldContext = React.createContext<FormFieldContextValue>(\n  {} as FormFieldContextValue\n)\n\nconst FormField = <\n  TFieldValues extends FieldValues = FieldValues,\n  TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n>({\n  ...props\n}: ControllerProps<TFieldValues, TName>) => {\n  return (\n    <FormFieldContext.Provider value={{ name: props.name }}>\n      <Controller {...props} />\n    </FormFieldContext.Provider>\n  )\n}\n\nconst useFormField = () => {\n  const fieldContext = React.useContext(FormFieldContext)\n  const itemContext = React.useContext(FormItemContext)\n  const { getFieldState, formState } = useFormContext()\n\n  const fieldState = getFieldState(fieldContext.name, formState)\n\n  if (!fieldContext) {\n    throw new Error(\"useFormField should be used within <FormField>\")\n  }\n\n  const { id } = itemContext\n\n  return {\n    id,\n    name: fieldContext.name,\n    formItemId: `${id}-form-item`,\n    formDescriptionId: `${id}-form-item-description`,\n    formMessageId: `${id}-form-item-message`,\n    ...fieldState,\n  }\n}\n\ntype FormItemContextValue = {\n  id: string\n}\n\nconst FormItemContext = React.createContext<FormItemContextValue>(\n  {} as FormItemContextValue\n)\n\nconst FormItem = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => {\n  const id = React.useId()\n\n  return (\n    <FormItemContext.Provider value={{ id }}>\n      <div ref={ref} className={cn(\"space-y-2\", className)} {...props} />\n    </FormItemContext.Provider>\n  )\n})\nFormItem.displayName = \"FormItem\"\n\nconst FormLabel = React.forwardRef<\n  React.ElementRef<typeof LabelPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root>\n>(({ className, ...props }, ref) => {\n  const { error, formItemId } = useFormField()\n\n  return (\n    <Label\n      ref={ref}\n      className={cn(error && \"text-destructive\", className)}\n      htmlFor={formItemId}\n      {...props}\n    />\n  )\n})\nFormLabel.displayName = \"FormLabel\"\n\nconst FormControl = React.forwardRef<\n  React.ElementRef<typeof Slot>,\n  React.ComponentPropsWithoutRef<typeof Slot>\n>(({ ...props }, ref) => {\n  const { error, formItemId, formDescriptionId, formMessageId } = useFormField()\n\n  return (\n    <Slot\n      ref={ref}\n      id={formItemId}\n      aria-describedby={\n        !error\n          ? `${formDescriptionId}`\n          : `${formDescriptionId} ${formMessageId}`\n      }\n      aria-invalid={!!error}\n      {...props}\n    />\n  )\n})\nFormControl.displayName = \"FormControl\"\n\nconst FormDescription = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, ...props }, ref) => {\n  const { formDescriptionId } = useFormField()\n\n  return (\n    <p\n      ref={ref}\n      id={formDescriptionId}\n      className={cn(\"text-[0.8rem] text-muted-foreground\", className)}\n      {...props}\n    />\n  )\n})\nFormDescription.displayName = \"FormDescription\"\n\nconst FormMessage = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, children, ...props }, ref) => {\n  const { error, formMessageId } = useFormField()\n  const body = error ? String(error?.message) : children\n\n  if (!body) {\n    return null\n  }\n\n  return (\n    <p\n      ref={ref}\n      id={formMessageId}\n      className={cn(\"text-[0.8rem] font-medium text-destructive\", className)}\n      {...props}\n    >\n      {body}\n    </p>\n  )\n})\nFormMessage.displayName = \"FormMessage\"\n\nexport {\n  useFormField,\n  Form,\n  FormItem,\n  FormLabel,\n  FormControl,\n  FormDescription,\n  FormMessage,\n  FormField,\n}\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst labelVariants = cva(\n  \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\"\n)\n\nconst Label = React.forwardRef<\n  React.ElementRef<typeof LabelPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &\n    VariantProps<typeof labelVariants>\n>(({ className, ...props }, ref) => (\n  <LabelPrimitive.Root\n    ref={ref}\n    className={cn(labelVariants(), className)}\n    {...props}\n  />\n))\nLabel.displayName = LabelPrimitive.Root.displayName\n\nexport { Label }\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nexport interface InputProps\n  extends React.InputHTMLAttributes<HTMLInputElement> {}\n\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n  ({ className, type, ...props }, ref) => {\n    return (\n      <input\n        type={type}\n        className={cn(\n          \"flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50\",\n          className\n        )}\n        ref={ref}\n        {...props}\n      />\n    )\n  }\n)\nInput.displayName = \"Input\"\n\nexport { Input }\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Popover = PopoverPrimitive.Root\n\nconst PopoverTrigger = PopoverPrimitive.Trigger\n\nconst PopoverAnchor = PopoverPrimitive.Anchor\n\nconst PopoverContent = React.forwardRef<\n  React.ElementRef<typeof PopoverPrimitive.Content>,\n  React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>\n>(({ className, align = \"center\", sideOffset = 4, ...props }, ref) => (\n  <PopoverPrimitive.Portal>\n    <PopoverPrimitive.Content\n      ref={ref}\n      align={align}\n      sideOffset={sideOffset}\n      className={cn(\n        \"z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none 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\",\n        className\n      )}\n      {...props}\n    />\n  </PopoverPrimitive.Portal>\n))\nPopoverContent.displayName = PopoverPrimitive.Content.displayName\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n", "\"use client\";\n\nimport { DragHandleDots2Icon } from \"@radix-ui/react-icons\";\nimport * as ResizablePrimitive from \"react-resizable-panels\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst ResizablePanelGroup = ({\n    className,\n    ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelGroup>) => (\n    <ResizablePrimitive.PanelGroup\n        className={cn(\n            \"flex h-full w-full data-[panel-group-direction=vertical]:flex-col\",\n            className,\n        )}\n        {...props}\n    />\n);\n\nconst ResizablePanel = ResizablePrimitive.Panel;\n\nconst ResizableHandle = ({\n    withHandle,\n    className,\n    ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelResizeHandle> & {\n    withHandle?: boolean;\n}) => (\n    <ResizablePrimitive.PanelResizeHandle\n        className={cn(\n            \"relative flex w-px items-center justify-center bg-border after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring focus-visible:ring-offset-1 data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:-translate-y-1/2 data-[panel-group-direction=vertical]:after:translate-x-0 [&[data-panel-group-direction=vertical]>div]:rotate-90\",\n            className,\n        )}\n        {...props}\n    >\n        {withHandle && (\n            <div className=\"z-10 flex h-4 w-3 items-center justify-center rounded-sm border bg-border\">\n                <DragHandleDots2Icon className=\"h-2.5 w-2.5\" />\n            </div>\n        )}\n    </ResizablePrimitive.PanelResizeHandle>\n);\n\nexport { ResizablePanelGroup, ResizablePanel, ResizableHandle };\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as ScrollAreaPrimitive from \"@radix-ui/react-scroll-area\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst ScrollArea = React.forwardRef<\n  React.ElementRef<typeof ScrollAreaPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.Root>\n>(({ className, children, ...props }, ref) => (\n  <ScrollAreaPrimitive.Root\n    ref={ref}\n    className={cn(\"relative overflow-hidden\", className)}\n    {...props}\n  >\n    <ScrollAreaPrimitive.Viewport className=\"h-full w-full rounded-[inherit]\">\n      {children}\n    </ScrollAreaPrimitive.Viewport>\n    <ScrollBar />\n    <ScrollAreaPrimitive.Corner />\n  </ScrollAreaPrimitive.Root>\n))\nScrollArea.displayName = ScrollAreaPrimitive.Root.displayName\n\nconst ScrollBar = React.forwardRef<\n  React.ElementRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>,\n  React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>\n>(({ className, orientation = \"vertical\", ...props }, ref) => (\n  <ScrollAreaPrimitive.ScrollAreaScrollbar\n    ref={ref}\n    orientation={orientation}\n    className={cn(\n      \"flex touch-none select-none transition-colors\",\n      orientation === \"vertical\" &&\n        \"h-full w-2.5 border-l border-l-transparent p-[1px]\",\n      orientation === \"horizontal\" &&\n        \"h-2.5 flex-col border-t border-t-transparent p-[1px]\",\n      className\n    )}\n    {...props}\n  >\n    <ScrollAreaPrimitive.ScrollAreaThumb className=\"relative flex-1 rounded-full bg-border\" />\n  </ScrollAreaPrimitive.ScrollAreaScrollbar>\n))\nScrollBar.displayName = ScrollAreaPrimitive.ScrollAreaScrollbar.displayName\n\nexport { ScrollArea, ScrollBar }\n", "\"use client\";\n\nimport * as React from \"react\";\nimport {\n    CaretSortIcon,\n    CheckIcon,\n    ChevronDownIcon,\n    ChevronUpIcon,\n} from \"@radix-ui/react-icons\";\nimport * as SelectPrimitive from \"@radix-ui/react-select\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Select = SelectPrimitive.Root;\n\nconst SelectGroup = SelectPrimitive.Group;\n\nconst SelectValue = SelectPrimitive.Value;\n\nconst SelectTrigger = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Trigger>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Trigger>\n>(({ className, children, ...props }, ref) => (\n    <SelectPrimitive.Trigger\n        ref={ref}\n        className={cn(\n            \"flex h-9 w-full items-center justify-between whitespace-nowrap rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-1 focus:ring-ring disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1\",\n            className,\n        )}\n        {...props}\n    >\n        {children}\n        <SelectPrimitive.Icon asChild>\n            <CaretSortIcon className=\"h-4 w-4 opacity-50\" />\n        </SelectPrimitive.Icon>\n    </SelectPrimitive.Trigger>\n));\nSelectTrigger.displayName = SelectPrimitive.Trigger.displayName;\n\nconst SelectScrollUpButton = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.ScrollUpButton>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.ScrollUpButton>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.ScrollUpButton\n        ref={ref}\n        className={cn(\n            \"flex cursor-default items-center justify-center py-1\",\n            className,\n        )}\n        {...props}\n    >\n        <ChevronUpIcon />\n    </SelectPrimitive.ScrollUpButton>\n));\nSelectScrollUpButton.displayName = SelectPrimitive.ScrollUpButton.displayName;\n\nconst SelectScrollDownButton = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.ScrollDownButton>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.ScrollDownButton>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.ScrollDownButton\n        ref={ref}\n        className={cn(\n            \"flex cursor-default items-center justify-center py-1\",\n            className,\n        )}\n        {...props}\n    >\n        <ChevronDownIcon />\n    </SelectPrimitive.ScrollDownButton>\n));\nSelectScrollDownButton.displayName =\n    SelectPrimitive.ScrollDownButton.displayName;\n\nconst SelectContent = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Content>\n>(({ className, children, position = \"popper\", ...props }, ref) => (\n    <SelectPrimitive.Portal>\n        <SelectPrimitive.Content\n            ref={ref}\n            className={cn(\n                \"relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md 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\",\n                position === \"popper\" &&\n                    \"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1\",\n                className,\n            )}\n            position={position}\n            {...props}\n        >\n            <SelectScrollUpButton />\n            <SelectPrimitive.Viewport\n                className={cn(\n                    \"p-1\",\n                    position === \"popper\" &&\n                        \"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]\",\n                )}\n            >\n                {children}\n            </SelectPrimitive.Viewport>\n            <SelectScrollDownButton />\n        </SelectPrimitive.Content>\n    </SelectPrimitive.Portal>\n));\nSelectContent.displayName = SelectPrimitive.Content.displayName;\n\nconst SelectLabel = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Label>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Label>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.Label\n        ref={ref}\n        className={cn(\"px-2 py-1.5 text-sm font-semibold\", className)}\n        {...props}\n    />\n));\nSelectLabel.displayName = SelectPrimitive.Label.displayName;\n\nconst SelectItem = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Item>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item>\n>(({ className, children, ...props }, ref) => (\n    <SelectPrimitive.Item\n        ref={ref}\n        className={cn(\n            \"relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            className,\n        )}\n        {...props}\n    >\n        <span className=\"absolute right-2 flex h-3.5 w-3.5 items-center justify-center\">\n            <SelectPrimitive.ItemIndicator>\n                <CheckIcon className=\"h-4 w-4\" />\n            </SelectPrimitive.ItemIndicator>\n        </span>\n        <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n    </SelectPrimitive.Item>\n));\nSelectItem.displayName = SelectPrimitive.Item.displayName;\n\nconst SelectSeparator = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Separator>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.Separator\n        ref={ref}\n        className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\n        {...props}\n    />\n));\nSelectSeparator.displayName = SelectPrimitive.Separator.displayName;\n\nexport {\n    Select,\n    SelectGroup,\n    SelectValue,\n    SelectTrigger,\n    SelectContent,\n    SelectLabel,\n    SelectItem,\n    SelectSeparator,\n    SelectScrollUpButton,\n    SelectScrollDownButton,\n};\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Separator = React.forwardRef<\n  React.ElementRef<typeof SeparatorPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof SeparatorPrimitive.Root>\n>(\n  (\n    { className, orientation = \"horizontal\", decorative = true, ...props },\n    ref\n  ) => (\n    <SeparatorPrimitive.Root\n      ref={ref}\n      decorative={decorative}\n      orientation={orientation}\n      className={cn(\n        \"shrink-0 bg-border\",\n        orientation === \"horizontal\" ? \"h-[1px] w-full\" : \"h-full w-[1px]\",\n        className\n      )}\n      {...props}\n    />\n  )\n)\nSeparator.displayName = SeparatorPrimitive.Root.displayName\n\nexport { Separator }\n", "\"use client\";\n\nimport { useTheme } from \"next-themes\";\nimport { Toaster as Sonner } from \"sonner\";\n\ntype ToasterProps = React.ComponentProps<typeof Sonner>;\n\nconst Toaster = ({ ...props }: ToasterProps) => {\n    const { theme = \"system\" } = useTheme();\n\n    return (\n        <Sonner\n            theme={theme as ToasterProps[\"theme\"]}\n            className=\"toaster group\"\n            toastOptions={{\n                classNames: {\n                    toast: \"group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg\",\n                    description: \"group-[.toast]:text-muted-foreground\",\n                    actionButton:\n                        \"group-[.toast]:bg-primary group-[.toast]:text-primary-foreground\",\n                    cancelButton:\n                        \"group-[.toast]:bg-muted group-[.toast]:text-muted-foreground\",\n                },\n            }}\n            {...props}\n        />\n    );\n};\n\nexport { Toaster };\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Table = React.forwardRef<\n  HTMLTableElement,\n  React.HTMLAttributes<HTMLTableElement>\n>(({ className, ...props }, ref) => (\n  <div className=\"relative w-full overflow-auto\">\n    <table\n      ref={ref}\n      className={cn(\"w-full caption-bottom text-sm\", className)}\n      {...props}\n    />\n  </div>\n))\nTable.displayName = \"Table\"\n\nconst TableHeader = React.forwardRef<\n  HTMLTableSectionElement,\n  React.HTMLAttributes<HTMLTableSectionElement>\n>(({ className, ...props }, ref) => (\n  <thead ref={ref} className={cn(\"[&_tr]:border-b\", className)} {...props} />\n))\nTableHeader.displayName = \"TableHeader\"\n\nconst TableBody = React.forwardRef<\n  HTMLTableSectionElement,\n  React.HTMLAttributes<HTMLTableSectionElement>\n>(({ className, ...props }, ref) => (\n  <tbody\n    ref={ref}\n    className={cn(\"[&_tr:last-child]:border-0\", className)}\n    {...props}\n  />\n))\nTableBody.displayName = \"TableBody\"\n\nconst TableFooter = React.forwardRef<\n  HTMLTableSectionElement,\n  React.HTMLAttributes<HTMLTableSectionElement>\n>(({ className, ...props }, ref) => (\n  <tfoot\n    ref={ref}\n    className={cn(\n      \"border-t bg-muted/50 font-medium [&>tr]:last:border-b-0\",\n      className\n    )}\n    {...props}\n  />\n))\nTableFooter.displayName = \"TableFooter\"\n\nconst TableRow = React.forwardRef<\n  HTMLTableRowElement,\n  React.HTMLAttributes<HTMLTableRowElement>\n>(({ className, ...props }, ref) => (\n  <tr\n    ref={ref}\n    className={cn(\n      \"border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted\",\n      className\n    )}\n    {...props}\n  />\n))\nTableRow.displayName = \"TableRow\"\n\nconst TableHead = React.forwardRef<\n  HTMLTableCellElement,\n  React.ThHTMLAttributes<HTMLTableCellElement>\n>(({ className, ...props }, ref) => (\n  <th\n    ref={ref}\n    className={cn(\n      \"h-10 px-2 text-left align-middle font-medium text-muted-foreground [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]\",\n      className\n    )}\n    {...props}\n  />\n))\nTableHead.displayName = \"TableHead\"\n\nconst TableCell = React.forwardRef<\n  HTMLTableCellElement,\n  React.TdHTMLAttributes<HTMLTableCellElement>\n>(({ className, ...props }, ref) => (\n  <td\n    ref={ref}\n    className={cn(\n      \"p-2 align-middle [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]\",\n      className\n    )}\n    {...props}\n  />\n))\nTableCell.displayName = \"TableCell\"\n\nconst TableCaption = React.forwardRef<\n  HTMLTableCaptionElement,\n  React.HTMLAttributes<HTMLTableCaptionElement>\n>(({ className, ...props }, ref) => (\n  <caption\n    ref={ref}\n    className={cn(\"mt-4 text-sm text-muted-foreground\", className)}\n    {...props}\n  />\n))\nTableCaption.displayName = \"TableCaption\"\n\nexport {\n  Table,\n  TableHeader,\n  TableBody,\n  TableFooter,\n  TableHead,\n  TableRow,\n  TableCell,\n  TableCaption,\n}\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nexport interface TextareaProps\n  extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {}\n\nconst Textarea = React.forwardRef<HTMLTextAreaElement, TextareaProps>(\n  ({ className, ...props }, ref) => {\n    return (\n      <textarea\n        className={cn(\n          \"flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50\",\n          className\n        )}\n        ref={ref}\n        {...props}\n      />\n    )\n  }\n)\nTextarea.displayName = \"Textarea\"\n\nexport { Textarea }\n", "\"use client\";\n\nimport * as React from \"react\";\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst Tooltip = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n    React.ElementRef<typeof TooltipPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n    <TooltipPrimitive.Content\n        ref={ref}\n        sideOffset={sideOffset}\n        className={cn(\n            \"z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs 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\",\n            className,\n        )}\n        {...props}\n    />\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };\n", "import type { ConfirmDialogProps } from \"@/types\";\nimport {\n    AlertDialog,\n    AlertDialogAction,\n    AlertDialogCancel,\n    AlertDialogContent,\n    AlertDialogDescription,\n    AlertDialogFooter,\n    AlertDialogHeader,\n    AlertDialogTitle,\n    AlertDialogTrigger,\n} from \"@/ui/alert-dialog\";\nimport { LoadingIcon } from \"@/ui/loading\";\nimport { CheckIcon, XIcon } from \"lucide-react\";\nimport { FC, isValidElement, useMemo } from \"react\";\n\nexport const ConfirmDialog: FC<ConfirmDialogProps> = ({\n    children,\n    title = \"Are you sure?\",\n    description = \"This action cannot be undone.\",\n    okText = \"Ok\",\n    cancelText = \"Cancel\",\n    okButtonSize = \"default\",\n    cancelButtonSize = \"default\",\n    okButtonVariant = \"default\",\n    cancelButtonVariant = \"outline\",\n    loading = false,\n    okIconSide = \"left\",\n    cancelIconSide = \"left\",\n    onConfirm,\n    okIcon,\n    cancelIcon,\n    open,\n    onOpenChange,\n    defaultOpen,\n}) => {\n    const CancelIcon = useMemo(() => {\n        if (isValidElement(cancelIcon)) {\n            return cancelIcon;\n        }\n\n        return <XIcon className=\"mr-2 h-4 w-4\" />;\n    }, [cancelIcon]);\n\n    const OkIcon = useMemo(() => {\n        if (loading) {\n            return <LoadingIcon className=\"mr-2\" />;\n        }\n        if (isValidElement(okIcon)) {\n            return okIcon;\n        }\n\n        return <CheckIcon className=\"mr-2 h-4 w-4\" />;\n    }, [okIcon, loading]);\n\n    return (\n        <AlertDialog\n            open={open}\n            onOpenChange={onOpenChange}\n            defaultOpen={defaultOpen}\n        >\n            <AlertDialogTrigger asChild>{children}</AlertDialogTrigger>\n            <AlertDialogContent>\n                <AlertDialogHeader>\n                    <AlertDialogTitle>{title}</AlertDialogTitle>\n                    <AlertDialogDescription>\n                        {description}\n                    </AlertDialogDescription>\n                </AlertDialogHeader>\n                <AlertDialogFooter>\n                    <AlertDialogCancel\n                        variant={cancelButtonVariant}\n                        size={cancelButtonSize}\n                        disabled={loading}\n                    >\n                        {cancelIconSide === \"left\" && CancelIcon}\n                        {cancelText}\n                        {cancelIconSide === \"right\" && CancelIcon}\n                    </AlertDialogCancel>\n                    <AlertDialogAction\n                        variant={okButtonVariant}\n                        size={okButtonSize}\n                        disabled={loading}\n                        onClick={onConfirm}\n                    >\n                        {okIconSide === \"left\" && OkIcon}\n                        {okText}\n                        {okIconSide === \"right\" && OkIcon}\n                    </AlertDialogAction>\n                </AlertDialogFooter>\n            </AlertDialogContent>\n        </AlertDialog>\n    );\n};\n\nConfirmDialog.displayName = \"ConfirmDialog\";\n", "import { cn } from \"@/lib/utils\";\nimport {\n    FormField,\n    FormControl,\n    FormDescription,\n    FormItem,\n    FormLabel,\n    FormMessage,\n} from \"@/ui\";\nimport { ReactElement, cloneElement } from \"react\";\nimport {\n    ControllerRenderProps,\n    FieldPath,\n    FieldValues,\n    UseControllerProps,\n} from \"react-hook-form\";\n\nexport type FieldProps<\n    TFieldValues extends FieldValues = FieldValues,\n    TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n> = UseControllerProps<TFieldValues, TName> & {\n    label?: string;\n    description?: string;\n    className?: string;\n    isCheckbox?: boolean;\n    children: ReactElement<{\n        field: ControllerRenderProps<TFieldValues, TName>;\n    }>;\n};\nexport const Field = (props: FieldProps) => {\n    return (\n        <FormField\n            control={props.control}\n            name={props.name}\n            render={({ field }: { field: any }) => {\n                return (\n                    <FormItem\n                        className={cn(\n                            props.className,\n                            props.isCheckbox\n                                ? \"flex flex-row items-center space-x-3 space-y-0\"\n                                : \"\",\n                        )}\n                    >\n                        {!props.isCheckbox && (\n                            <FormLabel>{props.label}</FormLabel>\n                        )}\n                        <FormControl>\n                            {cloneElement(props.children, {\n                                ...field,\n                                ...props.children.props,\n                            })}\n                        </FormControl>\n                        {props.isCheckbox && (\n                            <FormLabel className=\"text-sm font-normal\">\n                                {props.label}\n                            </FormLabel>\n                        )}\n                        {props.description && (\n                            <FormDescription>\n                                {props.description}\n                            </FormDescription>\n                        )}\n                        <FormMessage />\n                    </FormItem>\n                );\n            }}\n        />\n    );\n};\n", "\"use client\";\n\nimport type { SaveButtonProps } from \"@/types\";\nimport { Button, Card, CardContent, CardFooter, Form as FormUI } from \"@/ui\";\nimport {\n    useBack,\n    useNavigation,\n    useParsed,\n    useRouterType,\n    type BaseRecord,\n    type HttpError,\n} from \"@refinedev/core\";\nimport type { UseFormReturnType } from \"@refinedev/react-hook-form\";\nimport {\n    FC,\n    useRef,\n    type DetailedHTMLProps,\n    type FormHTMLAttributes,\n    type PropsWithChildren,\n} from \"react\";\nimport { type FieldValues } from \"react-hook-form\";\nimport { SaveButton } from \"../buttons\";\n\ntype NativeFormProps = Omit<\n    DetailedHTMLProps<FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>,\n    \"onSubmit\"\n>;\n\nexport type FormProps<\n    TQueryFnData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n    TVariables extends FieldValues = FieldValues,\n    TContext extends object = {},\n    TData extends BaseRecord = TQueryFnData,\n    TResponse extends BaseRecord = TData,\n    TResponseError extends HttpError = TError,\n> = PropsWithChildren &\n    UseFormReturnType<\n        TQueryFnData,\n        TError,\n        TVariables,\n        TContext,\n        TData,\n        TResponse,\n        TResponseError\n    > & {\n        formProps?: NativeFormProps;\n        isWatchable?: boolean;\n    };\n\nexport const Form = <\n    TQueryFnData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n    TVariables extends FieldValues = FieldValues,\n    TContext extends object = {},\n    TData extends BaseRecord = TQueryFnData,\n    TResponse extends BaseRecord = TData,\n    TResponseError extends HttpError = TError,\n>({\n    formProps,\n    isWatchable,\n    saveButtonProps,\n    ...props\n}: FormProps<\n    TQueryFnData,\n    TError,\n    TVariables,\n    TContext,\n    TData,\n    TResponse,\n    TResponseError\n>) => {\n    const watchable = useRef<boolean>(false);\n    const { resource: _resource, action } = useParsed();\n    const routerType = useRouterType();\n    const back = useBack();\n    const { goBack } = useNavigation();\n\n    const onBack =\n        action !== \"list\" || typeof action !== \"undefined\"\n            ? routerType === \"legacy\"\n                ? goBack\n                : back\n            : undefined;\n\n    if (isWatchable && !watchable.current) {\n        watchable.current = true;\n        props.watch();\n    }\n\n    const onSubmit = props.handleSubmit((_data: TVariables) => {\n        props.refineCore.onFinish(props.getValues()).then();\n    });\n\n    return (\n        <FormUI {...props}>\n            <form {...formProps} onSubmit={onSubmit}>\n                <Card className=\"border-border/40 shadow-sm\">\n                    <CardContent className=\"pt-6 space-y-4\">\n                        {props.children}\n                    </CardContent>\n\n                    <CardFooter className=\"flex justify-end gap-x-4\">\n                        <Button\n                            type=\"button\"\n                            onClick={onBack}\n                            disabled={props.refineCore.formLoading}\n                            variant=\"outline\"\n                        >\n                            Cancel\n                        </Button>\n\n                        <SaveButton\n                            type=\"submit\"\n                            loading={props.refineCore.formLoading}\n                            {...saveButtonProps}\n                        />\n                    </CardFooter>\n                </Card>\n            </form>\n        </FormUI>\n    );\n};\n", "\"use client\";\n\nimport { useTheme } from \"next-themes\";\nimport { Button } from \"@/ui/button\";\nimport {\n    DropdownMenu,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuTrigger,\n} from \"@/ui/dropdown-menu\";\nimport { MoonIcon, SunIcon } from \"@radix-ui/react-icons\";\n\nexport const ModeToggle = () => {\n    const { setTheme } = useTheme();\n    return (\n        <DropdownMenu>\n            <DropdownMenuTrigger asChild>\n                <Button variant=\"ghost\" size=\"icon\">\n                    <SunIcon className=\"h-[1.2rem] w-[1.2rem] rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0\" />\n                    <MoonIcon className=\"absolute h-[1.2rem] w-[1.2rem] rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100\" />\n                    <span className=\"sr-only\">Toggle theme</span>\n                </Button>\n            </DropdownMenuTrigger>\n            <DropdownMenuContent align={\"end\"}>\n                <DropdownMenuItem onClick={() => setTheme(\"light\")}>\n                    Light\n                </DropdownMenuItem>\n                <DropdownMenuItem onClick={() => setTheme(\"dark\")}>\n                    Dark\n                </DropdownMenuItem>\n                <DropdownMenuItem onClick={() => setTheme(\"system\")}>\n                    System\n                </DropdownMenuItem>\n            </DropdownMenuContent>\n        </DropdownMenu>\n    );\n};\n", "import { cn } from \"@/lib/utils\";\nimport { PageHeaderProps } from \"@/types/pageHeader\";\nimport { FC } from \"react\";\n\nexport const PageHeader: FC<PageHeaderProps> = ({ extra, ...props }) => {\n    return (\n        <div className=\"w-full\">\n            <div\n                className={cn(\n                    \"flex h-20 items-end lg:justify-between\",\n                    props.className,\n                    !props.breadcrumb && \"h-auto\",\n                )}\n            >\n                <div className=\"min-w-0 flex-1\">\n                    {props.breadcrumb}\n                    <div className=\"inline-flex flex-row items-center gap-x-4 mt-3\">\n                        <div className=\"inline-flex flex-col\">\n                            <h2 className=\"text-2xl font-bold leading-7 text-black dark:text-white sm:truncate sm:text-3xl sm:tracking-tight\">\n                                {props.title}\n                            </h2>\n                            {props.subTitle && (\n                                <div className=\"mt-2 flex items-center text-sm text-gray-300\">\n                                    {props.subTitle}\n                                </div>\n                            )}\n                        </div>\n                    </div>\n                </div>\n                <div className=\"flex lg:ml-4 lg:mt-0\">{extra}</div>\n            </div>\n        </div>\n    );\n};\n", "\"use client\";\n\nimport {\n    FormControl,\n    SelectContent,\n    SelectItem,\n    SelectTrigger,\n    Select as SelectUI,\n    SelectValue,\n} from \"@/ui\";\nimport type {\n    Content as SelectContentType,\n    SelectProps as SelectCoreProps,\n} from \"@radix-ui/react-select\";\nimport { BaseOption } from \"@refinedev/core\";\nimport React, { forwardRef } from \"react\";\n\ntype SelectProps = SelectCoreProps & {\n    placeholder?: string;\n    emptyMessage?: string;\n    onChange?: (value: string) => void;\n    options?: BaseOption[];\n};\n\nexport const Select = forwardRef<\n    React.ElementRef<typeof SelectContentType>,\n    SelectProps\n>(({ ...props }, ref) => {\n    const triggerRef = React.useRef<HTMLButtonElement>(null);\n    return (\n        <SelectUI\n            disabled={props.disabled || props.options?.length === 0}\n            onValueChange={props.onChange}\n            defaultValue={props.value}\n            value={props.value}\n        >\n            <FormControl>\n                <SelectTrigger ref={triggerRef}>\n                    <SelectValue placeholder={props.placeholder ?? \"Select\"} />\n                </SelectTrigger>\n            </FormControl>\n            <SelectContent\n                style={{\n                    width: triggerRef.current?.offsetWidth,\n                }}\n                ref={ref}\n            >\n                {props.options?.map((option, key: number) => (\n                    <SelectItem key={key} value={option.value}>\n                        {option.label}\n                    </SelectItem>\n                ))}\n            </SelectContent>\n        </SelectUI>\n    );\n});\n\nSelect.displayName = \"Select\";\n", "\"use client\";\n\nimport { cn } from \"@/lib/utils\";\nimport { buttonVariants } from \"@/ui/button\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"@/ui/tooltip\";\nimport { useMenu, useResourceParams } from \"@refinedev/core\";\nimport { useLocation } from \"react-use\";\nimport React from \"react\";\nimport { Link } from \"./link\";\n\ntype NavProps = {\n    isCollapsed: boolean;\n};\n\nexport const Sidebar = ({ isCollapsed }: NavProps) => {\n    const { menuItems } = useMenu();\n    const resourceParams = useResourceParams();\n    const { pathname } = useLocation();\n\n    const currentPathname = String(pathname);\n\n    const GetIcon = (item: (typeof menuItems)[0]) => {\n        const icon = item.meta?.icon;\n        if (React.isValidElement(icon)) {\n            return React.cloneElement<any>(icon, {\n                className: \"mr-2 w-4 h-4\",\n            });\n        }\n        return null;\n    };\n\n    return (\n        <div\n            data-collapsed={isCollapsed}\n            className=\"group flex flex-col gap-4 py-2 justify-between h-[94dvh] xl:h-[84dvh] data-[collapsed=true]:py-2\"\n        >\n            <nav className=\"grid gap-1 px-2 group-[[data-collapsed=true]]:justify-center group-[[data-collapsed=true]]:px-2\">\n                {menuItems\n                    .filter((i) => !i.meta?.hide)\n                    .map((item, key) => {\n                        const paths = [\n                            item.list?.toString(),\n                            item.create?.toString(),\n                            item.edit\n                                ?.toString()\n                                ?.replace(\":id\", resourceParams.id as string),\n                            item.show\n                                ?.toString()\n                                ?.replace(\":id\", resourceParams.id as string),\n                        ].filter(Boolean) as string[];\n                        const isActive =\n                            paths.includes(currentPathname) ||\n                            paths.some((path) => {\n                                return (\n                                    path?.startsWith(currentPathname) ||\n                                    currentPathname.startsWith(path)\n                                );\n                            });\n                        return isCollapsed ? (\n                            <Tooltip key={key} delayDuration={0}>\n                                <TooltipTrigger asChild>\n                                    <Link\n                                        key={key}\n                                        href={item.list?.toString() ?? \"/#\"}\n                                        title={item.meta?.title ?? item.name}\n                                        className={cn(\n                                            buttonVariants({\n                                                variant: \"ghost\",\n                                            }),\n                                            \"justify-start\",\n                                            isActive\n                                                ? \"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground\"\n                                                : \"\",\n                                        )}\n                                    >\n                                        {item.meta?.icon}\n                                        <span className=\"sr-only\">\n                                            {item.meta?.title ?? item.label}{\" \"}\n                                            {item.list ? \"List\" : \"Create\"}\n                                        </span>\n                                    </Link>\n                                </TooltipTrigger>\n                                <TooltipContent\n                                    side=\"right\"\n                                    className=\"flex items-center gap-4\"\n                                >\n                                    {item.label}\n                                    {item.meta?.label && (\n                                        <span className=\"ml-auto text-muted-foreground\">\n                                            {item.meta?.label}\n                                        </span>\n                                    )}\n                                </TooltipContent>\n                            </Tooltip>\n                        ) : (\n                            <Link\n                                key={key}\n                                href={item.list?.toString() ?? \"/#\"}\n                                title={item.meta?.title ?? item.name}\n                                className={cn(\n                                    buttonVariants({\n                                        variant: \"ghost\",\n                                    }),\n                                    \"justify-start\",\n                                    isActive\n                                        ? \"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground\"\n                                        : \"\",\n                                )}\n                            >\n                                {GetIcon(item)}\n                                {item.meta?.title ?? item.name}\n                            </Link>\n                        );\n                    })}\n            </nav>\n        </div>\n    );\n};\n\nSidebar.displayName = \"Sidebar\";\n", "import { EditButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useEditButton } from \"@refinedev/core\";\nimport { SquarePenIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const EditButton: FC<EditButtonProps> = ({\n    resource,\n    recordItemId,\n    hideText = false,\n    accessControl,\n    meta,\n    onClick,\n    children,\n    ...props\n}) => {\n    const { hidden, disabled, label, title, LinkComponent, to } = useEditButton(\n        {\n            resource,\n            id: recordItemId,\n            accessControl,\n            meta,\n        },\n    );\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<SquarePenIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nEditButton.displayName = \"EditButton\";\n", "import { ExportButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { CanAccess, useExportButton } from \"@refinedev/core\";\nimport { ShareIcon } from \"lucide-react\";\n\nimport type { FC } from \"react\";\n\nexport const ExportButton: FC<ExportButtonProps> = ({\n    hideText = false,\n    resource,\n    recordItemId,\n    accessControl,\n    access,\n    children,\n    ...props\n}) => {\n    const { label } = useExportButton();\n    const Com = !accessControl?.enabled ? Slot : CanAccess;\n\n    if (accessControl?.hideIfUnauthorized && accessControl.enabled) {\n        return null;\n    }\n\n    return (\n        <Com\n            params={{\n                id: recordItemId,\n            }}\n            resource={resource}\n            action=\"export\"\n            {...access}\n        >\n            <Button icon={<ShareIcon className=\"mr-2 w-4 h-4\" />} {...props}>\n                {!hideText && (children ?? label)}\n            </Button>\n        </Com>\n    );\n};\n\nExportButton.displayName = \"ExportButton\";\n", "import { ImportButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { CanAccess, useImportButton } from \"@refinedev/core\";\nimport { ImportIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const ImportButton: FC<ImportButtonProps> = ({\n    hideText = false,\n    resource,\n    onChange,\n    accept = \"image/*,application/*\",\n    recordItemId,\n    accessControl,\n    access,\n    children,\n    ...props\n}) => {\n    const { label } = useImportButton();\n    const Com = !accessControl?.enabled ? Slot : CanAccess;\n\n    const onClick = () => {\n        const el = document.createElement(\"input\");\n        el.type = \"file\";\n        el.accept = accept;\n        el.onchange = (e) => {\n            if (e.target instanceof HTMLInputElement) {\n                onChange(Array.from(e.target.files ?? []));\n                el.remove();\n            }\n        };\n        el.click();\n    };\n\n    if (accessControl?.hideIfUnauthorized && accessControl.enabled) {\n        return null;\n    }\n\n    return (\n        <Com\n            params={{\n                id: recordItemId,\n            }}\n            resource={resource}\n            action=\"import\"\n            {...access}\n        >\n            <Button\n                onClick={onClick}\n                icon={<ImportIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </Com>\n    );\n};\n\nImportButton.displayName = \"ImportButton\";\n", "import { ListButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useListButton } from \"@refinedev/core\";\nimport { ListIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const ListButton: FC<ListButtonProps> = ({\n    resource: resourceNameFromProps,\n    hideText = false,\n    accessControl,\n    meta,\n    children,\n    onClick,\n    ...props\n}) => {\n    const { hidden, disabled, label, title, LinkComponent, to } = useListButton(\n        {\n            resource: resourceNameFromProps,\n            accessControl,\n            meta,\n        },\n    );\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<ListIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nListButton.displayName = \"ListButton\";\n", "import { RefreshButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useRefreshButton } from \"@refinedev/core\";\nimport { RefreshCwIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const RefreshButton: FC<RefreshButtonProps> = ({\n    resource,\n    recordItemId,\n    hideText = false,\n    dataProviderName,\n    children,\n    ...props\n}) => {\n    const { onClick, label, loading } = useRefreshButton({\n        resource,\n        id: recordItemId,\n        dataProviderName,\n    });\n\n    return (\n        <Button\n            onClick={onClick}\n            loading={loading}\n            icon={<RefreshCwIcon className=\"mr-2 w-4 h-4\" />}\n            {...props}\n        >\n            {!hideText && (children ?? label)}\n        </Button>\n    );\n};\n\nRefreshButton.displayName = \"RefreshButton\";\n", "import { SaveButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { CanAccess, useSaveButton } from \"@refinedev/core\";\nimport { SaveIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const SaveButton: FC<SaveButtonProps> = ({\n    hideText = false,\n    children,\n    accessControl,\n    access,\n    resource,\n    recordItemId,\n    ...props\n}) => {\n    const { label } = useSaveButton();\n    const Com = !accessControl?.enabled ? Slot : CanAccess;\n\n    if (accessControl?.hideIfUnauthorized && accessControl.enabled) {\n        return null;\n    }\n\n    return (\n        <Com\n            params={{\n                id: recordItemId,\n            }}\n            resource={resource}\n            action=\"save\"\n            {...access}\n        >\n            <Button icon={<SaveIcon className=\"mr-2 w-4 h-4\" />} {...props}>\n                {!hideText && (children ?? label)}\n            </Button>\n        </Com>\n    );\n};\n\nSaveButton.displayName = \"SaveButton\";\n", "import { ShowButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useShowButton } from \"@refinedev/core\";\nimport { EyeIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const ShowButton: FC<ShowButtonProps> = ({\n    resource: resourceNameFromProps,\n    recordItemId,\n    hideText = false,\n    accessControl,\n    meta,\n    children,\n    onClick,\n    ...props\n}) => {\n    const { to, label, title, hidden, disabled, LinkComponent } = useShowButton(\n        {\n            resource: resourceNameFromProps,\n            id: recordItemId,\n            accessControl,\n            meta,\n        },\n    );\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                icon={<EyeIcon className=\"mr-2 w-4 h-4\" />}\n                title={title}\n                disabled={disabled}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nShowButton.displayName = \"ShowButton\";\n", "import { ListButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { CreateProps } from \"@/types\";\nimport {\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport React, { isValidElement, ReactNode } from \"react\";\n\nexport const CreatePage: React.FC<CreateProps> = ({\n    title,\n    resource: resourceFromProps,\n    breadcrumb: breadcrumbFromProps,\n    extra,\n    children,\n}): ReturnType<React.FC<CreateProps>> => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource, identifier } = useResource(resourceFromProps);\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `Create ${getUserFriendlyName(\n                            resource?.meta?.label ?? identifier,\n                            \"singular\",\n                        )}`,\n                    )\n                }\n                isBack\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                extra={\n                    extra ?? (\n                        <>\n                            <ListButton resource={resourceFromProps} />\n                        </>\n                    )\n                }\n            />\n            <div className=\"pt-4 !mt-0\">{children as ReactNode}</div>\n        </>\n    );\n};\n\nCreatePage.displayName = \"CreatePage\";\n", "import { DeleteButton, ShowButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { EditProps } from \"@/types\";\nimport {\n    useNavigation,\n    useRedirectionAfterSubmission,\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport { FC, isValidElement } from \"react\";\n\nexport const EditPage: FC<EditProps> = ({\n    title,\n    resource,\n    extra,\n    breadcrumb: breadcrumbFromProps,\n    children,\n}) => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n    const { list } = useNavigation();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource: _resource, identifier } = useResource(resource);\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `Edit ${getUserFriendlyName(\n                            _resource?.meta?.label ?? identifier,\n                            \"plural\",\n                        )}`,\n                    )\n                }\n                isBack\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                extra={\n                    extra ?? (\n                        <div className=\"inline-flex flex-row items-center gap-x-2\">\n                            <ShowButton resource={resource} />\n                            <DeleteButton\n                                resource={resource}\n                                onSuccess={() => {\n                                    list(_resource?.name as string);\n                                }}\n                            />\n                        </div>\n                    )\n                }\n            />\n            <div className=\"pt-4\">{children}</div>\n        </>\n    );\n};\n\nEditPage.displayName = \"EditPage\";\n", "\"use client\";\n\nimport { CreateButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { cn } from \"@/lib/utils\";\nimport { ListProps } from \"@/types\";\nimport {\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport { FC, isValidElement } from \"react\";\n\nexport const ListPage: FC<ListProps> = ({\n    title,\n    resource: resourceFromProps,\n    breadcrumb: breadcrumbFromProps,\n    createButtonProps,\n    className,\n    isCreate = true,\n    extra,\n    children,\n}) => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource, identifier } = useResource(resourceFromProps);\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `List ${getUserFriendlyName(\n                            resource?.meta?.label ?? identifier,\n                            \"plural\",\n                        )}`,\n                    )\n                }\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                extra={\n                    extra ?? (\n                        <>\n                            <div className=\"inline-flex flex-row gap-4\">\n                                {isCreate && (\n                                    <CreateButton\n                                        {...createButtonProps}\n                                        resource={\n                                            createButtonProps?.resource ??\n                                            identifier\n                                        }\n                                    />\n                                )}\n                            </div>\n                        </>\n                    )\n                }\n            />\n            <div className={cn(\"pt-2 sm:pt-4 !mt-0\", className)}>\n                {children}\n            </div>\n        </>\n    );\n};\n\nListPage.displayName = \"ListPage\";\n", "import { DeleteButton, EditButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { ShowProps } from \"@/types\";\nimport {\n    useNavigation,\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport { FC, isValidElement } from \"react\";\nimport { Row } from \"./row\";\n\nexport const ShowPage: FC<ShowProps> & {\n    Row: typeof Row;\n} = ({\n    title,\n    resource: resourceFromProps,\n    breadcrumb: breadcrumbFromProps,\n    isEdit = true,\n    isDelete = true,\n    extra,\n    children,\n}) => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource, identifier } = useResource(resourceFromProps);\n\n    const { list } = useNavigation();\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `Show ${getUserFriendlyName(\n                            resource?.meta?.label ?? identifier,\n                            \"singular\",\n                        )}`,\n                    )\n                }\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                isBack\n                extra={\n                    extra ?? (\n                        <div className=\"inline-flex items-center gap-x-2\">\n                            {isEdit && (\n                                <EditButton resource={resourceFromProps} />\n                            )}\n                            {isDelete && (\n                                <DeleteButton\n                                    resource={resourceFromProps}\n                                    onSuccess={() => {\n                                        list(resource?.name as string);\n                                    }}\n                                />\n                            )}\n                        </div>\n                    )\n                }\n            />\n            <div className=\"relative pt-4 !mt-0\">{children}</div>\n        </>\n    );\n};\n\nShowPage.Row = Row;\nShowPage.displayName = \"ShowPage\";\n", "import { PropsWithChildren, ReactNode } from \"react\";\n\nexport const Row = ({\n    title,\n    children,\n}: Required<\n    PropsWithChildren<{\n        title: string;\n    }>\n>) => {\n    return (\n        <>\n            <dl className=\"flex flex-wrap\">\n                <div className=\"flex-auto pt-4\">\n                    <dt className=\"scroll-m-20 text-xs font-semibold tracking-tight\">\n                        {title}\n                    </dt>\n                    <dd className=\"mt-1 text-base font-normal text-foreground leading-7\">\n                        {children}\n                    </dd>\n                </div>\n            </dl>\n        </>\n    );\n};\n", "\"use client\";\n\nimport { ThemeProvider as NextThemesProvider } from \"next-themes\";\nimport { type ThemeProviderProps } from \"next-themes/dist/types\";\n\nexport function ThemeProvider({ children, ...props }: ThemeProviderProps) {\n    return <NextThemesProvider {...props}>{children}</NextThemesProvider>;\n}\n", "import { ThemeProvider } from \"@/providers/theme-provider\";\nimport { LayoutProps } from \"@/types\";\nimport { Toaster, TooltipProvider } from \"@/ui\";\nimport { PropsWithChildren } from \"react\";\n\ntype Props = PropsWithChildren<\n    Pick<\n        LayoutProps,\n        | \"attribute\"\n        | \"defaultTheme\"\n        | \"enableSystem\"\n        | \"disableTransitionOnChange\"\n        | \"enableColorScheme\"\n        | \"forcedTheme\"\n        | \"nonce\"\n        | \"storageKey\"\n        | \"themes\"\n        | \"value\"\n    >\n>;\n\nconst BaseLayout = ({\n    attribute,\n    defaultTheme,\n    enableSystem,\n    disableTransitionOnChange,\n    enableColorScheme,\n    forcedTheme,\n    nonce,\n    storageKey,\n    themes,\n    value,\n    children,\n}: Props) => {\n    return (\n        <ThemeProvider\n            attribute={attribute ?? \"class\"}\n            defaultTheme={defaultTheme ?? \"system\"}\n            enableSystem={enableSystem ?? true}\n            disableTransitionOnChange={disableTransitionOnChange ?? false}\n            enableColorScheme={enableColorScheme ?? true}\n            forcedTheme={forcedTheme}\n            nonce={nonce}\n            storageKey={storageKey}\n            themes={themes}\n            value={value}\n        >\n            <TooltipProvider\n                delayDuration={0}\n                skipDelayDuration={0}\n                disableHoverableContent={true}\n            >\n                {children}\n                <Toaster />\n            </TooltipProvider>\n        </ThemeProvider>\n    );\n};\n\nBaseLayout.displayName = \"BaseLayout\";\n\nexport default BaseLayout;\n", "import * as React from 'react';\n\nfunction queriesDidChange(prevQueries, nextQueries) {\n  if (nextQueries === prevQueries) return false;\n  const nextQueriesArr = Object.values(nextQueries);\n  const prevQueriesArr = Object.values(prevQueries);\n  if (nextQueriesArr.length !== prevQueriesArr.length) return true;\n  if (nextQueriesArr.some((q, i) => q !== prevQueriesArr[i])) return true;\n  const prevKeys = Object.keys(prevQueries);\n  return Object.keys(nextQueries).some((n, i) => n !== prevKeys[i]);\n}\n\nfunction _ref(curr, key) {\n  curr.matches[key] = false;\n  curr.mediaQueries[key] = {};\n  return curr;\n}\n\nfunction init(queries) {\n  const queryKeys = Object.keys(queries);\n  /* istanbul ignore next */\n\n  if (typeof window === 'undefined') return queryKeys.reduce(_ref, {\n    mediaQueries: {},\n    matches: {}\n  });\n  return queryKeys.reduce((state, name) => {\n    const mql = window.matchMedia(queries[name]);\n    state.mediaQueries[name] = mql;\n    state.matches[name] = mql.matches;\n    return state;\n  }, {\n    mediaQueries: {},\n    matches: {}\n  });\n}\n\nfunction reducer(state, action) {\n  function _ref2(prev, key) {\n    prev[key] = state.mediaQueries[key].matches;\n    return prev;\n  }\n\n  switch (action.type) {\n    case 'updateMatches':\n      return {\n        matches: Object.keys(state.mediaQueries).reduce(_ref2, {}),\n        mediaQueries: state.mediaQueries\n      };\n\n    case 'setQueries':\n      return init(action.queries);\n  }\n}\n/**\n * A hook that returns a [`MediaQueryMatches`](#mediaquerymatches) object which will\n * tell you if specific media queries matched, all media queries matched, or\n * any media queries matched. Matches in this hook will always return `false` when\n * rendering on the server.\n *\n * @param queryMap The media queries you want to match against e.g. `{screen: \"screen\", width: \"(min-width: 12em)\"}`\n */\n\n\nexport function useMediaQueries(queryMap) {\n  const prevQueries = React.useRef(queryMap);\n  const [state, dispatch] = React.useReducer(reducer, queryMap, init);\n  React.useEffect(() => {\n    if (queriesDidChange(queryMap, prevQueries.current)) {\n      dispatch({\n        type: 'setQueries',\n        queries: queryMap\n      });\n      prevQueries.current = queryMap;\n    }\n  }, [queryMap]);\n\n  function _ref3() {\n    return dispatch({\n      type: 'updateMatches'\n    });\n  }\n\n  function _ref4(mq) {\n    const callback = _ref3;\n    if (typeof mq.addListener !== 'undefined') mq.addListener(callback);else mq.addEventListener('change', callback);\n    return callback;\n  }\n\n  React.useEffect(() => {\n    const queries = Object.values(state.mediaQueries);\n    const callbacks = queries.map(_ref4);\n\n    function _ref5(mq, i) {\n      if (typeof mq.addListener !== 'undefined') mq.removeListener(callbacks[i]);else mq.removeEventListener('change', callbacks[i]);\n    }\n\n    return () => {\n      queries.forEach(_ref5);\n    };\n  }, [state.mediaQueries]);\n  const {\n    matches\n  } = state;\n  const matchValues = React.useMemo(() => Object.values(matches), [matches]);\n  return {\n    matches,\n    matchesAny: matchValues.some(Boolean),\n    matchesAll: matchValues.length > 0 && matchValues.every(Boolean)\n  };\n}\n/**\n * A hook that returns `true` if the media query matched and `false` if not. This\n * hook will always return `false` when rendering on the server.\n *\n * @param query The media query you want to match against e.g. `\"only screen and (min-width: 12em)\"`\n */\n\nexport function useMediaQuery(query) {\n  return useMediaQueries(getObj(query)).matchesAll;\n}\nconst cache = {};\n\nfunction getObj(query) {\n  if (cache[query] === void 0) cache[query] = {\n    default: query\n  };\n  return cache[query];\n}", "import {\n    ResizableHandle,\n    ResizablePanel,\n    ResizablePanelGroup,\n} from \"@/ui/resizable\";\nimport { Toaster } from \"@/ui/sonner\";\nimport { TooltipProvider } from \"@/ui/tooltip\";\nimport { cn } from \"@/lib/utils\";\nimport type { LayoutProps, LogoType } from \"@/types\";\nimport { useMediaQuery } from \"@react-hook/media-query\";\nimport { useMemo, isValidElement, cloneElement, useState } from \"react\";\nimport { Sidebar, ModeToggle } from \"@/components\";\nimport { Link } from \"@/components/link\";\nimport { useResource } from \"@refinedev/core\";\nimport { ThemeProvider } from \"@/providers/theme-provider\";\nimport BaseLayout from \"./base\";\n\nexport const DefaultLayout = ({\n    children,\n    defaultLayout,\n    defaultCollapsed = false,\n    navCollapsedSize,\n    navbar,\n    footer,\n    logo,\n    attribute,\n    defaultTheme,\n    enableSystem,\n    disableTransitionOnChange,\n    enableColorScheme,\n    forcedTheme,\n    nonce,\n    storageKey,\n    themes,\n    value,\n}: LayoutProps) => {\n    const { resources } = useResource();\n\n    const firstDashboard = resources?.[0];\n\n    const xs = useMediaQuery(\"only screen and (max-width: 579.999px)\");\n    const sm = useMediaQuery(\n        \"only screen and (min-width: 640px) and (max-width: 767.999px)\",\n    );\n    const md = useMediaQuery(\n        \"only screen and (min-width: 768px) and (max-width: 1023.999px)\",\n    );\n    const lg = useMediaQuery(\"only screen and (min-width: 1024px)\");\n\n    const [isCollapsed, setIsCollapsed] = useState<boolean>(\n        xs ?? defaultCollapsed,\n    );\n\n    const layout = useMemo(() => {\n        if (defaultLayout) {\n            return defaultLayout;\n        }\n        if (xs) {\n            return [15, 85];\n        } else if (sm) {\n            return [20, 80];\n        } else if (md) {\n            return [25, 75];\n        }\n\n        return [15, 85];\n    }, [defaultLayout, xs, sm, md]);\n\n    const SidebarSizes = useMemo(() => {\n        if (lg) {\n            return {\n                minSize: 11,\n                maxSize: 15,\n            };\n        } else if (md) {\n            return {\n                minSize: 15,\n                maxSize: 25,\n            };\n        } else if (sm) {\n            return {\n                minSize: 20,\n                maxSize: 30,\n            };\n        }\n\n        return {\n            minSize: 15,\n            maxSize: 15,\n        };\n    }, [sm, md, lg]);\n\n    const hasCollapsed = useMemo(() => {\n        return isCollapsed || xs || sm || md;\n    }, [isCollapsed, md, sm, xs]);\n\n    const Logo: LogoType | undefined = useMemo<LogoType | undefined>(():\n        | LogoType\n        | undefined => {\n        if (!logo) {\n            return null;\n        }\n\n        if (!hasCollapsed) {\n            if (isValidElement(logo.default)) {\n                return cloneElement<LogoType>(logo.default, {\n                    className: \"w-auto h-8\",\n                });\n            }\n        }\n\n        const component = hasCollapsed ? logo.collapsed : logo.default;\n        if (isValidElement(component)) {\n            return cloneElement<LogoType>(component, {\n                className: \"w-auto h-8\",\n            });\n        }\n\n        return null;\n    }, [logo, defaultLayout, hasCollapsed]);\n\n    return (\n        <>\n            <BaseLayout\n                attribute={attribute}\n                defaultTheme={defaultTheme}\n                enableSystem={enableSystem}\n                disableTransitionOnChange={disableTransitionOnChange}\n                enableColorScheme={enableColorScheme}\n                forcedTheme={forcedTheme}\n                nonce={nonce}\n                storageKey={storageKey}\n                themes={themes}\n                value={value}\n            >\n                <ResizablePanelGroup\n                    direction=\"horizontal\"\n                    onLayout={(sizes: number[]) => {\n                        document.cookie = `react-resizable-panels:layout=${JSON.stringify(\n                            sizes,\n                        )}`;\n                    }}\n                    className=\"h-full items-stretch\"\n                >\n                    <ResizablePanel\n                        defaultSize={layout[0]}\n                        collapsedSize={navCollapsedSize}\n                        collapsible={true}\n                        minSize={SidebarSizes.minSize}\n                        maxSize={SidebarSizes.maxSize}\n                        onExpand={() => {\n                            const collapsed = xs;\n                            setIsCollapsed(collapsed);\n                            document.cookie = `react-resizable-panels:collapsed=${JSON.stringify(\n                                collapsed,\n                            )}`;\n                        }}\n                        onCollapse={() => {\n                            const collapsed = true;\n                            setIsCollapsed(collapsed);\n                            document.cookie = `react-resizable-panels:collapsed=${JSON.stringify(\n                                collapsed,\n                            )}`;\n                        }}\n                        className={cn(\n                            hasCollapsed &&\n                                \"min-w-[50px] transition-all duration-300 ease-in-out\",\n                        )}\n                    >\n                        <div\n                            className={cn(\n                                \"flex py-1.5 max-h-14 items-center border-b border-border/40 justify-center\",\n                                hasCollapsed && \"px-2\",\n                            )}\n                        >\n                            <Link\n                                href={firstDashboard.list?.toString() ?? \"/\"}\n                                className=\"inline-flex items-center justify-center\"\n                                title={\n                                    firstDashboard.meta?.label ??\n                                    firstDashboard.name\n                                }\n                            >\n                                {Logo}\n                            </Link>\n                        </div>\n                        <Sidebar isCollapsed={hasCollapsed} />\n                    </ResizablePanel>\n                    <ResizableHandle withHandle className=\"bg-border/40\" />\n                    <ResizablePanel\n                        defaultSize={layout[1]}\n                        minSize={25}\n                        className=\"xl:max-h-dvh h-full !overflow-y-auto flex flex-col overflow-x-hidden\"\n                    >\n                        <header\n                            className={cn(\n                                \"sticky top-0 z-50 py-2 h-14 px-4 flex justify-end items-center border-b border-border/40 bg-background/95 backdrop-blur supports-[backdrop-filter]:bg-background/60\",\n                                navbar?.rightSide && \"justify-between\",\n                            )}\n                        >\n                            {navbar?.leftSide && (\n                                <div className=\"flex items-center justify-start flex-1\">\n                                    {navbar?.leftSide}\n                                </div>\n                            )}\n                            {navbar?.rightSide ? (\n                                <div className=\"flex items-center justify-end flex-1\">\n                                    {<ModeToggle />}\n                                    {navbar?.rightSide}\n                                </div>\n                            ) : (\n                                <ModeToggle />\n                            )}\n                        </header>\n                        <main className=\"grow px-6 py-4\">{children}</main>\n                        {footer && (\n                            <footer className=\"px-6 py-4 border-t border-border/40 sticky bottom-0 bg-background text-primary flex flex-row items-center\">\n                                <div className=\"w-full\">{footer}</div>\n                            </footer>\n                        )}\n                    </ResizablePanel>\n                </ResizablePanelGroup>\n            </BaseLayout>\n        </>\n    );\n};\n\nDefaultLayout.displayName = \"DefaultLayout\";\n", "import { NotificationProvider } from \"@refinedev/core\";\nimport { toast } from \"sonner\";\n\nexport const notificationProvider: NotificationProvider = {\n    open: ({ key, message, description, type }) => {\n        if (type === \"success\") {\n            toast.success(message, { description, id: key });\n        }\n\n        if (type === \"error\") {\n            toast.error(message, { description, id: key });\n        }\n\n        if (type === \"progress\") {\n            toast.loading(message, { description, id: key });\n        }\n    },\n    close: (key) => toast.dismiss(key),\n};\n\nexport const useNotificationProvider = (): NotificationProvider => {\n    return notificationProvider;\n};\n", "import {\n    AccessControlContext,\n    CanReturnType,\n    useCan,\n    useNavigation,\n    useResource,\n    useTranslate,\n} from \"@refinedev/core\";\nimport { useContext } from \"react\";\n\ntype GetEditUrlReturnType = CanReturnType & {\n    url: string;\n};\n\nexport const useGetEditUrl = (\n    resource: string,\n    recordItemId: string,\n    meta?: any,\n): GetEditUrlReturnType => {\n    const accessControlContext = useContext(AccessControlContext);\n    const accessControlEnabled =\n        accessControlContext.options.buttons.enableAccessControl;\n\n    const hideIfUnauthorized =\n        accessControlContext.options.buttons.hideIfUnauthorized;\n\n    const { editUrl: generateEditUrl } = useNavigation();\n\n    const { id, resource: _resource } = useResource(resource);\n\n    const { data } = useCan({\n        resource: resource,\n        action: \"edit\",\n        params: { id: recordItemId, resource: _resource },\n        queryOptions: {\n            enabled: accessControlEnabled,\n        },\n    });\n\n    const translate = useTranslate();\n\n    const reason = () => {\n        if (data?.can) return \"\";\n        else if (data?.reason) return data.reason;\n        else\n            return translate(\n                \"buttons.notAccessTitle\",\n                \"You don't have permission to access\",\n            );\n    };\n\n    const editUrl =\n        resource && (recordItemId ?? id)\n            ? generateEditUrl(resource, recordItemId! ?? id!, meta)\n            : \"\";\n\n    return {\n        can: !Boolean(accessControlEnabled && hideIfUnauthorized && !data?.can),\n        reason: reason(),\n        url: editUrl,\n    };\n};\n", "import {\n    AccessControlContext,\n    CanReturnType,\n    useCan,\n    useNavigation,\n    useResource,\n    useTranslate,\n} from \"@refinedev/core\";\nimport { useContext } from \"react\";\n\ntype GetShowUrlReturnType = CanReturnType & {\n    url: string;\n};\n\nexport const useGetShowUrl = (\n    resource: string,\n    recordItemId: string,\n    meta?: any,\n): GetShowUrlReturnType => {\n    const accessControlContext = useContext(AccessControlContext);\n    const accessControlEnabled =\n        accessControlContext.options.buttons.enableAccessControl;\n\n    const hideIfUnauthorized =\n        accessControlContext.options.buttons.hideIfUnauthorized;\n\n    const { showUrl: generateShowUrl } = useNavigation();\n\n    const { id, resource: _resource } = useResource(resource);\n\n    const { data } = useCan({\n        resource: resource,\n        action: \"show\",\n        params: { id: recordItemId, resource: _resource },\n        queryOptions: {\n            enabled: accessControlEnabled,\n        },\n    });\n\n    const translate = useTranslate();\n\n    const reason = () => {\n        if (data?.can) return \"\";\n        else if (data?.reason) return data.reason;\n        else\n            return translate(\n                \"buttons.notAccessTitle\",\n                \"You don't have permission to access\",\n            );\n    };\n\n    const showUrl =\n        resource && (recordItemId || id)\n            ? generateShowUrl(resource, recordItemId! ?? id!, meta)\n            : \"\";\n\n    return {\n        can: !Boolean(accessControlEnabled && hideIfUnauthorized && !data?.can),\n        reason: reason(),\n        url: showUrl,\n    };\n};\n", "import {\n    AccessControlContext,\n    CanReturnType,\n    pickNotDeprecated,\n    useCan,\n    useDelete,\n    useMutationMode,\n    useResource,\n    useResourceParams,\n    useTranslate,\n    useWarnAboutChange,\n} from \"@refinedev/core\";\nimport { MutateOptions } from \"@tanstack/react-query\";\nimport { useContext } from \"react\";\n\ntype DeleteHelperReturnType = CanReturnType & {\n    isLoading: boolean;\n    mutate: (e?: MutateOptions<unknown, unknown, unknown, unknown>) => any; // TODO: UseDeleteReturnType fix\n};\n\nexport const useDeleteHelper = (\n    resource: string,\n    recordItemId: string,\n    meta?: any,\n): DeleteHelperReturnType => {\n    const accessControlContext = useContext(AccessControlContext);\n\n    const accessControlEnabled =\n        accessControlContext.options.buttons.enableAccessControl;\n\n    const hideIfUnauthorized =\n        accessControlContext.options.buttons.hideIfUnauthorized;\n\n    const translate = useTranslate();\n\n    const id = useResourceParams();\n\n    const { resource: _resource, identifier } = useResource(resource);\n\n    const { mutationMode } = useMutationMode();\n\n    const { mutate, isLoading } = useDelete();\n\n    const { data } = useCan({\n        resource: _resource?.name,\n        action: \"delete\",\n        params: { id: recordItemId ?? id, resource: _resource },\n        queryOptions: {\n            enabled: accessControlEnabled,\n        },\n    });\n\n    const reason = () => {\n        if (data?.can) return \"\";\n        else if (data?.reason) return data.reason;\n        else return translate(\"You don't have permission to access\");\n    };\n\n    const { setWarnWhen } = useWarnAboutChange();\n\n    const onDeleteMutate = (\n        options?: MutateOptions<unknown, unknown, unknown, unknown>,\n    ): any => {\n        if (accessControlEnabled && hideIfUnauthorized && !data?.can) {\n            return;\n        }\n        if ((recordItemId ?? id) && identifier) {\n            setWarnWhen(false);\n            return mutate(\n                {\n                    id: recordItemId ?? id ?? \"\",\n                    resource: identifier,\n                    mutationMode,\n                    meta: pickNotDeprecated(meta),\n                    metaData: pickNotDeprecated(meta),\n                },\n                options,\n            );\n        }\n\n        return undefined;\n    };\n\n    return {\n        can: !Boolean(accessControlEnabled && hideIfUnauthorized && !data?.can),\n        reason: reason(),\n        mutate: onDeleteMutate,\n        isLoading,\n    };\n};\n", "import {\n    BackFunction,\n    useBack,\n    useNavigation,\n    useResource,\n    useRouterType,\n} from \"@refinedev/core\";\n\nexport const useOnBack = (): BackFunction | undefined => {\n    const routerType = useRouterType();\n    const back = useBack();\n    const { goBack } = useNavigation();\n    const { action } = useResource();\n\n    const onBack =\n        action !== \"list\" || typeof action !== \"undefined\"\n            ? routerType === \"legacy\"\n                ? goBack\n                : back\n            : undefined;\n\n    return onBack;\n};\n", "\"use client\";\n\nimport { ConfirmDialog } from \"@/components/confirm\";\nimport { useDeleteHelper, useOnBack } from \"@/hooks\";\nimport { useTranslate } from \"@refinedev/core\";\nimport React, {\n    PropsWithChildren,\n    createContext,\n    useCallback,\n    useState,\n} from \"react\";\n\ntype DeleteDataType = {\n    toogle: boolean;\n    row: any;\n    resource: string;\n    redirectBack?: boolean;\n    onAfterHandle?: () => void;\n};\n\nexport interface DeleteContextType {\n    data: DeleteDataType;\n    updateData: (data: DeleteDataType) => void;\n}\n\nexport function DeleteActionModal(props: DeleteContextType) {\n    const back = useOnBack();\n    const { can, isLoading, mutate } = useDeleteHelper(\n        props.data?.resource,\n        props.data?.row?.id,\n    );\n\n    const translate = useTranslate();\n\n    const onDelete = useCallback(() => {\n        if (can) {\n            return mutate({\n                onSuccess() {\n                    const isRedirectBack = props?.data?.redirectBack ?? false;\n                    const onAfterHandle = props?.data?.onAfterHandle;\n                    props?.updateData({\n                        toogle: false,\n                        row: undefined,\n                        resource: \"\",\n                        redirectBack: false,\n                        onAfterHandle: undefined,\n                    });\n\n                    if (isRedirectBack) {\n                        back?.();\n                    }\n\n                    if (onAfterHandle) {\n                        onAfterHandle();\n                    }\n                },\n            });\n        }\n\n        return undefined;\n    }, [can, mutate, props, back]);\n\n    return (\n        <ConfirmDialog\n            open={can && props?.data?.toogle}\n            loading={isLoading}\n            title={translate(\"Are you sure?\")}\n            description={translate(\"This action cannot be undone.\")}\n            okText={translate(\"Delete\")}\n            cancelText={translate(\"Cancel\")}\n            okButtonVariant={\"destructive\"}\n            onOpenChange={() => {\n                if (!isLoading) {\n                    props?.updateData({\n                        toogle: false,\n                        row: undefined,\n                        resource: \"\",\n                    });\n                }\n            }}\n            onConfirm={onDelete}\n        />\n    );\n}\n\nconst DeleteContext = createContext<DeleteContextType | undefined>(undefined);\n\nconst DeleteProvider: React.FC<PropsWithChildren> = ({ children }) => {\n    const [data, setData] = useState<DeleteDataType>({\n        row: undefined,\n        resource: \"\",\n        toogle: false,\n        onAfterHandle: undefined,\n    });\n\n    const updateData = (data: DeleteDataType) => {\n        setData(data);\n    };\n\n    return (\n        <DeleteContext.Provider value={{ data, updateData }}>\n            {children}\n            <DeleteActionModal\n                data={data as DeleteDataType}\n                updateData={updateData}\n            />\n        </DeleteContext.Provider>\n    );\n};\n\nexport { DeleteContext, DeleteProvider };\n", "import { cn } from \"@/lib/utils\";\nimport React, { forwardRef } from \"react\";\n\nconst Loader = forwardRef<SVGSVGElement, React.SVGProps<SVGSVGElement>>(\n    ({ className, ...props }, ref) => {\n        return (\n            <svg\n                ref={ref}\n                xmlns=\"http://www.w3.org/2000/svg\"\n                className={cn(\"mx-auto inline\", className)}\n                viewBox=\"0 0 120 30\"\n                fill=\"currentColor\"\n                {...props}\n            >\n                <circle cx=\"15\" cy=\"15\" r=\"15\">\n                    <animate\n                        attributeName=\"r\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"15\"\n                        repeatCount=\"indefinite\"\n                        to=\"15\"\n                        values=\"15;9;15\"\n                    ></animate>\n                    <animate\n                        attributeName=\"fill-opacity\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"1\"\n                        repeatCount=\"indefinite\"\n                        to=\"1\"\n                        values=\"1;.5;1\"\n                    ></animate>\n                </circle>\n                <circle cx=\"60\" cy=\"15\" r=\"9\" fillOpacity=\"0.3\">\n                    <animate\n                        attributeName=\"r\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"9\"\n                        repeatCount=\"indefinite\"\n                        to=\"9\"\n                        values=\"9;15;9\"\n                    ></animate>\n                    <animate\n                        attributeName=\"fill-opacity\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"0.5\"\n                        repeatCount=\"indefinite\"\n                        to=\"0.5\"\n                        values=\".5;1;.5\"\n                    ></animate>\n                </circle>\n                <circle cx=\"105\" cy=\"15\" r=\"15\">\n                    <animate\n                        attributeName=\"r\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"15\"\n                        repeatCount=\"indefinite\"\n                        to=\"15\"\n                        values=\"15;9;15\"\n                    ></animate>\n                    <animate\n                        attributeName=\"fill-opacity\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"1\"\n                        repeatCount=\"indefinite\"\n                        to=\"1\"\n                        values=\"1;.5;1\"\n                    ></animate>\n                </circle>\n            </svg>\n        );\n    },\n);\n\nexport default Loader;\n", "import Loader from \"@/components/loader\";\nimport {\n    TableBody,\n    TableCell,\n    TableHead,\n    TableHeader,\n    TableRow,\n    Table as TableUi,\n} from \"@/ui/table\";\nimport { PopoverContentProps } from \"@radix-ui/react-popover\";\nimport { BaseOption, BaseRecord, HttpError } from \"@refinedev/core\";\nimport {\n    UseTableProps,\n    UseTableReturnType,\n    useTable,\n} from \"@refinedev/react-table\";\nimport {\n    CellContext,\n    Column,\n    ColumnDef,\n    ColumnDefTemplate,\n    TableOptionsResolved,\n    flexRender,\n} from \"@tanstack/react-table\";\nimport React, {\n    FC,\n    ReactElement,\n    useCallback,\n    useEffect,\n    useMemo,\n    useState,\n} from \"react\";\nimport { RowAction, RowActions } from \"./actions\";\nimport { EditAction } from \"./actions/edit\";\nimport { ShowAction } from \"./actions/show\";\nimport {\n    TableFilterDateRangePickerFilter,\n    TableFilterDropdown,\n    TableFilterSearchColumn,\n} from \"./fields\";\nimport { CheckAll } from \"./fields/checkall\";\nimport { Pagination } from \"./fields/pagination\";\nimport { SortAction } from \"./fields/sort\";\nimport { DataTableToolbar } from \"./toolbar\";\nimport { DeleteAction } from \"./actions/delete\";\nimport { DeleteProvider } from \"@/providers\";\n\nexport type TableListFilterOption = BaseOption & {\n    icon?: React.ComponentType<{ className?: string }>;\n};\n\nexport type TableFilterProps<TData extends BaseRecord = BaseRecord> = {\n    column: Column<TData>;\n    title?: string;\n    numberOfMonths?: number;\n    align?: PopoverContentProps[\"align\"];\n    options?: TableListFilterOption[];\n};\n\nexport type ColumnProps<\n    TData extends BaseRecord = BaseRecord,\n    TValue = unknown,\n    TError extends HttpError = HttpError,\n> = {\n    id: string;\n    accessorKey: string;\n    enableSorting?: boolean;\n    enableHiding?: boolean;\n    header?:\n        | string\n        | FC<{\n              table: UseTableReturnType<TData, TError>;\n          }>;\n    cell?: ColumnDefTemplate<CellContext<TData, TValue>>;\n    children?: ReactElement;\n    filter?: FC<TableFilterProps<TData>>;\n};\n\ntype CustomColumnDef<\n    TData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n> = ColumnDef<TData, TError> & Pick<ColumnProps<TData, TError>, \"filter\">;\n\nexport type TableProps<\n    TData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n> = Partial<UseTableProps<TData, TError, TData>> & {\n    children?: ReactElement<ColumnProps<TData, TError>>[];\n    showHeader?: boolean;\n};\n\nexport function Table<\n    TQueryFnData extends BaseRecord = BaseRecord,\n    TData extends BaseRecord = TQueryFnData,\n    TError extends HttpError = HttpError,\n>({\n    children,\n    showHeader = true,\n    columns = [],\n    ...props\n}: TableProps<TData, TError>) {\n    const mapColumn = useCallback(\n        ({\n            id,\n            accessorKey,\n            header,\n            enableSorting,\n            enableHiding,\n            filter,\n            cell,\n        }: ColumnProps<TData, TError>): ColumnDef<TData> => {\n            const column: any = {\n                id,\n                header,\n                accessorKey,\n                enableSorting: enableSorting ?? false,\n                enableHiding: enableHiding ?? false,\n                enableColumnFilter: true,\n                enableResizing: true,\n                filter,\n            };\n\n            if (cell) {\n                column[\"cell\"] = cell;\n            }\n\n            return column;\n        },\n        [],\n    );\n\n    columns = useMemo<ColumnDef<TData>[]>(() => {\n        if (Array.isArray(children)) {\n            return (children as ReactElement[])\n                .map((value: ReactElement) => value.props)\n                .map(mapColumn);\n        }\n\n        return [];\n    }, [children, mapColumn]);\n\n    const table = useTable({\n        columns,\n        ...props,\n    });\n\n    const tableOptions = useMemo<TableOptionsResolved<TData>>(\n        () => table.options,\n        [table],\n    );\n\n    const isFilterable = useMemo<boolean>(\n        () =>\n            Boolean(\n                tableOptions.enableColumnFilters || tableOptions?.enableFilters,\n            ),\n        [tableOptions],\n    );\n\n    return (\n        <DeleteProvider>\n            <div className=\"space-y-4\">\n                <DataTableToolbar table={table} />\n                <div className=\"rounded-md border border-border\">\n                    <TableUi>\n                        {showHeader && (\n                            <TableHeader>\n                                {table.getHeaderGroups().map((headerGroup) => (\n                                    <TableRow key={headerGroup.id}>\n                                        {headerGroup.headers.map((header) => {\n                                            const columnDef = header.column\n                                                .columnDef as CustomColumnDef<\n                                                TData,\n                                                TError\n                                            >;\n                                            return (\n                                                <TableHead key={header.id}>\n                                                    <div className=\"inline-flex flex-row items-center gap-x-2.5\">\n                                                        {header.isPlaceholder\n                                                            ? null\n                                                            : flexRender(\n                                                                  header.column\n                                                                      .columnDef\n                                                                      .header,\n                                                                  header.getContext(),\n                                                              )}\n                                                        {tableOptions.enableSorting &&\n                                                            columnDef.enableSorting && (\n                                                                <SortAction\n                                                                    column={\n                                                                        header.column\n                                                                    }\n                                                                />\n                                                            )}\n                                                        {isFilterable &&\n                                                            columnDef?.filter &&\n                                                            columnDef.filter({\n                                                                column: header.column,\n                                                                title: `${columnDef.header} Filter`,\n                                                            })}\n                                                    </div>\n                                                </TableHead>\n                                            );\n                                        })}\n                                    </TableRow>\n                                ))}\n                            </TableHeader>\n                        )}\n                        <TableBody>\n                            {table.refineCore.tableQuery.isLoading ? (\n                                <TableRow>\n                                    <TableCell\n                                        colSpan={columns.length}\n                                        className=\"h-24 text-center text-nowrap\"\n                                    >\n                                        <div className=\"flex items-center justify-center flex-row\">\n                                            <Loader className=\"h-4 text-primary\" />\n                                        </div>\n                                    </TableCell>\n                                </TableRow>\n                            ) : table.getRowModel().rows?.length ? (\n                                table.getRowModel().rows.map((row: any) => (\n                                    <TableRow\n                                        key={row.id}\n                                        data-state={\n                                            row.getIsSelected() && \"selected\"\n                                        }\n                                    >\n                                        {row\n                                            .getVisibleCells()\n                                            .map((cell: any) => (\n                                                <TableCell\n                                                    key={cell.id}\n                                                    className=\"text-nowrap\"\n                                                >\n                                                    {flexRender(\n                                                        cell.column.columnDef\n                                                            .cell,\n                                                        cell.getContext(),\n                                                    )}\n                                                </TableCell>\n                                            ))}\n                                    </TableRow>\n                                ))\n                            ) : (\n                                <TableRow>\n                                    <TableCell\n                                        colSpan={columns.length}\n                                        className=\"h-24 text-center\"\n                                    >\n                                        No results.\n                                    </TableCell>\n                                </TableRow>\n                            )}\n                        </TableBody>\n                    </TableUi>\n                </div>\n                <Pagination table={table} />\n            </div>\n        </DeleteProvider>\n    );\n}\n\nconst TableColumn = <\n    TData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n>(\n    props: ColumnProps<TData, TError>,\n) => {\n    return props.children;\n};\n\nTable.Column = TableColumn;\nTable.CheckAll = CheckAll;\nTable.Actions = RowActions;\nTable.Action = RowAction;\nTable.EditAction = EditAction;\nTable.ShowAction = ShowAction;\nTable.DeleteAction = DeleteAction;\nTable.Filter = {\n    DateRangePicker: TableFilterDateRangePickerFilter,\n    Dropdown: TableFilterDropdown,\n    Search: TableFilterSearchColumn,\n};\n\nTable.displayName = \"Table\";\n", "\"use client\";\nimport { Button } from \"@/ui/button\";\nimport {\n    DropdownMenu,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuTrigger,\n} from \"@/ui/dropdown-menu\";\nimport { Link } from \"@/components/link\";\nimport { DotsHorizontalIcon } from \"@radix-ui/react-icons\";\nimport { FC, PropsWithChildren, ReactNode } from \"react\";\n\ninterface RowActionsProps {\n    children?: ReactNode;\n}\n\nexport type RowActionProps = PropsWithChildren & {\n    to?: string;\n    title?: string;\n    asChild?: boolean;\n    className?: string;\n    disabled?: boolean;\n    icon?: ReactNode;\n    onClick?: (event: any) => void;\n};\n\nexport const RowAction: FC<RowActionProps> = (props) => {\n    return (\n        <DropdownMenuItem\n            disabled={props.disabled}\n            asChild={!(!props.to || (!props.to && !props.children))}\n            onClick={props.onClick}\n        >\n            {props.asChild ? (\n                props.children\n            ) : props.to ? (\n                <Link href={props.to} title={props.title}>\n                    {props.icon ? (\n                        <span className=\"mr-2\">{props.icon}</span>\n                    ) : null}\n                    {props.title}\n                </Link>\n            ) : (\n                <>\n                    {props.icon ? (\n                        <span className=\"mr-2\">{props.icon}</span>\n                    ) : null}\n                    {props.title}\n                </>\n            )}\n        </DropdownMenuItem>\n    );\n};\n\nRowAction.displayName = \"RowAction\";\n\nexport function RowActions({ children }: RowActionsProps) {\n    return (\n        <DropdownMenu>\n            <DropdownMenuTrigger asChild>\n                <Button variant=\"ghost\" size=\"icon\">\n                    <DotsHorizontalIcon className=\"h-4 w-4\" />\n                    <span className=\"sr-only\">Open menu</span>\n                </Button>\n            </DropdownMenuTrigger>\n            <DropdownMenuContent align=\"end\" className=\"w-[160px]\">\n                {children}\n            </DropdownMenuContent>\n        </DropdownMenu>\n    );\n}\n", "import type { RowActionProps } from \".\";\nimport { RowAction } from \".\";\nimport { useGetEditUrl } from \"@/hooks\";\n\ntype EditActionProps = RowActionProps & {\n    row: any;\n    resource: string;\n    title: string;\n};\n\nexport function EditAction({\n    row,\n    resource,\n    title,\n    disabled,\n    ...props\n}: EditActionProps) {\n    const edit = useGetEditUrl(resource, row.id);\n\n    return (\n        <RowAction\n            {...props}\n            disabled={!edit.can || disabled}\n            title={!edit?.can ? edit?.reason : title}\n            to={edit.url}\n        />\n    );\n}\n\nEditAction.displayName = \"EditAction\";\n", "import type { RowActionProps } from \".\";\nimport { RowAction } from \".\";\nimport { useGetShowUrl } from \"@/hooks\";\n\ntype ShowActionProps = RowActionProps & {\n    row: any;\n    resource: string;\n    title: string;\n};\n\nexport function ShowAction({\n    row,\n    resource,\n    title,\n    disabled,\n    ...props\n}: ShowActionProps) {\n    const detail = useGetShowUrl(resource, row.id);\n\n    return (\n        <RowAction\n            {...props}\n            disabled={!detail.can || disabled}\n            title={!detail?.can ? detail?.reason : title}\n            to={detail.url}\n        />\n    );\n}\n\nShowAction.displayName = \"ShowAction\";\n", "import { format } from \"date-fns\";\nimport { FilterIcon, FilterX } from \"lucide-react\";\nimport { useEffect, useState } from \"react\";\nimport { DateRange } from \"react-day-picker\";\n\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/ui/popover\";\nimport { Button } from \"@/ui/button\";\nimport { Separator } from \"@/ui/separator\";\nimport { Badge } from \"@/ui/badge\";\nimport { Calendar } from \"@/ui/calendar\";\nimport { BaseRecord } from \"@refinedev/core\";\n\nexport function TableFilterDateRangePickerFilter<\n    T extends BaseRecord = BaseRecord,\n>({\n    column,\n    title,\n    numberOfMonths = 2,\n    align = \"start\",\n}: Pick<TableFilterProps<T>, \"column\" | \"title\" | \"numberOfMonths\" | \"align\">) {\n    const [date, setDate] = useState<DateRange | undefined>({\n        from: undefined,\n        to: undefined,\n    });\n    const selectedValues = new Set(column?.getFilterValue() as string[]);\n\n    useEffect(() => {\n        if (date) {\n            const dates = Object.values(date).filter(Boolean);\n            if (dates.length) {\n                column?.setFilterValue(\n                    dates.map((date: Date | undefined) =>\n                        date ? format(date, \"yyyy-MM-dd\").toString() : \"\",\n                    ),\n                );\n            }\n        }\n    }, [column, date]);\n\n    return (\n        <Popover>\n            <PopoverTrigger asChild>\n                <div className=\"inline-flex flex-row items-center gap-x-0.5\">\n                    <Button\n                        title={title}\n                        variant=\"outline\"\n                        size=\"sm\"\n                        className=\"h-5 border-dashed px-1 py-2.5\"\n                    >\n                        <FilterIcon className={cn(\"h-3.5 w-3.5\")} />\n                        {date?.from ? (\n                            <>\n                                <Separator\n                                    orientation=\"vertical\"\n                                    className=\"mx-2 h-4\"\n                                />\n                                <Badge\n                                    variant=\"secondary\"\n                                    className=\"rounded-sm p-1 h-3.5 text-xs font-normal\"\n                                >\n                                    {date.to ? (\n                                        <>\n                                            {[\n                                                format(date.from, \"LLL dd, y\"),\n                                                format(date.to, \"LLL dd, y\"),\n                                            ].join(\" \")}\n                                        </>\n                                    ) : (\n                                        format(date.from, \"LLL dd, y\")\n                                    )}\n                                </Badge>\n                            </>\n                        ) : null}\n                    </Button>\n                    {selectedValues.size > 0 && (\n                        <Button\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-5 border-dashed px-1 py-2.5\"\n                            onClick={(e) => {\n                                e.preventDefault();\n                                column?.setFilterValue(undefined);\n                                setDate({ from: undefined, to: undefined });\n                            }}\n                        >\n                            <FilterX className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    )}\n                </div>\n            </PopoverTrigger>\n            <PopoverContent className=\"w-auto p-0\" align={align}>\n                <Calendar\n                    initialFocus\n                    mode=\"range\"\n                    defaultMonth={new Date()}\n                    selected={date}\n                    onSelect={setDate}\n                    numberOfMonths={numberOfMonths}\n                />\n                {selectedValues.size > 0 && (\n                    <>\n                        <Separator />\n                        <div className=\"flex flex-row items-center justify-center py-3\">\n                            <Button\n                                variant=\"outline\"\n                                size=\"sm\"\n                                className=\"h-8 border-dashed px-2\"\n                                onClick={() => {\n                                    column?.setFilterValue(undefined);\n                                    setDate({ from: undefined, to: undefined });\n                                }}\n                            >\n                                <FilterX size={16} className=\"mr-2\" />\n                                Clear\n                            </Button>\n                        </div>\n                    </>\n                )}\n            </PopoverContent>\n        </Popover>\n    );\n}\n", "import { CheckIcon } from \"@radix-ui/react-icons\";\nimport { FilterIcon, FilterX } from \"lucide-react\";\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/ui/popover\";\nimport { Button } from \"@/ui/button\";\nimport { Separator } from \"@/ui/separator\";\nimport { Badge } from \"@/ui/badge\";\nimport {\n    Command,\n    CommandEmpty,\n    CommandGroup,\n    CommandInput,\n    CommandItem,\n    CommandList,\n    CommandSeparator,\n} from \"@/ui/command\";\n\nexport function TableFilterDropdown({\n    column,\n    title,\n    options,\n    align = \"start\",\n}: TableFilterProps) {\n    const facets = column?.getFacetedUniqueValues();\n    const selectedValues = new Set(column?.getFilterValue() as string[]);\n\n    return (\n        <Popover>\n            <PopoverTrigger asChild>\n                <div className=\"inline-flex flex-row items-center gap-x-0.5\">\n                    <Button\n                        title={title}\n                        variant=\"outline\"\n                        size=\"sm\"\n                        className=\"h-5 border-dashed px-1 py-2.5\"\n                    >\n                        <FilterIcon className={cn(\"h-3.5 w-3.5\")} />\n                        {selectedValues?.size > 0 && (\n                            <>\n                                <Separator\n                                    orientation=\"vertical\"\n                                    className=\"mx-2 h-4\"\n                                />\n                                <Badge\n                                    variant=\"secondary\"\n                                    className=\"rounded-sm p-1 h-3.5 text-xs font-normal lg:hidden\"\n                                >\n                                    {selectedValues.size}\n                                </Badge>\n                                <div className=\"hidden space-x-1 lg:flex\">\n                                    {selectedValues.size > 2 ? (\n                                        <Badge\n                                            variant=\"secondary\"\n                                            className=\"rounded-sm p-1 text-xs h-3.5 font-normal\"\n                                        >\n                                            {selectedValues.size} selected\n                                        </Badge>\n                                    ) : (\n                                        options\n                                            ?.filter((option) =>\n                                                selectedValues.has(\n                                                    option.value,\n                                                ),\n                                            )\n                                            .map((option) => (\n                                                <Badge\n                                                    variant=\"secondary\"\n                                                    key={option.value}\n                                                    className=\"rounded-sm p-1 text-xs h-3.5 font-normal\"\n                                                >\n                                                    {option.label}\n                                                </Badge>\n                                            ))\n                                    )}\n                                </div>\n                            </>\n                        )}\n                    </Button>\n\n                    {selectedValues.size > 0 && (\n                        <Button\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-5 border-dashed px-1 py-2.5\"\n                            onClick={(e) => {\n                                e.preventDefault();\n                                column?.setFilterValue(undefined);\n                            }}\n                        >\n                            <FilterX className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    )}\n                </div>\n            </PopoverTrigger>\n            <PopoverContent className=\"w-[200px] p-0\" align={align}>\n                <Command>\n                    <CommandInput placeholder={title} />\n                    <CommandList>\n                        <CommandEmpty>No results found.</CommandEmpty>\n                        <CommandGroup>\n                            {options?.map((option) => {\n                                const isSelected = selectedValues.has(\n                                    option.value,\n                                );\n                                return (\n                                    <CommandItem\n                                        key={option.value}\n                                        onSelect={() => {\n                                            if (isSelected) {\n                                                selectedValues.delete(\n                                                    option.value,\n                                                );\n                                            } else {\n                                                selectedValues.add(\n                                                    option.value,\n                                                );\n                                            }\n                                            const filterValues =\n                                                Array.from(selectedValues);\n                                            column?.setFilterValue(\n                                                filterValues.length\n                                                    ? filterValues\n                                                    : undefined,\n                                            );\n                                        }}\n                                    >\n                                        <div\n                                            className={cn(\n                                                \"mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary\",\n                                                isSelected\n                                                    ? \"bg-primary text-primary-foreground\"\n                                                    : \"opacity-50 [&_svg]:invisible\",\n                                            )}\n                                        >\n                                            <CheckIcon\n                                                className={cn(\"h-4 w-4\")}\n                                            />\n                                        </div>\n                                        {option.icon && (\n                                            <option.icon className=\"mr-2 h-4 w-4 text-muted-foreground\" />\n                                        )}\n                                        <span>{option.label}</span>\n                                        {facets?.get(option.value) && (\n                                            <span className=\"ml-auto flex h-4 w-4 items-center justify-center font-mono text-xs\">\n                                                {facets.get(option.value)}\n                                            </span>\n                                        )}\n                                    </CommandItem>\n                                );\n                            })}\n                        </CommandGroup>\n                        {selectedValues.size > 0 && (\n                            <>\n                                <CommandSeparator />\n                                <CommandGroup>\n                                    <CommandItem\n                                        onSelect={() =>\n                                            column?.setFilterValue(undefined)\n                                        }\n                                        className=\"justify-center text-center\"\n                                    >\n                                        Clear filters\n                                    </CommandItem>\n                                </CommandGroup>\n                            </>\n                        )}\n                    </CommandList>\n                </Command>\n            </PopoverContent>\n        </Popover>\n    );\n}\n", "import { FilterIcon, FilterX } from \"lucide-react\";\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport { Button } from \"@/ui/button\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/ui/popover\";\nimport { Input } from \"@/ui/input\";\nimport { Separator } from \"@/ui/separator\";\n\nexport function TableFilterSearchColumn({\n    column,\n    title,\n    align = \"start\",\n}: TableFilterProps) {\n    const selectedValue = column?.getFilterValue() as string;\n\n    return (\n        <Popover>\n            <PopoverTrigger asChild>\n                <div className=\"inline-flex flex-row items-center gap-x-0.5\">\n                    {selectedValue ? (\n                        <Button\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-5 border-dashed px-1 py-2.5\"\n                            onClick={(e) => {\n                                e.preventDefault();\n                                column?.setFilterValue(undefined);\n                            }}\n                        >\n                            <FilterX className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    ) : (\n                        <Button\n                            title={title}\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-4 border-dashed px-1 py-2.5\"\n                        >\n                            <FilterIcon className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    )}\n                </div>\n            </PopoverTrigger>\n            <PopoverContent\n                className=\"w-[200px] p-0 overflow-hidden border-0 ring-0\"\n                align={align}\n            >\n                <div className=\"relative\">\n                    <div className=\"flex flex-row items-center px-3 text-popover-foreground bg-popover\">\n                        <svg\n                            width=\"15\"\n                            height=\"15\"\n                            viewBox=\"0 0 15 15\"\n                            fill=\"none\"\n                            xmlns=\"http://www.w3.org/2000/svg\"\n                            className=\"mr-2 h-4 w-4 shrink-0 opacity-50\"\n                        >\n                            <path\n                                d=\"M10 6.5C10 8.433 8.433 10 6.5 10C4.567 10 3 8.433 3 6.5C3 4.567 4.567 3 6.5 3C8.433 3 10 4.567 10 6.5ZM9.30884 10.0159C8.53901 10.6318 7.56251 11 6.5 11C4.01472 11 2 8.98528 2 6.5C2 4.01472 4.01472 2 6.5 2C8.98528 2 11 4.01472 11 6.5C11 7.56251 10.6318 8.53901 10.0159 9.30884L12.8536 12.1464C13.0488 12.3417 13.0488 12.6583 12.8536 12.8536C12.6583 13.0488 12.3417 13.0488 12.1464 12.8536L9.30884 10.0159Z\"\n                                fill=\"currentColor\"\n                                fillRule=\"evenodd\"\n                                clipRule=\"evenodd\"\n                            ></path>\n                        </svg>\n                        <Input\n                            defaultValue={selectedValue ?? \"\"}\n                            onChange={(e) => {\n                                column?.setFilterValue(e.target.value);\n                            }}\n                            className={cn(\n                                \"h-10 border-0 focus-visible:ring-0 ring-0 rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground shadow-none disabled:cursor-not-allowed disabled:opacity-50\",\n                            )}\n                            placeholder={title}\n                        />\n                    </div>\n                    {selectedValue && (\n                        <>\n                            <Separator />\n                            <div className=\"flex flex-row items-center justify-center py-3\">\n                                <Button\n                                    variant=\"outline\"\n                                    size=\"sm\"\n                                    className=\"h-8 border-dashed px-2\"\n                                    onClick={() => {\n                                        column?.setFilterValue(undefined);\n                                    }}\n                                >\n                                    <FilterX size={16} className=\"mr-2\" />\n                                    Clear\n                                </Button>\n                            </div>\n                        </>\n                    )}\n                </div>\n            </PopoverContent>\n        </Popover>\n    );\n}\n", "import { Button } from \"@/ui/button\";\nimport { Checkbox } from \"@/ui/checkbox\";\nimport { DotsVerticalIcon } from \"@radix-ui/react-icons\";\nimport {\n    DropdownMenu,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuLabel,\n    DropdownMenuSeparator,\n    DropdownMenuTrigger,\n} from \"@/ui/dropdown-menu\";\n\nimport { BaseRecord, HttpError } from \"@refinedev/core\";\nimport { UseTableReturnType } from \"@refinedev/react-table\";\n\nimport { FC, forwardRef, PropsWithChildren } from \"react\";\n\ntype CheckAllProps = React.ComponentPropsWithoutRef<typeof Checkbox> &\n    PropsWithChildren<{\n        table: UseTableReturnType<BaseRecord, HttpError>;\n        options?: {\n            label: string;\n            onClick: () => void;\n        }[];\n    }>;\n\nexport const CheckAll: FC<CheckAllProps> = forwardRef<\n    React.ElementRef<typeof Checkbox>,\n    CheckAllProps\n>(({ table, children, options }, ref) => {\n    return (\n        <>\n            <Checkbox\n                ref={ref}\n                checked={\n                    table.getIsSomeRowsSelected()\n                        ? \"indeterminate\"\n                        : table.getIsAllPageRowsSelected()\n                }\n                onCheckedChange={(value) =>\n                    table.toggleAllPageRowsSelected(!!value)\n                }\n                className=\"translate-y-[2px]\"\n                aria-label=\"Select all\"\n            />\n            {children ||\n                (Array.isArray(options) && options.length && (\n                    <DropdownMenu>\n                        <DropdownMenuTrigger asChild>\n                            <Button\n                                disabled={\n                                    !(\n                                        table.getIsSomeRowsSelected() ||\n                                        table.getIsAllPageRowsSelected()\n                                    )\n                                }\n                                size={\"icon\"}\n                                variant={\"ghost\"}\n                                className=\"px-0 w-5\"\n                            >\n                                <DotsVerticalIcon className=\"w-4 h-4\" />\n                            </Button>\n                        </DropdownMenuTrigger>\n                        <DropdownMenuContent align=\"start\">\n                            <DropdownMenuLabel>Bulk Actions</DropdownMenuLabel>\n                            <DropdownMenuSeparator />\n                            {!children &&\n                            Array.isArray(options) &&\n                            options?.length > 0\n                                ? options.map((option, key) => (\n                                      <DropdownMenuItem\n                                          key={key}\n                                          onSelect={option.onClick}\n                                      >\n                                          {option.label}\n                                      </DropdownMenuItem>\n                                  ))\n                                : children}\n                        </DropdownMenuContent>\n                    </DropdownMenu>\n                ))}\n        </>\n    );\n});\n\nCheckAll.displayName = \"CheckAll\";\n", "import {\n    ChevronLeftIcon,\n    ChevronRightIcon,\n    DoubleArrowLeftIcon,\n    DoubleArrowRightIcon,\n} from \"@radix-ui/react-icons\";\nimport { UseTableReturnType as Table } from \"@refinedev/react-table\";\n\nimport { BaseRecord } from \"@refinedev/core\";\nimport {\n    Select,\n    SelectContent,\n    SelectItem,\n    SelectTrigger,\n    SelectValue,\n} from \"@/ui/select\";\nimport { Button } from \"@/ui/button\";\nimport React, { FC } from \"react\";\n\ninterface DataTablePaginationProps<TData extends BaseRecord = BaseRecord> {\n    table: Table<TData>;\n}\n\nexport const Pagination = <TData extends BaseRecord = BaseRecord>({\n    table,\n}: DataTablePaginationProps<TData>) => {\n    return (\n        <div className=\"flex flex-col sm:flex-row gap-y-4 sm-gap-y-0 items-center justify-between\">\n            <div className=\"flex-1 text-sm text-muted-foreground\">\n                {table.getFilteredSelectedRowModel().rows.length} of{\" \"}\n                {table.getFilteredRowModel().rows.length} row(s) selected.\n            </div>\n            <div className=\"flex relative flex-col-reverse gap-y-4 sm:gap-y-0 sm:flex-row items-center space-x-6 lg:space-x-8\">\n                <div className=\"flex items-center space-x-2\">\n                    <p className=\"text-sm font-medium\">Rows per page</p>\n                    <Select\n                        value={`${table.getState().pagination.pageSize}`}\n                        onValueChange={(value) => {\n                            table.setPageSize(Number(value));\n                        }}\n                    >\n                        <SelectTrigger className=\"h-8 w-[70px]\">\n                            <SelectValue\n                                placeholder={\n                                    table.getState().pagination.pageSize\n                                }\n                            />\n                        </SelectTrigger>\n                        <SelectContent>\n                            {[10, 20, 30, 40, 50].map((pageSize) => (\n                                <SelectItem\n                                    key={pageSize}\n                                    value={`${pageSize}`}\n                                >\n                                    {pageSize}\n                                </SelectItem>\n                            ))}\n                        </SelectContent>\n                    </Select>\n                </div>\n                <div className=\"flex w-fit items-center justify-center text-sm font-medium\">\n                    Page {table.getState().pagination.pageIndex + 1} of{\" \"}\n                    {table.getPageCount()}\n                </div>\n                <div className=\"flex items-center space-x-2\">\n                    <Button\n                        variant=\"outline\"\n                        className=\"hidden h-8 w-8 p-0 lg:flex\"\n                        onClick={() => table.setPageIndex(0)}\n                        disabled={!table.getCanPreviousPage()}\n                    >\n                        <span className=\"sr-only\">Go to first page</span>\n                        <DoubleArrowLeftIcon className=\"h-4 w-4\" />\n                    </Button>\n                    <Button\n                        variant=\"outline\"\n                        className=\"h-8 w-8 p-0\"\n                        onClick={() => table.previousPage()}\n                        disabled={!table.getCanPreviousPage()}\n                    >\n                        <span className=\"sr-only\">Go to previous page</span>\n                        <ChevronLeftIcon className=\"h-4 w-4\" />\n                    </Button>\n                    <Button\n                        variant=\"outline\"\n                        className=\"h-8 w-8 p-0\"\n                        onClick={() => table.nextPage()}\n                        disabled={!table.getCanNextPage()}\n                    >\n                        <span className=\"sr-only\">Go to next page</span>\n                        <ChevronRightIcon className=\"h-4 w-4\" />\n                    </Button>\n                    <Button\n                        variant=\"outline\"\n                        className=\"hidden h-8 w-8 p-0 lg:flex\"\n                        onClick={() =>\n                            table.setPageIndex(table.getPageCount() - 1)\n                        }\n                        disabled={!table.getCanNextPage()}\n                    >\n                        <span className=\"sr-only\">Go to last page</span>\n                        <DoubleArrowRightIcon className=\"h-4 w-4\" />\n                    </Button>\n                </div>\n            </div>\n        </div>\n    );\n};\n\nPagination.displayName = \"Pagination\";\n", "import { CaretDownIcon, CaretUpIcon } from \"@radix-ui/react-icons\";\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport type { BaseRecord } from \"@refinedev/core\";\n\nexport const SortAction = <TData extends BaseRecord = BaseRecord>({\n  column,\n}: Pick<TableFilterProps<TData>, \"column\">) => {\n  return (\n    <div\n      className=\"cursor-pointer\"\n      onClick={() => {\n        column?.toggleSorting(column?.getIsSorted() === \"asc\");\n      }}\n    >\n      <div className=\"inline-flex flex-col\">\n        <CaretUpIcon\n          className={cn(\n            \"-mb-1.5 w-5 h-5\",\n            column?.getIsSorted() === \"asc\" ? \"text-foreground\" : \"text-input\"\n          )}\n        />\n        <CaretDownIcon\n          className={cn(\n            \"-mt-1.5 w-5 h-5\",\n            column?.getIsSorted() === \"desc\" ? \"text-foreground\" : \"text-input\"\n          )}\n        />\n      </div>\n    </div>\n  );\n};\n", "\"use client\";\nimport { DropdownMenuTrigger } from \"@radix-ui/react-dropdown-menu\";\nimport { MixerHorizontalIcon } from \"@radix-ui/react-icons\";\nimport { Table } from \"@tanstack/react-table\";\nimport { Button } from \"@/ui/button\";\nimport {\n    DropdownMenu,\n    DropdownMenuCheckboxItem,\n    DropdownMenuContent,\n    DropdownMenuLabel,\n    DropdownMenuSeparator,\n} from \"@/ui/dropdown-menu\";\nimport { FC, useMemo } from \"react\";\n\ninterface DataTableViewOptionsProps<TData> {\n    table: Table<TData>;\n}\n\nexport const DataTableViewOptions = <TData,>({\n    table,\n}: DataTableViewOptionsProps<TData>): ReturnType<\n    FC<DataTableViewOptionsProps<TData>>\n> => {\n    const columns = useMemo(() => {\n        return table\n            .getAllColumns()\n            .filter(\n                (column) =>\n                    typeof column.accessorFn !== \"undefined\" &&\n                    column.getCanHide(),\n            );\n    }, [table]);\n\n    return (\n        <DropdownMenu>\n            <DropdownMenuTrigger asChild>\n                <Button\n                    variant=\"outline\"\n                    size=\"sm\"\n                    className=\"ml-auto hidden h-8 lg:flex\"\n                >\n                    <MixerHorizontalIcon className=\"mr-2 h-4 w-4\" />\n                    View\n                </Button>\n            </DropdownMenuTrigger>\n            <DropdownMenuContent align=\"end\" className=\"w-[150px]\">\n                <DropdownMenuLabel>Toggle columns</DropdownMenuLabel>\n                <DropdownMenuSeparator />\n                {columns.map((column) => {\n                    return (\n                        <DropdownMenuCheckboxItem\n                            key={column.id}\n                            className=\"capitalize\"\n                            checked={column.getIsVisible()}\n                            onCheckedChange={(value) =>\n                                column.toggleVisibility(value)\n                            }\n                        >\n                            {column.id}\n                        </DropdownMenuCheckboxItem>\n                    );\n                })}\n            </DropdownMenuContent>\n        </DropdownMenu>\n    );\n};\n\nDataTableViewOptions.displayName = \"DataTableViewOptions\";\n", "\"use client\";\n\nimport { Table } from \"@tanstack/react-table\";\n\nimport { DataTableViewOptions } from \"./table-view-options-dropdown\";\n\ninterface DataTableToolbarProps<TData> {\n  table: Table<TData>;\n}\n\nexport function DataTableToolbar<TData>({\n  table,\n}: DataTableToolbarProps<TData>) {\n  return (\n    <div className=\"flex items-center justify-between\">\n      <div className=\"flex flex-1 items-center space-x-2\"></div>\n      <DataTableViewOptions table={table} />\n    </div>\n  );\n}\n", "import { useDeleteHelper } from \"@/hooks\";\nimport { DeleteContext } from \"@/providers\";\nimport { useContext } from \"react\";\nimport type { RowActionProps } from \".\";\nimport { RowAction } from \".\";\n\ntype DeleteActionProps = RowActionProps & {\n    row: any;\n    resource: string;\n    title: string;\n    onAfterHandle?: () => void;\n};\n\nexport function DeleteAction({\n    row,\n    resource,\n    title,\n    disabled,\n    onAfterHandle,\n    ...props\n}: DeleteActionProps) {\n    const { can, reason } = useDeleteHelper(resource, row.id);\n    const deleteContext = useContext(DeleteContext);\n\n    return (\n        <RowAction\n            {...props}\n            disabled={!can || disabled}\n            title={!can ? reason : title}\n            onClick={() =>\n                deleteContext?.updateData({\n                    row,\n                    resource,\n                    toogle: true,\n                    onAfterHandle,\n                })\n            }\n        />\n    );\n}\n\nDeleteAction.displayName = \"DeleteAction\";\n"],
  "mappings": "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",
  "names": ["src_exports", "__export", "Breadcrumbs", "CloneButton", "Combobox", "ConfirmDialog", "CreateButton", "CreatePage", "DefaultLayout", "DeleteActionModal", "DeleteButton", "DeleteContext", "DeleteProvider", "EditButton", "EditPage", "ExportButton", "Field", "Form", "ImportButton", "Link", "ListButton", "ListPage", "ModeToggle", "PageHeader", "RefreshButton", "SaveButton", "Select", "ShowButton", "ShowPage", "Sidebar", "Table", "notificationProvider", "useNotificationProvider", "__toCommonJS", "import_react_slot", "import_class_variance_authority", "React", "import_clsx", "import_tailwind_merge", "cn", "inputs", "__name", "import_lucide_react", "import_react", "import_jsx_runtime", "LoadingIcon", "React", "className", "props", "ref", "cn", "import_jsx_runtime", "buttonVariants", "Button", "className", "variant", "size", "icon", "loading", "asChild", "children", "disabled", "props", "ref", "Icon", "LoadingIcon", "cn", "import_core", "import_lucide_react", "import_jsx_runtime", "CloneButton", "__name", "resource", "recordItemId", "hideText", "accessControl", "meta", "onClick", "children", "props", "to", "LinkComponent", "label", "disabled", "hidden", "title", "e", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "CreateButton", "__name", "resource", "hideText", "accessControl", "meta", "onClick", "children", "props", "hidden", "disabled", "label", "title", "LinkComponent", "to", "e", "Button", "import_core", "import_lucide_react", "React", "import_react_icons", "import_react_slot", "import_jsx_runtime", "Breadcrumb", "props", "ref", "BreadcrumbList", "className", "cn", "BreadcrumbItem", "BreadcrumbLink", "asChild", "BreadcrumbPage", "BreadcrumbSeparator", "__name", "children", "BreadcrumbEllipsis", "import_core", "import_react", "import_react_slot", "import_core", "import_react", "import_jsx_runtime", "Link", "children", "href", "title", "className", "asChild", "ref", "LegacyLink", "routerType", "import_lucide_react", "import_jsx_runtime", "Breadcrumbs", "__name", "showHome", "meta", "breadcrumbs", "hasDashboard", "resources", "dashboardResource", "rootRouteResource", "BreadCrumbItems", "label", "href", "key", "BreadcrumbItem", "BreadcrumbLink", "Link", "BreadcrumbPage", "BreadcrumbSeparator", "Breadcrumb", "BreadcrumbList", "import_react_icons", "AlertDialogPrimitive", "React", "import_jsx_runtime", "AlertDialog", "AlertDialogTrigger", "AlertDialogPortal", "AlertDialogOverlay", "className", "props", "ref", "cn", "AlertDialogContent", "AlertDialogHeader", "__name", "AlertDialogFooter", "AlertDialogTitle", "AlertDialogDescription", "AlertDialogAction", "variant", "size", "buttonVariants", "AlertDialogCancel", "import_class_variance_authority", "import_jsx_runtime", "badgeVariants", "Badge", "className", "variant", "props", "cn", "__name", "import_react_icons", "import_react_day_picker", "import_jsx_runtime", "Calendar", "className", "classNames", "showOutsideDays", "props", "cn", "buttonVariants", "__name", "React", "import_jsx_runtime", "Card", "className", "props", "ref", "cn", "CardHeader", "CardTitle", "CardDescription", "CardContent", "CardFooter", "React", "CheckboxPrimitive", "import_react_icons", "import_jsx_runtime", "Checkbox", "className", "props", "ref", "cn", "React", "import_react_icons", "import_cmdk", "React", "DialogPrimitive", "import_react_icons", "import_jsx_runtime", "DialogPortal", "DialogOverlay", "className", "props", "ref", "cn", "DialogContent", "children", "DialogPortal", "DialogHeader", "__name", "DialogFooter", "DialogTitle", "DialogDescription", "import_jsx_runtime", "Command", "className", "props", "ref", "CommandPrimitive", "cn", "CommandInput", "className", "props", "ref", "CommandPrimitive", "cn", "CommandList", "CommandEmpty", "CommandGroup", "CommandSeparator", "CommandItem", "CommandShortcut", "__name", "React", "DropdownMenuPrimitive", "import_react_icons", "import_jsx_runtime", "DropdownMenu", "DropdownMenuTrigger", "DropdownMenuSubTrigger", "className", "inset", "children", "props", "ref", "cn", "DropdownMenuSubContent", "DropdownMenuContent", "sideOffset", "DropdownMenuItem", "DropdownMenuCheckboxItem", "checked", "DropdownMenuRadioItem", "DropdownMenuLabel", "DropdownMenuSeparator", "DropdownMenuShortcut", "__name", "React", "import_react_slot", "import_react_hook_form", "React", "LabelPrimitive", "import_class_variance_authority", "import_jsx_runtime", "labelVariants", "Label", "className", "props", "ref", "cn", "import_jsx_runtime", "Form", "FormFieldContext", "FormField", "__name", "props", "useFormField", "fieldContext", "itemContext", "FormItemContext", "getFieldState", "formState", "fieldState", "id", "FormItem", "className", "ref", "cn", "FormLabel", "error", "formItemId", "Label", "FormControl", "formDescriptionId", "formMessageId", "FormDescription", "FormMessage", "children", "body", "React", "import_jsx_runtime", "Input", "className", "type", "props", "ref", "cn", "React", "PopoverPrimitive", "import_jsx_runtime", "Popover", "PopoverTrigger", "PopoverContent", "className", "align", "sideOffset", "props", "ref", "cn", "import_react_icons", "ResizablePrimitive", "import_jsx_runtime", "ResizablePanelGroup", "__name", "className", "props", "cn", "ResizablePanel", "ResizableHandle", "withHandle", "React", "ScrollAreaPrimitive", "import_jsx_runtime", "ScrollArea", "className", "children", "props", "ref", "cn", "ScrollBar", "orientation", "React", "import_react_icons", "SelectPrimitive", "import_jsx_runtime", "Select", "SelectValue", "SelectTrigger", "className", "children", "props", "ref", "cn", "SelectScrollUpButton", "SelectScrollDownButton", "SelectContent", "position", "SelectLabel", "SelectItem", "SelectSeparator", "React", "SeparatorPrimitive", "import_jsx_runtime", "Separator", "className", "orientation", "decorative", "props", "ref", "cn", "import_next_themes", "import_sonner", "import_jsx_runtime", "Toaster", "__name", "props", "theme", "Sonner", "React", "import_jsx_runtime", "Table", "className", "props", "ref", "cn", "TableHeader", "TableBody", "TableFooter", "TableRow", "TableHead", "TableCell", "TableCaption", "React", "import_jsx_runtime", "Textarea", "className", "props", "ref", "cn", "React", "TooltipPrimitive", "import_jsx_runtime", "TooltipProvider", "Tooltip", "TooltipTrigger", "TooltipContent", "className", "sideOffset", "props", "ref", "cn", "import_react", "import_jsx_runtime", "Combobox", "props", "ref", "open", "setOpen", "value", "__name", "Popover", "PopoverTrigger", "FormControl", "Button", "cn", "option", "PopoverContent", "Command", "CommandInput", "CommandList", "CommandEmpty", "CommandGroup", "ScrollArea", "CommandItem", "import_lucide_react", "import_react", "import_jsx_runtime", "ConfirmDialog", "__name", "children", "title", "description", "okText", "cancelText", "okButtonSize", "cancelButtonSize", "okButtonVariant", "cancelButtonVariant", "loading", "okIconSide", "cancelIconSide", "onConfirm", "okIcon", "cancelIcon", "open", "onOpenChange", "defaultOpen", "CancelIcon", "OkIcon", "LoadingIcon", "AlertDialog", "AlertDialogTrigger", "AlertDialogContent", "AlertDialogHeader", "AlertDialogTitle", "AlertDialogDescription", "AlertDialogFooter", "AlertDialogCancel", "AlertDialogAction", "import_react", "import_jsx_runtime", "Field", "__name", "props", "FormField", "field", "FormItem", "cn", "FormLabel", "FormControl", "FormDescription", "FormMessage", "import_core", "import_react", "import_jsx_runtime", "Form", "__name", "formProps", "isWatchable", "saveButtonProps", "props", "watchable", "_resource", "action", "routerType", "back", "goBack", "onBack", "onSubmit", "_data", "Card", "CardContent", "CardFooter", "Button", "SaveButton", "import_next_themes", "import_react_icons", "import_jsx_runtime", "ModeToggle", "__name", "setTheme", "DropdownMenu", "DropdownMenuTrigger", "Button", "DropdownMenuContent", "DropdownMenuItem", "import_jsx_runtime", "PageHeader", "__name", "extra", "props", "cn", "import_react", "import_jsx_runtime", "Select", "props", "ref", "triggerRef", "React", "FormControl", "SelectTrigger", "SelectValue", "SelectContent", "option", "key", "SelectItem", "import_core", "import_react_use", "import_react", "import_jsx_runtime", "Sidebar", "__name", "isCollapsed", "menuItems", "resourceParams", "pathname", "currentPathname", "GetIcon", "item", "icon", "React", "i", "key", "paths", "isActive", "path", "Tooltip", "TooltipTrigger", "Link", "cn", "buttonVariants", "TooltipContent", "import_jsx_runtime", "DeleteButton", "__name", "resource", "recordItemId", "onSuccess", "mutationModeProp", "confirmTitle", "confirmDescription", "successNotification", "errorNotification", "hideText", "accessControl", "meta", "dataProviderName", "confirmOkText", "confirmCancelText", "invalidates", "children", "props", "title", "label", "hidden", "disabled", "loading", "defaultConfirmTitle", "defaultConfirmOkLabel", "defaultCancelLabel", "onConfirm", "ConfirmDialog", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "EditButton", "__name", "resource", "recordItemId", "hideText", "accessControl", "meta", "onClick", "children", "props", "hidden", "disabled", "label", "title", "LinkComponent", "to", "e", "Button", "import_react_slot", "import_core", "import_lucide_react", "import_jsx_runtime", "ExportButton", "__name", "hideText", "resource", "recordItemId", "accessControl", "access", "children", "props", "label", "Com", "Button", "import_react_slot", "import_core", "import_lucide_react", "import_jsx_runtime", "ImportButton", "__name", "hideText", "resource", "onChange", "accept", "recordItemId", "accessControl", "access", "children", "props", "label", "Com", "onClick", "el", "e", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "ListButton", "__name", "resourceNameFromProps", "hideText", "accessControl", "meta", "children", "onClick", "props", "hidden", "disabled", "label", "title", "LinkComponent", "to", "e", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "RefreshButton", "__name", "resource", "recordItemId", "hideText", "dataProviderName", "children", "props", "onClick", "label", "loading", "Button", "import_react_slot", "import_core", "import_lucide_react", "import_jsx_runtime", "SaveButton", "__name", "hideText", "children", "accessControl", "access", "resource", "recordItemId", "props", "label", "Com", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "ShowButton", "__name", "resourceNameFromProps", "recordItemId", "hideText", "accessControl", "meta", "children", "onClick", "props", "to", "label", "title", "hidden", "disabled", "LinkComponent", "e", "Button", "import_core", "import_react", "import_jsx_runtime", "CreatePage", "__name", "title", "resourceFromProps", "breadcrumbFromProps", "extra", "children", "translate", "globalBreadcrumb", "getUserFriendlyName", "resource", "identifier", "breadcrumb", "PageHeader", "Breadcrumbs", "ListButton", "import_core", "import_react", "import_jsx_runtime", "EditPage", "__name", "title", "resource", "extra", "breadcrumbFromProps", "children", "translate", "globalBreadcrumb", "list", "getUserFriendlyName", "_resource", "identifier", "breadcrumb", "PageHeader", "Breadcrumbs", "ShowButton", "DeleteButton", "import_core", "import_react", "import_jsx_runtime", "ListPage", "__name", "title", "resourceFromProps", "breadcrumbFromProps", "createButtonProps", "className", "isCreate", "extra", "children", "translate", "globalBreadcrumb", "getUserFriendlyName", "resource", "identifier", "breadcrumb", "PageHeader", "Breadcrumbs", "CreateButton", "cn", "import_core", "import_react", "import_jsx_runtime", "Row", "__name", "title", "children", "import_jsx_runtime", "ShowPage", "__name", "title", "resourceFromProps", "breadcrumbFromProps", "isEdit", "isDelete", "extra", "children", "translate", "globalBreadcrumb", "getUserFriendlyName", "resource", "identifier", "list", "breadcrumb", "PageHeader", "Breadcrumbs", "EditButton", "DeleteButton", "Row", "import_next_themes", "import_jsx_runtime", "ThemeProvider", "children", "props", "NextThemesProvider", "__name", "import_jsx_runtime", "BaseLayout", "__name", "attribute", "defaultTheme", "enableSystem", "disableTransitionOnChange", "enableColorScheme", "forcedTheme", "nonce", "storageKey", "themes", "value", "children", "ThemeProvider", "TooltipProvider", "Toaster", "base_default", "React", "queriesDidChange", "prevQueries", "nextQueries", "nextQueriesArr", "prevQueriesArr", "q", "i", "prevKeys", "n", "__name", "_ref", "curr", "key", "init", "queries", "queryKeys", "state", "name", "mql", "reducer", "action", "_ref2", "prev", "useMediaQueries", "queryMap", "dispatch", "_ref3", "_ref4", "mq", "callback", "callbacks", "_ref5", "matches", "matchValues", "useMediaQuery", "query", "getObj", "cache", "import_react", "import_core", "import_jsx_runtime", "DefaultLayout", "__name", "children", "defaultLayout", "defaultCollapsed", "navCollapsedSize", "navbar", "footer", "logo", "attribute", "defaultTheme", "enableSystem", "disableTransitionOnChange", "enableColorScheme", "forcedTheme", "nonce", "storageKey", "themes", "value", "resources", "firstDashboard", "xs", "useMediaQuery", "sm", "md", "lg", "isCollapsed", "setIsCollapsed", "layout", "SidebarSizes", "hasCollapsed", "Logo", "component", "base_default", "ResizablePanelGroup", "sizes", "ResizablePanel", "collapsed", "cn", "Link", "Sidebar", "ResizableHandle", "ModeToggle", "import_sonner", "notificationProvider", "__name", "key", "message", "description", "type", "useNotificationProvider", "import_core", "import_react", "useGetEditUrl", "__name", "resource", "recordItemId", "meta", "accessControlContext", "accessControlEnabled", "hideIfUnauthorized", "generateEditUrl", "id", "_resource", "data", "translate", "reason", "editUrl", "import_core", "import_react", "useGetShowUrl", "__name", "resource", "recordItemId", "meta", "accessControlContext", "accessControlEnabled", "hideIfUnauthorized", "generateShowUrl", "id", "_resource", "data", "translate", "reason", "showUrl", "import_core", "import_react", "useDeleteHelper", "__name", "resource", "recordItemId", "meta", "accessControlContext", "accessControlEnabled", "hideIfUnauthorized", "translate", "id", "_resource", "identifier", "mutationMode", "mutate", "isLoading", "data", "reason", "setWarnWhen", "onDeleteMutate", "options", "import_core", "useOnBack", "__name", "routerType", "back", "goBack", "action", "import_core", "import_react", "import_jsx_runtime", "DeleteActionModal", "props", "back", "useOnBack", "can", "isLoading", "mutate", "useDeleteHelper", "translate", "onDelete", "isRedirectBack", "onAfterHandle", "ConfirmDialog", "__name", "DeleteContext", "DeleteProvider", "children", "data", "setData", "updateData", "import_react", "import_jsx_runtime", "Loader", "className", "props", "ref", "cn", "loader_default", "import_react_table", "import_react", "import_react_icons", "import_jsx_runtime", "RowAction", "__name", "props", "DropdownMenuItem", "Link", "RowActions", "children", "DropdownMenu", "DropdownMenuTrigger", "Button", "DropdownMenuContent", "import_jsx_runtime", "EditAction", "row", "resource", "title", "disabled", "props", "edit", "useGetEditUrl", "RowAction", "__name", "import_jsx_runtime", "ShowAction", "row", "resource", "title", "disabled", "props", "detail", "useGetShowUrl", "RowAction", "__name", "import_date_fns", "import_lucide_react", "import_react", "import_jsx_runtime", "TableFilterDateRangePickerFilter", "column", "title", "numberOfMonths", "align", "date", "setDate", "selectedValues", "dates", "Popover", "PopoverTrigger", "Button", "cn", "Separator", "Badge", "e", "PopoverContent", "Calendar", "__name", "import_react_icons", "import_lucide_react", "import_jsx_runtime", "TableFilterDropdown", "column", "title", "options", "align", "facets", "selectedValues", "Popover", "PopoverTrigger", "Button", "cn", "Separator", "Badge", "option", "e", "PopoverContent", "Command", "CommandInput", "CommandList", "CommandEmpty", "CommandGroup", "isSelected", "CommandItem", "filterValues", "CommandSeparator", "__name", "import_lucide_react", "import_jsx_runtime", "TableFilterSearchColumn", "column", "title", "align", "selectedValue", "Popover", "PopoverTrigger", "Button", "e", "cn", "PopoverContent", "Input", "Separator", "__name", "import_react_icons", "import_react", "import_jsx_runtime", "CheckAll", "table", "children", "options", "ref", "Checkbox", "value", "DropdownMenu", "DropdownMenuTrigger", "Button", "DropdownMenuContent", "DropdownMenuLabel", "DropdownMenuSeparator", "option", "key", "DropdownMenuItem", "import_react_icons", "import_jsx_runtime", "Pagination", "__name", "table", "Select", "value", "SelectTrigger", "SelectValue", "SelectContent", "pageSize", "SelectItem", "Button", "import_react_icons", "import_jsx_runtime", "SortAction", "__name", "column", "cn", "import_react_dropdown_menu", "import_react_icons", "import_react", "import_jsx_runtime", "DataTableViewOptions", "__name", "table", "columns", "column", "DropdownMenu", "Button", "DropdownMenuContent", "DropdownMenuLabel", "DropdownMenuSeparator", "DropdownMenuCheckboxItem", "value", "import_jsx_runtime", "DataTableToolbar", "table", "DataTableViewOptions", "__name", "import_react", "import_jsx_runtime", "DeleteAction", "row", "resource", "title", "disabled", "onAfterHandle", "props", "can", "reason", "useDeleteHelper", "deleteContext", "DeleteContext", "RowAction", "__name", "import_jsx_runtime", "Table", "children", "showHeader", "columns", "props", "mapColumn", "id", "accessorKey", "header", "enableSorting", "enableHiding", "filter", "cell", "column", "value", "table", "tableOptions", "isFilterable", "DeleteProvider", "DataTableToolbar", "TableHeader", "headerGroup", "TableRow", "columnDef", "TableHead", "SortAction", "TableBody", "TableCell", "loader_default", "row", "Pagination", "__name", "TableColumn", "CheckAll", "RowActions", "RowAction", "EditAction", "ShowAction", "DeleteAction", "TableFilterDateRangePickerFilter", "TableFilterDropdown", "TableFilterSearchColumn"]
}
 \ No newline at end of file +"use strict";var e,r=Object.create,a=Object.defineProperty,t=Object.getOwnPropertyDescriptor,s=Object.getOwnPropertyNames,i=Object.getPrototypeOf,l=Object.prototype.hasOwnProperty,n=(e,r)=>a(e,"name",{value:r,configurable:!0}),o=(e,r,i,n)=>{if(r&&"object"==typeof r||"function"==typeof r)for(let o of s(r))!l.call(e,o)&&o!==i&&a(e,o,{get:()=>r[o],enumerable:!(n=t(r,o))||n.enumerable});return e},d=(e,t,s)=>(s=null!=e?r(i(e)):{},o(!t&&e&&e.__esModule?s:a(s,"default",{value:e,enumerable:!0}),e)),c={};((e,r)=>{for(var t in r)a(e,t,{get:r[t],enumerable:!0})})(c,{BaseLayout:()=>ws,Breadcrumbs:()=>ee,CloneButton:()=>k,Combobox:()=>Xa,ConfirmDialog:()=>et,CreateButton:()=>D,CreatePage:()=>ss,DefaultLayout:()=>Ls,DeleteActionModal:()=>ei,DeleteButton:()=>wt,DeleteContext:()=>ri,DeleteProvider:()=>ai,EditButton:()=>kt,EditPage:()=>os,ExportButton:()=>Tt,Field:()=>tt,Form:()=>nt,ImportButton:()=>At,Link:()=>J,ListButton:()=>Vt,ListPage:()=>ms,ModeToggle:()=>ut,PageHeader:()=>xt,RefreshButton:()=>Ut,SaveButton:()=>Xt,Select:()=>ht,ShowButton:()=>es,ShowPage:()=>js,Sidebar:()=>Nt,Table:()=>Ji,notificationProvider:()=>Ms,useNotificationProvider:()=>Os}),module.exports=(e=c,o(a({},"__esModule",{value:!0}),e));var u=require("@radix-ui/react-slot"),m=require("class-variance-authority"),x=d(require("react")),f=require("clsx"),p=require("tailwind-merge");function h(...e){return(0,p.twMerge)((0,f.clsx)(e))}n(h,"cn");var g=require("lucide-react"),j=d(require("react")),b=require("react/jsx-runtime"),v=j.default.forwardRef((({className:e,...r},a)=>(0,b.jsx)(g.RefreshCwIcon,{ref:a,className:h("h-4 w-4 animate-spin",e),...r}))),N=require("react/jsx-runtime"),y=(0,m.cva)("inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50",{variants:{variant:{default:"bg-primary text-primary-foreground shadow hover:bg-primary/90",destructive:"bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90",outline:"border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground",secondary:"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80",ghost:"hover:bg-accent hover:text-accent-foreground",link:"text-primary underline-offset-4 hover:underline"},size:{default:"h-9 px-4 py-2",sm:"h-8 rounded-md px-3 text-xs",lg:"h-10 rounded-md px-8",icon:"h-9 w-9"}},defaultVariants:{variant:"default",size:"default"}}),w=x.forwardRef((({className:e,variant:r,size:a,icon:t=null,loading:s=!1,asChild:i=!1,children:l,disabled:n,...o},d)=>{n=n||s;let c=x.useMemo((()=>x.isValidElement(t)?t:s?(0,N.jsx)(v,{className:"mr-2"}):null),[t,s]);return(0,N.jsx)(i?u.Slot:"button",{className:h(y({variant:r,size:a,className:e})),ref:d,disabled:n,...o,children:"icon"===a?s?(0,N.jsx)(v,{}):l:(0,N.jsxs)(N.Fragment,{children:[c,l]})})}));w.displayName="Button";var C=require("@refinedev/core"),q=require("lucide-react"),S=require("react/jsx-runtime"),k=n((({resource:e,recordItemId:r,hideText:a=!1,accessControl:t,meta:s,onClick:i,children:l,...n})=>{let{to:o,LinkComponent:d,label:c,disabled:u,hidden:m,title:x}=(0,C.useCloneButton)({id:r,resource:e,accessControl:t,meta:s});return m?null:(0,S.jsx)(d,{to:o,replace:!1,onClick:e=>{u?e.preventDefault():i&&(e.preventDefault(),i(e))},children:(0,S.jsx)(w,{disabled:u,title:x,icon:(0,S.jsx)(q.CopyPlus,{className:"mr-2 w-4 h-4"}),...n,children:!a&&(l??c)})})}),"CloneButton");k.displayName="CloneButton";var R=require("@refinedev/core"),I=require("lucide-react"),z=require("react/jsx-runtime"),D=n((({resource:e,hideText:r=!1,accessControl:a,meta:t,onClick:s,children:i,...l})=>{let{hidden:n,disabled:o,label:d,title:c,LinkComponent:u,to:m}=(0,R.useCreateButton)({resource:e,accessControl:a,meta:t});return n?null:(0,z.jsx)(u,{to:m,replace:!1,onClick:e=>{o?e.preventDefault():s&&(e.preventDefault(),s(e))},children:(0,z.jsx)(w,{disabled:o,title:c,icon:(0,z.jsx)(I.SquarePlusIcon,{className:"mr-2 w-4 h-4"}),...l,children:!r&&(i??d)})})}),"CreateButton");D.displayName="CreateButton";var T=require("@refinedev/core"),B=require("lucide-react"),F=d(require("react")),P=require("@radix-ui/react-icons"),L=require("@radix-ui/react-slot"),A=require("react/jsx-runtime"),M=F.forwardRef((({...e},r)=>(0,A.jsx)("nav",{ref:r,"aria-label":"breadcrumb",...e})));M.displayName="Breadcrumb";var O=F.forwardRef((({className:e,...r},a)=>(0,A.jsx)("ol",{ref:a,className:h("flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5",e),...r})));O.displayName="BreadcrumbList";var E=F.forwardRef((({className:e,...r},a)=>(0,A.jsx)("li",{ref:a,className:h("inline-flex items-center gap-1.5",e),...r})));E.displayName="BreadcrumbItem";var V=F.forwardRef((({asChild:e,className:r,...a},t)=>(0,A.jsx)(e?L.Slot:"a",{ref:t,className:h("transition-colors hover:text-foreground",r),...a})));V.displayName="BreadcrumbLink";var _=F.forwardRef((({className:e,...r},a)=>(0,A.jsx)("span",{ref:a,role:"link","aria-disabled":"true","aria-current":"page",className:h("font-normal text-foreground",e),...r})));_.displayName="BreadcrumbPage";var H=n((({children:e,className:r,...a})=>(0,A.jsx)("li",{role:"presentation","aria-hidden":"true",className:h("[&>svg]:size-3.5",r),...a,children:e??(0,A.jsx)(P.ChevronRightIcon,{})})),"BreadcrumbSeparator");H.displayName="BreadcrumbSeparator";var $=n((({className:e,...r})=>(0,A.jsxs)("span",{role:"presentation","aria-hidden":"true",className:h("flex h-9 w-9 items-center justify-center",e),...r,children:[(0,A.jsx)(P.DotsHorizontalIcon,{className:"h-4 w-4"}),(0,A.jsx)("span",{className:"sr-only",children:"More"})]})),"BreadcrumbEllipsis");$.displayName="BreadcrumbElipssis";var U=require("@refinedev/core"),Q=require("react"),G=require("@radix-ui/react-slot"),W=require("@refinedev/core"),K=require("react"),X=require("react/jsx-runtime"),J=(0,K.forwardRef)((({children:e,href:r,title:a,className:t,asChild:s},i)=>{let{Link:l}=(0,W.useRouterContext)(),n=(0,W.useRouterType)(),o=(0,W.useLink)();return(0,X.jsx)(s?G.Slot:"legacy"===n?l:o,{ref:i,to:r,className:t,title:a,children:e})}));J.displayName="Link";var Y=require("lucide-react"),Z=require("react/jsx-runtime"),ee=n((({showHome:e=!0,meta:r})=>{let{breadcrumbs:a}=(0,U.useBreadcrumb)({meta:r}),{hasDashboard:t}=(0,U.useRefineContext)(),{resources:s}=(0,U.useResource)(),i=s[0],l=(0,U.matchResourceFromRoute)("/",s),n=a.map((({label:e,href:r},t)=>(0,Z.jsxs)(Q.Fragment,{children:[(0,Z.jsx)(E,{children:r?(0,Z.jsx)(V,{asChild:!0,href:"#x",children:(0,Z.jsx)(J,{href:r,children:e})}):(0,Z.jsx)(_,{children:e})}),t(0,se.jsx)(ae.Overlay,{className:h("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...r,ref:a})));oe.displayName=ae.Overlay.displayName;var de=te.forwardRef((({className:e,...r},a)=>(0,se.jsxs)(ne,{children:[(0,se.jsx)(oe,{}),(0,se.jsx)(ae.Content,{ref:a,className:h("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",e),...r})]})));de.displayName=ae.Content.displayName;var ce=n((({className:e,...r})=>(0,se.jsx)("div",{className:h("flex flex-col space-y-2 text-center sm:text-left",e),...r})),"AlertDialogHeader");ce.displayName="AlertDialogHeader";var ue=n((({className:e,...r})=>(0,se.jsx)("div",{className:h("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...r})),"AlertDialogFooter");ue.displayName="AlertDialogFooter";var me=te.forwardRef((({className:e,...r},a)=>(0,se.jsx)(ae.Title,{ref:a,className:h("text-lg font-semibold",e),...r})));me.displayName=ae.Title.displayName;var xe=te.forwardRef((({className:e,...r},a)=>(0,se.jsx)(ae.Description,{ref:a,className:h("text-sm text-muted-foreground",e),...r})));xe.displayName=ae.Description.displayName;var fe=te.forwardRef((({className:e,variant:r="default",size:a="default",...t},s)=>(0,se.jsx)(ae.Action,{ref:s,className:h(y({variant:r,size:a}),e),...t})));fe.displayName=ae.Action.displayName;var pe=te.forwardRef((({className:e,variant:r="outline",size:a="default",...t},s)=>(0,se.jsx)(ae.Cancel,{ref:s,className:h(y({variant:r,size:a}),"mt-2 sm:mt-0",e),...t})));pe.displayName=ae.Cancel.displayName;var he=require("class-variance-authority"),ge=require("react/jsx-runtime"),je=(0,he.cva)("inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80",secondary:"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",destructive:"border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80",outline:"text-foreground"}},defaultVariants:{variant:"default"}});function be({className:e,variant:r,...a}){return(0,ge.jsx)("div",{className:h(je({variant:r}),e),...a})}n(be,"Badge");var ve=require("@radix-ui/react-icons"),Ne=require("react-day-picker"),ye=require("react/jsx-runtime");function we({className:e,classNames:r,showOutsideDays:a=!0,...t}){return(0,ye.jsx)(Ne.DayPicker,{showOutsideDays:a,className:h("p-3",e),classNames:{months:"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0",month:"space-y-4",caption:"flex justify-center pt-1 relative items-center",caption_label:"text-sm font-medium",nav:"space-x-1 flex items-center",nav_button:h(y({variant:"outline"}),"h-7 w-7 bg-transparent p-0 opacity-50 hover:opacity-100"),nav_button_previous:"absolute left-1",nav_button_next:"absolute right-1",table:"w-full border-collapse space-y-1",head_row:"flex",head_cell:"text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]",row:"flex w-full mt-2",cell:h("relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected].day-range-end)]:rounded-r-md","range"===t.mode?"[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md":"[&:has([aria-selected])]:rounded-md"),day:h(y({variant:"ghost"}),"h-8 w-8 p-0 font-normal aria-selected:opacity-100"),day_range_start:"day-range-start",day_range_end:"day-range-end",day_selected:"bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground",day_today:"bg-accent text-accent-foreground",day_outside:"day-outside text-muted-foreground opacity-50 aria-selected:bg-accent/50 aria-selected:text-muted-foreground aria-selected:opacity-30",day_disabled:"text-muted-foreground opacity-50",day_range_middle:"aria-selected:bg-accent aria-selected:text-accent-foreground",day_hidden:"invisible",...r},components:{IconLeft:n((()=>(0,ye.jsx)(ve.ChevronLeftIcon,{className:"h-4 w-4"})),"IconLeft"),IconRight:n((()=>(0,ye.jsx)(ve.ChevronRightIcon,{className:"h-4 w-4"})),"IconRight")},...t})}n(we,"Calendar"),we.displayName="Calendar";var Ce=d(require("react")),qe=require("react/jsx-runtime"),Se=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("rounded-xl border bg-card text-card-foreground shadow",e),...r})));Se.displayName="Card";var ke=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("flex flex-col space-y-1.5 p-6",e),...r})));ke.displayName="CardHeader";var Re=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("h3",{ref:a,className:h("font-semibold leading-none tracking-tight",e),...r})));Re.displayName="CardTitle";var Ie=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("p",{ref:a,className:h("text-sm text-muted-foreground",e),...r})));Ie.displayName="CardDescription";var ze=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("p-6 pt-0",e),...r})));ze.displayName="CardContent";var De=Ce.forwardRef((({className:e,...r},a)=>(0,qe.jsx)("div",{ref:a,className:h("flex items-center p-6 pt-0",e),...r})));De.displayName="CardFooter";var Te=d(require("react")),Be=d(require("@radix-ui/react-checkbox")),Fe=require("@radix-ui/react-icons"),Pe=require("react/jsx-runtime"),Le=Te.forwardRef((({className:e,...r},a)=>(0,Pe.jsx)(Be.Root,{ref:a,className:h("peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground",e),...r,children:(0,Pe.jsx)(Be.Indicator,{className:h("flex items-center justify-center text-current"),children:(0,Pe.jsx)(Fe.CheckIcon,{className:"h-4 w-4"})})})));Le.displayName=Be.Root.displayName;var Ae=d(require("react")),Me=require("@radix-ui/react-icons"),Oe=require("cmdk"),Ee=d(require("react")),Ve=d(require("@radix-ui/react-dialog")),_e=require("@radix-ui/react-icons"),He=require("react/jsx-runtime"),$e=Ve.Portal,Ue=Ee.forwardRef((({className:e,...r},a)=>(0,He.jsx)(Ve.Overlay,{ref:a,className:h("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...r})));Ue.displayName=Ve.Overlay.displayName;var Qe=Ee.forwardRef((({className:e,children:r,...a},t)=>(0,He.jsxs)($e,{children:[(0,He.jsx)(Ue,{}),(0,He.jsxs)(Ve.Content,{ref:t,className:h("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",e),...a,children:[r,(0,He.jsxs)(Ve.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground",children:[(0,He.jsx)(_e.Cross2Icon,{className:"h-4 w-4"}),(0,He.jsx)("span",{className:"sr-only",children:"Close"})]})]})]})));Qe.displayName=Ve.Content.displayName;var Ge=n((({className:e,...r})=>(0,He.jsx)("div",{className:h("flex flex-col space-y-1.5 text-center sm:text-left",e),...r})),"DialogHeader");Ge.displayName="DialogHeader";var We=n((({className:e,...r})=>(0,He.jsx)("div",{className:h("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...r})),"DialogFooter");We.displayName="DialogFooter";var Ke=Ee.forwardRef((({className:e,...r},a)=>(0,He.jsx)(Ve.Title,{ref:a,className:h("text-lg font-semibold leading-none tracking-tight",e),...r})));Ke.displayName=Ve.Title.displayName;var Xe=Ee.forwardRef((({className:e,...r},a)=>(0,He.jsx)(Ve.Description,{ref:a,className:h("text-sm text-muted-foreground",e),...r})));Xe.displayName=Ve.Description.displayName;var Je=require("react/jsx-runtime"),Ye=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command,{ref:a,className:h("flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",e),...r})));Ye.displayName=Oe.Command.displayName;var Ze=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsxs)("div",{className:"flex items-center border-b px-3","cmdk-input-wrapper":"",children:[(0,Je.jsx)(Me.MagnifyingGlassIcon,{className:"mr-2 h-4 w-4 shrink-0 opacity-50"}),(0,Je.jsx)(Oe.Command.Input,{ref:a,className:h("flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50",e),...r})]})));Ze.displayName=Oe.Command.Input.displayName;var er=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.List,{ref:a,className:h("max-h-[300px] overflow-y-auto overflow-x-hidden",e),...r})));er.displayName=Oe.Command.List.displayName;var rr=Ae.forwardRef(((e,r)=>(0,Je.jsx)(Oe.Command.Empty,{ref:r,className:"py-6 text-center text-sm",...e})));rr.displayName=Oe.Command.Empty.displayName;var ar=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.Group,{ref:a,className:h("overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",e),...r})));ar.displayName=Oe.Command.Group.displayName;var tr=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.Separator,{ref:a,className:h("-mx-1 h-px bg-border",e),...r})));tr.displayName=Oe.Command.Separator.displayName;var sr=Ae.forwardRef((({className:e,...r},a)=>(0,Je.jsx)(Oe.Command.Item,{ref:a,className:h("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50",e),...r})));sr.displayName=Oe.Command.Item.displayName;var ir=n((({className:e,...r})=>(0,Je.jsx)("span",{className:h("ml-auto text-xs tracking-widest text-muted-foreground",e),...r})),"CommandShortcut");ir.displayName="CommandShortcut";var lr=d(require("react")),nr=d(require("@radix-ui/react-dropdown-menu")),or=require("@radix-ui/react-icons"),dr=require("react/jsx-runtime"),cr=nr.Root,ur=nr.Trigger,mr=lr.forwardRef((({className:e,inset:r,children:a,...t},s)=>(0,dr.jsxs)(nr.SubTrigger,{ref:s,className:h("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent",r&&"pl-8",e),...t,children:[a,(0,dr.jsx)(or.ChevronRightIcon,{className:"ml-auto h-4 w-4"})]})));mr.displayName=nr.SubTrigger.displayName;var xr=lr.forwardRef((({className:e,...r},a)=>(0,dr.jsx)(nr.SubContent,{ref:a,className:h("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg 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",e),...r})));xr.displayName=nr.SubContent.displayName;var fr=lr.forwardRef((({className:e,sideOffset:r=4,...a},t)=>(0,dr.jsx)(nr.Portal,{children:(0,dr.jsx)(nr.Content,{ref:t,sideOffset:r,className:h("z-50 min-w-[8rem] overflow-hidden rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md","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",e),...a})})));fr.displayName=nr.Content.displayName;var pr=lr.forwardRef((({className:e,inset:r,...a},t)=>(0,dr.jsx)(nr.Item,{ref:t,className:h("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",r&&"pl-8",e),...a})));pr.displayName=nr.Item.displayName;var hr=lr.forwardRef((({className:e,children:r,checked:a,...t},s)=>(0,dr.jsxs)(nr.CheckboxItem,{ref:s,className:h("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:a,...t,children:[(0,dr.jsx)("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:(0,dr.jsx)(nr.ItemIndicator,{children:(0,dr.jsx)(or.CheckIcon,{className:"h-4 w-4"})})}),r]})));hr.displayName=nr.CheckboxItem.displayName;var gr=lr.forwardRef((({className:e,children:r,...a},t)=>(0,dr.jsxs)(nr.RadioItem,{ref:t,className:h("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...a,children:[(0,dr.jsx)("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:(0,dr.jsx)(nr.ItemIndicator,{children:(0,dr.jsx)(or.DotFilledIcon,{className:"h-4 w-4 fill-current"})})}),r]})));gr.displayName=nr.RadioItem.displayName;var jr=lr.forwardRef((({className:e,inset:r,...a},t)=>(0,dr.jsx)(nr.Label,{ref:t,className:h("px-2 py-1.5 text-sm font-semibold",r&&"pl-8",e),...a})));jr.displayName=nr.Label.displayName;var br=lr.forwardRef((({className:e,...r},a)=>(0,dr.jsx)(nr.Separator,{ref:a,className:h("-mx-1 my-1 h-px bg-muted",e),...r})));br.displayName=nr.Separator.displayName;var vr=n((({className:e,...r})=>(0,dr.jsx)("span",{className:h("ml-auto text-xs tracking-widest opacity-60",e),...r})),"DropdownMenuShortcut");vr.displayName="DropdownMenuShortcut";var Nr=d(require("react")),yr=require("@radix-ui/react-slot"),wr=require("react-hook-form"),Cr=d(require("react")),qr=d(require("@radix-ui/react-label")),Sr=require("class-variance-authority"),kr=require("react/jsx-runtime"),Rr=(0,Sr.cva)("text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"),Ir=Cr.forwardRef((({className:e,...r},a)=>(0,kr.jsx)(qr.Root,{ref:a,className:h(Rr(),e),...r})));Ir.displayName=qr.Root.displayName;var zr=require("react/jsx-runtime"),Dr=wr.FormProvider,Tr=Nr.createContext({}),Br=n((({...e})=>(0,zr.jsx)(Tr.Provider,{value:{name:e.name},children:(0,zr.jsx)(wr.Controller,{...e})})),"FormField"),Fr=n((()=>{let e=Nr.useContext(Tr),r=Nr.useContext(Pr),{getFieldState:a,formState:t}=(0,wr.useFormContext)(),s=a(e.name,t);if(!e)throw new Error("useFormField should be used within ");let{id:i}=r;return{id:i,name:e.name,formItemId:`${i}-form-item`,formDescriptionId:`${i}-form-item-description`,formMessageId:`${i}-form-item-message`,...s}}),"useFormField"),Pr=Nr.createContext({}),Lr=Nr.forwardRef((({className:e,...r},a)=>{let t=Nr.useId();return(0,zr.jsx)(Pr.Provider,{value:{id:t},children:(0,zr.jsx)("div",{ref:a,className:h("space-y-2",e),...r})})}));Lr.displayName="FormItem";var Ar=Nr.forwardRef((({className:e,...r},a)=>{let{error:t,formItemId:s}=Fr();return(0,zr.jsx)(Ir,{ref:a,className:h(t&&"text-destructive",e),htmlFor:s,...r})}));Ar.displayName="FormLabel";var Mr=Nr.forwardRef((({...e},r)=>{let{error:a,formItemId:t,formDescriptionId:s,formMessageId:i}=Fr();return(0,zr.jsx)(yr.Slot,{ref:r,id:t,"aria-describedby":a?`${s} ${i}`:`${s}`,"aria-invalid":!!a,...e})}));Mr.displayName="FormControl";var Or=Nr.forwardRef((({className:e,...r},a)=>{let{formDescriptionId:t}=Fr();return(0,zr.jsx)("p",{ref:a,id:t,className:h("text-[0.8rem] text-muted-foreground",e),...r})}));Or.displayName="FormDescription";var Er=Nr.forwardRef((({className:e,children:r,...a},t)=>{let{error:s,formMessageId:i}=Fr(),l=s?String(s?.message):r;return l?(0,zr.jsx)("p",{ref:t,id:i,className:h("text-[0.8rem] font-medium text-destructive",e),...a,children:l}):null}));Er.displayName="FormMessage";var Vr=d(require("react")),_r=require("react/jsx-runtime"),Hr=Vr.forwardRef((({className:e,type:r,...a},t)=>(0,_r.jsx)("input",{type:r,className:h("flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",e),ref:t,...a})));Hr.displayName="Input";var $r=d(require("react")),Ur=d(require("@radix-ui/react-popover")),Qr=require("react/jsx-runtime"),Gr=Ur.Root,Wr=Ur.Trigger,Kr=$r.forwardRef((({className:e,align:r="center",sideOffset:a=4,...t},s)=>(0,Qr.jsx)(Ur.Portal,{children:(0,Qr.jsx)(Ur.Content,{ref:s,align:r,sideOffset:a,className:h("z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none 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",e),...t})})));Kr.displayName=Ur.Content.displayName;var Xr=require("@radix-ui/react-icons"),Jr=d(require("react-resizable-panels")),Yr=require("react/jsx-runtime"),Zr=n((({className:e,...r})=>(0,Yr.jsx)(Jr.PanelGroup,{className:h("flex h-full w-full data-[panel-group-direction=vertical]:flex-col",e),...r})),"ResizablePanelGroup"),ea=Jr.Panel,ra=n((({withHandle:e,className:r,...a})=>(0,Yr.jsx)(Jr.PanelResizeHandle,{className:h("relative flex w-px items-center justify-center bg-border after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring focus-visible:ring-offset-1 data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:-translate-y-1/2 data-[panel-group-direction=vertical]:after:translate-x-0 [&[data-panel-group-direction=vertical]>div]:rotate-90",r),...a,children:e&&(0,Yr.jsx)("div",{className:"z-10 flex h-4 w-3 items-center justify-center rounded-sm border bg-border",children:(0,Yr.jsx)(Xr.DragHandleDots2Icon,{className:"h-2.5 w-2.5"})})})),"ResizableHandle"),aa=d(require("react")),ta=d(require("@radix-ui/react-scroll-area")),sa=require("react/jsx-runtime"),ia=aa.forwardRef((({className:e,children:r,...a},t)=>(0,sa.jsxs)(ta.Root,{ref:t,className:h("relative overflow-hidden",e),...a,children:[(0,sa.jsx)(ta.Viewport,{className:"h-full w-full rounded-[inherit]",children:r}),(0,sa.jsx)(la,{}),(0,sa.jsx)(ta.Corner,{})]})));ia.displayName=ta.Root.displayName;var la=aa.forwardRef((({className:e,orientation:r="vertical",...a},t)=>(0,sa.jsx)(ta.ScrollAreaScrollbar,{ref:t,orientation:r,className:h("flex touch-none select-none transition-colors","vertical"===r&&"h-full w-2.5 border-l border-l-transparent p-[1px]","horizontal"===r&&"h-2.5 flex-col border-t border-t-transparent p-[1px]",e),...a,children:(0,sa.jsx)(ta.ScrollAreaThumb,{className:"relative flex-1 rounded-full bg-border"})})));la.displayName=ta.ScrollAreaScrollbar.displayName;var na=d(require("react")),oa=require("@radix-ui/react-icons"),da=d(require("@radix-ui/react-select")),ca=require("react/jsx-runtime"),ua=da.Root,ma=da.Value,xa=na.forwardRef((({className:e,children:r,...a},t)=>(0,ca.jsxs)(da.Trigger,{ref:t,className:h("flex h-9 w-full items-center justify-between whitespace-nowrap rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-1 focus:ring-ring disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1",e),...a,children:[r,(0,ca.jsx)(da.Icon,{asChild:!0,children:(0,ca.jsx)(oa.CaretSortIcon,{className:"h-4 w-4 opacity-50"})})]})));xa.displayName=da.Trigger.displayName;var fa=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.ScrollUpButton,{ref:a,className:h("flex cursor-default items-center justify-center py-1",e),...r,children:(0,ca.jsx)(oa.ChevronUpIcon,{})})));fa.displayName=da.ScrollUpButton.displayName;var pa=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.ScrollDownButton,{ref:a,className:h("flex cursor-default items-center justify-center py-1",e),...r,children:(0,ca.jsx)(oa.ChevronDownIcon,{})})));pa.displayName=da.ScrollDownButton.displayName;var ha=na.forwardRef((({className:e,children:r,position:a="popper",...t},s)=>(0,ca.jsx)(da.Portal,{children:(0,ca.jsxs)(da.Content,{ref:s,className:h("relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md 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","popper"===a&&"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,...t,children:[(0,ca.jsx)(fa,{}),(0,ca.jsx)(da.Viewport,{className:h("p-1","popper"===a&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]"),children:r}),(0,ca.jsx)(pa,{})]})})));ha.displayName=da.Content.displayName;var ga=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.Label,{ref:a,className:h("px-2 py-1.5 text-sm font-semibold",e),...r})));ga.displayName=da.Label.displayName;var ja=na.forwardRef((({className:e,children:r,...a},t)=>(0,ca.jsxs)(da.Item,{ref:t,className:h("relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...a,children:[(0,ca.jsx)("span",{className:"absolute right-2 flex h-3.5 w-3.5 items-center justify-center",children:(0,ca.jsx)(da.ItemIndicator,{children:(0,ca.jsx)(oa.CheckIcon,{className:"h-4 w-4"})})}),(0,ca.jsx)(da.ItemText,{children:r})]})));ja.displayName=da.Item.displayName;var ba=na.forwardRef((({className:e,...r},a)=>(0,ca.jsx)(da.Separator,{ref:a,className:h("-mx-1 my-1 h-px bg-muted",e),...r})));ba.displayName=da.Separator.displayName;var va=d(require("react")),Na=d(require("@radix-ui/react-separator")),ya=require("react/jsx-runtime"),wa=va.forwardRef((({className:e,orientation:r="horizontal",decorative:a=!0,...t},s)=>(0,ya.jsx)(Na.Root,{ref:s,decorative:a,orientation:r,className:h("shrink-0 bg-border","horizontal"===r?"h-[1px] w-full":"h-full w-[1px]",e),...t})));wa.displayName=Na.Root.displayName;var Ca=require("next-themes"),qa=require("sonner"),Sa=require("react/jsx-runtime"),ka=n((({...e})=>{let{theme:r="system"}=(0,Ca.useTheme)();return(0,Sa.jsx)(qa.Toaster,{theme:r,className:"toaster group",toastOptions:{classNames:{toast:"group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg",description:"group-[.toast]:text-muted-foreground",actionButton:"group-[.toast]:bg-primary group-[.toast]:text-primary-foreground",cancelButton:"group-[.toast]:bg-muted group-[.toast]:text-muted-foreground"}},...e})}),"Toaster"),Ra=d(require("react")),Ia=require("react/jsx-runtime"),za=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("div",{className:"relative w-full overflow-auto",children:(0,Ia.jsx)("table",{ref:a,className:h("w-full caption-bottom text-sm",e),...r})})));za.displayName="Table";var Da=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("thead",{ref:a,className:h("[&_tr]:border-b",e),...r})));Da.displayName="TableHeader";var Ta=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("tbody",{ref:a,className:h("[&_tr:last-child]:border-0",e),...r})));Ta.displayName="TableBody";var Ba=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("tfoot",{ref:a,className:h("border-t bg-muted/50 font-medium [&>tr]:last:border-b-0",e),...r})));Ba.displayName="TableFooter";var Fa=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("tr",{ref:a,className:h("border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted",e),...r})));Fa.displayName="TableRow";var Pa=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("th",{ref:a,className:h("h-10 px-2 text-left align-middle font-medium text-muted-foreground [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",e),...r})));Pa.displayName="TableHead";var La=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("td",{ref:a,className:h("p-2 align-middle [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]",e),...r})));La.displayName="TableCell";var Aa=Ra.forwardRef((({className:e,...r},a)=>(0,Ia.jsx)("caption",{ref:a,className:h("mt-4 text-sm text-muted-foreground",e),...r})));Aa.displayName="TableCaption";var Ma=d(require("react")),Oa=require("react/jsx-runtime"),Ea=Ma.forwardRef((({className:e,...r},a)=>(0,Oa.jsx)("textarea",{className:h("flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",e),ref:a,...r})));Ea.displayName="Textarea";var Va=d(require("react")),_a=d(require("@radix-ui/react-tooltip")),Ha=require("react/jsx-runtime"),$a=_a.Provider,Ua=_a.Root,Qa=_a.Trigger,Ga=Va.forwardRef((({className:e,sideOffset:r=4,...a},t)=>(0,Ha.jsx)(_a.Content,{ref:t,sideOffset:r,className:h("z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs 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",e),...a})));Ga.displayName=_a.Content.displayName;var Wa=require("react"),Ka=require("react/jsx-runtime"),Xa=(0,Wa.forwardRef)((({...e},r)=>{let[a,t]=(0,Wa.useState)(!1),s=n((()=>"object"==typeof e.value&&"id"in e.value?e.value.id:e.value),"value");return(0,Ka.jsxs)(Gr,{open:a,onOpenChange:t,children:[(0,Ka.jsx)(Wr,{asChild:!0,children:(0,Ka.jsx)(Mr,{children:(0,Ka.jsxs)(w,{disabled:e.disabled,variant:"outline",role:"combobox","aria-expanded":a,className:h("w-full sm:w-[250px] flex justify-between",!s()&&"text-muted-foreground"),children:[s()?e.options?.find((e=>e.value===s()))?.label:e.placeholder??"Select",(0,Ka.jsx)(re.CaretSortIcon,{className:"ml-2 h-4 w-4 shrink-0 opacity-50"})]})})}),(0,Ka.jsx)(Kr,{className:"w-full max-w-full sm:w-[250px] p-0",children:(0,Ka.jsxs)(Ye,{className:"rounded-lg border shadow-md",ref:r,children:[(0,Ka.jsx)(Ze,{placeholder:"Type a command or search..."}),(0,Ka.jsxs)(er,{children:[(0,Ka.jsx)(rr,{children:"No results found."}),(0,Ka.jsx)(ar,{heading:"Suggestions",children:(0,Ka.jsx)(ia,{className:"max-h-52 overflow-y-auto",children:e.options?.map((r=>(0,Ka.jsxs)(sr,{value:r.label,onSelect:()=>{e.onChange?.(r.value),t(!1)},children:[r.label,(0,Ka.jsx)(re.CheckIcon,{className:h("ml-auto h-4 w-4",r.value===s()?"opacity-100":"opacity-0")})]},r.value)))})})]})]})})]})}));Xa.displayName="Combobox";var Ja=require("lucide-react"),Ya=require("react"),Za=require("react/jsx-runtime"),et=n((({children:e,title:r="Are you sure?",description:a="This action cannot be undone.",okText:t="Ok",cancelText:s="Cancel",okButtonSize:i="default",cancelButtonSize:l="default",okButtonVariant:n="default",cancelButtonVariant:o="outline",loading:d=!1,okIconSide:c="left",cancelIconSide:u="left",onConfirm:m,okIcon:x,cancelIcon:f,open:p,onOpenChange:h,defaultOpen:g})=>{let j=(0,Ya.useMemo)((()=>(0,Ya.isValidElement)(f)?f:(0,Za.jsx)(Ja.XIcon,{className:"mr-2 h-4 w-4"})),[f]),b=(0,Ya.useMemo)((()=>d?(0,Za.jsx)(v,{className:"mr-2"}):(0,Ya.isValidElement)(x)?x:(0,Za.jsx)(Ja.CheckIcon,{className:"mr-2 h-4 w-4"})),[x,d]);return(0,Za.jsxs)(ie,{open:p,onOpenChange:h,defaultOpen:g,children:[(0,Za.jsx)(le,{asChild:!0,children:e}),(0,Za.jsxs)(de,{children:[(0,Za.jsxs)(ce,{children:[(0,Za.jsx)(me,{children:r}),(0,Za.jsx)(xe,{children:a})]}),(0,Za.jsxs)(ue,{children:[(0,Za.jsxs)(pe,{variant:o,size:l,disabled:d,children:["left"===u&&j,s,"right"===u&&j]}),(0,Za.jsxs)(fe,{variant:n,size:i,disabled:d,onClick:m,children:["left"===c&&b,t,"right"===c&&b]})]})]})]})}),"ConfirmDialog");et.displayName="ConfirmDialog";var rt=require("react"),at=require("react/jsx-runtime"),tt=n((e=>(0,at.jsx)(Br,{control:e.control,name:e.name,render:({field:r})=>(0,at.jsxs)(Lr,{className:h(e.className,e.isCheckbox?"flex flex-row items-center space-x-3 space-y-0":""),children:[!e.isCheckbox&&(0,at.jsx)(Ar,{children:e.label}),(0,at.jsx)(Mr,{children:(0,rt.cloneElement)(e.children,{...r,...e.children.props})}),e.isCheckbox&&(0,at.jsx)(Ar,{className:"text-sm font-normal",children:e.label}),e.description&&(0,at.jsx)(Or,{children:e.description}),(0,at.jsx)(Er,{})]})})),"Field"),st=require("@refinedev/core"),it=require("react"),lt=require("react/jsx-runtime"),nt=n((({formProps:e,isWatchable:r,saveButtonProps:a,...t})=>{let s=(0,it.useRef)(!1),{resource:i,action:l}=(0,st.useParsed)(),n=(0,st.useRouterType)(),o=(0,st.useBack)(),{goBack:d}=(0,st.useNavigation)(),c="list"!==l||typeof l<"u"?"legacy"===n?d:o:void 0;r&&!s.current&&(s.current=!0,t.watch());let u=t.handleSubmit((e=>{t.refineCore.onFinish(t.getValues()).then()}));return(0,lt.jsx)(Dr,{...t,children:(0,lt.jsx)("form",{...e,onSubmit:u,children:(0,lt.jsxs)(Se,{className:"border-border/40 shadow-sm",children:[(0,lt.jsx)(ze,{className:"pt-6 space-y-4",children:t.children}),(0,lt.jsxs)(De,{className:"flex justify-end gap-x-4",children:[(0,lt.jsx)(w,{type:"button",onClick:c,disabled:t.refineCore.formLoading,variant:"outline",children:"Cancel"}),(0,lt.jsx)(Xt,{type:"submit",loading:t.refineCore.formLoading,...a})]})]})})})}),"Form"),ot=require("next-themes"),dt=require("@radix-ui/react-icons"),ct=require("react/jsx-runtime"),ut=n((()=>{let{setTheme:e}=(0,ot.useTheme)();return(0,ct.jsxs)(cr,{children:[(0,ct.jsx)(ur,{asChild:!0,children:(0,ct.jsxs)(w,{variant:"ghost",size:"icon",children:[(0,ct.jsx)(dt.SunIcon,{className:"h-[1.2rem] w-[1.2rem] rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0"}),(0,ct.jsx)(dt.MoonIcon,{className:"absolute h-[1.2rem] w-[1.2rem] rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100"}),(0,ct.jsx)("span",{className:"sr-only",children:"Toggle theme"})]})}),(0,ct.jsxs)(fr,{align:"end",children:[(0,ct.jsx)(pr,{onClick:()=>e("light"),children:"Light"}),(0,ct.jsx)(pr,{onClick:()=>e("dark"),children:"Dark"}),(0,ct.jsx)(pr,{onClick:()=>e("system"),children:"System"})]})]})}),"ModeToggle"),mt=require("react/jsx-runtime"),xt=n((({extra:e,...r})=>(0,mt.jsx)("div",{className:"w-full",children:(0,mt.jsxs)("div",{className:h("flex h-20 items-end lg:justify-between",r.className,!r.breadcrumb&&"h-auto"),children:[(0,mt.jsxs)("div",{className:"min-w-0 flex-1",children:[r.breadcrumb,(0,mt.jsx)("div",{className:"inline-flex flex-row items-center gap-x-4 mt-3",children:(0,mt.jsxs)("div",{className:"inline-flex flex-col",children:[(0,mt.jsx)("h2",{className:"text-2xl font-bold leading-7 text-black dark:text-white sm:truncate sm:text-3xl sm:tracking-tight",children:r.title}),r.subTitle&&(0,mt.jsx)("div",{className:"mt-2 flex items-center text-sm text-gray-300",children:r.subTitle})]})})]}),(0,mt.jsx)("div",{className:"flex lg:ml-4 lg:mt-0",children:e})]})})),"PageHeader"),ft=d(require("react")),pt=require("react/jsx-runtime"),ht=(0,ft.forwardRef)((({...e},r)=>{let a=ft.default.useRef(null);return(0,pt.jsxs)(ua,{disabled:e.disabled||0===e.options?.length,onValueChange:e.onChange,defaultValue:e.value,value:e.value,children:[(0,pt.jsx)(Mr,{children:(0,pt.jsx)(xa,{ref:a,children:(0,pt.jsx)(ma,{placeholder:e.placeholder??"Select"})})}),(0,pt.jsx)(ha,{style:{width:a.current?.offsetWidth},ref:r,children:e.options?.map(((e,r)=>(0,pt.jsx)(ja,{value:e.value,children:e.label},r)))})]})}));ht.displayName="Select";var gt=require("@refinedev/core"),jt=require("react-use"),bt=d(require("react")),vt=require("react/jsx-runtime"),Nt=n((({isCollapsed:e})=>{let{menuItems:r}=(0,gt.useMenu)(),a=(0,gt.useResourceParams)(),{pathname:t}=(0,jt.useLocation)(),s=String(t),i=n((e=>{let r=e.meta?.icon;return bt.default.isValidElement(r)?bt.default.cloneElement(r,{className:"mr-2 w-4 h-4"}):null}),"GetIcon");return(0,vt.jsx)("div",{"data-collapsed":e,className:"group flex flex-col gap-4 py-2 justify-between h-[94dvh] xl:h-[84dvh] data-[collapsed=true]:py-2",children:(0,vt.jsx)("nav",{className:"grid gap-1 px-2 group-[[data-collapsed=true]]:justify-center group-[[data-collapsed=true]]:px-2",children:r.filter((e=>!e.meta?.hide)).map(((r,t)=>{let l=[r.list?.toString(),r.create?.toString(),r.edit?.toString()?.replace(":id",a.id),r.show?.toString()?.replace(":id",a.id)].filter(Boolean),n=l.includes(s)||l.some((e=>e?.startsWith(s)||s.startsWith(e)));return e?(0,vt.jsxs)(Ua,{delayDuration:0,children:[(0,vt.jsx)(Qa,{asChild:!0,children:(0,vt.jsxs)(J,{href:r.list?.toString()??"/#",title:r.meta?.title??r.name,className:h(y({variant:"ghost"}),"justify-start",n?"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground":""),children:[r.meta?.icon,(0,vt.jsxs)("span",{className:"sr-only",children:[r.meta?.title??r.label," ",r.list?"List":"Create"]})]},t)}),(0,vt.jsxs)(Ga,{side:"right",className:"flex items-center gap-4",children:[r.label,r.meta?.label&&(0,vt.jsx)("span",{className:"ml-auto text-muted-foreground",children:r.meta?.label})]})]},t):(0,vt.jsxs)(J,{href:r.list?.toString()??"/#",title:r.meta?.title??r.name,className:h(y({variant:"ghost"}),"justify-start",n?"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground":""),children:[i(r),r.meta?.title??r.name]},t)}))})})}),"Sidebar");Nt.displayName="Sidebar";var yt=require("react/jsx-runtime"),wt=n((({resource:e,recordItemId:r,onSuccess:a,mutationMode:t,confirmTitle:s,confirmDescription:i,successNotification:l,errorNotification:n,hideText:o=!1,accessControl:d,meta:c,dataProviderName:u,confirmOkText:m,confirmCancelText:x,invalidates:f,children:p,...h})=>{let{title:g,label:j,hidden:b,disabled:v,loading:N,confirmTitle:y,confirmOkLabel:C,cancelLabel:q,onConfirm:S}=(0,T.useDeleteButton)({resource:e,id:r,dataProviderName:u,invalidates:f,meta:c,onSuccess:a,mutationMode:t,errorNotification:n,successNotification:l,accessControl:d});return b?null:(0,yt.jsx)(et,{okText:m??C,cancelText:x??q,okButtonVariant:"destructive",cancelButtonVariant:"outline",title:s??y,description:i,loading:N,onConfirm:S,children:(0,yt.jsx)(w,{disabled:v,title:g,loading:N,icon:(0,yt.jsx)(B.Trash2Icon,{className:"mr-2 w-4 h-4"}),...h,children:!o&&(p??j)})})}),"DeleteButton");wt.displayName="DeleteButton";var Ct=require("@refinedev/core"),qt=require("lucide-react"),St=require("react/jsx-runtime"),kt=n((({resource:e,recordItemId:r,hideText:a=!1,accessControl:t,meta:s,onClick:i,children:l,...n})=>{let{hidden:o,disabled:d,label:c,title:u,LinkComponent:m,to:x}=(0,Ct.useEditButton)({resource:e,id:r,accessControl:t,meta:s});return o?null:(0,St.jsx)(m,{to:x,replace:!1,onClick:e=>{d?e.preventDefault():i&&(e.preventDefault(),i(e))},children:(0,St.jsx)(w,{disabled:d,title:u,icon:(0,St.jsx)(qt.SquarePenIcon,{className:"mr-2 w-4 h-4"}),...n,children:!a&&(l??c)})})}),"EditButton");kt.displayName="EditButton";var Rt=require("@radix-ui/react-slot"),It=require("@refinedev/core"),zt=require("lucide-react"),Dt=require("react/jsx-runtime"),Tt=n((({hideText:e=!1,resource:r,recordItemId:a,accessControl:t,access:s,children:i,...l})=>{let{label:n}=(0,It.useExportButton)(),o=t?.enabled?It.CanAccess:Rt.Slot;return t?.hideIfUnauthorized&&t.enabled?null:(0,Dt.jsx)(o,{params:{id:a},resource:r,action:"export",...s,children:(0,Dt.jsx)(w,{icon:(0,Dt.jsx)(zt.ShareIcon,{className:"mr-2 w-4 h-4"}),...l,children:!e&&(i??n)})})}),"ExportButton");Tt.displayName="ExportButton";var Bt=require("@radix-ui/react-slot"),Ft=require("@refinedev/core"),Pt=require("lucide-react"),Lt=require("react/jsx-runtime"),At=n((({hideText:e=!1,resource:r,onChange:a,accept:t="image/*,application/*",recordItemId:s,accessControl:i,access:l,children:o,...d})=>{let{label:c}=(0,Ft.useImportButton)(),u=i?.enabled?Ft.CanAccess:Bt.Slot,m=n((()=>{let e=document.createElement("input");e.type="file",e.accept=t,e.onchange=r=>{r.target instanceof HTMLInputElement&&(a(Array.from(r.target.files??[])),e.remove())},e.click()}),"onClick");return i?.hideIfUnauthorized&&i.enabled?null:(0,Lt.jsx)(u,{params:{id:s},resource:r,action:"import",...l,children:(0,Lt.jsx)(w,{onClick:m,icon:(0,Lt.jsx)(Pt.ImportIcon,{className:"mr-2 w-4 h-4"}),...d,children:!e&&(o??c)})})}),"ImportButton");At.displayName="ImportButton";var Mt=require("@refinedev/core"),Ot=require("lucide-react"),Et=require("react/jsx-runtime"),Vt=n((({resource:e,hideText:r=!1,accessControl:a,meta:t,children:s,onClick:i,...l})=>{let{hidden:n,disabled:o,label:d,title:c,LinkComponent:u,to:m}=(0,Mt.useListButton)({resource:e,accessControl:a,meta:t});return n?null:(0,Et.jsx)(u,{to:m,replace:!1,onClick:e=>{o?e.preventDefault():i&&(e.preventDefault(),i(e))},children:(0,Et.jsx)(w,{disabled:o,title:c,icon:(0,Et.jsx)(Ot.ListIcon,{className:"mr-2 w-4 h-4"}),...l,children:!r&&(s??d)})})}),"ListButton");Vt.displayName="ListButton";var _t=require("@refinedev/core"),Ht=require("lucide-react"),$t=require("react/jsx-runtime"),Ut=n((({resource:e,recordItemId:r,hideText:a=!1,dataProviderName:t,children:s,...i})=>{let{onClick:l,label:n,loading:o}=(0,_t.useRefreshButton)({resource:e,id:r,dataProviderName:t});return(0,$t.jsx)(w,{onClick:l,loading:o,icon:(0,$t.jsx)(Ht.RefreshCwIcon,{className:"mr-2 w-4 h-4"}),...i,children:!a&&(s??n)})}),"RefreshButton");Ut.displayName="RefreshButton";var Qt=require("@radix-ui/react-slot"),Gt=require("@refinedev/core"),Wt=require("lucide-react"),Kt=require("react/jsx-runtime"),Xt=n((({hideText:e=!1,children:r,accessControl:a,access:t,resource:s,recordItemId:i,...l})=>{let{label:n}=(0,Gt.useSaveButton)(),o=a?.enabled?Gt.CanAccess:Qt.Slot;return a?.hideIfUnauthorized&&a.enabled?null:(0,Kt.jsx)(o,{params:{id:i},resource:s,action:"save",...t,children:(0,Kt.jsx)(w,{icon:(0,Kt.jsx)(Wt.SaveIcon,{className:"mr-2 w-4 h-4"}),...l,children:!e&&(r??n)})})}),"SaveButton");Xt.displayName="SaveButton";var Jt=require("@refinedev/core"),Yt=require("lucide-react"),Zt=require("react/jsx-runtime"),es=n((({resource:e,recordItemId:r,hideText:a=!1,accessControl:t,meta:s,children:i,onClick:l,...n})=>{let{to:o,label:d,title:c,hidden:u,disabled:m,LinkComponent:x}=(0,Jt.useShowButton)({resource:e,id:r,accessControl:t,meta:s});return u?null:(0,Zt.jsx)(x,{to:o,replace:!1,onClick:e=>{m?e.preventDefault():l&&(e.preventDefault(),l(e))},children:(0,Zt.jsx)(w,{icon:(0,Zt.jsx)(Yt.EyeIcon,{className:"mr-2 w-4 h-4"}),title:c,disabled:m,...n,children:!a&&(i??d)})})}),"ShowButton");es.displayName="ShowButton";var rs=require("@refinedev/core"),as=require("react"),ts=require("react/jsx-runtime"),ss=n((({title:e,resource:r,breadcrumb:a,extra:t,children:s})=>{let i=(0,rs.useTranslate)(),{options:{breadcrumb:l}={}}=(0,rs.useRefineContext)(),n=(0,rs.useUserFriendlyName)(),{resource:o,identifier:d}=(0,rs.useResource)(r),c=typeof a>"u"?l:a;return(0,ts.jsxs)(ts.Fragment,{children:[(0,ts.jsx)(xt,{title:e??i(`${d}.titles.List`,`Create ${n(o?.meta?.label??d,"singular")}`),isBack:!0,breadcrumb:(0,as.isValidElement)(c)?c:(0,ts.jsx)(ee,{}),extra:t??(0,ts.jsx)(ts.Fragment,{children:(0,ts.jsx)(Vt,{resource:r})})}),(0,ts.jsx)("div",{className:"pt-4 !mt-0",children:s})]})}),"CreatePage");ss.displayName="CreatePage";var is=require("@refinedev/core"),ls=require("react"),ns=require("react/jsx-runtime"),os=n((({title:e,resource:r,extra:a,breadcrumb:t,children:s})=>{let i=(0,is.useTranslate)(),{options:{breadcrumb:l}={}}=(0,is.useRefineContext)(),{list:n}=(0,is.useNavigation)(),o=(0,is.useUserFriendlyName)(),{resource:d,identifier:c}=(0,is.useResource)(r),u=typeof t>"u"?l:t;return(0,ns.jsxs)(ns.Fragment,{children:[(0,ns.jsx)(xt,{title:e??i(`${c}.titles.List`,`Edit ${o(d?.meta?.label??c,"plural")}`),isBack:!0,breadcrumb:(0,ls.isValidElement)(u)?u:(0,ns.jsx)(ee,{}),extra:a??(0,ns.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-2",children:[(0,ns.jsx)(es,{resource:r}),(0,ns.jsx)(wt,{resource:r,onSuccess:()=>{n(d?.name)}})]})}),(0,ns.jsx)("div",{className:"pt-4",children:s})]})}),"EditPage");os.displayName="EditPage";var ds=require("@refinedev/core"),cs=require("react"),us=require("react/jsx-runtime"),ms=n((({title:e,resource:r,breadcrumb:a,createButtonProps:t,className:s,isCreate:i=!0,extra:l,children:n})=>{let o=(0,ds.useTranslate)(),{options:{breadcrumb:d}={}}=(0,ds.useRefineContext)(),c=(0,ds.useUserFriendlyName)(),{resource:u,identifier:m}=(0,ds.useResource)(r),x=typeof a>"u"?d:a;return(0,us.jsxs)(us.Fragment,{children:[(0,us.jsx)(xt,{title:e??o(`${m}.titles.List`,`List ${c(u?.meta?.label??m,"plural")}`),breadcrumb:(0,cs.isValidElement)(x)?x:(0,us.jsx)(ee,{}),extra:l??(0,us.jsx)(us.Fragment,{children:(0,us.jsx)("div",{className:"inline-flex flex-row gap-4",children:i&&(0,us.jsx)(D,{...t,resource:t?.resource??m})})})}),(0,us.jsx)("div",{className:h("pt-2 sm:pt-4 !mt-0",s),children:n})]})}),"ListPage");ms.displayName="ListPage";var xs=require("@refinedev/core"),fs=require("react"),ps=require("react/jsx-runtime"),hs=n((({title:e,children:r})=>(0,ps.jsx)(ps.Fragment,{children:(0,ps.jsx)("dl",{className:"flex flex-wrap",children:(0,ps.jsxs)("div",{className:"flex-auto pt-4",children:[(0,ps.jsx)("dt",{className:"scroll-m-20 text-xs font-semibold tracking-tight",children:e}),(0,ps.jsx)("dd",{className:"mt-1 text-base font-normal text-foreground leading-7",children:r})]})})})),"Row"),gs=require("react/jsx-runtime"),js=n((({title:e,resource:r,breadcrumb:a,isEdit:t=!0,isDelete:s=!0,extra:i,children:l})=>{let n=(0,xs.useTranslate)(),{options:{breadcrumb:o}={}}=(0,xs.useRefineContext)(),d=(0,xs.useUserFriendlyName)(),{resource:c,identifier:u}=(0,xs.useResource)(r),{list:m}=(0,xs.useNavigation)(),x=typeof a>"u"?o:a;return(0,gs.jsxs)(gs.Fragment,{children:[(0,gs.jsx)(xt,{title:e??n(`${u}.titles.List`,`Show ${d(c?.meta?.label??u,"singular")}`),breadcrumb:(0,fs.isValidElement)(x)?x:(0,gs.jsx)(ee,{}),isBack:!0,extra:i??(0,gs.jsxs)("div",{className:"inline-flex items-center gap-x-2",children:[t&&(0,gs.jsx)(kt,{resource:r}),s&&(0,gs.jsx)(wt,{resource:r,onSuccess:()=>{m(c?.name)}})]})}),(0,gs.jsx)("div",{className:"relative pt-4 !mt-0",children:l})]})}),"ShowPage");js.Row=hs,js.displayName="ShowPage";var bs=require("next-themes"),vs=require("react/jsx-runtime");function Ns({children:e,...r}){return(0,vs.jsx)(bs.ThemeProvider,{...r,children:e})}n(Ns,"ThemeProvider");var ys=require("react/jsx-runtime"),ws=n((({attribute:e,defaultTheme:r,enableSystem:a,disableTransitionOnChange:t,enableColorScheme:s,forcedTheme:i,nonce:l,storageKey:n,themes:o,value:d,children:c})=>(0,ys.jsx)(Ns,{attribute:e??"class",defaultTheme:r??"system",enableSystem:a??!0,disableTransitionOnChange:t??!1,enableColorScheme:s??!0,forcedTheme:i,nonce:l,storageKey:n,themes:o,value:d,children:(0,ys.jsxs)($a,{delayDuration:0,skipDelayDuration:0,disableHoverableContent:!0,children:[c,(0,ys.jsx)(ka,{})]})})),"BaseLayout");ws.displayName="BaseLayout";var Cs=d(require("react"));function qs(e,r){if(r===e)return!1;let a=Object.values(r),t=Object.values(e);if(a.length!==t.length||a.some(((e,r)=>e!==t[r])))return!0;let s=Object.keys(e);return Object.keys(r).some(((e,r)=>e!==s[r]))}function Ss(e,r){return e.matches[r]=!1,e.mediaQueries[r]={},e}function ks(e){let r=Object.keys(e);return typeof window>"u"?r.reduce(Ss,{mediaQueries:{},matches:{}}):r.reduce(((r,a)=>{let t=window.matchMedia(e[a]);return r.mediaQueries[a]=t,r.matches[a]=t.matches,r}),{mediaQueries:{},matches:{}})}function Rs(e,r){function a(r,a){return r[a]=e.mediaQueries[a].matches,r}switch(n(a,"_ref2"),r.type){case"updateMatches":return{matches:Object.keys(e.mediaQueries).reduce(a,{}),mediaQueries:e.mediaQueries};case"setQueries":return ks(r.queries)}}function Is(e){let r=Cs.useRef(e),[a,t]=Cs.useReducer(Rs,e,ks);function s(){return t({type:"updateMatches"})}function i(e){let r=s;return typeof e.addListener<"u"?e.addListener(r):e.addEventListener("change",r),r}Cs.useEffect((()=>{qs(e,r.current)&&(t({type:"setQueries",queries:e}),r.current=e)}),[e]),n(s,"_ref3"),n(i,"_ref4"),Cs.useEffect((()=>{let e=Object.values(a.mediaQueries),r=e.map(i);function t(e,a){typeof e.addListener<"u"?e.removeListener(r[a]):e.removeEventListener("change",r[a])}return n(t,"_ref5"),()=>{e.forEach(t)}}),[a.mediaQueries]);let{matches:l}=a,o=Cs.useMemo((()=>Object.values(l)),[l]);return{matches:l,matchesAny:o.some(Boolean),matchesAll:o.length>0&&o.every(Boolean)}}function zs(e){return Is(Ts(e)).matchesAll}n(qs,"queriesDidChange"),n(Ss,"_ref"),n(ks,"init"),n(Rs,"reducer"),n(Is,"useMediaQueries"),n(zs,"useMediaQuery");var Ds={};function Ts(e){return void 0===Ds[e]&&(Ds[e]={default:e}),Ds[e]}n(Ts,"getObj");var Bs=require("@refinedev/core"),Fs=require("react"),Ps=require("react/jsx-runtime"),Ls=n((({children:e,defaultLayout:r,defaultCollapsed:a=!1,navCollapsedSize:t,navbar:s,footer:i,logo:l,attribute:n,defaultTheme:o,enableSystem:d,disableTransitionOnChange:c,enableColorScheme:u,forcedTheme:m,nonce:x,storageKey:f,themes:p,value:g})=>{let{resources:j}=(0,Bs.useResource)(),b=j?.[0],v=zs("only screen and (max-width: 579.999px)"),N=zs("only screen and (min-width: 640px) and (max-width: 767.999px)"),y=zs("only screen and (min-width: 768px) and (max-width: 1023.999px)"),w=zs("only screen and (min-width: 1024px)"),[C,q]=(0,Fs.useState)(v??a),S=(0,Fs.useMemo)((()=>r||(v?[15,85]:N?[20,80]:y?[25,75]:[15,85])),[r,v,N,y]),k=(0,Fs.useMemo)((()=>w?{minSize:11,maxSize:15}:y?{minSize:15,maxSize:25}:N?{minSize:20,maxSize:30}:{minSize:15,maxSize:15}),[N,y,w]),R=(0,Fs.useMemo)((()=>C||v||N||y),[C,y,N,v]),I=(0,Fs.useMemo)((()=>{if(!l)return null;if(!R&&(0,Fs.isValidElement)(l.default))return(0,Fs.cloneElement)(l.default,{className:"w-auto h-8"});let e=R?l.collapsed:l.default;return(0,Fs.isValidElement)(e)?(0,Fs.cloneElement)(e,{className:"w-auto h-8"}):null}),[l,r,R]);return(0,Ps.jsx)(Ps.Fragment,{children:(0,Ps.jsx)(ws,{attribute:n,defaultTheme:o,enableSystem:d,disableTransitionOnChange:c,enableColorScheme:u,forcedTheme:m,nonce:x,storageKey:f,themes:p,value:g,children:(0,Ps.jsxs)(Zr,{direction:"horizontal",onLayout:e=>{document.cookie=`react-resizable-panels:layout=${JSON.stringify(e)}`},className:"h-full items-stretch",children:[(0,Ps.jsxs)(ea,{defaultSize:S[0],collapsedSize:t,collapsible:!0,minSize:k.minSize,maxSize:k.maxSize,onExpand:()=>{let e=v;q(e),document.cookie=`react-resizable-panels:collapsed=${JSON.stringify(e)}`},onCollapse:()=>{q(!0),document.cookie=`react-resizable-panels:collapsed=${JSON.stringify(!0)}`},className:h(R&&"min-w-[50px] transition-all duration-300 ease-in-out"),children:[(0,Ps.jsx)("div",{className:h("flex py-1.5 max-h-14 items-center border-b border-border/40 justify-center",R&&"px-2"),children:(0,Ps.jsx)(J,{href:b.list?.toString()??"/",className:"inline-flex items-center justify-center",title:b.meta?.label??b.name,children:I})}),(0,Ps.jsx)(Nt,{isCollapsed:R})]}),(0,Ps.jsx)(ra,{withHandle:!0,className:"bg-border/40"}),(0,Ps.jsxs)(ea,{defaultSize:S[1],minSize:25,className:"xl:max-h-dvh h-full !overflow-y-auto flex flex-col overflow-x-hidden",children:[(0,Ps.jsxs)("header",{className:h("sticky top-0 z-50 py-2 h-14 px-4 flex justify-end items-center border-b border-border/40 bg-background/95 backdrop-blur supports-[backdrop-filter]:bg-background/60",s?.rightSide&&"justify-between"),children:[s?.leftSide&&(0,Ps.jsx)("div",{className:"flex items-center justify-start flex-1",children:s?.leftSide}),s?.rightSide?(0,Ps.jsxs)("div",{className:"flex items-center justify-end flex-1",children:[(0,Ps.jsx)(ut,{}),s?.rightSide]}):(0,Ps.jsx)(ut,{})]}),(0,Ps.jsx)("main",{className:"grow px-6 py-4",children:e}),i&&(0,Ps.jsx)("footer",{className:"px-6 py-4 border-t border-border/40 sticky bottom-0 bg-background text-primary flex flex-row items-center",children:(0,Ps.jsx)("div",{className:"w-full",children:i})})]})]})})})}),"DefaultLayout");Ls.displayName="DefaultLayout";var As=require("sonner"),Ms={open:n((({key:e,message:r,description:a,type:t})=>{"success"===t&&As.toast.success(r,{description:a,id:e}),"error"===t&&As.toast.error(r,{description:a,id:e}),"progress"===t&&As.toast.loading(r,{description:a,id:e})}),"open"),close:n((e=>As.toast.dismiss(e)),"close")},Os=n((()=>Ms),"useNotificationProvider"),Es=require("@refinedev/core"),Vs=require("react"),_s=n(((e,r,a)=>{let t=(0,Vs.useContext)(Es.AccessControlContext),s=t.options.buttons.enableAccessControl,i=t.options.buttons.hideIfUnauthorized,{editUrl:l}=(0,Es.useNavigation)(),{id:o,resource:d}=(0,Es.useResource)(e),{data:c}=(0,Es.useCan)({resource:e,action:"edit",params:{id:r,resource:d},queryOptions:{enabled:s}}),u=(0,Es.useTranslate)(),m=n((()=>c?.can?"":c?.reason?c.reason:u("buttons.notAccessTitle","You don't have permission to access")),"reason"),x=e&&(r??o)?l(e,r??o,a):"";return{can:!(s&&i&&!c?.can),reason:m(),url:x}}),"useGetEditUrl"),Hs=require("@refinedev/core"),$s=require("react"),Us=n(((e,r,a)=>{let t=(0,$s.useContext)(Hs.AccessControlContext),s=t.options.buttons.enableAccessControl,i=t.options.buttons.hideIfUnauthorized,{showUrl:l}=(0,Hs.useNavigation)(),{id:o,resource:d}=(0,Hs.useResource)(e),{data:c}=(0,Hs.useCan)({resource:e,action:"show",params:{id:r,resource:d},queryOptions:{enabled:s}}),u=(0,Hs.useTranslate)(),m=n((()=>c?.can?"":c?.reason?c.reason:u("buttons.notAccessTitle","You don't have permission to access")),"reason"),x=e&&(r||o)?l(e,r??o,a):"";return{can:!(s&&i&&!c?.can),reason:m(),url:x}}),"useGetShowUrl"),Qs=require("@refinedev/core"),Gs=require("react"),Ws=n(((e,r,a)=>{let t=(0,Gs.useContext)(Qs.AccessControlContext),s=t.options.buttons.enableAccessControl,i=t.options.buttons.hideIfUnauthorized,l=(0,Qs.useTranslate)(),o=(0,Qs.useResourceParams)(),{resource:d,identifier:c}=(0,Qs.useResource)(e),{mutationMode:u}=(0,Qs.useMutationMode)(),{mutate:m,isLoading:x}=(0,Qs.useDelete)(),{data:f}=(0,Qs.useCan)({resource:d?.name,action:"delete",params:{id:r??o,resource:d},queryOptions:{enabled:s}}),p=n((()=>f?.can?"":f?.reason?f.reason:l("You don't have permission to access")),"reason"),{setWarnWhen:h}=(0,Qs.useWarnAboutChange)(),g=n((e=>{if((!s||!i||f?.can)&&(r??o)&&c)return h(!1),m({id:r??o??"",resource:c,mutationMode:u,meta:(0,Qs.pickNotDeprecated)(a),metaData:(0,Qs.pickNotDeprecated)(a)},e)}),"onDeleteMutate");return{can:!(s&&i&&!f?.can),reason:p(),mutate:g,isLoading:x}}),"useDeleteHelper"),Ks=require("@refinedev/core"),Xs=n((()=>{let e=(0,Ks.useRouterType)(),r=(0,Ks.useBack)(),{goBack:a}=(0,Ks.useNavigation)(),{action:t}=(0,Ks.useResource)();return"list"!==t||typeof t<"u"?"legacy"===e?a:r:void 0}),"useOnBack"),Js=require("@refinedev/core"),Ys=require("react"),Zs=require("react/jsx-runtime");function ei(e){let r=Xs(),{can:a,isLoading:t,mutate:s}=Ws(e.data?.resource,e.data?.row?.id),i=(0,Js.useTranslate)(),l=(0,Ys.useCallback)((()=>{if(a)return s({onSuccess(){let a=e?.data?.redirectBack??!1,t=e?.data?.onAfterHandle;e?.updateData({toogle:!1,row:void 0,resource:"",redirectBack:!1,onAfterHandle:void 0}),a&&r?.(),t&&t()}})}),[a,s,e,r]);return(0,Zs.jsx)(et,{open:a&&e?.data?.toogle,loading:t,title:i("Are you sure?"),description:i("This action cannot be undone."),okText:i("Delete"),cancelText:i("Cancel"),okButtonVariant:"destructive",onOpenChange:()=>{t||e?.updateData({toogle:!1,row:void 0,resource:""})},onConfirm:l})}n(ei,"DeleteActionModal");var ri=(0,Ys.createContext)(void 0),ai=n((({children:e})=>{let[r,a]=(0,Ys.useState)({row:void 0,resource:"",toogle:!1,onAfterHandle:void 0}),t=n((e=>{a(e)}),"updateData");return(0,Zs.jsxs)(ri.Provider,{value:{data:r,updateData:t},children:[e,(0,Zs.jsx)(ei,{data:r,updateData:t})]})}),"DeleteProvider"),ti=require("react"),si=require("react/jsx-runtime"),ii=(0,ti.forwardRef)((({className:e,...r},a)=>(0,si.jsxs)("svg",{ref:a,xmlns:"http://www.w3.org/2000/svg",className:h("mx-auto inline",e),viewBox:"0 0 120 30",fill:"currentColor",...r,children:[(0,si.jsxs)("circle",{cx:"15",cy:"15",r:"15",children:[(0,si.jsx)("animate",{attributeName:"r",begin:"0s",calcMode:"linear",dur:"0.8s",from:"15",repeatCount:"indefinite",to:"15",values:"15;9;15"}),(0,si.jsx)("animate",{attributeName:"fill-opacity",begin:"0s",calcMode:"linear",dur:"0.8s",from:"1",repeatCount:"indefinite",to:"1",values:"1;.5;1"})]}),(0,si.jsxs)("circle",{cx:"60",cy:"15",r:"9",fillOpacity:"0.3",children:[(0,si.jsx)("animate",{attributeName:"r",begin:"0s",calcMode:"linear",dur:"0.8s",from:"9",repeatCount:"indefinite",to:"9",values:"9;15;9"}),(0,si.jsx)("animate",{attributeName:"fill-opacity",begin:"0s",calcMode:"linear",dur:"0.8s",from:"0.5",repeatCount:"indefinite",to:"0.5",values:".5;1;.5"})]}),(0,si.jsxs)("circle",{cx:"105",cy:"15",r:"15",children:[(0,si.jsx)("animate",{attributeName:"r",begin:"0s",calcMode:"linear",dur:"0.8s",from:"15",repeatCount:"indefinite",to:"15",values:"15;9;15"}),(0,si.jsx)("animate",{attributeName:"fill-opacity",begin:"0s",calcMode:"linear",dur:"0.8s",from:"1",repeatCount:"indefinite",to:"1",values:"1;.5;1"})]})]}))),li=ii,ni=require("@refinedev/react-table"),oi=require("@tanstack/react-table"),di=require("react"),ci=require("@radix-ui/react-icons"),ui=require("react/jsx-runtime"),mi=n((e=>(0,ui.jsx)(pr,{disabled:e.disabled,asChild:!(!e.to||!e.to&&!e.children),onClick:e.onClick,children:e.asChild?e.children:e.to?(0,ui.jsxs)(J,{href:e.to,title:e.title,children:[e.icon?(0,ui.jsx)("span",{className:"mr-2",children:e.icon}):null,e.title]}):(0,ui.jsxs)(ui.Fragment,{children:[e.icon?(0,ui.jsx)("span",{className:"mr-2",children:e.icon}):null,e.title]})})),"RowAction");function xi({children:e}){return(0,ui.jsxs)(cr,{children:[(0,ui.jsx)(ur,{asChild:!0,children:(0,ui.jsxs)(w,{variant:"ghost",size:"icon",children:[(0,ui.jsx)(ci.DotsHorizontalIcon,{className:"h-4 w-4"}),(0,ui.jsx)("span",{className:"sr-only",children:"Open menu"})]})}),(0,ui.jsx)(fr,{align:"end",className:"w-[160px]",children:e})]})}mi.displayName="RowAction",n(xi,"RowActions");var fi=require("react/jsx-runtime");function pi({row:e,resource:r,title:a,disabled:t,...s}){let i=_s(r,e.id);return(0,fi.jsx)(mi,{...s,disabled:!i.can||t,title:i?.can?a:i?.reason,to:i.url})}n(pi,"EditAction"),pi.displayName="EditAction";var hi=require("react/jsx-runtime");function gi({row:e,resource:r,title:a,disabled:t,...s}){let i=Us(r,e.id);return(0,hi.jsx)(mi,{...s,disabled:!i.can||t,title:i?.can?a:i?.reason,to:i.url})}n(gi,"ShowAction"),gi.displayName="ShowAction";var ji=require("date-fns"),bi=require("lucide-react"),vi=require("react"),Ni=require("react/jsx-runtime");function yi({column:e,title:r,numberOfMonths:a=2,align:t="start"}){let[s,i]=(0,vi.useState)({from:void 0,to:void 0}),l=new Set(e?.getFilterValue());return(0,vi.useEffect)((()=>{if(s){let r=Object.values(s).filter(Boolean);r.length&&e?.setFilterValue(r.map((e=>e?(0,ji.format)(e,"yyyy-MM-dd").toString():"")))}}),[e,s]),(0,Ni.jsxs)(Gr,{children:[(0,Ni.jsx)(Wr,{asChild:!0,children:(0,Ni.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-0.5",children:[(0,Ni.jsxs)(w,{title:r,variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",children:[(0,Ni.jsx)(bi.FilterIcon,{className:h("h-3.5 w-3.5")}),s?.from?(0,Ni.jsxs)(Ni.Fragment,{children:[(0,Ni.jsx)(wa,{orientation:"vertical",className:"mx-2 h-4"}),(0,Ni.jsx)(be,{variant:"secondary",className:"rounded-sm p-1 h-3.5 text-xs font-normal",children:s.to?(0,Ni.jsx)(Ni.Fragment,{children:[(0,ji.format)(s.from,"LLL dd, y"),(0,ji.format)(s.to,"LLL dd, y")].join(" ")}):(0,ji.format)(s.from,"LLL dd, y")})]}):null]}),l.size>0&&(0,Ni.jsx)(w,{variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",onClick:r=>{r.preventDefault(),e?.setFilterValue(void 0),i({from:void 0,to:void 0})},children:(0,Ni.jsx)(bi.FilterX,{className:h("h-3.5 w-3.5")})})]})}),(0,Ni.jsxs)(Kr,{className:"w-auto p-0",align:t,children:[(0,Ni.jsx)(we,{initialFocus:!0,mode:"range",defaultMonth:new Date,selected:s,onSelect:i,numberOfMonths:a}),l.size>0&&(0,Ni.jsxs)(Ni.Fragment,{children:[(0,Ni.jsx)(wa,{}),(0,Ni.jsx)("div",{className:"flex flex-row items-center justify-center py-3",children:(0,Ni.jsxs)(w,{variant:"outline",size:"sm",className:"h-8 border-dashed px-2",onClick:()=>{e?.setFilterValue(void 0),i({from:void 0,to:void 0})},children:[(0,Ni.jsx)(bi.FilterX,{size:16,className:"mr-2"}),"Clear"]})})]})]})]})}n(yi,"TableFilterDateRangePickerFilter");var wi=require("@radix-ui/react-icons"),Ci=require("lucide-react"),qi=require("react/jsx-runtime");function Si({column:e,title:r,options:a,align:t="start"}){let s=e?.getFacetedUniqueValues(),i=new Set(e?.getFilterValue());return(0,qi.jsxs)(Gr,{children:[(0,qi.jsx)(Wr,{asChild:!0,children:(0,qi.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-0.5",children:[(0,qi.jsxs)(w,{title:r,variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",children:[(0,qi.jsx)(Ci.FilterIcon,{className:h("h-3.5 w-3.5")}),i?.size>0&&(0,qi.jsxs)(qi.Fragment,{children:[(0,qi.jsx)(wa,{orientation:"vertical",className:"mx-2 h-4"}),(0,qi.jsx)(be,{variant:"secondary",className:"rounded-sm p-1 h-3.5 text-xs font-normal lg:hidden",children:i.size}),(0,qi.jsx)("div",{className:"hidden space-x-1 lg:flex",children:i.size>2?(0,qi.jsxs)(be,{variant:"secondary",className:"rounded-sm p-1 text-xs h-3.5 font-normal",children:[i.size," selected"]}):a?.filter((e=>i.has(e.value))).map((e=>(0,qi.jsx)(be,{variant:"secondary",className:"rounded-sm p-1 text-xs h-3.5 font-normal",children:e.label},e.value)))})]})]}),i.size>0&&(0,qi.jsx)(w,{variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",onClick:r=>{r.preventDefault(),e?.setFilterValue(void 0)},children:(0,qi.jsx)(Ci.FilterX,{className:h("h-3.5 w-3.5")})})]})}),(0,qi.jsx)(Kr,{className:"w-[200px] p-0",align:t,children:(0,qi.jsxs)(Ye,{children:[(0,qi.jsx)(Ze,{placeholder:r}),(0,qi.jsxs)(er,{children:[(0,qi.jsx)(rr,{children:"No results found."}),(0,qi.jsx)(ar,{children:a?.map((r=>{let a=i.has(r.value);return(0,qi.jsxs)(sr,{onSelect:()=>{a?i.delete(r.value):i.add(r.value);let t=Array.from(i);e?.setFilterValue(t.length?t:void 0)},children:[(0,qi.jsx)("div",{className:h("mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary",a?"bg-primary text-primary-foreground":"opacity-50 [&_svg]:invisible"),children:(0,qi.jsx)(wi.CheckIcon,{className:h("h-4 w-4")})}),r.icon&&(0,qi.jsx)(r.icon,{className:"mr-2 h-4 w-4 text-muted-foreground"}),(0,qi.jsx)("span",{children:r.label}),s?.get(r.value)&&(0,qi.jsx)("span",{className:"ml-auto flex h-4 w-4 items-center justify-center font-mono text-xs",children:s.get(r.value)})]},r.value)}))}),i.size>0&&(0,qi.jsxs)(qi.Fragment,{children:[(0,qi.jsx)(tr,{}),(0,qi.jsx)(ar,{children:(0,qi.jsx)(sr,{onSelect:()=>e?.setFilterValue(void 0),className:"justify-center text-center",children:"Clear filters"})})]})]})]})})]})}n(Si,"TableFilterDropdown");var ki=require("lucide-react"),Ri=require("react/jsx-runtime");function Ii({column:e,title:r,align:a="start"}){let t=e?.getFilterValue();return(0,Ri.jsxs)(Gr,{children:[(0,Ri.jsx)(Wr,{asChild:!0,children:(0,Ri.jsx)("div",{className:"inline-flex flex-row items-center gap-x-0.5",children:t?(0,Ri.jsx)(w,{variant:"outline",size:"sm",className:"h-5 border-dashed px-1 py-2.5",onClick:r=>{r.preventDefault(),e?.setFilterValue(void 0)},children:(0,Ri.jsx)(ki.FilterX,{className:h("h-3.5 w-3.5")})}):(0,Ri.jsx)(w,{title:r,variant:"outline",size:"sm",className:"h-4 border-dashed px-1 py-2.5",children:(0,Ri.jsx)(ki.FilterIcon,{className:h("h-3.5 w-3.5")})})})}),(0,Ri.jsx)(Kr,{className:"w-[200px] p-0 overflow-hidden border-0 ring-0",align:a,children:(0,Ri.jsxs)("div",{className:"relative",children:[(0,Ri.jsxs)("div",{className:"flex flex-row items-center px-3 text-popover-foreground bg-popover",children:[(0,Ri.jsx)("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:"mr-2 h-4 w-4 shrink-0 opacity-50",children:(0,Ri.jsx)("path",{d:"M10 6.5C10 8.433 8.433 10 6.5 10C4.567 10 3 8.433 3 6.5C3 4.567 4.567 3 6.5 3C8.433 3 10 4.567 10 6.5ZM9.30884 10.0159C8.53901 10.6318 7.56251 11 6.5 11C4.01472 11 2 8.98528 2 6.5C2 4.01472 4.01472 2 6.5 2C8.98528 2 11 4.01472 11 6.5C11 7.56251 10.6318 8.53901 10.0159 9.30884L12.8536 12.1464C13.0488 12.3417 13.0488 12.6583 12.8536 12.8536C12.6583 13.0488 12.3417 13.0488 12.1464 12.8536L9.30884 10.0159Z",fill:"currentColor",fillRule:"evenodd",clipRule:"evenodd"})}),(0,Ri.jsx)(Hr,{defaultValue:t??"",onChange:r=>{e?.setFilterValue(r.target.value)},className:h("h-10 border-0 focus-visible:ring-0 ring-0 rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground shadow-none disabled:cursor-not-allowed disabled:opacity-50"),placeholder:r})]}),t&&(0,Ri.jsxs)(Ri.Fragment,{children:[(0,Ri.jsx)(wa,{}),(0,Ri.jsx)("div",{className:"flex flex-row items-center justify-center py-3",children:(0,Ri.jsxs)(w,{variant:"outline",size:"sm",className:"h-8 border-dashed px-2",onClick:()=>{e?.setFilterValue(void 0)},children:[(0,Ri.jsx)(ki.FilterX,{size:16,className:"mr-2"}),"Clear"]})})]})]})})]})}n(Ii,"TableFilterSearchColumn");var zi=require("@radix-ui/react-icons"),Di=require("react"),Ti=require("react/jsx-runtime"),Bi=(0,Di.forwardRef)((({table:e,children:r,options:a},t)=>(0,Ti.jsxs)(Ti.Fragment,{children:[(0,Ti.jsx)(Le,{ref:t,checked:e.getIsSomeRowsSelected()?"indeterminate":e.getIsAllPageRowsSelected(),onCheckedChange:r=>e.toggleAllPageRowsSelected(!!r),className:"translate-y-[2px]","aria-label":"Select all"}),r||Array.isArray(a)&&a.length&&(0,Ti.jsxs)(cr,{children:[(0,Ti.jsx)(ur,{asChild:!0,children:(0,Ti.jsx)(w,{disabled:!(e.getIsSomeRowsSelected()||e.getIsAllPageRowsSelected()),size:"icon",variant:"ghost",className:"px-0 w-5",children:(0,Ti.jsx)(zi.DotsVerticalIcon,{className:"w-4 h-4"})})}),(0,Ti.jsxs)(fr,{align:"start",children:[(0,Ti.jsx)(jr,{children:"Bulk Actions"}),(0,Ti.jsx)(br,{}),!r&&Array.isArray(a)&&a?.length>0?a.map(((e,r)=>(0,Ti.jsx)(pr,{onSelect:e.onClick,children:e.label},r))):r]})]})]})));Bi.displayName="CheckAll";var Fi=require("@radix-ui/react-icons"),Pi=require("react/jsx-runtime"),Li=n((({table:e})=>(0,Pi.jsxs)("div",{className:"flex flex-col sm:flex-row gap-y-4 sm-gap-y-0 items-center justify-between",children:[(0,Pi.jsxs)("div",{className:"flex-1 text-sm text-muted-foreground",children:[e.getFilteredSelectedRowModel().rows.length," of"," ",e.getFilteredRowModel().rows.length," row(s) selected."]}),(0,Pi.jsxs)("div",{className:"flex relative flex-col-reverse gap-y-4 sm:gap-y-0 sm:flex-row items-center space-x-6 lg:space-x-8",children:[(0,Pi.jsxs)("div",{className:"flex items-center space-x-2",children:[(0,Pi.jsx)("p",{className:"text-sm font-medium",children:"Rows per page"}),(0,Pi.jsxs)(ua,{value:`${e.getState().pagination.pageSize}`,onValueChange:r=>{e.setPageSize(Number(r))},children:[(0,Pi.jsx)(xa,{className:"h-8 w-[70px]",children:(0,Pi.jsx)(ma,{placeholder:e.getState().pagination.pageSize})}),(0,Pi.jsx)(ha,{children:[10,20,30,40,50].map((e=>(0,Pi.jsx)(ja,{value:`${e}`,children:e},e)))})]})]}),(0,Pi.jsxs)("div",{className:"flex w-fit items-center justify-center text-sm font-medium",children:["Page ",e.getState().pagination.pageIndex+1," of"," ",e.getPageCount()]}),(0,Pi.jsxs)("div",{className:"flex items-center space-x-2",children:[(0,Pi.jsxs)(w,{variant:"outline",className:"hidden h-8 w-8 p-0 lg:flex",onClick:()=>e.setPageIndex(0),disabled:!e.getCanPreviousPage(),children:[(0,Pi.jsx)("span",{className:"sr-only",children:"Go to first page"}),(0,Pi.jsx)(Fi.DoubleArrowLeftIcon,{className:"h-4 w-4"})]}),(0,Pi.jsxs)(w,{variant:"outline",className:"h-8 w-8 p-0",onClick:()=>e.previousPage(),disabled:!e.getCanPreviousPage(),children:[(0,Pi.jsx)("span",{className:"sr-only",children:"Go to previous page"}),(0,Pi.jsx)(Fi.ChevronLeftIcon,{className:"h-4 w-4"})]}),(0,Pi.jsxs)(w,{variant:"outline",className:"h-8 w-8 p-0",onClick:()=>e.nextPage(),disabled:!e.getCanNextPage(),children:[(0,Pi.jsx)("span",{className:"sr-only",children:"Go to next page"}),(0,Pi.jsx)(Fi.ChevronRightIcon,{className:"h-4 w-4"})]}),(0,Pi.jsxs)(w,{variant:"outline",className:"hidden h-8 w-8 p-0 lg:flex",onClick:()=>e.setPageIndex(e.getPageCount()-1),disabled:!e.getCanNextPage(),children:[(0,Pi.jsx)("span",{className:"sr-only",children:"Go to last page"}),(0,Pi.jsx)(Fi.DoubleArrowRightIcon,{className:"h-4 w-4"})]})]})]})]})),"Pagination");Li.displayName="Pagination";var Ai=require("@radix-ui/react-icons"),Mi=require("react/jsx-runtime"),Oi=n((({column:e})=>(0,Mi.jsx)("div",{className:"cursor-pointer",onClick:()=>{e?.toggleSorting("asc"===e?.getIsSorted())},children:(0,Mi.jsxs)("div",{className:"inline-flex flex-col",children:[(0,Mi.jsx)(Ai.CaretUpIcon,{className:h("-mb-1.5 w-5 h-5","asc"===e?.getIsSorted()?"text-foreground":"text-input")}),(0,Mi.jsx)(Ai.CaretDownIcon,{className:h("-mt-1.5 w-5 h-5","desc"===e?.getIsSorted()?"text-foreground":"text-input")})]})})),"SortAction"),Ei=require("@radix-ui/react-dropdown-menu"),Vi=require("@radix-ui/react-icons"),_i=require("react"),Hi=require("react/jsx-runtime"),$i=n((({table:e})=>{let r=(0,_i.useMemo)((()=>e.getAllColumns().filter((e=>typeof e.accessorFn<"u"&&e.getCanHide()))),[e]);return(0,Hi.jsxs)(cr,{children:[(0,Hi.jsx)(Ei.DropdownMenuTrigger,{asChild:!0,children:(0,Hi.jsxs)(w,{variant:"outline",size:"sm",className:"ml-auto hidden h-8 lg:flex",children:[(0,Hi.jsx)(Vi.MixerHorizontalIcon,{className:"mr-2 h-4 w-4"}),"View"]})}),(0,Hi.jsxs)(fr,{align:"end",className:"w-[150px]",children:[(0,Hi.jsx)(jr,{children:"Toggle columns"}),(0,Hi.jsx)(br,{}),r.map((e=>(0,Hi.jsx)(hr,{className:"capitalize",checked:e.getIsVisible(),onCheckedChange:r=>e.toggleVisibility(r),children:e.id},e.id)))]})]})}),"DataTableViewOptions");$i.displayName="DataTableViewOptions";var Ui=require("react/jsx-runtime");function Qi({table:e}){return(0,Ui.jsxs)("div",{className:"flex items-center justify-between",children:[(0,Ui.jsx)("div",{className:"flex flex-1 items-center space-x-2"}),(0,Ui.jsx)($i,{table:e})]})}n(Qi,"DataTableToolbar");var Gi=require("react"),Wi=require("react/jsx-runtime");function Ki({row:e,resource:r,title:a,disabled:t,onAfterHandle:s,...i}){let{can:l,reason:n}=Ws(r,e.id),o=(0,Gi.useContext)(ri);return(0,Wi.jsx)(mi,{...i,disabled:!l||t,title:l?a:n,onClick:()=>o?.updateData({row:e,resource:r,toogle:!0,onAfterHandle:s})})}n(Ki,"DeleteAction"),Ki.displayName="DeleteAction";var Xi=require("react/jsx-runtime");function Ji({children:e,showHeader:r=!0,columns:a=[],...t}){let s=(0,di.useCallback)((({id:e,accessorKey:r,header:a,enableSorting:t,enableHiding:s,filter:i,cell:l})=>{let n={id:e,header:a,accessorKey:r,enableSorting:t??!1,enableHiding:s??!1,enableColumnFilter:!0,enableResizing:!0,filter:i};return l&&(n.cell=l),n}),[]);a=(0,di.useMemo)((()=>Array.isArray(e)?e.map((e=>e.props)).map(s):[]),[e,s]);let i=(0,ni.useTable)({columns:a,...t}),l=(0,di.useMemo)((()=>i.options),[i]),n=(0,di.useMemo)((()=>!(!l.enableColumnFilters&&!l?.enableFilters)),[l]);return(0,Xi.jsx)(ai,{children:(0,Xi.jsxs)("div",{className:"space-y-4",children:[(0,Xi.jsx)(Qi,{table:i}),(0,Xi.jsx)("div",{className:"rounded-md border border-border",children:(0,Xi.jsxs)(za,{children:[r&&(0,Xi.jsx)(Da,{children:i.getHeaderGroups().map((e=>(0,Xi.jsx)(Fa,{children:e.headers.map((e=>{let r=e.column.columnDef;return(0,Xi.jsx)(Pa,{children:(0,Xi.jsxs)("div",{className:"inline-flex flex-row items-center gap-x-2.5",children:[e.isPlaceholder?null:(0,oi.flexRender)(e.column.columnDef.header,e.getContext()),l.enableSorting&&r.enableSorting&&(0,Xi.jsx)(Oi,{column:e.column}),n&&r?.filter&&r.filter({column:e.column,title:`${r.header} Filter`})]})},e.id)}))},e.id)))}),(0,Xi.jsx)(Ta,{children:i.refineCore.tableQuery.isLoading?(0,Xi.jsx)(Fa,{children:(0,Xi.jsx)(La,{colSpan:a.length,className:"h-24 text-center text-nowrap",children:(0,Xi.jsx)("div",{className:"flex items-center justify-center flex-row",children:(0,Xi.jsx)(li,{className:"h-4 text-primary"})})})}):i.getRowModel().rows?.length?i.getRowModel().rows.map((e=>(0,Xi.jsx)(Fa,{"data-state":e.getIsSelected()&&"selected",children:e.getVisibleCells().map((e=>(0,Xi.jsx)(La,{className:"text-nowrap",children:(0,oi.flexRender)(e.column.columnDef.cell,e.getContext())},e.id)))},e.id))):(0,Xi.jsx)(Fa,{children:(0,Xi.jsx)(La,{colSpan:a.length,className:"h-24 text-center",children:"No results."})})})]})}),(0,Xi.jsx)(Li,{table:i})]})})}n(Ji,"Table");var Yi=n((e=>e.children),"TableColumn");Ji.Column=Yi,Ji.CheckAll=Bi,Ji.Actions=xi,Ji.Action=mi,Ji.EditAction=pi,Ji.ShowAction=gi,Ji.DeleteAction=Ki,Ji.Filter={DateRangePicker:yi,Dropdown:Si,Search:Ii},Ji.displayName="Table";//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/ui/button.tsx", "../src/lib/utils.ts", "../src/ui/loading.tsx", "../src/buttons/clone.tsx", "../src/buttons/create.tsx", "../src/buttons/delete.tsx", "../src/ui/breadcrumb.tsx", "../src/components/breadcrumbs.tsx", "../src/components/link.tsx", "../src/components/combobox.tsx", "../src/ui/alert-dialog.tsx", "../src/ui/badge.tsx", "../src/ui/calendar.tsx", "../src/ui/card.tsx", "../src/ui/checkbox.tsx", "../src/ui/command.tsx", "../src/ui/dialog.tsx", "../src/ui/dropdown-menu.tsx", "../src/ui/form.tsx", "../src/ui/label.tsx", "../src/ui/input.tsx", "../src/ui/popover.tsx", "../src/ui/resizable.tsx", "../src/ui/scroll-area.tsx", "../src/ui/select.tsx", "../src/ui/separator.tsx", "../src/ui/sonner.tsx", "../src/ui/table.tsx", "../src/ui/textarea.tsx", "../src/ui/tooltip.tsx", "../src/components/confirm.tsx", "../src/components/field.tsx", "../src/components/form.tsx", "../src/components/modeToggle.tsx", "../src/components/pageHeader.tsx", "../src/components/select.tsx", "../src/components/sidebar.tsx", "../src/buttons/edit.tsx", "../src/buttons/export.tsx", "../src/buttons/import.tsx", "../src/buttons/list.tsx", "../src/buttons/refresh.tsx", "../src/buttons/save.tsx", "../src/buttons/show.tsx", "../src/curds/create.tsx", "../src/curds/edit.tsx", "../src/curds/list.tsx", "../src/curds/show/index.tsx", "../src/curds/show/row.tsx", "../src/providers/theme-provider.tsx", "../src/layouts/base.tsx", "../../../node_modules/@react-hook/media-query/dist/module/index.js", "../src/layouts/default.tsx", "../src/providers/notificationProvider.ts", "../src/hooks/useGetEditUrl.tsx", "../src/hooks/useGetShowUrl.tsx", "../src/hooks/useDeleteHelper.tsx", "../src/hooks/useOnBack.tsx", "../src/providers/deleteProvider.tsx", "../src/components/loader.tsx", "../src/table/index.tsx", "../src/table/actions/index.tsx", "../src/table/actions/edit.tsx", "../src/table/actions/show.tsx", "../src/table/fields/table-filter-date-range-picker.tsx", "../src/table/fields/table-filter-dropdown.tsx", "../src/table/fields/table-filter-search-column.tsx", "../src/table/fields/checkall.tsx", "../src/table/fields/pagination.tsx", "../src/table/fields/sort.tsx", "../src/table/toolbar/table-view-options-dropdown.tsx", "../src/table/toolbar/index.tsx", "../src/table/actions/delete.tsx"],
  "sourcesContent": ["export * from \"./buttons\";\nexport * from \"./components\";\nexport * from \"./curds\";\nexport * from \"./layouts\";\nexport * from \"./providers\";\nexport * from \"./table\";\n", "import { Slot } from \"@radix-ui/react-slot\";\nimport { cva, VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\nimport { LoadingIcon } from \"./loading\";\n\nconst buttonVariants = cva(\n    \"inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50\",\n    {\n        variants: {\n            variant: {\n                default:\n                    \"bg-primary text-primary-foreground shadow hover:bg-primary/90\",\n                destructive:\n                    \"bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90\",\n                outline:\n                    \"border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground\",\n                secondary:\n                    \"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80\",\n                ghost: \"hover:bg-accent hover:text-accent-foreground\",\n                link: \"text-primary underline-offset-4 hover:underline\",\n            },\n            size: {\n                default: \"h-9 px-4 py-2\",\n                sm: \"h-8 rounded-md px-3 text-xs\",\n                lg: \"h-10 rounded-md px-8\",\n                icon: \"h-9 w-9\",\n            },\n        },\n        defaultVariants: {\n            variant: \"default\",\n            size: \"default\",\n        },\n    },\n);\n\nexport interface ButtonProps\n    extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n        VariantProps<typeof buttonVariants> {\n    asChild?: boolean;\n    loading?: boolean;\n    icon?: React.ReactElement<SVGSVGElement>;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n    (\n        {\n            className,\n            variant,\n            size,\n            icon = null,\n            loading = false,\n            asChild = false,\n            children,\n            disabled,\n            ...props\n        },\n        ref,\n    ) => {\n        disabled = disabled || loading;\n        const Icon = React.useMemo(() => {\n            if (React.isValidElement(icon)) {\n                return icon;\n            }\n            return loading ? <LoadingIcon className=\"mr-2\" /> : null;\n        }, [icon, loading]);\n        const Comp = asChild ? Slot : \"button\";\n        return (\n            <Comp\n                className={cn(buttonVariants({ variant, size, className }))}\n                ref={ref}\n                disabled={disabled}\n                {...props}\n            >\n                {size === \"icon\" ? (\n                    loading ? (\n                        <LoadingIcon />\n                    ) : (\n                        children\n                    )\n                ) : (\n                    <>\n                        {Icon}\n                        {children}\n                    </>\n                )}\n            </Comp>\n        );\n    },\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n", "import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n    return twMerge(clsx(inputs));\n}\n", "import { cn } from \"@/lib/utils\";\nimport { LucideProps, RefreshCwIcon } from \"lucide-react\";\nimport React from \"react\";\n\nexport const LoadingIcon = React.forwardRef<SVGSVGElement, LucideProps>(\n    ({ className, ...props }, ref) => {\n        return (\n            <RefreshCwIcon\n                ref={ref}\n                className={cn(\"h-4 w-4 animate-spin\", className)}\n                {...props}\n            />\n        );\n    },\n);\n", "import { CloneButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useCloneButton } from \"@refinedev/core\";\nimport { CopyPlus } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const CloneButton: FC<CloneButtonProps> = ({\n    resource,\n    recordItemId,\n    hideText = false,\n    accessControl,\n    meta,\n    onClick,\n    children,\n    ...props\n}) => {\n    const { to, LinkComponent, label, disabled, hidden, title } =\n        useCloneButton({\n            id: recordItemId,\n            resource: resource,\n            accessControl: accessControl,\n            meta: meta,\n        });\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<CopyPlus className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nCloneButton.displayName = \"CloneButton\";\n", "import { CreateButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useCreateButton } from \"@refinedev/core\";\nimport { SquarePlusIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const CreateButton: FC<CreateButtonProps> = ({\n    resource,\n    hideText = false,\n    accessControl,\n    meta,\n    onClick,\n    children,\n    ...props\n}) => {\n    const { hidden, disabled, label, title, LinkComponent, to } =\n        useCreateButton({\n            resource,\n            accessControl,\n            meta,\n        });\n\n    if (hidden) return null;\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<SquarePlusIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nCreateButton.displayName = \"CreateButton\";\n", "import { DeleteButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useDeleteButton } from \"@refinedev/core\";\nimport { Trash2Icon } from \"lucide-react\";\nimport type { FC } from \"react\";\nimport { ConfirmDialog } from \"@/components\";\n\nexport const DeleteButton: FC<DeleteButtonProps> = ({\n    resource,\n    recordItemId,\n    onSuccess,\n    mutationMode: mutationModeProp,\n    confirmTitle,\n    confirmDescription,\n    successNotification,\n    errorNotification,\n    hideText = false,\n    accessControl,\n    meta,\n    dataProviderName,\n    confirmOkText,\n    confirmCancelText,\n    invalidates,\n    children,\n    ...props\n}) => {\n    const {\n        title,\n        label,\n        hidden,\n        disabled,\n        loading,\n        confirmTitle: defaultConfirmTitle,\n        confirmOkLabel: defaultConfirmOkLabel,\n        cancelLabel: defaultCancelLabel,\n        onConfirm,\n    } = useDeleteButton({\n        resource,\n        id: recordItemId,\n        dataProviderName,\n        invalidates,\n        meta,\n        onSuccess,\n        mutationMode: mutationModeProp,\n        errorNotification,\n        successNotification,\n        accessControl,\n    });\n\n    if (hidden) return null;\n\n    return (\n        <ConfirmDialog\n            okText={confirmOkText ?? defaultConfirmOkLabel}\n            cancelText={confirmCancelText ?? defaultCancelLabel}\n            okButtonVariant={\"destructive\"}\n            cancelButtonVariant={\"outline\"}\n            title={confirmTitle ?? defaultConfirmTitle}\n            description={confirmDescription}\n            loading={loading}\n            onConfirm={onConfirm}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                loading={loading}\n                icon={<Trash2Icon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </ConfirmDialog>\n    );\n};\n\nDeleteButton.displayName = \"DeleteButton\";\n", "import * as React from \"react\"\nimport { ChevronRightIcon, DotsHorizontalIcon } from \"@radix-ui/react-icons\"\nimport { Slot } from \"@radix-ui/react-slot\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Breadcrumb = React.forwardRef<\n  HTMLElement,\n  React.ComponentPropsWithoutRef<\"nav\"> & {\n    separator?: React.ReactNode\n  }\n>(({ ...props }, ref) => <nav ref={ref} aria-label=\"breadcrumb\" {...props} />)\nBreadcrumb.displayName = \"Breadcrumb\"\n\nconst BreadcrumbList = React.forwardRef<\n  HTMLOListElement,\n  React.ComponentPropsWithoutRef<\"ol\">\n>(({ className, ...props }, ref) => (\n  <ol\n    ref={ref}\n    className={cn(\n      \"flex flex-wrap items-center gap-1.5 break-words text-sm text-muted-foreground sm:gap-2.5\",\n      className\n    )}\n    {...props}\n  />\n))\nBreadcrumbList.displayName = \"BreadcrumbList\"\n\nconst BreadcrumbItem = React.forwardRef<\n  HTMLLIElement,\n  React.ComponentPropsWithoutRef<\"li\">\n>(({ className, ...props }, ref) => (\n  <li\n    ref={ref}\n    className={cn(\"inline-flex items-center gap-1.5\", className)}\n    {...props}\n  />\n))\nBreadcrumbItem.displayName = \"BreadcrumbItem\"\n\nconst BreadcrumbLink = React.forwardRef<\n  HTMLAnchorElement,\n  React.ComponentPropsWithoutRef<\"a\"> & {\n    asChild?: boolean\n  }\n>(({ asChild, className, ...props }, ref) => {\n  const Comp = asChild ? Slot : \"a\"\n\n  return (\n    <Comp\n      ref={ref}\n      className={cn(\"transition-colors hover:text-foreground\", className)}\n      {...props}\n    />\n  )\n})\nBreadcrumbLink.displayName = \"BreadcrumbLink\"\n\nconst BreadcrumbPage = React.forwardRef<\n  HTMLSpanElement,\n  React.ComponentPropsWithoutRef<\"span\">\n>(({ className, ...props }, ref) => (\n  <span\n    ref={ref}\n    role=\"link\"\n    aria-disabled=\"true\"\n    aria-current=\"page\"\n    className={cn(\"font-normal text-foreground\", className)}\n    {...props}\n  />\n))\nBreadcrumbPage.displayName = \"BreadcrumbPage\"\n\nconst BreadcrumbSeparator = ({\n  children,\n  className,\n  ...props\n}: React.ComponentProps<\"li\">) => (\n  <li\n    role=\"presentation\"\n    aria-hidden=\"true\"\n    className={cn(\"[&>svg]:size-3.5\", className)}\n    {...props}\n  >\n    {children ?? <ChevronRightIcon />}\n  </li>\n)\nBreadcrumbSeparator.displayName = \"BreadcrumbSeparator\"\n\nconst BreadcrumbEllipsis = ({\n  className,\n  ...props\n}: React.ComponentProps<\"span\">) => (\n  <span\n    role=\"presentation\"\n    aria-hidden=\"true\"\n    className={cn(\"flex h-9 w-9 items-center justify-center\", className)}\n    {...props}\n  >\n    <DotsHorizontalIcon className=\"h-4 w-4\" />\n    <span className=\"sr-only\">More</span>\n  </span>\n)\nBreadcrumbEllipsis.displayName = \"BreadcrumbElipssis\"\n\nexport {\n  Breadcrumb,\n  BreadcrumbList,\n  BreadcrumbItem,\n  BreadcrumbLink,\n  BreadcrumbPage,\n  BreadcrumbSeparator,\n  BreadcrumbEllipsis,\n}\n", "import {\n    Breadcrumb,\n    BreadcrumbItem,\n    BreadcrumbLink,\n    BreadcrumbList,\n    BreadcrumbPage,\n    BreadcrumbSeparator,\n} from \"@/ui/breadcrumb\";\nimport {\n    matchResourceFromRoute,\n    useBreadcrumb,\n    useRefineContext,\n    useResource,\n} from \"@refinedev/core\";\nimport { RefineBreadcrumbProps } from \"@refinedev/ui-types\";\nimport { FC, Fragment } from \"react\";\nimport { Link } from \"./link\";\nimport { HomeIcon } from \"lucide-react\";\nexport type BreadcrumbProps = RefineBreadcrumbProps;\n\nexport const Breadcrumbs: FC<BreadcrumbProps> = ({ showHome = true, meta }) => {\n    const { breadcrumbs } = useBreadcrumb({\n        meta,\n    });\n\n    const { hasDashboard } = useRefineContext();\n\n    const { resources } = useResource();\n\n    const dashboardResource = resources[0];\n\n    const rootRouteResource = matchResourceFromRoute(\"/\", resources);\n\n    const BreadCrumbItems = breadcrumbs.map(({ label, href }, key) => (\n        <Fragment key={key}>\n            <BreadcrumbItem>\n                {href ? (\n                    <BreadcrumbLink asChild href={`#x`}>\n                        <Link href={href}>{label}</Link>\n                    </BreadcrumbLink>\n                ) : (\n                    <BreadcrumbPage>{label}</BreadcrumbPage>\n                )}\n            </BreadcrumbItem>\n            {key < breadcrumbs.length - 1 && <BreadcrumbSeparator />}\n        </Fragment>\n    ));\n\n    return (\n        <Breadcrumb>\n            <BreadcrumbList>\n                {showHome || hasDashboard || rootRouteResource.found ? (\n                    <>\n                        <BreadcrumbItem>\n                            <BreadcrumbLink\n                                href={dashboardResource.list?.toString()}\n                                asChild\n                                title={\n                                    dashboardResource?.meta?.title ??\n                                    dashboardResource.name ??\n                                    \"Dashboard\"\n                                }\n                            >\n                                <Link\n                                    href={dashboardResource.list?.toString()}\n                                    title={\n                                        dashboardResource?.meta?.title ??\n                                        dashboardResource.name ??\n                                        \"Dashboard\"\n                                    }\n                                >\n                                    {dashboardResource?.meta?.icon ?? (\n                                        <HomeIcon className=\"h-4 w-4\" />\n                                    )}\n                                </Link>\n                            </BreadcrumbLink>\n                        </BreadcrumbItem>\n                        <BreadcrumbSeparator />\n                    </>\n                ) : null}\n                {BreadCrumbItems}\n            </BreadcrumbList>\n        </Breadcrumb>\n    );\n};\n", "import { LayoutResource } from \"@/types\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { useLink, useRouterContext, useRouterType } from \"@refinedev/core\";\nimport { forwardRef } from \"react\";\n\ntype LinkProps = LayoutResource[\"link\"] & {\n    asChild?: boolean;\n};\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(\n    ({ children, href, title, className, asChild }, ref) => {\n        const { Link: LegacyLink } = useRouterContext();\n        const routerType = useRouterType();\n        const Link = useLink();\n\n        const ActiveLink = routerType === \"legacy\" ? LegacyLink : Link;\n        const Comp = asChild ? Slot : ActiveLink;\n\n        return (\n            <Comp ref={ref} to={href} className={className} title={title}>\n                {children}\n            </Comp>\n        );\n    },\n);\n\nLink.displayName = \"Link\";\n", "\"use client\";\n\nimport {\n    CalendarIcon,\n    EnvelopeClosedIcon,\n    FaceIcon,\n    GearIcon,\n    PersonIcon,\n    RocketIcon,\n} from \"@radix-ui/react-icons\";\nimport { CaretSortIcon, CheckIcon } from \"@radix-ui/react-icons\";\n\nimport { cn } from \"@/lib/utils\";\nimport {\n    Button,\n    Command,\n    CommandEmpty,\n    CommandGroup,\n    CommandInput,\n    CommandItem,\n    CommandList,\n    CommandSeparator,\n    CommandShortcut,\n    FormControl,\n    Popover,\n    PopoverContent,\n    PopoverTrigger,\n    ScrollArea,\n} from \"@/ui\";\nimport { BaseOption, BaseRecord, UseSelectReturnType } from \"@refinedev/core\";\nimport {\n    ComponentPropsWithoutRef,\n    forwardRef,\n    useState,\n    type ElementRef,\n} from \"react\";\n\ntype ComboboxProps = ComponentPropsWithoutRef<typeof Command> &\n    Pick<UseSelectReturnType<BaseOption, any>, \"options\"> & {\n        placeholder?: string;\n        emptyMessage?: string;\n        onChange?: (value: string | number) => void;\n        value?: string | number | BaseRecord;\n        disabled?: boolean;\n    };\n\nexport const Combobox = forwardRef<ElementRef<typeof Command>, ComboboxProps>(\n    ({ ...props }, ref) => {\n        const [open, setOpen] = useState(false);\n\n        const value = () => {\n            if (typeof props.value === \"object\" && \"id\" in props.value) {\n                return (props.value as BaseRecord).id;\n            }\n\n            return props.value;\n        };\n\n        return (\n            <Popover open={open} onOpenChange={setOpen}>\n                <PopoverTrigger asChild>\n                    <FormControl>\n                        <Button\n                            disabled={props.disabled}\n                            variant=\"outline\"\n                            role=\"combobox\"\n                            aria-expanded={open}\n                            className={cn(\n                                \"w-full sm:w-[250px] flex justify-between\",\n                                !value() && \"text-muted-foreground\",\n                            )}\n                        >\n                            {value()\n                                ? props.options?.find(\n                                      (option) => option.value === value(),\n                                  )?.label\n                                : props.placeholder ?? \"Select\"}\n                            <CaretSortIcon className=\"ml-2 h-4 w-4 shrink-0 opacity-50\" />\n                        </Button>\n                    </FormControl>\n                </PopoverTrigger>\n                <PopoverContent className=\"w-full max-w-full sm:w-[250px] p-0\">\n                    <Command className=\"rounded-lg border shadow-md\" ref={ref}>\n                        <CommandInput placeholder=\"Type a command or search...\" />\n                        <CommandList>\n                            <CommandEmpty>No results found.</CommandEmpty>\n                            <CommandGroup heading=\"Suggestions\">\n                                <ScrollArea className=\"max-h-52 overflow-y-auto\">\n                                    {props.options?.map((option) => (\n                                        <CommandItem\n                                            value={option.label}\n                                            key={option.value}\n                                            onSelect={() => {\n                                                props.onChange?.(option.value);\n                                                setOpen(false);\n                                            }}\n                                        >\n                                            {option.label}\n                                            <CheckIcon\n                                                className={cn(\n                                                    \"ml-auto h-4 w-4\",\n                                                    option.value === value()\n                                                        ? \"opacity-100\"\n                                                        : \"opacity-0\",\n                                                )}\n                                            />\n                                        </CommandItem>\n                                    ))}\n                                </ScrollArea>\n                            </CommandGroup>\n                        </CommandList>\n                    </Command>\n                </PopoverContent>\n            </Popover>\n        );\n    },\n);\n\nCombobox.displayName = \"Combobox\";\n", "\"use client\";\n\nimport { cn } from \"@/lib/utils\";\nimport * as AlertDialogPrimitive from \"@radix-ui/react-alert-dialog\";\nimport { VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\nimport { buttonVariants } from \"src/ui/button\";\n\nconst AlertDialog = AlertDialogPrimitive.Root;\n\nconst AlertDialogTrigger = AlertDialogPrimitive.Trigger;\n\nconst AlertDialogPortal = AlertDialogPrimitive.Portal;\n\nconst AlertDialogOverlay = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Overlay>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPrimitive.Overlay\n        className={cn(\n            \"fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n            className,\n        )}\n        {...props}\n        ref={ref}\n    />\n));\nAlertDialogOverlay.displayName = AlertDialogPrimitive.Overlay.displayName;\n\nconst AlertDialogContent = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Content>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPortal>\n        <AlertDialogOverlay />\n        <AlertDialogPrimitive.Content\n            ref={ref}\n            className={cn(\n                \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg\",\n                className,\n            )}\n            {...props}\n        />\n    </AlertDialogPortal>\n));\nAlertDialogContent.displayName = AlertDialogPrimitive.Content.displayName;\n\nconst AlertDialogHeader = ({\n    className,\n    ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n    <div\n        className={cn(\n            \"flex flex-col space-y-2 text-center sm:text-left\",\n            className,\n        )}\n        {...props}\n    />\n);\nAlertDialogHeader.displayName = \"AlertDialogHeader\";\n\nconst AlertDialogFooter = ({\n    className,\n    ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n    <div\n        className={cn(\n            \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n            className,\n        )}\n        {...props}\n    />\n);\nAlertDialogFooter.displayName = \"AlertDialogFooter\";\n\nconst AlertDialogTitle = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Title>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPrimitive.Title\n        ref={ref}\n        className={cn(\"text-lg font-semibold\", className)}\n        {...props}\n    />\n));\nAlertDialogTitle.displayName = AlertDialogPrimitive.Title.displayName;\n\nconst AlertDialogDescription = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Description>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n    <AlertDialogPrimitive.Description\n        ref={ref}\n        className={cn(\"text-sm text-muted-foreground\", className)}\n        {...props}\n    />\n));\nAlertDialogDescription.displayName =\n    AlertDialogPrimitive.Description.displayName;\n\nconst AlertDialogAction = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Action> &\n        VariantProps<typeof buttonVariants>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Action> &\n        VariantProps<typeof buttonVariants>\n>(({ className, variant = \"default\", size = \"default\", ...props }, ref) => (\n    <AlertDialogPrimitive.Action\n        ref={ref}\n        className={cn(\n            buttonVariants({\n                variant,\n                size,\n            }),\n            className,\n        )}\n        {...props}\n    />\n));\nAlertDialogAction.displayName = AlertDialogPrimitive.Action.displayName;\n\nconst AlertDialogCancel = React.forwardRef<\n    React.ElementRef<typeof AlertDialogPrimitive.Cancel> &\n        VariantProps<typeof buttonVariants>,\n    React.ComponentPropsWithoutRef<typeof AlertDialogPrimitive.Cancel> &\n        VariantProps<typeof buttonVariants>\n>(({ className, variant = \"outline\", size = \"default\", ...props }, ref) => (\n    <AlertDialogPrimitive.Cancel\n        ref={ref}\n        className={cn(\n            buttonVariants({ variant, size }),\n            \"mt-2 sm:mt-0\",\n            className,\n        )}\n        {...props}\n    />\n));\nAlertDialogCancel.displayName = AlertDialogPrimitive.Cancel.displayName;\n\nexport {\n    AlertDialog,\n    AlertDialogAction,\n    AlertDialogCancel,\n    AlertDialogContent,\n    AlertDialogDescription,\n    AlertDialogFooter,\n    AlertDialogHeader,\n    AlertDialogOverlay,\n    AlertDialogPortal,\n    AlertDialogTitle,\n    AlertDialogTrigger,\n};\n", "import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst badgeVariants = cva(\n  \"inline-flex items-center rounded-md border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2\",\n  {\n    variants: {\n      variant: {\n        default:\n          \"border-transparent bg-primary text-primary-foreground shadow hover:bg-primary/80\",\n        secondary:\n          \"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n        destructive:\n          \"border-transparent bg-destructive text-destructive-foreground shadow hover:bg-destructive/80\",\n        outline: \"text-foreground\",\n      },\n    },\n    defaultVariants: {\n      variant: \"default\",\n    },\n  }\n)\n\nexport interface BadgeProps\n  extends React.HTMLAttributes<HTMLDivElement>,\n    VariantProps<typeof badgeVariants> {}\n\nfunction Badge({ className, variant, ...props }: BadgeProps) {\n  return (\n    <div className={cn(badgeVariants({ variant }), className)} {...props} />\n  )\n}\n\nexport { Badge, badgeVariants }\n", "\"use client\";\n\nimport * as React from \"react\";\nimport { ChevronLeftIcon, ChevronRightIcon } from \"@radix-ui/react-icons\";\nimport { DayPicker } from \"react-day-picker\";\n\nimport { cn } from \"@/lib/utils\";\nimport { buttonVariants } from \"src/ui/button\";\n\nexport type CalendarProps = React.ComponentProps<typeof DayPicker>;\n\nfunction Calendar({\n    className,\n    classNames,\n    showOutsideDays = true,\n    ...props\n}: CalendarProps) {\n    return (\n        <DayPicker\n            showOutsideDays={showOutsideDays}\n            className={cn(\"p-3\", className)}\n            classNames={{\n                months: \"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0\",\n                month: \"space-y-4\",\n                caption: \"flex justify-center pt-1 relative items-center\",\n                caption_label: \"text-sm font-medium\",\n                nav: \"space-x-1 flex items-center\",\n                nav_button: cn(\n                    buttonVariants({ variant: \"outline\" }),\n                    \"h-7 w-7 bg-transparent p-0 opacity-50 hover:opacity-100\",\n                ),\n                nav_button_previous: \"absolute left-1\",\n                nav_button_next: \"absolute right-1\",\n                table: \"w-full border-collapse space-y-1\",\n                head_row: \"flex\",\n                head_cell:\n                    \"text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]\",\n                row: \"flex w-full mt-2\",\n                cell: cn(\n                    \"relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected].day-range-end)]:rounded-r-md\",\n                    props.mode === \"range\"\n                        ? \"[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md\"\n                        : \"[&:has([aria-selected])]:rounded-md\",\n                ),\n                day: cn(\n                    buttonVariants({ variant: \"ghost\" }),\n                    \"h-8 w-8 p-0 font-normal aria-selected:opacity-100\",\n                ),\n                day_range_start: \"day-range-start\",\n                day_range_end: \"day-range-end\",\n                day_selected:\n                    \"bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground\",\n                day_today: \"bg-accent text-accent-foreground\",\n                day_outside:\n                    \"day-outside text-muted-foreground opacity-50  aria-selected:bg-accent/50 aria-selected:text-muted-foreground aria-selected:opacity-30\",\n                day_disabled: \"text-muted-foreground opacity-50\",\n                day_range_middle:\n                    \"aria-selected:bg-accent aria-selected:text-accent-foreground\",\n                day_hidden: \"invisible\",\n                ...classNames,\n            }}\n            components={{\n                IconLeft: () => <ChevronLeftIcon className=\"h-4 w-4\" />,\n                IconRight: () => <ChevronRightIcon className=\"h-4 w-4\" />,\n            }}\n            {...props}\n        />\n    );\n}\nCalendar.displayName = \"Calendar\";\n\nexport { Calendar };\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Card = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div\n    ref={ref}\n    className={cn(\n      \"rounded-xl border bg-card text-card-foreground shadow\",\n      className\n    )}\n    {...props}\n  />\n))\nCard.displayName = \"Card\"\n\nconst CardHeader = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div\n    ref={ref}\n    className={cn(\"flex flex-col space-y-1.5 p-6\", className)}\n    {...props}\n  />\n))\nCardHeader.displayName = \"CardHeader\"\n\nconst CardTitle = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLHeadingElement>\n>(({ className, ...props }, ref) => (\n  <h3\n    ref={ref}\n    className={cn(\"font-semibold leading-none tracking-tight\", className)}\n    {...props}\n  />\n))\nCardTitle.displayName = \"CardTitle\"\n\nconst CardDescription = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, ...props }, ref) => (\n  <p\n    ref={ref}\n    className={cn(\"text-sm text-muted-foreground\", className)}\n    {...props}\n  />\n))\nCardDescription.displayName = \"CardDescription\"\n\nconst CardContent = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div ref={ref} className={cn(\"p-6 pt-0\", className)} {...props} />\n))\nCardContent.displayName = \"CardContent\"\n\nconst CardFooter = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => (\n  <div\n    ref={ref}\n    className={cn(\"flex items-center p-6 pt-0\", className)}\n    {...props}\n  />\n))\nCardFooter.displayName = \"CardFooter\"\n\nexport { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent }\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as CheckboxPrimitive from \"@radix-ui/react-checkbox\"\nimport { CheckIcon } from \"@radix-ui/react-icons\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Checkbox = React.forwardRef<\n  React.ElementRef<typeof CheckboxPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>\n>(({ className, ...props }, ref) => (\n  <CheckboxPrimitive.Root\n    ref={ref}\n    className={cn(\n      \"peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground\",\n      className\n    )}\n    {...props}\n  >\n    <CheckboxPrimitive.Indicator\n      className={cn(\"flex items-center justify-center text-current\")}\n    >\n      <CheckIcon className=\"h-4 w-4\" />\n    </CheckboxPrimitive.Indicator>\n  </CheckboxPrimitive.Root>\n))\nCheckbox.displayName = CheckboxPrimitive.Root.displayName\n\nexport { Checkbox }\n", "\"use client\"\n\nimport * as React from \"react\"\nimport { type DialogProps } from \"@radix-ui/react-dialog\"\nimport { MagnifyingGlassIcon } from \"@radix-ui/react-icons\"\nimport { Command as CommandPrimitive } from \"cmdk\"\n\nimport { cn } from \"@/lib/utils\"\nimport { Dialog, DialogContent } from \"src/ui/dialog\"\n\nconst Command = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive\n    ref={ref}\n    className={cn(\n      \"flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground\",\n      className\n    )}\n    {...props}\n  />\n))\nCommand.displayName = CommandPrimitive.displayName\n\ninterface CommandDialogProps extends DialogProps {}\n\nconst CommandDialog = ({ children, ...props }: CommandDialogProps) => {\n  return (\n    <Dialog {...props}>\n      <DialogContent className=\"overflow-hidden p-0\">\n        <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n          {children}\n        </Command>\n      </DialogContent>\n    </Dialog>\n  )\n}\n\nconst CommandInput = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Input>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>\n>(({ className, ...props }, ref) => (\n  <div className=\"flex items-center border-b px-3\" cmdk-input-wrapper=\"\">\n    <MagnifyingGlassIcon className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n    <CommandPrimitive.Input\n      ref={ref}\n      className={cn(\n        \"flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50\",\n        className\n      )}\n      {...props}\n    />\n  </div>\n))\n\nCommandInput.displayName = CommandPrimitive.Input.displayName\n\nconst CommandList = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.List>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.List\n    ref={ref}\n    className={cn(\"max-h-[300px] overflow-y-auto overflow-x-hidden\", className)}\n    {...props}\n  />\n))\n\nCommandList.displayName = CommandPrimitive.List.displayName\n\nconst CommandEmpty = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Empty>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => (\n  <CommandPrimitive.Empty\n    ref={ref}\n    className=\"py-6 text-center text-sm\"\n    {...props}\n  />\n))\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName\n\nconst CommandGroup = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Group>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.Group\n    ref={ref}\n    className={cn(\n      \"overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground\",\n      className\n    )}\n    {...props}\n  />\n))\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName\n\nconst CommandSeparator = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Separator>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.Separator\n    ref={ref}\n    className={cn(\"-mx-1 h-px bg-border\", className)}\n    {...props}\n  />\n))\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName\n\nconst CommandItem = React.forwardRef<\n  React.ElementRef<typeof CommandPrimitive.Item>,\n  React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n  <CommandPrimitive.Item\n    ref={ref}\n    className={cn(\n      \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50\",\n      className\n    )}\n    {...props}\n  />\n))\n\nCommandItem.displayName = CommandPrimitive.Item.displayName\n\nconst CommandShortcut = ({\n  className,\n  ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n  return (\n    <span\n      className={cn(\n        \"ml-auto text-xs tracking-widest text-muted-foreground\",\n        className\n      )}\n      {...props}\n    />\n  )\n}\nCommandShortcut.displayName = \"CommandShortcut\"\n\nexport {\n  Command,\n  CommandDialog,\n  CommandInput,\n  CommandList,\n  CommandEmpty,\n  CommandGroup,\n  CommandItem,\n  CommandShortcut,\n  CommandSeparator,\n}\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\"\nimport { Cross2Icon } from \"@radix-ui/react-icons\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Dialog = DialogPrimitive.Root\n\nconst DialogTrigger = DialogPrimitive.Trigger\n\nconst DialogPortal = DialogPrimitive.Portal\n\nconst DialogClose = DialogPrimitive.Close\n\nconst DialogOverlay = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Overlay>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n  <DialogPrimitive.Overlay\n    ref={ref}\n    className={cn(\n      \"fixed inset-0 z-50 bg-black/80  data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n      className\n    )}\n    {...props}\n  />\n))\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName\n\nconst DialogContent = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Content>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n  <DialogPortal>\n    <DialogOverlay />\n    <DialogPrimitive.Content\n      ref={ref}\n      className={cn(\n        \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 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-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg\",\n        className\n      )}\n      {...props}\n    >\n      {children}\n      <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n        <Cross2Icon className=\"h-4 w-4\" />\n        <span className=\"sr-only\">Close</span>\n      </DialogPrimitive.Close>\n    </DialogPrimitive.Content>\n  </DialogPortal>\n))\nDialogContent.displayName = DialogPrimitive.Content.displayName\n\nconst DialogHeader = ({\n  className,\n  ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n  <div\n    className={cn(\n      \"flex flex-col space-y-1.5 text-center sm:text-left\",\n      className\n    )}\n    {...props}\n  />\n)\nDialogHeader.displayName = \"DialogHeader\"\n\nconst DialogFooter = ({\n  className,\n  ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n  <div\n    className={cn(\n      \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n      className\n    )}\n    {...props}\n  />\n)\nDialogFooter.displayName = \"DialogFooter\"\n\nconst DialogTitle = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Title>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n  <DialogPrimitive.Title\n    ref={ref}\n    className={cn(\n      \"text-lg font-semibold leading-none tracking-tight\",\n      className\n    )}\n    {...props}\n  />\n))\nDialogTitle.displayName = DialogPrimitive.Title.displayName\n\nconst DialogDescription = React.forwardRef<\n  React.ElementRef<typeof DialogPrimitive.Description>,\n  React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n  <DialogPrimitive.Description\n    ref={ref}\n    className={cn(\"text-sm text-muted-foreground\", className)}\n    {...props}\n  />\n))\nDialogDescription.displayName = DialogPrimitive.Description.displayName\n\nexport {\n  Dialog,\n  DialogPortal,\n  DialogOverlay,\n  DialogTrigger,\n  DialogClose,\n  DialogContent,\n  DialogHeader,\n  DialogFooter,\n  DialogTitle,\n  DialogDescription,\n}\n", "\"use client\";\n\nimport * as React from \"react\";\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\";\nimport {\n    CheckIcon,\n    ChevronRightIcon,\n    DotFilledIcon,\n} from \"@radix-ui/react-icons\";\n\nimport { cn } from \"../lib/utils\";\n\nconst DropdownMenu = DropdownMenuPrimitive.Root;\n\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger;\n\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group;\n\nconst DropdownMenuPortal = DropdownMenuPrimitive.Portal;\n\nconst DropdownMenuSub = DropdownMenuPrimitive.Sub;\n\nconst DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup;\n\nconst DropdownMenuSubTrigger = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.SubTrigger>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> & {\n        inset?: boolean;\n    }\n>(({ className, inset, children, ...props }, ref) => (\n    <DropdownMenuPrimitive.SubTrigger\n        ref={ref}\n        className={cn(\n            \"flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent\",\n            inset && \"pl-8\",\n            className,\n        )}\n        {...props}\n    >\n        {children}\n        <ChevronRightIcon className=\"ml-auto h-4 w-4\" />\n    </DropdownMenuPrimitive.SubTrigger>\n));\nDropdownMenuSubTrigger.displayName =\n    DropdownMenuPrimitive.SubTrigger.displayName;\n\nconst DropdownMenuSubContent = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.SubContent>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n    <DropdownMenuPrimitive.SubContent\n        ref={ref}\n        className={cn(\n            \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg 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\",\n            className,\n        )}\n        {...props}\n    />\n));\nDropdownMenuSubContent.displayName =\n    DropdownMenuPrimitive.SubContent.displayName;\n\nconst DropdownMenuContent = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n    <DropdownMenuPrimitive.Portal>\n        <DropdownMenuPrimitive.Content\n            ref={ref}\n            sideOffset={sideOffset}\n            className={cn(\n                \"z-50 min-w-[8rem] overflow-hidden rounded-md border border-border bg-popover p-1 text-popover-foreground shadow-md\",\n                \"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\",\n                className,\n            )}\n            {...props}\n        />\n    </DropdownMenuPrimitive.Portal>\n));\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName;\n\nconst DropdownMenuItem = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> & {\n        inset?: boolean;\n    }\n>(({ className, inset, ...props }, ref) => (\n    <DropdownMenuPrimitive.Item\n        ref={ref}\n        className={cn(\n            \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            inset && \"pl-8\",\n            className,\n        )}\n        {...props}\n    />\n));\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName;\n\nconst DropdownMenuCheckboxItem = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.CheckboxItem>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n    <DropdownMenuPrimitive.CheckboxItem\n        ref={ref}\n        className={cn(\n            \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            className,\n        )}\n        checked={checked}\n        {...props}\n    >\n        <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n            <DropdownMenuPrimitive.ItemIndicator>\n                <CheckIcon className=\"h-4 w-4\" />\n            </DropdownMenuPrimitive.ItemIndicator>\n        </span>\n        {children}\n    </DropdownMenuPrimitive.CheckboxItem>\n));\nDropdownMenuCheckboxItem.displayName =\n    DropdownMenuPrimitive.CheckboxItem.displayName;\n\nconst DropdownMenuRadioItem = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.RadioItem>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n    <DropdownMenuPrimitive.RadioItem\n        ref={ref}\n        className={cn(\n            \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            className,\n        )}\n        {...props}\n    >\n        <span className=\"absolute left-2 flex h-3.5 w-3.5 items-center justify-center\">\n            <DropdownMenuPrimitive.ItemIndicator>\n                <DotFilledIcon className=\"h-4 w-4 fill-current\" />\n            </DropdownMenuPrimitive.ItemIndicator>\n        </span>\n        {children}\n    </DropdownMenuPrimitive.RadioItem>\n));\nDropdownMenuRadioItem.displayName = DropdownMenuPrimitive.RadioItem.displayName;\n\nconst DropdownMenuLabel = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Label>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> & {\n        inset?: boolean;\n    }\n>(({ className, inset, ...props }, ref) => (\n    <DropdownMenuPrimitive.Label\n        ref={ref}\n        className={cn(\n            \"px-2 py-1.5 text-sm font-semibold\",\n            inset && \"pl-8\",\n            className,\n        )}\n        {...props}\n    />\n));\nDropdownMenuLabel.displayName = DropdownMenuPrimitive.Label.displayName;\n\nconst DropdownMenuSeparator = React.forwardRef<\n    React.ElementRef<typeof DropdownMenuPrimitive.Separator>,\n    React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n    <DropdownMenuPrimitive.Separator\n        ref={ref}\n        className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\n        {...props}\n    />\n));\nDropdownMenuSeparator.displayName = DropdownMenuPrimitive.Separator.displayName;\n\nconst DropdownMenuShortcut = ({\n    className,\n    ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n    return (\n        <span\n            className={cn(\n                \"ml-auto text-xs tracking-widest opacity-60\",\n                className,\n            )}\n            {...props}\n        />\n    );\n};\nDropdownMenuShortcut.displayName = \"DropdownMenuShortcut\";\n\nexport {\n    DropdownMenu,\n    DropdownMenuTrigger,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuCheckboxItem,\n    DropdownMenuRadioItem,\n    DropdownMenuLabel,\n    DropdownMenuSeparator,\n    DropdownMenuShortcut,\n    DropdownMenuGroup,\n    DropdownMenuPortal,\n    DropdownMenuSub,\n    DropdownMenuSubContent,\n    DropdownMenuSubTrigger,\n    DropdownMenuRadioGroup,\n};\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport {\n  Controller,\n  ControllerProps,\n  FieldPath,\n  FieldValues,\n  FormProvider,\n  useFormContext,\n} from \"react-hook-form\"\n\nimport { cn } from \"@/lib/utils\"\nimport { Label } from \"src/ui/label\"\n\nconst Form = FormProvider\n\ntype FormFieldContextValue<\n  TFieldValues extends FieldValues = FieldValues,\n  TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> = {\n  name: TName\n}\n\nconst FormFieldContext = React.createContext<FormFieldContextValue>(\n  {} as FormFieldContextValue\n)\n\nconst FormField = <\n  TFieldValues extends FieldValues = FieldValues,\n  TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n>({\n  ...props\n}: ControllerProps<TFieldValues, TName>) => {\n  return (\n    <FormFieldContext.Provider value={{ name: props.name }}>\n      <Controller {...props} />\n    </FormFieldContext.Provider>\n  )\n}\n\nconst useFormField = () => {\n  const fieldContext = React.useContext(FormFieldContext)\n  const itemContext = React.useContext(FormItemContext)\n  const { getFieldState, formState } = useFormContext()\n\n  const fieldState = getFieldState(fieldContext.name, formState)\n\n  if (!fieldContext) {\n    throw new Error(\"useFormField should be used within <FormField>\")\n  }\n\n  const { id } = itemContext\n\n  return {\n    id,\n    name: fieldContext.name,\n    formItemId: `${id}-form-item`,\n    formDescriptionId: `${id}-form-item-description`,\n    formMessageId: `${id}-form-item-message`,\n    ...fieldState,\n  }\n}\n\ntype FormItemContextValue = {\n  id: string\n}\n\nconst FormItemContext = React.createContext<FormItemContextValue>(\n  {} as FormItemContextValue\n)\n\nconst FormItem = React.forwardRef<\n  HTMLDivElement,\n  React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => {\n  const id = React.useId()\n\n  return (\n    <FormItemContext.Provider value={{ id }}>\n      <div ref={ref} className={cn(\"space-y-2\", className)} {...props} />\n    </FormItemContext.Provider>\n  )\n})\nFormItem.displayName = \"FormItem\"\n\nconst FormLabel = React.forwardRef<\n  React.ElementRef<typeof LabelPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root>\n>(({ className, ...props }, ref) => {\n  const { error, formItemId } = useFormField()\n\n  return (\n    <Label\n      ref={ref}\n      className={cn(error && \"text-destructive\", className)}\n      htmlFor={formItemId}\n      {...props}\n    />\n  )\n})\nFormLabel.displayName = \"FormLabel\"\n\nconst FormControl = React.forwardRef<\n  React.ElementRef<typeof Slot>,\n  React.ComponentPropsWithoutRef<typeof Slot>\n>(({ ...props }, ref) => {\n  const { error, formItemId, formDescriptionId, formMessageId } = useFormField()\n\n  return (\n    <Slot\n      ref={ref}\n      id={formItemId}\n      aria-describedby={\n        !error\n          ? `${formDescriptionId}`\n          : `${formDescriptionId} ${formMessageId}`\n      }\n      aria-invalid={!!error}\n      {...props}\n    />\n  )\n})\nFormControl.displayName = \"FormControl\"\n\nconst FormDescription = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, ...props }, ref) => {\n  const { formDescriptionId } = useFormField()\n\n  return (\n    <p\n      ref={ref}\n      id={formDescriptionId}\n      className={cn(\"text-[0.8rem] text-muted-foreground\", className)}\n      {...props}\n    />\n  )\n})\nFormDescription.displayName = \"FormDescription\"\n\nconst FormMessage = React.forwardRef<\n  HTMLParagraphElement,\n  React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, children, ...props }, ref) => {\n  const { error, formMessageId } = useFormField()\n  const body = error ? String(error?.message) : children\n\n  if (!body) {\n    return null\n  }\n\n  return (\n    <p\n      ref={ref}\n      id={formMessageId}\n      className={cn(\"text-[0.8rem] font-medium text-destructive\", className)}\n      {...props}\n    >\n      {body}\n    </p>\n  )\n})\nFormMessage.displayName = \"FormMessage\"\n\nexport {\n  useFormField,\n  Form,\n  FormItem,\n  FormLabel,\n  FormControl,\n  FormDescription,\n  FormMessage,\n  FormField,\n}\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as LabelPrimitive from \"@radix-ui/react-label\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst labelVariants = cva(\n  \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\"\n)\n\nconst Label = React.forwardRef<\n  React.ElementRef<typeof LabelPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &\n    VariantProps<typeof labelVariants>\n>(({ className, ...props }, ref) => (\n  <LabelPrimitive.Root\n    ref={ref}\n    className={cn(labelVariants(), className)}\n    {...props}\n  />\n))\nLabel.displayName = LabelPrimitive.Root.displayName\n\nexport { Label }\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nexport interface InputProps\n  extends React.InputHTMLAttributes<HTMLInputElement> {}\n\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n  ({ className, type, ...props }, ref) => {\n    return (\n      <input\n        type={type}\n        className={cn(\n          \"flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50\",\n          className\n        )}\n        ref={ref}\n        {...props}\n      />\n    )\n  }\n)\nInput.displayName = \"Input\"\n\nexport { Input }\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Popover = PopoverPrimitive.Root\n\nconst PopoverTrigger = PopoverPrimitive.Trigger\n\nconst PopoverAnchor = PopoverPrimitive.Anchor\n\nconst PopoverContent = React.forwardRef<\n  React.ElementRef<typeof PopoverPrimitive.Content>,\n  React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>\n>(({ className, align = \"center\", sideOffset = 4, ...props }, ref) => (\n  <PopoverPrimitive.Portal>\n    <PopoverPrimitive.Content\n      ref={ref}\n      align={align}\n      sideOffset={sideOffset}\n      className={cn(\n        \"z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none 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\",\n        className\n      )}\n      {...props}\n    />\n  </PopoverPrimitive.Portal>\n))\nPopoverContent.displayName = PopoverPrimitive.Content.displayName\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n", "\"use client\";\n\nimport { DragHandleDots2Icon } from \"@radix-ui/react-icons\";\nimport * as ResizablePrimitive from \"react-resizable-panels\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst ResizablePanelGroup = ({\n    className,\n    ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelGroup>) => (\n    <ResizablePrimitive.PanelGroup\n        className={cn(\n            \"flex h-full w-full data-[panel-group-direction=vertical]:flex-col\",\n            className,\n        )}\n        {...props}\n    />\n);\n\nconst ResizablePanel = ResizablePrimitive.Panel;\n\nconst ResizableHandle = ({\n    withHandle,\n    className,\n    ...props\n}: React.ComponentProps<typeof ResizablePrimitive.PanelResizeHandle> & {\n    withHandle?: boolean;\n}) => (\n    <ResizablePrimitive.PanelResizeHandle\n        className={cn(\n            \"relative flex w-px items-center justify-center bg-border after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring focus-visible:ring-offset-1 data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:-translate-y-1/2 data-[panel-group-direction=vertical]:after:translate-x-0 [&[data-panel-group-direction=vertical]>div]:rotate-90\",\n            className,\n        )}\n        {...props}\n    >\n        {withHandle && (\n            <div className=\"z-10 flex h-4 w-3 items-center justify-center rounded-sm border bg-border\">\n                <DragHandleDots2Icon className=\"h-2.5 w-2.5\" />\n            </div>\n        )}\n    </ResizablePrimitive.PanelResizeHandle>\n);\n\nexport { ResizablePanelGroup, ResizablePanel, ResizableHandle };\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as ScrollAreaPrimitive from \"@radix-ui/react-scroll-area\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst ScrollArea = React.forwardRef<\n  React.ElementRef<typeof ScrollAreaPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.Root>\n>(({ className, children, ...props }, ref) => (\n  <ScrollAreaPrimitive.Root\n    ref={ref}\n    className={cn(\"relative overflow-hidden\", className)}\n    {...props}\n  >\n    <ScrollAreaPrimitive.Viewport className=\"h-full w-full rounded-[inherit]\">\n      {children}\n    </ScrollAreaPrimitive.Viewport>\n    <ScrollBar />\n    <ScrollAreaPrimitive.Corner />\n  </ScrollAreaPrimitive.Root>\n))\nScrollArea.displayName = ScrollAreaPrimitive.Root.displayName\n\nconst ScrollBar = React.forwardRef<\n  React.ElementRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>,\n  React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>\n>(({ className, orientation = \"vertical\", ...props }, ref) => (\n  <ScrollAreaPrimitive.ScrollAreaScrollbar\n    ref={ref}\n    orientation={orientation}\n    className={cn(\n      \"flex touch-none select-none transition-colors\",\n      orientation === \"vertical\" &&\n        \"h-full w-2.5 border-l border-l-transparent p-[1px]\",\n      orientation === \"horizontal\" &&\n        \"h-2.5 flex-col border-t border-t-transparent p-[1px]\",\n      className\n    )}\n    {...props}\n  >\n    <ScrollAreaPrimitive.ScrollAreaThumb className=\"relative flex-1 rounded-full bg-border\" />\n  </ScrollAreaPrimitive.ScrollAreaScrollbar>\n))\nScrollBar.displayName = ScrollAreaPrimitive.ScrollAreaScrollbar.displayName\n\nexport { ScrollArea, ScrollBar }\n", "\"use client\";\n\nimport * as React from \"react\";\nimport {\n    CaretSortIcon,\n    CheckIcon,\n    ChevronDownIcon,\n    ChevronUpIcon,\n} from \"@radix-ui/react-icons\";\nimport * as SelectPrimitive from \"@radix-ui/react-select\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Select = SelectPrimitive.Root;\n\nconst SelectGroup = SelectPrimitive.Group;\n\nconst SelectValue = SelectPrimitive.Value;\n\nconst SelectTrigger = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Trigger>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Trigger>\n>(({ className, children, ...props }, ref) => (\n    <SelectPrimitive.Trigger\n        ref={ref}\n        className={cn(\n            \"flex h-9 w-full items-center justify-between whitespace-nowrap rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-1 focus:ring-ring disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1\",\n            className,\n        )}\n        {...props}\n    >\n        {children}\n        <SelectPrimitive.Icon asChild>\n            <CaretSortIcon className=\"h-4 w-4 opacity-50\" />\n        </SelectPrimitive.Icon>\n    </SelectPrimitive.Trigger>\n));\nSelectTrigger.displayName = SelectPrimitive.Trigger.displayName;\n\nconst SelectScrollUpButton = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.ScrollUpButton>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.ScrollUpButton>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.ScrollUpButton\n        ref={ref}\n        className={cn(\n            \"flex cursor-default items-center justify-center py-1\",\n            className,\n        )}\n        {...props}\n    >\n        <ChevronUpIcon />\n    </SelectPrimitive.ScrollUpButton>\n));\nSelectScrollUpButton.displayName = SelectPrimitive.ScrollUpButton.displayName;\n\nconst SelectScrollDownButton = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.ScrollDownButton>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.ScrollDownButton>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.ScrollDownButton\n        ref={ref}\n        className={cn(\n            \"flex cursor-default items-center justify-center py-1\",\n            className,\n        )}\n        {...props}\n    >\n        <ChevronDownIcon />\n    </SelectPrimitive.ScrollDownButton>\n));\nSelectScrollDownButton.displayName =\n    SelectPrimitive.ScrollDownButton.displayName;\n\nconst SelectContent = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Content>\n>(({ className, children, position = \"popper\", ...props }, ref) => (\n    <SelectPrimitive.Portal>\n        <SelectPrimitive.Content\n            ref={ref}\n            className={cn(\n                \"relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md 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\",\n                position === \"popper\" &&\n                    \"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1\",\n                className,\n            )}\n            position={position}\n            {...props}\n        >\n            <SelectScrollUpButton />\n            <SelectPrimitive.Viewport\n                className={cn(\n                    \"p-1\",\n                    position === \"popper\" &&\n                        \"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]\",\n                )}\n            >\n                {children}\n            </SelectPrimitive.Viewport>\n            <SelectScrollDownButton />\n        </SelectPrimitive.Content>\n    </SelectPrimitive.Portal>\n));\nSelectContent.displayName = SelectPrimitive.Content.displayName;\n\nconst SelectLabel = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Label>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Label>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.Label\n        ref={ref}\n        className={cn(\"px-2 py-1.5 text-sm font-semibold\", className)}\n        {...props}\n    />\n));\nSelectLabel.displayName = SelectPrimitive.Label.displayName;\n\nconst SelectItem = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Item>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item>\n>(({ className, children, ...props }, ref) => (\n    <SelectPrimitive.Item\n        ref={ref}\n        className={cn(\n            \"relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-2 pr-8 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n            className,\n        )}\n        {...props}\n    >\n        <span className=\"absolute right-2 flex h-3.5 w-3.5 items-center justify-center\">\n            <SelectPrimitive.ItemIndicator>\n                <CheckIcon className=\"h-4 w-4\" />\n            </SelectPrimitive.ItemIndicator>\n        </span>\n        <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n    </SelectPrimitive.Item>\n));\nSelectItem.displayName = SelectPrimitive.Item.displayName;\n\nconst SelectSeparator = React.forwardRef<\n    React.ElementRef<typeof SelectPrimitive.Separator>,\n    React.ComponentPropsWithoutRef<typeof SelectPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n    <SelectPrimitive.Separator\n        ref={ref}\n        className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\n        {...props}\n    />\n));\nSelectSeparator.displayName = SelectPrimitive.Separator.displayName;\n\nexport {\n    Select,\n    SelectGroup,\n    SelectValue,\n    SelectTrigger,\n    SelectContent,\n    SelectLabel,\n    SelectItem,\n    SelectSeparator,\n    SelectScrollUpButton,\n    SelectScrollDownButton,\n};\n", "\"use client\"\n\nimport * as React from \"react\"\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Separator = React.forwardRef<\n  React.ElementRef<typeof SeparatorPrimitive.Root>,\n  React.ComponentPropsWithoutRef<typeof SeparatorPrimitive.Root>\n>(\n  (\n    { className, orientation = \"horizontal\", decorative = true, ...props },\n    ref\n  ) => (\n    <SeparatorPrimitive.Root\n      ref={ref}\n      decorative={decorative}\n      orientation={orientation}\n      className={cn(\n        \"shrink-0 bg-border\",\n        orientation === \"horizontal\" ? \"h-[1px] w-full\" : \"h-full w-[1px]\",\n        className\n      )}\n      {...props}\n    />\n  )\n)\nSeparator.displayName = SeparatorPrimitive.Root.displayName\n\nexport { Separator }\n", "\"use client\";\n\nimport { useTheme } from \"next-themes\";\nimport { Toaster as Sonner } from \"sonner\";\n\ntype ToasterProps = React.ComponentProps<typeof Sonner>;\n\nconst Toaster = ({ ...props }: ToasterProps) => {\n    const { theme = \"system\" } = useTheme();\n\n    return (\n        <Sonner\n            theme={theme as ToasterProps[\"theme\"]}\n            className=\"toaster group\"\n            toastOptions={{\n                classNames: {\n                    toast: \"group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg\",\n                    description: \"group-[.toast]:text-muted-foreground\",\n                    actionButton:\n                        \"group-[.toast]:bg-primary group-[.toast]:text-primary-foreground\",\n                    cancelButton:\n                        \"group-[.toast]:bg-muted group-[.toast]:text-muted-foreground\",\n                },\n            }}\n            {...props}\n        />\n    );\n};\n\nexport { Toaster };\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst Table = React.forwardRef<\n  HTMLTableElement,\n  React.HTMLAttributes<HTMLTableElement>\n>(({ className, ...props }, ref) => (\n  <div className=\"relative w-full overflow-auto\">\n    <table\n      ref={ref}\n      className={cn(\"w-full caption-bottom text-sm\", className)}\n      {...props}\n    />\n  </div>\n))\nTable.displayName = \"Table\"\n\nconst TableHeader = React.forwardRef<\n  HTMLTableSectionElement,\n  React.HTMLAttributes<HTMLTableSectionElement>\n>(({ className, ...props }, ref) => (\n  <thead ref={ref} className={cn(\"[&_tr]:border-b\", className)} {...props} />\n))\nTableHeader.displayName = \"TableHeader\"\n\nconst TableBody = React.forwardRef<\n  HTMLTableSectionElement,\n  React.HTMLAttributes<HTMLTableSectionElement>\n>(({ className, ...props }, ref) => (\n  <tbody\n    ref={ref}\n    className={cn(\"[&_tr:last-child]:border-0\", className)}\n    {...props}\n  />\n))\nTableBody.displayName = \"TableBody\"\n\nconst TableFooter = React.forwardRef<\n  HTMLTableSectionElement,\n  React.HTMLAttributes<HTMLTableSectionElement>\n>(({ className, ...props }, ref) => (\n  <tfoot\n    ref={ref}\n    className={cn(\n      \"border-t bg-muted/50 font-medium [&>tr]:last:border-b-0\",\n      className\n    )}\n    {...props}\n  />\n))\nTableFooter.displayName = \"TableFooter\"\n\nconst TableRow = React.forwardRef<\n  HTMLTableRowElement,\n  React.HTMLAttributes<HTMLTableRowElement>\n>(({ className, ...props }, ref) => (\n  <tr\n    ref={ref}\n    className={cn(\n      \"border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted\",\n      className\n    )}\n    {...props}\n  />\n))\nTableRow.displayName = \"TableRow\"\n\nconst TableHead = React.forwardRef<\n  HTMLTableCellElement,\n  React.ThHTMLAttributes<HTMLTableCellElement>\n>(({ className, ...props }, ref) => (\n  <th\n    ref={ref}\n    className={cn(\n      \"h-10 px-2 text-left align-middle font-medium text-muted-foreground [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]\",\n      className\n    )}\n    {...props}\n  />\n))\nTableHead.displayName = \"TableHead\"\n\nconst TableCell = React.forwardRef<\n  HTMLTableCellElement,\n  React.TdHTMLAttributes<HTMLTableCellElement>\n>(({ className, ...props }, ref) => (\n  <td\n    ref={ref}\n    className={cn(\n      \"p-2 align-middle [&:has([role=checkbox])]:pr-0 [&>[role=checkbox]]:translate-y-[2px]\",\n      className\n    )}\n    {...props}\n  />\n))\nTableCell.displayName = \"TableCell\"\n\nconst TableCaption = React.forwardRef<\n  HTMLTableCaptionElement,\n  React.HTMLAttributes<HTMLTableCaptionElement>\n>(({ className, ...props }, ref) => (\n  <caption\n    ref={ref}\n    className={cn(\"mt-4 text-sm text-muted-foreground\", className)}\n    {...props}\n  />\n))\nTableCaption.displayName = \"TableCaption\"\n\nexport {\n  Table,\n  TableHeader,\n  TableBody,\n  TableFooter,\n  TableHead,\n  TableRow,\n  TableCell,\n  TableCaption,\n}\n", "import * as React from \"react\"\n\nimport { cn } from \"@/lib/utils\"\n\nexport interface TextareaProps\n  extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {}\n\nconst Textarea = React.forwardRef<HTMLTextAreaElement, TextareaProps>(\n  ({ className, ...props }, ref) => {\n    return (\n      <textarea\n        className={cn(\n          \"flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50\",\n          className\n        )}\n        ref={ref}\n        {...props}\n      />\n    )\n  }\n)\nTextarea.displayName = \"Textarea\"\n\nexport { Textarea }\n", "\"use client\";\n\nimport * as React from \"react\";\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst Tooltip = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n    React.ElementRef<typeof TooltipPrimitive.Content>,\n    React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n    <TooltipPrimitive.Content\n        ref={ref}\n        sideOffset={sideOffset}\n        className={cn(\n            \"z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs 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\",\n            className,\n        )}\n        {...props}\n    />\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };\n", "import type { ConfirmDialogProps } from \"@/types\";\nimport {\n    AlertDialog,\n    AlertDialogAction,\n    AlertDialogCancel,\n    AlertDialogContent,\n    AlertDialogDescription,\n    AlertDialogFooter,\n    AlertDialogHeader,\n    AlertDialogTitle,\n    AlertDialogTrigger,\n} from \"@/ui/alert-dialog\";\nimport { LoadingIcon } from \"@/ui/loading\";\nimport { CheckIcon, XIcon } from \"lucide-react\";\nimport { FC, isValidElement, useMemo } from \"react\";\n\nexport const ConfirmDialog: FC<ConfirmDialogProps> = ({\n    children,\n    title = \"Are you sure?\",\n    description = \"This action cannot be undone.\",\n    okText = \"Ok\",\n    cancelText = \"Cancel\",\n    okButtonSize = \"default\",\n    cancelButtonSize = \"default\",\n    okButtonVariant = \"default\",\n    cancelButtonVariant = \"outline\",\n    loading = false,\n    okIconSide = \"left\",\n    cancelIconSide = \"left\",\n    onConfirm,\n    okIcon,\n    cancelIcon,\n    open,\n    onOpenChange,\n    defaultOpen,\n}) => {\n    const CancelIcon = useMemo(() => {\n        if (isValidElement(cancelIcon)) {\n            return cancelIcon;\n        }\n\n        return <XIcon className=\"mr-2 h-4 w-4\" />;\n    }, [cancelIcon]);\n\n    const OkIcon = useMemo(() => {\n        if (loading) {\n            return <LoadingIcon className=\"mr-2\" />;\n        }\n        if (isValidElement(okIcon)) {\n            return okIcon;\n        }\n\n        return <CheckIcon className=\"mr-2 h-4 w-4\" />;\n    }, [okIcon, loading]);\n\n    return (\n        <AlertDialog\n            open={open}\n            onOpenChange={onOpenChange}\n            defaultOpen={defaultOpen}\n        >\n            <AlertDialogTrigger asChild>{children}</AlertDialogTrigger>\n            <AlertDialogContent>\n                <AlertDialogHeader>\n                    <AlertDialogTitle>{title}</AlertDialogTitle>\n                    <AlertDialogDescription>\n                        {description}\n                    </AlertDialogDescription>\n                </AlertDialogHeader>\n                <AlertDialogFooter>\n                    <AlertDialogCancel\n                        variant={cancelButtonVariant}\n                        size={cancelButtonSize}\n                        disabled={loading}\n                    >\n                        {cancelIconSide === \"left\" && CancelIcon}\n                        {cancelText}\n                        {cancelIconSide === \"right\" && CancelIcon}\n                    </AlertDialogCancel>\n                    <AlertDialogAction\n                        variant={okButtonVariant}\n                        size={okButtonSize}\n                        disabled={loading}\n                        onClick={onConfirm}\n                    >\n                        {okIconSide === \"left\" && OkIcon}\n                        {okText}\n                        {okIconSide === \"right\" && OkIcon}\n                    </AlertDialogAction>\n                </AlertDialogFooter>\n            </AlertDialogContent>\n        </AlertDialog>\n    );\n};\n\nConfirmDialog.displayName = \"ConfirmDialog\";\n", "import { cn } from \"@/lib/utils\";\nimport {\n    FormField,\n    FormControl,\n    FormDescription,\n    FormItem,\n    FormLabel,\n    FormMessage,\n} from \"@/ui\";\nimport { ReactElement, cloneElement } from \"react\";\nimport {\n    ControllerRenderProps,\n    FieldPath,\n    FieldValues,\n    UseControllerProps,\n} from \"react-hook-form\";\n\nexport type FieldProps<\n    TFieldValues extends FieldValues = FieldValues,\n    TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n> = UseControllerProps<TFieldValues, TName> & {\n    label?: string;\n    description?: string;\n    className?: string;\n    isCheckbox?: boolean;\n    children: ReactElement<{\n        field: ControllerRenderProps<TFieldValues, TName>;\n    }>;\n};\nexport const Field = (props: FieldProps) => {\n    return (\n        <FormField\n            control={props.control}\n            name={props.name}\n            render={({ field }: { field: any }) => {\n                return (\n                    <FormItem\n                        className={cn(\n                            props.className,\n                            props.isCheckbox\n                                ? \"flex flex-row items-center space-x-3 space-y-0\"\n                                : \"\",\n                        )}\n                    >\n                        {!props.isCheckbox && (\n                            <FormLabel>{props.label}</FormLabel>\n                        )}\n                        <FormControl>\n                            {cloneElement(props.children, {\n                                ...field,\n                                ...props.children.props,\n                            })}\n                        </FormControl>\n                        {props.isCheckbox && (\n                            <FormLabel className=\"text-sm font-normal\">\n                                {props.label}\n                            </FormLabel>\n                        )}\n                        {props.description && (\n                            <FormDescription>\n                                {props.description}\n                            </FormDescription>\n                        )}\n                        <FormMessage />\n                    </FormItem>\n                );\n            }}\n        />\n    );\n};\n", "\"use client\";\n\nimport type { SaveButtonProps } from \"@/types\";\nimport { Button, Card, CardContent, CardFooter, Form as FormUI } from \"@/ui\";\nimport {\n    useBack,\n    useNavigation,\n    useParsed,\n    useRouterType,\n    type BaseRecord,\n    type HttpError,\n} from \"@refinedev/core\";\nimport type { UseFormReturnType } from \"@refinedev/react-hook-form\";\nimport {\n    FC,\n    useRef,\n    type DetailedHTMLProps,\n    type FormHTMLAttributes,\n    type PropsWithChildren,\n} from \"react\";\nimport { type FieldValues } from \"react-hook-form\";\nimport { SaveButton } from \"../buttons\";\n\ntype NativeFormProps = Omit<\n    DetailedHTMLProps<FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>,\n    \"onSubmit\"\n>;\n\nexport type FormProps<\n    TQueryFnData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n    TVariables extends FieldValues = FieldValues,\n    TContext extends object = {},\n    TData extends BaseRecord = TQueryFnData,\n    TResponse extends BaseRecord = TData,\n    TResponseError extends HttpError = TError,\n> = PropsWithChildren &\n    UseFormReturnType<\n        TQueryFnData,\n        TError,\n        TVariables,\n        TContext,\n        TData,\n        TResponse,\n        TResponseError\n    > & {\n        formProps?: NativeFormProps;\n        isWatchable?: boolean;\n    };\n\nexport const Form = <\n    TQueryFnData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n    TVariables extends FieldValues = FieldValues,\n    TContext extends object = {},\n    TData extends BaseRecord = TQueryFnData,\n    TResponse extends BaseRecord = TData,\n    TResponseError extends HttpError = TError,\n>({\n    formProps,\n    isWatchable,\n    saveButtonProps,\n    ...props\n}: FormProps<\n    TQueryFnData,\n    TError,\n    TVariables,\n    TContext,\n    TData,\n    TResponse,\n    TResponseError\n>) => {\n    const watchable = useRef<boolean>(false);\n    const { resource: _resource, action } = useParsed();\n    const routerType = useRouterType();\n    const back = useBack();\n    const { goBack } = useNavigation();\n\n    const onBack =\n        action !== \"list\" || typeof action !== \"undefined\"\n            ? routerType === \"legacy\"\n                ? goBack\n                : back\n            : undefined;\n\n    if (isWatchable && !watchable.current) {\n        watchable.current = true;\n        props.watch();\n    }\n\n    const onSubmit = props.handleSubmit((_data: TVariables) => {\n        props.refineCore.onFinish(props.getValues()).then();\n    });\n\n    return (\n        <FormUI {...props}>\n            <form {...formProps} onSubmit={onSubmit}>\n                <Card className=\"border-border/40 shadow-sm\">\n                    <CardContent className=\"pt-6 space-y-4\">\n                        {props.children}\n                    </CardContent>\n\n                    <CardFooter className=\"flex justify-end gap-x-4\">\n                        <Button\n                            type=\"button\"\n                            onClick={onBack}\n                            disabled={props.refineCore.formLoading}\n                            variant=\"outline\"\n                        >\n                            Cancel\n                        </Button>\n\n                        <SaveButton\n                            type=\"submit\"\n                            loading={props.refineCore.formLoading}\n                            {...saveButtonProps}\n                        />\n                    </CardFooter>\n                </Card>\n            </form>\n        </FormUI>\n    );\n};\n", "\"use client\";\n\nimport { useTheme } from \"next-themes\";\nimport { Button } from \"@/ui/button\";\nimport {\n    DropdownMenu,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuTrigger,\n} from \"@/ui/dropdown-menu\";\nimport { MoonIcon, SunIcon } from \"@radix-ui/react-icons\";\n\nexport const ModeToggle = () => {\n    const { setTheme } = useTheme();\n    return (\n        <DropdownMenu>\n            <DropdownMenuTrigger asChild>\n                <Button variant=\"ghost\" size=\"icon\">\n                    <SunIcon className=\"h-[1.2rem] w-[1.2rem] rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0\" />\n                    <MoonIcon className=\"absolute h-[1.2rem] w-[1.2rem] rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100\" />\n                    <span className=\"sr-only\">Toggle theme</span>\n                </Button>\n            </DropdownMenuTrigger>\n            <DropdownMenuContent align={\"end\"}>\n                <DropdownMenuItem onClick={() => setTheme(\"light\")}>\n                    Light\n                </DropdownMenuItem>\n                <DropdownMenuItem onClick={() => setTheme(\"dark\")}>\n                    Dark\n                </DropdownMenuItem>\n                <DropdownMenuItem onClick={() => setTheme(\"system\")}>\n                    System\n                </DropdownMenuItem>\n            </DropdownMenuContent>\n        </DropdownMenu>\n    );\n};\n", "import { cn } from \"@/lib/utils\";\nimport { PageHeaderProps } from \"@/types/pageHeader\";\nimport { FC } from \"react\";\n\nexport const PageHeader: FC<PageHeaderProps> = ({ extra, ...props }) => {\n    return (\n        <div className=\"w-full\">\n            <div\n                className={cn(\n                    \"flex h-20 items-end lg:justify-between\",\n                    props.className,\n                    !props.breadcrumb && \"h-auto\",\n                )}\n            >\n                <div className=\"min-w-0 flex-1\">\n                    {props.breadcrumb}\n                    <div className=\"inline-flex flex-row items-center gap-x-4 mt-3\">\n                        <div className=\"inline-flex flex-col\">\n                            <h2 className=\"text-2xl font-bold leading-7 text-black dark:text-white sm:truncate sm:text-3xl sm:tracking-tight\">\n                                {props.title}\n                            </h2>\n                            {props.subTitle && (\n                                <div className=\"mt-2 flex items-center text-sm text-gray-300\">\n                                    {props.subTitle}\n                                </div>\n                            )}\n                        </div>\n                    </div>\n                </div>\n                <div className=\"flex lg:ml-4 lg:mt-0\">{extra}</div>\n            </div>\n        </div>\n    );\n};\n", "\"use client\";\n\nimport {\n    FormControl,\n    SelectContent,\n    SelectItem,\n    SelectTrigger,\n    Select as SelectUI,\n    SelectValue,\n} from \"@/ui\";\nimport type {\n    Content as SelectContentType,\n    SelectProps as SelectCoreProps,\n} from \"@radix-ui/react-select\";\nimport { BaseOption } from \"@refinedev/core\";\nimport React, { forwardRef } from \"react\";\n\ntype SelectProps = SelectCoreProps & {\n    placeholder?: string;\n    emptyMessage?: string;\n    onChange?: (value: string) => void;\n    options?: BaseOption[];\n};\n\nexport const Select = forwardRef<\n    React.ElementRef<typeof SelectContentType>,\n    SelectProps\n>(({ ...props }, ref) => {\n    const triggerRef = React.useRef<HTMLButtonElement>(null);\n    return (\n        <SelectUI\n            disabled={props.disabled || props.options?.length === 0}\n            onValueChange={props.onChange}\n            defaultValue={props.value}\n            value={props.value}\n        >\n            <FormControl>\n                <SelectTrigger ref={triggerRef}>\n                    <SelectValue placeholder={props.placeholder ?? \"Select\"} />\n                </SelectTrigger>\n            </FormControl>\n            <SelectContent\n                style={{\n                    width: triggerRef.current?.offsetWidth,\n                }}\n                ref={ref}\n            >\n                {props.options?.map((option, key: number) => (\n                    <SelectItem key={key} value={option.value}>\n                        {option.label}\n                    </SelectItem>\n                ))}\n            </SelectContent>\n        </SelectUI>\n    );\n});\n\nSelect.displayName = \"Select\";\n", "\"use client\";\n\nimport { cn } from \"@/lib/utils\";\nimport { buttonVariants } from \"@/ui/button\";\nimport { Tooltip, TooltipContent, TooltipTrigger } from \"@/ui/tooltip\";\nimport { useMenu, useResourceParams } from \"@refinedev/core\";\nimport { useLocation } from \"react-use\";\nimport React from \"react\";\nimport { Link } from \"./link\";\n\ntype NavProps = {\n    isCollapsed: boolean;\n};\n\nexport const Sidebar = ({ isCollapsed }: NavProps) => {\n    const { menuItems } = useMenu();\n    const resourceParams = useResourceParams();\n    const { pathname } = useLocation();\n\n    const currentPathname = String(pathname);\n\n    const GetIcon = (item: (typeof menuItems)[0]) => {\n        const icon = item.meta?.icon;\n        if (React.isValidElement(icon)) {\n            return React.cloneElement<any>(icon, {\n                className: \"mr-2 w-4 h-4\",\n            });\n        }\n        return null;\n    };\n\n    return (\n        <div\n            data-collapsed={isCollapsed}\n            className=\"group flex flex-col gap-4 py-2 justify-between h-[94dvh] xl:h-[84dvh] data-[collapsed=true]:py-2\"\n        >\n            <nav className=\"grid gap-1 px-2 group-[[data-collapsed=true]]:justify-center group-[[data-collapsed=true]]:px-2\">\n                {menuItems\n                    .filter((i) => !i.meta?.hide)\n                    .map((item, key) => {\n                        const paths = [\n                            item.list?.toString(),\n                            item.create?.toString(),\n                            item.edit\n                                ?.toString()\n                                ?.replace(\":id\", resourceParams.id as string),\n                            item.show\n                                ?.toString()\n                                ?.replace(\":id\", resourceParams.id as string),\n                        ].filter(Boolean) as string[];\n                        const isActive =\n                            paths.includes(currentPathname) ||\n                            paths.some((path) => {\n                                return (\n                                    path?.startsWith(currentPathname) ||\n                                    currentPathname.startsWith(path)\n                                );\n                            });\n                        return isCollapsed ? (\n                            <Tooltip key={key} delayDuration={0}>\n                                <TooltipTrigger asChild>\n                                    <Link\n                                        key={key}\n                                        href={item.list?.toString() ?? \"/#\"}\n                                        title={item.meta?.title ?? item.name}\n                                        className={cn(\n                                            buttonVariants({\n                                                variant: \"ghost\",\n                                            }),\n                                            \"justify-start\",\n                                            isActive\n                                                ? \"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground\"\n                                                : \"\",\n                                        )}\n                                    >\n                                        {item.meta?.icon}\n                                        <span className=\"sr-only\">\n                                            {item.meta?.title ?? item.label}{\" \"}\n                                            {item.list ? \"List\" : \"Create\"}\n                                        </span>\n                                    </Link>\n                                </TooltipTrigger>\n                                <TooltipContent\n                                    side=\"right\"\n                                    className=\"flex items-center gap-4\"\n                                >\n                                    {item.label}\n                                    {item.meta?.label && (\n                                        <span className=\"ml-auto text-muted-foreground\">\n                                            {item.meta?.label}\n                                        </span>\n                                    )}\n                                </TooltipContent>\n                            </Tooltip>\n                        ) : (\n                            <Link\n                                key={key}\n                                href={item.list?.toString() ?? \"/#\"}\n                                title={item.meta?.title ?? item.name}\n                                className={cn(\n                                    buttonVariants({\n                                        variant: \"ghost\",\n                                    }),\n                                    \"justify-start\",\n                                    isActive\n                                        ? \"bg-primary text-primary-foreground hover:bg-primary/80 hover:text-primary-foreground\"\n                                        : \"\",\n                                )}\n                            >\n                                {GetIcon(item)}\n                                {item.meta?.title ?? item.name}\n                            </Link>\n                        );\n                    })}\n            </nav>\n        </div>\n    );\n};\n\nSidebar.displayName = \"Sidebar\";\n", "import { EditButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useEditButton } from \"@refinedev/core\";\nimport { SquarePenIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const EditButton: FC<EditButtonProps> = ({\n    resource,\n    recordItemId,\n    hideText = false,\n    accessControl,\n    meta,\n    onClick,\n    children,\n    ...props\n}) => {\n    const { hidden, disabled, label, title, LinkComponent, to } = useEditButton(\n        {\n            resource,\n            id: recordItemId,\n            accessControl,\n            meta,\n        },\n    );\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<SquarePenIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nEditButton.displayName = \"EditButton\";\n", "import { ExportButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { CanAccess, useExportButton } from \"@refinedev/core\";\nimport { ShareIcon } from \"lucide-react\";\n\nimport type { FC } from \"react\";\n\nexport const ExportButton: FC<ExportButtonProps> = ({\n    hideText = false,\n    resource,\n    recordItemId,\n    accessControl,\n    access,\n    children,\n    ...props\n}) => {\n    const { label } = useExportButton();\n    const Com = !accessControl?.enabled ? Slot : CanAccess;\n\n    if (accessControl?.hideIfUnauthorized && accessControl.enabled) {\n        return null;\n    }\n\n    return (\n        <Com\n            params={{\n                id: recordItemId,\n            }}\n            resource={resource}\n            action=\"export\"\n            {...access}\n        >\n            <Button icon={<ShareIcon className=\"mr-2 w-4 h-4\" />} {...props}>\n                {!hideText && (children ?? label)}\n            </Button>\n        </Com>\n    );\n};\n\nExportButton.displayName = \"ExportButton\";\n", "import { ImportButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { CanAccess, useImportButton } from \"@refinedev/core\";\nimport { ImportIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const ImportButton: FC<ImportButtonProps> = ({\n    hideText = false,\n    resource,\n    onChange,\n    accept = \"image/*,application/*\",\n    recordItemId,\n    accessControl,\n    access,\n    children,\n    ...props\n}) => {\n    const { label } = useImportButton();\n    const Com = !accessControl?.enabled ? Slot : CanAccess;\n\n    const onClick = () => {\n        const el = document.createElement(\"input\");\n        el.type = \"file\";\n        el.accept = accept;\n        el.onchange = (e) => {\n            if (e.target instanceof HTMLInputElement) {\n                onChange(Array.from(e.target.files ?? []));\n                el.remove();\n            }\n        };\n        el.click();\n    };\n\n    if (accessControl?.hideIfUnauthorized && accessControl.enabled) {\n        return null;\n    }\n\n    return (\n        <Com\n            params={{\n                id: recordItemId,\n            }}\n            resource={resource}\n            action=\"import\"\n            {...access}\n        >\n            <Button\n                onClick={onClick}\n                icon={<ImportIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </Com>\n    );\n};\n\nImportButton.displayName = \"ImportButton\";\n", "import { ListButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useListButton } from \"@refinedev/core\";\nimport { ListIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const ListButton: FC<ListButtonProps> = ({\n    resource: resourceNameFromProps,\n    hideText = false,\n    accessControl,\n    meta,\n    children,\n    onClick,\n    ...props\n}) => {\n    const { hidden, disabled, label, title, LinkComponent, to } = useListButton(\n        {\n            resource: resourceNameFromProps,\n            accessControl,\n            meta,\n        },\n    );\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                disabled={disabled}\n                title={title}\n                icon={<ListIcon className=\"mr-2 w-4 h-4\" />}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nListButton.displayName = \"ListButton\";\n", "import { RefreshButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useRefreshButton } from \"@refinedev/core\";\nimport { RefreshCwIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const RefreshButton: FC<RefreshButtonProps> = ({\n    resource,\n    recordItemId,\n    hideText = false,\n    dataProviderName,\n    children,\n    ...props\n}) => {\n    const { onClick, label, loading } = useRefreshButton({\n        resource,\n        id: recordItemId,\n        dataProviderName,\n    });\n\n    return (\n        <Button\n            onClick={onClick}\n            loading={loading}\n            icon={<RefreshCwIcon className=\"mr-2 w-4 h-4\" />}\n            {...props}\n        >\n            {!hideText && (children ?? label)}\n        </Button>\n    );\n};\n\nRefreshButton.displayName = \"RefreshButton\";\n", "import { SaveButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { CanAccess, useSaveButton } from \"@refinedev/core\";\nimport { SaveIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const SaveButton: FC<SaveButtonProps> = ({\n    hideText = false,\n    children,\n    accessControl,\n    access,\n    resource,\n    recordItemId,\n    ...props\n}) => {\n    const { label } = useSaveButton();\n    const Com = !accessControl?.enabled ? Slot : CanAccess;\n\n    if (accessControl?.hideIfUnauthorized && accessControl.enabled) {\n        return null;\n    }\n\n    return (\n        <Com\n            params={{\n                id: recordItemId,\n            }}\n            resource={resource}\n            action=\"save\"\n            {...access}\n        >\n            <Button icon={<SaveIcon className=\"mr-2 w-4 h-4\" />} {...props}>\n                {!hideText && (children ?? label)}\n            </Button>\n        </Com>\n    );\n};\n\nSaveButton.displayName = \"SaveButton\";\n", "import { ShowButtonProps } from \"@/types\";\nimport { Button } from \"@/ui/button\";\nimport { useShowButton } from \"@refinedev/core\";\nimport { EyeIcon } from \"lucide-react\";\nimport type { FC } from \"react\";\n\nexport const ShowButton: FC<ShowButtonProps> = ({\n    resource: resourceNameFromProps,\n    recordItemId,\n    hideText = false,\n    accessControl,\n    meta,\n    children,\n    onClick,\n    ...props\n}) => {\n    const { to, label, title, hidden, disabled, LinkComponent } = useShowButton(\n        {\n            resource: resourceNameFromProps,\n            id: recordItemId,\n            accessControl,\n            meta,\n        },\n    );\n\n    if (hidden) return null;\n\n    return (\n        <LinkComponent\n            to={to}\n            replace={false}\n            onClick={(e: React.PointerEvent<HTMLButtonElement>) => {\n                if (disabled) {\n                    e.preventDefault();\n                    return;\n                }\n                if (onClick) {\n                    e.preventDefault();\n                    onClick(e);\n                }\n            }}\n        >\n            <Button\n                icon={<EyeIcon className=\"mr-2 w-4 h-4\" />}\n                title={title}\n                disabled={disabled}\n                {...props}\n            >\n                {!hideText && (children ?? label)}\n            </Button>\n        </LinkComponent>\n    );\n};\n\nShowButton.displayName = \"ShowButton\";\n", "import { ListButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { CreateProps } from \"@/types\";\nimport {\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport React, { isValidElement, ReactNode } from \"react\";\n\nexport const CreatePage: React.FC<CreateProps> = ({\n    title,\n    resource: resourceFromProps,\n    breadcrumb: breadcrumbFromProps,\n    extra,\n    children,\n}): ReturnType<React.FC<CreateProps>> => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource, identifier } = useResource(resourceFromProps);\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `Create ${getUserFriendlyName(\n                            resource?.meta?.label ?? identifier,\n                            \"singular\",\n                        )}`,\n                    )\n                }\n                isBack\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                extra={\n                    extra ?? (\n                        <>\n                            <ListButton resource={resourceFromProps} />\n                        </>\n                    )\n                }\n            />\n            <div className=\"pt-4 !mt-0\">{children as ReactNode}</div>\n        </>\n    );\n};\n\nCreatePage.displayName = \"CreatePage\";\n", "import { DeleteButton, ShowButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { EditProps } from \"@/types\";\nimport {\n    useNavigation,\n    useRedirectionAfterSubmission,\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport { FC, isValidElement } from \"react\";\n\nexport const EditPage: FC<EditProps> = ({\n    title,\n    resource,\n    extra,\n    breadcrumb: breadcrumbFromProps,\n    children,\n}) => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n    const { list } = useNavigation();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource: _resource, identifier } = useResource(resource);\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `Edit ${getUserFriendlyName(\n                            _resource?.meta?.label ?? identifier,\n                            \"plural\",\n                        )}`,\n                    )\n                }\n                isBack\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                extra={\n                    extra ?? (\n                        <div className=\"inline-flex flex-row items-center gap-x-2\">\n                            <ShowButton resource={resource} />\n                            <DeleteButton\n                                resource={resource}\n                                onSuccess={() => {\n                                    list(_resource?.name as string);\n                                }}\n                            />\n                        </div>\n                    )\n                }\n            />\n            <div className=\"pt-4\">{children}</div>\n        </>\n    );\n};\n\nEditPage.displayName = \"EditPage\";\n", "\"use client\";\n\nimport { CreateButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { cn } from \"@/lib/utils\";\nimport { ListProps } from \"@/types\";\nimport {\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport { FC, isValidElement } from \"react\";\n\nexport const ListPage: FC<ListProps> = ({\n    title,\n    resource: resourceFromProps,\n    breadcrumb: breadcrumbFromProps,\n    createButtonProps,\n    className,\n    isCreate = true,\n    extra,\n    children,\n}) => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource, identifier } = useResource(resourceFromProps);\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `List ${getUserFriendlyName(\n                            resource?.meta?.label ?? identifier,\n                            \"plural\",\n                        )}`,\n                    )\n                }\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                extra={\n                    extra ?? (\n                        <>\n                            <div className=\"inline-flex flex-row gap-4\">\n                                {isCreate && (\n                                    <CreateButton\n                                        {...createButtonProps}\n                                        resource={\n                                            createButtonProps?.resource ??\n                                            identifier\n                                        }\n                                    />\n                                )}\n                            </div>\n                        </>\n                    )\n                }\n            />\n            <div className={cn(\"pt-2 sm:pt-4 !mt-0\", className)}>\n                {children}\n            </div>\n        </>\n    );\n};\n\nListPage.displayName = \"ListPage\";\n", "import { DeleteButton, EditButton } from \"@/buttons\";\nimport { Breadcrumbs, PageHeader } from \"@/components\";\nimport { ShowProps } from \"@/types\";\nimport {\n    useNavigation,\n    useRefineContext,\n    useResource,\n    useTranslate,\n    useUserFriendlyName,\n} from \"@refinedev/core\";\nimport { FC, isValidElement } from \"react\";\nimport { Row } from \"./row\";\n\nexport const ShowPage: FC<ShowProps> & {\n    Row: typeof Row;\n} = ({\n    title,\n    resource: resourceFromProps,\n    breadcrumb: breadcrumbFromProps,\n    isEdit = true,\n    isDelete = true,\n    extra,\n    children,\n}) => {\n    const translate = useTranslate();\n    const { options: { breadcrumb: globalBreadcrumb } = {} } =\n        useRefineContext();\n\n    const getUserFriendlyName = useUserFriendlyName();\n\n    const { resource, identifier } = useResource(resourceFromProps);\n\n    const { list } = useNavigation();\n\n    const breadcrumb =\n        typeof breadcrumbFromProps === \"undefined\"\n            ? globalBreadcrumb\n            : breadcrumbFromProps;\n\n    return (\n        <>\n            <PageHeader\n                title={\n                    title ??\n                    translate(\n                        `${identifier}.titles.List`,\n                        `Show ${getUserFriendlyName(\n                            resource?.meta?.label ?? identifier,\n                            \"singular\",\n                        )}`,\n                    )\n                }\n                breadcrumb={\n                    isValidElement(breadcrumb) ? breadcrumb : <Breadcrumbs />\n                }\n                isBack\n                extra={\n                    extra ?? (\n                        <div className=\"inline-flex items-center gap-x-2\">\n                            {isEdit && (\n                                <EditButton resource={resourceFromProps} />\n                            )}\n                            {isDelete && (\n                                <DeleteButton\n                                    resource={resourceFromProps}\n                                    onSuccess={() => {\n                                        list(resource?.name as string);\n                                    }}\n                                />\n                            )}\n                        </div>\n                    )\n                }\n            />\n            <div className=\"relative pt-4 !mt-0\">{children}</div>\n        </>\n    );\n};\n\nShowPage.Row = Row;\nShowPage.displayName = \"ShowPage\";\n", "import { PropsWithChildren, ReactNode } from \"react\";\n\nexport const Row = ({\n    title,\n    children,\n}: Required<\n    PropsWithChildren<{\n        title: string;\n    }>\n>) => {\n    return (\n        <>\n            <dl className=\"flex flex-wrap\">\n                <div className=\"flex-auto pt-4\">\n                    <dt className=\"scroll-m-20 text-xs font-semibold tracking-tight\">\n                        {title}\n                    </dt>\n                    <dd className=\"mt-1 text-base font-normal text-foreground leading-7\">\n                        {children}\n                    </dd>\n                </div>\n            </dl>\n        </>\n    );\n};\n", "\"use client\";\n\nimport { ThemeProvider as NextThemesProvider } from \"next-themes\";\nimport { type ThemeProviderProps } from \"next-themes/dist/types\";\n\nexport function ThemeProvider({ children, ...props }: ThemeProviderProps) {\n    return <NextThemesProvider {...props}>{children}</NextThemesProvider>;\n}\n", "import { ThemeProvider } from \"@/providers/theme-provider\";\nimport { LayoutProps } from \"@/types\";\nimport { Toaster, TooltipProvider } from \"@/ui\";\nimport { PropsWithChildren } from \"react\";\n\ntype Props = PropsWithChildren<\n    Pick<\n        LayoutProps,\n        | \"attribute\"\n        | \"defaultTheme\"\n        | \"enableSystem\"\n        | \"disableTransitionOnChange\"\n        | \"enableColorScheme\"\n        | \"forcedTheme\"\n        | \"nonce\"\n        | \"storageKey\"\n        | \"themes\"\n        | \"value\"\n    >\n>;\n\nexport const BaseLayout = ({\n    attribute,\n    defaultTheme,\n    enableSystem,\n    disableTransitionOnChange,\n    enableColorScheme,\n    forcedTheme,\n    nonce,\n    storageKey,\n    themes,\n    value,\n    children,\n}: Props) => {\n    return (\n        <ThemeProvider\n            attribute={attribute ?? \"class\"}\n            defaultTheme={defaultTheme ?? \"system\"}\n            enableSystem={enableSystem ?? true}\n            disableTransitionOnChange={disableTransitionOnChange ?? false}\n            enableColorScheme={enableColorScheme ?? true}\n            forcedTheme={forcedTheme}\n            nonce={nonce}\n            storageKey={storageKey}\n            themes={themes}\n            value={value}\n        >\n            <TooltipProvider\n                delayDuration={0}\n                skipDelayDuration={0}\n                disableHoverableContent={true}\n            >\n                {children}\n                <Toaster />\n            </TooltipProvider>\n        </ThemeProvider>\n    );\n};\n\nBaseLayout.displayName = \"BaseLayout\";\n", "import * as React from 'react';\n\nfunction queriesDidChange(prevQueries, nextQueries) {\n  if (nextQueries === prevQueries) return false;\n  const nextQueriesArr = Object.values(nextQueries);\n  const prevQueriesArr = Object.values(prevQueries);\n  if (nextQueriesArr.length !== prevQueriesArr.length) return true;\n  if (nextQueriesArr.some((q, i) => q !== prevQueriesArr[i])) return true;\n  const prevKeys = Object.keys(prevQueries);\n  return Object.keys(nextQueries).some((n, i) => n !== prevKeys[i]);\n}\n\nfunction _ref(curr, key) {\n  curr.matches[key] = false;\n  curr.mediaQueries[key] = {};\n  return curr;\n}\n\nfunction init(queries) {\n  const queryKeys = Object.keys(queries);\n  /* istanbul ignore next */\n\n  if (typeof window === 'undefined') return queryKeys.reduce(_ref, {\n    mediaQueries: {},\n    matches: {}\n  });\n  return queryKeys.reduce((state, name) => {\n    const mql = window.matchMedia(queries[name]);\n    state.mediaQueries[name] = mql;\n    state.matches[name] = mql.matches;\n    return state;\n  }, {\n    mediaQueries: {},\n    matches: {}\n  });\n}\n\nfunction reducer(state, action) {\n  function _ref2(prev, key) {\n    prev[key] = state.mediaQueries[key].matches;\n    return prev;\n  }\n\n  switch (action.type) {\n    case 'updateMatches':\n      return {\n        matches: Object.keys(state.mediaQueries).reduce(_ref2, {}),\n        mediaQueries: state.mediaQueries\n      };\n\n    case 'setQueries':\n      return init(action.queries);\n  }\n}\n/**\n * A hook that returns a [`MediaQueryMatches`](#mediaquerymatches) object which will\n * tell you if specific media queries matched, all media queries matched, or\n * any media queries matched. Matches in this hook will always return `false` when\n * rendering on the server.\n *\n * @param queryMap The media queries you want to match against e.g. `{screen: \"screen\", width: \"(min-width: 12em)\"}`\n */\n\n\nexport function useMediaQueries(queryMap) {\n  const prevQueries = React.useRef(queryMap);\n  const [state, dispatch] = React.useReducer(reducer, queryMap, init);\n  React.useEffect(() => {\n    if (queriesDidChange(queryMap, prevQueries.current)) {\n      dispatch({\n        type: 'setQueries',\n        queries: queryMap\n      });\n      prevQueries.current = queryMap;\n    }\n  }, [queryMap]);\n\n  function _ref3() {\n    return dispatch({\n      type: 'updateMatches'\n    });\n  }\n\n  function _ref4(mq) {\n    const callback = _ref3;\n    if (typeof mq.addListener !== 'undefined') mq.addListener(callback);else mq.addEventListener('change', callback);\n    return callback;\n  }\n\n  React.useEffect(() => {\n    const queries = Object.values(state.mediaQueries);\n    const callbacks = queries.map(_ref4);\n\n    function _ref5(mq, i) {\n      if (typeof mq.addListener !== 'undefined') mq.removeListener(callbacks[i]);else mq.removeEventListener('change', callbacks[i]);\n    }\n\n    return () => {\n      queries.forEach(_ref5);\n    };\n  }, [state.mediaQueries]);\n  const {\n    matches\n  } = state;\n  const matchValues = React.useMemo(() => Object.values(matches), [matches]);\n  return {\n    matches,\n    matchesAny: matchValues.some(Boolean),\n    matchesAll: matchValues.length > 0 && matchValues.every(Boolean)\n  };\n}\n/**\n * A hook that returns `true` if the media query matched and `false` if not. This\n * hook will always return `false` when rendering on the server.\n *\n * @param query The media query you want to match against e.g. `\"only screen and (min-width: 12em)\"`\n */\n\nexport function useMediaQuery(query) {\n  return useMediaQueries(getObj(query)).matchesAll;\n}\nconst cache = {};\n\nfunction getObj(query) {\n  if (cache[query] === void 0) cache[query] = {\n    default: query\n  };\n  return cache[query];\n}", "import { ModeToggle, Sidebar } from \"@/components\";\nimport { Link } from \"@/components/link\";\nimport { cn } from \"@/lib/utils\";\nimport type { LayoutProps, LogoType } from \"@/types\";\nimport {\n    ResizableHandle,\n    ResizablePanel,\n    ResizablePanelGroup,\n} from \"@/ui/resizable\";\nimport { useMediaQuery } from \"@react-hook/media-query\";\nimport { useResource } from \"@refinedev/core\";\nimport { cloneElement, isValidElement, useMemo, useState } from \"react\";\nimport { BaseLayout } from \"./base\";\n\nexport const DefaultLayout = ({\n    children,\n    defaultLayout,\n    defaultCollapsed = false,\n    navCollapsedSize,\n    navbar,\n    footer,\n    logo,\n    attribute,\n    defaultTheme,\n    enableSystem,\n    disableTransitionOnChange,\n    enableColorScheme,\n    forcedTheme,\n    nonce,\n    storageKey,\n    themes,\n    value,\n}: LayoutProps) => {\n    const { resources } = useResource();\n\n    const firstDashboard = resources?.[0];\n\n    const xs = useMediaQuery(\"only screen and (max-width: 579.999px)\");\n    const sm = useMediaQuery(\n        \"only screen and (min-width: 640px) and (max-width: 767.999px)\",\n    );\n    const md = useMediaQuery(\n        \"only screen and (min-width: 768px) and (max-width: 1023.999px)\",\n    );\n    const lg = useMediaQuery(\"only screen and (min-width: 1024px)\");\n\n    const [isCollapsed, setIsCollapsed] = useState<boolean>(\n        xs ?? defaultCollapsed,\n    );\n\n    const layout = useMemo(() => {\n        if (defaultLayout) {\n            return defaultLayout;\n        }\n        if (xs) {\n            return [15, 85];\n        } else if (sm) {\n            return [20, 80];\n        } else if (md) {\n            return [25, 75];\n        }\n\n        return [15, 85];\n    }, [defaultLayout, xs, sm, md]);\n\n    const SidebarSizes = useMemo(() => {\n        if (lg) {\n            return {\n                minSize: 11,\n                maxSize: 15,\n            };\n        } else if (md) {\n            return {\n                minSize: 15,\n                maxSize: 25,\n            };\n        } else if (sm) {\n            return {\n                minSize: 20,\n                maxSize: 30,\n            };\n        }\n\n        return {\n            minSize: 15,\n            maxSize: 15,\n        };\n    }, [sm, md, lg]);\n\n    const hasCollapsed = useMemo(() => {\n        return isCollapsed || xs || sm || md;\n    }, [isCollapsed, md, sm, xs]);\n\n    const Logo: LogoType | undefined = useMemo<LogoType | undefined>(():\n        | LogoType\n        | undefined => {\n        if (!logo) {\n            return null;\n        }\n\n        if (!hasCollapsed) {\n            if (isValidElement(logo.default)) {\n                return cloneElement<LogoType>(logo.default, {\n                    className: \"w-auto h-8\",\n                });\n            }\n        }\n\n        const component = hasCollapsed ? logo.collapsed : logo.default;\n        if (isValidElement(component)) {\n            return cloneElement<LogoType>(component, {\n                className: \"w-auto h-8\",\n            });\n        }\n\n        return null;\n    }, [logo, defaultLayout, hasCollapsed]);\n\n    return (\n        <>\n            <BaseLayout\n                attribute={attribute}\n                defaultTheme={defaultTheme}\n                enableSystem={enableSystem}\n                disableTransitionOnChange={disableTransitionOnChange}\n                enableColorScheme={enableColorScheme}\n                forcedTheme={forcedTheme}\n                nonce={nonce}\n                storageKey={storageKey}\n                themes={themes}\n                value={value}\n            >\n                <ResizablePanelGroup\n                    direction=\"horizontal\"\n                    onLayout={(sizes: number[]) => {\n                        document.cookie = `react-resizable-panels:layout=${JSON.stringify(\n                            sizes,\n                        )}`;\n                    }}\n                    className=\"h-full items-stretch\"\n                >\n                    <ResizablePanel\n                        defaultSize={layout[0]}\n                        collapsedSize={navCollapsedSize}\n                        collapsible={true}\n                        minSize={SidebarSizes.minSize}\n                        maxSize={SidebarSizes.maxSize}\n                        onExpand={() => {\n                            const collapsed = xs;\n                            setIsCollapsed(collapsed);\n                            document.cookie = `react-resizable-panels:collapsed=${JSON.stringify(\n                                collapsed,\n                            )}`;\n                        }}\n                        onCollapse={() => {\n                            const collapsed = true;\n                            setIsCollapsed(collapsed);\n                            document.cookie = `react-resizable-panels:collapsed=${JSON.stringify(\n                                collapsed,\n                            )}`;\n                        }}\n                        className={cn(\n                            hasCollapsed &&\n                                \"min-w-[50px] transition-all duration-300 ease-in-out\",\n                        )}\n                    >\n                        <div\n                            className={cn(\n                                \"flex py-1.5 max-h-14 items-center border-b border-border/40 justify-center\",\n                                hasCollapsed && \"px-2\",\n                            )}\n                        >\n                            <Link\n                                href={firstDashboard.list?.toString() ?? \"/\"}\n                                className=\"inline-flex items-center justify-center\"\n                                title={\n                                    firstDashboard.meta?.label ??\n                                    firstDashboard.name\n                                }\n                            >\n                                {Logo}\n                            </Link>\n                        </div>\n                        <Sidebar isCollapsed={hasCollapsed} />\n                    </ResizablePanel>\n                    <ResizableHandle withHandle className=\"bg-border/40\" />\n                    <ResizablePanel\n                        defaultSize={layout[1]}\n                        minSize={25}\n                        className=\"xl:max-h-dvh h-full !overflow-y-auto flex flex-col overflow-x-hidden\"\n                    >\n                        <header\n                            className={cn(\n                                \"sticky top-0 z-50 py-2 h-14 px-4 flex justify-end items-center border-b border-border/40 bg-background/95 backdrop-blur supports-[backdrop-filter]:bg-background/60\",\n                                navbar?.rightSide && \"justify-between\",\n                            )}\n                        >\n                            {navbar?.leftSide && (\n                                <div className=\"flex items-center justify-start flex-1\">\n                                    {navbar?.leftSide}\n                                </div>\n                            )}\n                            {navbar?.rightSide ? (\n                                <div className=\"flex items-center justify-end flex-1\">\n                                    {<ModeToggle />}\n                                    {navbar?.rightSide}\n                                </div>\n                            ) : (\n                                <ModeToggle />\n                            )}\n                        </header>\n                        <main className=\"grow px-6 py-4\">{children}</main>\n                        {footer && (\n                            <footer className=\"px-6 py-4 border-t border-border/40 sticky bottom-0 bg-background text-primary flex flex-row items-center\">\n                                <div className=\"w-full\">{footer}</div>\n                            </footer>\n                        )}\n                    </ResizablePanel>\n                </ResizablePanelGroup>\n            </BaseLayout>\n        </>\n    );\n};\n\nDefaultLayout.displayName = \"DefaultLayout\";\n", "import { NotificationProvider } from \"@refinedev/core\";\nimport { toast } from \"sonner\";\n\nexport const notificationProvider: NotificationProvider = {\n    open: ({ key, message, description, type }) => {\n        if (type === \"success\") {\n            toast.success(message, { description, id: key });\n        }\n\n        if (type === \"error\") {\n            toast.error(message, { description, id: key });\n        }\n\n        if (type === \"progress\") {\n            toast.loading(message, { description, id: key });\n        }\n    },\n    close: (key) => toast.dismiss(key),\n};\n\nexport const useNotificationProvider = (): NotificationProvider => {\n    return notificationProvider;\n};\n", "import {\n    AccessControlContext,\n    CanReturnType,\n    useCan,\n    useNavigation,\n    useResource,\n    useTranslate,\n} from \"@refinedev/core\";\nimport { useContext } from \"react\";\n\ntype GetEditUrlReturnType = CanReturnType & {\n    url: string;\n};\n\nexport const useGetEditUrl = (\n    resource: string,\n    recordItemId: string,\n    meta?: any,\n): GetEditUrlReturnType => {\n    const accessControlContext = useContext(AccessControlContext);\n    const accessControlEnabled =\n        accessControlContext.options.buttons.enableAccessControl;\n\n    const hideIfUnauthorized =\n        accessControlContext.options.buttons.hideIfUnauthorized;\n\n    const { editUrl: generateEditUrl } = useNavigation();\n\n    const { id, resource: _resource } = useResource(resource);\n\n    const { data } = useCan({\n        resource: resource,\n        action: \"edit\",\n        params: { id: recordItemId, resource: _resource },\n        queryOptions: {\n            enabled: accessControlEnabled,\n        },\n    });\n\n    const translate = useTranslate();\n\n    const reason = () => {\n        if (data?.can) return \"\";\n        else if (data?.reason) return data.reason;\n        else\n            return translate(\n                \"buttons.notAccessTitle\",\n                \"You don't have permission to access\",\n            );\n    };\n\n    const editUrl =\n        resource && (recordItemId ?? id)\n            ? generateEditUrl(resource, recordItemId! ?? id!, meta)\n            : \"\";\n\n    return {\n        can: !Boolean(accessControlEnabled && hideIfUnauthorized && !data?.can),\n        reason: reason(),\n        url: editUrl,\n    };\n};\n", "import {\n    AccessControlContext,\n    CanReturnType,\n    useCan,\n    useNavigation,\n    useResource,\n    useTranslate,\n} from \"@refinedev/core\";\nimport { useContext } from \"react\";\n\ntype GetShowUrlReturnType = CanReturnType & {\n    url: string;\n};\n\nexport const useGetShowUrl = (\n    resource: string,\n    recordItemId: string,\n    meta?: any,\n): GetShowUrlReturnType => {\n    const accessControlContext = useContext(AccessControlContext);\n    const accessControlEnabled =\n        accessControlContext.options.buttons.enableAccessControl;\n\n    const hideIfUnauthorized =\n        accessControlContext.options.buttons.hideIfUnauthorized;\n\n    const { showUrl: generateShowUrl } = useNavigation();\n\n    const { id, resource: _resource } = useResource(resource);\n\n    const { data } = useCan({\n        resource: resource,\n        action: \"show\",\n        params: { id: recordItemId, resource: _resource },\n        queryOptions: {\n            enabled: accessControlEnabled,\n        },\n    });\n\n    const translate = useTranslate();\n\n    const reason = () => {\n        if (data?.can) return \"\";\n        else if (data?.reason) return data.reason;\n        else\n            return translate(\n                \"buttons.notAccessTitle\",\n                \"You don't have permission to access\",\n            );\n    };\n\n    const showUrl =\n        resource && (recordItemId || id)\n            ? generateShowUrl(resource, recordItemId! ?? id!, meta)\n            : \"\";\n\n    return {\n        can: !Boolean(accessControlEnabled && hideIfUnauthorized && !data?.can),\n        reason: reason(),\n        url: showUrl,\n    };\n};\n", "import {\n    AccessControlContext,\n    CanReturnType,\n    pickNotDeprecated,\n    useCan,\n    useDelete,\n    useMutationMode,\n    useResource,\n    useResourceParams,\n    useTranslate,\n    useWarnAboutChange,\n} from \"@refinedev/core\";\nimport { MutateOptions } from \"@tanstack/react-query\";\nimport { useContext } from \"react\";\n\ntype DeleteHelperReturnType = CanReturnType & {\n    isLoading: boolean;\n    mutate: (e?: MutateOptions<unknown, unknown, unknown, unknown>) => any; // TODO: UseDeleteReturnType fix\n};\n\nexport const useDeleteHelper = (\n    resource: string,\n    recordItemId: string,\n    meta?: any,\n): DeleteHelperReturnType => {\n    const accessControlContext = useContext(AccessControlContext);\n\n    const accessControlEnabled =\n        accessControlContext.options.buttons.enableAccessControl;\n\n    const hideIfUnauthorized =\n        accessControlContext.options.buttons.hideIfUnauthorized;\n\n    const translate = useTranslate();\n\n    const id = useResourceParams();\n\n    const { resource: _resource, identifier } = useResource(resource);\n\n    const { mutationMode } = useMutationMode();\n\n    const { mutate, isLoading } = useDelete();\n\n    const { data } = useCan({\n        resource: _resource?.name,\n        action: \"delete\",\n        params: { id: recordItemId ?? id, resource: _resource },\n        queryOptions: {\n            enabled: accessControlEnabled,\n        },\n    });\n\n    const reason = () => {\n        if (data?.can) return \"\";\n        else if (data?.reason) return data.reason;\n        else return translate(\"You don't have permission to access\");\n    };\n\n    const { setWarnWhen } = useWarnAboutChange();\n\n    const onDeleteMutate = (\n        options?: MutateOptions<unknown, unknown, unknown, unknown>,\n    ): any => {\n        if (accessControlEnabled && hideIfUnauthorized && !data?.can) {\n            return;\n        }\n        if ((recordItemId ?? id) && identifier) {\n            setWarnWhen(false);\n            return mutate(\n                {\n                    id: recordItemId ?? id ?? \"\",\n                    resource: identifier,\n                    mutationMode,\n                    meta: pickNotDeprecated(meta),\n                    metaData: pickNotDeprecated(meta),\n                },\n                options,\n            );\n        }\n\n        return undefined;\n    };\n\n    return {\n        can: !Boolean(accessControlEnabled && hideIfUnauthorized && !data?.can),\n        reason: reason(),\n        mutate: onDeleteMutate,\n        isLoading,\n    };\n};\n", "import {\n    BackFunction,\n    useBack,\n    useNavigation,\n    useResource,\n    useRouterType,\n} from \"@refinedev/core\";\n\nexport const useOnBack = (): BackFunction | undefined => {\n    const routerType = useRouterType();\n    const back = useBack();\n    const { goBack } = useNavigation();\n    const { action } = useResource();\n\n    const onBack =\n        action !== \"list\" || typeof action !== \"undefined\"\n            ? routerType === \"legacy\"\n                ? goBack\n                : back\n            : undefined;\n\n    return onBack;\n};\n", "\"use client\";\n\nimport { ConfirmDialog } from \"@/components/confirm\";\nimport { useDeleteHelper, useOnBack } from \"@/hooks\";\nimport { useTranslate } from \"@refinedev/core\";\nimport React, {\n    PropsWithChildren,\n    createContext,\n    useCallback,\n    useState,\n} from \"react\";\n\ntype DeleteDataType = {\n    toogle: boolean;\n    row: any;\n    resource: string;\n    redirectBack?: boolean;\n    onAfterHandle?: () => void;\n};\n\nexport interface DeleteContextType {\n    data: DeleteDataType;\n    updateData: (data: DeleteDataType) => void;\n}\n\nexport function DeleteActionModal(props: DeleteContextType) {\n    const back = useOnBack();\n    const { can, isLoading, mutate } = useDeleteHelper(\n        props.data?.resource,\n        props.data?.row?.id,\n    );\n\n    const translate = useTranslate();\n\n    const onDelete = useCallback(() => {\n        if (can) {\n            return mutate({\n                onSuccess() {\n                    const isRedirectBack = props?.data?.redirectBack ?? false;\n                    const onAfterHandle = props?.data?.onAfterHandle;\n                    props?.updateData({\n                        toogle: false,\n                        row: undefined,\n                        resource: \"\",\n                        redirectBack: false,\n                        onAfterHandle: undefined,\n                    });\n\n                    if (isRedirectBack) {\n                        back?.();\n                    }\n\n                    if (onAfterHandle) {\n                        onAfterHandle();\n                    }\n                },\n            });\n        }\n\n        return undefined;\n    }, [can, mutate, props, back]);\n\n    return (\n        <ConfirmDialog\n            open={can && props?.data?.toogle}\n            loading={isLoading}\n            title={translate(\"Are you sure?\")}\n            description={translate(\"This action cannot be undone.\")}\n            okText={translate(\"Delete\")}\n            cancelText={translate(\"Cancel\")}\n            okButtonVariant={\"destructive\"}\n            onOpenChange={() => {\n                if (!isLoading) {\n                    props?.updateData({\n                        toogle: false,\n                        row: undefined,\n                        resource: \"\",\n                    });\n                }\n            }}\n            onConfirm={onDelete}\n        />\n    );\n}\n\nconst DeleteContext = createContext<DeleteContextType | undefined>(undefined);\n\nconst DeleteProvider: React.FC<PropsWithChildren> = ({ children }) => {\n    const [data, setData] = useState<DeleteDataType>({\n        row: undefined,\n        resource: \"\",\n        toogle: false,\n        onAfterHandle: undefined,\n    });\n\n    const updateData = (data: DeleteDataType) => {\n        setData(data);\n    };\n\n    return (\n        <DeleteContext.Provider value={{ data, updateData }}>\n            {children}\n            <DeleteActionModal\n                data={data as DeleteDataType}\n                updateData={updateData}\n            />\n        </DeleteContext.Provider>\n    );\n};\n\nexport { DeleteContext, DeleteProvider };\n", "import { cn } from \"@/lib/utils\";\nimport React, { forwardRef } from \"react\";\n\nconst Loader = forwardRef<SVGSVGElement, React.SVGProps<SVGSVGElement>>(\n    ({ className, ...props }, ref) => {\n        return (\n            <svg\n                ref={ref}\n                xmlns=\"http://www.w3.org/2000/svg\"\n                className={cn(\"mx-auto inline\", className)}\n                viewBox=\"0 0 120 30\"\n                fill=\"currentColor\"\n                {...props}\n            >\n                <circle cx=\"15\" cy=\"15\" r=\"15\">\n                    <animate\n                        attributeName=\"r\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"15\"\n                        repeatCount=\"indefinite\"\n                        to=\"15\"\n                        values=\"15;9;15\"\n                    ></animate>\n                    <animate\n                        attributeName=\"fill-opacity\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"1\"\n                        repeatCount=\"indefinite\"\n                        to=\"1\"\n                        values=\"1;.5;1\"\n                    ></animate>\n                </circle>\n                <circle cx=\"60\" cy=\"15\" r=\"9\" fillOpacity=\"0.3\">\n                    <animate\n                        attributeName=\"r\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"9\"\n                        repeatCount=\"indefinite\"\n                        to=\"9\"\n                        values=\"9;15;9\"\n                    ></animate>\n                    <animate\n                        attributeName=\"fill-opacity\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"0.5\"\n                        repeatCount=\"indefinite\"\n                        to=\"0.5\"\n                        values=\".5;1;.5\"\n                    ></animate>\n                </circle>\n                <circle cx=\"105\" cy=\"15\" r=\"15\">\n                    <animate\n                        attributeName=\"r\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"15\"\n                        repeatCount=\"indefinite\"\n                        to=\"15\"\n                        values=\"15;9;15\"\n                    ></animate>\n                    <animate\n                        attributeName=\"fill-opacity\"\n                        begin=\"0s\"\n                        calcMode=\"linear\"\n                        dur=\"0.8s\"\n                        from=\"1\"\n                        repeatCount=\"indefinite\"\n                        to=\"1\"\n                        values=\"1;.5;1\"\n                    ></animate>\n                </circle>\n            </svg>\n        );\n    },\n);\n\nexport default Loader;\n", "import Loader from \"@/components/loader\";\nimport {\n    TableBody,\n    TableCell,\n    TableHead,\n    TableHeader,\n    TableRow,\n    Table as TableUi,\n} from \"@/ui/table\";\nimport { PopoverContentProps } from \"@radix-ui/react-popover\";\nimport { BaseOption, BaseRecord, HttpError } from \"@refinedev/core\";\nimport {\n    UseTableProps,\n    UseTableReturnType,\n    useTable,\n} from \"@refinedev/react-table\";\nimport {\n    CellContext,\n    Column,\n    ColumnDef,\n    ColumnDefTemplate,\n    TableOptionsResolved,\n    flexRender,\n} from \"@tanstack/react-table\";\nimport React, {\n    FC,\n    ReactElement,\n    useCallback,\n    useEffect,\n    useMemo,\n    useState,\n} from \"react\";\nimport { RowAction, RowActions } from \"./actions\";\nimport { EditAction } from \"./actions/edit\";\nimport { ShowAction } from \"./actions/show\";\nimport {\n    TableFilterDateRangePickerFilter,\n    TableFilterDropdown,\n    TableFilterSearchColumn,\n} from \"./fields\";\nimport { CheckAll } from \"./fields/checkall\";\nimport { Pagination } from \"./fields/pagination\";\nimport { SortAction } from \"./fields/sort\";\nimport { DataTableToolbar } from \"./toolbar\";\nimport { DeleteAction } from \"./actions/delete\";\nimport { DeleteProvider } from \"@/providers\";\n\nexport type TableListFilterOption = BaseOption & {\n    icon?: React.ComponentType<{ className?: string }>;\n};\n\nexport type TableFilterProps<TData extends BaseRecord = BaseRecord> = {\n    column: Column<TData>;\n    title?: string;\n    numberOfMonths?: number;\n    align?: PopoverContentProps[\"align\"];\n    options?: TableListFilterOption[];\n};\n\nexport type ColumnProps<\n    TData extends BaseRecord = BaseRecord,\n    TValue = unknown,\n    TError extends HttpError = HttpError,\n> = {\n    id: string;\n    accessorKey: string;\n    enableSorting?: boolean;\n    enableHiding?: boolean;\n    header?:\n        | string\n        | FC<{\n              table: UseTableReturnType<TData, TError>;\n          }>;\n    cell?: ColumnDefTemplate<CellContext<TData, TValue>>;\n    children?: ReactElement;\n    filter?: FC<TableFilterProps<TData>>;\n};\n\ntype CustomColumnDef<\n    TData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n> = ColumnDef<TData, TError> & Pick<ColumnProps<TData, TError>, \"filter\">;\n\nexport type TableProps<\n    TData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n> = Partial<UseTableProps<TData, TError, TData>> & {\n    children?: ReactElement<ColumnProps<TData, TError>>[];\n    showHeader?: boolean;\n};\n\nexport function Table<\n    TQueryFnData extends BaseRecord = BaseRecord,\n    TData extends BaseRecord = TQueryFnData,\n    TError extends HttpError = HttpError,\n>({\n    children,\n    showHeader = true,\n    columns = [],\n    ...props\n}: TableProps<TData, TError>) {\n    const mapColumn = useCallback(\n        ({\n            id,\n            accessorKey,\n            header,\n            enableSorting,\n            enableHiding,\n            filter,\n            cell,\n        }: ColumnProps<TData, TError>): ColumnDef<TData> => {\n            const column: any = {\n                id,\n                header,\n                accessorKey,\n                enableSorting: enableSorting ?? false,\n                enableHiding: enableHiding ?? false,\n                enableColumnFilter: true,\n                enableResizing: true,\n                filter,\n            };\n\n            if (cell) {\n                column[\"cell\"] = cell;\n            }\n\n            return column;\n        },\n        [],\n    );\n\n    columns = useMemo<ColumnDef<TData>[]>(() => {\n        if (Array.isArray(children)) {\n            return (children as ReactElement[])\n                .map((value: ReactElement) => value.props)\n                .map(mapColumn);\n        }\n\n        return [];\n    }, [children, mapColumn]);\n\n    const table = useTable({\n        columns,\n        ...props,\n    });\n\n    const tableOptions = useMemo<TableOptionsResolved<TData>>(\n        () => table.options,\n        [table],\n    );\n\n    const isFilterable = useMemo<boolean>(\n        () =>\n            Boolean(\n                tableOptions.enableColumnFilters || tableOptions?.enableFilters,\n            ),\n        [tableOptions],\n    );\n\n    return (\n        <DeleteProvider>\n            <div className=\"space-y-4\">\n                <DataTableToolbar table={table} />\n                <div className=\"rounded-md border border-border\">\n                    <TableUi>\n                        {showHeader && (\n                            <TableHeader>\n                                {table.getHeaderGroups().map((headerGroup) => (\n                                    <TableRow key={headerGroup.id}>\n                                        {headerGroup.headers.map((header) => {\n                                            const columnDef = header.column\n                                                .columnDef as CustomColumnDef<\n                                                TData,\n                                                TError\n                                            >;\n                                            return (\n                                                <TableHead key={header.id}>\n                                                    <div className=\"inline-flex flex-row items-center gap-x-2.5\">\n                                                        {header.isPlaceholder\n                                                            ? null\n                                                            : flexRender(\n                                                                  header.column\n                                                                      .columnDef\n                                                                      .header,\n                                                                  header.getContext(),\n                                                              )}\n                                                        {tableOptions.enableSorting &&\n                                                            columnDef.enableSorting && (\n                                                                <SortAction\n                                                                    column={\n                                                                        header.column\n                                                                    }\n                                                                />\n                                                            )}\n                                                        {isFilterable &&\n                                                            columnDef?.filter &&\n                                                            columnDef.filter({\n                                                                column: header.column,\n                                                                title: `${columnDef.header} Filter`,\n                                                            })}\n                                                    </div>\n                                                </TableHead>\n                                            );\n                                        })}\n                                    </TableRow>\n                                ))}\n                            </TableHeader>\n                        )}\n                        <TableBody>\n                            {table.refineCore.tableQuery.isLoading ? (\n                                <TableRow>\n                                    <TableCell\n                                        colSpan={columns.length}\n                                        className=\"h-24 text-center text-nowrap\"\n                                    >\n                                        <div className=\"flex items-center justify-center flex-row\">\n                                            <Loader className=\"h-4 text-primary\" />\n                                        </div>\n                                    </TableCell>\n                                </TableRow>\n                            ) : table.getRowModel().rows?.length ? (\n                                table.getRowModel().rows.map((row: any) => (\n                                    <TableRow\n                                        key={row.id}\n                                        data-state={\n                                            row.getIsSelected() && \"selected\"\n                                        }\n                                    >\n                                        {row\n                                            .getVisibleCells()\n                                            .map((cell: any) => (\n                                                <TableCell\n                                                    key={cell.id}\n                                                    className=\"text-nowrap\"\n                                                >\n                                                    {flexRender(\n                                                        cell.column.columnDef\n                                                            .cell,\n                                                        cell.getContext(),\n                                                    )}\n                                                </TableCell>\n                                            ))}\n                                    </TableRow>\n                                ))\n                            ) : (\n                                <TableRow>\n                                    <TableCell\n                                        colSpan={columns.length}\n                                        className=\"h-24 text-center\"\n                                    >\n                                        No results.\n                                    </TableCell>\n                                </TableRow>\n                            )}\n                        </TableBody>\n                    </TableUi>\n                </div>\n                <Pagination table={table} />\n            </div>\n        </DeleteProvider>\n    );\n}\n\nconst TableColumn = <\n    TData extends BaseRecord = BaseRecord,\n    TError extends HttpError = HttpError,\n>(\n    props: ColumnProps<TData, TError>,\n) => {\n    return props.children;\n};\n\nTable.Column = TableColumn;\nTable.CheckAll = CheckAll;\nTable.Actions = RowActions;\nTable.Action = RowAction;\nTable.EditAction = EditAction;\nTable.ShowAction = ShowAction;\nTable.DeleteAction = DeleteAction;\nTable.Filter = {\n    DateRangePicker: TableFilterDateRangePickerFilter,\n    Dropdown: TableFilterDropdown,\n    Search: TableFilterSearchColumn,\n};\n\nTable.displayName = \"Table\";\n", "\"use client\";\nimport { Button } from \"@/ui/button\";\nimport {\n    DropdownMenu,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuTrigger,\n} from \"@/ui/dropdown-menu\";\nimport { Link } from \"@/components/link\";\nimport { DotsHorizontalIcon } from \"@radix-ui/react-icons\";\nimport { FC, PropsWithChildren, ReactNode } from \"react\";\n\ninterface RowActionsProps {\n    children?: ReactNode;\n}\n\nexport type RowActionProps = PropsWithChildren & {\n    to?: string;\n    title?: string;\n    asChild?: boolean;\n    className?: string;\n    disabled?: boolean;\n    icon?: ReactNode;\n    onClick?: (event: any) => void;\n};\n\nexport const RowAction: FC<RowActionProps> = (props) => {\n    return (\n        <DropdownMenuItem\n            disabled={props.disabled}\n            asChild={!(!props.to || (!props.to && !props.children))}\n            onClick={props.onClick}\n        >\n            {props.asChild ? (\n                props.children\n            ) : props.to ? (\n                <Link href={props.to} title={props.title}>\n                    {props.icon ? (\n                        <span className=\"mr-2\">{props.icon}</span>\n                    ) : null}\n                    {props.title}\n                </Link>\n            ) : (\n                <>\n                    {props.icon ? (\n                        <span className=\"mr-2\">{props.icon}</span>\n                    ) : null}\n                    {props.title}\n                </>\n            )}\n        </DropdownMenuItem>\n    );\n};\n\nRowAction.displayName = \"RowAction\";\n\nexport function RowActions({ children }: RowActionsProps) {\n    return (\n        <DropdownMenu>\n            <DropdownMenuTrigger asChild>\n                <Button variant=\"ghost\" size=\"icon\">\n                    <DotsHorizontalIcon className=\"h-4 w-4\" />\n                    <span className=\"sr-only\">Open menu</span>\n                </Button>\n            </DropdownMenuTrigger>\n            <DropdownMenuContent align=\"end\" className=\"w-[160px]\">\n                {children}\n            </DropdownMenuContent>\n        </DropdownMenu>\n    );\n}\n", "import type { RowActionProps } from \".\";\nimport { RowAction } from \".\";\nimport { useGetEditUrl } from \"@/hooks\";\n\ntype EditActionProps = RowActionProps & {\n    row: any;\n    resource: string;\n    title: string;\n};\n\nexport function EditAction({\n    row,\n    resource,\n    title,\n    disabled,\n    ...props\n}: EditActionProps) {\n    const edit = useGetEditUrl(resource, row.id);\n\n    return (\n        <RowAction\n            {...props}\n            disabled={!edit.can || disabled}\n            title={!edit?.can ? edit?.reason : title}\n            to={edit.url}\n        />\n    );\n}\n\nEditAction.displayName = \"EditAction\";\n", "import type { RowActionProps } from \".\";\nimport { RowAction } from \".\";\nimport { useGetShowUrl } from \"@/hooks\";\n\ntype ShowActionProps = RowActionProps & {\n    row: any;\n    resource: string;\n    title: string;\n};\n\nexport function ShowAction({\n    row,\n    resource,\n    title,\n    disabled,\n    ...props\n}: ShowActionProps) {\n    const detail = useGetShowUrl(resource, row.id);\n\n    return (\n        <RowAction\n            {...props}\n            disabled={!detail.can || disabled}\n            title={!detail?.can ? detail?.reason : title}\n            to={detail.url}\n        />\n    );\n}\n\nShowAction.displayName = \"ShowAction\";\n", "import { format } from \"date-fns\";\nimport { FilterIcon, FilterX } from \"lucide-react\";\nimport { useEffect, useState } from \"react\";\nimport { DateRange } from \"react-day-picker\";\n\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/ui/popover\";\nimport { Button } from \"@/ui/button\";\nimport { Separator } from \"@/ui/separator\";\nimport { Badge } from \"@/ui/badge\";\nimport { Calendar } from \"@/ui/calendar\";\nimport { BaseRecord } from \"@refinedev/core\";\n\nexport function TableFilterDateRangePickerFilter<\n    T extends BaseRecord = BaseRecord,\n>({\n    column,\n    title,\n    numberOfMonths = 2,\n    align = \"start\",\n}: Pick<TableFilterProps<T>, \"column\" | \"title\" | \"numberOfMonths\" | \"align\">) {\n    const [date, setDate] = useState<DateRange | undefined>({\n        from: undefined,\n        to: undefined,\n    });\n    const selectedValues = new Set(column?.getFilterValue() as string[]);\n\n    useEffect(() => {\n        if (date) {\n            const dates = Object.values(date).filter(Boolean);\n            if (dates.length) {\n                column?.setFilterValue(\n                    dates.map((date: Date | undefined) =>\n                        date ? format(date, \"yyyy-MM-dd\").toString() : \"\",\n                    ),\n                );\n            }\n        }\n    }, [column, date]);\n\n    return (\n        <Popover>\n            <PopoverTrigger asChild>\n                <div className=\"inline-flex flex-row items-center gap-x-0.5\">\n                    <Button\n                        title={title}\n                        variant=\"outline\"\n                        size=\"sm\"\n                        className=\"h-5 border-dashed px-1 py-2.5\"\n                    >\n                        <FilterIcon className={cn(\"h-3.5 w-3.5\")} />\n                        {date?.from ? (\n                            <>\n                                <Separator\n                                    orientation=\"vertical\"\n                                    className=\"mx-2 h-4\"\n                                />\n                                <Badge\n                                    variant=\"secondary\"\n                                    className=\"rounded-sm p-1 h-3.5 text-xs font-normal\"\n                                >\n                                    {date.to ? (\n                                        <>\n                                            {[\n                                                format(date.from, \"LLL dd, y\"),\n                                                format(date.to, \"LLL dd, y\"),\n                                            ].join(\" \")}\n                                        </>\n                                    ) : (\n                                        format(date.from, \"LLL dd, y\")\n                                    )}\n                                </Badge>\n                            </>\n                        ) : null}\n                    </Button>\n                    {selectedValues.size > 0 && (\n                        <Button\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-5 border-dashed px-1 py-2.5\"\n                            onClick={(e) => {\n                                e.preventDefault();\n                                column?.setFilterValue(undefined);\n                                setDate({ from: undefined, to: undefined });\n                            }}\n                        >\n                            <FilterX className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    )}\n                </div>\n            </PopoverTrigger>\n            <PopoverContent className=\"w-auto p-0\" align={align}>\n                <Calendar\n                    initialFocus\n                    mode=\"range\"\n                    defaultMonth={new Date()}\n                    selected={date}\n                    onSelect={setDate}\n                    numberOfMonths={numberOfMonths}\n                />\n                {selectedValues.size > 0 && (\n                    <>\n                        <Separator />\n                        <div className=\"flex flex-row items-center justify-center py-3\">\n                            <Button\n                                variant=\"outline\"\n                                size=\"sm\"\n                                className=\"h-8 border-dashed px-2\"\n                                onClick={() => {\n                                    column?.setFilterValue(undefined);\n                                    setDate({ from: undefined, to: undefined });\n                                }}\n                            >\n                                <FilterX size={16} className=\"mr-2\" />\n                                Clear\n                            </Button>\n                        </div>\n                    </>\n                )}\n            </PopoverContent>\n        </Popover>\n    );\n}\n", "import { CheckIcon } from \"@radix-ui/react-icons\";\nimport { FilterIcon, FilterX } from \"lucide-react\";\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/ui/popover\";\nimport { Button } from \"@/ui/button\";\nimport { Separator } from \"@/ui/separator\";\nimport { Badge } from \"@/ui/badge\";\nimport {\n    Command,\n    CommandEmpty,\n    CommandGroup,\n    CommandInput,\n    CommandItem,\n    CommandList,\n    CommandSeparator,\n} from \"@/ui/command\";\n\nexport function TableFilterDropdown({\n    column,\n    title,\n    options,\n    align = \"start\",\n}: TableFilterProps) {\n    const facets = column?.getFacetedUniqueValues();\n    const selectedValues = new Set(column?.getFilterValue() as string[]);\n\n    return (\n        <Popover>\n            <PopoverTrigger asChild>\n                <div className=\"inline-flex flex-row items-center gap-x-0.5\">\n                    <Button\n                        title={title}\n                        variant=\"outline\"\n                        size=\"sm\"\n                        className=\"h-5 border-dashed px-1 py-2.5\"\n                    >\n                        <FilterIcon className={cn(\"h-3.5 w-3.5\")} />\n                        {selectedValues?.size > 0 && (\n                            <>\n                                <Separator\n                                    orientation=\"vertical\"\n                                    className=\"mx-2 h-4\"\n                                />\n                                <Badge\n                                    variant=\"secondary\"\n                                    className=\"rounded-sm p-1 h-3.5 text-xs font-normal lg:hidden\"\n                                >\n                                    {selectedValues.size}\n                                </Badge>\n                                <div className=\"hidden space-x-1 lg:flex\">\n                                    {selectedValues.size > 2 ? (\n                                        <Badge\n                                            variant=\"secondary\"\n                                            className=\"rounded-sm p-1 text-xs h-3.5 font-normal\"\n                                        >\n                                            {selectedValues.size} selected\n                                        </Badge>\n                                    ) : (\n                                        options\n                                            ?.filter((option) =>\n                                                selectedValues.has(\n                                                    option.value,\n                                                ),\n                                            )\n                                            .map((option) => (\n                                                <Badge\n                                                    variant=\"secondary\"\n                                                    key={option.value}\n                                                    className=\"rounded-sm p-1 text-xs h-3.5 font-normal\"\n                                                >\n                                                    {option.label}\n                                                </Badge>\n                                            ))\n                                    )}\n                                </div>\n                            </>\n                        )}\n                    </Button>\n\n                    {selectedValues.size > 0 && (\n                        <Button\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-5 border-dashed px-1 py-2.5\"\n                            onClick={(e) => {\n                                e.preventDefault();\n                                column?.setFilterValue(undefined);\n                            }}\n                        >\n                            <FilterX className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    )}\n                </div>\n            </PopoverTrigger>\n            <PopoverContent className=\"w-[200px] p-0\" align={align}>\n                <Command>\n                    <CommandInput placeholder={title} />\n                    <CommandList>\n                        <CommandEmpty>No results found.</CommandEmpty>\n                        <CommandGroup>\n                            {options?.map((option) => {\n                                const isSelected = selectedValues.has(\n                                    option.value,\n                                );\n                                return (\n                                    <CommandItem\n                                        key={option.value}\n                                        onSelect={() => {\n                                            if (isSelected) {\n                                                selectedValues.delete(\n                                                    option.value,\n                                                );\n                                            } else {\n                                                selectedValues.add(\n                                                    option.value,\n                                                );\n                                            }\n                                            const filterValues =\n                                                Array.from(selectedValues);\n                                            column?.setFilterValue(\n                                                filterValues.length\n                                                    ? filterValues\n                                                    : undefined,\n                                            );\n                                        }}\n                                    >\n                                        <div\n                                            className={cn(\n                                                \"mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary\",\n                                                isSelected\n                                                    ? \"bg-primary text-primary-foreground\"\n                                                    : \"opacity-50 [&_svg]:invisible\",\n                                            )}\n                                        >\n                                            <CheckIcon\n                                                className={cn(\"h-4 w-4\")}\n                                            />\n                                        </div>\n                                        {option.icon && (\n                                            <option.icon className=\"mr-2 h-4 w-4 text-muted-foreground\" />\n                                        )}\n                                        <span>{option.label}</span>\n                                        {facets?.get(option.value) && (\n                                            <span className=\"ml-auto flex h-4 w-4 items-center justify-center font-mono text-xs\">\n                                                {facets.get(option.value)}\n                                            </span>\n                                        )}\n                                    </CommandItem>\n                                );\n                            })}\n                        </CommandGroup>\n                        {selectedValues.size > 0 && (\n                            <>\n                                <CommandSeparator />\n                                <CommandGroup>\n                                    <CommandItem\n                                        onSelect={() =>\n                                            column?.setFilterValue(undefined)\n                                        }\n                                        className=\"justify-center text-center\"\n                                    >\n                                        Clear filters\n                                    </CommandItem>\n                                </CommandGroup>\n                            </>\n                        )}\n                    </CommandList>\n                </Command>\n            </PopoverContent>\n        </Popover>\n    );\n}\n", "import { FilterIcon, FilterX } from \"lucide-react\";\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport { Button } from \"@/ui/button\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"@/ui/popover\";\nimport { Input } from \"@/ui/input\";\nimport { Separator } from \"@/ui/separator\";\n\nexport function TableFilterSearchColumn({\n    column,\n    title,\n    align = \"start\",\n}: TableFilterProps) {\n    const selectedValue = column?.getFilterValue() as string;\n\n    return (\n        <Popover>\n            <PopoverTrigger asChild>\n                <div className=\"inline-flex flex-row items-center gap-x-0.5\">\n                    {selectedValue ? (\n                        <Button\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-5 border-dashed px-1 py-2.5\"\n                            onClick={(e) => {\n                                e.preventDefault();\n                                column?.setFilterValue(undefined);\n                            }}\n                        >\n                            <FilterX className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    ) : (\n                        <Button\n                            title={title}\n                            variant=\"outline\"\n                            size=\"sm\"\n                            className=\"h-4 border-dashed px-1 py-2.5\"\n                        >\n                            <FilterIcon className={cn(\"h-3.5 w-3.5\")} />\n                        </Button>\n                    )}\n                </div>\n            </PopoverTrigger>\n            <PopoverContent\n                className=\"w-[200px] p-0 overflow-hidden border-0 ring-0\"\n                align={align}\n            >\n                <div className=\"relative\">\n                    <div className=\"flex flex-row items-center px-3 text-popover-foreground bg-popover\">\n                        <svg\n                            width=\"15\"\n                            height=\"15\"\n                            viewBox=\"0 0 15 15\"\n                            fill=\"none\"\n                            xmlns=\"http://www.w3.org/2000/svg\"\n                            className=\"mr-2 h-4 w-4 shrink-0 opacity-50\"\n                        >\n                            <path\n                                d=\"M10 6.5C10 8.433 8.433 10 6.5 10C4.567 10 3 8.433 3 6.5C3 4.567 4.567 3 6.5 3C8.433 3 10 4.567 10 6.5ZM9.30884 10.0159C8.53901 10.6318 7.56251 11 6.5 11C4.01472 11 2 8.98528 2 6.5C2 4.01472 4.01472 2 6.5 2C8.98528 2 11 4.01472 11 6.5C11 7.56251 10.6318 8.53901 10.0159 9.30884L12.8536 12.1464C13.0488 12.3417 13.0488 12.6583 12.8536 12.8536C12.6583 13.0488 12.3417 13.0488 12.1464 12.8536L9.30884 10.0159Z\"\n                                fill=\"currentColor\"\n                                fillRule=\"evenodd\"\n                                clipRule=\"evenodd\"\n                            ></path>\n                        </svg>\n                        <Input\n                            defaultValue={selectedValue ?? \"\"}\n                            onChange={(e) => {\n                                column?.setFilterValue(e.target.value);\n                            }}\n                            className={cn(\n                                \"h-10 border-0 focus-visible:ring-0 ring-0 rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground shadow-none disabled:cursor-not-allowed disabled:opacity-50\",\n                            )}\n                            placeholder={title}\n                        />\n                    </div>\n                    {selectedValue && (\n                        <>\n                            <Separator />\n                            <div className=\"flex flex-row items-center justify-center py-3\">\n                                <Button\n                                    variant=\"outline\"\n                                    size=\"sm\"\n                                    className=\"h-8 border-dashed px-2\"\n                                    onClick={() => {\n                                        column?.setFilterValue(undefined);\n                                    }}\n                                >\n                                    <FilterX size={16} className=\"mr-2\" />\n                                    Clear\n                                </Button>\n                            </div>\n                        </>\n                    )}\n                </div>\n            </PopoverContent>\n        </Popover>\n    );\n}\n", "import { Button } from \"@/ui/button\";\nimport { Checkbox } from \"@/ui/checkbox\";\nimport { DotsVerticalIcon } from \"@radix-ui/react-icons\";\nimport {\n    DropdownMenu,\n    DropdownMenuContent,\n    DropdownMenuItem,\n    DropdownMenuLabel,\n    DropdownMenuSeparator,\n    DropdownMenuTrigger,\n} from \"@/ui/dropdown-menu\";\n\nimport { BaseRecord, HttpError } from \"@refinedev/core\";\nimport { UseTableReturnType } from \"@refinedev/react-table\";\n\nimport { FC, forwardRef, PropsWithChildren } from \"react\";\n\ntype CheckAllProps = React.ComponentPropsWithoutRef<typeof Checkbox> &\n    PropsWithChildren<{\n        table: UseTableReturnType<BaseRecord, HttpError>;\n        options?: {\n            label: string;\n            onClick: () => void;\n        }[];\n    }>;\n\nexport const CheckAll: FC<CheckAllProps> = forwardRef<\n    React.ElementRef<typeof Checkbox>,\n    CheckAllProps\n>(({ table, children, options }, ref) => {\n    return (\n        <>\n            <Checkbox\n                ref={ref}\n                checked={\n                    table.getIsSomeRowsSelected()\n                        ? \"indeterminate\"\n                        : table.getIsAllPageRowsSelected()\n                }\n                onCheckedChange={(value) =>\n                    table.toggleAllPageRowsSelected(!!value)\n                }\n                className=\"translate-y-[2px]\"\n                aria-label=\"Select all\"\n            />\n            {children ||\n                (Array.isArray(options) && options.length && (\n                    <DropdownMenu>\n                        <DropdownMenuTrigger asChild>\n                            <Button\n                                disabled={\n                                    !(\n                                        table.getIsSomeRowsSelected() ||\n                                        table.getIsAllPageRowsSelected()\n                                    )\n                                }\n                                size={\"icon\"}\n                                variant={\"ghost\"}\n                                className=\"px-0 w-5\"\n                            >\n                                <DotsVerticalIcon className=\"w-4 h-4\" />\n                            </Button>\n                        </DropdownMenuTrigger>\n                        <DropdownMenuContent align=\"start\">\n                            <DropdownMenuLabel>Bulk Actions</DropdownMenuLabel>\n                            <DropdownMenuSeparator />\n                            {!children &&\n                            Array.isArray(options) &&\n                            options?.length > 0\n                                ? options.map((option, key) => (\n                                      <DropdownMenuItem\n                                          key={key}\n                                          onSelect={option.onClick}\n                                      >\n                                          {option.label}\n                                      </DropdownMenuItem>\n                                  ))\n                                : children}\n                        </DropdownMenuContent>\n                    </DropdownMenu>\n                ))}\n        </>\n    );\n});\n\nCheckAll.displayName = \"CheckAll\";\n", "import {\n    ChevronLeftIcon,\n    ChevronRightIcon,\n    DoubleArrowLeftIcon,\n    DoubleArrowRightIcon,\n} from \"@radix-ui/react-icons\";\nimport { UseTableReturnType as Table } from \"@refinedev/react-table\";\n\nimport { BaseRecord } from \"@refinedev/core\";\nimport {\n    Select,\n    SelectContent,\n    SelectItem,\n    SelectTrigger,\n    SelectValue,\n} from \"@/ui/select\";\nimport { Button } from \"@/ui/button\";\nimport React, { FC } from \"react\";\n\ninterface DataTablePaginationProps<TData extends BaseRecord = BaseRecord> {\n    table: Table<TData>;\n}\n\nexport const Pagination = <TData extends BaseRecord = BaseRecord>({\n    table,\n}: DataTablePaginationProps<TData>) => {\n    return (\n        <div className=\"flex flex-col sm:flex-row gap-y-4 sm-gap-y-0 items-center justify-between\">\n            <div className=\"flex-1 text-sm text-muted-foreground\">\n                {table.getFilteredSelectedRowModel().rows.length} of{\" \"}\n                {table.getFilteredRowModel().rows.length} row(s) selected.\n            </div>\n            <div className=\"flex relative flex-col-reverse gap-y-4 sm:gap-y-0 sm:flex-row items-center space-x-6 lg:space-x-8\">\n                <div className=\"flex items-center space-x-2\">\n                    <p className=\"text-sm font-medium\">Rows per page</p>\n                    <Select\n                        value={`${table.getState().pagination.pageSize}`}\n                        onValueChange={(value) => {\n                            table.setPageSize(Number(value));\n                        }}\n                    >\n                        <SelectTrigger className=\"h-8 w-[70px]\">\n                            <SelectValue\n                                placeholder={\n                                    table.getState().pagination.pageSize\n                                }\n                            />\n                        </SelectTrigger>\n                        <SelectContent>\n                            {[10, 20, 30, 40, 50].map((pageSize) => (\n                                <SelectItem\n                                    key={pageSize}\n                                    value={`${pageSize}`}\n                                >\n                                    {pageSize}\n                                </SelectItem>\n                            ))}\n                        </SelectContent>\n                    </Select>\n                </div>\n                <div className=\"flex w-fit items-center justify-center text-sm font-medium\">\n                    Page {table.getState().pagination.pageIndex + 1} of{\" \"}\n                    {table.getPageCount()}\n                </div>\n                <div className=\"flex items-center space-x-2\">\n                    <Button\n                        variant=\"outline\"\n                        className=\"hidden h-8 w-8 p-0 lg:flex\"\n                        onClick={() => table.setPageIndex(0)}\n                        disabled={!table.getCanPreviousPage()}\n                    >\n                        <span className=\"sr-only\">Go to first page</span>\n                        <DoubleArrowLeftIcon className=\"h-4 w-4\" />\n                    </Button>\n                    <Button\n                        variant=\"outline\"\n                        className=\"h-8 w-8 p-0\"\n                        onClick={() => table.previousPage()}\n                        disabled={!table.getCanPreviousPage()}\n                    >\n                        <span className=\"sr-only\">Go to previous page</span>\n                        <ChevronLeftIcon className=\"h-4 w-4\" />\n                    </Button>\n                    <Button\n                        variant=\"outline\"\n                        className=\"h-8 w-8 p-0\"\n                        onClick={() => table.nextPage()}\n                        disabled={!table.getCanNextPage()}\n                    >\n                        <span className=\"sr-only\">Go to next page</span>\n                        <ChevronRightIcon className=\"h-4 w-4\" />\n                    </Button>\n                    <Button\n                        variant=\"outline\"\n                        className=\"hidden h-8 w-8 p-0 lg:flex\"\n                        onClick={() =>\n                            table.setPageIndex(table.getPageCount() - 1)\n                        }\n                        disabled={!table.getCanNextPage()}\n                    >\n                        <span className=\"sr-only\">Go to last page</span>\n                        <DoubleArrowRightIcon className=\"h-4 w-4\" />\n                    </Button>\n                </div>\n            </div>\n        </div>\n    );\n};\n\nPagination.displayName = \"Pagination\";\n", "import { CaretDownIcon, CaretUpIcon } from \"@radix-ui/react-icons\";\nimport type { TableFilterProps } from \"..\";\nimport { cn } from \"@/lib/utils\";\nimport type { BaseRecord } from \"@refinedev/core\";\n\nexport const SortAction = <TData extends BaseRecord = BaseRecord>({\n  column,\n}: Pick<TableFilterProps<TData>, \"column\">) => {\n  return (\n    <div\n      className=\"cursor-pointer\"\n      onClick={() => {\n        column?.toggleSorting(column?.getIsSorted() === \"asc\");\n      }}\n    >\n      <div className=\"inline-flex flex-col\">\n        <CaretUpIcon\n          className={cn(\n            \"-mb-1.5 w-5 h-5\",\n            column?.getIsSorted() === \"asc\" ? \"text-foreground\" : \"text-input\"\n          )}\n        />\n        <CaretDownIcon\n          className={cn(\n            \"-mt-1.5 w-5 h-5\",\n            column?.getIsSorted() === \"desc\" ? \"text-foreground\" : \"text-input\"\n          )}\n        />\n      </div>\n    </div>\n  );\n};\n", "\"use client\";\nimport { DropdownMenuTrigger } from \"@radix-ui/react-dropdown-menu\";\nimport { MixerHorizontalIcon } from \"@radix-ui/react-icons\";\nimport { Table } from \"@tanstack/react-table\";\nimport { Button } from \"@/ui/button\";\nimport {\n    DropdownMenu,\n    DropdownMenuCheckboxItem,\n    DropdownMenuContent,\n    DropdownMenuLabel,\n    DropdownMenuSeparator,\n} from \"@/ui/dropdown-menu\";\nimport { FC, useMemo } from \"react\";\n\ninterface DataTableViewOptionsProps<TData> {\n    table: Table<TData>;\n}\n\nexport const DataTableViewOptions = <TData,>({\n    table,\n}: DataTableViewOptionsProps<TData>): ReturnType<\n    FC<DataTableViewOptionsProps<TData>>\n> => {\n    const columns = useMemo(() => {\n        return table\n            .getAllColumns()\n            .filter(\n                (column) =>\n                    typeof column.accessorFn !== \"undefined\" &&\n                    column.getCanHide(),\n            );\n    }, [table]);\n\n    return (\n        <DropdownMenu>\n            <DropdownMenuTrigger asChild>\n                <Button\n                    variant=\"outline\"\n                    size=\"sm\"\n                    className=\"ml-auto hidden h-8 lg:flex\"\n                >\n                    <MixerHorizontalIcon className=\"mr-2 h-4 w-4\" />\n                    View\n                </Button>\n            </DropdownMenuTrigger>\n            <DropdownMenuContent align=\"end\" className=\"w-[150px]\">\n                <DropdownMenuLabel>Toggle columns</DropdownMenuLabel>\n                <DropdownMenuSeparator />\n                {columns.map((column) => {\n                    return (\n                        <DropdownMenuCheckboxItem\n                            key={column.id}\n                            className=\"capitalize\"\n                            checked={column.getIsVisible()}\n                            onCheckedChange={(value) =>\n                                column.toggleVisibility(value)\n                            }\n                        >\n                            {column.id}\n                        </DropdownMenuCheckboxItem>\n                    );\n                })}\n            </DropdownMenuContent>\n        </DropdownMenu>\n    );\n};\n\nDataTableViewOptions.displayName = \"DataTableViewOptions\";\n", "\"use client\";\n\nimport { Table } from \"@tanstack/react-table\";\n\nimport { DataTableViewOptions } from \"./table-view-options-dropdown\";\n\ninterface DataTableToolbarProps<TData> {\n  table: Table<TData>;\n}\n\nexport function DataTableToolbar<TData>({\n  table,\n}: DataTableToolbarProps<TData>) {\n  return (\n    <div className=\"flex items-center justify-between\">\n      <div className=\"flex flex-1 items-center space-x-2\"></div>\n      <DataTableViewOptions table={table} />\n    </div>\n  );\n}\n", "import { useDeleteHelper } from \"@/hooks\";\nimport { DeleteContext } from \"@/providers\";\nimport { useContext } from \"react\";\nimport type { RowActionProps } from \".\";\nimport { RowAction } from \".\";\n\ntype DeleteActionProps = RowActionProps & {\n    row: any;\n    resource: string;\n    title: string;\n    onAfterHandle?: () => void;\n};\n\nexport function DeleteAction({\n    row,\n    resource,\n    title,\n    disabled,\n    onAfterHandle,\n    ...props\n}: DeleteActionProps) {\n    const { can, reason } = useDeleteHelper(resource, row.id);\n    const deleteContext = useContext(DeleteContext);\n\n    return (\n        <RowAction\n            {...props}\n            disabled={!can || disabled}\n            title={!can ? reason : title}\n            onClick={() =>\n                deleteContext?.updateData({\n                    row,\n                    resource,\n                    toogle: true,\n                    onAfterHandle,\n                })\n            }\n        />\n    );\n}\n\nDeleteAction.displayName = \"DeleteAction\";\n"],
  "mappings": "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",
  "names": ["src_exports", "__export", "BaseLayout", "Breadcrumbs", "CloneButton", "Combobox", "ConfirmDialog", "CreateButton", "CreatePage", "DefaultLayout", "DeleteActionModal", "DeleteButton", "DeleteContext", "DeleteProvider", "EditButton", "EditPage", "ExportButton", "Field", "Form", "ImportButton", "Link", "ListButton", "ListPage", "ModeToggle", "PageHeader", "RefreshButton", "SaveButton", "Select", "ShowButton", "ShowPage", "Sidebar", "Table", "notificationProvider", "useNotificationProvider", "__toCommonJS", "import_react_slot", "import_class_variance_authority", "React", "import_clsx", "import_tailwind_merge", "cn", "inputs", "__name", "import_lucide_react", "import_react", "import_jsx_runtime", "LoadingIcon", "React", "className", "props", "ref", "cn", "import_jsx_runtime", "buttonVariants", "Button", "className", "variant", "size", "icon", "loading", "asChild", "children", "disabled", "props", "ref", "Icon", "LoadingIcon", "cn", "import_core", "import_lucide_react", "import_jsx_runtime", "CloneButton", "__name", "resource", "recordItemId", "hideText", "accessControl", "meta", "onClick", "children", "props", "to", "LinkComponent", "label", "disabled", "hidden", "title", "e", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "CreateButton", "__name", "resource", "hideText", "accessControl", "meta", "onClick", "children", "props", "hidden", "disabled", "label", "title", "LinkComponent", "to", "e", "Button", "import_core", "import_lucide_react", "React", "import_react_icons", "import_react_slot", "import_jsx_runtime", "Breadcrumb", "props", "ref", "BreadcrumbList", "className", "cn", "BreadcrumbItem", "BreadcrumbLink", "asChild", "BreadcrumbPage", "BreadcrumbSeparator", "__name", "children", "BreadcrumbEllipsis", "import_core", "import_react", "import_react_slot", "import_core", "import_react", "import_jsx_runtime", "Link", "children", "href", "title", "className", "asChild", "ref", "LegacyLink", "routerType", "import_lucide_react", "import_jsx_runtime", "Breadcrumbs", "__name", "showHome", "meta", "breadcrumbs", "hasDashboard", "resources", "dashboardResource", "rootRouteResource", "BreadCrumbItems", "label", "href", "key", "BreadcrumbItem", "BreadcrumbLink", "Link", "BreadcrumbPage", "BreadcrumbSeparator", "Breadcrumb", "BreadcrumbList", "import_react_icons", "AlertDialogPrimitive", "React", "import_jsx_runtime", "AlertDialog", "AlertDialogTrigger", "AlertDialogPortal", "AlertDialogOverlay", "className", "props", "ref", "cn", "AlertDialogContent", "AlertDialogHeader", "__name", "AlertDialogFooter", "AlertDialogTitle", "AlertDialogDescription", "AlertDialogAction", "variant", "size", "buttonVariants", "AlertDialogCancel", "import_class_variance_authority", "import_jsx_runtime", "badgeVariants", "Badge", "className", "variant", "props", "cn", "__name", "import_react_icons", "import_react_day_picker", "import_jsx_runtime", "Calendar", "className", "classNames", "showOutsideDays", "props", "cn", "buttonVariants", "__name", "React", "import_jsx_runtime", "Card", "className", "props", "ref", "cn", "CardHeader", "CardTitle", "CardDescription", "CardContent", "CardFooter", "React", "CheckboxPrimitive", "import_react_icons", "import_jsx_runtime", "Checkbox", "className", "props", "ref", "cn", "React", "import_react_icons", "import_cmdk", "React", "DialogPrimitive", "import_react_icons", "import_jsx_runtime", "DialogPortal", "DialogOverlay", "className", "props", "ref", "cn", "DialogContent", "children", "DialogPortal", "DialogHeader", "__name", "DialogFooter", "DialogTitle", "DialogDescription", "import_jsx_runtime", "Command", "className", "props", "ref", "CommandPrimitive", "cn", "CommandInput", "className", "props", "ref", "CommandPrimitive", "cn", "CommandList", "CommandEmpty", "CommandGroup", "CommandSeparator", "CommandItem", "CommandShortcut", "__name", "React", "DropdownMenuPrimitive", "import_react_icons", "import_jsx_runtime", "DropdownMenu", "DropdownMenuTrigger", "DropdownMenuSubTrigger", "className", "inset", "children", "props", "ref", "cn", "DropdownMenuSubContent", "DropdownMenuContent", "sideOffset", "DropdownMenuItem", "DropdownMenuCheckboxItem", "checked", "DropdownMenuRadioItem", "DropdownMenuLabel", "DropdownMenuSeparator", "DropdownMenuShortcut", "__name", "React", "import_react_slot", "import_react_hook_form", "React", "LabelPrimitive", "import_class_variance_authority", "import_jsx_runtime", "labelVariants", "Label", "className", "props", "ref", "cn", "import_jsx_runtime", "Form", "FormFieldContext", "FormField", "__name", "props", "useFormField", "fieldContext", "itemContext", "FormItemContext", "getFieldState", "formState", "fieldState", "id", "FormItem", "className", "ref", "cn", "FormLabel", "error", "formItemId", "Label", "FormControl", "formDescriptionId", "formMessageId", "FormDescription", "FormMessage", "children", "body", "React", "import_jsx_runtime", "Input", "className", "type", "props", "ref", "cn", "React", "PopoverPrimitive", "import_jsx_runtime", "Popover", "PopoverTrigger", "PopoverContent", "className", "align", "sideOffset", "props", "ref", "cn", "import_react_icons", "ResizablePrimitive", "import_jsx_runtime", "ResizablePanelGroup", "__name", "className", "props", "cn", "ResizablePanel", "ResizableHandle", "withHandle", "React", "ScrollAreaPrimitive", "import_jsx_runtime", "ScrollArea", "className", "children", "props", "ref", "cn", "ScrollBar", "orientation", "React", "import_react_icons", "SelectPrimitive", "import_jsx_runtime", "Select", "SelectValue", "SelectTrigger", "className", "children", "props", "ref", "cn", "SelectScrollUpButton", "SelectScrollDownButton", "SelectContent", "position", "SelectLabel", "SelectItem", "SelectSeparator", "React", "SeparatorPrimitive", "import_jsx_runtime", "Separator", "className", "orientation", "decorative", "props", "ref", "cn", "import_next_themes", "import_sonner", "import_jsx_runtime", "Toaster", "__name", "props", "theme", "Sonner", "React", "import_jsx_runtime", "Table", "className", "props", "ref", "cn", "TableHeader", "TableBody", "TableFooter", "TableRow", "TableHead", "TableCell", "TableCaption", "React", "import_jsx_runtime", "Textarea", "className", "props", "ref", "cn", "React", "TooltipPrimitive", "import_jsx_runtime", "TooltipProvider", "Tooltip", "TooltipTrigger", "TooltipContent", "className", "sideOffset", "props", "ref", "cn", "import_react", "import_jsx_runtime", "Combobox", "props", "ref", "open", "setOpen", "value", "__name", "Popover", "PopoverTrigger", "FormControl", "Button", "cn", "option", "PopoverContent", "Command", "CommandInput", "CommandList", "CommandEmpty", "CommandGroup", "ScrollArea", "CommandItem", "import_lucide_react", "import_react", "import_jsx_runtime", "ConfirmDialog", "__name", "children", "title", "description", "okText", "cancelText", "okButtonSize", "cancelButtonSize", "okButtonVariant", "cancelButtonVariant", "loading", "okIconSide", "cancelIconSide", "onConfirm", "okIcon", "cancelIcon", "open", "onOpenChange", "defaultOpen", "CancelIcon", "OkIcon", "LoadingIcon", "AlertDialog", "AlertDialogTrigger", "AlertDialogContent", "AlertDialogHeader", "AlertDialogTitle", "AlertDialogDescription", "AlertDialogFooter", "AlertDialogCancel", "AlertDialogAction", "import_react", "import_jsx_runtime", "Field", "__name", "props", "FormField", "field", "FormItem", "cn", "FormLabel", "FormControl", "FormDescription", "FormMessage", "import_core", "import_react", "import_jsx_runtime", "Form", "__name", "formProps", "isWatchable", "saveButtonProps", "props", "watchable", "_resource", "action", "routerType", "back", "goBack", "onBack", "onSubmit", "_data", "Card", "CardContent", "CardFooter", "Button", "SaveButton", "import_next_themes", "import_react_icons", "import_jsx_runtime", "ModeToggle", "__name", "setTheme", "DropdownMenu", "DropdownMenuTrigger", "Button", "DropdownMenuContent", "DropdownMenuItem", "import_jsx_runtime", "PageHeader", "__name", "extra", "props", "cn", "import_react", "import_jsx_runtime", "Select", "props", "ref", "triggerRef", "React", "FormControl", "SelectTrigger", "SelectValue", "SelectContent", "option", "key", "SelectItem", "import_core", "import_react_use", "import_react", "import_jsx_runtime", "Sidebar", "__name", "isCollapsed", "menuItems", "resourceParams", "pathname", "currentPathname", "GetIcon", "item", "icon", "React", "i", "key", "paths", "isActive", "path", "Tooltip", "TooltipTrigger", "Link", "cn", "buttonVariants", "TooltipContent", "import_jsx_runtime", "DeleteButton", "__name", "resource", "recordItemId", "onSuccess", "mutationModeProp", "confirmTitle", "confirmDescription", "successNotification", "errorNotification", "hideText", "accessControl", "meta", "dataProviderName", "confirmOkText", "confirmCancelText", "invalidates", "children", "props", "title", "label", "hidden", "disabled", "loading", "defaultConfirmTitle", "defaultConfirmOkLabel", "defaultCancelLabel", "onConfirm", "ConfirmDialog", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "EditButton", "__name", "resource", "recordItemId", "hideText", "accessControl", "meta", "onClick", "children", "props", "hidden", "disabled", "label", "title", "LinkComponent", "to", "e", "Button", "import_react_slot", "import_core", "import_lucide_react", "import_jsx_runtime", "ExportButton", "__name", "hideText", "resource", "recordItemId", "accessControl", "access", "children", "props", "label", "Com", "Button", "import_react_slot", "import_core", "import_lucide_react", "import_jsx_runtime", "ImportButton", "__name", "hideText", "resource", "onChange", "accept", "recordItemId", "accessControl", "access", "children", "props", "label", "Com", "onClick", "el", "e", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "ListButton", "__name", "resourceNameFromProps", "hideText", "accessControl", "meta", "children", "onClick", "props", "hidden", "disabled", "label", "title", "LinkComponent", "to", "e", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "RefreshButton", "__name", "resource", "recordItemId", "hideText", "dataProviderName", "children", "props", "onClick", "label", "loading", "Button", "import_react_slot", "import_core", "import_lucide_react", "import_jsx_runtime", "SaveButton", "__name", "hideText", "children", "accessControl", "access", "resource", "recordItemId", "props", "label", "Com", "Button", "import_core", "import_lucide_react", "import_jsx_runtime", "ShowButton", "__name", "resourceNameFromProps", "recordItemId", "hideText", "accessControl", "meta", "children", "onClick", "props", "to", "label", "title", "hidden", "disabled", "LinkComponent", "e", "Button", "import_core", "import_react", "import_jsx_runtime", "CreatePage", "__name", "title", "resourceFromProps", "breadcrumbFromProps", "extra", "children", "translate", "globalBreadcrumb", "getUserFriendlyName", "resource", "identifier", "breadcrumb", "PageHeader", "Breadcrumbs", "ListButton", "import_core", "import_react", "import_jsx_runtime", "EditPage", "__name", "title", "resource", "extra", "breadcrumbFromProps", "children", "translate", "globalBreadcrumb", "list", "getUserFriendlyName", "_resource", "identifier", "breadcrumb", "PageHeader", "Breadcrumbs", "ShowButton", "DeleteButton", "import_core", "import_react", "import_jsx_runtime", "ListPage", "__name", "title", "resourceFromProps", "breadcrumbFromProps", "createButtonProps", "className", "isCreate", "extra", "children", "translate", "globalBreadcrumb", "getUserFriendlyName", "resource", "identifier", "breadcrumb", "PageHeader", "Breadcrumbs", "CreateButton", "cn", "import_core", "import_react", "import_jsx_runtime", "Row", "__name", "title", "children", "import_jsx_runtime", "ShowPage", "__name", "title", "resourceFromProps", "breadcrumbFromProps", "isEdit", "isDelete", "extra", "children", "translate", "globalBreadcrumb", "getUserFriendlyName", "resource", "identifier", "list", "breadcrumb", "PageHeader", "Breadcrumbs", "EditButton", "DeleteButton", "Row", "import_next_themes", "import_jsx_runtime", "ThemeProvider", "children", "props", "NextThemesProvider", "__name", "import_jsx_runtime", "BaseLayout", "__name", "attribute", "defaultTheme", "enableSystem", "disableTransitionOnChange", "enableColorScheme", "forcedTheme", "nonce", "storageKey", "themes", "value", "children", "ThemeProvider", "TooltipProvider", "Toaster", "React", "queriesDidChange", "prevQueries", "nextQueries", "nextQueriesArr", "prevQueriesArr", "q", "i", "prevKeys", "n", "__name", "_ref", "curr", "key", "init", "queries", "queryKeys", "state", "name", "mql", "reducer", "action", "_ref2", "prev", "useMediaQueries", "queryMap", "dispatch", "_ref3", "_ref4", "mq", "callback", "callbacks", "_ref5", "matches", "matchValues", "useMediaQuery", "query", "getObj", "cache", "import_core", "import_react", "import_jsx_runtime", "DefaultLayout", "__name", "children", "defaultLayout", "defaultCollapsed", "navCollapsedSize", "navbar", "footer", "logo", "attribute", "defaultTheme", "enableSystem", "disableTransitionOnChange", "enableColorScheme", "forcedTheme", "nonce", "storageKey", "themes", "value", "resources", "firstDashboard", "xs", "useMediaQuery", "sm", "md", "lg", "isCollapsed", "setIsCollapsed", "layout", "SidebarSizes", "hasCollapsed", "Logo", "component", "BaseLayout", "ResizablePanelGroup", "sizes", "ResizablePanel", "collapsed", "cn", "Link", "Sidebar", "ResizableHandle", "ModeToggle", "import_sonner", "notificationProvider", "__name", "key", "message", "description", "type", "useNotificationProvider", "import_core", "import_react", "useGetEditUrl", "__name", "resource", "recordItemId", "meta", "accessControlContext", "accessControlEnabled", "hideIfUnauthorized", "generateEditUrl", "id", "_resource", "data", "translate", "reason", "editUrl", "import_core", "import_react", "useGetShowUrl", "__name", "resource", "recordItemId", "meta", "accessControlContext", "accessControlEnabled", "hideIfUnauthorized", "generateShowUrl", "id", "_resource", "data", "translate", "reason", "showUrl", "import_core", "import_react", "useDeleteHelper", "__name", "resource", "recordItemId", "meta", "accessControlContext", "accessControlEnabled", "hideIfUnauthorized", "translate", "id", "_resource", "identifier", "mutationMode", "mutate", "isLoading", "data", "reason", "setWarnWhen", "onDeleteMutate", "options", "import_core", "useOnBack", "__name", "routerType", "back", "goBack", "action", "import_core", "import_react", "import_jsx_runtime", "DeleteActionModal", "props", "back", "useOnBack", "can", "isLoading", "mutate", "useDeleteHelper", "translate", "onDelete", "isRedirectBack", "onAfterHandle", "ConfirmDialog", "__name", "DeleteContext", "DeleteProvider", "children", "data", "setData", "updateData", "import_react", "import_jsx_runtime", "Loader", "className", "props", "ref", "cn", "loader_default", "import_react_table", "import_react", "import_react_icons", "import_jsx_runtime", "RowAction", "__name", "props", "DropdownMenuItem", "Link", "RowActions", "children", "DropdownMenu", "DropdownMenuTrigger", "Button", "DropdownMenuContent", "import_jsx_runtime", "EditAction", "row", "resource", "title", "disabled", "props", "edit", "useGetEditUrl", "RowAction", "__name", "import_jsx_runtime", "ShowAction", "row", "resource", "title", "disabled", "props", "detail", "useGetShowUrl", "RowAction", "__name", "import_date_fns", "import_lucide_react", "import_react", "import_jsx_runtime", "TableFilterDateRangePickerFilter", "column", "title", "numberOfMonths", "align", "date", "setDate", "selectedValues", "dates", "Popover", "PopoverTrigger", "Button", "cn", "Separator", "Badge", "e", "PopoverContent", "Calendar", "__name", "import_react_icons", "import_lucide_react", "import_jsx_runtime", "TableFilterDropdown", "column", "title", "options", "align", "facets", "selectedValues", "Popover", "PopoverTrigger", "Button", "cn", "Separator", "Badge", "option", "e", "PopoverContent", "Command", "CommandInput", "CommandList", "CommandEmpty", "CommandGroup", "isSelected", "CommandItem", "filterValues", "CommandSeparator", "__name", "import_lucide_react", "import_jsx_runtime", "TableFilterSearchColumn", "column", "title", "align", "selectedValue", "Popover", "PopoverTrigger", "Button", "e", "cn", "PopoverContent", "Input", "Separator", "__name", "import_react_icons", "import_react", "import_jsx_runtime", "CheckAll", "table", "children", "options", "ref", "Checkbox", "value", "DropdownMenu", "DropdownMenuTrigger", "Button", "DropdownMenuContent", "DropdownMenuLabel", "DropdownMenuSeparator", "option", "key", "DropdownMenuItem", "import_react_icons", "import_jsx_runtime", "Pagination", "__name", "table", "Select", "value", "SelectTrigger", "SelectValue", "SelectContent", "pageSize", "SelectItem", "Button", "import_react_icons", "import_jsx_runtime", "SortAction", "__name", "column", "cn", "import_react_dropdown_menu", "import_react_icons", "import_react", "import_jsx_runtime", "DataTableViewOptions", "__name", "table", "columns", "column", "DropdownMenu", "Button", "DropdownMenuContent", "DropdownMenuLabel", "DropdownMenuSeparator", "DropdownMenuCheckboxItem", "value", "import_jsx_runtime", "DataTableToolbar", "table", "DataTableViewOptions", "__name", "import_react", "import_jsx_runtime", "DeleteAction", "row", "resource", "title", "disabled", "onAfterHandle", "props", "can", "reason", "useDeleteHelper", "deleteContext", "DeleteContext", "RowAction", "__name", "import_jsx_runtime", "Table", "children", "showHeader", "columns", "props", "mapColumn", "id", "accessorKey", "header", "enableSorting", "enableHiding", "filter", "cell", "column", "value", "table", "tableOptions", "isFilterable", "DeleteProvider", "DataTableToolbar", "TableHeader", "headerGroup", "TableRow", "columnDef", "TableHead", "SortAction", "TableBody", "TableCell", "loader_default", "row", "Pagination", "__name", "TableColumn", "CheckAll", "RowActions", "RowAction", "EditAction", "ShowAction", "DeleteAction", "TableFilterDateRangePickerFilter", "TableFilterDropdown", "TableFilterSearchColumn"]
}
 \ No newline at end of file diff --git a/packages/theme/package.json b/packages/theme/package.json index b505395..62569fe 100644 --- a/packages/theme/package.json +++ b/packages/theme/package.json @@ -1,6 +1,6 @@ { "name": "@ferdiunal/refine-shadcn", - "version": "1.1.0", + "version": "1.1.1", "description": "theme for refine.dev with shadcn-ui", "main": "dist/index.js", "module": "dist/index.mjs",