@samkwang/ui-kit 0.4.0 → 0.5.1

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