@libxai/board 0.17.226 → 0.17.227
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 +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -339,7 +339,7 @@
|
|
|
339
339
|
</Calendars>
|
|
340
340
|
<Tasks>${p}
|
|
341
341
|
</Tasks>
|
|
342
|
-
</Project>`,m=new Blob([n],{type:"application/xml;charset=utf-8;"}),d=document.createElement("a");d.href=URL.createObjectURL(m),d.download=a,d.click(),URL.revokeObjectURL(d.href);},calculateCriticalPath:e=>{let t=le.flattenTasks(e),a=t.filter(n=>n.startDate&&n.endDate);if(a.length===0)return [];let r=new Map,o=n=>{if(r.has(n.id))return;let m=n.startDate&&n.endDate?le.calculateDuration(n.startDate,n.endDate):0,d=0;if(n.dependencies&&n.dependencies.length>0)for(let u of n.dependencies){let x=t.find(f=>f.id===u);if(x){o(x);let f=r.get(u)?.ef||0;d=Math.max(d,f);}}let i=d+m;r.set(n.id,{es:d,ef:i});};a.forEach(o);let s=Math.max(...Array.from(r.values()).map(n=>n.ef)),l=new Map,c=n=>{if(l.has(n.id))return;let m=n.startDate&&n.endDate?le.calculateDuration(n.startDate,n.endDate):0,d=t.filter(x=>x.dependencies&&x.dependencies.includes(n.id)),i=s;if(d.length>0)for(let x of d){c(x);let f=l.get(x.id)?.ls||0;i=Math.min(i,f);}let u=i-m;l.set(n.id,{ls:u,lf:i});};a.forEach(c);let p=[];for(let n of a){let m=r.get(n.id),d=l.get(n.id);if(m&&d){let i=d.ls-m.es;Math.abs(i)<.01&&p.push(n.id);}}return p},calculateSlack:(e,t)=>{let a=le.findTaskById(e,t);if(!a||!a.startDate||!a.endDate)return null;if(le.calculateCriticalPath(e).includes(t))return 0;let o=le.getDependentTasks(e,t);if(o.length===0){let c=le.getLatestEndDate(e);if(!c)return null;let p=le.calculateDuration(a.endDate,c);return Math.max(0,p)}let s=o.filter(c=>c.startDate).map(c=>c.startDate.getTime()).sort((c,p)=>c-p)[0];if(!s)return null;let l=le.calculateDuration(a.endDate,new Date(s));return Math.max(0,l)},isOnCriticalPath:(e,t)=>le.calculateCriticalPath(e).includes(t),autoScheduleDependents:(e,t,a)=>{let r=le.findTaskById(e,t);if(!r||!r.endDate)return e;let o=le.getDependentTasks(e,t);if(o.length===0)return e;let s=[...e];for(let l of o){if(!l.startDate||!l.endDate)continue;let c=le.calculateDuration(l.startDate,l.endDate),p;a!==void 0?(p=new Date(l.startDate),p.setDate(p.getDate()+a)):(p=new Date(r.endDate),p.setDate(p.getDate()+1));let n=le.calculateEndDate(p,c),m=d=>d.map(i=>i.id===l.id?{...i,startDate:p,endDate:n}:i.subtasks?{...i,subtasks:m(i.subtasks)}:i);s=m(s),s=le.autoScheduleDependents(s,l.id,a);}return s},calculateCascadePreview:(e,t,a,r,o,s,l,c)=>{if(a===0)return [];let p=[],n=o.getTime(),m=1e3*60*60*24,d=le.findTaskById(e,t);if(!d||!d.endDate)return [];let i=(u,x,f=new Set)=>{if(f.has(u))return;f.add(u);let g=le.getDependentTasks(e,u);for(let k of g){if(!k.startDate||!k.endDate)continue;let h=r.findIndex(w=>w.id===k.id);if(h===-1)continue;let b=k.startDate.getTime(),D=(k.endDate.getTime()-b)/m,A=(b-n)/m*s,v=A+x*s,B=Math.max(D*s,s),T=c+h*l+12;p.push({taskId:k.id,taskName:k.name,originalX:A,previewX:v,width:B,y:T,rowIndex:h,daysDelta:x,color:k.color}),i(k.id,x,f);}};return i(t,a),p},splitTask:(e,t,a,r=3)=>{let o=le.findTaskById(e,t);if(!o||!o.startDate||!o.endDate)return e;if(a<=o.startDate||a>=o.endDate)return console.warn("Split date must be between task start and end dates"),e;let s=new Date(a);s.setDate(s.getDate()-1);let l=new Date(a);l.setDate(l.getDate()+r);let c=new Date(o.endDate);c.setDate(c.getDate()+r);let p=[{startDate:new Date(o.startDate),endDate:s},{startDate:l,endDate:c}],n=m=>m.map(d=>d.id===o.id?{...d,endDate:c,segments:p}:d.subtasks?{...d,subtasks:n(d.subtasks)}:d);return n(e)}};function hn({tasks:e,theme:t,rowHeight:a,timeScale:r,startDate:o,endDate:s,zoom:l,templates:c,onTaskClick:p,onTaskDblClick:n,onTaskContextMenu:m,onTaskDateChange:d,onDependencyCreate:i,onDependencyDelete:u}){let[f,g]=react.useState([]),[k,h]=react.useState(null),[b,y]=react.useState(null),D=react.useCallback(z=>{h(z);},[]),N=Math.ceil((s.getTime()-o.getTime())/(1e3*60*60*24)),A=r==="day"?60:r==="week"?20:8,v=N*A*l,B=z=>{let F=new Date(Date.UTC(z.getFullYear(),z.getMonth(),z.getDate())),H=F.getUTCDay()||7;F.setUTCDate(F.getUTCDate()+4-H);let P=new Date(Date.UTC(F.getUTCFullYear(),0,1));return Math.ceil(((F.getTime()-P.getTime())/864e5+1)/7)},T=z=>{let F=z.getDay();return F===0||F===6},w=react.useCallback(z=>{let F=Math.round(z/(A*l)),H=new Date(o);return H.setDate(H.getDate()+F),H},[o,A,l]),R=react.useCallback((z,F)=>{if(F.startDate&&F.endDate)return;let H=z.currentTarget.ownerSVGElement;if(!H)return;let P=H.createSVGPoint();P.x=z.clientX,P.y=z.clientY;let Y=P.matrixTransform(H.getScreenCTM()?.inverse()),J=w(Y.x),$=new Date(J);$.setDate($.getDate()+1),d?.(F,J,$);},[w,d]),M=react.useMemo(()=>{let z=Y=>Y.map(J=>{if(J.subtasks&&J.subtasks.length>0){let $=z(J.subtasks),Te=$.filter(ke=>ke.startDate&&ke.endDate);if(Te.length>0){let ke=Te.map(Me=>Me.startDate.getTime()),Ue=Te.map(Me=>Me.endDate.getTime()),he=new Date(Math.min(...ke)),et=new Date(Math.max(...Ue));return {...J,subtasks:$,startDate:he,endDate:et}}return {...J,subtasks:$}}return J}),F=(Y,J=[])=>{for(let $ of Y)J.push($),$.subtasks&&$.subtasks.length>0&&($.isExpanded===void 0||$.isExpanded)&&F($.subtasks,J);return J},H=z(e);return F(H)},[e]),G=react.useCallback(z=>{if(!z.startDate||!z.endDate)return {x:0,width:0};let F=z.startDate.getTime(),H=z.endDate.getTime(),P=o.getTime(),Y=(F-P)/(1e3*60*60*24),J=(H-F)/(1e3*60*60*24),$=Y*A*l,Te=Math.max(A*l,40),ke=Math.max(J*A*l,Te);return {x:$,width:ke}},[o,A,l]),X=react.useMemo(()=>M.filter(z=>z.startDate&&z.endDate).map(z=>{let{x:F,width:H}=G(z),Y=M.findIndex(J=>J.id===z.id)*a+12;return {id:z.id,x:F,y:Y,width:H,height:32}}),[M,G]),fe=react.useCallback((z,F,H)=>{if(!H||F===0){g([]);return}let P=le.calculateCascadePreview(e,z,F,M,o,A*l,a,48);g(P);},[e,M,o,A,l,a,48]),xe=react.useMemo(()=>{let z=[],F=new Date(o);for(;F<=s;){let Y=(F.getTime()-o.getTime())/864e5*A*l;if(r==="day")z.push({date:new Date(F),label:F.toLocaleDateString("en-US",{day:"numeric",month:"short"}),x:Y}),F.setDate(F.getDate()+1);else if(r==="week"){let J=B(F);z.push({date:new Date(F),label:`Week ${J}`,x:Y}),F.setDate(F.getDate()+7);}else z.push({date:new Date(F),label:F.toLocaleDateString("en-US",{month:"short",year:"numeric"}),x:Y}),F.setMonth(F.getMonth()+1);}return z},[o,s,r,A,l]),Ie=react.useMemo(()=>(new Date().getTime()-o.getTime())/(1e3*60*60*24)*A*l,[o,A,l]),Oe=Math.max(M.length*a,552);return jsxRuntime.jsxs("div",{className:"w-full h-full flex flex-col","data-gantt-chart":true,style:{backgroundColor:t.bgPrimary,overflow:"visible"},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(v,1e3),height:47,style:{display:"block"},children:[jsxRuntime.jsx("rect",{x:0,y:0,width:Math.max(v,1e3),height:48,fill:t.bgGrid}),xe.map((z,F)=>jsxRuntime.jsxs("g",{children:[F>0&&jsxRuntime.jsx("line",{x1:z.x,y1:0,x2:z.x,y2:48,stroke:t.border,strokeWidth:1,opacity:.1}),jsxRuntime.jsx("text",{x:z.x+8,y:48/2,fill:t.textTertiary,fontSize:"11",fontFamily:"'JetBrains Mono', ui-monospace, monospace",fontWeight:"500",dominantBaseline:"middle",children:z.label})]},`header-${F}`)),Ie>=0&&Ie<=v&&jsxRuntime.jsx("circle",{cx:Ie,cy:38,r:6,fill:t.today,opacity:1})]})}),jsxRuntime.jsxs("svg",{width:Math.max(v,1e3),height:Oe,style:{display:"block",flexShrink:0,overflow:"visible"},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(v,1e3),height:Oe,fill:t.bgPrimary}),xe.map((z,F)=>{let H=xe[F+1]?.x||v,P=T(z.date);return jsxRuntime.jsxs("g",{children:[P&&jsxRuntime.jsx("rect",{x:z.x,y:0,width:H-z.x,height:M.length*a,fill:t.bgWeekend,opacity:1}),F>0&&jsxRuntime.jsx("line",{x1:z.x,y1:0,x2:z.x,y2:M.length*a,stroke:t.border,strokeWidth:1,opacity:.1})]},F)}),M.map((z,F)=>{let H=z.startDate&&z.endDate;return jsxRuntime.jsxs("g",{children:[jsxRuntime.jsx("rect",{x:0,y:F*a,width:v,height:a,fill:F%2===0?t.bgPrimary:t.bgGrid,opacity:1,style:{pointerEvents:"none"}},`row-${z.id}`),!H&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:0,y:F*a,width:v,height:a,fill:"transparent",style:{cursor:"pointer",pointerEvents:"all"},onClick:P=>R(P,z),onMouseEnter:P=>{P.currentTarget.setAttribute("fill",t.accentLight),P.currentTarget.setAttribute("opacity","0.5");},onMouseLeave:P=>{P.currentTarget.setAttribute("fill","transparent"),P.currentTarget.setAttribute("opacity","1");}},`clickable-${z.id}`),jsxRuntime.jsx("text",{x:Ie>0?Ie:100,y:F*a+a/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-${z.id}`)]})]},`row-group-${z.id}`)}),M.map((z,F)=>!z.dependencies||z.dependencies.length===0||!z.startDate||!z.endDate?null:z.dependencies.map(H=>{let P=M.find(Te=>Te.id===H);if(!P||!P.startDate||!P.endDate)return null;let Y=M.findIndex(Te=>Te.id===H),J=G(P),$=G(z);return jsxRuntime.jsx(mn,{x1:J.x+J.width,y1:Y*a+a/2,x2:$.x,y2:F*a+a/2,theme:t},`dep-${H}-${z.id}`)})),M.map((z,F)=>{if(!z.startDate||!z.endDate)return null;let{x:H,width:P}=G(z),Y=F*a+12,J=z.subtasks&&z.subtasks.length>0&&!z.isMilestone;return z.isMilestone?jsxRuntime.jsx(gn,{task:z,x:H+P/2,y:Y+16,theme:t,onClick:p},z.id):J?jsxRuntime.jsxs("g",{onClick:()=>p?.(z),onContextMenu:$=>{$.preventDefault(),$.stopPropagation(),m?.(z,$);},style:{cursor:"default"},children:[jsxRuntime.jsx("rect",{x:H,y:Y,width:P,height:32,fill:t.primary,opacity:.25,rx:6}),jsxRuntime.jsx("line",{x1:H,y1:Y,x2:H+P,y2:Y,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:H,y1:Y,x2:H,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:H+P,y1:Y,x2:H+P,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:H,y1:Y+32,x2:H+P,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),P>60&&jsxRuntime.jsx("text",{x:H+12,y:Y+16,dominantBaseline:"middle",fill:"#FFFFFF",fontSize:"13",fontWeight:"500",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:z.name})]},z.id):jsxRuntime.jsx(dn,{task:z,x:H,y:Y,width:P,theme:t,dayWidth:A*l,startDate:o,templates:c,onClick:p,onDoubleClick:n,onContextMenu:m,onDateChange:d,onDependencyCreate:i,allTaskPositions:X,onDragMove:fe,onHoverChange:D},z.id)}),M.map((z,F)=>!z.dependencies||z.dependencies.length===0||!z.startDate||!z.endDate?null:z.dependencies.map(H=>{let P=M.find(pe=>pe.id===H);if(!P||!P.startDate||!P.endDate)return null;let Y=M.findIndex(pe=>pe.id===H),J=G(P),$=G(z),Te=J.x+J.width,ke=Y*a+a/2,Ue=$.x,he=F*a+a/2,et=Ue-Te,Me=Te+et/2,Ze=pe=>{let Ce=1-pe,Ee=Ce*Ce,tt=Ee*Ce,ut=pe*pe,Le=ut*pe,I=tt*Te+3*Ee*pe*Me+3*Ce*ut*Me+Le*Ue,q=tt*ke+3*Ee*pe*ke+3*Ce*ut*he+Le*he;return {x:I,y:q}},bt=20,St=[];for(let pe=0;pe<=bt;pe++){let Ce=.1+pe/bt*.8;St.push(Ze(Ce));}let lt=St[0],O=`M ${lt.x} ${lt.y} `+St.slice(1).map(pe=>`L ${pe.x} ${pe.y}`).join(" ");return b&&b.x1===Te&&b.y1===ke&&b.x2===Ue&&b.y2===he?null:jsxRuntime.jsx("path",{d:O,fill:"none",stroke:"transparent",strokeWidth:12,strokeLinecap:"round",style:{cursor:"pointer"},onMouseEnter:()=>{y({x1:Te,y1:ke,x2:Ue,y2:he,onDelete:()=>u?.(z.id,H)});}},`dep-hover-${H}-${z.id}`)})),f.map(z=>jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[jsxRuntime.jsx("rect",{x:z.previewX,y:z.y-48,width:z.width,height:32,rx:8,fill:z.color||t.accent,opacity:.3,stroke:t.accent,strokeWidth:2,strokeDasharray:"4 2"}),Math.abs(z.daysDelta)>0&&jsxRuntime.jsx("text",{x:z.previewX+z.width/2,y:z.y-48+16,textAnchor:"middle",dominantBaseline:"middle",fill:t.accent,fontSize:"10",fontWeight:"600",fontFamily:"Inter, sans-serif",style:{userSelect:"none"},children:z.daysDelta>0?`+${z.daysDelta}d`:`${z.daysDelta}d`})]},`cascade-preview-${z.taskId}`)),b&&(()=>{let{x1:z,y1:F,x2:H,y2:P,onDelete:Y}=b,J=H-z,$=P-F,Te=z+J/2,ke=(F+P)/2,Ue=`M ${z} ${F} C ${Te} ${F}, ${Te} ${P}, ${H} ${P}`,he=6,et=Math.atan2($,J),Me=H-he*Math.cos(et-Math.PI/6),Ze=P-he*Math.sin(et-Math.PI/6),bt=H-he*Math.cos(et+Math.PI/6),St=P-he*Math.sin(et+Math.PI/6),lt=t.dependency,O="#f87171";return jsxRuntime.jsxs("g",{onMouseLeave:()=>y(null),children:[jsxRuntime.jsx("path",{d:Ue,fill:"none",stroke:"transparent",strokeWidth:50,strokeLinecap:"round",style:{cursor:"pointer"}}),jsxRuntime.jsx("circle",{cx:Te,cy:ke,r:25,fill:"transparent",style:{cursor:"pointer"}}),jsxRuntime.jsx("path",{d:Ue,fill:"none",stroke:lt,strokeWidth:8,strokeLinecap:"round",opacity:.15,style:{pointerEvents:"none",filter:"blur(4px)"}}),jsxRuntime.jsx("path",{d:Ue,fill:"none",stroke:lt,strokeWidth:2.5,strokeLinecap:"round",opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsx("path",{d:`M ${H} ${P} L ${Me} ${Ze} M ${H} ${P} L ${bt} ${St}`,fill:"none",stroke:lt,strokeWidth:2.5,strokeLinecap:"round",opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsx("circle",{cx:H,cy:P,r:4,fill:lt,opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,scale:.8},animate:{opacity:1,scale:1},transition:{duration:.15,ease:"easeOut"},onClick:pe=>{pe.stopPropagation(),y(null),Y();},style:{cursor:"pointer"},children:[jsxRuntime.jsx("circle",{cx:Te,cy:ke,r:9,fill:"rgba(248, 113, 113, 0.15)",stroke:O,strokeWidth:1.5,style:{transition:"all 0.15s ease"}}),jsxRuntime.jsx("line",{x1:Te-3,y1:ke-3,x2:Te+3,y2:ke+3,stroke:O,strokeWidth:1.5,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:Te+3,y1:ke-3,x2:Te-3,y2:ke+3,stroke:O,strokeWidth:1.5,strokeLinecap:"round"})]})]})})(),Ie>=0&&Ie<=v&&jsxRuntime.jsx("line",{x1:Ie,y1:0,x2:Ie,y2:Oe,stroke:t.today,strokeWidth:1,opacity:1,style:{pointerEvents:"none"}}),k&&jsxRuntime.jsx(Gd,{tooltipData:k,theme:t})]})]})}var bn=[{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:"Coral",value:"#F97316",light:"#FB923C"},{name:"Magenta",value:"#E11D48",light:"#FB7185"}];var ei=[{id:"todo",title:"Por Hacer",color:"#6B7280"},{id:"in-progress",title:"En Progreso",color:"#F59E0B"},{id:"completed",title:"Completada",color:"#10B981"}],ti=[{id:"low",label:"Baja",color:"#10B981",icon:"\u{1F7E2}"},{id:"medium",label:"Media",color:"#F59E0B",icon:"\u{1F7E1}"},{id:"high",label:"Alta",color:"#F97316",icon:"\u{1F7E0}"},{id:"urgent",label:"Urgente",color:"#EF4444",icon:"\u{1F534}"}];function yn({isOpen:e,onClose:t,task:a,availableTasks:r=[],availableUsers:o=[],onSubmit:s,isLoading:l=false,mode:c=a?"edit":"create",theme:p="dark",customStatuses:n=[],availableTags:m=[],onCreateTag:d,attachments:i=[],onUploadAttachments:u,onDeleteAttachment:x}){let f=[...ei,...n.filter(O=>!ei.some(re=>re.id===O.id))],g=_e[p]||_e.dark,[k,h]=react.useState(false),[b,y]=react.useState(false),[D,N]=react.useState(false),[A,v]=react.useState(false),[B,T]=react.useState({top:0,left:0}),[w,R]=react.useState(null),[M,G]=react.useState(new Date),[X,fe]=react.useState({top:0,left:0}),[xe,Ie]=react.useState(false),[Oe,z]=react.useState([]),F=react.useRef(null),H=react.useRef(null),P=react.useRef(null),Y=react.useRef(null),J=react.useRef(null),[$,Te]=react.useState({name:"",description:"",progress:0,status:"todo",priority:"medium",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[],tags:[]}),[ke,Ue]=react.useState({});react.useEffect(()=>{a?(Te({name:a.name,description:a.description||"",startDate:a.startDate,endDate:a.endDate,progress:a.progress,status:a.status||"todo",priority:a.priority||"medium",isMilestone:a.isMilestone||false,color:a.color||"#6366F1",assignees:a.assignees||[],dependencies:a.dependencies||[],tags:a.tags||[]}),(a.dependencies&&a.dependencies.length>0||a.isMilestone)&&Ie(true)):(Te({name:"",description:"",progress:0,status:"todo",priority:"medium",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[],pendingFiles:[],tags:[]}),Ie(false),z([]));},[a,e]),react.useEffect(()=>{let O=re=>{F.current&&!F.current.contains(re.target)&&h(false),H.current&&!H.current.contains(re.target)&&y(false),P.current&&!P.current.contains(re.target)&&N(false),Y.current&&!Y.current.contains(re.target)&&v(false);};return document.addEventListener("mousedown",O),()=>document.removeEventListener("mousedown",O)},[]);let he=()=>{let O={};return $.name.trim()||(O.name="El nombre es requerido"),$.startDate&&$.endDate&&$.startDate>$.endDate&&(O.endDate="La fecha de fin debe ser posterior a la de inicio"),Ue(O),Object.keys(O).length===0},et=async O=>{if(O.preventDefault(),!!he())try{let re=c==="create"&&Oe.length>0?{...$,pendingFiles:Oe}:$;await s(re),z([]),t();}catch(re){console.error("Error submitting task:",re);}},Me=(O,re)=>{Te(pe=>{let Ce={...pe,[O]:re};if(O==="status"){let Ee=re;Ee==="todo"?Ce.progress=0:Ee==="in-progress"?(pe.progress===0||pe.progress===100)&&(Ce.progress=50):Ee==="completed"||Ee==="closed"?Ce.progress=100:(Ee==="in-review"||Ee==="review")&&(Ce.progress=75);}if(O==="progress"){let Ee=typeof re=="number"?re:parseInt(re,10);Ee===100&&pe.status!=="completed"?Ce.status="completed":Ee>0&&Ee<100&&pe.status==="todo"?Ce.status="in-progress":Ee===0&&pe.status!=="todo"&&(Ce.status="todo");}return Ce}),ke[O]&&Ue(pe=>{let Ce={...pe};return delete Ce[O],Ce});},Ze=f.find(O=>O.id===$.status)??ei[0],bt=ti.find(O=>O.id===$.priority)??ti[1],St=bn.find(O=>O.value===$.color)??bn[0],lt={backgroundColor:g.bgSecondary,border:`1px solid ${g.borderLight}`,color:g.textPrimary};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/60 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:.15,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-xl rounded-xl shadow-2xl pointer-events-auto overflow-hidden","data-theme":p,style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},onClick:O=>O.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-5 py-3",style:{borderBottom:`1px solid ${g.border}`},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx("div",{className:"w-3 h-3 rounded-full",style:{backgroundColor:Ze.color||g.accent}}),jsxRuntime.jsx("span",{className:"text-sm font-medium",style:{color:g.textSecondary},children:c==="create"?"Nueva tarea":"Editar tarea"})]}),jsxRuntime.jsx("button",{onClick:t,className:"p-1.5 rounded-lg transition-colors",style:{color:g.textTertiary},onMouseEnter:O=>{O.currentTarget.style.backgroundColor=g.hoverBg,O.currentTarget.style.color=g.textPrimary;},onMouseLeave:O=>{O.currentTarget.style.backgroundColor="transparent",O.currentTarget.style.color=g.textTertiary;},disabled:l,children:jsxRuntime.jsx(lucideReact.X,{className:"w-4 h-4"})})]}),jsxRuntime.jsxs("form",{onSubmit:et,className:"max-h-[calc(100vh-200px)] overflow-y-auto",children:[jsxRuntime.jsxs("div",{className:"p-5 space-y-4",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("input",{type:"text",value:$.name,onChange:O=>Me("name",O.target.value),className:"w-full text-lg font-medium bg-transparent border-none focus:outline-none focus:ring-0 placeholder:opacity-50",style:{color:g.textPrimary},placeholder:"Nombre de la tarea",disabled:l,autoFocus:true}),ke.name&&jsxRuntime.jsxs("p",{className:"mt-1 text-xs text-red-400 flex items-center gap-1",children:[jsxRuntime.jsx(lucideReact.AlertCircle,{className:"w-3 h-3"}),ke.name]})]}),jsxRuntime.jsx("div",{children:jsxRuntime.jsx("textarea",{value:$.description||"",onChange:O=>Me("description",O.target.value),className:"w-full text-sm bg-transparent border-none focus:outline-none focus:ring-0 resize-none placeholder:opacity-40",style:{color:g.textSecondary},placeholder:"Agregar descripci\xF3n...",rows:2,disabled:l})}),jsxRuntime.jsx("div",{style:{borderTop:`1px solid ${g.borderLight}`}}),jsxRuntime.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[jsxRuntime.jsxs("div",{ref:F,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>!l&&h(!k),className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:{...lt,borderColor:Ze.color,backgroundColor:`${Ze.color}15`},disabled:l,children:[jsxRuntime.jsx(lucideReact.CircleDot,{className:"w-3.5 h-3.5",style:{color:Ze.color}}),jsxRuntime.jsx("span",{style:{color:Ze.color},children:Ze.title}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:Ze.color}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:k&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},className:"absolute left-0 top-full mt-1 z-50 min-w-[140px] rounded-lg shadow-xl overflow-hidden",style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},children:f.map(O=>jsxRuntime.jsxs("button",{type:"button",className:"w-full flex items-center gap-2 px-3 py-2 text-sm transition-colors",style:{color:g.textPrimary},onMouseEnter:re=>re.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:re=>re.currentTarget.style.backgroundColor="transparent",onClick:()=>{Me("status",O.id),h(false);},children:[jsxRuntime.jsx(lucideReact.CircleDot,{className:"w-3.5 h-3.5",style:{color:O.color}}),O.title,$.status===O.id&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5 ml-auto",style:{color:g.accent}})]},O.id))})})]}),jsxRuntime.jsxs("div",{ref:H,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>!l&&y(!b),className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:lt,disabled:l,children:[jsxRuntime.jsx(lucideReact.Flag,{className:"w-3.5 h-3.5",style:{color:bt.color}}),jsxRuntime.jsx("span",{children:bt.label}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:g.textTertiary}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:b&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},className:"absolute left-0 top-full mt-1 z-50 min-w-[130px] rounded-lg shadow-xl overflow-hidden",style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},children:ti.map(O=>jsxRuntime.jsxs("button",{type:"button",className:"w-full flex items-center gap-2 px-3 py-2 text-sm transition-colors",style:{color:g.textPrimary},onMouseEnter:re=>re.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:re=>re.currentTarget.style.backgroundColor="transparent",onClick:()=>{Me("priority",O.id),y(false);},children:[jsxRuntime.jsx("span",{children:O.icon}),O.label,$.priority===O.id&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5 ml-auto",style:{color:g.accent}})]},O.id))})})]}),o.length>0&&jsxRuntime.jsxs("div",{ref:P,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>!l&&N(!D),className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:lt,disabled:l,children:[$.assignees&&$.assignees.length>0?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"flex -space-x-1",children:$.assignees.slice(0,3).map((O,re)=>jsxRuntime.jsx("div",{className:"w-5 h-5 rounded-full flex items-center justify-center text-[10px] text-white font-medium border-2",style:{backgroundColor:O.color||g.accent,borderColor:g.bgSecondary},children:O.initials},re))}),$.assignees.length>3&&jsxRuntime.jsxs("span",{style:{color:g.textTertiary},children:["+",$.assignees.length-3]})]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(lucideReact.Users,{className:"w-3.5 h-3.5",style:{color:g.textTertiary}}),jsxRuntime.jsx("span",{style:{color:g.textTertiary},children:"Asignar"})]}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:g.textTertiary}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:D&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},className:"absolute left-0 top-full mt-1 z-50 min-w-[180px] max-h-[200px] overflow-y-auto rounded-lg shadow-xl",style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},children:o.map(O=>{let re=$.assignees?.some(pe=>pe.name===O.name);return jsxRuntime.jsxs("button",{type:"button",className:"w-full flex items-center gap-2 px-3 py-2 text-sm transition-colors",style:{color:g.textPrimary},onMouseEnter:pe=>pe.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:pe=>pe.currentTarget.style.backgroundColor="transparent",onClick:()=>{let pe=re?($.assignees||[]).filter(Ce=>Ce.name!==O.name):[...$.assignees||[],{name:O.name,avatar:O.avatar,initials:O.name.split(" ").map(Ce=>Ce[0]).join("").toUpperCase().slice(0,2),color:g.accent}];Me("assignees",pe);},children:[jsxRuntime.jsx("div",{className:"w-6 h-6 rounded-full flex items-center justify-center text-xs text-white font-medium flex-shrink-0",style:{backgroundColor:g.accent},children:O.name.charAt(0).toUpperCase()}),jsxRuntime.jsx("span",{className:"truncate flex-1 text-left",children:O.name}),jsxRuntime.jsx("div",{className:"w-4 flex-shrink-0 flex justify-end",children:re&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5",style:{color:g.accent}})})]},O.id)})})})]}),jsxRuntime.jsxs("div",{ref:Y,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>{if(!l)if(A)v(false);else {if(Y.current){let O=Y.current.getBoundingClientRect(),re=window.innerHeight,pe=120,Ee=re-O.bottom<pe?O.top-pe-8:O.bottom+8;T({top:Ee,left:O.left});}v(true);}},className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:lt,disabled:l,children:[jsxRuntime.jsx("div",{className:"w-3.5 h-3.5 rounded-full",style:{backgroundColor:$.color}}),jsxRuntime.jsx("span",{children:St.name}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:g.textTertiary}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:A&&jsxRuntime.jsxs(rt,{children:[jsxRuntime.jsx("div",{className:"fixed inset-0",style:{zIndex:99998},onClick:()=>v(false)}),jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},transition:{duration:.12},className:"rounded-lg",style:{position:"fixed",top:`${B.top}px`,left:`${B.left}px`,zIndex:99999,backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`,boxShadow:"0 4px 20px rgba(0, 0, 0, 0.25)"},onClick:O=>O.stopPropagation(),children:jsxRuntime.jsx("div",{style:{padding:"6px 8px"},children:jsxRuntime.jsx("div",{style:{display:"grid",gridTemplateColumns:"repeat(6, 28px)",gap:"2px"},children:bn.slice(0,18).map(O=>{let re=$.color===O.value;return jsxRuntime.jsx("button",{type:"button",onClick:pe=>{pe.preventDefault(),pe.stopPropagation(),Me("color",O.value),v(false);},style:{width:"28px",height:"28px",borderRadius:"6px",backgroundColor:"transparent",cursor:"pointer",border:"none",display:"flex",alignItems:"center",justifyContent:"center",padding:0},title:O.name,children:jsxRuntime.jsx("span",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:O.value,outline:re?`2px solid ${O.value}`:"none",outlineOffset:"2px",pointerEvents:"none",display:"block"}})},O.value)})})})})]})})]}),m.length>0||d?jsxRuntime.jsx(Vr,{selectedTags:$.tags||[],availableTags:m,onChange:O=>Me("tags",O),onCreateTag:d,theme:g,disabled:l}):null]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"w-4 h-4",style:{color:g.textTertiary}}),jsxRuntime.jsxs("div",{ref:J,className:"flex items-center gap-2 flex-1 relative",children:[jsxRuntime.jsx("button",{type:"button",onClick:()=>{if(!l&&!$.isMilestone)if(w==="start")R(null);else {if(J.current){let O=J.current.getBoundingClientRect(),re=window.innerHeight,pe=320,Ee=re-O.bottom<pe?O.top-pe-8:O.bottom+8;fe({top:Ee,left:O.left});}R("start"),G($.startDate||new Date);}},className:"px-3 py-1.5 rounded-lg text-sm transition-colors",style:{...lt,opacity:$.isMilestone?.5:1,cursor:$.isMilestone?"not-allowed":"pointer"},disabled:l||$.isMilestone,children:$.startDate?$.startDate.toLocaleDateString("es-ES",{day:"numeric",month:"short"}):"Inicio"}),jsxRuntime.jsx("span",{style:{color:g.textTertiary},children:"\u2192"}),jsxRuntime.jsx("button",{type:"button",onClick:()=>{if(!l&&!$.isMilestone)if(w==="end")R(null);else {if(J.current){let O=J.current.getBoundingClientRect(),re=window.innerHeight,pe=320,Ee=re-O.bottom<pe?O.top-pe-8:O.bottom+8;fe({top:Ee,left:O.left});}R("end"),G($.endDate||$.startDate||new Date);}},className:"px-3 py-1.5 rounded-lg text-sm transition-colors",style:{...lt,opacity:$.isMilestone?.5:1,cursor:$.isMilestone?"not-allowed":"pointer"},disabled:l||$.isMilestone,children:$.endDate?$.endDate.toLocaleDateString("es-ES",{day:"numeric",month:"short"}):"Fin"}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:w&&jsxRuntime.jsxs(rt,{children:[jsxRuntime.jsx("div",{className:"fixed inset-0",style:{zIndex:99998},onClick:()=>R(null)}),jsxRuntime.jsxs(framerMotion.motion.div,{initial:{opacity:0,y:-10},animate:{opacity:1,y:0},exit:{opacity:0,y:-10},className:"rounded-xl shadow-2xl overflow-hidden flex",style:{position:"fixed",top:`${X.top}px`,left:`${X.left}px`,zIndex:99999,backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},onClick:O=>O.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"w-40 py-2",style:{borderRight:`1px solid ${g.border}`},children:[(()=>{let O=new Date,re=new Date(O);re.setDate(O.getDate()+1);let pe=new Date(O);pe.setDate(O.getDate()+7);let Ce=new Date(O);return Ce.setDate(O.getDate()+14),[{label:"Hoy",date:O},{label:"Ma\xF1ana",date:re},{label:"Pr\xF3xima semana",date:pe},{label:"2 semanas",date:Ce}].map((tt,ut)=>jsxRuntime.jsx("button",{type:"button",className:"w-full px-3 py-2 text-sm text-left transition-colors",style:{color:g.textPrimary},onMouseEnter:Le=>Le.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:Le=>Le.currentTarget.style.backgroundColor="transparent",onClick:()=>{w==="start"?(Me("startDate",tt.date),(!$.endDate||tt.date>$.endDate)&&Me("endDate",tt.date),R("end")):(Me("endDate",tt.date),(!$.startDate||tt.date<$.startDate)&&Me("startDate",tt.date),R(null));},children:tt.label},ut))})(),jsxRuntime.jsx("div",{style:{borderTop:`1px solid ${g.border}`,margin:"0.5rem 0"}}),jsxRuntime.jsx("button",{type:"button",className:"w-full px-3 py-2 text-sm text-left transition-colors",style:{color:"#EF4444"},onMouseEnter:O=>O.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:O=>O.currentTarget.style.backgroundColor="transparent",onClick:()=>{Me("startDate",void 0),Me("endDate",void 0),R(null);},children:"Borrar fechas"})]}),jsxRuntime.jsxs("div",{className:"p-3",children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between mb-3",children:[jsxRuntime.jsx("button",{type:"button",onClick:()=>G(new Date(M.getFullYear(),M.getMonth()-1)),className:"p-1 rounded hover:bg-white/10",children:jsxRuntime.jsx(lucideReact.ChevronLeft,{className:"w-4 h-4",style:{color:g.textSecondary}})}),jsxRuntime.jsx("span",{className:"text-sm font-medium",style:{color:g.textPrimary},children:M.toLocaleDateString("es-ES",{month:"long",year:"numeric"})}),jsxRuntime.jsx("button",{type:"button",onClick:()=>G(new Date(M.getFullYear(),M.getMonth()+1)),className:"p-1 rounded hover:bg-white/10",children:jsxRuntime.jsx(lucideReact.ChevronRight,{className:"w-4 h-4",style:{color:g.textSecondary}})})]}),jsxRuntime.jsx("div",{className:"grid grid-cols-7 gap-1 mb-1",children:["D","L","M","M","J","V","S"].map((O,re)=>jsxRuntime.jsx("div",{className:"w-7 h-7 flex items-center justify-center text-xs",style:{color:g.textTertiary},children:O},re))}),jsxRuntime.jsx("div",{className:"grid grid-cols-7 gap-1",children:(()=>{let O=M.getFullYear(),re=M.getMonth(),pe=new Date(O,re,1).getDay(),Ce=new Date(O,re+1,0).getDate(),Ee=new Date,tt=[];for(let Le=pe-1;Le>=0;Le--)tt.push({day:new Date(O,re,-Le).getDate(),date:new Date(O,re-1,new Date(O,re,-Le).getDate()),isCurrentMonth:false});for(let Le=1;Le<=Ce;Le++)tt.push({day:Le,date:new Date(O,re,Le),isCurrentMonth:true});let ut=42-tt.length;for(let Le=1;Le<=ut;Le++)tt.push({day:Le,date:new Date(O,re+1,Le),isCurrentMonth:false});return tt.map((Le,I)=>{let q=Le.date.toDateString()===Ee.toDateString(),We=$.startDate?.toDateString()===Le.date.toDateString(),He=$.endDate?.toDateString()===Le.date.toDateString(),vt=$.startDate&&$.endDate&&Le.date>=$.startDate&&Le.date<=$.endDate;return jsxRuntime.jsx("button",{type:"button",className:"w-7 h-7 rounded-full flex items-center justify-center text-xs transition-colors",style:{color:Le.isCurrentMonth?We||He?"#FFF":g.textPrimary:g.textTertiary,backgroundColor:We?"#3B82F6":He?"#7C3AED":vt?"rgba(124, 58, 237, 0.2)":"transparent",boxShadow:q&&!We&&!He?"inset 0 0 0 1px #3B82F6":"none"},onClick:()=>{w==="start"?(Me("startDate",Le.date),$.endDate&&Le.date>$.endDate&&Me("endDate",Le.date),R("end")):(Me("endDate",Le.date),$.startDate&&Le.date<$.startDate&&Me("startDate",Le.date),R(null));},children:Le.day},I)})})()})]})]})]})})]}),ke.endDate&&jsxRuntime.jsx("span",{className:"text-xs text-red-400",children:ke.endDate})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(lucideReact.Clock,{className:"w-4 h-4",style:{color:g.textTertiary}}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3 flex-1",children:[jsxRuntime.jsx("input",{type:"range",min:"0",max:"100",step:"5",value:$.progress,onChange:O=>Me("progress",parseInt(O.target.value)),className:"flex-1 h-1.5 rounded-full appearance-none cursor-pointer",style:{backgroundColor:g.bgSecondary,accentColor:$.progress<30?"#EF4444":$.progress<70?"#F59E0B":"#10B981"},disabled:l}),jsxRuntime.jsxs("span",{className:"text-xs font-medium px-2 py-0.5 rounded-full min-w-[45px] text-center",style:{backgroundColor:`${$.progress<30?"#EF4444":$.progress<70?"#F59E0B":"#10B981"}20`,color:$.progress<30?"#EF4444":$.progress<70?"#F59E0B":"#10B981"},children:[$.progress,"%"]})]})]}),(u||i.length>0||c==="create")&&jsxRuntime.jsxs("div",{className:"pt-2",children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 mb-2",children:[jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",style:{color:g.textTertiary},children:jsxRuntime.jsx("path",{d:"M21.44 11.05l-9.19 9.19a6 6 0 01-8.49-8.49l9.19-9.19a4 4 0 015.66 5.66l-9.2 9.19a2 2 0 01-2.83-2.83l8.49-8.48"})}),jsxRuntime.jsxs("span",{className:"text-xs",style:{color:g.textTertiary},children:["Adjuntos ",c==="create"?Oe.length>0&&`(${Oe.length})`:i.length>0&&`(${i.length})`]})]}),c==="create"?jsxRuntime.jsx($a,{cardId:"pending",attachments:Oe.map((O,re)=>({id:`pending-${re}`,cardId:"pending",name:O.name,size:O.size,type:O.type,url:URL.createObjectURL(O),uploadedAt:new Date().toISOString(),uploadedBy:"current-user"})),onUpload:O=>z(re=>[...re,...O]),onDelete:O=>{let re=parseInt(O.replace("pending-",""),10);z(pe=>pe.filter((Ce,Ee)=>Ee!==re));},maxSizeMB:10,maxFiles:20}):jsxRuntime.jsx($a,{cardId:a?.id||"new",attachments:i,onUpload:u&&a?.id?O=>u(a.id,O):void 0,onDelete:x,maxSizeMB:10,maxFiles:20}),c==="create"&&Oe.length>0&&jsxRuntime.jsxs("p",{className:"text-xs mt-1",style:{color:g.textTertiary},children:[Oe.length," archivo(s) se subir\xE1n al crear la tarea"]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>Ie(!xe),className:"flex items-center gap-2 text-xs w-full py-2 transition-colors",style:{color:g.textTertiary},children:[jsxRuntime.jsx(lucideReact.ChevronDown,{className:`w-3 h-3 transition-transform ${xe?"rotate-180":""}`}),"Opciones avanzadas"]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:xe&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},className:"overflow-hidden",children:jsxRuntime.jsxs("div",{className:"pt-3 space-y-3",children:[jsxRuntime.jsxs("label",{className:"flex items-center gap-3 cursor-pointer p-2 rounded-lg transition-colors hover:bg-white/5",children:[jsxRuntime.jsx("input",{type:"checkbox",checked:$.isMilestone,onChange:O=>Me("isMilestone",O.target.checked),className:"w-4 h-4 rounded",style:{accentColor:g.accent},disabled:l}),jsxRuntime.jsx(lucideReact.Milestone,{className:"w-4 h-4 text-yellow-500"}),jsxRuntime.jsx("span",{className:"text-sm",style:{color:g.textPrimary},children:"Marcar como hito"})]}),r.length>0&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"flex items-center gap-2 text-xs mb-2",style:{color:g.textTertiary},children:[jsxRuntime.jsx(lucideReact.Link2,{className:"w-3.5 h-3.5"}),"Dependencias"]}),jsxRuntime.jsx("div",{className:"flex flex-wrap gap-1.5 max-h-24 overflow-y-auto p-2 rounded-lg",style:{backgroundColor:g.bgSecondary},children:r.filter(O=>O.id!==a?.id).map(O=>{let re=$.dependencies?.includes(O.id);return jsxRuntime.jsx("button",{type:"button",onClick:()=>{let pe=re?($.dependencies||[]).filter(Ce=>Ce!==O.id):[...$.dependencies||[],O.id];Me("dependencies",pe);},className:"px-2 py-1 rounded-full text-xs transition-colors",style:{backgroundColor:re?`${g.accent}30`:g.bgPrimary,color:re?g.accent:g.textSecondary,border:`1px solid ${re?g.accent:g.borderLight}`},disabled:l,children:O.name},O.id)})})]})]})})})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-end gap-2 px-5 py-3",style:{borderTop:`1px solid ${g.border}`},children:[jsxRuntime.jsx("button",{type:"button",onClick:t,className:"px-4 py-2 text-sm rounded-lg transition-colors",style:{color:g.textSecondary},onMouseEnter:O=>O.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:O=>O.currentTarget.style.backgroundColor="transparent",disabled:l,children:"Cancelar"}),jsxRuntime.jsx("button",{type:"submit",disabled:l,className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors flex items-center gap-2",style:{backgroundColor:g.accent,color:"#FFF"},onMouseEnter:O=>!l&&(O.currentTarget.style.opacity="0.9"),onMouseLeave:O=>!l&&(O.currentTarget.style.opacity="1"),children:l?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.jsx(jsxRuntime.Fragment,{children:c==="create"?"Crear tarea":"Guardar"})})]})]})]})})]})})}var Nf=['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"'],Yd=()=>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"})]}),Sf=()=>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"})}),Ef=()=>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"})}),Pf=()=>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"})}),Mf=()=>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 vn({tasks:e,theme:t,config:a,onTasksUpdate:r,onTaskUpdate:o,onTaskCreate:s,onTaskDelete:l,onDependencyCreate:c,onDependencyDelete:p}){let[n,m]=react.useState(false),[d,i]=react.useState(false),[u,x]=react.useState([]),[f,g]=react.useState(""),[k,h]=react.useState(false),[b,y]=react.useState(true),D=react.useRef(null),N=react.useRef(null),A=react.useRef(null),{enabled:v=true,placeholder:B='Ask AI to edit tasks... (e.g., "Move Design to next week")',position:T="bottom-right",onCommand:w,suggestions:R=Nf,maxHistory:M=50,persistHistory:G}=a,X=G?.storageKey||"gantt-ai-history",fe=G?.maxMessages??5;react.useEffect(()=>{if(G?.enabled)try{let H=localStorage.getItem(X);if(H){let Y=JSON.parse(H).map(J=>({...J,timestamp:new Date(J.timestamp)}));x(Y.slice(-fe));}}catch(H){console.warn("[GanttAIAssistant] Failed to load persisted history:",H);}},[G?.enabled,X,fe]),react.useEffect(()=>{if(G?.enabled&&u.length>0)try{let H=u.filter(P=>!P.isLoading).slice(-fe);localStorage.setItem(X,JSON.stringify(H));}catch(H){console.warn("[GanttAIAssistant] Failed to persist history:",H);}},[u,G?.enabled,X,fe]),react.useEffect(()=>{N.current&&N.current.scrollIntoView({behavior:"smooth"});},[u]),react.useEffect(()=>{n&&!d&&D.current&&setTimeout(()=>D.current?.focus(),100);},[n,d]);let xe=react.useCallback(H=>{if(H.success)switch(H.type){case "move_task":case "resize_task":case "rename_task":case "set_progress":case "set_status":case "assign_task":H.taskId&&H.updates&&o?.(H.taskId,H.updates);break;case "create_task":H.newTask&&s?.(H.newTask);break;case "delete_task":H.taskId&&l?.(H.taskId);break;case "link_tasks":H.dependencyFrom&&H.dependencyTo&&c?.(H.dependencyFrom,H.dependencyTo);break;case "unlink_tasks":H.taskId&&H.dependencyFrom&&p?.(H.taskId,H.dependencyFrom);break}},[o,s,l,c,p]),Ie=react.useCallback(async H=>{if(!H.trim()||k)return;let P={id:`user-${Date.now()}`,role:"user",content:H,timestamp:new Date};x(J=>[...J.slice(-(M-1)),P]),g(""),y(false),h(true);let Y={id:`loading-${Date.now()}`,role:"assistant",content:"",timestamp:new Date,isLoading:true};x(J=>[...J,Y]);try{if(w){let J=await w(H,e);x($=>{let Te=$.filter(Ue=>!Ue.isLoading),ke={id:`assistant-${Date.now()}`,role:"assistant",content:J.message,timestamp:new Date,command:J};return [...Te,ke]}),xe(J);}else x(J=>[...J.filter(Te=>!Te.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(J){x($=>[...$.filter(ke=>!ke.isLoading),{id:`error-${Date.now()}`,role:"assistant",content:`Sorry, I encountered an error: ${J instanceof Error?J.message:"Unknown error"}`,timestamp:new Date}]);}finally{h(false);}},[k,M,w,e,xe]),Oe=H=>{H.preventDefault(),Ie(f);},z=H=>{g(H),D.current?.focus();};if(react.useEffect(()=>{let H=P=>{(P.metaKey||P.ctrlKey)&&P.key==="k"&&(P.preventDefault(),m(Y=>!Y),n||i(false)),P.key==="Escape"&&n&&m(false);};return document.addEventListener("keydown",H),()=>document.removeEventListener("keydown",H)},[n]),react.useEffect(()=>{if(!n)return;let H=Y=>{let J=Y.target;A.current&&!A.current.contains(J)&&m(false);},P=setTimeout(()=>{document.addEventListener("mousedown",H);},100);return ()=>{clearTimeout(P),document.removeEventListener("mousedown",H);}},[n]),!v)return null;let F={"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(rt,{children:[jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!n&&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 ${F[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:()=>m(true),children:[jsxRuntime.jsx(Yd,{}),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:n&&jsxRuntime.jsxs(framerMotion.motion.div,{ref:A,initial:{opacity:0,y:20,scale:.95},animate:{opacity:1,y:0,scale:1,height:d?"auto":500},exit:{opacity:0,y:20,scale:.95},transition:{type:"spring",damping:25,stiffness:300},className:`fixed ${F[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(Yd,{}),jsxRuntime.jsx("span",{className:"font-semibold",children:"Gantt AI Assistant"})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("button",{onClick:()=>i(H=>!H),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(Pf,{})}),jsxRuntime.jsx("button",{onClick:()=>m(false),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(Ef,{})})]})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!d&&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:[u.length===0&&b&&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:R.slice(0,4).map((H,P)=>jsxRuntime.jsx("button",{onClick:()=>z(H),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:H.length>30?H.slice(0,30)+"...":H},P))})]}),u.map(H=>jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},className:`flex ${H.role==="user"?"justify-end":"justify-start"}`,children:jsxRuntime.jsxs("div",{className:`max-w-[85%] rounded-2xl px-4 py-2.5 ${H.role==="user"?"rounded-br-md":"rounded-bl-md"}`,style:{background:H.role==="user"?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":t.bgSecondary,color:H.role==="user"?"white":t.textPrimary},children:[H.isLoading?jsxRuntime.jsx(Mf,{}):jsxRuntime.jsx("p",{className:"text-sm whitespace-pre-wrap",children:H.content}),H.command&&jsxRuntime.jsxs("div",{className:"mt-2 text-xs px-2 py-1 rounded-md inline-flex items-center gap-1",style:{background:H.command.success?"rgba(16, 185, 129, 0.2)":"rgba(239, 68, 68, 0.2)",color:H.command.success?"#10B981":"#EF4444"},children:[H.command.success?"\u2713":"\u2717",jsxRuntime.jsx("span",{className:"capitalize",children:H.command.type.replace(/_/g," ")})]})]})},H.id)),jsxRuntime.jsx("div",{ref:N})]}),jsxRuntime.jsxs("form",{onSubmit:Oe,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:D,type:"text",value:f,onChange:H=>g(H.target.value),placeholder:B,disabled:k,className:"flex-1 bg-transparent text-sm outline-none",style:{color:t.textPrimary}}),jsxRuntime.jsx("button",{type:"submit",disabled:!f.trim()||k,className:"p-2 rounded-lg transition-all disabled:opacity-50",style:{background:f.trim()?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":"transparent",color:f.trim()?"white":t.textSecondary},children:jsxRuntime.jsx(Sf,{})})]}),jsxRuntime.jsx("p",{className:"text-[10px] text-center mt-2",style:{color:t.textTertiary},children:"Press Enter to send \u2022 Esc to close"})]})]})})]})})]})}function qd(e,t=50){let[a,r]=react.useState({past:[],present:e,future:[]}),o=react.useRef(false),s=react.useCallback((n,m=true)=>{r(d=>{let i=typeof n=="function"?n(d.present):n;if(o.current)return {...d,present:i};if(!m)return {...d,present:i};let u=[...d.past,d.present];return u.length>t&&u.shift(),{past:u,present:i,future:[]}});},[t]),l=react.useCallback(()=>{r(n=>{if(n.past.length===0)return n;let m=n.past[n.past.length-1],d=n.past.slice(0,n.past.length-1);return o.current=true,setTimeout(()=>{o.current=false;},0),{past:d,present:m,future:[n.present,...n.future]}});},[]),c=react.useCallback(()=>{r(n=>{if(n.future.length===0)return n;let m=n.future[0],d=n.future.slice(1);return o.current=true,setTimeout(()=>{o.current=false;},0),{past:[...n.past,n.present],present:m,future:d}});},[]),p=react.useCallback(()=>{r(n=>({past:[],present:n.present,future:[]}));},[]);return {state:a.present,setState:s,undo:l,redo:c,canUndo:a.past.length>0,canRedo:a.future.length>0,clearHistory:p}}function Xd({undo:e,redo:t,canUndo:a,canRedo:r,enabled:o=true}){react.useEffect(()=>{if(!o)return;let s=l=>{let c=navigator.platform.toUpperCase().indexOf("MAC")>=0,p=c?l.metaKey:l.ctrlKey;if(p&&l.key==="z"&&!l.shiftKey&&a){l.preventDefault(),e();return}if(r){if(!c&&p&&l.key==="y"){l.preventDefault(),t();return}if(c&&p&&l.shiftKey&&l.key==="z"){l.preventDefault(),t();return}}};return window.addEventListener("keydown",s),()=>{window.removeEventListener("keydown",s);}},[e,t,a,r,o]);}var Ff={taskTooltip:e=>{let t=[`<strong>${e.name}</strong>`];if(e.startDate&&e.endDate){t.push(`${le.formatDate(e.startDate)} - ${le.formatDate(e.endDate)}`);let a=le.calculateDuration(e.startDate,e.endDate);t.push(`Duration: ${a} 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 a=e.assignees.map(r=>r.name).join(", ");t.push(`Assigned: ${a}`);}return e.dependencies&&e.dependencies.length>0&&t.push(`Dependencies: ${e.dependencies.length}`),t.join("<br/>")},taskLabel:e=>e.name,gridCell:(e,t,a)=>a,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=>le.formatDate(e),durationFormat:e=>e===1?"1 day":`${e} days`,progressFormat:e=>`${e}%`};function Jd(e){return {...Ff,...e}}var Hf=e=>{switch(e){case "compact":return 44;case "comfortable":return 52;case "spacious":return 60;default:return 52}},ec=react.forwardRef(function({tasks:t,config:a={},onTasksChange:r},o){let{theme:s,timeScale:l="week",rowDensity:c="comfortable",showThemeSelector:p=true,showExportButton:n=true,availableUsers:m=[],templates:d,enableAutoCriticalPath:i=true,persistExpandedState:u,aiAssistant:x,locale:f="en",customTranslations:g,showCreateTaskButton:k=false,createTaskLabel:h,onCreateTask:b,onThemeChange:y,onTaskClick:D,onTaskDblClick:N,onTaskContextMenu:A,onTaskUpdate:v,onProgressChange:B,onTaskEdit:T,onTaskAddSubtask:w,onTaskMarkIncomplete:R,onTaskSetInProgress:M,onDependencyCreate:G,onDependencyDelete:X,onBeforeTaskAdd:fe,onAfterTaskAdd:xe,onBeforeTaskUpdate:Ie,onAfterTaskUpdate:Oe,onBeforeTaskDelete:z,onAfterTaskDelete:F}=a,P=react.useContext(tn)?.theme,[Y,J]=react.useState(P||s||"dark"),[$,Te]=react.useState(l),[ke,Ue]=react.useState(c),[he,et]=react.useState(1),[Me,Ze]=react.useState(0),[bt,St]=react.useState(false),[lt,O]=react.useState(null),[re,pe]=react.useState({isOpen:false,x:0,y:0,task:null}),[Ce,Ee]=react.useState(null),[tt,ut]=react.useState(null);react.useEffect(()=>{P&&P!==Y&&J(P);},[P]),react.useEffect(()=>{s&&s!==Y&&J(s);},[s]);let Le=react.useCallback(S=>{J(S),y?.(S);},[y]),{state:I,setState:q,undo:We,redo:He,canUndo:vt,canRedo:Q,clearHistory:oe}=qd(t,50),ye=react.useCallback(()=>u?typeof u=="string"?u:"gantt-expanded-tasks":null,[u]),we=react.useRef(new Map),ne=react.useRef(false);if(!ne.current&&u){ne.current=true;let S=typeof u=="string"?u:"gantt-expanded-tasks";try{let E=localStorage.getItem(S);if(E){let W=JSON.parse(E);Array.isArray(W)&&(we.current=new Map(W));}}catch(E){console.warn("[GanttBoard] Error loading expanded state from localStorage:",E);}}let Ne=react.useCallback(()=>{let S=ye();if(S)try{let E=Array.from(we.current.entries());localStorage.setItem(S,JSON.stringify(E));}catch(E){console.warn("[GanttBoard] Error saving expanded state to localStorage:",E);}},[ye]);react.useEffect(()=>{let S=E=>E.map(W=>{let ee=we.current.get(W.id),ce=ee!==void 0?{...W,isExpanded:ee}:W;return ce.subtasks?.length?{...ce,subtasks:S(ce.subtasks)}:ce});we.current.size>0?q(S(t)):q(t);},[t,q]);let be=react.useRef(t),De=react.useRef(true);react.useEffect(()=>{if(De.current){De.current=false,be.current=I;return}if(!r)return;let S=JSON.stringify(be.current),E=JSON.stringify(I);S!==E&&(be.current=I,r(I));},[I,r]);let ie=react.useMemo(()=>zs(f,g),[f,g]),Be=react.useCallback(S=>[{id:"name",label:S.columns.taskName,width:400,minWidth:200,maxWidth:2e3,visible:true,sortable:true,resizable:true},{id:"startDate",label:S.columns.startDate,width:110,minWidth:80,maxWidth:200,visible:false,sortable:true,resizable:true},{id:"endDate",label:S.columns.endDate,width:110,minWidth:80,maxWidth:200,visible:false,sortable:true,resizable:true},{id:"duration",label:S.columns.duration,width:80,minWidth:60,maxWidth:150,visible:false,sortable:true,resizable:true},{id:"assignees",label:S.columns.assignees,width:120,minWidth:80,maxWidth:300,visible:false,sortable:false,resizable:true},{id:"status",label:S.columns.status,width:100,minWidth:70,maxWidth:180,visible:false,sortable:true,resizable:true},{id:"progress",label:S.columns.progress,width:120,minWidth:80,maxWidth:200,visible:false,sortable:true,resizable:true},{id:"priority",label:S.columns.priority,width:90,minWidth:70,maxWidth:150,visible:false,sortable:true,resizable:true}],[]),[Ae,je]=react.useState(()=>Be(ie));react.useEffect(()=>{je(S=>S.map(E=>({...E,label:ie.columns[E.id==="name"?"taskName":E.id]||E.label})));},[ie]);let gt=react.useMemo(()=>Ae.filter(E=>E.visible).reduce((E,W)=>E+W.width,0),[Ae]),Vt=react.useRef(Ae.filter(S=>S.visible).map(S=>S.id).join(","));react.useEffect(()=>{let S=Ae.filter(ee=>ee.visible),E=S.map(ee=>ee.id).join(","),W=Vt.current;if(E!==W){let ee=S.some(ve=>ve.id!=="name"),ce=W.includes(",");ee?!ce&&ee&&O(null):O(null),Vt.current=E;}},[Ae]);let j=60,Z=.6,Se=react.useMemo(()=>{let E=gt+j,W=typeof window<"u"?window.innerWidth*Z:800,ee=Math.max(E,W);return lt!==null?Math.max(200,Math.min(lt,ee)):Math.max(200,E)},[lt,gt]),Ge=react.useRef(null),Re=react.useRef(null),U=react.useRef(null),K=react.useMemo(()=>fd(Y),[Y]),Pe=react.useMemo(()=>({theme:K,themeName:Y}),[K,Y]),xt=react.useMemo(()=>Jd(d),[d]),at=react.useMemo(()=>{if(!i)return I;let S=le.calculateCriticalPath(I),E=W=>W.map(ee=>({...ee,isCriticalPath:S.includes(ee.id),subtasks:ee.subtasks?E(ee.subtasks):void 0}));return E(I)},[I,i]),Wa=Hf(ke);Xd({undo:We,redo:He,canUndo:vt,canRedo:Q,enabled:true}),react.useImperativeHandle(o,()=>({getTask:S=>le.findTaskById(I,S),addTask:(S,E)=>{q(W=>{if(!E)return [...W,{...S,level:0}];let ee=ce=>ce.map(ve=>ve.id===E?{...ve,subtasks:[...ve.subtasks||[],{...S,parentId:E,level:(ve.level||0)+1}],isExpanded:true}:ve.subtasks?{...ve,subtasks:ee(ve.subtasks)}:ve);return ee(W)});},updateTask:(S,E)=>{q(W=>{let ee=ce=>ce.map(ve=>ve.id===S?{...ve,...E}:ve.subtasks?{...ve,subtasks:ee(ve.subtasks)}:ve);return ee(W)});},deleteTask:S=>{q(E=>{let W=ee=>ee.filter(ce=>ce.id===S?false:(ce.subtasks&&(ce.subtasks=W(ce.subtasks)),true));return W(E)});},deleteTasks:S=>{q(E=>Vs(E,S));},duplicateTask:S=>{q(E=>js(E,[S]));},splitTask:(S,E,W=3)=>{q(ee=>le.splitTask(ee,S,E,W));},calculateEndDate:le.calculateEndDate,calculateDuration:le.calculateDuration,validateDependency:(S,E)=>!le.validateDependencies(I,S,E),getAllTasks:()=>le.flattenTasks(I),getTasksByStatus:S=>le.flattenTasks(I).filter(E=>E.status===S),getTasksByParent:S=>S?le.findTaskById(I,S)?.subtasks||[]:I.filter(W=>!W.parentId),getCriticalPath:()=>le.flattenTasks(I).filter(S=>S.isCriticalPath),indentTask:S=>{q(E=>Ws(E,[S]));},outdentTask:S=>{q(E=>Gs(E,[S]));},moveTask:(S,E)=>{q(W=>_s(W,[S],E));},createSubtask:async S=>{let{tasks:E,newTask:W}=qs(I,S);if(fe){let ee=fe({...W,parentId:S});if((ee instanceof Promise?await ee:ee)===false)return}q(E),xe&&xe({...W,parentId:S});},scrollToTask:S=>{let W=le.flattenTasks(I).findIndex(ee=>ee.id===S);if(W!==-1&&Ge.current){let ee=W*Wa;Ge.current.scrollTo({top:ee,behavior:"smooth"}),Re.current&&Re.current.scrollTo({top:ee,behavior:"smooth"});}},highlightTask:(S,E=2e3)=>{},expandTask:S=>{q(E=>{let W=ee=>ee.map(ce=>ce.id===S?{...ce,isExpanded:true}:ce.subtasks?{...ce,subtasks:W(ce.subtasks)}:ce);return W(E)});},collapseTask:S=>{q(E=>{let W=ee=>ee.map(ce=>ce.id===S?{...ce,isExpanded:false}:ce.subtasks?{...ce,subtasks:W(ce.subtasks)}:ce);return W(E)});},expandAll:()=>{q(S=>{let E=W=>W.map(ee=>({...ee,isExpanded:true,subtasks:ee.subtasks?E(ee.subtasks):void 0}));return E(S)});},collapseAll:()=>{q(S=>{let E=W=>W.map(ee=>({...ee,isExpanded:false,subtasks:ee.subtasks?E(ee.subtasks):void 0}));return E(S)});},undo:We,redo:He,canUndo:()=>vt,canRedo:()=>Q,clearHistory:oe,exportToPNG:async()=>{if(!U.current||!Ge.current||!Re.current)throw new Error("Gantt container not found");let S=U.current,E=Ge.current.querySelector(".gantt-grid-scroll"),W=Re.current,ee=E?.scrollTop||0,ce=W.scrollTop,ve=S.style.overflow,dt=S.style.height;try{let $t=E?.querySelector(".gantt-taskgrid-content"),aa=W.querySelector("svg"),ra=$t?.scrollHeight||E?.scrollHeight||600,ma=aa?.getBoundingClientRect().height||W.scrollHeight,fr=(S.querySelector('[class*="h-12"]')?.offsetHeight||48)+Math.max(ra,ma)+20;E&&(E.scrollTop=0),W.scrollTop=0,S.style.overflow="visible",S.style.height=`${fr}px`,await new Promise(er=>setTimeout(er,100));let Qa=await Qd__default.default(S,{backgroundColor:K.bgPrimary,scale:2,logging:!1,useCORS:!0,ignoreElements:er=>{let zr=window.getComputedStyle(er),hr=parseInt(zr.zIndex,10);return !isNaN(hr)&&hr>=50||zr.position==="fixed"}});return new Promise((er,zr)=>{Qa.toBlob(hr=>{hr?er(hr):zr(new Error("Failed to create blob from canvas"));},"image/png");})}finally{S.style.overflow=ve,S.style.height=dt,E&&(E.scrollTop=ee),W.scrollTop=ce;}},exportToPDF:async S=>{await le.exportToPDF(I,S);},exportToExcel:async S=>{await le.exportToExcel(I,S);},exportToJSON:()=>le.exportToJSON(I),exportToCSV:()=>le.exportToCSV(I),importFromJSON:S=>{let E=le.importFromJSON(S);q(E);},getTasks:()=>I,refresh:()=>{q(S=>[...S]);},clearAll:()=>{q([]);}}),[I,We,He,vt,Q,oe,K,Wa]);let ur=react.useCallback(S=>{je(E=>E.map(W=>W.id===S?{...W,visible:!W.visible}:W));},[]),Xa=react.useCallback((S,E)=>{je(W=>W.map(ee=>{if(ee.id!==S)return ee;let ce=ee.minWidth??100,ve=ee.maxWidth??800,dt=Math.max(ce,Math.min(ve,E));return {...ee,width:dt}}));},[]),oo=react.useCallback(S=>{q(E=>{let W=Ys(E,S),ee=ce=>{for(let ve of ce){if(ve.id===S){we.current.set(S,ve.isExpanded??true);return}ve.subtasks?.length&&ee(ve.subtasks);}};return ee(W),Ne(),W}),a.onTaskToggleExpand?.(S);},[a,Ne]),de=react.useCallback((S,E)=>{if(Ie&&Ie(S,E)===false)return;let ee=le.findTaskById(I,S)?.progress,ce=dt=>dt.map($t=>$t.id===S?{...$t,...E}:$t.subtasks?{...$t,subtasks:ce($t.subtasks)}:$t);q(ce(I));let ve=le.findTaskById(ce(I),S);ve&&(v?.(ve),Oe?.(ve),E.progress!==void 0&&ee!==void 0&&E.progress!==ee&&B?.(S,ee,E.progress));},[I,v,Ie,Oe,B]),Et=react.useCallback(S=>{S.length!==0&&(q(E=>Ws(E,S)),a.onTaskIndent?.(S[0]));},[a]),Zt=react.useCallback(S=>{S.length!==0&&(q(E=>Gs(E,S)),a.onTaskOutdent?.(S[0]));},[a]),Rr=react.useCallback((S,E,W)=>{q(ee=>Bd(ee,S,E,W)),a.onTaskReparent?.(S,E,W);},[a]),Bo=react.useCallback((S,E)=>{S.length!==0&&(q(W=>_s(W,S,E)),a.onTaskMove?.(S[0],E));},[a]),Ja=react.useCallback(async S=>{let E=[];for(let W of S)z&&await Promise.resolve(z(W))===false||E.push(W);E.length!==0&&(a.onMultiTaskDelete?a.onMultiTaskDelete(E):(q(W=>Vs(W,E)),E.forEach(W=>a.onTaskDelete?.(W))),F&&E.forEach(W=>F(W)));},[a,z,F]),Ga=react.useCallback(S=>{q(E=>js(E,S)),S.forEach(E=>a.onTaskDuplicate?.(E));},[a]),gr=react.useCallback((S,E)=>{q(W=>{let{tasks:ee,newTask:ce}=Fd(W,S,E);return fe&&fe(ce)===false?W:(a.onTaskCreate?.(ce.parentId,ce.position||0),xe?.(ce),ee)});},[a,fe,xe]),Ot=react.useCallback((S,E)=>{q(W=>Ks(W,S,E)),a.onTaskRename?.(S,E);},[a]),no=react.useCallback(S=>{q(E=>{let{tasks:W}=qs(E,S);return a.onTaskCreate?.(S,0),W});},[a]),$n=react.useCallback((S,E,W)=>{let ee=S.startDate?Math.round((E.getTime()-S.startDate.getTime())/864e5):0,ce=$t=>$t.map(aa=>aa.id===S.id?{...aa,startDate:E,endDate:W,...S.segments&&{segments:S.segments}}:aa.subtasks?{...aa,subtasks:ce(aa.subtasks)}:aa),ve=ce(I);ve=le.autoScheduleDependents(ve,S.id,ee),q(ve);let dt={...S,startDate:E,endDate:W};v?.(dt);},[I,v]),Xi=react.useCallback((S,E)=>{A?.(S,E),pe({isOpen:true,x:E.clientX,y:E.clientY,task:S});},[A]),so=react.useCallback((S,E)=>{let W=le.splitTask(I,S.id,E);q(W),pe({isOpen:false,x:0,y:0,task:null});},[I]),Ji=react.useCallback(S=>{let E=le.findTaskById(I,S.id)||S;N?.(E),T||Ee(E);},[I,N,T]),Zi=react.useCallback((S,E,W)=>{let ee=new Map,ce=ra=>{ra.forEach(ma=>{ma.dependencies&&ee.set(ma.id,ma.dependencies),ma.subtasks&&ce(ma.subtasks);});};ce(W);let ve=ee.get(E)||[];ee.set(E,[...ve,S]);let dt=new Set,$t=new Set,aa=ra=>{if(!dt.has(ra)){dt.add(ra),$t.add(ra);let ma=ee.get(ra)||[];for(let Za of ma){if(!dt.has(Za)&&aa(Za))return true;if($t.has(Za))return true}}return $t.delete(ra),false};return aa(E)},[]),Qi=react.useCallback((S,E)=>{if(Zi(S.id,E,I)){console.warn("Cannot create dependency: would create a circular dependency"),alert(`Cannot create this dependency: it would create a circular dependency chain.
|
|
342
|
+
</Project>`,m=new Blob([n],{type:"application/xml;charset=utf-8;"}),d=document.createElement("a");d.href=URL.createObjectURL(m),d.download=a,d.click(),URL.revokeObjectURL(d.href);},calculateCriticalPath:e=>{let t=le.flattenTasks(e),a=t.filter(n=>n.startDate&&n.endDate);if(a.length===0)return [];let r=new Map,o=n=>{if(r.has(n.id))return;let m=n.startDate&&n.endDate?le.calculateDuration(n.startDate,n.endDate):0,d=0;if(n.dependencies&&n.dependencies.length>0)for(let u of n.dependencies){let x=t.find(f=>f.id===u);if(x){o(x);let f=r.get(u)?.ef||0;d=Math.max(d,f);}}let i=d+m;r.set(n.id,{es:d,ef:i});};a.forEach(o);let s=Math.max(...Array.from(r.values()).map(n=>n.ef)),l=new Map,c=n=>{if(l.has(n.id))return;let m=n.startDate&&n.endDate?le.calculateDuration(n.startDate,n.endDate):0,d=t.filter(x=>x.dependencies&&x.dependencies.includes(n.id)),i=s;if(d.length>0)for(let x of d){c(x);let f=l.get(x.id)?.ls||0;i=Math.min(i,f);}let u=i-m;l.set(n.id,{ls:u,lf:i});};a.forEach(c);let p=[];for(let n of a){let m=r.get(n.id),d=l.get(n.id);if(m&&d){let i=d.ls-m.es;Math.abs(i)<.01&&p.push(n.id);}}return p},calculateSlack:(e,t)=>{let a=le.findTaskById(e,t);if(!a||!a.startDate||!a.endDate)return null;if(le.calculateCriticalPath(e).includes(t))return 0;let o=le.getDependentTasks(e,t);if(o.length===0){let c=le.getLatestEndDate(e);if(!c)return null;let p=le.calculateDuration(a.endDate,c);return Math.max(0,p)}let s=o.filter(c=>c.startDate).map(c=>c.startDate.getTime()).sort((c,p)=>c-p)[0];if(!s)return null;let l=le.calculateDuration(a.endDate,new Date(s));return Math.max(0,l)},isOnCriticalPath:(e,t)=>le.calculateCriticalPath(e).includes(t),autoScheduleDependents:(e,t,a)=>{let r=le.findTaskById(e,t);if(!r||!r.endDate)return e;let o=le.getDependentTasks(e,t);if(o.length===0)return e;let s=[...e];for(let l of o){if(!l.startDate||!l.endDate)continue;let c=le.calculateDuration(l.startDate,l.endDate),p;a!==void 0?(p=new Date(l.startDate),p.setDate(p.getDate()+a)):(p=new Date(r.endDate),p.setDate(p.getDate()+1));let n=le.calculateEndDate(p,c),m=d=>d.map(i=>i.id===l.id?{...i,startDate:p,endDate:n}:i.subtasks?{...i,subtasks:m(i.subtasks)}:i);s=m(s),s=le.autoScheduleDependents(s,l.id,a);}return s},calculateCascadePreview:(e,t,a,r,o,s,l,c)=>{if(a===0)return [];let p=[],n=o.getTime(),m=1e3*60*60*24,d=le.findTaskById(e,t);if(!d||!d.endDate)return [];let i=(u,x,f=new Set)=>{if(f.has(u))return;f.add(u);let g=le.getDependentTasks(e,u);for(let k of g){if(!k.startDate||!k.endDate)continue;let h=r.findIndex(w=>w.id===k.id);if(h===-1)continue;let b=k.startDate.getTime(),D=(k.endDate.getTime()-b)/m,A=(b-n)/m*s,v=A+x*s,B=Math.max(D*s,s),T=c+h*l+12;p.push({taskId:k.id,taskName:k.name,originalX:A,previewX:v,width:B,y:T,rowIndex:h,daysDelta:x,color:k.color}),i(k.id,x,f);}};return i(t,a),p},splitTask:(e,t,a,r=3)=>{let o=le.findTaskById(e,t);if(!o||!o.startDate||!o.endDate)return e;if(a<=o.startDate||a>=o.endDate)return console.warn("Split date must be between task start and end dates"),e;let s=new Date(a);s.setDate(s.getDate()-1);let l=new Date(a);l.setDate(l.getDate()+r);let c=new Date(o.endDate);c.setDate(c.getDate()+r);let p=[{startDate:new Date(o.startDate),endDate:s},{startDate:l,endDate:c}],n=m=>m.map(d=>d.id===o.id?{...d,endDate:c,segments:p}:d.subtasks?{...d,subtasks:n(d.subtasks)}:d);return n(e)}};function hn({tasks:e,theme:t,rowHeight:a,timeScale:r,startDate:o,endDate:s,zoom:l,templates:c,onTaskClick:p,onTaskDblClick:n,onTaskContextMenu:m,onTaskDateChange:d,onDependencyCreate:i,onDependencyDelete:u}){let[f,g]=react.useState([]),[k,h]=react.useState(null),[b,y]=react.useState(null),D=react.useCallback(z=>{h(z);},[]),N=Math.ceil((s.getTime()-o.getTime())/(1e3*60*60*24)),A=r==="day"?60:r==="week"?20:8,v=N*A*l,B=z=>{let F=new Date(Date.UTC(z.getFullYear(),z.getMonth(),z.getDate())),H=F.getUTCDay()||7;F.setUTCDate(F.getUTCDate()+4-H);let P=new Date(Date.UTC(F.getUTCFullYear(),0,1));return Math.ceil(((F.getTime()-P.getTime())/864e5+1)/7)},T=z=>{let F=z.getDay();return F===0||F===6},w=react.useCallback(z=>{let F=Math.round(z/(A*l)),H=new Date(o);return H.setDate(H.getDate()+F),H},[o,A,l]),R=react.useCallback((z,F)=>{if(F.startDate&&F.endDate)return;let H=z.currentTarget.ownerSVGElement;if(!H)return;let P=H.createSVGPoint();P.x=z.clientX,P.y=z.clientY;let Y=P.matrixTransform(H.getScreenCTM()?.inverse()),J=w(Y.x),$=new Date(J);$.setDate($.getDate()+1),d?.(F,J,$);},[w,d]),M=react.useMemo(()=>{let z=Y=>Y.map(J=>{if(J.subtasks&&J.subtasks.length>0){let $=z(J.subtasks),Te=$.filter(ke=>ke.startDate&&ke.endDate);if(Te.length>0){let ke=Te.map(Me=>Me.startDate.getTime()),Ue=Te.map(Me=>Me.endDate.getTime()),he=new Date(Math.min(...ke)),et=new Date(Math.max(...Ue));return {...J,subtasks:$,startDate:he,endDate:et}}return {...J,subtasks:$}}return J}),F=(Y,J=[])=>{for(let $ of Y)J.push($),$.subtasks&&$.subtasks.length>0&&($.isExpanded===void 0||$.isExpanded)&&F($.subtasks,J);return J},H=z(e);return F(H)},[e]),G=react.useCallback(z=>{if(!z.startDate||!z.endDate)return {x:0,width:0};let F=z.startDate.getTime(),H=z.endDate.getTime(),P=o.getTime(),Y=(F-P)/(1e3*60*60*24),J=(H-F)/(1e3*60*60*24),$=Y*A*l,Te=Math.max(A*l,40),ke=Math.max(J*A*l,Te);return {x:$,width:ke}},[o,A,l]),X=react.useMemo(()=>M.filter(z=>z.startDate&&z.endDate).map(z=>{let{x:F,width:H}=G(z),Y=M.findIndex(J=>J.id===z.id)*a+12;return {id:z.id,x:F,y:Y,width:H,height:32}}),[M,G]),fe=react.useCallback((z,F,H)=>{if(!H||F===0){g([]);return}let P=le.calculateCascadePreview(e,z,F,M,o,A*l,a,48);g(P);},[e,M,o,A,l,a,48]),xe=react.useMemo(()=>{let z=[],F=new Date(o);for(;F<=s;){let Y=(F.getTime()-o.getTime())/864e5*A*l;if(r==="day")z.push({date:new Date(F),label:F.toLocaleDateString("en-US",{day:"numeric",month:"short"}),x:Y}),F.setDate(F.getDate()+1);else if(r==="week"){let J=B(F);z.push({date:new Date(F),label:`Week ${J}`,x:Y}),F.setDate(F.getDate()+7);}else z.push({date:new Date(F),label:F.toLocaleDateString("en-US",{month:"short",year:"numeric"}),x:Y}),F.setMonth(F.getMonth()+1);}return z},[o,s,r,A,l]),Ie=react.useMemo(()=>(new Date().getTime()-o.getTime())/(1e3*60*60*24)*A*l,[o,A,l]),Oe=Math.max(M.length*a,552);return jsxRuntime.jsxs("div",{className:"w-full h-full flex flex-col","data-gantt-chart":true,style:{backgroundColor:t.bgPrimary,overflow:"visible"},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(v,1e3),height:47,style:{display:"block"},children:[jsxRuntime.jsx("rect",{x:0,y:0,width:Math.max(v,1e3),height:48,fill:t.bgGrid}),xe.map((z,F)=>jsxRuntime.jsxs("g",{children:[F>0&&jsxRuntime.jsx("line",{x1:z.x,y1:0,x2:z.x,y2:48,stroke:t.border,strokeWidth:1,opacity:.1}),jsxRuntime.jsx("text",{x:z.x+8,y:48/2,fill:t.textTertiary,fontSize:"11",fontFamily:"'JetBrains Mono', ui-monospace, monospace",fontWeight:"500",dominantBaseline:"middle",children:z.label})]},`header-${F}`)),Ie>=0&&Ie<=v&&jsxRuntime.jsx("circle",{cx:Ie,cy:38,r:6,fill:t.today,opacity:1})]})}),jsxRuntime.jsxs("svg",{width:Math.max(v,1e3),height:Oe,style:{display:"block",flexShrink:0,overflow:"visible"},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(v,1e3),height:Oe,fill:t.bgPrimary}),xe.map((z,F)=>{let H=xe[F+1]?.x||v,P=T(z.date);return jsxRuntime.jsxs("g",{children:[P&&jsxRuntime.jsx("rect",{x:z.x,y:0,width:H-z.x,height:M.length*a,fill:t.bgWeekend,opacity:1}),F>0&&jsxRuntime.jsx("line",{x1:z.x,y1:0,x2:z.x,y2:M.length*a,stroke:t.border,strokeWidth:1,opacity:.1})]},F)}),M.map((z,F)=>{let H=z.startDate&&z.endDate;return jsxRuntime.jsxs("g",{children:[jsxRuntime.jsx("rect",{x:0,y:F*a,width:v,height:a,fill:F%2===0?t.bgPrimary:t.bgGrid,opacity:1,style:{pointerEvents:"none"}},`row-${z.id}`),!H&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("rect",{x:0,y:F*a,width:v,height:a,fill:"transparent",style:{cursor:"pointer",pointerEvents:"all"},onClick:P=>R(P,z),onMouseEnter:P=>{P.currentTarget.setAttribute("fill",t.accentLight),P.currentTarget.setAttribute("opacity","0.5");},onMouseLeave:P=>{P.currentTarget.setAttribute("fill","transparent"),P.currentTarget.setAttribute("opacity","1");}},`clickable-${z.id}`),jsxRuntime.jsx("text",{x:Ie>0?Ie:100,y:F*a+a/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-${z.id}`)]})]},`row-group-${z.id}`)}),M.map((z,F)=>!z.dependencies||z.dependencies.length===0||!z.startDate||!z.endDate?null:z.dependencies.map(H=>{let P=M.find(Te=>Te.id===H);if(!P||!P.startDate||!P.endDate)return null;let Y=M.findIndex(Te=>Te.id===H),J=G(P),$=G(z);return jsxRuntime.jsx(mn,{x1:J.x+J.width,y1:Y*a+a/2,x2:$.x,y2:F*a+a/2,theme:t},`dep-${H}-${z.id}`)})),M.map((z,F)=>{if(!z.startDate||!z.endDate)return null;let{x:H,width:P}=G(z),Y=F*a+12,J=z.subtasks&&z.subtasks.length>0&&!z.isMilestone;return z.isMilestone?jsxRuntime.jsx(gn,{task:z,x:H+P/2,y:Y+16,theme:t,onClick:p},z.id):J?jsxRuntime.jsxs("g",{onClick:()=>p?.(z),onContextMenu:$=>{$.preventDefault(),$.stopPropagation(),m?.(z,$);},style:{cursor:"default"},children:[jsxRuntime.jsx("rect",{x:H,y:Y,width:P,height:32,fill:t.primary,opacity:.25,rx:6}),jsxRuntime.jsx("line",{x1:H,y1:Y,x2:H+P,y2:Y,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:H,y1:Y,x2:H,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:H+P,y1:Y,x2:H+P,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:H,y1:Y+32,x2:H+P,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),P>60&&jsxRuntime.jsx("text",{x:H+12,y:Y+16,dominantBaseline:"middle",fill:"#FFFFFF",fontSize:"13",fontWeight:"500",fontFamily:"Inter, sans-serif",style:{pointerEvents:"none",userSelect:"none"},children:z.name})]},z.id):jsxRuntime.jsx(dn,{task:z,x:H,y:Y,width:P,theme:t,dayWidth:A*l,startDate:o,templates:c,onClick:p,onDoubleClick:n,onContextMenu:m,onDateChange:d,onDependencyCreate:i,allTaskPositions:X,onDragMove:fe,onHoverChange:D},z.id)}),M.map((z,F)=>!z.dependencies||z.dependencies.length===0||!z.startDate||!z.endDate?null:z.dependencies.map(H=>{let P=M.find(pe=>pe.id===H);if(!P||!P.startDate||!P.endDate)return null;let Y=M.findIndex(pe=>pe.id===H),J=G(P),$=G(z),Te=J.x+J.width,ke=Y*a+a/2,Ue=$.x,he=F*a+a/2,et=Ue-Te,Me=Te+et/2,Ze=pe=>{let Ce=1-pe,Ee=Ce*Ce,tt=Ee*Ce,ut=pe*pe,Le=ut*pe,I=tt*Te+3*Ee*pe*Me+3*Ce*ut*Me+Le*Ue,q=tt*ke+3*Ee*pe*ke+3*Ce*ut*he+Le*he;return {x:I,y:q}},bt=20,St=[];for(let pe=0;pe<=bt;pe++){let Ce=.1+pe/bt*.8;St.push(Ze(Ce));}let lt=St[0],O=`M ${lt.x} ${lt.y} `+St.slice(1).map(pe=>`L ${pe.x} ${pe.y}`).join(" ");return b&&b.x1===Te&&b.y1===ke&&b.x2===Ue&&b.y2===he?null:jsxRuntime.jsx("path",{d:O,fill:"none",stroke:"transparent",strokeWidth:12,strokeLinecap:"round",style:{cursor:"pointer"},onMouseEnter:()=>{y({x1:Te,y1:ke,x2:Ue,y2:he,onDelete:()=>u?.(z.id,H)});}},`dep-hover-${H}-${z.id}`)})),f.map(z=>jsxRuntime.jsxs("g",{style:{pointerEvents:"none"},children:[jsxRuntime.jsx("rect",{x:z.previewX,y:z.y-48,width:z.width,height:32,rx:8,fill:z.color||t.accent,opacity:.3,stroke:t.accent,strokeWidth:2,strokeDasharray:"4 2"}),Math.abs(z.daysDelta)>0&&jsxRuntime.jsx("text",{x:z.previewX+z.width/2,y:z.y-48+16,textAnchor:"middle",dominantBaseline:"middle",fill:t.accent,fontSize:"10",fontWeight:"600",fontFamily:"Inter, sans-serif",style:{userSelect:"none"},children:z.daysDelta>0?`+${z.daysDelta}d`:`${z.daysDelta}d`})]},`cascade-preview-${z.taskId}`)),b&&(()=>{let{x1:z,y1:F,x2:H,y2:P,onDelete:Y}=b,J=H-z,$=P-F,Te=z+J/2,ke=(F+P)/2,Ue=`M ${z} ${F} C ${Te} ${F}, ${Te} ${P}, ${H} ${P}`,he=6,et=Math.atan2($,J),Me=H-he*Math.cos(et-Math.PI/6),Ze=P-he*Math.sin(et-Math.PI/6),bt=H-he*Math.cos(et+Math.PI/6),St=P-he*Math.sin(et+Math.PI/6),lt=t.dependency,O="#f87171";return jsxRuntime.jsxs("g",{onMouseLeave:()=>y(null),children:[jsxRuntime.jsx("path",{d:Ue,fill:"none",stroke:"transparent",strokeWidth:50,strokeLinecap:"round",style:{cursor:"pointer"}}),jsxRuntime.jsx("circle",{cx:Te,cy:ke,r:25,fill:"transparent",style:{cursor:"pointer"}}),jsxRuntime.jsx("path",{d:Ue,fill:"none",stroke:lt,strokeWidth:8,strokeLinecap:"round",opacity:.15,style:{pointerEvents:"none",filter:"blur(4px)"}}),jsxRuntime.jsx("path",{d:Ue,fill:"none",stroke:lt,strokeWidth:2.5,strokeLinecap:"round",opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsx("path",{d:`M ${H} ${P} L ${Me} ${Ze} M ${H} ${P} L ${bt} ${St}`,fill:"none",stroke:lt,strokeWidth:2.5,strokeLinecap:"round",opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsx("circle",{cx:H,cy:P,r:4,fill:lt,opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsxs(framerMotion.motion.g,{initial:{opacity:0,scale:.8},animate:{opacity:1,scale:1},transition:{duration:.15,ease:"easeOut"},onClick:pe=>{pe.stopPropagation(),y(null),Y();},style:{cursor:"pointer"},children:[jsxRuntime.jsx("circle",{cx:Te,cy:ke,r:9,fill:"rgba(248, 113, 113, 0.15)",stroke:O,strokeWidth:1.5,style:{transition:"all 0.15s ease"}}),jsxRuntime.jsx("line",{x1:Te-3,y1:ke-3,x2:Te+3,y2:ke+3,stroke:O,strokeWidth:1.5,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:Te+3,y1:ke-3,x2:Te-3,y2:ke+3,stroke:O,strokeWidth:1.5,strokeLinecap:"round"})]})]})})(),Ie>=0&&Ie<=v&&jsxRuntime.jsx("line",{x1:Ie,y1:0,x2:Ie,y2:Oe,stroke:t.today,strokeWidth:1,opacity:1,style:{pointerEvents:"none"}}),k&&jsxRuntime.jsx(Gd,{tooltipData:k,theme:t})]})]})}var bn=[{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:"Coral",value:"#F97316",light:"#FB923C"},{name:"Magenta",value:"#E11D48",light:"#FB7185"}];var ei=[{id:"todo",title:"Por Hacer",color:"#6B7280"},{id:"in-progress",title:"En Progreso",color:"#F59E0B"},{id:"completed",title:"Completada",color:"#10B981"}],ti=[{id:"low",label:"Baja",color:"#10B981",icon:"\u{1F7E2}"},{id:"medium",label:"Media",color:"#F59E0B",icon:"\u{1F7E1}"},{id:"high",label:"Alta",color:"#F97316",icon:"\u{1F7E0}"},{id:"urgent",label:"Urgente",color:"#EF4444",icon:"\u{1F534}"}];function yn({isOpen:e,onClose:t,task:a,availableTasks:r=[],availableUsers:o=[],onSubmit:s,isLoading:l=false,mode:c=a?"edit":"create",theme:p="dark",customStatuses:n=[],availableTags:m=[],onCreateTag:d,attachments:i=[],onUploadAttachments:u,onDeleteAttachment:x}){let f=[...ei,...n.filter(O=>!ei.some(re=>re.id===O.id))],g=_e[p]||_e.dark,[k,h]=react.useState(false),[b,y]=react.useState(false),[D,N]=react.useState(false),[A,v]=react.useState(false),[B,T]=react.useState({top:0,left:0}),[w,R]=react.useState(null),[M,G]=react.useState(new Date),[X,fe]=react.useState({top:0,left:0}),[xe,Ie]=react.useState(false),[Oe,z]=react.useState([]),F=react.useRef(null),H=react.useRef(null),P=react.useRef(null),Y=react.useRef(null),J=react.useRef(null),[$,Te]=react.useState({name:"",description:"",progress:0,status:"todo",priority:"medium",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[],tags:[]}),[ke,Ue]=react.useState({});react.useEffect(()=>{a?(Te({name:a.name,description:a.description||"",startDate:a.startDate,endDate:a.endDate,progress:a.progress,status:a.status||"todo",priority:a.priority||"medium",isMilestone:a.isMilestone||false,color:a.color||"#6366F1",assignees:a.assignees||[],dependencies:a.dependencies||[],tags:a.tags||[]}),(a.dependencies&&a.dependencies.length>0||a.isMilestone)&&Ie(true)):(Te({name:"",description:"",progress:0,status:"todo",priority:"medium",isMilestone:false,color:"#6366F1",assignees:[],dependencies:[],pendingFiles:[],tags:[]}),Ie(false),z([]));},[a,e]),react.useEffect(()=>{let O=re=>{F.current&&!F.current.contains(re.target)&&h(false),H.current&&!H.current.contains(re.target)&&y(false),P.current&&!P.current.contains(re.target)&&N(false),Y.current&&!Y.current.contains(re.target)&&v(false);};return document.addEventListener("mousedown",O),()=>document.removeEventListener("mousedown",O)},[]);let he=()=>{let O={};return $.name.trim()||(O.name="El nombre es requerido"),$.startDate&&$.endDate&&$.startDate>$.endDate&&(O.endDate="La fecha de fin debe ser posterior a la de inicio"),Ue(O),Object.keys(O).length===0},et=async O=>{if(O.preventDefault(),!!he())try{let re=c==="create"&&Oe.length>0?{...$,pendingFiles:Oe}:$;await s(re),z([]),t();}catch(re){console.error("Error submitting task:",re);}},Me=(O,re)=>{Te(pe=>{let Ce={...pe,[O]:re};if(O==="status"){let Ee=re;Ee==="todo"?Ce.progress=0:Ee==="in-progress"?(pe.progress===0||pe.progress===100)&&(Ce.progress=50):Ee==="completed"||Ee==="closed"?Ce.progress=100:(Ee==="in-review"||Ee==="review")&&(Ce.progress=75);}if(O==="progress"){let Ee=typeof re=="number"?re:parseInt(re,10);Ee===100&&pe.status!=="completed"?Ce.status="completed":Ee>0&&Ee<100&&pe.status==="todo"?Ce.status="in-progress":Ee===0&&pe.status!=="todo"&&(Ce.status="todo");}return Ce}),ke[O]&&Ue(pe=>{let Ce={...pe};return delete Ce[O],Ce});},Ze=f.find(O=>O.id===$.status)??ei[0],bt=ti.find(O=>O.id===$.priority)??ti[1],St=bn.find(O=>O.value===$.color)??bn[0],lt={backgroundColor:g.bgSecondary,border:`1px solid ${g.borderLight}`,color:g.textPrimary};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/60 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:.15,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-xl rounded-xl shadow-2xl pointer-events-auto overflow-hidden","data-theme":p,style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},onClick:O=>O.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between px-5 py-3",style:{borderBottom:`1px solid ${g.border}`},children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx("div",{className:"w-3 h-3 rounded-full",style:{backgroundColor:Ze.color||g.accent}}),jsxRuntime.jsx("span",{className:"text-sm font-medium",style:{color:g.textSecondary},children:c==="create"?"Nueva tarea":"Editar tarea"})]}),jsxRuntime.jsx("button",{onClick:t,className:"p-1.5 rounded-lg transition-colors",style:{color:g.textTertiary},onMouseEnter:O=>{O.currentTarget.style.backgroundColor=g.hoverBg,O.currentTarget.style.color=g.textPrimary;},onMouseLeave:O=>{O.currentTarget.style.backgroundColor="transparent",O.currentTarget.style.color=g.textTertiary;},disabled:l,children:jsxRuntime.jsx(lucideReact.X,{className:"w-4 h-4"})})]}),jsxRuntime.jsxs("form",{onSubmit:et,className:"max-h-[calc(100vh-200px)] overflow-y-auto",children:[jsxRuntime.jsxs("div",{className:"p-5 space-y-4",children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("input",{type:"text",value:$.name,onChange:O=>Me("name",O.target.value),className:"w-full text-lg font-medium bg-transparent border-none focus:outline-none focus:ring-0 placeholder:opacity-50",style:{color:g.textPrimary},placeholder:"Nombre de la tarea",disabled:l,autoFocus:true}),ke.name&&jsxRuntime.jsxs("p",{className:"mt-1 text-xs text-red-400 flex items-center gap-1",children:[jsxRuntime.jsx(lucideReact.AlertCircle,{className:"w-3 h-3"}),ke.name]})]}),jsxRuntime.jsx("div",{children:jsxRuntime.jsx("textarea",{value:$.description||"",onChange:O=>Me("description",O.target.value),className:"w-full text-sm bg-transparent border-none focus:outline-none focus:ring-0 resize-none placeholder:opacity-40",style:{color:g.textSecondary},placeholder:"Agregar descripci\xF3n...",rows:2,disabled:l})}),jsxRuntime.jsx("div",{style:{borderTop:`1px solid ${g.borderLight}`}}),jsxRuntime.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[jsxRuntime.jsxs("div",{ref:F,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>!l&&h(!k),className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:{...lt,borderColor:Ze.color,backgroundColor:`${Ze.color}15`},disabled:l,children:[jsxRuntime.jsx(lucideReact.CircleDot,{className:"w-3.5 h-3.5",style:{color:Ze.color}}),jsxRuntime.jsx("span",{style:{color:Ze.color},children:Ze.title}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:Ze.color}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:k&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},className:"absolute left-0 top-full mt-1 z-50 min-w-[140px] rounded-lg shadow-xl overflow-hidden",style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},children:f.map(O=>jsxRuntime.jsxs("button",{type:"button",className:"w-full flex items-center gap-2 px-3 py-2 text-sm transition-colors",style:{color:g.textPrimary},onMouseEnter:re=>re.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:re=>re.currentTarget.style.backgroundColor="transparent",onClick:()=>{Me("status",O.id),h(false);},children:[jsxRuntime.jsx(lucideReact.CircleDot,{className:"w-3.5 h-3.5",style:{color:O.color}}),O.title,$.status===O.id&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5 ml-auto",style:{color:g.accent}})]},O.id))})})]}),jsxRuntime.jsxs("div",{ref:H,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>!l&&y(!b),className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:lt,disabled:l,children:[jsxRuntime.jsx(lucideReact.Flag,{className:"w-3.5 h-3.5",style:{color:bt.color}}),jsxRuntime.jsx("span",{children:bt.label}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:g.textTertiary}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:b&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},className:"absolute left-0 top-full mt-1 z-50 min-w-[130px] rounded-lg shadow-xl overflow-hidden",style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},children:ti.map(O=>jsxRuntime.jsxs("button",{type:"button",className:"w-full flex items-center gap-2 px-3 py-2 text-sm transition-colors",style:{color:g.textPrimary},onMouseEnter:re=>re.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:re=>re.currentTarget.style.backgroundColor="transparent",onClick:()=>{Me("priority",O.id),y(false);},children:[jsxRuntime.jsx("span",{children:O.icon}),O.label,$.priority===O.id&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5 ml-auto",style:{color:g.accent}})]},O.id))})})]}),o.length>0&&jsxRuntime.jsxs("div",{ref:P,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>!l&&N(!D),className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:lt,disabled:l,children:[$.assignees&&$.assignees.length>0?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{className:"flex -space-x-1",children:$.assignees.slice(0,3).map((O,re)=>jsxRuntime.jsx("div",{className:"w-5 h-5 rounded-full flex items-center justify-center text-[10px] text-white font-medium border-2",style:{backgroundColor:O.color||g.accent,borderColor:g.bgSecondary},children:O.initials},re))}),$.assignees.length>3&&jsxRuntime.jsxs("span",{style:{color:g.textTertiary},children:["+",$.assignees.length-3]})]}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(lucideReact.Users,{className:"w-3.5 h-3.5",style:{color:g.textTertiary}}),jsxRuntime.jsx("span",{style:{color:g.textTertiary},children:"Asignar"})]}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:g.textTertiary}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:D&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},className:"absolute left-0 top-full mt-1 z-50 min-w-[180px] max-h-[200px] overflow-y-auto rounded-lg shadow-xl",style:{backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},children:o.map(O=>{let re=$.assignees?.some(pe=>pe.name===O.name);return jsxRuntime.jsxs("button",{type:"button",className:"w-full flex items-center gap-2 px-3 py-2 text-sm transition-colors",style:{color:g.textPrimary},onMouseEnter:pe=>pe.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:pe=>pe.currentTarget.style.backgroundColor="transparent",onClick:()=>{let pe=re?($.assignees||[]).filter(Ce=>Ce.name!==O.name):[...$.assignees||[],{name:O.name,avatar:O.avatar,initials:O.name.split(" ").map(Ce=>Ce[0]).join("").toUpperCase().slice(0,2),color:g.accent}];Me("assignees",pe);},children:[jsxRuntime.jsx("div",{className:"w-6 h-6 rounded-full flex items-center justify-center text-xs text-white font-medium flex-shrink-0",style:{backgroundColor:g.accent},children:O.name.charAt(0).toUpperCase()}),jsxRuntime.jsx("span",{className:"truncate flex-1 text-left",children:O.name}),jsxRuntime.jsx("div",{className:"w-4 flex-shrink-0 flex justify-end",children:re&&jsxRuntime.jsx(lucideReact.Check,{className:"w-3.5 h-3.5",style:{color:g.accent}})})]},O.id)})})})]}),jsxRuntime.jsxs("div",{ref:Y,className:"relative",children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>{if(!l)if(A)v(false);else {if(Y.current){let O=Y.current.getBoundingClientRect(),re=window.innerHeight,pe=120,Ee=re-O.bottom<pe?O.top-pe-8:O.bottom+8;T({top:Ee,left:O.left});}v(true);}},className:"flex items-center gap-2 px-3 py-1.5 rounded-full text-sm transition-all hover:opacity-80",style:lt,disabled:l,children:[jsxRuntime.jsx("div",{className:"w-3.5 h-3.5 rounded-full",style:{backgroundColor:$.color}}),jsxRuntime.jsx("span",{children:St.name}),jsxRuntime.jsx(lucideReact.ChevronDown,{className:"w-3 h-3",style:{color:g.textTertiary}})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:A&&jsxRuntime.jsxs(rt,{children:[jsxRuntime.jsx("div",{className:"fixed inset-0",style:{zIndex:99998},onClick:()=>v(false)}),jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:-5},animate:{opacity:1,y:0},exit:{opacity:0,y:-5},transition:{duration:.12},className:"rounded-lg",style:{position:"fixed",top:`${B.top}px`,left:`${B.left}px`,zIndex:99999,backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`,boxShadow:"0 4px 20px rgba(0, 0, 0, 0.25)"},onClick:O=>O.stopPropagation(),children:jsxRuntime.jsx("div",{style:{padding:"6px 8px"},children:jsxRuntime.jsx("div",{style:{display:"grid",gridTemplateColumns:"repeat(6, 28px)",gap:"2px"},children:bn.slice(0,18).map(O=>{let re=$.color===O.value;return jsxRuntime.jsx("button",{type:"button",onClick:pe=>{pe.preventDefault(),pe.stopPropagation(),Me("color",O.value),v(false);},style:{width:"28px",height:"28px",borderRadius:"6px",backgroundColor:"transparent",cursor:"pointer",border:"none",display:"flex",alignItems:"center",justifyContent:"center",padding:0},title:O.name,children:jsxRuntime.jsx("span",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:O.value,outline:re?`2px solid ${O.value}`:"none",outlineOffset:"2px",pointerEvents:"none",display:"block"}})},O.value)})})})})]})})]}),m.length>0||d?jsxRuntime.jsx(Vr,{selectedTags:$.tags||[],availableTags:m,onChange:O=>Me("tags",O),onCreateTag:d,theme:g,disabled:l}):null]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(lucideReact.Calendar,{className:"w-4 h-4",style:{color:g.textTertiary}}),jsxRuntime.jsxs("div",{ref:J,className:"flex items-center gap-2 flex-1 relative",children:[jsxRuntime.jsx("button",{type:"button",onClick:()=>{if(!l&&!$.isMilestone)if(w==="start")R(null);else {if(J.current){let O=J.current.getBoundingClientRect(),re=window.innerHeight,pe=320,Ee=re-O.bottom<pe?O.top-pe-8:O.bottom+8;fe({top:Ee,left:O.left});}R("start"),G($.startDate||new Date);}},className:"px-3 py-1.5 rounded-lg text-sm transition-colors",style:{...lt,opacity:$.isMilestone?.5:1,cursor:$.isMilestone?"not-allowed":"pointer"},disabled:l||$.isMilestone,children:$.startDate?$.startDate.toLocaleDateString("es-ES",{day:"numeric",month:"short"}):"Inicio"}),jsxRuntime.jsx("span",{style:{color:g.textTertiary},children:"\u2192"}),jsxRuntime.jsx("button",{type:"button",onClick:()=>{if(!l&&!$.isMilestone)if(w==="end")R(null);else {if(J.current){let O=J.current.getBoundingClientRect(),re=window.innerHeight,pe=320,Ee=re-O.bottom<pe?O.top-pe-8:O.bottom+8;fe({top:Ee,left:O.left});}R("end"),G($.endDate||$.startDate||new Date);}},className:"px-3 py-1.5 rounded-lg text-sm transition-colors",style:{...lt,opacity:$.isMilestone?.5:1,cursor:$.isMilestone?"not-allowed":"pointer"},disabled:l||$.isMilestone,children:$.endDate?$.endDate.toLocaleDateString("es-ES",{day:"numeric",month:"short"}):"Fin"}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:w&&jsxRuntime.jsxs(rt,{children:[jsxRuntime.jsx("div",{className:"fixed inset-0",style:{zIndex:99998},onClick:()=>R(null)}),jsxRuntime.jsxs(framerMotion.motion.div,{initial:{opacity:0,y:-10},animate:{opacity:1,y:0},exit:{opacity:0,y:-10},className:"rounded-xl shadow-2xl overflow-hidden flex",style:{position:"fixed",top:`${X.top}px`,left:`${X.left}px`,zIndex:99999,backgroundColor:g.bgPrimary,border:`1px solid ${g.border}`},onClick:O=>O.stopPropagation(),children:[jsxRuntime.jsxs("div",{className:"w-40 py-2",style:{borderRight:`1px solid ${g.border}`},children:[(()=>{let O=new Date,re=new Date(O);re.setDate(O.getDate()+1);let pe=new Date(O);pe.setDate(O.getDate()+7);let Ce=new Date(O);return Ce.setDate(O.getDate()+14),[{label:"Hoy",date:O},{label:"Ma\xF1ana",date:re},{label:"Pr\xF3xima semana",date:pe},{label:"2 semanas",date:Ce}].map((tt,ut)=>jsxRuntime.jsx("button",{type:"button",className:"w-full px-3 py-2 text-sm text-left transition-colors",style:{color:g.textPrimary},onMouseEnter:Le=>Le.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:Le=>Le.currentTarget.style.backgroundColor="transparent",onClick:()=>{w==="start"?(Me("startDate",tt.date),(!$.endDate||tt.date>$.endDate)&&Me("endDate",tt.date),R("end")):(Me("endDate",tt.date),(!$.startDate||tt.date<$.startDate)&&Me("startDate",tt.date),R(null));},children:tt.label},ut))})(),jsxRuntime.jsx("div",{style:{borderTop:`1px solid ${g.border}`,margin:"0.5rem 0"}}),jsxRuntime.jsx("button",{type:"button",className:"w-full px-3 py-2 text-sm text-left transition-colors",style:{color:"#EF4444"},onMouseEnter:O=>O.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:O=>O.currentTarget.style.backgroundColor="transparent",onClick:()=>{Me("startDate",void 0),Me("endDate",void 0),R(null);},children:"Borrar fechas"})]}),jsxRuntime.jsxs("div",{className:"p-3",children:[jsxRuntime.jsxs("div",{className:"flex items-center justify-between mb-3",children:[jsxRuntime.jsx("button",{type:"button",onClick:()=>G(new Date(M.getFullYear(),M.getMonth()-1)),className:"p-1 rounded hover:bg-white/10",children:jsxRuntime.jsx(lucideReact.ChevronLeft,{className:"w-4 h-4",style:{color:g.textSecondary}})}),jsxRuntime.jsx("span",{className:"text-sm font-medium",style:{color:g.textPrimary},children:M.toLocaleDateString("es-ES",{month:"long",year:"numeric"})}),jsxRuntime.jsx("button",{type:"button",onClick:()=>G(new Date(M.getFullYear(),M.getMonth()+1)),className:"p-1 rounded hover:bg-white/10",children:jsxRuntime.jsx(lucideReact.ChevronRight,{className:"w-4 h-4",style:{color:g.textSecondary}})})]}),jsxRuntime.jsx("div",{className:"grid grid-cols-7 gap-1 mb-1",children:["D","L","M","M","J","V","S"].map((O,re)=>jsxRuntime.jsx("div",{className:"w-7 h-7 flex items-center justify-center text-xs",style:{color:g.textTertiary},children:O},re))}),jsxRuntime.jsx("div",{className:"grid grid-cols-7 gap-1",children:(()=>{let O=M.getFullYear(),re=M.getMonth(),pe=new Date(O,re,1).getDay(),Ce=new Date(O,re+1,0).getDate(),Ee=new Date,tt=[];for(let Le=pe-1;Le>=0;Le--)tt.push({day:new Date(O,re,-Le).getDate(),date:new Date(O,re-1,new Date(O,re,-Le).getDate()),isCurrentMonth:false});for(let Le=1;Le<=Ce;Le++)tt.push({day:Le,date:new Date(O,re,Le),isCurrentMonth:true});let ut=42-tt.length;for(let Le=1;Le<=ut;Le++)tt.push({day:Le,date:new Date(O,re+1,Le),isCurrentMonth:false});return tt.map((Le,I)=>{let q=Le.date.toDateString()===Ee.toDateString(),We=$.startDate?.toDateString()===Le.date.toDateString(),He=$.endDate?.toDateString()===Le.date.toDateString(),vt=$.startDate&&$.endDate&&Le.date>=$.startDate&&Le.date<=$.endDate;return jsxRuntime.jsx("button",{type:"button",className:"w-7 h-7 rounded-full flex items-center justify-center text-xs transition-colors",style:{color:Le.isCurrentMonth?We||He?"#FFF":g.textPrimary:g.textTertiary,backgroundColor:We?"#3B82F6":He?"#7C3AED":vt?"rgba(124, 58, 237, 0.2)":"transparent",boxShadow:q&&!We&&!He?"inset 0 0 0 1px #3B82F6":"none"},onClick:()=>{w==="start"?(Me("startDate",Le.date),$.endDate&&Le.date>$.endDate&&Me("endDate",Le.date),R("end")):(Me("endDate",Le.date),$.startDate&&Le.date<$.startDate&&Me("startDate",Le.date),R(null));},children:Le.day},I)})})()})]})]})]})})]}),ke.endDate&&jsxRuntime.jsx("span",{className:"text-xs text-red-400",children:ke.endDate})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3",children:[jsxRuntime.jsx(lucideReact.Clock,{className:"w-4 h-4",style:{color:g.textTertiary}}),jsxRuntime.jsxs("div",{className:"flex items-center gap-3 flex-1",children:[jsxRuntime.jsx("input",{type:"range",min:"0",max:"100",step:"5",value:$.progress,onChange:O=>Me("progress",parseInt(O.target.value)),className:"flex-1 h-1.5 rounded-full appearance-none cursor-pointer",style:{backgroundColor:g.bgSecondary,accentColor:$.progress<30?"#EF4444":$.progress<70?"#F59E0B":"#10B981"},disabled:l}),jsxRuntime.jsxs("span",{className:"text-xs font-medium px-2 py-0.5 rounded-full min-w-[45px] text-center",style:{backgroundColor:`${$.progress<30?"#EF4444":$.progress<70?"#F59E0B":"#10B981"}20`,color:$.progress<30?"#EF4444":$.progress<70?"#F59E0B":"#10B981"},children:[$.progress,"%"]})]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>Ie(!xe),className:"flex items-center gap-2 text-xs w-full py-2 transition-colors",style:{color:g.textTertiary},children:[jsxRuntime.jsx(lucideReact.ChevronDown,{className:`w-3 h-3 transition-transform ${xe?"rotate-180":""}`}),"Opciones avanzadas"]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:xe&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},className:"overflow-hidden",children:jsxRuntime.jsxs("div",{className:"pt-3 space-y-3",children:[(u||i.length>0||c==="create")&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("div",{className:"flex items-center gap-2 mb-2",children:[jsxRuntime.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",style:{color:g.textTertiary},children:jsxRuntime.jsx("path",{d:"M21.44 11.05l-9.19 9.19a6 6 0 01-8.49-8.49l9.19-9.19a4 4 0 015.66 5.66l-9.2 9.19a2 2 0 01-2.83-2.83l8.49-8.48"})}),jsxRuntime.jsxs("span",{className:"text-xs",style:{color:g.textTertiary},children:["Adjuntos ",c==="create"?Oe.length>0&&`(${Oe.length})`:i.length>0&&`(${i.length})`]})]}),c==="create"?jsxRuntime.jsx($a,{cardId:"pending",attachments:Oe.map((O,re)=>({id:`pending-${re}`,cardId:"pending",name:O.name,size:O.size,type:O.type,url:URL.createObjectURL(O),uploadedAt:new Date().toISOString(),uploadedBy:"current-user"})),onUpload:O=>z(re=>[...re,...O]),onDelete:O=>{let re=parseInt(O.replace("pending-",""),10);z(pe=>pe.filter((Ce,Ee)=>Ee!==re));},maxSizeMB:10,maxFiles:20}):jsxRuntime.jsx($a,{cardId:a?.id||"new",attachments:i,onUpload:u&&a?.id?O=>u(a.id,O):void 0,onDelete:x,maxSizeMB:10,maxFiles:20}),c==="create"&&Oe.length>0&&jsxRuntime.jsxs("p",{className:"text-xs mt-1",style:{color:g.textTertiary},children:[Oe.length," archivo(s) se subir\xE1n al crear la tarea"]})]}),jsxRuntime.jsxs("label",{className:"flex items-center gap-3 cursor-pointer p-2 rounded-lg transition-colors hover:bg-white/5",children:[jsxRuntime.jsx("input",{type:"checkbox",checked:$.isMilestone,onChange:O=>Me("isMilestone",O.target.checked),className:"w-4 h-4 rounded",style:{accentColor:g.accent},disabled:l}),jsxRuntime.jsx(lucideReact.Milestone,{className:"w-4 h-4 text-yellow-500"}),jsxRuntime.jsx("span",{className:"text-sm",style:{color:g.textPrimary},children:"Marcar como hito"})]}),r.length>0&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("label",{className:"flex items-center gap-2 text-xs mb-2",style:{color:g.textTertiary},children:[jsxRuntime.jsx(lucideReact.Link2,{className:"w-3.5 h-3.5"}),"Dependencias"]}),jsxRuntime.jsx("div",{className:"flex flex-wrap gap-1.5 max-h-24 overflow-y-auto p-2 rounded-lg",style:{backgroundColor:g.bgSecondary},children:r.filter(O=>O.id!==a?.id).map(O=>{let re=$.dependencies?.includes(O.id);return jsxRuntime.jsx("button",{type:"button",onClick:()=>{let pe=re?($.dependencies||[]).filter(Ce=>Ce!==O.id):[...$.dependencies||[],O.id];Me("dependencies",pe);},className:"px-2 py-1 rounded-full text-xs transition-colors",style:{backgroundColor:re?`${g.accent}30`:g.bgPrimary,color:re?g.accent:g.textSecondary,border:`1px solid ${re?g.accent:g.borderLight}`},disabled:l,children:O.name},O.id)})})]})]})})})]})]}),jsxRuntime.jsxs("div",{className:"flex items-center justify-end gap-2 px-5 py-3",style:{borderTop:`1px solid ${g.border}`},children:[jsxRuntime.jsx("button",{type:"button",onClick:t,className:"px-4 py-2 text-sm rounded-lg transition-colors",style:{color:g.textSecondary},onMouseEnter:O=>O.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:O=>O.currentTarget.style.backgroundColor="transparent",disabled:l,children:"Cancelar"}),jsxRuntime.jsx("button",{type:"submit",disabled:l,className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors flex items-center gap-2",style:{backgroundColor:g.accent,color:"#FFF"},onMouseEnter:O=>!l&&(O.currentTarget.style.opacity="0.9"),onMouseLeave:O=>!l&&(O.currentTarget.style.opacity="1"),children:l?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.jsx(jsxRuntime.Fragment,{children:c==="create"?"Crear tarea":"Guardar"})})]})]})]})})]})})}var Nf=['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"'],Yd=()=>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"})]}),Sf=()=>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"})}),Ef=()=>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"})}),Pf=()=>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"})}),Mf=()=>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 vn({tasks:e,theme:t,config:a,onTasksUpdate:r,onTaskUpdate:o,onTaskCreate:s,onTaskDelete:l,onDependencyCreate:c,onDependencyDelete:p}){let[n,m]=react.useState(false),[d,i]=react.useState(false),[u,x]=react.useState([]),[f,g]=react.useState(""),[k,h]=react.useState(false),[b,y]=react.useState(true),D=react.useRef(null),N=react.useRef(null),A=react.useRef(null),{enabled:v=true,placeholder:B='Ask AI to edit tasks... (e.g., "Move Design to next week")',position:T="bottom-right",onCommand:w,suggestions:R=Nf,maxHistory:M=50,persistHistory:G}=a,X=G?.storageKey||"gantt-ai-history",fe=G?.maxMessages??5;react.useEffect(()=>{if(G?.enabled)try{let H=localStorage.getItem(X);if(H){let Y=JSON.parse(H).map(J=>({...J,timestamp:new Date(J.timestamp)}));x(Y.slice(-fe));}}catch(H){console.warn("[GanttAIAssistant] Failed to load persisted history:",H);}},[G?.enabled,X,fe]),react.useEffect(()=>{if(G?.enabled&&u.length>0)try{let H=u.filter(P=>!P.isLoading).slice(-fe);localStorage.setItem(X,JSON.stringify(H));}catch(H){console.warn("[GanttAIAssistant] Failed to persist history:",H);}},[u,G?.enabled,X,fe]),react.useEffect(()=>{N.current&&N.current.scrollIntoView({behavior:"smooth"});},[u]),react.useEffect(()=>{n&&!d&&D.current&&setTimeout(()=>D.current?.focus(),100);},[n,d]);let xe=react.useCallback(H=>{if(H.success)switch(H.type){case "move_task":case "resize_task":case "rename_task":case "set_progress":case "set_status":case "assign_task":H.taskId&&H.updates&&o?.(H.taskId,H.updates);break;case "create_task":H.newTask&&s?.(H.newTask);break;case "delete_task":H.taskId&&l?.(H.taskId);break;case "link_tasks":H.dependencyFrom&&H.dependencyTo&&c?.(H.dependencyFrom,H.dependencyTo);break;case "unlink_tasks":H.taskId&&H.dependencyFrom&&p?.(H.taskId,H.dependencyFrom);break}},[o,s,l,c,p]),Ie=react.useCallback(async H=>{if(!H.trim()||k)return;let P={id:`user-${Date.now()}`,role:"user",content:H,timestamp:new Date};x(J=>[...J.slice(-(M-1)),P]),g(""),y(false),h(true);let Y={id:`loading-${Date.now()}`,role:"assistant",content:"",timestamp:new Date,isLoading:true};x(J=>[...J,Y]);try{if(w){let J=await w(H,e);x($=>{let Te=$.filter(Ue=>!Ue.isLoading),ke={id:`assistant-${Date.now()}`,role:"assistant",content:J.message,timestamp:new Date,command:J};return [...Te,ke]}),xe(J);}else x(J=>[...J.filter(Te=>!Te.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(J){x($=>[...$.filter(ke=>!ke.isLoading),{id:`error-${Date.now()}`,role:"assistant",content:`Sorry, I encountered an error: ${J instanceof Error?J.message:"Unknown error"}`,timestamp:new Date}]);}finally{h(false);}},[k,M,w,e,xe]),Oe=H=>{H.preventDefault(),Ie(f);},z=H=>{g(H),D.current?.focus();};if(react.useEffect(()=>{let H=P=>{(P.metaKey||P.ctrlKey)&&P.key==="k"&&(P.preventDefault(),m(Y=>!Y),n||i(false)),P.key==="Escape"&&n&&m(false);};return document.addEventListener("keydown",H),()=>document.removeEventListener("keydown",H)},[n]),react.useEffect(()=>{if(!n)return;let H=Y=>{let J=Y.target;A.current&&!A.current.contains(J)&&m(false);},P=setTimeout(()=>{document.addEventListener("mousedown",H);},100);return ()=>{clearTimeout(P),document.removeEventListener("mousedown",H);}},[n]),!v)return null;let F={"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(rt,{children:[jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!n&&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 ${F[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:()=>m(true),children:[jsxRuntime.jsx(Yd,{}),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:n&&jsxRuntime.jsxs(framerMotion.motion.div,{ref:A,initial:{opacity:0,y:20,scale:.95},animate:{opacity:1,y:0,scale:1,height:d?"auto":500},exit:{opacity:0,y:20,scale:.95},transition:{type:"spring",damping:25,stiffness:300},className:`fixed ${F[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(Yd,{}),jsxRuntime.jsx("span",{className:"font-semibold",children:"Gantt AI Assistant"})]}),jsxRuntime.jsxs("div",{className:"flex items-center gap-1",children:[jsxRuntime.jsx("button",{onClick:()=>i(H=>!H),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(Pf,{})}),jsxRuntime.jsx("button",{onClick:()=>m(false),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(Ef,{})})]})]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:!d&&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:[u.length===0&&b&&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:R.slice(0,4).map((H,P)=>jsxRuntime.jsx("button",{onClick:()=>z(H),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:H.length>30?H.slice(0,30)+"...":H},P))})]}),u.map(H=>jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},className:`flex ${H.role==="user"?"justify-end":"justify-start"}`,children:jsxRuntime.jsxs("div",{className:`max-w-[85%] rounded-2xl px-4 py-2.5 ${H.role==="user"?"rounded-br-md":"rounded-bl-md"}`,style:{background:H.role==="user"?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":t.bgSecondary,color:H.role==="user"?"white":t.textPrimary},children:[H.isLoading?jsxRuntime.jsx(Mf,{}):jsxRuntime.jsx("p",{className:"text-sm whitespace-pre-wrap",children:H.content}),H.command&&jsxRuntime.jsxs("div",{className:"mt-2 text-xs px-2 py-1 rounded-md inline-flex items-center gap-1",style:{background:H.command.success?"rgba(16, 185, 129, 0.2)":"rgba(239, 68, 68, 0.2)",color:H.command.success?"#10B981":"#EF4444"},children:[H.command.success?"\u2713":"\u2717",jsxRuntime.jsx("span",{className:"capitalize",children:H.command.type.replace(/_/g," ")})]})]})},H.id)),jsxRuntime.jsx("div",{ref:N})]}),jsxRuntime.jsxs("form",{onSubmit:Oe,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:D,type:"text",value:f,onChange:H=>g(H.target.value),placeholder:B,disabled:k,className:"flex-1 bg-transparent text-sm outline-none",style:{color:t.textPrimary}}),jsxRuntime.jsx("button",{type:"submit",disabled:!f.trim()||k,className:"p-2 rounded-lg transition-all disabled:opacity-50",style:{background:f.trim()?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":"transparent",color:f.trim()?"white":t.textSecondary},children:jsxRuntime.jsx(Sf,{})})]}),jsxRuntime.jsx("p",{className:"text-[10px] text-center mt-2",style:{color:t.textTertiary},children:"Press Enter to send \u2022 Esc to close"})]})]})})]})})]})}function qd(e,t=50){let[a,r]=react.useState({past:[],present:e,future:[]}),o=react.useRef(false),s=react.useCallback((n,m=true)=>{r(d=>{let i=typeof n=="function"?n(d.present):n;if(o.current)return {...d,present:i};if(!m)return {...d,present:i};let u=[...d.past,d.present];return u.length>t&&u.shift(),{past:u,present:i,future:[]}});},[t]),l=react.useCallback(()=>{r(n=>{if(n.past.length===0)return n;let m=n.past[n.past.length-1],d=n.past.slice(0,n.past.length-1);return o.current=true,setTimeout(()=>{o.current=false;},0),{past:d,present:m,future:[n.present,...n.future]}});},[]),c=react.useCallback(()=>{r(n=>{if(n.future.length===0)return n;let m=n.future[0],d=n.future.slice(1);return o.current=true,setTimeout(()=>{o.current=false;},0),{past:[...n.past,n.present],present:m,future:d}});},[]),p=react.useCallback(()=>{r(n=>({past:[],present:n.present,future:[]}));},[]);return {state:a.present,setState:s,undo:l,redo:c,canUndo:a.past.length>0,canRedo:a.future.length>0,clearHistory:p}}function Xd({undo:e,redo:t,canUndo:a,canRedo:r,enabled:o=true}){react.useEffect(()=>{if(!o)return;let s=l=>{let c=navigator.platform.toUpperCase().indexOf("MAC")>=0,p=c?l.metaKey:l.ctrlKey;if(p&&l.key==="z"&&!l.shiftKey&&a){l.preventDefault(),e();return}if(r){if(!c&&p&&l.key==="y"){l.preventDefault(),t();return}if(c&&p&&l.shiftKey&&l.key==="z"){l.preventDefault(),t();return}}};return window.addEventListener("keydown",s),()=>{window.removeEventListener("keydown",s);}},[e,t,a,r,o]);}var Ff={taskTooltip:e=>{let t=[`<strong>${e.name}</strong>`];if(e.startDate&&e.endDate){t.push(`${le.formatDate(e.startDate)} - ${le.formatDate(e.endDate)}`);let a=le.calculateDuration(e.startDate,e.endDate);t.push(`Duration: ${a} 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 a=e.assignees.map(r=>r.name).join(", ");t.push(`Assigned: ${a}`);}return e.dependencies&&e.dependencies.length>0&&t.push(`Dependencies: ${e.dependencies.length}`),t.join("<br/>")},taskLabel:e=>e.name,gridCell:(e,t,a)=>a,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=>le.formatDate(e),durationFormat:e=>e===1?"1 day":`${e} days`,progressFormat:e=>`${e}%`};function Jd(e){return {...Ff,...e}}var Hf=e=>{switch(e){case "compact":return 44;case "comfortable":return 52;case "spacious":return 60;default:return 52}},ec=react.forwardRef(function({tasks:t,config:a={},onTasksChange:r},o){let{theme:s,timeScale:l="week",rowDensity:c="comfortable",showThemeSelector:p=true,showExportButton:n=true,availableUsers:m=[],templates:d,enableAutoCriticalPath:i=true,persistExpandedState:u,aiAssistant:x,locale:f="en",customTranslations:g,showCreateTaskButton:k=false,createTaskLabel:h,onCreateTask:b,onThemeChange:y,onTaskClick:D,onTaskDblClick:N,onTaskContextMenu:A,onTaskUpdate:v,onProgressChange:B,onTaskEdit:T,onTaskAddSubtask:w,onTaskMarkIncomplete:R,onTaskSetInProgress:M,onDependencyCreate:G,onDependencyDelete:X,onBeforeTaskAdd:fe,onAfterTaskAdd:xe,onBeforeTaskUpdate:Ie,onAfterTaskUpdate:Oe,onBeforeTaskDelete:z,onAfterTaskDelete:F}=a,P=react.useContext(tn)?.theme,[Y,J]=react.useState(P||s||"dark"),[$,Te]=react.useState(l),[ke,Ue]=react.useState(c),[he,et]=react.useState(1),[Me,Ze]=react.useState(0),[bt,St]=react.useState(false),[lt,O]=react.useState(null),[re,pe]=react.useState({isOpen:false,x:0,y:0,task:null}),[Ce,Ee]=react.useState(null),[tt,ut]=react.useState(null);react.useEffect(()=>{P&&P!==Y&&J(P);},[P]),react.useEffect(()=>{s&&s!==Y&&J(s);},[s]);let Le=react.useCallback(S=>{J(S),y?.(S);},[y]),{state:I,setState:q,undo:We,redo:He,canUndo:vt,canRedo:Q,clearHistory:oe}=qd(t,50),ye=react.useCallback(()=>u?typeof u=="string"?u:"gantt-expanded-tasks":null,[u]),we=react.useRef(new Map),ne=react.useRef(false);if(!ne.current&&u){ne.current=true;let S=typeof u=="string"?u:"gantt-expanded-tasks";try{let E=localStorage.getItem(S);if(E){let W=JSON.parse(E);Array.isArray(W)&&(we.current=new Map(W));}}catch(E){console.warn("[GanttBoard] Error loading expanded state from localStorage:",E);}}let Ne=react.useCallback(()=>{let S=ye();if(S)try{let E=Array.from(we.current.entries());localStorage.setItem(S,JSON.stringify(E));}catch(E){console.warn("[GanttBoard] Error saving expanded state to localStorage:",E);}},[ye]);react.useEffect(()=>{let S=E=>E.map(W=>{let ee=we.current.get(W.id),ce=ee!==void 0?{...W,isExpanded:ee}:W;return ce.subtasks?.length?{...ce,subtasks:S(ce.subtasks)}:ce});we.current.size>0?q(S(t)):q(t);},[t,q]);let be=react.useRef(t),De=react.useRef(true);react.useEffect(()=>{if(De.current){De.current=false,be.current=I;return}if(!r)return;let S=JSON.stringify(be.current),E=JSON.stringify(I);S!==E&&(be.current=I,r(I));},[I,r]);let ie=react.useMemo(()=>zs(f,g),[f,g]),Be=react.useCallback(S=>[{id:"name",label:S.columns.taskName,width:400,minWidth:200,maxWidth:2e3,visible:true,sortable:true,resizable:true},{id:"startDate",label:S.columns.startDate,width:110,minWidth:80,maxWidth:200,visible:false,sortable:true,resizable:true},{id:"endDate",label:S.columns.endDate,width:110,minWidth:80,maxWidth:200,visible:false,sortable:true,resizable:true},{id:"duration",label:S.columns.duration,width:80,minWidth:60,maxWidth:150,visible:false,sortable:true,resizable:true},{id:"assignees",label:S.columns.assignees,width:120,minWidth:80,maxWidth:300,visible:false,sortable:false,resizable:true},{id:"status",label:S.columns.status,width:100,minWidth:70,maxWidth:180,visible:false,sortable:true,resizable:true},{id:"progress",label:S.columns.progress,width:120,minWidth:80,maxWidth:200,visible:false,sortable:true,resizable:true},{id:"priority",label:S.columns.priority,width:90,minWidth:70,maxWidth:150,visible:false,sortable:true,resizable:true}],[]),[Ae,je]=react.useState(()=>Be(ie));react.useEffect(()=>{je(S=>S.map(E=>({...E,label:ie.columns[E.id==="name"?"taskName":E.id]||E.label})));},[ie]);let gt=react.useMemo(()=>Ae.filter(E=>E.visible).reduce((E,W)=>E+W.width,0),[Ae]),Vt=react.useRef(Ae.filter(S=>S.visible).map(S=>S.id).join(","));react.useEffect(()=>{let S=Ae.filter(ee=>ee.visible),E=S.map(ee=>ee.id).join(","),W=Vt.current;if(E!==W){let ee=S.some(ve=>ve.id!=="name"),ce=W.includes(",");ee?!ce&&ee&&O(null):O(null),Vt.current=E;}},[Ae]);let j=60,Z=.6,Se=react.useMemo(()=>{let E=gt+j,W=typeof window<"u"?window.innerWidth*Z:800,ee=Math.max(E,W);return lt!==null?Math.max(200,Math.min(lt,ee)):Math.max(200,E)},[lt,gt]),Ge=react.useRef(null),Re=react.useRef(null),U=react.useRef(null),K=react.useMemo(()=>fd(Y),[Y]),Pe=react.useMemo(()=>({theme:K,themeName:Y}),[K,Y]),xt=react.useMemo(()=>Jd(d),[d]),at=react.useMemo(()=>{if(!i)return I;let S=le.calculateCriticalPath(I),E=W=>W.map(ee=>({...ee,isCriticalPath:S.includes(ee.id),subtasks:ee.subtasks?E(ee.subtasks):void 0}));return E(I)},[I,i]),Wa=Hf(ke);Xd({undo:We,redo:He,canUndo:vt,canRedo:Q,enabled:true}),react.useImperativeHandle(o,()=>({getTask:S=>le.findTaskById(I,S),addTask:(S,E)=>{q(W=>{if(!E)return [...W,{...S,level:0}];let ee=ce=>ce.map(ve=>ve.id===E?{...ve,subtasks:[...ve.subtasks||[],{...S,parentId:E,level:(ve.level||0)+1}],isExpanded:true}:ve.subtasks?{...ve,subtasks:ee(ve.subtasks)}:ve);return ee(W)});},updateTask:(S,E)=>{q(W=>{let ee=ce=>ce.map(ve=>ve.id===S?{...ve,...E}:ve.subtasks?{...ve,subtasks:ee(ve.subtasks)}:ve);return ee(W)});},deleteTask:S=>{q(E=>{let W=ee=>ee.filter(ce=>ce.id===S?false:(ce.subtasks&&(ce.subtasks=W(ce.subtasks)),true));return W(E)});},deleteTasks:S=>{q(E=>Vs(E,S));},duplicateTask:S=>{q(E=>js(E,[S]));},splitTask:(S,E,W=3)=>{q(ee=>le.splitTask(ee,S,E,W));},calculateEndDate:le.calculateEndDate,calculateDuration:le.calculateDuration,validateDependency:(S,E)=>!le.validateDependencies(I,S,E),getAllTasks:()=>le.flattenTasks(I),getTasksByStatus:S=>le.flattenTasks(I).filter(E=>E.status===S),getTasksByParent:S=>S?le.findTaskById(I,S)?.subtasks||[]:I.filter(W=>!W.parentId),getCriticalPath:()=>le.flattenTasks(I).filter(S=>S.isCriticalPath),indentTask:S=>{q(E=>Ws(E,[S]));},outdentTask:S=>{q(E=>Gs(E,[S]));},moveTask:(S,E)=>{q(W=>_s(W,[S],E));},createSubtask:async S=>{let{tasks:E,newTask:W}=qs(I,S);if(fe){let ee=fe({...W,parentId:S});if((ee instanceof Promise?await ee:ee)===false)return}q(E),xe&&xe({...W,parentId:S});},scrollToTask:S=>{let W=le.flattenTasks(I).findIndex(ee=>ee.id===S);if(W!==-1&&Ge.current){let ee=W*Wa;Ge.current.scrollTo({top:ee,behavior:"smooth"}),Re.current&&Re.current.scrollTo({top:ee,behavior:"smooth"});}},highlightTask:(S,E=2e3)=>{},expandTask:S=>{q(E=>{let W=ee=>ee.map(ce=>ce.id===S?{...ce,isExpanded:true}:ce.subtasks?{...ce,subtasks:W(ce.subtasks)}:ce);return W(E)});},collapseTask:S=>{q(E=>{let W=ee=>ee.map(ce=>ce.id===S?{...ce,isExpanded:false}:ce.subtasks?{...ce,subtasks:W(ce.subtasks)}:ce);return W(E)});},expandAll:()=>{q(S=>{let E=W=>W.map(ee=>({...ee,isExpanded:true,subtasks:ee.subtasks?E(ee.subtasks):void 0}));return E(S)});},collapseAll:()=>{q(S=>{let E=W=>W.map(ee=>({...ee,isExpanded:false,subtasks:ee.subtasks?E(ee.subtasks):void 0}));return E(S)});},undo:We,redo:He,canUndo:()=>vt,canRedo:()=>Q,clearHistory:oe,exportToPNG:async()=>{if(!U.current||!Ge.current||!Re.current)throw new Error("Gantt container not found");let S=U.current,E=Ge.current.querySelector(".gantt-grid-scroll"),W=Re.current,ee=E?.scrollTop||0,ce=W.scrollTop,ve=S.style.overflow,dt=S.style.height;try{let $t=E?.querySelector(".gantt-taskgrid-content"),aa=W.querySelector("svg"),ra=$t?.scrollHeight||E?.scrollHeight||600,ma=aa?.getBoundingClientRect().height||W.scrollHeight,fr=(S.querySelector('[class*="h-12"]')?.offsetHeight||48)+Math.max(ra,ma)+20;E&&(E.scrollTop=0),W.scrollTop=0,S.style.overflow="visible",S.style.height=`${fr}px`,await new Promise(er=>setTimeout(er,100));let Qa=await Qd__default.default(S,{backgroundColor:K.bgPrimary,scale:2,logging:!1,useCORS:!0,ignoreElements:er=>{let zr=window.getComputedStyle(er),hr=parseInt(zr.zIndex,10);return !isNaN(hr)&&hr>=50||zr.position==="fixed"}});return new Promise((er,zr)=>{Qa.toBlob(hr=>{hr?er(hr):zr(new Error("Failed to create blob from canvas"));},"image/png");})}finally{S.style.overflow=ve,S.style.height=dt,E&&(E.scrollTop=ee),W.scrollTop=ce;}},exportToPDF:async S=>{await le.exportToPDF(I,S);},exportToExcel:async S=>{await le.exportToExcel(I,S);},exportToJSON:()=>le.exportToJSON(I),exportToCSV:()=>le.exportToCSV(I),importFromJSON:S=>{let E=le.importFromJSON(S);q(E);},getTasks:()=>I,refresh:()=>{q(S=>[...S]);},clearAll:()=>{q([]);}}),[I,We,He,vt,Q,oe,K,Wa]);let ur=react.useCallback(S=>{je(E=>E.map(W=>W.id===S?{...W,visible:!W.visible}:W));},[]),Xa=react.useCallback((S,E)=>{je(W=>W.map(ee=>{if(ee.id!==S)return ee;let ce=ee.minWidth??100,ve=ee.maxWidth??800,dt=Math.max(ce,Math.min(ve,E));return {...ee,width:dt}}));},[]),oo=react.useCallback(S=>{q(E=>{let W=Ys(E,S),ee=ce=>{for(let ve of ce){if(ve.id===S){we.current.set(S,ve.isExpanded??true);return}ve.subtasks?.length&&ee(ve.subtasks);}};return ee(W),Ne(),W}),a.onTaskToggleExpand?.(S);},[a,Ne]),de=react.useCallback((S,E)=>{if(Ie&&Ie(S,E)===false)return;let ee=le.findTaskById(I,S)?.progress,ce=dt=>dt.map($t=>$t.id===S?{...$t,...E}:$t.subtasks?{...$t,subtasks:ce($t.subtasks)}:$t);q(ce(I));let ve=le.findTaskById(ce(I),S);ve&&(v?.(ve),Oe?.(ve),E.progress!==void 0&&ee!==void 0&&E.progress!==ee&&B?.(S,ee,E.progress));},[I,v,Ie,Oe,B]),Et=react.useCallback(S=>{S.length!==0&&(q(E=>Ws(E,S)),a.onTaskIndent?.(S[0]));},[a]),Zt=react.useCallback(S=>{S.length!==0&&(q(E=>Gs(E,S)),a.onTaskOutdent?.(S[0]));},[a]),Rr=react.useCallback((S,E,W)=>{q(ee=>Bd(ee,S,E,W)),a.onTaskReparent?.(S,E,W);},[a]),Bo=react.useCallback((S,E)=>{S.length!==0&&(q(W=>_s(W,S,E)),a.onTaskMove?.(S[0],E));},[a]),Ja=react.useCallback(async S=>{let E=[];for(let W of S)z&&await Promise.resolve(z(W))===false||E.push(W);E.length!==0&&(a.onMultiTaskDelete?a.onMultiTaskDelete(E):(q(W=>Vs(W,E)),E.forEach(W=>a.onTaskDelete?.(W))),F&&E.forEach(W=>F(W)));},[a,z,F]),Ga=react.useCallback(S=>{q(E=>js(E,S)),S.forEach(E=>a.onTaskDuplicate?.(E));},[a]),gr=react.useCallback((S,E)=>{q(W=>{let{tasks:ee,newTask:ce}=Fd(W,S,E);return fe&&fe(ce)===false?W:(a.onTaskCreate?.(ce.parentId,ce.position||0),xe?.(ce),ee)});},[a,fe,xe]),Ot=react.useCallback((S,E)=>{q(W=>Ks(W,S,E)),a.onTaskRename?.(S,E);},[a]),no=react.useCallback(S=>{q(E=>{let{tasks:W}=qs(E,S);return a.onTaskCreate?.(S,0),W});},[a]),$n=react.useCallback((S,E,W)=>{let ee=S.startDate?Math.round((E.getTime()-S.startDate.getTime())/864e5):0,ce=$t=>$t.map(aa=>aa.id===S.id?{...aa,startDate:E,endDate:W,...S.segments&&{segments:S.segments}}:aa.subtasks?{...aa,subtasks:ce(aa.subtasks)}:aa),ve=ce(I);ve=le.autoScheduleDependents(ve,S.id,ee),q(ve);let dt={...S,startDate:E,endDate:W};v?.(dt);},[I,v]),Xi=react.useCallback((S,E)=>{A?.(S,E),pe({isOpen:true,x:E.clientX,y:E.clientY,task:S});},[A]),so=react.useCallback((S,E)=>{let W=le.splitTask(I,S.id,E);q(W),pe({isOpen:false,x:0,y:0,task:null});},[I]),Ji=react.useCallback(S=>{let E=le.findTaskById(I,S.id)||S;N?.(E),T||Ee(E);},[I,N,T]),Zi=react.useCallback((S,E,W)=>{let ee=new Map,ce=ra=>{ra.forEach(ma=>{ma.dependencies&&ee.set(ma.id,ma.dependencies),ma.subtasks&&ce(ma.subtasks);});};ce(W);let ve=ee.get(E)||[];ee.set(E,[...ve,S]);let dt=new Set,$t=new Set,aa=ra=>{if(!dt.has(ra)){dt.add(ra),$t.add(ra);let ma=ee.get(ra)||[];for(let Za of ma){if(!dt.has(Za)&&aa(Za))return true;if($t.has(Za))return true}}return $t.delete(ra),false};return aa(E)},[]),Qi=react.useCallback((S,E)=>{if(Zi(S.id,E,I)){console.warn("Cannot create dependency: would create a circular dependency"),alert(`Cannot create this dependency: it would create a circular dependency chain.
|
|
343
343
|
|
|
344
344
|
Task dependencies must flow in one direction only.`);return}let W=ee=>ee.map(ce=>{if(ce.id===E){let ve=ce.dependencies||[];if(!ve.includes(S.id))return {...ce,dependencies:[...ve,S.id]}}return ce.subtasks?{...ce,subtasks:W(ce.subtasks)}:ce});q(W(I)),G?.(S.id,E);},[I,G,Zi]),el=react.useCallback((S,E)=>{let W=ee=>ee.map(ce=>{if(ce.id===S&&ce.dependencies){let ve=ce.dependencies.filter(dt=>dt!==E);return {...ce,dependencies:ve}}return ce.subtasks?{...ce,subtasks:W(ce.subtasks)}:ce});q(W(I)),X?.(S,E);},[I,X]),{startDate:gp,endDate:fp}=react.useMemo(()=>{let S=I.filter(ve=>ve.startDate&&ve.endDate);if(S.length===0){let ve=new Date,dt=new Date(ve);dt.setDate(dt.getDate()-30);let $t=new Date(ve);return $t.setDate($t.getDate()+60),{startDate:dt,endDate:$t}}let E=S.flatMap(ve=>[ve.startDate,ve.endDate]).filter(ve=>ve!==void 0),W=new Date(Math.min(...E.map(ve=>ve.getTime()))),ee=new Date(Math.max(...E.map(ve=>ve.getTime()))),ce=$==="day"?7:$==="week"?14:30;return W.setDate(W.getDate()-ce),ee.setDate(ee.getDate()+ce),{startDate:W,endDate:ee}},[I,$]),hp=react.useCallback(async()=>{if(!U.current||!Ge.current||!Re.current)return;await new Promise(fr=>setTimeout(fr,200));let S=U.current,E=Ge.current.querySelector(".gantt-grid-scroll"),W=Re.current,ee=E?.scrollTop||0,ce=E?.scrollLeft||0,ve=W.scrollTop,dt=W.scrollLeft,$t=S.style.overflow,aa=S.style.height,ra=E?.style.overflow||"",ma=W.style.overflow,Za=S.style.width,Ro=W.style.width;try{let fr=E?.querySelector(".gantt-taskgrid-content"),Qa=W.querySelector("svg"),er=Qa?.getAttribute("height")?parseInt(Qa.getAttribute("height"),10):Qa?.getBoundingClientRect().height||0,zr=fr?.scrollHeight||E?.scrollHeight||600,hr=Math.max(er,W.scrollHeight),tl=Qa?.getAttribute("width")?parseInt(Qa.getAttribute("width"),10):Qa?.getBoundingClientRect().width||W.scrollWidth,Cp=S.querySelector('[class*="h-12"]')?.offsetHeight||48,Un=Math.max(zr,hr,er),Hn=Cp+Un+50,Wn=(E?.offsetWidth||300)+tl+10;E&&(E.scrollTop=0,E.scrollLeft=0),W.scrollTop=0,W.scrollLeft=0,S.style.overflow="visible",S.style.height=`${Hn}px`,S.style.width=`${Wn}px`,E&&(E.style.overflow="visible",E.style.height=`${Un+50}px`),W.style.overflow="visible",W.style.height=`${Un+50}px`,W.style.width=`${tl+10}px`,await new Promise(_n=>setTimeout(_n,150));let Tp=await Qd__default.default(S,{backgroundColor:K.bgPrimary,scale:2,logging:!1,useCORS:!0,allowTaint:!0,width:Wn,height:Hn,windowWidth:Wn+100,windowHeight:Hn+100,scrollX:0,scrollY:0,ignoreElements:_n=>{let al=window.getComputedStyle(_n),rl=parseInt(al.zIndex,10);return !isNaN(rl)&&rl>=50||al.position==="fixed"}}),Gn=document.createElement("a");Gn.download=`gantt-chart-${new Date().toISOString().slice(0,10)}.png`,Gn.href=Tp.toDataURL("image/png"),Gn.click();}finally{S.style.overflow=$t,S.style.height=aa,S.style.width=Za,E&&(E.style.overflow=ra,E.style.height="",E.scrollTop=ee,E.scrollLeft=ce),W.style.overflow=ma,W.style.height="",W.style.width=Ro,W.scrollTop=ve,W.scrollLeft=dt;}},[K]),bp=react.useCallback(async()=>{await le.exportToPDF(I);},[I]),yp=react.useCallback(async()=>{await le.exportToExcel(I);},[I]),vp=react.useCallback(()=>{let S=le.exportToCSV(I),E=new Blob([S],{type:"text/csv;charset=utf-8;"}),W=document.createElement("a");W.href=URL.createObjectURL(E),W.download="gantt-chart.csv",W.click(),URL.revokeObjectURL(W.href);},[I]),xp=react.useCallback(()=>{let S=le.exportToJSON(I),E=new Blob([S],{type:"application/json;charset=utf-8;"}),W=document.createElement("a");W.href=URL.createObjectURL(E),W.download="gantt-chart.json",W.click(),URL.revokeObjectURL(W.href);},[I]),kp=react.useCallback(()=>{le.exportToMSProject(I,"Gantt Project","project.xml");},[I]),wp=S=>{S.preventDefault(),St(true);},Or=react.useRef(false);return react.useEffect(()=>{let S=Re.current,E=Ge.current?.querySelector(".gantt-grid-scroll");if(!S||!E)return;let W=()=>{if(Or.current)return;Or.current=true;let dt=S.scrollTop;Ze(dt),E.scrollTop=dt,requestAnimationFrame(()=>{Or.current=false;});},ee=()=>{if(Or.current)return;Or.current=true;let dt=E.scrollTop;Ze(dt),S.scrollTop=dt,requestAnimationFrame(()=>{Or.current=false;});},ce=dt=>{if(bt&&E){let aa=E.parentElement?.getBoundingClientRect()?.left||0,ra=dt.clientX-aa,ma=200,Za=gt+j,Ro=window.innerWidth*Z,fr=Math.max(Za,Ro);ra>=ma&&ra<=fr&&O(ra);}},ve=()=>{St(false);};return S.addEventListener("scroll",W),E.addEventListener("scroll",ee),document.addEventListener("mousemove",ce),document.addEventListener("mouseup",ve),()=>{S.removeEventListener("scroll",W),E.removeEventListener("scroll",ee),document.removeEventListener("mousemove",ce),document.removeEventListener("mouseup",ve);}},[bt,gt]),jsxRuntime.jsx(Xr.Provider,{value:ie,children:jsxRuntime.jsx(qn.Provider,{value:Pe,children:jsxRuntime.jsxs("div",{ref:U,className:"flex flex-col h-full w-full",style:{backgroundColor:K.bgPrimary,fontFamily:"Inter, sans-serif",minHeight:0,...a.disableScrollSync&&{scrollBehavior:"auto",overflowAnchor:"none"}},children:[jsxRuntime.jsx(rn,{theme:K,timeScale:$,onTimeScaleChange:Te,zoom:he,onZoomChange:et,currentTheme:Y,onThemeChange:Le,rowDensity:ke,onRowDensityChange:Ue,showThemeSelector:p,showCreateTaskButton:k,createTaskLabel:h,onCreateTask:b,onExportPNG:n?hp:void 0,onExportPDF:n?bp:void 0,onExportExcel:n?yp:void 0,onExportCSV:n?vp:void 0,onExportJSON:n?xp:void 0,onExportMSProject:n?kp:void 0}),jsxRuntime.jsxs("div",{ref:Ge,className:"flex-1 flex min-h-0",style:{overflow:"clip",overflowClipMargin:"100px"},children:[jsxRuntime.jsx("div",{className:"gantt-grid-scroll flex-shrink-0",style:{width:Se,overflowX:"auto",overflowY:"scroll",scrollbarWidth:"none",msOverflowStyle:"none"},children:jsxRuntime.jsx(ln,{tasks:at,theme:K,rowHeight:Wa,availableUsers:m,templates:xt,onTaskClick:D,onTaskDblClick:Ji,onTaskContextMenu:A,onTaskToggle:oo,scrollTop:Me,columns:Ae,onToggleColumn:ur,onColumnResize:Xa,onTaskUpdate:de,onTaskIndent:Et,onTaskOutdent:Zt,onTaskMove:Bo,onMultiTaskDelete:Ja,onTaskDuplicate:Ga,onTaskCreate:gr,onTaskRename:Ot,onCreateSubtask:no,onOpenTaskModal:D?S=>D(S):void 0,onDeleteRequest:(S,E)=>ut({taskId:S,taskName:E}),onTaskReparent:Rr})}),jsxRuntime.jsx("div",{className:"flex-shrink-0 cursor-col-resize hover:bg-blue-500/50 transition-colors h-full",style:{width:1,backgroundColor:K.border,zIndex:15},onMouseDown:wp}),jsxRuntime.jsx("div",{ref:Re,className:"gantt-timeline-scroll flex-1",style:{minHeight:0,overflowX:"auto",overflowY:"auto",...a.disableScrollSync&&{scrollBehavior:"auto",overflowAnchor:"none"}},children:jsxRuntime.jsx(hn,{tasks:at,theme:K,rowHeight:Wa,timeScale:$,startDate:gp,endDate:fp,zoom:he,templates:xt,onTaskClick:D,onTaskDblClick:Ji,onTaskContextMenu:Xi,onTaskDateChange:$n,onDependencyCreate:Qi,onDependencyDelete:el})})]}),re.task&&jsxRuntime.jsx(Jr,{isOpen:re.isOpen,x:re.x,y:re.y,theme:K,onClose:()=>pe({isOpen:false,x:0,y:0,task:null}),items:(()=>{let S=re.task;if(!S)return [];let E=le.findTaskById(I,S.id)||S;return E.subtasks&&E.subtasks.length>0?[{id:"addSubtask",label:ie.contextMenu?.addSubtask||"Add Subtask",icon:Dt.Add,onClick:()=>{w?w(E):no(E.id);}},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:ie.contextMenu?.deleteTask||"Delete Task",icon:Dt.Delete,onClick:()=>{ut({taskId:E.id,taskName:E.name});}}]:[{id:"edit",label:ie.contextMenu?.editTask||"Edit Task",icon:Dt.Pencil,onClick:()=>{T?T(E):Ee(E);}},{id:"addSubtask",label:ie.contextMenu?.addSubtask||"Add Subtask",icon:Dt.Add,onClick:()=>{w?w(E):no(E.id);}},{id:"separator-status",label:"",separator:true,onClick:()=>{}},{id:"markIncomplete",label:ie.contextMenu?.markIncomplete||"Mark Incomplete",icon:Dt.MarkIncomplete,onClick:()=>{R?R(E):de(E.id,{status:"todo",progress:0});},disabled:E.status==="todo"},{id:"setInProgress",label:ie.contextMenu?.setInProgress||"Set In Progress",icon:Dt.SetInProgress,onClick:()=>{M?M(E):de(E.id,{status:"in-progress"});},disabled:E.status==="in-progress"},{id:"markComplete",label:ie.contextMenu?.markComplete||"Mark Complete",icon:Dt.MarkComplete,onClick:()=>{de(E.id,{status:"completed",progress:100});},disabled:E.status==="completed"},{id:"separator-advanced",label:"",separator:true,onClick:()=>{}},{id:"split",label:ie.contextMenu?.splitTask||"Split Task",icon:Dt.Split,onClick:()=>{if(!E.startDate||!E.endDate){console.warn("Cannot split task without dates");return}let ee=E.startDate.getTime(),ce=E.endDate.getTime(),ve=ee+(ce-ee)/2,dt=new Date(ve);so(E,dt);},disabled:!E.startDate||!E.endDate},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:ie.contextMenu?.deleteTask||"Delete Task",icon:Dt.Delete,onClick:()=>{ut({taskId:E.id,taskName:E.name});}}]})()}),Ce&&jsxRuntime.jsx(yn,{isOpen:true,onClose:()=>Ee(null),task:Ce,onSubmit:S=>{de(Ce.id,S),Ee(null);},mode:"edit",theme:Y}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:tt&&jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},className:"fixed inset-0 z-[10000] flex items-center justify-center p-4",style:{backgroundColor:"rgba(0, 0, 0, 0.6)"},onClick:()=>ut(null),children:jsxRuntime.jsxs(framerMotion.motion.div,{initial:{opacity:0,scale:.9},animate:{opacity:1,scale:1},exit:{opacity:0,scale:.9},transition:{duration:.2,ease:"easeOut"},onClick:S=>S.stopPropagation(),className:"w-full max-w-md rounded-xl shadow-2xl overflow-hidden",style:{backgroundColor:K.bgSecondary,border:`1px solid ${K.border}`},children:[jsxRuntime.jsx("div",{className:"px-6 py-4",style:{borderBottom:`1px solid ${K.border}`},children:jsxRuntime.jsxs("div",{className:"flex items-start gap-3",children:[jsxRuntime.jsx("div",{className:"w-10 h-10 rounded-full flex items-center justify-center flex-shrink-0",style:{backgroundColor:"rgba(239, 68, 68, 0.2)"},children:jsxRuntime.jsx(lucideReact.AlertTriangle,{className:"w-5 h-5",style:{color:"#EF4444"}})}),jsxRuntime.jsxs("div",{className:"flex-1",children:[jsxRuntime.jsxs("h3",{className:"text-lg font-semibold",style:{color:K.textPrimary,fontFamily:"Inter, sans-serif"},children:[ie.contextMenu?.deleteTask||"Delete Task","?"]}),jsxRuntime.jsx("p",{className:"text-sm mt-1",style:{color:K.textSecondary,fontFamily:"Inter, sans-serif"},children:f==="es"?"Esta acci\xF3n no se puede deshacer":"This action cannot be undone"})]})]})}),jsxRuntime.jsx("div",{className:"px-6 py-4",children:jsxRuntime.jsxs("p",{className:"text-sm leading-relaxed",style:{color:K.textSecondary,fontFamily:"Inter, sans-serif"},children:[f==="es"?"Est\xE1s a punto de eliminar la tarea":"You are about to delete the task"," ",jsxRuntime.jsxs("span",{className:"font-semibold",style:{color:K.textPrimary},children:['"',tt.taskName,'"']}),"."]})}),jsxRuntime.jsxs("div",{className:"px-6 py-4 flex items-center justify-end gap-3",style:{backgroundColor:K.bgPrimary,borderTop:`1px solid ${K.border}`},children:[jsxRuntime.jsx("button",{onClick:()=>ut(null),className:"px-4 py-2 text-sm font-medium rounded-lg transition-colors",style:{color:K.textSecondary,fontFamily:"Inter, sans-serif"},onMouseEnter:S=>{S.currentTarget.style.backgroundColor=K.hoverBg;},onMouseLeave:S=>{S.currentTarget.style.backgroundColor="transparent";},children:f==="es"?"Cancelar":"Cancel"}),jsxRuntime.jsxs("button",{onClick:()=>{Ja([tt.taskId]),ut(null);},className:"px-4 py-2 text-sm font-medium text-white rounded-lg transition-colors flex items-center gap-2",style:{backgroundColor:"#EF4444",fontFamily:"Inter, sans-serif"},onMouseEnter:S=>{S.currentTarget.style.backgroundColor="#DC2626";},onMouseLeave:S=>{S.currentTarget.style.backgroundColor="#EF4444";},children:[jsxRuntime.jsx(lucideReact.Trash2,{className:"w-4 h-4"}),f==="es"?"Eliminar":"Delete"]})]})]})})}),x?.enabled&&jsxRuntime.jsx(vn,{tasks:I,theme:K,config:x,onTasksUpdate:q,onTaskUpdate:de,onTaskCreate:S=>{q(E=>[...E,S]);},onTaskDelete:S=>{Ja([S]);},onDependencyCreate:(S,E)=>{let W=le.findTaskById(I,S);W&&Qi(W,E);},onDependencyDelete:el})]})})})});var tc=`You are a Gantt chart AI assistant. You help users edit project tasks using natural language commands.
|
|
345
345
|
|