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