@libxai/board 0.17.5 → 0.17.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +2 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -42,7 +42,7 @@
|
|
|
42
42
|
1.
|
|
43
43
|
|
|
44
44
|
**Action items:**
|
|
45
|
-
- [ ] `,priority:"MEDIUM",labels:["meeting"]}}];function rs({templates:e,onSelectTemplate:t,className:r}){let[a,n]=Se.useState(false),o=Se.useRef(null),s=Se.useRef(null);Se.useEffect(()=>{function i(p){o.current&&!o.current.contains(p.target)&&s.current&&!s.current.contains(p.target)&&n(false);}if(a)return document.addEventListener("mousedown",i),()=>document.removeEventListener("mousedown",i)},[a]);let c=i=>{t(i),n(false);},u=e.reduce((i,p)=>{let l=p.category||"Other";return i[l]||(i[l]=[]),i[l].push(p),i},{});return jsxRuntime.jsxs("div",{className:L("relative inline-block",r),children:[jsxRuntime.jsxs("button",{ref:s,onClick:()=>n(!a),className:"flex items-center gap-2 px-3 py-2 rounded-lg border transition-all text-sm font-medium shadow-lg",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)",color:"var(--theme-text-primary)"},onMouseEnter:i=>{i.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)",i.currentTarget.style.borderColor="var(--theme-border-secondary)";},onMouseLeave:i=>{i.currentTarget.style.backgroundColor="var(--theme-bg-secondary)",i.currentTarget.style.borderColor="var(--theme-border-primary)";},title:"Create from template",children:[jsxRuntime.jsx("span",{className:"text-base leading-none",children:"\u{1F4CB}"}),jsxRuntime.jsx("span",{children:"Templates"}),jsxRuntime.jsx("svg",{className:L("w-4 h-4 transition-transform",a&&"rotate-180"),fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:jsxRuntime.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"})})]}),a&&jsxRuntime.jsxs("div",{ref:o,className:"absolute top-full left-0 mt-2 min-w-[320px] max-w-[400px] rounded-xl backdrop-blur-xl border shadow-2xl z-50 overflow-hidden max-h-[500px] overflow-y-auto",style:{backgroundColor:"var(--theme-bg-primary)",borderColor:"var(--theme-border-primary)"},children:[jsxRuntime.jsxs("div",{className:"px-4 py-3 border-b sticky top-0 backdrop-blur-sm",style:{borderColor:"var(--theme-border-primary)",backgroundColor:"var(--theme-bg-secondary)"},children:[jsxRuntime.jsx("span",{className:"text-sm font-bold uppercase tracking-wider",style:{color:"var(--theme-text-primary)"},children:"Card Templates"}),jsxRuntime.jsx("p",{className:"text-xs mt-0.5",style:{color:"var(--theme-text-tertiary)"},children:"Quick start with pre-configured cards"})]}),Object.entries(u).map(([i,p])=>jsxRuntime.jsxs("div",{className:"py-2",children:[jsxRuntime.jsx("div",{className:"px-4 py-2",children:jsxRuntime.jsx("h4",{className:"text-xs font-semibold uppercase tracking-wider",style:{color:"var(--theme-text-secondary)"},children:i})}),jsxRuntime.jsx("div",{children:p.map(l=>jsxRuntime.jsxs("button",{onClick:()=>c(l),className:"w-full px-4 py-3 flex items-start gap-3 text-left transition-all active:scale-[0.98]",style:{color:"var(--theme-text-primary)"},onMouseEnter:d=>{d.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:d=>{d.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{className:"text-2xl leading-none mt-0.5",children:l.icon}),jsxRuntime.jsxs("div",{className:"flex-1 min-w-0",children:[jsxRuntime.jsx("div",{className:"font-semibold text-sm",style:{color:"var(--theme-text-primary)"},children:l.name}),l.description&&jsxRuntime.jsx("p",{className:"text-xs mt-0.5",style:{color:"var(--theme-text-tertiary)"},children:l.description})]})]},l.id))})]},i)),e.length===0&&jsxRuntime.jsx("div",{className:"px-4 py-8 text-center",style:{color:"var(--theme-text-tertiary)"},children:jsxRuntime.jsx("p",{className:"text-sm",children:"No templates available"})})]})]})}function ns({board:e,isOpen:t,onClose:r,onImport:a,boardElementRef:n,className:o}){let[s,c]=Se.useState("export"),[u,i]=Se.useState("json"),[p,l]=Se.useState(null),d=Se.useRef(null);if(!t)return null;let m=async()=>{let y=n?.current||void 0,h=await Mi(e,u,y);Ii(h,u);},v=async y=>{let h=y.target.files?.[0];if(h){try{let g=await Fi(h),b=h.name.endsWith(".json")?"json":"csv",f=Li(g,b);l(f),f.success&&a&&a(f,g);}catch(g){l({success:false,errors:[`Failed to read file: ${g instanceof Error?g.message:"Unknown error"}`]});}d.current&&(d.current.value="");}};return jsxRuntime.jsxs("div",{className:L("fixed inset-0 z-[9999] flex items-center justify-center",o),children:[jsxRuntime.jsx("div",{className:"absolute inset-0 bg-black/60 backdrop-blur-sm",onClick:r}),jsxRuntime.jsxs("div",{className:"relative bg-gradient-to-br from-gray-900/95 to-gray-800/95 backdrop-blur-xl rounded-2xl border border-white/20 shadow-2xl max-w-2xl w-full mx-4",children:[jsxRuntime.jsxs("div",{className:"px-6 py-5 border-b border-white/10 flex items-center justify-between",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("h2",{className:"text-2xl font-bold text-white flex items-center gap-3",children:[jsxRuntime.jsx("span",{className:"text-3xl",children:"\u{1F4E6}"}),"Export / Import"]}),jsxRuntime.jsx("p",{className:"text-sm text-white/60 mt-1",children:"Transfer your board data"})]}),jsxRuntime.jsx("button",{onClick:r,className:"text-white/50 hover:text-white transition-colors text-2xl leading-none p-2 hover:bg-white/10 rounded-lg","aria-label":"Close",children:"\xD7"})]}),jsxRuntime.jsxs("div",{className:"flex border-b border-white/10",children:[jsxRuntime.jsx("button",{onClick:()=>c("export"),className:L("flex-1 px-6 py-4 font-semibold transition-colors",s==="export"?"text-white border-b-2 border-blue-500":"text-white/50 hover:text-white/80"),children:"Export"}),jsxRuntime.jsx("button",{onClick:()=>c("import"),className:L("flex-1 px-6 py-4 font-semibold transition-colors",s==="import"?"text-white border-b-2 border-blue-500":"text-white/50 hover:text-white/80"),children:"Import"})]}),jsxRuntime.jsxs("div",{className:"p-6",children:[s==="export"&&jsxRuntime.jsxs("div",{className:"space-y-6",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{className:"block text-sm font-semibold text-white/90 mb-3",children:"Select format"}),jsxRuntime.jsx("div",{className:"grid grid-cols-3 gap-3",children:["json","csv","pdf"].map(y=>jsxRuntime.jsxs("button",{onClick:()=>i(y),className:L("p-4 rounded-lg border-2 transition-all text-center",u===y?"border-blue-500 bg-blue-500/20 text-white":"border-white/20 hover:border-white/40 text-white/70 hover:text-white"),children:[jsxRuntime.jsxs("div",{className:"text-2xl mb-2",children:[y==="json"&&"\u{1F4C4}",y==="csv"&&"\u{1F4CA}",y==="pdf"&&"\u{1F4DD}"]}),jsxRuntime.jsx("div",{className:"font-semibold uppercase text-xs",children:y})]},y))})]}),jsxRuntime.jsxs("div",{className:"bg-white/5 rounded-lg p-4",children:[jsxRuntime.jsx("h3",{className:"text-sm font-semibold text-white/90 mb-2",children:"Preview"}),jsxRuntime.jsxs("div",{className:"text-xs text-white/60",children:[jsxRuntime.jsxs("div",{children:["Board: ",jsxRuntime.jsx("span",{className:"text-white/90",children:e.title||"Untitled"})]}),jsxRuntime.jsxs("div",{children:["Columns: ",jsxRuntime.jsx("span",{className:"text-white/90",children:e.columns.length})]}),jsxRuntime.jsxs("div",{children:["Cards: ",jsxRuntime.jsx("span",{className:"text-white/90",children:e.cards.length})]})]})]}),jsxRuntime.jsx("button",{onClick:m,className:"w-full py-3 px-4 bg-gradient-to-r from-blue-600 to-blue-700 hover:from-blue-500 hover:to-blue-600 text-white font-semibold rounded-lg transition-all shadow-lg shadow-blue-500/20",children:"Export Board"})]}),s==="import"&&jsxRuntime.jsxs("div",{className:"space-y-6",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{className:"block text-sm font-semibold text-white/90 mb-3",children:"Upload file"}),jsxRuntime.jsx("input",{ref:d,type:"file",accept:".json,.csv",onChange:v,className:"hidden"}),jsxRuntime.jsxs("button",{onClick:()=>d.current?.click(),className:"w-full py-12 px-4 border-2 border-dashed border-white/30 hover:border-white/50 rounded-lg transition-colors text-white/70 hover:text-white",children:[jsxRuntime.jsx("div",{className:"text-5xl mb-3",children:"\u{1F4C1}"}),jsxRuntime.jsx("div",{className:"font-semibold mb-1",children:"Click to select file"}),jsxRuntime.jsx("div",{className:"text-xs text-white/50",children:"Supports JSON and CSV files"})]})]}),p&&jsxRuntime.jsxs("div",{className:L("p-4 rounded-lg",p.success?"bg-green-500/20 border border-green-500/30":"bg-red-500/20 border border-red-500/30"),children:[jsxRuntime.jsx("h3",{className:L("font-semibold mb-2",p.success?"text-green-400":"text-red-400"),children:p.success?"\u2713 Import Successful":"\u2717 Import Failed"}),p.success&&jsxRuntime.jsxs("div",{className:"text-sm text-white/80",children:[jsxRuntime.jsxs("div",{children:["Cards imported: ",p.cardsImported]}),jsxRuntime.jsxs("div",{children:["Columns imported: ",p.columnsImported]})]}),p.errors&&p.errors.length>0&&jsxRuntime.jsx("div",{className:"mt-2 text-sm",children:p.errors.map((y,h)=>jsxRuntime.jsxs("div",{className:"text-red-300",children:["\u2022 ",y]},h))})]})]})]})]})]})}var Mf=["URGENT","HIGH","MEDIUM","LOW"],If=[{value:"none",label:"None"},{value:"created",label:"Date Created"},{value:"priority",label:"Priority"},{value:"dueDate",label:"Due Date"},{value:"title",label:"Title"},{value:"estimate",label:"Estimate"}],Af=[{value:"none",label:"No Grouping"},{value:"priority",label:"By Priority"},{value:"assignee",label:"By Assignee"},{value:"label",label:"By Label"}];function os({filters:e,sort:t,onFiltersChange:r,onSortChange:a,onReset:n,onFilterMyTasks:o,onFilterOverdue:s,onFilterHighPriority:c,availableUsers:u=[],availableLabels:i=[],availableColumns:p=[],showQuickFilters:l=true,compact:d=false,groupBy:m="none",onGroupByChange:v}){let[y,h]=Se.useState(true),g=Se.useCallback(x=>{r({search:x.target.value});},[r]),b=Se.useCallback(x=>{r({dateFilter:x.target.value});},[r]),f=Se.useCallback(x=>{a({by:x.target.value});},[a]),k=Se.useCallback(()=>{a({order:t.order==="asc"?"desc":"asc"});},[t.order,a]),w=e.search||e.dateFilter!=="all"||e.priorities.length>0||e.assignees.length>0||e.labels.length>0||t.by!=="none";return jsxRuntime.jsxs("div",{className:`filter-bar ${d?"filter-bar--compact":""} ${y?"filter-bar--collapsed":""}`,children:[jsxRuntime.jsxs("div",{className:"filter-bar__header",onClick:()=>h(!y),style:{cursor:"pointer",display:"flex",alignItems:"center",gap:"8px",marginBottom:y?"0":"12px",padding:"4px 6px",borderRadius:"6px",transition:"all 0.2s ease"},onMouseEnter:x=>{x.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:x=>{x.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",style:{transform:y?"rotate(-90deg)":"rotate(0deg)",transition:"transform 0.2s",color:"var(--theme-text-secondary)"},children:jsxRuntime.jsx("polyline",{points:"6 9 12 15 18 9"})}),jsxRuntime.jsx("span",{className:"filter-bar__label",style:{fontWeight:500,fontSize:"0.875rem",color:"var(--theme-text-primary)"},children:"Filters & Grouping"}),w&&jsxRuntime.jsxs("span",{style:{color:"var(--theme-accent-primary)",fontSize:"0.75rem",fontWeight:600},children:["(",[e.search&&"search",e.dateFilter!=="all"&&"date",e.priorities.length>0&&"priority",e.assignees.length>0&&"assignee",e.labels.length>0&&"label",t.by!=="none"&&"sort"].filter(Boolean).length," active)"]})]}),!y&&jsxRuntime.jsxs("div",{className:"filter-bar__content",children:[l&&jsxRuntime.jsxs("div",{className:"filter-bar__quick",style:{marginBottom:"12px"},children:[jsxRuntime.jsx("span",{className:"filter-bar__label",children:"Quick:"}),o&&jsxRuntime.jsx("button",{onClick:o,className:"filter-bar__quick-btn",title:"Show only my tasks",children:"My Tasks"}),s&&jsxRuntime.jsx("button",{onClick:s,className:"filter-bar__quick-btn",title:"Show overdue tasks",children:"Overdue"}),c&&jsxRuntime.jsx("button",{onClick:c,className:"filter-bar__quick-btn",title:"Show high priority tasks",children:"High Priority"})]}),jsxRuntime.jsxs("div",{className:"filter-bar__main",children:[jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsx("input",{type:"text",placeholder:"Search tasks...",value:e.search,onChange:g,className:"filter-bar__search"})}),jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.dateFilter,onChange:b,className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Dates"}),jsxRuntime.jsx("option",{value:"overdue",children:"Overdue"}),jsxRuntime.jsx("option",{value:"today",children:"Today"}),jsxRuntime.jsx("option",{value:"this-week",children:"This Week"})]})}),jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.priorities[0]||"all",onChange:x=>{let D=x.target.value;r({priorities:D==="all"?[]:[D]});},className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Priorities"}),Mf.map(x=>jsxRuntime.jsx("option",{value:x,children:x},x))]})}),u.length>0&&jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.assignees[0]||"all",onChange:x=>{let D=x.target.value;r({assignees:D==="all"?[]:[D]});},className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Assignees"}),u.map(x=>jsxRuntime.jsx("option",{value:x.id,children:x.name},x.id))]})}),i.length>0&&jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.labels[0]||"all",onChange:x=>{let D=x.target.value;r({labels:D==="all"?[]:[D]});},className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Labels"}),i.map(x=>jsxRuntime.jsx("option",{value:x,children:x},x))]})}),jsxRuntime.jsxs("div",{className:"filter-bar__field filter-bar__sort",children:[jsxRuntime.jsx("span",{className:"filter-bar__label",style:{color:"var(--theme-text-secondary)"},children:"Sort:"}),jsxRuntime.jsx("select",{value:t.by,onChange:f,className:"filter-bar__select filter-bar__select--sm",children:If.map(x=>jsxRuntime.jsx("option",{value:x.value,children:x.label},x.value))}),t.by!=="none"&&jsxRuntime.jsx("button",{onClick:k,className:"filter-bar__sort-toggle",title:`Sort ${t.order==="asc"?"descending":"ascending"}`,children:t.order==="asc"?"\u2191":"\u2193"})]}),v&&jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsx("select",{value:m,onChange:x=>v(x.target.value),className:"filter-bar__select",style:{fontWeight:500,borderWidth:"2px"},children:Af.map(x=>jsxRuntime.jsx("option",{value:x.value,children:x.label},x.value))})}),w&&jsxRuntime.jsx("button",{onClick:n,className:"filter-bar__reset",title:"Clear all filters",children:"Clear"})]})]})]})}function ss({onOpenExport:e,onOpenThemes:t,onOpenShortcuts:r,className:a,viewMode:n="kanban",onExportGanttPDF:o,onExportGanttExcel:s,onExportGanttPNG:c,onExportGanttCSV:u}){let[i,p]=Se.useState(false),l=Se.useRef(null);Se.useEffect(()=>{let m=v=>{l.current&&!l.current.contains(v.target)&&p(false);};return i&&document.addEventListener("mousedown",m),()=>{document.removeEventListener("mousedown",m);}},[i]);let d=m=>{m(),p(false);};return jsxRuntime.jsxs("div",{className:L("relative",a),ref:l,children:[jsxRuntime.jsxs("button",{onClick:()=>p(!i),className:"flex items-center gap-2 px-3 py-2 rounded-lg text-sm font-medium transition-all border",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)",color:"var(--theme-text-secondary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)",m.currentTarget.style.color="var(--theme-text-primary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-secondary)",m.currentTarget.style.color="var(--theme-text-secondary)";},"aria-label":"Configuration Menu","aria-expanded":i,children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"3"}),jsxRuntime.jsx("path",{d:"M12 1v6m0 6v6M5.6 5.6l4.2 4.2m4.2 4.2l4.2 4.2M1 12h6m6 0h6M5.6 18.4l4.2-4.2m4.2-4.2l4.2-4.2"})]}),jsxRuntime.jsx("span",{children:"Config"})]}),i&&jsxRuntime.jsxs("div",{className:"absolute right-0 mt-2 w-48 rounded-lg border shadow-lg overflow-hidden z-50",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)"},children:[n==="kanban"?jsxRuntime.jsxs("button",{onClick:()=>d(e),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4M7 10l5 5 5-5M12 15V3"})}),"Export"]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("button",{onClick:()=>d(async()=>await o?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),jsxRuntime.jsx("polyline",{points:"14 2 14 8 20 8"}),jsxRuntime.jsx("line",{x1:"16",y1:"13",x2:"8",y2:"13"}),jsxRuntime.jsx("line",{x1:"16",y1:"17",x2:"8",y2:"17"}),jsxRuntime.jsx("polyline",{points:"10 9 9 9 8 9"})]}),"Export PDF"]}),jsxRuntime.jsxs("button",{onClick:()=>d(async()=>await s?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),jsxRuntime.jsx("polyline",{points:"14 2 14 8 20 8"}),jsxRuntime.jsx("line",{x1:"12",y1:"18",x2:"12",y2:"12"}),jsxRuntime.jsx("line",{x1:"9",y1:"15",x2:"15",y2:"15"})]}),"Export Excel"]}),jsxRuntime.jsxs("button",{onClick:()=>d(async()=>await c?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("rect",{x:"3",y:"3",width:"18",height:"18",rx:"2",ry:"2"}),jsxRuntime.jsx("circle",{cx:"8.5",cy:"8.5",r:"1.5"}),jsxRuntime.jsx("polyline",{points:"21 15 16 10 5 21"})]}),"Export PNG"]}),jsxRuntime.jsxs("button",{onClick:()=>d(()=>u?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),jsxRuntime.jsx("polyline",{points:"14 2 14 8 20 8"}),jsxRuntime.jsx("line",{x1:"8",y1:"13",x2:"16",y2:"13"}),jsxRuntime.jsx("line",{x1:"8",y1:"17",x2:"16",y2:"17"})]}),"Export CSV"]})]}),jsxRuntime.jsxs("button",{onClick:()=>d(t),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"5"}),jsxRuntime.jsx("path",{d:"M12 1v6m0 6v6m8.5-8.5L17 15M7 9L3.5 5.5M7 15l-3.5 3.5M20.5 5.5L17 9m3.5 11.5L17 17"})]}),"Themes"]}),jsxRuntime.jsxs("button",{onClick:()=>d(r),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("rect",{x:"2",y:"4",width:"20",height:"16",rx:"2"}),jsxRuntime.jsx("path",{d:"M6 8h.01M10 8h.01M14 8h.01M18 8h.01M8 12h.01M12 12h.01M16 12h.01M7 16h10"})]}),"Shortcuts"]})]})]})}var is={name:"dark",displayName:"Dark (Enhanced)",emoji:"\u{1F319}",colors:{bgPrimary:"#222326",bgSecondary:"#2A2B2F",bgTertiary:"#33343A",bgCard:"#2d2d2d",bgHover:"#353535",bgActive:"#404040",bgInput:"#2a2a2a",textPrimary:"#F4F5F8",textSecondary:"#AEB6C0",textTertiary:"#7A7F8A",textDisabled:"#606060",textInverse:"#1a1a1a",borderPrimary:"rgba(255, 255, 255, 0.1)",borderSecondary:"rgba(255, 255, 255, 0.05)",borderDefault:"#404040",borderHover:"#505050",borderSubtle:"#2a2a2a",accentPrimary:"#5E6AD2",accentHover:"#7780DD",interactivePrimary:"#0ea5e9",interactivePrimaryHover:"#0284c7",interactivePrimaryBorder:"rgba(14, 165, 233, 0.3)",interactivePrimaryBackground:"rgba(14, 165, 233, 0.1)",interactivePrimaryBackgroundHover:"rgba(14, 165, 233, 0.2)",success:"#10B981",warning:"#F59E0B",error:"#EF4444",info:"#3B82F6",danger:"#ef4444",dangerBorder:"rgba(239, 68, 68, 0.3)",dangerBackground:"rgba(239, 68, 68, 0.1)",dangerBackgroundHover:"rgba(239, 68, 68, 0.2)"},shadows:{sm:"0 1px 2px rgba(0, 0, 0, 0.3)",md:"0 4px 12px rgba(0, 0, 0, 0.4)",lg:"0 12px 32px rgba(0, 0, 0, 0.5)"},radii:{sm:"6px",md:"8px",lg:"12px",full:"9999px"},spacing:{xs:"4px",sm:"8px",md:"16px",lg:"24px",xl:"32px"}},ls={name:"light",displayName:"Light (Standard)",emoji:"\u2600\uFE0F",colors:{bgPrimary:"#FFFFFF",bgSecondary:"#F7F7F8",bgTertiary:"#EEEFF1",bgCard:"#ffffff",bgHover:"#f3f4f6",bgActive:"#e5e7eb",bgInput:"#f9fafb",textPrimary:"#1A1A1A",textSecondary:"#5A5A5A",textTertiary:"#8A8A8A",textDisabled:"#d1d5db",textInverse:"#ffffff",borderPrimary:"rgba(0, 0, 0, 0.1)",borderSecondary:"rgba(0, 0, 0, 0.05)",borderDefault:"#e5e7eb",borderHover:"#d1d5db",borderSubtle:"#f3f4f6",accentPrimary:"#5E6AD2",accentHover:"#4A56B8",interactivePrimary:"#0ea5e9",interactivePrimaryHover:"#0284c7",interactivePrimaryBorder:"rgba(14, 165, 233, 0.3)",interactivePrimaryBackground:"rgba(14, 165, 233, 0.08)",interactivePrimaryBackgroundHover:"rgba(14, 165, 233, 0.15)",success:"#059669",warning:"#D97706",error:"#DC2626",info:"#2563EB",danger:"#dc2626",dangerBorder:"rgba(220, 38, 38, 0.3)",dangerBackground:"rgba(220, 38, 38, 0.08)",dangerBackgroundHover:"rgba(220, 38, 38, 0.15)"},shadows:{sm:"0 1px 3px rgba(0, 0, 0, 0.12)",md:"0 4px 12px rgba(0, 0, 0, 0.15)",lg:"0 12px 32px rgba(0, 0, 0, 0.2)"},radii:{sm:"6px",md:"8px",lg:"12px",full:"9999px"},spacing:{xs:"4px",sm:"8px",md:"16px",lg:"24px",xl:"32px"}},cs={name:"neutral",emoji:"\u26AA",displayName:"Neutral (Zen)",colors:{bgPrimary:"#FAFAF9",bgSecondary:"#F5F5F4",bgTertiary:"#E7E5E4",bgCard:"#FEFEFE",bgHover:"#F0EFEE",bgActive:"#E7E5E4",bgInput:"#FAFAF9",textPrimary:"#1C1917",textSecondary:"#57534E",textTertiary:"#A8A29E",textDisabled:"#D6D3D1",textInverse:"#FAFAF9",borderPrimary:"#E7E5E4",borderSecondary:"#F0EFEE",borderDefault:"#E7E5E4",borderHover:"#D6D3D1",borderSubtle:"#F5F5F4",accentPrimary:"#292524",accentHover:"#44403C",interactivePrimary:"#292524",interactivePrimaryHover:"#44403C",interactivePrimaryBorder:"rgba(41, 37, 36, 0.3)",interactivePrimaryBackground:"rgba(41, 37, 36, 0.06)",interactivePrimaryBackgroundHover:"rgba(41, 37, 36, 0.12)",success:"#15803D",warning:"#CA8A04",error:"#B91C1C",info:"#1D4ED8",danger:"#B91C1C",dangerBorder:"rgba(185, 28, 28, 0.3)",dangerBackground:"rgba(185, 28, 28, 0.08)",dangerBackgroundHover:"rgba(185, 28, 28, 0.15)"},shadows:{sm:"0 1px 3px rgba(0, 0, 0, 0.1)",md:"0 4px 12px rgba(0, 0, 0, 0.12)",lg:"0 12px 32px rgba(0, 0, 0, 0.15)"},radii:{sm:"6px",md:"8px",lg:"12px",full:"9999px"},spacing:{xs:"4px",sm:"8px",md:"16px",lg:"24px",xl:"32px"}},Yr={dark:is,light:ls,neutral:cs},Ln="dark";var Fn=Se.createContext(void 0),_f="asakaa-theme";function ac({children:e,defaultTheme:t=Ln,storageKey:r=_f}){let[a,n]=Se.useState(()=>{if(typeof window<"u"){let c=localStorage.getItem(r);if(c&&(c==="dark"||c==="light"||c==="neutral"))return c}return t}),o=Se.useCallback(c=>{n(c),typeof window<"u"&&localStorage.setItem(r,c);},[r]);Se.useEffect(()=>{if(typeof window>"u")return;let c=document.documentElement,u=Yr[a];Object.entries(u.colors).forEach(([p,l])=>{l&&c.style.setProperty(`--theme-${Hf(p)}`,l);}),Object.entries({bgPrimary:"--asakaa-color-background-primary",bgSecondary:"--asakaa-color-background-secondary",bgTertiary:"--asakaa-color-background-tertiary",bgCard:"--asakaa-color-background-card",bgHover:"--asakaa-color-background-hover",bgActive:"--asakaa-color-background-active",bgInput:"--asakaa-color-background-input",textPrimary:"--asakaa-color-text-primary",textSecondary:"--asakaa-color-text-secondary",textTertiary:"--asakaa-color-text-tertiary",textDisabled:"--asakaa-color-text-disabled",textInverse:"--asakaa-color-text-inverse",borderPrimary:"--asakaa-color-border-primary",borderSecondary:"--asakaa-color-border-secondary",borderDefault:"--asakaa-color-border-default",borderHover:"--asakaa-color-border-hover",borderSubtle:"--asakaa-color-border-subtle",accentPrimary:"--asakaa-color-accent-primary",accentHover:"--asakaa-color-accent-hover",interactivePrimary:"--asakaa-color-interactive-primary",interactivePrimaryHover:"--asakaa-color-interactive-primaryHover",interactivePrimaryBorder:"--asakaa-color-interactive-primaryBorder",interactivePrimaryBackground:"--asakaa-color-interactive-primaryBackground",interactivePrimaryBackgroundHover:"--asakaa-color-interactive-primaryBackgroundHover",success:"--asakaa-color-status-success",warning:"--asakaa-color-status-warning",error:"--asakaa-color-status-error",info:"--asakaa-color-status-info",danger:"--asakaa-color-danger",dangerBorder:"--asakaa-color-danger-border",dangerBackground:"--asakaa-color-danger-background",dangerBackgroundHover:"--asakaa-color-danger-backgroundHover"}).forEach(([p,l])=>{let d=u.colors[p];d&&c.style.setProperty(l,d);}),c.setAttribute("data-theme",a),c.classList.remove("theme-dark","theme-light","theme-neutral"),c.classList.add(`theme-${a}`);},[a]);let s={theme:a,setTheme:o,themes:Yr};return jsxRuntime.jsx(Fn.Provider,{value:s,children:e})}function pa(){let e=Se.useContext(Fn);if(!e)throw new Error("useTheme must be used within ThemeProvider");return e}function Hf(e){return e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase()}function ds({isOpen:e,onClose:t,className:r}){let{theme:a,setTheme:n}=pa();return e?jsxRuntime.jsxs("div",{className:L("fixed inset-0 z-[9999] flex items-center justify-center",r),children:[jsxRuntime.jsx("div",{className:"absolute inset-0 bg-black/60 backdrop-blur-sm",onClick:t}),jsxRuntime.jsxs("div",{className:"relative rounded-2xl border shadow-2xl max-w-md w-full mx-4",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)"},children:[jsxRuntime.jsxs("div",{className:"px-6 py-5 border-b flex items-center justify-between",style:{borderColor:"var(--theme-border-primary)"},children:[jsxRuntime.jsx("h2",{className:"text-2xl font-bold",style:{color:"var(--theme-text-primary)"},children:"Select Theme"}),jsxRuntime.jsx("button",{onClick:t,className:"text-2xl leading-none p-2 hover:bg-white/10 rounded-lg transition-colors",style:{color:"var(--theme-text-secondary)"},"aria-label":"Close",children:"\xD7"})]}),jsxRuntime.jsx("div",{className:"p-6 space-y-3",children:Object.entries(Yr).map(([o,s])=>jsxRuntime.jsxs("button",{onClick:()=>{n(o),t();},className:L("w-full p-4 rounded-lg border-2 transition-all flex items-center gap-4",a===o?"border-blue-500 bg-blue-500/20":"border-white/20 hover:border-white/40"),style:{backgroundColor:a===o?"var(--theme-accent-primary)20":"transparent"},children:[jsxRuntime.jsx("div",{className:"text-3xl",children:s.emoji}),jsxRuntime.jsxs("div",{className:"text-left flex-1",children:[jsxRuntime.jsx("div",{className:"font-semibold",style:{color:"var(--theme-text-primary)"},children:s.displayName}),jsxRuntime.jsxs("div",{className:"text-xs",style:{color:"var(--theme-text-secondary)"},children:[o==="dark"&&"Default dark theme with Linear-inspired colors",o==="light"&&"Clean light theme with high contrast",o==="neutral"&&"Monochrome zen theme"]})]}),a===o&&jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"3",children:jsxRuntime.jsx("path",{d:"M20 6L9 17l-5-5"})})]},o))})]})]}):null}var Ce={dark:{bgPrimary:"#1A1D21",bgSecondary:"#23272E",bgGrid:"#1C1F24",bgWeekend:"rgba(59, 130, 246, 0.02)",border:"#2D3139",borderLight:"#26292F",textPrimary:"#F5F5F7",textSecondary:"#B4B9C5",textTertiary:"#7C8394",accent:"#3B82F6",accentHover:"#60A5FA",accentLight:"rgba(59, 130, 246, 0.12)",taskBarPrimary:"#3B82F6",taskBarProgress:"#2563EB",taskBarHandle:"#FFFFFF",dependency:"rgba(180, 185, 197, 0.25)",dependencyHover:"rgba(180, 185, 197, 0.45)",criticalPath:"#EF4444",criticalPathLight:"rgba(239, 68, 68, 0.12)",today:"#EF4444",todayLight:"rgba(239, 68, 68, 0.08)",milestone:"#F59E0B",milestoneLight:"rgba(245, 158, 11, 0.1)",statusTodo:"#7C8394",statusInProgress:"#3B82F6",statusCompleted:"#10B981",hoverBg:"rgba(255, 255, 255, 0.05)",focusRing:"#3B82F6"},light:{bgPrimary:"#FFFFFF",bgSecondary:"#F9FAFB",bgGrid:"#FDFEFE",bgWeekend:"rgba(37, 99, 235, 0.02)",border:"#E5E7EB",borderLight:"#F0F1F3",textPrimary:"#111827",textSecondary:"#4B5563",textTertiary:"#9CA3AF",accent:"#2563EB",accentHover:"#1D4ED8",accentLight:"rgba(37, 99, 235, 0.08)",taskBarPrimary:"#2563EB",taskBarProgress:"#1E40AF",taskBarHandle:"#FFFFFF",dependency:"rgba(75, 85, 99, 0.2)",dependencyHover:"rgba(75, 85, 99, 0.4)",criticalPath:"#DC2626",criticalPathLight:"rgba(220, 38, 38, 0.1)",today:"#2563EB",todayLight:"rgba(37, 99, 235, 0.08)",milestone:"#F59E0B",milestoneLight:"rgba(245, 158, 11, 0.08)",statusTodo:"#9CA3AF",statusInProgress:"#2563EB",statusCompleted:"#059669",hoverBg:"rgba(0, 0, 0, 0.03)",focusRing:"#2563EB"},neutral:{bgPrimary:"#FAFAF9",bgSecondary:"#F5F5F4",bgGrid:"#FBFBFA",bgWeekend:"rgba(41, 37, 36, 0.015)",border:"#E7E5E4",borderLight:"#F0EFEE",textPrimary:"#1C1917",textSecondary:"#57534E",textTertiary:"#A8A29E",accent:"#292524",accentHover:"#44403C",accentLight:"rgba(41, 37, 36, 0.06)",taskBarPrimary:"#292524",taskBarProgress:"#1C1917",taskBarHandle:"#FFFFFF",dependency:"rgba(87, 83, 78, 0.2)",dependencyHover:"rgba(87, 83, 78, 0.35)",criticalPath:"#44403C",criticalPathLight:"rgba(68, 64, 60, 0.08)",today:"#1C1917",todayLight:"rgba(28, 25, 23, 0.04)",milestone:"#57534E",milestoneLight:"rgba(87, 83, 78, 0.06)",statusTodo:"#A8A29E",statusInProgress:"#292524",statusCompleted:"#15803D",hoverBg:"rgba(0, 0, 0, 0.025)",focusRing:"#292524"}};function nc(e="dark"){if(typeof window>"u"||typeof getComputedStyle>"u")return Ce[e]||Ce.dark;let t=document.documentElement,r=getComputedStyle(t),a=(o,s)=>r.getPropertyValue(o).trim()||s;return {bgPrimary:a("--theme-bg-primary",Ce[e].bgPrimary),bgSecondary:a("--theme-bg-secondary",Ce[e].bgSecondary),bgGrid:a("--theme-bg-card",Ce[e].bgGrid),bgWeekend:a("--theme-bg-hover",Ce[e].bgWeekend),border:a("--theme-border-primary",Ce[e].border),borderLight:a("--theme-border-subtle",Ce[e].borderLight),textPrimary:a("--theme-text-primary",Ce[e].textPrimary),textSecondary:a("--theme-text-secondary",Ce[e].textSecondary),textTertiary:a("--theme-text-tertiary",Ce[e].textTertiary),accent:a("--theme-accent-primary",Ce[e].accent),accentHover:a("--theme-accent-hover",Ce[e].accentHover),accentLight:a("--theme-accent-primary",Ce[e].accentLight),taskBarPrimary:a("--theme-accent-primary",Ce[e].taskBarPrimary),taskBarProgress:a("--theme-accent-hover",Ce[e].taskBarProgress),taskBarHandle:a("--theme-text-inverse",Ce[e].taskBarHandle||"#FFFFFF"),dependency:a("--theme-border-secondary",Ce[e].dependency),dependencyHover:a("--theme-border-secondary",Ce[e].dependencyHover),criticalPath:a("--theme-error",Ce[e].criticalPath),criticalPathLight:a("--theme-error",Ce[e].criticalPathLight),today:e==="light"?a("--theme-accent-primary",Ce[e].today):e==="neutral"?a("--theme-text-primary",Ce[e].today):a("--theme-error",Ce[e].today),todayLight:e==="light"?a("--theme-accent-primary",Ce[e].todayLight):e==="neutral"?a("--theme-text-primary",Ce[e].todayLight):a("--theme-error",Ce[e].todayLight),milestone:a("--theme-warning",Ce[e].milestone),milestoneLight:a("--theme-warning",Ce[e].milestoneLight),statusTodo:a("--theme-text-tertiary",Ce[e].statusTodo),statusInProgress:a("--theme-accent-primary",Ce[e].statusInProgress),statusCompleted:a("--theme-success",Ce[e].statusCompleted),hoverBg:a("--theme-bg-hover",Ce[e].hoverBg),focusRing:a("--theme-accent-primary",Ce[e].focusRing)}}var Bn={columns:{taskName:"TASK NAME",startDate:"Start Date",endDate:"End Date",duration:"Duration",assignees:"Assignees",status:"Status",progress:"% Complete"},toolbar:{today:"Today",day:"Day",week:"Week",month:"Month",export:"Export",exportPdf:"Export to PDF",exportPng:"Export to PNG",exportCsv:"Export to CSV",exportExcel:"Export to Excel",exportMsProject:"Export to MS Project",undo:"Undo",redo:"Redo",createTask:"New Task",density:"Row Density",compact:"Compact",normal:"Normal",spacious:"Spacious"},contextMenu:{editTask:"Edit Task",addSubtask:"Add Subtask",markIncomplete:"Mark Incomplete",setInProgress:"Set In Progress",markComplete:"Mark Complete",splitTask:"Split Task",deleteTask:"Delete Task"},actions:{edit:"Edit",delete:"Delete",duplicate:"Duplicate",addSubtask:"Add Subtask",indent:"Indent",outdent:"Outdent",moveUp:"Move Up",moveDown:"Move Down",splitTask:"Split Task",linkTasks:"Link Tasks",unlinkTasks:"Unlink Tasks"},status:{todo:"To Do",inProgress:"In Progress",completed:"Completed"},labels:{progress:"Progress",duration:"Duration",days:"days",day:"day",assigned:"Assigned",milestone:"Milestone",criticalPath:"Critical Path",subtask:"Subtask",task:"Task",noTasks:"No tasks yet",addTask:"Add task",newTask:"New Task",loading:"Loading...",error:"Error",today:"Today"},ai:{placeholder:'Ask AI to edit tasks... (e.g., "Move Design to next week")',thinking:"Thinking...",suggestions:{moveTask:'Move "Task Name" to next Monday',extendTask:'Extend "Task Name" by 3 days',renameTask:'Rename "Old Name" to "New Name"',setProgress:'Set "Task Name" progress to 50%',linkTasks:'Link "Task A" to "Task B"',createTask:'Create a new task called "New Task"',deleteTask:'Delete "Task Name"',assignTask:'Assign John to "Task Name"'},errors:{taskNotFound:"Task not found",invalidDate:"Invalid date",invalidDuration:"Invalid duration",invalidProgress:"Invalid progress value",unknownCommand:"Unknown command",processingError:"Error processing command"}},export:{projectName:"Gantt Project",ganttTasks:"Gantt Tasks",taskId:"Task ID",taskName:"Task Name",startDate:"Start Date",endDate:"End Date",isMilestone:"Is Milestone",parentId:"Parent ID",yes:"Yes",no:"No",noTasksToExport:"No tasks available to export"},dateFormat:{short:"MM/dd",medium:"MMM d",long:"MMMM d, yyyy"}},oc={columns:{taskName:"NOMBRE DE TAREA",startDate:"Fecha Inicio",endDate:"Fecha Fin",duration:"Duraci\xF3n",assignees:"Asignados",status:"Estado",progress:"% Completado"},toolbar:{today:"Hoy",day:"D\xEDa",week:"Semana",month:"Mes",export:"Exportar",exportPdf:"Exportar a PDF",exportPng:"Exportar a PNG",exportCsv:"Exportar a CSV",exportExcel:"Exportar a Excel",exportMsProject:"Exportar a MS Project",undo:"Deshacer",redo:"Rehacer",createTask:"Nueva Tarea",density:"Densidad",compact:"Compacto",normal:"Normal",spacious:"Espacioso"},contextMenu:{editTask:"Editar Tarea",addSubtask:"Agregar Subtarea",markIncomplete:"Marcar Incompleta",setInProgress:"Marcar En Progreso",markComplete:"Marcar Completada",splitTask:"Dividir Tarea",deleteTask:"Eliminar Tarea"},actions:{edit:"Editar",delete:"Eliminar",duplicate:"Duplicar",addSubtask:"Agregar Subtarea",indent:"Aumentar Nivel",outdent:"Disminuir Nivel",moveUp:"Mover Arriba",moveDown:"Mover Abajo",splitTask:"Dividir Tarea",linkTasks:"Vincular Tareas",unlinkTasks:"Desvincular Tareas"},status:{todo:"Por Hacer",inProgress:"En Progreso",completed:"Completado"},labels:{progress:"Progreso",duration:"Duraci\xF3n",days:"d\xEDas",day:"d\xEDa",assigned:"Asignado",milestone:"Hito",criticalPath:"Ruta Cr\xEDtica",subtask:"Subtarea",task:"Tarea",noTasks:"Sin tareas a\xFAn",addTask:"Agregar tarea",newTask:"Nueva Tarea",loading:"Cargando...",error:"Error",today:"Hoy"},ai:{placeholder:'P\xEDdele a la IA que edite tareas... (ej: "Mover Dise\xF1o a la pr\xF3xima semana")',thinking:"Pensando...",suggestions:{moveTask:'Mover "Nombre de Tarea" al pr\xF3ximo lunes',extendTask:'Extender "Nombre de Tarea" por 3 d\xEDas',renameTask:'Renombrar "Nombre Anterior" a "Nombre Nuevo"',setProgress:'Establecer progreso de "Nombre de Tarea" al 50%',linkTasks:'Vincular "Tarea A" con "Tarea B"',createTask:'Crear una nueva tarea llamada "Nueva Tarea"',deleteTask:'Eliminar "Nombre de Tarea"',assignTask:'Asignar a Juan a "Nombre de Tarea"'},errors:{taskNotFound:"Tarea no encontrada",invalidDate:"Fecha inv\xE1lida",invalidDuration:"Duraci\xF3n inv\xE1lida",invalidProgress:"Valor de progreso inv\xE1lido",unknownCommand:"Comando desconocido",processingError:"Error procesando el comando"}},export:{projectName:"Proyecto Gantt",ganttTasks:"Tareas Gantt",taskId:"ID de Tarea",taskName:"Nombre de Tarea",startDate:"Fecha Inicio",endDate:"Fecha Fin",isMilestone:"Es Hito",parentId:"ID Padre",yes:"S\xED",no:"No",noTasksToExport:"No hay tareas disponibles para exportar"},dateFormat:{short:"dd/MM",medium:"d MMM",long:"d de MMMM de yyyy"}},us={en:Bn,es:oc};function sc(e){return us[e]||us.en}function ms(e,t){let r=sc(e);return t?{columns:{...r.columns,...t.columns},toolbar:{...r.toolbar,...t.toolbar},contextMenu:{...r.contextMenu,...t.contextMenu},actions:{...r.actions,...t.actions},status:{...r.status,...t.status},labels:{...r.labels,...t.labels},ai:{...r.ai,...t.ai,suggestions:{...r.ai.suggestions,...t.ai?.suggestions},errors:{...r.ai.errors,...t.ai?.errors}},export:{...r.export,...t.export},dateFormat:{...r.dateFormat,...t.dateFormat}}:r}var ga=Se.createContext(Bn);function Ha(){return Se.useContext(ga)}function ig({theme:e,onExportPNG:t,onExportPDF:r,onExportExcel:a,onExportCSV:n,onExportJSON:o,onExportMSProject:s}){let[c,u]=Se.useState(false),[i,p]=Se.useState(null),l=Se.useRef(null),d=Ha();if(Se.useEffect(()=>{let h=g=>{l.current&&!l.current.contains(g.target)&&u(false);};return c&&document.addEventListener("mousedown",h),()=>document.removeEventListener("mousedown",h)},[c]),!(t||r||a||n||o||s))return null;let v=[{id:"png",label:"PNG",description:"Image",icon:jsxRuntime.jsx(lucideReact.FileImage,{className:"w-4 h-4"}),handler:t},{id:"pdf",label:"PDF",description:"Document",icon:jsxRuntime.jsx(lucideReact.FileText,{className:"w-4 h-4"}),handler:r},{id:"excel",label:"Excel",description:"Spreadsheet",icon:jsxRuntime.jsx(lucideReact.FileSpreadsheet,{className:"w-4 h-4"}),handler:a},{id:"csv",label:"CSV",description:"Comma-separated",icon:jsxRuntime.jsx(lucideReact.FileText,{className:"w-4 h-4"}),handler:n},{id:"json",label:"JSON",description:"Data",icon:jsxRuntime.jsx(lucideReact.FileJson,{className:"w-4 h-4"}),handler:o},{id:"msproject",label:"MS Project",description:"XML",icon:jsxRuntime.jsx(lucideReact.FolderKanban,{className:"w-4 h-4"}),handler:s}].filter(h=>h.handler),y=async(h,g)=>{if(g){p(h);try{await g();}catch(b){console.error(`Export ${h} failed:`,b);}finally{p(null),u(false);}}};return jsxRuntime.jsxs("div",{ref:l,className:"relative",children:[jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>u(!c),className:"flex items-center gap-2 px-3 py-1.5 rounded-lg text-xs transition-all",style:{backgroundColor:c?e.accent:e.bgSecondary,border:`1px solid ${c?e.accent:e.borderLight}`,color:c?"#FFFFFF":e.textSecondary,fontFamily:"Inter, sans-serif",fontWeight:500},whileHover:{scale:1.02,backgroundColor:e.accent,color:"#FFFFFF"},whileTap:{scale:.98},children:[jsxRuntime.jsx(lucideReact.Download,{className:"w-3.5 h-3.5"}),jsxRuntime.jsx("span",{children:d.toolbar.export}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3 transition-transform",style:{transform:c?"rotate(180deg)":"rotate(0deg)"}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:c&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-8,scale:.95},animate:{opacity:1,y:0,scale:1},exit:{opacity:0,y:-8,scale:.95},transition:{duration:.15,ease:"easeOut"},className:"absolute right-0 mt-2 w-48 rounded-lg overflow-hidden z-50",style:{backgroundColor:e.bgSecondary,border:`1px solid ${e.border}`,boxShadow:"0 10px 40px rgba(0, 0, 0, 0.25)"},children:jsxRuntime.jsx("div",{className:"py-1",children:v.map((h,g)=>jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>y(h.id,h.handler),disabled:i!==null,className:"w-full flex items-center gap-3 px-3 py-2.5 text-left transition-all",style:{backgroundColor:"transparent",borderBottom:g<v.length-1?`1px solid ${e.borderLight}`:"none"},whileHover:{backgroundColor:e.hoverBg},initial:{opacity:0,x:-10},animate:{opacity:1,x:0},transition:{delay:g*.03},children:[jsxRuntime.jsx("div",{className:"flex items-center justify-center w-8 h-8 rounded-md",style:{backgroundColor:e.accentLight,color:e.accent},children:i===h.id?jsxRuntime.jsx(framerMotion.motion.div,{animate:{rotate:360},transition:{duration:1,repeat:1/0,ease:"linear"},children:jsxRuntime.jsx(lucideReact.Download,{className:"w-4 h-4"})}):h.icon}),jsxRuntime.jsxs("div",{className:"flex-1 min-w-0",children:[jsxRuntime.jsx("div",{className:"text-xs font-medium truncate",style:{color:e.textPrimary},children:h.label}),jsxRuntime.jsx("div",{className:"text-[10px] truncate",style:{color:e.textTertiary},children:h.description})]})]},h.id))})})})]})}function lg({options:e,value:t,onChange:r,theme:a,layoutId:n="activeSegment"}){return jsxRuntime.jsx("div",{className:"inline-flex p-1 rounded-lg relative",style:{backgroundColor:a.bgSecondary,border:`1px solid ${a.borderLight}`},children:e.map(o=>{let s=t===o.value;return jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>r(o.value),className:"relative px-3 py-1.5 rounded-md text-xs transition-all flex items-center gap-1.5 min-w-[70px] justify-center",style:{color:s?a.textPrimary:a.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:s?600:500,zIndex:s?2:1},whileHover:{scale:1.02},whileTap:{scale:.98},children:[s&&jsxRuntime.jsx(framerMotion.motion.div,{layoutId:n,className:"absolute inset-0 rounded-md",style:{backgroundColor:a.accent,boxShadow:"0 1px 3px rgba(0, 0, 0, 0.1)"},transition:{type:"spring",stiffness:400,damping:30}}),o.icon&&jsxRuntime.jsx("span",{className:"relative z-10",style:{color:s?"#FFFFFF":a.textTertiary},children:o.icon}),jsxRuntime.jsx("span",{className:"relative z-10",style:{color:s?"#FFFFFF":a.textTertiary},children:o.label})]},o.value)})})}function cg({options:e,value:t,onChange:r,theme:a}){return jsxRuntime.jsx("div",{className:"inline-flex items-center gap-1",children:e.map(n=>{let o=t===n.value;return jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>r(n.value),className:"relative px-3 py-1.5 text-xs transition-all",style:{color:o?a.accent:a.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:o?600:500},whileHover:{color:o?a.accent:a.textSecondary},whileTap:{scale:.98},children:[jsxRuntime.jsx("span",{children:n.label}),o&&jsxRuntime.jsx(framerMotion.motion.div,{layoutId:"timeScaleUnderline",className:"absolute bottom-0 left-1 right-1 h-0.5 rounded-full",style:{backgroundColor:a.accent},transition:{type:"spring",stiffness:400,damping:30}})]},n.value)})})}function dg({theme:e,value:t,onChange:r}){let[a,n]=Se.useState(false),o=Se.useRef(null),s=Ha();Se.useEffect(()=>{let i=p=>{o.current&&!o.current.contains(p.target)&&n(false);};return a&&document.addEventListener("mousedown",i),()=>document.removeEventListener("mousedown",i)},[a]);let c=[{value:"compact",label:s.toolbar.compact||"Compact"},{value:"comfortable",label:s.toolbar.normal||"Normal"},{value:"spacious",label:s.toolbar.spacious||"Spacious"}],u=c.find(i=>i.value===t)?.label||"Normal";return jsxRuntime.jsxs("div",{ref:o,className:"relative",children:[jsxRuntime.jsx(framerMotion.motion.button,{onClick:()=>n(!a),className:"flex items-center justify-center p-2 rounded-lg transition-all",style:{backgroundColor:a?e.accentLight:e.bgSecondary,border:`1px solid ${a?e.accent:e.borderLight}`,color:a?e.accent:e.textSecondary},whileHover:{backgroundColor:e.hoverBg,scale:1.02},whileTap:{scale:.98},title:`${s.toolbar.density||"Density"}: ${u}`,children:jsxRuntime.jsx(lucideReact.Rows3,{className:"w-4 h-4"})}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:a&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-8,scale:.95},animate:{opacity:1,y:0,scale:1},exit:{opacity:0,y:-8,scale:.95},transition:{duration:.15,ease:"easeOut"},className:"absolute left-0 mt-2 w-36 rounded-lg overflow-hidden z-50",style:{backgroundColor:e.bgSecondary,border:`1px solid ${e.border}`,boxShadow:"0 10px 40px rgba(0, 0, 0, 0.25)"},children:jsxRuntime.jsx("div",{className:"py-1",children:c.map((i,p)=>{let l=t===i.value;return jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>{r(i.value),n(false);},className:"w-full flex items-center justify-between px-3 py-2 text-left transition-all",style:{backgroundColor:l?e.accentLight:"transparent",borderBottom:p<c.length-1?`1px solid ${e.borderLight}`:"none"},whileHover:{backgroundColor:l?e.accentLight:e.hoverBg},initial:{opacity:0,x:-10},animate:{opacity:1,x:0},transition:{delay:p*.03},children:[jsxRuntime.jsx("span",{className:"text-xs",style:{color:l?e.accent:e.textPrimary,fontFamily:"Inter, sans-serif",fontWeight:l?600:500},children:i.label}),l&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5",style:{color:e.accent}})]},i.value)})})})})]})}function On({theme:e,timeScale:t,onTimeScaleChange:r,zoom:a,onZoomChange:n,currentTheme:o,onThemeChange:s,rowDensity:c,onRowDensityChange:u,showThemeSelector:i=true,showCreateTaskButton:p=false,createTaskLabel:l,onCreateTask:d,onExportPNG:m,onExportPDF:v,onExportExcel:y,onExportCSV:h,onExportJSON:g,onExportMSProject:b}){let f=Ha(),k=m||v||y||h||g||b,w=[{value:"day",label:f.toolbar.day},{value:"week",label:f.toolbar.week},{value:"month",label:f.toolbar.month}],x=[{value:"dark",label:"Dark",icon:jsxRuntime.jsx(lucideReact.Moon,{className:"w-3.5 h-3.5"})},{value:"light",label:"Light",icon:jsxRuntime.jsx(lucideReact.Sun,{className:"w-3.5 h-3.5"})},{value:"neutral",label:"Zen",icon:jsxRuntime.jsx(lucideReact.Palette,{className:"w-3.5 h-3.5"})}];return jsxRuntime.jsxs("div",{className:"h-12 px-4 flex items-center justify-between border-b",style:{backgroundColor:e.bgGrid,borderColor:e.border},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(cg,{options:w,value:t,onChange:D=>r(D),theme:e}),jsxRuntime.jsx("div",{className:"w-px h-5",style:{backgroundColor:e.borderLight}}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx(framerMotion.motion.button,{onClick:()=>n(Math.max(.5,a-.1)),className:"p-1.5 rounded-md transition-all",style:{backgroundColor:"transparent",color:e.textSecondary},whileHover:{backgroundColor:e.hoverBg,scale:1.05},whileTap:{scale:.95},children:jsxRuntime.jsx(lucideReact.ZoomOut,{className:"w-3.5 h-3.5"})}),jsxRuntime.jsxs("div",{className:"px-2 py-0.5 rounded text-xs tabular-nums min-w-[42px] text-center",style:{color:e.textSecondary,fontFamily:"Inter, sans-serif",fontWeight:500},children:[Math.round(a*100),"%"]}),jsxRuntime.jsx(framerMotion.motion.button,{onClick:()=>n(Math.min(2,a+.1)),className:"p-1.5 rounded-md transition-all",style:{backgroundColor:"transparent",color:e.textSecondary},whileHover:{backgroundColor:e.hoverBg,scale:1.05},whileTap:{scale:.95},children:jsxRuntime.jsx(lucideReact.ZoomIn,{className:"w-3.5 h-3.5"})})]}),jsxRuntime.jsx("div",{className:"w-px h-5",style:{backgroundColor:e.borderLight}}),jsxRuntime.jsx(dg,{theme:e,value:c,onChange:u})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[p&&d&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs(framerMotion.motion.button,{onClick:d,className:"flex items-center gap-2 px-3 py-1.5 rounded-lg text-xs transition-all",style:{background:"linear-gradient(135deg, #10B981 0%, #059669 100%)",color:"#FFFFFF",fontFamily:"Inter, sans-serif",fontWeight:500,boxShadow:"0 2px 8px rgba(16, 185, 129, 0.3)"},whileHover:{scale:1.02,boxShadow:"0 4px 12px rgba(16, 185, 129, 0.4)"},whileTap:{scale:.98},children:[jsxRuntime.jsx(lucideReact.Plus,{className:"w-3.5 h-3.5"}),jsxRuntime.jsx("span",{children:l||f.toolbar.createTask})]}),(k||i)&&jsxRuntime.jsx("div",{className:"w-px h-6",style:{backgroundColor:e.borderLight}})]}),k&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(ig,{theme:e,onExportPNG:m,onExportPDF:v,onExportExcel:y,onExportCSV:h,onExportJSON:g,onExportMSProject:b}),i&&jsxRuntime.jsx("div",{className:"w-px h-6",style:{backgroundColor:e.borderLight}})]}),i&&jsxRuntime.jsx(lg,{options:x,value:o,onChange:D=>s(D),theme:e})]})]})}function zn({columns:e,onToggleColumn:t,theme:r}){let[a,n]=Se.useState(false),[o,s]=Se.useState({x:0,y:0}),c=Se.useRef(null),u=Se.useRef(null);Se.useEffect(()=>{if(!a)return;let p=l=>{c.current&&!c.current.contains(l.target)&&n(false);};return document.addEventListener("mousedown",p),()=>document.removeEventListener("mousedown",p)},[a]);let i=e.filter(p=>p.id!=="name");return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(framerMotion.motion.button,{ref:u,onClick:()=>{if(!a&&u.current){let p=u.current.getBoundingClientRect();s({x:p.left,y:p.bottom+4});}n(!a);},className:"p-2 rounded-md transition-colors flex items-center gap-1",style:{backgroundColor:r.bgSecondary,border:`1px solid ${r.borderLight}`,color:r.textSecondary},whileHover:{backgroundColor:r.hoverBg,scale:1.05},whileTap:{scale:.95},children:jsxRuntime.jsx(lucideReact.Plus,{className:"w-4 h-4"})}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:a&&jsxRuntime.jsx(Ye,{children:jsxRuntime.jsx(framerMotion.motion.div,{ref:c,initial:{opacity:0,scale:.95,y:-10},animate:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:-10},transition:{duration:.15},className:"column-manager-menu fixed min-w-[180px] rounded-lg shadow-xl z-[9999]",style:{left:`${o.x}px`,top:`${o.y}px`,backgroundColor:r.bgSecondary,border:`1px solid ${r.border}`},children:jsxRuntime.jsxs("div",{className:"py-1",children:[jsxRuntime.jsx("div",{className:"px-3 py-2 text-xs uppercase tracking-wider",style:{color:r.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:600},children:"Add Column"}),i.map(p=>jsxRuntime.jsxs("button",{onClick:()=>{t(p.id);},className:"w-full px-3 py-2 text-left flex items-center justify-between transition-colors text-sm",style:{color:r.textPrimary,backgroundColor:"transparent",fontFamily:"Inter, sans-serif"},onMouseEnter:l=>{l.currentTarget.style.backgroundColor=r.hoverBg;},onMouseLeave:l=>{l.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{children:p.label}),p.visible&&jsxRuntime.jsx(lucideReact.Check,{className:"w-4 h-4",style:{color:r.accent}})]},p.id))]})})})})]})}function ha({isOpen:e,x:t,y:r,items:a,onClose:n,theme:o}){let s=Se.useRef(null);return Se.useEffect(()=>{if(!e)return;let c=i=>{s.current&&!s.current.contains(i.target)&&n();},u=i=>{i.key==="Escape"&&n();};return document.addEventListener("mousedown",c),document.addEventListener("keydown",u),()=>{document.removeEventListener("mousedown",c),document.removeEventListener("keydown",u);}},[e,n]),e?jsxRuntime.jsx(framerMotion.AnimatePresence,{children:jsxRuntime.jsx(framerMotion.motion.div,{ref:s,initial:{opacity:0,scale:.95,y:-10},animate:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:-10},transition:{duration:.15,ease:[.4,0,.2,1]},className:"fixed z-[9999] min-w-[200px] rounded-lg shadow-xl",style:{left:`${t}px`,top:`${r}px`,backgroundColor:o.bgSecondary,border:`1px solid ${o.border}`},children:jsxRuntime.jsx("div",{className:"py-1",children:a.map(c=>jsxRuntime.jsxs("div",{children:[c.separator&&jsxRuntime.jsx("div",{className:"my-1 h-px",style:{backgroundColor:o.borderLight}}),jsxRuntime.jsxs("button",{onClick:()=>{c.disabled||(c.onClick(),n());},disabled:c.disabled,className:"w-full px-3 py-2 text-left flex items-center gap-2 transition-colors text-sm",style:{color:c.disabled?o.textTertiary:o.textPrimary,backgroundColor:"transparent",fontFamily:"Inter, sans-serif",cursor:c.disabled?"not-allowed":"pointer",opacity:c.disabled?.5:1},onMouseEnter:u=>{c.disabled||(u.currentTarget.style.backgroundColor=o.hoverBg);},onMouseLeave:u=>{u.currentTarget.style.backgroundColor="transparent";},children:[c.icon&&jsxRuntime.jsx("span",{style:{color:o.textSecondary},children:c.icon}),jsxRuntime.jsx("span",{className:"flex-1",children:c.label}),c.submenu&&jsxRuntime.jsx(lucideReact.ChevronRight,{className:"w-3.5 h-3.5",style:{color:o.textTertiary}})]})]},c.id))})})}):null}var lt={Edit:jsxRuntime.jsx(lucideReact.Edit3,{className:"w-4 h-4"}),Pencil:jsxRuntime.jsx(lucideReact.Pencil,{className:"w-4 h-4"}),Delete:jsxRuntime.jsx(lucideReact.Trash2,{className:"w-4 h-4"}),Add:jsxRuntime.jsx(lucideReact.Plus,{className:"w-4 h-4"}),AddSubtask:jsxRuntime.jsx(lucideReact.Plus,{className:"w-4 h-4"}),Remove:jsxRuntime.jsx(lucideReact.Minus,{className:"w-4 h-4"}),Link:jsxRuntime.jsx(lucideReact.Link2,{className:"w-4 h-4"}),Progress:jsxRuntime.jsx(lucideReact.BarChart3,{className:"w-4 h-4"}),Sort:jsxRuntime.jsx(lucideReact.ArrowUpDown,{className:"w-4 h-4"}),SortAsc:jsxRuntime.jsx(lucideReact.ArrowUp,{className:"w-4 h-4"}),SortDesc:jsxRuntime.jsx(lucideReact.ArrowDown,{className:"w-4 h-4"}),Hide:jsxRuntime.jsx(lucideReact.EyeOff,{className:"w-4 h-4"}),Show:jsxRuntime.jsx(lucideReact.Eye,{className:"w-4 h-4"}),Settings:jsxRuntime.jsx(lucideReact.Settings,{className:"w-4 h-4"}),Split:jsxRuntime.jsx(lucideReact.Scissors,{className:"w-4 h-4"}),MarkIncomplete:jsxRuntime.jsx(lucideReact.Circle,{className:"w-4 h-4"}),SetInProgress:jsxRuntime.jsx(lucideReact.PlayCircle,{className:"w-4 h-4"}),MarkComplete:jsxRuntime.jsx(lucideReact.CheckCircle2,{className:"w-4 h-4"})};function vc({tasks:e,selectedTaskIds:t,onTaskSelect:r,onTaskCreate:a,onTaskDelete:n,onTaskDuplicate:o,onTaskMove:s,onTaskIndent:c,onTaskOutdent:u,onTaskRename:i,onTaskToggleExpand:p,onOpenTaskModal:l,enableKeyboard:d=true}){let m=Se.useRef(false),v=Se.useCallback(f=>{m.current=f;},[]),y=Se.useCallback(f=>{let k=[],w=x=>{for(let D of x)k.push(D),D.subtasks&&D.subtasks.length>0&&D.isExpanded&&w(D.subtasks);};return w(f),k},[]),h=Se.useCallback(()=>{let f=y(e);for(let k of f)if(t.has(k.id))return k;return null},[e,t,y]),g=Se.useCallback((f,k)=>{let w=y(e);if(w.length===0)return;let x=h();if(!x){r(w[0].id,false);return}let D=w.findIndex(T=>T.id===x.id);if(D===-1)return;let C=f==="up"?D-1:D+1;if(C<0||C>=w.length)return;let N=w[C];r(N.id,k);},[e,h,y,r]),b=Se.useCallback(f=>{if(!d)return;let k=f.target;if(k.tagName==="INPUT"||k.tagName==="TEXTAREA"||k.isContentEditable||m.current){f.key==="Escape"&&(k.blur(),m.current=false);return}let D=navigator.platform.toUpperCase().indexOf("MAC")>=0?f.metaKey:f.ctrlKey,C=Array.from(t),N=h();if(f.key==="ArrowUp"){f.preventDefault(),g("up",f.shiftKey);return}if(f.key==="ArrowDown"){f.preventDefault(),g("down",f.shiftKey);return}if(N&&(f.key==="ArrowRight"||f.key==="ArrowLeft")){N.subtasks&&N.subtasks.length>0&&(f.preventDefault(),(f.key==="ArrowRight"&&!N.isExpanded||f.key==="ArrowLeft"&&N.isExpanded)&&p(N.id));return}if(f.altKey&&(f.key==="ArrowUp"||f.key==="ArrowDown")){C.length>0&&(f.preventDefault(),s(C,f.key==="ArrowUp"?"up":"down"));return}if(f.key==="Tab"&&!f.shiftKey){C.length>0&&(f.preventDefault(),c(C));return}if(f.key==="Tab"&&f.shiftKey){C.length>0&&(f.preventDefault(),u(C));return}if(f.key==="Enter"&&!f.shiftKey&&!D){N&&(f.preventDefault(),a(N.id,"below"));return}if(f.key==="Enter"&&f.shiftKey&&!D){N&&(f.preventDefault(),a(N.id,"above"));return}if(f.key==="Enter"&&D){N&&(f.preventDefault(),l(N.id));return}if(f.key==="F2"){N&&(f.preventDefault(),i(N.id));return}if(f.key==="Delete"||f.key==="Backspace"&&D){C.length>0&&(f.preventDefault(),n(C));return}if(f.key==="d"&&D&&!f.shiftKey){C.length>0&&(f.preventDefault(),o(C));return}},[d,t,h,g,a,n,o,s,c,u,i,p,l]);return Se.useEffect(()=>{if(d)return window.addEventListener("keydown",b),()=>{window.removeEventListener("keydown",b);}},[d,b]),{setIsEditing:v}}function xc(){let[e,t]=Se.useState(new Set),[r,a]=Se.useState(null),n=Se.useCallback(l=>{t(new Set([l])),a(l);},[]),o=Se.useCallback(l=>{t(d=>{let m=new Set(d);return m.has(l)?m.delete(l):m.add(l),m}),a(l);},[]),s=Se.useCallback((l,d)=>{if(!r){n(l);return}let m=d.indexOf(r),v=d.indexOf(l);if(m===-1||v===-1){n(l);return}let y=Math.min(m,v),h=Math.max(m,v),g=d.slice(y,h+1);t(new Set(g)),a(l);},[r,n]),c=Se.useCallback((l,d,m,v)=>{v?s(l,d):m?o(l):n(l);},[n,o,s]),u=Se.useCallback((l,d)=>{d?t(m=>{let v=new Set(m);return v.add(l),v}):n(l);},[n]),i=Se.useCallback(()=>{t(new Set),a(null);},[]),p=Se.useCallback(l=>e.has(l),[e]);return {selectedTaskIds:e,selectTask:n,toggleTaskSelection:o,selectTaskRange:s,handleTaskClick:c,handleKeyboardSelection:u,clearSelection:i,isTaskSelected:p}}function ba(e){let t=[],r=(a,n,o=0)=>{for(let s=0;s<a.length;s++){let c={...a[s],parentId:n,level:o,position:s};t.push(c),c.subtasks&&c.subtasks.length>0&&c.isExpanded&&r(c.subtasks,c.id,o+1);}};return r(e),t}function gs(e,t){for(let r of e)if(r.subtasks){if(r.subtasks.some(n=>n.id===t))return r;let a=gs(r.subtasks,t);if(a)return a}return null}function hs(e,t){if(t.length===0)return e;let r=ba(e),a=t[0],n=r.findIndex(l=>l.id===a);if(n<=0)return e;let o=r[n-1],s=(l,d)=>{let m=[];return {tasks:l.filter(y=>{if(d.has(y.id))return m.push(y),false;if(y.subtasks){let h=s(y.subtasks,d);y.subtasks=h.tasks,m.push(...h.removed);}return true}),removed:m}},c=(l,d,m)=>l.map(v=>v.id===d?{...v,subtasks:[...v.subtasks||[],...m],isExpanded:true}:v.subtasks?{...v,subtasks:c(v.subtasks,d,m)}:v),u=new Set(t),{tasks:i,removed:p}=s(e,u);return c(i,o.id,p)}function bs(e,t){if(t.length===0)return e;let r=[...e];for(let a of t){let n=gs(r,a);if(!n)continue;let o=gs(r,n.id),s=(i,p,l)=>{for(let d=0;d<i.length;d++){let m=i[d];if(m.id===p&&m.subtasks){let v=m.subtasks.findIndex(y=>y.id===l);if(v!==-1){let[y]=m.subtasks.splice(v,1);return y}}if(m.subtasks){let v=s(m.subtasks,p,l);if(v)return v}}return null},c=(i,p,l)=>{let d=i.findIndex(m=>m.id===p);if(d!==-1)return i.splice(d+1,0,l),i;for(let m of i)m.subtasks&&c(m.subtasks,p,l);return i},u=s(r,n.id,a);u&&(o&&o.subtasks?c(o.subtasks,n.id,u):c(r,n.id,u));}return r}function vs(e,t,r){if(t.length===0)return e;let a=[...e],n=t[0],o=(s,c,u)=>{let i=s.findIndex(l=>l.id===c);if(i===-1){for(let l of s)if(l.subtasks&&o(l.subtasks,c,u))return true;return false}let p=u==="up"?i-1:i+1;return p<0||p>=s.length?false:([s[i],s[p]]=[s[p],s[i]],true)};return o(a,n,r),a}function $n(e,t){let r=new Set(t),a=n=>n.filter(o=>!r.has(o.id)).map(o=>o.subtasks?{...o,subtasks:a(o.subtasks)}:o);return a(e)}function ys(e,t){let r=[...e];for(let a of t){let n=s=>{let c=s.findIndex(p=>p.id===a);if(c===-1){for(let p of s)if(p.subtasks&&n(p.subtasks))return true;return false}let u=s[c],i={...u,id:`${u.id}-copy-${Date.now()}`,name:`${u.name} (Copy)`,subtasks:u.subtasks?o(u.subtasks):void 0};return s.splice(c+1,0,i),true},o=s=>s.map(c=>({...c,id:`${c.id}-copy-${Date.now()}`,subtasks:c.subtasks?o(c.subtasks):void 0}));n(r);}return r}function kc(e,t,r){let a=[...e],n=new Date,o=new Date(n);o.setDate(o.getDate()+7);let s={id:`task-${Date.now()}`,name:"New Task",progress:0,status:"todo",startDate:n,endDate:o,color:"#6366F1"},c=u=>{let i=u.findIndex(l=>l.id===t);if(i===-1){for(let l of u)if(l.subtasks&&c(l.subtasks))return true;return false}let p=r==="above"?i:i+1;return u.splice(p,0,s),true};return c(a),{tasks:a,newTask:s}}function xs(e,t,r){return e.map(a=>a.id===t?{...a,name:r}:a.subtasks?{...a,subtasks:xs(a.subtasks,t,r)}:a)}function ks(e,t){return e.map(r=>r.id===t?{...r,isExpanded:!r.isExpanded}:r.subtasks?{...r,subtasks:ks(r.subtasks,t)}:r)}function ws(e,t){let r=p=>{for(let l of p){if(l.id===t)return l;if(l.subtasks){let d=r(l.subtasks);if(d)return d}}return null},a=r(e),n=new Date,o=new Date(n);o.setDate(o.getDate()+7);let s=a?.startDate||n,c=a?.endDate||o,u={id:`task-${Date.now()}`,name:"New Subtask",progress:0,status:"todo",startDate:new Date(s),endDate:new Date(c),color:a?.color||"#3B82F6"},i=p=>p.map(l=>{if(l.id===t){let d=l.subtasks||[];return {...l,subtasks:[...d,u],isExpanded:true}}return l.subtasks?{...l,subtasks:i(l.subtasks)}:l});return {tasks:i(e),newTask:u}}var Tc={todo:{label:"To Do",color:"#94a3b8",icon:"circle"},"in-progress":{label:"In Progress",color:"#60a5fa",icon:"circle-dot"},completed:{label:"Completed",color:"#34d399",icon:"check-circle"}},Dc=({icon:e,color:t})=>e==="circle"?jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"6",stroke:t,strokeWidth:"1.5",fill:"none"})}):e==="circle-dot"?jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"6",stroke:t,strokeWidth:"1.5",fill:"none"}),jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"3",fill:t})]}):jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"6",stroke:t,strokeWidth:"1.5",fill:t,fillOpacity:"0.2"}),jsxRuntime.jsx("path",{d:"M5 8L7 10L11 6",stroke:t,strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})]});function Sc({status:e="todo",onChange:t,className:r}){let[a,n]=Se.useState(false),[o,s]=Se.useState({top:0,left:0}),c=Se.useRef(null),u=Se.useRef(null);Se.useEffect(()=>{if(a&&u.current){let d=u.current.getBoundingClientRect();s({top:d.bottom+window.scrollY+8,left:d.left+window.scrollX});}},[a]),Se.useEffect(()=>{let d=m=>{c.current&&!c.current.contains(m.target)&&!u.current?.contains(m.target)&&n(false);};if(a)return document.addEventListener("mousedown",d),()=>document.removeEventListener("mousedown",d)},[a]),Se.useEffect(()=>{let d=m=>{m.key==="Escape"&&n(false);};if(a)return document.addEventListener("keydown",d),()=>document.removeEventListener("keydown",d)},[a]);let i=d=>{t(d),n(false);},p=Tc[e],l=p.color;return jsxRuntime.jsxs("div",{className:`relative ${r||""}`,children:[jsxRuntime.jsx("button",{ref:u,onClick:()=>n(!a),className:"flex items-center justify-center w-8 h-8 rounded-lg transition-all hover:bg-white/15 hover:scale-110 active:scale-95",style:{background:`${l}10`,boxShadow:`0 0 0 2px ${l}30 inset`},title:p.label,children:jsxRuntime.jsx(Dc,{icon:p.icon,color:l})}),a&&jsxRuntime.jsx(Ye,{children:jsxRuntime.jsxs("div",{ref:c,className:"status-selector-menu",style:{position:"absolute",top:`${o.top}px`,left:`${o.left}px`,zIndex:99999,minWidth:"180px",borderRadius:"8px",background:"var(--modal-v2-bg, #1f1f1f)",border:"1px solid var(--modal-v2-border, rgba(255, 255, 255, 0.15))",boxShadow:"0 10px 40px rgba(0, 0, 0, 0.8), 0 0 0 1px rgba(255, 255, 255, 0.1)"},children:[jsxRuntime.jsx("div",{className:"px-3 py-1.5 border-b",style:{borderColor:"var(--modal-v2-border, rgba(255, 255, 255, 0.1))"},children:jsxRuntime.jsx("span",{className:"text-[10px] font-bold uppercase tracking-wider",style:{color:"var(--modal-v2-text-secondary, rgba(255, 255, 255, 0.7))"},children:"Status"})}),jsxRuntime.jsx("div",{className:"py-1",children:Object.entries(Tc).map(([d,m])=>jsxRuntime.jsxs("button",{onClick:()=>i(d),className:"w-full px-3 py-2 flex items-center gap-2.5 text-sm font-medium transition-all active:scale-[0.98] status-option",style:{color:m.color,background:"transparent"},onMouseEnter:v=>{v.currentTarget.style.background="var(--modal-v2-bg-tertiary, rgba(255, 255, 255, 0.15))";},onMouseLeave:v=>{v.currentTarget.style.background="transparent";},children:[jsxRuntime.jsx(Dc,{icon:m.icon,color:m.color}),jsxRuntime.jsx("span",{className:"font-semibold",children:m.label}),e===d&&jsxRuntime.jsx("svg",{className:"ml-auto",width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:jsxRuntime.jsx("path",{d:"M13.5 4.5L6 12L2.5 8.5",stroke:"#3B82F6",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})]},d))})]})})]})}function Wn({tasks:e,theme:t,rowHeight:r,availableUsers:a=[],templates:n,onTaskClick:o,onTaskDblClick:s,onTaskContextMenu:c,onTaskToggle:u,scrollTop:i,columns:p,onToggleColumn:l,onColumnResize:d,onTaskUpdate:m,onTaskIndent:v,onTaskOutdent:y,onTaskMove:h,onMultiTaskDelete:g,onTaskDuplicate:b,onTaskCreate:f,onTaskRename:k,onCreateSubtask:w,onOpenTaskModal:x}){let D=Se.useContext(ga),[C,N]=Se.useState(null),[T,$]=Se.useState(false),[z,R]=Se.useState(null),[W,E]=Se.useState(""),O=Se.useRef(null),G=Se.useRef(null),[U,A]=Se.useState(null),[K,_]=Se.useState(0),[ae,M]=Se.useState(0),[de,ie]=Se.useState({isOpen:false,x:0,y:0,type:"header"});Se.useEffect(()=>{function X(j){O.current&&!O.current.contains(j.target)&&$(false);}if(T)return document.addEventListener("mousedown",X),()=>document.removeEventListener("mousedown",X)},[T]),Se.useEffect(()=>{z&&G.current&&(G.current.focus(),G.current.select());},[z]),Se.useEffect(()=>{if(!U)return;let X=Te=>{let We=Te.clientX-K,re=ae+We;d?.(U,re);},j=()=>{A(null),document.body.style.cursor="",document.body.style.userSelect="";};return document.addEventListener("mousemove",X),document.addEventListener("mouseup",j),document.body.style.cursor="col-resize",document.body.style.userSelect="none",()=>{document.removeEventListener("mousemove",X),document.removeEventListener("mouseup",j),document.body.style.cursor="",document.body.style.userSelect="";}},[U,K,ae,d]);let{selectedTaskIds:kt,handleTaskClick:rt,isTaskSelected:ir}=xc(),{setIsEditing:De}=vc({tasks:e,selectedTaskIds:kt,onTaskSelect:(X,j)=>{let We=ba(e).map(re=>re.id);rt(X,We,j||false,false);},onTaskCreate:f||(()=>{}),onTaskDelete:g||(()=>{}),onTaskDuplicate:b||(()=>{}),onTaskMove:h||(()=>{}),onTaskIndent:v||(()=>{}),onTaskOutdent:y||(()=>{}),onTaskRename:X=>{let j=ba(e).find(Te=>Te.id===X);j&&zr(j);},onTaskToggleExpand:u||(()=>{}),onOpenTaskModal:X=>{let j=ba(e).find(Te=>Te.id===X);j&&x&&x(j);},enableKeyboard:true}),bt=(X,j=0)=>{let Te=[];for(let We of X)Te.push({task:We,level:j}),We.subtasks&&We.subtasks.length>0&&We.isExpanded&&Te.push(...bt(We.subtasks,j+1));return Te},wt=bt(e),jt=48,hr=X=>!X.startDate||!X.endDate?"-":`${Math.ceil((X.endDate.getTime()-X.startDate.getTime())/(1e3*60*60*24))}d`,zr=X=>{R(X.id),E(X.name),De(true);},he=X=>{W.trim()&&W!==e.find(j=>j.id===X)?.name&&k?.(X,W.trim()),R(null),E(""),De(false);},at=()=>{R(null),E(""),De(false);},Kt=(X,j)=>{j.stopPropagation(),w?.(X.id);},Wt=(X,j,Te)=>{switch(X.id){case "name":let We=z===j.id,re=C===j.id;return jsxRuntime.jsxs("div",{className:"flex items-center gap-2 flex-1 min-w-0 relative",style:{paddingLeft:`${Te*20}px`},children:[j.subtasks&&j.subtasks.length>0?jsxRuntime.jsx("button",{onClick:J=>{J.stopPropagation(),u?.(j.id);},className:"p-0.5 hover:bg-opacity-10 rounded transition-colors flex-shrink-0",style:{color:t.textSecondary},children:j.isExpanded?jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-4 h-4"}):jsxRuntime.jsx(lucideReact.ChevronRight,{className:"w-4 h-4"})}):jsxRuntime.jsx("div",{className:"w-5 h-5 flex-shrink-0"}),jsxRuntime.jsx("div",{className:"w-3 h-3 rounded-full flex-shrink-0 border",style:{backgroundColor:j.color||"#3B82F6",opacity:j.parentId?.6:1,borderColor:j.isMilestone?t.accent:"transparent",borderWidth:j.isMilestone?"2px":"0px"},title:j.isMilestone?"Milestone":j.parentId?"Subtask":"Task"}),We?jsxRuntime.jsx("input",{ref:G,type:"text",value:W,onChange:J=>E(J.target.value),onKeyDown:J=>{J.key==="Enter"?he(j.id):J.key==="Escape"&&at();},onBlur:()=>he(j.id),className:"flex-1 px-2 py-1 rounded border outline-none",style:{backgroundColor:t.bgPrimary,borderColor:t.accent,color:t.textPrimary,fontFamily:"Inter, sans-serif",fontSize:"13px",fontWeight:500},onClick:J=>J.stopPropagation()}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("span",{className:"truncate flex-1",style:{color:t.textPrimary,fontFamily:"Inter, sans-serif",fontSize:Te===0?"14px":Te===1?"13px":"12px",fontWeight:j.isMilestone?600:j.subtasks&&j.subtasks.length>0?500:400,opacity:Te===0?1:Te===1?.95:.88},title:j.name,children:j.name}),re&&!We&&jsxRuntime.jsxs("div",{className:"flex items-center gap-1 ml-2",onClick:J=>J.stopPropagation(),children:[jsxRuntime.jsx("button",{onClick:J=>Kt(j,J),className:"p-1 rounded hover:bg-opacity-20 transition-colors",style:{color:t.textTertiary,backgroundColor:"transparent"},title:"Create subtask",children:jsxRuntime.jsx(lucideReact.Plus,{className:"w-3.5 h-3.5"})}),jsxRuntime.jsx("button",{onClick:J=>{J.stopPropagation(),zr(j);},className:"p-1 rounded hover:bg-opacity-20 transition-colors",style:{color:t.textTertiary,backgroundColor:"transparent"},title:"Rename (F2)",children:jsxRuntime.jsx(lucideReact.Edit3,{className:"w-3.5 h-3.5"})})]})]})]});case "startDate":let le=j.startDate?typeof j.startDate=="string"?j.startDate:j.startDate.toISOString().split("T")[0]:void 0;return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx("input",{type:"date",value:le||"",onChange:J=>{m?.(j.id,{startDate:J.target.value?new Date(J.target.value):void 0});},className:"bg-transparent border-none text-xs cursor-pointer outline-none text-center",style:{color:t.textSecondary,fontFamily:"Inter, sans-serif"}})});case "endDate":let lr=j.endDate?typeof j.endDate=="string"?j.endDate:j.endDate.toISOString().split("T")[0]:void 0;return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx("input",{type:"date",value:lr||"",onChange:J=>{m?.(j.id,{endDate:J.target.value?new Date(J.target.value):void 0});},className:"bg-transparent border-none text-xs cursor-pointer outline-none text-center",style:{color:t.textSecondary,fontFamily:"Inter, sans-serif"}})});case "duration":return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",children:jsxRuntime.jsx("span",{className:"text-xs tabular-nums",style:{color:t.textSecondary,fontFamily:"Inter, sans-serif",fontWeight:600},children:hr(j)})});case "assignees":let Ut=a.filter(J=>j.assignees?.some(Y=>Y.name===J.name||Y.initials===J.initials));return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx(Vr,{assignedUsers:Ut,availableUsers:a,onChange:J=>{let Y=J.map(ve=>({id:ve.id,name:ve.name,initials:ve.initials,color:ve.color}));m?.(j.id,{assignees:Y.length>0?Y:void 0});}})});case "status":return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx(Sc,{status:j.status||"todo",onChange:J=>{m?.(j.id,{status:J,progress:J==="completed"?100:j.progress});}})});case "progress":return jsxRuntime.jsxs("div",{className:"flex items-center justify-center gap-2 w-full",children:[jsxRuntime.jsx("div",{className:"flex-1 h-1.5 rounded-full overflow-hidden max-w-[60px]",style:{backgroundColor:t.bgSecondary},children:jsxRuntime.jsx("div",{className:"h-full rounded-full transition-all",style:{width:`${j.progress}%`,backgroundColor:j.progress===100?t.statusCompleted:t.accent}})}),jsxRuntime.jsxs("span",{className:"text-xs tabular-nums min-w-[35px] text-right",style:{color:t.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:600},children:[j.progress,"%"]})]});default:return null}},$r=X=>[{id:"hide",label:"Hide Column",icon:lt.Hide,onClick:()=>l(X),disabled:X==="name"},{id:"sep1",label:"",onClick:()=>{},separator:true},{id:"sortAsc",label:"Sort Ascending",icon:lt.SortAsc,onClick:()=>{}},{id:"sortDesc",label:"Sort Descending",icon:lt.SortDesc,onClick:()=>{}}],se=X=>[{id:"edit",label:D?.contextMenu?.editTask||"Edit Task",icon:lt.Pencil,onClick:()=>{s?.(X);}},{id:"addSubtask",label:D?.contextMenu?.addSubtask||"Add Subtask",icon:lt.Add,onClick:()=>{w?.(X.id);}},{id:"sep1",label:"",onClick:()=>{},separator:true},{id:"markIncomplete",label:D?.contextMenu?.markIncomplete||"Mark Incomplete",icon:lt.MarkIncomplete,onClick:()=>{m?.(X.id,{status:"todo",progress:0});},disabled:X.status==="todo"},{id:"setInProgress",label:D?.contextMenu?.setInProgress||"Set In Progress",icon:lt.SetInProgress,onClick:()=>{m?.(X.id,{status:"in-progress"});},disabled:X.status==="in-progress"},{id:"markComplete",label:D?.contextMenu?.markComplete||"Mark Complete",icon:lt.MarkComplete,onClick:()=>{m?.(X.id,{status:"completed",progress:100});},disabled:X.status==="completed"},{id:"sep2",label:"",onClick:()=>{},separator:true},{id:"split",label:D?.contextMenu?.splitTask||"Split Task",icon:lt.Split,onClick:()=>{},disabled:true},{id:"sep3",label:"",onClick:()=>{},separator:true},{id:"delete",label:D?.contextMenu?.deleteTask||"Delete Task",icon:lt.Delete,onClick:()=>{g?.([X.id]);}}],ue=p.filter(X=>X.visible);return jsxRuntime.jsxs("div",{className:"h-full overflow-hidden",style:{backgroundColor:t.bgPrimary},children:[jsxRuntime.jsxs("div",{className:"sticky top-0 z-10 flex items-center",style:{backgroundColor:t.bgGrid,height:`${jt}px`,paddingLeft:"3px",borderBottom:`1px solid ${t.border}`,boxSizing:"border-box"},children:[ue.map((X,j)=>jsxRuntime.jsxs("div",{className:`flex items-center px-4 cursor-pointer hover:bg-opacity-50 transition-colors relative ${X.id==="name"?"justify-start":"justify-center"}`,style:{width:`${X.width}px`,minWidth:`${X.width}px`,maxWidth:`${X.width}px`,borderRight:j<ue.length-1?`1px solid ${t.borderLight}`:"none",height:"100%",boxSizing:"border-box"},onContextMenu:Te=>{Te.preventDefault(),ie({isOpen:true,x:Te.clientX,y:Te.clientY,type:"header",columnId:X.id});},onMouseEnter:Te=>{Te.currentTarget.style.backgroundColor=t.hoverBg;},onMouseLeave:Te=>{Te.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{className:"text-xs uppercase tracking-wider",style:{color:t.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:600},children:X.label}),X.resizable&&jsxRuntime.jsx("div",{className:"absolute right-0 top-0 bottom-0 w-1 cursor-col-resize hover:bg-blue-500 transition-colors group",style:{backgroundColor:U===X.id?t.accent:"transparent"},onMouseDown:Te=>{Te.preventDefault(),Te.stopPropagation(),A(X.id),_(Te.clientX),M(X.width);},title:"Drag to resize column",children:jsxRuntime.jsx("div",{className:"absolute right-0 top-2 bottom-2 w-0.5 opacity-0 group-hover:opacity-100 transition-opacity",style:{backgroundColor:t.accent}})})]},X.id)),jsxRuntime.jsxs("div",{className:"px-3 flex items-center gap-2 h-full",children:[jsxRuntime.jsx(zn,{columns:p,onToggleColumn:l,theme:t}),jsxRuntime.jsxs("button",{onClick:()=>$(!T),className:"p-1.5 rounded hover:bg-opacity-10 transition-colors relative group",style:{color:t.textTertiary},title:"Keyboard shortcuts",children:[jsxRuntime.jsx(lucideReact.Keyboard,{className:"w-4 h-4"}),T&&jsxRuntime.jsxs("div",{ref:O,className:"absolute top-full right-0 mt-2 p-4 rounded-lg shadow-2xl z-50 min-w-[400px]",style:{backgroundColor:t.bgPrimary,border:`1px solid ${t.border}`,color:t.textPrimary},onClick:X=>X.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between mb-3 pb-2 border-b",style:{borderColor:t.border},children:[jsxRuntime.jsx("h3",{className:"font-semibold text-sm",style:{color:t.textPrimary},children:"Keyboard Shortcuts"}),jsxRuntime.jsx("button",{onClick:()=>$(false),className:"text-xs px-2 py-1 rounded hover:bg-opacity-10",style:{color:t.textTertiary},children:"Close"})]}),jsxRuntime.jsxs("div",{className:"space-y-3 text-xs",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Navigation"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Move focus up/down"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"\u2191 / \u2193"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Select range"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Shift + \u2191 / \u2193"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Toggle selection"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Cmd/Ctrl + Click"})]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Hierarchy"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Indent task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Tab"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Outdent task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Shift + Tab"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Expand/Collapse"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"\u2192 / \u2190"})]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Editing"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Create task below"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Enter"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Create task above"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Shift + Enter"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Open task modal"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Cmd/Ctrl + Enter"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Rename task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"F2"})]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Actions"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Move task up/down"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Alt + \u2191 / \u2193"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Delete task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Delete"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Duplicate task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Cmd/Ctrl + D"})]})]})]})]})]})]})]})]}),jsxRuntime.jsx("div",{className:"gantt-taskgrid-content",children:wt.map(({task:X,level:j},Te)=>{let We=ir(X.id);return jsxRuntime.jsx(framerMotion.motion.div,{className:"flex items-center cursor-pointer group",style:{height:`${r}px`,borderLeft:We?`3px solid ${t.accent}`:"3px solid transparent",backgroundColor:We?t.accentLight:Te%2===0?t.bgPrimary:t.bgGrid},onMouseEnter:()=>N(X.id),onMouseLeave:()=>N(null),onClick:re=>{let lr=ba(e).map(Y=>Y.id),J=navigator.platform.toUpperCase().indexOf("MAC")>=0?re.metaKey:re.ctrlKey;rt(X.id,lr,J,re.shiftKey),o?.(X);},onDoubleClick:re=>{re.stopPropagation(),s?.(X);},onContextMenu:re=>{re.preventDefault(),ie({isOpen:true,x:re.clientX,y:re.clientY,type:"task",task:X}),c?.(X,re);},whileHover:{backgroundColor:We?t.accentLight:t.hoverBg},children:ue.map((re,le)=>jsxRuntime.jsx("div",{className:`px-4 flex items-center ${re.id==="name"?"justify-start":"justify-center"} ${le<ue.length-1?"border-r":""}`,style:{width:`${re.width}px`,minWidth:`${re.width}px`,maxWidth:`${re.width}px`,borderColor:C===X.id?t.border:t.borderLight,height:"100%",boxSizing:"border-box"},children:Wt(re,X,re.id==="name"?j:0)},`${X.id}-${re.id}`))},X.id)})}),jsxRuntime.jsx(ha,{isOpen:de.isOpen,x:de.x,y:de.y,items:de.type==="header"&&de.columnId?$r(de.columnId):de.type==="task"&&de.task?se(de.task):[],onClose:()=>ie({...de,isOpen:false}),theme:t})]})}function Ec(e,t){let[r,a]=Se.useState("none"),[n,o]=Se.useState(0),[s,c]=Se.useState(e),[u,i]=Se.useState(t),[p,l]=Se.useState(null),[d,m]=Se.useState(null),[v,y]=Se.useState(null),[h,g]=Se.useState(null),[b,f]=Se.useState(0),[k,w]=Se.useState(0),[x,D]=Se.useState(null),[C,N]=Se.useState(false);return {dragMode:r,setDragMode:a,dragOffset:n,setDragOffset:o,ghostX:s,setGhostX:c,ghostWidth:u,setGhostWidth:i,connectionLine:p,setConnectionLine:l,hoveredTaskId:d,setHoveredTaskId:m,activeZone:v,setActiveZone:y,draggedSegmentIndex:h,setDraggedSegmentIndex:g,draggedSegmentStartX:b,setDraggedSegmentStartX:f,segmentDragOffsetX:k,setSegmentDragOffsetX:w,hoveredSegmentIndex:x,setHoveredSegmentIndex:D,isHovered:C,setIsHovered:N,isDragging:r!=="none",isResizing:r==="resize-start"||r==="resize-end",isConnecting:r==="connect",resetDragState:(W,E)=>{a("none"),l(null),m(null),c(W),i(E),w(0),g(null),f(0);}}}function Un({task:e,x:t,y:r,width:a,theme:n,dayWidth:o,startDate:s,templates:c,onClick:u,onDoubleClick:i,onContextMenu:p,onDateChange:l,onDependencyCreate:d,allTaskPositions:m=[],onDragMove:v}){let y=Ec(t,a),h=Se.useRef(null),{dragMode:g,setDragMode:b,dragOffset:f,setDragOffset:k,ghostX:w,setGhostX:x,ghostWidth:D,setGhostWidth:C,connectionLine:N,setConnectionLine:T,hoveredTaskId:$,setHoveredTaskId:z,activeZone:R,setActiveZone:W,draggedSegmentIndex:E,setDraggedSegmentIndex:O,draggedSegmentStartX:G,setDraggedSegmentStartX:U,segmentDragOffsetX:A,setSegmentDragOffsetX:K,hoveredSegmentIndex:_,setHoveredSegmentIndex:ae,isHovered:M,setIsHovered:de,isDragging:ie,isResizing:kt,isConnecting:rt,resetDragState:ir}=y,De=32,bt=8,wt=e.endDate&&e.endDate<new Date&&e.progress<100,jt=e.isCriticalPath,hr=n.name==="neutral"||n.today==="#1C1917",he=(Y=>Y>=80?20:Y>=60?15:Y>=50?12:10)(a),at=a<50,Kt=a<40,Wt=Y=>Y.toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}),$r=()=>{let Y=Math.ceil((e.endDate.getTime()-e.startDate.getTime())/864e5);return `${Y} day${Y!==1?"s":""}`},se=Y=>Math.round(Y/o)*o,ue=Y=>{let ve=Math.round(Y/o),S=new Date(s);return S.setDate(S.getDate()+ve),S},X=(Y,ve)=>{for(let S of m){if(S.id===e.id)continue;let H=5;if(Y>=S.x-H&&Y<=S.x+S.width+H&&ve>=S.y-H&&ve<=S.y+S.height+H)return S.id}return null},j=Se.useCallback((Y,ve,S)=>{Y.preventDefault(),Y.stopPropagation();let H=h.current?.ownerSVGElement;if(!H)return;let me=H.createSVGPoint();me.x=Y.clientX,me.y=Y.clientY;let ye=me.matrixTransform(H.getScreenCTM()?.inverse()),Be=S!==void 0?S:t,Ue=ve;if(!Ue){let Mt=ye.x-Be;Y.shiftKey?(Ue="connect",T({x:t+a,y:r+De/2})):Y.ctrlKey||Y.metaKey?Ue="move":Y.altKey?Ue=Mt<a/2?"resize-start":"resize-end":Kt?Mt<a/2?Ue="move":Ue="resize-end":at?Mt<=he/2?Ue="resize-start":Mt>=a-he/2?Ue="resize-end":Ue="move":Mt<=he?Ue="resize-start":Mt>=a-he?Ue="resize-end":Ue="move";}b(Ue),de(false),W(null),Ue==="move"?k(ye.x-Be):Ue==="connect"?T({x:t+a,y:r+De/2}):k(0),x(Be),C(a);},[t,a,r,De]),Te=Se.useCallback(Y=>{if(g==="none")return;let ve=h.current?.ownerSVGElement;if(!ve)return;let S=ve.createSVGPoint();S.x=Y.clientX,S.y=Y.clientY;let H=S.matrixTransform(ve.getScreenCTM()?.inverse());if(g==="connect"){T({x:H.x,y:H.y});let me=X(H.x,H.y);z(me);}else if(g==="move"){let me=H.x-f,ye=se(me);x(ye),C(a);let Be=Math.round((ye-t)/o);if(v?.(e.id,Be,true),e.segments&&e.segments.length>0&&E!==null){let Ue=ye-G;K(Ue);}}else if(g==="resize-start"){let me=H.x,ye=se(me),Be=t+a-ye;Be>=o&&(x(ye),C(Be));}else if(g==="resize-end"){let me=H.x,Be=se(me)-t;Be>=o&&C(Be);}},[g,t,a,o,f,e,se,E,G,X,z,T,x,C,K,v]),We=Se.useCallback(()=>{if(g!=="none"){if(g==="connect")$&&d&&d(e,$),T(null),z(null);else {let Y=e.endDate.getTime()-e.startDate.getTime(),ve,S,H=true;if(g==="move"){if(ve=ue(w),S=new Date(ve.getTime()+Y),e.segments&&e.segments.length>0&&E!==null){let me=Math.round(A/o),ye=e.segments.map((St,go)=>{if(go===E){let wa=new Date(St.startDate),Ca=new Date(St.endDate);return wa.setDate(wa.getDate()+me),Ca.setDate(Ca.getDate()+me),{startDate:wa,endDate:Ca}}return St}),Be=ye.flatMap(St=>[St.startDate,St.endDate]),Ue=new Date(Math.min(...Be.map(St=>St.getTime()))),Mt=new Date(Math.max(...Be.map(St=>St.getTime())));l?.({...e,segments:ye},Ue,Mt),ir(t,a);return}}else g==="resize-start"?(ve=ue(w),S=e.endDate,ve>=S&&(console.warn("Invalid date range: start date must be before end date"),H=false)):g==="resize-end"?(ve=e.startDate,S=ue(w+D),S<=ve&&(console.warn("Invalid date range: end date must be after start date"),H=false)):H=false;H&&ve&&S&&(S.getTime()-ve.getTime()<864e5?console.warn("Invalid date range: task must be at least 1 day long"):l?.(e,ve,S));}v?.(e.id,0,false),ir(t,a);}},[g,w,D,e,l,$,d,t,a,o,ue,A,E,ir,v]);Se.useEffect(()=>{if(g==="none")return;let Y=S=>{Te(S);},ve=()=>{We();};return window.addEventListener("mousemove",Y),window.addEventListener("mouseup",ve),()=>{window.removeEventListener("mousemove",Y),window.removeEventListener("mouseup",ve);}},[g,Te,We]);let re=ie&&!rt?w:t,le=ie&&!rt?D:a,lr=c.taskTooltip(e),Ut=typeof lr=="string"?lr:"",J=c.taskClass(e);return jsxRuntime.jsxs("g",{ref:h,onMouseEnter:()=>!ie&&de(true),onMouseLeave:()=>{ie||(de(false),W(null));},onClick:()=>!ie&&u?.(e),onDoubleClick:Y=>{ie||(Y.stopPropagation(),i?.(e));},onContextMenu:Y=>{Y.preventDefault(),p?.(e,Y);},children:[Ut&&jsxRuntime.jsx("title",{dangerouslySetInnerHTML:{__html:Ut}}),M&&!ie&&!at&&!e.segments&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:t,y:r,width:he,height:De,fill:R==="resize-start"?n.accent:"transparent",opacity:R==="resize-start"?.15:0,style:{cursor:"ew-resize",pointerEvents:"all"},onMouseEnter:()=>W("resize-start"),onMouseDown:Y=>j(Y,"resize-start")}),jsxRuntime.jsx("rect",{x:t+he,y:r,width:a-he*2,height:De,fill:R==="move"?n.accent:"transparent",opacity:R==="move"?.1:0,style:{cursor:"grab",pointerEvents:"all"},onMouseEnter:()=>W("move"),onMouseDown:Y=>j(Y,"move")}),jsxRuntime.jsx("rect",{x:t+a-he,y:r,width:he,height:De,fill:R==="resize-end"?n.accent:"transparent",opacity:R==="resize-end"?.15:0,style:{cursor:"ew-resize",pointerEvents:"all"},onMouseEnter:()=>W("resize-end"),onMouseDown:Y=>j(Y,"resize-end")})]}),M&&!ie&&Kt&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:t,y:r,width:a/2,height:De,fill:R==="move"?n.accent:"transparent",opacity:R==="move"?.2:0,style:{cursor:"grab",pointerEvents:"all"},onMouseEnter:()=>W("move"),onMouseDown:Y=>j(Y,"move")}),jsxRuntime.jsx("rect",{x:t+a/2,y:r,width:a/2,height:De,fill:R==="resize-end"?n.accent:"transparent",opacity:R==="resize-end"?.2:0,style:{cursor:"ew-resize",pointerEvents:"all"},onMouseEnter:()=>W("resize-end"),onMouseDown:Y=>j(Y,"resize-end")}),M&&jsxRuntime.jsx(framerMotion.motion.line,{x1:t+a/2,y1:r+4,x2:t+a/2,y2:r+De-4,stroke:n.textTertiary,strokeWidth:1,strokeDasharray:"2 2",opacity:.3,initial:{opacity:0},animate:{opacity:.3},transition:{duration:.2},style:{pointerEvents:"none"}})]}),ie&&!rt&&!e.segments&&jsxRuntime.jsx(framerMotion.motion.rect,{x:w,y:r,width:D,height:De,rx:bt,fill:n.accent,opacity:.5,stroke:n.accent,strokeWidth:2,strokeDasharray:"4 4",initial:{opacity:0},animate:{opacity:.6},transition:{duration:.15},style:{pointerEvents:"none"}}),!e.segments&&jsxRuntime.jsx(framerMotion.motion.rect,{x:re,y:r,width:le,height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarPrimary,"data-task-class":J,initial:{opacity:0,scale:.95},animate:{opacity:ie&&!rt?.15:e.parentId?.6:M?.9:.8,scale:M&&!ie?1.02:1},transition:{duration:.2,ease:[.4,0,.2,1]},onMouseDown:Y=>j(Y),style:{cursor:ie?rt?"crosshair":kt?"ew-resize":"grabbing":"grab",pointerEvents:"all"}}),!e.segments&&jsxRuntime.jsx("rect",{x:re,y:r,width:le*(e.progress/100),height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarProgress,opacity:1,style:{pointerEvents:"none"}}),e.segments&&e.segments.map((Y,ve)=>{let S=(Y.startDate.getTime()-s.getTime())/864e5*o,me=(Y.endDate.getTime()-s.getTime())/(1e3*60*60*24)*o-S+o,ye=ie&&g==="move"&&E===ve,Be=_===ve,Ue=ye?S+A:S;return jsxRuntime.jsxs("g",{onMouseEnter:()=>!ie&&ae(ve),onMouseLeave:()=>!ie&&ae(null),children:[jsxRuntime.jsx(framerMotion.motion.rect,{x:Ue,y:r,width:me,height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarPrimary,initial:{opacity:0,scale:.95},animate:{opacity:ye||e.parentId?.6:Be?.9:.8,scale:Be&&!ie?1.02:1},transition:{duration:.2,ease:[.4,0,.2,1]},onMouseDown:Mt=>{Mt.stopPropagation(),O(ve),U(S),j(Mt,void 0,S);},style:{cursor:ie?rt?"crosshair":kt?"ew-resize":"grabbing":"grab",pointerEvents:"all"}}),jsxRuntime.jsx("rect",{x:Ue,y:r,width:me*(e.progress/100),height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarProgress,opacity:1,style:{pointerEvents:"none"}})]},`segment-${ve}`)}),hr&&(wt||jt)&&!e.segments&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jt&&!wt&&jsxRuntime.jsx("rect",{x:re,y:r,width:le,height:De,rx:bt,fill:"none",stroke:n.border,strokeWidth:2,strokeDasharray:"4 4",opacity:.8,style:{pointerEvents:"none"}}),wt&&jsxRuntime.jsx("rect",{x:re,y:r,width:le,height:De,rx:bt,fill:"url(#diagonal-stripes)",opacity:.3,style:{pointerEvents:"none"}})]}),le>60&&!e.segments&&(()=>{let Y=c.taskLabel(e),ve=typeof Y=="string"?Y:e.name,S=ve.length>Math.floor(le/8)?`${ve.substring(0,Math.floor(le/8))}...`:ve;return jsxRuntime.jsx("text",{x:re+12,y:r+De/2,dominantBaseline:"middle",fill:"#FFFFFF",fontSize:"13",fontWeight:"500",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:S})})(),le>100&&e.progress>0&&e.progress<100&&!ie&&!e.segments&&jsxRuntime.jsxs("text",{x:re+le-12,y:r+De/2,dominantBaseline:"middle",textAnchor:"end",fill:"rgba(255, 255, 255, 0.9)",fontSize:"11",fontWeight:"600",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:[e.progress,"%"]}),e.status&&le>80&&!ie&&!e.segments&&jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[e.status==="completed"&&jsxRuntime.jsx("circle",{cx:re+le-8,cy:r+8,r:4,fill:n.statusCompleted,stroke:"#FFFFFF",strokeWidth:1.5}),e.status==="in-progress"&&jsxRuntime.jsx("circle",{cx:re+le-8,cy:r+8,r:4,fill:n.statusInProgress,stroke:"#FFFFFF",strokeWidth:1.5,opacity:.8})]}),(M||kt)&&!rt&&!e.segments&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("g",{style:{pointerEvents:"all"},children:[jsxRuntime.jsx("rect",{x:at?re-15:re-10,y:r-5,width:at?25:20,height:De+10,fill:"transparent",onMouseDown:Y=>j(Y,"resize-start"),style:{cursor:"ew-resize"}}),jsxRuntime.jsx(framerMotion.motion.rect,{x:at?re-8:re-3,y:r+6,width:at?8:6,height:at?De-12:De-16,rx:3,fill:g==="resize-start"?n.accent:n.taskBarHandle,stroke:n.taskBarPrimary,strokeWidth:1.5,initial:{opacity:0,scale:0},animate:{opacity:1,scale:g==="resize-start"?1.2:1},transition:{duration:.2,type:"spring",stiffness:400,damping:25},style:{pointerEvents:"none"}})]}),jsxRuntime.jsxs("g",{style:{pointerEvents:"all"},children:[jsxRuntime.jsx("rect",{x:re+le-10,y:r-5,width:at?25:20,height:De+10,fill:"transparent",onMouseDown:Y=>j(Y,"resize-end"),style:{cursor:"ew-resize"}}),jsxRuntime.jsx(framerMotion.motion.rect,{x:at?re+le:re+le-3,y:r+6,width:at?8:6,height:at?De-12:De-16,rx:3,fill:g==="resize-end"?n.accent:n.taskBarHandle,stroke:n.taskBarPrimary,strokeWidth:1.5,initial:{opacity:0,scale:0},animate:{opacity:1,scale:g==="resize-end"?1.2:1},transition:{duration:.2,type:"spring",stiffness:400,damping:25},style:{pointerEvents:"none"}})]})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:M&&!ie&&!e.segments&&jsxRuntime.jsxs(framerMotion.motion.g,{style:{pointerEvents:"all"},initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15},children:[jsxRuntime.jsx(framerMotion.motion.circle,{cx:t+a+8,cy:r+De/2,r:6,fill:n.accent,stroke:"#FFFFFF",strokeWidth:2,initial:{scale:0},animate:{scale:1},exit:{scale:0},transition:{duration:.2,type:"spring",stiffness:400,damping:25},onMouseDown:Y=>{Y.stopPropagation(),j(Y,"connect");},style:{cursor:"crosshair"}}),jsxRuntime.jsx("text",{x:t+a+20,y:r+De/2,dominantBaseline:"middle",fill:n.textTertiary,fontSize:"10",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:"Link"})]})}),rt&&N&&jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[jsxRuntime.jsx(framerMotion.motion.line,{x1:t+a,y1:r+De/2,x2:N.x,y2:N.y,stroke:$?n.statusCompleted:n.accent,strokeWidth:$?3:2,strokeDasharray:"6 4",initial:{opacity:0},animate:{opacity:$?1:.8},transition:{duration:.15}}),jsxRuntime.jsx(framerMotion.motion.circle,{cx:N.x,cy:N.y,r:$?8:6,fill:$?n.statusCompleted:n.accent,stroke:"#FFFFFF",strokeWidth:2,initial:{scale:0},animate:{scale:1},transition:{duration:.15}}),$&&jsxRuntime.jsx(framerMotion.motion.text,{x:N.x+15,y:N.y,dominantBaseline:"middle",fill:n.statusCompleted,fontSize:"11",fontWeight:"600",fontFamily:"Inter, sans-serif",initial:{opacity:0,x:N.x+10},animate:{opacity:1,x:N.x+15},transition:{duration:.2},children:"Connect"})]}),(M||ie)&&!rt&&!e.segments&&jsxRuntime.jsx(framerMotion.motion.rect,{x:re-2,y:r-2,width:le+4,height:De+4,rx:bt+2,fill:"none",stroke:ie?n.accent:n.taskBarPrimary,strokeWidth:2,opacity:ie?.6:.4,initial:{opacity:0},animate:{opacity:ie?.6:.4},transition:{duration:.2},style:{pointerEvents:"none"}}),kt&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("line",{x1:w,y1:0,x2:w,y2:1e3,stroke:n.accent,strokeWidth:1,strokeDasharray:"4 4",opacity:.3,style:{pointerEvents:"none"}}),jsxRuntime.jsx("line",{x1:w+D,y1:0,x2:w+D,y2:1e3,stroke:n.accent,strokeWidth:1,strokeDasharray:"4 4",opacity:.3,style:{pointerEvents:"none"}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:M&&!ie&&!e.segments&&jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},exit:{opacity:0,y:10},transition:{duration:.2},style:{pointerEvents:"none"},children:[jsxRuntime.jsx("rect",{x:re+le/2-120,y:r-95,width:240,height:82,rx:8,fill:n.bgSecondary,stroke:n.border,strokeWidth:1,filter:"drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15))"}),jsxRuntime.jsx("path",{d:`M ${re+le/2-6} ${r-13} L ${re+le/2} ${r-3} L ${re+le/2+6} ${r-13}`,fill:n.bgSecondary,stroke:n.border,strokeWidth:1}),jsxRuntime.jsx("text",{x:re+le/2,y:r-73,textAnchor:"middle",fill:n.textPrimary,fontSize:"13",fontWeight:"600",fontFamily:"Inter, sans-serif",children:e.name.length>28?`${e.name.substring(0,28)}...`:e.name}),jsxRuntime.jsx("text",{x:re+le/2-110,y:r-55,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Start:"}),jsxRuntime.jsx("text",{x:re+le/2-70,y:r-55,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:Wt(e.startDate)}),jsxRuntime.jsx("text",{x:re+le/2-110,y:r-40,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"End:"}),jsxRuntime.jsx("text",{x:re+le/2-70,y:r-40,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:Wt(e.endDate)}),jsxRuntime.jsx("text",{x:re+le/2+10,y:r-55,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Duration:"}),jsxRuntime.jsx("text",{x:re+le/2+65,y:r-55,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:$r()}),jsxRuntime.jsx("text",{x:re+le/2+10,y:r-40,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Progress:"}),jsxRuntime.jsxs("text",{x:re+le/2+65,y:r-40,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:[e.progress,"%"]}),e.assignees&&e.assignees.length>0&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("text",{x:re+le/2-110,y:r-25,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Assignees:"}),jsxRuntime.jsxs("text",{x:re+le/2-50,y:r-25,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:[e.assignees.map(Y=>Y.name).join(", ").substring(0,30),e.assignees.map(Y=>Y.name).join(", ").length>30?"...":""]})]}),jsxRuntime.jsx("text",{x:re+le/2,y:r-18,textAnchor:"middle",fill:n.textTertiary,fontSize:"9",fontFamily:"Inter, sans-serif",style:{opacity:.7},children:Kt?"Left: move \u2022 Right: resize":at?"Drag to move \u2022 Hold ALT + drag edge to resize":"Drag edges to resize \u2022 Drag center to move \u2022 Click \u26AB to link"})]})})]})}function _n({x1:e,y1:t,x2:r,y2:a,theme:n,onDelete:o}){let[s,c]=Se.useState(false),u=r-e,i=a-t,p=e+u/2,l=`M ${e} ${t} C ${p} ${t}, ${p} ${a}, ${r} ${a}`,d=6,m=Math.atan2(i,u),v=r-d*Math.cos(m-Math.PI/6),y=a-d*Math.sin(m-Math.PI/6),h=r-d*Math.cos(m+Math.PI/6),g=a-d*Math.sin(m+Math.PI/6),b=n.dependency;return jsxRuntime.jsxs("g",{onMouseEnter:()=>c(true),onMouseLeave:()=>c(false),children:[jsxRuntime.jsx("path",{d:l,fill:"none",stroke:"transparent",strokeWidth:20,strokeLinecap:"round",style:{cursor:"pointer"}}),jsxRuntime.jsx(framerMotion.motion.path,{d:l,fill:"none",stroke:b,strokeWidth:2,strokeLinecap:"round",initial:{pathLength:0,opacity:0},animate:{pathLength:1,opacity:s?1:.6,strokeWidth:s?2.5:2},transition:{pathLength:{duration:.5,ease:"easeInOut"},opacity:{duration:.2},strokeWidth:{duration:.2}}}),jsxRuntime.jsx(framerMotion.motion.path,{d:`M ${r} ${a} L ${v} ${y} M ${r} ${a} L ${h} ${g}`,fill:"none",stroke:b,strokeWidth:2,strokeLinecap:"round",initial:{opacity:0,scale:.8},animate:{opacity:s?1:.6,scale:s?1.1:1,strokeWidth:s?2.5:2},transition:{duration:.2}}),jsxRuntime.jsx(framerMotion.motion.circle,{cx:r,cy:a,r:3,fill:b,initial:{scale:0},animate:{scale:s?1.33:1},transition:{scale:{delay:.3,duration:.2}}}),s&&o&&jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,scale:0},animate:{opacity:1,scale:1},transition:{duration:.2},onClick:f=>{f.stopPropagation(),o();},style:{cursor:"pointer"},children:[jsxRuntime.jsx("circle",{cx:p,cy:(t+a)/2,r:10,fill:n.bgSecondary,stroke:n.error||"#ef4444",strokeWidth:2}),jsxRuntime.jsx("line",{x1:p-4,y1:(t+a)/2-4,x2:p+4,y2:(t+a)/2+4,stroke:n.error||"#ef4444",strokeWidth:2,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:p+4,y1:(t+a)/2-4,x2:p-4,y2:(t+a)/2+4,stroke:n.error||"#ef4444",strokeWidth:2,strokeLinecap:"round"})]})]})}function Vn({task:e,x:t,y:r,theme:a,onClick:n}){let[o,s]=Se.useState(false),c=16,u=i=>i.toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"});return jsxRuntime.jsxs("g",{onMouseEnter:()=>s(true),onMouseLeave:()=>s(false),onClick:()=>n?.(e),style:{cursor:"pointer"},children:[e.isCriticalPath&&jsxRuntime.jsx(framerMotion.motion.circle,{cx:t,cy:r+16,r:c+4,fill:a.criticalPathLight,initial:{scale:0},animate:{scale:o?1.2:1},transition:{duration:.3}}),jsxRuntime.jsx(framerMotion.motion.rect,{x:t-c/2,y:r+16-c/2,width:c,height:c,fill:e.isCriticalPath?a.criticalPath:a.milestone,stroke:a.bgGrid,strokeWidth:2,transform:`rotate(45 ${t} ${r+16})`,initial:{scale:0,rotate:0},animate:{scale:o?1.15:1,rotate:45},transition:{duration:.3,type:"spring",stiffness:300,damping:20}}),o&&jsxRuntime.jsx(framerMotion.motion.rect,{x:t-(c+4)/2,y:r+16-(c+4)/2,width:c+4,height:c+4,fill:"none",stroke:e.isCriticalPath?a.criticalPath:a.milestone,strokeWidth:2,opacity:.5,transform:`rotate(45 ${t} ${r+16})`,initial:{scale:.8,opacity:0},animate:{scale:1,opacity:.5},transition:{duration:.2}}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:o&&jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},exit:{opacity:0,y:10},transition:{duration:.2},children:[jsxRuntime.jsx("rect",{x:t-80,y:r-50,width:160,height:44,rx:8,fill:a.bgSecondary,stroke:a.border,strokeWidth:1,filter:"drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15))"}),jsxRuntime.jsx("path",{d:`M ${t-6} ${r-6} L ${t} ${r+4} L ${t+6} ${r-6}`,fill:a.bgSecondary,stroke:a.border,strokeWidth:1}),jsxRuntime.jsx("rect",{x:t-70,y:r-38,width:8,height:8,fill:e.isCriticalPath?a.criticalPath:a.milestone,transform:`rotate(45 ${t-66} ${r-34})`}),jsxRuntime.jsx("text",{x:t-55,y:r-32,fill:a.textPrimary,fontSize:"12",fontWeight:"600",fontFamily:"Inter, sans-serif",children:e.name.length>18?`${e.name.substring(0,18)}...`:e.name}),jsxRuntime.jsx("text",{x:t-55,y:r-18,fill:a.textTertiary,fontSize:"10",fontFamily:"Inter, sans-serif",children:u(e.startDate)}),e.isCriticalPath&&jsxRuntime.jsxs("g",{children:[jsxRuntime.jsx("rect",{x:t+10,y:r-40,width:60,height:16,rx:4,fill:a.criticalPathLight}),jsxRuntime.jsx("text",{x:t+40,y:r-30,textAnchor:"middle",fill:a.criticalPath,fontSize:"9",fontWeight:"700",fontFamily:"Inter, sans-serif",letterSpacing:"0.5",children:"CRITICAL"})]})]})})]})}var q={calculateEndDate:(e,t)=>{let r=new Date(e);return r.setDate(r.getDate()+t),r},calculateDuration:(e,t)=>{let r=t.getTime()-e.getTime();return Math.ceil(r/(1e3*60*60*24))},calculateWorkingDays:(e,t)=>{let r=0,a=new Date(e);for(;a<=t;){let n=a.getDay();n!==0&&n!==6&&r++,a.setDate(a.getDate()+1);}return r},addWorkingDays:(e,t)=>{let r=new Date(e),a=0;for(;a<t;){r.setDate(r.getDate()+1);let n=r.getDay();n!==0&&n!==6&&a++;}return r},isWeekend:e=>{let t=e.getDay();return t===0||t===6},validateDependencies:(e,t,r)=>{let a=new Map,n=i=>{i.forEach(p=>{p.dependencies&&a.set(p.id,p.dependencies),p.subtasks&&n(p.subtasks);});};n(e);let o=a.get(r)||[];a.set(r,[...o,t]);let s=new Set,c=new Set,u=i=>{if(!s.has(i)){s.add(i),c.add(i);let p=a.get(i)||[];for(let l of p){if(!s.has(l)&&u(l))return true;if(c.has(l))return true}}return c.delete(i),false};return u(r)},flattenTasks:e=>{let t=[],r=a=>{a.forEach(n=>{t.push(n),n.subtasks&&n.subtasks.length>0&&r(n.subtasks);});};return r(e),t},findTaskById:(e,t)=>{for(let r of e){if(r.id===t)return r;if(r.subtasks){let a=q.findTaskById(r.subtasks,t);if(a)return a}}},getParentTasks:(e,t)=>{let r=[],a=q.findTaskById(e,t);if(!a||!a.parentId)return r;let n=a.parentId;for(;n;){let o=q.findTaskById(e,n);if(o)r.unshift(o),n=o.parentId;else break}return r},exportToJSON:e=>JSON.stringify(e,null,2),importFromJSON:e=>{try{let t=JSON.parse(e);if(!Array.isArray(t))throw new Error("Invalid JSON: expected an array of tasks");return t.forEach((r,a)=>{if(!r.id||!r.name)throw new Error(`Invalid task at index ${a}: missing required fields (id, name)`)}),t}catch(t){throw new Error(`Failed to import tasks: ${t instanceof Error?t.message:"Unknown error"}`)}},exportToCSV:e=>{let t=q.flattenTasks(e),a=[["ID","Name","Start Date","End Date","Progress","Status","Dependencies"].join(",")];return t.forEach(n=>{let o=[n.id,`"${n.name.replace(/"/g,'""')}"`,n.startDate?n.startDate.toISOString().split("T")[0]:"",n.endDate?n.endDate.toISOString().split("T")[0]:"",n.progress.toString(),n.status||"",n.dependencies?.join(";")||""];a.push(o.join(","));}),a.join(`
|
|
45
|
+
- [ ] `,priority:"MEDIUM",labels:["meeting"]}}];function rs({templates:e,onSelectTemplate:t,className:r}){let[a,n]=Se.useState(false),o=Se.useRef(null),s=Se.useRef(null);Se.useEffect(()=>{function i(p){o.current&&!o.current.contains(p.target)&&s.current&&!s.current.contains(p.target)&&n(false);}if(a)return document.addEventListener("mousedown",i),()=>document.removeEventListener("mousedown",i)},[a]);let c=i=>{t(i),n(false);},u=e.reduce((i,p)=>{let l=p.category||"Other";return i[l]||(i[l]=[]),i[l].push(p),i},{});return jsxRuntime.jsxs("div",{className:L("relative inline-block",r),children:[jsxRuntime.jsxs("button",{ref:s,onClick:()=>n(!a),className:"flex items-center gap-2 px-3 py-2 rounded-lg border transition-all text-sm font-medium shadow-lg",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)",color:"var(--theme-text-primary)"},onMouseEnter:i=>{i.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)",i.currentTarget.style.borderColor="var(--theme-border-secondary)";},onMouseLeave:i=>{i.currentTarget.style.backgroundColor="var(--theme-bg-secondary)",i.currentTarget.style.borderColor="var(--theme-border-primary)";},title:"Create from template",children:[jsxRuntime.jsx("span",{className:"text-base leading-none",children:"\u{1F4CB}"}),jsxRuntime.jsx("span",{children:"Templates"}),jsxRuntime.jsx("svg",{className:L("w-4 h-4 transition-transform",a&&"rotate-180"),fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:jsxRuntime.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"})})]}),a&&jsxRuntime.jsxs("div",{ref:o,className:"absolute top-full left-0 mt-2 min-w-[320px] max-w-[400px] rounded-xl backdrop-blur-xl border shadow-2xl z-50 overflow-hidden max-h-[500px] overflow-y-auto",style:{backgroundColor:"var(--theme-bg-primary)",borderColor:"var(--theme-border-primary)"},children:[jsxRuntime.jsxs("div",{className:"px-4 py-3 border-b sticky top-0 backdrop-blur-sm",style:{borderColor:"var(--theme-border-primary)",backgroundColor:"var(--theme-bg-secondary)"},children:[jsxRuntime.jsx("span",{className:"text-sm font-bold uppercase tracking-wider",style:{color:"var(--theme-text-primary)"},children:"Card Templates"}),jsxRuntime.jsx("p",{className:"text-xs mt-0.5",style:{color:"var(--theme-text-tertiary)"},children:"Quick start with pre-configured cards"})]}),Object.entries(u).map(([i,p])=>jsxRuntime.jsxs("div",{className:"py-2",children:[jsxRuntime.jsx("div",{className:"px-4 py-2",children:jsxRuntime.jsx("h4",{className:"text-xs font-semibold uppercase tracking-wider",style:{color:"var(--theme-text-secondary)"},children:i})}),jsxRuntime.jsx("div",{children:p.map(l=>jsxRuntime.jsxs("button",{onClick:()=>c(l),className:"w-full px-4 py-3 flex items-start gap-3 text-left transition-all active:scale-[0.98]",style:{color:"var(--theme-text-primary)"},onMouseEnter:d=>{d.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:d=>{d.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{className:"text-2xl leading-none mt-0.5",children:l.icon}),jsxRuntime.jsxs("div",{className:"flex-1 min-w-0",children:[jsxRuntime.jsx("div",{className:"font-semibold text-sm",style:{color:"var(--theme-text-primary)"},children:l.name}),l.description&&jsxRuntime.jsx("p",{className:"text-xs mt-0.5",style:{color:"var(--theme-text-tertiary)"},children:l.description})]})]},l.id))})]},i)),e.length===0&&jsxRuntime.jsx("div",{className:"px-4 py-8 text-center",style:{color:"var(--theme-text-tertiary)"},children:jsxRuntime.jsx("p",{className:"text-sm",children:"No templates available"})})]})]})}function ns({board:e,isOpen:t,onClose:r,onImport:a,boardElementRef:n,className:o}){let[s,c]=Se.useState("export"),[u,i]=Se.useState("json"),[p,l]=Se.useState(null),d=Se.useRef(null);if(!t)return null;let m=async()=>{let y=n?.current||void 0,h=await Mi(e,u,y);Ii(h,u);},v=async y=>{let h=y.target.files?.[0];if(h){try{let g=await Fi(h),b=h.name.endsWith(".json")?"json":"csv",f=Li(g,b);l(f),f.success&&a&&a(f,g);}catch(g){l({success:false,errors:[`Failed to read file: ${g instanceof Error?g.message:"Unknown error"}`]});}d.current&&(d.current.value="");}};return jsxRuntime.jsxs("div",{className:L("fixed inset-0 z-[9999] flex items-center justify-center",o),children:[jsxRuntime.jsx("div",{className:"absolute inset-0 bg-black/60 backdrop-blur-sm",onClick:r}),jsxRuntime.jsxs("div",{className:"relative bg-gradient-to-br from-gray-900/95 to-gray-800/95 backdrop-blur-xl rounded-2xl border border-white/20 shadow-2xl max-w-2xl w-full mx-4",children:[jsxRuntime.jsxs("div",{className:"px-6 py-5 border-b border-white/10 flex items-center justify-between",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("h2",{className:"text-2xl font-bold text-white flex items-center gap-3",children:[jsxRuntime.jsx("span",{className:"text-3xl",children:"\u{1F4E6}"}),"Export / Import"]}),jsxRuntime.jsx("p",{className:"text-sm text-white/60 mt-1",children:"Transfer your board data"})]}),jsxRuntime.jsx("button",{onClick:r,className:"text-white/50 hover:text-white transition-colors text-2xl leading-none p-2 hover:bg-white/10 rounded-lg","aria-label":"Close",children:"\xD7"})]}),jsxRuntime.jsxs("div",{className:"flex border-b border-white/10",children:[jsxRuntime.jsx("button",{onClick:()=>c("export"),className:L("flex-1 px-6 py-4 font-semibold transition-colors",s==="export"?"text-white border-b-2 border-blue-500":"text-white/50 hover:text-white/80"),children:"Export"}),jsxRuntime.jsx("button",{onClick:()=>c("import"),className:L("flex-1 px-6 py-4 font-semibold transition-colors",s==="import"?"text-white border-b-2 border-blue-500":"text-white/50 hover:text-white/80"),children:"Import"})]}),jsxRuntime.jsxs("div",{className:"p-6",children:[s==="export"&&jsxRuntime.jsxs("div",{className:"space-y-6",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{className:"block text-sm font-semibold text-white/90 mb-3",children:"Select format"}),jsxRuntime.jsx("div",{className:"grid grid-cols-3 gap-3",children:["json","csv","pdf"].map(y=>jsxRuntime.jsxs("button",{onClick:()=>i(y),className:L("p-4 rounded-lg border-2 transition-all text-center",u===y?"border-blue-500 bg-blue-500/20 text-white":"border-white/20 hover:border-white/40 text-white/70 hover:text-white"),children:[jsxRuntime.jsxs("div",{className:"text-2xl mb-2",children:[y==="json"&&"\u{1F4C4}",y==="csv"&&"\u{1F4CA}",y==="pdf"&&"\u{1F4DD}"]}),jsxRuntime.jsx("div",{className:"font-semibold uppercase text-xs",children:y})]},y))})]}),jsxRuntime.jsxs("div",{className:"bg-white/5 rounded-lg p-4",children:[jsxRuntime.jsx("h3",{className:"text-sm font-semibold text-white/90 mb-2",children:"Preview"}),jsxRuntime.jsxs("div",{className:"text-xs text-white/60",children:[jsxRuntime.jsxs("div",{children:["Board: ",jsxRuntime.jsx("span",{className:"text-white/90",children:e.title||"Untitled"})]}),jsxRuntime.jsxs("div",{children:["Columns: ",jsxRuntime.jsx("span",{className:"text-white/90",children:e.columns.length})]}),jsxRuntime.jsxs("div",{children:["Cards: ",jsxRuntime.jsx("span",{className:"text-white/90",children:e.cards.length})]})]})]}),jsxRuntime.jsx("button",{onClick:m,className:"w-full py-3 px-4 bg-gradient-to-r from-blue-600 to-blue-700 hover:from-blue-500 hover:to-blue-600 text-white font-semibold rounded-lg transition-all shadow-lg shadow-blue-500/20",children:"Export Board"})]}),s==="import"&&jsxRuntime.jsxs("div",{className:"space-y-6",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{className:"block text-sm font-semibold text-white/90 mb-3",children:"Upload file"}),jsxRuntime.jsx("input",{ref:d,type:"file",accept:".json,.csv",onChange:v,className:"hidden"}),jsxRuntime.jsxs("button",{onClick:()=>d.current?.click(),className:"w-full py-12 px-4 border-2 border-dashed border-white/30 hover:border-white/50 rounded-lg transition-colors text-white/70 hover:text-white",children:[jsxRuntime.jsx("div",{className:"text-5xl mb-3",children:"\u{1F4C1}"}),jsxRuntime.jsx("div",{className:"font-semibold mb-1",children:"Click to select file"}),jsxRuntime.jsx("div",{className:"text-xs text-white/50",children:"Supports JSON and CSV files"})]})]}),p&&jsxRuntime.jsxs("div",{className:L("p-4 rounded-lg",p.success?"bg-green-500/20 border border-green-500/30":"bg-red-500/20 border border-red-500/30"),children:[jsxRuntime.jsx("h3",{className:L("font-semibold mb-2",p.success?"text-green-400":"text-red-400"),children:p.success?"\u2713 Import Successful":"\u2717 Import Failed"}),p.success&&jsxRuntime.jsxs("div",{className:"text-sm text-white/80",children:[jsxRuntime.jsxs("div",{children:["Cards imported: ",p.cardsImported]}),jsxRuntime.jsxs("div",{children:["Columns imported: ",p.columnsImported]})]}),p.errors&&p.errors.length>0&&jsxRuntime.jsx("div",{className:"mt-2 text-sm",children:p.errors.map((y,h)=>jsxRuntime.jsxs("div",{className:"text-red-300",children:["\u2022 ",y]},h))})]})]})]})]})]})}var Mf=["URGENT","HIGH","MEDIUM","LOW"],If=[{value:"none",label:"None"},{value:"created",label:"Date Created"},{value:"priority",label:"Priority"},{value:"dueDate",label:"Due Date"},{value:"title",label:"Title"},{value:"estimate",label:"Estimate"}],Af=[{value:"none",label:"No Grouping"},{value:"priority",label:"By Priority"},{value:"assignee",label:"By Assignee"},{value:"label",label:"By Label"}];function os({filters:e,sort:t,onFiltersChange:r,onSortChange:a,onReset:n,onFilterMyTasks:o,onFilterOverdue:s,onFilterHighPriority:c,availableUsers:u=[],availableLabels:i=[],availableColumns:p=[],showQuickFilters:l=true,compact:d=false,groupBy:m="none",onGroupByChange:v}){let[y,h]=Se.useState(true),g=Se.useCallback(x=>{r({search:x.target.value});},[r]),b=Se.useCallback(x=>{r({dateFilter:x.target.value});},[r]),f=Se.useCallback(x=>{a({by:x.target.value});},[a]),k=Se.useCallback(()=>{a({order:t.order==="asc"?"desc":"asc"});},[t.order,a]),w=e.search||e.dateFilter!=="all"||e.priorities.length>0||e.assignees.length>0||e.labels.length>0||t.by!=="none";return jsxRuntime.jsxs("div",{className:`filter-bar ${d?"filter-bar--compact":""} ${y?"filter-bar--collapsed":""}`,children:[jsxRuntime.jsxs("div",{className:"filter-bar__header",onClick:()=>h(!y),style:{cursor:"pointer",display:"flex",alignItems:"center",gap:"8px",marginBottom:y?"0":"12px",padding:"4px 6px",borderRadius:"6px",transition:"all 0.2s ease"},onMouseEnter:x=>{x.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:x=>{x.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",style:{transform:y?"rotate(-90deg)":"rotate(0deg)",transition:"transform 0.2s",color:"var(--theme-text-secondary)"},children:jsxRuntime.jsx("polyline",{points:"6 9 12 15 18 9"})}),jsxRuntime.jsx("span",{className:"filter-bar__label",style:{fontWeight:500,fontSize:"0.875rem",color:"var(--theme-text-primary)"},children:"Filters & Grouping"}),w&&jsxRuntime.jsxs("span",{style:{color:"var(--theme-accent-primary)",fontSize:"0.75rem",fontWeight:600},children:["(",[e.search&&"search",e.dateFilter!=="all"&&"date",e.priorities.length>0&&"priority",e.assignees.length>0&&"assignee",e.labels.length>0&&"label",t.by!=="none"&&"sort"].filter(Boolean).length," active)"]})]}),!y&&jsxRuntime.jsxs("div",{className:"filter-bar__content",children:[l&&jsxRuntime.jsxs("div",{className:"filter-bar__quick",style:{marginBottom:"12px"},children:[jsxRuntime.jsx("span",{className:"filter-bar__label",children:"Quick:"}),o&&jsxRuntime.jsx("button",{onClick:o,className:"filter-bar__quick-btn",title:"Show only my tasks",children:"My Tasks"}),s&&jsxRuntime.jsx("button",{onClick:s,className:"filter-bar__quick-btn",title:"Show overdue tasks",children:"Overdue"}),c&&jsxRuntime.jsx("button",{onClick:c,className:"filter-bar__quick-btn",title:"Show high priority tasks",children:"High Priority"})]}),jsxRuntime.jsxs("div",{className:"filter-bar__main",children:[jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsx("input",{type:"text",placeholder:"Search tasks...",value:e.search,onChange:g,className:"filter-bar__search"})}),jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.dateFilter,onChange:b,className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Dates"}),jsxRuntime.jsx("option",{value:"overdue",children:"Overdue"}),jsxRuntime.jsx("option",{value:"today",children:"Today"}),jsxRuntime.jsx("option",{value:"this-week",children:"This Week"})]})}),jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.priorities[0]||"all",onChange:x=>{let D=x.target.value;r({priorities:D==="all"?[]:[D]});},className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Priorities"}),Mf.map(x=>jsxRuntime.jsx("option",{value:x,children:x},x))]})}),u.length>0&&jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.assignees[0]||"all",onChange:x=>{let D=x.target.value;r({assignees:D==="all"?[]:[D]});},className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Assignees"}),u.map(x=>jsxRuntime.jsx("option",{value:x.id,children:x.name},x.id))]})}),i.length>0&&jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsxs("select",{value:e.labels[0]||"all",onChange:x=>{let D=x.target.value;r({labels:D==="all"?[]:[D]});},className:"filter-bar__select",children:[jsxRuntime.jsx("option",{value:"all",children:"All Labels"}),i.map(x=>jsxRuntime.jsx("option",{value:x,children:x},x))]})}),jsxRuntime.jsxs("div",{className:"filter-bar__field filter-bar__sort",children:[jsxRuntime.jsx("span",{className:"filter-bar__label",style:{color:"var(--theme-text-secondary)"},children:"Sort:"}),jsxRuntime.jsx("select",{value:t.by,onChange:f,className:"filter-bar__select filter-bar__select--sm",children:If.map(x=>jsxRuntime.jsx("option",{value:x.value,children:x.label},x.value))}),t.by!=="none"&&jsxRuntime.jsx("button",{onClick:k,className:"filter-bar__sort-toggle",title:`Sort ${t.order==="asc"?"descending":"ascending"}`,children:t.order==="asc"?"\u2191":"\u2193"})]}),v&&jsxRuntime.jsx("div",{className:"filter-bar__field",children:jsxRuntime.jsx("select",{value:m,onChange:x=>v(x.target.value),className:"filter-bar__select",style:{fontWeight:500,borderWidth:"2px"},children:Af.map(x=>jsxRuntime.jsx("option",{value:x.value,children:x.label},x.value))})}),w&&jsxRuntime.jsx("button",{onClick:n,className:"filter-bar__reset",title:"Clear all filters",children:"Clear"})]})]})]})}function ss({onOpenExport:e,onOpenThemes:t,onOpenShortcuts:r,className:a,viewMode:n="kanban",onExportGanttPDF:o,onExportGanttExcel:s,onExportGanttPNG:c,onExportGanttCSV:u}){let[i,p]=Se.useState(false),l=Se.useRef(null);Se.useEffect(()=>{let m=v=>{l.current&&!l.current.contains(v.target)&&p(false);};return i&&document.addEventListener("mousedown",m),()=>{document.removeEventListener("mousedown",m);}},[i]);let d=m=>{m(),p(false);};return jsxRuntime.jsxs("div",{className:L("relative",a),ref:l,children:[jsxRuntime.jsxs("button",{onClick:()=>p(!i),className:"flex items-center gap-2 px-3 py-2 rounded-lg text-sm font-medium transition-all border",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)",color:"var(--theme-text-secondary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)",m.currentTarget.style.color="var(--theme-text-primary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-secondary)",m.currentTarget.style.color="var(--theme-text-secondary)";},"aria-label":"Configuration Menu","aria-expanded":i,children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"3"}),jsxRuntime.jsx("path",{d:"M12 1v6m0 6v6M5.6 5.6l4.2 4.2m4.2 4.2l4.2 4.2M1 12h6m6 0h6M5.6 18.4l4.2-4.2m4.2-4.2l4.2-4.2"})]}),jsxRuntime.jsx("span",{children:"Config"})]}),i&&jsxRuntime.jsxs("div",{className:"absolute right-0 mt-2 w-48 rounded-lg border shadow-lg overflow-hidden z-50",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)"},children:[n==="kanban"?jsxRuntime.jsxs("button",{onClick:()=>d(e),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4M7 10l5 5 5-5M12 15V3"})}),"Export"]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("button",{onClick:()=>d(async()=>await o?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),jsxRuntime.jsx("polyline",{points:"14 2 14 8 20 8"}),jsxRuntime.jsx("line",{x1:"16",y1:"13",x2:"8",y2:"13"}),jsxRuntime.jsx("line",{x1:"16",y1:"17",x2:"8",y2:"17"}),jsxRuntime.jsx("polyline",{points:"10 9 9 9 8 9"})]}),"Export PDF"]}),jsxRuntime.jsxs("button",{onClick:()=>d(async()=>await s?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),jsxRuntime.jsx("polyline",{points:"14 2 14 8 20 8"}),jsxRuntime.jsx("line",{x1:"12",y1:"18",x2:"12",y2:"12"}),jsxRuntime.jsx("line",{x1:"9",y1:"15",x2:"15",y2:"15"})]}),"Export Excel"]}),jsxRuntime.jsxs("button",{onClick:()=>d(async()=>await c?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("rect",{x:"3",y:"3",width:"18",height:"18",rx:"2",ry:"2"}),jsxRuntime.jsx("circle",{cx:"8.5",cy:"8.5",r:"1.5"}),jsxRuntime.jsx("polyline",{points:"21 15 16 10 5 21"})]}),"Export PNG"]}),jsxRuntime.jsxs("button",{onClick:()=>d(()=>u?.()),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),jsxRuntime.jsx("polyline",{points:"14 2 14 8 20 8"}),jsxRuntime.jsx("line",{x1:"8",y1:"13",x2:"16",y2:"13"}),jsxRuntime.jsx("line",{x1:"8",y1:"17",x2:"16",y2:"17"})]}),"Export CSV"]})]}),jsxRuntime.jsxs("button",{onClick:()=>d(t),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"5"}),jsxRuntime.jsx("path",{d:"M12 1v6m0 6v6m8.5-8.5L17 15M7 9L3.5 5.5M7 15l-3.5 3.5M20.5 5.5L17 9m3.5 11.5L17 17"})]}),"Themes"]}),jsxRuntime.jsxs("button",{onClick:()=>d(r),className:"w-full px-4 py-3 text-left text-sm font-medium transition-colors flex items-center gap-3",style:{color:"var(--theme-text-primary)"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor="var(--theme-bg-tertiary)";},onMouseLeave:m=>{m.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("rect",{x:"2",y:"4",width:"20",height:"16",rx:"2"}),jsxRuntime.jsx("path",{d:"M6 8h.01M10 8h.01M14 8h.01M18 8h.01M8 12h.01M12 12h.01M16 12h.01M7 16h10"})]}),"Shortcuts"]})]})]})}var is={name:"dark",displayName:"Dark (Enhanced)",emoji:"\u{1F319}",colors:{bgPrimary:"#222326",bgSecondary:"#2A2B2F",bgTertiary:"#33343A",bgCard:"#2d2d2d",bgHover:"#353535",bgActive:"#404040",bgInput:"#2a2a2a",textPrimary:"#F4F5F8",textSecondary:"#AEB6C0",textTertiary:"#7A7F8A",textDisabled:"#606060",textInverse:"#1a1a1a",borderPrimary:"rgba(255, 255, 255, 0.1)",borderSecondary:"rgba(255, 255, 255, 0.05)",borderDefault:"#404040",borderHover:"#505050",borderSubtle:"#2a2a2a",accentPrimary:"#5E6AD2",accentHover:"#7780DD",interactivePrimary:"#0ea5e9",interactivePrimaryHover:"#0284c7",interactivePrimaryBorder:"rgba(14, 165, 233, 0.3)",interactivePrimaryBackground:"rgba(14, 165, 233, 0.1)",interactivePrimaryBackgroundHover:"rgba(14, 165, 233, 0.2)",success:"#10B981",warning:"#F59E0B",error:"#EF4444",info:"#3B82F6",danger:"#ef4444",dangerBorder:"rgba(239, 68, 68, 0.3)",dangerBackground:"rgba(239, 68, 68, 0.1)",dangerBackgroundHover:"rgba(239, 68, 68, 0.2)"},shadows:{sm:"0 1px 2px rgba(0, 0, 0, 0.3)",md:"0 4px 12px rgba(0, 0, 0, 0.4)",lg:"0 12px 32px rgba(0, 0, 0, 0.5)"},radii:{sm:"6px",md:"8px",lg:"12px",full:"9999px"},spacing:{xs:"4px",sm:"8px",md:"16px",lg:"24px",xl:"32px"}},ls={name:"light",displayName:"Light (Standard)",emoji:"\u2600\uFE0F",colors:{bgPrimary:"#FFFFFF",bgSecondary:"#F7F7F8",bgTertiary:"#EEEFF1",bgCard:"#ffffff",bgHover:"#f3f4f6",bgActive:"#e5e7eb",bgInput:"#f9fafb",textPrimary:"#1A1A1A",textSecondary:"#5A5A5A",textTertiary:"#8A8A8A",textDisabled:"#d1d5db",textInverse:"#ffffff",borderPrimary:"rgba(0, 0, 0, 0.1)",borderSecondary:"rgba(0, 0, 0, 0.05)",borderDefault:"#e5e7eb",borderHover:"#d1d5db",borderSubtle:"#f3f4f6",accentPrimary:"#5E6AD2",accentHover:"#4A56B8",interactivePrimary:"#0ea5e9",interactivePrimaryHover:"#0284c7",interactivePrimaryBorder:"rgba(14, 165, 233, 0.3)",interactivePrimaryBackground:"rgba(14, 165, 233, 0.08)",interactivePrimaryBackgroundHover:"rgba(14, 165, 233, 0.15)",success:"#059669",warning:"#D97706",error:"#DC2626",info:"#2563EB",danger:"#dc2626",dangerBorder:"rgba(220, 38, 38, 0.3)",dangerBackground:"rgba(220, 38, 38, 0.08)",dangerBackgroundHover:"rgba(220, 38, 38, 0.15)"},shadows:{sm:"0 1px 3px rgba(0, 0, 0, 0.12)",md:"0 4px 12px rgba(0, 0, 0, 0.15)",lg:"0 12px 32px rgba(0, 0, 0, 0.2)"},radii:{sm:"6px",md:"8px",lg:"12px",full:"9999px"},spacing:{xs:"4px",sm:"8px",md:"16px",lg:"24px",xl:"32px"}},cs={name:"neutral",emoji:"\u26AA",displayName:"Neutral (Zen)",colors:{bgPrimary:"#FAFAF9",bgSecondary:"#F5F5F4",bgTertiary:"#E7E5E4",bgCard:"#FEFEFE",bgHover:"#F0EFEE",bgActive:"#E7E5E4",bgInput:"#FAFAF9",textPrimary:"#1C1917",textSecondary:"#57534E",textTertiary:"#A8A29E",textDisabled:"#D6D3D1",textInverse:"#FAFAF9",borderPrimary:"#E7E5E4",borderSecondary:"#F0EFEE",borderDefault:"#E7E5E4",borderHover:"#D6D3D1",borderSubtle:"#F5F5F4",accentPrimary:"#292524",accentHover:"#44403C",interactivePrimary:"#292524",interactivePrimaryHover:"#44403C",interactivePrimaryBorder:"rgba(41, 37, 36, 0.3)",interactivePrimaryBackground:"rgba(41, 37, 36, 0.06)",interactivePrimaryBackgroundHover:"rgba(41, 37, 36, 0.12)",success:"#15803D",warning:"#CA8A04",error:"#B91C1C",info:"#1D4ED8",danger:"#B91C1C",dangerBorder:"rgba(185, 28, 28, 0.3)",dangerBackground:"rgba(185, 28, 28, 0.08)",dangerBackgroundHover:"rgba(185, 28, 28, 0.15)"},shadows:{sm:"0 1px 3px rgba(0, 0, 0, 0.1)",md:"0 4px 12px rgba(0, 0, 0, 0.12)",lg:"0 12px 32px rgba(0, 0, 0, 0.15)"},radii:{sm:"6px",md:"8px",lg:"12px",full:"9999px"},spacing:{xs:"4px",sm:"8px",md:"16px",lg:"24px",xl:"32px"}},Yr={dark:is,light:ls,neutral:cs},Ln="dark";var Fn=Se.createContext(void 0),_f="asakaa-theme";function ac({children:e,defaultTheme:t=Ln,storageKey:r=_f}){let[a,n]=Se.useState(()=>{if(typeof window<"u"){let c=localStorage.getItem(r);if(c&&(c==="dark"||c==="light"||c==="neutral"))return c}return t}),o=Se.useCallback(c=>{n(c),typeof window<"u"&&localStorage.setItem(r,c);},[r]);Se.useEffect(()=>{if(typeof window>"u")return;let c=document.documentElement,u=Yr[a];Object.entries(u.colors).forEach(([p,l])=>{l&&c.style.setProperty(`--theme-${Hf(p)}`,l);}),Object.entries({bgPrimary:"--asakaa-color-background-primary",bgSecondary:"--asakaa-color-background-secondary",bgTertiary:"--asakaa-color-background-tertiary",bgCard:"--asakaa-color-background-card",bgHover:"--asakaa-color-background-hover",bgActive:"--asakaa-color-background-active",bgInput:"--asakaa-color-background-input",textPrimary:"--asakaa-color-text-primary",textSecondary:"--asakaa-color-text-secondary",textTertiary:"--asakaa-color-text-tertiary",textDisabled:"--asakaa-color-text-disabled",textInverse:"--asakaa-color-text-inverse",borderPrimary:"--asakaa-color-border-primary",borderSecondary:"--asakaa-color-border-secondary",borderDefault:"--asakaa-color-border-default",borderHover:"--asakaa-color-border-hover",borderSubtle:"--asakaa-color-border-subtle",accentPrimary:"--asakaa-color-accent-primary",accentHover:"--asakaa-color-accent-hover",interactivePrimary:"--asakaa-color-interactive-primary",interactivePrimaryHover:"--asakaa-color-interactive-primaryHover",interactivePrimaryBorder:"--asakaa-color-interactive-primaryBorder",interactivePrimaryBackground:"--asakaa-color-interactive-primaryBackground",interactivePrimaryBackgroundHover:"--asakaa-color-interactive-primaryBackgroundHover",success:"--asakaa-color-status-success",warning:"--asakaa-color-status-warning",error:"--asakaa-color-status-error",info:"--asakaa-color-status-info",danger:"--asakaa-color-danger",dangerBorder:"--asakaa-color-danger-border",dangerBackground:"--asakaa-color-danger-background",dangerBackgroundHover:"--asakaa-color-danger-backgroundHover"}).forEach(([p,l])=>{let d=u.colors[p];d&&c.style.setProperty(l,d);}),c.setAttribute("data-theme",a),c.classList.remove("theme-dark","theme-light","theme-neutral"),c.classList.add(`theme-${a}`);},[a]);let s={theme:a,setTheme:o,themes:Yr};return jsxRuntime.jsx(Fn.Provider,{value:s,children:e})}function pa(){let e=Se.useContext(Fn);if(!e)throw new Error("useTheme must be used within ThemeProvider");return e}function Hf(e){return e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase()}function ds({isOpen:e,onClose:t,className:r}){let{theme:a,setTheme:n}=pa();return e?jsxRuntime.jsxs("div",{className:L("fixed inset-0 z-[9999] flex items-center justify-center",r),children:[jsxRuntime.jsx("div",{className:"absolute inset-0 bg-black/60 backdrop-blur-sm",onClick:t}),jsxRuntime.jsxs("div",{className:"relative rounded-2xl border shadow-2xl max-w-md w-full mx-4",style:{backgroundColor:"var(--theme-bg-secondary)",borderColor:"var(--theme-border-primary)"},children:[jsxRuntime.jsxs("div",{className:"px-6 py-5 border-b flex items-center justify-between",style:{borderColor:"var(--theme-border-primary)"},children:[jsxRuntime.jsx("h2",{className:"text-2xl font-bold",style:{color:"var(--theme-text-primary)"},children:"Select Theme"}),jsxRuntime.jsx("button",{onClick:t,className:"text-2xl leading-none p-2 hover:bg-white/10 rounded-lg transition-colors",style:{color:"var(--theme-text-secondary)"},"aria-label":"Close",children:"\xD7"})]}),jsxRuntime.jsx("div",{className:"p-6 space-y-3",children:Object.entries(Yr).map(([o,s])=>jsxRuntime.jsxs("button",{onClick:()=>{n(o),t();},className:L("w-full p-4 rounded-lg border-2 transition-all flex items-center gap-4",a===o?"border-blue-500 bg-blue-500/20":"border-white/20 hover:border-white/40"),style:{backgroundColor:a===o?"var(--theme-accent-primary)20":"transparent"},children:[jsxRuntime.jsx("div",{className:"text-3xl",children:s.emoji}),jsxRuntime.jsxs("div",{className:"text-left flex-1",children:[jsxRuntime.jsx("div",{className:"font-semibold",style:{color:"var(--theme-text-primary)"},children:s.displayName}),jsxRuntime.jsxs("div",{className:"text-xs",style:{color:"var(--theme-text-secondary)"},children:[o==="dark"&&"Default dark theme with Linear-inspired colors",o==="light"&&"Clean light theme with high contrast",o==="neutral"&&"Monochrome zen theme"]})]}),a===o&&jsxRuntime.jsx("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"3",children:jsxRuntime.jsx("path",{d:"M20 6L9 17l-5-5"})})]},o))})]})]}):null}var Ce={dark:{bgPrimary:"#1A1D21",bgSecondary:"#23272E",bgGrid:"#1C1F24",bgWeekend:"rgba(59, 130, 246, 0.02)",border:"#2D3139",borderLight:"#26292F",textPrimary:"#F5F5F7",textSecondary:"#B4B9C5",textTertiary:"#7C8394",accent:"#3B82F6",accentHover:"#60A5FA",accentLight:"rgba(59, 130, 246, 0.12)",taskBarPrimary:"#3B82F6",taskBarProgress:"#2563EB",taskBarHandle:"#FFFFFF",dependency:"rgba(180, 185, 197, 0.25)",dependencyHover:"rgba(180, 185, 197, 0.45)",criticalPath:"#EF4444",criticalPathLight:"rgba(239, 68, 68, 0.12)",today:"#EF4444",todayLight:"rgba(239, 68, 68, 0.08)",milestone:"#F59E0B",milestoneLight:"rgba(245, 158, 11, 0.1)",statusTodo:"#7C8394",statusInProgress:"#3B82F6",statusCompleted:"#10B981",hoverBg:"rgba(255, 255, 255, 0.05)",focusRing:"#3B82F6"},light:{bgPrimary:"#FFFFFF",bgSecondary:"#F9FAFB",bgGrid:"#FDFEFE",bgWeekend:"rgba(37, 99, 235, 0.02)",border:"#E5E7EB",borderLight:"#F0F1F3",textPrimary:"#111827",textSecondary:"#4B5563",textTertiary:"#9CA3AF",accent:"#2563EB",accentHover:"#1D4ED8",accentLight:"rgba(37, 99, 235, 0.08)",taskBarPrimary:"#2563EB",taskBarProgress:"#1E40AF",taskBarHandle:"#FFFFFF",dependency:"rgba(75, 85, 99, 0.2)",dependencyHover:"rgba(75, 85, 99, 0.4)",criticalPath:"#DC2626",criticalPathLight:"rgba(220, 38, 38, 0.1)",today:"#2563EB",todayLight:"rgba(37, 99, 235, 0.08)",milestone:"#F59E0B",milestoneLight:"rgba(245, 158, 11, 0.08)",statusTodo:"#9CA3AF",statusInProgress:"#2563EB",statusCompleted:"#059669",hoverBg:"rgba(0, 0, 0, 0.03)",focusRing:"#2563EB"},neutral:{bgPrimary:"#FAFAF9",bgSecondary:"#F5F5F4",bgGrid:"#FBFBFA",bgWeekend:"rgba(41, 37, 36, 0.015)",border:"#E7E5E4",borderLight:"#F0EFEE",textPrimary:"#1C1917",textSecondary:"#57534E",textTertiary:"#A8A29E",accent:"#292524",accentHover:"#44403C",accentLight:"rgba(41, 37, 36, 0.06)",taskBarPrimary:"#292524",taskBarProgress:"#1C1917",taskBarHandle:"#FFFFFF",dependency:"rgba(87, 83, 78, 0.2)",dependencyHover:"rgba(87, 83, 78, 0.35)",criticalPath:"#44403C",criticalPathLight:"rgba(68, 64, 60, 0.08)",today:"#1C1917",todayLight:"rgba(28, 25, 23, 0.04)",milestone:"#57534E",milestoneLight:"rgba(87, 83, 78, 0.06)",statusTodo:"#A8A29E",statusInProgress:"#292524",statusCompleted:"#15803D",hoverBg:"rgba(0, 0, 0, 0.025)",focusRing:"#292524"}};function nc(e="dark"){if(typeof window>"u"||typeof getComputedStyle>"u")return Ce[e]||Ce.dark;let t=document.documentElement,r=getComputedStyle(t),a=(o,s)=>r.getPropertyValue(o).trim()||s;return {bgPrimary:a("--theme-bg-primary",Ce[e].bgPrimary),bgSecondary:a("--theme-bg-secondary",Ce[e].bgSecondary),bgGrid:a("--theme-bg-card",Ce[e].bgGrid),bgWeekend:a("--theme-bg-hover",Ce[e].bgWeekend),border:a("--theme-border-primary",Ce[e].border),borderLight:a("--theme-border-subtle",Ce[e].borderLight),textPrimary:a("--theme-text-primary",Ce[e].textPrimary),textSecondary:a("--theme-text-secondary",Ce[e].textSecondary),textTertiary:a("--theme-text-tertiary",Ce[e].textTertiary),accent:a("--theme-accent-primary",Ce[e].accent),accentHover:a("--theme-accent-hover",Ce[e].accentHover),accentLight:a("--theme-accent-primary",Ce[e].accentLight),taskBarPrimary:a("--theme-accent-primary",Ce[e].taskBarPrimary),taskBarProgress:a("--theme-accent-hover",Ce[e].taskBarProgress),taskBarHandle:a("--theme-text-inverse",Ce[e].taskBarHandle||"#FFFFFF"),dependency:a("--theme-border-secondary",Ce[e].dependency),dependencyHover:a("--theme-border-secondary",Ce[e].dependencyHover),criticalPath:a("--theme-error",Ce[e].criticalPath),criticalPathLight:a("--theme-error",Ce[e].criticalPathLight),today:e==="light"?a("--theme-accent-primary",Ce[e].today):e==="neutral"?a("--theme-text-primary",Ce[e].today):a("--theme-error",Ce[e].today),todayLight:e==="light"?a("--theme-accent-primary",Ce[e].todayLight):e==="neutral"?a("--theme-text-primary",Ce[e].todayLight):a("--theme-error",Ce[e].todayLight),milestone:a("--theme-warning",Ce[e].milestone),milestoneLight:a("--theme-warning",Ce[e].milestoneLight),statusTodo:a("--theme-text-tertiary",Ce[e].statusTodo),statusInProgress:a("--theme-accent-primary",Ce[e].statusInProgress),statusCompleted:a("--theme-success",Ce[e].statusCompleted),hoverBg:a("--theme-bg-hover",Ce[e].hoverBg),focusRing:a("--theme-accent-primary",Ce[e].focusRing)}}var Bn={columns:{taskName:"TASK NAME",startDate:"Start Date",endDate:"End Date",duration:"Duration",assignees:"Assignees",status:"Status",progress:"% Complete"},toolbar:{today:"Today",day:"Day",week:"Week",month:"Month",export:"Export",exportPdf:"Export to PDF",exportPng:"Export to PNG",exportCsv:"Export to CSV",exportExcel:"Export to Excel",exportMsProject:"Export to MS Project",undo:"Undo",redo:"Redo",createTask:"New Task",density:"Row Density",compact:"Compact",normal:"Normal",spacious:"Spacious"},contextMenu:{editTask:"Edit Task",addSubtask:"Add Subtask",markIncomplete:"Mark Incomplete",setInProgress:"Set In Progress",markComplete:"Mark Complete",splitTask:"Split Task",deleteTask:"Delete Task"},actions:{edit:"Edit",delete:"Delete",duplicate:"Duplicate",addSubtask:"Add Subtask",indent:"Indent",outdent:"Outdent",moveUp:"Move Up",moveDown:"Move Down",splitTask:"Split Task",linkTasks:"Link Tasks",unlinkTasks:"Unlink Tasks"},status:{todo:"To Do",inProgress:"In Progress",completed:"Completed"},labels:{progress:"Progress",duration:"Duration",days:"days",day:"day",assigned:"Assigned",milestone:"Milestone",criticalPath:"Critical Path",subtask:"Subtask",task:"Task",noTasks:"No tasks yet",addTask:"Add task",newTask:"New Task",loading:"Loading...",error:"Error",today:"Today"},ai:{placeholder:'Ask AI to edit tasks... (e.g., "Move Design to next week")',thinking:"Thinking...",suggestions:{moveTask:'Move "Task Name" to next Monday',extendTask:'Extend "Task Name" by 3 days',renameTask:'Rename "Old Name" to "New Name"',setProgress:'Set "Task Name" progress to 50%',linkTasks:'Link "Task A" to "Task B"',createTask:'Create a new task called "New Task"',deleteTask:'Delete "Task Name"',assignTask:'Assign John to "Task Name"'},errors:{taskNotFound:"Task not found",invalidDate:"Invalid date",invalidDuration:"Invalid duration",invalidProgress:"Invalid progress value",unknownCommand:"Unknown command",processingError:"Error processing command"}},export:{projectName:"Gantt Project",ganttTasks:"Gantt Tasks",taskId:"Task ID",taskName:"Task Name",startDate:"Start Date",endDate:"End Date",isMilestone:"Is Milestone",parentId:"Parent ID",yes:"Yes",no:"No",noTasksToExport:"No tasks available to export"},dateFormat:{short:"MM/dd",medium:"MMM d",long:"MMMM d, yyyy"}},oc={columns:{taskName:"NOMBRE DE TAREA",startDate:"Fecha Inicio",endDate:"Fecha Fin",duration:"Duraci\xF3n",assignees:"Asignados",status:"Estado",progress:"% Completado"},toolbar:{today:"Hoy",day:"D\xEDa",week:"Semana",month:"Mes",export:"Exportar",exportPdf:"Exportar a PDF",exportPng:"Exportar a PNG",exportCsv:"Exportar a CSV",exportExcel:"Exportar a Excel",exportMsProject:"Exportar a MS Project",undo:"Deshacer",redo:"Rehacer",createTask:"Nueva Tarea",density:"Densidad",compact:"Compacto",normal:"Normal",spacious:"Espacioso"},contextMenu:{editTask:"Editar Tarea",addSubtask:"Agregar Subtarea",markIncomplete:"Marcar Incompleta",setInProgress:"Marcar En Progreso",markComplete:"Marcar Completada",splitTask:"Dividir Tarea",deleteTask:"Eliminar Tarea"},actions:{edit:"Editar",delete:"Eliminar",duplicate:"Duplicar",addSubtask:"Agregar Subtarea",indent:"Aumentar Nivel",outdent:"Disminuir Nivel",moveUp:"Mover Arriba",moveDown:"Mover Abajo",splitTask:"Dividir Tarea",linkTasks:"Vincular Tareas",unlinkTasks:"Desvincular Tareas"},status:{todo:"Por Hacer",inProgress:"En Progreso",completed:"Completado"},labels:{progress:"Progreso",duration:"Duraci\xF3n",days:"d\xEDas",day:"d\xEDa",assigned:"Asignado",milestone:"Hito",criticalPath:"Ruta Cr\xEDtica",subtask:"Subtarea",task:"Tarea",noTasks:"Sin tareas a\xFAn",addTask:"Agregar tarea",newTask:"Nueva Tarea",loading:"Cargando...",error:"Error",today:"Hoy"},ai:{placeholder:'P\xEDdele a la IA que edite tareas... (ej: "Mover Dise\xF1o a la pr\xF3xima semana")',thinking:"Pensando...",suggestions:{moveTask:'Mover "Nombre de Tarea" al pr\xF3ximo lunes',extendTask:'Extender "Nombre de Tarea" por 3 d\xEDas',renameTask:'Renombrar "Nombre Anterior" a "Nombre Nuevo"',setProgress:'Establecer progreso de "Nombre de Tarea" al 50%',linkTasks:'Vincular "Tarea A" con "Tarea B"',createTask:'Crear una nueva tarea llamada "Nueva Tarea"',deleteTask:'Eliminar "Nombre de Tarea"',assignTask:'Asignar a Juan a "Nombre de Tarea"'},errors:{taskNotFound:"Tarea no encontrada",invalidDate:"Fecha inv\xE1lida",invalidDuration:"Duraci\xF3n inv\xE1lida",invalidProgress:"Valor de progreso inv\xE1lido",unknownCommand:"Comando desconocido",processingError:"Error procesando el comando"}},export:{projectName:"Proyecto Gantt",ganttTasks:"Tareas Gantt",taskId:"ID de Tarea",taskName:"Nombre de Tarea",startDate:"Fecha Inicio",endDate:"Fecha Fin",isMilestone:"Es Hito",parentId:"ID Padre",yes:"S\xED",no:"No",noTasksToExport:"No hay tareas disponibles para exportar"},dateFormat:{short:"dd/MM",medium:"d MMM",long:"d de MMMM de yyyy"}},us={en:Bn,es:oc};function sc(e){return us[e]||us.en}function ms(e,t){let r=sc(e);return t?{columns:{...r.columns,...t.columns},toolbar:{...r.toolbar,...t.toolbar},contextMenu:{...r.contextMenu,...t.contextMenu},actions:{...r.actions,...t.actions},status:{...r.status,...t.status},labels:{...r.labels,...t.labels},ai:{...r.ai,...t.ai,suggestions:{...r.ai.suggestions,...t.ai?.suggestions},errors:{...r.ai.errors,...t.ai?.errors}},export:{...r.export,...t.export},dateFormat:{...r.dateFormat,...t.dateFormat}}:r}var ga=Se.createContext(Bn);function Ha(){return Se.useContext(ga)}function ig({theme:e,onExportPNG:t,onExportPDF:r,onExportExcel:a,onExportCSV:n,onExportJSON:o,onExportMSProject:s}){let[c,u]=Se.useState(false),[i,p]=Se.useState(null),l=Se.useRef(null),d=Ha();if(Se.useEffect(()=>{let h=g=>{l.current&&!l.current.contains(g.target)&&u(false);};return c&&document.addEventListener("mousedown",h),()=>document.removeEventListener("mousedown",h)},[c]),!(t||r||a||n||o||s))return null;let v=[{id:"png",label:"PNG",description:"Image",icon:jsxRuntime.jsx(lucideReact.FileImage,{className:"w-4 h-4"}),handler:t},{id:"pdf",label:"PDF",description:"Document",icon:jsxRuntime.jsx(lucideReact.FileText,{className:"w-4 h-4"}),handler:r},{id:"excel",label:"Excel",description:"Spreadsheet",icon:jsxRuntime.jsx(lucideReact.FileSpreadsheet,{className:"w-4 h-4"}),handler:a},{id:"csv",label:"CSV",description:"Comma-separated",icon:jsxRuntime.jsx(lucideReact.FileText,{className:"w-4 h-4"}),handler:n},{id:"json",label:"JSON",description:"Data",icon:jsxRuntime.jsx(lucideReact.FileJson,{className:"w-4 h-4"}),handler:o},{id:"msproject",label:"MS Project",description:"XML",icon:jsxRuntime.jsx(lucideReact.FolderKanban,{className:"w-4 h-4"}),handler:s}].filter(h=>h.handler),y=async(h,g)=>{if(g){p(h);try{await g();}catch(b){console.error(`Export ${h} failed:`,b);}finally{p(null),u(false);}}};return jsxRuntime.jsxs("div",{ref:l,className:"relative",children:[jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>u(!c),className:"flex items-center gap-2 px-3 py-1.5 rounded-lg text-xs transition-all",style:{backgroundColor:c?e.accent:e.bgSecondary,border:`1px solid ${c?e.accent:e.borderLight}`,color:c?"#FFFFFF":e.textSecondary,fontFamily:"Inter, sans-serif",fontWeight:500},whileHover:{scale:1.02,backgroundColor:e.accent,color:"#FFFFFF"},whileTap:{scale:.98},children:[jsxRuntime.jsx(lucideReact.Download,{className:"w-3.5 h-3.5"}),jsxRuntime.jsx("span",{children:d.toolbar.export}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3 transition-transform",style:{transform:c?"rotate(180deg)":"rotate(0deg)"}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:c&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-8,scale:.95},animate:{opacity:1,y:0,scale:1},exit:{opacity:0,y:-8,scale:.95},transition:{duration:.15,ease:"easeOut"},className:"absolute right-0 mt-2 w-48 rounded-lg overflow-hidden z-50",style:{backgroundColor:e.bgSecondary,border:`1px solid ${e.border}`,boxShadow:"0 10px 40px rgba(0, 0, 0, 0.25)"},children:jsxRuntime.jsx("div",{className:"py-1",children:v.map((h,g)=>jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>y(h.id,h.handler),disabled:i!==null,className:"w-full flex items-center gap-3 px-3 py-2.5 text-left transition-all",style:{backgroundColor:"transparent",borderBottom:g<v.length-1?`1px solid ${e.borderLight}`:"none"},whileHover:{backgroundColor:e.hoverBg},initial:{opacity:0,x:-10},animate:{opacity:1,x:0},transition:{delay:g*.03},children:[jsxRuntime.jsx("div",{className:"flex items-center justify-center w-8 h-8 rounded-md",style:{backgroundColor:e.accentLight,color:e.accent},children:i===h.id?jsxRuntime.jsx(framerMotion.motion.div,{animate:{rotate:360},transition:{duration:1,repeat:1/0,ease:"linear"},children:jsxRuntime.jsx(lucideReact.Download,{className:"w-4 h-4"})}):h.icon}),jsxRuntime.jsxs("div",{className:"flex-1 min-w-0",children:[jsxRuntime.jsx("div",{className:"text-xs font-medium truncate",style:{color:e.textPrimary},children:h.label}),jsxRuntime.jsx("div",{className:"text-[10px] truncate",style:{color:e.textTertiary},children:h.description})]})]},h.id))})})})]})}function lg({options:e,value:t,onChange:r,theme:a,layoutId:n="activeSegment"}){return jsxRuntime.jsx("div",{className:"inline-flex p-1 rounded-lg relative",style:{backgroundColor:a.bgSecondary,border:`1px solid ${a.borderLight}`},children:e.map(o=>{let s=t===o.value;return jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>r(o.value),className:"relative px-3 py-1.5 rounded-md text-xs transition-all flex items-center gap-1.5 min-w-[70px] justify-center",style:{color:s?a.textPrimary:a.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:s?600:500,zIndex:s?2:1},whileHover:{scale:1.02},whileTap:{scale:.98},children:[s&&jsxRuntime.jsx(framerMotion.motion.div,{layoutId:n,className:"absolute inset-0 rounded-md",style:{backgroundColor:a.accent,boxShadow:"0 1px 3px rgba(0, 0, 0, 0.1)"},transition:{type:"spring",stiffness:400,damping:30}}),o.icon&&jsxRuntime.jsx("span",{className:"relative z-10",style:{color:s?"#FFFFFF":a.textTertiary},children:o.icon}),jsxRuntime.jsx("span",{className:"relative z-10",style:{color:s?"#FFFFFF":a.textTertiary},children:o.label})]},o.value)})})}function cg({options:e,value:t,onChange:r,theme:a}){return jsxRuntime.jsx("div",{className:"inline-flex items-center gap-1",children:e.map(n=>{let o=t===n.value;return jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>r(n.value),className:"relative px-3 py-1.5 text-xs transition-all",style:{color:o?a.accent:a.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:o?600:500},whileHover:{color:o?a.accent:a.textSecondary},whileTap:{scale:.98},children:[jsxRuntime.jsx("span",{children:n.label}),o&&jsxRuntime.jsx(framerMotion.motion.div,{layoutId:"timeScaleUnderline",className:"absolute bottom-0 left-1 right-1 h-0.5 rounded-full",style:{backgroundColor:a.accent},transition:{type:"spring",stiffness:400,damping:30}})]},n.value)})})}function dg({theme:e,value:t,onChange:r}){let[a,n]=Se.useState(false),o=Se.useRef(null),s=Ha();Se.useEffect(()=>{let i=p=>{o.current&&!o.current.contains(p.target)&&n(false);};return a&&document.addEventListener("mousedown",i),()=>document.removeEventListener("mousedown",i)},[a]);let c=[{value:"compact",label:s.toolbar.compact||"Compact"},{value:"comfortable",label:s.toolbar.normal||"Normal"},{value:"spacious",label:s.toolbar.spacious||"Spacious"}],u=c.find(i=>i.value===t)?.label||"Normal";return jsxRuntime.jsxs("div",{ref:o,className:"relative",children:[jsxRuntime.jsx(framerMotion.motion.button,{onClick:()=>n(!a),className:"flex items-center justify-center p-2 rounded-lg transition-all",style:{backgroundColor:a?e.accentLight:e.bgSecondary,border:`1px solid ${a?e.accent:e.borderLight}`,color:a?e.accent:e.textSecondary},whileHover:{backgroundColor:e.hoverBg,scale:1.02},whileTap:{scale:.98},title:`${s.toolbar.density||"Density"}: ${u}`,children:jsxRuntime.jsx(lucideReact.Rows3,{className:"w-4 h-4"})}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:a&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-8,scale:.95},animate:{opacity:1,y:0,scale:1},exit:{opacity:0,y:-8,scale:.95},transition:{duration:.15,ease:"easeOut"},className:"absolute left-0 mt-2 w-36 rounded-lg overflow-hidden z-50",style:{backgroundColor:e.bgSecondary,border:`1px solid ${e.border}`,boxShadow:"0 10px 40px rgba(0, 0, 0, 0.25)"},children:jsxRuntime.jsx("div",{className:"py-1",children:c.map((i,p)=>{let l=t===i.value;return jsxRuntime.jsxs(framerMotion.motion.button,{onClick:()=>{r(i.value),n(false);},className:"w-full flex items-center justify-between px-3 py-2 text-left transition-all",style:{backgroundColor:l?e.accentLight:"transparent",borderBottom:p<c.length-1?`1px solid ${e.borderLight}`:"none"},whileHover:{backgroundColor:l?e.accentLight:e.hoverBg},initial:{opacity:0,x:-10},animate:{opacity:1,x:0},transition:{delay:p*.03},children:[jsxRuntime.jsx("span",{className:"text-xs",style:{color:l?e.accent:e.textPrimary,fontFamily:"Inter, sans-serif",fontWeight:l?600:500},children:i.label}),l&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5",style:{color:e.accent}})]},i.value)})})})})]})}function On({theme:e,timeScale:t,onTimeScaleChange:r,zoom:a,onZoomChange:n,currentTheme:o,onThemeChange:s,rowDensity:c,onRowDensityChange:u,showThemeSelector:i=true,showCreateTaskButton:p=false,createTaskLabel:l,onCreateTask:d,onExportPNG:m,onExportPDF:v,onExportExcel:y,onExportCSV:h,onExportJSON:g,onExportMSProject:b}){let f=Ha(),k=m||v||y||h||g||b,w=[{value:"day",label:f.toolbar.day},{value:"week",label:f.toolbar.week},{value:"month",label:f.toolbar.month}],x=[{value:"dark",label:"Dark",icon:jsxRuntime.jsx(lucideReact.Moon,{className:"w-3.5 h-3.5"})},{value:"light",label:"Light",icon:jsxRuntime.jsx(lucideReact.Sun,{className:"w-3.5 h-3.5"})},{value:"neutral",label:"Zen",icon:jsxRuntime.jsx(lucideReact.Palette,{className:"w-3.5 h-3.5"})}];return jsxRuntime.jsxs("div",{className:"h-12 px-4 flex items-center justify-between border-b",style:{backgroundColor:e.bgGrid,borderColor:e.border},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(cg,{options:w,value:t,onChange:D=>r(D),theme:e}),jsxRuntime.jsx("div",{className:"w-px h-5",style:{backgroundColor:e.borderLight}}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx(framerMotion.motion.button,{onClick:()=>n(Math.max(.5,a-.1)),className:"p-1.5 rounded-md transition-all",style:{backgroundColor:"transparent",color:e.textSecondary},whileHover:{backgroundColor:e.hoverBg,scale:1.05},whileTap:{scale:.95},children:jsxRuntime.jsx(lucideReact.ZoomOut,{className:"w-3.5 h-3.5"})}),jsxRuntime.jsxs("div",{className:"px-2 py-0.5 rounded text-xs tabular-nums min-w-[42px] text-center",style:{color:e.textSecondary,fontFamily:"Inter, sans-serif",fontWeight:500},children:[Math.round(a*100),"%"]}),jsxRuntime.jsx(framerMotion.motion.button,{onClick:()=>n(Math.min(2,a+.1)),className:"p-1.5 rounded-md transition-all",style:{backgroundColor:"transparent",color:e.textSecondary},whileHover:{backgroundColor:e.hoverBg,scale:1.05},whileTap:{scale:.95},children:jsxRuntime.jsx(lucideReact.ZoomIn,{className:"w-3.5 h-3.5"})})]}),jsxRuntime.jsx("div",{className:"w-px h-5",style:{backgroundColor:e.borderLight}}),jsxRuntime.jsx(dg,{theme:e,value:c,onChange:u})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[p&&d&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs(framerMotion.motion.button,{onClick:d,className:"flex items-center gap-2 px-3 py-1.5 rounded-lg text-xs transition-all",style:{background:"linear-gradient(135deg, #10B981 0%, #059669 100%)",color:"#FFFFFF",fontFamily:"Inter, sans-serif",fontWeight:500,boxShadow:"0 2px 8px rgba(16, 185, 129, 0.3)"},whileHover:{scale:1.02,boxShadow:"0 4px 12px rgba(16, 185, 129, 0.4)"},whileTap:{scale:.98},children:[jsxRuntime.jsx(lucideReact.Plus,{className:"w-3.5 h-3.5"}),jsxRuntime.jsx("span",{children:l||f.toolbar.createTask})]}),(k||i)&&jsxRuntime.jsx("div",{className:"w-px h-6",style:{backgroundColor:e.borderLight}})]}),k&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(ig,{theme:e,onExportPNG:m,onExportPDF:v,onExportExcel:y,onExportCSV:h,onExportJSON:g,onExportMSProject:b}),i&&jsxRuntime.jsx("div",{className:"w-px h-6",style:{backgroundColor:e.borderLight}})]}),i&&jsxRuntime.jsx(lg,{options:x,value:o,onChange:D=>s(D),theme:e})]})]})}function zn({columns:e,onToggleColumn:t,theme:r}){let[a,n]=Se.useState(false),[o,s]=Se.useState({x:0,y:0}),c=Se.useRef(null),u=Se.useRef(null);Se.useEffect(()=>{if(!a)return;let p=l=>{c.current&&!c.current.contains(l.target)&&n(false);};return document.addEventListener("mousedown",p),()=>document.removeEventListener("mousedown",p)},[a]);let i=e.filter(p=>p.id!=="name");return jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(framerMotion.motion.button,{ref:u,onClick:()=>{if(!a&&u.current){let p=u.current.getBoundingClientRect();s({x:p.left,y:p.bottom+4});}n(!a);},className:"p-2 rounded-md transition-colors flex items-center gap-1",style:{backgroundColor:r.bgSecondary,border:`1px solid ${r.borderLight}`,color:r.textSecondary},whileHover:{backgroundColor:r.hoverBg,scale:1.05},whileTap:{scale:.95},children:jsxRuntime.jsx(lucideReact.Plus,{className:"w-4 h-4"})}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:a&&jsxRuntime.jsx(Ye,{children:jsxRuntime.jsx(framerMotion.motion.div,{ref:c,initial:{opacity:0,scale:.95,y:-10},animate:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:-10},transition:{duration:.15},className:"column-manager-menu fixed min-w-[180px] rounded-lg shadow-xl z-[9999]",style:{left:`${o.x}px`,top:`${o.y}px`,backgroundColor:r.bgSecondary,border:`1px solid ${r.border}`},children:jsxRuntime.jsxs("div",{className:"py-1",children:[jsxRuntime.jsx("div",{className:"px-3 py-2 text-xs uppercase tracking-wider",style:{color:r.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:600},children:"Add Column"}),i.map(p=>jsxRuntime.jsxs("button",{onClick:()=>{t(p.id);},className:"w-full px-3 py-2 text-left flex items-center justify-between transition-colors text-sm",style:{color:r.textPrimary,backgroundColor:"transparent",fontFamily:"Inter, sans-serif"},onMouseEnter:l=>{l.currentTarget.style.backgroundColor=r.hoverBg;},onMouseLeave:l=>{l.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{children:p.label}),p.visible&&jsxRuntime.jsx(lucideReact.Check,{className:"w-4 h-4",style:{color:r.accent}})]},p.id))]})})})})]})}function ha({isOpen:e,x:t,y:r,items:a,onClose:n,theme:o}){let s=Se.useRef(null);return Se.useEffect(()=>{if(!e)return;let c=i=>{s.current&&!s.current.contains(i.target)&&n();},u=i=>{i.key==="Escape"&&n();};return document.addEventListener("mousedown",c),document.addEventListener("keydown",u),()=>{document.removeEventListener("mousedown",c),document.removeEventListener("keydown",u);}},[e,n]),e?jsxRuntime.jsx(framerMotion.AnimatePresence,{children:jsxRuntime.jsx(framerMotion.motion.div,{ref:s,initial:{opacity:0,scale:.95,y:-10},animate:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:-10},transition:{duration:.15,ease:[.4,0,.2,1]},className:"fixed z-[9999] min-w-[200px] rounded-lg shadow-xl",style:{left:`${t}px`,top:`${r}px`,backgroundColor:o.bgSecondary,border:`1px solid ${o.border}`},children:jsxRuntime.jsx("div",{className:"py-1",children:a.map(c=>jsxRuntime.jsxs("div",{children:[c.separator&&jsxRuntime.jsx("div",{className:"my-1 h-px",style:{backgroundColor:o.borderLight}}),jsxRuntime.jsxs("button",{onClick:()=>{c.disabled||(c.onClick(),n());},disabled:c.disabled,className:"w-full px-3 py-2 text-left flex items-center gap-2 transition-colors text-sm",style:{color:c.disabled?o.textTertiary:o.textPrimary,backgroundColor:"transparent",fontFamily:"Inter, sans-serif",cursor:c.disabled?"not-allowed":"pointer",opacity:c.disabled?.5:1},onMouseEnter:u=>{c.disabled||(u.currentTarget.style.backgroundColor=o.hoverBg);},onMouseLeave:u=>{u.currentTarget.style.backgroundColor="transparent";},children:[c.icon&&jsxRuntime.jsx("span",{style:{color:o.textSecondary},children:c.icon}),jsxRuntime.jsx("span",{className:"flex-1",children:c.label}),c.submenu&&jsxRuntime.jsx(lucideReact.ChevronRight,{className:"w-3.5 h-3.5",style:{color:o.textTertiary}})]})]},c.id))})})}):null}var lt={Edit:jsxRuntime.jsx(lucideReact.Edit3,{className:"w-4 h-4"}),Pencil:jsxRuntime.jsx(lucideReact.Pencil,{className:"w-4 h-4"}),Delete:jsxRuntime.jsx(lucideReact.Trash2,{className:"w-4 h-4"}),Add:jsxRuntime.jsx(lucideReact.Plus,{className:"w-4 h-4"}),AddSubtask:jsxRuntime.jsx(lucideReact.Plus,{className:"w-4 h-4"}),Remove:jsxRuntime.jsx(lucideReact.Minus,{className:"w-4 h-4"}),Link:jsxRuntime.jsx(lucideReact.Link2,{className:"w-4 h-4"}),Progress:jsxRuntime.jsx(lucideReact.BarChart3,{className:"w-4 h-4"}),Sort:jsxRuntime.jsx(lucideReact.ArrowUpDown,{className:"w-4 h-4"}),SortAsc:jsxRuntime.jsx(lucideReact.ArrowUp,{className:"w-4 h-4"}),SortDesc:jsxRuntime.jsx(lucideReact.ArrowDown,{className:"w-4 h-4"}),Hide:jsxRuntime.jsx(lucideReact.EyeOff,{className:"w-4 h-4"}),Show:jsxRuntime.jsx(lucideReact.Eye,{className:"w-4 h-4"}),Settings:jsxRuntime.jsx(lucideReact.Settings,{className:"w-4 h-4"}),Split:jsxRuntime.jsx(lucideReact.Scissors,{className:"w-4 h-4"}),MarkIncomplete:jsxRuntime.jsx(lucideReact.Circle,{className:"w-4 h-4"}),SetInProgress:jsxRuntime.jsx(lucideReact.PlayCircle,{className:"w-4 h-4"}),MarkComplete:jsxRuntime.jsx(lucideReact.CheckCircle2,{className:"w-4 h-4"})};function vc({tasks:e,selectedTaskIds:t,onTaskSelect:r,onTaskCreate:a,onTaskDelete:n,onTaskDuplicate:o,onTaskMove:s,onTaskIndent:c,onTaskOutdent:u,onTaskRename:i,onTaskToggleExpand:p,onOpenTaskModal:l,enableKeyboard:d=true}){let m=Se.useRef(false),v=Se.useCallback(f=>{m.current=f;},[]),y=Se.useCallback(f=>{let k=[],w=x=>{for(let D of x)k.push(D),D.subtasks&&D.subtasks.length>0&&D.isExpanded&&w(D.subtasks);};return w(f),k},[]),h=Se.useCallback(()=>{let f=y(e);for(let k of f)if(t.has(k.id))return k;return null},[e,t,y]),g=Se.useCallback((f,k)=>{let w=y(e);if(w.length===0)return;let x=h();if(!x){r(w[0].id,false);return}let D=w.findIndex(T=>T.id===x.id);if(D===-1)return;let C=f==="up"?D-1:D+1;if(C<0||C>=w.length)return;let N=w[C];r(N.id,k);},[e,h,y,r]),b=Se.useCallback(f=>{if(!d)return;let k=f.target;if(k.tagName==="INPUT"||k.tagName==="TEXTAREA"||k.isContentEditable||m.current){f.key==="Escape"&&(k.blur(),m.current=false);return}let D=navigator.platform.toUpperCase().indexOf("MAC")>=0?f.metaKey:f.ctrlKey,C=Array.from(t),N=h();if(f.key==="ArrowUp"){f.preventDefault(),g("up",f.shiftKey);return}if(f.key==="ArrowDown"){f.preventDefault(),g("down",f.shiftKey);return}if(N&&(f.key==="ArrowRight"||f.key==="ArrowLeft")){N.subtasks&&N.subtasks.length>0&&(f.preventDefault(),(f.key==="ArrowRight"&&!N.isExpanded||f.key==="ArrowLeft"&&N.isExpanded)&&p(N.id));return}if(f.altKey&&(f.key==="ArrowUp"||f.key==="ArrowDown")){C.length>0&&(f.preventDefault(),s(C,f.key==="ArrowUp"?"up":"down"));return}if(f.key==="Tab"&&!f.shiftKey){C.length>0&&(f.preventDefault(),c(C));return}if(f.key==="Tab"&&f.shiftKey){C.length>0&&(f.preventDefault(),u(C));return}if(f.key==="Enter"&&!f.shiftKey&&!D){N&&(f.preventDefault(),a(N.id,"below"));return}if(f.key==="Enter"&&f.shiftKey&&!D){N&&(f.preventDefault(),a(N.id,"above"));return}if(f.key==="Enter"&&D){N&&(f.preventDefault(),l(N.id));return}if(f.key==="F2"){N&&(f.preventDefault(),i(N.id));return}if(f.key==="Delete"||f.key==="Backspace"&&D){C.length>0&&(f.preventDefault(),n(C));return}if(f.key==="d"&&D&&!f.shiftKey){C.length>0&&(f.preventDefault(),o(C));return}},[d,t,h,g,a,n,o,s,c,u,i,p,l]);return Se.useEffect(()=>{if(d)return window.addEventListener("keydown",b),()=>{window.removeEventListener("keydown",b);}},[d,b]),{setIsEditing:v}}function xc(){let[e,t]=Se.useState(new Set),[r,a]=Se.useState(null),n=Se.useCallback(l=>{t(new Set([l])),a(l);},[]),o=Se.useCallback(l=>{t(d=>{let m=new Set(d);return m.has(l)?m.delete(l):m.add(l),m}),a(l);},[]),s=Se.useCallback((l,d)=>{if(!r){n(l);return}let m=d.indexOf(r),v=d.indexOf(l);if(m===-1||v===-1){n(l);return}let y=Math.min(m,v),h=Math.max(m,v),g=d.slice(y,h+1);t(new Set(g)),a(l);},[r,n]),c=Se.useCallback((l,d,m,v)=>{v?s(l,d):m?o(l):n(l);},[n,o,s]),u=Se.useCallback((l,d)=>{d?t(m=>{let v=new Set(m);return v.add(l),v}):n(l);},[n]),i=Se.useCallback(()=>{t(new Set),a(null);},[]),p=Se.useCallback(l=>e.has(l),[e]);return {selectedTaskIds:e,selectTask:n,toggleTaskSelection:o,selectTaskRange:s,handleTaskClick:c,handleKeyboardSelection:u,clearSelection:i,isTaskSelected:p}}function ba(e){let t=[],r=(a,n,o=0)=>{for(let s=0;s<a.length;s++){let c={...a[s],parentId:n,level:o,position:s};t.push(c),c.subtasks&&c.subtasks.length>0&&c.isExpanded&&r(c.subtasks,c.id,o+1);}};return r(e),t}function gs(e,t){for(let r of e)if(r.subtasks){if(r.subtasks.some(n=>n.id===t))return r;let a=gs(r.subtasks,t);if(a)return a}return null}function hs(e,t){if(t.length===0)return e;let r=ba(e),a=t[0],n=r.findIndex(l=>l.id===a);if(n<=0)return e;let o=r[n-1],s=(l,d)=>{let m=[];return {tasks:l.filter(y=>{if(d.has(y.id))return m.push(y),false;if(y.subtasks){let h=s(y.subtasks,d);y.subtasks=h.tasks,m.push(...h.removed);}return true}),removed:m}},c=(l,d,m)=>l.map(v=>v.id===d?{...v,subtasks:[...v.subtasks||[],...m],isExpanded:true}:v.subtasks?{...v,subtasks:c(v.subtasks,d,m)}:v),u=new Set(t),{tasks:i,removed:p}=s(e,u);return c(i,o.id,p)}function bs(e,t){if(t.length===0)return e;let r=[...e];for(let a of t){let n=gs(r,a);if(!n)continue;let o=gs(r,n.id),s=(i,p,l)=>{for(let d=0;d<i.length;d++){let m=i[d];if(m.id===p&&m.subtasks){let v=m.subtasks.findIndex(y=>y.id===l);if(v!==-1){let[y]=m.subtasks.splice(v,1);return y}}if(m.subtasks){let v=s(m.subtasks,p,l);if(v)return v}}return null},c=(i,p,l)=>{let d=i.findIndex(m=>m.id===p);if(d!==-1)return i.splice(d+1,0,l),i;for(let m of i)m.subtasks&&c(m.subtasks,p,l);return i},u=s(r,n.id,a);u&&(o&&o.subtasks?c(o.subtasks,n.id,u):c(r,n.id,u));}return r}function vs(e,t,r){if(t.length===0)return e;let a=[...e],n=t[0],o=(s,c,u)=>{let i=s.findIndex(l=>l.id===c);if(i===-1){for(let l of s)if(l.subtasks&&o(l.subtasks,c,u))return true;return false}let p=u==="up"?i-1:i+1;return p<0||p>=s.length?false:([s[i],s[p]]=[s[p],s[i]],true)};return o(a,n,r),a}function $n(e,t){let r=new Set(t),a=n=>n.filter(o=>!r.has(o.id)).map(o=>o.subtasks?{...o,subtasks:a(o.subtasks)}:o);return a(e)}function ys(e,t){let r=[...e];for(let a of t){let n=s=>{let c=s.findIndex(p=>p.id===a);if(c===-1){for(let p of s)if(p.subtasks&&n(p.subtasks))return true;return false}let u=s[c],i={...u,id:`${u.id}-copy-${Date.now()}`,name:`${u.name} (Copy)`,subtasks:u.subtasks?o(u.subtasks):void 0};return s.splice(c+1,0,i),true},o=s=>s.map(c=>({...c,id:`${c.id}-copy-${Date.now()}`,subtasks:c.subtasks?o(c.subtasks):void 0}));n(r);}return r}function kc(e,t,r){let a=[...e],n=new Date,o=new Date(n);o.setDate(o.getDate()+7);let s={id:`task-${Date.now()}`,name:"New Task",progress:0,status:"todo",startDate:n,endDate:o,color:"#6366F1"},c=u=>{let i=u.findIndex(l=>l.id===t);if(i===-1){for(let l of u)if(l.subtasks&&c(l.subtasks))return true;return false}let p=r==="above"?i:i+1;return u.splice(p,0,s),true};return c(a),{tasks:a,newTask:s}}function xs(e,t,r){return e.map(a=>a.id===t?{...a,name:r}:a.subtasks?{...a,subtasks:xs(a.subtasks,t,r)}:a)}function ks(e,t){return e.map(r=>r.id===t?{...r,isExpanded:!r.isExpanded}:r.subtasks?{...r,subtasks:ks(r.subtasks,t)}:r)}function ws(e,t){let r=p=>{for(let l of p){if(l.id===t)return l;if(l.subtasks){let d=r(l.subtasks);if(d)return d}}return null},a=r(e),n=new Date,o=new Date(n);o.setDate(o.getDate()+7);let s=a?.startDate||n,c=a?.endDate||o,u={id:`task-${Date.now()}`,name:"New Subtask",progress:0,status:"todo",startDate:new Date(s),endDate:new Date(c),color:a?.color||"#3B82F6"},i=p=>p.map(l=>{if(l.id===t){let d=l.subtasks||[];return {...l,subtasks:[...d,u],isExpanded:true}}return l.subtasks?{...l,subtasks:i(l.subtasks)}:l});return {tasks:i(e),newTask:u}}var Tc={todo:{label:"To Do",color:"#94a3b8",icon:"circle"},"in-progress":{label:"In Progress",color:"#60a5fa",icon:"circle-dot"},completed:{label:"Completed",color:"#34d399",icon:"check-circle"}},Dc=({icon:e,color:t})=>e==="circle"?jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"6",stroke:t,strokeWidth:"1.5",fill:"none"})}):e==="circle-dot"?jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"6",stroke:t,strokeWidth:"1.5",fill:"none"}),jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"3",fill:t})]}):jsxRuntime.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[jsxRuntime.jsx("circle",{cx:"8",cy:"8",r:"6",stroke:t,strokeWidth:"1.5",fill:t,fillOpacity:"0.2"}),jsxRuntime.jsx("path",{d:"M5 8L7 10L11 6",stroke:t,strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})]});function Sc({status:e="todo",onChange:t,className:r}){let[a,n]=Se.useState(false),[o,s]=Se.useState({top:0,left:0}),c=Se.useRef(null),u=Se.useRef(null);Se.useEffect(()=>{if(a&&u.current){let d=u.current.getBoundingClientRect();s({top:d.bottom+window.scrollY+8,left:d.left+window.scrollX});}},[a]),Se.useEffect(()=>{let d=m=>{c.current&&!c.current.contains(m.target)&&!u.current?.contains(m.target)&&n(false);};if(a)return document.addEventListener("mousedown",d),()=>document.removeEventListener("mousedown",d)},[a]),Se.useEffect(()=>{let d=m=>{m.key==="Escape"&&n(false);};if(a)return document.addEventListener("keydown",d),()=>document.removeEventListener("keydown",d)},[a]);let i=d=>{t(d),n(false);},p=Tc[e],l=p.color;return jsxRuntime.jsxs("div",{className:`relative ${r||""}`,children:[jsxRuntime.jsx("button",{ref:u,onClick:()=>n(!a),className:"flex items-center justify-center w-8 h-8 rounded-lg transition-all hover:bg-white/15 hover:scale-110 active:scale-95",style:{background:`${l}10`,boxShadow:`0 0 0 2px ${l}30 inset`},title:p.label,children:jsxRuntime.jsx(Dc,{icon:p.icon,color:l})}),a&&jsxRuntime.jsx(Ye,{children:jsxRuntime.jsxs("div",{ref:c,className:"status-selector-menu",style:{position:"absolute",top:`${o.top}px`,left:`${o.left}px`,zIndex:99999,minWidth:"180px",borderRadius:"8px",background:"var(--modal-v2-bg, #1f1f1f)",border:"1px solid var(--modal-v2-border, rgba(255, 255, 255, 0.15))",boxShadow:"0 10px 40px rgba(0, 0, 0, 0.8), 0 0 0 1px rgba(255, 255, 255, 0.1)"},children:[jsxRuntime.jsx("div",{className:"px-3 py-1.5 border-b",style:{borderColor:"var(--modal-v2-border, rgba(255, 255, 255, 0.1))"},children:jsxRuntime.jsx("span",{className:"text-[10px] font-bold uppercase tracking-wider",style:{color:"var(--modal-v2-text-secondary, rgba(255, 255, 255, 0.7))"},children:"Status"})}),jsxRuntime.jsx("div",{className:"py-1",children:Object.entries(Tc).map(([d,m])=>jsxRuntime.jsxs("button",{onClick:()=>i(d),className:"w-full px-3 py-2 flex items-center gap-2.5 text-sm font-medium transition-all active:scale-[0.98] status-option",style:{color:m.color,background:"transparent"},onMouseEnter:v=>{v.currentTarget.style.background="var(--modal-v2-bg-tertiary, rgba(255, 255, 255, 0.15))";},onMouseLeave:v=>{v.currentTarget.style.background="transparent";},children:[jsxRuntime.jsx(Dc,{icon:m.icon,color:m.color}),jsxRuntime.jsx("span",{className:"font-semibold",children:m.label}),e===d&&jsxRuntime.jsx("svg",{className:"ml-auto",width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:jsxRuntime.jsx("path",{d:"M13.5 4.5L6 12L2.5 8.5",stroke:"#3B82F6",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})]},d))})]})})]})}function Wn({tasks:e,theme:t,rowHeight:r,availableUsers:a=[],templates:n,onTaskClick:o,onTaskDblClick:s,onTaskContextMenu:c,onTaskToggle:u,scrollTop:i,columns:p,onToggleColumn:l,onColumnResize:d,onTaskUpdate:m,onTaskIndent:v,onTaskOutdent:y,onTaskMove:h,onMultiTaskDelete:g,onTaskDuplicate:b,onTaskCreate:f,onTaskRename:k,onCreateSubtask:w,onOpenTaskModal:x}){let D=Se.useContext(ga),[C,N]=Se.useState(null),[T,$]=Se.useState(false),[z,R]=Se.useState(null),[W,E]=Se.useState(""),O=Se.useRef(null),G=Se.useRef(null),[U,A]=Se.useState(null),[K,_]=Se.useState(0),[ae,M]=Se.useState(0),[de,ie]=Se.useState({isOpen:false,x:0,y:0,type:"header"});Se.useEffect(()=>{function X(j){O.current&&!O.current.contains(j.target)&&$(false);}if(T)return document.addEventListener("mousedown",X),()=>document.removeEventListener("mousedown",X)},[T]),Se.useEffect(()=>{z&&G.current&&(G.current.focus(),G.current.select());},[z]),Se.useEffect(()=>{if(!U)return;let X=Te=>{let We=Te.clientX-K,re=ae+We;d?.(U,re);},j=()=>{A(null),document.body.style.cursor="",document.body.style.userSelect="";};return document.addEventListener("mousemove",X),document.addEventListener("mouseup",j),document.body.style.cursor="col-resize",document.body.style.userSelect="none",()=>{document.removeEventListener("mousemove",X),document.removeEventListener("mouseup",j),document.body.style.cursor="",document.body.style.userSelect="";}},[U,K,ae,d]);let{selectedTaskIds:kt,handleTaskClick:rt,isTaskSelected:ir}=xc(),{setIsEditing:De}=vc({tasks:e,selectedTaskIds:kt,onTaskSelect:(X,j)=>{let We=ba(e).map(re=>re.id);rt(X,We,j||false,false);},onTaskCreate:f||(()=>{}),onTaskDelete:g||(()=>{}),onTaskDuplicate:b||(()=>{}),onTaskMove:h||(()=>{}),onTaskIndent:v||(()=>{}),onTaskOutdent:y||(()=>{}),onTaskRename:X=>{let j=ba(e).find(Te=>Te.id===X);j&&zr(j);},onTaskToggleExpand:u||(()=>{}),onOpenTaskModal:X=>{let j=ba(e).find(Te=>Te.id===X);j&&x&&x(j);},enableKeyboard:true}),bt=(X,j=0)=>{let Te=[];for(let We of X)Te.push({task:We,level:j}),We.subtasks&&We.subtasks.length>0&&We.isExpanded&&Te.push(...bt(We.subtasks,j+1));return Te},wt=bt(e),jt=48,hr=X=>!X.startDate||!X.endDate?"-":`${Math.ceil((X.endDate.getTime()-X.startDate.getTime())/(1e3*60*60*24))}d`,zr=X=>{R(X.id),E(X.name),De(true);},he=X=>{W.trim()&&W!==e.find(j=>j.id===X)?.name&&k?.(X,W.trim()),R(null),E(""),De(false);},at=()=>{R(null),E(""),De(false);},Kt=(X,j)=>{j.stopPropagation(),w?.(X.id);},Wt=(X,j,Te)=>{switch(X.id){case "name":let We=z===j.id,re=C===j.id;return jsxRuntime.jsxs("div",{className:"flex items-center gap-2 flex-1 min-w-0 relative",style:{paddingLeft:`${Te*20}px`},children:[j.subtasks&&j.subtasks.length>0?jsxRuntime.jsx("button",{onClick:J=>{J.stopPropagation(),u?.(j.id);},className:"p-0.5 hover:bg-opacity-10 rounded transition-colors flex-shrink-0",style:{color:t.textSecondary},children:j.isExpanded?jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-4 h-4"}):jsxRuntime.jsx(lucideReact.ChevronRight,{className:"w-4 h-4"})}):jsxRuntime.jsx("div",{className:"w-5 h-5 flex-shrink-0"}),jsxRuntime.jsx("div",{className:"w-3 h-3 rounded-full flex-shrink-0 border",style:{backgroundColor:j.color||"#3B82F6",opacity:j.parentId?.6:1,borderColor:j.isMilestone?t.accent:"transparent",borderWidth:j.isMilestone?"2px":"0px"},title:j.isMilestone?"Milestone":j.parentId?"Subtask":"Task"}),We?jsxRuntime.jsx("input",{ref:G,type:"text",value:W,onChange:J=>E(J.target.value),onKeyDown:J=>{J.key==="Enter"?he(j.id):J.key==="Escape"&&at();},onBlur:()=>he(j.id),className:"flex-1 px-2 py-1 rounded border outline-none",style:{backgroundColor:t.bgPrimary,borderColor:t.accent,color:t.textPrimary,fontFamily:"Inter, sans-serif",fontSize:"13px",fontWeight:500},onClick:J=>J.stopPropagation()}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("span",{className:"flex-1",style:{color:t.textPrimary,fontFamily:"Inter, sans-serif",fontSize:Te===0?"14px":Te===1?"13px":"12px",fontWeight:j.isMilestone?600:j.subtasks&&j.subtasks.length>0?500:400,opacity:Te===0?1:Te===1?.95:.88},title:j.name,children:j.name}),re&&!We&&jsxRuntime.jsxs("div",{className:"flex items-center gap-1 ml-2",onClick:J=>J.stopPropagation(),children:[jsxRuntime.jsx("button",{onClick:J=>Kt(j,J),className:"p-1 rounded hover:bg-opacity-20 transition-colors",style:{color:t.textTertiary,backgroundColor:"transparent"},title:"Create subtask",children:jsxRuntime.jsx(lucideReact.Plus,{className:"w-3.5 h-3.5"})}),jsxRuntime.jsx("button",{onClick:J=>{J.stopPropagation(),zr(j);},className:"p-1 rounded hover:bg-opacity-20 transition-colors",style:{color:t.textTertiary,backgroundColor:"transparent"},title:"Rename (F2)",children:jsxRuntime.jsx(lucideReact.Edit3,{className:"w-3.5 h-3.5"})})]})]})]});case "startDate":let le=j.startDate?typeof j.startDate=="string"?j.startDate:j.startDate.toISOString().split("T")[0]:void 0;return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx("input",{type:"date",value:le||"",onChange:J=>{m?.(j.id,{startDate:J.target.value?new Date(J.target.value):void 0});},className:"bg-transparent border-none text-xs cursor-pointer outline-none text-center",style:{color:t.textSecondary,fontFamily:"Inter, sans-serif"}})});case "endDate":let lr=j.endDate?typeof j.endDate=="string"?j.endDate:j.endDate.toISOString().split("T")[0]:void 0;return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx("input",{type:"date",value:lr||"",onChange:J=>{m?.(j.id,{endDate:J.target.value?new Date(J.target.value):void 0});},className:"bg-transparent border-none text-xs cursor-pointer outline-none text-center",style:{color:t.textSecondary,fontFamily:"Inter, sans-serif"}})});case "duration":return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",children:jsxRuntime.jsx("span",{className:"text-xs tabular-nums",style:{color:t.textSecondary,fontFamily:"Inter, sans-serif",fontWeight:600},children:hr(j)})});case "assignees":let Ut=a.filter(J=>j.assignees?.some(Y=>Y.name===J.name||Y.initials===J.initials));return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx(Vr,{assignedUsers:Ut,availableUsers:a,onChange:J=>{let Y=J.map(ve=>({id:ve.id,name:ve.name,initials:ve.initials,color:ve.color}));m?.(j.id,{assignees:Y.length>0?Y:void 0});}})});case "status":return jsxRuntime.jsx("div",{className:"flex items-center justify-center w-full",onClick:J=>J.stopPropagation(),children:jsxRuntime.jsx(Sc,{status:j.status||"todo",onChange:J=>{m?.(j.id,{status:J,progress:J==="completed"?100:j.progress});}})});case "progress":return jsxRuntime.jsxs("div",{className:"flex items-center justify-center gap-2 w-full",children:[jsxRuntime.jsx("div",{className:"flex-1 h-1.5 rounded-full overflow-hidden max-w-[60px]",style:{backgroundColor:t.bgSecondary},children:jsxRuntime.jsx("div",{className:"h-full rounded-full transition-all",style:{width:`${j.progress}%`,backgroundColor:j.progress===100?t.statusCompleted:t.accent}})}),jsxRuntime.jsxs("span",{className:"text-xs tabular-nums min-w-[35px] text-right",style:{color:t.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:600},children:[j.progress,"%"]})]});default:return null}},$r=X=>[{id:"hide",label:"Hide Column",icon:lt.Hide,onClick:()=>l(X),disabled:X==="name"},{id:"sep1",label:"",onClick:()=>{},separator:true},{id:"sortAsc",label:"Sort Ascending",icon:lt.SortAsc,onClick:()=>{}},{id:"sortDesc",label:"Sort Descending",icon:lt.SortDesc,onClick:()=>{}}],se=X=>[{id:"edit",label:D?.contextMenu?.editTask||"Edit Task",icon:lt.Pencil,onClick:()=>{s?.(X);}},{id:"addSubtask",label:D?.contextMenu?.addSubtask||"Add Subtask",icon:lt.Add,onClick:()=>{w?.(X.id);}},{id:"sep1",label:"",onClick:()=>{},separator:true},{id:"markIncomplete",label:D?.contextMenu?.markIncomplete||"Mark Incomplete",icon:lt.MarkIncomplete,onClick:()=>{m?.(X.id,{status:"todo",progress:0});},disabled:X.status==="todo"},{id:"setInProgress",label:D?.contextMenu?.setInProgress||"Set In Progress",icon:lt.SetInProgress,onClick:()=>{m?.(X.id,{status:"in-progress"});},disabled:X.status==="in-progress"},{id:"markComplete",label:D?.contextMenu?.markComplete||"Mark Complete",icon:lt.MarkComplete,onClick:()=>{m?.(X.id,{status:"completed",progress:100});},disabled:X.status==="completed"},{id:"sep2",label:"",onClick:()=>{},separator:true},{id:"split",label:D?.contextMenu?.splitTask||"Split Task",icon:lt.Split,onClick:()=>{},disabled:true},{id:"sep3",label:"",onClick:()=>{},separator:true},{id:"delete",label:D?.contextMenu?.deleteTask||"Delete Task",icon:lt.Delete,onClick:()=>{g?.([X.id]);}}],ue=p.filter(X=>X.visible);return jsxRuntime.jsxs("div",{className:"h-full overflow-hidden",style:{backgroundColor:t.bgPrimary},children:[jsxRuntime.jsxs("div",{className:"sticky top-0 z-10 flex items-center",style:{backgroundColor:t.bgGrid,height:`${jt}px`,paddingLeft:"3px",borderBottom:`1px solid ${t.border}`,boxSizing:"border-box"},children:[ue.map((X,j)=>jsxRuntime.jsxs("div",{className:`flex items-center px-4 cursor-pointer hover:bg-opacity-50 transition-colors relative ${X.id==="name"?"justify-start":"justify-center"}`,style:{width:`${X.width}px`,minWidth:`${X.width}px`,maxWidth:`${X.width}px`,borderRight:j<ue.length-1?`1px solid ${t.borderLight}`:"none",height:"100%",boxSizing:"border-box"},onContextMenu:Te=>{Te.preventDefault(),ie({isOpen:true,x:Te.clientX,y:Te.clientY,type:"header",columnId:X.id});},onMouseEnter:Te=>{Te.currentTarget.style.backgroundColor=t.hoverBg;},onMouseLeave:Te=>{Te.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{className:"text-xs uppercase tracking-wider",style:{color:t.textTertiary,fontFamily:"Inter, sans-serif",fontWeight:600},children:X.label}),X.resizable&&jsxRuntime.jsx("div",{className:"absolute right-0 top-0 bottom-0 w-1 cursor-col-resize hover:bg-blue-500 transition-colors group",style:{backgroundColor:U===X.id?t.accent:"transparent"},onMouseDown:Te=>{Te.preventDefault(),Te.stopPropagation(),A(X.id),_(Te.clientX),M(X.width);},title:"Drag to resize column",children:jsxRuntime.jsx("div",{className:"absolute right-0 top-2 bottom-2 w-0.5 opacity-0 group-hover:opacity-100 transition-opacity",style:{backgroundColor:t.accent}})})]},X.id)),jsxRuntime.jsxs("div",{className:"px-3 flex items-center gap-2 h-full",children:[jsxRuntime.jsx(zn,{columns:p,onToggleColumn:l,theme:t}),jsxRuntime.jsxs("button",{onClick:()=>$(!T),className:"p-1.5 rounded hover:bg-opacity-10 transition-colors relative group",style:{color:t.textTertiary},title:"Keyboard shortcuts",children:[jsxRuntime.jsx(lucideReact.Keyboard,{className:"w-4 h-4"}),T&&jsxRuntime.jsxs("div",{ref:O,className:"absolute top-full right-0 mt-2 p-4 rounded-lg shadow-2xl z-50 min-w-[400px]",style:{backgroundColor:t.bgPrimary,border:`1px solid ${t.border}`,color:t.textPrimary},onClick:X=>X.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between mb-3 pb-2 border-b",style:{borderColor:t.border},children:[jsxRuntime.jsx("h3",{className:"font-semibold text-sm",style:{color:t.textPrimary},children:"Keyboard Shortcuts"}),jsxRuntime.jsx("button",{onClick:()=>$(false),className:"text-xs px-2 py-1 rounded hover:bg-opacity-10",style:{color:t.textTertiary},children:"Close"})]}),jsxRuntime.jsxs("div",{className:"space-y-3 text-xs",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Navigation"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Move focus up/down"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"\u2191 / \u2193"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Select range"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Shift + \u2191 / \u2193"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Toggle selection"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Cmd/Ctrl + Click"})]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Hierarchy"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Indent task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Tab"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Outdent task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Shift + Tab"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Expand/Collapse"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"\u2192 / \u2190"})]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Editing"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Create task below"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Enter"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Create task above"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Shift + Enter"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Open task modal"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Cmd/Ctrl + Enter"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Rename task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"F2"})]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("div",{className:"font-semibold mb-1.5",style:{color:t.textSecondary},children:"Actions"}),jsxRuntime.jsxs("div",{className:"space-y-1",children:[jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Move task up/down"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Alt + \u2191 / \u2193"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Delete task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Delete"})]}),jsxRuntime.jsxs("div",{className:"flex justify-between",children:[jsxRuntime.jsx("span",{style:{color:t.textTertiary},children:"Duplicate task"}),jsxRuntime.jsx("kbd",{className:"px-2 py-0.5 rounded font-mono text-xs",style:{backgroundColor:t.bgGrid,color:t.textPrimary},children:"Cmd/Ctrl + D"})]})]})]})]})]})]})]})]}),jsxRuntime.jsx("div",{className:"gantt-taskgrid-content",children:wt.map(({task:X,level:j},Te)=>{let We=ir(X.id);return jsxRuntime.jsx(framerMotion.motion.div,{className:"flex items-center cursor-pointer group",style:{height:`${r}px`,borderLeft:We?`3px solid ${t.accent}`:"3px solid transparent",backgroundColor:We?t.accentLight:Te%2===0?t.bgPrimary:t.bgGrid},onMouseEnter:()=>N(X.id),onMouseLeave:()=>N(null),onClick:re=>{let lr=ba(e).map(Y=>Y.id),J=navigator.platform.toUpperCase().indexOf("MAC")>=0?re.metaKey:re.ctrlKey;rt(X.id,lr,J,re.shiftKey),o?.(X);},onDoubleClick:re=>{re.stopPropagation(),s?.(X);},onContextMenu:re=>{re.preventDefault(),ie({isOpen:true,x:re.clientX,y:re.clientY,type:"task",task:X}),c?.(X,re);},whileHover:{backgroundColor:We?t.accentLight:t.hoverBg},children:ue.map((re,le)=>jsxRuntime.jsx("div",{className:`px-4 flex items-center ${re.id==="name"?"justify-start":"justify-center"} ${le<ue.length-1?"border-r":""}`,style:{width:`${re.width}px`,minWidth:`${re.width}px`,maxWidth:`${re.width}px`,borderColor:C===X.id?t.border:t.borderLight,height:"100%",boxSizing:"border-box"},children:Wt(re,X,re.id==="name"?j:0)},`${X.id}-${re.id}`))},X.id)})}),jsxRuntime.jsx(ha,{isOpen:de.isOpen,x:de.x,y:de.y,items:de.type==="header"&&de.columnId?$r(de.columnId):de.type==="task"&&de.task?se(de.task):[],onClose:()=>ie({...de,isOpen:false}),theme:t})]})}function Ec(e,t){let[r,a]=Se.useState("none"),[n,o]=Se.useState(0),[s,c]=Se.useState(e),[u,i]=Se.useState(t),[p,l]=Se.useState(null),[d,m]=Se.useState(null),[v,y]=Se.useState(null),[h,g]=Se.useState(null),[b,f]=Se.useState(0),[k,w]=Se.useState(0),[x,D]=Se.useState(null),[C,N]=Se.useState(false);return {dragMode:r,setDragMode:a,dragOffset:n,setDragOffset:o,ghostX:s,setGhostX:c,ghostWidth:u,setGhostWidth:i,connectionLine:p,setConnectionLine:l,hoveredTaskId:d,setHoveredTaskId:m,activeZone:v,setActiveZone:y,draggedSegmentIndex:h,setDraggedSegmentIndex:g,draggedSegmentStartX:b,setDraggedSegmentStartX:f,segmentDragOffsetX:k,setSegmentDragOffsetX:w,hoveredSegmentIndex:x,setHoveredSegmentIndex:D,isHovered:C,setIsHovered:N,isDragging:r!=="none",isResizing:r==="resize-start"||r==="resize-end",isConnecting:r==="connect",resetDragState:(W,E)=>{a("none"),l(null),m(null),c(W),i(E),w(0),g(null),f(0);}}}function Un({task:e,x:t,y:r,width:a,theme:n,dayWidth:o,startDate:s,templates:c,onClick:u,onDoubleClick:i,onContextMenu:p,onDateChange:l,onDependencyCreate:d,allTaskPositions:m=[],onDragMove:v}){let y=Ec(t,a),h=Se.useRef(null),{dragMode:g,setDragMode:b,dragOffset:f,setDragOffset:k,ghostX:w,setGhostX:x,ghostWidth:D,setGhostWidth:C,connectionLine:N,setConnectionLine:T,hoveredTaskId:$,setHoveredTaskId:z,activeZone:R,setActiveZone:W,draggedSegmentIndex:E,setDraggedSegmentIndex:O,draggedSegmentStartX:G,setDraggedSegmentStartX:U,segmentDragOffsetX:A,setSegmentDragOffsetX:K,hoveredSegmentIndex:_,setHoveredSegmentIndex:ae,isHovered:M,setIsHovered:de,isDragging:ie,isResizing:kt,isConnecting:rt,resetDragState:ir}=y,De=32,bt=8,wt=e.endDate&&e.endDate<new Date&&e.progress<100,jt=e.isCriticalPath,hr=n.name==="neutral"||n.today==="#1C1917",he=(Y=>Y>=80?20:Y>=60?15:Y>=50?12:10)(a),at=a<50,Kt=a<40,Wt=Y=>Y.toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"}),$r=()=>{let Y=Math.ceil((e.endDate.getTime()-e.startDate.getTime())/864e5);return `${Y} day${Y!==1?"s":""}`},se=Y=>Math.round(Y/o)*o,ue=Y=>{let ve=Math.round(Y/o),S=new Date(s);return S.setDate(S.getDate()+ve),S},X=(Y,ve)=>{for(let S of m){if(S.id===e.id)continue;let H=5;if(Y>=S.x-H&&Y<=S.x+S.width+H&&ve>=S.y-H&&ve<=S.y+S.height+H)return S.id}return null},j=Se.useCallback((Y,ve,S)=>{Y.preventDefault(),Y.stopPropagation();let H=h.current?.ownerSVGElement;if(!H)return;let me=H.createSVGPoint();me.x=Y.clientX,me.y=Y.clientY;let ye=me.matrixTransform(H.getScreenCTM()?.inverse()),Be=S!==void 0?S:t,Ue=ve;if(!Ue){let Mt=ye.x-Be;Y.shiftKey?(Ue="connect",T({x:t+a,y:r+De/2})):Y.ctrlKey||Y.metaKey?Ue="move":Y.altKey?Ue=Mt<a/2?"resize-start":"resize-end":Kt?Mt<a/2?Ue="move":Ue="resize-end":at?Mt<=he/2?Ue="resize-start":Mt>=a-he/2?Ue="resize-end":Ue="move":Mt<=he?Ue="resize-start":Mt>=a-he?Ue="resize-end":Ue="move";}b(Ue),de(false),W(null),Ue==="move"?k(ye.x-Be):Ue==="connect"?T({x:t+a,y:r+De/2}):k(0),x(Be),C(a);},[t,a,r,De]),Te=Se.useCallback(Y=>{if(g==="none")return;let ve=h.current?.ownerSVGElement;if(!ve)return;let S=ve.createSVGPoint();S.x=Y.clientX,S.y=Y.clientY;let H=S.matrixTransform(ve.getScreenCTM()?.inverse());if(g==="connect"){T({x:H.x,y:H.y});let me=X(H.x,H.y);z(me);}else if(g==="move"){let me=H.x-f,ye=se(me);x(ye),C(a);let Be=Math.round((ye-t)/o);if(v?.(e.id,Be,true),e.segments&&e.segments.length>0&&E!==null){let Ue=ye-G;K(Ue);}}else if(g==="resize-start"){let me=H.x,ye=se(me),Be=t+a-ye;Be>=o&&(x(ye),C(Be));}else if(g==="resize-end"){let me=H.x,Be=se(me)-t;Be>=o&&C(Be);}},[g,t,a,o,f,e,se,E,G,X,z,T,x,C,K,v]),We=Se.useCallback(()=>{if(g!=="none"){if(g==="connect")$&&d&&d(e,$),T(null),z(null);else {let Y=e.endDate.getTime()-e.startDate.getTime(),ve,S,H=true;if(g==="move"){if(ve=ue(w),S=new Date(ve.getTime()+Y),e.segments&&e.segments.length>0&&E!==null){let me=Math.round(A/o),ye=e.segments.map((St,go)=>{if(go===E){let wa=new Date(St.startDate),Ca=new Date(St.endDate);return wa.setDate(wa.getDate()+me),Ca.setDate(Ca.getDate()+me),{startDate:wa,endDate:Ca}}return St}),Be=ye.flatMap(St=>[St.startDate,St.endDate]),Ue=new Date(Math.min(...Be.map(St=>St.getTime()))),Mt=new Date(Math.max(...Be.map(St=>St.getTime())));l?.({...e,segments:ye},Ue,Mt),ir(t,a);return}}else g==="resize-start"?(ve=ue(w),S=e.endDate,ve>=S&&(console.warn("Invalid date range: start date must be before end date"),H=false)):g==="resize-end"?(ve=e.startDate,S=ue(w+D),S<=ve&&(console.warn("Invalid date range: end date must be after start date"),H=false)):H=false;H&&ve&&S&&(S.getTime()-ve.getTime()<864e5?console.warn("Invalid date range: task must be at least 1 day long"):l?.(e,ve,S));}v?.(e.id,0,false),ir(t,a);}},[g,w,D,e,l,$,d,t,a,o,ue,A,E,ir,v]);Se.useEffect(()=>{if(g==="none")return;let Y=S=>{Te(S);},ve=()=>{We();};return window.addEventListener("mousemove",Y),window.addEventListener("mouseup",ve),()=>{window.removeEventListener("mousemove",Y),window.removeEventListener("mouseup",ve);}},[g,Te,We]);let re=ie&&!rt?w:t,le=ie&&!rt?D:a,lr=c.taskTooltip(e),Ut=typeof lr=="string"?lr:"",J=c.taskClass(e);return jsxRuntime.jsxs("g",{ref:h,onMouseEnter:()=>!ie&&de(true),onMouseLeave:()=>{ie||(de(false),W(null));},onClick:()=>!ie&&u?.(e),onDoubleClick:Y=>{ie||(Y.stopPropagation(),i?.(e));},onContextMenu:Y=>{Y.preventDefault(),p?.(e,Y);},children:[Ut&&jsxRuntime.jsx("title",{dangerouslySetInnerHTML:{__html:Ut}}),M&&!ie&&!at&&!e.segments&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:t,y:r,width:he,height:De,fill:R==="resize-start"?n.accent:"transparent",opacity:R==="resize-start"?.15:0,style:{cursor:"ew-resize",pointerEvents:"all"},onMouseEnter:()=>W("resize-start"),onMouseDown:Y=>j(Y,"resize-start")}),jsxRuntime.jsx("rect",{x:t+he,y:r,width:a-he*2,height:De,fill:R==="move"?n.accent:"transparent",opacity:R==="move"?.1:0,style:{cursor:"grab",pointerEvents:"all"},onMouseEnter:()=>W("move"),onMouseDown:Y=>j(Y,"move")}),jsxRuntime.jsx("rect",{x:t+a-he,y:r,width:he,height:De,fill:R==="resize-end"?n.accent:"transparent",opacity:R==="resize-end"?.15:0,style:{cursor:"ew-resize",pointerEvents:"all"},onMouseEnter:()=>W("resize-end"),onMouseDown:Y=>j(Y,"resize-end")})]}),M&&!ie&&Kt&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:t,y:r,width:a/2,height:De,fill:R==="move"?n.accent:"transparent",opacity:R==="move"?.2:0,style:{cursor:"grab",pointerEvents:"all"},onMouseEnter:()=>W("move"),onMouseDown:Y=>j(Y,"move")}),jsxRuntime.jsx("rect",{x:t+a/2,y:r,width:a/2,height:De,fill:R==="resize-end"?n.accent:"transparent",opacity:R==="resize-end"?.2:0,style:{cursor:"ew-resize",pointerEvents:"all"},onMouseEnter:()=>W("resize-end"),onMouseDown:Y=>j(Y,"resize-end")}),M&&jsxRuntime.jsx(framerMotion.motion.line,{x1:t+a/2,y1:r+4,x2:t+a/2,y2:r+De-4,stroke:n.textTertiary,strokeWidth:1,strokeDasharray:"2 2",opacity:.3,initial:{opacity:0},animate:{opacity:.3},transition:{duration:.2},style:{pointerEvents:"none"}})]}),ie&&!rt&&!e.segments&&jsxRuntime.jsx(framerMotion.motion.rect,{x:w,y:r,width:D,height:De,rx:bt,fill:n.accent,opacity:.5,stroke:n.accent,strokeWidth:2,strokeDasharray:"4 4",initial:{opacity:0},animate:{opacity:.6},transition:{duration:.15},style:{pointerEvents:"none"}}),!e.segments&&jsxRuntime.jsx(framerMotion.motion.rect,{x:re,y:r,width:le,height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarPrimary,"data-task-class":J,initial:{opacity:0,scale:.95},animate:{opacity:ie&&!rt?.15:e.parentId?.6:M?.9:.8,scale:M&&!ie?1.02:1},transition:{duration:.2,ease:[.4,0,.2,1]},onMouseDown:Y=>j(Y),style:{cursor:ie?rt?"crosshair":kt?"ew-resize":"grabbing":"grab",pointerEvents:"all"}}),!e.segments&&jsxRuntime.jsx("rect",{x:re,y:r,width:le*(e.progress/100),height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarProgress,opacity:1,style:{pointerEvents:"none"}}),e.segments&&e.segments.map((Y,ve)=>{let S=(Y.startDate.getTime()-s.getTime())/864e5*o,me=(Y.endDate.getTime()-s.getTime())/(1e3*60*60*24)*o-S+o,ye=ie&&g==="move"&&E===ve,Be=_===ve,Ue=ye?S+A:S;return jsxRuntime.jsxs("g",{onMouseEnter:()=>!ie&&ae(ve),onMouseLeave:()=>!ie&&ae(null),children:[jsxRuntime.jsx(framerMotion.motion.rect,{x:Ue,y:r,width:me,height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarPrimary,initial:{opacity:0,scale:.95},animate:{opacity:ye||e.parentId?.6:Be?.9:.8,scale:Be&&!ie?1.02:1},transition:{duration:.2,ease:[.4,0,.2,1]},onMouseDown:Mt=>{Mt.stopPropagation(),O(ve),U(S),j(Mt,void 0,S);},style:{cursor:ie?rt?"crosshair":kt?"ew-resize":"grabbing":"grab",pointerEvents:"all"}}),jsxRuntime.jsx("rect",{x:Ue,y:r,width:me*(e.progress/100),height:De,rx:bt,fill:e.isCriticalPath||wt?"#DC2626":e.color?e.color:n.taskBarProgress,opacity:1,style:{pointerEvents:"none"}})]},`segment-${ve}`)}),hr&&(wt||jt)&&!e.segments&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jt&&!wt&&jsxRuntime.jsx("rect",{x:re,y:r,width:le,height:De,rx:bt,fill:"none",stroke:n.border,strokeWidth:2,strokeDasharray:"4 4",opacity:.8,style:{pointerEvents:"none"}}),wt&&jsxRuntime.jsx("rect",{x:re,y:r,width:le,height:De,rx:bt,fill:"url(#diagonal-stripes)",opacity:.3,style:{pointerEvents:"none"}})]}),le>60&&!e.segments&&(()=>{let Y=c.taskLabel(e),ve=typeof Y=="string"?Y:e.name,S=ve.length>Math.floor(le/8)?`${ve.substring(0,Math.floor(le/8))}...`:ve;return jsxRuntime.jsx("text",{x:re+12,y:r+De/2,dominantBaseline:"middle",fill:"#FFFFFF",fontSize:"13",fontWeight:"500",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:S})})(),le>100&&e.progress>0&&e.progress<100&&!ie&&!e.segments&&jsxRuntime.jsxs("text",{x:re+le-12,y:r+De/2,dominantBaseline:"middle",textAnchor:"end",fill:"rgba(255, 255, 255, 0.9)",fontSize:"11",fontWeight:"600",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:[e.progress,"%"]}),e.status&&le>80&&!ie&&!e.segments&&jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[e.status==="completed"&&jsxRuntime.jsx("circle",{cx:re+le-8,cy:r+8,r:4,fill:n.statusCompleted,stroke:"#FFFFFF",strokeWidth:1.5}),e.status==="in-progress"&&jsxRuntime.jsx("circle",{cx:re+le-8,cy:r+8,r:4,fill:n.statusInProgress,stroke:"#FFFFFF",strokeWidth:1.5,opacity:.8})]}),(M||kt)&&!rt&&!e.segments&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("g",{style:{pointerEvents:"all"},children:[jsxRuntime.jsx("rect",{x:at?re-15:re-10,y:r-5,width:at?25:20,height:De+10,fill:"transparent",onMouseDown:Y=>j(Y,"resize-start"),style:{cursor:"ew-resize"}}),jsxRuntime.jsx(framerMotion.motion.rect,{x:at?re-8:re-3,y:r+6,width:at?8:6,height:at?De-12:De-16,rx:3,fill:g==="resize-start"?n.accent:n.taskBarHandle,stroke:n.taskBarPrimary,strokeWidth:1.5,initial:{opacity:0,scale:0},animate:{opacity:1,scale:g==="resize-start"?1.2:1},transition:{duration:.2,type:"spring",stiffness:400,damping:25},style:{pointerEvents:"none"}})]}),jsxRuntime.jsxs("g",{style:{pointerEvents:"all"},children:[jsxRuntime.jsx("rect",{x:re+le-10,y:r-5,width:at?25:20,height:De+10,fill:"transparent",onMouseDown:Y=>j(Y,"resize-end"),style:{cursor:"ew-resize"}}),jsxRuntime.jsx(framerMotion.motion.rect,{x:at?re+le:re+le-3,y:r+6,width:at?8:6,height:at?De-12:De-16,rx:3,fill:g==="resize-end"?n.accent:n.taskBarHandle,stroke:n.taskBarPrimary,strokeWidth:1.5,initial:{opacity:0,scale:0},animate:{opacity:1,scale:g==="resize-end"?1.2:1},transition:{duration:.2,type:"spring",stiffness:400,damping:25},style:{pointerEvents:"none"}})]})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:M&&!ie&&!e.segments&&jsxRuntime.jsxs(framerMotion.motion.g,{style:{pointerEvents:"all"},initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.15},children:[jsxRuntime.jsx(framerMotion.motion.circle,{cx:t+a+8,cy:r+De/2,r:6,fill:n.accent,stroke:"#FFFFFF",strokeWidth:2,initial:{scale:0},animate:{scale:1},exit:{scale:0},transition:{duration:.2,type:"spring",stiffness:400,damping:25},onMouseDown:Y=>{Y.stopPropagation(),j(Y,"connect");},style:{cursor:"crosshair"}}),jsxRuntime.jsx("text",{x:t+a+20,y:r+De/2,dominantBaseline:"middle",fill:n.textTertiary,fontSize:"10",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:"Link"})]})}),rt&&N&&jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[jsxRuntime.jsx(framerMotion.motion.line,{x1:t+a,y1:r+De/2,x2:N.x,y2:N.y,stroke:$?n.statusCompleted:n.accent,strokeWidth:$?3:2,strokeDasharray:"6 4",initial:{opacity:0},animate:{opacity:$?1:.8},transition:{duration:.15}}),jsxRuntime.jsx(framerMotion.motion.circle,{cx:N.x,cy:N.y,r:$?8:6,fill:$?n.statusCompleted:n.accent,stroke:"#FFFFFF",strokeWidth:2,initial:{scale:0},animate:{scale:1},transition:{duration:.15}}),$&&jsxRuntime.jsx(framerMotion.motion.text,{x:N.x+15,y:N.y,dominantBaseline:"middle",fill:n.statusCompleted,fontSize:"11",fontWeight:"600",fontFamily:"Inter, sans-serif",initial:{opacity:0,x:N.x+10},animate:{opacity:1,x:N.x+15},transition:{duration:.2},children:"Connect"})]}),(M||ie)&&!rt&&!e.segments&&jsxRuntime.jsx(framerMotion.motion.rect,{x:re-2,y:r-2,width:le+4,height:De+4,rx:bt+2,fill:"none",stroke:ie?n.accent:n.taskBarPrimary,strokeWidth:2,opacity:ie?.6:.4,initial:{opacity:0},animate:{opacity:ie?.6:.4},transition:{duration:.2},style:{pointerEvents:"none"}}),kt&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("line",{x1:w,y1:0,x2:w,y2:1e3,stroke:n.accent,strokeWidth:1,strokeDasharray:"4 4",opacity:.3,style:{pointerEvents:"none"}}),jsxRuntime.jsx("line",{x1:w+D,y1:0,x2:w+D,y2:1e3,stroke:n.accent,strokeWidth:1,strokeDasharray:"4 4",opacity:.3,style:{pointerEvents:"none"}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:M&&!ie&&!e.segments&&jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},exit:{opacity:0,y:10},transition:{duration:.2},style:{pointerEvents:"none"},children:[jsxRuntime.jsx("rect",{x:re+le/2-120,y:r-95,width:240,height:82,rx:8,fill:n.bgSecondary,stroke:n.border,strokeWidth:1,filter:"drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15))"}),jsxRuntime.jsx("path",{d:`M ${re+le/2-6} ${r-13} L ${re+le/2} ${r-3} L ${re+le/2+6} ${r-13}`,fill:n.bgSecondary,stroke:n.border,strokeWidth:1}),jsxRuntime.jsx("text",{x:re+le/2,y:r-73,textAnchor:"middle",fill:n.textPrimary,fontSize:"13",fontWeight:"600",fontFamily:"Inter, sans-serif",children:e.name.length>28?`${e.name.substring(0,28)}...`:e.name}),jsxRuntime.jsx("text",{x:re+le/2-110,y:r-55,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Start:"}),jsxRuntime.jsx("text",{x:re+le/2-70,y:r-55,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:Wt(e.startDate)}),jsxRuntime.jsx("text",{x:re+le/2-110,y:r-40,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"End:"}),jsxRuntime.jsx("text",{x:re+le/2-70,y:r-40,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:Wt(e.endDate)}),jsxRuntime.jsx("text",{x:re+le/2+10,y:r-55,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Duration:"}),jsxRuntime.jsx("text",{x:re+le/2+65,y:r-55,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:$r()}),jsxRuntime.jsx("text",{x:re+le/2+10,y:r-40,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Progress:"}),jsxRuntime.jsxs("text",{x:re+le/2+65,y:r-40,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:[e.progress,"%"]}),e.assignees&&e.assignees.length>0&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("text",{x:re+le/2-110,y:r-25,fill:n.textTertiary,fontSize:"11",fontFamily:"Inter, sans-serif",children:"Assignees:"}),jsxRuntime.jsxs("text",{x:re+le/2-50,y:r-25,fill:n.textSecondary,fontSize:"11",fontWeight:"500",fontFamily:"Inter, sans-serif",children:[e.assignees.map(Y=>Y.name).join(", ").substring(0,30),e.assignees.map(Y=>Y.name).join(", ").length>30?"...":""]})]}),jsxRuntime.jsx("text",{x:re+le/2,y:r-18,textAnchor:"middle",fill:n.textTertiary,fontSize:"9",fontFamily:"Inter, sans-serif",style:{opacity:.7},children:Kt?"Left: move \u2022 Right: resize":at?"Drag to move \u2022 Hold ALT + drag edge to resize":"Drag edges to resize \u2022 Drag center to move \u2022 Click \u26AB to link"})]})})]})}function _n({x1:e,y1:t,x2:r,y2:a,theme:n,onDelete:o}){let[s,c]=Se.useState(false),u=r-e,i=a-t,p=e+u/2,l=`M ${e} ${t} C ${p} ${t}, ${p} ${a}, ${r} ${a}`,d=6,m=Math.atan2(i,u),v=r-d*Math.cos(m-Math.PI/6),y=a-d*Math.sin(m-Math.PI/6),h=r-d*Math.cos(m+Math.PI/6),g=a-d*Math.sin(m+Math.PI/6),b=n.dependency;return jsxRuntime.jsxs("g",{onMouseEnter:()=>c(true),onMouseLeave:()=>c(false),children:[jsxRuntime.jsx("path",{d:l,fill:"none",stroke:"transparent",strokeWidth:20,strokeLinecap:"round",style:{cursor:"pointer"}}),jsxRuntime.jsx(framerMotion.motion.path,{d:l,fill:"none",stroke:b,strokeWidth:2,strokeLinecap:"round",initial:{pathLength:0,opacity:0},animate:{pathLength:1,opacity:s?1:.6,strokeWidth:s?2.5:2},transition:{pathLength:{duration:.5,ease:"easeInOut"},opacity:{duration:.2},strokeWidth:{duration:.2}}}),jsxRuntime.jsx(framerMotion.motion.path,{d:`M ${r} ${a} L ${v} ${y} M ${r} ${a} L ${h} ${g}`,fill:"none",stroke:b,strokeWidth:2,strokeLinecap:"round",initial:{opacity:0,scale:.8},animate:{opacity:s?1:.6,scale:s?1.1:1,strokeWidth:s?2.5:2},transition:{duration:.2}}),jsxRuntime.jsx(framerMotion.motion.circle,{cx:r,cy:a,r:3,fill:b,initial:{scale:0},animate:{scale:s?1.33:1},transition:{scale:{delay:.3,duration:.2}}}),s&&o&&jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,scale:0},animate:{opacity:1,scale:1},transition:{duration:.2},onClick:f=>{f.stopPropagation(),o();},style:{cursor:"pointer"},children:[jsxRuntime.jsx("circle",{cx:p,cy:(t+a)/2,r:10,fill:n.bgSecondary,stroke:n.error||"#ef4444",strokeWidth:2}),jsxRuntime.jsx("line",{x1:p-4,y1:(t+a)/2-4,x2:p+4,y2:(t+a)/2+4,stroke:n.error||"#ef4444",strokeWidth:2,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:p+4,y1:(t+a)/2-4,x2:p-4,y2:(t+a)/2+4,stroke:n.error||"#ef4444",strokeWidth:2,strokeLinecap:"round"})]})]})}function Vn({task:e,x:t,y:r,theme:a,onClick:n}){let[o,s]=Se.useState(false),c=16,u=i=>i.toLocaleDateString("en-US",{month:"short",day:"numeric",year:"numeric"});return jsxRuntime.jsxs("g",{onMouseEnter:()=>s(true),onMouseLeave:()=>s(false),onClick:()=>n?.(e),style:{cursor:"pointer"},children:[e.isCriticalPath&&jsxRuntime.jsx(framerMotion.motion.circle,{cx:t,cy:r+16,r:c+4,fill:a.criticalPathLight,initial:{scale:0},animate:{scale:o?1.2:1},transition:{duration:.3}}),jsxRuntime.jsx(framerMotion.motion.rect,{x:t-c/2,y:r+16-c/2,width:c,height:c,fill:e.isCriticalPath?a.criticalPath:a.milestone,stroke:a.bgGrid,strokeWidth:2,transform:`rotate(45 ${t} ${r+16})`,initial:{scale:0,rotate:0},animate:{scale:o?1.15:1,rotate:45},transition:{duration:.3,type:"spring",stiffness:300,damping:20}}),o&&jsxRuntime.jsx(framerMotion.motion.rect,{x:t-(c+4)/2,y:r+16-(c+4)/2,width:c+4,height:c+4,fill:"none",stroke:e.isCriticalPath?a.criticalPath:a.milestone,strokeWidth:2,opacity:.5,transform:`rotate(45 ${t} ${r+16})`,initial:{scale:.8,opacity:0},animate:{scale:1,opacity:.5},transition:{duration:.2}}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:o&&jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},exit:{opacity:0,y:10},transition:{duration:.2},children:[jsxRuntime.jsx("rect",{x:t-80,y:r-50,width:160,height:44,rx:8,fill:a.bgSecondary,stroke:a.border,strokeWidth:1,filter:"drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15))"}),jsxRuntime.jsx("path",{d:`M ${t-6} ${r-6} L ${t} ${r+4} L ${t+6} ${r-6}`,fill:a.bgSecondary,stroke:a.border,strokeWidth:1}),jsxRuntime.jsx("rect",{x:t-70,y:r-38,width:8,height:8,fill:e.isCriticalPath?a.criticalPath:a.milestone,transform:`rotate(45 ${t-66} ${r-34})`}),jsxRuntime.jsx("text",{x:t-55,y:r-32,fill:a.textPrimary,fontSize:"12",fontWeight:"600",fontFamily:"Inter, sans-serif",children:e.name.length>18?`${e.name.substring(0,18)}...`:e.name}),jsxRuntime.jsx("text",{x:t-55,y:r-18,fill:a.textTertiary,fontSize:"10",fontFamily:"Inter, sans-serif",children:u(e.startDate)}),e.isCriticalPath&&jsxRuntime.jsxs("g",{children:[jsxRuntime.jsx("rect",{x:t+10,y:r-40,width:60,height:16,rx:4,fill:a.criticalPathLight}),jsxRuntime.jsx("text",{x:t+40,y:r-30,textAnchor:"middle",fill:a.criticalPath,fontSize:"9",fontWeight:"700",fontFamily:"Inter, sans-serif",letterSpacing:"0.5",children:"CRITICAL"})]})]})})]})}var q={calculateEndDate:(e,t)=>{let r=new Date(e);return r.setDate(r.getDate()+t),r},calculateDuration:(e,t)=>{let r=t.getTime()-e.getTime();return Math.ceil(r/(1e3*60*60*24))},calculateWorkingDays:(e,t)=>{let r=0,a=new Date(e);for(;a<=t;){let n=a.getDay();n!==0&&n!==6&&r++,a.setDate(a.getDate()+1);}return r},addWorkingDays:(e,t)=>{let r=new Date(e),a=0;for(;a<t;){r.setDate(r.getDate()+1);let n=r.getDay();n!==0&&n!==6&&a++;}return r},isWeekend:e=>{let t=e.getDay();return t===0||t===6},validateDependencies:(e,t,r)=>{let a=new Map,n=i=>{i.forEach(p=>{p.dependencies&&a.set(p.id,p.dependencies),p.subtasks&&n(p.subtasks);});};n(e);let o=a.get(r)||[];a.set(r,[...o,t]);let s=new Set,c=new Set,u=i=>{if(!s.has(i)){s.add(i),c.add(i);let p=a.get(i)||[];for(let l of p){if(!s.has(l)&&u(l))return true;if(c.has(l))return true}}return c.delete(i),false};return u(r)},flattenTasks:e=>{let t=[],r=a=>{a.forEach(n=>{t.push(n),n.subtasks&&n.subtasks.length>0&&r(n.subtasks);});};return r(e),t},findTaskById:(e,t)=>{for(let r of e){if(r.id===t)return r;if(r.subtasks){let a=q.findTaskById(r.subtasks,t);if(a)return a}}},getParentTasks:(e,t)=>{let r=[],a=q.findTaskById(e,t);if(!a||!a.parentId)return r;let n=a.parentId;for(;n;){let o=q.findTaskById(e,n);if(o)r.unshift(o),n=o.parentId;else break}return r},exportToJSON:e=>JSON.stringify(e,null,2),importFromJSON:e=>{try{let t=JSON.parse(e);if(!Array.isArray(t))throw new Error("Invalid JSON: expected an array of tasks");return t.forEach((r,a)=>{if(!r.id||!r.name)throw new Error(`Invalid task at index ${a}: missing required fields (id, name)`)}),t}catch(t){throw new Error(`Failed to import tasks: ${t instanceof Error?t.message:"Unknown error"}`)}},exportToCSV:e=>{let t=q.flattenTasks(e),a=[["ID","Name","Start Date","End Date","Progress","Status","Dependencies"].join(",")];return t.forEach(n=>{let o=[n.id,`"${n.name.replace(/"/g,'""')}"`,n.startDate?n.startDate.toISOString().split("T")[0]:"",n.endDate?n.endDate.toISOString().split("T")[0]:"",n.progress.toString(),n.status||"",n.dependencies?.join(";")||""];a.push(o.join(","));}),a.join(`
|
|
46
46
|
`)},formatDate:e=>{let t=e.getFullYear(),r=String(e.getMonth()+1).padStart(2,"0"),a=String(e.getDate()).padStart(2,"0");return `${t}-${r}-${a}`},parseDate:e=>new Date(e),getTaskDateRange:e=>!e.startDate||!e.endDate?null:{start:e.startDate,end:e.endDate},getEarliestStartDate:e=>{let r=q.flattenTasks(e).filter(a=>a.startDate);return r.length===0?null:new Date(Math.min(...r.map(a=>a.startDate.getTime())))},getLatestEndDate:e=>{let r=q.flattenTasks(e).filter(a=>a.endDate);return r.length===0?null:new Date(Math.max(...r.map(a=>a.endDate.getTime())))},tasksOverlap:(e,t)=>!e.startDate||!e.endDate||!t.startDate||!t.endDate?false:e.startDate<=t.endDate&&t.startDate<=e.endDate,getDependentTasks:(e,t)=>q.flattenTasks(e).filter(a=>a.dependencies&&a.dependencies.includes(t)),getDependencyTasks:(e,t)=>{let r=q.findTaskById(e,t);return !r||!r.dependencies?[]:q.flattenTasks(e).filter(n=>r.dependencies.includes(n.id))},filterByStatus:(e,t)=>q.flattenTasks(e).filter(r=>r.status===t),filterByDateRange:(e,t,r)=>q.flattenTasks(e).filter(a=>!a.startDate||!a.endDate?false:a.startDate<=r&&a.endDate>=t),sortByStartDate:(e,t=true)=>[...e].sort((r,a)=>{if(!r.startDate||!a.startDate)return 0;let n=r.startDate.getTime()-a.startDate.getTime();return t?n:-n}),sortByEndDate:(e,t=true)=>[...e].sort((r,a)=>{if(!r.endDate||!a.endDate)return 0;let n=r.endDate.getTime()-a.endDate.getTime();return t?n:-n}),sortByProgress:(e,t=true)=>[...e].sort((r,a)=>{let n=r.progress-a.progress;return t?n:-n}),calculateTotalProgress:e=>{let t=q.flattenTasks(e);if(t.length===0)return 0;let r=t.reduce((a,n)=>a+n.progress,0);return Math.round(r/t.length)},getTaskByPath:(e,t)=>{let r=e,a;for(let n=0;n<t.length;n++){let o=t[n];if(!r||o===void 0||o>=r.length||(a=r[o],!a))return;n<t.length-1&&(r=a.subtasks||[]);}return a},cloneTask:(e,t)=>({...e,id:t||`${e.id}-copy`,subtasks:e.subtasks?.map(r=>q.cloneTask(r))}),exportToPDF:async(e,t="gantt-chart.pdf")=>{try{if(!e||e.length===0){alert("No tasks available to export to PDF");return}let{jsPDF:r}=await import('jspdf'),{default:a}=await import('jspdf-autotable'),n=new r,o=q.flattenTasks(e);if(o.length===0){alert("No tasks found to export");return}n.setFontSize(16),n.text("Gantt Chart - Task List",14,20);let s=[["Task Name","Start Date","End Date","Duration","Progress","Status"]],c=o.map(u=>{let i=u.startDate&&u.endDate?q.calculateDuration(u.startDate,u.endDate):0;return [u.name,u.startDate?q.formatDate(u.startDate):"N/A",u.endDate?q.formatDate(u.endDate):"N/A",i>0?`${i} days`:"N/A",`${u.progress}%`,u.status||"N/A"]});a(n,{head:s,body:c,startY:30,styles:{fontSize:9,cellPadding:3},headStyles:{fillColor:[66,139,202],textColor:255,fontStyle:"bold"},alternateRowStyles:{fillColor:[245,245,245]},columnStyles:{0:{cellWidth:60},1:{cellWidth:30},2:{cellWidth:30},3:{cellWidth:25},4:{cellWidth:20},5:{cellWidth:25}}}),n.save(t);}catch(r){throw r}},exportToExcel:async(e,t="gantt-chart.xlsx")=>{let r=await import('xlsx'),n=q.flattenTasks(e).map(u=>{let i=u.startDate&&u.endDate?q.calculateDuration(u.startDate,u.endDate):0;return {"Task ID":u.id,"Task Name":u.name,"Start Date":u.startDate?q.formatDate(u.startDate):"","End Date":u.endDate?q.formatDate(u.endDate):"","Duration (days)":i>0?i:"","Progress (%)":u.progress,Status:u.status||"",Assignees:u.assignees?.map(p=>p.name).join(", ")||"",Dependencies:u.dependencies?.join(", ")||"","Is Milestone":u.isMilestone?"Yes":"No","Parent ID":u.parentId||"",Level:u.level||0}}),o=r.utils.json_to_sheet(n),s=[{wch:15},{wch:40},{wch:12},{wch:12},{wch:15},{wch:12},{wch:15},{wch:30},{wch:20},{wch:12},{wch:15},{wch:8}];o["!cols"]=s;let c=r.utils.book_new();r.utils.book_append_sheet(c,o,"Gantt Tasks"),r.writeFile(c,t);},exportToMSProject:(e,t="Gantt Project",r="project.xml")=>{let a=q.flattenTasks(e),n=new Map;a.forEach((d,m)=>{n.set(d.id,m+1);});let o=d=>d.toISOString().replace("Z",""),s=q.getEarliestStartDate(e)||new Date,c=q.getLatestEndDate(e)||new Date,u=a.map((d,m)=>{let v=n.get(d.id),y=d.startDate&&d.endDate?q.calculateDuration(d.startDate,d.endDate):0,h=(d.dependencies||[]).filter(g=>n.has(g)).map(g=>`
|
|
47
47
|
<PredecessorLink>
|
|
48
48
|
<PredecessorUID>${n.get(g)}</PredecessorUID>
|
|
@@ -273,7 +273,7 @@
|
|
|
273
273
|
</Calendars>
|
|
274
274
|
<Tasks>${u}
|
|
275
275
|
</Tasks>
|
|
276
|
-
</Project>`,p=new Blob([i],{type:"application/xml;charset=utf-8;"}),l=document.createElement("a");l.href=URL.createObjectURL(p),l.download=r,l.click(),URL.revokeObjectURL(l.href);},calculateCriticalPath:e=>{let t=q.flattenTasks(e),r=t.filter(i=>i.startDate&&i.endDate);if(r.length===0)return [];let a=new Map,n=i=>{if(a.has(i.id))return;let p=i.startDate&&i.endDate?q.calculateDuration(i.startDate,i.endDate):0,l=0;if(i.dependencies&&i.dependencies.length>0)for(let m of i.dependencies){let v=t.find(y=>y.id===m);if(v){n(v);let y=a.get(m)?.ef||0;l=Math.max(l,y);}}let d=l+p;a.set(i.id,{es:l,ef:d});};r.forEach(n);let o=Math.max(...Array.from(a.values()).map(i=>i.ef)),s=new Map,c=i=>{if(s.has(i.id))return;let p=i.startDate&&i.endDate?q.calculateDuration(i.startDate,i.endDate):0,l=t.filter(v=>v.dependencies&&v.dependencies.includes(i.id)),d=o;if(l.length>0)for(let v of l){c(v);let y=s.get(v.id)?.ls||0;d=Math.min(d,y);}let m=d-p;s.set(i.id,{ls:m,lf:d});};r.forEach(c);let u=[];for(let i of r){let p=a.get(i.id),l=s.get(i.id);if(p&&l){let d=l.ls-p.es;Math.abs(d)<.01&&u.push(i.id);}}return u},calculateSlack:(e,t)=>{let r=q.findTaskById(e,t);if(!r||!r.startDate||!r.endDate)return null;if(q.calculateCriticalPath(e).includes(t))return 0;let n=q.getDependentTasks(e,t);if(n.length===0){let c=q.getLatestEndDate(e);if(!c)return null;let u=q.calculateDuration(r.endDate,c);return Math.max(0,u)}let o=n.filter(c=>c.startDate).map(c=>c.startDate.getTime()).sort((c,u)=>c-u)[0];if(!o)return null;let s=q.calculateDuration(r.endDate,new Date(o));return Math.max(0,s)},isOnCriticalPath:(e,t)=>q.calculateCriticalPath(e).includes(t),autoScheduleDependents:(e,t,r)=>{let a=q.findTaskById(e,t);if(!a||!a.endDate)return e;let n=q.getDependentTasks(e,t);if(n.length===0)return e;let o=[...e];for(let s of n){if(!s.startDate||!s.endDate)continue;let c=q.calculateDuration(s.startDate,s.endDate),u;r!==void 0?(u=new Date(s.startDate),u.setDate(u.getDate()+r)):(u=new Date(a.endDate),u.setDate(u.getDate()+1));let i=q.calculateEndDate(u,c),p=l=>l.map(d=>d.id===s.id?{...d,startDate:u,endDate:i}:d.subtasks?{...d,subtasks:p(d.subtasks)}:d);o=p(o),o=q.autoScheduleDependents(o,s.id,r);}return o},calculateCascadePreview:(e,t,r,a,n,o,s,c)=>{if(r===0)return [];let u=[],i=n.getTime(),p=1e3*60*60*24,l=q.findTaskById(e,t);if(!l||!l.endDate)return [];let d=(m,v,y=new Set)=>{if(y.has(m))return;y.add(m);let h=q.getDependentTasks(e,m);for(let g of h){if(!g.startDate||!g.endDate)continue;let b=a.findIndex($=>$.id===g.id);if(b===-1)continue;let f=g.startDate.getTime(),w=(g.endDate.getTime()-f)/p,D=(f-i)/p*o,C=D+v*o,N=Math.max(w*o,o),T=c+b*s+12;u.push({taskId:g.id,taskName:g.name,originalX:D,previewX:C,width:N,y:T,rowIndex:b,daysDelta:v,color:g.color}),d(g.id,v,y);}};return d(t,r),u},splitTask:(e,t,r,a=3)=>{let n=q.findTaskById(e,t);if(!n||!n.startDate||!n.endDate)return e;if(r<=n.startDate||r>=n.endDate)return console.warn("Split date must be between task start and end dates"),e;let o=new Date(r);o.setDate(o.getDate()-1);let s=new Date(r);s.setDate(s.getDate()+a);let c=new Date(n.endDate);c.setDate(c.getDate()+a);let u=[{startDate:new Date(n.startDate),endDate:o},{startDate:s,endDate:c}],i=p=>p.map(l=>l.id===n.id?{...l,endDate:c,segments:u}:l.subtasks?{...l,subtasks:i(l.subtasks)}:l);return i(e)}};function Yn({tasks:e,theme:t,rowHeight:r,timeScale:a,startDate:n,endDate:o,zoom:s,templates:c,onTaskClick:u,onTaskDblClick:i,onTaskContextMenu:p,onTaskDateChange:l,onDependencyCreate:d,onDependencyDelete:m}){let[y,h]=Se.useState([]),g=Math.ceil((o.getTime()-n.getTime())/(1e3*60*60*24)),b=a==="day"?60:a==="week"?20:8,f=g*b*s,k=E=>{let O=new Date(Date.UTC(E.getFullYear(),E.getMonth(),E.getDate())),G=O.getUTCDay()||7;O.setUTCDate(O.getUTCDate()+4-G);let U=new Date(Date.UTC(O.getUTCFullYear(),0,1));return Math.ceil(((O.getTime()-U.getTime())/864e5+1)/7)},w=E=>{let O=E.getDay();return O===0||O===6},x=Se.useCallback(E=>{let O=Math.round(E/(b*s)),G=new Date(n);return G.setDate(G.getDate()+O),G},[n,b,s]),D=Se.useCallback((E,O)=>{if(O.startDate&&O.endDate)return;let G=E.currentTarget.ownerSVGElement;if(!G)return;let U=G.createSVGPoint();U.x=E.clientX,U.y=E.clientY;let A=U.matrixTransform(G.getScreenCTM()?.inverse()),K=x(A.x),_=new Date(K);_.setDate(_.getDate()+1),l?.(O,K,_);},[x,l]),C=Se.useMemo(()=>{let E=A=>A.map(K=>{if(K.subtasks&&K.subtasks.length>0){let _=E(K.subtasks),ae=_.filter(M=>M.startDate&&M.endDate);if(ae.length>0){let M=ae.map(rt=>rt.startDate.getTime()),de=ae.map(rt=>rt.endDate.getTime()),ie=new Date(Math.min(...M)),kt=new Date(Math.max(...de));return {...K,subtasks:_,startDate:K.startDate||ie,endDate:K.endDate||kt}}return {...K,subtasks:_}}return K}),O=(A,K=[])=>{for(let _ of A)K.push(_),_.subtasks&&_.subtasks.length>0&&(_.isExpanded===void 0||_.isExpanded)&&O(_.subtasks,K);return K},G=E(e);return O(G)},[e]),N=Se.useCallback(E=>{if(!E.startDate||!E.endDate)return {x:0,width:0};let O=E.startDate.getTime(),G=E.endDate.getTime(),U=n.getTime(),A=(O-U)/(1e3*60*60*24),K=(G-O)/(1e3*60*60*24),_=A*b*s,ae=Math.max(b*s,40),M=Math.max(K*b*s,ae);return {x:_,width:M}},[n,b,s]),T=Se.useMemo(()=>C.filter(E=>E.startDate&&E.endDate).map(E=>{let{x:O,width:G}=N(E),A=C.findIndex(K=>K.id===E.id)*r+12;return {id:E.id,x:O,y:A,width:G,height:32}}),[C,N]),$=Se.useCallback((E,O,G)=>{if(!G||O===0){h([]);return}let U=q.calculateCascadePreview(e,E,O,C,n,b*s,r,48);h(U);},[e,C,n,b,s,r,48]),z=Se.useMemo(()=>{let E=[],O=new Date(n);for(;O<=o;){let A=(O.getTime()-n.getTime())/864e5*b*s;if(a==="day")E.push({date:new Date(O),label:O.toLocaleDateString("en-US",{day:"numeric",month:"short"}),x:A}),O.setDate(O.getDate()+1);else if(a==="week"){let K=k(O);E.push({date:new Date(O),label:`Week ${K}`,x:A}),O.setDate(O.getDate()+7);}else E.push({date:new Date(O),label:O.toLocaleDateString("en-US",{month:"short",year:"numeric"}),x:A}),O.setMonth(O.getMonth()+1);}return E},[n,o,a,b,s]),R=Se.useMemo(()=>(new Date().getTime()-n.getTime())/(1e3*60*60*24)*b*s,[n,b,s]),W=Math.max(C.length*r,552);return jsxRuntime.jsxs("div",{className:"w-full h-full flex flex-col","data-gantt-chart":true,style:{backgroundColor:t.bgPrimary},children:[jsxRuntime.jsx("div",{style:{position:"sticky",top:0,zIndex:10,backgroundColor:t.bgGrid,flexShrink:0,height:"48px",borderBottom:`1px solid ${t.border}`,boxSizing:"border-box"},children:jsxRuntime.jsxs("svg",{width:Math.max(f,1e3),height:47,style:{display:"block"},children:[jsxRuntime.jsx("rect",{x:0,y:0,width:Math.max(f,1e3),height:48,fill:t.bgGrid}),z.map((E,O)=>jsxRuntime.jsxs("g",{children:[O>0&&jsxRuntime.jsx("line",{x1:E.x,y1:0,x2:E.x,y2:48,stroke:t.border,strokeWidth:1,opacity:.1}),jsxRuntime.jsx("text",{x:E.x+8,y:48/2,fill:t.textTertiary,fontSize:"11",fontFamily:"'JetBrains Mono', ui-monospace, monospace",fontWeight:"500",dominantBaseline:"middle",children:E.label})]},`header-${O}`)),R>=0&&R<=f&&jsxRuntime.jsx("circle",{cx:R,cy:38,r:6,fill:t.today,opacity:1})]})}),jsxRuntime.jsxs("svg",{width:Math.max(f,1e3),height:W,style:{display:"block",flexShrink:0},children:[jsxRuntime.jsxs("defs",{children:[jsxRuntime.jsx("filter",{id:"shadow",children:jsxRuntime.jsx("feDropShadow",{dx:"0",dy:"1",stdDeviation:"2",floodOpacity:"0.1"})}),jsxRuntime.jsx("pattern",{id:"diagonal-stripes",width:"8",height:"8",patternUnits:"userSpaceOnUse",patternTransform:"rotate(45)",children:jsxRuntime.jsx("line",{x1:"0",y1:"0",x2:"0",y2:"8",stroke:t.border,strokeWidth:"2"})})]}),jsxRuntime.jsx("rect",{x:0,y:0,width:Math.max(f,1e3),height:W,fill:t.bgPrimary}),z.map((E,O)=>{let G=z[O+1]?.x||f,U=w(E.date);return jsxRuntime.jsxs("g",{children:[U&&jsxRuntime.jsx("rect",{x:E.x,y:0,width:G-E.x,height:C.length*r,fill:t.bgWeekend,opacity:1}),O>0&&jsxRuntime.jsx("line",{x1:E.x,y1:0,x2:E.x,y2:C.length*r,stroke:t.border,strokeWidth:1,opacity:.1})]},O)}),R>=0&&R<=f&&jsxRuntime.jsx("line",{x1:R,y1:0,x2:R,y2:C.length*r,stroke:t.today,strokeWidth:2,opacity:1}),C.map((E,O)=>{let G=E.startDate&&E.endDate;return jsxRuntime.jsxs("g",{children:[jsxRuntime.jsx("rect",{x:0,y:O*r,width:f,height:r,fill:O%2===0?"transparent":t.bgSecondary,opacity:1,style:{pointerEvents:"none"}},`row-${E.id}`),!G&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:0,y:O*r,width:f,height:r,fill:"transparent",style:{cursor:"pointer",pointerEvents:"all"},onClick:U=>D(U,E),onMouseEnter:U=>{U.currentTarget.setAttribute("fill",t.accentLight),U.currentTarget.setAttribute("opacity","0.5");},onMouseLeave:U=>{U.currentTarget.setAttribute("fill","transparent"),U.currentTarget.setAttribute("opacity","1");}},`clickable-${E.id}`),jsxRuntime.jsx("text",{x:R>0?R:100,y:O*r+r/2,fill:t.textTertiary,fontSize:"12",fontFamily:"Inter, sans-serif",fontStyle:"italic",dominantBaseline:"middle",opacity:.4,style:{pointerEvents:"none",userSelect:"none"},children:"Click to set dates..."},`placeholder-${E.id}`)]})]},`row-group-${E.id}`)}),C.map((E,O)=>!E.dependencies||E.dependencies.length===0||!E.startDate||!E.endDate?null:E.dependencies.map(G=>{let U=C.find(ae=>ae.id===G);if(!U||!U.startDate||!U.endDate)return null;let A=C.findIndex(ae=>ae.id===G),K=N(U),_=N(E);return jsxRuntime.jsx(_n,{x1:K.x+K.width,y1:A*r+r/2,x2:_.x,y2:O*r+r/2,theme:t,onDelete:()=>m?.(E.id,G)},`dep-${G}-${E.id}`)})),C.map((E,O)=>{if(!E.startDate||!E.endDate)return null;let{x:G,width:U}=N(E),A=O*r+12,K=E.subtasks&&E.subtasks.length>0&&!E.isMilestone;return E.isMilestone?jsxRuntime.jsx(Vn,{task:E,x:G+U/2,y:A+16,theme:t,onClick:u},E.id):K?jsxRuntime.jsxs("g",{onClick:()=>u?.(E),style:{cursor:"pointer"},children:[jsxRuntime.jsx("rect",{x:G,y:A,width:U,height:32,fill:t.primary,opacity:.25,rx:6}),jsxRuntime.jsx("line",{x1:G,y1:A,x2:G+U,y2:A,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:G,y1:A,x2:G,y2:A+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:G+U,y1:A,x2:G+U,y2:A+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:G,y1:A+32,x2:G+U,y2:A+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),U>60&&jsxRuntime.jsx("text",{x:G+12,y:A+16,dominantBaseline:"middle",fill:"#FFFFFF",fontSize:"13",fontWeight:"500",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:E.name})]},E.id):jsxRuntime.jsx(Un,{task:E,x:G,y:A,width:U,theme:t,dayWidth:b*s,startDate:n,templates:c,onClick:u,onDoubleClick:i,onContextMenu:p,onDateChange:l,onDependencyCreate:d,allTaskPositions:T,onDragMove:$},E.id)}),y.map(E=>jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[jsxRuntime.jsx("rect",{x:E.previewX,y:E.y-48,width:E.width,height:32,rx:8,fill:E.color||t.accent,opacity:.3,stroke:t.accent,strokeWidth:2,strokeDasharray:"4 2"}),Math.abs(E.daysDelta)>0&&jsxRuntime.jsx("text",{x:E.previewX+E.width/2,y:E.y-48+16,textAnchor:"middle",dominantBaseline:"middle",fill:t.accent,fontSize:"10",fontWeight:"600",fontFamily:"Inter, sans-serif",style:{userSelect:"none"},children:E.daysDelta>0?`+${E.daysDelta}d`:`${E.daysDelta}d`})]},`cascade-preview-${E.taskId}`))]})]})}var Ic=[{name:"Azul",value:"#6366F1",light:"#818CF8"},{name:"P\xFArpura",value:"#A855F7",light:"#C084FC"},{name:"Rosa",value:"#EC4899",light:"#F472B6"},{name:"Rojo",value:"#EF4444",light:"#F87171"},{name:"Naranja",value:"#F59E0B",light:"#FBBF24"},{name:"Amarillo",value:"#EAB308",light:"#FACC15"},{name:"Lima",value:"#84CC16",light:"#A3E635"},{name:"Verde",value:"#10B981",light:"#34D399"},{name:"Esmeralda",value:"#059669",light:"#10B981"},{name:"Cyan",value:"#06B6D4",light:"#22D3EE"},{name:"Azul Cielo",value:"#0EA5E9",light:"#38BDF8"},{name:"\xCDndigo",value:"#4F46E5",light:"#6366F1"},{name:"Violeta",value:"#8B5CF6",light:"#A78BFA"},{name:"Fucsia",value:"#D946EF",light:"#E879F9"},{name:"Gris",value:"#6B7280",light:"#9CA3AF"},{name:"Piedra",value:"#78716C",light:"#A8A29E"}];function Ac({value:e="#6366F1",onChange:t,disabled:r=false}){return jsxRuntime.jsxs("div",{className:"space-y-2",children:[jsxRuntime.jsx("div",{className:"flex flex-wrap gap-2",children:Ic.map(a=>{let n=e===a.value;return jsxRuntime.jsx(framerMotion.motion.button,{type:"button",onClick:()=>!r&&t(a.value),className:"relative rounded-full transition-all focus:outline-none focus:ring-2 focus:ring-offset-2",style:{width:"32px",height:"32px",backgroundColor:a.value,boxShadow:n?`0 0 0 2px #FFFFFF, 0 0 0 4px ${a.value}`:"0 1px 3px rgba(0, 0, 0, 0.12)",opacity:r?.5:1,cursor:r?"not-allowed":"pointer"},whileHover:r?{}:{scale:1.1},whileTap:r?{}:{scale:.95},title:a.name,disabled:r,children:n&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{scale:0},animate:{scale:1},className:"absolute inset-0 flex items-center justify-center",children:jsxRuntime.jsx(lucideReact.Check,{className:"w-4 h-4 text-white drop-shadow-md",strokeWidth:3})})},a.value)})}),e&&jsxRuntime.jsx("div",{className:"text-xs text-center font-medium",style:{color:e},children:Ic.find(a=>a.value===e)?.name||"Personalizado"})]})}function qn({isOpen:e,onClose:t,task:r,availableTasks:a=[],availableUsers:n=[],onSubmit:o,isLoading:s=false,mode:c=r?"edit":"create",theme:u="dark"}){let i=Ce[u]||Ce.dark,p={backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`,color:i.textPrimary},l={color:i.textSecondary},[d,m]=Se.useState({name:"",progress:0,status:"todo",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[]}),[v,y]=Se.useState({});Se.useEffect(()=>{m(r?{name:r.name,startDate:r.startDate,endDate:r.endDate,progress:r.progress,status:r.status||"todo",isMilestone:r.isMilestone||false,color:r.color||"#6366F1",assignees:r.assignees||[],dependencies:r.dependencies||[]}:{name:"",progress:0,status:"todo",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[]});},[r,e]);let h=()=>{let f={};return d.name.trim()||(f.name="El nombre es requerido"),d.startDate&&d.endDate&&d.startDate>d.endDate&&(f.endDate="La fecha de fin debe ser posterior a la de inicio"),y(f),Object.keys(f).length===0},g=async f=>{if(f.preventDefault(),!!h())try{await o(d),t();}catch(k){console.error("Error submitting task:",k);}},b=(f,k)=>{m(w=>{let x={...w,[f]:k};if(f==="progress"){let D=typeof k=="number"?k:parseInt(k,10);D===100&&w.status!=="completed"?x.status="completed":D>0&&D<100&&w.status==="todo"?x.status="in-progress":D===0&&w.status==="in-progress"&&(x.status="todo");}return x}),v[f]&&y(w=>{let x={...w};return delete x[f],x});};return jsxRuntime.jsx(framerMotion.AnimatePresence,{children:e&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},className:"fixed inset-0 bg-black/50 z-50",onClick:t}),jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,scale:.95,y:20},animate:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:20},transition:{duration:.2,ease:[.4,0,.2,1]},className:"fixed inset-0 z-50 flex items-center justify-center p-4 pointer-events-none",children:jsxRuntime.jsxs("div",{className:"w-full max-w-2xl rounded-xl shadow-2xl pointer-events-auto overflow-hidden",style:{backgroundColor:i.bgPrimary,border:`1px solid ${i.border}`},onClick:f=>f.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-6 py-4",style:{borderBottom:`1px solid ${i.border}`},children:[jsxRuntime.jsx("h2",{className:"text-lg font-semibold",style:{color:i.textPrimary},children:c==="create"?"Crear Nueva Tarea":"Editar Tarea"}),jsxRuntime.jsx("button",{onClick:t,className:"p-2 rounded-lg transition-colors",style:{color:i.textSecondary},onMouseEnter:f=>f.currentTarget.style.backgroundColor=i.hoverBg,onMouseLeave:f=>f.currentTarget.style.backgroundColor="transparent",disabled:s,children:jsxRuntime.jsx(lucideReact.X,{className:"w-5 h-5"})})]}),jsxRuntime.jsxs("form",{onSubmit:g,className:"p-6 space-y-6 max-h-[calc(100vh-200px)] overflow-y-auto",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{className:"block text-sm font-medium mb-2",style:l,children:"Nombre de la Tarea *"}),jsxRuntime.jsx("input",{type:"text",value:d.name,onChange:f=>b("name",f.target.value),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,onFocus:f=>f.currentTarget.style.borderColor=i.accent,onBlur:f=>f.currentTarget.style.borderColor=i.borderLight,placeholder:"Ej: Dise\xF1ar mockups de la aplicaci\xF3n",disabled:s}),v.name&&jsxRuntime.jsxs("p",{className:"mt-1 text-sm text-red-400 flex items-center gap-1",children:[jsxRuntime.jsx(lucideReact.AlertCircle,{className:"w-4 h-4"}),v.name]})]}),jsxRuntime.jsxs("div",{className:"grid grid-cols-2 gap-4",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"w-4 h-4"}),"Fecha de Inicio"]}),jsxRuntime.jsx("input",{type:"date",value:d.startDate?d.startDate.toISOString().split("T")[0]:"",onChange:f=>b("startDate",f.target.value?new Date(f.target.value):void 0),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,disabled:s||d.isMilestone})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"w-4 h-4"}),"Fecha de Fin"]}),jsxRuntime.jsx("input",{type:"date",value:d.endDate?d.endDate.toISOString().split("T")[0]:"",onChange:f=>b("endDate",f.target.value?new Date(f.target.value):void 0),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,disabled:s||d.isMilestone}),v.endDate&&jsxRuntime.jsxs("p",{className:"mt-1 text-sm text-red-400 flex items-center gap-1",children:[jsxRuntime.jsx(lucideReact.AlertCircle,{className:"w-4 h-4"}),v.endDate]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.CheckCircle2,{className:"w-4 h-4"}),"Estado"]}),jsxRuntime.jsxs("select",{value:d.status,onChange:f=>b("status",f.target.value),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,disabled:s,children:[jsxRuntime.jsx("option",{value:"todo",children:"Por Hacer"}),jsxRuntime.jsx("option",{value:"in-progress",children:"En Progreso"}),jsxRuntime.jsx("option",{value:"completed",children:"Completada"})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-3 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Palette,{className:"w-4 h-4"}),"Color de la Tarea"]}),jsxRuntime.jsx(Ac,{value:d.color,onChange:f=>b("color",f),disabled:s}),jsxRuntime.jsx("p",{className:"text-xs mt-2",style:{color:i.textTertiary},children:r?.parentId?"Esta subtarea hereda el color de su tarea padre":r?.subtasks&&r.subtasks.length>0?"Las subtareas heredar\xE1n este color con menor opacidad":"Elige un color para organizar visualmente tus tareas"})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center justify-between",style:l,children:[jsxRuntime.jsxs("span",{className:"flex items-center gap-2",children:[jsxRuntime.jsx(lucideReact.Clock,{className:"w-4 h-4"}),"Progreso"]}),jsxRuntime.jsxs("span",{className:"font-semibold px-2 py-0.5 rounded text-sm",style:{color:d.progress<30?"#EF4444":d.progress<70?"#F59E0B":"#10B981",backgroundColor:d.progress<30?"rgba(239, 68, 68, 0.1)":d.progress<70?"rgba(245, 158, 11, 0.1)":"rgba(16, 185, 129, 0.1)"},children:[d.progress,"%"]})]}),jsxRuntime.jsxs("div",{className:"relative",children:[jsxRuntime.jsx("input",{type:"range",min:"0",max:"100",step:"5",value:d.progress,onChange:f=>b("progress",parseInt(f.target.value)),className:"w-full h-2 rounded-lg appearance-none cursor-pointer",style:{backgroundColor:i.bgSecondary,accentColor:d.progress<30?"#EF4444":d.progress<70?"#F59E0B":"#10B981"},disabled:s}),jsxRuntime.jsx("div",{className:"absolute top-0 left-0 h-2 rounded-lg pointer-events-none transition-all duration-300",style:{width:`${d.progress}%`,backgroundColor:d.progress<30?"rgba(239, 68, 68, 0.3)":d.progress<70?"rgba(245, 158, 11, 0.3)":"rgba(16, 185, 129, 0.3)"}})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-between mt-3 gap-2",children:[jsxRuntime.jsx("span",{className:"text-xs",style:{color:i.textTertiary},children:"Accesos r\xE1pidos:"}),jsxRuntime.jsx("div",{className:"flex gap-1.5",children:[0,25,50,75,100].map(f=>jsxRuntime.jsxs("button",{type:"button",onClick:()=>b("progress",f),disabled:s,className:"px-3 py-1 text-xs font-medium rounded-md transition-all duration-200 hover:scale-105 active:scale-95",style:{backgroundColor:d.progress===f?f<30?"#EF4444":f<70?"#F59E0B":"#10B981":i.bgSecondary,color:d.progress===f?"#FFFFFF":i.textSecondary,border:`1px solid ${d.progress===f?f<30?"#EF4444":f<70?"#F59E0B":"#10B981":i.borderLight}`},children:[f,"%"]},f))})]}),jsxRuntime.jsxs("div",{className:"flex justify-between text-xs mt-2",style:{color:i.textTertiary},children:[jsxRuntime.jsx("span",{children:"0%"}),jsxRuntime.jsx("span",{children:"25%"}),jsxRuntime.jsx("span",{children:"50%"}),jsxRuntime.jsx("span",{children:"75%"}),jsxRuntime.jsx("span",{children:"100%"})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3 p-4 rounded-lg",style:{backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`},children:[jsxRuntime.jsx("input",{type:"checkbox",id:"isMilestone",checked:d.isMilestone,onChange:f=>b("isMilestone",f.target.checked),className:"w-4 h-4 rounded focus:ring-2",style:{accentColor:i.accent},disabled:s}),jsxRuntime.jsxs("label",{htmlFor:"isMilestone",className:"flex items-center gap-2 text-sm cursor-pointer",style:{color:i.textPrimary},children:[jsxRuntime.jsx(lucideReact.Milestone,{className:"w-4 h-4 text-yellow-500"}),"Marcar como Hito (Milestone)"]})]}),n.length>0&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Users,{className:"w-4 h-4"}),"Asignar a"]}),jsxRuntime.jsx("div",{className:"space-y-2 max-h-32 overflow-y-auto p-3 rounded-lg",style:{backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`},children:n.map(f=>jsxRuntime.jsxs("label",{className:"flex items-center gap-3 cursor-pointer p-2 rounded",onMouseEnter:k=>k.currentTarget.style.backgroundColor=i.hoverBg,onMouseLeave:k=>k.currentTarget.style.backgroundColor="transparent",children:[jsxRuntime.jsx("input",{type:"checkbox",checked:d.assignees?.some(k=>k.name===f.name),onChange:k=>{let w=k.target.checked?[...d.assignees||[],{name:f.name,avatar:f.avatar,initials:f.name.split(" ").map(x=>x[0]).join("").toUpperCase().slice(0,2),color:i.accent}]:(d.assignees||[]).filter(x=>x.name!==f.name);b("assignees",w);},className:"w-4 h-4 rounded",style:{accentColor:i.accent},disabled:s}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[jsxRuntime.jsx("div",{className:"w-6 h-6 rounded-full flex items-center justify-center text-xs text-white font-semibold",style:{backgroundColor:i.accent},children:f.name.charAt(0).toUpperCase()}),jsxRuntime.jsx("span",{className:"text-sm",style:{color:i.textPrimary},children:f.name})]})]},f.id))})]}),a.length>0&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Link2,{className:"w-4 h-4"}),"Dependencias"]}),jsxRuntime.jsx("div",{className:"space-y-2 max-h-32 overflow-y-auto p-3 rounded-lg",style:{backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`},children:a.filter(f=>f.id!==r?.id).map(f=>jsxRuntime.jsxs("label",{className:"flex items-center gap-3 cursor-pointer p-2 rounded",onMouseEnter:k=>k.currentTarget.style.backgroundColor=i.hoverBg,onMouseLeave:k=>k.currentTarget.style.backgroundColor="transparent",children:[jsxRuntime.jsx("input",{type:"checkbox",checked:d.dependencies?.includes(f.id),onChange:k=>{let w=k.target.checked?[...d.dependencies||[],f.id]:(d.dependencies||[]).filter(x=>x!==f.id);b("dependencies",w);},className:"w-4 h-4 rounded",style:{accentColor:i.accent},disabled:s}),jsxRuntime.jsx("span",{className:"text-sm",style:{color:i.textPrimary},children:f.name})]},f.id))})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-end gap-3 px-6 py-4",style:{borderTop:`1px solid ${i.border}`,backgroundColor:i.bgPrimary},children:[jsxRuntime.jsx("button",{type:"button",onClick:t,className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors",style:{color:i.textSecondary},onMouseEnter:f=>{f.currentTarget.style.color=i.textPrimary,f.currentTarget.style.backgroundColor=i.hoverBg;},onMouseLeave:f=>{f.currentTarget.style.color=i.textSecondary,f.currentTarget.style.backgroundColor="transparent";},disabled:s,children:"Cancelar"}),jsxRuntime.jsx("button",{onClick:g,disabled:s,className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors disabled:opacity-50 disabled:cursor-not-allowed flex items-center gap-2",style:{backgroundColor:i.accent,color:"#FFFFFF"},onMouseEnter:f=>!s&&(f.currentTarget.style.backgroundColor=i.accentHover),onMouseLeave:f=>!s&&(f.currentTarget.style.backgroundColor=i.accent),children:s?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"w-4 h-4 border-2 border-white/30 border-t-white rounded-full animate-spin"}),"Guardando..."]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(lucideReact.CheckCircle2,{className:"w-4 h-4"}),c==="create"?"Crear Tarea":"Guardar Cambios"]})})]})]})})]})})}var dh=['Move "Task Name" to next Monday','Extend "Task Name" by 3 days','Rename "Old Name" to "New Name"','Set "Task Name" progress to 50%','Link "Task A" to "Task B"','Create a new task called "New Task"','Delete "Task Name"','Assign John to "Task Name"'],Wc=()=>jsxRuntime.jsxs("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M12 3v1m0 16v1m9-9h-1M4 12H3m15.364 6.364l-.707-.707M6.343 6.343l-.707-.707m12.728 0l-.707.707M6.343 17.657l-.707.707"}),jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"4"})]}),uh=()=>jsxRuntime.jsx("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M22 2L11 13M22 2L15 22L11 13M22 2L2 9L11 13"})}),mh=()=>jsxRuntime.jsx("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M18 6L6 18M6 6L18 18"})}),ph=()=>jsxRuntime.jsx("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M5 12h14"})}),fh=()=>jsxRuntime.jsx("div",{className:"flex gap-1 items-center",children:[0,1,2].map(e=>jsxRuntime.jsx(framerMotion.motion.div,{className:"w-2 h-2 rounded-full bg-current",animate:{scale:[1,1.2,1],opacity:[.5,1,.5]},transition:{duration:.8,repeat:1/0,delay:e*.15}},e))});function Xn({tasks:e,theme:t,config:r,onTasksUpdate:a,onTaskUpdate:n,onTaskCreate:o,onTaskDelete:s,onDependencyCreate:c,onDependencyDelete:u}){let[i,p]=Se.useState(false),[l,d]=Se.useState(false),[m,v]=Se.useState([]),[y,h]=Se.useState(""),[g,b]=Se.useState(false),[f,k]=Se.useState(true),w=Se.useRef(null),x=Se.useRef(null),D=Se.useRef(null),{enabled:C=true,placeholder:N='Ask AI to edit tasks... (e.g., "Move Design to next week")',position:T="bottom-right",onCommand:$,suggestions:z=dh,maxHistory:R=50}=r;Se.useEffect(()=>{x.current&&x.current.scrollIntoView({behavior:"smooth"});},[m]),Se.useEffect(()=>{i&&!l&&w.current&&setTimeout(()=>w.current?.focus(),100);},[i,l]);let W=Se.useCallback(A=>{if(A.success)switch(A.type){case "move_task":case "resize_task":case "rename_task":case "set_progress":case "set_status":case "assign_task":A.taskId&&A.updates&&n?.(A.taskId,A.updates);break;case "create_task":A.newTask&&o?.(A.newTask);break;case "delete_task":A.taskId&&s?.(A.taskId);break;case "link_tasks":A.dependencyFrom&&A.dependencyTo&&c?.(A.dependencyFrom,A.dependencyTo);break;case "unlink_tasks":A.taskId&&A.dependencyFrom&&u?.(A.taskId,A.dependencyFrom);break}},[n,o,s,c,u]),E=Se.useCallback(async A=>{if(!A.trim()||g)return;let K={id:`user-${Date.now()}`,role:"user",content:A,timestamp:new Date};v(ae=>[...ae.slice(-(R-1)),K]),h(""),k(false),b(true);let _={id:`loading-${Date.now()}`,role:"assistant",content:"",timestamp:new Date,isLoading:true};v(ae=>[...ae,_]);try{if($){let ae=await $(A,e);v(M=>{let de=M.filter(kt=>!kt.isLoading),ie={id:`assistant-${Date.now()}`,role:"assistant",content:ae.message,timestamp:new Date,command:ae};return [...de,ie]}),W(ae);}else v(ae=>[...ae.filter(de=>!de.isLoading),{id:`assistant-${Date.now()}`,role:"assistant",content:"AI handler not configured. Please provide an onCommand handler in the aiAssistant config.",timestamp:new Date}]);}catch(ae){v(M=>[...M.filter(ie=>!ie.isLoading),{id:`error-${Date.now()}`,role:"assistant",content:`Sorry, I encountered an error: ${ae instanceof Error?ae.message:"Unknown error"}`,timestamp:new Date}]);}finally{b(false);}},[g,R,$,e,W]),O=A=>{A.preventDefault(),E(y);},G=A=>{h(A),w.current?.focus();};if(Se.useEffect(()=>{let A=K=>{(K.metaKey||K.ctrlKey)&&K.key==="k"&&(K.preventDefault(),p(_=>!_),i||d(false)),K.key==="Escape"&&i&&p(false);};return document.addEventListener("keydown",A),()=>document.removeEventListener("keydown",A)},[i]),!C)return null;let U={"bottom-right":"bottom-4 right-4","bottom-left":"bottom-4 left-4","top-right":"top-4 right-4","top-left":"top-4 left-4"};return jsxRuntime.jsxs(Ye,{children:[jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!i&&jsxRuntime.jsxs(framerMotion.motion.button,{initial:{scale:0,opacity:0},animate:{scale:1,opacity:1},exit:{scale:0,opacity:0},whileHover:{scale:1.05},whileTap:{scale:.95},className:`fixed ${U[T]} z-[99999] flex items-center gap-2 px-4 py-3 rounded-full shadow-lg transition-colors`,style:{background:"linear-gradient(135deg, #3B82F6 0%, #2563EB 100%)",color:"white",boxShadow:"0 4px 20px rgba(59, 130, 246, 0.4)"},onClick:()=>p(true),children:[jsxRuntime.jsx(Wc,{}),jsxRuntime.jsx("span",{className:"text-sm font-medium",children:"AI Assistant"}),jsxRuntime.jsx("kbd",{className:"hidden sm:inline-flex items-center gap-0.5 px-1.5 py-0.5 text-[10px] font-mono rounded bg-white/20",children:"\u2318K"})]})}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:i&&jsxRuntime.jsxs(framerMotion.motion.div,{ref:D,initial:{opacity:0,y:20,scale:.95},animate:{opacity:1,y:0,scale:1,height:l?"auto":500},exit:{opacity:0,y:20,scale:.95},transition:{type:"spring",damping:25,stiffness:300},className:`fixed ${U[T]} z-[99999] w-96 rounded-2xl overflow-hidden shadow-2xl flex flex-col`,style:{background:t.bgPrimary,border:`1px solid ${t.border}`,boxShadow:`0 20px 60px rgba(0, 0, 0, 0.3), 0 0 0 1px ${t.border}`},children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-4 py-3",style:{background:"linear-gradient(135deg, #3B82F6 0%, #2563EB 100%)"},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 text-white",children:[jsxRuntime.jsx(Wc,{}),jsxRuntime.jsx("span",{className:"font-semibold",children:"Gantt AI Assistant"})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("button",{onClick:()=>d(A=>!A),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(ph,{})}),jsxRuntime.jsx("button",{onClick:()=>p(false),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(mh,{})})]})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!l&&jsxRuntime.jsxs(framerMotion.motion.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},className:"flex flex-col flex-1 min-h-0",children:[jsxRuntime.jsxs("div",{className:"flex-1 overflow-y-auto p-4 space-y-4",style:{maxHeight:350},children:[m.length===0&&f&&jsxRuntime.jsxs("div",{className:"space-y-3",children:[jsxRuntime.jsx("p",{className:"text-sm text-center",style:{color:t.textSecondary},children:"Try asking me to edit your Gantt chart:"}),jsxRuntime.jsx("div",{className:"flex flex-wrap gap-2",children:z.slice(0,4).map((A,K)=>jsxRuntime.jsx("button",{onClick:()=>G(A),className:"text-xs px-3 py-1.5 rounded-full transition-colors",style:{background:t.bgSecondary,color:t.textSecondary,border:`1px solid ${t.border}`},children:A.length>30?A.slice(0,30)+"...":A},K))})]}),m.map(A=>jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},className:`flex ${A.role==="user"?"justify-end":"justify-start"}`,children:jsxRuntime.jsxs("div",{className:`max-w-[85%] rounded-2xl px-4 py-2.5 ${A.role==="user"?"rounded-br-md":"rounded-bl-md"}`,style:{background:A.role==="user"?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":t.bgSecondary,color:A.role==="user"?"white":t.textPrimary},children:[A.isLoading?jsxRuntime.jsx(fh,{}):jsxRuntime.jsx("p",{className:"text-sm whitespace-pre-wrap",children:A.content}),A.command&&jsxRuntime.jsxs("div",{className:"mt-2 text-xs px-2 py-1 rounded-md inline-flex items-center gap-1",style:{background:A.command.success?"rgba(16, 185, 129, 0.2)":"rgba(239, 68, 68, 0.2)",color:A.command.success?"#10B981":"#EF4444"},children:[A.command.success?"\u2713":"\u2717",jsxRuntime.jsx("span",{className:"capitalize",children:A.command.type.replace(/_/g," ")})]})]})},A.id)),jsxRuntime.jsx("div",{ref:x})]}),jsxRuntime.jsxs("form",{onSubmit:O,className:"p-3 border-t",style:{borderColor:t.border},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 rounded-xl px-4 py-2",style:{background:t.bgSecondary,border:`1px solid ${t.border}`},children:[jsxRuntime.jsx("input",{ref:w,type:"text",value:y,onChange:A=>h(A.target.value),placeholder:N,disabled:g,className:"flex-1 bg-transparent text-sm outline-none",style:{color:t.textPrimary}}),jsxRuntime.jsx("button",{type:"submit",disabled:!y.trim()||g,className:"p-2 rounded-lg transition-all disabled:opacity-50",style:{background:y.trim()?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":"transparent",color:y.trim()?"white":t.textSecondary},children:jsxRuntime.jsx(uh,{})})]}),jsxRuntime.jsx("p",{className:"text-[10px] text-center mt-2",style:{color:t.textTertiary},children:"Press Enter to send \u2022 Esc to close"})]})]})})]})})]})}function Uc(e,t=50){let[r,a]=Se.useState({past:[],present:e,future:[]}),n=Se.useRef(false),o=Se.useCallback((i,p=true)=>{a(l=>{let d=typeof i=="function"?i(l.present):i;if(n.current)return {...l,present:d};if(!p)return {...l,present:d};let m=[...l.past,l.present];return m.length>t&&m.shift(),{past:m,present:d,future:[]}});},[t]),s=Se.useCallback(()=>{a(i=>{if(i.past.length===0)return i;let p=i.past[i.past.length-1],l=i.past.slice(0,i.past.length-1);return n.current=true,setTimeout(()=>{n.current=false;},0),{past:l,present:p,future:[i.present,...i.future]}});},[]),c=Se.useCallback(()=>{a(i=>{if(i.future.length===0)return i;let p=i.future[0],l=i.future.slice(1);return n.current=true,setTimeout(()=>{n.current=false;},0),{past:[...i.past,i.present],present:p,future:l}});},[]),u=Se.useCallback(()=>{a(i=>({past:[],present:i.present,future:[]}));},[]);return {state:r.present,setState:o,undo:s,redo:c,canUndo:r.past.length>0,canRedo:r.future.length>0,clearHistory:u}}function Gc({undo:e,redo:t,canUndo:r,canRedo:a,enabled:n=true}){Se.useEffect(()=>{if(!n)return;let o=s=>{let c=navigator.platform.toUpperCase().indexOf("MAC")>=0,u=c?s.metaKey:s.ctrlKey;if(u&&s.key==="z"&&!s.shiftKey&&r){s.preventDefault(),e();return}if(a){if(!c&&u&&s.key==="y"){s.preventDefault(),t();return}if(c&&u&&s.shiftKey&&s.key==="z"){s.preventDefault(),t();return}}};return window.addEventListener("keydown",o),()=>{window.removeEventListener("keydown",o);}},[e,t,r,a,n]);}var vh={taskTooltip:e=>{let t=[`<strong>${e.name}</strong>`];if(e.startDate&&e.endDate){t.push(`${q.formatDate(e.startDate)} - ${q.formatDate(e.endDate)}`);let r=q.calculateDuration(e.startDate,e.endDate);t.push(`Duration: ${r} days`);}if(e.progress!==void 0&&t.push(`Progress: ${e.progress}%`),e.status&&t.push(`Status: ${e.status}`),e.assignees&&e.assignees.length>0){let r=e.assignees.map(a=>a.name).join(", ");t.push(`Assigned: ${r}`);}return e.dependencies&&e.dependencies.length>0&&t.push(`Dependencies: ${e.dependencies.length}`),t.join("<br/>")},taskLabel:e=>e.name,gridCell:(e,t,r)=>r,taskClass:e=>{let t=[];return e.isCriticalPath&&t.push("critical-path"),e.status==="completed"?t.push("completed"):e.status==="in-progress"?t.push("in-progress"):e.status==="todo"&&t.push("todo"),e.isMilestone&&t.push("milestone"),t.join(" ")},milestoneContent:e=>`\u25C6 ${e.name}`,dateFormat:e=>q.formatDate(e),durationFormat:e=>e===1?"1 day":`${e} days`,progressFormat:e=>`${e}%`};function _c(e){return {...vh,...e}}var wh=e=>{switch(e){case "compact":return 40;case "comfortable":return 48;case "spacious":return 56;default:return 48}},jc=Se.forwardRef(function({tasks:t,config:r={},onTasksChange:a},n){let{theme:o,timeScale:s="week",rowDensity:c="comfortable",showThemeSelector:u=true,showExportButton:i=true,availableUsers:p=[],templates:l,enableAutoCriticalPath:d=true,aiAssistant:m,locale:v="en",customTranslations:y,showCreateTaskButton:h=false,createTaskLabel:g,onCreateTask:b,onThemeChange:f,onTaskClick:k,onTaskDblClick:w,onTaskContextMenu:x,onTaskUpdate:D,onProgressChange:C,onTaskEdit:N,onTaskAddSubtask:T,onTaskMarkIncomplete:$,onTaskSetInProgress:z,onDependencyCreate:R,onDependencyDelete:W,onBeforeTaskAdd:E,onAfterTaskAdd:O,onBeforeTaskUpdate:G,onAfterTaskUpdate:U}=r,K=Se.useContext(Fn)?.theme,[_,ae]=Se.useState(K||o||"dark"),[M,de]=Se.useState(s),[ie,kt]=Se.useState(c),[rt,ir]=Se.useState(1),[De,bt]=Se.useState(0),[wt,jt]=Se.useState(false),[hr,zr]=Se.useState(null),[he,at]=Se.useState({isOpen:false,x:0,y:0,task:null}),[Kt,Wt]=Se.useState(null);Se.useEffect(()=>{K&&K!==_&&ae(K);},[K]),Se.useEffect(()=>{o&&o!==_&&ae(o);},[o]);let $r=Se.useCallback(P=>{ae(P),f?.(P);},[f]),{state:se,setState:ue,undo:X,redo:j,canUndo:Te,canRedo:We,clearHistory:re}=Uc(t,50);Se.useEffect(()=>{ue(t);},[t,ue]),Se.useEffect(()=>{a&&a(se);},[se,a]);let le=Se.useMemo(()=>ms(v,y),[v,y]),lr=Se.useCallback(P=>[{id:"name",label:P.columns.taskName,width:320,minWidth:180,maxWidth:800,visible:true,sortable:true,resizable:true},{id:"startDate",label:P.columns.startDate,width:110,visible:false,sortable:true},{id:"endDate",label:P.columns.endDate,width:110,visible:false,sortable:true},{id:"duration",label:P.columns.duration,width:80,visible:false,sortable:true},{id:"assignees",label:P.columns.assignees,width:120,visible:false,sortable:false},{id:"status",label:P.columns.status,width:80,visible:false,sortable:true},{id:"progress",label:P.columns.progress,width:120,visible:false,sortable:true}],[]),[Ut,J]=Se.useState(()=>lr(le));Se.useEffect(()=>{J(P=>P.map(I=>({...I,label:le.columns[I.id==="name"?"taskName":I.id]||I.label})));},[le]);let Y=Se.useMemo(()=>Ut.filter(P=>P.visible).reduce((P,I)=>P+I.width,0)+60,[Ut]),ve=hr||Y,S=Se.useRef(null),H=Se.useRef(null),me=Se.useRef(null),ye=Se.useMemo(()=>nc(_),[_]),Be=Se.useMemo(()=>({theme:ye,themeName:_}),[ye,_]),Ue=Se.useMemo(()=>_c(l),[l]),Mt=Se.useMemo(()=>{if(!d)return se;let P=q.calculateCriticalPath(se),I=V=>V.map(ee=>({...ee,isCriticalPath:P.includes(ee.id),subtasks:ee.subtasks?I(ee.subtasks):void 0}));return I(se)},[se,d]),St=wh(ie);Gc({undo:X,redo:j,canUndo:Te,canRedo:We,enabled:true}),Se.useImperativeHandle(n,()=>({getTask:P=>q.findTaskById(se,P),addTask:(P,I)=>{ue(V=>{if(!I)return [...V,{...P,level:0}];let ee=oe=>oe.map(ce=>ce.id===I?{...ce,subtasks:[...ce.subtasks||[],{...P,parentId:I,level:(ce.level||0)+1}],isExpanded:true}:ce.subtasks?{...ce,subtasks:ee(ce.subtasks)}:ce);return ee(V)});},updateTask:(P,I)=>{ue(V=>{let ee=oe=>oe.map(ce=>ce.id===P?{...ce,...I}:ce.subtasks?{...ce,subtasks:ee(ce.subtasks)}:ce);return ee(V)});},deleteTask:P=>{ue(I=>{let V=ee=>ee.filter(oe=>oe.id===P?false:(oe.subtasks&&(oe.subtasks=V(oe.subtasks)),true));return V(I)});},deleteTasks:P=>{ue(I=>$n(I,P));},duplicateTask:P=>{ue(I=>ys(I,[P]));},splitTask:(P,I,V=3)=>{ue(ee=>q.splitTask(ee,P,I,V));},calculateEndDate:q.calculateEndDate,calculateDuration:q.calculateDuration,validateDependency:(P,I)=>!q.validateDependencies(se,P,I),getAllTasks:()=>q.flattenTasks(se),getTasksByStatus:P=>q.flattenTasks(se).filter(I=>I.status===P),getTasksByParent:P=>P?q.findTaskById(se,P)?.subtasks||[]:se.filter(V=>!V.parentId),getCriticalPath:()=>q.flattenTasks(se).filter(P=>P.isCriticalPath),indentTask:P=>{ue(I=>hs(I,[P]));},outdentTask:P=>{ue(I=>bs(I,[P]));},moveTask:(P,I)=>{ue(V=>vs(V,[P],I));},createSubtask:async P=>{let{tasks:I,newTask:V}=ws(se,P);if(E){let ee=E({...V,parentId:P});if((ee instanceof Promise?await ee:ee)===false)return}ue(I),O&&O({...V,parentId:P});},scrollToTask:P=>{let V=q.flattenTasks(se).findIndex(ee=>ee.id===P);if(V!==-1&&S.current){let ee=V*St;S.current.scrollTo({top:ee,behavior:"smooth"}),H.current&&H.current.scrollTo({top:ee,behavior:"smooth"});}},highlightTask:(P,I=2e3)=>{},expandTask:P=>{ue(I=>{let V=ee=>ee.map(oe=>oe.id===P?{...oe,isExpanded:true}:oe.subtasks?{...oe,subtasks:V(oe.subtasks)}:oe);return V(I)});},collapseTask:P=>{ue(I=>{let V=ee=>ee.map(oe=>oe.id===P?{...oe,isExpanded:false}:oe.subtasks?{...oe,subtasks:V(oe.subtasks)}:oe);return V(I)});},expandAll:()=>{ue(P=>{let I=V=>V.map(ee=>({...ee,isExpanded:true,subtasks:ee.subtasks?I(ee.subtasks):void 0}));return I(P)});},collapseAll:()=>{ue(P=>{let I=V=>V.map(ee=>({...ee,isExpanded:false,subtasks:ee.subtasks?I(ee.subtasks):void 0}));return I(P)});},undo:X,redo:j,canUndo:()=>Te,canRedo:()=>We,clearHistory:re,exportToPNG:async()=>{if(!me.current)throw new Error("Gantt container not found");let P=await Hc__default.default(me.current,{backgroundColor:ye.bgPrimary,scale:2});return new Promise((I,V)=>{P.toBlob(ee=>{ee?I(ee):V(new Error("Failed to create blob from canvas"));},"image/png");})},exportToPDF:async P=>{await q.exportToPDF(se,P);},exportToExcel:async P=>{await q.exportToExcel(se,P);},exportToJSON:()=>q.exportToJSON(se),exportToCSV:()=>q.exportToCSV(se),importFromJSON:P=>{let I=q.importFromJSON(P);ue(I);},getTasks:()=>se,refresh:()=>{ue(P=>[...P]);},clearAll:()=>{ue([]);}}),[se,X,j,Te,We,re,ye,St]);let go=Se.useCallback(P=>{J(I=>I.map(V=>V.id===P?{...V,visible:!V.visible}:V));},[]),wa=Se.useCallback((P,I)=>{J(V=>V.map(ee=>{if(ee.id!==P)return ee;let oe=ee.minWidth??100,ce=ee.maxWidth??800,nt=Math.max(oe,Math.min(ce,I));return {...ee,width:nt}}));},[]),Ca=Se.useCallback(P=>{ue(I=>ks(I,P)),r.onTaskToggleExpand?.(P);},[r]),aa=Se.useCallback((P,I)=>{if(G&&G(P,I)===false)return;let ee=q.findTaskById(se,P)?.progress,oe=nt=>nt.map(vt=>vt.id===P?{...vt,...I}:vt.subtasks?{...vt,subtasks:oe(vt.subtasks)}:vt);ue(oe(se));let ce=q.findTaskById(oe(se),P);ce&&(D?.(ce),U?.(ce),I.progress!==void 0&&ee!==void 0&&I.progress!==ee&&C?.(P,ee,I.progress));},[se,D,G,U,C]),nu=Se.useCallback(P=>{P.length!==0&&(ue(I=>hs(I,P)),r.onTaskIndent?.(P[0]));},[r]),ou=Se.useCallback(P=>{P.length!==0&&(ue(I=>bs(I,P)),r.onTaskOutdent?.(P[0]));},[r]),su=Se.useCallback((P,I)=>{P.length!==0&&(ue(V=>vs(V,P,I)),r.onTaskMove?.(P[0],I));},[r]),ki=Se.useCallback(P=>{r.onMultiTaskDelete?r.onMultiTaskDelete(P):(ue(I=>$n(I,P)),P.forEach(I=>r.onTaskDelete?.(I)));},[r]),iu=Se.useCallback(P=>{ue(I=>ys(I,P)),P.forEach(I=>r.onTaskDuplicate?.(I));},[r]),lu=Se.useCallback((P,I)=>{ue(V=>{let{tasks:ee,newTask:oe}=kc(V,P,I);return E&&E(oe)===false?V:(r.onTaskCreate?.(oe.parentId,oe.position||0),O?.(oe),ee)});},[r,E,O]),cu=Se.useCallback((P,I)=>{ue(V=>xs(V,P,I)),r.onTaskRename?.(P,I);},[r]),wi=Se.useCallback(P=>{ue(I=>{let{tasks:V}=ws(I,P);return r.onTaskCreate?.(P,0),V});},[r]),du=Se.useCallback((P,I,V)=>{let ee=P.startDate?Math.round((I.getTime()-P.startDate.getTime())/864e5):0,oe=vt=>vt.map(Yt=>Yt.id===P.id?{...Yt,startDate:I,endDate:V,...P.segments&&{segments:P.segments}}:Yt.subtasks?{...Yt,subtasks:oe(Yt.subtasks)}:Yt),ce=oe(se);ce=q.autoScheduleDependents(ce,P.id,ee),ue(ce);let nt={...P,startDate:I,endDate:V};D?.(nt);},[se,D]),uu=Se.useCallback((P,I)=>{x?.(P,I),at({isOpen:true,x:I.clientX,y:I.clientY,task:P});},[x]),mu=Se.useCallback((P,I)=>{let V=q.splitTask(se,P.id,I);ue(V),at({isOpen:false,x:0,y:0,task:null});},[se]),Ci=Se.useCallback(P=>{w?.(P),N||Wt(P);},[w,N]),Ti=Se.useCallback((P,I,V)=>{let ee=new Map,oe=qt=>{qt.forEach(br=>{br.dependencies&&ee.set(br.id,br.dependencies),br.subtasks&&oe(br.subtasks);});};oe(V);let ce=ee.get(I)||[];ee.set(I,[...ce,P]);let nt=new Set,vt=new Set,Yt=qt=>{if(!nt.has(qt)){nt.add(qt),vt.add(qt);let br=ee.get(qt)||[];for(let Ta of br){if(!nt.has(Ta)&&Yt(Ta))return true;if(vt.has(Ta))return true}}return vt.delete(qt),false};return Yt(I)},[]),Di=Se.useCallback((P,I)=>{if(Ti(P.id,I,se)){console.warn("Cannot create dependency: would create a circular dependency"),alert(`Cannot create this dependency: it would create a circular dependency chain.
|
|
276
|
+
</Project>`,p=new Blob([i],{type:"application/xml;charset=utf-8;"}),l=document.createElement("a");l.href=URL.createObjectURL(p),l.download=r,l.click(),URL.revokeObjectURL(l.href);},calculateCriticalPath:e=>{let t=q.flattenTasks(e),r=t.filter(i=>i.startDate&&i.endDate);if(r.length===0)return [];let a=new Map,n=i=>{if(a.has(i.id))return;let p=i.startDate&&i.endDate?q.calculateDuration(i.startDate,i.endDate):0,l=0;if(i.dependencies&&i.dependencies.length>0)for(let m of i.dependencies){let v=t.find(y=>y.id===m);if(v){n(v);let y=a.get(m)?.ef||0;l=Math.max(l,y);}}let d=l+p;a.set(i.id,{es:l,ef:d});};r.forEach(n);let o=Math.max(...Array.from(a.values()).map(i=>i.ef)),s=new Map,c=i=>{if(s.has(i.id))return;let p=i.startDate&&i.endDate?q.calculateDuration(i.startDate,i.endDate):0,l=t.filter(v=>v.dependencies&&v.dependencies.includes(i.id)),d=o;if(l.length>0)for(let v of l){c(v);let y=s.get(v.id)?.ls||0;d=Math.min(d,y);}let m=d-p;s.set(i.id,{ls:m,lf:d});};r.forEach(c);let u=[];for(let i of r){let p=a.get(i.id),l=s.get(i.id);if(p&&l){let d=l.ls-p.es;Math.abs(d)<.01&&u.push(i.id);}}return u},calculateSlack:(e,t)=>{let r=q.findTaskById(e,t);if(!r||!r.startDate||!r.endDate)return null;if(q.calculateCriticalPath(e).includes(t))return 0;let n=q.getDependentTasks(e,t);if(n.length===0){let c=q.getLatestEndDate(e);if(!c)return null;let u=q.calculateDuration(r.endDate,c);return Math.max(0,u)}let o=n.filter(c=>c.startDate).map(c=>c.startDate.getTime()).sort((c,u)=>c-u)[0];if(!o)return null;let s=q.calculateDuration(r.endDate,new Date(o));return Math.max(0,s)},isOnCriticalPath:(e,t)=>q.calculateCriticalPath(e).includes(t),autoScheduleDependents:(e,t,r)=>{let a=q.findTaskById(e,t);if(!a||!a.endDate)return e;let n=q.getDependentTasks(e,t);if(n.length===0)return e;let o=[...e];for(let s of n){if(!s.startDate||!s.endDate)continue;let c=q.calculateDuration(s.startDate,s.endDate),u;r!==void 0?(u=new Date(s.startDate),u.setDate(u.getDate()+r)):(u=new Date(a.endDate),u.setDate(u.getDate()+1));let i=q.calculateEndDate(u,c),p=l=>l.map(d=>d.id===s.id?{...d,startDate:u,endDate:i}:d.subtasks?{...d,subtasks:p(d.subtasks)}:d);o=p(o),o=q.autoScheduleDependents(o,s.id,r);}return o},calculateCascadePreview:(e,t,r,a,n,o,s,c)=>{if(r===0)return [];let u=[],i=n.getTime(),p=1e3*60*60*24,l=q.findTaskById(e,t);if(!l||!l.endDate)return [];let d=(m,v,y=new Set)=>{if(y.has(m))return;y.add(m);let h=q.getDependentTasks(e,m);for(let g of h){if(!g.startDate||!g.endDate)continue;let b=a.findIndex($=>$.id===g.id);if(b===-1)continue;let f=g.startDate.getTime(),w=(g.endDate.getTime()-f)/p,D=(f-i)/p*o,C=D+v*o,N=Math.max(w*o,o),T=c+b*s+12;u.push({taskId:g.id,taskName:g.name,originalX:D,previewX:C,width:N,y:T,rowIndex:b,daysDelta:v,color:g.color}),d(g.id,v,y);}};return d(t,r),u},splitTask:(e,t,r,a=3)=>{let n=q.findTaskById(e,t);if(!n||!n.startDate||!n.endDate)return e;if(r<=n.startDate||r>=n.endDate)return console.warn("Split date must be between task start and end dates"),e;let o=new Date(r);o.setDate(o.getDate()-1);let s=new Date(r);s.setDate(s.getDate()+a);let c=new Date(n.endDate);c.setDate(c.getDate()+a);let u=[{startDate:new Date(n.startDate),endDate:o},{startDate:s,endDate:c}],i=p=>p.map(l=>l.id===n.id?{...l,endDate:c,segments:u}:l.subtasks?{...l,subtasks:i(l.subtasks)}:l);return i(e)}};function Yn({tasks:e,theme:t,rowHeight:r,timeScale:a,startDate:n,endDate:o,zoom:s,templates:c,onTaskClick:u,onTaskDblClick:i,onTaskContextMenu:p,onTaskDateChange:l,onDependencyCreate:d,onDependencyDelete:m}){let[y,h]=Se.useState([]),g=Math.ceil((o.getTime()-n.getTime())/(1e3*60*60*24)),b=a==="day"?60:a==="week"?20:8,f=g*b*s,k=E=>{let O=new Date(Date.UTC(E.getFullYear(),E.getMonth(),E.getDate())),G=O.getUTCDay()||7;O.setUTCDate(O.getUTCDate()+4-G);let U=new Date(Date.UTC(O.getUTCFullYear(),0,1));return Math.ceil(((O.getTime()-U.getTime())/864e5+1)/7)},w=E=>{let O=E.getDay();return O===0||O===6},x=Se.useCallback(E=>{let O=Math.round(E/(b*s)),G=new Date(n);return G.setDate(G.getDate()+O),G},[n,b,s]),D=Se.useCallback((E,O)=>{if(O.startDate&&O.endDate)return;let G=E.currentTarget.ownerSVGElement;if(!G)return;let U=G.createSVGPoint();U.x=E.clientX,U.y=E.clientY;let A=U.matrixTransform(G.getScreenCTM()?.inverse()),K=x(A.x),_=new Date(K);_.setDate(_.getDate()+1),l?.(O,K,_);},[x,l]),C=Se.useMemo(()=>{let E=A=>A.map(K=>{if(K.subtasks&&K.subtasks.length>0){let _=E(K.subtasks),ae=_.filter(M=>M.startDate&&M.endDate);if(ae.length>0){let M=ae.map(rt=>rt.startDate.getTime()),de=ae.map(rt=>rt.endDate.getTime()),ie=new Date(Math.min(...M)),kt=new Date(Math.max(...de));return {...K,subtasks:_,startDate:K.startDate||ie,endDate:K.endDate||kt}}return {...K,subtasks:_}}return K}),O=(A,K=[])=>{for(let _ of A)K.push(_),_.subtasks&&_.subtasks.length>0&&(_.isExpanded===void 0||_.isExpanded)&&O(_.subtasks,K);return K},G=E(e);return O(G)},[e]),N=Se.useCallback(E=>{if(!E.startDate||!E.endDate)return {x:0,width:0};let O=E.startDate.getTime(),G=E.endDate.getTime(),U=n.getTime(),A=(O-U)/(1e3*60*60*24),K=(G-O)/(1e3*60*60*24),_=A*b*s,ae=Math.max(b*s,40),M=Math.max(K*b*s,ae);return {x:_,width:M}},[n,b,s]),T=Se.useMemo(()=>C.filter(E=>E.startDate&&E.endDate).map(E=>{let{x:O,width:G}=N(E),A=C.findIndex(K=>K.id===E.id)*r+12;return {id:E.id,x:O,y:A,width:G,height:32}}),[C,N]),$=Se.useCallback((E,O,G)=>{if(!G||O===0){h([]);return}let U=q.calculateCascadePreview(e,E,O,C,n,b*s,r,48);h(U);},[e,C,n,b,s,r,48]),z=Se.useMemo(()=>{let E=[],O=new Date(n);for(;O<=o;){let A=(O.getTime()-n.getTime())/864e5*b*s;if(a==="day")E.push({date:new Date(O),label:O.toLocaleDateString("en-US",{day:"numeric",month:"short"}),x:A}),O.setDate(O.getDate()+1);else if(a==="week"){let K=k(O);E.push({date:new Date(O),label:`Week ${K}`,x:A}),O.setDate(O.getDate()+7);}else E.push({date:new Date(O),label:O.toLocaleDateString("en-US",{month:"short",year:"numeric"}),x:A}),O.setMonth(O.getMonth()+1);}return E},[n,o,a,b,s]),R=Se.useMemo(()=>(new Date().getTime()-n.getTime())/(1e3*60*60*24)*b*s,[n,b,s]),W=Math.max(C.length*r,552);return jsxRuntime.jsxs("div",{className:"w-full h-full flex flex-col","data-gantt-chart":true,style:{backgroundColor:t.bgPrimary},children:[jsxRuntime.jsx("div",{style:{position:"sticky",top:0,zIndex:10,backgroundColor:t.bgGrid,flexShrink:0,height:"48px",borderBottom:`1px solid ${t.border}`,boxSizing:"border-box"},children:jsxRuntime.jsxs("svg",{width:Math.max(f,1e3),height:47,style:{display:"block"},children:[jsxRuntime.jsx("rect",{x:0,y:0,width:Math.max(f,1e3),height:48,fill:t.bgGrid}),z.map((E,O)=>jsxRuntime.jsxs("g",{children:[O>0&&jsxRuntime.jsx("line",{x1:E.x,y1:0,x2:E.x,y2:48,stroke:t.border,strokeWidth:1,opacity:.1}),jsxRuntime.jsx("text",{x:E.x+8,y:48/2,fill:t.textTertiary,fontSize:"11",fontFamily:"'JetBrains Mono', ui-monospace, monospace",fontWeight:"500",dominantBaseline:"middle",children:E.label})]},`header-${O}`)),R>=0&&R<=f&&jsxRuntime.jsx("circle",{cx:R,cy:38,r:6,fill:t.today,opacity:1})]})}),jsxRuntime.jsxs("svg",{width:Math.max(f,1e3),height:W,style:{display:"block",flexShrink:0},children:[jsxRuntime.jsxs("defs",{children:[jsxRuntime.jsx("filter",{id:"shadow",children:jsxRuntime.jsx("feDropShadow",{dx:"0",dy:"1",stdDeviation:"2",floodOpacity:"0.1"})}),jsxRuntime.jsx("pattern",{id:"diagonal-stripes",width:"8",height:"8",patternUnits:"userSpaceOnUse",patternTransform:"rotate(45)",children:jsxRuntime.jsx("line",{x1:"0",y1:"0",x2:"0",y2:"8",stroke:t.border,strokeWidth:"2"})})]}),jsxRuntime.jsx("rect",{x:0,y:0,width:Math.max(f,1e3),height:W,fill:t.bgPrimary}),z.map((E,O)=>{let G=z[O+1]?.x||f,U=w(E.date);return jsxRuntime.jsxs("g",{children:[U&&jsxRuntime.jsx("rect",{x:E.x,y:0,width:G-E.x,height:C.length*r,fill:t.bgWeekend,opacity:1}),O>0&&jsxRuntime.jsx("line",{x1:E.x,y1:0,x2:E.x,y2:C.length*r,stroke:t.border,strokeWidth:1,opacity:.1})]},O)}),R>=0&&R<=f&&jsxRuntime.jsx("line",{x1:R,y1:0,x2:R,y2:C.length*r,stroke:t.today,strokeWidth:2,opacity:1}),C.map((E,O)=>{let G=E.startDate&&E.endDate;return jsxRuntime.jsxs("g",{children:[jsxRuntime.jsx("rect",{x:0,y:O*r,width:f,height:r,fill:O%2===0?"transparent":t.bgSecondary,opacity:1,style:{pointerEvents:"none"}},`row-${E.id}`),!G&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:0,y:O*r,width:f,height:r,fill:"transparent",style:{cursor:"pointer",pointerEvents:"all"},onClick:U=>D(U,E),onMouseEnter:U=>{U.currentTarget.setAttribute("fill",t.accentLight),U.currentTarget.setAttribute("opacity","0.5");},onMouseLeave:U=>{U.currentTarget.setAttribute("fill","transparent"),U.currentTarget.setAttribute("opacity","1");}},`clickable-${E.id}`),jsxRuntime.jsx("text",{x:R>0?R:100,y:O*r+r/2,fill:t.textTertiary,fontSize:"12",fontFamily:"Inter, sans-serif",fontStyle:"italic",dominantBaseline:"middle",opacity:.4,style:{pointerEvents:"none",userSelect:"none"},children:"Click to set dates..."},`placeholder-${E.id}`)]})]},`row-group-${E.id}`)}),C.map((E,O)=>!E.dependencies||E.dependencies.length===0||!E.startDate||!E.endDate?null:E.dependencies.map(G=>{let U=C.find(ae=>ae.id===G);if(!U||!U.startDate||!U.endDate)return null;let A=C.findIndex(ae=>ae.id===G),K=N(U),_=N(E);return jsxRuntime.jsx(_n,{x1:K.x+K.width,y1:A*r+r/2,x2:_.x,y2:O*r+r/2,theme:t,onDelete:()=>m?.(E.id,G)},`dep-${G}-${E.id}`)})),C.map((E,O)=>{if(!E.startDate||!E.endDate)return null;let{x:G,width:U}=N(E),A=O*r+12,K=E.subtasks&&E.subtasks.length>0&&!E.isMilestone;return E.isMilestone?jsxRuntime.jsx(Vn,{task:E,x:G+U/2,y:A+16,theme:t,onClick:u},E.id):K?jsxRuntime.jsxs("g",{onClick:()=>u?.(E),style:{cursor:"pointer"},children:[jsxRuntime.jsx("rect",{x:G,y:A,width:U,height:32,fill:t.primary,opacity:.25,rx:6}),jsxRuntime.jsx("line",{x1:G,y1:A,x2:G+U,y2:A,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:G,y1:A,x2:G,y2:A+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:G+U,y1:A,x2:G+U,y2:A+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:G,y1:A+32,x2:G+U,y2:A+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),U>60&&jsxRuntime.jsx("text",{x:G+12,y:A+16,dominantBaseline:"middle",fill:"#FFFFFF",fontSize:"13",fontWeight:"500",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:E.name})]},E.id):jsxRuntime.jsx(Un,{task:E,x:G,y:A,width:U,theme:t,dayWidth:b*s,startDate:n,templates:c,onClick:u,onDoubleClick:i,onContextMenu:p,onDateChange:l,onDependencyCreate:d,allTaskPositions:T,onDragMove:$},E.id)}),y.map(E=>jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[jsxRuntime.jsx("rect",{x:E.previewX,y:E.y-48,width:E.width,height:32,rx:8,fill:E.color||t.accent,opacity:.3,stroke:t.accent,strokeWidth:2,strokeDasharray:"4 2"}),Math.abs(E.daysDelta)>0&&jsxRuntime.jsx("text",{x:E.previewX+E.width/2,y:E.y-48+16,textAnchor:"middle",dominantBaseline:"middle",fill:t.accent,fontSize:"10",fontWeight:"600",fontFamily:"Inter, sans-serif",style:{userSelect:"none"},children:E.daysDelta>0?`+${E.daysDelta}d`:`${E.daysDelta}d`})]},`cascade-preview-${E.taskId}`))]})]})}var Ic=[{name:"Azul",value:"#6366F1",light:"#818CF8"},{name:"P\xFArpura",value:"#A855F7",light:"#C084FC"},{name:"Rosa",value:"#EC4899",light:"#F472B6"},{name:"Rojo",value:"#EF4444",light:"#F87171"},{name:"Naranja",value:"#F59E0B",light:"#FBBF24"},{name:"Amarillo",value:"#EAB308",light:"#FACC15"},{name:"Lima",value:"#84CC16",light:"#A3E635"},{name:"Verde",value:"#10B981",light:"#34D399"},{name:"Esmeralda",value:"#059669",light:"#10B981"},{name:"Cyan",value:"#06B6D4",light:"#22D3EE"},{name:"Azul Cielo",value:"#0EA5E9",light:"#38BDF8"},{name:"\xCDndigo",value:"#4F46E5",light:"#6366F1"},{name:"Violeta",value:"#8B5CF6",light:"#A78BFA"},{name:"Fucsia",value:"#D946EF",light:"#E879F9"},{name:"Gris",value:"#6B7280",light:"#9CA3AF"},{name:"Piedra",value:"#78716C",light:"#A8A29E"}];function Ac({value:e="#6366F1",onChange:t,disabled:r=false}){return jsxRuntime.jsxs("div",{className:"space-y-2",children:[jsxRuntime.jsx("div",{className:"flex flex-wrap gap-2",children:Ic.map(a=>{let n=e===a.value;return jsxRuntime.jsx(framerMotion.motion.button,{type:"button",onClick:()=>!r&&t(a.value),className:"relative rounded-full transition-all focus:outline-none focus:ring-2 focus:ring-offset-2",style:{width:"32px",height:"32px",backgroundColor:a.value,boxShadow:n?`0 0 0 2px #FFFFFF, 0 0 0 4px ${a.value}`:"0 1px 3px rgba(0, 0, 0, 0.12)",opacity:r?.5:1,cursor:r?"not-allowed":"pointer"},whileHover:r?{}:{scale:1.1},whileTap:r?{}:{scale:.95},title:a.name,disabled:r,children:n&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{scale:0},animate:{scale:1},className:"absolute inset-0 flex items-center justify-center",children:jsxRuntime.jsx(lucideReact.Check,{className:"w-4 h-4 text-white drop-shadow-md",strokeWidth:3})})},a.value)})}),e&&jsxRuntime.jsx("div",{className:"text-xs text-center font-medium",style:{color:e},children:Ic.find(a=>a.value===e)?.name||"Personalizado"})]})}function qn({isOpen:e,onClose:t,task:r,availableTasks:a=[],availableUsers:n=[],onSubmit:o,isLoading:s=false,mode:c=r?"edit":"create",theme:u="dark"}){let i=Ce[u]||Ce.dark,p={backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`,color:i.textPrimary},l={color:i.textSecondary},[d,m]=Se.useState({name:"",progress:0,status:"todo",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[]}),[v,y]=Se.useState({});Se.useEffect(()=>{m(r?{name:r.name,startDate:r.startDate,endDate:r.endDate,progress:r.progress,status:r.status||"todo",isMilestone:r.isMilestone||false,color:r.color||"#6366F1",assignees:r.assignees||[],dependencies:r.dependencies||[]}:{name:"",progress:0,status:"todo",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[]});},[r,e]);let h=()=>{let f={};return d.name.trim()||(f.name="El nombre es requerido"),d.startDate&&d.endDate&&d.startDate>d.endDate&&(f.endDate="La fecha de fin debe ser posterior a la de inicio"),y(f),Object.keys(f).length===0},g=async f=>{if(f.preventDefault(),!!h())try{await o(d),t();}catch(k){console.error("Error submitting task:",k);}},b=(f,k)=>{m(w=>{let x={...w,[f]:k};if(f==="progress"){let D=typeof k=="number"?k:parseInt(k,10);D===100&&w.status!=="completed"?x.status="completed":D>0&&D<100&&w.status==="todo"?x.status="in-progress":D===0&&w.status==="in-progress"&&(x.status="todo");}return x}),v[f]&&y(w=>{let x={...w};return delete x[f],x});};return jsxRuntime.jsx(framerMotion.AnimatePresence,{children:e&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},className:"fixed inset-0 bg-black/50 z-50",onClick:t}),jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,scale:.95,y:20},animate:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:20},transition:{duration:.2,ease:[.4,0,.2,1]},className:"fixed inset-0 z-50 flex items-center justify-center p-4 pointer-events-none",children:jsxRuntime.jsxs("div",{className:"w-full max-w-2xl rounded-xl shadow-2xl pointer-events-auto overflow-hidden",style:{backgroundColor:i.bgPrimary,border:`1px solid ${i.border}`},onClick:f=>f.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-6 py-4",style:{borderBottom:`1px solid ${i.border}`},children:[jsxRuntime.jsx("h2",{className:"text-lg font-semibold",style:{color:i.textPrimary},children:c==="create"?"Crear Nueva Tarea":"Editar Tarea"}),jsxRuntime.jsx("button",{onClick:t,className:"p-2 rounded-lg transition-colors",style:{color:i.textSecondary},onMouseEnter:f=>f.currentTarget.style.backgroundColor=i.hoverBg,onMouseLeave:f=>f.currentTarget.style.backgroundColor="transparent",disabled:s,children:jsxRuntime.jsx(lucideReact.X,{className:"w-5 h-5"})})]}),jsxRuntime.jsxs("form",{onSubmit:g,className:"p-6 space-y-6 max-h-[calc(100vh-200px)] overflow-y-auto",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{className:"block text-sm font-medium mb-2",style:l,children:"Nombre de la Tarea *"}),jsxRuntime.jsx("input",{type:"text",value:d.name,onChange:f=>b("name",f.target.value),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,onFocus:f=>f.currentTarget.style.borderColor=i.accent,onBlur:f=>f.currentTarget.style.borderColor=i.borderLight,placeholder:"Ej: Dise\xF1ar mockups de la aplicaci\xF3n",disabled:s}),v.name&&jsxRuntime.jsxs("p",{className:"mt-1 text-sm text-red-400 flex items-center gap-1",children:[jsxRuntime.jsx(lucideReact.AlertCircle,{className:"w-4 h-4"}),v.name]})]}),jsxRuntime.jsxs("div",{className:"grid grid-cols-2 gap-4",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"w-4 h-4"}),"Fecha de Inicio"]}),jsxRuntime.jsx("input",{type:"date",value:d.startDate?d.startDate.toISOString().split("T")[0]:"",onChange:f=>b("startDate",f.target.value?new Date(f.target.value):void 0),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,disabled:s||d.isMilestone})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"w-4 h-4"}),"Fecha de Fin"]}),jsxRuntime.jsx("input",{type:"date",value:d.endDate?d.endDate.toISOString().split("T")[0]:"",onChange:f=>b("endDate",f.target.value?new Date(f.target.value):void 0),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,disabled:s||d.isMilestone}),v.endDate&&jsxRuntime.jsxs("p",{className:"mt-1 text-sm text-red-400 flex items-center gap-1",children:[jsxRuntime.jsx(lucideReact.AlertCircle,{className:"w-4 h-4"}),v.endDate]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.CheckCircle2,{className:"w-4 h-4"}),"Estado"]}),jsxRuntime.jsxs("select",{value:d.status,onChange:f=>b("status",f.target.value),className:"w-full px-4 py-2.5 rounded-lg focus:outline-none focus:ring-2 focus:border-transparent",style:p,disabled:s,children:[jsxRuntime.jsx("option",{value:"todo",children:"Por Hacer"}),jsxRuntime.jsx("option",{value:"in-progress",children:"En Progreso"}),jsxRuntime.jsx("option",{value:"completed",children:"Completada"})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-3 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Palette,{className:"w-4 h-4"}),"Color de la Tarea"]}),jsxRuntime.jsx(Ac,{value:d.color,onChange:f=>b("color",f),disabled:s}),jsxRuntime.jsx("p",{className:"text-xs mt-2",style:{color:i.textTertiary},children:r?.parentId?"Esta subtarea hereda el color de su tarea padre":r?.subtasks&&r.subtasks.length>0?"Las subtareas heredar\xE1n este color con menor opacidad":"Elige un color para organizar visualmente tus tareas"})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center justify-between",style:l,children:[jsxRuntime.jsxs("span",{className:"flex items-center gap-2",children:[jsxRuntime.jsx(lucideReact.Clock,{className:"w-4 h-4"}),"Progreso"]}),jsxRuntime.jsxs("span",{className:"font-semibold px-2 py-0.5 rounded text-sm",style:{color:d.progress<30?"#EF4444":d.progress<70?"#F59E0B":"#10B981",backgroundColor:d.progress<30?"rgba(239, 68, 68, 0.1)":d.progress<70?"rgba(245, 158, 11, 0.1)":"rgba(16, 185, 129, 0.1)"},children:[d.progress,"%"]})]}),jsxRuntime.jsxs("div",{className:"relative",children:[jsxRuntime.jsx("input",{type:"range",min:"0",max:"100",step:"5",value:d.progress,onChange:f=>b("progress",parseInt(f.target.value)),className:"w-full h-2 rounded-lg appearance-none cursor-pointer",style:{backgroundColor:i.bgSecondary,accentColor:d.progress<30?"#EF4444":d.progress<70?"#F59E0B":"#10B981"},disabled:s}),jsxRuntime.jsx("div",{className:"absolute top-0 left-0 h-2 rounded-lg pointer-events-none transition-all duration-300",style:{width:`${d.progress}%`,backgroundColor:d.progress<30?"rgba(239, 68, 68, 0.3)":d.progress<70?"rgba(245, 158, 11, 0.3)":"rgba(16, 185, 129, 0.3)"}})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-between mt-3 gap-2",children:[jsxRuntime.jsx("span",{className:"text-xs",style:{color:i.textTertiary},children:"Accesos r\xE1pidos:"}),jsxRuntime.jsx("div",{className:"flex gap-1.5",children:[0,25,50,75,100].map(f=>jsxRuntime.jsxs("button",{type:"button",onClick:()=>b("progress",f),disabled:s,className:"px-3 py-1 text-xs font-medium rounded-md transition-all duration-200 hover:scale-105 active:scale-95",style:{backgroundColor:d.progress===f?f<30?"#EF4444":f<70?"#F59E0B":"#10B981":i.bgSecondary,color:d.progress===f?"#FFFFFF":i.textSecondary,border:`1px solid ${d.progress===f?f<30?"#EF4444":f<70?"#F59E0B":"#10B981":i.borderLight}`},children:[f,"%"]},f))})]}),jsxRuntime.jsxs("div",{className:"flex justify-between text-xs mt-2",style:{color:i.textTertiary},children:[jsxRuntime.jsx("span",{children:"0%"}),jsxRuntime.jsx("span",{children:"25%"}),jsxRuntime.jsx("span",{children:"50%"}),jsxRuntime.jsx("span",{children:"75%"}),jsxRuntime.jsx("span",{children:"100%"})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3 p-4 rounded-lg",style:{backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`},children:[jsxRuntime.jsx("input",{type:"checkbox",id:"isMilestone",checked:d.isMilestone,onChange:f=>b("isMilestone",f.target.checked),className:"w-4 h-4 rounded focus:ring-2",style:{accentColor:i.accent},disabled:s}),jsxRuntime.jsxs("label",{htmlFor:"isMilestone",className:"flex items-center gap-2 text-sm cursor-pointer",style:{color:i.textPrimary},children:[jsxRuntime.jsx(lucideReact.Milestone,{className:"w-4 h-4 text-yellow-500"}),"Marcar como Hito (Milestone)"]})]}),n.length>0&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Users,{className:"w-4 h-4"}),"Asignar a"]}),jsxRuntime.jsx("div",{className:"space-y-2 max-h-32 overflow-y-auto p-3 rounded-lg",style:{backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`},children:n.map(f=>jsxRuntime.jsxs("label",{className:"flex items-center gap-3 cursor-pointer p-2 rounded",onMouseEnter:k=>k.currentTarget.style.backgroundColor=i.hoverBg,onMouseLeave:k=>k.currentTarget.style.backgroundColor="transparent",children:[jsxRuntime.jsx("input",{type:"checkbox",checked:d.assignees?.some(k=>k.name===f.name),onChange:k=>{let w=k.target.checked?[...d.assignees||[],{name:f.name,avatar:f.avatar,initials:f.name.split(" ").map(x=>x[0]).join("").toUpperCase().slice(0,2),color:i.accent}]:(d.assignees||[]).filter(x=>x.name!==f.name);b("assignees",w);},className:"w-4 h-4 rounded",style:{accentColor:i.accent},disabled:s}),jsxRuntime.jsxs("div",{className:"flex items-center gap-2",children:[jsxRuntime.jsx("div",{className:"w-6 h-6 rounded-full flex items-center justify-center text-xs text-white font-semibold",style:{backgroundColor:i.accent},children:f.name.charAt(0).toUpperCase()}),jsxRuntime.jsx("span",{className:"text-sm",style:{color:i.textPrimary},children:f.name})]})]},f.id))})]}),a.length>0&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"block text-sm font-medium mb-2 flex items-center gap-2",style:l,children:[jsxRuntime.jsx(lucideReact.Link2,{className:"w-4 h-4"}),"Dependencias"]}),jsxRuntime.jsx("div",{className:"space-y-2 max-h-32 overflow-y-auto p-3 rounded-lg",style:{backgroundColor:i.bgSecondary,border:`1px solid ${i.borderLight}`},children:a.filter(f=>f.id!==r?.id).map(f=>jsxRuntime.jsxs("label",{className:"flex items-center gap-3 cursor-pointer p-2 rounded",onMouseEnter:k=>k.currentTarget.style.backgroundColor=i.hoverBg,onMouseLeave:k=>k.currentTarget.style.backgroundColor="transparent",children:[jsxRuntime.jsx("input",{type:"checkbox",checked:d.dependencies?.includes(f.id),onChange:k=>{let w=k.target.checked?[...d.dependencies||[],f.id]:(d.dependencies||[]).filter(x=>x!==f.id);b("dependencies",w);},className:"w-4 h-4 rounded",style:{accentColor:i.accent},disabled:s}),jsxRuntime.jsx("span",{className:"text-sm",style:{color:i.textPrimary},children:f.name})]},f.id))})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-end gap-3 px-6 py-4",style:{borderTop:`1px solid ${i.border}`,backgroundColor:i.bgPrimary},children:[jsxRuntime.jsx("button",{type:"button",onClick:t,className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors",style:{color:i.textSecondary},onMouseEnter:f=>{f.currentTarget.style.color=i.textPrimary,f.currentTarget.style.backgroundColor=i.hoverBg;},onMouseLeave:f=>{f.currentTarget.style.color=i.textSecondary,f.currentTarget.style.backgroundColor="transparent";},disabled:s,children:"Cancelar"}),jsxRuntime.jsx("button",{onClick:g,disabled:s,className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors disabled:opacity-50 disabled:cursor-not-allowed flex items-center gap-2",style:{backgroundColor:i.accent,color:"#FFFFFF"},onMouseEnter:f=>!s&&(f.currentTarget.style.backgroundColor=i.accentHover),onMouseLeave:f=>!s&&(f.currentTarget.style.backgroundColor=i.accent),children:s?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"w-4 h-4 border-2 border-white/30 border-t-white rounded-full animate-spin"}),"Guardando..."]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(lucideReact.CheckCircle2,{className:"w-4 h-4"}),c==="create"?"Crear Tarea":"Guardar Cambios"]})})]})]})})]})})}var dh=['Move "Task Name" to next Monday','Extend "Task Name" by 3 days','Rename "Old Name" to "New Name"','Set "Task Name" progress to 50%','Link "Task A" to "Task B"','Create a new task called "New Task"','Delete "Task Name"','Assign John to "Task Name"'],Wc=()=>jsxRuntime.jsxs("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:[jsxRuntime.jsx("path",{d:"M12 3v1m0 16v1m9-9h-1M4 12H3m15.364 6.364l-.707-.707M6.343 6.343l-.707-.707m12.728 0l-.707.707M6.343 17.657l-.707.707"}),jsxRuntime.jsx("circle",{cx:"12",cy:"12",r:"4"})]}),uh=()=>jsxRuntime.jsx("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M22 2L11 13M22 2L15 22L11 13M22 2L2 9L11 13"})}),mh=()=>jsxRuntime.jsx("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M18 6L6 18M6 6L18 18"})}),ph=()=>jsxRuntime.jsx("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:jsxRuntime.jsx("path",{d:"M5 12h14"})}),fh=()=>jsxRuntime.jsx("div",{className:"flex gap-1 items-center",children:[0,1,2].map(e=>jsxRuntime.jsx(framerMotion.motion.div,{className:"w-2 h-2 rounded-full bg-current",animate:{scale:[1,1.2,1],opacity:[.5,1,.5]},transition:{duration:.8,repeat:1/0,delay:e*.15}},e))});function Xn({tasks:e,theme:t,config:r,onTasksUpdate:a,onTaskUpdate:n,onTaskCreate:o,onTaskDelete:s,onDependencyCreate:c,onDependencyDelete:u}){let[i,p]=Se.useState(false),[l,d]=Se.useState(false),[m,v]=Se.useState([]),[y,h]=Se.useState(""),[g,b]=Se.useState(false),[f,k]=Se.useState(true),w=Se.useRef(null),x=Se.useRef(null),D=Se.useRef(null),{enabled:C=true,placeholder:N='Ask AI to edit tasks... (e.g., "Move Design to next week")',position:T="bottom-right",onCommand:$,suggestions:z=dh,maxHistory:R=50}=r;Se.useEffect(()=>{x.current&&x.current.scrollIntoView({behavior:"smooth"});},[m]),Se.useEffect(()=>{i&&!l&&w.current&&setTimeout(()=>w.current?.focus(),100);},[i,l]);let W=Se.useCallback(A=>{if(A.success)switch(A.type){case "move_task":case "resize_task":case "rename_task":case "set_progress":case "set_status":case "assign_task":A.taskId&&A.updates&&n?.(A.taskId,A.updates);break;case "create_task":A.newTask&&o?.(A.newTask);break;case "delete_task":A.taskId&&s?.(A.taskId);break;case "link_tasks":A.dependencyFrom&&A.dependencyTo&&c?.(A.dependencyFrom,A.dependencyTo);break;case "unlink_tasks":A.taskId&&A.dependencyFrom&&u?.(A.taskId,A.dependencyFrom);break}},[n,o,s,c,u]),E=Se.useCallback(async A=>{if(!A.trim()||g)return;let K={id:`user-${Date.now()}`,role:"user",content:A,timestamp:new Date};v(ae=>[...ae.slice(-(R-1)),K]),h(""),k(false),b(true);let _={id:`loading-${Date.now()}`,role:"assistant",content:"",timestamp:new Date,isLoading:true};v(ae=>[...ae,_]);try{if($){let ae=await $(A,e);v(M=>{let de=M.filter(kt=>!kt.isLoading),ie={id:`assistant-${Date.now()}`,role:"assistant",content:ae.message,timestamp:new Date,command:ae};return [...de,ie]}),W(ae);}else v(ae=>[...ae.filter(de=>!de.isLoading),{id:`assistant-${Date.now()}`,role:"assistant",content:"AI handler not configured. Please provide an onCommand handler in the aiAssistant config.",timestamp:new Date}]);}catch(ae){v(M=>[...M.filter(ie=>!ie.isLoading),{id:`error-${Date.now()}`,role:"assistant",content:`Sorry, I encountered an error: ${ae instanceof Error?ae.message:"Unknown error"}`,timestamp:new Date}]);}finally{b(false);}},[g,R,$,e,W]),O=A=>{A.preventDefault(),E(y);},G=A=>{h(A),w.current?.focus();};if(Se.useEffect(()=>{let A=K=>{(K.metaKey||K.ctrlKey)&&K.key==="k"&&(K.preventDefault(),p(_=>!_),i||d(false)),K.key==="Escape"&&i&&p(false);};return document.addEventListener("keydown",A),()=>document.removeEventListener("keydown",A)},[i]),!C)return null;let U={"bottom-right":"bottom-4 right-4","bottom-left":"bottom-4 left-4","top-right":"top-4 right-4","top-left":"top-4 left-4"};return jsxRuntime.jsxs(Ye,{children:[jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!i&&jsxRuntime.jsxs(framerMotion.motion.button,{initial:{scale:0,opacity:0},animate:{scale:1,opacity:1},exit:{scale:0,opacity:0},whileHover:{scale:1.05},whileTap:{scale:.95},className:`fixed ${U[T]} z-[99999] flex items-center gap-2 px-4 py-3 rounded-full shadow-lg transition-colors`,style:{background:"linear-gradient(135deg, #3B82F6 0%, #2563EB 100%)",color:"white",boxShadow:"0 4px 20px rgba(59, 130, 246, 0.4)"},onClick:()=>p(true),children:[jsxRuntime.jsx(Wc,{}),jsxRuntime.jsx("span",{className:"text-sm font-medium",children:"AI Assistant"}),jsxRuntime.jsx("kbd",{className:"hidden sm:inline-flex items-center gap-0.5 px-1.5 py-0.5 text-[10px] font-mono rounded bg-white/20",children:"\u2318K"})]})}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:i&&jsxRuntime.jsxs(framerMotion.motion.div,{ref:D,initial:{opacity:0,y:20,scale:.95},animate:{opacity:1,y:0,scale:1,height:l?"auto":500},exit:{opacity:0,y:20,scale:.95},transition:{type:"spring",damping:25,stiffness:300},className:`fixed ${U[T]} z-[99999] w-96 rounded-2xl overflow-hidden shadow-2xl flex flex-col`,style:{background:t.bgPrimary,border:`1px solid ${t.border}`,boxShadow:`0 20px 60px rgba(0, 0, 0, 0.3), 0 0 0 1px ${t.border}`},children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-4 py-3",style:{background:"linear-gradient(135deg, #3B82F6 0%, #2563EB 100%)"},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 text-white",children:[jsxRuntime.jsx(Wc,{}),jsxRuntime.jsx("span",{className:"font-semibold",children:"Gantt AI Assistant"})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("button",{onClick:()=>d(A=>!A),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(ph,{})}),jsxRuntime.jsx("button",{onClick:()=>p(false),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(mh,{})})]})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!l&&jsxRuntime.jsxs(framerMotion.motion.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},className:"flex flex-col flex-1 min-h-0",children:[jsxRuntime.jsxs("div",{className:"flex-1 overflow-y-auto p-4 space-y-4",style:{maxHeight:350},children:[m.length===0&&f&&jsxRuntime.jsxs("div",{className:"space-y-3",children:[jsxRuntime.jsx("p",{className:"text-sm text-center",style:{color:t.textSecondary},children:"Try asking me to edit your Gantt chart:"}),jsxRuntime.jsx("div",{className:"flex flex-wrap gap-2",children:z.slice(0,4).map((A,K)=>jsxRuntime.jsx("button",{onClick:()=>G(A),className:"text-xs px-3 py-1.5 rounded-full transition-colors",style:{background:t.bgSecondary,color:t.textSecondary,border:`1px solid ${t.border}`},children:A.length>30?A.slice(0,30)+"...":A},K))})]}),m.map(A=>jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},className:`flex ${A.role==="user"?"justify-end":"justify-start"}`,children:jsxRuntime.jsxs("div",{className:`max-w-[85%] rounded-2xl px-4 py-2.5 ${A.role==="user"?"rounded-br-md":"rounded-bl-md"}`,style:{background:A.role==="user"?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":t.bgSecondary,color:A.role==="user"?"white":t.textPrimary},children:[A.isLoading?jsxRuntime.jsx(fh,{}):jsxRuntime.jsx("p",{className:"text-sm whitespace-pre-wrap",children:A.content}),A.command&&jsxRuntime.jsxs("div",{className:"mt-2 text-xs px-2 py-1 rounded-md inline-flex items-center gap-1",style:{background:A.command.success?"rgba(16, 185, 129, 0.2)":"rgba(239, 68, 68, 0.2)",color:A.command.success?"#10B981":"#EF4444"},children:[A.command.success?"\u2713":"\u2717",jsxRuntime.jsx("span",{className:"capitalize",children:A.command.type.replace(/_/g," ")})]})]})},A.id)),jsxRuntime.jsx("div",{ref:x})]}),jsxRuntime.jsxs("form",{onSubmit:O,className:"p-3 border-t",style:{borderColor:t.border},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 rounded-xl px-4 py-2",style:{background:t.bgSecondary,border:`1px solid ${t.border}`},children:[jsxRuntime.jsx("input",{ref:w,type:"text",value:y,onChange:A=>h(A.target.value),placeholder:N,disabled:g,className:"flex-1 bg-transparent text-sm outline-none",style:{color:t.textPrimary}}),jsxRuntime.jsx("button",{type:"submit",disabled:!y.trim()||g,className:"p-2 rounded-lg transition-all disabled:opacity-50",style:{background:y.trim()?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":"transparent",color:y.trim()?"white":t.textSecondary},children:jsxRuntime.jsx(uh,{})})]}),jsxRuntime.jsx("p",{className:"text-[10px] text-center mt-2",style:{color:t.textTertiary},children:"Press Enter to send \u2022 Esc to close"})]})]})})]})})]})}function Uc(e,t=50){let[r,a]=Se.useState({past:[],present:e,future:[]}),n=Se.useRef(false),o=Se.useCallback((i,p=true)=>{a(l=>{let d=typeof i=="function"?i(l.present):i;if(n.current)return {...l,present:d};if(!p)return {...l,present:d};let m=[...l.past,l.present];return m.length>t&&m.shift(),{past:m,present:d,future:[]}});},[t]),s=Se.useCallback(()=>{a(i=>{if(i.past.length===0)return i;let p=i.past[i.past.length-1],l=i.past.slice(0,i.past.length-1);return n.current=true,setTimeout(()=>{n.current=false;},0),{past:l,present:p,future:[i.present,...i.future]}});},[]),c=Se.useCallback(()=>{a(i=>{if(i.future.length===0)return i;let p=i.future[0],l=i.future.slice(1);return n.current=true,setTimeout(()=>{n.current=false;},0),{past:[...i.past,i.present],present:p,future:l}});},[]),u=Se.useCallback(()=>{a(i=>({past:[],present:i.present,future:[]}));},[]);return {state:r.present,setState:o,undo:s,redo:c,canUndo:r.past.length>0,canRedo:r.future.length>0,clearHistory:u}}function Gc({undo:e,redo:t,canUndo:r,canRedo:a,enabled:n=true}){Se.useEffect(()=>{if(!n)return;let o=s=>{let c=navigator.platform.toUpperCase().indexOf("MAC")>=0,u=c?s.metaKey:s.ctrlKey;if(u&&s.key==="z"&&!s.shiftKey&&r){s.preventDefault(),e();return}if(a){if(!c&&u&&s.key==="y"){s.preventDefault(),t();return}if(c&&u&&s.shiftKey&&s.key==="z"){s.preventDefault(),t();return}}};return window.addEventListener("keydown",o),()=>{window.removeEventListener("keydown",o);}},[e,t,r,a,n]);}var vh={taskTooltip:e=>{let t=[`<strong>${e.name}</strong>`];if(e.startDate&&e.endDate){t.push(`${q.formatDate(e.startDate)} - ${q.formatDate(e.endDate)}`);let r=q.calculateDuration(e.startDate,e.endDate);t.push(`Duration: ${r} days`);}if(e.progress!==void 0&&t.push(`Progress: ${e.progress}%`),e.status&&t.push(`Status: ${e.status}`),e.assignees&&e.assignees.length>0){let r=e.assignees.map(a=>a.name).join(", ");t.push(`Assigned: ${r}`);}return e.dependencies&&e.dependencies.length>0&&t.push(`Dependencies: ${e.dependencies.length}`),t.join("<br/>")},taskLabel:e=>e.name,gridCell:(e,t,r)=>r,taskClass:e=>{let t=[];return e.isCriticalPath&&t.push("critical-path"),e.status==="completed"?t.push("completed"):e.status==="in-progress"?t.push("in-progress"):e.status==="todo"&&t.push("todo"),e.isMilestone&&t.push("milestone"),t.join(" ")},milestoneContent:e=>`\u25C6 ${e.name}`,dateFormat:e=>q.formatDate(e),durationFormat:e=>e===1?"1 day":`${e} days`,progressFormat:e=>`${e}%`};function _c(e){return {...vh,...e}}var wh=e=>{switch(e){case "compact":return 40;case "comfortable":return 48;case "spacious":return 56;default:return 48}},jc=Se.forwardRef(function({tasks:t,config:r={},onTasksChange:a},n){let{theme:o,timeScale:s="week",rowDensity:c="comfortable",showThemeSelector:u=true,showExportButton:i=true,availableUsers:p=[],templates:l,enableAutoCriticalPath:d=true,aiAssistant:m,locale:v="en",customTranslations:y,showCreateTaskButton:h=false,createTaskLabel:g,onCreateTask:b,onThemeChange:f,onTaskClick:k,onTaskDblClick:w,onTaskContextMenu:x,onTaskUpdate:D,onProgressChange:C,onTaskEdit:N,onTaskAddSubtask:T,onTaskMarkIncomplete:$,onTaskSetInProgress:z,onDependencyCreate:R,onDependencyDelete:W,onBeforeTaskAdd:E,onAfterTaskAdd:O,onBeforeTaskUpdate:G,onAfterTaskUpdate:U}=r,K=Se.useContext(Fn)?.theme,[_,ae]=Se.useState(K||o||"dark"),[M,de]=Se.useState(s),[ie,kt]=Se.useState(c),[rt,ir]=Se.useState(1),[De,bt]=Se.useState(0),[wt,jt]=Se.useState(false),[hr,zr]=Se.useState(null),[he,at]=Se.useState({isOpen:false,x:0,y:0,task:null}),[Kt,Wt]=Se.useState(null);Se.useEffect(()=>{K&&K!==_&&ae(K);},[K]),Se.useEffect(()=>{o&&o!==_&&ae(o);},[o]);let $r=Se.useCallback(P=>{ae(P),f?.(P);},[f]),{state:se,setState:ue,undo:X,redo:j,canUndo:Te,canRedo:We,clearHistory:re}=Uc(t,50);Se.useEffect(()=>{ue(t);},[t,ue]),Se.useEffect(()=>{a&&a(se);},[se,a]);let le=Se.useMemo(()=>ms(v,y),[v,y]),lr=Se.useCallback(P=>[{id:"name",label:P.columns.taskName,width:400,minWidth:200,maxWidth:2e3,visible:true,sortable:true,resizable:false},{id:"startDate",label:P.columns.startDate,width:110,visible:false,sortable:true},{id:"endDate",label:P.columns.endDate,width:110,visible:false,sortable:true},{id:"duration",label:P.columns.duration,width:80,visible:false,sortable:true},{id:"assignees",label:P.columns.assignees,width:120,visible:false,sortable:false},{id:"status",label:P.columns.status,width:80,visible:false,sortable:true},{id:"progress",label:P.columns.progress,width:120,visible:false,sortable:true}],[]),[Ut,J]=Se.useState(()=>lr(le));Se.useEffect(()=>{J(P=>P.map(I=>({...I,label:le.columns[I.id==="name"?"taskName":I.id]||I.label})));},[le]);let Y=Se.useMemo(()=>Ut.filter(P=>P.visible).reduce((P,I)=>P+I.width,0)+60,[Ut]),ve=hr||Y,S=Se.useRef(null),H=Se.useRef(null),me=Se.useRef(null),ye=Se.useMemo(()=>nc(_),[_]),Be=Se.useMemo(()=>({theme:ye,themeName:_}),[ye,_]),Ue=Se.useMemo(()=>_c(l),[l]),Mt=Se.useMemo(()=>{if(!d)return se;let P=q.calculateCriticalPath(se),I=V=>V.map(ee=>({...ee,isCriticalPath:P.includes(ee.id),subtasks:ee.subtasks?I(ee.subtasks):void 0}));return I(se)},[se,d]),St=wh(ie);Gc({undo:X,redo:j,canUndo:Te,canRedo:We,enabled:true}),Se.useImperativeHandle(n,()=>({getTask:P=>q.findTaskById(se,P),addTask:(P,I)=>{ue(V=>{if(!I)return [...V,{...P,level:0}];let ee=oe=>oe.map(ce=>ce.id===I?{...ce,subtasks:[...ce.subtasks||[],{...P,parentId:I,level:(ce.level||0)+1}],isExpanded:true}:ce.subtasks?{...ce,subtasks:ee(ce.subtasks)}:ce);return ee(V)});},updateTask:(P,I)=>{ue(V=>{let ee=oe=>oe.map(ce=>ce.id===P?{...ce,...I}:ce.subtasks?{...ce,subtasks:ee(ce.subtasks)}:ce);return ee(V)});},deleteTask:P=>{ue(I=>{let V=ee=>ee.filter(oe=>oe.id===P?false:(oe.subtasks&&(oe.subtasks=V(oe.subtasks)),true));return V(I)});},deleteTasks:P=>{ue(I=>$n(I,P));},duplicateTask:P=>{ue(I=>ys(I,[P]));},splitTask:(P,I,V=3)=>{ue(ee=>q.splitTask(ee,P,I,V));},calculateEndDate:q.calculateEndDate,calculateDuration:q.calculateDuration,validateDependency:(P,I)=>!q.validateDependencies(se,P,I),getAllTasks:()=>q.flattenTasks(se),getTasksByStatus:P=>q.flattenTasks(se).filter(I=>I.status===P),getTasksByParent:P=>P?q.findTaskById(se,P)?.subtasks||[]:se.filter(V=>!V.parentId),getCriticalPath:()=>q.flattenTasks(se).filter(P=>P.isCriticalPath),indentTask:P=>{ue(I=>hs(I,[P]));},outdentTask:P=>{ue(I=>bs(I,[P]));},moveTask:(P,I)=>{ue(V=>vs(V,[P],I));},createSubtask:async P=>{let{tasks:I,newTask:V}=ws(se,P);if(E){let ee=E({...V,parentId:P});if((ee instanceof Promise?await ee:ee)===false)return}ue(I),O&&O({...V,parentId:P});},scrollToTask:P=>{let V=q.flattenTasks(se).findIndex(ee=>ee.id===P);if(V!==-1&&S.current){let ee=V*St;S.current.scrollTo({top:ee,behavior:"smooth"}),H.current&&H.current.scrollTo({top:ee,behavior:"smooth"});}},highlightTask:(P,I=2e3)=>{},expandTask:P=>{ue(I=>{let V=ee=>ee.map(oe=>oe.id===P?{...oe,isExpanded:true}:oe.subtasks?{...oe,subtasks:V(oe.subtasks)}:oe);return V(I)});},collapseTask:P=>{ue(I=>{let V=ee=>ee.map(oe=>oe.id===P?{...oe,isExpanded:false}:oe.subtasks?{...oe,subtasks:V(oe.subtasks)}:oe);return V(I)});},expandAll:()=>{ue(P=>{let I=V=>V.map(ee=>({...ee,isExpanded:true,subtasks:ee.subtasks?I(ee.subtasks):void 0}));return I(P)});},collapseAll:()=>{ue(P=>{let I=V=>V.map(ee=>({...ee,isExpanded:false,subtasks:ee.subtasks?I(ee.subtasks):void 0}));return I(P)});},undo:X,redo:j,canUndo:()=>Te,canRedo:()=>We,clearHistory:re,exportToPNG:async()=>{if(!me.current)throw new Error("Gantt container not found");let P=await Hc__default.default(me.current,{backgroundColor:ye.bgPrimary,scale:2});return new Promise((I,V)=>{P.toBlob(ee=>{ee?I(ee):V(new Error("Failed to create blob from canvas"));},"image/png");})},exportToPDF:async P=>{await q.exportToPDF(se,P);},exportToExcel:async P=>{await q.exportToExcel(se,P);},exportToJSON:()=>q.exportToJSON(se),exportToCSV:()=>q.exportToCSV(se),importFromJSON:P=>{let I=q.importFromJSON(P);ue(I);},getTasks:()=>se,refresh:()=>{ue(P=>[...P]);},clearAll:()=>{ue([]);}}),[se,X,j,Te,We,re,ye,St]);let go=Se.useCallback(P=>{J(I=>I.map(V=>V.id===P?{...V,visible:!V.visible}:V));},[]),wa=Se.useCallback((P,I)=>{J(V=>V.map(ee=>{if(ee.id!==P)return ee;let oe=ee.minWidth??100,ce=ee.maxWidth??800,nt=Math.max(oe,Math.min(ce,I));return {...ee,width:nt}}));},[]),Ca=Se.useCallback(P=>{ue(I=>ks(I,P)),r.onTaskToggleExpand?.(P);},[r]),aa=Se.useCallback((P,I)=>{if(G&&G(P,I)===false)return;let ee=q.findTaskById(se,P)?.progress,oe=nt=>nt.map(vt=>vt.id===P?{...vt,...I}:vt.subtasks?{...vt,subtasks:oe(vt.subtasks)}:vt);ue(oe(se));let ce=q.findTaskById(oe(se),P);ce&&(D?.(ce),U?.(ce),I.progress!==void 0&&ee!==void 0&&I.progress!==ee&&C?.(P,ee,I.progress));},[se,D,G,U,C]),nu=Se.useCallback(P=>{P.length!==0&&(ue(I=>hs(I,P)),r.onTaskIndent?.(P[0]));},[r]),ou=Se.useCallback(P=>{P.length!==0&&(ue(I=>bs(I,P)),r.onTaskOutdent?.(P[0]));},[r]),su=Se.useCallback((P,I)=>{P.length!==0&&(ue(V=>vs(V,P,I)),r.onTaskMove?.(P[0],I));},[r]),ki=Se.useCallback(P=>{r.onMultiTaskDelete?r.onMultiTaskDelete(P):(ue(I=>$n(I,P)),P.forEach(I=>r.onTaskDelete?.(I)));},[r]),iu=Se.useCallback(P=>{ue(I=>ys(I,P)),P.forEach(I=>r.onTaskDuplicate?.(I));},[r]),lu=Se.useCallback((P,I)=>{ue(V=>{let{tasks:ee,newTask:oe}=kc(V,P,I);return E&&E(oe)===false?V:(r.onTaskCreate?.(oe.parentId,oe.position||0),O?.(oe),ee)});},[r,E,O]),cu=Se.useCallback((P,I)=>{ue(V=>xs(V,P,I)),r.onTaskRename?.(P,I);},[r]),wi=Se.useCallback(P=>{ue(I=>{let{tasks:V}=ws(I,P);return r.onTaskCreate?.(P,0),V});},[r]),du=Se.useCallback((P,I,V)=>{let ee=P.startDate?Math.round((I.getTime()-P.startDate.getTime())/864e5):0,oe=vt=>vt.map(Yt=>Yt.id===P.id?{...Yt,startDate:I,endDate:V,...P.segments&&{segments:P.segments}}:Yt.subtasks?{...Yt,subtasks:oe(Yt.subtasks)}:Yt),ce=oe(se);ce=q.autoScheduleDependents(ce,P.id,ee),ue(ce);let nt={...P,startDate:I,endDate:V};D?.(nt);},[se,D]),uu=Se.useCallback((P,I)=>{x?.(P,I),at({isOpen:true,x:I.clientX,y:I.clientY,task:P});},[x]),mu=Se.useCallback((P,I)=>{let V=q.splitTask(se,P.id,I);ue(V),at({isOpen:false,x:0,y:0,task:null});},[se]),Ci=Se.useCallback(P=>{w?.(P),N||Wt(P);},[w,N]),Ti=Se.useCallback((P,I,V)=>{let ee=new Map,oe=qt=>{qt.forEach(br=>{br.dependencies&&ee.set(br.id,br.dependencies),br.subtasks&&oe(br.subtasks);});};oe(V);let ce=ee.get(I)||[];ee.set(I,[...ce,P]);let nt=new Set,vt=new Set,Yt=qt=>{if(!nt.has(qt)){nt.add(qt),vt.add(qt);let br=ee.get(qt)||[];for(let Ta of br){if(!nt.has(Ta)&&Yt(Ta))return true;if(vt.has(Ta))return true}}return vt.delete(qt),false};return Yt(I)},[]),Di=Se.useCallback((P,I)=>{if(Ti(P.id,I,se)){console.warn("Cannot create dependency: would create a circular dependency"),alert(`Cannot create this dependency: it would create a circular dependency chain.
|
|
277
277
|
|
|
278
278
|
Task dependencies must flow in one direction only.`);return}let V=ee=>ee.map(oe=>{if(oe.id===I){let ce=oe.dependencies||[];if(!ce.includes(P.id))return {...oe,dependencies:[...ce,P.id]}}return oe.subtasks?{...oe,subtasks:V(oe.subtasks)}:oe});ue(V(se)),R?.(P.id,I);},[se,R,Ti]),Si=Se.useCallback((P,I)=>{let V=ee=>ee.map(oe=>{if(oe.id===P&&oe.dependencies){let ce=oe.dependencies.filter(nt=>nt!==I);return {...oe,dependencies:ce}}return oe.subtasks?{...oe,subtasks:V(oe.subtasks)}:oe});ue(V(se)),W?.(P,I);},[se,W]),{startDate:pu,endDate:fu}=Se.useMemo(()=>{let P=se.filter(ce=>ce.startDate&&ce.endDate);if(P.length===0){let ce=new Date,nt=new Date(ce);nt.setDate(nt.getDate()-30);let vt=new Date(ce);return vt.setDate(vt.getDate()+60),{startDate:nt,endDate:vt}}let I=P.flatMap(ce=>[ce.startDate,ce.endDate]).filter(ce=>ce!==void 0),V=new Date(Math.min(...I.map(ce=>ce.getTime()))),ee=new Date(Math.max(...I.map(ce=>ce.getTime()))),oe=M==="day"?7:M==="week"?14:30;return V.setDate(V.getDate()-oe),ee.setDate(ee.getDate()+oe),{startDate:V,endDate:ee}},[se,M]),gu=Se.useCallback(async()=>{if(!me.current)return;let P=await Hc__default.default(me.current,{backgroundColor:ye.bgPrimary,scale:2}),I=document.createElement("a");I.download="gantt-chart.png",I.href=P.toDataURL("image/png"),I.click();},[ye]),hu=Se.useCallback(async()=>{await q.exportToPDF(se);},[se]),bu=Se.useCallback(async()=>{await q.exportToExcel(se);},[se]),vu=Se.useCallback(()=>{let P=q.exportToCSV(se),I=new Blob([P],{type:"text/csv;charset=utf-8;"}),V=document.createElement("a");V.href=URL.createObjectURL(I),V.download="gantt-chart.csv",V.click(),URL.revokeObjectURL(V.href);},[se]),yu=Se.useCallback(()=>{let P=q.exportToJSON(se),I=new Blob([P],{type:"application/json;charset=utf-8;"}),V=document.createElement("a");V.href=URL.createObjectURL(I),V.download="gantt-chart.json",V.click(),URL.revokeObjectURL(V.href);},[se]),xu=Se.useCallback(()=>{q.exportToMSProject(se,"Gantt Project","project.xml");},[se]),ku=P=>{P.preventDefault(),jt(true);};return Se.useEffect(()=>{let P=H.current,I=S.current;if(!P||!I)return;let V=I.querySelector(".gantt-taskgrid-content"),ee=()=>{let nt=P.scrollTop;bt(nt),V&&(V.style.transform=`translateY(-${nt}px)`);},oe=nt=>{if(wt&&I){let Yt=I.parentElement?.getBoundingClientRect()?.left||0,qt=nt.clientX-Yt,br=200,Ta=Math.min(window.innerWidth-300,800);qt>=br&&qt<=Ta&&zr(qt);}},ce=()=>{jt(false);};return P.addEventListener("scroll",ee),document.addEventListener("mousemove",oe),document.addEventListener("mouseup",ce),()=>{P.removeEventListener("scroll",ee),document.removeEventListener("mousemove",oe),document.removeEventListener("mouseup",ce);}},[wt]),jsxRuntime.jsx(ga.Provider,{value:le,children:jsxRuntime.jsx(Ao.Provider,{value:Be,children:jsxRuntime.jsxs("div",{ref:me,className:"flex flex-col h-full w-full",style:{backgroundColor:ye.bgPrimary,fontFamily:"Inter, sans-serif",minHeight:0,...r.disableScrollSync&&{scrollBehavior:"auto",overflowAnchor:"none"}},children:[jsxRuntime.jsx(On,{theme:ye,timeScale:M,onTimeScaleChange:de,zoom:rt,onZoomChange:ir,currentTheme:_,onThemeChange:$r,rowDensity:ie,onRowDensityChange:kt,showThemeSelector:u,showCreateTaskButton:h,createTaskLabel:g,onCreateTask:b,onExportPNG:i?gu:void 0,onExportPDF:i?hu:void 0,onExportExcel:i?bu:void 0,onExportCSV:i?vu:void 0,onExportJSON:i?yu:void 0,onExportMSProject:i?xu:void 0}),jsxRuntime.jsxs("div",{ref:S,className:"flex-1 flex min-h-0",style:{overflow:"hidden"},children:[jsxRuntime.jsx("div",{className:"gantt-grid-scroll flex-shrink-0",style:{width:ve,overflow:"hidden"},children:jsxRuntime.jsx(Wn,{tasks:Mt,theme:ye,rowHeight:St,availableUsers:p,templates:Ue,onTaskClick:k,onTaskDblClick:Ci,onTaskContextMenu:x,onTaskToggle:Ca,scrollTop:De,columns:Ut,onToggleColumn:go,onColumnResize:wa,onTaskUpdate:aa,onTaskIndent:nu,onTaskOutdent:ou,onTaskMove:su,onMultiTaskDelete:ki,onTaskDuplicate:iu,onTaskCreate:lu,onTaskRename:cu,onCreateSubtask:wi,onOpenTaskModal:k?P=>k(P):void 0})}),jsxRuntime.jsx("div",{className:"flex-shrink-0 cursor-col-resize",style:{width:6,marginLeft:-3,zIndex:10},onMouseDown:ku}),jsxRuntime.jsx("div",{ref:H,className:"gantt-timeline-scroll flex-1 overflow-auto",style:{minHeight:0,...r.disableScrollSync&&{scrollBehavior:"auto",overflowAnchor:"none"}},children:jsxRuntime.jsx(Yn,{tasks:Mt,theme:ye,rowHeight:St,timeScale:M,startDate:pu,endDate:fu,zoom:rt,templates:Ue,onTaskClick:k,onTaskDblClick:Ci,onTaskContextMenu:uu,onTaskDateChange:du,onDependencyCreate:Di,onDependencyDelete:Si})})]}),he.task&&jsxRuntime.jsx(ha,{isOpen:he.isOpen,x:he.x,y:he.y,theme:ye,onClose:()=>at({isOpen:false,x:0,y:0,task:null}),items:[{id:"edit",label:le.contextMenu?.editTask||"Edit Task",icon:lt.Pencil,onClick:()=>{he.task&&(N?N(he.task):Wt(he.task));}},{id:"addSubtask",label:le.contextMenu?.addSubtask||"Add Subtask",icon:lt.Add,onClick:()=>{he.task&&(T?T(he.task):wi(he.task.id));}},{id:"separator-status",label:"",separator:true,onClick:()=>{}},{id:"markIncomplete",label:le.contextMenu?.markIncomplete||"Mark Incomplete",icon:lt.MarkIncomplete,onClick:()=>{he.task&&($?$(he.task):aa(he.task.id,{status:"todo",progress:0}));},disabled:he.task?.status==="todo"},{id:"setInProgress",label:le.contextMenu?.setInProgress||"Set In Progress",icon:lt.SetInProgress,onClick:()=>{he.task&&(z?z(he.task):aa(he.task.id,{status:"in-progress"}));},disabled:he.task?.status==="in-progress"},{id:"markComplete",label:le.contextMenu?.markComplete||"Mark Complete",icon:lt.MarkComplete,onClick:()=>{he.task&&aa(he.task.id,{status:"completed",progress:100});},disabled:he.task?.status==="completed"},{id:"separator-advanced",label:"",separator:true,onClick:()=>{}},{id:"split",label:le.contextMenu?.splitTask||"Split Task",icon:lt.Split,onClick:()=>{if(!he.task?.startDate||!he.task?.endDate){console.warn("Cannot split task without dates");return}let P=he.task.startDate.getTime(),I=he.task.endDate.getTime(),V=P+(I-P)/2,ee=new Date(V);mu(he.task,ee);},disabled:!he.task?.startDate||!he.task?.endDate},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:le.contextMenu?.deleteTask||"Delete Task",icon:lt.Delete,onClick:()=>{he.task&&ki([he.task.id]);}}]}),Kt&&jsxRuntime.jsx(qn,{isOpen:true,onClose:()=>Wt(null),task:Kt,onSubmit:P=>{aa(Kt.id,P),Wt(null);},mode:"edit",theme:_}),m?.enabled&&jsxRuntime.jsx(Xn,{tasks:se,theme:ye,config:m,onTasksUpdate:ue,onTaskUpdate:aa,onTaskCreate:P=>{ue(I=>[...I,P]);},onTaskDelete:P=>{ue(I=>$n(I,[P]));},onDependencyCreate:(P,I)=>{let V=q.findTaskById(se,P);V&&Di(V,I);},onDependencyDelete:Si})]})})})});var Kc=`You are a Gantt chart AI assistant. You help users edit project tasks using natural language commands.
|
|
279
279
|
|