@libxai/board 0.17.222 → 0.17.223
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/dist/styles.css +17 -0
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -341,7 +341,7 @@
|
|
|
341
341
|
</Tasks>
|
|
342
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 cn({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())),W=F.getUTCDay()||7;F.setUTCDate(F.getUTCDate()+4-W);let E=new Date(Date.UTC(F.getUTCFullYear(),0,1));return Math.ceil(((F.getTime()-E.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)),W=new Date(o);return W.setDate(W.getDate()+F),W},[o,A,l]),R=react.useCallback((z,F)=>{if(F.startDate&&F.endDate)return;let W=z.currentTarget.ownerSVGElement;if(!W)return;let E=W.createSVGPoint();E.x=z.clientX,E.y=z.clientY;let Y=E.matrixTransform(W.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(xe=>xe.startDate&&xe.endDate);if(Te.length>0){let xe=Te.map(Me=>Me.startDate.getTime()),$e=Te.map(Me=>Me.endDate.getTime()),he=new Date(Math.min(...xe)),et=new Date(Math.max(...$e));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},W=z(e);return F(W)},[e]),H=react.useCallback(z=>{if(!z.startDate||!z.endDate)return {x:0,width:0};let F=z.startDate.getTime(),W=z.endDate.getTime(),E=o.getTime(),Y=(F-E)/(1e3*60*60*24),J=(W-F)/(1e3*60*60*24),$=Y*A*l,Te=Math.max(A*l,40),xe=Math.max(J*A*l,Te);return {x:$,width:xe}},[o,A,l]),X=react.useMemo(()=>M.filter(z=>z.startDate&&z.endDate).map(z=>{let{x:F,width:W}=H(z),Y=M.findIndex(J=>J.id===z.id)*a+12;return {id:z.id,x:F,y:Y,width:W,height:32}}),[M,H]),fe=react.useCallback((z,F,W)=>{if(!W||F===0){g([]);return}let E=le.calculateCascadePreview(e,z,F,M,o,A*l,a,48);g(E);},[e,M,o,A,l,a,48]),ve=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]),Re=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}),ve.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:Re,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:Re,fill:t.bgPrimary}),ve.map((z,F)=>{let W=ve[F+1]?.x||v,E=T(z.date);return jsxRuntime.jsxs("g",{children:[E&&jsxRuntime.jsx("rect",{x:z.x,y:0,width:W-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 W=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}`),!W&&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:E=>R(E,z),onMouseEnter:E=>{E.currentTarget.setAttribute("fill",t.accentLight),E.currentTarget.setAttribute("opacity","0.5");},onMouseLeave:E=>{E.currentTarget.setAttribute("fill","transparent"),E.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(W=>{let E=M.find(Te=>Te.id===W);if(!E||!E.startDate||!E.endDate)return null;let Y=M.findIndex(Te=>Te.id===W),J=H(E),$=H(z);return jsxRuntime.jsx(nn,{x1:J.x+J.width,y1:Y*a+a/2,x2:$.x,y2:F*a+a/2,theme:t},`dep-${W}-${z.id}`)})),M.map((z,F)=>{if(!z.startDate||!z.endDate)return null;let{x:W,width:E}=H(z),Y=F*a+12,J=z.subtasks&&z.subtasks.length>0&&!z.isMilestone;return z.isMilestone?jsxRuntime.jsx(ln,{task:z,x:W+E/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:W,y:Y,width:E,height:32,fill:t.primary,opacity:.25,rx:6}),jsxRuntime.jsx("line",{x1:W,y1:Y,x2:W+E,y2:Y,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:W,y1:Y,x2:W,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:W+E,y1:Y,x2:W+E,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:W,y1:Y+32,x2:W+E,y2:Y+32,stroke:t.primary,strokeWidth:3,opacity:.9,strokeLinecap:"round"}),E>60&&jsxRuntime.jsx("text",{x:W+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(an,{task:z,x:W,y:Y,width:E,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(W=>{let E=M.find(ce=>ce.id===W);if(!E||!E.startDate||!E.endDate)return null;let Y=M.findIndex(ce=>ce.id===W),J=H(E),$=H(z),Te=J.x+J.width,xe=Y*a+a/2,$e=$.x,he=F*a+a/2,et=$e-Te,Me=Te+et/2,Ze=ce=>{let Ce=1-ce,Ee=Ce*Ce,tt=Ee*Ce,mt=ce*ce,Le=mt*ce,I=tt*Te+3*Ee*ce*Me+3*Ce*mt*Me+Le*$e,q=tt*xe+3*Ee*ce*xe+3*Ce*mt*he+Le*he;return {x:I,y:q}},ht=20,St=[];for(let ce=0;ce<=ht;ce++){let Ce=.1+ce/ht*.8;St.push(Ze(Ce));}let lt=St[0],O=`M ${lt.x} ${lt.y} `+St.slice(1).map(ce=>`L ${ce.x} ${ce.y}`).join(" ");return b&&b.x1===Te&&b.y1===xe&&b.x2===$e&&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:xe,x2:$e,y2:he,onDelete:()=>u?.(z.id,W)});}},`dep-hover-${W}-${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:W,y2:E,onDelete:Y}=b,J=W-z,$=E-F,Te=z+J/2,xe=(F+E)/2,$e=`M ${z} ${F} C ${Te} ${F}, ${Te} ${E}, ${W} ${E}`,he=6,et=Math.atan2($,J),Me=W-he*Math.cos(et-Math.PI/6),Ze=E-he*Math.sin(et-Math.PI/6),ht=W-he*Math.cos(et+Math.PI/6),St=E-he*Math.sin(et+Math.PI/6),lt=t.dependency,O="#f87171";return jsxRuntime.jsxs("g",{onMouseLeave:()=>y(null),children:[jsxRuntime.jsx("path",{d:$e,fill:"none",stroke:"transparent",strokeWidth:50,strokeLinecap:"round",style:{cursor:"pointer"}}),jsxRuntime.jsx("circle",{cx:Te,cy:xe,r:25,fill:"transparent",style:{cursor:"pointer"}}),jsxRuntime.jsx("path",{d:$e,fill:"none",stroke:lt,strokeWidth:8,strokeLinecap:"round",opacity:.15,style:{pointerEvents:"none",filter:"blur(4px)"}}),jsxRuntime.jsx("path",{d:$e,fill:"none",stroke:lt,strokeWidth:2.5,strokeLinecap:"round",opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsx("path",{d:`M ${W} ${E} L ${Me} ${Ze} M ${W} ${E} L ${ht} ${St}`,fill:"none",stroke:lt,strokeWidth:2.5,strokeLinecap:"round",opacity:.9,style:{pointerEvents:"none"}}),jsxRuntime.jsx("circle",{cx:W,cy:E,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:ce=>{ce.stopPropagation(),y(null),Y();},style:{cursor:"pointer"},children:[jsxRuntime.jsx("circle",{cx:Te,cy:xe,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:xe-3,x2:Te+3,y2:xe+3,stroke:O,strokeWidth:1.5,strokeLinecap:"round"}),jsxRuntime.jsx("line",{x1:Te+3,y1:xe-3,x2:Te-3,y2:xe+3,stroke:O,strokeWidth:1.5,strokeLinecap:"round"})]})]})})(),Ie>=0&&Ie<=v&&jsxRuntime.jsx("line",{x1:Ie,y1:0,x2:Ie,y2:Re,stroke:t.today,strokeWidth:1,opacity:1,style:{pointerEvents:"none"}}),k&&jsxRuntime.jsx(Pd,{tooltipData:k,theme:t})]})]})}var pn=[{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 Gs=[{id:"todo",title:"Por Hacer",color:"#6B7280"},{id:"in-progress",title:"En Progreso",color:"#F59E0B"},{id:"completed",title:"Completada",color:"#10B981"}],_s=[{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 mn({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=[...Gs,...n.filter(O=>!Gs.some(re=>re.id===O.id))],g=Ge[p]||Ge.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,H]=react.useState(new Date),[X,fe]=react.useState({top:0,left:0}),[ve,Ie]=react.useState(false),[Re,z]=react.useState([]),F=react.useRef(null),W=react.useRef(null),E=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:[]}),[xe,$e]=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),W.current&&!W.current.contains(re.target)&&y(false),E.current&&!E.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"),$e(O),Object.keys(O).length===0},et=async O=>{if(O.preventDefault(),!!he())try{let re=c==="create"&&Re.length>0?{...$,pendingFiles:Re}:$;await s(re),z([]),t();}catch(re){console.error("Error submitting task:",re);}},Me=(O,re)=>{Te(ce=>{let Ce={...ce,[O]:re};if(O==="status"){let Ee=re;Ee==="todo"?Ce.progress=0:Ee==="in-progress"?(ce.progress===0||ce.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&&ce.status!=="completed"?Ce.status="completed":Ee>0&&Ee<100&&ce.status==="todo"?Ce.status="in-progress":Ee===0&&ce.status!=="todo"&&(Ce.status="todo");}return Ce}),xe[O]&&$e(ce=>{let Ce={...ce};return delete Ce[O],Ce});},Ze=f.find(O=>O.id===$.status)??Gs[0],ht=_s.find(O=>O.id===$.priority)??_s[1],St=pn.find(O=>O.value===$.color)??pn[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}),xe.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"}),xe.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:W,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:ht.color}}),jsxRuntime.jsx("span",{children:ht.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:_s.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:E,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(ce=>ce.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:ce=>ce.currentTarget.style.backgroundColor=g.hoverBg,onMouseLeave:ce=>ce.currentTarget.style.backgroundColor="transparent",onClick:()=>{let ce=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",ce);},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,ce=120,Ee=re-O.bottom<ce?O.top-ce-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:pn.slice(0,18).map(O=>{let re=$.color===O.value;return jsxRuntime.jsx("button",{type:"button",onClick:ce=>{ce.preventDefault(),ce.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($r,{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,ce=320,Ee=re-O.bottom<ce?O.top-ce-8:O.bottom+8;fe({top:Ee,left:O.left});}R("start"),H($.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,ce=320,Ee=re-O.bottom<ce?O.top-ce-8:O.bottom+8;fe({top:Ee,left:O.left});}R("end"),H($.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 ce=new Date(O);ce.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:ce},{label:"2 semanas",date:Ce}].map((tt,mt)=>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},mt))})(),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:()=>H(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:()=>H(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(),ce=new Date(O,re,1).getDay(),Ce=new Date(O,re+1,0).getDate(),Ee=new Date,tt=[];for(let Le=ce-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 mt=42-tt.length;for(let Le=1;Le<=mt;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(),Ue=$.endDate?.toDateString()===Le.date.toDateString(),yt=$.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||Ue?"#FFF":g.textPrimary:g.textTertiary,backgroundColor:We?"#3B82F6":Ue?"#7C3AED":yt?"rgba(124, 58, 237, 0.2)":"transparent",boxShadow:q&&!We&&!Ue?"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)})})()})]})]})]})})]}),xe.endDate&&jsxRuntime.jsx("span",{className:"text-xs text-red-400",children:xe.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"?Re.length>0&&`(${Re.length})`:i.length>0&&`(${i.length})`]})]}),c==="create"?jsxRuntime.jsx(za,{cardId:"pending",attachments:Re.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(ce=>ce.filter((Ce,Ee)=>Ee!==re));},maxSizeMB:10,maxFiles:20}):jsxRuntime.jsx(za,{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"&&Re.length>0&&jsxRuntime.jsxs("p",{className:"text-xs mt-1",style:{color:g.textTertiary},children:[Re.length," archivo(s) se subir\xE1n al crear la tarea"]})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsxs("button",{type:"button",onClick:()=>Ie(!ve),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 ${ve?"rotate-180":""}`}),"Opciones avanzadas"]}),jsxRuntime.jsx(framerMotion.AnimatePresence,{children:ve&&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 ce=re?($.dependencies||[]).filter(Ce=>Ce!==O.id):[...$.dependencies||[],O.id];Me("dependencies",ce);},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 mf=['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"'],Fd=()=>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"})]}),uf=()=>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"})}),gf=()=>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"})}),ff=()=>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"})}),hf=()=>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 un({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=mf,maxHistory:M=50,persistHistory:H}=a,X=H?.storageKey||"gantt-ai-history",fe=H?.maxMessages??5;react.useEffect(()=>{if(H?.enabled)try{let W=localStorage.getItem(X);if(W){let Y=JSON.parse(W).map(J=>({...J,timestamp:new Date(J.timestamp)}));x(Y.slice(-fe));}}catch(W){console.warn("[GanttAIAssistant] Failed to load persisted history:",W);}},[H?.enabled,X,fe]),react.useEffect(()=>{if(H?.enabled&&u.length>0)try{let W=u.filter(E=>!E.isLoading).slice(-fe);localStorage.setItem(X,JSON.stringify(W));}catch(W){console.warn("[GanttAIAssistant] Failed to persist history:",W);}},[u,H?.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 ve=react.useCallback(W=>{if(W.success)switch(W.type){case "move_task":case "resize_task":case "rename_task":case "set_progress":case "set_status":case "assign_task":W.taskId&&W.updates&&o?.(W.taskId,W.updates);break;case "create_task":W.newTask&&s?.(W.newTask);break;case "delete_task":W.taskId&&l?.(W.taskId);break;case "link_tasks":W.dependencyFrom&&W.dependencyTo&&c?.(W.dependencyFrom,W.dependencyTo);break;case "unlink_tasks":W.taskId&&W.dependencyFrom&&p?.(W.taskId,W.dependencyFrom);break}},[o,s,l,c,p]),Ie=react.useCallback(async W=>{if(!W.trim()||k)return;let E={id:`user-${Date.now()}`,role:"user",content:W,timestamp:new Date};x(J=>[...J.slice(-(M-1)),E]),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(W,e);x($=>{let Te=$.filter($e=>!$e.isLoading),xe={id:`assistant-${Date.now()}`,role:"assistant",content:J.message,timestamp:new Date,command:J};return [...Te,xe]}),ve(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(xe=>!xe.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,ve]),Re=W=>{W.preventDefault(),Ie(f);},z=W=>{g(W),D.current?.focus();};if(react.useEffect(()=>{let W=E=>{(E.metaKey||E.ctrlKey)&&E.key==="k"&&(E.preventDefault(),m(Y=>!Y),n||i(false)),E.key==="Escape"&&n&&m(false);};return document.addEventListener("keydown",W),()=>document.removeEventListener("keydown",W)},[n]),react.useEffect(()=>{if(!n)return;let W=Y=>{let J=Y.target;A.current&&!A.current.contains(J)&&m(false);},E=setTimeout(()=>{document.addEventListener("mousedown",W);},100);return ()=>{clearTimeout(E),document.removeEventListener("mousedown",W);}},[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(Fd,{}),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(Fd,{}),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(W=>!W),className:"p-1.5 rounded-lg hover:bg-white/20 text-white/80 hover:text-white transition-colors",children:jsxRuntime.jsx(ff,{})}),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(gf,{})})]})]}),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((W,E)=>jsxRuntime.jsx("button",{onClick:()=>z(W),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:W.length>30?W.slice(0,30)+"...":W},E))})]}),u.map(W=>jsxRuntime.jsx(framerMotion.motion.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},className:`flex ${W.role==="user"?"justify-end":"justify-start"}`,children:jsxRuntime.jsxs("div",{className:`max-w-[85%] rounded-2xl px-4 py-2.5 ${W.role==="user"?"rounded-br-md":"rounded-bl-md"}`,style:{background:W.role==="user"?"linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%)":t.bgSecondary,color:W.role==="user"?"white":t.textPrimary},children:[W.isLoading?jsxRuntime.jsx(hf,{}):jsxRuntime.jsx("p",{className:"text-sm whitespace-pre-wrap",children:W.content}),W.command&&jsxRuntime.jsxs("div",{className:"mt-2 text-xs px-2 py-1 rounded-md inline-flex items-center gap-1",style:{background:W.command.success?"rgba(16, 185, 129, 0.2)":"rgba(239, 68, 68, 0.2)",color:W.command.success?"#10B981":"#EF4444"},children:[W.command.success?"\u2713":"\u2717",jsxRuntime.jsx("span",{className:"capitalize",children:W.command.type.replace(/_/g," ")})]})]})},W.id)),jsxRuntime.jsx("div",{ref:N})]}),jsxRuntime.jsxs("form",{onSubmit:Re,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:W=>g(W.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(uf,{})})]}),jsxRuntime.jsx("p",{className:"text-[10px] text-center mt-2",style:{color:t.textTertiary},children:"Press Enter to send \u2022 Esc to close"})]})]})})]})})]})}function Bd(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 Rd({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 xf={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 Od(e){return {...xf,...e}}var Sf=e=>{switch(e){case "compact":return 44;case "comfortable":return 52;case "spacious":return 60;default:return 52}},Ud=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:H,onDependencyDelete:X,onBeforeTaskAdd:fe,onAfterTaskAdd:ve,onBeforeTaskUpdate:Ie,onAfterTaskUpdate:Re,onBeforeTaskDelete:z,onAfterTaskDelete:F}=a,E=react.useContext(qo)?.theme,[Y,J]=react.useState(E||s||"dark"),[$,Te]=react.useState(l),[xe,$e]=react.useState(c),[he,et]=react.useState(1),[Me,Ze]=react.useState(0),[ht,St]=react.useState(false),[lt,O]=react.useState(null),[re,ce]=react.useState({isOpen:false,x:0,y:0,task:null}),[Ce,Ee]=react.useState(null),[tt,mt]=react.useState(null);react.useEffect(()=>{E&&E!==Y&&J(E);},[E]),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:Ue,canUndo:yt,canRedo:Q,clearHistory:oe}=Bd(t,50),ye=react.useCallback(()=>u?typeof u=="string"?u:"gantt-expanded-tasks":null,[u]),ke=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 P=localStorage.getItem(S);if(P){let V=JSON.parse(P);Array.isArray(V)&&(ke.current=new Map(V));}}catch(P){console.warn("[GanttBoard] Error loading expanded state from localStorage:",P);}}let Ne=react.useCallback(()=>{let S=ye();if(S)try{let P=Array.from(ke.current.entries());localStorage.setItem(S,JSON.stringify(P));}catch(P){console.warn("[GanttBoard] Error saving expanded state to localStorage:",P);}},[ye]);react.useEffect(()=>{let S=P=>P.map(V=>{let ee=ke.current.get(V.id),pe=ee!==void 0?{...V,isExpanded:ee}:V;return pe.subtasks?.length?{...pe,subtasks:S(pe.subtasks)}:pe});ke.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),P=JSON.stringify(I);S!==P&&(be.current=I,r(I));},[I,r]);let ie=react.useMemo(()=>Ss(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,Ve]=react.useState(()=>Be(ie));react.useEffect(()=>{Ve(S=>S.map(P=>({...P,label:ie.columns[P.id==="name"?"taskName":P.id]||P.label})));},[ie]);let ut=react.useMemo(()=>Ae.filter(P=>P.visible).reduce((P,V)=>P+V.width,0),[Ae]),_t=react.useRef(Ae.filter(S=>S.visible).map(S=>S.id).join(","));react.useEffect(()=>{let S=Ae.filter(ee=>ee.visible),P=S.map(ee=>ee.id).join(","),V=_t.current;if(P!==V){let ee=S.some(we=>we.id!=="name"),pe=V.includes(",");ee?!pe&&ee&&O(null):O(null),_t.current=P;}},[Ae]);let j=60,Z=.6,Se=react.useMemo(()=>{let P=ut+j,V=typeof window<"u"?window.innerWidth*Z:800,ee=Math.max(P,V);return lt!==null?Math.max(200,Math.min(lt,ee)):Math.max(200,P)},[lt,ut]),qe=react.useRef(null),He=react.useRef(null),U=react.useRef(null),K=react.useMemo(()=>td(Y),[Y]),Pe=react.useMemo(()=>({theme:K,themeName:Y}),[K,Y]),vt=react.useMemo(()=>Od(d),[d]),at=react.useMemo(()=>{if(!i)return I;let S=le.calculateCriticalPath(I),P=V=>V.map(ee=>({...ee,isCriticalPath:S.includes(ee.id),subtasks:ee.subtasks?P(ee.subtasks):void 0}));return P(I)},[I,i]),Wa=Sf(xe);Rd({undo:We,redo:Ue,canUndo:yt,canRedo:Q,enabled:true}),react.useImperativeHandle(o,()=>({getTask:S=>le.findTaskById(I,S),addTask:(S,P)=>{q(V=>{if(!P)return [...V,{...S,level:0}];let ee=pe=>pe.map(we=>we.id===P?{...we,subtasks:[...we.subtasks||[],{...S,parentId:P,level:(we.level||0)+1}],isExpanded:true}:we.subtasks?{...we,subtasks:ee(we.subtasks)}:we);return ee(V)});},updateTask:(S,P)=>{q(V=>{let ee=pe=>pe.map(we=>we.id===S?{...we,...P}:we.subtasks?{...we,subtasks:ee(we.subtasks)}:we);return ee(V)});},deleteTask:S=>{q(P=>{let V=ee=>ee.filter(pe=>pe.id===S?false:(pe.subtasks&&(pe.subtasks=V(pe.subtasks)),true));return V(P)});},deleteTasks:S=>{q(P=>Fs(P,S));},duplicateTask:S=>{q(P=>Bs(P,[S]));},splitTask:(S,P,V=3)=>{q(ee=>le.splitTask(ee,S,P,V));},calculateEndDate:le.calculateEndDate,calculateDuration:le.calculateDuration,validateDependency:(S,P)=>!le.validateDependencies(I,S,P),getAllTasks:()=>le.flattenTasks(I),getTasksByStatus:S=>le.flattenTasks(I).filter(P=>P.status===S),getTasksByParent:S=>S?le.findTaskById(I,S)?.subtasks||[]:I.filter(V=>!V.parentId),getCriticalPath:()=>le.flattenTasks(I).filter(S=>S.isCriticalPath),indentTask:S=>{q(P=>As(P,[S]));},outdentTask:S=>{q(P=>Is(P,[S]));},moveTask:(S,P)=>{q(V=>Ls(V,[S],P));},createSubtask:async S=>{let{tasks:P,newTask:V}=zs(I,S);if(fe){let ee=fe({...V,parentId:S});if((ee instanceof Promise?await ee:ee)===false)return}q(P),ve&&ve({...V,parentId:S});},scrollToTask:S=>{let V=le.flattenTasks(I).findIndex(ee=>ee.id===S);if(V!==-1&&qe.current){let ee=V*Wa;qe.current.scrollTo({top:ee,behavior:"smooth"}),He.current&&He.current.scrollTo({top:ee,behavior:"smooth"});}},highlightTask:(S,P=2e3)=>{},expandTask:S=>{q(P=>{let V=ee=>ee.map(pe=>pe.id===S?{...pe,isExpanded:true}:pe.subtasks?{...pe,subtasks:V(pe.subtasks)}:pe);return V(P)});},collapseTask:S=>{q(P=>{let V=ee=>ee.map(pe=>pe.id===S?{...pe,isExpanded:false}:pe.subtasks?{...pe,subtasks:V(pe.subtasks)}:pe);return V(P)});},expandAll:()=>{q(S=>{let P=V=>V.map(ee=>({...ee,isExpanded:true,subtasks:ee.subtasks?P(ee.subtasks):void 0}));return P(S)});},collapseAll:()=>{q(S=>{let P=V=>V.map(ee=>({...ee,isExpanded:false,subtasks:ee.subtasks?P(ee.subtasks):void 0}));return P(S)});},undo:We,redo:Ue,canUndo:()=>yt,canRedo:()=>Q,clearHistory:oe,exportToPNG:async()=>{if(!U.current)throw new Error("Gantt container not found");let S=await $d__default.default(U.current,{backgroundColor:K.bgPrimary,scale:2});return new Promise((P,V)=>{S.toBlob(ee=>{ee?P(ee):V(new Error("Failed to create blob from canvas"));},"image/png");})},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 P=le.importFromJSON(S);q(P);},getTasks:()=>I,refresh:()=>{q(S=>[...S]);},clearAll:()=>{q([]);}}),[I,We,Ue,yt,Q,oe,K,Wa]);let cr=react.useCallback(S=>{Ve(P=>P.map(V=>V.id===S?{...V,visible:!V.visible}:V));},[]),Xa=react.useCallback((S,P)=>{Ve(V=>V.map(ee=>{if(ee.id!==S)return ee;let pe=ee.minWidth??100,we=ee.maxWidth??800,xt=Math.max(pe,Math.min(we,P));return {...ee,width:xt}}));},[]),Zr=react.useCallback(S=>{q(P=>{let V=Os(P,S),ee=pe=>{for(let we of pe){if(we.id===S){ke.current.set(S,we.isExpanded??true);return}we.subtasks?.length&&ee(we.subtasks);}};return ee(V),Ne(),V}),a.onTaskToggleExpand?.(S);},[a,Ne]),de=react.useCallback((S,P)=>{if(Ie&&Ie(S,P)===false)return;let ee=le.findTaskById(I,S)?.progress,pe=xt=>xt.map(Zt=>Zt.id===S?{...Zt,...P}:Zt.subtasks?{...Zt,subtasks:pe(Zt.subtasks)}:Zt);q(pe(I));let we=le.findTaskById(pe(I),S);we&&(v?.(we),Re?.(we),P.progress!==void 0&&ee!==void 0&&P.progress!==ee&&B?.(S,ee,P.progress));},[I,v,Ie,Re,B]),Et=react.useCallback(S=>{S.length!==0&&(q(P=>As(P,S)),a.onTaskIndent?.(S[0]));},[a]),Jt=react.useCallback(S=>{S.length!==0&&(q(P=>Is(P,S)),a.onTaskOutdent?.(S[0]));},[a]),Ar=react.useCallback((S,P,V)=>{q(ee=>kd(ee,S,P,V)),a.onTaskReparent?.(S,P,V);},[a]),Mo=react.useCallback((S,P)=>{S.length!==0&&(q(V=>Ls(V,S,P)),a.onTaskMove?.(S[0],P));},[a]),Ja=react.useCallback(async S=>{let P=[];for(let V of S)z&&await Promise.resolve(z(V))===false||P.push(V);P.length!==0&&(a.onMultiTaskDelete?a.onMultiTaskDelete(P):(q(V=>Fs(V,P)),P.forEach(V=>a.onTaskDelete?.(V))),F&&P.forEach(V=>F(V)));},[a,z,F]),Ha=react.useCallback(S=>{q(P=>Bs(P,S)),S.forEach(P=>a.onTaskDuplicate?.(P));},[a]),pr=react.useCallback((S,P)=>{q(V=>{let{tasks:ee,newTask:pe}=xd(V,S,P);return fe&&fe(pe)===false?V:(a.onTaskCreate?.(pe.parentId,pe.position||0),ve?.(pe),ee)});},[a,fe,ve]),Ot=react.useCallback((S,P)=>{q(V=>Rs(V,S,P)),a.onTaskRename?.(S,P);},[a]),Qr=react.useCallback(S=>{q(P=>{let{tasks:V}=zs(P,S);return a.onTaskCreate?.(S,0),V});},[a]),Ln=react.useCallback((S,P,V)=>{let ee=S.startDate?Math.round((P.getTime()-S.startDate.getTime())/864e5):0,pe=Zt=>Zt.map(Ta=>Ta.id===S.id?{...Ta,startDate:P,endDate:V,...S.segments&&{segments:S.segments}}:Ta.subtasks?{...Ta,subtasks:pe(Ta.subtasks)}:Ta),we=pe(I);we=le.autoScheduleDependents(we,S.id,ee),q(we);let xt={...S,startDate:P,endDate:V};v?.(xt);},[I,v]),$i=react.useCallback((S,P)=>{A?.(S,P),ce({isOpen:true,x:P.clientX,y:P.clientY,task:S});},[A]),eo=react.useCallback((S,P)=>{let V=le.splitTask(I,S.id,P);q(V),ce({isOpen:false,x:0,y:0,task:null});},[I]),Ui=react.useCallback(S=>{let P=le.findTaskById(I,S.id)||S;N?.(P),T||Ee(P);},[I,N,T]),Wi=react.useCallback((S,P,V)=>{let ee=new Map,pe=Da=>{Da.forEach(Ga=>{Ga.dependencies&&ee.set(Ga.id,Ga.dependencies),Ga.subtasks&&pe(Ga.subtasks);});};pe(V);let we=ee.get(P)||[];ee.set(P,[...we,S]);let xt=new Set,Zt=new Set,Ta=Da=>{if(!xt.has(Da)){xt.add(Da),Zt.add(Da);let Ga=ee.get(Da)||[];for(let to of Ga){if(!xt.has(to)&&Ta(to))return true;if(Zt.has(to))return true}}return Zt.delete(Da),false};return Ta(P)},[]),Hi=react.useCallback((S,P)=>{if(Wi(S.id,P,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
|
-
Task dependencies must flow in one direction only.`);return}let V=ee=>ee.map(pe=>{if(pe.id===P){let we=pe.dependencies||[];if(!we.includes(S.id))return {...pe,dependencies:[...we,S.id]}}return pe.subtasks?{...pe,subtasks:V(pe.subtasks)}:pe});q(V(I)),H?.(S.id,P);},[I,H,Wi]),Gi=react.useCallback((S,P)=>{let V=ee=>ee.map(pe=>{if(pe.id===S&&pe.dependencies){let we=pe.dependencies.filter(xt=>xt!==P);return {...pe,dependencies:we}}return pe.subtasks?{...pe,subtasks:V(pe.subtasks)}:pe});q(V(I)),X?.(S,P);},[I,X]),{startDate:ep,endDate:tp}=react.useMemo(()=>{let S=I.filter(we=>we.startDate&&we.endDate);if(S.length===0){let we=new Date,xt=new Date(we);xt.setDate(xt.getDate()-30);let Zt=new Date(we);return Zt.setDate(Zt.getDate()+60),{startDate:xt,endDate:Zt}}let P=S.flatMap(we=>[we.startDate,we.endDate]).filter(we=>we!==void 0),V=new Date(Math.min(...P.map(we=>we.getTime()))),ee=new Date(Math.max(...P.map(we=>we.getTime()))),pe=$==="day"?7:$==="week"?14:30;return V.setDate(V.getDate()-pe),ee.setDate(ee.getDate()+pe),{startDate:V,endDate:ee}},[I,$]),ap=react.useCallback(async()=>{if(!U.current)return;let S=await $d__default.default(U.current,{backgroundColor:K.bgPrimary,scale:2}),P=document.createElement("a");P.download="gantt-chart.png",P.href=S.toDataURL("image/png"),P.click();},[K]),rp=react.useCallback(async()=>{await le.exportToPDF(I);},[I]),op=react.useCallback(async()=>{await le.exportToExcel(I);},[I]),np=react.useCallback(()=>{let S=le.exportToCSV(I),P=new Blob([S],{type:"text/csv;charset=utf-8;"}),V=document.createElement("a");V.href=URL.createObjectURL(P),V.download="gantt-chart.csv",V.click(),URL.revokeObjectURL(V.href);},[I]),sp=react.useCallback(()=>{let S=le.exportToJSON(I),P=new Blob([S],{type:"application/json;charset=utf-8;"}),V=document.createElement("a");V.href=URL.createObjectURL(P),V.download="gantt-chart.json",V.click(),URL.revokeObjectURL(V.href);},[I]),ip=react.useCallback(()=>{le.exportToMSProject(I,"Gantt Project","project.xml");},[I]),lp=S=>{S.preventDefault(),St(true);},Ir=react.useRef(false);return react.useEffect(()=>{let S=He.current,P=qe.current?.querySelector(".gantt-grid-scroll");if(!S||!P)return;let V=()=>{if(Ir.current)return;Ir.current=true;let xt=S.scrollTop;Ze(xt),P.scrollTop=xt,requestAnimationFrame(()=>{Ir.current=false;});},ee=()=>{if(Ir.current)return;Ir.current=true;let xt=P.scrollTop;Ze(xt),S.scrollTop=xt,requestAnimationFrame(()=>{Ir.current=false;});},pe=xt=>{if(ht&&P){let Ta=P.parentElement?.getBoundingClientRect()?.left||0,Da=xt.clientX-Ta,Ga=200,to=ut+j,dp=window.innerWidth*Z,cp=Math.max(to,dp);Da>=Ga&&Da<=cp&&O(Da);}},we=()=>{St(false);};return S.addEventListener("scroll",V),P.addEventListener("scroll",ee),document.addEventListener("mousemove",pe),document.addEventListener("mouseup",we),()=>{S.removeEventListener("scroll",V),P.removeEventListener("scroll",ee),document.removeEventListener("mousemove",pe),document.removeEventListener("mouseup",we);}},[ht,ut]),jsxRuntime.jsx(_r.Provider,{value:ie,children:jsxRuntime.jsx(zn.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(Jo,{theme:K,timeScale:$,onTimeScaleChange:Te,zoom:he,onZoomChange:et,currentTheme:Y,onThemeChange:Le,rowDensity:xe,onRowDensityChange:$e,showThemeSelector:p,showCreateTaskButton:k,createTaskLabel:h,onCreateTask:b,onExportPNG:n?ap:void 0,onExportPDF:n?rp:void 0,onExportExcel:n?op:void 0,onExportCSV:n?np:void 0,onExportJSON:n?sp:void 0,onExportMSProject:n?ip:void 0}),jsxRuntime.jsxs("div",{ref:qe,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:"auto"},children:jsxRuntime.jsx(tn,{tasks:at,theme:K,rowHeight:Wa,availableUsers:m,templates:vt,onTaskClick:D,onTaskDblClick:Ui,onTaskContextMenu:A,onTaskToggle:Zr,scrollTop:Me,columns:Ae,onToggleColumn:cr,onColumnResize:Xa,onTaskUpdate:de,onTaskIndent:Et,onTaskOutdent:Jt,onTaskMove:Mo,onMultiTaskDelete:Ja,onTaskDuplicate:Ha,onTaskCreate:pr,onTaskRename:Ot,onCreateSubtask:Qr,onOpenTaskModal:D?S=>D(S):void 0,onDeleteRequest:(S,P)=>mt({taskId:S,taskName:P}),onTaskReparent:Ar})}),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:lp}),jsxRuntime.jsx("div",{ref:He,className:"gantt-timeline-scroll flex-1",style:{minHeight:0,overflowX:"auto",overflowY:"auto",...a.disableScrollSync&&{scrollBehavior:"auto",overflowAnchor:"none"}},children:jsxRuntime.jsx(cn,{tasks:at,theme:K,rowHeight:Wa,timeScale:$,startDate:ep,endDate:tp,zoom:he,templates:vt,onTaskClick:D,onTaskDblClick:Ui,onTaskContextMenu:$i,onTaskDateChange:Ln,onDependencyCreate:Hi,onDependencyDelete:Gi})})]}),re.task&&jsxRuntime.jsx(Vr,{isOpen:re.isOpen,x:re.x,y:re.y,theme:K,onClose:()=>ce({isOpen:false,x:0,y:0,task:null}),items:(()=>{let S=re.task;if(!S)return [];let P=le.findTaskById(I,S.id)||S;return P.subtasks&&P.subtasks.length>0?[{id:"addSubtask",label:ie.contextMenu?.addSubtask||"Add Subtask",icon:Dt.Add,onClick:()=>{w?w(P):Qr(P.id);}},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:ie.contextMenu?.deleteTask||"Delete Task",icon:Dt.Delete,onClick:()=>{mt({taskId:P.id,taskName:P.name});}}]:[{id:"edit",label:ie.contextMenu?.editTask||"Edit Task",icon:Dt.Pencil,onClick:()=>{T?T(P):Ee(P);}},{id:"addSubtask",label:ie.contextMenu?.addSubtask||"Add Subtask",icon:Dt.Add,onClick:()=>{w?w(P):Qr(P.id);}},{id:"separator-status",label:"",separator:true,onClick:()=>{}},{id:"markIncomplete",label:ie.contextMenu?.markIncomplete||"Mark Incomplete",icon:Dt.MarkIncomplete,onClick:()=>{R?R(P):de(P.id,{status:"todo",progress:0});},disabled:P.status==="todo"},{id:"setInProgress",label:ie.contextMenu?.setInProgress||"Set In Progress",icon:Dt.SetInProgress,onClick:()=>{M?M(P):de(P.id,{status:"in-progress"});},disabled:P.status==="in-progress"},{id:"markComplete",label:ie.contextMenu?.markComplete||"Mark Complete",icon:Dt.MarkComplete,onClick:()=>{de(P.id,{status:"completed",progress:100});},disabled:P.status==="completed"},{id:"separator-advanced",label:"",separator:true,onClick:()=>{}},{id:"split",label:ie.contextMenu?.splitTask||"Split Task",icon:Dt.Split,onClick:()=>{if(!P.startDate||!P.endDate){console.warn("Cannot split task without dates");return}let ee=P.startDate.getTime(),pe=P.endDate.getTime(),we=ee+(pe-ee)/2,xt=new Date(we);eo(P,xt);},disabled:!P.startDate||!P.endDate},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:ie.contextMenu?.deleteTask||"Delete Task",icon:Dt.Delete,onClick:()=>{mt({taskId:P.id,taskName:P.name});}}]})()}),Ce&&jsxRuntime.jsx(mn,{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:()=>mt(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:()=>mt(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]),mt(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(un,{tasks:I,theme:K,config:x,onTasksUpdate:q,onTaskUpdate:de,onTaskCreate:S=>{q(P=>[...P,S]);},onTaskDelete:S=>{Ja([S]);},onDependencyCreate:(S,P)=>{let V=le.findTaskById(I,S);V&&Hi(V,P);},onDependencyDelete:Gi})]})})})});var Wd=`You are a Gantt chart AI assistant. You help users edit project tasks using natural language commands.
|
|
344
|
+
Task dependencies must flow in one direction only.`);return}let V=ee=>ee.map(pe=>{if(pe.id===P){let we=pe.dependencies||[];if(!we.includes(S.id))return {...pe,dependencies:[...we,S.id]}}return pe.subtasks?{...pe,subtasks:V(pe.subtasks)}:pe});q(V(I)),H?.(S.id,P);},[I,H,Wi]),Gi=react.useCallback((S,P)=>{let V=ee=>ee.map(pe=>{if(pe.id===S&&pe.dependencies){let we=pe.dependencies.filter(xt=>xt!==P);return {...pe,dependencies:we}}return pe.subtasks?{...pe,subtasks:V(pe.subtasks)}:pe});q(V(I)),X?.(S,P);},[I,X]),{startDate:ep,endDate:tp}=react.useMemo(()=>{let S=I.filter(we=>we.startDate&&we.endDate);if(S.length===0){let we=new Date,xt=new Date(we);xt.setDate(xt.getDate()-30);let Zt=new Date(we);return Zt.setDate(Zt.getDate()+60),{startDate:xt,endDate:Zt}}let P=S.flatMap(we=>[we.startDate,we.endDate]).filter(we=>we!==void 0),V=new Date(Math.min(...P.map(we=>we.getTime()))),ee=new Date(Math.max(...P.map(we=>we.getTime()))),pe=$==="day"?7:$==="week"?14:30;return V.setDate(V.getDate()-pe),ee.setDate(ee.getDate()+pe),{startDate:V,endDate:ee}},[I,$]),ap=react.useCallback(async()=>{if(!U.current)return;let S=await $d__default.default(U.current,{backgroundColor:K.bgPrimary,scale:2}),P=document.createElement("a");P.download="gantt-chart.png",P.href=S.toDataURL("image/png"),P.click();},[K]),rp=react.useCallback(async()=>{await le.exportToPDF(I);},[I]),op=react.useCallback(async()=>{await le.exportToExcel(I);},[I]),np=react.useCallback(()=>{let S=le.exportToCSV(I),P=new Blob([S],{type:"text/csv;charset=utf-8;"}),V=document.createElement("a");V.href=URL.createObjectURL(P),V.download="gantt-chart.csv",V.click(),URL.revokeObjectURL(V.href);},[I]),sp=react.useCallback(()=>{let S=le.exportToJSON(I),P=new Blob([S],{type:"application/json;charset=utf-8;"}),V=document.createElement("a");V.href=URL.createObjectURL(P),V.download="gantt-chart.json",V.click(),URL.revokeObjectURL(V.href);},[I]),ip=react.useCallback(()=>{le.exportToMSProject(I,"Gantt Project","project.xml");},[I]),lp=S=>{S.preventDefault(),St(true);},Ir=react.useRef(false);return react.useEffect(()=>{let S=He.current,P=qe.current?.querySelector(".gantt-grid-scroll");if(!S||!P)return;let V=()=>{if(Ir.current)return;Ir.current=true;let xt=S.scrollTop;Ze(xt),P.scrollTop=xt,requestAnimationFrame(()=>{Ir.current=false;});},ee=()=>{if(Ir.current)return;Ir.current=true;let xt=P.scrollTop;Ze(xt),S.scrollTop=xt,requestAnimationFrame(()=>{Ir.current=false;});},pe=xt=>{if(ht&&P){let Ta=P.parentElement?.getBoundingClientRect()?.left||0,Da=xt.clientX-Ta,Ga=200,to=ut+j,dp=window.innerWidth*Z,cp=Math.max(to,dp);Da>=Ga&&Da<=cp&&O(Da);}},we=()=>{St(false);};return S.addEventListener("scroll",V),P.addEventListener("scroll",ee),document.addEventListener("mousemove",pe),document.addEventListener("mouseup",we),()=>{S.removeEventListener("scroll",V),P.removeEventListener("scroll",ee),document.removeEventListener("mousemove",pe),document.removeEventListener("mouseup",we);}},[ht,ut]),jsxRuntime.jsx(_r.Provider,{value:ie,children:jsxRuntime.jsx(zn.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(Jo,{theme:K,timeScale:$,onTimeScaleChange:Te,zoom:he,onZoomChange:et,currentTheme:Y,onThemeChange:Le,rowDensity:xe,onRowDensityChange:$e,showThemeSelector:p,showCreateTaskButton:k,createTaskLabel:h,onCreateTask:b,onExportPNG:n?ap:void 0,onExportPDF:n?rp:void 0,onExportExcel:n?op:void 0,onExportCSV:n?np:void 0,onExportJSON:n?sp:void 0,onExportMSProject:n?ip:void 0}),jsxRuntime.jsxs("div",{ref:qe,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(tn,{tasks:at,theme:K,rowHeight:Wa,availableUsers:m,templates:vt,onTaskClick:D,onTaskDblClick:Ui,onTaskContextMenu:A,onTaskToggle:Zr,scrollTop:Me,columns:Ae,onToggleColumn:cr,onColumnResize:Xa,onTaskUpdate:de,onTaskIndent:Et,onTaskOutdent:Jt,onTaskMove:Mo,onMultiTaskDelete:Ja,onTaskDuplicate:Ha,onTaskCreate:pr,onTaskRename:Ot,onCreateSubtask:Qr,onOpenTaskModal:D?S=>D(S):void 0,onDeleteRequest:(S,P)=>mt({taskId:S,taskName:P}),onTaskReparent:Ar})}),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:lp}),jsxRuntime.jsx("div",{ref:He,className:"gantt-timeline-scroll flex-1",style:{minHeight:0,overflowX:"auto",overflowY:"auto",...a.disableScrollSync&&{scrollBehavior:"auto",overflowAnchor:"none"}},children:jsxRuntime.jsx(cn,{tasks:at,theme:K,rowHeight:Wa,timeScale:$,startDate:ep,endDate:tp,zoom:he,templates:vt,onTaskClick:D,onTaskDblClick:Ui,onTaskContextMenu:$i,onTaskDateChange:Ln,onDependencyCreate:Hi,onDependencyDelete:Gi})})]}),re.task&&jsxRuntime.jsx(Vr,{isOpen:re.isOpen,x:re.x,y:re.y,theme:K,onClose:()=>ce({isOpen:false,x:0,y:0,task:null}),items:(()=>{let S=re.task;if(!S)return [];let P=le.findTaskById(I,S.id)||S;return P.subtasks&&P.subtasks.length>0?[{id:"addSubtask",label:ie.contextMenu?.addSubtask||"Add Subtask",icon:Dt.Add,onClick:()=>{w?w(P):Qr(P.id);}},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:ie.contextMenu?.deleteTask||"Delete Task",icon:Dt.Delete,onClick:()=>{mt({taskId:P.id,taskName:P.name});}}]:[{id:"edit",label:ie.contextMenu?.editTask||"Edit Task",icon:Dt.Pencil,onClick:()=>{T?T(P):Ee(P);}},{id:"addSubtask",label:ie.contextMenu?.addSubtask||"Add Subtask",icon:Dt.Add,onClick:()=>{w?w(P):Qr(P.id);}},{id:"separator-status",label:"",separator:true,onClick:()=>{}},{id:"markIncomplete",label:ie.contextMenu?.markIncomplete||"Mark Incomplete",icon:Dt.MarkIncomplete,onClick:()=>{R?R(P):de(P.id,{status:"todo",progress:0});},disabled:P.status==="todo"},{id:"setInProgress",label:ie.contextMenu?.setInProgress||"Set In Progress",icon:Dt.SetInProgress,onClick:()=>{M?M(P):de(P.id,{status:"in-progress"});},disabled:P.status==="in-progress"},{id:"markComplete",label:ie.contextMenu?.markComplete||"Mark Complete",icon:Dt.MarkComplete,onClick:()=>{de(P.id,{status:"completed",progress:100});},disabled:P.status==="completed"},{id:"separator-advanced",label:"",separator:true,onClick:()=>{}},{id:"split",label:ie.contextMenu?.splitTask||"Split Task",icon:Dt.Split,onClick:()=>{if(!P.startDate||!P.endDate){console.warn("Cannot split task without dates");return}let ee=P.startDate.getTime(),pe=P.endDate.getTime(),we=ee+(pe-ee)/2,xt=new Date(we);eo(P,xt);},disabled:!P.startDate||!P.endDate},{id:"separator-delete",label:"",separator:true,onClick:()=>{}},{id:"delete",label:ie.contextMenu?.deleteTask||"Delete Task",icon:Dt.Delete,onClick:()=>{mt({taskId:P.id,taskName:P.name});}}]})()}),Ce&&jsxRuntime.jsx(mn,{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:()=>mt(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:()=>mt(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]),mt(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(un,{tasks:I,theme:K,config:x,onTasksUpdate:q,onTaskUpdate:de,onTaskCreate:S=>{q(P=>[...P,S]);},onTaskDelete:S=>{Ja([S]);},onDependencyCreate:(S,P)=>{let V=le.findTaskById(I,S);V&&Hi(V,P);},onDependencyDelete:Gi})]})})})});var Wd=`You are a Gantt chart AI assistant. You help users edit project tasks using natural language commands.
|
|
345
345
|
|
|
346
346
|
AVAILABLE COMMANDS:
|
|
347
347
|
1. move_task - Move a task to a different date
|