@samkwang/ui-kit 0.5.2 → 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  "use client";
2
- import*as Gr from"react";import{Slot as ms}from"@radix-ui/react-slot";import{cva as xs}from"class-variance-authority";import{clsx as cs}from"clsx";import{twMerge as ps}from"tailwind-merge";function o(...e){return ps(cs(e))}import{jsx as Wr,jsxs as Ls}from"react/jsx-runtime";var ke=xs("inline-flex items-center justify-center gap-2 whitespace-nowrap font-medium transition-colors duration-[110ms] ease-[cubic-bezier(0,0,0.38,0.9)] disabled:pointer-events-none disabled:opacity-40 [&_svg]:pointer-events-none [&_svg]:shrink-0 min-touch-target",{variants:{variant:{primary:"bg-[var(--color-brand)] text-[var(--app-text-on-color)] hover:bg-[var(--color-brand-hover)] active:bg-[var(--color-brand-active)]",secondary:"border border-[var(--app-border-strong)] bg-transparent text-[var(--app-text)] hover:bg-[var(--app-hover)]",danger:"bg-[var(--color-accent)] text-[var(--app-text-on-color)] hover:bg-[var(--color-accent-hover)]",ghost:"bg-transparent text-[var(--color-brand)] hover:bg-[var(--app-hover)]",link:"bg-transparent text-[var(--color-brand)] underline-offset-4 hover:underline"},size:{sm:"h-8 px-4 text-xs",default:"h-10 px-6 text-sm",lg:"h-12 px-8 text-base",icon:"h-10 w-10"}},defaultVariants:{variant:"primary",size:"default"}}),$a=Gr.forwardRef(({className:e,variant:a,size:t,asChild:r=!1,loading:l,fullWidth:d,disabled:s,children:u,...f},i)=>Ls(r?ms:"button",{className:o(ke({variant:a,size:t}),d&&"w-full",e),ref:i,disabled:s||l,...f,children:[l&&Wr("svg",{className:"h-4 w-4 animate-spin",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:Wr("path",{d:"M12 2a10 10 0 0 1 10 10",strokeLinecap:"round"})}),u]}));$a.displayName="Button";import*as ia from"react";import*as Vr from"react";import*as zr from"@radix-ui/react-label";import{jsx as gs,jsxs as Cs}from"react/jsx-runtime";var Y=Vr.forwardRef(({className:e,required:a,children:t,...r},l)=>Cs(zr.Root,{ref:l,className:o("text-xs font-medium text-[var(--app-text-secondary)] peer-disabled:cursor-not-allowed peer-disabled:opacity-40",e),...r,children:[t,a&&gs("span",{className:"ml-0.5 text-[var(--color-error)]",children:"*"})]}));Y.displayName="Label";import{jsx as ua,jsxs as hs}from"react/jsx-runtime";var Is={sm:"h-8 text-xs",default:"h-10 text-sm",lg:"h-12 text-base"},Ya=ia.forwardRef(({className:e,label:a,helperText:t,errorText:r,required:l,inputSize:d="default",id:s,...u},f)=>{let i=s||ia.useId();return hs("div",{className:"flex flex-col gap-1",children:[a&&ua(Y,{htmlFor:i,required:l,children:a}),ua("input",{id:i,ref:f,required:l,className:o("w-full bg-[var(--app-field)] px-4 font-[var(--font-sans)] text-[var(--app-text)] outline-none border-0 border-b transition-colors duration-[110ms]","placeholder:text-[var(--app-text-placeholder)]","disabled:cursor-not-allowed disabled:opacity-40",!!r?"border-b-2 border-[var(--color-error)]":"border-b border-[var(--app-border-strong)] focus:border-b-2 focus:border-[var(--app-focus)]",Is[d],e),...u}),r&&ua("span",{className:"text-xs text-[var(--color-error)]",children:r}),!r&&t&&ua("span",{className:"text-xs text-[var(--app-text-secondary)]",children:t})]})});Ya.displayName="Input";import*as na from"react";import{jsx as fa,jsxs as bs}from"react/jsx-runtime";var ja=na.forwardRef(({className:e,label:a,helperText:t,errorText:r,required:l,rows:d=4,id:s,...u},f)=>{let i=s||na.useId();return bs("div",{className:"flex flex-col gap-1",children:[a&&fa(Y,{htmlFor:i,required:l,children:a}),fa("textarea",{id:i,ref:f,rows:d,required:l,className:o("w-full resize-y bg-[var(--app-field)] px-4 py-3 font-[var(--font-sans)] text-sm text-[var(--app-text)] outline-none border-0 border-b transition-colors duration-[110ms]","placeholder:text-[var(--app-text-placeholder)]","disabled:cursor-not-allowed disabled:opacity-40",!!r?"border-b-2 border-[var(--color-error)]":"border-b border-[var(--app-border-strong)] focus:border-b-2 focus:border-[var(--app-focus)]",e),...u}),r&&fa("span",{className:"text-xs text-[var(--color-error)]",children:r}),!r&&t&&fa("span",{className:"text-xs text-[var(--app-text-secondary)]",children:t})]})});ja.displayName="Textarea";import*as ma from"react";import{forwardRef as Rs,createElement as ys}from"react";var ca=(...e)=>e.filter((a,t,r)=>!!a&&a.trim()!==""&&r.indexOf(a)===t).join(" ").trim();var Xr=e=>e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase();var _r=e=>e.replace(/^([A-Z])|[\s-_]+(\w)/g,(a,t,r)=>r?r.toUpperCase():t.toLowerCase());var et=e=>{let a=_r(e);return a.charAt(0).toUpperCase()+a.slice(1)};import{forwardRef as ws,createElement as Qr}from"react";var pa={xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};var Kr=e=>{for(let a in e)if(a.startsWith("aria-")||a==="role"||a==="title")return!0;return!1};import{createContext as Ps,useContext as Ss,useMemo as tf,createElement as of}from"react";var vs=Ps({});var Zr=()=>Ss(vs);var Jr=ws(({color:e,size:a,strokeWidth:t,absoluteStrokeWidth:r,className:l="",children:d,iconNode:s,...u},f)=>{let{size:i=24,strokeWidth:x=2,absoluteStrokeWidth:P=!1,color:U="currentColor",className:h=""}=Zr()??{},k=r??P?Number(t??x)*24/Number(a??i):t??x;return Qr("svg",{ref:f,...pa,width:a??i??pa.width,height:a??i??pa.height,stroke:e??U,strokeWidth:k,className:ca("lucide",h,l),...!d&&!Kr(u)&&{"aria-hidden":"true"},...u},[...s.map(([E,D])=>Qr(E,D)),...Array.isArray(d)?d:[d]])});var c=(e,a)=>{let t=Rs(({className:r,...l},d)=>ys(Jr,{ref:d,iconNode:a,className:ca(`lucide-${Xr(et(e))}`,`lucide-${e}`,r),...l}));return t.displayName=et(e),t};var Ms=[["path",{d:"M10.268 21a2 2 0 0 0 3.464 0",key:"vwvbt9"}],["path",{d:"M3.262 15.326A1 1 0 0 0 4 17h16a1 1 0 0 0 .74-1.673C19.41 13.956 18 12.499 18 8A6 6 0 0 0 6 8c0 4.499-1.411 5.956-2.738 7.326",key:"11g9vi"}]],Ve=c("bell",Ms);var ks=[["path",{d:"M8 2v4",key:"1cmpym"}],["path",{d:"M16 2v4",key:"4m81vk"}],["rect",{width:"18",height:"18",x:"3",y:"4",rx:"2",key:"1hopcy"}],["path",{d:"M3 10h18",key:"8toen8"}]],ze=c("calendar",ks);var Ds=[["path",{d:"M20 6 9 17l-5-5",key:"1gmf2c"}]],W=c("check",Ds);var Ts=[["path",{d:"m6 9 6 6 6-6",key:"qrunsl"}]],j=c("chevron-down",Ts);var As=[["path",{d:"m15 18-6-6 6-6",key:"1wnfg3"}]],X=c("chevron-left",As);var Bs=[["path",{d:"m9 18 6-6-6-6",key:"mthhwq"}]],I=c("chevron-right",Bs);var Fs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["line",{x1:"12",x2:"12",y1:"8",y2:"12",key:"1pkeuh"}],["line",{x1:"12",x2:"12.01",y1:"16",y2:"16",key:"4dfq90"}]],se=c("circle-alert",Fs);var Ns=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m9 12 2 2 4-4",key:"dzmm74"}]],_=c("circle-check",Ns);var Hs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m15 9-6 6",key:"1uzhvr"}],["path",{d:"m9 9 6 6",key:"z0biqf"}]],ue=c("circle-x",Hs);var qs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}]],ee=c("circle",qs);var Os=[["circle",{cx:"12.1",cy:"12.1",r:"1",key:"18d7e5"}]],Xe=c("dot",Os);var Us=[["circle",{cx:"12",cy:"12",r:"1",key:"41hilf"}],["circle",{cx:"19",cy:"12",r:"1",key:"1wjl8i"}],["circle",{cx:"5",cy:"12",r:"1",key:"1pcz8c"}]],ie=c("ellipsis",Us);var Es=[["circle",{cx:"9",cy:"12",r:"1",key:"1vctgf"}],["circle",{cx:"9",cy:"5",r:"1",key:"hp0tcf"}],["circle",{cx:"9",cy:"19",r:"1",key:"fkjjf6"}],["circle",{cx:"15",cy:"12",r:"1",key:"1tmaij"}],["circle",{cx:"15",cy:"5",r:"1",key:"19l28e"}],["circle",{cx:"15",cy:"19",r:"1",key:"f4zoj3"}]],_e=c("grip-vertical",Es);var Ws=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"M12 16v-4",key:"1dtifu"}],["path",{d:"M12 8h.01",key:"e9boi3"}]],be=c("info",Ws);var Gs=[["path",{d:"m21 21-4.34-4.34",key:"14j7rj"}],["circle",{cx:"11",cy:"11",r:"8",key:"4ej97u"}]],Pe=c("search",Gs);var Vs=[["path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3",key:"wmoenq"}],["path",{d:"M12 9v4",key:"juzpu7"}],["path",{d:"M12 17h.01",key:"p32p05"}]],K=c("triangle-alert",Vs);var zs=[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]],N=c("x",zs);import{jsx as De,jsxs as at}from"react/jsx-runtime";var Xs={sm:"h-8 text-xs",default:"h-10 text-sm",lg:"h-12 text-base"},tt=ma.forwardRef(({className:e,label:a,helperText:t,errorText:r,options:l,placeholder:d,required:s,selectSize:u="default",id:f,...i},x)=>{let P=f||ma.useId();return at("div",{className:"flex flex-col gap-1",children:[a&&De(Y,{htmlFor:P,required:s,children:a}),at("div",{className:"relative",children:[at("select",{id:P,ref:x,required:s,className:o("w-full appearance-none bg-[var(--app-field)] px-4 pr-10 font-[var(--font-sans)] text-[var(--app-text)] outline-none border-0 border-b transition-colors duration-[110ms] cursor-pointer","disabled:cursor-not-allowed disabled:opacity-40",!!r?"border-b-2 border-[var(--color-error)]":"border-b border-[var(--app-border-strong)] focus:border-b-2 focus:border-[var(--app-focus)]",Xs[u],e),...i,children:[d&&De("option",{value:"",disabled:!0,children:d}),l.map(h=>De("option",{value:h.value,disabled:h.disabled,children:h.label},h.value))]}),De(j,{className:"pointer-events-none absolute right-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[var(--app-text-secondary)]"})]}),r&&De("span",{className:"text-xs text-[var(--color-error)]",children:r}),!r&&t&&De("span",{className:"text-xs text-[var(--app-text-secondary)]",children:t})]})});tt.displayName="Select";import*as La from"react";import*as ga from"@radix-ui/react-checkbox";import{jsx as xa,jsxs as _s}from"react/jsx-runtime";var ot=La.forwardRef(({className:e,label:a,id:t,...r},l)=>{let d=t||La.useId();return _s("div",{className:"flex items-center gap-2",children:[xa(ga.Root,{ref:l,id:d,className:o("peer relative h-4 w-4 shrink-0 border border-(--app-border-strong) bg-transparent","disabled:cursor-not-allowed disabled:opacity-40","data-[state=checked]:bg-(--color-brand) data-[state=checked]:border-(--color-brand) data-[state=checked]:text-(--app-text-on-color)","before:absolute before:-inset-[14px] before:content-['']",e),...r,children:xa(ga.Indicator,{className:"flex items-center justify-center",children:xa(W,{className:"h-3.5 w-3.5",strokeWidth:3})})}),a&&xa("label",{htmlFor:d,className:"text-sm text-(--app-text) cursor-pointer peer-disabled:cursor-not-allowed peer-disabled:opacity-40",children:a})]})});ot.displayName="Checkbox";import*as Ca from"react";import*as Ia from"@radix-ui/react-switch";import{jsx as rt,jsxs as Ks}from"react/jsx-runtime";var lt=Ca.forwardRef(({className:e,label:a,switchSize:t="default",id:r,...l},d)=>{let s=r||Ca.useId(),u=t==="sm";return Ks("div",{className:"flex items-center gap-2",children:[rt(Ia.Root,{ref:d,id:s,className:o("peer relative inline-flex shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent transition-colors duration-[150ms]","disabled:cursor-not-allowed disabled:opacity-40","data-[state=checked]:bg-(--color-brand) data-[state=unchecked]:bg-(--app-border-strong)",u?"h-4 w-8":"h-6 w-12",u?"before:absolute before:-inset-[14px] before:content-['']":"before:absolute before:-inset-[10px] before:content-['']",e),...l,children:rt(Ia.Thumb,{className:o("pointer-events-none block rounded-full bg-white shadow transition-transform duration-[150ms]",u?"h-3 w-3 data-[state=checked]:translate-x-4 data-[state=unchecked]:translate-x-0":"h-5 w-5 data-[state=checked]:translate-x-6 data-[state=unchecked]:translate-x-0")})}),a&&rt("label",{htmlFor:s,className:"text-sm text-(--app-text) cursor-pointer peer-disabled:cursor-not-allowed peer-disabled:opacity-40",children:a})]})});lt.displayName="Switch";import*as $r from"react";import{jsx as ha,jsxs as Zs}from"react/jsx-runtime";var dt=$r.forwardRef(({className:e,searchSize:a="lg",value:t,onClear:r,onChange:l,...d},s)=>{let u=t!==void 0&&t!=="";return Zs("div",{className:o("relative",e),children:[ha(Pe,{className:"absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[var(--app-text-secondary)]"}),ha("input",{ref:s,type:"search",value:t,onChange:l,className:o("w-full bg-[var(--app-field)] pl-10 pr-10 font-[var(--font-sans)] text-[var(--app-text)] outline-none border-0 border-b border-[var(--app-border-strong)] transition-colors duration-[110ms]","placeholder:text-[var(--app-text-placeholder)]","focus:border-b-2 focus:border-[var(--app-focus)]","[&::-webkit-search-cancel-button]:hidden",a==="sm"?"h-8 text-xs":"h-10 text-sm"),...d}),u&&ha("button",{type:"button",onClick:r,className:"absolute right-3 top-1/2 -translate-y-1/2 text-[var(--app-text-secondary)] hover:text-[var(--app-text)] transition-colors","aria-label":"\uAC80\uC0C9\uC5B4 \uC0AD\uC81C",children:ha(N,{className:"h-4 w-4"})})]})});dt.displayName="Search";import{jsx as Js}from"react/jsx-runtime";var Qs={danger:"text-[var(--color-danger)] bg-[color-mix(in_srgb,var(--color-danger)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-danger)_32%,var(--app-border))]",warning:"text-[var(--color-warning)] bg-[color-mix(in_srgb,var(--color-warning)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-warning)_32%,var(--app-border))]",success:"text-[var(--color-success)] bg-[color-mix(in_srgb,var(--color-success)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-success)_32%,var(--app-border))]",info:"text-[var(--color-info)] bg-[color-mix(in_srgb,var(--color-info)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-info)_32%,var(--app-border))]",neutral:"text-[var(--app-muted)] bg-[var(--app-bg-subtle)] border-[var(--app-border)]"};function Yr({variant:e,className:a="",children:t,...r}){return Js("span",{className:["inline-flex min-h-6 items-center justify-center whitespace-nowrap rounded-(--radius-sm) border border-solid px-2.5 py-0.5 align-middle text-xs font-semibold leading-[1.2] tracking-[-0.02em]",Qs[e],a].filter(Boolean).join(" "),...r,children:t})}import{jsx as jr}from"react/jsx-runtime";function ba({frameClassName:e,className:a,children:t,...r}){return jr("div",{className:["sk-table-frame w-full max-w-full min-h-0 overflow-x-auto overflow-y-hidden bg-transparent",e].filter(Boolean).join(" "),children:jr("table",{className:["sk-table w-max min-w-full border-collapse table-auto bg-[var(--sk-table-bg)] text-[var(--app-text)] text-sm leading-[1.2] tracking-[-0.025em] tabular-nums",a].filter(Boolean).join(" "),...r,children:t})})}import{jsx as st,jsxs as $s}from"react/jsx-runtime";function Pa({pageIndex:e,pageCount:a,onPageChange:t,className:r="","aria-label":l="\uD398\uC774\uC9C0 \uC774\uB3D9"}){if(a<=1)return null;let d=e>0,s=e<a-1,u="min-h-8 min-w-8 cursor-pointer rounded-md border border-solid border-[var(--sk-table-row-border)] bg-[var(--sk-table-bg)] px-2 py-1 text-sm leading-[1.2] text-[var(--sk-table-th-fg)] transition-colors hover:bg-[var(--sk-table-hover)] hover:text-[var(--app-text)] disabled:cursor-not-allowed disabled:opacity-45",f=i=>[u,i?"border-[var(--sk-table-sort-fg)] bg-[color-mix(in_srgb,var(--sk-table-sort-fg)_16%,var(--sk-table-bg))] font-semibold text-[var(--sk-table-sort-fg)]":""].filter(Boolean).join(" ");return $s("nav",{className:["inline-flex flex-wrap items-center gap-1",r].filter(Boolean).join(" "),"aria-label":l,children:[st("button",{type:"button",className:u,disabled:!d,onClick:()=>t(e-1),"aria-label":"\uC774\uC804 \uD398\uC774\uC9C0",children:"\u2039"}),Array.from({length:a},(i,x)=>st("button",{type:"button",className:f(x===e),onClick:()=>t(x),"aria-current":x===e?"page":void 0,children:x+1},x)),st("button",{type:"button",className:u,disabled:!s,onClick:()=>t(e+1),"aria-label":"\uB2E4\uC74C \uD398\uC774\uC9C0",children:"\u203A"})]})}import{flexRender as ut,getCoreRowModel as Ys,getPaginationRowModel as js,getSortedRowModel as eu,getExpandedRowModel as au,useReactTable as tu}from"@tanstack/react-table";import{Icon as al}from"@iconify/react";import ou,{useEffect as ru,useState as Ke,useCallback as lu}from"react";import{Fragment as uu,jsx as g,jsxs as Ze}from"react/jsx-runtime";var tl={"service-desk":{wrap:"service-desk-list__table-wrap",table:"service-desk-table",sortBtn:""},"data-table":{wrap:"",table:"",sortBtn:""},"project-task":{wrap:"sk-page__table-wrap",table:"project-task-table",sortBtn:""}};function du(e){let a=e.getIsSorted();return a==="asc"?"ascending":a==="desc"?"descending":"none"}function su(e,a){let t=e.column.columnDef.meta,r=[];return a==="service-desk"&&t?.headerAlign==="left"&&r.push("service-desk-table__th--left"),e.column.getIsSorted()&&(r.push("text-[var(--sk-table-sort-fg)]"),a==="service-desk"&&r.push("service-desk-table__th--active")),r.filter(Boolean).join(" ")}function ol({column:e,children:a,variant:t,sortButtonClassName:r}){let d=["sk-table__sort-btn inline-flex w-full items-center justify-start gap-1 rounded border-0 bg-transparent p-1 text-left transition-colors hover:bg-[var(--sk-table-hover)] hover:text-[var(--sk-table-th-fg)] focus:outline-none focus-visible:outline-2 focus-visible:outline-offset-2",tl[t].sortBtn,r].filter(Boolean).join(" ");if(!e.getCanSort())return g("span",{className:"font-inherit text-inherit",children:a});let s=e.getIsSorted();return Ze("button",{type:"button",className:d,onClick:e.getToggleSortingHandler(),"aria-label":s?`${String(a)}, ${s==="asc"?"\uC624\uB984\uCC28\uC21C":"\uB0B4\uB9BC\uCC28\uC21C"}, \uC815\uB82C \uC804\uD658`:`${String(a)}, \uC815\uB82C`,children:[a,s?g("span",{className:"shrink-0 text-[var(--sk-table-sort-fg)] opacity-95","aria-hidden":!0,children:g(al,{icon:s==="asc"?"mdi:chevron-up":"mdi:chevron-down",width:8,height:8})}):null]})}function el({checked:e,indeterminate:a,onChange:t,ariaLabel:r}){return g("input",{type:"checkbox",checked:e,ref:l=>{l&&(l.indeterminate=a??!1)},onChange:t,"aria-label":r,className:"h-4 w-4 cursor-pointer accent-[var(--color-brand)] border-[var(--app-border-strong)]",onClick:l=>l.stopPropagation()})}function rl({data:e,columns:a,getRowId:t,onRowClick:r,enableRowSelection:l=!0,selectedRowId:d,onSelectedRowChange:s,enableMultiSelect:u=!1,hideChildRowSelection:f=!1,selectedRowIds:i,onSelectedRowsChange:x,rowClassName:P,emptyMessage:U="\uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4.",variant:h="data-table",wrapClassName:k,tableClassName:E,initialSorting:D,enableSorting:w=!0,pageSize:T,getSubRows:Za,renderSubComponent:la,autoResetExpanded:Xd=!1}){let Or=tl[h],[_d,Kd]=Ke(()=>D??[]),[Zd,Qd]=Ke({}),[Jd,$d]=Ke(null),[Yd,jd]=Ke({}),he=T!=null&&T>0,[es,Ur]=Ke(()=>({pageIndex:0,pageSize:he?T:Math.max(1,e.length||1)})),Qa=i??Yd,as=lu(n=>{let R=typeof n=="function"?n(Qa):n;if(i||jd(R),x){let Ge=e.filter((da,sa)=>{let F=t?t(da,sa):String(sa);return R[F]});x(R,Ge)}},[Qa,i,x,e,t]);ru(()=>{he&&Ur(n=>({...n,pageSize:T,pageIndex:0}))},[he,T,e.length]);let ts=u?[{id:"_select",size:40,enableSorting:!1,header:({table:n})=>g(el,{checked:n.getIsAllPageRowsSelected(),indeterminate:n.getIsSomePageRowsSelected(),onChange:n.getToggleAllPageRowsSelectedHandler(),ariaLabel:"\uC804\uCCB4 \uC120\uD0DD"}),cell:({row:n})=>f&&n.depth>0?null:g(el,{checked:n.getIsSelected(),onChange:n.getToggleSelectedHandler(),ariaLabel:`\uD589 ${n.id} \uC120\uD0DD`})},...a]:a,Me=tu({data:e,columns:ts,state:{sorting:_d,expanded:Zd,...he?{pagination:es}:{},...u?{rowSelection:Qa}:{}},onSortingChange:Kd,onExpandedChange:Qd,onPaginationChange:he?Ur:void 0,...u?{onRowSelectionChange:as,enableRowSelection:!0,enableSubRowSelection:!1}:{},getCoreRowModel:Ys(),getSortedRowModel:eu(),getExpandedRowModel:au(),getSubRows:Za,autoResetExpanded:Xd,...he?{getPaginationRowModel:js()}:{},getRowId:t,enableSorting:w}),os=[Or.wrap,k].filter(Boolean).join(" "),rs=[Or.table,E].filter(Boolean).join(" "),ls=d??Jd;if(e.length===0)return g("div",{className:"px-8 py-8 text-center text-base leading-[1.35] text-[var(--app-muted)]",role:"status",children:U});let ds=he&&Me.getPageCount()>1;return Ze(uu,{children:[Ze(ba,{frameClassName:os,className:rs,children:[g("thead",{children:Me.getHeaderGroups().map(n=>g("tr",{children:n.headers.map(R=>{let We=R.column.columnDef.meta?.align,Ge={...We?{textAlign:We}:{},whiteSpace:"nowrap"};return g("th",{colSpan:R.colSpan,scope:"col",className:["h-[var(--density-row-height,28px)] border-b border-solid border-[var(--sk-table-row-border)] bg-[var(--sk-table-header-bg)] px-[var(--density-padding-x,0.5rem)] text-left align-middle text-sm font-semibold whitespace-nowrap text-[var(--sk-table-th-fg)]",su(R,h)].filter(Boolean).join(" "),"aria-sort":R.column.getCanSort()?du(R.column):void 0,"data-align":We,style:Ge,children:R.isPlaceholder?null:ut(R.column.columnDef.header,R.getContext())},R.id)})},n.id))}),g("tbody",{children:Me.getRowModel().rows.map(n=>{let R=l&&ls===n.id,Ge=[P?.(n.original)??""].filter(Boolean).join(" "),da=!!(r||l),sa=()=>{if(l){let F=R?null:n.id;d==null&&$d(F),s?.(F,F?n.original:null)}r?.(n.original)};return Ze(ou.Fragment,{children:[g("tr",{className:Ge,onClick:da?sa:void 0,style:da?{cursor:"pointer"}:void 0,children:n.getVisibleCells().map((F,ss)=>{let us=F.column.columnDef.meta?.tdClassName??"",Ja=F.column.columnDef.meta?.align,is={...Ja?{textAlign:Ja}:{},whiteSpace:"nowrap"},fs=ss===(u?1:0)&&(Za||la),ns=Za?n.getCanExpand():!!la;return g("td",{className:["h-[var(--density-row-height,28px)] whitespace-nowrap border-b border-solid border-[var(--sk-table-row-border)] px-[var(--density-padding-x,0.5rem)] align-middle text-[var(--app-text)]",R?"bg-[color-mix(in_srgb,var(--app-muted)_24%,var(--sk-table-bg))]":"bg-[var(--sk-table-bg)]",us].filter(Boolean).join(" "),"data-align":Ja,style:is,children:fs?Ze("div",{style:{paddingLeft:`${n.depth*1.5}rem`},className:"flex items-center gap-2 w-full",children:[ns?g("button",{type:"button",className:"p-1 min-touch-target shrink-0 flex items-center justify-center rounded-md hover:bg-[var(--app-hover)] text-[var(--app-muted)] transition-colors focus:outline-none focus-visible:ring-2 focus-visible:ring-[var(--shadow-focus)]",onClick:Er=>{Er.preventDefault(),Er.stopPropagation(),n.toggleExpanded()},"aria-label":"\uD1A0\uAE00 \uC5F4\uAE30/\uB2EB\uAE30",children:g(al,{icon:n.getIsExpanded()?"mdi:chevron-down":"mdi:chevron-right",width:20,className:"transition-transform duration-200"})}):g("span",{className:"w-[28px] shrink-0 inline-block"}),g("div",{className:"min-w-0 flex-1 truncate",children:ut(F.column.columnDef.cell,F.getContext())})]}):ut(F.column.columnDef.cell,F.getContext())},F.id)})}),n.getIsExpanded()&&la&&g("tr",{className:"bg-[var(--app-surface-02)]",children:g("td",{colSpan:n.getVisibleCells().length,className:"p-0 border-b border-[var(--sk-table-row-border)]",children:g("div",{className:"p-4 w-full h-full flex flex-col bg-[var(--app-bg)] shadow-[inset_0_4px_6px_-6px_rgba(0,0,0,0.1)]",children:la({row:n})})})})]},n.id)})})]}),ds?g("div",{className:"flex w-full items-center justify-end box-border px-2 pt-3",children:g(Pa,{pageIndex:Me.getState().pagination.pageIndex,pageCount:Me.getPageCount(),onPageChange:n=>Me.setPageIndex(n)})}):null]})}import*as G from"react";import*as fe from"@radix-ui/react-tabs";import{jsx as Sa}from"react/jsx-runtime";var ll=fe.Root;function iu(){let e=G.useRef(null),a=G.useRef({isDown:!1,startX:0,scrollLeft:0}),t=G.useCallback(d=>{let s=e.current;s&&(d.target.closest('button, a, [role="tab"]')||(a.current={isDown:!0,startX:d.clientX-s.offsetLeft,scrollLeft:s.scrollLeft},s.setPointerCapture(d.pointerId),s.style.cursor="grabbing"))},[]),r=G.useCallback(d=>{if(!a.current.isDown||!e.current)return;let s=d.clientX-e.current.offsetLeft;e.current.scrollLeft=a.current.scrollLeft-(s-a.current.startX)},[]),l=G.useCallback(d=>{a.current.isDown=!1,e.current&&(e.current.releasePointerCapture(d.pointerId),e.current.style.cursor="")},[]);return{ref:e,onPointerDown:t,onPointerMove:r,onPointerUp:l}}var it=G.forwardRef(({className:e,variant:a="line",wrapperClassName:t,...r},l)=>{let d=iu();return Sa("div",{ref:d.ref,onPointerDown:d.onPointerDown,onPointerMove:d.onPointerMove,onPointerUp:d.onPointerUp,onPointerLeave:d.onPointerUp,className:o("sk-tabs-scroll w-full overflow-x-auto cursor-grab select-none",a==="line"&&"border-b border-(--app-border)",t),children:Sa(fe.List,{ref:l,className:o("inline-flex items-center",a==="line"&&"gap-0 -mb-px",a==="contained"&&"gap-0 bg-(--app-surface)",e),...r})})});it.displayName="TabsList";var ft=G.forwardRef(({className:e,variant:a="line",...t},r)=>Sa(fe.Trigger,{ref:r,className:o("inline-flex items-center justify-center whitespace-nowrap px-4 py-2 text-sm font-medium transition-colors duration-[110ms]","disabled:pointer-events-none disabled:opacity-40","focus-visible:outline-2 focus-visible:outline-(--app-focus) focus-visible:outline-offset-[-2px]",a==="line"&&["border-b-2 border-transparent text-(--app-text-secondary)","hover:text-(--app-text) hover:bg-(--app-hover)","data-[state=active]:border-(--color-brand) data-[state=active]:text-(--app-text) data-[state=active]:font-semibold"],a==="contained"&&["border border-(--app-border) text-(--app-text-secondary)","hover:bg-(--app-hover)","data-[state=active]:bg-(--app-bg) data-[state=active]:text-(--app-text) data-[state=active]:font-semibold data-[state=active]:border-b-(--app-bg)"],e),...t}));ft.displayName="TabsTrigger";var nt=G.forwardRef(({className:e,...a},t)=>Sa(fe.Content,{ref:t,className:o("mt-4 focus-visible:outline-none",e),...a}));nt.displayName="TabsContent";import*as va from"react";import{jsx as ne,jsxs as dl}from"react/jsx-runtime";function sl({node:e,level:a,expanded:t,onToggle:r,onSelect:l,selectedId:d}){let s=e.children&&e.children.length>0,u=t.has(e.id),f=d===e.id;return dl("li",{role:"treeitem","aria-expanded":s?u:void 0,children:[dl("button",{type:"button",disabled:e.disabled,className:o("flex w-full items-center gap-1 py-1.5 text-sm outline-none transition-colors duration-[70ms]","hover:bg-[var(--app-hover)]","focus-visible:outline-2 focus-visible:outline-[var(--app-focus)]","disabled:pointer-events-none disabled:opacity-40",f&&"bg-[var(--app-selected)] font-medium",!f&&"text-[var(--app-text)]"),style:{paddingLeft:`${a*24+8}px`},onClick:()=>{s&&r(e.id),l?.(e)},children:[s?ne(I,{className:o("h-4 w-4 shrink-0 text-[var(--app-text-secondary)] transition-transform duration-[150ms]",u&&"rotate-90")}):ne("span",{className:"w-4 shrink-0"}),e.icon&&ne("span",{className:"shrink-0",children:e.icon}),ne("span",{className:"truncate",children:e.label})]}),s&&u&&ne("ul",{role:"group",children:e.children.map(i=>ne(sl,{node:i,level:a+1,expanded:t,onToggle:r,onSelect:l,selectedId:d},i.id))})]})}function ul({data:e,defaultExpanded:a=[],onSelect:t,selectedId:r,className:l}){let[d,s]=va.useState(new Set(a)),u=va.useCallback(f=>{s(i=>{let x=new Set(i);return x.has(f)?x.delete(f):x.add(f),x})},[]);return ne("ul",{role:"tree",className:o("text-sm",l),children:e.map(f=>ne(sl,{node:f,level:0,expanded:d,onToggle:u,onSelect:t,selectedId:r},f.id))})}import*as wa from"react";import{jsx as xt}from"react/jsx-runtime";var ct=wa.forwardRef(({className:e,variant:a="default",...t},r)=>xt("ul",{ref:r,className:o("text-sm text-[var(--app-text)]",a==="contained"&&"border border-[var(--app-border)]",e),...t}));ct.displayName="List";var pt=wa.forwardRef(({className:e,active:a,disabled:t,interactive:r=!0,...l},d)=>xt("li",{ref:d,className:o("flex items-center gap-3 px-4 py-2 border-b border-[var(--app-border)] last:border-b-0",r&&"cursor-pointer hover:bg-[var(--app-hover)] transition-colors duration-[70ms]",a&&"bg-[var(--app-selected)]",t&&"pointer-events-none opacity-40",e),...l}));pt.displayName="ListItem";var mt=wa.forwardRef(({className:e,...a},t)=>xt("div",{ref:t,className:o("px-4 py-2 text-xs font-semibold text-[var(--app-text-secondary)] bg-[var(--app-surface)] border-b border-[var(--app-border)]",e),...a}));mt.displayName="ListHeader";import*as Ra from"react";import*as Z from"@radix-ui/react-accordion";import{jsx as Qe,jsxs as fu}from"react/jsx-runtime";var il=Z.Root,Lt=Ra.forwardRef(({className:e,...a},t)=>Qe(Z.Item,{ref:t,className:o("border-b border-[var(--app-border)]",e),...a}));Lt.displayName="AccordionItem";var gt=Ra.forwardRef(({className:e,children:a,...t},r)=>Qe(Z.Header,{className:"flex",children:fu(Z.Trigger,{ref:r,className:o("flex flex-1 items-center justify-between py-3 px-4 text-sm font-medium text-[var(--app-text)] transition-all duration-[150ms] min-touch-target","hover:bg-[var(--app-hover)]","[&[data-state=open]>svg]:rotate-180",e),...t,children:[a,Qe(j,{className:"h-4 w-4 shrink-0 text-[var(--app-text-secondary)] transition-transform duration-[150ms]"})]})}));gt.displayName="AccordionTrigger";var Ct=Ra.forwardRef(({className:e,children:a,...t},r)=>Qe(Z.Content,{ref:r,className:"overflow-hidden text-sm data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down",...t,children:Qe("div",{className:o("px-4 pb-3 text-[var(--app-text-secondary)]",e),children:a})}));Ct.displayName="AccordionContent";import*as Je from"react";import*as S from"@radix-ui/react-dialog";import{jsx as ae,jsxs as It}from"react/jsx-runtime";var ya=S.Root,fl=S.Trigger,nl=S.Close,cl=S.Portal,ht=Je.forwardRef(({className:e,...a},t)=>ae(S.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));ht.displayName="DialogOverlay";var $e=Je.forwardRef(({className:e,children:a,size:t="default",hideClose:r,...l},d)=>It(cl,{children:[ae(ht,{}),It(S.Content,{ref:d,className:o("fixed left-1/2 top-1/2 z-50 w-full -translate-x-1/2 -translate-y-1/2 rounded-(--radius-lg)","bg-(--app-bg) text-(--app-text) shadow-(--shadow-modal)","duration-[240ms] ease-[cubic-bezier(0,0,0.38,0.9)]","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","max-h-[85vh] overflow-y-auto",{sm:"max-w-md",default:"max-w-lg",lg:"max-w-2xl",xl:"max-w-4xl",full:"max-w-[90vw]"}[t],e),...l,children:[a,!r&&It(S.Close,{className:"absolute right-4 top-4 text-[var(--app-text-secondary)] hover:text-[var(--app-text)] transition-colors",children:[ae(N,{className:"h-5 w-5"}),ae("span",{className:"sr-only",children:"\uB2EB\uAE30"})]})]})]}));$e.displayName="DialogContent";var pl=({className:e,...a})=>ae("div",{className:o("px-6 py-4 border-b border-[var(--app-border)]",e),...a}),bt=Je.forwardRef(({className:e,...a},t)=>ae(S.Title,{ref:t,className:o("text-lg font-semibold text-[var(--app-text)]",e),...a}));bt.displayName="DialogTitle";var Pt=Je.forwardRef(({className:e,...a},t)=>ae(S.Description,{ref:t,className:o("text-sm text-[var(--app-text-secondary)]",e),...a}));Pt.displayName="DialogDescription";var ml=({className:e,...a})=>ae("div",{className:o("px-6 py-4",e),...a}),xl=({className:e,...a})=>ae("div",{className:o("flex justify-end gap-2 px-6 py-4 border-t border-[var(--app-border)]",e),...a});import{useEffect as pu,useCallback as mu}from"react";import{createPortal as xu}from"react-dom";import{jsx as Ll,jsxs as nu}from"react/jsx-runtime";function Ma({title:e,actions:a}){return nu("div",{className:"standard-modal-header",children:[Ll("h2",{className:"standard-modal-title",children:e}),a!=null&&Ll("div",{className:"standard-modal-header-actions-wrap",children:a})]})}import{jsx as gl,jsxs as cu}from"react/jsx-runtime";function ka({onCancel:e,onSave:a,cancelLabel:t="\uCDE8\uC18C",saveLabel:r="\uC800\uC7A5",saveDisabled:l=!1}){return cu("div",{className:"standard-modal-header-actions",children:[gl("button",{type:"button",className:"btn-standard-modal btn-ghost",onClick:e,children:t}),a!=null&&gl("button",{type:"button",className:"btn-standard-modal btn-primary",onClick:()=>{let d=a();d!=null&&typeof d?.then=="function"&&d.catch(()=>{})},disabled:l,children:r})]})}import{jsx as Da,jsxs as Lu}from"react/jsx-runtime";function Cl({open:e,onClose:a,title:t,children:r,onSave:l,cancelLabel:d,saveLabel:s,hasUnsavedChanges:u=!1,saveDisabled:f=!1,headerActions:i,closeOnOverlayClick:x=!1,ariaLabel:P,modalClassName:U}){let h=mu(()=>{u&&!window.confirm("\uBCC0\uACBD\uC0AC\uD56D\uC774 \uC788\uC2B5\uB2C8\uB2E4. \uB2EB\uC73C\uC2DC\uACA0\uC2B5\uB2C8\uAE4C?")||a()},[a,u]);if(pu(()=>{if(!e)return;let D=w=>{w.key==="Escape"&&h()};return window.addEventListener("keydown",D),()=>window.removeEventListener("keydown",D)},[e,h]),!e)return null;let k=i??Da(ka,{onCancel:h,onSave:l,cancelLabel:d,saveLabel:s,saveDisabled:f}),E=Da("div",{className:"standard-modal-overlay",role:"dialog","aria-modal":"true","aria-label":P??t,onClick:x?h:void 0,children:Lu("div",{className:["standard-modal",U].filter(Boolean).join(" "),onClick:D=>D.stopPropagation(),children:[Da(Ma,{title:t,actions:k}),Da("div",{className:"standard-modal-body",children:r})]})});return xu(E,document.body)}import{jsx as Il,jsxs as gu}from"react/jsx-runtime";function hl({title:e,children:a,fullWidth:t}){return gu("section",{className:`standard-modal-section ${t?"standard-modal-section--full":""}`,children:[Il("h3",{className:"standard-modal-section-title",children:e}),Il("div",{className:"standard-modal-section-body",children:a})]})}import{jsx as Cu}from"react/jsx-runtime";function bl({children:e,fullWidth:a}){return Cu("div",{className:`standard-form-grid ${a?"standard-form-grid--full":""}`,children:e})}import{jsx as Pl,jsxs as Sl}from"react/jsx-runtime";function vl({label:e,required:a,helper:t,fullWidth:r,children:l}){return Sl("div",{className:`standard-form-field ${r?"standard-form-field--full":""}`,children:[Sl("label",{children:[e,a&&Pl("span",{className:"required","aria-hidden":!0,children:" *"})]}),l,t!=null&&Pl("p",{className:"helper",children:t})]})}import*as ce from"react";import*as L from"@radix-ui/react-dropdown-menu";import{jsx as Q,jsxs as kl}from"react/jsx-runtime";var wl=L.Root,Rl=L.Trigger,yl=L.Group;var Ml=L.Sub;var St=ce.forwardRef(({className:e,children:a,...t},r)=>kl(L.SubTrigger,{ref:r,className:o("flex cursor-pointer items-center gap-2 px-4 py-2 text-sm outline-none select-none","text-[var(--app-text)] hover:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]",e),...t,children:[a,Q(I,{className:"ml-auto h-4 w-4"})]}));St.displayName="DropdownMenuSubTrigger";var vt=ce.forwardRef(({className:e,...a},t)=>Q(L.SubContent,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) text-(--app-text) shadow-(--shadow-dropdown)","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));vt.displayName="DropdownMenuSubContent";var wt=ce.forwardRef(({className:e,sideOffset:a=4,...t},r)=>Q(L.Portal,{children:Q(L.Content,{ref:r,sideOffset:a,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) py-1 text-(--app-text) shadow-(--shadow-dropdown)","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...t})}));wt.displayName="DropdownMenuContent";var Rt=ce.forwardRef(({className:e,destructive:a,...t},r)=>Q(L.Item,{ref:r,className:o("relative flex cursor-pointer items-center gap-2 px-4 py-2 text-sm outline-none select-none transition-colors","focus:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-40",a&&"text-[var(--color-error)] focus:text-[var(--color-error)]",!a&&"text-[var(--app-text)]",e),...t}));Rt.displayName="DropdownMenuItem";var yt=ce.forwardRef(({className:e,children:a,checked:t,...r},l)=>kl(L.CheckboxItem,{ref:l,className:o("relative flex cursor-pointer items-center py-2 pl-8 pr-4 text-sm outline-none select-none transition-colors","text-[var(--app-text)] focus:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-40",e),checked:t,...r,children:[Q("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:Q(L.ItemIndicator,{children:Q(W,{className:"h-4 w-4"})})}),a]}));yt.displayName="DropdownMenuCheckboxItem";var Mt=ce.forwardRef(({className:e,...a},t)=>Q(L.Separator,{ref:t,className:o("my-1 h-px bg-[var(--app-border)]",e),...a}));Mt.displayName="DropdownMenuSeparator";var kt=ce.forwardRef(({className:e,...a},t)=>Q(L.Label,{ref:t,className:o("px-4 py-2 text-xs font-semibold text-[var(--app-text-secondary)]",e),...a}));kt.displayName="DropdownMenuLabel";import*as Tl from"react";import*as H from"@radix-ui/react-popover";import{jsx as Dl}from"react/jsx-runtime";var Ta=H.Root,Aa=H.Trigger,Al=H.Anchor,Bl=H.Close,Ye=Tl.forwardRef(({className:e,align:a="center",sideOffset:t=4,...r},l)=>Dl(H.Portal,{children:Dl(H.Content,{ref:l,align:a,sideOffset:t,className:o("z-50 w-72 rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) p-4 text-(--app-text) shadow-(--shadow-dropdown) outline-none","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...r})}));Ye.displayName="PopoverContent";import"react";import*as q from"@radix-ui/react-tooltip";import{jsx as Dt,jsxs as Fl}from"react/jsx-runtime";var Nl=q.Provider;function Hl({content:e,children:a,side:t="top",delayDuration:r=200,className:l}){return Fl(q.Root,{delayDuration:r,children:[Dt(q.Trigger,{asChild:!0,children:a}),Dt(q.Portal,{children:Fl(q.Content,{side:t,sideOffset:4,className:o("z-50 max-w-[240px] rounded-(--radius-md) bg-(--app-text) px-4 py-2 text-xs text-(--app-text-on-color)","animate-in fade-in-0 zoom-in-95 duration-[110ms]","data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95",l),children:[e,Dt(q.Arrow,{className:"fill-[var(--app-text)]",width:12,height:6})]})})]})}import{cva as Iu}from"class-variance-authority";import{jsx as Te,jsxs as Ol}from"react/jsx-runtime";var Tt=Iu("relative flex items-start gap-3 p-4 border-l-[3px] text-sm",{variants:{variant:{success:"border-l-[var(--color-success)] bg-[color-mix(in_srgb,var(--color-success)_10%,var(--app-bg))]",warning:"border-l-[var(--color-warning)] bg-[color-mix(in_srgb,var(--color-warning)_10%,var(--app-bg))]",error:"border-l-[var(--color-error)] bg-[color-mix(in_srgb,var(--color-error)_10%,var(--app-bg))]",info:"border-l-[var(--color-info)] bg-[color-mix(in_srgb,var(--color-info)_10%,var(--app-bg))]"}},defaultVariants:{variant:"info"}}),hu={success:_,warning:K,error:ue,info:be},ql={success:"text-[var(--color-success)]",warning:"text-[var(--color-warning)]",error:"text-[var(--color-error)]",info:"text-[var(--color-info)]"};function Ul({variant:e="info",title:a,message:t,onClose:r,closable:l=!0,action:d,className:s}){let u=hu[e];return Ol("div",{className:o(Tt({variant:e}),s),role:"alert",children:[Te(u,{className:o("mt-0.5 h-5 w-5 shrink-0",ql[e])}),Ol("div",{className:"flex-1 min-w-0",children:[Te("p",{className:"font-medium text-[var(--app-text)]",children:a}),t&&Te("p",{className:"mt-1 text-xs text-[var(--app-text-secondary)]",children:t}),d&&Te("button",{type:"button",onClick:d.onClick,className:o("mt-2 text-xs font-medium underline-offset-2 hover:underline",ql[e]),children:d.label})]}),l&&r&&Te("button",{type:"button",onClick:r,className:"shrink-0 text-[var(--app-text-secondary)] hover:text-[var(--app-text)] transition-colors","aria-label":"\uB2EB\uAE30",children:Te(N,{className:"h-4 w-4"})})]})}import*as El from"react";import{jsx as bu}from"react/jsx-runtime";var At=El.forwardRef(({className:e,variant:a="rectangular",...t},r)=>bu("div",{ref:r,className:o("animate-pulse bg-[var(--app-surface)]",a==="text"&&"h-4 w-full",a==="circular"&&"rounded-full",a==="rectangular"&&"w-full",e),...t}));At.displayName="Skeleton";import{jsx as Ae,jsxs as vu}from"react/jsx-runtime";var Pu={sm:16,default:32,lg:64},Su={sm:2,default:3,lg:4};function Wl({size:e="default",label:a,className:t}){let r=Pu[e],l=Su[e],d=(r-l)/2;return vu("div",{className:o("inline-flex flex-col items-center gap-2",t),role:"status",children:[Ae("svg",{width:r,height:r,viewBox:`0 0 ${r} ${r}`,className:"animate-spin",style:{animationDuration:"700ms"},children:Ae("circle",{cx:r/2,cy:r/2,r:d,fill:"none",stroke:"var(--color-brand)",strokeWidth:l,strokeLinecap:"round",strokeDasharray:`${d*Math.PI*1.5} ${d*Math.PI*2}`})}),a&&Ae("span",{className:"text-xs text-[var(--app-text-secondary)]",children:a}),Ae("span",{className:"sr-only",children:a||"\uB85C\uB529 \uC911"})]})}function Gl({className:e}){return Ae("svg",{width:16,height:16,viewBox:"0 0 16 16",className:o("animate-spin",e),style:{animationDuration:"700ms"},role:"status",children:Ae("circle",{cx:8,cy:8,r:6,fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeDasharray:`${6*Math.PI*1.5} ${6*Math.PI*2}`})})}import*as jl from"react";function Ba(e){return(a={})=>{let t=a.width?String(a.width):e.defaultWidth;return e.formats[t]||e.formats[e.defaultWidth]}}function Be(e){return(a,t)=>{let r=t?.context?String(t.context):"standalone",l;if(r==="formatting"&&e.formattingValues){let s=e.defaultFormattingWidth||e.defaultWidth,u=t?.width?String(t.width):s;l=e.formattingValues[u]||e.formattingValues[s]}else{let s=e.defaultWidth,u=t?.width?String(t.width):e.defaultWidth;l=e.values[u]||e.values[s]}let d=e.argumentCallback?e.argumentCallback(a):a;return l[d]}}function Fe(e){return(a,t={})=>{let r=t.width,l=r&&e.matchPatterns[r]||e.matchPatterns[e.defaultMatchWidth],d=a.match(l);if(!d)return null;let s=d[0],u=r&&e.parsePatterns[r]||e.parsePatterns[e.defaultParseWidth],f=Array.isArray(u)?Ru(u,P=>P.test(s)):wu(u,P=>P.test(s)),i;i=e.valueCallback?e.valueCallback(f):f,i=t.valueCallback?t.valueCallback(i):i;let x=a.slice(s.length);return{value:i,rest:x}}}function wu(e,a){for(let t in e)if(Object.prototype.hasOwnProperty.call(e,t)&&a(e[t]))return t}function Ru(e,a){for(let t=0;t<e.length;t++)if(a(e[t]))return t}function Vl(e){return(a,t={})=>{let r=a.match(e.matchPattern);if(!r)return null;let l=r[0],d=a.match(e.parsePattern);if(!d)return null;let s=e.valueCallback?e.valueCallback(d[0]):d[0];s=t.valueCallback?t.valueCallback(s):s;let u=a.slice(l.length);return{value:s,rest:u}}}var yu={lessThanXSeconds:{one:"1\uCD08 \uBBF8\uB9CC",other:"{{count}}\uCD08 \uBBF8\uB9CC"},xSeconds:{one:"1\uCD08",other:"{{count}}\uCD08"},halfAMinute:"30\uCD08",lessThanXMinutes:{one:"1\uBD84 \uBBF8\uB9CC",other:"{{count}}\uBD84 \uBBF8\uB9CC"},xMinutes:{one:"1\uBD84",other:"{{count}}\uBD84"},aboutXHours:{one:"\uC57D 1\uC2DC\uAC04",other:"\uC57D {{count}}\uC2DC\uAC04"},xHours:{one:"1\uC2DC\uAC04",other:"{{count}}\uC2DC\uAC04"},xDays:{one:"1\uC77C",other:"{{count}}\uC77C"},aboutXWeeks:{one:"\uC57D 1\uC8FC",other:"\uC57D {{count}}\uC8FC"},xWeeks:{one:"1\uC8FC",other:"{{count}}\uC8FC"},aboutXMonths:{one:"\uC57D 1\uAC1C\uC6D4",other:"\uC57D {{count}}\uAC1C\uC6D4"},xMonths:{one:"1\uAC1C\uC6D4",other:"{{count}}\uAC1C\uC6D4"},aboutXYears:{one:"\uC57D 1\uB144",other:"\uC57D {{count}}\uB144"},xYears:{one:"1\uB144",other:"{{count}}\uB144"},overXYears:{one:"1\uB144 \uC774\uC0C1",other:"{{count}}\uB144 \uC774\uC0C1"},almostXYears:{one:"\uAC70\uC758 1\uB144",other:"\uAC70\uC758 {{count}}\uB144"}},zl=(e,a,t)=>{let r,l=yu[e];return typeof l=="string"?r=l:a===1?r=l.one:r=l.other.replace("{{count}}",a.toString()),t?.addSuffix?t.comparison&&t.comparison>0?r+" \uD6C4":r+" \uC804":r};var Mu={full:"y\uB144 M\uC6D4 d\uC77C EEEE",long:"y\uB144 M\uC6D4 d\uC77C",medium:"y.MM.dd",short:"y.MM.dd"},ku={full:"a H\uC2DC mm\uBD84 ss\uCD08 zzzz",long:"a H:mm:ss z",medium:"HH:mm:ss",short:"HH:mm"},Du={full:"{{date}} {{time}}",long:"{{date}} {{time}}",medium:"{{date}} {{time}}",short:"{{date}} {{time}}"},Xl={date:Ba({formats:Mu,defaultWidth:"full"}),time:Ba({formats:ku,defaultWidth:"full"}),dateTime:Ba({formats:Du,defaultWidth:"full"})};var Tu={lastWeek:"'\uC9C0\uB09C' eeee p",yesterday:"'\uC5B4\uC81C' p",today:"'\uC624\uB298' p",tomorrow:"'\uB0B4\uC77C' p",nextWeek:"'\uB2E4\uC74C' eeee p",other:"P"},_l=(e,a,t,r)=>Tu[e];var Au={narrow:["BC","AD"],abbreviated:["BC","AD"],wide:["\uAE30\uC6D0\uC804","\uC11C\uAE30"]},Bu={narrow:["1","2","3","4"],abbreviated:["Q1","Q2","Q3","Q4"],wide:["1\uBD84\uAE30","2\uBD84\uAE30","3\uBD84\uAE30","4\uBD84\uAE30"]},Fu={narrow:["1","2","3","4","5","6","7","8","9","10","11","12"],abbreviated:["1\uC6D4","2\uC6D4","3\uC6D4","4\uC6D4","5\uC6D4","6\uC6D4","7\uC6D4","8\uC6D4","9\uC6D4","10\uC6D4","11\uC6D4","12\uC6D4"],wide:["1\uC6D4","2\uC6D4","3\uC6D4","4\uC6D4","5\uC6D4","6\uC6D4","7\uC6D4","8\uC6D4","9\uC6D4","10\uC6D4","11\uC6D4","12\uC6D4"]},Nu={narrow:["\uC77C","\uC6D4","\uD654","\uC218","\uBAA9","\uAE08","\uD1A0"],short:["\uC77C","\uC6D4","\uD654","\uC218","\uBAA9","\uAE08","\uD1A0"],abbreviated:["\uC77C","\uC6D4","\uD654","\uC218","\uBAA9","\uAE08","\uD1A0"],wide:["\uC77C\uC694\uC77C","\uC6D4\uC694\uC77C","\uD654\uC694\uC77C","\uC218\uC694\uC77C","\uBAA9\uC694\uC77C","\uAE08\uC694\uC77C","\uD1A0\uC694\uC77C"]},Hu={narrow:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},abbreviated:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},wide:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"}},qu={narrow:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},abbreviated:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},wide:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"}},Ou=(e,a)=>{let t=Number(e);switch(String(a?.unit)){case"minute":case"second":return String(t);case"date":return t+"\uC77C";default:return t+"\uBC88\uC9F8"}},Kl={ordinalNumber:Ou,era:Be({values:Au,defaultWidth:"wide"}),quarter:Be({values:Bu,defaultWidth:"wide",argumentCallback:e=>e-1}),month:Be({values:Fu,defaultWidth:"wide"}),day:Be({values:Nu,defaultWidth:"wide"}),dayPeriod:Be({values:Hu,defaultWidth:"wide",formattingValues:qu,defaultFormattingWidth:"wide"})};var Uu=/^(\d+)(일|번째)?/i,Eu=/\d+/i,Wu={narrow:/^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i,abbreviated:/^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i,wide:/^(기원전|서기)/i},Gu={any:[/^(bc|기원전)/i,/^(ad|서기)/i]},Vu={narrow:/^[1234]/i,abbreviated:/^q[1234]/i,wide:/^[1234]사?분기/i},zu={any:[/1/i,/2/i,/3/i,/4/i]},Xu={narrow:/^(1[012]|[123456789])/,abbreviated:/^(1[012]|[123456789])월/i,wide:/^(1[012]|[123456789])월/i},_u={any:[/^1월?$/,/^2/,/^3/,/^4/,/^5/,/^6/,/^7/,/^8/,/^9/,/^10/,/^11/,/^12/]},Ku={narrow:/^[일월화수목금토]/,short:/^[일월화수목금토]/,abbreviated:/^[일월화수목금토]/,wide:/^[일월화수목금토]요일/},Zu={any:[/^일/,/^월/,/^화/,/^수/,/^목/,/^금/,/^토/]},Qu={any:/^(am|pm|오전|오후|자정|정오|아침|저녁|밤)/i},Ju={any:{am:/^(am|오전)/i,pm:/^(pm|오후)/i,midnight:/^자정/i,noon:/^정오/i,morning:/^아침/i,afternoon:/^오후/i,evening:/^저녁/i,night:/^밤/i}},Zl={ordinalNumber:Vl({matchPattern:Uu,parsePattern:Eu,valueCallback:e=>parseInt(e,10)}),era:Fe({matchPatterns:Wu,defaultMatchWidth:"wide",parsePatterns:Gu,defaultParseWidth:"any"}),quarter:Fe({matchPatterns:Vu,defaultMatchWidth:"wide",parsePatterns:zu,defaultParseWidth:"any",valueCallback:e=>e+1}),month:Fe({matchPatterns:Xu,defaultMatchWidth:"wide",parsePatterns:_u,defaultParseWidth:"any"}),day:Fe({matchPatterns:Ku,defaultMatchWidth:"wide",parsePatterns:Zu,defaultParseWidth:"any"}),dayPeriod:Fe({matchPatterns:Qu,defaultMatchWidth:"any",parsePatterns:Ju,defaultParseWidth:"any"})};var Ql={code:"ko",formatDistance:zl,formatLong:Xl,formatRelative:_l,localize:Kl,match:Zl,options:{weekStartsOn:0,firstWeekContainsDate:1}};import"react";import{DayPicker as $u,useDayPicker as Yu}from"react-day-picker";import{jsx as pe,jsxs as ei}from"react/jsx-runtime";var Jl=o("h-7 w-7 flex items-center justify-center","bg-transparent border border-(--app-border) text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:opacity-40 disabled:pointer-events-none");function ju({calendarMonth:e,displayIndex:a,...t}){let{goToMonth:r,previousMonth:l,nextMonth:d}=Yu();return ei("div",{...t,className:o(t.className,"flex justify-center items-center gap-1 h-9"),children:[a===0&&pe("button",{type:"button",className:Jl,disabled:!l,"aria-label":"\uC774\uC804 \uB2EC",onClick:()=>l&&r(l),children:pe(X,{className:"h-4 w-4"})}),pe("span",{className:"text-sm font-medium text-(--app-text) mx-1",children:e.date.toLocaleString("default",{month:"long",year:"numeric"})}),a===0&&pe("button",{type:"button",className:Jl,disabled:!d,"aria-label":"\uB2E4\uC74C \uB2EC",onClick:()=>d&&r(d),children:pe(I,{className:"h-4 w-4"})})]})}function je({className:e,classNames:a,showOutsideDays:t=!0,...r}){return pe($u,{showOutsideDays:t,className:o("p-3 bg-(--app-bg) text-(--app-text) select-none",e),classNames:{months:"flex flex-col sm:flex-row gap-4",month:"flex flex-col gap-4",month_caption:"",caption_label:"text-sm font-medium text-(--app-text)",nav:"hidden",month_grid:"w-full border-collapse",weekdays:"flex",weekday:"text-(--app-muted) w-9 text-center text-[0.8rem] font-normal",week:"flex w-full mt-2",day:o("relative h-9 w-9 p-0 text-center text-sm","focus-within:relative focus-within:z-20"),day_button:o("h-9 w-9 p-0 font-normal flex items-center justify-center","text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","aria-selected:opacity-100"),range_start:"day-range-start",range_end:"day-range-end",selected:"[&>button]:bg-(--color-brand) [&>button]:text-white [&>button]:hover:bg-(--color-brand-hover) [&>button]:hover:text-white",today:"[&>button]:border [&>button]:border-(--app-border-strong) [&>button]:font-semibold",outside:"[&>button]:text-(--app-muted) [&>button]:opacity-50",disabled:"[&>button]:text-(--app-muted) [&>button]:opacity-40 [&>button]:pointer-events-none",range_middle:"[&>button]:bg-(--app-surface) [&>button]:text-(--app-text) [&>button]:hover:bg-(--app-surface)",hidden:"invisible",...a},components:{MonthCaption:ju,Chevron:({orientation:l})=>l==="left"?pe(X,{className:"h-4 w-4"}):pe(I,{className:"h-4 w-4"})},...r})}je.displayName="Calendar";function Fa(e){if(!e)return null;let[a,t,r]=e.split("-").map(Number);return a==null||t==null||r==null?null:new Date(a,t-1,r)}function $l(e){if(!e)return"";let a=e.getFullYear(),t=String(e.getMonth()+1).padStart(2,"0"),r=String(e.getDate()).padStart(2,"0");return`${a}-${t}-${r}`}import{jsx as Se,jsxs as Yl}from"react/jsx-runtime";function ed({value:e,onChange:a,placeholder:t="\uB0A0\uC9DC \uC120\uD0DD",disabled:r=!1,id:l,required:d,className:s,minDate:u,maxDate:f,onBlur:i}){let[x,P]=jl.useState(!1),U=Fa(e??""),h=u?Fa(u):void 0,k=f?Fa(f):void 0,E=w=>{a(w?$l(w):""),P(!1)},D=w=>{w.stopPropagation(),a("")};return Yl(Ta,{open:x,onOpenChange:w=>{P(w),w||i?.()},children:[Se(Aa,{asChild:!0,children:Yl("button",{id:l,type:"button",disabled:r,"aria-required":d,className:o("inline-flex items-center gap-2 h-8 w-full px-3 text-sm text-left","bg-(--app-field) border-b border-(--app-border-strong)","text-(--app-text) transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","hover:bg-(--app-hover)","focus-visible:outline-none focus-visible:border-(--color-brand)","disabled:pointer-events-none disabled:opacity-40",!e&&"text-(--app-text-placeholder)",s),children:[Se(ze,{className:"h-4 w-4 shrink-0 text-(--app-muted)"}),Se("span",{className:"flex-1 truncate",children:e||t}),e&&!r&&Se("span",{role:"button",tabIndex:-1,onClick:D,className:"shrink-0 text-(--app-muted) hover:text-(--app-text) transition-colors",children:Se(N,{className:"h-3.5 w-3.5"})})]})}),Se(Ye,{className:"w-auto p-0",align:"start",children:Se(je,{mode:"single",selected:U??void 0,onSelect:E,defaultMonth:U??void 0,disabled:w=>!!(h&&w<h||k&&w>k),locale:Ql})})]})}import*as ad from"react";import*as td from"@radix-ui/react-separator";import{jsx as ai}from"react/jsx-runtime";var Bt=ad.forwardRef(({className:e,orientation:a="horizontal",decorative:t=!0,...r},l)=>ai(td.Root,{ref:l,decorative:t,orientation:a,className:o("shrink-0 bg-[var(--app-border)]",a==="horizontal"?"h-px w-full":"h-full w-px",e),...r}));Bt.displayName="Separator";import*as Ft from"react";import*as J from"@radix-ui/react-scroll-area";import{jsx as ea,jsxs as ti}from"react/jsx-runtime";var Nt=Ft.forwardRef(({className:e,children:a,...t},r)=>ti(J.Root,{ref:r,className:o("relative overflow-hidden",e),...t,children:[ea(J.Viewport,{className:"h-full w-full rounded-[inherit]",children:a}),ea(Na,{}),ea(J.Corner,{})]}));Nt.displayName="ScrollArea";var Na=Ft.forwardRef(({className:e,orientation:a="vertical",...t},r)=>ea(J.ScrollAreaScrollbar,{ref:r,orientation:a,className:o("flex touch-none select-none transition-colors",a==="vertical"&&"h-full w-2 border-l border-l-transparent p-px",a==="horizontal"&&"h-2 flex-col border-t border-t-transparent p-px",e),...t,children:ea(J.ScrollAreaThumb,{className:"relative flex-1 rounded-full bg-[var(--app-border-strong)]"})}));Na.displayName="ScrollBar";import*as od from"@radix-ui/react-aspect-ratio";var rd=od.Root;import*as ve from"react";import{jsx as Ne}from"react/jsx-runtime";var Ht=ve.forwardRef(({className:e,...a},t)=>Ne("div",{ref:t,className:o("rounded-(--radius-md) border border-(--app-border) bg-(--app-surface) text-(--app-text) shadow-sm",e),...a}));Ht.displayName="Card";var qt=ve.forwardRef(({className:e,...a},t)=>Ne("div",{ref:t,className:o("flex flex-col gap-1.5 p-4 pb-0",e),...a}));qt.displayName="CardHeader";var Ot=ve.forwardRef(({className:e,...a},t)=>Ne("h3",{ref:t,className:o("font-semibold leading-none tracking-tight",e),...a}));Ot.displayName="CardTitle";var Ut=ve.forwardRef(({className:e,...a},t)=>Ne("p",{ref:t,className:o("text-sm text-[var(--app-text-secondary)]",e),...a}));Ut.displayName="CardDescription";var Et=ve.forwardRef(({className:e,...a},t)=>Ne("div",{ref:t,className:o("p-4",e),...a}));Et.displayName="CardContent";var Wt=ve.forwardRef(({className:e,...a},t)=>Ne("div",{ref:t,className:o("flex items-center justify-end gap-2 p-4 pt-0",e),...a}));Wt.displayName="CardFooter";import*as He from"react";import{jsx as te,jsxs as oi}from"react/jsx-runtime";var Gt=He.forwardRef(({...e},a)=>te("nav",{ref:a,"aria-label":"breadcrumb",...e}));Gt.displayName="Breadcrumb";var Vt=He.forwardRef(({className:e,...a},t)=>te("ol",{ref:t,className:o("flex flex-wrap items-center gap-1 break-words text-sm text-[var(--app-text-secondary)]",e),...a}));Vt.displayName="BreadcrumbList";var zt=He.forwardRef(({className:e,...a},t)=>te("li",{ref:t,className:o("inline-flex items-center gap-1",e),...a}));zt.displayName="BreadcrumbItem";var Xt=He.forwardRef(({className:e,...a},t)=>te("a",{ref:t,className:o("transition-colors hover:text-[var(--app-text)] focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[var(--color-brand)]",e),...a}));Xt.displayName="BreadcrumbLink";var _t=He.forwardRef(({className:e,...a},t)=>te("span",{ref:t,role:"link","aria-disabled":"true","aria-current":"page",className:o("font-medium text-[var(--app-text)]",e),...a}));_t.displayName="BreadcrumbPage";var Kt=({children:e,className:a,...t})=>te("li",{role:"presentation","aria-hidden":"true",className:o("[&>svg]:h-3.5 [&>svg]:w-3.5 text-[var(--app-text-secondary)]",a),...t,children:e??te(I,{})});Kt.displayName="BreadcrumbSeparator";var Zt=({className:e,...a})=>oi("span",{role:"presentation","aria-hidden":"true",className:o("flex h-9 w-9 items-center justify-center",e),...a,children:[te("span",{className:"text-[var(--app-text-secondary)]",children:"\u2026"}),te("span",{className:"sr-only",children:"More pages"})]});Zt.displayName="BreadcrumbEllipsis";import*as qa from"react";import{cva as ri}from"class-variance-authority";import{jsx as Ha,jsxs as di}from"react/jsx-runtime";var Qt=ri("relative flex gap-3 rounded-(--radius-sm) border-l-[3px] p-4 text-sm transition-colors [&_svg]:h-5 [&_svg]:w-5 [&_svg]:shrink-0 [&_svg]:mt-0.5",{variants:{variant:{default:"border-l-[var(--app-border-strong)] bg-[var(--app-layer-02)] text-[var(--app-text)]",success:"border-l-[var(--color-success)] bg-[var(--color-success-subtle,color-mix(in_srgb,var(--color-success)_10%,transparent))] text-[var(--app-text)] [&_svg]:text-[var(--color-success)]",error:"border-l-[var(--color-accent)] bg-[var(--color-accent-subtle,color-mix(in_srgb,var(--color-accent)_10%,transparent))] text-[var(--app-text)] [&_svg]:text-[var(--color-accent)]",warning:"border-l-[var(--color-warning,#f59e0b)] bg-[color-mix(in_srgb,var(--color-warning,#f59e0b)_10%,transparent)] text-[var(--app-text)] [&_svg]:text-[var(--color-warning,#f59e0b)]",info:"border-l-[var(--color-brand)] bg-[color-mix(in_srgb,var(--color-brand)_10%,transparent)] text-[var(--app-text)] [&_svg]:text-[var(--color-brand)]"}},defaultVariants:{variant:"default"}}),li={default:Ve,success:_,error:se,warning:K,info:be},Jt=qa.forwardRef(({className:e,variant:a="default",icon:t,children:r,...l},d)=>{let s=li[a??"default"];return di("div",{ref:d,role:"alert",className:o(Qt({variant:a}),e),...l,children:[t!==void 0?t:Ha(s,{}),Ha("div",{className:"flex-1",children:r})]})});Jt.displayName="Alert";var $t=qa.forwardRef(({className:e,...a},t)=>Ha("h5",{ref:t,className:o("mb-1 font-semibold leading-none tracking-tight",e),...a}));$t.displayName="AlertTitle";var Yt=qa.forwardRef(({className:e,...a},t)=>Ha("p",{ref:t,className:o("text-sm leading-relaxed text-[var(--app-text-secondary)]",e),...a}));Yt.displayName="AlertDescription";import*as dd from"react";import*as Oa from"@radix-ui/react-progress";import{jsx as ld}from"react/jsx-runtime";var jt=dd.forwardRef(({className:e,value:a,indicatorClassName:t,...r},l)=>ld(Oa.Root,{ref:l,className:o("relative h-2 w-full overflow-hidden rounded-full bg-[var(--app-layer-02)]",e),...r,children:ld(Oa.Indicator,{className:o("h-full w-full flex-1 rounded-full bg-[var(--color-brand)] transition-all duration-300 ease-[cubic-bezier(0,0,0.38,0.9)]",t),style:{transform:`translateX(-${100-(a??0)}%)`}})}));jt.displayName="Progress";import*as we from"react";import*as b from"@radix-ui/react-alert-dialog";import{jsx as oe,jsxs as si}from"react/jsx-runtime";var sd=b.Root,ud=b.Trigger,eo=b.Portal,Ua=we.forwardRef(({className:e,...a},t)=>oe(b.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));Ua.displayName="AlertDialogOverlay";var ao=we.forwardRef(({className:e,...a},t)=>si(eo,{children:[oe(Ua,{}),oe(b.Content,{ref:t,className:o("fixed left-1/2 top-1/2 z-50 w-full max-w-lg -translate-x-1/2 -translate-y-1/2 rounded-(--radius-lg) bg-[var(--app-bg)] p-6 text-[var(--app-text)] shadow-[var(--shadow-modal)] 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%]",e),...a})]}));ao.displayName="AlertDialogContent";var to=({className:e,...a})=>oe("div",{className:o("flex flex-col gap-2 text-left",e),...a});to.displayName="AlertDialogHeader";var oo=({className:e,...a})=>oe("div",{className:o("flex justify-end gap-2 pt-4",e),...a});oo.displayName="AlertDialogFooter";var ro=we.forwardRef(({className:e,...a},t)=>oe(b.Title,{ref:t,className:o("text-base font-semibold text-[var(--app-text)]",e),...a}));ro.displayName="AlertDialogTitle";var lo=we.forwardRef(({className:e,...a},t)=>oe(b.Description,{ref:t,className:o("text-sm text-[var(--app-text-secondary)]",e),...a}));lo.displayName="AlertDialogDescription";var so=we.forwardRef(({className:e,...a},t)=>oe(b.Action,{ref:t,className:o(ke({variant:"primary"}),e),...a}));so.displayName="AlertDialogAction";var uo=we.forwardRef(({className:e,...a},t)=>oe(b.Cancel,{ref:t,className:o(ke({variant:"secondary"}),e),...a}));uo.displayName="AlertDialogCancel";import*as Ea from"react";import*as qe from"@radix-ui/react-avatar";import{cva as ui}from"class-variance-authority";import{jsx as po}from"react/jsx-runtime";var io=ui("relative flex shrink-0 overflow-hidden rounded-full",{variants:{size:{sm:"h-8 w-8 text-xs",default:"h-10 w-10 text-sm",lg:"h-14 w-14 text-base"}},defaultVariants:{size:"default"}}),fo=Ea.forwardRef(({className:e,size:a,...t},r)=>po(qe.Root,{ref:r,className:o(io({size:a}),e),...t}));fo.displayName="Avatar";var no=Ea.forwardRef(({className:e,...a},t)=>po(qe.Image,{ref:t,className:o("aspect-square h-full w-full object-cover",e),...a}));no.displayName="AvatarImage";var co=Ea.forwardRef(({className:e,...a},t)=>po(qe.Fallback,{ref:t,className:o("flex h-full w-full items-center justify-center rounded-full bg-[var(--app-layer-02)] font-medium text-[var(--app-text-secondary)]",e),...a}));co.displayName="AvatarFallback";import*as Oe from"@radix-ui/react-collapsible";var id=Oe.Root,fd=Oe.Trigger,nd=Oe.Content;import*as re from"react";import*as m from"@radix-ui/react-context-menu";import{jsx as A,jsxs as So}from"react/jsx-runtime";var cd=m.Root,pd=m.Trigger,md=m.Group,xd=m.Portal,Ld=m.Sub,gd=m.RadioGroup,mo=re.forwardRef(({className:e,children:a,...t},r)=>So(m.SubTrigger,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[a,A(I,{className:"ml-auto h-4 w-4"})]}));mo.displayName="ContextMenuSubTrigger";var xo=re.forwardRef(({className:e,...a},t)=>A(m.SubContent,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));xo.displayName="ContextMenuSubContent";var Lo=re.forwardRef(({className:e,...a},t)=>A(m.Portal,{children:A(m.Content,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a})}));Lo.displayName="ContextMenuContent";var go=re.forwardRef(({className:e,destructive:a,...t},r)=>A(m.Item,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",a?"text-[var(--color-error)] data-[highlighted]:text-[var(--color-error)]":"text-[var(--app-text)]",e),...t}));go.displayName="ContextMenuItem";var Co=re.forwardRef(({className:e,children:a,checked:t,...r},l)=>So(m.CheckboxItem,{ref:l,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:t,...r,children:[A("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:A(m.ItemIndicator,{children:A(W,{className:"h-4 w-4"})})}),a]}));Co.displayName="ContextMenuCheckboxItem";var Io=re.forwardRef(({className:e,children:a,...t},r)=>So(m.RadioItem,{ref:r,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[A("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:A(m.ItemIndicator,{children:A(ee,{className:"h-2 w-2 fill-current"})})}),a]}));Io.displayName="ContextMenuRadioItem";var ho=re.forwardRef(({className:e,...a},t)=>A(m.Label,{ref:t,className:o("px-3 py-1.5 text-xs font-semibold text-[var(--app-muted)]",e),...a}));ho.displayName="ContextMenuLabel";var bo=re.forwardRef(({className:e,...a},t)=>A(m.Separator,{ref:t,className:o("h-px bg-[var(--app-border)] -mx-1 my-1",e),...a}));bo.displayName="ContextMenuSeparator";var Po=({className:e,...a})=>A("span",{className:o("ml-auto text-xs tracking-widest text-[var(--app-muted)]",e),...a});Po.displayName="ContextMenuShortcut";import*as Id from"react";import*as me from"@radix-ui/react-hover-card";import{jsx as Cd}from"react/jsx-runtime";var hd=me.Root,bd=me.Trigger,vo=Id.forwardRef(({className:e,align:a="center",sideOffset:t=4,...r},l)=>Cd(me.Portal,{children:Cd(me.Content,{ref:l,align:a,sideOffset:t,className:o("z-50 w-64 rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) p-4 text-(--app-text) shadow-(--shadow-dropdown) 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-[side=bottom]:slide-in-from-top-2 data-[side=top]:slide-in-from-bottom-2","data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2",e),...r})}));vo.displayName="HoverCardContent";import*as V from"react";import*as p from"@radix-ui/react-menubar";import{jsx as y,jsxs as Ho}from"react/jsx-runtime";var Pd=p.Menu,Sd=p.Group,vd=p.Portal,wd=p.Sub,Rd=p.RadioGroup,wo=V.forwardRef(({className:e,...a},t)=>y(p.Root,{ref:t,className:o("flex h-9 items-center gap-0 border border-[var(--app-border)] bg-[var(--app-bg)] px-1",e),...a}));wo.displayName="Menubar";var Ro=V.forwardRef(({className:e,...a},t)=>y(p.Trigger,{ref:t,className:o("flex cursor-default select-none items-center px-3 py-1.5 text-sm font-medium outline-none","text-[var(--app-text)] hover:bg-[var(--app-hover)]","data-[state=open]:bg-[var(--app-hover)]","focus:bg-[var(--app-hover)]",e),...a}));Ro.displayName="MenubarTrigger";var yo=V.forwardRef(({className:e,children:a,...t},r)=>Ho(p.SubTrigger,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[a,y(I,{className:"ml-auto h-4 w-4"})]}));yo.displayName="MenubarSubTrigger";var Mo=V.forwardRef(({className:e,...a},t)=>y(p.SubContent,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));Mo.displayName="MenubarSubContent";var ko=V.forwardRef(({className:e,align:a="start",alignOffset:t=-4,sideOffset:r=8,...l},d)=>y(p.Portal,{children:y(p.Content,{ref:d,align:a,alignOffset:t,sideOffset:r,className:o("z-50 min-w-[12rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...l})}));ko.displayName="MenubarContent";var Do=V.forwardRef(({className:e,destructive:a,...t},r)=>y(p.Item,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",a?"text-[var(--color-error)] data-[highlighted]:text-[var(--color-error)]":"text-[var(--app-text)]",e),...t}));Do.displayName="MenubarItem";var To=V.forwardRef(({className:e,children:a,checked:t,...r},l)=>Ho(p.CheckboxItem,{ref:l,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:t,...r,children:[y("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:y(p.ItemIndicator,{children:y(W,{className:"h-4 w-4"})})}),a]}));To.displayName="MenubarCheckboxItem";var Ao=V.forwardRef(({className:e,children:a,...t},r)=>Ho(p.RadioItem,{ref:r,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[y("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:y(p.ItemIndicator,{children:y(ee,{className:"h-2 w-2 fill-current"})})}),a]}));Ao.displayName="MenubarRadioItem";var Bo=V.forwardRef(({className:e,...a},t)=>y(p.Label,{ref:t,className:o("px-3 py-1.5 text-xs font-semibold text-[var(--app-muted)]",e),...a}));Bo.displayName="MenubarLabel";var Fo=V.forwardRef(({className:e,...a},t)=>y(p.Separator,{ref:t,className:o("h-px bg-[var(--app-border)] -mx-1 my-1",e),...a}));Fo.displayName="MenubarSeparator";var No=({className:e,...a})=>y("span",{className:o("ml-auto text-xs tracking-widest text-[var(--app-muted)]",e),...a});No.displayName="MenubarShortcut";import*as xe from"react";import*as M from"@radix-ui/react-navigation-menu";import{jsx as le,jsxs as Md}from"react/jsx-runtime";var qo=xe.forwardRef(({className:e,children:a,...t},r)=>Md(M.Root,{ref:r,className:o("relative z-10 flex items-center",e),...t,children:[a,le(Ga,{})]}));qo.displayName="NavigationMenu";var Oo=xe.forwardRef(({className:e,...a},t)=>le(M.List,{ref:t,className:o("flex flex-1 list-none items-center gap-1",e),...a}));Oo.displayName="NavigationMenuList";var yd=M.Item,Wa=o("group inline-flex h-9 items-center justify-center px-4 py-2 text-sm font-medium outline-none transition-colors","text-[var(--app-text)] bg-transparent hover:bg-[var(--app-hover)]","focus:bg-[var(--app-hover)]","data-[active]:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]","disabled:pointer-events-none disabled:opacity-50"),Uo=xe.forwardRef(({className:e,children:a,...t},r)=>Md(M.Trigger,{ref:r,className:o(Wa,"gap-1",e),...t,children:[a,le(j,{className:"relative h-3 w-3 transition-transform duration-200 group-data-[state=open]:rotate-180","aria-hidden":"true"})]}));Uo.displayName="NavigationMenuTrigger";var Eo=xe.forwardRef(({className:e,...a},t)=>le(M.Content,{ref:t,className:o("left-0 top-0 w-full md:absolute md:w-auto","data-[motion=from-end]:animate-in data-[motion=from-start]:animate-in data-[motion=to-end]:animate-out data-[motion=to-start]:animate-out","data-[motion=from-end]:slide-in-from-right-52 data-[motion=from-start]:slide-in-from-left-52","data-[motion=to-end]:slide-out-to-right-52 data-[motion=to-start]:slide-out-to-left-52",e),...a}));Eo.displayName="NavigationMenuContent";var Wo=xe.forwardRef(({className:e,...a},t)=>le(M.Link,{ref:t,className:o(Wa,e),...a}));Wo.displayName="NavigationMenuLink";var Ga=xe.forwardRef(({className:e,...a},t)=>le("div",{className:o("absolute left-0 top-full flex justify-center"),children:le(M.Viewport,{className:o("origin-top-center relative mt-1.5 h-[var(--radix-navigation-menu-viewport-height)] w-full overflow-hidden rounded-(--radius-md)","bg-(--app-bg) border border-(--app-border) shadow-(--shadow-dropdown)","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-90","md:w-[var(--radix-navigation-menu-viewport-width)]",e),ref:t,...a})}));Ga.displayName="NavigationMenuViewport";var Go=xe.forwardRef(({className:e,...a},t)=>le(M.Indicator,{ref:t,className:o("top-full z-[1] flex h-1.5 items-end justify-center overflow-hidden","data-[state=visible]:animate-in data-[state=hidden]:animate-out","data-[state=hidden]:fade-out data-[state=visible]:fade-in",e),...a,children:le("div",{className:"relative top-[60%] h-2 w-2 rotate-45 bg-[var(--app-border)] shadow-md"})}));Go.displayName="NavigationMenuIndicator";import*as Vo from"react";import*as Ue from"@radix-ui/react-radio-group";import{jsx as Va}from"react/jsx-runtime";var zo=Vo.forwardRef(({className:e,...a},t)=>Va(Ue.Root,{ref:t,className:o("grid gap-2",e),...a}));zo.displayName="RadioGroup";var Xo=Vo.forwardRef(({className:e,...a},t)=>Va(Ue.Item,{ref:t,className:o("relative aspect-square h-4 w-4 rounded-full border border-(--app-border-strong) text-(--color-brand)","shadow-sm outline-none transition-colors","hover:border-(--color-brand)","focus-visible:ring-2 focus-visible:ring-(--color-brand) focus-visible:ring-offset-2","disabled:cursor-not-allowed disabled:opacity-50","data-[state=checked]:border-(--color-brand) data-[state=checked]:bg-(--color-brand)","before:absolute before:-inset-[14px] before:content-['']",e),...a,children:Va(Ue.Indicator,{className:"flex items-center justify-center",children:Va(ee,{className:"h-2 w-2 fill-white text-white"})})}));Xo.displayName="RadioGroupItem";import*as kd from"react";import*as Le from"@radix-ui/react-slider";import{jsx as _o,jsxs as ii}from"react/jsx-runtime";var Ko=kd.forwardRef(({className:e,...a},t)=>ii(Le.Root,{ref:t,className:o("relative flex w-full touch-none select-none items-center",e),...a,children:[_o(Le.Track,{className:"relative h-1.5 w-full grow overflow-hidden bg-[var(--app-border)]",children:_o(Le.Range,{className:"absolute h-full bg-[var(--color-brand)]"})}),(a.defaultValue??a.value??[0]).map((r,l)=>_o(Le.Thumb,{className:o("block h-4 w-4 border-2 border-[var(--color-brand)] bg-[var(--app-bg)] shadow transition-colors","hover:border-[var(--color-brand-hover)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[var(--color-brand)] focus-visible:ring-offset-2","disabled:pointer-events-none disabled:opacity-50")},l))]}));Ko.displayName="Slider";import*as Dd from"react";import*as Td from"@radix-ui/react-toggle";import{cva as fi}from"class-variance-authority";import{jsx as ni}from"react/jsx-runtime";var aa=fi(["inline-flex items-center justify-center gap-2 text-sm font-medium outline-none transition-colors","text-[var(--app-muted)] hover:bg-[var(--app-hover)] hover:text-[var(--app-text)]","focus-visible:ring-2 focus-visible:ring-[var(--color-brand)] focus-visible:ring-offset-2","disabled:pointer-events-none disabled:opacity-50","data-[state=on]:bg-[var(--app-surface)] data-[state=on]:text-[var(--app-text)]"],{variants:{variant:{default:"bg-transparent",outline:"border border-[var(--app-border)] bg-transparent hover:border-[var(--app-border-strong)]"},size:{sm:"h-7 px-2 text-xs",default:"h-9 px-3",lg:"h-11 px-5 text-base"}},defaultVariants:{variant:"default",size:"default"}}),Zo=Dd.forwardRef(({className:e,variant:a,size:t,...r},l)=>ni(Td.Root,{ref:l,className:o(aa({variant:a,size:t}),e),...r}));Zo.displayName="Toggle";import*as Re from"react";import*as za from"@radix-ui/react-toggle-group";import"class-variance-authority";import{jsx as Qo}from"react/jsx-runtime";var Ad=Re.createContext({size:"default",variant:"default"}),Jo=Re.forwardRef(({className:e,variant:a,size:t,children:r,...l},d)=>Qo(za.Root,{ref:d,className:o("flex items-center gap-1",e),...l,children:Qo(Ad.Provider,{value:{variant:a,size:t},children:r})}));Jo.displayName="ToggleGroup";var $o=Re.forwardRef(({className:e,children:a,variant:t,size:r,...l},d)=>{let s=Re.useContext(Ad);return Qo(za.Item,{ref:d,className:o(aa({variant:t??s.variant,size:r??s.size}),e),...l,children:a})});$o.displayName="ToggleGroupItem";import*as ye from"react";import{OTPInput as ci,OTPInputContext as pi}from"input-otp";import{jsx as Ee,jsxs as mi}from"react/jsx-runtime";var Yo=ye.forwardRef(({className:e,containerClassName:a,...t},r)=>Ee(ci,{ref:r,containerClassName:o("flex items-center gap-2 has-[:disabled]:opacity-50",a),className:o("disabled:cursor-not-allowed",e),...t}));Yo.displayName="InputOTP";var jo=ye.forwardRef(({className:e,...a},t)=>Ee("div",{ref:t,className:o("flex items-center",e),...a}));jo.displayName="InputOTPGroup";var er=ye.forwardRef(({index:e,className:a,...t},r)=>{let d=ye.useContext(pi).slots[e],s=d?.char,u=d?.hasFakeCaret,f=d?.isActive;return mi("div",{ref:r,className:o("relative flex h-10 w-10 items-center justify-center","border-y border-r border-(--app-border)","text-sm text-(--app-text) bg-(--app-bg)","transition-all duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","first:border-l",f&&"z-10 ring-2 ring-(--color-brand) border-(--color-brand)",a),...t,children:[s,u&&Ee("div",{className:"pointer-events-none absolute inset-0 flex items-center justify-center",children:Ee("div",{className:"animate-caret-blink h-4 w-px bg-(--app-text) duration-1000"})})]})});er.displayName="InputOTPSlot";var ar=ye.forwardRef(({...e},a)=>Ee("div",{ref:a,role:"separator",...e,children:Ee(Xe,{className:"h-4 w-4 text-(--app-muted)"})}));ar.displayName="InputOTPSeparator";import*as ta from"react";import*as v from"@radix-ui/react-dialog";import{jsx as ge,jsxs as tr}from"react/jsx-runtime";var Bd=v.Root,Fd=v.Trigger,Nd=v.Close,Hd=v.Portal,or=ta.forwardRef(({className:e,...a},t)=>ge(v.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0","duration-240 ease-[cubic-bezier(0,0,0.38,0.9)]",e),...a}));or.displayName="SheetOverlay";var xi=e=>{let a=o("fixed z-50 bg-(--app-bg) text-(--app-text) shadow-(--shadow-modal)","duration-240 ease-[cubic-bezier(0,0,0.38,0.9)]","data-[state=open]:animate-in data-[state=closed]:animate-out");return{top:o(a,"inset-x-0 top-0 border-b border-(--app-border) rounded-b-(--radius-lg)","data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top"),right:o(a,"inset-y-0 right-0 h-full w-3/4 border-l border-(--app-border) rounded-l-(--radius-lg) sm:max-w-sm","data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right"),bottom:o(a,"inset-x-0 bottom-0 border-t border-(--app-border) rounded-t-(--radius-lg)","data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom"),left:o(a,"inset-y-0 left-0 h-full w-3/4 border-r border-(--app-border) rounded-r-(--radius-lg) sm:max-w-sm","data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left")}[e]},rr=ta.forwardRef(({side:e="right",className:a,children:t,...r},l)=>tr(Hd,{children:[ge(or,{}),tr(v.Content,{ref:l,className:o(xi(e),a),...r,children:[tr(v.Close,{className:o("absolute right-4 top-4 text-(--app-muted)","hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:pointer-events-none"),children:[ge(N,{className:"h-4 w-4"}),ge("span",{className:"sr-only",children:"\uB2EB\uAE30"})]}),t]})]}));rr.displayName="SheetContent";var lr=({className:e,...a})=>ge("div",{className:o("flex flex-col gap-1.5 px-6 py-4","border-b border-(--app-border)",e),...a});lr.displayName="SheetHeader";var dr=({className:e,...a})=>ge("div",{className:o("flex flex-col-reverse sm:flex-row sm:justify-end gap-2 px-6 py-4","border-t border-(--app-border) mt-auto",e),...a});dr.displayName="SheetFooter";var sr=ta.forwardRef(({className:e,...a},t)=>ge(v.Title,{ref:t,className:o("text-lg font-semibold text-(--app-text)",e),...a}));sr.displayName="SheetTitle";var ur=ta.forwardRef(({className:e,...a},t)=>ge(v.Description,{ref:t,className:o("text-sm text-(--app-muted)",e),...a}));ur.displayName="SheetDescription";import*as oa from"react";import{Drawer as z}from"vaul";import{jsx as Ce,jsxs as qd}from"react/jsx-runtime";var ir=({shouldScaleBackground:e=!0,...a})=>Ce(z.Root,{shouldScaleBackground:e,...a});ir.displayName="Drawer";var Od=z.Trigger,Ud=z.Portal,Ed=z.Close,fr=oa.forwardRef(({className:e,...a},t)=>Ce(z.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60",e),...a}));fr.displayName=z.Overlay.displayName;var nr=oa.forwardRef(({className:e,children:a,...t},r)=>qd(Ud,{children:[Ce(fr,{}),qd(z.Content,{ref:r,className:o("fixed inset-x-0 bottom-0 z-50 mt-24 flex h-auto flex-col rounded-t-(--radius-lg)","bg-(--app-bg) text-(--app-text)","border-t border-(--app-border)","shadow-(--shadow-modal)",e),...t,children:[Ce("div",{className:"mx-auto mt-4 h-2 w-[100px] bg-(--app-border-strong)"}),a]})]}));nr.displayName="DrawerContent";var cr=({className:e,...a})=>Ce("div",{className:o("grid gap-1.5 p-4 text-center sm:text-left","border-b border-(--app-border)",e),...a});cr.displayName="DrawerHeader";var pr=({className:e,...a})=>Ce("div",{className:o("mt-auto flex flex-col gap-2 p-4","border-t border-(--app-border)",e),...a});pr.displayName="DrawerFooter";var mr=oa.forwardRef(({className:e,...a},t)=>Ce(z.Title,{ref:t,className:o("text-lg font-semibold leading-none tracking-tight text-(--app-text)",e),...a}));mr.displayName=z.Title.displayName;var xr=oa.forwardRef(({className:e,...a},t)=>Ce(z.Description,{ref:t,className:o("text-sm text-(--app-muted)",e),...a}));xr.displayName=z.Description.displayName;import*as Ie from"react";import{Command as B}from"cmdk";import{jsx as O,jsxs as Li}from"react/jsx-runtime";var Xa=Ie.forwardRef(({className:e,...a},t)=>O(B,{ref:t,className:o("flex h-full w-full flex-col overflow-hidden rounded-(--radius-lg)","bg-(--app-bg) text-(--app-text)",e),...a}));Xa.displayName=B.displayName;var Wd=({children:e,...a})=>O(ya,{...a,children:O($e,{className:"overflow-hidden p-0 shadow-(--shadow-modal)",hideClose:!0,children:O(Xa,{className:"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-(--app-muted) [&_[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",children:e})})}),Lr=Ie.forwardRef(({className:e,...a},t)=>Li("div",{className:"flex items-center border-b border-(--app-border) px-3","cmdk-input-wrapper":"",children:[O(Pe,{className:"mr-2 h-4 w-4 shrink-0 text-(--app-muted)"}),O(B.Input,{ref:t,className:o("flex h-10 w-full bg-transparent py-3 text-sm outline-none","text-(--app-text) placeholder:text-(--app-muted)","disabled:cursor-not-allowed disabled:opacity-50",e),...a})]}));Lr.displayName=B.Input.displayName;var gr=Ie.forwardRef(({className:e,...a},t)=>O(B.List,{ref:t,className:o("max-h-[300px] overflow-y-auto overflow-x-hidden",e),...a}));gr.displayName=B.List.displayName;var Cr=Ie.forwardRef((e,a)=>O(B.Empty,{ref:a,className:"py-6 text-center text-sm text-(--app-muted)",...e}));Cr.displayName=B.Empty.displayName;var Ir=Ie.forwardRef(({className:e,...a},t)=>O(B.Group,{ref:t,className:o("overflow-hidden p-1 text-(--app-text)","[&_[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-(--app-muted)",e),...a}));Ir.displayName=B.Group.displayName;var hr=Ie.forwardRef(({className:e,...a},t)=>O(B.Separator,{ref:t,className:o("-mx-1 h-px bg-(--app-border)",e),...a}));hr.displayName=B.Separator.displayName;var br=Ie.forwardRef(({className:e,...a},t)=>O(B.Item,{ref:t,className:o("relative flex cursor-default gap-2 select-none items-center px-2 py-1.5 text-sm outline-none","text-(--app-text)","data-[selected=true]:bg-(--app-surface) data-[selected=true]:text-(--app-text)","data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","[&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",e),...a}));br.displayName=B.Item.displayName;var Pr=({className:e,...a})=>O("span",{className:o("ml-auto text-xs tracking-widest text-(--app-muted)",e),...a});Pr.displayName="CommandShortcut";import*as C from"react";import gi from"embla-carousel-react";import{jsx as de,jsxs as Vd}from"react/jsx-runtime";var Gd=C.createContext(null);function _a(){let e=C.useContext(Gd);if(!e)throw new Error("useCarousel must be used within <Carousel />");return e}var Sr=C.forwardRef(({orientation:e="horizontal",opts:a,setApi:t,plugins:r,className:l,children:d,...s},u)=>{let[f,i]=gi({...a,axis:e==="horizontal"?"x":"y"},r),[x,P]=C.useState(!1),[U,h]=C.useState(!1),k=C.useCallback(T=>{T&&(P(T.canScrollPrev()),h(T.canScrollNext()))},[]),E=C.useCallback(()=>i?.scrollPrev(),[i]),D=C.useCallback(()=>i?.scrollNext(),[i]),w=C.useCallback(T=>{T.key==="ArrowLeft"?(T.preventDefault(),E()):T.key==="ArrowRight"&&(T.preventDefault(),D())},[E,D]);return C.useEffect(()=>{!i||!t||t(i)},[i,t]),C.useEffect(()=>{if(i)return k(i),i.on("reInit",k),i.on("select",k),()=>{i?.off("select",k)}},[i,k]),de(Gd.Provider,{value:{carouselRef:f,api:i,opts:a,orientation:e,scrollPrev:E,scrollNext:D,canScrollPrev:x,canScrollNext:U},children:de("div",{ref:u,onKeyDownCapture:w,className:o("relative",l),role:"region","aria-roledescription":"carousel",...s,children:d})})});Sr.displayName="Carousel";var vr=C.forwardRef(({className:e,...a},t)=>{let{carouselRef:r,orientation:l}=_a();return de("div",{ref:r,className:"overflow-hidden",children:de("div",{ref:t,className:o("flex",l==="horizontal"?"-ml-4":"-mt-4 flex-col",e),...a})})});vr.displayName="CarouselContent";var wr=C.forwardRef(({className:e,...a},t)=>{let{orientation:r}=_a();return de("div",{ref:t,role:"group","aria-roledescription":"slide",className:o("min-w-0 shrink-0 grow-0 basis-full",r==="horizontal"?"pl-4":"pt-4",e),...a})});wr.displayName="CarouselItem";var Rr=C.forwardRef(({className:e,...a},t)=>{let{orientation:r,scrollPrev:l,canScrollPrev:d}=_a();return Vd("button",{ref:t,className:o("absolute h-8 w-8 flex items-center justify-center","border border-(--app-border) bg-(--app-bg) text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:opacity-40 disabled:pointer-events-none",r==="horizontal"?"-left-12 top-1/2 -translate-y-1/2":"-top-12 left-1/2 -translate-x-1/2 rotate-90",e),disabled:!d,onClick:l,"aria-label":"\uC774\uC804 \uC2AC\uB77C\uC774\uB4DC",...a,children:[de(X,{className:"h-4 w-4"}),de("span",{className:"sr-only",children:"\uC774\uC804"})]})});Rr.displayName="CarouselPrevious";var yr=C.forwardRef(({className:e,...a},t)=>{let{orientation:r,scrollNext:l,canScrollNext:d}=_a();return Vd("button",{ref:t,className:o("absolute h-8 w-8 flex items-center justify-center","border border-(--app-border) bg-(--app-bg) text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:opacity-40 disabled:pointer-events-none",r==="horizontal"?"-right-12 top-1/2 -translate-y-1/2":"-bottom-12 left-1/2 -translate-x-1/2 rotate-90",e),disabled:!d,onClick:l,"aria-label":"\uB2E4\uC74C \uC2AC\uB77C\uC774\uB4DC",...a,children:[de(I,{className:"h-4 w-4"}),de("span",{className:"sr-only",children:"\uB2E4\uC74C"})]})});yr.displayName="CarouselNext";import*as Mr from"react";import{jsx as $,jsxs as Nr}from"react/jsx-runtime";var kr=({className:e,...a})=>$("nav",{role:"navigation","aria-label":"pagination",className:o("mx-auto flex w-full justify-center",e),...a});kr.displayName="Pagination";var Dr=Mr.forwardRef(({className:e,...a},t)=>$("ul",{ref:t,className:o("flex flex-row items-center gap-1",e),...a}));Dr.displayName="PaginationContent";var Tr=Mr.forwardRef(({className:e,...a},t)=>$("li",{ref:t,className:o("",e),...a}));Tr.displayName="PaginationItem";var ra=({className:e,isActive:a,size:t="default",...r})=>$("a",{"aria-current":a?"page":void 0,className:o("flex items-center justify-center text-sm","border border-transparent","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","cursor-pointer",t==="default"?"h-9 min-w-9 px-3":"h-9 w-9",a?"bg-(--color-brand) text-white border-(--color-brand) hover:bg-(--color-brand-hover)":"text-(--app-text) hover:bg-(--app-surface) border-(--app-border)",e),...r});ra.displayName="PaginationLink";var Ar=({className:e,...a})=>Nr(ra,{"aria-label":"\uC774\uC804 \uD398\uC774\uC9C0\uB85C \uC774\uB3D9",size:"default",className:o("gap-1 pl-2.5",e),...a,children:[$(X,{className:"h-4 w-4"}),$("span",{children:"\uC774\uC804"})]});Ar.displayName="PaginationPrevious";var Br=({className:e,...a})=>Nr(ra,{"aria-label":"\uB2E4\uC74C \uD398\uC774\uC9C0\uB85C \uC774\uB3D9",size:"default",className:o("gap-1 pr-2.5",e),...a,children:[$("span",{children:"\uB2E4\uC74C"}),$(I,{className:"h-4 w-4"})]});Br.displayName="PaginationNext";var Fr=({className:e,...a})=>Nr("span",{"aria-hidden":!0,className:o("flex h-9 w-9 items-center justify-center text-(--app-muted)",e),...a,children:[$(ie,{className:"h-4 w-4"}),$("span",{className:"sr-only",children:"\uB354\uBCF4\uAE30"})]});Fr.displayName="PaginationEllipsis";import"react";import{Group as Ci,Panel as Ii,Separator as hi}from"react-resizable-panels";import{jsx as Ka}from"react/jsx-runtime";var Hr=({className:e,...a})=>Ka(Ci,{className:o("flex h-full w-full data-[orientation=vertical]:flex-col",e),...a});Hr.displayName="ResizablePanelGroup";var zd=Ii,qr=({withHandle:e,className:a,...t})=>Ka(hi,{className:o("relative flex items-center justify-center","bg-(--app-border)","data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full","data-[orientation=vertical]:w-px data-[orientation=vertical]:h-full","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand) focus-visible:ring-offset-1","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","hover:bg-(--color-brand)",a),...t,children:e&&Ka("div",{className:"z-10 flex h-4 w-3 items-center justify-center border border-(--app-border) bg-(--app-bg)",children:Ka(_e,{className:"h-2.5 w-2.5 text-(--app-muted)"})})});qr.displayName="ResizableHandle";export{il as Accordion,Ct as AccordionContent,Lt as AccordionItem,gt as AccordionTrigger,Jt as Alert,Yt as AlertDescription,sd as AlertDialog,so as AlertDialogAction,uo as AlertDialogCancel,ao as AlertDialogContent,lo as AlertDialogDescription,oo as AlertDialogFooter,to as AlertDialogHeader,Ua as AlertDialogOverlay,eo as AlertDialogPortal,ro as AlertDialogTitle,ud as AlertDialogTrigger,$t as AlertTitle,rd as AspectRatio,fo as Avatar,co as AvatarFallback,no as AvatarImage,Yr as Badge,Gt as Breadcrumb,Zt as BreadcrumbEllipsis,zt as BreadcrumbItem,Xt as BreadcrumbLink,Vt as BreadcrumbList,_t as BreadcrumbPage,Kt as BreadcrumbSeparator,$a as Button,je as Calendar,Ht as Card,Et as CardContent,Ut as CardDescription,Wt as CardFooter,qt as CardHeader,Ot as CardTitle,Sr as Carousel,vr as CarouselContent,wr as CarouselItem,yr as CarouselNext,Rr as CarouselPrevious,ot as Checkbox,id as Collapsible,nd as CollapsibleContent,fd as CollapsibleTrigger,Xa as Command,Wd as CommandDialog,Cr as CommandEmpty,Ir as CommandGroup,Lr as CommandInput,br as CommandItem,gr as CommandList,hr as CommandSeparator,Pr as CommandShortcut,cd as ContextMenu,Co as ContextMenuCheckboxItem,Lo as ContextMenuContent,md as ContextMenuGroup,go as ContextMenuItem,ho as ContextMenuLabel,xd as ContextMenuPortal,gd as ContextMenuRadioGroup,Io as ContextMenuRadioItem,bo as ContextMenuSeparator,Po as ContextMenuShortcut,Ld as ContextMenuSub,xo as ContextMenuSubContent,mo as ContextMenuSubTrigger,pd as ContextMenuTrigger,rl as DataTable,ed as DatePicker,ya as Dialog,ml as DialogBody,nl as DialogClose,$e as DialogContent,Pt as DialogDescription,xl as DialogFooter,pl as DialogHeader,bt as DialogTitle,fl as DialogTrigger,ir as Drawer,Ed as DrawerClose,nr as DrawerContent,xr as DrawerDescription,pr as DrawerFooter,cr as DrawerHeader,mr as DrawerTitle,Od as DrawerTrigger,wl as DropdownMenu,yt as DropdownMenuCheckboxItem,wt as DropdownMenuContent,yl as DropdownMenuGroup,Rt as DropdownMenuItem,kt as DropdownMenuLabel,Mt as DropdownMenuSeparator,Ml as DropdownMenuSub,vt as DropdownMenuSubContent,St as DropdownMenuSubTrigger,Rl as DropdownMenuTrigger,vl as FormField,bl as FormGrid,hd as HoverCard,vo as HoverCardContent,bd as HoverCardTrigger,Ya as Input,Yo as InputOTP,jo as InputOTPGroup,ar as InputOTPSeparator,er as InputOTPSlot,Y as Label,ct as List,mt as ListHeader,pt as ListItem,wo as Menubar,To as MenubarCheckboxItem,ko as MenubarContent,Sd as MenubarGroup,Do as MenubarItem,Bo as MenubarLabel,Pd as MenubarMenu,vd as MenubarPortal,Rd as MenubarRadioGroup,Ao as MenubarRadioItem,Fo as MenubarSeparator,No as MenubarShortcut,wd as MenubarSub,Mo as MenubarSubContent,yo as MenubarSubTrigger,Ro as MenubarTrigger,ka as ModalActionButtons,Ma as ModalHeader,hl as ModalSection,qo as NavigationMenu,Eo as NavigationMenuContent,Go as NavigationMenuIndicator,yd as NavigationMenuItem,Wo as NavigationMenuLink,Oo as NavigationMenuList,Uo as NavigationMenuTrigger,Ga as NavigationMenuViewport,Ul as Notification,kr as Pagination,Dr as PaginationContent,Fr as PaginationEllipsis,Tr as PaginationItem,ra as PaginationLink,Br as PaginationNext,Ar as PaginationPrevious,Ta as Popover,Al as PopoverAnchor,Bl as PopoverClose,Ye as PopoverContent,Aa as PopoverTrigger,jt as Progress,zo as RadioGroup,Xo as RadioGroupItem,qr as ResizableHandle,zd as ResizablePanel,Hr as ResizablePanelGroup,Nt as ScrollArea,Na as ScrollBar,dt as Search,tt as Select,Bt as Separator,Bd as Sheet,Nd as SheetClose,rr as SheetContent,ur as SheetDescription,dr as SheetFooter,lr as SheetHeader,sr as SheetTitle,Fd as SheetTrigger,At as Skeleton,Ko as Slider,ol as SortButton,Wl as Spinner,Gl as SpinnerInline,Cl as StandardModal,lt as Switch,ba as Table,Pa as TablePagination,ll as Tabs,nt as TabsContent,it as TabsList,ft as TabsTrigger,ja as Textarea,Zo as Toggle,Jo as ToggleGroup,$o as ToggleGroupItem,Hl as Tooltip,Nl as TooltipProvider,ul as TreeView,Qt as alertVariants,io as avatarVariants,ke as buttonVariants,o as cn,Wa as navigationMenuTriggerStyle,Tt as notificationVariants,aa as toggleVariants};
2
+ import*as Yr from"react";import{Slot as hs}from"@radix-ui/react-slot";import{cva as bs}from"class-variance-authority";import{clsx as Cs}from"clsx";import{twMerge as Is}from"tailwind-merge";function o(...e){return Is(Cs(e))}import{jsx as $r,jsxs as Ps}from"react/jsx-runtime";var Oe=bs("inline-flex items-center justify-center gap-2 whitespace-nowrap font-medium transition-colors duration-[110ms] ease-[cubic-bezier(0,0,0.38,0.9)] disabled:pointer-events-none disabled:opacity-40 [&_svg]:pointer-events-none [&_svg]:shrink-0 min-touch-target",{variants:{variant:{primary:"bg-[var(--color-brand)] text-[var(--app-text-on-color)] hover:bg-[var(--color-brand-hover)] active:bg-[var(--color-brand-active)]",secondary:"border border-[var(--app-border-strong)] bg-transparent text-[var(--app-text)] hover:bg-[var(--app-hover)]",danger:"bg-[var(--color-accent)] text-[var(--app-text-on-color)] hover:bg-[var(--color-accent-hover)]",ghost:"bg-transparent text-[var(--color-brand)] hover:bg-[var(--app-hover)]",link:"bg-transparent text-[var(--color-brand)] underline-offset-4 hover:underline"},size:{sm:"h-8 px-4 text-xs",default:"h-10 px-6 text-sm",lg:"h-12 px-8 text-base",icon:"h-10 w-10"}},defaultVariants:{variant:"primary",size:"default"}}),nt=Yr.forwardRef(({className:e,variant:a,size:t,asChild:r=!1,loading:l,fullWidth:d,disabled:s,children:u,...f},i)=>Ps(r?hs:"button",{className:o(Oe({variant:a,size:t}),d&&"w-full",e),ref:i,disabled:s||l,...f,children:[l&&$r("svg",{className:"h-4 w-4 animate-spin",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:$r("path",{d:"M12 2a10 10 0 0 1 10 10",strokeLinecap:"round"})}),u]}));nt.displayName="Button";import*as wa from"react";import*as jr from"react";import*as el from"@radix-ui/react-label";import{jsx as Ss,jsxs as vs}from"react/jsx-runtime";var ee=jr.forwardRef(({className:e,required:a,children:t,...r},l)=>vs(el.Root,{ref:l,className:o("text-xs font-medium text-[var(--app-text-secondary)] peer-disabled:cursor-not-allowed peer-disabled:opacity-40",e),...r,children:[t,a&&Ss("span",{className:"ml-0.5 text-[var(--color-error)]",children:"*"})]}));ee.displayName="Label";import{jsx as va,jsxs as Rs}from"react/jsx-runtime";var ws={sm:"h-8 text-xs",default:"h-10 text-sm",lg:"h-12 text-base"},ct=wa.forwardRef(({className:e,label:a,helperText:t,errorText:r,required:l,inputSize:d="default",id:s,...u},f)=>{let i=s||wa.useId();return Rs("div",{className:"flex flex-col gap-1",children:[a&&va(ee,{htmlFor:i,required:l,children:a}),va("input",{id:i,ref:f,required:l,className:o("w-full bg-[var(--app-field)] px-4 font-[var(--font-sans)] text-[var(--app-text)] outline-none border-0 border-b transition-colors duration-[110ms]","placeholder:text-[var(--app-text-placeholder)]","disabled:cursor-not-allowed disabled:opacity-40",!!r?"border-b-2 border-[var(--color-error)]":"border-b border-[var(--app-border-strong)] focus:border-b-2 focus:border-[var(--app-focus)]",ws[d],e),...u}),r&&va("span",{className:"text-xs text-[var(--color-error)]",children:r}),!r&&t&&va("span",{className:"text-xs text-[var(--app-text-secondary)]",children:t})]})});ct.displayName="Input";import*as ya from"react";import{jsx as Ra,jsxs as ys}from"react/jsx-runtime";var pt=ya.forwardRef(({className:e,label:a,helperText:t,errorText:r,required:l,rows:d=4,id:s,...u},f)=>{let i=s||ya.useId();return ys("div",{className:"flex min-w-0 flex-col gap-1",children:[a&&Ra(ee,{htmlFor:i,required:l,children:a}),Ra("textarea",{id:i,ref:f,rows:d,required:l,className:o("w-full min-w-[100%] resize-y bg-[var(--app-field)] px-4 py-3 font-[var(--font-sans)] text-sm text-[var(--app-text)] outline-none border-0 border-b transition-colors duration-[110ms]","placeholder:text-[var(--app-text-placeholder)]","disabled:cursor-not-allowed disabled:opacity-40",!!r?"border-b-2 border-[var(--color-error)]":"border-b border-[var(--app-border-strong)] focus:border-b-2 focus:border-[var(--app-focus)]",e),...u}),r&&Ra("span",{className:"text-xs text-[var(--color-error)]",children:r}),!r&&t&&Ra("span",{className:"text-xs text-[var(--app-text-secondary)]",children:t})]})});pt.displayName="Textarea";import*as Da from"react";import{forwardRef as As,createElement as Bs}from"react";var Ma=(...e)=>e.filter((a,t,r)=>!!a&&a.trim()!==""&&r.indexOf(a)===t).join(" ").trim();var al=e=>e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase();var tl=e=>e.replace(/^([A-Z])|[\s-_]+(\w)/g,(a,t,r)=>r?r.toUpperCase():t.toLowerCase());var mt=e=>{let a=tl(e);return a.charAt(0).toUpperCase()+a.slice(1)};import{forwardRef as Ts,createElement as ll}from"react";var ka={xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};var ol=e=>{for(let a in e)if(a.startsWith("aria-")||a==="role"||a==="title")return!0;return!1};import{createContext as Ms,useContext as ks,useMemo as nf,createElement as cf}from"react";var Ds=Ms({});var rl=()=>ks(Ds);var dl=Ts(({color:e,size:a,strokeWidth:t,absoluteStrokeWidth:r,className:l="",children:d,iconNode:s,...u},f)=>{let{size:i=24,strokeWidth:c=2,absoluteStrokeWidth:b=!1,color:q="currentColor",className:g=""}=rl()??{},v=r??b?Number(t??c)*24/Number(a??i):t??c;return ll("svg",{ref:f,...ka,width:a??i??ka.width,height:a??i??ka.height,stroke:e??q,strokeWidth:v,className:Ma("lucide",g,l),...!d&&!ol(u)&&{"aria-hidden":"true"},...u},[...s.map(([C,w])=>ll(C,w)),...Array.isArray(d)?d:[d]])});var n=(e,a)=>{let t=As(({className:r,...l},d)=>Bs(dl,{ref:d,iconNode:a,className:Ma(`lucide-${al(mt(e))}`,`lucide-${e}`,r),...l}));return t.displayName=mt(e),t};var Fs=[["path",{d:"M10.268 21a2 2 0 0 0 3.464 0",key:"vwvbt9"}],["path",{d:"M3.262 15.326A1 1 0 0 0 4 17h16a1 1 0 0 0 .74-1.673C19.41 13.956 18 12.499 18 8A6 6 0 0 0 6 8c0 4.499-1.411 5.956-2.738 7.326",key:"11g9vi"}]],ta=n("bell",Fs);var Ns=[["path",{d:"M8 2v4",key:"1cmpym"}],["path",{d:"M16 2v4",key:"4m81vk"}],["rect",{width:"18",height:"18",x:"3",y:"4",rx:"2",key:"1hopcy"}],["path",{d:"M3 10h18",key:"8toen8"}]],oa=n("calendar",Ns);var Hs=[["path",{d:"M20 6 9 17l-5-5",key:"1gmf2c"}]],F=n("check",Hs);var qs=[["path",{d:"m6 9 6 6 6-6",key:"qrunsl"}]],ae=n("chevron-down",qs);var Os=[["path",{d:"m15 18-6-6 6-6",key:"1wnfg3"}]],K=n("chevron-left",Os);var Us=[["path",{d:"m9 18 6-6-6-6",key:"mthhwq"}]],P=n("chevron-right",Us);var Es=[["path",{d:"m7 15 5 5 5-5",key:"1hf1tw"}],["path",{d:"m7 9 5-5 5 5",key:"sgt6xg"}]],ra=n("chevrons-up-down",Es);var Ws=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["line",{x1:"12",x2:"12",y1:"8",y2:"12",key:"1pkeuh"}],["line",{x1:"12",x2:"12.01",y1:"16",y2:"16",key:"4dfq90"}]],fe=n("circle-alert",Ws);var Gs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m9 12 2 2 4-4",key:"dzmm74"}]],Z=n("circle-check",Gs);var Vs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m15 9-6 6",key:"1uzhvr"}],["path",{d:"m9 9 6 6",key:"z0biqf"}]],ne=n("circle-x",Vs);var zs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}]],te=n("circle",zs);var Xs=[["circle",{cx:"12.1",cy:"12.1",r:"1",key:"18d7e5"}]],la=n("dot",Xs);var _s=[["circle",{cx:"12",cy:"12",r:"1",key:"41hilf"}],["circle",{cx:"19",cy:"12",r:"1",key:"1wjl8i"}],["circle",{cx:"5",cy:"12",r:"1",key:"1pcz8c"}]],ce=n("ellipsis",_s);var Ks=[["circle",{cx:"9",cy:"12",r:"1",key:"1vctgf"}],["circle",{cx:"9",cy:"5",r:"1",key:"hp0tcf"}],["circle",{cx:"9",cy:"19",r:"1",key:"fkjjf6"}],["circle",{cx:"15",cy:"12",r:"1",key:"1tmaij"}],["circle",{cx:"15",cy:"5",r:"1",key:"19l28e"}],["circle",{cx:"15",cy:"19",r:"1",key:"f4zoj3"}]],da=n("grip-vertical",Ks);var Zs=[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"M12 16v-4",key:"1dtifu"}],["path",{d:"M12 8h.01",key:"e9boi3"}]],Re=n("info",Zs);var Qs=[["path",{d:"M21 12a9 9 0 1 1-6.219-8.56",key:"13zald"}]],pe=n("loader-circle",Qs);var Js=[["path",{d:"m21 21-4.34-4.34",key:"14j7rj"}],["circle",{cx:"11",cy:"11",r:"8",key:"4ej97u"}]],ye=n("search",Js);var $s=[["path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3",key:"wmoenq"}],["path",{d:"M12 9v4",key:"juzpu7"}],["path",{d:"M12 17h.01",key:"p32p05"}]],Q=n("triangle-alert",$s);var Ys=[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]],U=n("x",Ys);import{jsx as Ue,jsxs as xt}from"react/jsx-runtime";var js={sm:"h-8 text-xs",default:"h-10 text-sm",lg:"h-12 text-base"},Lt=Da.forwardRef(({className:e,label:a,helperText:t,errorText:r,options:l,placeholder:d,required:s,selectSize:u="default",id:f,...i},c)=>{let b=f||Da.useId();return xt("div",{className:"flex flex-col gap-1",children:[a&&Ue(ee,{htmlFor:b,required:s,children:a}),xt("div",{className:"relative",children:[xt("select",{id:b,ref:c,required:s,className:o("w-full appearance-none bg-[var(--app-field)] px-4 pr-10 font-[var(--font-sans)] text-[var(--app-text)] outline-none border-0 border-b transition-colors duration-[110ms] cursor-pointer","disabled:cursor-not-allowed disabled:opacity-40",!!r?"border-b-2 border-[var(--color-error)]":"border-b border-[var(--app-border-strong)] focus:border-b-2 focus:border-[var(--app-focus)]",js[u],e),...i,children:[d&&Ue("option",{value:"",disabled:!0,children:d}),l.map(g=>Ue("option",{value:g.value,disabled:g.disabled,children:g.label},g.value))]}),Ue(ae,{className:"pointer-events-none absolute right-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[var(--app-text-secondary)]"})]}),r&&Ue("span",{className:"text-xs text-[var(--color-error)]",children:r}),!r&&t&&Ue("span",{className:"text-xs text-[var(--app-text-secondary)]",children:t})]})});Lt.displayName="Select";import*as Aa from"react";import*as Ba from"@radix-ui/react-checkbox";import{jsx as Ta,jsxs as eu}from"react/jsx-runtime";var gt=Aa.forwardRef(({className:e,label:a,id:t,...r},l)=>{let d=t||Aa.useId();return eu("div",{className:"flex items-center gap-2",children:[Ta(Ba.Root,{ref:l,id:d,className:o("peer relative h-4 w-4 shrink-0 border border-(--app-border-strong) bg-transparent","disabled:cursor-not-allowed disabled:opacity-40","data-[state=checked]:bg-(--color-brand) data-[state=checked]:border-(--color-brand) data-[state=checked]:text-(--app-text-on-color)","before:absolute before:-inset-[14px] before:content-['']",e),...r,children:Ta(Ba.Indicator,{className:"flex items-center justify-center",children:Ta(F,{className:"h-3.5 w-3.5",strokeWidth:3})})}),a&&Ta("label",{htmlFor:d,className:"text-sm text-(--app-text) cursor-pointer peer-disabled:cursor-not-allowed peer-disabled:opacity-40",children:a})]})});gt.displayName="Checkbox";import*as Fa from"react";import*as Na from"@radix-ui/react-switch";import{jsx as Ct,jsxs as au}from"react/jsx-runtime";var It=Fa.forwardRef(({className:e,label:a,switchSize:t="default",id:r,...l},d)=>{let s=r||Fa.useId(),u=t==="sm";return au("div",{className:"flex items-center gap-2",children:[Ct(Na.Root,{ref:d,id:s,className:o("peer relative inline-flex shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent transition-colors duration-[150ms]","disabled:cursor-not-allowed disabled:opacity-40","data-[state=checked]:bg-(--color-brand) data-[state=unchecked]:bg-(--app-border-strong)",u?"h-4 w-8":"h-6 w-12",u?"before:absolute before:-inset-[14px] before:content-['']":"before:absolute before:-inset-[10px] before:content-['']",e),...l,children:Ct(Na.Thumb,{className:o("pointer-events-none block rounded-full bg-white shadow transition-transform duration-[150ms]",u?"h-3 w-3 data-[state=checked]:translate-x-4 data-[state=unchecked]:translate-x-0":"h-5 w-5 data-[state=checked]:translate-x-6 data-[state=unchecked]:translate-x-0")})}),a&&Ct("label",{htmlFor:s,className:"text-sm text-(--app-text) cursor-pointer peer-disabled:cursor-not-allowed peer-disabled:opacity-40",children:a})]})});It.displayName="Switch";import*as sl from"react";import{jsx as Ha,jsxs as tu}from"react/jsx-runtime";var ht=sl.forwardRef(({className:e,searchSize:a="lg",value:t,onClear:r,onChange:l,...d},s)=>{let u=t!==void 0&&t!=="";return tu("div",{className:o("relative",e),children:[Ha(ye,{className:"absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[var(--app-text-secondary)]"}),Ha("input",{ref:s,type:"search",value:t,onChange:l,className:o("w-full bg-[var(--app-field)] pl-10 pr-10 font-[var(--font-sans)] text-[var(--app-text)] outline-none border-0 border-b border-[var(--app-border-strong)] transition-colors duration-[110ms]","placeholder:text-[var(--app-text-placeholder)]","focus:border-b-2 focus:border-[var(--app-focus)]","[&::-webkit-search-cancel-button]:hidden",a==="sm"?"h-8 text-xs":"h-10 text-sm"),...d}),u&&Ha("button",{type:"button",onClick:r,className:"absolute right-3 top-1/2 -translate-y-1/2 text-[var(--app-text-secondary)] hover:text-[var(--app-text)] transition-colors","aria-label":"\uAC80\uC0C9\uC5B4 \uC0AD\uC81C",children:Ha(U,{className:"h-4 w-4"})})]})});ht.displayName="Search";import*as yt from"react";import*as il from"react";import*as W from"@radix-ui/react-popover";import{jsx as ul}from"react/jsx-runtime";var Ee=W.Root,We=W.Trigger,fl=W.Anchor,nl=W.Close,Me=il.forwardRef(({className:e,align:a="center",sideOffset:t=4,...r},l)=>ul(W.Portal,{children:ul(W.Content,{ref:l,align:a,sideOffset:t,className:o("z-50 w-72 rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) p-4 text-(--app-text) shadow-(--shadow-dropdown) outline-none","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...r})}));Me.displayName="PopoverContent";import*as me from"react";import{Command as N}from"cmdk";import*as sa from"react";import*as M from"@radix-ui/react-dialog";import{jsx as oe,jsxs as bt}from"react/jsx-runtime";var qa=M.Root,cl=M.Trigger,pl=M.Close,ml=M.Portal,Pt=sa.forwardRef(({className:e,...a},t)=>oe(M.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));Pt.displayName="DialogOverlay";var ua=sa.forwardRef(({className:e,children:a,size:t="default",hideClose:r,...l},d)=>bt(ml,{children:[oe(Pt,{}),bt(M.Content,{ref:d,className:o("fixed left-1/2 top-1/2 z-50 w-full -translate-x-1/2 -translate-y-1/2 rounded-(--radius-lg)","bg-(--app-bg) text-(--app-text) shadow-(--shadow-modal)","duration-[240ms] ease-[cubic-bezier(0,0,0.38,0.9)]","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","max-h-[85vh] overflow-y-auto",{sm:"max-w-md",default:"max-w-lg",lg:"max-w-2xl",xl:"max-w-4xl",full:"max-w-[90vw]"}[t],e),...l,children:[a,!r&&bt(M.Close,{className:"absolute right-4 top-4 text-[var(--app-text-secondary)] hover:text-[var(--app-text)] transition-colors",children:[oe(U,{className:"h-5 w-5"}),oe("span",{className:"sr-only",children:"\uB2EB\uAE30"})]})]})]}));ua.displayName="DialogContent";var xl=({className:e,...a})=>oe("div",{className:o("px-6 py-4 border-b border-[var(--app-border)]",e),...a}),St=sa.forwardRef(({className:e,...a},t)=>oe(M.Title,{ref:t,className:o("text-lg font-semibold text-[var(--app-text)]",e),...a}));St.displayName="DialogTitle";var vt=sa.forwardRef(({className:e,...a},t)=>oe(M.Description,{ref:t,className:o("text-sm text-[var(--app-text-secondary)]",e),...a}));vt.displayName="DialogDescription";var Ll=({className:e,...a})=>oe("div",{className:o("px-6 py-4",e),...a}),gl=({className:e,...a})=>oe("div",{className:o("flex justify-end gap-2 px-6 py-4 border-t border-[var(--app-border)]",e),...a});import{jsx as G,jsxs as ou}from"react/jsx-runtime";var Ge=me.forwardRef(({className:e,...a},t)=>G(N,{ref:t,className:o("flex h-full w-full flex-col overflow-hidden rounded-(--radius-lg)","bg-(--app-bg) text-(--app-text)",e),...a}));Ge.displayName=N.displayName;var Cl=({children:e,...a})=>G(qa,{...a,children:G(ua,{className:"overflow-hidden p-0 shadow-(--shadow-modal)",hideClose:!0,children:G(Ge,{className:"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-(--app-muted) [&_[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",children:e})})}),ia=me.forwardRef(({className:e,...a},t)=>ou("div",{className:"flex items-center border-b border-(--app-border) px-3","cmdk-input-wrapper":"",children:[G(ye,{className:"mr-2 h-4 w-4 shrink-0 text-(--app-muted)"}),G(N.Input,{ref:t,className:o("flex h-10 w-full bg-transparent py-3 text-sm outline-none","text-(--app-text) placeholder:text-(--app-muted)","disabled:cursor-not-allowed disabled:opacity-50",e),...a})]}));ia.displayName=N.Input.displayName;var fa=me.forwardRef(({className:e,...a},t)=>G(N.List,{ref:t,className:o("max-h-[300px] overflow-y-auto overflow-x-hidden",e),...a}));fa.displayName=N.List.displayName;var na=me.forwardRef((e,a)=>G(N.Empty,{ref:a,className:"py-6 text-center text-sm text-(--app-muted)",...e}));na.displayName=N.Empty.displayName;var ca=me.forwardRef(({className:e,...a},t)=>G(N.Group,{ref:t,className:o("overflow-hidden p-1 text-(--app-text)","[&_[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-(--app-muted)",e),...a}));ca.displayName=N.Group.displayName;var wt=me.forwardRef(({className:e,...a},t)=>G(N.Separator,{ref:t,className:o("-mx-1 h-px bg-(--app-border)",e),...a}));wt.displayName=N.Separator.displayName;var ke=me.forwardRef(({className:e,...a},t)=>G(N.Item,{ref:t,className:o("relative flex cursor-default gap-2 select-none items-center px-2 py-1.5 text-sm outline-none","text-(--app-text)","data-[selected=true]:bg-(--app-surface) data-[selected=true]:text-(--app-text)","data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","[&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",e),...a}));ke.displayName=N.Item.displayName;var Rt=({className:e,...a})=>G("span",{className:o("ml-auto text-xs tracking-widest text-(--app-muted)",e),...a});Rt.displayName="CommandShortcut";import{jsx as E,jsxs as re}from"react/jsx-runtime";function Mt({options:e,value:a="",onChange:t,onSearchChange:r,placeholder:l="\uC120\uD0DD\uD558\uC138\uC694",searchPlaceholder:d="\uAC80\uC0C9...",emptyText:s="'{query}' \uC0AC\uC6A9",disabled:u=!1,loading:f=!1,label:i,errorText:c,helperText:b,className:q}){let[g,v]=yt.useState(!1),[C,w]=yt.useState(""),R=!!c,Ne=e.find(S=>S.value===a)?.label??(a||void 0),He=S=>{w(S),r?.(S)},st=S=>{t?.(S===a?"":S),w(""),r?.(""),v(!1)},je=()=>{C.trim()&&(t?.(C.trim()),w(""),r?.(""),v(!1))},ve=r?e:e.filter(S=>S.label.toLowerCase().includes(C.toLowerCase())),ut=ve.some(S=>S.label.toLowerCase()===C.toLowerCase());return re("div",{className:o("flex flex-col gap-1",q),children:[i&&E("label",{className:"text-xs font-medium text-(--app-muted)",children:i}),re(Ee,{open:g,onOpenChange:v,children:[E(We,{asChild:!0,children:re("button",{type:"button",role:"combobox","aria-expanded":g,disabled:u,className:o("flex h-10 w-full items-center justify-between px-4 text-sm","bg-(--app-field) text-(--app-text) outline-none border-0 border-b","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","disabled:cursor-not-allowed disabled:opacity-40",R?"border-b-2 border-(--color-error)":"border-b border-(--app-border-strong) hover:bg-(--app-hover)",!Ne&&"text-(--app-text-placeholder)"),children:[E("span",{className:"truncate",children:Ne??l}),E(ra,{className:"ml-2 h-4 w-4 shrink-0 text-(--app-muted)"})]})}),E(Me,{className:"w-[var(--radix-popover-trigger-width)] p-0",align:"start",children:re(Ge,{shouldFilter:!1,children:[E(ia,{placeholder:d,value:C,onValueChange:He}),re(fa,{children:[f&&re("div",{className:"flex items-center justify-center gap-2 py-6 text-sm text-(--app-muted)",children:[E(pe,{className:"h-4 w-4 animate-spin"}),"\uAC80\uC0C9 \uC911..."]}),!f&&ve.length===0&&!C.trim()&&E(na,{children:"\uAC80\uC0C9 \uACB0\uACFC \uC5C6\uC74C"}),!f&&ve.length===0&&C.trim()&&E(ke,{onSelect:je,children:s.replace("{query}",C.trim())}),!f&&ve.length>0&&re(ca,{children:[ve.map(S=>re(ke,{value:S.value,disabled:S.disabled,onSelect:st,children:[E(F,{className:o("mr-2 h-4 w-4",a===S.value?"opacity-100":"opacity-0")}),S.label]},S.value)),C.trim()&&!ut&&re(ke,{onSelect:je,children:[E(F,{className:"mr-2 h-4 w-4 opacity-0"}),'"',C.trim(),'" \uC9C1\uC811 \uC785\uB825']})]})]})]})})]}),c&&E("span",{className:"text-xs text-(--color-error)",children:c}),!c&&b&&E("span",{className:"text-xs text-(--app-muted)",children:b})]})}Mt.displayName="Combobox";import{jsx as lu}from"react/jsx-runtime";var ru={danger:"text-[var(--color-danger)] bg-[color-mix(in_srgb,var(--color-danger)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-danger)_32%,var(--app-border))]",warning:"text-[var(--color-warning)] bg-[color-mix(in_srgb,var(--color-warning)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-warning)_32%,var(--app-border))]",success:"text-[var(--color-success)] bg-[color-mix(in_srgb,var(--color-success)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-success)_32%,var(--app-border))]",info:"text-[var(--color-info)] bg-[color-mix(in_srgb,var(--color-info)_14%,var(--app-bg))] border-[color-mix(in_srgb,var(--color-info)_32%,var(--app-border))]",neutral:"text-[var(--app-muted)] bg-[var(--app-bg-subtle)] border-[var(--app-border)]"};function Il({variant:e,className:a="",children:t,...r}){return lu("span",{className:["inline-flex min-h-6 items-center justify-center whitespace-nowrap rounded-(--radius-sm) border border-solid px-2.5 py-0.5 align-middle text-xs font-semibold leading-[1.2] tracking-[-0.02em]",ru[e],a].filter(Boolean).join(" "),...r,children:t})}import{jsx as hl}from"react/jsx-runtime";function Oa({frameClassName:e,className:a,children:t,...r}){return hl("div",{className:["sk-table-frame w-full max-w-full min-h-0 overflow-x-auto overflow-y-hidden bg-transparent",e].filter(Boolean).join(" "),children:hl("table",{className:["sk-table w-max min-w-full border-collapse table-auto bg-[var(--sk-table-bg)] text-[var(--app-text)] text-sm leading-[1.2] tracking-[-0.025em] tabular-nums",a].filter(Boolean).join(" "),...r,children:t})})}import{jsx as kt,jsxs as du}from"react/jsx-runtime";function Ua({pageIndex:e,pageCount:a,onPageChange:t,className:r="","aria-label":l="\uD398\uC774\uC9C0 \uC774\uB3D9"}){if(a<=1)return null;let d=e>0,s=e<a-1,u="min-h-8 min-w-8 cursor-pointer rounded-md border border-solid border-[var(--sk-table-row-border)] bg-[var(--sk-table-bg)] px-2 py-1 text-sm leading-[1.2] text-[var(--sk-table-th-fg)] transition-colors hover:bg-[var(--sk-table-hover)] hover:text-[var(--app-text)] disabled:cursor-not-allowed disabled:opacity-45",f=i=>[u,i?"border-[var(--sk-table-sort-fg)] bg-[color-mix(in_srgb,var(--sk-table-sort-fg)_16%,var(--sk-table-bg))] font-semibold text-[var(--sk-table-sort-fg)]":""].filter(Boolean).join(" ");return du("nav",{className:["inline-flex flex-wrap items-center gap-1",r].filter(Boolean).join(" "),"aria-label":l,children:[kt("button",{type:"button",className:u,disabled:!d,onClick:()=>t(e-1),"aria-label":"\uC774\uC804 \uD398\uC774\uC9C0",children:"\u2039"}),Array.from({length:a},(i,c)=>kt("button",{type:"button",className:f(c===e),onClick:()=>t(c),"aria-current":c===e?"page":void 0,children:c+1},c)),kt("button",{type:"button",className:u,disabled:!s,onClick:()=>t(e+1),"aria-label":"\uB2E4\uC74C \uD398\uC774\uC9C0",children:"\u203A"})]})}import{flexRender as Dt,getCoreRowModel as su,getPaginationRowModel as uu,getSortedRowModel as iu,getExpandedRowModel as fu,useReactTable as nu}from"@tanstack/react-table";import{Icon as Pl}from"@iconify/react";import cu,{useEffect as pu,useState as pa,useCallback as mu}from"react";import{Fragment as gu,jsx as I,jsxs as ma}from"react/jsx-runtime";var Sl={"service-desk":{wrap:"service-desk-list__table-wrap",table:"service-desk-table",sortBtn:""},"data-table":{wrap:"",table:"",sortBtn:""},"project-task":{wrap:"sk-page__table-wrap",table:"project-task-table",sortBtn:""}};function xu(e){let a=e.getIsSorted();return a==="asc"?"ascending":a==="desc"?"descending":"none"}function Lu(e,a){let t=e.column.columnDef.meta,r=[];return a==="service-desk"&&t?.headerAlign==="left"&&r.push("service-desk-table__th--left"),e.column.getIsSorted()&&(r.push("text-[var(--sk-table-sort-fg)]"),a==="service-desk"&&r.push("service-desk-table__th--active")),r.filter(Boolean).join(" ")}function vl({column:e,children:a,variant:t,sortButtonClassName:r}){let d=["sk-table__sort-btn inline-flex w-full items-center justify-start gap-1 rounded border-0 bg-transparent p-1 text-left transition-colors hover:bg-[var(--sk-table-hover)] hover:text-[var(--sk-table-th-fg)] focus:outline-none focus-visible:outline-2 focus-visible:outline-offset-2",Sl[t].sortBtn,r].filter(Boolean).join(" ");if(!e.getCanSort())return I("span",{className:"font-inherit text-inherit",children:a});let s=e.getIsSorted();return ma("button",{type:"button",className:d,onClick:e.getToggleSortingHandler(),"aria-label":s?`${String(a)}, ${s==="asc"?"\uC624\uB984\uCC28\uC21C":"\uB0B4\uB9BC\uCC28\uC21C"}, \uC815\uB82C \uC804\uD658`:`${String(a)}, \uC815\uB82C`,children:[a,s?I("span",{className:"shrink-0 text-[var(--sk-table-sort-fg)] opacity-95","aria-hidden":!0,children:I(Pl,{icon:s==="asc"?"mdi:chevron-up":"mdi:chevron-down",width:8,height:8})}):null]})}function bl({checked:e,indeterminate:a,onChange:t,ariaLabel:r}){return I("input",{type:"checkbox",checked:e,ref:l=>{l&&(l.indeterminate=a??!1)},onChange:t,"aria-label":r,className:"h-4 w-4 cursor-pointer accent-[var(--color-brand)] border-[var(--app-border-strong)]",onClick:l=>l.stopPropagation()})}function wl({data:e,columns:a,getRowId:t,onRowClick:r,enableRowSelection:l=!0,selectedRowId:d,onSelectedRowChange:s,enableMultiSelect:u=!1,hideChildRowSelection:f=!1,selectedRowIds:i,onSelectedRowsChange:c,rowClassName:b,emptyMessage:q="\uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4.",variant:g="data-table",wrapClassName:v,tableClassName:C,initialSorting:w,enableSorting:R=!0,pageSize:B,getSubRows:Ne,renderSubComponent:He,autoResetExpanded:st=!1}){let je=Sl[g],[ve,ut]=pa(()=>w??[]),[S,as]=pa({}),[ts,os]=pa(null),[rs,ls]=pa({}),we=B!=null&&B>0,[ds,Qr]=pa(()=>({pageIndex:0,pageSize:we?B:Math.max(1,e.length||1)})),it=i??rs,ss=mu(p=>{let D=typeof p=="function"?p(it):p;if(i||ls(D),c){let aa=e.filter((Pa,Sa)=>{let O=t?t(Pa,Sa):String(Sa);return D[O]});c(D,aa)}},[it,i,c,e,t]);pu(()=>{we&&Qr(p=>({...p,pageSize:B,pageIndex:0}))},[we,B,e.length]);let us=u?[{id:"_select",size:40,enableSorting:!1,header:({table:p})=>I(bl,{checked:p.getIsAllPageRowsSelected(),indeterminate:p.getIsSomePageRowsSelected(),onChange:p.getToggleAllPageRowsSelectedHandler(),ariaLabel:"\uC804\uCCB4 \uC120\uD0DD"}),cell:({row:p})=>f&&p.depth>0?null:I(bl,{checked:p.getIsSelected(),onChange:p.getToggleSelectedHandler(),ariaLabel:`\uD589 ${p.id} \uC120\uD0DD`})},...a]:a,qe=nu({data:e,columns:us,state:{sorting:ve,expanded:S,...we?{pagination:ds}:{},...u?{rowSelection:it}:{}},onSortingChange:ut,onExpandedChange:as,onPaginationChange:we?Qr:void 0,...u?{onRowSelectionChange:ss,enableRowSelection:!0,enableSubRowSelection:!1}:{},getCoreRowModel:su(),getSortedRowModel:iu(),getExpandedRowModel:fu(),getSubRows:Ne,autoResetExpanded:st,...we?{getPaginationRowModel:uu()}:{},getRowId:t,enableSorting:R}),is=[je.wrap,v].filter(Boolean).join(" "),fs=[je.table,C].filter(Boolean).join(" "),ns=d??ts;if(e.length===0)return I("div",{className:"px-8 py-8 text-center text-base leading-[1.35] text-[var(--app-muted)]",role:"status",children:q});let cs=we&&qe.getPageCount()>1;return ma(gu,{children:[ma(Oa,{frameClassName:is,className:fs,children:[I("thead",{children:qe.getHeaderGroups().map(p=>I("tr",{children:p.headers.map(D=>{let ea=D.column.columnDef.meta?.align,aa={...ea?{textAlign:ea}:{},whiteSpace:"nowrap"};return I("th",{colSpan:D.colSpan,scope:"col",className:["h-[var(--density-row-height,28px)] border-b border-solid border-[var(--sk-table-row-border)] bg-[var(--sk-table-header-bg)] px-[var(--density-padding-x,0.5rem)] text-left align-middle text-sm font-semibold whitespace-nowrap text-[var(--sk-table-th-fg)]",Lu(D,g)].filter(Boolean).join(" "),"aria-sort":D.column.getCanSort()?xu(D.column):void 0,"data-align":ea,style:aa,children:D.isPlaceholder?null:Dt(D.column.columnDef.header,D.getContext())},D.id)})},p.id))}),I("tbody",{children:qe.getRowModel().rows.map(p=>{let D=l&&ns===p.id,aa=[b?.(p.original)??""].filter(Boolean).join(" "),Pa=!!(r||l),Sa=()=>{if(l){let O=D?null:p.id;d==null&&os(O),s?.(O,O?p.original:null)}r?.(p.original)};return ma(cu.Fragment,{children:[I("tr",{className:aa,onClick:Pa?Sa:void 0,style:Pa?{cursor:"pointer"}:void 0,children:p.getVisibleCells().map((O,ps)=>{let ms=O.column.columnDef.meta?.tdClassName??"",ft=O.column.columnDef.meta?.align,xs={...ft?{textAlign:ft}:{},whiteSpace:"nowrap"},Ls=ps===(u?1:0)&&(Ne||He),gs=Ne?p.getCanExpand():!!He;return I("td",{className:["h-[var(--density-row-height,28px)] whitespace-nowrap border-b border-solid border-[var(--sk-table-row-border)] px-[var(--density-padding-x,0.5rem)] align-middle text-[var(--app-text)]",D?"bg-[color-mix(in_srgb,var(--app-muted)_24%,var(--sk-table-bg))]":"bg-[var(--sk-table-bg)]",ms].filter(Boolean).join(" "),"data-align":ft,style:xs,children:Ls?ma("div",{style:{paddingLeft:`${p.depth*1.5}rem`},className:"flex items-center gap-2 w-full",children:[gs?I("button",{type:"button",className:"p-1 min-touch-target shrink-0 flex items-center justify-center rounded-md hover:bg-[var(--app-hover)] text-[var(--app-muted)] transition-colors focus:outline-none focus-visible:ring-2 focus-visible:ring-[var(--shadow-focus)]",onClick:Jr=>{Jr.preventDefault(),Jr.stopPropagation(),p.toggleExpanded()},"aria-label":"\uD1A0\uAE00 \uC5F4\uAE30/\uB2EB\uAE30",children:I(Pl,{icon:p.getIsExpanded()?"mdi:chevron-down":"mdi:chevron-right",width:20,className:"transition-transform duration-200"})}):I("span",{className:"w-[28px] shrink-0 inline-block"}),I("div",{className:"min-w-0 flex-1 truncate",children:Dt(O.column.columnDef.cell,O.getContext())})]}):Dt(O.column.columnDef.cell,O.getContext())},O.id)})}),p.getIsExpanded()&&He&&I("tr",{className:"bg-[var(--app-surface-02)]",children:I("td",{colSpan:p.getVisibleCells().length,className:"p-0 border-b border-[var(--sk-table-row-border)]",children:I("div",{className:"p-4 w-full h-full flex flex-col bg-[var(--app-bg)] shadow-[inset_0_4px_6px_-6px_rgba(0,0,0,0.1)]",children:He({row:p})})})})]},p.id)})})]}),cs?I("div",{className:"flex w-full items-center justify-end box-border px-2 pt-3",children:I(Ua,{pageIndex:qe.getState().pagination.pageIndex,pageCount:qe.getPageCount(),onPageChange:p=>qe.setPageIndex(p)})}):null]})}import*as z from"react";import*as xe from"@radix-ui/react-tabs";import{jsx as Ea}from"react/jsx-runtime";var Rl=xe.Root;function Cu(){let e=z.useRef(null),a=z.useRef({isDown:!1,startX:0,scrollLeft:0}),t=z.useCallback(d=>{let s=e.current;s&&(d.target.closest('button, a, [role="tab"]')||(a.current={isDown:!0,startX:d.clientX-s.offsetLeft,scrollLeft:s.scrollLeft},s.setPointerCapture(d.pointerId),s.style.cursor="grabbing"))},[]),r=z.useCallback(d=>{if(!a.current.isDown||!e.current)return;let s=d.clientX-e.current.offsetLeft;e.current.scrollLeft=a.current.scrollLeft-(s-a.current.startX)},[]),l=z.useCallback(d=>{a.current.isDown=!1,e.current&&(e.current.releasePointerCapture(d.pointerId),e.current.style.cursor="")},[]);return{ref:e,onPointerDown:t,onPointerMove:r,onPointerUp:l}}var Tt=z.forwardRef(({className:e,variant:a="line",wrapperClassName:t,...r},l)=>{let d=Cu();return Ea("div",{ref:d.ref,onPointerDown:d.onPointerDown,onPointerMove:d.onPointerMove,onPointerUp:d.onPointerUp,onPointerLeave:d.onPointerUp,className:o("sk-tabs-scroll w-full overflow-x-auto cursor-grab select-none",a==="line"&&"border-b border-(--app-border)",t),children:Ea(xe.List,{ref:l,className:o("inline-flex items-center",a==="line"&&"gap-0 -mb-px",a==="contained"&&"gap-0 bg-(--app-surface)",e),...r})})});Tt.displayName="TabsList";var At=z.forwardRef(({className:e,variant:a="line",...t},r)=>Ea(xe.Trigger,{ref:r,className:o("inline-flex items-center justify-center whitespace-nowrap px-4 py-2 text-sm font-medium transition-colors duration-[110ms]","disabled:pointer-events-none disabled:opacity-40","focus-visible:outline-2 focus-visible:outline-(--app-focus) focus-visible:outline-offset-[-2px]",a==="line"&&["border-b-2 border-transparent text-(--app-text-secondary)","hover:text-(--app-text) hover:bg-(--app-hover)","data-[state=active]:border-(--color-brand) data-[state=active]:text-(--app-text) data-[state=active]:font-semibold"],a==="contained"&&["border border-(--app-border) text-(--app-text-secondary)","hover:bg-(--app-hover)","data-[state=active]:bg-(--app-bg) data-[state=active]:text-(--app-text) data-[state=active]:font-semibold data-[state=active]:border-b-(--app-bg)"],e),...t}));At.displayName="TabsTrigger";var Bt=z.forwardRef(({className:e,...a},t)=>Ea(xe.Content,{ref:t,className:o("mt-4 focus-visible:outline-none",e),...a}));Bt.displayName="TabsContent";import*as Wa from"react";import{jsx as Le,jsxs as yl}from"react/jsx-runtime";function Ml({node:e,level:a,expanded:t,onToggle:r,onSelect:l,selectedId:d}){let s=e.children&&e.children.length>0,u=t.has(e.id),f=d===e.id;return yl("li",{role:"treeitem","aria-expanded":s?u:void 0,children:[yl("button",{type:"button",disabled:e.disabled,className:o("flex w-full items-center gap-1 py-1.5 text-sm outline-none transition-colors duration-[70ms]","hover:bg-[var(--app-hover)]","focus-visible:outline-2 focus-visible:outline-[var(--app-focus)]","disabled:pointer-events-none disabled:opacity-40",f&&"bg-[var(--app-selected)] font-medium",!f&&"text-[var(--app-text)]"),style:{paddingLeft:`${a*24+8}px`},onClick:()=>{s&&r(e.id),l?.(e)},children:[s?Le(P,{className:o("h-4 w-4 shrink-0 text-[var(--app-text-secondary)] transition-transform duration-[150ms]",u&&"rotate-90")}):Le("span",{className:"w-4 shrink-0"}),e.icon&&Le("span",{className:"shrink-0",children:e.icon}),Le("span",{className:"truncate",children:e.label})]}),s&&u&&Le("ul",{role:"group",children:e.children.map(i=>Le(Ml,{node:i,level:a+1,expanded:t,onToggle:r,onSelect:l,selectedId:d},i.id))})]})}function kl({data:e,defaultExpanded:a=[],onSelect:t,selectedId:r,className:l}){let[d,s]=Wa.useState(new Set(a)),u=Wa.useCallback(f=>{s(i=>{let c=new Set(i);return c.has(f)?c.delete(f):c.add(f),c})},[]);return Le("ul",{role:"tree",className:o("text-sm",l),children:e.map(f=>Le(Ml,{node:f,level:0,expanded:d,onToggle:u,onSelect:t,selectedId:r},f.id))})}import*as Ga from"react";import{jsx as qt}from"react/jsx-runtime";var Ft=Ga.forwardRef(({className:e,variant:a="default",...t},r)=>qt("ul",{ref:r,className:o("text-sm text-[var(--app-text)]",a==="contained"&&"border border-[var(--app-border)]",e),...t}));Ft.displayName="List";var Nt=Ga.forwardRef(({className:e,active:a,disabled:t,interactive:r=!0,...l},d)=>qt("li",{ref:d,className:o("flex items-center gap-3 px-4 py-2 border-b border-[var(--app-border)] last:border-b-0",r&&"cursor-pointer hover:bg-[var(--app-hover)] transition-colors duration-[70ms]",a&&"bg-[var(--app-selected)]",t&&"pointer-events-none opacity-40",e),...l}));Nt.displayName="ListItem";var Ht=Ga.forwardRef(({className:e,...a},t)=>qt("div",{ref:t,className:o("px-4 py-2 text-xs font-semibold text-[var(--app-text-secondary)] bg-[var(--app-surface)] border-b border-[var(--app-border)]",e),...a}));Ht.displayName="ListHeader";import*as Va from"react";import*as J from"@radix-ui/react-accordion";import{jsx as xa,jsxs as Iu}from"react/jsx-runtime";var Dl=J.Root,Ot=Va.forwardRef(({className:e,...a},t)=>xa(J.Item,{ref:t,className:o("border-b border-[var(--app-border)]",e),...a}));Ot.displayName="AccordionItem";var Ut=Va.forwardRef(({className:e,children:a,...t},r)=>xa(J.Header,{className:"flex",children:Iu(J.Trigger,{ref:r,className:o("flex flex-1 items-center justify-between py-3 px-4 text-sm font-medium text-[var(--app-text)] transition-all duration-[150ms] min-touch-target","hover:bg-[var(--app-hover)]","[&[data-state=open]>svg]:rotate-180",e),...t,children:[a,xa(ae,{className:"h-4 w-4 shrink-0 text-[var(--app-text-secondary)] transition-transform duration-[150ms]"})]})}));Ut.displayName="AccordionTrigger";var Et=Va.forwardRef(({className:e,children:a,...t},r)=>xa(J.Content,{ref:r,className:"overflow-hidden text-sm data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down",...t,children:xa("div",{className:o("px-4 pb-3 text-[var(--app-text-secondary)]",e),children:a})}));Et.displayName="AccordionContent";import{useEffect as Pu,useCallback as Su}from"react";import{createPortal as vu}from"react-dom";import{jsx as Tl,jsxs as hu}from"react/jsx-runtime";function za({title:e,actions:a}){return hu("div",{className:"standard-modal-header",children:[Tl("h2",{className:"standard-modal-title",children:e}),a!=null&&Tl("div",{className:"standard-modal-header-actions-wrap",children:a})]})}import{jsx as Al,jsxs as bu}from"react/jsx-runtime";function Xa({onCancel:e,onSave:a,cancelLabel:t="\uCDE8\uC18C",saveLabel:r="\uC800\uC7A5",saveDisabled:l=!1}){return bu("div",{className:"standard-modal-header-actions",children:[Al("button",{type:"button",className:"btn-standard-modal btn-ghost",onClick:e,children:t}),a!=null&&Al("button",{type:"button",className:"btn-standard-modal btn-primary",onClick:()=>{let d=a();d!=null&&typeof d?.then=="function"&&d.catch(()=>{})},disabled:l,children:r})]})}import{jsx as _a,jsxs as wu}from"react/jsx-runtime";function Bl({open:e,onClose:a,title:t,children:r,onSave:l,cancelLabel:d,saveLabel:s,hasUnsavedChanges:u=!1,saveDisabled:f=!1,headerActions:i,closeOnOverlayClick:c=!1,ariaLabel:b,modalClassName:q}){let g=Su(()=>{u&&!window.confirm("\uBCC0\uACBD\uC0AC\uD56D\uC774 \uC788\uC2B5\uB2C8\uB2E4. \uB2EB\uC73C\uC2DC\uACA0\uC2B5\uB2C8\uAE4C?")||a()},[a,u]);if(Pu(()=>{if(!e)return;let w=R=>{R.key==="Escape"&&g()};return window.addEventListener("keydown",w),()=>window.removeEventListener("keydown",w)},[e,g]),!e)return null;let v=i??_a(Xa,{onCancel:g,onSave:l,cancelLabel:d,saveLabel:s,saveDisabled:f}),C=_a("div",{className:"standard-modal-overlay",role:"dialog","aria-modal":"true","aria-label":b??t,onClick:c?g:void 0,children:wu("div",{className:["standard-modal",q].filter(Boolean).join(" "),onClick:w=>w.stopPropagation(),children:[_a(za,{title:t,actions:v}),_a("div",{className:"standard-modal-body",children:r})]})});return vu(C,document.body)}import{jsx as Fl,jsxs as Ru}from"react/jsx-runtime";function Nl({title:e,children:a,fullWidth:t}){return Ru("section",{className:`standard-modal-section ${t?"standard-modal-section--full":""}`,children:[Fl("h3",{className:"standard-modal-section-title",children:e}),Fl("div",{className:"standard-modal-section-body",children:a})]})}import{jsx as yu}from"react/jsx-runtime";function Hl({children:e,fullWidth:a}){return yu("div",{className:`standard-form-grid ${a?"standard-form-grid--full":""}`,children:e})}import{jsx as ql,jsxs as Ol}from"react/jsx-runtime";function Ul({label:e,required:a,helper:t,fullWidth:r,children:l}){return Ol("div",{className:`standard-form-field ${r?"standard-form-field--full":""}`,children:[Ol("label",{children:[e,a&&ql("span",{className:"required","aria-hidden":!0,children:" *"})]}),l,t!=null&&ql("p",{className:"helper",children:t})]})}import*as ge from"react";import*as L from"@radix-ui/react-dropdown-menu";import{jsx as $,jsxs as zl}from"react/jsx-runtime";var El=L.Root,Wl=L.Trigger,Gl=L.Group;var Vl=L.Sub;var Wt=ge.forwardRef(({className:e,children:a,...t},r)=>zl(L.SubTrigger,{ref:r,className:o("flex cursor-pointer items-center gap-2 px-4 py-2 text-sm outline-none select-none","text-[var(--app-text)] hover:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]",e),...t,children:[a,$(P,{className:"ml-auto h-4 w-4"})]}));Wt.displayName="DropdownMenuSubTrigger";var Gt=ge.forwardRef(({className:e,...a},t)=>$(L.SubContent,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) text-(--app-text) shadow-(--shadow-dropdown)","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));Gt.displayName="DropdownMenuSubContent";var Vt=ge.forwardRef(({className:e,sideOffset:a=4,...t},r)=>$(L.Portal,{children:$(L.Content,{ref:r,sideOffset:a,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) py-1 text-(--app-text) shadow-(--shadow-dropdown)","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...t})}));Vt.displayName="DropdownMenuContent";var zt=ge.forwardRef(({className:e,destructive:a,...t},r)=>$(L.Item,{ref:r,className:o("relative flex cursor-pointer items-center gap-2 px-4 py-2 text-sm outline-none select-none transition-colors","focus:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-40",a&&"text-[var(--color-error)] focus:text-[var(--color-error)]",!a&&"text-[var(--app-text)]",e),...t}));zt.displayName="DropdownMenuItem";var Xt=ge.forwardRef(({className:e,children:a,checked:t,...r},l)=>zl(L.CheckboxItem,{ref:l,className:o("relative flex cursor-pointer items-center py-2 pl-8 pr-4 text-sm outline-none select-none transition-colors","text-[var(--app-text)] focus:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-40",e),checked:t,...r,children:[$("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:$(L.ItemIndicator,{children:$(F,{className:"h-4 w-4"})})}),a]}));Xt.displayName="DropdownMenuCheckboxItem";var _t=ge.forwardRef(({className:e,...a},t)=>$(L.Separator,{ref:t,className:o("my-1 h-px bg-[var(--app-border)]",e),...a}));_t.displayName="DropdownMenuSeparator";var Kt=ge.forwardRef(({className:e,...a},t)=>$(L.Label,{ref:t,className:o("px-4 py-2 text-xs font-semibold text-[var(--app-text-secondary)]",e),...a}));Kt.displayName="DropdownMenuLabel";import"react";import*as V from"@radix-ui/react-tooltip";import{jsx as Zt,jsxs as Xl}from"react/jsx-runtime";var _l=V.Provider;function Kl({content:e,children:a,side:t="top",delayDuration:r=200,className:l}){return Xl(V.Root,{delayDuration:r,children:[Zt(V.Trigger,{asChild:!0,children:a}),Zt(V.Portal,{children:Xl(V.Content,{side:t,sideOffset:4,className:o("z-50 max-w-[240px] rounded-(--radius-md) bg-(--app-text) px-4 py-2 text-xs text-(--app-text-on-color)","animate-in fade-in-0 zoom-in-95 duration-[110ms]","data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95",l),children:[e,Zt(V.Arrow,{className:"fill-[var(--app-text)]",width:12,height:6})]})})]})}import{cva as Mu}from"class-variance-authority";import{jsx as Ve,jsxs as Ql}from"react/jsx-runtime";var Qt=Mu("relative flex items-start gap-3 p-4 border-l-[3px] text-sm",{variants:{variant:{success:"border-l-[var(--color-success)] bg-[color-mix(in_srgb,var(--color-success)_10%,var(--app-bg))]",warning:"border-l-[var(--color-warning)] bg-[color-mix(in_srgb,var(--color-warning)_10%,var(--app-bg))]",error:"border-l-[var(--color-error)] bg-[color-mix(in_srgb,var(--color-error)_10%,var(--app-bg))]",info:"border-l-[var(--color-info)] bg-[color-mix(in_srgb,var(--color-info)_10%,var(--app-bg))]"}},defaultVariants:{variant:"info"}}),ku={success:Z,warning:Q,error:ne,info:Re},Zl={success:"text-[var(--color-success)]",warning:"text-[var(--color-warning)]",error:"text-[var(--color-error)]",info:"text-[var(--color-info)]"};function Jl({variant:e="info",title:a,message:t,onClose:r,closable:l=!0,action:d,className:s}){let u=ku[e];return Ql("div",{className:o(Qt({variant:e}),s),role:"alert",children:[Ve(u,{className:o("mt-0.5 h-5 w-5 shrink-0",Zl[e])}),Ql("div",{className:"flex-1 min-w-0",children:[Ve("p",{className:"font-medium text-[var(--app-text)]",children:a}),t&&Ve("p",{className:"mt-1 text-xs text-[var(--app-text-secondary)]",children:t}),d&&Ve("button",{type:"button",onClick:d.onClick,className:o("mt-2 text-xs font-medium underline-offset-2 hover:underline",Zl[e]),children:d.label})]}),l&&r&&Ve("button",{type:"button",onClick:r,className:"shrink-0 text-[var(--app-text-secondary)] hover:text-[var(--app-text)] transition-colors","aria-label":"\uB2EB\uAE30",children:Ve(U,{className:"h-4 w-4"})})]})}import*as $l from"react";import{jsx as Du}from"react/jsx-runtime";var Jt=$l.forwardRef(({className:e,variant:a="rectangular",...t},r)=>Du("div",{ref:r,className:o("animate-pulse bg-[var(--app-surface)]",a==="text"&&"h-4 w-full",a==="circular"&&"rounded-full",a==="rectangular"&&"w-full",e),...t}));Jt.displayName="Skeleton";import{jsx as ze,jsxs as Bu}from"react/jsx-runtime";var Tu={sm:16,default:32,lg:64},Au={sm:2,default:3,lg:4};function Yl({size:e="default",label:a,className:t}){let r=Tu[e],l=Au[e],d=(r-l)/2;return Bu("div",{className:o("inline-flex flex-col items-center gap-2",t),role:"status",children:[ze("svg",{width:r,height:r,viewBox:`0 0 ${r} ${r}`,className:"animate-spin",style:{animationDuration:"700ms"},children:ze("circle",{cx:r/2,cy:r/2,r:d,fill:"none",stroke:"var(--color-brand)",strokeWidth:l,strokeLinecap:"round",strokeDasharray:`${d*Math.PI*1.5} ${d*Math.PI*2}`})}),a&&ze("span",{className:"text-xs text-[var(--app-text-secondary)]",children:a}),ze("span",{className:"sr-only",children:a||"\uB85C\uB529 \uC911"})]})}function jl({className:e}){return ze("svg",{width:16,height:16,viewBox:"0 0 16 16",className:o("animate-spin",e),style:{animationDuration:"700ms"},role:"status",children:ze("circle",{cx:8,cy:8,r:6,fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeDasharray:`${6*Math.PI*1.5} ${6*Math.PI*2}`})})}import*as fd from"react";function Ka(e){return(a={})=>{let t=a.width?String(a.width):e.defaultWidth;return e.formats[t]||e.formats[e.defaultWidth]}}function Xe(e){return(a,t)=>{let r=t?.context?String(t.context):"standalone",l;if(r==="formatting"&&e.formattingValues){let s=e.defaultFormattingWidth||e.defaultWidth,u=t?.width?String(t.width):s;l=e.formattingValues[u]||e.formattingValues[s]}else{let s=e.defaultWidth,u=t?.width?String(t.width):e.defaultWidth;l=e.values[u]||e.values[s]}let d=e.argumentCallback?e.argumentCallback(a):a;return l[d]}}function _e(e){return(a,t={})=>{let r=t.width,l=r&&e.matchPatterns[r]||e.matchPatterns[e.defaultMatchWidth],d=a.match(l);if(!d)return null;let s=d[0],u=r&&e.parsePatterns[r]||e.parsePatterns[e.defaultParseWidth],f=Array.isArray(u)?Nu(u,b=>b.test(s)):Fu(u,b=>b.test(s)),i;i=e.valueCallback?e.valueCallback(f):f,i=t.valueCallback?t.valueCallback(i):i;let c=a.slice(s.length);return{value:i,rest:c}}}function Fu(e,a){for(let t in e)if(Object.prototype.hasOwnProperty.call(e,t)&&a(e[t]))return t}function Nu(e,a){for(let t=0;t<e.length;t++)if(a(e[t]))return t}function ed(e){return(a,t={})=>{let r=a.match(e.matchPattern);if(!r)return null;let l=r[0],d=a.match(e.parsePattern);if(!d)return null;let s=e.valueCallback?e.valueCallback(d[0]):d[0];s=t.valueCallback?t.valueCallback(s):s;let u=a.slice(l.length);return{value:s,rest:u}}}var Hu={lessThanXSeconds:{one:"1\uCD08 \uBBF8\uB9CC",other:"{{count}}\uCD08 \uBBF8\uB9CC"},xSeconds:{one:"1\uCD08",other:"{{count}}\uCD08"},halfAMinute:"30\uCD08",lessThanXMinutes:{one:"1\uBD84 \uBBF8\uB9CC",other:"{{count}}\uBD84 \uBBF8\uB9CC"},xMinutes:{one:"1\uBD84",other:"{{count}}\uBD84"},aboutXHours:{one:"\uC57D 1\uC2DC\uAC04",other:"\uC57D {{count}}\uC2DC\uAC04"},xHours:{one:"1\uC2DC\uAC04",other:"{{count}}\uC2DC\uAC04"},xDays:{one:"1\uC77C",other:"{{count}}\uC77C"},aboutXWeeks:{one:"\uC57D 1\uC8FC",other:"\uC57D {{count}}\uC8FC"},xWeeks:{one:"1\uC8FC",other:"{{count}}\uC8FC"},aboutXMonths:{one:"\uC57D 1\uAC1C\uC6D4",other:"\uC57D {{count}}\uAC1C\uC6D4"},xMonths:{one:"1\uAC1C\uC6D4",other:"{{count}}\uAC1C\uC6D4"},aboutXYears:{one:"\uC57D 1\uB144",other:"\uC57D {{count}}\uB144"},xYears:{one:"1\uB144",other:"{{count}}\uB144"},overXYears:{one:"1\uB144 \uC774\uC0C1",other:"{{count}}\uB144 \uC774\uC0C1"},almostXYears:{one:"\uAC70\uC758 1\uB144",other:"\uAC70\uC758 {{count}}\uB144"}},ad=(e,a,t)=>{let r,l=Hu[e];return typeof l=="string"?r=l:a===1?r=l.one:r=l.other.replace("{{count}}",a.toString()),t?.addSuffix?t.comparison&&t.comparison>0?r+" \uD6C4":r+" \uC804":r};var qu={full:"y\uB144 M\uC6D4 d\uC77C EEEE",long:"y\uB144 M\uC6D4 d\uC77C",medium:"y.MM.dd",short:"y.MM.dd"},Ou={full:"a H\uC2DC mm\uBD84 ss\uCD08 zzzz",long:"a H:mm:ss z",medium:"HH:mm:ss",short:"HH:mm"},Uu={full:"{{date}} {{time}}",long:"{{date}} {{time}}",medium:"{{date}} {{time}}",short:"{{date}} {{time}}"},td={date:Ka({formats:qu,defaultWidth:"full"}),time:Ka({formats:Ou,defaultWidth:"full"}),dateTime:Ka({formats:Uu,defaultWidth:"full"})};var Eu={lastWeek:"'\uC9C0\uB09C' eeee p",yesterday:"'\uC5B4\uC81C' p",today:"'\uC624\uB298' p",tomorrow:"'\uB0B4\uC77C' p",nextWeek:"'\uB2E4\uC74C' eeee p",other:"P"},od=(e,a,t,r)=>Eu[e];var Wu={narrow:["BC","AD"],abbreviated:["BC","AD"],wide:["\uAE30\uC6D0\uC804","\uC11C\uAE30"]},Gu={narrow:["1","2","3","4"],abbreviated:["Q1","Q2","Q3","Q4"],wide:["1\uBD84\uAE30","2\uBD84\uAE30","3\uBD84\uAE30","4\uBD84\uAE30"]},Vu={narrow:["1","2","3","4","5","6","7","8","9","10","11","12"],abbreviated:["1\uC6D4","2\uC6D4","3\uC6D4","4\uC6D4","5\uC6D4","6\uC6D4","7\uC6D4","8\uC6D4","9\uC6D4","10\uC6D4","11\uC6D4","12\uC6D4"],wide:["1\uC6D4","2\uC6D4","3\uC6D4","4\uC6D4","5\uC6D4","6\uC6D4","7\uC6D4","8\uC6D4","9\uC6D4","10\uC6D4","11\uC6D4","12\uC6D4"]},zu={narrow:["\uC77C","\uC6D4","\uD654","\uC218","\uBAA9","\uAE08","\uD1A0"],short:["\uC77C","\uC6D4","\uD654","\uC218","\uBAA9","\uAE08","\uD1A0"],abbreviated:["\uC77C","\uC6D4","\uD654","\uC218","\uBAA9","\uAE08","\uD1A0"],wide:["\uC77C\uC694\uC77C","\uC6D4\uC694\uC77C","\uD654\uC694\uC77C","\uC218\uC694\uC77C","\uBAA9\uC694\uC77C","\uAE08\uC694\uC77C","\uD1A0\uC694\uC77C"]},Xu={narrow:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},abbreviated:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},wide:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"}},_u={narrow:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},abbreviated:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"},wide:{am:"\uC624\uC804",pm:"\uC624\uD6C4",midnight:"\uC790\uC815",noon:"\uC815\uC624",morning:"\uC544\uCE68",afternoon:"\uC624\uD6C4",evening:"\uC800\uB141",night:"\uBC24"}},Ku=(e,a)=>{let t=Number(e);switch(String(a?.unit)){case"minute":case"second":return String(t);case"date":return t+"\uC77C";default:return t+"\uBC88\uC9F8"}},rd={ordinalNumber:Ku,era:Xe({values:Wu,defaultWidth:"wide"}),quarter:Xe({values:Gu,defaultWidth:"wide",argumentCallback:e=>e-1}),month:Xe({values:Vu,defaultWidth:"wide"}),day:Xe({values:zu,defaultWidth:"wide"}),dayPeriod:Xe({values:Xu,defaultWidth:"wide",formattingValues:_u,defaultFormattingWidth:"wide"})};var Zu=/^(\d+)(일|번째)?/i,Qu=/\d+/i,Ju={narrow:/^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i,abbreviated:/^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i,wide:/^(기원전|서기)/i},$u={any:[/^(bc|기원전)/i,/^(ad|서기)/i]},Yu={narrow:/^[1234]/i,abbreviated:/^q[1234]/i,wide:/^[1234]사?분기/i},ju={any:[/1/i,/2/i,/3/i,/4/i]},ei={narrow:/^(1[012]|[123456789])/,abbreviated:/^(1[012]|[123456789])월/i,wide:/^(1[012]|[123456789])월/i},ai={any:[/^1월?$/,/^2/,/^3/,/^4/,/^5/,/^6/,/^7/,/^8/,/^9/,/^10/,/^11/,/^12/]},ti={narrow:/^[일월화수목금토]/,short:/^[일월화수목금토]/,abbreviated:/^[일월화수목금토]/,wide:/^[일월화수목금토]요일/},oi={any:[/^일/,/^월/,/^화/,/^수/,/^목/,/^금/,/^토/]},ri={any:/^(am|pm|오전|오후|자정|정오|아침|저녁|밤)/i},li={any:{am:/^(am|오전)/i,pm:/^(pm|오후)/i,midnight:/^자정/i,noon:/^정오/i,morning:/^아침/i,afternoon:/^오후/i,evening:/^저녁/i,night:/^밤/i}},ld={ordinalNumber:ed({matchPattern:Zu,parsePattern:Qu,valueCallback:e=>parseInt(e,10)}),era:_e({matchPatterns:Ju,defaultMatchWidth:"wide",parsePatterns:$u,defaultParseWidth:"any"}),quarter:_e({matchPatterns:Yu,defaultMatchWidth:"wide",parsePatterns:ju,defaultParseWidth:"any",valueCallback:e=>e+1}),month:_e({matchPatterns:ei,defaultMatchWidth:"wide",parsePatterns:ai,defaultParseWidth:"any"}),day:_e({matchPatterns:ti,defaultMatchWidth:"wide",parsePatterns:oi,defaultParseWidth:"any"}),dayPeriod:_e({matchPatterns:ri,defaultMatchWidth:"any",parsePatterns:li,defaultParseWidth:"any"})};var dd={code:"ko",formatDistance:ad,formatLong:td,formatRelative:od,localize:rd,match:ld,options:{weekStartsOn:0,firstWeekContainsDate:1}};import"react";import{DayPicker as di,useDayPicker as si}from"react-day-picker";import{jsx as Ce,jsxs as ii}from"react/jsx-runtime";var sd=o("h-7 w-7 flex items-center justify-center","bg-transparent border border-(--app-border) text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:opacity-40 disabled:pointer-events-none");function ui({calendarMonth:e,displayIndex:a,...t}){let{goToMonth:r,previousMonth:l,nextMonth:d}=si();return ii("div",{...t,className:o(t.className,"flex justify-center items-center gap-1 h-9"),children:[a===0&&Ce("button",{type:"button",className:sd,disabled:!l,"aria-label":"\uC774\uC804 \uB2EC",onClick:()=>l&&r(l),children:Ce(K,{className:"h-4 w-4"})}),Ce("span",{className:"text-sm font-medium text-(--app-text) mx-1",children:e.date.toLocaleString("default",{month:"long",year:"numeric"})}),a===0&&Ce("button",{type:"button",className:sd,disabled:!d,"aria-label":"\uB2E4\uC74C \uB2EC",onClick:()=>d&&r(d),children:Ce(P,{className:"h-4 w-4"})})]})}function La({className:e,classNames:a,showOutsideDays:t=!0,...r}){return Ce(di,{showOutsideDays:t,className:o("p-3 bg-(--app-bg) text-(--app-text) select-none",e),classNames:{months:"flex flex-col sm:flex-row gap-4",month:"flex flex-col gap-4",month_caption:"",caption_label:"text-sm font-medium text-(--app-text)",nav:"hidden",month_grid:"w-full border-collapse",weekdays:"flex",weekday:"text-(--app-muted) w-9 text-center text-[0.8rem] font-normal",week:"flex w-full mt-2",day:o("relative h-9 w-9 p-0 text-center text-sm","focus-within:relative focus-within:z-20"),day_button:o("h-9 w-9 p-0 font-normal flex items-center justify-center","text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","aria-selected:opacity-100"),range_start:"day-range-start",range_end:"day-range-end",selected:"[&>button]:bg-(--color-brand) [&>button]:text-white [&>button]:hover:bg-(--color-brand-hover) [&>button]:hover:text-white",today:"[&>button]:border [&>button]:border-(--app-border-strong) [&>button]:font-semibold",outside:"[&>button]:text-(--app-muted) [&>button]:opacity-50",disabled:"[&>button]:text-(--app-muted) [&>button]:opacity-40 [&>button]:pointer-events-none",range_middle:"[&>button]:bg-(--app-surface) [&>button]:text-(--app-text) [&>button]:hover:bg-(--app-surface)",hidden:"invisible",...a},components:{MonthCaption:ui,Chevron:({orientation:l})=>l==="left"?Ce(K,{className:"h-4 w-4"}):Ce(P,{className:"h-4 w-4"})},...r})}La.displayName="Calendar";function Za(e){if(!e)return null;let[a,t,r]=e.split("-").map(Number);return a==null||t==null||r==null?null:new Date(a,t-1,r)}function ud(e){if(!e)return"";let a=e.getFullYear(),t=String(e.getMonth()+1).padStart(2,"0"),r=String(e.getDate()).padStart(2,"0");return`${a}-${t}-${r}`}import{jsx as De,jsxs as id}from"react/jsx-runtime";function nd({value:e,onChange:a,placeholder:t="\uB0A0\uC9DC \uC120\uD0DD",disabled:r=!1,id:l,required:d,className:s,minDate:u,maxDate:f,onBlur:i}){let[c,b]=fd.useState(!1),q=Za(e??""),g=u?Za(u):void 0,v=f?Za(f):void 0,C=R=>{a(R?ud(R):""),b(!1)},w=R=>{R.stopPropagation(),a("")};return id(Ee,{open:c,onOpenChange:R=>{b(R),R||i?.()},children:[De(We,{asChild:!0,children:id("button",{id:l,type:"button",disabled:r,"aria-required":d,className:o("inline-flex items-center gap-2 h-8 w-full px-3 text-sm text-left","bg-(--app-field) border-b border-(--app-border-strong)","text-(--app-text) transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","hover:bg-(--app-hover)","focus-visible:outline-none focus-visible:border-(--color-brand)","disabled:pointer-events-none disabled:opacity-40",!e&&"text-(--app-text-placeholder)",s),children:[De(oa,{className:"h-4 w-4 shrink-0 text-(--app-muted)"}),De("span",{className:"flex-1 truncate",children:e||t}),e&&!r&&De("span",{role:"button",tabIndex:-1,onClick:w,className:"shrink-0 text-(--app-muted) hover:text-(--app-text) transition-colors",children:De(U,{className:"h-3.5 w-3.5"})})]})}),De(Me,{className:"w-auto p-0",align:"start",children:De(La,{mode:"single",selected:q??void 0,onSelect:C,defaultMonth:q??void 0,disabled:R=>!!(g&&R<g||v&&R>v),locale:dd})})]})}import*as cd from"react";import*as pd from"@radix-ui/react-separator";import{jsx as fi}from"react/jsx-runtime";var $t=cd.forwardRef(({className:e,orientation:a="horizontal",decorative:t=!0,...r},l)=>fi(pd.Root,{ref:l,decorative:t,orientation:a,className:o("shrink-0 bg-[var(--app-border)]",a==="horizontal"?"h-px w-full":"h-full w-px",e),...r}));$t.displayName="Separator";import*as Yt from"react";import*as Y from"@radix-ui/react-scroll-area";import{jsx as ga,jsxs as ni}from"react/jsx-runtime";var jt=Yt.forwardRef(({className:e,children:a,...t},r)=>ni(Y.Root,{ref:r,className:o("relative overflow-hidden",e),...t,children:[ga(Y.Viewport,{className:"h-full w-full rounded-[inherit]",children:a}),ga(Qa,{}),ga(Y.Corner,{})]}));jt.displayName="ScrollArea";var Qa=Yt.forwardRef(({className:e,orientation:a="vertical",...t},r)=>ga(Y.ScrollAreaScrollbar,{ref:r,orientation:a,className:o("flex touch-none select-none transition-colors",a==="vertical"&&"h-full w-2 border-l border-l-transparent p-px",a==="horizontal"&&"h-2 flex-col border-t border-t-transparent p-px",e),...t,children:ga(Y.ScrollAreaThumb,{className:"relative flex-1 rounded-full bg-[var(--app-border-strong)]"})}));Qa.displayName="ScrollBar";import*as md from"@radix-ui/react-aspect-ratio";var xd=md.Root;import*as Te from"react";import{jsx as Ke}from"react/jsx-runtime";var eo=Te.forwardRef(({className:e,...a},t)=>Ke("div",{ref:t,className:o("rounded-(--radius-md) border border-(--app-border) bg-(--app-surface) text-(--app-text) shadow-sm",e),...a}));eo.displayName="Card";var ao=Te.forwardRef(({className:e,...a},t)=>Ke("div",{ref:t,className:o("flex flex-col gap-1.5 p-4 pb-0",e),...a}));ao.displayName="CardHeader";var to=Te.forwardRef(({className:e,...a},t)=>Ke("h3",{ref:t,className:o("font-semibold leading-none tracking-tight",e),...a}));to.displayName="CardTitle";var oo=Te.forwardRef(({className:e,...a},t)=>Ke("p",{ref:t,className:o("text-sm text-[var(--app-text-secondary)]",e),...a}));oo.displayName="CardDescription";var ro=Te.forwardRef(({className:e,...a},t)=>Ke("div",{ref:t,className:o("p-4",e),...a}));ro.displayName="CardContent";var lo=Te.forwardRef(({className:e,...a},t)=>Ke("div",{ref:t,className:o("flex items-center justify-end gap-2 p-4 pt-0",e),...a}));lo.displayName="CardFooter";import*as Ze from"react";import{jsx as le,jsxs as ci}from"react/jsx-runtime";var so=Ze.forwardRef(({...e},a)=>le("nav",{ref:a,"aria-label":"breadcrumb",...e}));so.displayName="Breadcrumb";var uo=Ze.forwardRef(({className:e,...a},t)=>le("ol",{ref:t,className:o("flex flex-wrap items-center gap-1 break-words text-sm text-[var(--app-text-secondary)]",e),...a}));uo.displayName="BreadcrumbList";var io=Ze.forwardRef(({className:e,...a},t)=>le("li",{ref:t,className:o("inline-flex items-center gap-1",e),...a}));io.displayName="BreadcrumbItem";var fo=Ze.forwardRef(({className:e,...a},t)=>le("a",{ref:t,className:o("transition-colors hover:text-[var(--app-text)] focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[var(--color-brand)]",e),...a}));fo.displayName="BreadcrumbLink";var no=Ze.forwardRef(({className:e,...a},t)=>le("span",{ref:t,role:"link","aria-disabled":"true","aria-current":"page",className:o("font-medium text-[var(--app-text)]",e),...a}));no.displayName="BreadcrumbPage";var co=({children:e,className:a,...t})=>le("li",{role:"presentation","aria-hidden":"true",className:o("[&>svg]:h-3.5 [&>svg]:w-3.5 text-[var(--app-text-secondary)]",a),...t,children:e??le(P,{})});co.displayName="BreadcrumbSeparator";var po=({className:e,...a})=>ci("span",{role:"presentation","aria-hidden":"true",className:o("flex h-9 w-9 items-center justify-center",e),...a,children:[le("span",{className:"text-[var(--app-text-secondary)]",children:"\u2026"}),le("span",{className:"sr-only",children:"More pages"})]});po.displayName="BreadcrumbEllipsis";import*as $a from"react";import{cva as pi}from"class-variance-authority";import{jsx as Ja,jsxs as xi}from"react/jsx-runtime";var mo=pi("relative flex gap-3 rounded-(--radius-sm) border-l-[3px] p-4 text-sm transition-colors [&_svg]:h-5 [&_svg]:w-5 [&_svg]:shrink-0 [&_svg]:mt-0.5",{variants:{variant:{default:"border-l-[var(--app-border-strong)] bg-[var(--app-layer-02)] text-[var(--app-text)]",success:"border-l-[var(--color-success)] bg-[var(--color-success-subtle,color-mix(in_srgb,var(--color-success)_10%,transparent))] text-[var(--app-text)] [&_svg]:text-[var(--color-success)]",error:"border-l-[var(--color-accent)] bg-[var(--color-accent-subtle,color-mix(in_srgb,var(--color-accent)_10%,transparent))] text-[var(--app-text)] [&_svg]:text-[var(--color-accent)]",warning:"border-l-[var(--color-warning,#f59e0b)] bg-[color-mix(in_srgb,var(--color-warning,#f59e0b)_10%,transparent)] text-[var(--app-text)] [&_svg]:text-[var(--color-warning,#f59e0b)]",info:"border-l-[var(--color-brand)] bg-[color-mix(in_srgb,var(--color-brand)_10%,transparent)] text-[var(--app-text)] [&_svg]:text-[var(--color-brand)]"}},defaultVariants:{variant:"default"}}),mi={default:ta,success:Z,error:fe,warning:Q,info:Re},xo=$a.forwardRef(({className:e,variant:a="default",icon:t,children:r,...l},d)=>{let s=mi[a??"default"];return xi("div",{ref:d,role:"alert",className:o(mo({variant:a}),e),...l,children:[t!==void 0?t:Ja(s,{}),Ja("div",{className:"flex-1",children:r})]})});xo.displayName="Alert";var Lo=$a.forwardRef(({className:e,...a},t)=>Ja("h5",{ref:t,className:o("mb-1 font-semibold leading-none tracking-tight",e),...a}));Lo.displayName="AlertTitle";var go=$a.forwardRef(({className:e,...a},t)=>Ja("p",{ref:t,className:o("text-sm leading-relaxed text-[var(--app-text-secondary)]",e),...a}));go.displayName="AlertDescription";import*as gd from"react";import*as Ya from"@radix-ui/react-progress";import{jsx as Ld}from"react/jsx-runtime";var Co=gd.forwardRef(({className:e,value:a,indicatorClassName:t,...r},l)=>Ld(Ya.Root,{ref:l,className:o("relative h-2 w-full overflow-hidden rounded-full bg-[var(--app-layer-02)]",e),...r,children:Ld(Ya.Indicator,{className:o("h-full w-full flex-1 rounded-full bg-[var(--color-brand)] transition-all duration-300 ease-[cubic-bezier(0,0,0.38,0.9)]",t),style:{transform:`translateX(-${100-(a??0)}%)`}})}));Co.displayName="Progress";import*as Ae from"react";import*as y from"@radix-ui/react-alert-dialog";import{jsx as de,jsxs as Li}from"react/jsx-runtime";var Cd=y.Root,Id=y.Trigger,Io=y.Portal,ja=Ae.forwardRef(({className:e,...a},t)=>de(y.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));ja.displayName="AlertDialogOverlay";var ho=Ae.forwardRef(({className:e,...a},t)=>Li(Io,{children:[de(ja,{}),de(y.Content,{ref:t,className:o("fixed left-1/2 top-1/2 z-50 w-full max-w-lg -translate-x-1/2 -translate-y-1/2 rounded-(--radius-lg) bg-[var(--app-bg)] p-6 text-[var(--app-text)] shadow-[var(--shadow-modal)] 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%]",e),...a})]}));ho.displayName="AlertDialogContent";var bo=({className:e,...a})=>de("div",{className:o("flex flex-col gap-2 text-left",e),...a});bo.displayName="AlertDialogHeader";var Po=({className:e,...a})=>de("div",{className:o("flex justify-end gap-2 pt-4",e),...a});Po.displayName="AlertDialogFooter";var So=Ae.forwardRef(({className:e,...a},t)=>de(y.Title,{ref:t,className:o("text-base font-semibold text-[var(--app-text)]",e),...a}));So.displayName="AlertDialogTitle";var vo=Ae.forwardRef(({className:e,...a},t)=>de(y.Description,{ref:t,className:o("text-sm text-[var(--app-text-secondary)]",e),...a}));vo.displayName="AlertDialogDescription";var wo=Ae.forwardRef(({className:e,...a},t)=>de(y.Action,{ref:t,className:o(Oe({variant:"primary"}),e),...a}));wo.displayName="AlertDialogAction";var Ro=Ae.forwardRef(({className:e,...a},t)=>de(y.Cancel,{ref:t,className:o(Oe({variant:"secondary"}),e),...a}));Ro.displayName="AlertDialogCancel";import*as et from"react";import*as Qe from"@radix-ui/react-avatar";import{cva as gi}from"class-variance-authority";import{jsx as To}from"react/jsx-runtime";var yo=gi("relative flex shrink-0 overflow-hidden rounded-full",{variants:{size:{sm:"h-8 w-8 text-xs",default:"h-10 w-10 text-sm",lg:"h-14 w-14 text-base"}},defaultVariants:{size:"default"}}),Mo=et.forwardRef(({className:e,size:a,...t},r)=>To(Qe.Root,{ref:r,className:o(yo({size:a}),e),...t}));Mo.displayName="Avatar";var ko=et.forwardRef(({className:e,...a},t)=>To(Qe.Image,{ref:t,className:o("aspect-square h-full w-full object-cover",e),...a}));ko.displayName="AvatarImage";var Do=et.forwardRef(({className:e,...a},t)=>To(Qe.Fallback,{ref:t,className:o("flex h-full w-full items-center justify-center rounded-full bg-[var(--app-layer-02)] font-medium text-[var(--app-text-secondary)]",e),...a}));Do.displayName="AvatarFallback";import*as Je from"@radix-ui/react-collapsible";var hd=Je.Root,bd=Je.Trigger,Pd=Je.Content;import*as se from"react";import*as x from"@radix-ui/react-context-menu";import{jsx as H,jsxs as Wo}from"react/jsx-runtime";var Sd=x.Root,vd=x.Trigger,wd=x.Group,Rd=x.Portal,yd=x.Sub,Md=x.RadioGroup,Ao=se.forwardRef(({className:e,children:a,...t},r)=>Wo(x.SubTrigger,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[a,H(P,{className:"ml-auto h-4 w-4"})]}));Ao.displayName="ContextMenuSubTrigger";var Bo=se.forwardRef(({className:e,...a},t)=>H(x.SubContent,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));Bo.displayName="ContextMenuSubContent";var Fo=se.forwardRef(({className:e,...a},t)=>H(x.Portal,{children:H(x.Content,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a})}));Fo.displayName="ContextMenuContent";var No=se.forwardRef(({className:e,destructive:a,...t},r)=>H(x.Item,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",a?"text-[var(--color-error)] data-[highlighted]:text-[var(--color-error)]":"text-[var(--app-text)]",e),...t}));No.displayName="ContextMenuItem";var Ho=se.forwardRef(({className:e,children:a,checked:t,...r},l)=>Wo(x.CheckboxItem,{ref:l,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:t,...r,children:[H("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:H(x.ItemIndicator,{children:H(F,{className:"h-4 w-4"})})}),a]}));Ho.displayName="ContextMenuCheckboxItem";var qo=se.forwardRef(({className:e,children:a,...t},r)=>Wo(x.RadioItem,{ref:r,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[H("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:H(x.ItemIndicator,{children:H(te,{className:"h-2 w-2 fill-current"})})}),a]}));qo.displayName="ContextMenuRadioItem";var Oo=se.forwardRef(({className:e,...a},t)=>H(x.Label,{ref:t,className:o("px-3 py-1.5 text-xs font-semibold text-[var(--app-muted)]",e),...a}));Oo.displayName="ContextMenuLabel";var Uo=se.forwardRef(({className:e,...a},t)=>H(x.Separator,{ref:t,className:o("h-px bg-[var(--app-border)] -mx-1 my-1",e),...a}));Uo.displayName="ContextMenuSeparator";var Eo=({className:e,...a})=>H("span",{className:o("ml-auto text-xs tracking-widest text-[var(--app-muted)]",e),...a});Eo.displayName="ContextMenuShortcut";import*as Dd from"react";import*as Ie from"@radix-ui/react-hover-card";import{jsx as kd}from"react/jsx-runtime";var Td=Ie.Root,Ad=Ie.Trigger,Go=Dd.forwardRef(({className:e,align:a="center",sideOffset:t=4,...r},l)=>kd(Ie.Portal,{children:kd(Ie.Content,{ref:l,align:a,sideOffset:t,className:o("z-50 w-64 rounded-(--radius-md) bg-(--app-bg) border border-(--app-border) p-4 text-(--app-text) shadow-(--shadow-dropdown) 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-[side=bottom]:slide-in-from-top-2 data-[side=top]:slide-in-from-bottom-2","data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2",e),...r})}));Go.displayName="HoverCardContent";import*as X from"react";import*as m from"@radix-ui/react-menubar";import{jsx as T,jsxs as er}from"react/jsx-runtime";var Bd=m.Menu,Fd=m.Group,Nd=m.Portal,Hd=m.Sub,qd=m.RadioGroup,Vo=X.forwardRef(({className:e,...a},t)=>T(m.Root,{ref:t,className:o("flex h-9 items-center gap-0 border border-[var(--app-border)] bg-[var(--app-bg)] px-1",e),...a}));Vo.displayName="Menubar";var zo=X.forwardRef(({className:e,...a},t)=>T(m.Trigger,{ref:t,className:o("flex cursor-default select-none items-center px-3 py-1.5 text-sm font-medium outline-none","text-[var(--app-text)] hover:bg-[var(--app-hover)]","data-[state=open]:bg-[var(--app-hover)]","focus:bg-[var(--app-hover)]",e),...a}));zo.displayName="MenubarTrigger";var Xo=X.forwardRef(({className:e,children:a,...t},r)=>er(m.SubTrigger,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[a,T(P,{className:"ml-auto h-4 w-4"})]}));Xo.displayName="MenubarSubTrigger";var _o=X.forwardRef(({className:e,...a},t)=>T(m.SubContent,{ref:t,className:o("z-50 min-w-[8rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...a}));_o.displayName="MenubarSubContent";var Ko=X.forwardRef(({className:e,align:a="start",alignOffset:t=-4,sideOffset:r=8,...l},d)=>T(m.Portal,{children:T(m.Content,{ref:d,align:a,alignOffset:t,sideOffset:r,className:o("z-50 min-w-[12rem] overflow-hidden rounded-(--radius-md) bg-(--app-bg) text-(--app-text) shadow-(--shadow-dropdown) border border-(--app-border) py-1","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...l})}));Ko.displayName="MenubarContent";var Zo=X.forwardRef(({className:e,destructive:a,...t},r)=>T(m.Item,{ref:r,className:o("relative flex cursor-default select-none items-center px-3 py-1.5 text-sm outline-none transition-colors duration-[110ms]","data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",a?"text-[var(--color-error)] data-[highlighted]:text-[var(--color-error)]":"text-[var(--app-text)]",e),...t}));Zo.displayName="MenubarItem";var Qo=X.forwardRef(({className:e,children:a,checked:t,...r},l)=>er(m.CheckboxItem,{ref:l,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:t,...r,children:[T("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:T(m.ItemIndicator,{children:T(F,{className:"h-4 w-4"})})}),a]}));Qo.displayName="MenubarCheckboxItem";var Jo=X.forwardRef(({className:e,children:a,...t},r)=>er(m.RadioItem,{ref:r,className:o("relative flex cursor-default select-none items-center py-1.5 pl-8 pr-3 text-sm outline-none transition-colors duration-[110ms]","text-[var(--app-text)] data-[highlighted]:bg-[var(--app-hover)]","data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...t,children:[T("span",{className:"absolute left-2 flex h-4 w-4 items-center justify-center",children:T(m.ItemIndicator,{children:T(te,{className:"h-2 w-2 fill-current"})})}),a]}));Jo.displayName="MenubarRadioItem";var $o=X.forwardRef(({className:e,...a},t)=>T(m.Label,{ref:t,className:o("px-3 py-1.5 text-xs font-semibold text-[var(--app-muted)]",e),...a}));$o.displayName="MenubarLabel";var Yo=X.forwardRef(({className:e,...a},t)=>T(m.Separator,{ref:t,className:o("h-px bg-[var(--app-border)] -mx-1 my-1",e),...a}));Yo.displayName="MenubarSeparator";var jo=({className:e,...a})=>T("span",{className:o("ml-auto text-xs tracking-widest text-[var(--app-muted)]",e),...a});jo.displayName="MenubarShortcut";import*as he from"react";import*as A from"@radix-ui/react-navigation-menu";import{jsx as ue,jsxs as Ud}from"react/jsx-runtime";var ar=he.forwardRef(({className:e,children:a,...t},r)=>Ud(A.Root,{ref:r,className:o("relative z-10 flex items-center",e),...t,children:[a,ue(tt,{})]}));ar.displayName="NavigationMenu";var tr=he.forwardRef(({className:e,...a},t)=>ue(A.List,{ref:t,className:o("flex flex-1 list-none items-center gap-1",e),...a}));tr.displayName="NavigationMenuList";var Od=A.Item,at=o("group inline-flex h-9 items-center justify-center px-4 py-2 text-sm font-medium outline-none transition-colors","text-[var(--app-text)] bg-transparent hover:bg-[var(--app-hover)]","focus:bg-[var(--app-hover)]","data-[active]:bg-[var(--app-hover)] data-[state=open]:bg-[var(--app-hover)]","disabled:pointer-events-none disabled:opacity-50"),or=he.forwardRef(({className:e,children:a,...t},r)=>Ud(A.Trigger,{ref:r,className:o(at,"gap-1",e),...t,children:[a,ue(ae,{className:"relative h-3 w-3 transition-transform duration-200 group-data-[state=open]:rotate-180","aria-hidden":"true"})]}));or.displayName="NavigationMenuTrigger";var rr=he.forwardRef(({className:e,...a},t)=>ue(A.Content,{ref:t,className:o("left-0 top-0 w-full md:absolute md:w-auto","data-[motion=from-end]:animate-in data-[motion=from-start]:animate-in data-[motion=to-end]:animate-out data-[motion=to-start]:animate-out","data-[motion=from-end]:slide-in-from-right-52 data-[motion=from-start]:slide-in-from-left-52","data-[motion=to-end]:slide-out-to-right-52 data-[motion=to-start]:slide-out-to-left-52",e),...a}));rr.displayName="NavigationMenuContent";var lr=he.forwardRef(({className:e,...a},t)=>ue(A.Link,{ref:t,className:o(at,e),...a}));lr.displayName="NavigationMenuLink";var tt=he.forwardRef(({className:e,...a},t)=>ue("div",{className:o("absolute left-0 top-full flex justify-center"),children:ue(A.Viewport,{className:o("origin-top-center relative mt-1.5 h-[var(--radix-navigation-menu-viewport-height)] w-full overflow-hidden rounded-(--radius-md)","bg-(--app-bg) border border-(--app-border) shadow-(--shadow-dropdown)","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-90","md:w-[var(--radix-navigation-menu-viewport-width)]",e),ref:t,...a})}));tt.displayName="NavigationMenuViewport";var dr=he.forwardRef(({className:e,...a},t)=>ue(A.Indicator,{ref:t,className:o("top-full z-[1] flex h-1.5 items-end justify-center overflow-hidden","data-[state=visible]:animate-in data-[state=hidden]:animate-out","data-[state=hidden]:fade-out data-[state=visible]:fade-in",e),...a,children:ue("div",{className:"relative top-[60%] h-2 w-2 rotate-45 bg-[var(--app-border)] shadow-md"})}));dr.displayName="NavigationMenuIndicator";import*as sr from"react";import*as $e from"@radix-ui/react-radio-group";import{jsx as ot}from"react/jsx-runtime";var ur=sr.forwardRef(({className:e,...a},t)=>ot($e.Root,{ref:t,className:o("grid gap-2",e),...a}));ur.displayName="RadioGroup";var ir=sr.forwardRef(({className:e,...a},t)=>ot($e.Item,{ref:t,className:o("relative aspect-square h-4 w-4 rounded-full border border-(--app-border-strong) text-(--color-brand)","shadow-sm outline-none transition-colors","hover:border-(--color-brand)","focus-visible:ring-2 focus-visible:ring-(--color-brand) focus-visible:ring-offset-2","disabled:cursor-not-allowed disabled:opacity-50","data-[state=checked]:border-(--color-brand) data-[state=checked]:bg-(--color-brand)","before:absolute before:-inset-[14px] before:content-['']",e),...a,children:ot($e.Indicator,{className:"flex items-center justify-center",children:ot(te,{className:"h-2 w-2 fill-white text-white"})})}));ir.displayName="RadioGroupItem";import*as Ed from"react";import*as be from"@radix-ui/react-slider";import{jsx as fr,jsxs as Ci}from"react/jsx-runtime";var nr=Ed.forwardRef(({className:e,...a},t)=>Ci(be.Root,{ref:t,className:o("relative flex w-full touch-none select-none items-center",e),...a,children:[fr(be.Track,{className:"relative h-1.5 w-full grow overflow-hidden bg-[var(--app-border)]",children:fr(be.Range,{className:"absolute h-full bg-[var(--color-brand)]"})}),(a.defaultValue??a.value??[0]).map((r,l)=>fr(be.Thumb,{className:o("block h-4 w-4 border-2 border-[var(--color-brand)] bg-[var(--app-bg)] shadow transition-colors","hover:border-[var(--color-brand-hover)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[var(--color-brand)] focus-visible:ring-offset-2","disabled:pointer-events-none disabled:opacity-50")},l))]}));nr.displayName="Slider";import*as Wd from"react";import*as Gd from"@radix-ui/react-toggle";import{cva as Ii}from"class-variance-authority";import{jsx as hi}from"react/jsx-runtime";var Ca=Ii(["inline-flex items-center justify-center gap-2 text-sm font-medium outline-none transition-colors","text-[var(--app-muted)] hover:bg-[var(--app-hover)] hover:text-[var(--app-text)]","focus-visible:ring-2 focus-visible:ring-[var(--color-brand)] focus-visible:ring-offset-2","disabled:pointer-events-none disabled:opacity-50","data-[state=on]:bg-[var(--app-surface)] data-[state=on]:text-[var(--app-text)]"],{variants:{variant:{default:"bg-transparent",outline:"border border-[var(--app-border)] bg-transparent hover:border-[var(--app-border-strong)]"},size:{sm:"h-7 px-2 text-xs",default:"h-9 px-3",lg:"h-11 px-5 text-base"}},defaultVariants:{variant:"default",size:"default"}}),cr=Wd.forwardRef(({className:e,variant:a,size:t,...r},l)=>hi(Gd.Root,{ref:l,className:o(Ca({variant:a,size:t}),e),...r}));cr.displayName="Toggle";import*as Be from"react";import*as rt from"@radix-ui/react-toggle-group";import"class-variance-authority";import{jsx as pr}from"react/jsx-runtime";var Vd=Be.createContext({size:"default",variant:"default"}),mr=Be.forwardRef(({className:e,variant:a,size:t,children:r,...l},d)=>pr(rt.Root,{ref:d,className:o("flex items-center gap-1",e),...l,children:pr(Vd.Provider,{value:{variant:a,size:t},children:r})}));mr.displayName="ToggleGroup";var xr=Be.forwardRef(({className:e,children:a,variant:t,size:r,...l},d)=>{let s=Be.useContext(Vd);return pr(rt.Item,{ref:d,className:o(Ca({variant:t??s.variant,size:r??s.size}),e),...l,children:a})});xr.displayName="ToggleGroupItem";import*as Fe from"react";import{OTPInput as bi,OTPInputContext as Pi}from"input-otp";import{jsx as Ye,jsxs as Si}from"react/jsx-runtime";var Lr=Fe.forwardRef(({className:e,containerClassName:a,...t},r)=>Ye(bi,{ref:r,containerClassName:o("flex items-center gap-2 has-[:disabled]:opacity-50",a),className:o("disabled:cursor-not-allowed",e),...t}));Lr.displayName="InputOTP";var gr=Fe.forwardRef(({className:e,...a},t)=>Ye("div",{ref:t,className:o("flex items-center",e),...a}));gr.displayName="InputOTPGroup";var Cr=Fe.forwardRef(({index:e,className:a,...t},r)=>{let d=Fe.useContext(Pi).slots[e],s=d?.char,u=d?.hasFakeCaret,f=d?.isActive;return Si("div",{ref:r,className:o("relative flex h-10 w-10 items-center justify-center","border-y border-r border-(--app-border)","text-sm text-(--app-text) bg-(--app-bg)","transition-all duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","first:border-l",f&&"z-10 ring-2 ring-(--color-brand) border-(--color-brand)",a),...t,children:[s,u&&Ye("div",{className:"pointer-events-none absolute inset-0 flex items-center justify-center",children:Ye("div",{className:"animate-caret-blink h-4 w-px bg-(--app-text) duration-1000"})})]})});Cr.displayName="InputOTPSlot";var Ir=Fe.forwardRef(({...e},a)=>Ye("div",{ref:a,role:"separator",...e,children:Ye(la,{className:"h-4 w-4 text-(--app-muted)"})}));Ir.displayName="InputOTPSeparator";import*as Ia from"react";import*as k from"@radix-ui/react-dialog";import{jsx as Pe,jsxs as hr}from"react/jsx-runtime";var zd=k.Root,Xd=k.Trigger,_d=k.Close,Kd=k.Portal,br=Ia.forwardRef(({className:e,...a},t)=>Pe(k.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0","duration-240 ease-[cubic-bezier(0,0,0.38,0.9)]",e),...a}));br.displayName="SheetOverlay";var vi=e=>{let a=o("fixed z-50 bg-(--app-bg) text-(--app-text) shadow-(--shadow-modal)","duration-240 ease-[cubic-bezier(0,0,0.38,0.9)]","data-[state=open]:animate-in data-[state=closed]:animate-out");return{top:o(a,"inset-x-0 top-0 border-b border-(--app-border) rounded-b-(--radius-lg)","data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top"),right:o(a,"inset-y-0 right-0 h-full w-3/4 border-l border-(--app-border) rounded-l-(--radius-lg) sm:max-w-sm","data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right"),bottom:o(a,"inset-x-0 bottom-0 border-t border-(--app-border) rounded-t-(--radius-lg)","data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom"),left:o(a,"inset-y-0 left-0 h-full w-3/4 border-r border-(--app-border) rounded-r-(--radius-lg) sm:max-w-sm","data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left")}[e]},Pr=Ia.forwardRef(({side:e="right",className:a,children:t,...r},l)=>hr(Kd,{children:[Pe(br,{}),hr(k.Content,{ref:l,className:o(vi(e),a),...r,children:[hr(k.Close,{className:o("absolute right-4 top-4 text-(--app-muted)","hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:pointer-events-none"),children:[Pe(U,{className:"h-4 w-4"}),Pe("span",{className:"sr-only",children:"\uB2EB\uAE30"})]}),t]})]}));Pr.displayName="SheetContent";var Sr=({className:e,...a})=>Pe("div",{className:o("flex flex-col gap-1.5 px-6 py-4","border-b border-(--app-border)",e),...a});Sr.displayName="SheetHeader";var vr=({className:e,...a})=>Pe("div",{className:o("flex flex-col-reverse sm:flex-row sm:justify-end gap-2 px-6 py-4","border-t border-(--app-border) mt-auto",e),...a});vr.displayName="SheetFooter";var wr=Ia.forwardRef(({className:e,...a},t)=>Pe(k.Title,{ref:t,className:o("text-lg font-semibold text-(--app-text)",e),...a}));wr.displayName="SheetTitle";var Rr=Ia.forwardRef(({className:e,...a},t)=>Pe(k.Description,{ref:t,className:o("text-sm text-(--app-muted)",e),...a}));Rr.displayName="SheetDescription";import*as ha from"react";import{Drawer as _}from"vaul";import{jsx as Se,jsxs as Zd}from"react/jsx-runtime";var yr=({shouldScaleBackground:e=!0,...a})=>Se(_.Root,{shouldScaleBackground:e,...a});yr.displayName="Drawer";var Qd=_.Trigger,Jd=_.Portal,$d=_.Close,Mr=ha.forwardRef(({className:e,...a},t)=>Se(_.Overlay,{ref:t,className:o("fixed inset-0 z-50 bg-black/60",e),...a}));Mr.displayName=_.Overlay.displayName;var kr=ha.forwardRef(({className:e,children:a,...t},r)=>Zd(Jd,{children:[Se(Mr,{}),Zd(_.Content,{ref:r,className:o("fixed inset-x-0 bottom-0 z-50 mt-24 flex h-auto flex-col rounded-t-(--radius-lg)","bg-(--app-bg) text-(--app-text)","border-t border-(--app-border)","shadow-(--shadow-modal)",e),...t,children:[Se("div",{className:"mx-auto mt-4 h-2 w-[100px] bg-(--app-border-strong)"}),a]})]}));kr.displayName="DrawerContent";var Dr=({className:e,...a})=>Se("div",{className:o("grid gap-1.5 p-4 text-center sm:text-left","border-b border-(--app-border)",e),...a});Dr.displayName="DrawerHeader";var Tr=({className:e,...a})=>Se("div",{className:o("mt-auto flex flex-col gap-2 p-4","border-t border-(--app-border)",e),...a});Tr.displayName="DrawerFooter";var Ar=ha.forwardRef(({className:e,...a},t)=>Se(_.Title,{ref:t,className:o("text-lg font-semibold leading-none tracking-tight text-(--app-text)",e),...a}));Ar.displayName=_.Title.displayName;var Br=ha.forwardRef(({className:e,...a},t)=>Se(_.Description,{ref:t,className:o("text-sm text-(--app-muted)",e),...a}));Br.displayName=_.Description.displayName;import*as h from"react";import wi from"embla-carousel-react";import{jsx as ie,jsxs as jd}from"react/jsx-runtime";var Yd=h.createContext(null);function lt(){let e=h.useContext(Yd);if(!e)throw new Error("useCarousel must be used within <Carousel />");return e}var Fr=h.forwardRef(({orientation:e="horizontal",opts:a,setApi:t,plugins:r,className:l,children:d,...s},u)=>{let[f,i]=wi({...a,axis:e==="horizontal"?"x":"y"},r),[c,b]=h.useState(!1),[q,g]=h.useState(!1),v=h.useCallback(B=>{B&&(b(B.canScrollPrev()),g(B.canScrollNext()))},[]),C=h.useCallback(()=>i?.scrollPrev(),[i]),w=h.useCallback(()=>i?.scrollNext(),[i]),R=h.useCallback(B=>{B.key==="ArrowLeft"?(B.preventDefault(),C()):B.key==="ArrowRight"&&(B.preventDefault(),w())},[C,w]);return h.useEffect(()=>{!i||!t||t(i)},[i,t]),h.useEffect(()=>{if(i)return v(i),i.on("reInit",v),i.on("select",v),()=>{i?.off("select",v)}},[i,v]),ie(Yd.Provider,{value:{carouselRef:f,api:i,opts:a,orientation:e,scrollPrev:C,scrollNext:w,canScrollPrev:c,canScrollNext:q},children:ie("div",{ref:u,onKeyDownCapture:R,className:o("relative",l),role:"region","aria-roledescription":"carousel",...s,children:d})})});Fr.displayName="Carousel";var Nr=h.forwardRef(({className:e,...a},t)=>{let{carouselRef:r,orientation:l}=lt();return ie("div",{ref:r,className:"overflow-hidden",children:ie("div",{ref:t,className:o("flex",l==="horizontal"?"-ml-4":"-mt-4 flex-col",e),...a})})});Nr.displayName="CarouselContent";var Hr=h.forwardRef(({className:e,...a},t)=>{let{orientation:r}=lt();return ie("div",{ref:t,role:"group","aria-roledescription":"slide",className:o("min-w-0 shrink-0 grow-0 basis-full",r==="horizontal"?"pl-4":"pt-4",e),...a})});Hr.displayName="CarouselItem";var qr=h.forwardRef(({className:e,...a},t)=>{let{orientation:r,scrollPrev:l,canScrollPrev:d}=lt();return jd("button",{ref:t,className:o("absolute h-8 w-8 flex items-center justify-center","border border-(--app-border) bg-(--app-bg) text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:opacity-40 disabled:pointer-events-none",r==="horizontal"?"-left-12 top-1/2 -translate-y-1/2":"-top-12 left-1/2 -translate-x-1/2 rotate-90",e),disabled:!d,onClick:l,"aria-label":"\uC774\uC804 \uC2AC\uB77C\uC774\uB4DC",...a,children:[ie(K,{className:"h-4 w-4"}),ie("span",{className:"sr-only",children:"\uC774\uC804"})]})});qr.displayName="CarouselPrevious";var Or=h.forwardRef(({className:e,...a},t)=>{let{orientation:r,scrollNext:l,canScrollNext:d}=lt();return jd("button",{ref:t,className:o("absolute h-8 w-8 flex items-center justify-center","border border-(--app-border) bg-(--app-bg) text-(--app-text)","hover:bg-(--app-surface) hover:text-(--app-text)","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","disabled:opacity-40 disabled:pointer-events-none",r==="horizontal"?"-right-12 top-1/2 -translate-y-1/2":"-bottom-12 left-1/2 -translate-x-1/2 rotate-90",e),disabled:!d,onClick:l,"aria-label":"\uB2E4\uC74C \uC2AC\uB77C\uC774\uB4DC",...a,children:[ie(P,{className:"h-4 w-4"}),ie("span",{className:"sr-only",children:"\uB2E4\uC74C"})]})});Or.displayName="CarouselNext";import*as Ur from"react";import{jsx as j,jsxs as _r}from"react/jsx-runtime";var Er=({className:e,...a})=>j("nav",{role:"navigation","aria-label":"pagination",className:o("mx-auto flex w-full justify-center",e),...a});Er.displayName="Pagination";var Wr=Ur.forwardRef(({className:e,...a},t)=>j("ul",{ref:t,className:o("flex flex-row items-center gap-1",e),...a}));Wr.displayName="PaginationContent";var Gr=Ur.forwardRef(({className:e,...a},t)=>j("li",{ref:t,className:o("",e),...a}));Gr.displayName="PaginationItem";var ba=({className:e,isActive:a,size:t="default",...r})=>j("a",{"aria-current":a?"page":void 0,className:o("flex items-center justify-center text-sm","border border-transparent","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand)","cursor-pointer",t==="default"?"h-9 min-w-9 px-3":"h-9 w-9",a?"bg-(--color-brand) text-white border-(--color-brand) hover:bg-(--color-brand-hover)":"text-(--app-text) hover:bg-(--app-surface) border-(--app-border)",e),...r});ba.displayName="PaginationLink";var Vr=({className:e,...a})=>_r(ba,{"aria-label":"\uC774\uC804 \uD398\uC774\uC9C0\uB85C \uC774\uB3D9",size:"default",className:o("gap-1 pl-2.5",e),...a,children:[j(K,{className:"h-4 w-4"}),j("span",{children:"\uC774\uC804"})]});Vr.displayName="PaginationPrevious";var zr=({className:e,...a})=>_r(ba,{"aria-label":"\uB2E4\uC74C \uD398\uC774\uC9C0\uB85C \uC774\uB3D9",size:"default",className:o("gap-1 pr-2.5",e),...a,children:[j("span",{children:"\uB2E4\uC74C"}),j(P,{className:"h-4 w-4"})]});zr.displayName="PaginationNext";var Xr=({className:e,...a})=>_r("span",{"aria-hidden":!0,className:o("flex h-9 w-9 items-center justify-center text-(--app-muted)",e),...a,children:[j(ce,{className:"h-4 w-4"}),j("span",{className:"sr-only",children:"\uB354\uBCF4\uAE30"})]});Xr.displayName="PaginationEllipsis";import"react";import{Group as Ri,Panel as yi,Separator as Mi}from"react-resizable-panels";import{jsx as dt}from"react/jsx-runtime";var Kr=({className:e,...a})=>dt(Ri,{className:o("flex h-full w-full data-[orientation=vertical]:flex-col",e),...a});Kr.displayName="ResizablePanelGroup";var es=yi,Zr=({withHandle:e,className:a,...t})=>dt(Mi,{className:o("relative flex items-center justify-center","bg-(--app-border)","data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full","data-[orientation=vertical]:w-px data-[orientation=vertical]:h-full","focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-(--color-brand) focus-visible:ring-offset-1","transition-colors duration-110 ease-[cubic-bezier(0,0,0.38,0.9)]","hover:bg-(--color-brand)",a),...t,children:e&&dt("div",{className:"z-10 flex h-4 w-3 items-center justify-center border border-(--app-border) bg-(--app-bg)",children:dt(da,{className:"h-2.5 w-2.5 text-(--app-muted)"})})});Zr.displayName="ResizableHandle";export{Dl as Accordion,Et as AccordionContent,Ot as AccordionItem,Ut as AccordionTrigger,xo as Alert,go as AlertDescription,Cd as AlertDialog,wo as AlertDialogAction,Ro as AlertDialogCancel,ho as AlertDialogContent,vo as AlertDialogDescription,Po as AlertDialogFooter,bo as AlertDialogHeader,ja as AlertDialogOverlay,Io as AlertDialogPortal,So as AlertDialogTitle,Id as AlertDialogTrigger,Lo as AlertTitle,xd as AspectRatio,Mo as Avatar,Do as AvatarFallback,ko as AvatarImage,Il as Badge,so as Breadcrumb,po as BreadcrumbEllipsis,io as BreadcrumbItem,fo as BreadcrumbLink,uo as BreadcrumbList,no as BreadcrumbPage,co as BreadcrumbSeparator,nt as Button,La as Calendar,eo as Card,ro as CardContent,oo as CardDescription,lo as CardFooter,ao as CardHeader,to as CardTitle,Fr as Carousel,Nr as CarouselContent,Hr as CarouselItem,Or as CarouselNext,qr as CarouselPrevious,gt as Checkbox,hd as Collapsible,Pd as CollapsibleContent,bd as CollapsibleTrigger,Mt as Combobox,Ge as Command,Cl as CommandDialog,na as CommandEmpty,ca as CommandGroup,ia as CommandInput,ke as CommandItem,fa as CommandList,wt as CommandSeparator,Rt as CommandShortcut,Sd as ContextMenu,Ho as ContextMenuCheckboxItem,Fo as ContextMenuContent,wd as ContextMenuGroup,No as ContextMenuItem,Oo as ContextMenuLabel,Rd as ContextMenuPortal,Md as ContextMenuRadioGroup,qo as ContextMenuRadioItem,Uo as ContextMenuSeparator,Eo as ContextMenuShortcut,yd as ContextMenuSub,Bo as ContextMenuSubContent,Ao as ContextMenuSubTrigger,vd as ContextMenuTrigger,wl as DataTable,nd as DatePicker,qa as Dialog,Ll as DialogBody,pl as DialogClose,ua as DialogContent,vt as DialogDescription,gl as DialogFooter,xl as DialogHeader,St as DialogTitle,cl as DialogTrigger,yr as Drawer,$d as DrawerClose,kr as DrawerContent,Br as DrawerDescription,Tr as DrawerFooter,Dr as DrawerHeader,Ar as DrawerTitle,Qd as DrawerTrigger,El as DropdownMenu,Xt as DropdownMenuCheckboxItem,Vt as DropdownMenuContent,Gl as DropdownMenuGroup,zt as DropdownMenuItem,Kt as DropdownMenuLabel,_t as DropdownMenuSeparator,Vl as DropdownMenuSub,Gt as DropdownMenuSubContent,Wt as DropdownMenuSubTrigger,Wl as DropdownMenuTrigger,Ul as FormField,Hl as FormGrid,Td as HoverCard,Go as HoverCardContent,Ad as HoverCardTrigger,ct as Input,Lr as InputOTP,gr as InputOTPGroup,Ir as InputOTPSeparator,Cr as InputOTPSlot,ee as Label,Ft as List,Ht as ListHeader,Nt as ListItem,Vo as Menubar,Qo as MenubarCheckboxItem,Ko as MenubarContent,Fd as MenubarGroup,Zo as MenubarItem,$o as MenubarLabel,Bd as MenubarMenu,Nd as MenubarPortal,qd as MenubarRadioGroup,Jo as MenubarRadioItem,Yo as MenubarSeparator,jo as MenubarShortcut,Hd as MenubarSub,_o as MenubarSubContent,Xo as MenubarSubTrigger,zo as MenubarTrigger,Xa as ModalActionButtons,za as ModalHeader,Nl as ModalSection,ar as NavigationMenu,rr as NavigationMenuContent,dr as NavigationMenuIndicator,Od as NavigationMenuItem,lr as NavigationMenuLink,tr as NavigationMenuList,or as NavigationMenuTrigger,tt as NavigationMenuViewport,Jl as Notification,Er as Pagination,Wr as PaginationContent,Xr as PaginationEllipsis,Gr as PaginationItem,ba as PaginationLink,zr as PaginationNext,Vr as PaginationPrevious,Ee as Popover,fl as PopoverAnchor,nl as PopoverClose,Me as PopoverContent,We as PopoverTrigger,Co as Progress,ur as RadioGroup,ir as RadioGroupItem,Zr as ResizableHandle,es as ResizablePanel,Kr as ResizablePanelGroup,jt as ScrollArea,Qa as ScrollBar,ht as Search,Lt as Select,$t as Separator,zd as Sheet,_d as SheetClose,Pr as SheetContent,Rr as SheetDescription,vr as SheetFooter,Sr as SheetHeader,wr as SheetTitle,Xd as SheetTrigger,Jt as Skeleton,nr as Slider,vl as SortButton,Yl as Spinner,jl as SpinnerInline,Bl as StandardModal,It as Switch,Oa as Table,Ua as TablePagination,Rl as Tabs,Bt as TabsContent,Tt as TabsList,At as TabsTrigger,pt as Textarea,cr as Toggle,mr as ToggleGroup,xr as ToggleGroupItem,Kl as Tooltip,_l as TooltipProvider,kl as TreeView,mo as alertVariants,yo as avatarVariants,Oe as buttonVariants,o as cn,at as navigationMenuTriggerStyle,Qt as notificationVariants,Ca as toggleVariants};
3
3
  /*! Bundled license information:
4
4
 
5
5
  lucide-react/dist/esm/shared/src/utils/mergeClasses.js:
@@ -17,6 +17,7 @@ lucide-react/dist/esm/icons/check.js:
17
17
  lucide-react/dist/esm/icons/chevron-down.js:
18
18
  lucide-react/dist/esm/icons/chevron-left.js:
19
19
  lucide-react/dist/esm/icons/chevron-right.js:
20
+ lucide-react/dist/esm/icons/chevrons-up-down.js:
20
21
  lucide-react/dist/esm/icons/circle-alert.js:
21
22
  lucide-react/dist/esm/icons/circle-check.js:
22
23
  lucide-react/dist/esm/icons/circle-x.js:
@@ -25,6 +26,7 @@ lucide-react/dist/esm/icons/dot.js:
25
26
  lucide-react/dist/esm/icons/ellipsis.js:
26
27
  lucide-react/dist/esm/icons/grip-vertical.js:
27
28
  lucide-react/dist/esm/icons/info.js:
29
+ lucide-react/dist/esm/icons/loader-circle.js:
28
30
  lucide-react/dist/esm/icons/search.js:
29
31
  lucide-react/dist/esm/icons/triangle-alert.js:
30
32
  lucide-react/dist/esm/icons/x.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@samkwang/ui-kit",
3
- "version": "0.5.2",
3
+ "version": "0.7.0",
4
4
  "description": "Samkwang Design System UI Components for React / Next.js",
5
5
  "type": "module",
6
6
  "main": "./dist/index.cjs",