@progress/kendo-react-gantt 7.1.0-develop.7 → 7.1.0-develop.8

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/index.js CHANGED
@@ -2,4 +2,4 @@
2
2
  * Copyright © 2024 Progress Software Corporation. All rights reserved.
3
3
  * Licensed under commercial license. See LICENSE.md in the package root for more information
4
4
  *-------------------------------------------------------------------------------------------*/
5
- "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const la=require("react"),i=require("prop-types"),h=require("@progress/kendo-react-common"),k=require("@progress/kendo-date-math"),y=require("@progress/kendo-react-data-tools"),ue=require("@progress/kendo-react-treelist"),B=require("@progress/kendo-react-intl"),gt=require("@progress/kendo-svg-icons"),ae=require("@progress/kendo-react-buttons"),ia=require("react-dom"),se=require("@progress/kendo-react-form"),Ae=require("@progress/kendo-react-dialogs"),le=require("@progress/kendo-react-labels"),Gt=require("@progress/kendo-react-inputs"),ca=require("@progress/kendo-react-dateinputs");function Wt(e){const a=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const n in e)if(n!=="default"){const o=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(a,n,o.get?o:{enumerable:!0,get:()=>e[n]})}}return a.default=e,Object.freeze(a)}const t=Wt(la),Pt=Wt(ia),da=y.TABLE_ROW_INDEX_ATTRIBUTE,ua=y.TABLE_COL_INDEX_ATTRIBUTE,ma=y.TABLE_PREVENT_SELECTION_ELEMENT,Lt=new Date().getTime(),_t=7,ga="hh:mm a",rt={skeleton:"MEd"},ha="MMM",fa="yyyy",Ie=100,pa=6,Oe="data-dependency-drag-handle",Ca="start",ka="finish",zt={[Oe]:Ca},Ht={[Oe]:ka},Ve="data-task-id",Kt={id:"id",start:"start",end:"end",title:"title",percentComplete:"percentComplete",isRollup:"isRollup",isExpanded:"isExpanded",isInEdit:"isInEdit",children:"children",isSelected:"isSelected"},Bt={id:"id",fromId:"fromId",toId:"toId",type:"type"},Da=y.orderBy,Ea=y.filterBy,Ge=h.mapTree,wa=h.extendDataItem,ya=ue.createDataTree,ba=e=>({fields:{...Kt,...e}}),va=e=>({fields:{...Bt,...e}}),Ut=e=>k.getDate(e),ht=(e,a)=>k.getDate(k.addDays(e,a||1)),Ta=(e,a,n,o)=>n<a&&e<=o;function ie(e){return new Date(Date.UTC(e.getFullYear(),e.getMonth(),e.getDate(),e.getHours(),e.getMinutes(),e.getSeconds(),e.getMilliseconds()))}const ne=4,ot=10,Ra=(e,a,n,o)=>{const s=[];let l=0,r=0;const c=ot,m=Math.floor(n/2),g=e.top<a.top,d=()=>s.push({left:r,top:l});if(o===0||o===3){const u=o===3?"start":"end";l=e.top,r=e[u],d(),r=Math[u==="start"?"min":"max"](e[u],a[u]),r=u==="start"?r-c:r+c,d(),l=a.top,d(),r=u==="start"?a[u]-ne:a[u]+ne,d(),At(l,r,s,u!=="start")}else{const u=o===2?"start":"end",f=o===2?"end":"start",C=o===2?e[u]-ot*2>=a[f]:e[u]+ot*2<=a[f];l=e.top,r=e[u],d(),r=u==="start"?r-c:r+c,d(),C||(l=g?l+m:l-m,d(),r=u==="start"?a[f]+c:a[f]-c,d()),l=a.top,d(),r=f==="start"?a[f]-ne:a[f]+ne,d(),At(l,r,s,f!=="start")}return s},At=(e,a,n,o)=>o?Sa(e,a,n):Ia(e,a,n),Sa=(e,a,n)=>{n.push({top:e-ne/2,left:a}),n.push({top:e,left:a-ne+1}),n.push({top:e+ne/2,left:a}),n.push({top:e,left:a})},Ia=(e,a,n)=>{n.push({top:e+ne/2,left:a}),n.push({top:e,left:a+ne-1}),n.push({top:e-ne/2,left:a}),n.push({top:e,left:a})},qt=e=>{if(e.workWeekStart===void 0||e.workWeekEnd===void 0)return[];const a=[];let n=e.workWeekStart;for(a.push(n);e.workWeekEnd!==n;)n>6?n-=7:n++,a.push(n);return a},xa=(e,a)=>{const n=e.getDay();return a.indexOf(n)>-1},$t=(e,{step:a,timezone:n})=>{const o=[],s=k.ZonedDate.fromLocalDate(e.start,n),l=k.ZonedDate.fromLocalDate(e.end,n);let r=s.clone();for(;r.getTime()<l.getTime();){const c=r.clone(),m=c.clone().addTime(a),g=new Date(c.getTime()),u={end:new Date(m.getTime()),start:g,zonedStart:c,zonedEnd:m};o.push(u),r=r.addTime(a)}return o},Na=(e,{timezone:a},n)=>{const o=[],s=k.ZonedDate.fromLocalDate(e.start,a),l=k.ZonedDate.fromLocalDate(e.end,a);for(let r=s.clone(),c=0;r.getTime()<l.getTime();c++){const m=r.clone(),g=ht(k.firstDayInWeek(k.getDate(m),n.firstDay()),_t),d=k.ZonedDate.fromUTCDate(ie(g),a),u=d.getTime()>l.getTime()?l.clone():d;r=u.clone();const f=new Date(m.getTime()),D={end:new Date(u.getTime()),start:f,zonedStart:m,zonedEnd:u};o.push(D)}return o},Ma=(e,{timezone:a})=>{const n=[],o=k.ZonedDate.fromLocalDate(e.start,a),s=k.ZonedDate.fromLocalDate(e.end,a);for(let l=o.clone(),r=0;l.getTime()<s.getTime();r++){const c=l.clone(),m=k.ZonedDate.fromLocalDate(k.addMonths(new Date(c.getTime()),1),a);l=m.clone();const g=new Date(c.getTime()),u={end:new Date(m.getTime()),start:g,zonedStart:c,zonedEnd:m};n.push(u)}return n},Fa=(e,{timezone:a})=>{const n=[],o=k.ZonedDate.fromLocalDate(e.start,a),s=k.ZonedDate.fromLocalDate(e.end,a);for(let l=o.clone(),r=0;l.getTime()<s.getTime();r++){const c=l.clone(),m=k.ZonedDate.fromLocalDate(k.addMonths(new Date(c.getTime()),12),a);l=m.clone();const g=new Date(c.getTime()),u={end:new Date(m.getTime()),start:g,zonedStart:c,zonedEnd:m};n.push(u)}return n},La=(e,a,n)=>{const o=n.parseDate(a.workDayStart).getHours(),s=n.parseDate(a.workDayEnd).getHours();return $t(e,{step:k.MS_PER_MINUTE*a.slotDuration,timezone:a.timezone}).map(r=>{const c=r.zonedStart.getHours();return{range:r,isWork:c>=o&&c<s,span:1,text:n.formatDate(r.zonedStart,ga),type:"time"}})},Yt=(e,a,n)=>$t(e,{step:k.MS_PER_DAY,timezone:a.timezone}).map(s=>({range:s,isWork:xa(s.start,a.workDays),span:1,text:n.formatDate(s.zonedStart,rt),type:"day"})),Zt=(e,a,n)=>Na(e,{timezone:a.timezone},n).map(s=>{const l=Math.round((s.zonedEnd.getTime()-s.zonedStart.getTime())/k.MS_PER_DAY);return{range:s,isWork:!1,span:l,text:`${n.formatDate(s.zonedStart,rt)} - ${n.formatDate(s.zonedEnd,rt)}`,type:"week"}}),jt=(e,a,n)=>Ma(e,{timezone:a.timezone}).map(s=>{const l=Math.round((s.zonedEnd.getTime()-s.zonedStart.getTime())/k.MS_PER_DAY);return{range:s,isWork:!1,span:l,text:n.formatDate(s.zonedStart,ha),type:"month"}}),za=(e,a,n)=>Fa(e,{timezone:a.timezone}).map(s=>{const l=Math.round((s.zonedEnd.getTime()-s.zonedStart.getTime())/k.MS_PER_DAY);return{range:s,isWork:!1,span:l,text:n.formatDate(s.zonedStart,fa),type:"year"}}),Ha=(e,a,n)=>{const o=n;return t.createElement("table",{className:"k-table k-table-md",ref:a,"aria-hidden":!0},t.createElement("tbody",{className:"k-table-tbody"},e.map((s,l)=>t.createElement("tr",{className:"k-table-row",key:l},s.map((r,c)=>t.createElement("td",{key:r.range.start.getTime(),colSpan:r.span,className:h.classNames("k-table-th",{"k-header":!0,"k-nonwork-hour":!r.isWork})},o?t.createElement(o,{rowIndex:l,index:c,range:r.range,text:r.text,isWork:r.isWork,type:r.type}):r.text))))))},Aa=(e,a)=>{const n=e[e.length-1];return t.createElement("table",{className:"k-table k-table-md k-gantt-columns",ref:a,"aria-hidden":!0},t.createElement("tbody",{className:"k-table-tbody"},t.createElement("tr",{className:"k-table-row"},n.map(o=>t.createElement("td",{key:o.range.start.getTime(),colSpan:o.span,className:h.classNames("k-table-td",{"k-nonwork-hour":!o.isWork})})))))},Oa=(e,a)=>{const n=e[e.length-1];let o=0,s=0;return n.forEach(l=>{const r=l.span;s+=r,r>o&&(o=r)}),Math.round(s*a/o)},st=(e,a)=>!!h.getter(a)(e),Xt=(e,a)=>!!h.getter(a)(e),Va=(e,a)=>n=>st(n,e)&&Xt(n,a)?[...h.getter(a)(n)]:[],ft=t.createContext([]),Ga=()=>t.useContext(ft);ft.displayName="KendoReactGanttTaskDataContext";const pt=t.createContext([]),Wa=()=>t.useContext(pt);pt.displayName="KendoReactGanttDependencyDataContext";const Ct=t.createContext(Kt),kt=()=>t.useContext(Ct);Ct.displayName="KendoReactGanttTaskModelFieldsContext";const Dt=t.createContext(Bt),Jt=()=>t.useContext(Dt);Dt.displayName="KendoReactGanttDependencyModelFieldsContext";const Et=t.createContext({}),xe=()=>t.useContext(Et);Et.displayName="KendoReactGanttPropsContext";const wt=t.createContext({start:new Date,end:new Date,zonedStart:k.ZonedDate.fromLocalDate(new Date),zonedEnd:k.ZonedDate.fromLocalDate(new Date)}),Ne=()=>t.useContext(wt);wt.displayName="KendoReactGanttDateRangeContext";const yt=t.createContext([]),Pa=()=>t.useContext(yt);yt.displayName="KendoReactGanttViewsContext";const bt=t.createContext(["week",h.noop]),Qt=()=>t.useContext(bt);bt.displayName="KendoReactGanttActiveViewContext";const vt=t.createContext(0),en=()=>t.useContext(vt);vt.displayName="KendoReactGanttRowHeightContext";const Tt=t.createContext(0),_a=()=>t.useContext(Tt);Tt.displayName="KendoReactGanttToolbarHeightContext";const Rt=t.createContext({onDataStateChange:h.noop,onSortChange:h.noop,onFilterChange:h.noop,onColumnMenuFilterChange:h.noop,onExpandChange:h.noop,onRowClick:h.noop,onRowDoubleClick:h.noop,onRowContextMenu:h.noop,onColumnResize:h.noop,onColumnReorder:h.noop,onDependencyCreate:h.noop,onKeyDown:h.noop,onSelectionChange:h.noop,onHeaderSelectionChange:h.noop}),Ka=()=>t.useContext(Rt);Rt.displayName="KendoReactGanttEventsContext";const St=t.createContext({onTaskClick:h.noop,onTaskDoubleClick:h.noop,onTaskContextMenu:h.noop}),Ba=()=>t.useContext(St);St.displayName="KendoReactGanttTaskEventsContext";const tn=({children:e,taskData:a,dependencyData:n,taskModelFields:o,dependencyModelFields:s,props:l,dateRange:r,views:c,activeView:m,rowHeight:g,toolbarHeight:d,events:u,taskEvents:f})=>t.createElement(Et.Provider,{value:l},t.createElement(ft.Provider,{value:a},t.createElement(pt.Provider,{value:n},t.createElement(Ct.Provider,{value:o},t.createElement(Dt.Provider,{value:s},t.createElement(wt.Provider,{value:r},t.createElement(yt.Provider,{value:c},t.createElement(bt.Provider,{value:m},t.createElement(vt.Provider,{value:g},t.createElement(Tt.Provider,{value:d},t.createElement(Rt.Provider,{value:u},t.createElement(St.Provider,{value:f},e))))))))))));tn.displayName="KendoReactGanttContext";const It=t.createContext([{current:{}},h.noop]),nn=()=>t.useContext(It);It.displayName="KendoReactGanttViewContext";const xt=t.createContext(0),Ua=()=>t.useContext(xt);xt.displayName="KendoReactGanttViewTimelineWidthContext";const Nt=t.createContext({onDependencyHandlePress:h.noop,onDependencyHandleDrag:h.noop,onDependencyHandleRelease:h.noop,isEnabled:!1,draggedId:null}),qa=()=>t.useContext(Nt);Nt.displayName="KendoReactGanttViewDependencyDragContext";const an=({children:e,tasksStore:a,timelineWidth:n,dependencyDrag:o})=>t.createElement(It.Provider,{value:a},t.createElement(xt.Provider,{value:n},t.createElement(Nt.Provider,{value:o},e)));an.displayName="KendoReactGanttViewContext";var lt=(e=>(e[e.add=0]="add",e[e.remove=1]="remove",e))(lt||{});const $a=()=>{const e=t.useRef({}),a=t.useCallback(n=>{switch(n.type){case 0:e.current[n.id]=n.itemRef;break;case 1:delete e.current[n.id];break}},[]);return[e,a]},Ya=(e,a,n,o)=>{const s=t.useRef(null),[,l]=nn();t.useImperativeHandle(s,()=>({element:o.current,dataItem:e})),t.useImperativeHandle(n,()=>s.current),t.useLayoutEffect(()=>{const r=s.current;if(r)return l({type:lt.add,itemRef:r,id:a}),()=>{l({type:lt.remove,itemRef:r,id:a})}})},on=t.forwardRef((e,a)=>{const n=Ne(),o=kt(),s=Ua(),l=qa(),r=Ba(),c=t.useRef(null),m=t.useRef(null);Ya(e.dataItem,h.getter(o.id)(e.dataItem),a,c);const g=t.useRef(null),d=h.getter(o.id)(e.dataItem),u=h.getter(o.start)(e.dataItem),f=h.getter(o.end)(e.dataItem),C=h.getter(o.title)(e.dataItem),D=h.getter(o.percentComplete)(e.dataItem),p=h.getter(o.children)(e.dataItem),T=h.getter(o.isSelected)(e.dataItem),L=u&&u.getTime(),A=f&&f.getTime(),M=p&&p.length,x=!M&&L===A,O=L&&A&&Ta(n.start,n.end,u,f),[Q,S]=t.useState(!1),j=t.useRef(null),H=t.useRef(null);h.useDraggable(j,{onPress:l.onDependencyHandlePress,onDrag:l.onDependencyHandleDrag,onRelease:l.onDependencyHandleRelease}),h.useDraggable(H,{onPress:l.onDependencyHandlePress,onDrag:l.onDependencyHandleDrag,onRelease:l.onDependencyHandleRelease});const X=t.useCallback(b=>{r.onTaskClick&&r.onTaskClick({dataItem:e.dataItem,level:e.level,nativeEvent:b&&b.nativeEvent,syntheticEvent:b,target:null})},[e.dataItem,e.level]),V=t.useCallback(b=>{r.onTaskDoubleClick&&r.onTaskDoubleClick({dataItem:e.dataItem,level:e.level,nativeEvent:b&&b.nativeEvent,syntheticEvent:b,target:null})},[e.dataItem,e.level]),U=t.useCallback(b=>{r.onTaskContextMenu&&r.onTaskContextMenu({dataItem:e.dataItem,level:e.level,nativeEvent:b&&b.nativeEvent,syntheticEvent:b,target:null})},[e.dataItem,e.level]),w=t.useCallback(b=>{r.onTaskRemoveClick&&r.onTaskRemoveClick({dataItem:e.dataItem,level:e.level,nativeEvent:b&&b.nativeEvent,syntheticEvent:b,target:null})},[e.dataItem,e.level]),z=t.useCallback(()=>{const b=n.start,J=n.end,R=g.current,I=c.current,K=m.current;if(!O||R===null||I===null)return;const Y=R.clientWidth/(J.getTime()-b.getTime()),G=(u.getTime()-b.getTime())*Y,W=(f.getTime()-u.getTime())*Y,fe=(R.offsetHeight-I.offsetHeight)/2;I.style.left=`${Math.round(x?G-pa:G)}px`,I.style.top=`${Math.round(fe)}px`,x||(I.style.width=`${Math.round(W)}px`,K!==null&&(K.style.width=`${Math.round(W*(D||0))}px`)),S(!0)},[n.start.getTime(),n.end.getTime(),L,A,O,D,s]);t.useEffect(z,[z]);const ee={visibility:Q?void 0:"hidden",display:O?void 0:"none"},_={userSelect:"none",display:l.draggedId===String(d)?"block":void 0};return t.createElement("td",{ref:g,key:d,role:"presentation"},x?t.createElement("div",{"aria-hidden":!0,className:h.classNames({"k-task":!0,"k-task-milestone":!0,"k-selected":T&&!Array.isArray(T)}),style:ee,ref:c,[Ve]:d,onClick:X,onDoubleClick:V,onContextMenu:U},t.createElement("div",{className:"k-task-milestone-content"}),l.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-start",ref:j,style:_,...zt}),l.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-end",ref:H,style:_,...Ht})):t.createElement("div",{"aria-hidden":!0,className:h.classNames({"k-task":!0,"k-task-summary":M,"k-task-single":!M,"k-selected":T&&!Array.isArray(T)}),ref:c,style:ee,[Ve]:d,onClick:X,onDoubleClick:V,onContextMenu:U},M?t.createElement("div",{className:"k-task-summary-progress",ref:m},t.createElement("div",{className:"k-task-summary-complete"})):t.createElement("div",{className:"k-task-complete",ref:m}),!M&&t.createElement(t.Fragment,null,t.createElement("div",{className:"k-task-content"},C),r.onTaskRemoveClick?t.createElement("span",{className:"k-task-actions"},t.createElement("span",{onClick:w,className:"k-link k-task-delete","aria-label":"Delete"},t.createElement(h.IconWrap,{name:"x",icon:gt.xIcon}))):null),l.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-start",ref:j,style:_,...zt}),l.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-end",ref:H,style:_,...Ht})))});on.displayName="KendoReactGanttTask";const rn=e=>{const{dependency:a}=e,[n]=nn(),o=t.useRef(null),s=Jt(),l=en(),[r,c]=t.useState(!1),m=()=>{if(o.current===null||n.current===null){c(!1);return}const g=n.current[h.getter(s.fromId)(a)],d=n.current[h.getter(s.toId)(a)];if(!g||!d){c(!1);return}const u=g.element,f=d.element;if(!u||!f){c(!1);return}if(r===!1){c(!0);return}const C={top:u.offsetTop+u.offsetHeight/2,start:u.offsetLeft,end:u.offsetLeft+u.offsetWidth},D={top:f.offsetTop+f.offsetHeight/2,start:f.offsetLeft,end:f.offsetLeft+f.offsetWidth},p=h.getter(s.type)(a),T=Ra(C,D,l,p);T&&T.length&&o.current.setAttribute("points",T.map(L=>`${L.left},${L.top}`).join(" "))};return t.useEffect(m),t.createElement("polyline",{ref:o,style:{display:r?void 0:"none"}})};rn.displayName="KendoReactGanttDependency";class Mt extends t.Component{constructor(a){super(a),this.state={activeId:void 0,level:0},this.tableElement=null,this.tbodyElement=null,this.wrapperScrollLeft=0,this.wrapperScrollTop=0,this.updateOnScroll=!1,this.tbodyOffsetTop=0,this.prevData=[],this.flattedData=[],this.element=null,this.contextStateRef={current:void 0},this.navigationStateRef={current:void 0},this.scrollIntoView=n=>{if(!this.element)return;const{rowIndex:o=0}=n,{rowHeight:s=0}=this.props;this.element.scroll(0,(o-1)*s)},this.getColumns=n=>{const o=n.filter(l=>l.declarationIndex>=0&&l.parentIndex===-1),s=l=>(l.sort((r,c)=>r.declarationIndex-c.declarationIndex),l.map(r=>{const{declarationIndex:c,parentIndex:m,depth:g,colSpan:d,rowSpan:u,index:f,kFirst:C,groupable:D,children:p,...T}=r;return p.length?{children:s(p),...T}:T}));return s(o)},this.onKeyDown=n=>{if(y.tableKeyboardNavigation.onKeyDown(n,{contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef}),this.props.onKeyDown){const{mode:o,cell:s}=y.getSelectionOptions(this.props.selectable),l={dataItems:this.getLeafDataItems(),mode:o,cell:s,componentId:this.props.treelistId,selectedField:this.props.selectedField,...this.getEventArguments(n)};this.props.onKeyDown.call(void 0,l)}},this.onFocus=n=>{y.tableKeyboardNavigation.onFocus(n,{contextStateRef:this.contextStateRef})},this.onRowDrag=n=>{if(this.props.onRowDrag){const o={...n,target:this};this.props.onRowDrag.call(void 0,o)}},this.onRowDrop=n=>{if(this.props.onRowDrop){const o={...n,target:this};this.props.onRowDrop.call(void 0,o)}},this.onColumnReorder=(n,o,s)=>{const{extendedColumns:l}=this.props,r=l[n].depth,c=d=>{do d++;while(d<l.length&&l[d].depth>r);return d},m=[...l],g=m.splice(n,c(n)-n);if(m.splice(n<o?c(o-g.length):o,0,...g),m.filter(d=>d.declarationIndex>=0).forEach((d,u)=>d.orderIndex=u),this.props.onColumnReorder){const d={target:this,columns:this.getColumns(m),nativeEvent:s};this.props.onColumnReorder.call(void 0,d)}},this.onColumnResize=(n,o,s,l,r)=>{if(this.props.onColumnResize){const c=this.props.extendedColumns.filter(g=>g.children.length===0).reduce((g,d)=>g+=parseFloat(String(d.width)),0);this.tableElement&&(this.tableElement.style.width=c+"px");const m={columns:this.getColumns(this.props.extendedColumns),totalWidth:c,index:n,nativeEvent:l,newWidth:o,oldWidth:s,end:r,target:this};this.props.onColumnResize.call(void 0,m)}},this.onScroll=n=>{const o=n.currentTarget.scrollLeft,s=n.currentTarget.scrollTop,{columnVirtualization:l,scrollable:r,rowHeight:c=0}=this.props,m=c,g=0;let d=!1;l&&Math.abs(this.wrapperScrollLeft-o)>g&&(this.wrapperScrollLeft=o,d=!0),r==="virtual"&&Math.abs(this.wrapperScrollTop-s)>m&&(this.wrapperScrollTop=s,d=!0),d&&(this.updateOnScroll=!0,this.forceUpdate())},this.calculateSizes=n=>{if(!n||this.props.scrollable==="none")return;const o=Array.from(n.childNodes),s=o.find(c=>c.nodeName==="TABLE"),l=this.props.toolbar&&o.find(c=>c.nodeType===1&&c.classList.contains("k-grid-toolbar"));let r=0;if(l){const c=l.style.boxSizing;l.style.boxSizing="border-box",r=parseFloat(String(window.getComputedStyle(l).height))||l.offsetHeight,l.style.boxSizing=c,l.getAttribute("style")||l.removeAttribute("style")}this.tbodyOffsetTop=s.tBodies[0].offsetTop,ue.setHeaderRowsTop(s,r)},this.onItemChange=n=>{if(n.field===this.props.expandField){const o=this.props.onExpandChange;if(o){const s={...this.getEventArguments(n.syntheticEvent),dataItem:n.dataItem,level:n.level,value:n.value};o.call(void 0,s)}return}if(this.props.onItemChange){const o={...this.getEventArguments(n.syntheticEvent),dataItem:n.dataItem,level:n.level,field:n.field,value:n.value};this.props.onItemChange.call(void 0,o)}},this.onHeaderSelectionChange=n=>{if(this.props.onHeaderSelectionChange){const o={field:n.field,nativeEvent:n.syntheticEvent&&n.syntheticEvent.nativeEvent,syntheticEvent:n.syntheticEvent,target:this,dataItems:this.getLeafDataItems()};this.props.onHeaderSelectionChange.call(void 0,o)}},this.selectionRelease=n=>{if(this.props.onSelectionChange){const o={syntheticEvent:void 0,target:this,selectedField:this.props.selectedField||"",componentId:this.props.treelistId,dataItems:this.getLeafDataItems(),dataItem:null,level:[],...n};this.props.onSelectionChange.call(void 0,o)}},this.onSortChange=(n,o,s)=>{this.onDataStateChange(this.props.onSortChange,{sort:o,field:s},n)},this.onFilterChange=n=>{const{filter:o,field:s}=n;this.onDataStateChange(this.props.onFilterChange,{filter:o,field:s},n.syntheticEvent)},this.onColumnMenuFilterChange=(n,o,s)=>{if(!s)return;const{onColumnMenuFilterChange:l}=this.props;if(!l)return;const r={syntheticEvent:n,filter:o,field:s,target:this,nativeEvent:n.nativeEvent};l.call(void 0,r)},this.onExpandChange=(n,o,s)=>{const{expandField:l,onExpandChange:r}=this.props;if(l&&r){const c={...this.getEventArguments(n),dataItem:o,level:s,value:st(o,this.props.expandField)};r.call(void 0,c)}},this.onRowClick=(n,o)=>{if(this.props.onRowClick&&n.target.nodeName==="TD"){const s={dataItem:o.dataItem,level:o.level,...this.getEventArguments(n)};this.props.onRowClick.call(void 0,s)}},this.rowDoubleClick=(n,o)=>{if(this.props.onRowDoubleClick&&n.target.nodeName==="TD"){const s={dataItem:o.dataItem,level:o.level,...this.getEventArguments(n)};this.props.onRowDoubleClick.call(void 0,s)}},this.rowContextMenu=(n,o)=>{if(this.props.onRowContextMenu&&n.target.nodeName==="TD"){const s={dataItem:o.dataItem,level:o.level,...this.getEventArguments(n)};this.props.onRowContextMenu.call(void 0,s)}},this.onPageChange=n=>{if(this.props.onPageChange){const o={...this.getEventArguments(n.syntheticEvent),skip:n.skip,take:n.take};this.props.onPageChange.call(void 0,o)}},this.onDataStateChange=(n,o,s)=>{if(n&&n.call(void 0,{...this.getEventArguments(s),...o}),this.props.onDataStateChange){const l={...this.getEventArguments(s),dataState:{...this.getDataState(),...o}};this.props.onDataStateChange.call(void 0,l)}},this.getDataState=()=>({filter:this.props.filter,sort:this.props.sort}),this.getEventArguments=n=>({nativeEvent:n&&n.nativeEvent,syntheticEvent:n,target:this}),this.getLeafDataItems=()=>this.flatData.map(n=>n.dataItem),this.dragLogic=new y.CommonDragLogic(this.onColumnReorder,h.noop,h.noop),this.columnResize=new y.ColumnResize(this.onColumnResize),y.tableKeyboardNavigation.onConstructor({navigatable:!!a.navigatable,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef,idPrefix:a.idPrefix})}get document(){if(h.canUseDOM)return this.element&&this.element.ownerDocument||document}componentDidMount(){this.calculateSizes(this.element),y.tableKeyboardNavigation.onComponentDidMount({scope:this.element||void 0,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef})}getSnapshotBeforeUpdate(){return y.tableKeyboardNavigation.onGetSnapshotBeforeUpdate({document:this.document,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef}),null}componentDidUpdate(a){a.columns!==this.props.columns&&this.calculateSizes(this.element),y.tableKeyboardNavigation.onComponentDidUpdate({scope:this.element||void 0,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef})}componentWillUnmount(){this.columnResize.columns=[],this.dragLogic.columns=[],this.prevData=[],this.flattedData=[],this.updateOnScroll=!1}render(){const{filterRow:a,scrollable:n="scrollable",resizable:o=!1,reorderable:s=!1,skip:l,take:r,afterContent:c,extendedColumns:m=[],columnsMap:g}=this.props,d=m.some(w=>!!w.filter)||a!==void 0,u=a||y.FilterRow,f=y.tableKeyboardNavigationTools.getIdPrefix(this.navigationStateRef);this.columnResize.columns=m,this.columnResize.resizable=o,this.dragLogic.columns=m,this.dragLogic.reorderable=s,this.dragLogic.groupable=!1;const C=m.filter(w=>w.children.length===0),D=t.createElement(y.Header,{headerRow:t.createElement(y.HeaderRow,{sort:this.props.sort,sortable:this.props.sortable,sortChange:this.onSortChange,selectionChange:this.onHeaderSelectionChange,columns:m,columnsMap:g,cellRender:this.props.headerCellRender,columnResize:this.columnResize,columnMenu:this.props.columnMenu,columnMenuFilter:this.props.columnMenuFilter,columnMenuFilterChange:this.onColumnMenuFilterChange,pressHandler:this.dragLogic.pressHandler,dragHandler:this.dragLogic.dragHandler,releaseHandler:this.dragLogic.releaseHandler}),filterRow:d&&t.createElement(u,{columns:C,filter:this.props.filter,filterChange:this.onFilterChange,sort:this.props.sort,ariaRowIndex:g.length+1})||void 0,columnResize:this.columnResize}),p=this.props.style||{},{colSpans:T,hiddenColumns:L}=y.tableColumnsVirtualization({enabled:this.props.columnVirtualization,columns:C,scrollLeft:this.wrapperScrollLeft,tableViewPortWidth:parseFloat((p.width||"").toString())}),A=(w,z,ee,_,b,J)=>C.map((R,I)=>{if(L[I])return null;const K=R.id?R.id:I,Y=`k-table-td ${R.className?R.className+" ":""}${R.locked?"k-grid-content-sticky":""}`,G={id:y.tableKeyboardNavigationTools.generateNavigatableId(`${ee}-${String(I)}`,f),colSpan:T[I],dataItem:w.dataItem,field:R.field,format:R.format,className:Y||void 0,render:this.props.cellRender,onChange:this.onItemChange,selectionChange:this.props.onSelectionChange?W=>{this.onSelectionChange({event:W,item:w,columnIndex:I,dataIndex:b})}:void 0,level:w.level,expandable:R.expandable,expanded:_,hasChildren:Xt(w.dataItem,this.props.subItemsField),colIndex:I,ariaColumnIndex:R.ariaColumnIndex,onExpandChange:this.onExpandChange,style:R.left!==void 0&&{left:R.left,right:R.right,borderRightWidth:R.rightBorder?"1px":""}||{},isSelected:Array.isArray(J)&&J.indexOf(I)>-1};return z&&R.editCell?t.createElement(R.editCell,{...G,onChange:this.onItemChange,key:K}):R.cell?t.createElement(R.cell,{key:K,...G}):t.createElement(ue.TreeListCell,{key:K,...G})});let M=this.flatData;const x=M.length;l!==void 0&&r!==void 0&&(M=M.slice(l,l+r)),n==="virtual"&&(M=ue.tableRowsVirtualization({rows:M,tableViewPortHeight:parseFloat((p.height||p.maxHeight||"").toString()),scrollTop:this.wrapperScrollTop}),this.updateOnScroll=!1);const O=M.map(w=>w.level),Q=g.length+(d?1:0)+1,S=M.length>0&&M.map((w,z)=>{const ee=h.getter(this.props.editField||"")(w.dataItem),_=h.getter(this.props.dataItemKey)(w.dataItem),b=String(_||w.level.join(".")),J=st(w.dataItem,this.props.expandField),R=this.props.selectedField?h.getter(this.props.selectedField)(w.dataItem):void 0,I={key:b,level:w.level,levels:O,dataItem:w.dataItem,selectedField:this.props.selectedField,rowHeight:w.height,render:this.props.rowRender,onDrop:this.onRowDrop,onDrag:this.onRowDrag,onClick:W=>this.onRowClick(W,w),onDoubleClick:W=>this.rowDoubleClick(W,w),onContextMenu:W=>this.rowContextMenu(W,w),isAltRow:z%2!==0,expanded:J,rowIndex:z,ariaRowIndex:Q+z,ariaSetSize:w.levelCount,ariaPosInSet:w.level[w.level.length-1]+1,isSelected:typeof R=="boolean"&&R},K=this.props.editRow,Y=this.props.row||ue.TreeListRow,G=A(w,ee,b,J,z,R);return ee&&K?t.createElement(K,{...I,key:I.key},G):t.createElement(Y,{...I,key:I.key},G)})||t.createElement("tr",{className:"k-table-row k-grid-norecords"},t.createElement("td",{className:"k-table-td",colSpan:C.length},this.props.noRecords||t.createElement(ue.TreeListNoRecords,null))),j=w=>this.props.sort&&this.props.sort.some(z=>z.field===w),H=t.createElement("colgroup",{ref:w=>{this.columnResize.colGroupMain=w}},C.map((w,z)=>t.createElement("col",{key:z.toString(),className:j(w.field)?"k-sorted":void 0,style:w.width!==void 0?{width:w.width}:void 0}))),X=this.props.columnVirtualization||this.props.scrollable==="virtual",V=this.props.selectable&&this.props.selectable.drag?"none":void 0,U=this.props.tableProps||{};return t.createElement(y.TableKeyboardNavigationContext.Provider,{value:this.contextStateRef.current},t.createElement("div",{id:this.props.treelistId,style:this.props.style,className:h.classNames("k-grid k-grid-md",this.props.className,{"k-treelist-scrollable":n!=="none"}),ref:w=>this.element=w,onScroll:X?this.onScroll:void 0,onKeyDown:this.onKeyDown,onFocus:this.onFocus,"aria-rowcount":x,"aria-colcount":C.length,role:"treegrid",...y.tableKeyboardNavigationScopeAttributes},this.props.toolbar,t.createElement(y.TableSelection,{selectable:this.props.selectable,onRelease:this.selectionRelease,childRef:w=>{this.tableElement=w}},t.createElement("table",{className:"k-table k-table-md",...this.props.tableProps||{},style:{...U.style||{},userSelect:V},role:"presentation"},H,D,t.createElement("tbody",{className:"k-table-tbody",...y.tableKeyboardNavigationBodyAttributes,ref:w=>this.tbodyElement=w,role:"presentation"},S))),this.props.pager&&t.createElement(this.props.pager,{className:"k-grid-pager",total:x,skip:l,take:r,onPageChange:this.onPageChange}),s&&t.createElement(t.Fragment,null,t.createElement(y.DropClue,{ref:this.dragLogic.refDropElementClue}),t.createElement(y.DragClue,{ref:this.dragLogic.refDragElementClue})),c))}get flatData(){const{data:a=[],rowHeight:n=0}=this.props;let o=0;const s=()=>{const r={height:n,offsetTop:o};return o+=r.height,r},l=this.updateOnScroll&&this.prevData===a&&this.tbodyOffsetTop>0&&this.flattedData.length?this.flattedData:a.map(r=>({...r,...s()}));return this.prevData=a,this.flattedData=l,l}onSelectionChange(a){if(this.props.onSelectionChange){const{event:n,item:o,dataIndex:s,columnIndex:l}=a,{mode:r,cell:c}=y.getSelectionOptions(this.props.selectable),m={...this.getEventArguments(n.syntheticEvent),dataItem:o.dataItem,level:o.level,startColIndex:l,endColIndex:l,startRowIndex:s,endRowIndex:s,dataItems:this.getLeafDataItems(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,mode:r,cell:c,isDrag:!1,componentId:this.props.treelistId,selectedField:this.props.selectedField||""};this.props.onSelectionChange.call(void 0,m)}}}Mt.propTypes={data:i.array,resizable:i.bool,reorderable:i.bool,sortable:i.oneOfType([i.bool,i.shape({mode:i.oneOf(["single","multiple"]),allowUnsort:i.bool})]),onSortChange:i.func,sort:i.array,columns:i.arrayOf(i.object),columnVirtualization:i.bool,filter:i.array,onFilterChange:i.func,filterRow:i.any,toolbar:i.any,noRecords:i.any,onExpandChange:i.func,expandField:i.string,subItemsField:i.string,selectedField:i.string,onSelectionChange:i.func,onHeaderSelectionChange:i.func,onRowClick:i.func,onItemChange:i.func,editField:i.string,scrollable:i.oneOf(["none","scrollable","virtual"]),rowHeight:i.number,style:i.object,tableProps:i.object,pager:i.any,skip:i.number,take:i.number,onPageChange:i.func,onDataStateChange:i.func,onColumnResize:i.func,onColumnReorder:i.func,extendedColumns:i.arrayOf(i.object),columnsMap:i.arrayOf(i.array),dataItemKey:i.string.isRequired,afterContent:i.any,navigatable:i.bool,idPrefix:i.string,treelistId:i.string};Mt.contextType=y.TableKeyboardNavigationContext;const Me=t.forwardRef((e,a)=>{const{slotLevels:n,slotWidth:o,timelineHeaderCell:s}=e,{columns:l,noRecords:r,resizable:c,reorderable:m,sortable:g,sort:d,filter:u,columnMenuFilter:f,columnMenu:C,navigatable:D,row:p,selectable:T}=xe(),{onDataStateChange:L,onSortChange:A,onFilterChange:M,onColumnMenuFilterChange:x,onExpandChange:O,onRowClick:Q,onRowDoubleClick:S,onRowContextMenu:j,onColumnResize:H,onColumnReorder:X,onDependencyCreate:V,onKeyDown:U,onSelectionChange:w,onHeaderSelectionChange:z}=Ka(),ee=en(),_=_a(),b=kt(),J=Jt(),R=Ga(),I=Wa(),K=t.useRef(null),Y=t.useRef(null),G=t.useRef(null),W=t.useRef(null),fe=t.useRef(0),ye=t.useRef(h.useId()),F=t.useRef(h.useId()),te=t.useRef(null),Le=t.useRef(null),Ze=t.useCallback(v=>{G.current&&G.current.scrollIntoView(v)},[]);t.useImperativeHandle(Le,()=>({scrollIntoView:Ze})),t.useImperativeHandle(a,()=>Le.current);const pe=t.useRef(0),Ce=t.useRef(0),ke=t.useRef(0),De=t.useRef(0),me=t.useRef(null),be=t.useRef(null),[ge,ve]=t.useState(null),je=Ha(n,K,s),Xe=Aa(n,Y),Ee=Oa(n,o),{extendedColumns:Je,columnsWidth:Qe,columnsMap:et}=t.useMemo(()=>{const v=y.readColumns([...l,{title:"",sortable:!1,resizable:!1,reorderable:!1,width:Ee,headerCell:()=>je,cell:on,orderIndex:Number.MAX_SAFE_INTEGER,navigatable:!1}],{prevId:0,idPrefix:ye.current});let P=0;return v.forEach((N,q,Z)=>{const $=q+1===Z.length,de=N.children.length===0;$?N.isAccessible=!1:(N.locked=!0,de&&(N.width=N.width||Ie)),de&&(P+=parseFloat(String(N.width)))}),{extendedColumns:v,columnsWidth:P,columnsMap:y.mapColumns(v)}},[l,Ee]),[tt,nt]=$a(),E=t.useCallback(()=>K.current&&K.current.parentElement,[]),re=()=>{const v=E(),P=Y.current,N=G.current&&G.current.tbodyElement;if(!v||!P||!N)return;const q=N.offsetTop,Z=v.offsetLeft,$=Ee;P.style.top=q+"px",P.style.left=Z+"px",P.style.width=$+"px",P.style.height=N.offsetHeight+"px"},ce=()=>{const v=E();v&&(fe.current=v.offsetLeft)};t.useEffect(re),t.useEffect(ce);const Te=t.useCallback(v=>{if(!W.current)return;const P=v.columns.slice(0,v.columns.length-1);if(v.end)W.current.style.left="0px";else{const N=E();if(!N)return;W.current.style.left=N.offsetLeft-fe.current+"px",re()}H({...v,columns:P})},[H]),Re=t.useCallback(v=>{const P=v.columns.slice(0,v.columns.length-1);X({...v,columns:P})},[H]),at=t.useCallback(v=>{const N=(te.current&&te.current.ownerDocument?te.current.ownerDocument:document).elementFromPoint(v.clientX,v.clientY),q=te.current;if(!N||!N.parentElement||!q)return;const Z=q.parentElement,$=q.firstElementChild;if(!Z||!$)return;const de=N.getAttribute(Oe);if(de){const ta=q.offsetTop,na=q.offsetLeft,aa=Z.offsetTop,oa=Z.offsetLeft,ra=$.scrollTop,sa=$.scrollLeft;ke.current=na+oa,De.current=ta+aa,pe.current=v.clientX-ke.current+sa,Ce.current=v.clientY-De.current+ra,me.current=N.parentElement.getAttribute(Ve),be.current=de}},[]),we=t.useCallback(v=>{const P=te.current;if(!P)return;const N=P.firstElementChild;if(!N)return;const q=N.scrollTop,Z=N.scrollLeft,$=v.clientX-ke.current+Z,de=v.clientY-De.current+q;Math.abs(pe.current-$)<10&&Math.abs(Ce.current-de)<10||ve({startX:pe.current,startY:Ce.current,endX:$,endY:de})},[]),ea=t.useCallback(v=>{const N=(te.current&&te.current.ownerDocument?te.current.ownerDocument:document).elementFromPoint(v.clientX,v.clientY);if(!N||!N.parentElement)return;const q=N.parentElement.getAttribute(Ve),Z=N.getAttribute(Oe);if(Z&&q!==me.current&&V){let $;be.current==="start"?$=Z==="start"?3:2:$=Z==="start"?1:0,V({fromId:me.current,toId:q,type:$})}pe.current=0,Ce.current=0,ke.current=0,De.current=0,me.current=null,be.current=null,ve(null)},[V,ve]);return t.createElement(an,{tasksStore:[tt,nt],timelineWidth:Ee,dependencyDrag:{isEnabled:!!V,draggedId:me.current,onDependencyHandlePress:at,onDependencyHandleDrag:we,onDependencyHandleRelease:ea}},t.createElement("div",{className:"k-gantt-content",ref:te,style:{height:`calc(100% - ${_}px)`}},t.createElement(Mt,{treelistId:F.current,ref:G,extendedColumns:Je,columnsMap:et,dataItemKey:b.id,data:R,idPrefix:ye.current,navigatable:D,expandField:b.isExpanded,subItemsField:b.children,editField:b.isInEdit,selectedField:b.isSelected,onDataStateChange:L,onSortChange:A,onFilterChange:M,onExpandChange:O,onRowClick:Q,onRowDoubleClick:S,onRowContextMenu:j,onColumnResize:Te,onColumnReorder:Re,onColumnMenuFilterChange:x,onKeyDown:U,onSelectionChange:w,onHeaderSelectionChange:z,tableProps:{style:{width:Qe},className:"k-table k-table-md k-table-layout-fixed"},noRecords:r,rowHeight:ee,resizable:c,reorderable:m,sortable:g,sort:d,filter:u,columnMenuFilter:f,columnMenu:C,row:p,selectable:T,afterContent:t.createElement(t.Fragment,null,t.createElement("svg",{className:"k-gantt-dependencies-svg",ref:W,style:{left:0,top:0}},I.map(v=>t.createElement(rn,{key:h.getter(J.id)(v),dependency:v}))),t.createElement("svg",{className:"k-gantt-dependencies-svg",style:{left:0,top:0,zIndex:3}},ge&&t.createElement("polyline",{points:`${ge.startX},${ge.startY} ${ge.endX},${ge.endY}`})),R&&R.length?Xe:null)})))});Me.displayName="KendoReactGanttBaseView";const it="gantt.weekViewTitle",ct="gantt.dayViewTitle",dt="gantt.monthViewTitle",ut="gantt.yearViewTitle",mt="gantt.filterClearButton",We="gantt.filterEqOperator",Pe="gantt.filterNotEqOperator",_e="gantt.filterIsNullOperator",Ke="gantt.filterIsNotNullOperator",sn="gantt.filterIsEmptyOperator",ln="gantt.filterIsNotEmptyOperator",cn="gantt.filterStartsWithOperator",dn="gantt.filterContainsOperator",un="gantt.filterNotContainsOperator",mn="gantt.filterEndsWithOperator",gn="gantt.filterGteOperator",hn="gantt.filterGtOperator",fn="gantt.filterLteOperator",pn="gantt.filterLtOperator",Cn="gantt.filterIsTrue",kn="gantt.filterIsFalse",Dn="gantt.filterBooleanAll",En="gantt.filterAfterOrEqualOperator",wn="gantt.filterAfterOperator",yn="gantt.filterBeforeOperator",bn="gantt.filterBeforeOrEqualOperator",Za="gantt.noRecords",vn="gantt.editSave",Ft="gantt.editCancel",Tn="gantt.editorTitle",Rn="gantt.editorTaskTitle",Sn="gantt.editorTaskStart",In="gantt.editorTaskEnd",xn="gantt.editorTaskComplete",Nn="gantt.editorValidationRequired",Mn="gantt.editorValidationStart",Fn="gantt.editorValidationEnd",Ln="gantt.addTask",zn="gantt.addChild",Hn="gantt.addAbove",An="gantt.addBelow",On="gantt.editorDelete",Vn="gantt.deleteConfirmation",Gn="gantt.deleteDialogTitle",oe={[it]:"Week",[ct]:"Day",[dt]:"Month",[ut]:"Year",[mt]:"Clear",[We]:"Is equal to",[Pe]:"Is not equal to",[_e]:"Is null",[Ke]:"Is not null",[sn]:"Is empty",[ln]:"Is not empty",[cn]:"Starts with",[dn]:"Contains",[un]:"Does not contain",[mn]:"Ends with",[gn]:"Is greater than or equal to",[hn]:"Is greater than",[fn]:"Is less than or equal to",[pn]:"Is less than",[Cn]:"Is true",[kn]:"Is false",[Dn]:"(All)",[En]:"Is after or equal to",[wn]:"Is after",[yn]:"Is before",[bn]:"Is before or equal to",[Za]:"No records available",[vn]:"Save",[Ft]:"Cancel",[Tn]:"Task",[Rn]:"Title",[Sn]:"Start",[In]:"End",[xn]:"Complete",[Nn]:"Field is required.",[Mn]:"Start time must be be before End time.",[Fn]:"End time must be after Start time.",[Ln]:"Add Task",[zn]:"Add Child",[Hn]:"Add Above",[An]:"Add Below",[On]:"Delete",[Vn]:"Are you sure you want to delete this event?",[Gn]:"Delete Event"},Fe=t.forwardRef((e,a)=>{const{slotWidth:n=ze.slotWidth,firstSlotRangeRef:o,timelineHeaderCell:s}=e,{timezone:l}=xe(),r=B.useInternationalization(),c=t.useRef(null),m=t.useRef(null),g=t.useCallback(D=>{m.current&&m.current.scrollIntoView(D)},[]);t.useImperativeHandle(c,()=>({scrollIntoView:g})),t.useImperativeHandle(a,()=>c.current);const d=Ne(),u=e.workWeekStart||ze.workWeekStart,f=e.workWeekEnd||ze.workWeekEnd,C=t.useMemo(()=>{const D=qt({workWeekStart:u,workWeekEnd:f}),p=[],T=Zt(d,{timezone:l},r);return T.forEach(L=>{const A=Yt(L.range,{workDays:D,timezone:l},r);p.push.apply(p,A)}),o&&p[0]&&(o.current=p[0].range),[T,p]},[l,d.start.getTime(),d.end.getTime(),r,u,f]);return t.createElement(Me,{ref:m,slotWidth:n,slotLevels:C,timelineHeaderCell:s})}),ja=({intl:e,tasksStart:a,tasksEnd:n,timezone:o})=>{const s=k.ZonedDate.fromLocalDate(a,o),l=k.ZonedDate.fromLocalDate(n,o),r=Ut(k.firstDayInWeek(k.getDate(s),e.firstDay())),c=ht(k.firstDayInWeek(k.getDate(l),e.firstDay()),_t),m=k.ZonedDate.fromUTCDate(ie(r),o),g=k.ZonedDate.fromUTCDate(ie(c),o);return{start:new Date(m.getTime()),end:new Date(g.getTime()),zonedStart:m,zonedEnd:g}},ze={name:"week",dateRange:ja,title:e=>e.toLanguageString(it,oe[it]),slotWidth:Ie,workWeekStart:1,workWeekEnd:5,workDayStart:"08:00",workDayEnd:"17:00"};Fe.defaultProps=ze;Fe.propTypes={name:i.string,dateRange:i.oneOfType([i.func,i.object]),title:i.oneOfType([i.string,i.func]),slotWidth:i.number,workWeekStart:i.number,workWeekEnd:i.number,workDayStart:i.string,workDayEnd:i.string};Fe.displayName="KendoReactGanttWeekView";const Xa=(e,a,n)=>{const[o,s]=t.useState(a||e),l=t.useCallback((r,c)=>{s(r),n&&n.call(void 0,{...c,value:r})},[n,s]);return[a!==void 0?a:o,l]},Wn=e=>{const[a,n]=Qt(),o=B.useLocalization(),s=t.useMemo(()=>typeof e.view.title=="function"?e.view.title.call(void 0,o):e.view.title,[e.view.title,o]),l=t.useCallback(()=>{e.view.name&&n(e.view.name)},[n,e.view.name]);return t.createElement(ae.Button,{role:"button",type:"button",tabIndex:-1,togglable:!0,selected:e.view.name===a,onClick:l},s)};Wn.displayName="KendoReactGanttViewSelectorItem";const Pn=t.forwardRef(()=>{const e=Pa(),[a,n]=Qt(),o=e.find(r=>r.props.name===a),s=B.useLocalization(),l=t.useCallback(r=>{n&&(r.syntheticEvent.preventDefault(),n(r.item.name))},[n]);return t.createElement("div",{className:"k-gantt-views-wrapper"},t.createElement(ae.ButtonGroup,{className:"k-gantt-views"},e.map(r=>t.createElement(Wn,{key:r.props.name,view:r.props}))),o&&t.createElement(ae.DropDownButton,{className:"k-views-dropdown",onItemClick:l,popupSettings:{popupClass:"k-gantt-toolbar"},textField:"title",items:e.map(r=>({...r.props,selected:r.props.name===a,title:typeof r.props.title=="function"?r.props.title.call(void 0,s):r.props.title})),text:t.createElement(t.Fragment,null,typeof o.props.title=="function"?o.props.title.call(void 0,s):o.props.title,t.createElement(h.IconWrap,{name:"caret-alt-down",icon:gt.caretAltDownIcon}))}))});Pn.displayName="KendoReactGanttViewSelectorList";const _n=t.forwardRef((e,a)=>{const{className:n,...o}=e,s=t.useRef(null);return t.useImperativeHandle(a,()=>({element:s.current,props:e})),t.createElement(ae.ToolbarItem,{ref:l=>{l&&(s.current=l.element)},className:h.classNames("k-gantt-views",n),...o},e.children)});_n.displayName="KendoReactGanttViewSelector";const Kn=t.forwardRef((e,a)=>{const{className:n,...o}=e,s=t.useRef(null),l=t.useRef(null);t.useImperativeHandle(l,()=>({element:s.current,props:e})),t.useImperativeHandle(a,()=>l.current);const r=t.useMemo(()=>h.classNames("k-gantt-toolbar k-gantt-header",n),[n]);return t.createElement(ae.Toolbar,{ref:c=>{c&&(s.current=c.element)},className:r,...o},e.children)});Kn.displayName="KendoReactGanttToolbar";const Ot={name:"@progress/kendo-react-gantt",productName:"KendoReact",productCodes:["KENDOUIREACT","KENDOUICOMPLETE"],publishDate:0,version:"",licensingDocsUrl:"https://www.telerik.com/kendo-react-ui/components/my-license/"},Bn=t.forwardRef((e,a)=>{const n=B.useLocalization(),o=u=>n.toLanguageString(u,oe[u]),s=o(Ln),l=o(zn),r=o(Hn),c=o(An),m=t.useCallback(u=>{u.syntheticEvent.preventDefault();const f=u.item&&u.item.direction?u.item.direction:"none";e.onClick&&e.onClick({nativeEvent:u.nativeEvent,syntheticEvent:u.syntheticEvent,direction:f})},[e.onClick]),g=t.useCallback(u=>{u.preventDefault(),e.onClick&&e.onClick({nativeEvent:u&&u.nativeEvent,syntheticEvent:u,direction:"none"})},[e.onClick]),d=t.createElement(t.Fragment,null,t.createElement(h.IconWrap,{name:"plus",icon:gt.plusIcon}),s);return e.selectedTask?t.createElement(ae.DropDownButton,{className:"k-views-dropdown",onItemClick:m,popupSettings:{popupClass:"k-gantt-toolbar"},textField:"title",items:[{title:l,direction:"child"},{title:r,direction:"above"},{title:c,direction:"below"}],text:d}):t.createElement(ae.Button,{onClick:g},d)});Bn.displayName="KendoReactGanttAddButton";const Be=t.forwardRef((e,a)=>{h.validatePackage(Ot);const n=h.shouldShowValidationUI(Ot),{columns:o=Se.columns,taskData:s=Se.taskData,dependencyData:l=Se.dependencyData,style:r,className:c,noRecords:m,timezone:g,rowHeight:d=Se.rowHeight,resizable:u,reorderable:f,sortable:C,sort:D,filter:p,columnMenuFilter:T,columnMenu:L,navigatable:A,toolbar:M,row:x,selectable:O}=e,Q=B.useInternationalization(),{fields:S}=t.useMemo(()=>ba(e.taskModelFields),[e.taskModelFields]),{fields:j}=t.useMemo(()=>va(e.dependencyModelFields),[e.dependencyModelFields]),H=t.useCallback(Va(S.isExpanded,S.children),[S.isExpanded,S.children]),X=t.useRef(null),V=t.useRef(null),U=t.useRef(null),w=t.useRef(null),z=t.useRef(null),ee=t.useCallback(E=>{const re=h.getter(S.start)(E),ce=h.getter(S.end)(E),Te=h.getter(S.isSelected)(E);(!V.current||re<V.current)&&(V.current=re),(!U.current||ce>U.current)&&(U.current=ce),Te&&(w.current=E)},[S.start,S.end]),_=t.useMemo(()=>(V.current=null,U.current=null,w.current=null,ue.flatData(s,H,ee)),[s,H]);(!V.current||!U.current)&&(V.current=new Date(Lt),U.current=new Date(Lt));const b=t.Children.toArray(e.children||[t.createElement(Fe,{key:"week",firstSlotRangeRef:z})]),[J,R]=Xa(e.defaultView||b[0].props.name,e.view,e.onViewChange),I=b.find(E=>E.props.name===J)||b[0],K=typeof I.props.dateRange=="function"?I.props.dateRange.call(void 0,{intl:Q,tasksStart:V.current,tasksEnd:U.current,timezone:g}):I.props.dateRange,Y=t.useRef(null),[G,W]=t.useState(0);t.useLayoutEffect(()=>{Y.current&&W(Y.current.element.offsetHeight)},[]);const fe=t.useCallback(E=>{X.current&&X.current.scrollIntoView(E)},[]),ye=t.useRef(null),F=t.useRef(null);t.useImperativeHandle(F,()=>({props:e,element:ye.current,scrollIntoView:fe})),t.useImperativeHandle(a,()=>F.current);const te=t.useCallback(E=>{e.onDataStateChange&&e.onDataStateChange.call(void 0,{...E,target:F.current})},[e.onDataStateChange]),Le=t.useCallback(E=>{e.onSortChange&&e.onSortChange.call(void 0,{...E,target:F.current})},[e.onSortChange]),Ze=t.useCallback(E=>{e.onKeyDown&&e.onKeyDown.call(void 0,{...E,target:F.current})},[e.onKeyDown]),pe=t.useCallback(E=>{e.onSelectionChange&&e.onSelectionChange.call(void 0,{...E,target:F.current})},[e.onSelectionChange]),Ce=t.useCallback(E=>{e.onHeaderSelectionChange&&e.onHeaderSelectionChange.call(void 0,{...E,target:F.current})},[e.onHeaderSelectionChange]),ke=t.useCallback(E=>{e.onFilterChange&&e.onFilterChange.call(void 0,{...E,target:F.current})},[e.onFilterChange]),De=t.useCallback(E=>{e.onColumnMenuFilterChange&&e.onColumnMenuFilterChange.call(void 0,{...E,target:F.current})},[e.onColumnMenuFilterChange]),me=t.useCallback(E=>{e.onExpandChange&&e.onExpandChange.call(void 0,{...E,target:F.current})},[e.onExpandChange]),be=t.useCallback(E=>{e.onAddClick&&e.onAddClick.call(void 0,{...E,target:F.current,selectedDataItem:w.current,slotStart:z.current&&new Date(z.current.start.getTime()),slotEnd:z.current&&new Date(z.current.end.getTime())})},[e.onAddClick]),ge=t.useCallback(E=>{e.onColumnResize&&e.onColumnResize.call(void 0,{...E,target:F.current})},[e.onColumnResize]),ve=t.useCallback(E=>{e.onColumnReorder&&e.onColumnReorder.call(void 0,{...E,target:F.current})},[e.onColumnReorder]),je=t.useCallback(E=>{e.onRowClick&&e.onRowClick.call(void 0,{...E,target:F.current})},[e.onRowClick]),Xe=t.useCallback(E=>{e.onRowDoubleClick&&e.onRowDoubleClick.call(void 0,{...E,target:F.current})},[e.onRowClick]),Ee=t.useCallback(E=>{e.onRowContextMenu&&e.onRowContextMenu.call(void 0,{...E,target:F.current})},[e.onRowClick]),Je=t.useCallback(E=>{e.onTaskClick&&e.onTaskClick.call(void 0,{...E,target:F.current})},[e.onTaskClick]),Qe=t.useCallback(E=>{e.onTaskDoubleClick&&e.onTaskDoubleClick.call(void 0,{...E,target:F.current})},[e.onTaskDoubleClick]),et=t.useCallback(E=>{e.onTaskContextMenu&&e.onTaskContextMenu.call(void 0,{...E,target:F.current})},[e.onTaskContextMenu]),tt=t.useCallback(E=>{e.onTaskRemoveClick&&e.onTaskRemoveClick.call(void 0,{...E,target:F.current})},[e.onTaskRemoveClick]),nt=t.useCallback(E=>{if(e.onDependencyCreate){let re,ce;const Te=h.getter(S.id);for(let Re=0;Re<_.length;Re++){const at=_[Re],we=Te(at.dataItem);if(String(we)===E.fromId&&(re=we),String(we)===E.toId&&(ce=we),re&&ce)break}e.onDependencyCreate.call(void 0,{fromId:re,toId:ce,target:F.current,type:E.type})}},[e.onDependencyCreate,S,_]);return t.createElement(tn,{dateRange:K,taskData:_,dependencyData:l,taskModelFields:S,dependencyModelFields:j,views:b,activeView:[J,R],rowHeight:d,toolbarHeight:G,props:{columns:o,noRecords:m,timezone:g,resizable:u,reorderable:f,sortable:C,sort:D,filter:p,columnMenuFilter:T,columnMenu:L,navigatable:A,row:x,selectable:O},events:{onDataStateChange:te,onSortChange:Le,onFilterChange:ke,onColumnMenuFilterChange:De,onExpandChange:me,onRowClick:je,onRowDoubleClick:Xe,onRowContextMenu:Ee,onColumnResize:ge,onColumnReorder:ve,onDependencyCreate:e.onDependencyCreate&&nt,onKeyDown:Ze,onSelectionChange:pe,onHeaderSelectionChange:Ce},taskEvents:{onTaskClick:Je,onTaskDoubleClick:Qe,onTaskContextMenu:et,onTaskRemoveClick:e.onTaskRemoveClick&&tt}},t.createElement("div",{ref:ye,role:"application",style:r,className:h.classNames("k-gantt",c)},t.createElement(Kn,{ref:Y},M&&M.addTaskButton?t.createElement(Bn,{selectedTask:w.current,onClick:be}):null,t.createElement(ae.ToolbarSpacer,null),t.createElement(_n,null,t.createElement(Pn,null))),I&&t.createElement(I.type,{key:I.props.name,ref:X,...I.props,firstSlotRangeRef:z}),n&&t.createElement(h.WatermarkOverlay,null)))}),Se={taskData:[],dependencyData:[],columns:[],rowHeight:40};Be.propTypes={taskData:i.array,taskModelFields:i.shape({id:i.string,start:i.string,end:i.string,title:i.string,percentComplete:i.string,isRollup:i.string,isExpanded:i.string,children:i.string,isInEdit:i.string}),dependencyData:i.array,dependencyModelFields:i.shape({id:i.string,fromId:i.string,toId:i.string,type:i.string}),columns:i.arrayOf(i.shape({width:i.number,cell:i.any,editCell:i.any,headerCell:i.any,filter:i.any,children:i.any,field:i.string,title:i.string,sortable:i.any,expandable:i.bool,headerSelectionValue:i.bool,format:i.string,headerClassName:i.string,className:i.string,resizable:i.bool,reorderable:i.bool,minResizableWidth:i.number,orderIndex:i.number,columnMenu:i.any})),sort:i.array,filter:i.array,columnMenuFilter:i.array,columnMenu:i.any,style:i.object,className:i.string,children:i.any,timezone:i.string,defaultView:i.string,view:i.string,rowHeight:i.number,navigatable:i.bool,onViewChange:i.func,onDataStateChange:i.func,onSortChange:i.func,onFilterChange:i.func,onExpandChange:i.func,onRowClick:i.func,onColumnResize:i.func,onColumnReorder:i.func};Be.defaultProps=Se;Be.displayName="KendoReactGantt";const Ue=t.forwardRef((e,a)=>{const{slotWidth:n=he.slotWidth,slotDuration:o=he.slotDuration,firstSlotRangeRef:s,timelineHeaderCell:l}=e,{timezone:r}=xe(),c=B.useInternationalization(),m=t.useRef(null),g=t.useRef(null),d=t.useCallback(L=>{g.current&&g.current.scrollIntoView(L)},[]);t.useImperativeHandle(m,()=>({scrollIntoView:d})),t.useImperativeHandle(a,()=>m.current);const u=Ne(),f=e.workWeekStart||he.workWeekStart,C=e.workWeekEnd||he.workWeekEnd,D=e.workDayStart||he.workDayStart,p=e.workDayEnd||he.workDayEnd,T=t.useMemo(()=>{const L=qt({workWeekStart:f,workWeekEnd:C}),A=[],M=Yt(u,{workDays:L,timezone:r},c);return M.forEach(x=>{const O=La(x.range,{workDayStart:D,workDayEnd:p,timezone:r,slotDuration:o},c);x.span=O.length,A.push.apply(A,O)}),s&&A[0]&&(s.current=A[0].range),[M,A]},[r,u.start.getTime(),u.end.getTime(),c,f,C,D,p]);return t.createElement(Me,{ref:g,slotWidth:n,slotLevels:T,timelineHeaderCell:l})}),Ja=({tasksStart:e,tasksEnd:a,timezone:n})=>{const o=k.ZonedDate.fromLocalDate(e,n),s=k.ZonedDate.fromLocalDate(a,n),l=Ut(o),r=ht(s),c=k.ZonedDate.fromUTCDate(ie(l),n),m=k.ZonedDate.fromUTCDate(ie(r),n);return{start:new Date(c.getTime()),end:new Date(m.getTime()),zonedStart:c,zonedEnd:m}},he={name:"day",dateRange:Ja,title:e=>e.toLanguageString(ct,oe[ct]),slotWidth:Ie,slotDuration:60,workWeekStart:1,workWeekEnd:5,workDayStart:"08:00",workDayEnd:"17:00"};Ue.defaultProps=he;Ue.propTypes={name:i.string,dateRange:i.oneOfType([i.func,i.object]),title:i.oneOfType([i.string,i.func]),slotWidth:i.number,slotDuration:i.number,workWeekStart:i.number,workWeekEnd:i.number,workDayStart:i.string,workDayEnd:i.string};Ue.displayName="KendoReactGanttDayView";const qe=t.forwardRef((e,a)=>{const{slotWidth:n=Un.slotWidth,firstSlotRangeRef:o,timelineHeaderCell:s}=e,{timezone:l}=xe(),r=B.useInternationalization(),c=t.useRef(null),m=t.useRef(null),g=t.useCallback(f=>{m.current&&m.current.scrollIntoView(f)},[]);t.useImperativeHandle(c,()=>({scrollIntoView:g})),t.useImperativeHandle(a,()=>c.current);const d=Ne(),u=t.useMemo(()=>{const f=[],C=jt(d,{timezone:l},r);return C.forEach(D=>{const p=Zt(D.range,{timezone:l},r);f.push.apply(f,p)}),o&&f[0]&&(o.current=f[0].range),[C,f]},[l,d.start.getTime(),d.end.getTime(),r]);return t.createElement(Me,{ref:m,slotWidth:n,slotLevels:u,timelineHeaderCell:s})}),Qa=({tasksStart:e,tasksEnd:a,timezone:n})=>{const o=k.ZonedDate.fromLocalDate(e,n),s=k.ZonedDate.fromLocalDate(a,n),l=k.firstDayOfMonth(k.getDate(o)),r=k.addDays(k.lastDayOfMonth(k.getDate(s)),1),c=k.ZonedDate.fromUTCDate(ie(l),n),m=k.ZonedDate.fromUTCDate(ie(r),n);return{start:new Date(c.getTime()),end:new Date(m.getTime()),zonedStart:c,zonedEnd:m}},Un={name:"month",dateRange:Qa,title:e=>e.toLanguageString(dt,oe[dt]),slotWidth:Ie,workWeekStart:1,workWeekEnd:5,workDayStart:"08:00",workDayEnd:"17:00"};qe.defaultProps=Un;qe.propTypes={name:i.string,dateRange:i.oneOfType([i.func,i.object]),title:i.oneOfType([i.string,i.func]),slotWidth:i.number,workWeekStart:i.number,workWeekEnd:i.number,workDayStart:i.string,workDayEnd:i.string};qe.displayName="GanttMonthView";const $e=t.forwardRef((e,a)=>{const{slotWidth:n=qn.slotWidth,firstSlotRangeRef:o,timelineHeaderCell:s}=e,{timezone:l}=xe(),r=B.useInternationalization(),c=t.useRef(null),m=t.useRef(null),g=t.useCallback(f=>{m.current&&m.current.scrollIntoView(f)},[]);t.useImperativeHandle(c,()=>({scrollIntoView:g})),t.useImperativeHandle(a,()=>c.current);const d=Ne(),u=t.useMemo(()=>{const f=za(d,{timezone:l},r),C=[];return f.forEach(D=>{const p=jt(D.range,{timezone:l},r);C.push.apply(C,p)}),o&&C[0]&&(o.current=C[0].range),[f,C]},[l,d.start.getTime(),d.end.getTime(),r]);return t.createElement(Me,{slotWidth:n,slotLevels:u,timelineHeaderCell:s})}),eo=({tasksStart:e,tasksEnd:a,timezone:n})=>{const o=k.ZonedDate.fromLocalDate(e,n),s=k.ZonedDate.fromLocalDate(a,n),l=k.firstDayOfMonth(k.firstMonthOfYear(k.getDate(o))),r=k.addDays(k.lastDayOfMonth(k.lastMonthOfYear(k.getDate(s))),1),c=k.ZonedDate.fromUTCDate(ie(l),n),m=k.ZonedDate.fromUTCDate(ie(r),n);return{start:new Date(c.getTime()),end:new Date(m.getTime()),zonedStart:c,zonedEnd:m}},qn={name:"year",dateRange:eo,title:e=>e.toLanguageString(ut,oe[ut]),slotWidth:Ie};$e.defaultProps=qn;$e.propTypes={name:i.string,dateRange:i.oneOfType([i.func,i.object]),title:i.oneOfType([i.string,i.func]),slotWidth:i.number};$e.displayName="GanttYearView";const to=[{text:dn,operator:"contains"},{text:un,operator:"doesnotcontain"},{text:We,operator:"eq"},{text:Pe,operator:"neq"},{text:cn,operator:"startswith"},{text:mn,operator:"endswith"},{text:_e,operator:"isnull"},{text:Ke,operator:"isnotnull"},{text:sn,operator:"isempty"},{text:ln,operator:"isnotempty"}],no=[{text:We,operator:"eq"},{text:Pe,operator:"neq"},{text:gn,operator:"gte"},{text:hn,operator:"gt"},{text:fn,operator:"lte"},{text:pn,operator:"lt"},{text:_e,operator:"isnull"},{text:Ke,operator:"isnotnull"}],ao=[{text:We,operator:"eq"},{text:Pe,operator:"neq"},{text:En,operator:"gte"},{text:wn,operator:"gt"},{text:yn,operator:"lt"},{text:bn,operator:"lte"},{text:_e,operator:"isnull"},{text:Ke,operator:"isnotnull"}],oo=[{text:Dn,operator:""},{text:Cn,operator:!0},{text:kn,operator:!1}];function Ye(e,a){return{clearButtonTitle:e.toLanguageString(mt,oe[mt]),operators:a.map(n=>({text:e.toLanguageString(n.text,oe[n.text]),operator:n.operator}))}}const $n=e=>{const{operators:a,...n}=e;return t.createElement(y.TextFilterCell,{ariaLabel:"text filter",...Ye(B.useLocalization(),a||to),...n})};$n.displayName="KendoReactGanttTextFilter";const Yn=e=>{const{operators:a,...n}=e;return t.createElement(y.NumericFilterCell,{ariaLabel:"numeric filter",...Ye(B.useLocalization(),a||no),...n})};Yn.displayName="KendoReactGanttNumericFilter";const Zn=e=>{const{operators:a,...n}=e;return t.createElement(y.BooleanFilterCell,{ariaLabel:"boolean filter",...Ye(B.useLocalization(),a||oo),...n})};Zn.displayName="KendoReactGanttBooleanFilter";const jn=e=>{const{operators:a,...n}=e;return t.createElement(y.DateFilterCell,{ariaLabel:"date filter",...Ye(B.useLocalization(),a||ao),...n})};jn.displayName="KendoReactGanttDateFilter";const ro=e=>{const{dependencyData:a,dependencyModelFields:n,defaultDataItem:o,fromId:s,toId:l,type:r}=e,c=a.map(f=>({...f})),m=h.setter(n.fromId),g=h.setter(n.toId),d=h.setter(n.type),u=o?{...o}:{};return m(u,s),g(u,l),d(u,r),c.push(u),c},so=e=>{const{defaultDataItem:a,selectedDataItem:n,direction:o,taskModelFields:s,dataTree:l,slotStart:r,slotEnd:c}=e,m=Ge(l,s.children,p=>({...p})),g=h.setter(s.start),d=h.setter(s.end),u=h.getter(s.start),f=h.getter(s.end),C=a?{...a}:{},D=u(C)&&f(C);if(!n||o==="none")D||(g(C,r),d(C,c)),m.unshift(C);else{const p=[{task:{[s.children]:m},childrenIndex:0}],T=h.getter(s.id),L=h.getter(s.children),A=h.setter(s.children),M=T(n);for(;p.length>0;){const x=p[p.length-1],O=x.task,Q=T(O),S=L(O);if(Q&&Q===M)break;S&&S.length&&S.length>x.childrenIndex?(p.push({task:S[x.childrenIndex],childrenIndex:0}),x.childrenIndex++):p.pop()}if(p.length>1){const x=p[p.length-1].task,O=p[p.length-2].childrenIndex,S=p[p.length-2].task,j=L(S);switch(o){case"child":{let H=L(x);H||(H=[],A(x,H)),D||(g(C,new Date(u(x).getTime())),d(C,new Date(f(x).getTime()))),H.push(C),He(p.splice(1,p.length-1).map(X=>X.task),s);break}case"above":{u(S)&&f(S)&&!D?(g(C,new Date(u(x).getTime())),d(C,new Date(f(x).getTime()))):(g(C,r),d(C,c)),j.splice(O-1,0,C),He(p.splice(1,p.length-2).map(H=>H.task),s);break}case"below":{u(S)&&f(S)&&!D?(g(C,new Date(u(x).getTime())),d(C,new Date(f(x).getTime()))):(g(C,r),d(C,c)),j.splice(O,0,C),He(p.splice(1,p.length-2).map(H=>H.task),s);break}}}}return m},lo=e=>{const{updatedDataItem:a,taskModelFields:n,dataTree:o}=e,s=h.getter(n.id),l=h.getter(n.children),r=s(a);let c;const m=Ge(o,n.children,d=>s(d)===r?(c=d,{...a}):{...d});let g=[{task:{[n.children]:m},childrenIndex:0}];for(;g.length>0;){const d=g[g.length-1],u=d.task,f=s(u),C=l(u);if(f&&f===r)break;C&&C.length&&C.length>d.childrenIndex?(g.push({task:C[d.childrenIndex],childrenIndex:0}),d.childrenIndex++):g.pop()}if(g.length>1){g=g.splice(1,g.length-2);const d=h.getter(n.start),u=h.getter(n.end),f=h.getter(n.percentComplete);if(d(c).getTime()!==d(a).getTime()){Xn(g.map(D=>D.task),n);const C=d(a).getTime()-d(c).getTime();co(l(a),n,C)}u(c).getTime()!==u(a).getTime()&&Jn(g.map(C=>C.task),n),f(c)!==f(a)&&Qn(g.map(C=>C.task),n)}return m},io=e=>{const{removedDataItem:a,taskModelFields:n,dataTree:o}=e,s=Ge(o,n.children,g=>({...g}));let l=[{task:{[n.children]:s},childrenIndex:0}];const r=h.getter(n.id),c=h.getter(n.children),m=r(a);for(;l.length>0;){const g=l[l.length-1],d=g.task,u=r(d),f=c(d);if(u&&u===m)break;f&&f.length&&f.length>g.childrenIndex?(l.push({task:f[g.childrenIndex],childrenIndex:0}),g.childrenIndex++):l.pop()}if(l.length>1){const g=l[l.length-2],d=g.task;c(d).splice(g.childrenIndex-1,1),l=l.splice(1,l.length-2),He(l.map(f=>f.task),n)}return s},He=(e,a)=>{Xn(e,a),Jn(e,a),Qn(e,a)},Xn=(e,a)=>{if(!e.length)return;const n=h.getter(a.children),o=h.getter(a.start),s=h.setter(a.start);for(let l=e.length-1;l>=0;l--){const r=e[l],c=n(r);if(c&&c.length){const m=c.reduce((g,d)=>Math.min(g,o(d).getTime()),o(c[0]).getTime());s(r,new Date(m))}}},Jn=(e,a)=>{if(!e.length)return;const n=h.getter(a.children),o=h.getter(a.end),s=h.setter(a.end);for(let l=e.length-1;l>=0;l--){const r=e[l],c=n(r);if(c&&c.length){const m=c.reduce((g,d)=>Math.max(g,o(d).getTime()),o(c[0]).getTime());s(r,new Date(m))}}},Qn=(e,a)=>{if(!e.length)return;const n=h.getter(a.children),o=h.getter(a.percentComplete),s=h.setter(a.percentComplete),l=({avg:r,n:c},m)=>({avg:((o(m)||0)+c*r)/(c+1),n:c+1});for(let r=e.length-1;r>=0;r--){const c=e[r],m=n(c);if(m&&m.length){const g=m.reduce(l,{avg:0,n:0}).avg;s(c,g)}}},co=(e,a,n)=>{if(!e)return;const o=h.getter(a.children),s=h.getter(a.start),l=h.setter(a.start),r=h.getter(a.end),c=h.setter(a.end),m=e.map(g=>({task:g,childrenIndex:0}));for(;m.length>0;){const g=m[m.length-1],d=g.task,u=o(d);u&&u.length&&u.length>g.childrenIndex?(m.push({task:u[g.childrenIndex],childrenIndex:0}),g.childrenIndex++):(m.pop(),l(d,new Date(s(d).getTime()+n)),c(d,new Date(r(d).getTime()+n)))}},uo=e=>{const{validationMessage:a,touched:n,label:o,id:s,valid:l,disabled:r,hint:c,type:m,optional:g,...d}=e,u=n&&a,f=!u&&c,C=f?`${s}_hint`:"",D=u?`${s}_error`:"";return t.createElement(se.FieldWrapper,null,t.createElement(le.Label,{editorId:s,editorValid:l,editorDisabled:r,optional:g},o),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(Gt.Input,{valid:l,type:m,id:s,disabled:r,ariaDescribedBy:`${C} ${D}`,...d}),f&&t.createElement(le.Hint,{id:C},c),u&&t.createElement(le.Error,{id:D},a)))},Vt=e=>{const{validationMessage:a,touched:n,label:o,id:s,valid:l,disabled:r,hint:c,wrapperStyle:m,...g}=e,d=n&&a,u=!d&&c,f=u?`${s}_hint`:"",C=d?`${s}_error`:"",D=o?`${s}_label`:"";return t.createElement(se.FieldWrapper,{style:m},t.createElement(le.Label,{id:D,editorId:s,editorValid:l,editorDisabled:r},o),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(ca.DateTimePicker,{ariaLabelledBy:D,ariaDescribedBy:`${f} ${C}`,valid:l,id:s,disabled:r,...g}),u&&t.createElement(le.Hint,{id:f},c),d&&t.createElement(le.Error,{id:C},a)))},mo=e=>{const{validationMessage:a,touched:n,label:o,id:s,valid:l,disabled:r,hint:c,...m}=e,g=n&&a,d=!g&&c,u=d?`${s}_hint`:"",f=g?`${s}_error`:"";return t.createElement(se.FieldWrapper,null,t.createElement(le.Label,{editorId:s,editorValid:l,editorDisabled:r},o),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(Gt.NumericTextBox,{ariaDescribedBy:`${u} ${f}`,valid:l,id:s,disabled:r,...m}),d&&t.createElement(le.Hint,{id:u},c),g&&t.createElement(le.Error,{id:f},a)))},go=()=>{const e=kt(),a=B.useLocalization(),n=p=>a.toLanguageString(p,oe[p]),o=n(Rn),s=n(Sn),l=n(In),r=n(xn),c=n(Nn),m=n(Mn),g=n(Fn),d=t.useCallback(p=>p||p===0?void 0:c,[c]),u=t.useCallback((p,T)=>p&&T(e.end)&&p.getTime()>T(e.end).getTime()?m:void 0,[e,m]),f=t.useCallback((p,T)=>p&&T(e.start)&&p.getTime()<T(e.start).getTime()?g:void 0,[e,g]),C=t.useMemo(()=>[d,u],[d,u]),D=t.useMemo(()=>[d,f],[d,f]);return t.createElement(se.FormElement,{style:{width:400},horizontal:!0},t.createElement(se.Field,{id:`${e.title}_gantteditor`,name:e.title,label:o,component:uo,validator:d}),t.createElement(se.Field,{id:`${e.start}_gantteditor`,name:e.start,label:s,component:Vt,validator:C}),t.createElement(se.Field,{id:`${e.end}_gantteditor`,name:e.end,label:l,component:Vt,validator:D}),t.createElement(se.Field,{id:`${e.percentComplete}_gantteditor`,name:e.percentComplete,format:"p",label:r,component:mo,step:.01,validator:d}))},ho=e=>{const{onCancel:a,onClose:n,onSubmit:o,...s}=e,l=B.useLocalization(),r=D=>l.toLanguageString(D,oe[D]),c=r(vn),m=r(Ft),g=r(Tn),d=t.useCallback(D=>{if(a){const p={syntheticEvent:D,nativeEvent:D.nativeEvent,dataItem:e.dataItem};a.call(void 0,p)}},[a,e.dataItem]),u=t.useCallback(({syntheticEvent:D})=>{if(n){const p={syntheticEvent:D,nativeEvent:D.nativeEvent,dataItem:e.dataItem};n.call(void 0,p)}},[n,e.dataItem]),f=t.useCallback((D,p)=>{if(o){const T={dataItem:D,syntheticEvent:p,nativeEvent:p&&p.nativeEvent};o.call(void 0,T)}},[o]),C=t.createElement(se.Form,{initialValues:e.dataItem,onSubmit:f,render:D=>t.createElement(Ae.Dialog,{title:g,minWidth:600,onClose:u,style:{zIndex:90}},t.createElement(go,null),t.createElement(Ae.DialogActionsBar,null,t.createElement(ae.Button,{disabled:!D.allowSubmit,onClick:D.onSubmit},c),t.createElement(ae.Button,{onClick:d},m))),...s});return h.canUseDOM?Pt.createPortal(C,document&&document.body):null},fo=e=>{const{onClose:a,onCancel:n,onConfirm:o,dataItem:s}=e,l=B.useLocalization(),r=p=>l.toLanguageString(p,oe[p]),c=r(On),m=r(Ft),g=r(Vn),d=r(Gn),u=t.useCallback(({syntheticEvent:p})=>{a&&a.call(void 0,{syntheticEvent:p,nativeEvent:p&&p.nativeEvent,dataItem:null})},[a]),f=t.useCallback(p=>{n&&n.call(void 0,{syntheticEvent:p,nativeEvent:p&&p.nativeEvent,dataItem:null})},[n]),C=t.useCallback(p=>{o&&o.call(void 0,{syntheticEvent:p,nativeEvent:p&&p.nativeEvent,dataItem:s})},[o,s]),D=t.createElement(Ae.Dialog,{title:d,onClose:u},g,t.createElement(Ae.DialogActionsBar,null,t.createElement("button",{className:"k-button",onClick:f},m),t.createElement("button",{className:"k-button",onClick:C},c)));return h.canUseDOM?Pt.createPortal(D,document&&document.body):null},po=ue.TreeListRow;Object.defineProperty(exports,"getSelectedState",{enumerable:!0,get:()=>y.getSelectedState});Object.defineProperty(exports,"getSelectedStateFromKeyDown",{enumerable:!0,get:()=>y.getSelectedStateFromKeyDown});Object.defineProperty(exports,"setSelectedState",{enumerable:!0,get:()=>y.setSelectedState});exports.GANTT_COL_INDEX_ATTRIBUTE=ua;exports.GANTT_PREVENT_SELECTION_ELEMENT=ma;exports.GANTT_ROW_INDEX_ATTRIBUTE=da;exports.Gantt=Be;exports.GanttBooleanFilter=Zn;exports.GanttDateFilter=jn;exports.GanttDayView=Ue;exports.GanttForm=ho;exports.GanttMonthView=qe;exports.GanttNumericFilter=Yn;exports.GanttRemoveDialog=fo;exports.GanttRow=po;exports.GanttTextFilter=$n;exports.GanttWeekView=Fe;exports.GanttYearView=$e;exports.addDependency=ro;exports.addTask=so;exports.createDataTree=ya;exports.extendDataItem=wa;exports.filterBy=Ea;exports.mapTree=Ge;exports.orderBy=Da;exports.removeTask=io;exports.updateTask=lo;
5
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Ra=require("react"),u=require("prop-types"),h=require("@progress/kendo-react-common"),y=require("@progress/kendo-date-math"),I=require("@progress/kendo-react-data-tools"),fe=require("@progress/kendo-react-treelist"),J=require("@progress/kendo-react-intl"),pe=require("@progress/kendo-svg-icons"),te=require("@progress/kendo-react-buttons"),xa=require("react-dom"),ee=require("@progress/kendo-react-form"),Ke=require("@progress/kendo-react-dialogs"),de=require("@progress/kendo-react-labels"),Qt=require("@progress/kendo-react-inputs"),Oe=require("@progress/kendo-react-layout"),Ma=require("@progress/kendo-react-dateinputs"),Z=require("@progress/kendo-react-dropdowns"),Te=require("@progress/kendo-react-grid"),Ue=require("@progress/kendo-data-query");function Jt(e){const a=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const n in e)if(n!=="default"){const r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(a,n,r.get?r:{enumerable:!0,get:()=>e[n]})}}return a.default=e,Object.freeze(a)}const t=Jt(Ra),en=Jt(xa),Na=I.TABLE_ROW_INDEX_ATTRIBUTE,Fa=I.TABLE_COL_INDEX_ATTRIBUTE,La=I.TABLE_PREVENT_SELECTION_ELEMENT,$t=new Date().getTime(),tn=7,Va="hh:mm a",mt={skeleton:"MEd"},Aa="MMM",Ga="yyyy",Ve=100,za=6,$e="data-dependency-drag-handle",Ha="start",Pa="finish",qt={[$e]:Ha},Ut={[$e]:Pa},qe="data-task-id",nn={id:"id",start:"start",end:"end",title:"title",percentComplete:"percentComplete",parentId:"parentId",isRollup:"isRollup",isExpanded:"isExpanded",isInEdit:"isInEdit",children:"children",isSelected:"isSelected"},an={id:"id",fromId:"fromId",toId:"toId",type:"type"},Oa=I.orderBy,Wa=I.filterBy,Ae=h.mapTree,_a=h.extendDataItem,Ba=fe.createDataTree,Ka=e=>({fields:{...nn,...e}}),$a=e=>({fields:{...an,...e}}),on=e=>y.getDate(e),Et=(e,a)=>y.getDate(y.addDays(e,a||1)),qa=(e,a,n,r)=>n<a&&e<=r;function Ce(e){return new Date(Date.UTC(e.getFullYear(),e.getMonth(),e.getDate(),e.getHours(),e.getMinutes(),e.getSeconds(),e.getMilliseconds()))}const ge=4,ut=10,Ua=(e,a,n,r)=>{const s=[];let o=0,l=0;const i=ut,g=Math.floor(n/2),d=e.top<a.top,m=()=>s.push({left:l,top:o});if(r===0||r===3){const c=r===3?"start":"end";o=e.top,l=e[c],m(),l=Math[c==="start"?"min":"max"](e[c],a[c]),l=c==="start"?l-i:l+i,m(),o=a.top,m(),l=c==="start"?a[c]-ge:a[c]+ge,m(),Yt(o,l,s,c!=="start")}else{const c=r===2?"start":"end",f=r===2?"end":"start",k=r===2?e[c]-ut*2>=a[f]:e[c]+ut*2<=a[f];o=e.top,l=e[c],m(),l=c==="start"?l-i:l+i,m(),k||(o=d?o+g:o-g,m(),l=c==="start"?a[f]+i:a[f]-i,m()),o=a.top,m(),l=f==="start"?a[f]-ge:a[f]+ge,m(),Yt(o,l,s,f!=="start")}return s},Yt=(e,a,n,r)=>r?Ya(e,a,n):Za(e,a,n),Ya=(e,a,n)=>{n.push({top:e-ge/2,left:a}),n.push({top:e,left:a-ge+1}),n.push({top:e+ge/2,left:a}),n.push({top:e,left:a})},Za=(e,a,n)=>{n.push({top:e+ge/2,left:a}),n.push({top:e,left:a+ge-1}),n.push({top:e-ge/2,left:a}),n.push({top:e,left:a})},rn=e=>{if(e.workWeekStart===void 0||e.workWeekEnd===void 0)return[];const a=[];let n=e.workWeekStart;for(a.push(n);e.workWeekEnd!==n;)n>6?n-=7:n++,a.push(n);return a},Xa=(e,a)=>{const n=e.getDay();return a.indexOf(n)>-1},sn=(e,{step:a,timezone:n})=>{const r=[],s=y.ZonedDate.fromLocalDate(e.start,n),o=y.ZonedDate.fromLocalDate(e.end,n);let l=s.clone();for(;l.getTime()<o.getTime();){const i=l.clone(),g=i.clone().addTime(a),d=new Date(i.getTime()),c={end:new Date(g.getTime()),start:d,zonedStart:i,zonedEnd:g};r.push(c),l=l.addTime(a)}return r},ja=(e,{timezone:a},n)=>{const r=[],s=y.ZonedDate.fromLocalDate(e.start,a),o=y.ZonedDate.fromLocalDate(e.end,a);for(let l=s.clone(),i=0;l.getTime()<o.getTime();i++){const g=l.clone(),d=Et(y.firstDayInWeek(y.getDate(g),n.firstDay()),tn),m=y.ZonedDate.fromUTCDate(Ce(d),a),c=m.getTime()>o.getTime()?o.clone():m;l=c.clone();const f=new Date(g.getTime()),p={end:new Date(c.getTime()),start:f,zonedStart:g,zonedEnd:c};r.push(p)}return r},Qa=(e,{timezone:a})=>{const n=[],r=y.ZonedDate.fromLocalDate(e.start,a),s=y.ZonedDate.fromLocalDate(e.end,a);for(let o=r.clone(),l=0;o.getTime()<s.getTime();l++){const i=o.clone(),g=y.ZonedDate.fromLocalDate(y.addMonths(new Date(i.getTime()),1),a);o=g.clone();const d=new Date(i.getTime()),c={end:new Date(g.getTime()),start:d,zonedStart:i,zonedEnd:g};n.push(c)}return n},Ja=(e,{timezone:a})=>{const n=[],r=y.ZonedDate.fromLocalDate(e.start,a),s=y.ZonedDate.fromLocalDate(e.end,a);for(let o=r.clone(),l=0;o.getTime()<s.getTime();l++){const i=o.clone(),g=y.ZonedDate.fromLocalDate(y.addMonths(new Date(i.getTime()),12),a);o=g.clone();const d=new Date(i.getTime()),c={end:new Date(g.getTime()),start:d,zonedStart:i,zonedEnd:g};n.push(c)}return n},eo=(e,a,n)=>{const r=n.parseDate(a.workDayStart).getHours(),s=n.parseDate(a.workDayEnd).getHours();return sn(e,{step:y.MS_PER_MINUTE*a.slotDuration,timezone:a.timezone}).map(l=>{const i=l.zonedStart.getHours();return{range:l,isWork:i>=r&&i<s,span:1,text:n.formatDate(l.zonedStart,Va),type:"time"}})},ln=(e,a,n)=>sn(e,{step:y.MS_PER_DAY,timezone:a.timezone}).map(s=>({range:s,isWork:Xa(s.start,a.workDays),span:1,text:n.formatDate(s.zonedStart,mt),type:"day"})),cn=(e,a,n)=>ja(e,{timezone:a.timezone},n).map(s=>{const o=Math.round((s.zonedEnd.getTime()-s.zonedStart.getTime())/y.MS_PER_DAY);return{range:s,isWork:!1,span:o,text:`${n.formatDate(s.zonedStart,mt)} - ${n.formatDate(s.zonedEnd,mt)}`,type:"week"}}),dn=(e,a,n)=>Qa(e,{timezone:a.timezone}).map(s=>{const o=Math.round((s.zonedEnd.getTime()-s.zonedStart.getTime())/y.MS_PER_DAY);return{range:s,isWork:!1,span:o,text:n.formatDate(s.zonedStart,Aa),type:"month"}}),to=(e,a,n)=>Ja(e,{timezone:a.timezone}).map(s=>{const o=Math.round((s.zonedEnd.getTime()-s.zonedStart.getTime())/y.MS_PER_DAY);return{range:s,isWork:!1,span:o,text:n.formatDate(s.zonedStart,Ga),type:"year"}}),no=(e,a,n)=>{const r=n;return t.createElement("table",{className:"k-table k-table-md",ref:a,"aria-hidden":!0},t.createElement("tbody",{className:"k-table-tbody"},e.map((s,o)=>t.createElement("tr",{className:"k-table-row",key:o},s.map((l,i)=>t.createElement("td",{key:l.range.start.getTime(),colSpan:l.span,className:h.classNames("k-table-th",{"k-header":!0,"k-nonwork-hour":!l.isWork})},r?t.createElement(r,{rowIndex:o,index:i,range:l.range,text:l.text,isWork:l.isWork,type:l.type}):l.text))))))},ao=(e,a)=>{const n=e[e.length-1];return t.createElement("table",{className:"k-table k-table-md k-gantt-columns",ref:a,"aria-hidden":!0},t.createElement("tbody",{className:"k-table-tbody"},t.createElement("tr",{className:"k-table-row"},n.map(r=>t.createElement("td",{key:r.range.start.getTime(),colSpan:r.span,className:h.classNames("k-table-td",{"k-nonwork-hour":!r.isWork})})))))},oo=(e,a)=>{const n=e[e.length-1];let r=0,s=0;return n.forEach(o=>{const l=o.span;s+=l,l>r&&(r=l)}),Math.round(s*a/r)},gt=(e,a)=>!!h.getter(a)(e),un=(e,a)=>!!h.getter(a)(e),ro=(e,a)=>n=>gt(n,e)&&un(n,a)?[...h.getter(a)(n)]:[],wt=t.createContext([]),so=()=>t.useContext(wt);wt.displayName="KendoReactGanttTaskDataContext";const vt=t.createContext([]),lo=()=>t.useContext(vt);vt.displayName="KendoReactGanttDependencyDataContext";const Tt=t.createContext(nn),bt=()=>t.useContext(Tt);Tt.displayName="KendoReactGanttTaskModelFieldsContext";const St=t.createContext(an),mn=()=>t.useContext(St);St.displayName="KendoReactGanttDependencyModelFieldsContext";const It=t.createContext({}),Ge=()=>t.useContext(It);It.displayName="KendoReactGanttPropsContext";const Rt=t.createContext({start:new Date,end:new Date,zonedStart:y.ZonedDate.fromLocalDate(new Date),zonedEnd:y.ZonedDate.fromLocalDate(new Date)}),ze=()=>t.useContext(Rt);Rt.displayName="KendoReactGanttDateRangeContext";const xt=t.createContext([]),io=()=>t.useContext(xt);xt.displayName="KendoReactGanttViewsContext";const Mt=t.createContext(["week",h.noop]),gn=()=>t.useContext(Mt);Mt.displayName="KendoReactGanttActiveViewContext";const Nt=t.createContext(0),hn=()=>t.useContext(Nt);Nt.displayName="KendoReactGanttRowHeightContext";const Ft=t.createContext(0),co=()=>t.useContext(Ft);Ft.displayName="KendoReactGanttToolbarHeightContext";const Lt=t.createContext({onDataStateChange:h.noop,onSortChange:h.noop,onFilterChange:h.noop,onColumnMenuFilterChange:h.noop,onExpandChange:h.noop,onRowClick:h.noop,onRowDoubleClick:h.noop,onRowContextMenu:h.noop,onColumnResize:h.noop,onColumnReorder:h.noop,onDependencyCreate:h.noop,onKeyDown:h.noop,onSelectionChange:h.noop,onHeaderSelectionChange:h.noop}),uo=()=>t.useContext(Lt);Lt.displayName="KendoReactGanttEventsContext";const Vt=t.createContext({onTaskClick:h.noop,onTaskDoubleClick:h.noop,onTaskContextMenu:h.noop}),mo=()=>t.useContext(Vt);Vt.displayName="KendoReactGanttTaskEventsContext";const fn=({children:e,taskData:a,dependencyData:n,taskModelFields:r,dependencyModelFields:s,props:o,dateRange:l,views:i,activeView:g,rowHeight:d,toolbarHeight:m,events:c,taskEvents:f})=>t.createElement(It.Provider,{value:o},t.createElement(wt.Provider,{value:a},t.createElement(vt.Provider,{value:n},t.createElement(Tt.Provider,{value:r},t.createElement(St.Provider,{value:s},t.createElement(Rt.Provider,{value:l},t.createElement(xt.Provider,{value:i},t.createElement(Mt.Provider,{value:g},t.createElement(Nt.Provider,{value:d},t.createElement(Ft.Provider,{value:m},t.createElement(Lt.Provider,{value:c},t.createElement(Vt.Provider,{value:f},e))))))))))));fn.displayName="KendoReactGanttContext";const At=t.createContext([{current:{}},h.noop]),pn=()=>t.useContext(At);At.displayName="KendoReactGanttViewContext";const Gt=t.createContext(0),go=()=>t.useContext(Gt);Gt.displayName="KendoReactGanttViewTimelineWidthContext";const zt=t.createContext({onDependencyHandlePress:h.noop,onDependencyHandleDrag:h.noop,onDependencyHandleRelease:h.noop,isEnabled:!1,draggedId:null}),ho=()=>t.useContext(zt);zt.displayName="KendoReactGanttViewDependencyDragContext";const Cn=({children:e,tasksStore:a,timelineWidth:n,dependencyDrag:r})=>t.createElement(At.Provider,{value:a},t.createElement(Gt.Provider,{value:n},t.createElement(zt.Provider,{value:r},e)));Cn.displayName="KendoReactGanttViewContext";var ht=(e=>(e[e.add=0]="add",e[e.remove=1]="remove",e))(ht||{});const fo=()=>{const e=t.useRef({}),a=t.useCallback(n=>{switch(n.type){case 0:e.current[n.id]=n.itemRef;break;case 1:delete e.current[n.id];break}},[]);return[e,a]},po=(e,a,n,r)=>{const s=t.useRef(null),[,o]=pn();t.useImperativeHandle(s,()=>({element:r.current,dataItem:e})),t.useImperativeHandle(n,()=>s.current),t.useLayoutEffect(()=>{const l=s.current;if(l)return o({type:ht.add,itemRef:l,id:a}),()=>{o({type:ht.remove,itemRef:l,id:a})}})},kn=t.forwardRef((e,a)=>{const n=ze(),r=bt(),s=go(),o=ho(),l=mo(),i=t.useRef(null),g=t.useRef(null);po(e.dataItem,h.getter(r.id)(e.dataItem),a,i);const d=t.useRef(null),m=h.getter(r.id)(e.dataItem),c=h.getter(r.start)(e.dataItem),f=h.getter(r.end)(e.dataItem),k=h.getter(r.title)(e.dataItem),p=h.getter(r.percentComplete)(e.dataItem),D=h.getter(r.children)(e.dataItem),v=h.getter(r.isSelected)(e.dataItem),F=c&&c.getTime(),A=f&&f.getTime(),N=D&&D.length,O=!N&&F===A,R=F&&A&&qa(n.start,n.end,c,f),[V,T]=t.useState(!1),b=t.useRef(null),$=t.useRef(null);h.useDraggable(b,{onPress:o.onDependencyHandlePress,onDrag:o.onDependencyHandleDrag,onRelease:o.onDependencyHandleRelease}),h.useDraggable($,{onPress:o.onDependencyHandlePress,onDrag:o.onDependencyHandleDrag,onRelease:o.onDependencyHandleRelease});const W=t.useCallback(S=>{l.onTaskClick&&l.onTaskClick({dataItem:e.dataItem,level:e.level,nativeEvent:S&&S.nativeEvent,syntheticEvent:S,target:null})},[e.dataItem,e.level]),_=t.useCallback(S=>{l.onTaskDoubleClick&&l.onTaskDoubleClick({dataItem:e.dataItem,level:e.level,nativeEvent:S&&S.nativeEvent,syntheticEvent:S,target:null})},[e.dataItem,e.level]),X=t.useCallback(S=>{l.onTaskContextMenu&&l.onTaskContextMenu({dataItem:e.dataItem,level:e.level,nativeEvent:S&&S.nativeEvent,syntheticEvent:S,target:null})},[e.dataItem,e.level]),E=t.useCallback(S=>{l.onTaskRemoveClick&&l.onTaskRemoveClick({dataItem:e.dataItem,level:e.level,nativeEvent:S&&S.nativeEvent,syntheticEvent:S,target:null})},[e.dataItem,e.level]),P=t.useCallback(()=>{const S=n.start,ne=n.end,x=d.current,L=i.current,j=g.current;if(!R||x===null||L===null)return;const ae=x.clientWidth/(ne.getTime()-S.getTime()),B=(c.getTime()-S.getTime())*ae,U=(f.getTime()-c.getTime())*ae,ke=(x.offsetHeight-L.offsetHeight)/2;L.style.left=`${Math.round(O?B-za:B)}px`,L.style.top=`${Math.round(ke)}px`,O||(L.style.width=`${Math.round(U)}px`,j!==null&&(j.style.width=`${Math.round(U*(p||0))}px`)),T(!0)},[n.start.getTime(),n.end.getTime(),F,A,R,p,s]);t.useEffect(P,[P]);const Y={visibility:V?void 0:"hidden",display:R?void 0:"none"},q={userSelect:"none",display:o.draggedId===String(m)?"block":void 0};return t.createElement("td",{ref:d,key:m,role:"presentation"},O?t.createElement("div",{"aria-hidden":!0,className:h.classNames({"k-task":!0,"k-task-milestone":!0,"k-selected":v&&!Array.isArray(v)}),style:Y,ref:i,[qe]:m,onClick:W,onDoubleClick:_,onContextMenu:X},t.createElement("div",{className:"k-task-milestone-content"}),o.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-start",ref:b,style:q,...qt}),o.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-end",ref:$,style:q,...Ut})):t.createElement("div",{"aria-hidden":!0,className:h.classNames({"k-task":!0,"k-task-summary":N,"k-task-single":!N,"k-selected":v&&!Array.isArray(v)}),ref:i,style:Y,[qe]:m,onClick:W,onDoubleClick:_,onContextMenu:X},N?t.createElement("div",{className:"k-task-summary-progress",ref:g},t.createElement("div",{className:"k-task-summary-complete"})):t.createElement("div",{className:"k-task-complete",ref:g}),!N&&t.createElement(t.Fragment,null,t.createElement("div",{className:"k-task-content"},k),l.onTaskRemoveClick?t.createElement("span",{className:"k-task-actions"},t.createElement("span",{onClick:E,className:"k-link k-task-delete","aria-label":"Delete"},t.createElement(h.IconWrap,{name:"x",icon:pe.xIcon}))):null),o.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-start",ref:b,style:q,...qt}),o.isEnabled&&t.createElement("div",{className:"k-task-dot k-task-end",ref:$,style:q,...Ut})))});kn.displayName="KendoReactGanttTask";const Dn=e=>{const{dependency:a}=e,[n]=pn(),r=t.useRef(null),s=mn(),o=hn(),[l,i]=t.useState(!1),g=()=>{if(r.current===null||n.current===null){i(!1);return}const d=n.current[h.getter(s.fromId)(a)],m=n.current[h.getter(s.toId)(a)];if(!d||!m){i(!1);return}const c=d.element,f=m.element;if(!c||!f){i(!1);return}if(l===!1){i(!0);return}const k={top:c.offsetTop+c.offsetHeight/2,start:c.offsetLeft,end:c.offsetLeft+c.offsetWidth},p={top:f.offsetTop+f.offsetHeight/2,start:f.offsetLeft,end:f.offsetLeft+f.offsetWidth},D=h.getter(s.type)(a),v=Ua(k,p,o,D);v&&v.length&&r.current.setAttribute("points",v.map(F=>`${F.left},${F.top}`).join(" "))};return t.useEffect(g),t.createElement("polyline",{ref:r,style:{display:l?void 0:"none"}})};Dn.displayName="KendoReactGanttDependency";class Ht extends t.Component{constructor(a){super(a),this.state={activeId:void 0,level:0},this.tableElement=null,this.tbodyElement=null,this.wrapperScrollLeft=0,this.wrapperScrollTop=0,this.updateOnScroll=!1,this.tbodyOffsetTop=0,this.prevData=[],this.flattedData=[],this.element=null,this.contextStateRef={current:void 0},this.navigationStateRef={current:void 0},this.scrollIntoView=n=>{if(!this.element)return;const{rowIndex:r=0}=n,{rowHeight:s=0}=this.props;this.element.scroll(0,(r-1)*s)},this.getColumns=n=>{const r=n.filter(o=>o.declarationIndex>=0&&o.parentIndex===-1),s=o=>(o.sort((l,i)=>l.declarationIndex-i.declarationIndex),o.map(l=>{const{declarationIndex:i,parentIndex:g,depth:d,colSpan:m,rowSpan:c,index:f,kFirst:k,groupable:p,children:D,...v}=l;return D.length?{children:s(D),...v}:v}));return s(r)},this.onKeyDown=n=>{if(I.tableKeyboardNavigation.onKeyDown(n,{contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef}),this.props.onKeyDown){const{mode:r,cell:s}=I.getSelectionOptions(this.props.selectable),o={dataItems:this.getLeafDataItems(),mode:r,cell:s,componentId:this.props.treelistId,selectedField:this.props.selectedField,...this.getEventArguments(n)};this.props.onKeyDown.call(void 0,o)}},this.onFocus=n=>{I.tableKeyboardNavigation.onFocus(n,{contextStateRef:this.contextStateRef})},this.onRowDrag=n=>{if(this.props.onRowDrag){const r={...n,target:this};this.props.onRowDrag.call(void 0,r)}},this.onRowDrop=n=>{if(this.props.onRowDrop){const r={...n,target:this};this.props.onRowDrop.call(void 0,r)}},this.onColumnReorder=(n,r,s)=>{const{extendedColumns:o}=this.props,l=o[n].depth,i=m=>{do m++;while(m<o.length&&o[m].depth>l);return m},g=[...o],d=g.splice(n,i(n)-n);if(g.splice(n<r?i(r-d.length):r,0,...d),g.filter(m=>m.declarationIndex>=0).forEach((m,c)=>m.orderIndex=c),this.props.onColumnReorder){const m={target:this,columns:this.getColumns(g),nativeEvent:s};this.props.onColumnReorder.call(void 0,m)}},this.onColumnResize=(n,r,s,o,l)=>{if(this.props.onColumnResize){const i=this.props.extendedColumns.filter(d=>d.children.length===0).reduce((d,m)=>d+=parseFloat(String(m.width)),0);this.tableElement&&(this.tableElement.style.width=i+"px");const g={columns:this.getColumns(this.props.extendedColumns),totalWidth:i,index:n,nativeEvent:o,newWidth:r,oldWidth:s,end:l,target:this};this.props.onColumnResize.call(void 0,g)}},this.onScroll=n=>{const r=n.currentTarget.scrollLeft,s=n.currentTarget.scrollTop,{columnVirtualization:o,scrollable:l,rowHeight:i=0}=this.props,g=i,d=0;let m=!1;o&&Math.abs(this.wrapperScrollLeft-r)>d&&(this.wrapperScrollLeft=r,m=!0),l==="virtual"&&Math.abs(this.wrapperScrollTop-s)>g&&(this.wrapperScrollTop=s,m=!0),m&&(this.updateOnScroll=!0,this.forceUpdate())},this.calculateSizes=n=>{if(!n||this.props.scrollable==="none")return;const r=Array.from(n.childNodes),s=r.find(i=>i.nodeName==="TABLE"),o=this.props.toolbar&&r.find(i=>i.nodeType===1&&i.classList.contains("k-grid-toolbar"));let l=0;if(o){const i=o.style.boxSizing;o.style.boxSizing="border-box",l=parseFloat(String(window.getComputedStyle(o).height))||o.offsetHeight,o.style.boxSizing=i,o.getAttribute("style")||o.removeAttribute("style")}this.tbodyOffsetTop=s.tBodies[0].offsetTop,fe.setHeaderRowsTop(s,l)},this.onItemChange=n=>{if(n.field===this.props.expandField){const r=this.props.onExpandChange;if(r){const s={...this.getEventArguments(n.syntheticEvent),dataItem:n.dataItem,level:n.level,value:n.value};r.call(void 0,s)}return}if(this.props.onItemChange){const r={...this.getEventArguments(n.syntheticEvent),dataItem:n.dataItem,level:n.level,field:n.field,value:n.value};this.props.onItemChange.call(void 0,r)}},this.onHeaderSelectionChange=n=>{if(this.props.onHeaderSelectionChange){const r={field:n.field,nativeEvent:n.syntheticEvent&&n.syntheticEvent.nativeEvent,syntheticEvent:n.syntheticEvent,target:this,dataItems:this.getLeafDataItems()};this.props.onHeaderSelectionChange.call(void 0,r)}},this.selectionRelease=n=>{if(this.props.onSelectionChange){const r={syntheticEvent:void 0,target:this,selectedField:this.props.selectedField||"",componentId:this.props.treelistId,dataItems:this.getLeafDataItems(),dataItem:null,level:[],...n};this.props.onSelectionChange.call(void 0,r)}},this.onSortChange=(n,r,s)=>{this.onDataStateChange(this.props.onSortChange,{sort:r,field:s},n)},this.onFilterChange=n=>{const{filter:r,field:s}=n;this.onDataStateChange(this.props.onFilterChange,{filter:r,field:s},n.syntheticEvent)},this.onColumnMenuFilterChange=(n,r,s)=>{if(!s)return;const{onColumnMenuFilterChange:o}=this.props;if(!o)return;const l={syntheticEvent:n,filter:r,field:s,target:this,nativeEvent:n.nativeEvent};o.call(void 0,l)},this.onExpandChange=(n,r,s)=>{const{expandField:o,onExpandChange:l}=this.props;if(o&&l){const i={...this.getEventArguments(n),dataItem:r,level:s,value:gt(r,this.props.expandField)};l.call(void 0,i)}},this.onRowClick=(n,r)=>{if(this.props.onRowClick&&n.target.nodeName==="TD"){const s={dataItem:r.dataItem,level:r.level,...this.getEventArguments(n)};this.props.onRowClick.call(void 0,s)}},this.rowDoubleClick=(n,r)=>{if(this.props.onRowDoubleClick&&n.target.nodeName==="TD"){const s={dataItem:r.dataItem,level:r.level,...this.getEventArguments(n)};this.props.onRowDoubleClick.call(void 0,s)}},this.rowContextMenu=(n,r)=>{if(this.props.onRowContextMenu&&n.target.nodeName==="TD"){const s={dataItem:r.dataItem,level:r.level,...this.getEventArguments(n)};this.props.onRowContextMenu.call(void 0,s)}},this.onPageChange=n=>{if(this.props.onPageChange){const r={...this.getEventArguments(n.syntheticEvent),skip:n.skip,take:n.take};this.props.onPageChange.call(void 0,r)}},this.onDataStateChange=(n,r,s)=>{if(n&&n.call(void 0,{...this.getEventArguments(s),...r}),this.props.onDataStateChange){const o={...this.getEventArguments(s),dataState:{...this.getDataState(),...r}};this.props.onDataStateChange.call(void 0,o)}},this.getDataState=()=>({filter:this.props.filter,sort:this.props.sort}),this.getEventArguments=n=>({nativeEvent:n&&n.nativeEvent,syntheticEvent:n,target:this}),this.getLeafDataItems=()=>this.flatData.map(n=>n.dataItem),this.dragLogic=new I.CommonDragLogic(this.onColumnReorder,h.noop,h.noop),this.columnResize=new I.ColumnResize(this.onColumnResize),I.tableKeyboardNavigation.onConstructor({navigatable:!!a.navigatable,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef,idPrefix:a.idPrefix})}get document(){if(h.canUseDOM)return this.element&&this.element.ownerDocument||document}componentDidMount(){this.calculateSizes(this.element),I.tableKeyboardNavigation.onComponentDidMount({scope:this.element||void 0,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef})}getSnapshotBeforeUpdate(){return I.tableKeyboardNavigation.onGetSnapshotBeforeUpdate({document:this.document,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef}),null}componentDidUpdate(a){a.columns!==this.props.columns&&this.calculateSizes(this.element),I.tableKeyboardNavigation.onComponentDidUpdate({scope:this.element||void 0,contextStateRef:this.contextStateRef,navigationStateRef:this.navigationStateRef})}componentWillUnmount(){this.columnResize.columns=[],this.dragLogic.columns=[],this.prevData=[],this.flattedData=[],this.updateOnScroll=!1}render(){const{filterRow:a,scrollable:n="scrollable",resizable:r=!1,reorderable:s=!1,skip:o,take:l,afterContent:i,extendedColumns:g=[],columnsMap:d}=this.props,m=g.some(E=>!!E.filter)||a!==void 0,c=a||I.FilterRow,f=I.tableKeyboardNavigationTools.getIdPrefix(this.navigationStateRef);this.columnResize.columns=g,this.columnResize.resizable=r,this.dragLogic.columns=g,this.dragLogic.reorderable=s,this.dragLogic.groupable=!1;const k=g.filter(E=>E.children.length===0),p=t.createElement(I.Header,{headerRow:t.createElement(I.HeaderRow,{sort:this.props.sort,sortable:this.props.sortable,sortChange:this.onSortChange,selectionChange:this.onHeaderSelectionChange,columns:g,columnsMap:d,cellRender:this.props.headerCellRender,columnResize:this.columnResize,columnMenu:this.props.columnMenu,columnMenuFilter:this.props.columnMenuFilter,columnMenuFilterChange:this.onColumnMenuFilterChange,pressHandler:this.dragLogic.pressHandler,dragHandler:this.dragLogic.dragHandler,releaseHandler:this.dragLogic.releaseHandler}),filterRow:m&&t.createElement(c,{columns:k,filter:this.props.filter,filterChange:this.onFilterChange,sort:this.props.sort,ariaRowIndex:d.length+1})||void 0,columnResize:this.columnResize}),D=this.props.style||{},{colSpans:v,hiddenColumns:F}=I.tableColumnsVirtualization({enabled:this.props.columnVirtualization,columns:k,scrollLeft:this.wrapperScrollLeft,tableViewPortWidth:parseFloat((D.width||"").toString())}),A=(E,P,Y,q,S,ne)=>k.map((x,L)=>{if(F[L])return null;const j=x.id?x.id:L,ae=`k-table-td ${x.className?x.className+" ":""}${x.locked?"k-grid-content-sticky":""}`,B={id:I.tableKeyboardNavigationTools.generateNavigatableId(`${Y}-${String(L)}`,f),colSpan:v[L],dataItem:E.dataItem,field:x.field,format:x.format,className:ae||void 0,render:this.props.cellRender,onChange:this.onItemChange,selectionChange:this.props.onSelectionChange?U=>{this.onSelectionChange({event:U,item:E,columnIndex:L,dataIndex:S})}:void 0,level:E.level,expandable:x.expandable,expanded:q,hasChildren:un(E.dataItem,this.props.subItemsField),colIndex:L,ariaColumnIndex:x.ariaColumnIndex,onExpandChange:this.onExpandChange,style:x.left!==void 0&&{left:x.left,right:x.right,borderRightWidth:x.rightBorder?"1px":""}||{},isSelected:Array.isArray(ne)&&ne.indexOf(L)>-1};return P&&x.editCell?t.createElement(x.editCell,{...B,onChange:this.onItemChange,key:j}):x.cell?t.createElement(x.cell,{key:j,...B}):t.createElement(fe.TreeListCell,{key:j,...B})});let N=this.flatData;const O=N.length;o!==void 0&&l!==void 0&&(N=N.slice(o,o+l)),n==="virtual"&&(N=fe.tableRowsVirtualization({rows:N,tableViewPortHeight:parseFloat((D.height||D.maxHeight||"").toString()),scrollTop:this.wrapperScrollTop}),this.updateOnScroll=!1);const R=N.map(E=>E.level),V=d.length+(m?1:0)+1,T=N.length>0&&N.map((E,P)=>{const Y=h.getter(this.props.editField||"")(E.dataItem),q=h.getter(this.props.dataItemKey)(E.dataItem),S=String(q||E.level.join(".")),ne=gt(E.dataItem,this.props.expandField),x=this.props.selectedField?h.getter(this.props.selectedField)(E.dataItem):void 0,L={key:S,level:E.level,levels:R,dataItem:E.dataItem,selectedField:this.props.selectedField,rowHeight:E.height,render:this.props.rowRender,onDrop:this.onRowDrop,onDrag:this.onRowDrag,onClick:U=>this.onRowClick(U,E),onDoubleClick:U=>this.rowDoubleClick(U,E),onContextMenu:U=>this.rowContextMenu(U,E),isAltRow:P%2!==0,expanded:ne,rowIndex:P,ariaRowIndex:V+P,ariaSetSize:E.levelCount,ariaPosInSet:E.level[E.level.length-1]+1,isSelected:typeof x=="boolean"&&x},j=this.props.editRow,ae=this.props.row||fe.TreeListRow,B=A(E,Y,S,ne,P,x);return Y&&j?t.createElement(j,{...L,key:L.key},B):t.createElement(ae,{...L,key:L.key},B)})||t.createElement("tr",{className:"k-table-row k-grid-norecords"},t.createElement("td",{className:"k-table-td",colSpan:k.length},this.props.noRecords||t.createElement(fe.TreeListNoRecords,null))),b=E=>this.props.sort&&this.props.sort.some(P=>P.field===E),$=t.createElement("colgroup",{ref:E=>{this.columnResize.colGroupMain=E}},k.map((E,P)=>t.createElement("col",{key:P.toString(),className:b(E.field)?"k-sorted":void 0,style:E.width!==void 0?{width:E.width}:void 0}))),W=this.props.columnVirtualization||this.props.scrollable==="virtual",_=this.props.selectable&&this.props.selectable.drag?"none":void 0,X=this.props.tableProps||{};return t.createElement(I.TableKeyboardNavigationContext.Provider,{value:this.contextStateRef.current},t.createElement("div",{id:this.props.treelistId,style:this.props.style,className:h.classNames("k-grid k-grid-md",this.props.className,{"k-treelist-scrollable":n!=="none"}),ref:E=>this.element=E,onScroll:W?this.onScroll:void 0,onKeyDown:this.onKeyDown,onFocus:this.onFocus,"aria-rowcount":O,"aria-colcount":k.length,role:"treegrid",...I.tableKeyboardNavigationScopeAttributes},this.props.toolbar,t.createElement(I.TableSelection,{selectable:this.props.selectable,onRelease:this.selectionRelease,childRef:E=>{this.tableElement=E}},t.createElement("table",{className:"k-table k-table-md",...this.props.tableProps||{},style:{...X.style||{},userSelect:_},role:"presentation"},$,p,t.createElement("tbody",{className:"k-table-tbody",...I.tableKeyboardNavigationBodyAttributes,ref:E=>this.tbodyElement=E,role:"presentation"},T))),this.props.pager&&t.createElement(this.props.pager,{className:"k-grid-pager",total:O,skip:o,take:l,onPageChange:this.onPageChange}),s&&t.createElement(t.Fragment,null,t.createElement(I.DropClue,{ref:this.dragLogic.refDropElementClue}),t.createElement(I.DragClue,{ref:this.dragLogic.refDragElementClue})),i))}get flatData(){const{data:a=[],rowHeight:n=0}=this.props;let r=0;const s=()=>{const l={height:n,offsetTop:r};return r+=l.height,l},o=this.updateOnScroll&&this.prevData===a&&this.tbodyOffsetTop>0&&this.flattedData.length?this.flattedData:a.map(l=>({...l,...s()}));return this.prevData=a,this.flattedData=o,o}onSelectionChange(a){if(this.props.onSelectionChange){const{event:n,item:r,dataIndex:s,columnIndex:o}=a,{mode:l,cell:i}=I.getSelectionOptions(this.props.selectable),g={...this.getEventArguments(n.syntheticEvent),dataItem:r.dataItem,level:r.level,startColIndex:o,endColIndex:o,startRowIndex:s,endRowIndex:s,dataItems:this.getLeafDataItems(),altKey:!1,ctrlKey:!1,shiftKey:!1,metaKey:!1,mode:l,cell:i,isDrag:!1,componentId:this.props.treelistId,selectedField:this.props.selectedField||""};this.props.onSelectionChange.call(void 0,g)}}}Ht.propTypes={data:u.array,resizable:u.bool,reorderable:u.bool,sortable:u.oneOfType([u.bool,u.shape({mode:u.oneOf(["single","multiple"]),allowUnsort:u.bool})]),onSortChange:u.func,sort:u.array,columns:u.arrayOf(u.object),columnVirtualization:u.bool,filter:u.array,onFilterChange:u.func,filterRow:u.any,toolbar:u.any,noRecords:u.any,onExpandChange:u.func,expandField:u.string,subItemsField:u.string,selectedField:u.string,onSelectionChange:u.func,onHeaderSelectionChange:u.func,onRowClick:u.func,onItemChange:u.func,editField:u.string,scrollable:u.oneOf(["none","scrollable","virtual"]),rowHeight:u.number,style:u.object,tableProps:u.object,pager:u.any,skip:u.number,take:u.number,onPageChange:u.func,onDataStateChange:u.func,onColumnResize:u.func,onColumnReorder:u.func,extendedColumns:u.arrayOf(u.object),columnsMap:u.arrayOf(u.array),dataItemKey:u.string.isRequired,afterContent:u.any,navigatable:u.bool,idPrefix:u.string,treelistId:u.string};Ht.contextType=I.TableKeyboardNavigationContext;const He=t.forwardRef((e,a)=>{const{slotLevels:n,slotWidth:r,timelineHeaderCell:s}=e,{columns:o,noRecords:l,resizable:i,reorderable:g,sortable:d,sort:m,filter:c,columnMenuFilter:f,columnMenu:k,navigatable:p,row:D,selectable:v}=Ge(),{onDataStateChange:F,onSortChange:A,onFilterChange:N,onColumnMenuFilterChange:O,onExpandChange:R,onRowClick:V,onRowDoubleClick:T,onRowContextMenu:b,onColumnResize:$,onColumnReorder:W,onDependencyCreate:_,onKeyDown:X,onSelectionChange:E,onHeaderSelectionChange:P}=uo(),Y=hn(),q=co(),S=bt(),ne=mn(),x=so(),L=lo(),j=t.useRef(null),ae=t.useRef(null),B=t.useRef(null),U=t.useRef(null),ke=t.useRef(0),De=t.useRef(h.useId()),H=t.useRef(h.useId()),se=t.useRef(null),Se=t.useRef(null),xe=t.useCallback(M=>{B.current&&B.current.scrollIntoView(M)},[]);t.useImperativeHandle(Se,()=>({scrollIntoView:xe})),t.useImperativeHandle(a,()=>Se.current);const ye=t.useRef(0),C=t.useRef(0),G=t.useRef(0),K=t.useRef(0),ue=t.useRef(null),Ee=t.useRef(null),[ce,Me]=t.useState(null),at=no(n,j,s),ot=ao(n,ae),Ie=oo(n,r),{extendedColumns:rt,columnsWidth:st,columnsMap:lt}=t.useMemo(()=>{const M=I.readColumns([...o,{title:"",sortable:!1,resizable:!1,reorderable:!1,width:Ie,headerCell:()=>at,cell:kn,orderIndex:Number.MAX_SAFE_INTEGER,navigatable:!1}],{prevId:0,idPrefix:De.current});let Q=0;return M.forEach((z,oe,le)=>{const re=oe+1===le.length,ve=z.children.length===0;re?z.isAccessible=!1:(z.locked=!0,ve&&(z.width=z.width||Ve)),ve&&(Q+=parseFloat(String(z.width)))}),{extendedColumns:M,columnsWidth:Q,columnsMap:I.mapColumns(M)}},[o,Ie]),[it,ct]=fo(),w=t.useCallback(()=>j.current&&j.current.parentElement,[]),he=()=>{const M=w(),Q=ae.current,z=B.current&&B.current.tbodyElement;if(!M||!Q||!z)return;const oe=z.offsetTop,le=M.offsetLeft,re=Ie;Q.style.top=oe+"px",Q.style.left=le+"px",Q.style.width=re+"px",Q.style.height=z.offsetHeight+"px"},we=()=>{const M=w();M&&(ke.current=M.offsetLeft)};t.useEffect(he),t.useEffect(we);const Ne=t.useCallback(M=>{if(!U.current)return;const Q=M.columns.slice(0,M.columns.length-1);if(M.end)U.current.style.left="0px";else{const z=w();if(!z)return;U.current.style.left=z.offsetLeft-ke.current+"px",he()}$({...M,columns:Q})},[$]),Fe=t.useCallback(M=>{const Q=M.columns.slice(0,M.columns.length-1);W({...M,columns:Q})},[$]),dt=t.useCallback(M=>{const z=(se.current&&se.current.ownerDocument?se.current.ownerDocument:document).elementFromPoint(M.clientX,M.clientY),oe=se.current;if(!z||!z.parentElement||!oe)return;const le=oe.parentElement,re=oe.firstElementChild;if(!le||!re)return;const ve=z.getAttribute($e);if(ve){const wa=oe.offsetTop,va=oe.offsetLeft,Ta=le.offsetTop,ba=le.offsetLeft,Sa=re.scrollTop,Ia=re.scrollLeft;G.current=va+ba,K.current=wa+Ta,ye.current=M.clientX-G.current+Ia,C.current=M.clientY-K.current+Sa,ue.current=z.parentElement.getAttribute(qe),Ee.current=ve}},[]),Re=t.useCallback(M=>{const Q=se.current;if(!Q)return;const z=Q.firstElementChild;if(!z)return;const oe=z.scrollTop,le=z.scrollLeft,re=M.clientX-G.current+le,ve=M.clientY-K.current+oe;Math.abs(ye.current-re)<10&&Math.abs(C.current-ve)<10||Me({startX:ye.current,startY:C.current,endX:re,endY:ve})},[]),Ea=t.useCallback(M=>{const z=(se.current&&se.current.ownerDocument?se.current.ownerDocument:document).elementFromPoint(M.clientX,M.clientY);if(!z||!z.parentElement)return;const oe=z.parentElement.getAttribute(qe),le=z.getAttribute($e);if(le&&oe!==ue.current&&_){let re;Ee.current==="start"?re=le==="start"?3:2:re=le==="start"?1:0,_({fromId:ue.current,toId:oe,type:re})}ye.current=0,C.current=0,G.current=0,K.current=0,ue.current=null,Ee.current=null,Me(null)},[_,Me]);return t.createElement(Cn,{tasksStore:[it,ct],timelineWidth:Ie,dependencyDrag:{isEnabled:!!_,draggedId:ue.current,onDependencyHandlePress:dt,onDependencyHandleDrag:Re,onDependencyHandleRelease:Ea}},t.createElement("div",{className:"k-gantt-content",ref:se,style:{height:`calc(100% - ${q}px)`}},t.createElement(Ht,{treelistId:H.current,ref:B,extendedColumns:rt,columnsMap:lt,dataItemKey:S.id,data:x,idPrefix:De.current,navigatable:p,expandField:S.isExpanded,subItemsField:S.children,editField:S.isInEdit,selectedField:S.isSelected,onDataStateChange:F,onSortChange:A,onFilterChange:N,onExpandChange:R,onRowClick:V,onRowDoubleClick:T,onRowContextMenu:b,onColumnResize:Ne,onColumnReorder:Fe,onColumnMenuFilterChange:O,onKeyDown:X,onSelectionChange:E,onHeaderSelectionChange:P,tableProps:{style:{width:st},className:"k-table k-table-md k-table-layout-fixed"},noRecords:l,rowHeight:Y,resizable:i,reorderable:g,sortable:d,sort:m,filter:c,columnMenuFilter:f,columnMenu:k,row:D,selectable:v,afterContent:t.createElement(t.Fragment,null,t.createElement("svg",{className:"k-gantt-dependencies-svg",ref:U,style:{left:0,top:0}},L.map(M=>t.createElement(Dn,{key:h.getter(ne.id)(M),dependency:M}))),t.createElement("svg",{className:"k-gantt-dependencies-svg",style:{left:0,top:0,zIndex:3}},ce&&t.createElement("polyline",{points:`${ce.startX},${ce.startY} ${ce.endX},${ce.endY}`})),x&&x.length?ot:null)})))});He.displayName="KendoReactGanttBaseView";const ft="gantt.weekViewTitle",pt="gantt.dayViewTitle",Ct="gantt.monthViewTitle",kt="gantt.yearViewTitle",Dt="gantt.filterClearButton",Ye="gantt.filterEqOperator",Ze="gantt.filterNotEqOperator",Xe="gantt.filterIsNullOperator",je="gantt.filterIsNotNullOperator",yn="gantt.filterIsEmptyOperator",En="gantt.filterIsNotEmptyOperator",wn="gantt.filterStartsWithOperator",vn="gantt.filterContainsOperator",Tn="gantt.filterNotContainsOperator",bn="gantt.filterEndsWithOperator",Sn="gantt.filterGteOperator",In="gantt.filterGtOperator",Rn="gantt.filterLteOperator",xn="gantt.filterLtOperator",Mn="gantt.filterIsTrue",Nn="gantt.filterIsFalse",Fn="gantt.filterBooleanAll",Ln="gantt.filterAfterOrEqualOperator",Vn="gantt.filterAfterOperator",An="gantt.filterBeforeOperator",Gn="gantt.filterBeforeOrEqualOperator",Co="gantt.noRecords",zn="gantt.editSave",Pt="gantt.editCancel",Ot="gantt.editAdd",Wt="gantt.editRemove",Hn="gantt.editTabGeneral",Pn="gantt.editTabPredecessors",On="gantt.editTabSuccessors",Wn="gantt.editorTitle",_n="gantt.editorTaskTitle",Bn="gantt.editorTaskStart",Kn="gantt.editorTaskEnd",ko="gantt.editorTaskPlannedStart",Do="gantt.editorTaskPlannedEnd",yo="gantt.editorTaskActualStart",Eo="gantt.editorTaskActualEnd",$n="gantt.editorTaskComplete",qn="gantt.editorTaskParent",Un="gantt.editorValidationRequired",Yn="gantt.editorValidationStart",Zn="gantt.editorValidationEnd",Xn="gantt.editorValidationPercentCompleteRange",yt="gantt.editorDependencyTypesFF",jn="gantt.editorDependencyTypesSF",Qn="gantt.editorDependencyTypesFS",Jn="gantt.editorDependencyTypesSS",ea="gantt.addTask",ta="gantt.addChild",na="gantt.addAbove",aa="gantt.addBelow",oa="gantt.viewSelector",_t="gantt.editorDelete",ra="gantt.deleteConfirmation",sa="gantt.deleteDialogTitle",Bt="gantt.editorDependencyNameLabel",Kt="gantt.editorDependencyTypeLabel",ie={[ft]:"Week",[pt]:"Day",[Ct]:"Month",[kt]:"Year",[Dt]:"Clear",[Ye]:"Is equal to",[Ze]:"Is not equal to",[Xe]:"Is null",[je]:"Is not null",[yn]:"Is empty",[En]:"Is not empty",[wn]:"Starts with",[vn]:"Contains",[Tn]:"Does not contain",[bn]:"Ends with",[Sn]:"Is greater than or equal to",[In]:"Is greater than",[Rn]:"Is less than or equal to",[xn]:"Is less than",[Mn]:"Is true",[Nn]:"Is false",[Fn]:"(All)",[Ln]:"Is after or equal to",[Vn]:"Is after",[An]:"Is before",[Gn]:"Is before or equal to",[Co]:"No records available",[zn]:"Save",[Pt]:"Cancel",[Ot]:"Add",[Wt]:"Remove",[Hn]:"General",[Pn]:"Predecessors",[On]:"Successors",[Wn]:"Edit task",[_n]:"Title",[Bn]:"Start",[Kn]:"End",[ko]:"Planned Start Date",[Do]:"Planned End Date",[yo]:"Actual Start Date",[Eo]:"Actual End Date",[$n]:"Complete",[qn]:"Parent",[Un]:"Field is required.",[Yn]:"Start time must be be before End time.",[Zn]:"End time must be after Start time.",[Xn]:"Value should be between 0 and 100.",[yt]:"Finish-Finish",[Qn]:"Finish-Start",[jn]:"Start-Finish",[Jn]:"Start-Start",[ea]:"Add Task",[ta]:"Add Child",[na]:"Add Above",[aa]:"Add Below",[oa]:"View Selector",[_t]:"Delete",[ra]:"Are you sure you want to delete this event?",[sa]:"Delete Event",[Bt]:"Name",[Kt]:"Type"},Pe=t.forwardRef((e,a)=>{const{slotWidth:n=_e.slotWidth,firstSlotRangeRef:r,timelineHeaderCell:s}=e,{timezone:o}=Ge(),l=J.useInternationalization(),i=t.useRef(null),g=t.useRef(null),d=t.useCallback(p=>{g.current&&g.current.scrollIntoView(p)},[]);t.useImperativeHandle(i,()=>({scrollIntoView:d})),t.useImperativeHandle(a,()=>i.current);const m=ze(),c=e.workWeekStart||_e.workWeekStart,f=e.workWeekEnd||_e.workWeekEnd,k=t.useMemo(()=>{const p=rn({workWeekStart:c,workWeekEnd:f}),D=[],v=cn(m,{timezone:o},l);return v.forEach(F=>{const A=ln(F.range,{workDays:p,timezone:o},l);D.push.apply(D,A)}),r&&D[0]&&(r.current=D[0].range),[v,D]},[o,m.start.getTime(),m.end.getTime(),l,c,f]);return t.createElement(He,{ref:g,slotWidth:n,slotLevels:k,timelineHeaderCell:s})}),wo=({intl:e,tasksStart:a,tasksEnd:n,timezone:r})=>{const s=y.ZonedDate.fromLocalDate(a,r),o=y.ZonedDate.fromLocalDate(n,r),l=on(y.firstDayInWeek(y.getDate(s),e.firstDay())),i=Et(y.firstDayInWeek(y.getDate(o),e.firstDay()),tn),g=y.ZonedDate.fromUTCDate(Ce(l),r),d=y.ZonedDate.fromUTCDate(Ce(i),r);return{start:new Date(g.getTime()),end:new Date(d.getTime()),zonedStart:g,zonedEnd:d}},_e={name:"week",dateRange:wo,title:e=>e.toLanguageString(ft,ie[ft]),slotWidth:Ve,workWeekStart:1,workWeekEnd:5,workDayStart:"08:00",workDayEnd:"17:00"};Pe.defaultProps=_e;Pe.propTypes={name:u.string,dateRange:u.oneOfType([u.func,u.object]),title:u.oneOfType([u.string,u.func]),slotWidth:u.number,workWeekStart:u.number,workWeekEnd:u.number,workDayStart:u.string,workDayEnd:u.string};Pe.displayName="KendoReactGanttWeekView";const vo=(e,a,n)=>{const[r,s]=t.useState(a||e),o=t.useCallback((l,i)=>{s(l),n&&n.call(void 0,{...i,value:l})},[n,s]);return[a!==void 0?a:r,o]},la=e=>{const[a,n]=gn(),r=J.useLocalization(),s=t.useMemo(()=>typeof e.view.title=="function"?e.view.title.call(void 0,r):e.view.title,[e.view.title,r]),o=t.useCallback(()=>{e.view.name&&n(e.view.name)},[n,e.view.name]);return t.createElement(te.Button,{role:"button",type:"button",tabIndex:-1,togglable:!0,selected:e.view.name===a,onClick:o},s)};la.displayName="KendoReactGanttViewSelectorItem";const ia=t.forwardRef(()=>{const e=io(),[a,n]=gn(),r=J.useLocalization(),s=l=>r.toLanguageString(l,ie[l]),o=t.useCallback(l=>{n&&(l.preventDefault(),n(l.target.value))},[n]);return t.createElement("div",{className:"k-gantt-views-wrapper"},t.createElement(te.ButtonGroup,{className:"k-gantt-views"},e.map(l=>t.createElement(la,{key:l.props.name,view:l.props}))),t.createElement("select",{value:a,onChange:o,"aria-label":s(oa),className:"k-picker k-picker-solid k-dropdown-list k-dropdown k-views-dropdown k-rounded-md"},e.map(l=>t.createElement("option",{key:l.props.name,value:l.props.name},typeof l.props.title=="function"?l.props.title.call(void 0,r):l.props.title))))});ia.displayName="KendoReactGanttViewSelectorList";const ca=t.forwardRef((e,a)=>{const{className:n,...r}=e,s=t.useRef(null);return t.useImperativeHandle(a,()=>({element:s.current,props:e})),t.createElement(te.ToolbarItem,{ref:o=>{o&&(s.current=o.element)},className:h.classNames("k-gantt-views",n),...r},e.children)});ca.displayName="KendoReactGanttViewSelector";const da=t.forwardRef((e,a)=>{const{className:n,...r}=e,s=t.useRef(null),o=t.useRef(null);t.useImperativeHandle(o,()=>({element:s.current,props:e})),t.useImperativeHandle(a,()=>o.current);const l=t.useMemo(()=>h.classNames("k-gantt-toolbar k-gantt-header",n),[n]);return t.createElement(te.Toolbar,{ref:i=>{i&&(s.current=i.element)},className:l,...r},e.children)});da.displayName="KendoReactGanttToolbar";const Zt={name:"@progress/kendo-react-gantt",productName:"KendoReact",productCodes:["KENDOUIREACT","KENDOUICOMPLETE"],publishDate:0,version:"",licensingDocsUrl:"https://www.telerik.com/kendo-react-ui/components/my-license/"},ua=t.forwardRef((e,a)=>{const n=J.useLocalization(),r=c=>n.toLanguageString(c,ie[c]),s=r(ea),o=r(ta),l=r(na),i=r(aa),g=t.useCallback(c=>{c.syntheticEvent.preventDefault();const f=c.item&&c.item.direction?c.item.direction:"none";e.onClick&&e.onClick({nativeEvent:c.nativeEvent,syntheticEvent:c.syntheticEvent,direction:f})},[e.onClick]),d=t.useCallback(c=>{c.preventDefault(),e.onClick&&e.onClick({nativeEvent:c&&c.nativeEvent,syntheticEvent:c,direction:"none"})},[e.onClick]),m=t.createElement(t.Fragment,null,t.createElement(h.IconWrap,{name:"plus",icon:pe.plusIcon}),s);return e.selectedTask?t.createElement(te.DropDownButton,{className:"k-views-dropdown",onItemClick:g,popupSettings:{popupClass:"k-gantt-toolbar"},textField:"title",items:[{title:o,direction:"child"},{title:l,direction:"above"},{title:i,direction:"below"}],text:m}):t.createElement(te.Button,{onClick:d},m)});ua.displayName="KendoReactGanttAddButton";const Qe=t.forwardRef((e,a)=>{h.validatePackage(Zt);const n=h.shouldShowValidationUI(Zt),{columns:r=Le.columns,taskData:s=Le.taskData,dependencyData:o=Le.dependencyData,style:l,className:i,noRecords:g,timezone:d,rowHeight:m=Le.rowHeight,resizable:c,reorderable:f,sortable:k,sort:p,filter:D,columnMenuFilter:v,columnMenu:F,navigatable:A,toolbar:N,row:O,selectable:R}=e,V=J.useInternationalization(),{fields:T}=t.useMemo(()=>Ka(e.taskModelFields),[e.taskModelFields]),{fields:b}=t.useMemo(()=>$a(e.dependencyModelFields),[e.dependencyModelFields]),$=t.useCallback(ro(T.isExpanded,T.children),[T.isExpanded,T.children]),W=t.useRef(null),_=t.useRef(null),X=t.useRef(null),E=t.useRef(null),P=t.useRef(null),Y=t.useCallback(w=>{const he=h.getter(T.start)(w),we=h.getter(T.end)(w),Ne=h.getter(T.isSelected)(w);(!_.current||he<_.current)&&(_.current=he),(!X.current||we>X.current)&&(X.current=we),Ne&&(E.current=w)},[T.start,T.end]),q=t.useMemo(()=>(_.current=null,X.current=null,E.current=null,fe.flatData(s,$,Y)),[s,$]);(!_.current||!X.current)&&(_.current=new Date($t),X.current=new Date($t));const S=t.Children.toArray(e.children||[t.createElement(Pe,{key:"week",firstSlotRangeRef:P})]),[ne,x]=vo(e.defaultView||S[0].props.name,e.view,e.onViewChange),L=S.find(w=>w.props.name===ne)||S[0],j=typeof L.props.dateRange=="function"?L.props.dateRange.call(void 0,{intl:V,tasksStart:_.current,tasksEnd:X.current,timezone:d}):L.props.dateRange,ae=t.useRef(null),[B,U]=t.useState(0);t.useLayoutEffect(()=>{ae.current&&U(ae.current.element.offsetHeight)},[]);const ke=t.useCallback(w=>{W.current&&W.current.scrollIntoView(w)},[]),De=t.useRef(null),H=t.useRef(null);t.useImperativeHandle(H,()=>({props:e,element:De.current,scrollIntoView:ke})),t.useImperativeHandle(a,()=>H.current);const se=t.useCallback(w=>{e.onDataStateChange&&e.onDataStateChange.call(void 0,{...w,target:H.current})},[e.onDataStateChange]),Se=t.useCallback(w=>{e.onSortChange&&e.onSortChange.call(void 0,{...w,target:H.current})},[e.onSortChange]),xe=t.useCallback(w=>{e.onKeyDown&&e.onKeyDown.call(void 0,{...w,target:H.current})},[e.onKeyDown]),ye=t.useCallback(w=>{e.onSelectionChange&&e.onSelectionChange.call(void 0,{...w,target:H.current})},[e.onSelectionChange]),C=t.useCallback(w=>{e.onHeaderSelectionChange&&e.onHeaderSelectionChange.call(void 0,{...w,target:H.current})},[e.onHeaderSelectionChange]),G=t.useCallback(w=>{e.onFilterChange&&e.onFilterChange.call(void 0,{...w,target:H.current})},[e.onFilterChange]),K=t.useCallback(w=>{e.onColumnMenuFilterChange&&e.onColumnMenuFilterChange.call(void 0,{...w,target:H.current})},[e.onColumnMenuFilterChange]),ue=t.useCallback(w=>{e.onExpandChange&&e.onExpandChange.call(void 0,{...w,target:H.current})},[e.onExpandChange]),Ee=t.useCallback(w=>{e.onAddClick&&e.onAddClick.call(void 0,{...w,target:H.current,selectedDataItem:E.current,slotStart:P.current&&new Date(P.current.start.getTime()),slotEnd:P.current&&new Date(P.current.end.getTime())})},[e.onAddClick]),ce=t.useCallback(w=>{e.onColumnResize&&e.onColumnResize.call(void 0,{...w,target:H.current})},[e.onColumnResize]),Me=t.useCallback(w=>{e.onColumnReorder&&e.onColumnReorder.call(void 0,{...w,target:H.current})},[e.onColumnReorder]),at=t.useCallback(w=>{e.onRowClick&&e.onRowClick.call(void 0,{...w,target:H.current})},[e.onRowClick]),ot=t.useCallback(w=>{e.onRowDoubleClick&&e.onRowDoubleClick.call(void 0,{...w,target:H.current})},[e.onRowClick]),Ie=t.useCallback(w=>{e.onRowContextMenu&&e.onRowContextMenu.call(void 0,{...w,target:H.current})},[e.onRowClick]),rt=t.useCallback(w=>{e.onTaskClick&&e.onTaskClick.call(void 0,{...w,target:H.current})},[e.onTaskClick]),st=t.useCallback(w=>{e.onTaskDoubleClick&&e.onTaskDoubleClick.call(void 0,{...w,target:H.current})},[e.onTaskDoubleClick]),lt=t.useCallback(w=>{e.onTaskContextMenu&&e.onTaskContextMenu.call(void 0,{...w,target:H.current})},[e.onTaskContextMenu]),it=t.useCallback(w=>{e.onTaskRemoveClick&&e.onTaskRemoveClick.call(void 0,{...w,target:H.current})},[e.onTaskRemoveClick]),ct=t.useCallback(w=>{if(e.onDependencyCreate){let he,we;const Ne=h.getter(T.id);for(let Fe=0;Fe<q.length;Fe++){const dt=q[Fe],Re=Ne(dt.dataItem);if(String(Re)===w.fromId&&(he=Re),String(Re)===w.toId&&(we=Re),he&&we)break}e.onDependencyCreate.call(void 0,{fromId:he,toId:we,target:H.current,type:w.type})}},[e.onDependencyCreate,T,q]);return t.createElement(fn,{dateRange:j,taskData:q,dependencyData:o,taskModelFields:T,dependencyModelFields:b,views:S,activeView:[ne,x],rowHeight:m,toolbarHeight:B,props:{columns:r,noRecords:g,timezone:d,resizable:c,reorderable:f,sortable:k,sort:p,filter:D,columnMenuFilter:v,columnMenu:F,navigatable:A,row:O,selectable:R},events:{onDataStateChange:se,onSortChange:Se,onFilterChange:G,onColumnMenuFilterChange:K,onExpandChange:ue,onRowClick:at,onRowDoubleClick:ot,onRowContextMenu:Ie,onColumnResize:ce,onColumnReorder:Me,onDependencyCreate:e.onDependencyCreate&&ct,onKeyDown:xe,onSelectionChange:ye,onHeaderSelectionChange:C},taskEvents:{onTaskClick:rt,onTaskDoubleClick:st,onTaskContextMenu:lt,onTaskRemoveClick:e.onTaskRemoveClick&&it}},t.createElement("div",{ref:De,role:"application",style:l,className:h.classNames("k-gantt",i)},t.createElement(da,{ref:ae},N&&N.addTaskButton?t.createElement(ua,{selectedTask:E.current,onClick:Ee}):null,t.createElement(te.ToolbarSpacer,null),t.createElement(ca,null,t.createElement(ia,null))),L&&t.createElement(L.type,{key:L.props.name,ref:W,...L.props,firstSlotRangeRef:P}),n&&t.createElement(h.WatermarkOverlay,null)))}),Le={taskData:[],dependencyData:[],columns:[],rowHeight:40};Qe.propTypes={taskData:u.array,taskModelFields:u.shape({id:u.string,start:u.string,end:u.string,title:u.string,percentComplete:u.string,parentId:u.string,isRollup:u.string,isExpanded:u.string,children:u.string,isInEdit:u.string}),dependencyData:u.array,dependencyModelFields:u.shape({id:u.string,fromId:u.string,toId:u.string,type:u.string}),columns:u.arrayOf(u.shape({width:u.number,cell:u.any,editCell:u.any,headerCell:u.any,filter:u.any,children:u.any,field:u.string,title:u.string,sortable:u.any,expandable:u.bool,headerSelectionValue:u.bool,format:u.string,headerClassName:u.string,className:u.string,resizable:u.bool,reorderable:u.bool,minResizableWidth:u.number,orderIndex:u.number,columnMenu:u.any})),sort:u.array,filter:u.array,columnMenuFilter:u.array,columnMenu:u.any,style:u.object,className:u.string,children:u.any,timezone:u.string,defaultView:u.string,view:u.string,rowHeight:u.number,navigatable:u.bool,onViewChange:u.func,onDataStateChange:u.func,onSortChange:u.func,onFilterChange:u.func,onExpandChange:u.func,onRowClick:u.func,onColumnResize:u.func,onColumnReorder:u.func};Qe.defaultProps=Le;Qe.displayName="KendoReactGantt";const Je=t.forwardRef((e,a)=>{const{slotWidth:n=be.slotWidth,slotDuration:r=be.slotDuration,firstSlotRangeRef:s,timelineHeaderCell:o}=e,{timezone:l}=Ge(),i=J.useInternationalization(),g=t.useRef(null),d=t.useRef(null),m=t.useCallback(F=>{d.current&&d.current.scrollIntoView(F)},[]);t.useImperativeHandle(g,()=>({scrollIntoView:m})),t.useImperativeHandle(a,()=>g.current);const c=ze(),f=e.workWeekStart||be.workWeekStart,k=e.workWeekEnd||be.workWeekEnd,p=e.workDayStart||be.workDayStart,D=e.workDayEnd||be.workDayEnd,v=t.useMemo(()=>{const F=rn({workWeekStart:f,workWeekEnd:k}),A=[],N=ln(c,{workDays:F,timezone:l},i);return N.forEach(O=>{const R=eo(O.range,{workDayStart:p,workDayEnd:D,timezone:l,slotDuration:r},i);O.span=R.length,A.push.apply(A,R)}),s&&A[0]&&(s.current=A[0].range),[N,A]},[l,c.start.getTime(),c.end.getTime(),i,f,k,p,D]);return t.createElement(He,{ref:d,slotWidth:n,slotLevels:v,timelineHeaderCell:o})}),To=({tasksStart:e,tasksEnd:a,timezone:n})=>{const r=y.ZonedDate.fromLocalDate(e,n),s=y.ZonedDate.fromLocalDate(a,n),o=on(r),l=Et(s),i=y.ZonedDate.fromUTCDate(Ce(o),n),g=y.ZonedDate.fromUTCDate(Ce(l),n);return{start:new Date(i.getTime()),end:new Date(g.getTime()),zonedStart:i,zonedEnd:g}},be={name:"day",dateRange:To,title:e=>e.toLanguageString(pt,ie[pt]),slotWidth:Ve,slotDuration:60,workWeekStart:1,workWeekEnd:5,workDayStart:"08:00",workDayEnd:"17:00"};Je.defaultProps=be;Je.propTypes={name:u.string,dateRange:u.oneOfType([u.func,u.object]),title:u.oneOfType([u.string,u.func]),slotWidth:u.number,slotDuration:u.number,workWeekStart:u.number,workWeekEnd:u.number,workDayStart:u.string,workDayEnd:u.string};Je.displayName="KendoReactGanttDayView";const et=t.forwardRef((e,a)=>{const{slotWidth:n=ma.slotWidth,firstSlotRangeRef:r,timelineHeaderCell:s}=e,{timezone:o}=Ge(),l=J.useInternationalization(),i=t.useRef(null),g=t.useRef(null),d=t.useCallback(f=>{g.current&&g.current.scrollIntoView(f)},[]);t.useImperativeHandle(i,()=>({scrollIntoView:d})),t.useImperativeHandle(a,()=>i.current);const m=ze(),c=t.useMemo(()=>{const f=[],k=dn(m,{timezone:o},l);return k.forEach(p=>{const D=cn(p.range,{timezone:o},l);f.push.apply(f,D)}),r&&f[0]&&(r.current=f[0].range),[k,f]},[o,m.start.getTime(),m.end.getTime(),l]);return t.createElement(He,{ref:g,slotWidth:n,slotLevels:c,timelineHeaderCell:s})}),bo=({tasksStart:e,tasksEnd:a,timezone:n})=>{const r=y.ZonedDate.fromLocalDate(e,n),s=y.ZonedDate.fromLocalDate(a,n),o=y.firstDayOfMonth(y.getDate(r)),l=y.addDays(y.lastDayOfMonth(y.getDate(s)),1),i=y.ZonedDate.fromUTCDate(Ce(o),n),g=y.ZonedDate.fromUTCDate(Ce(l),n);return{start:new Date(i.getTime()),end:new Date(g.getTime()),zonedStart:i,zonedEnd:g}},ma={name:"month",dateRange:bo,title:e=>e.toLanguageString(Ct,ie[Ct]),slotWidth:Ve,workWeekStart:1,workWeekEnd:5,workDayStart:"08:00",workDayEnd:"17:00"};et.defaultProps=ma;et.propTypes={name:u.string,dateRange:u.oneOfType([u.func,u.object]),title:u.oneOfType([u.string,u.func]),slotWidth:u.number,workWeekStart:u.number,workWeekEnd:u.number,workDayStart:u.string,workDayEnd:u.string};et.displayName="GanttMonthView";const tt=t.forwardRef((e,a)=>{const{slotWidth:n=ga.slotWidth,firstSlotRangeRef:r,timelineHeaderCell:s}=e,{timezone:o}=Ge(),l=J.useInternationalization(),i=t.useRef(null),g=t.useRef(null),d=t.useCallback(f=>{g.current&&g.current.scrollIntoView(f)},[]);t.useImperativeHandle(i,()=>({scrollIntoView:d})),t.useImperativeHandle(a,()=>i.current);const m=ze(),c=t.useMemo(()=>{const f=to(m,{timezone:o},l),k=[];return f.forEach(p=>{const D=dn(p.range,{timezone:o},l);k.push.apply(k,D)}),r&&k[0]&&(r.current=k[0].range),[f,k]},[o,m.start.getTime(),m.end.getTime(),l]);return t.createElement(He,{slotWidth:n,slotLevels:c,timelineHeaderCell:s})}),So=({tasksStart:e,tasksEnd:a,timezone:n})=>{const r=y.ZonedDate.fromLocalDate(e,n),s=y.ZonedDate.fromLocalDate(a,n),o=y.firstDayOfMonth(y.firstMonthOfYear(y.getDate(r))),l=y.addDays(y.lastDayOfMonth(y.lastMonthOfYear(y.getDate(s))),1),i=y.ZonedDate.fromUTCDate(Ce(o),n),g=y.ZonedDate.fromUTCDate(Ce(l),n);return{start:new Date(i.getTime()),end:new Date(g.getTime()),zonedStart:i,zonedEnd:g}},ga={name:"year",dateRange:So,title:e=>e.toLanguageString(kt,ie[kt]),slotWidth:Ve};tt.defaultProps=ga;tt.propTypes={name:u.string,dateRange:u.oneOfType([u.func,u.object]),title:u.oneOfType([u.string,u.func]),slotWidth:u.number};tt.displayName="GanttYearView";const Io=[{text:vn,operator:"contains"},{text:Tn,operator:"doesnotcontain"},{text:Ye,operator:"eq"},{text:Ze,operator:"neq"},{text:wn,operator:"startswith"},{text:bn,operator:"endswith"},{text:Xe,operator:"isnull"},{text:je,operator:"isnotnull"},{text:yn,operator:"isempty"},{text:En,operator:"isnotempty"}],Ro=[{text:Ye,operator:"eq"},{text:Ze,operator:"neq"},{text:Sn,operator:"gte"},{text:In,operator:"gt"},{text:Rn,operator:"lte"},{text:xn,operator:"lt"},{text:Xe,operator:"isnull"},{text:je,operator:"isnotnull"}],xo=[{text:Ye,operator:"eq"},{text:Ze,operator:"neq"},{text:Ln,operator:"gte"},{text:Vn,operator:"gt"},{text:An,operator:"lt"},{text:Gn,operator:"lte"},{text:Xe,operator:"isnull"},{text:je,operator:"isnotnull"}],Mo=[{text:Fn,operator:""},{text:Mn,operator:!0},{text:Nn,operator:!1}];function nt(e,a){return{clearButtonTitle:e.toLanguageString(Dt,ie[Dt]),operators:a.map(n=>({text:e.toLanguageString(n.text,ie[n.text]),operator:n.operator}))}}const ha=e=>{const{operators:a,...n}=e;return t.createElement(I.TextFilterCell,{ariaLabel:"text filter",...nt(J.useLocalization(),a||Io),...n})};ha.displayName="KendoReactGanttTextFilter";const fa=e=>{const{operators:a,...n}=e;return t.createElement(I.NumericFilterCell,{ariaLabel:"numeric filter",...nt(J.useLocalization(),a||Ro),...n})};fa.displayName="KendoReactGanttNumericFilter";const pa=e=>{const{operators:a,...n}=e;return t.createElement(I.BooleanFilterCell,{ariaLabel:"boolean filter",...nt(J.useLocalization(),a||Mo),...n})};pa.displayName="KendoReactGanttBooleanFilter";const Ca=e=>{const{operators:a,...n}=e;return t.createElement(I.DateFilterCell,{ariaLabel:"date filter",...nt(J.useLocalization(),a||xo),...n})};Ca.displayName="KendoReactGanttDateFilter";const No=e=>{const{dependencyData:a,dependencyModelFields:n,defaultDataItem:r,fromId:s,toId:o,type:l}=e,i=a.map(f=>({...f})),g=h.setter(n.fromId),d=h.setter(n.toId),m=h.setter(n.type),c=r?{...r}:{};return g(c,s),d(c,o),m(c,l),i.push(c),i},Fo=e=>{const{defaultDataItem:a,selectedDataItem:n,direction:r,taskModelFields:s,dataTree:o,slotStart:l,slotEnd:i}=e,g=Ae(o,s.children,v=>({...v})),d=h.setter(s.start),m=h.setter(s.end),c=h.getter(s.start),f=h.getter(s.end),k=h.setter(s.parentId||""),p=a?{...a}:{},D=c(p)&&f(p);if(!n||r==="none")D||(d(p,l),m(p,i)),s.parentId&&k(p,null),g.unshift(p);else{const v=[{task:{[s.children]:g},childrenIndex:0}],F=h.getter(s.id),A=h.getter(s.children),N=h.setter(s.children),O=F(n);for(;v.length>0;){const R=v[v.length-1],V=R.task,T=F(V),b=A(V);if(T&&T===O)break;b&&b.length&&b.length>R.childrenIndex?(v.push({task:b[R.childrenIndex],childrenIndex:0}),R.childrenIndex++):v.pop()}if(v.length>1){const R=v[v.length-1].task,V=v[v.length-2].childrenIndex,b=v[v.length-2].task,$=A(b);switch(r){case"child":{let W=A(R);W||(W=[],N(R,W)),D||(d(p,new Date(c(R).getTime())),m(p,new Date(f(R).getTime()))),W.push(p),k(p,F(R)),Be(v.splice(1,v.length-1).map(_=>_.task),s);break}case"above":{c(b)&&f(b)&&!D?(d(p,new Date(c(R).getTime())),m(p,new Date(f(R).getTime()))):(d(p,l),m(p,i)),$.splice(V-1,0,p),k(p,F(b)),Be(v.splice(1,v.length-2).map(W=>W.task),s);break}case"below":{c(b)&&f(b)&&!D?(d(p,new Date(c(R).getTime())),m(p,new Date(f(R).getTime()))):(d(p,l),m(p,i)),$.splice(V,0,p),k(p,F(b)),Be(v.splice(1,v.length-2).map(W=>W.task),s);break}}}}return g},Lo=e=>{const{updatedDataItem:a,taskModelFields:n,dataTree:r}=e,s=h.getter(n.id),o=h.getter(n.children),l=s(a);let i;const g=Ae(r,n.children,m=>s(m)===l?(i=m,{...a}):{...m});let d=[{task:{[n.children]:g},childrenIndex:0}];for(;d.length>0;){const m=d[d.length-1],c=m.task,f=s(c),k=o(c);if(f&&f===l)break;k&&k.length&&k.length>m.childrenIndex?(d.push({task:k[m.childrenIndex],childrenIndex:0}),m.childrenIndex++):d.pop()}if(d.length>1){d=d.splice(1,d.length-2);const m=h.getter(n.start),c=h.getter(n.end),f=h.getter(n.percentComplete),k=h.getter(n.parentId||"");if(m(i).getTime()!==m(a).getTime()){ka(d.map(D=>D.task),n);const p=m(a).getTime()-m(i).getTime();zo(o(a),n,p)}if(c(i).getTime()!==c(a).getTime()&&Da(d.map(p=>p.task),n),f(i)!==f(a)&&ya(d.map(p=>p.task),n),n.parentId&&k(i)!==k(a)){let p;return d.length?Ao(d.map(D=>D.task),n,i):p=g.filter(D=>s(D)!==s(a)),Go(p||g,n,a)}}return g},Vo=e=>{const{removedDataItem:a,taskModelFields:n,dataTree:r}=e,s=Ae(r,n.children,d=>({...d}));let o=[{task:{[n.children]:s},childrenIndex:0}];const l=h.getter(n.id),i=h.getter(n.children),g=l(a);for(;o.length>0;){const d=o[o.length-1],m=d.task,c=l(m),f=i(m);if(c&&c===g)break;f&&f.length&&f.length>d.childrenIndex?(o.push({task:f[d.childrenIndex],childrenIndex:0}),d.childrenIndex++):o.pop()}if(o.length>1){const d=o[o.length-2],m=d.task;i(m).splice(d.childrenIndex-1,1),o=o.splice(1,o.length-2),Be(o.map(f=>f.task),n)}return s},Be=(e,a)=>{ka(e,a),Da(e,a),ya(e,a)},Ao=(e,a,n)=>{const r=h.getter(a.children),s=h.setter(a.children);for(let o=e.length-1;o>=0;o--){const l=e[o],i=r(l);if(n.parentId===l.id){const g=i.filter(d=>d.parentId===l.id);s(l,g)}}},Go=(e,a,n)=>{const r=h.getter(a.children),s=h.setter(a.children);return n.parentId===null?[...e,n]:(e=Ae(e,a.children,o=>{if(o.id===n.parentId){const l=r(o)||[];s(o,[...l,n])}return{...o}}),e)},ka=(e,a)=>{if(!e.length)return;const n=h.getter(a.children),r=h.getter(a.start),s=h.setter(a.start);for(let o=e.length-1;o>=0;o--){const l=e[o],i=n(l);if(i&&i.length){const g=i.reduce((d,m)=>Math.min(d,r(m).getTime()),r(i[0]).getTime());s(l,new Date(g))}}},Da=(e,a)=>{if(!e.length)return;const n=h.getter(a.children),r=h.getter(a.end),s=h.setter(a.end);for(let o=e.length-1;o>=0;o--){const l=e[o],i=n(l);if(i&&i.length){const g=i.reduce((d,m)=>Math.max(d,r(m).getTime()),r(i[0]).getTime());s(l,new Date(g))}}},ya=(e,a)=>{if(!e.length)return;const n=h.getter(a.children),r=h.getter(a.percentComplete),s=h.setter(a.percentComplete),o=({avg:l,n:i},g)=>({avg:((r(g)||0)+i*l)/(i+1),n:i+1});for(let l=e.length-1;l>=0;l--){const i=e[l],g=n(i);if(g&&g.length){const d=g.reduce(o,{avg:0,n:0}).avg;s(i,d)}}},zo=(e,a,n)=>{if(!e)return;const r=h.getter(a.children),s=h.getter(a.start),o=h.setter(a.start),l=h.getter(a.end),i=h.setter(a.end),g=e.map(d=>({task:d,childrenIndex:0}));for(;g.length>0;){const d=g[g.length-1],m=d.task,c=r(m);c&&c.length&&c.length>d.childrenIndex?(g.push({task:c[d.childrenIndex],childrenIndex:0}),d.childrenIndex++):(g.pop(),o(m,new Date(s(m).getTime()+n)),i(m,new Date(l(m).getTime()+n)))}},Xt=e=>{const{validationMessage:a,touched:n,label:r,id:s,valid:o,disabled:l,hint:i,type:g,optional:d,...m}=e,c=n&&a,f=!c&&i,k=f?`${s}_hint`:"",p=c?`${s}_error`:"";return t.createElement(ee.FieldWrapper,{className:"k-col-span-full"},t.createElement(de.Label,{editorId:s,editorValid:o,editorDisabled:l,optional:d},r),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(Qt.Input,{valid:o,type:g,id:s,disabled:l,ariaDescribedBy:`${k} ${p}`,...m}),f&&t.createElement(de.Hint,{id:k},i),c&&t.createElement(de.Error,{id:p},a)))},We=e=>{const{validationMessage:a,touched:n,label:r,id:s,valid:o,disabled:l,hint:i,wrapperStyle:g,...d}=e,m=n&&a,c=!m&&i,f=c?`${s}_hint`:"",k=m?`${s}_error`:"",p=r?`${s}_label`:"";return t.createElement(ee.FieldWrapper,{style:g,className:"k-col-span-2"},t.createElement(de.Label,{id:p,editorId:s,editorValid:o,editorDisabled:l},r),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(Ma.DateTimePicker,{ariaLabelledBy:p,ariaDescribedBy:`${f} ${k}`,valid:o,id:s,disabled:l,...d}),c&&t.createElement(de.Hint,{id:f},i),m&&t.createElement(de.Error,{id:k},a)))},jt=e=>{const{validationMessage:a,visited:n,label:r,id:s,valid:o,disabled:l,hint:i,...g}=e,d=n&&a,m=!d&&i,c=m?`${s}_hint`:"",f=d?`${s}_error`:"";return t.createElement(ee.FieldWrapper,null,t.createElement(de.Label,{editorId:s,editorValid:o,editorDisabled:l},r),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(Qt.NumericTextBox,{ariaDescribedBy:`${c} ${f}`,valid:o,id:s,disabled:l,format:"p0",step:.01,...g}),m&&t.createElement(de.Hint,{id:c},i),d&&t.createElement(de.Error,{id:f},a)))},Ho=e=>{const{validationMessage:a,touched:n,label:r,id:s,valid:o,disabled:l,hint:i,idField:g,dataItem:d,...m}=e,c={id:null,title:"-None-",parentId:null},f=[],k=n&&a,p=!k&&i,D=p?`${s}_hint`:"",v=k?`${s}_error`:"",F=t.useCallback(V=>{if(!V||!V.children)return e.data;for(const b of V.children)f.push(b),b.children&&F(b);const T=f.map(b=>b.id);return e.data.filter(b=>!T.includes(b.id))},[e.data]),A=F(d),N=t.useMemo(()=>A.map(V=>{const T=new Date(V.start).toLocaleDateString(),b=new Date(V.end).toLocaleDateString();return{...V,title:`${V.title} (${T}-${b})`}}),[F]),O=t.useMemo(()=>Z.findByFieldValue(N,g,e.value),[N,g,e.value]),R=V=>{V.value.id===null?e.onChange({value:null}):e.onChange({value:V.value[g]})};return t.createElement(ee.FieldWrapper,{className:"k-col-span-full"},t.createElement(de.Label,{editorId:s,editorValid:o,editorDisabled:l},r),t.createElement("div",{className:"k-form-field-wrap"},t.createElement(Z.DropDownList,{textField:"title",ariaDescribedBy:`${D} ${v}`,valid:o,id:s,disabled:l,...m,value:O,data:N,onChange:R,defaultItem:c}),p&&t.createElement(de.Hint,{id:D},i),k&&t.createElement(de.Error,{id:v},a)))},Po=(e,a,n,r)=>{const[s,o]=t.useState(e),l=t.useRef(null),i=c=>{r(a,"fromId",c.target.value.id)},g=()=>{if(n&&!a.uid)return n.id===a.id;if(n&&a.id===null)return n.uid===a.uid},d=t.useMemo(()=>Z.findByFieldValue(e,"id",a.fromId),[e,a.fromId]),m=c=>{const f=Ue.filterBy(e,c.filter);o(f)};return t.createElement("td",{ref:l,className:h.classNames(g()&&"k-selected")},t.createElement(Z.DropDownList,{textField:"title",data:s,value:d,onChange:i,filterable:!0,onFilterChange:m,required:!0}))},Oo=(e,a,n,r)=>{const s=i=>{r(a,"type",i.target.value.type)},o=()=>{if(n&&!a.uid)return n.id===a.id;if(n&&a.id===null)return n.uid===a.uid},l=t.useMemo(()=>Z.findByFieldValue(e,"type",a.type),[e,a.type]);return t.createElement("td",{className:h.classNames(o()&&"k-selected")},t.createElement(Z.DropDownList,{textField:"name",data:e,value:l,onChange:s}))},Wo=e=>{var m;const[a,n]=t.useState([]),r=J.useLocalization(),s=c=>r.toLanguageString(c,ie[c]),o=s(Ot),l=s(Wt),i=s(Bt),g=s(Kt),d=t.useMemo(()=>{const c=e.predecessors.map(f=>{const k=Z.findByFieldValue(e.flatTasks,"id",f.fromId),p=Z.findByFieldValue(e.dependencyTypes,"type",f.type);return{...f,taskTitle:k?k.title:"",typeName:p?p.type:""}});return Ue.orderBy(c,a)},[e.predecessors,e.dependencyTypes,e.flatTasks,a]);return t.createElement(Te.Grid,{data:d,sort:a,sortable:!0,onRowClick:e.onSelectRow,onSortChange:c=>{n(c.sort)},style:{height:"23em"}},t.createElement(Te.GridToolbar,null,t.createElement(te.Button,{icon:"plus",svgIcon:pe.plusIcon,onClick:e.addPredecessorsDependency},o),t.createElement(te.Button,{icon:"minus",svgIcon:pe.minusIcon,onClick:e.deleteDependency,disabled:((m=e.selectedItem)==null?void 0:m.id)===void 0},l)),t.createElement(Te.GridColumn,{field:"taskTitle",title:i,cell:c=>Po(e.flatTasks,c.dataItem,e.selectedItem,e.updateDependency)}),t.createElement(Te.GridColumn,{field:"typeName",title:g,cell:c=>Oo(e.dependencyTypes,c.dataItem,e.selectedItem,e.updateDependency)}))},_o=(e,a,n,r)=>{const[s,o]=t.useState(e),l=m=>{r(a,"toId",m.target.value.id)},i=()=>{if(n&&!a.uid)return n.id===a.id;if(n&&a.id===null)return n.uid===a.uid},g=t.useMemo(()=>Z.findByFieldValue(e,"id",a.toId),[e,a.toId]),d=m=>{const c=Ue.filterBy(e,m.filter);o(c)};return t.createElement("td",{className:h.classNames(i()&&"k-selected")},t.createElement(Z.DropDownList,{textField:"title",data:s,value:g,onChange:l,filterable:!0,onFilterChange:d,required:!0}))},Bo=(e,a,n,r)=>{const s=i=>{r(a,"type",i.target.value.type)},o=()=>{if(n&&!a.uid)return n.id===a.id;if(n&&a.id===null)return n.uid===a.uid},l=t.useMemo(()=>Z.findByFieldValue(e,"type",a.type),[e,a.type]);return t.createElement("td",{className:h.classNames(o()&&"k-selected")},t.createElement(Z.DropDownList,{textField:"name",data:e,value:l,onChange:s}))},Ko=e=>{var m;const[a,n]=t.useState([]),r=J.useLocalization(),s=c=>r.toLanguageString(c,ie[c]),o=s(Ot),l=s(Wt),i=s(Bt),g=s(Kt),d=t.useMemo(()=>{const c=e.successors.map(f=>{const k=Z.findByFieldValue(e.flatTasks,"id",f.toId),p=Z.findByFieldValue(e.dependencyTypes,"type",f.type);return{...f,taskTitle:k?k.title:"",typeName:p?p.type:""}});return Ue.orderBy(c,a)},[e.successors,e.dependencyTypes,e.flatTasks,a]);return t.createElement(Te.Grid,{data:d,sort:a,sortable:!0,onRowClick:e.onSelectRow,onSortChange:c=>{n(c.sort)},style:{height:"23em"}},t.createElement(Te.GridToolbar,null,t.createElement(te.Button,{icon:"plus",svgIcon:pe.plusIcon,onClick:e.addSuccessorsDependency},o),t.createElement(te.Button,{icon:"minus",svgIcon:pe.minusIcon,onClick:e.deleteDependency,disabled:((m=e.selectedItem)==null?void 0:m.id)===void 0},l)),t.createElement(Te.GridColumn,{field:"taskTitle",title:i,cell:c=>_o(e.flatTasks,c.dataItem,e.selectedItem,e.updateDependency)}),t.createElement(Te.GridColumn,{field:"type",title:g,cell:c=>Bo(e.dependencyTypes,c.dataItem,e.selectedItem,e.updateDependency)}))};var me=(e=>(e[e.FF=0]="FF",e[e.FS=1]="FS",e[e.SF=2]="SF",e[e.SS=3]="SS",e))(me||{});const $o=[{type:me.FF},{type:me.FS},{type:me.SF},{type:me.SS}],qo=e=>{const[a,n]=t.useState(0),[r,s]=t.useState(),[o,l]=t.useState([...e.dependencyData||[]]),[i,g]=t.useState([]),d=bt(),m=J.useLocalization(),c=C=>m.toLanguageString(C,ie[C]),f=c(_n),k=c(Bn),p=c(Kn),D=c($n),v=c(qn),F=c(Hn),A=c(Pn),N=c(On),O=c(Un),R=c(Yn),V=c(Zn),T=c(Xn),b=t.useMemo(()=>fe.flatData(e.taskData||[],C=>C.children||[],C=>{const G={title:C[d.title],id:C[d.id],start:C[d.start],end:C[d.end],parentId:null};return d.parentId&&(G.parentId=C[d.parentId]),G}),[e.taskData,d]),$=t.useMemo(()=>b.filter(C=>C.id!==e.dataItem.id),[b,e.dataItem]),W=t.useMemo(()=>o.filter(C=>C.toId===e.dataItem.id),[o,e.dataItem]),_=t.useMemo(()=>o.filter(C=>C.fromId===e.dataItem.id),[o,e.dataItem]),X=t.useMemo(()=>o.filter(C=>C.id===null).map(C=>({id:C.id,fromId:C.fromId,toId:C.toId,type:C.type})),[o]),E=t.useMemo(()=>o.filter(C=>C.id!==null&&C.uid).map(C=>({id:C.id,fromId:C.fromId,toId:C.toId,type:C.type})),[o]),P=()=>{if(r){if(r.id){const C=o.filter(K=>K.id!==r.id);l(C);const G=o.filter(K=>K.id===r.id);g(K=>[...K,...G])}else{const C=o.filter(K=>K.uid!==r.uid);l(C);const G=o.filter(K=>K.uid===r.uid);g(K=>[...K,...G])}s(void 0)}},Y=t.useCallback(C=>C||C===0?void 0:O,[O]),q=t.useCallback(C=>C||C===0?C>=0&&C<=1?void 0:T:O,[O,T]),S=t.useCallback((C,G)=>C&&G(d.end)&&C.getTime()>G(d.end).getTime()?R:void 0,[d,R]),ne=t.useCallback((C,G)=>C&&G(d.start)&&C.getTime()<G(d.start).getTime()?V:void 0,[d,V]),x=t.useMemo(()=>[Y,S],[Y,S]),L=t.useMemo(()=>[Y,ne],[Y,ne]),j=t.useMemo(()=>Z.findByFieldValue(o,"fromId",null)||Z.findByFieldValue(o,"toId",null),[o]),ae=C=>{j||(n(C.selected),s(void 0))},B=C=>{s(C.dataItem)},U=()=>{const C={uid:h.guid(),id:null,fromId:null,toId:e.dataItem.id,type:me.FS};l([...o,C])},ke=()=>{const C={uid:h.guid(),id:null,fromId:e.dataItem.id,toId:null,type:me.FS};l([...o,C])},De=(C,G,K)=>{const ue={...C,uid:C.uid||h.guid(),[G]:K},Ee=o.findIndex(ce=>ce.id&&ce.id===ue.id||ce.uid&&ce.uid===ue.uid);Ee>-1&&(o.splice(Ee,1,ue),l([...o]))},H=t.useMemo(()=>$o.map(C=>{let G;switch(C.type){case me.FF:G=c(yt);break;case me.FS:G=c(Qn);break;case me.SF:G=c(jn);break;case me.SS:G=c(Jn);break;default:G=c(yt);break}return{...C,name:G}}),[c]);t.useEffect(()=>{e.onDependencyCreate&&e.onDependencyCreate.call(void 0,{createdDependencies:X,updatedDependencies:E,deletedDependencies:i})},[X,E,i,e.onDependencyCreate]);const se=e.dependencyData&&e.taskData,Se=t.createElement(ee.FormElement,{style:{width:400},horizontal:!0},t.createElement(ee.Field,{id:`${d.title}_gantteditor`,name:d.title,label:f,component:Xt,validator:Y}),t.createElement(ee.Field,{id:`${d.start}_gantteditor`,name:d.start,label:k,component:We,validator:x}),t.createElement(ee.Field,{id:`${d.end}_gantteditor`,name:d.end,label:p,component:We,validator:L}),t.createElement(ee.Field,{id:`${d.percentComplete}_gantteditor`,name:d.percentComplete,label:D,component:jt,validator:q})),xe=t.createElement(ee.FormElement,{style:{paddingInline:"4px"}},t.createElement("div",{className:"k-form-fieldset"},t.createElement("div",{className:"k-form-layout k-d-grid k-grid-cols-4 k-gap-x-2"},t.createElement(ee.Field,{id:`${d.title}_gantteditor`,name:d.title,label:f,component:Xt,validator:Y}),t.createElement(ee.Field,{id:`${d.start}_gantteditor`,name:d.start,label:k,component:We,validator:x}),t.createElement(ee.Field,{id:`${d.end}_gantteditor`,name:d.end,label:p,component:We,validator:L}),t.createElement(ee.Field,{id:`${d.percentComplete}_gantteditor`,name:d.percentComplete,label:D,component:jt,validator:q}),d.parentId&&t.createElement(ee.Field,{id:`${d.parentId}_gantteditor`,name:d.parentId||"",idField:d.id,label:v,component:Ho,data:$,dataItem:e.dataItem})))),ye=t.createElement(Oe.TabStrip,{selected:a,onSelect:ae},t.createElement(Oe.TabStripTab,{title:F},xe),t.createElement(Oe.TabStripTab,{title:A},t.createElement(Wo,{flatTasks:b,predecessors:W,dependencyTypes:H,selectedItem:r,onSelectRow:B,addPredecessorsDependency:U,deleteDependency:P,updateDependency:De})),t.createElement(Oe.TabStripTab,{title:N},t.createElement(Ko,{flatTasks:b,successors:_,dependencyTypes:H,selectedItem:r,onSelectRow:B,addSuccessorsDependency:ke,deleteDependency:P,updateDependency:De})));return se?ye:Se},Uo=e=>{const{onCancel:a,onDelete:n,onClose:r,onSubmit:s,...o}=e,l=t.useRef(e.dataItem),[i,g]=t.useState({}),d=J.useLocalization(),m=T=>d.toLanguageString(T,ie[T]),c=m(zn),f=m(Pt),k=m(_t),p=m(Wn),D=t.useCallback(T=>{if(a){const b={syntheticEvent:T,nativeEvent:T.nativeEvent,dataItem:e.dataItem};a.call(void 0,b)}},[a,e.dataItem]),v=t.useCallback(T=>{if(n){const b={syntheticEvent:T,nativeEvent:T.nativeEvent,dataItem:e.dataItem};n.call(void 0,b)}},[n,e.dataItem]),F=t.useCallback(({syntheticEvent:T})=>{if(r){const b={syntheticEvent:T,nativeEvent:T.nativeEvent,dataItem:e.dataItem};r.call(void 0,b)}},[r,e.dataItem]),A=t.useCallback((T,b)=>{if(s){const $={dataItem:T,initialDataItem:l.current,syntheticEvent:b,nativeEvent:b&&b.nativeEvent,dependencies:i};s.call(void 0,$)}},[s,i]),N=t.useMemo(()=>Z.findByFieldValue(i.createdDependencies,"fromId",null)||Z.findByFieldValue(i.createdDependencies,"toId",null),[i]),O=t.useMemo(()=>i.createdDependencies&&i.createdDependencies.length&&N===void 0||i.updatedDependencies&&i.updatedDependencies.length||i.deletedDependencies&&i.deletedDependencies.length,[i,N]),R=t.useCallback(T=>{g(T)},[]),V=t.createElement(ee.Form,{initialValues:e.dataItem,onSubmit:A,render:T=>t.createElement(Ke.Window,{title:p,minWidth:90,width:554,modal:!0,height:0,onClose:F},t.createElement(qo,{taskData:e.taskData,dependencyData:e.dependencyData,dataItem:e.dataItem,onDependencyCreate:R}),t.createElement(Ke.WindowActionsBar,{layout:"start"},t.createElement(te.Button,{disabled:!T.allowSubmit&&!O,onClick:T.allowSubmit?T.onSubmit:b=>A(e.dataItem,b),icon:"save",svgIcon:pe.saveIcon,themeColor:"primary"},c),t.createElement(te.Button,{onClick:D,type:"button",icon:"cancel",svgIcon:pe.cancelIcon},f),t.createElement("div",{className:"k-spacer"}),n&&t.createElement(te.Button,{onClick:v,icon:"trash",svgIcon:pe.trashIcon,fillMode:"flat",themeColor:"primary"},k))),...o});return h.canUseDOM?en.createPortal(V,document&&document.body):null},Yo=e=>{const{onClose:a,onCancel:n,onConfirm:r,dataItem:s}=e,o=J.useLocalization(),l=D=>o.toLanguageString(D,ie[D]),i=l(_t),g=l(Pt),d=l(ra),m=l(sa),c=t.useCallback(({syntheticEvent:D})=>{a&&a.call(void 0,{syntheticEvent:D,nativeEvent:D&&D.nativeEvent,dataItem:null})},[a]),f=t.useCallback(D=>{n&&n.call(void 0,{syntheticEvent:D,nativeEvent:D&&D.nativeEvent,dataItem:null})},[n]),k=t.useCallback(D=>{r&&r.call(void 0,{syntheticEvent:D,nativeEvent:D&&D.nativeEvent,dataItem:s})},[r,s]),p=t.createElement(Ke.Dialog,{title:m,onClose:c},d,t.createElement(Ke.DialogActionsBar,{layout:"end"},t.createElement(te.Button,{themeColor:"primary",onClick:k},i),t.createElement(te.Button,{onClick:f},g)));return h.canUseDOM?en.createPortal(p,document&&document.body):null},Zo=fe.TreeListRow;Object.defineProperty(exports,"getSelectedState",{enumerable:!0,get:()=>I.getSelectedState});Object.defineProperty(exports,"getSelectedStateFromKeyDown",{enumerable:!0,get:()=>I.getSelectedStateFromKeyDown});Object.defineProperty(exports,"setSelectedState",{enumerable:!0,get:()=>I.setSelectedState});exports.GANTT_COL_INDEX_ATTRIBUTE=Fa;exports.GANTT_PREVENT_SELECTION_ELEMENT=La;exports.GANTT_ROW_INDEX_ATTRIBUTE=Na;exports.Gantt=Qe;exports.GanttBooleanFilter=pa;exports.GanttDateFilter=Ca;exports.GanttDayView=Je;exports.GanttForm=Uo;exports.GanttMonthView=et;exports.GanttNumericFilter=fa;exports.GanttRemoveDialog=Yo;exports.GanttRow=Zo;exports.GanttTextFilter=ha;exports.GanttWeekView=Pe;exports.GanttYearView=tt;exports.addDependency=No;exports.addTask=Fo;exports.createDataTree=Ba;exports.extendDataItem=_a;exports.filterBy=Wa;exports.mapTree=Ae;exports.orderBy=Oa;exports.removeTask=Vo;exports.updateTask=Lo;