@imj_media/tareas 1.6.0 → 1.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/modules/teams/ui/organisms/TeamsGridSkeleton.d.ts +1 -1
- package/dist/src/modules/templates/components/atoms/tasks/AssignedTeam.d.ts +23 -0
- package/dist/src/modules/templates/components/atoms/tasks/Responsible.d.ts +6 -5
- package/dist/src/modules/templates/components/atoms/tasks/index.d.ts +1 -0
- package/dist/src/modules/templates/hooks/filters/useGetInputFiltersByPath.d.ts +2 -2
- package/dist/src/modules/templates/hooks/useTeamFlowPreview.d.ts +34 -0
- package/dist/tareas.cjs +8 -8
- package/dist/tareas.css +1 -1
- package/dist/tareas.es.js +4575 -4587
- package/package.json +1 -1
package/dist/tareas.cjs
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("react/jsx-runtime"),me=require("@tanstack/react-query"),x=require("@imj_media/ui"),u=require("react"),Ye=require("axios"),Pe=require("qs"),ne=require("@fortawesome/pro-regular-svg-icons"),Os=require("echarts-for-react"),de=require("@fortawesome/pro-solid-svg-icons"),Na=require("react-dom"),Ce=require("@fortawesome/free-solid-svg-icons"),ct=require("date-fns"),Pt=require("date-fns/locale"),Se=require("react-hook-form"),oe=require("@xyflow/react"),Ue=require("zustand"),Tt=require("moment"),ze=require("@fortawesome/pro-duotone-svg-icons");require("@xyflow/react/dist/style.css");const Ls=require("react-pick-color"),Qt=e=>{const a={...e};return delete a.project,delete a["project.id"],a},Xt=e=>{let a={};return Object.entries(e).forEach(([n,s])=>{if(n.includes(".")){let[o,i]=n.split(".");a[o]=a[o]||{},a[o][i]=s}else a[n]=s}),a},Sa=u.createContext({}),Bs=({children:e})=>{const[a,n]=u.useState({}),[s,o]=u.useState({}),[i,r]=u.useState([]),[c,m]=u.useState(""),l=({name:f,value:g})=>{function y(j){return!isNaN(j)&&j!==null&&j!==""?parseFloat(j):null}let w=y(g);o(j=>{let b={...j},_=i==null?void 0:i.find(M=>M.label.toLowerCase().replace(/ /g,"_")===f);return _?b[_.id]=w??g:b[f]=w??g,((_==null?void 0:_.id)??f)==="owner.config"&&(b["project.id"]=null),b})};u.useEffect(()=>{let f=i.map(g=>g.id==="owner.config"?[g.id,"yo_y_mis_equipos"]:g.id==="dependency"?[g.id,"ambas"]:[g.id,null]);o(g=>{const y={search:g==null?void 0:g.search,taskName:g==null?void 0:g.taskName};return f.forEach(([w,j])=>{y[w]=(g==null?void 0:g[w])!==void 0?g==null?void 0:g[w]:j}),y})},[i]);const d=()=>{let f=i.map(g=>g.id==="owner.config"?[g.id,"yo_y_mis_equipos"]:g.id==="dependency"?[g.id,"ambas"]:[g.id,null]);o(Object.fromEntries(f)),n(Xt(Object.fromEntries(f)))},p=f=>({1:"Muy facil",2:"Facil",3:"Media",4:"Dificil",5:"Muy dificil"})[f],h=()=>{let f=Xt(s);f.difficulty&&(f.difficulty=p(f.difficulty)),n(f)};return t.jsx(Sa.Provider,{value:{fields:i,filters:a,path:c,defineFields:r,updateFilters:l,cleanFilters:d,applyFilters:h,initialFilters:s,selectPath:m},children:e})},De=()=>u.useContext(Sa),Ea=u.createContext({}),Rs=({children:e,user:a,url:n,mode:s})=>{const o=s==="prod"?"https://services.imjmedia.com.mx":"https://devobp.imjmedia.com.mx",i=Ye.create({baseURL:n,headers:{Authorization:`Bearer ${a.accessToken}`},paramsSerializer:m=>Pe.stringify(m,{encodeValuesOnly:!0})}),r=()=>o,c=m=>m==="undefined"||m===void 0?"":`${o}${m}`;return t.jsx(Ea.Provider,{value:{tasks_api:i,getOBPUrlApi:r,getImageOBP:c},children:e})},he=()=>u.useContext(Ea),Pa=u.createContext({}),qs=({children:e,user:a,url:n})=>{const s=Ye.create({baseURL:n,headers:{Authorization:`Bearer ${a.accessToken}`},paramsSerializer:o=>Pe.stringify(o,{encodeValuesOnly:!0})});return t.jsx(Pa.Provider,{value:{user:a,tasks_api:s},children:e})},we=()=>u.useContext(Pa),be=e=>{const a=i=>Object.prototype.toString.call(i)==="[object Object]",n=i=>i&&typeof i=="object"&&("source"in i||"target"in i)&&!("attributes"in i),s=i=>i&&typeof i=="object"&&"position"in i&&typeof i.position=="object"&&("x"in i.position||"y"in i.position)&&!("attributes"in i),o=i=>i.attributes?{id:i.id,...i.attributes}:i;if(Array.isArray(e))return e.map(i=>be(i));if(a(e)){if(n(e)){const i={};for(const r in e)i[r]=be(e[r]);return i}if(s(e)){const i={};for(const r in e)i[r]=be(e[r]);return i}Array.isArray(e.data)?e=[...e.data]:a(e.data)?e=o({...e.data}):e.data===null?e=null:e=o(e);for(const i in e)e[i]=be(e[i]);return e}return e},Yt=[{label:"Tipo de dependencia",type:"select",id:"dependency",options:[{id:"con",name:"Con dependencia"},{id:"sin",name:"Sin dependencia"},{id:"ambas",name:"Ambas"}]},{label:"Por campaña",type:"select",id:"project.id",options:[]},{label:"Por responsable",type:"select",id:"owner.config",options:[{id:"yo",name:"Mis tareas"},{id:"yo_y_mis_equipos",name:"Tareas mías y de mis equipos"},{id:"mis_equipos",name:"Tareas de mis equipos"}]},{label:"Por ejecutivo comercial",type:"select",id:"salesman.id",options:[]},{label:"Por dificultad",type:"select",id:"difficulty",options:[{id:1,name:"Muy facil"},{id:2,name:"Facil"},{id:3,name:"Media"},{id:4,name:"Dificil"},{id:5,name:"Muy dificil"}]}],Jt=[{label:"Responsable",type:"select",id:"responsable.responsableType",options:[{id:"yo_y_mis_equipos",name:"Yo y mis equipos"},{id:"mis_equipos",name:"Mis equipos"},{id:"yo",name:"Yo"}]},{label:"Por Ejecutivo",type:"select",id:"ejecutivo",options:[]}],ft=(e,a,n)=>`${e} ${e===1?a:n}`;function zs(e){const a=e??{pausas:0,atrasos:0,vencidos:0};if((a.pausas??0)===0&&(a.atrasos??0)===0&&(a.vencidos??0)===0)return[{label:"Sin alertas",color:"gray",variant:"sin-alertas"}];const n=[];return(a.atrasos??0)>0&&n.push({label:ft(a.atrasos,"atrasada","atrasadas"),color:"danger",variant:"atrasos"}),(a.pausas??0)>0&&n.push({label:ft(a.pausas,"pausada","pausadas"),color:"warning",variant:"pausas"}),(a.vencidos??0)>0&&n.push({label:ft(a.vencidos,"vencida","vencidas"),color:"info",variant:"vencidos"}),n.slice(0,2)}const $s=ne.faLightEmergencyOn,Us={name:$s},Hs=({tags:e})=>{const a=Array.isArray(e)?e:[];return t.jsx("div",{className:"tm-inline-flex tm-min-w-0 tm-max-w-full tm-flex-wrap tm-content-center tm-items-center tm-gap-1 tm-justify-center",children:a.map((n,s)=>t.jsx("div",{className:"tm-min-w-0 tm-max-w-full tm-flex-shrink-0",children:t.jsx(x.Tag,{label:n.label,color:n.color,stroke:!1,truncateLabel:!0,truncateTooltip:!0,infoIcon:n.variant==="atrasos"?Us:void 0})},`${n.variant}-${n.label}-${s}`))})},Ks=(e,a=500)=>{const[n,s]=u.useState(e);return u.useEffect(()=>{const o=setTimeout(()=>{s(e)},a);return()=>{clearTimeout(o)}},[e,a]),n},Gs=async e=>{const a=Pe.stringify({fields:["id","nombre"],sort:["nombre:asc"]},{encodeValuesOnly:!0}),n=await e.get(`/api/equipos?${a}`);return n.data?{data:be(n.data.data)}:{data:[]}},Vs=()=>{const{tasks_api:e}=he();return me.useQuery({queryKey:["teams"],queryFn:()=>Gs(e),staleTime:1e3*60*60*24,select:n=>n.data.map(o=>({label:o.nombre,value:o.id}))})},Ws="/api/listado-progreso",Qs="/api/proyectos/listado-progreso";function Xs(e){return Pe.stringify(e,{encodeValuesOnly:!0,arrayFormat:"repeat"})}function Ys(e){var i,r,c;const a=Number(e.proyecto_id);if(!Number.isFinite(a)||a<=0||!Number.isInteger(a))throw new Error("listado-progreso: proyecto_id debe ser un entero positivo");const n=String(e.fase).trim().toLowerCase();if(n!=="preventa"&&n!=="venta")throw new Error('listado-progreso: fase debe ser "preventa" o "venta"');const s={proyecto_id:a,fase:n};(i=e.status)!=null&&i.length&&(s.status=e.status.map(m=>String(m).trim()).filter(Boolean)),(r=e.types_media)!=null&&r.length&&(s.types_media=e.types_media.map(m=>String(m).trim()).filter(Boolean)),(c=e.locations)!=null&&c.length&&(s.locations=e.locations.map(m=>String(m).trim()));const o=e.search!=null?String(e.search).trim():"";return o&&(s.search=o),e.blocked_only!==void 0&&(s.blocked_only=e.blocked_only===!0||e.blocked_only==="true"?"true":"false"),s}function Zt(e){const a=Array.isArray(e.data)?e.data:[],n=e.grafico,s=e.graficos,o=Array.isArray(n)&&n.length>0?n:Array.isArray(s)?s:[];return{data:a,grafico:o}}async function ea(e,a,n){const{data:s}=await e.get(a,{params:n,paramsSerializer:Xs});return s??{}}async function Js(e,a){var s;const n=Ys(a);try{const o=await ea(e,Ws,n);return Zt(o)}catch(o){if(Ye.isAxiosError(o)&&((s=o.response)==null?void 0:s.status)===404){const i=await ea(e,Qs,n);return Zt(i)}throw o}}function Zs({proyectoId:e,fase:a,enabled:n,filters:s}){const{tasks_api:o}=he(),i=n&&Number.isFinite(e)&&Number.isInteger(e)&&e>0;return me.useQuery({queryKey:["listado-progreso",e,a,s],queryFn:()=>Js(o,{proyecto_id:e,fase:a,...s}),enabled:i,staleTime:3e4})}const en=({campaignName:e,searchValue:a,onSearchChange:n})=>t.jsx("div",{className:"tm-border-b tm-border-light-gray-100 tm-pb-6 tm-pt-6",children:t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-3",children:[t.jsx("h3",{className:"tm-text-[21px] tm-font-semibold tm-leading-tight tm-text-gray-800",children:e||"-"}),t.jsx("div",{className:"tm-w-full sm:tm-w-[260px] md:tm-w-[300px]",children:t.jsx(x.Input,{size:"sm",fullWidth:!0,leftSlot:ne.faSearch,placeholder:"Buscar...",value:a,onValueChange:n,clearable:!0,onClear:()=>n("")})})]})});function tn(e,a){Array.isArray(e)&&a(e.map(String))}function gt({options:e,selected:a,onChange:n,emptyPlaceholder:s,header:o,tagsOverflowPopoverTitle:i,panelSearch:r,panelSearchPlaceholder:c="Buscar…"}){return t.jsx(x.Dropdown,{field:{placeholder:s},items:{options:e},values:{value:a},events:{onValueChange:m=>tn(m,n)},multi:{multiple:!0,selectionSummary:"tags",tagsOverflow:"single-line",tagsOverflowPopoverTitle:i},popover:{fullWidth:!0},list:{listVariant:"search-multi-checkbox",searchMultiCheckbox:{header:o,search:{show:r,placeholder:c},showClearSelection:!1}},menuSearch:{searchable:!1}})}const an=({mediosOptions:e,plazasOptions:a,estadosOptions:n,selectedMedios:s,selectedPlazas:o,selectedEstados:i,onlyDelayed:r,onChangeMedios:c,onChangePlazas:m,onChangeEstados:l,onChangeOnlyDelayed:d})=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-2 tm-mt-5 tm-mb-5",children:t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-3",children:[t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-4 tm-flex-1",children:[t.jsx("div",{className:"tm-w-full sm:tm-w-[280px]",children:t.jsx(gt,{options:e,selected:s,onChange:c,emptyPlaceholder:"Todos los medios",header:{id:"listado-progreso-medios-all",label:"Todos los medios"},tagsOverflowPopoverTitle:"Medios seleccionados",panelSearch:!1})}),t.jsx("div",{className:"tm-w-full sm:tm-w-[280px]",children:t.jsx(gt,{options:a,selected:o,onChange:m,emptyPlaceholder:"Todas las plazas",header:{id:"listado-progreso-plazas-all",label:"Todas las plazas"},tagsOverflowPopoverTitle:"Plazas seleccionadas",panelSearch:!0,panelSearchPlaceholder:"Buscar…"})}),t.jsx("div",{className:"tm-w-full sm:tm-w-[280px]",children:t.jsx(gt,{options:n,selected:i,onChange:l,emptyPlaceholder:"Todos los estados",header:{id:"listado-progreso-estados-all",label:"Todos los estados"},tagsOverflowPopoverTitle:"Estados seleccionados",panelSearch:!1})})]}),t.jsx("div",{className:"tm-flex tm-items-center",children:t.jsx(x.Toggle,{label:"Solo Atrasadas",checked:r,onChange:d})})]})}),At=[{singular:"completada",serieApiName:"completadas",uiLabel:"Completada",chartLegendLabel:"Completadas",tagColor:"success",chartColorHex:"#22C55E"},{singular:"progresada",serieApiName:"progresadas",uiLabel:"En progreso",chartLegendLabel:"En progreso",tagColor:"accent",chartColorHex:"#3658C1"},{singular:"pausada",serieApiName:"pausadas",uiLabel:"Pausada",chartLegendLabel:"Pausadas",tagColor:"warning",chartColorHex:"#EAB308"},{singular:"atrasada",serieApiName:"atrasadas",uiLabel:"Atrasada",chartLegendLabel:"Atrasadas",tagColor:"danger",chartColorHex:"#EF4444"},{singular:"pendiente",serieApiName:"pendientes",uiLabel:"Pendiente",chartLegendLabel:"Pendientes",tagColor:"gray",chartColorHex:"#BABCBF"},{singular:"vencida",serieApiName:"vencidas",uiLabel:"Vencida",chartLegendLabel:"Vencidas",tagColor:"info",chartColorHex:"#0592AA"}],sn=Object.fromEntries(At.map(e=>[e.singular,e])),ta=At.map(e=>e.serieApiName),nn="atrasada";function It(e){return sn[e]}function on(e){var a;return(a=It(e.trim().toLowerCase()))==null?void 0:a.serieApiName}function Aa(e){return e?e.charAt(0).toUpperCase()+e.slice(1):""}function rn(e){const a=It(e);return a?a.uiLabel:Aa(e)}function ln(e,a){const n=(e??"").trim().toLowerCase();if(!n)return[{label:a,color:"gray"}];const s=It(n);return s?[{label:s.uiLabel,color:s.tagColor}]:[{label:Aa(n),color:"gray"}]}function cn(e){var a,n;if(Ye.isAxiosError(e)){const s=(a=e.response)==null?void 0:a.data;if(typeof s=="string"&&s.trim())return s;if(s&&typeof s=="object"&&"message"in s){const i=s.message;if(typeof i=="string")return i}const o=(n=e.response)==null?void 0:n.status;if(o)return`Error del servidor (${o}). Revisa logs del backend o el body de la respuesta.`}return e.message||"No se pudieron cargar los datos de progreso."}function dn(e){if(!e||typeof e!="object")return null;const n=e.event;if(n&&typeof n=="object"){const s=n;if(typeof s.offsetX=="number"&&typeof s.offsetY=="number")return{x:s.offsetX,y:s.offsetY};const o=s.event;if(o&&typeof o.offsetX=="number"&&typeof o.offsetY=="number")return{x:o.offsetX,y:o.offsetY}}return null}function mn(e){if(!e||typeof e!="object")return 0;const a=e.value;return typeof a=="number"?a:Array.isArray(a)&&typeof a[0]=="number"?a[0]:0}function un(e){return(Number.isFinite(e)?e:0).toFixed(0)}const pn=({id:e,listadoProgreso:a,phaseLabel:n,listadoForUi:s})=>{const{isPending:o,isError:i,error:r,isSuccess:c,data:m}=a,[l,d]=u.useState(null),p=s??m,h=u.useMemo(()=>{const w=(p==null?void 0:p.grafico)??[],j=F=>{var R,N;return((N=(R=w.find(D=>D.name===F))==null?void 0:R.data)==null?void 0:N[0])??0},b=At.map(F=>({key:F.serieApiName,label:F.chartLegendLabel,color:F.chartColorHex})),_=b.map(F=>F.label),M={legendLabel:{color:"#6C6E73",fontSize:12,fontWeight:"bold",padding:[0,0,0,20]}};return b.forEach((F,R)=>{M[`legendDot${R}`]={color:F.color,fontSize:20,fontWeight:"bold",padding:[0,0,0,6]}}),{tooltip:{show:!1},grid:{top:"20%",bottom:"20%",left:"7%",right:"3%"},xAxis:{type:"value",max:100,splitLine:{show:!0},axisLine:{show:!1},axisTick:{show:!1}},yAxis:{type:"category",data:[n],axisLine:{show:!1},axisTick:{show:!1},axisLabel:{color:"#6C6E73",fontWeight:"bold",fontSize:12}},legend:{data:_,orient:"horizontal",top:"0%",left:"center",itemGap:30,icon:"none",itemWidth:0,itemHeight:0,formatter:F=>{const R=b.findIndex(N=>N.label===F);return R===-1?F:`{legendLabel|${F}}{legendDot${R}|●}`},textStyle:{rich:M}},series:b.map(F=>({name:F.label,type:"bar",stack:"total",itemStyle:{color:F.color},barWidth:"50%",data:[j(F.key)]}))}},[p==null?void 0:p.grafico,n]),f=u.useCallback(w=>{const j=w;if(j.componentType!=="series")return;const b=dn(w);if(!b)return;const _=mn(w),M=typeof j.seriesName=="string"?j.seriesName:"";d({x:b.x,y:b.y,label:`${un(_)}% ${M}`})},[]),g=u.useCallback(()=>{d(null)},[]),y=u.useMemo(()=>({mouseover:f,mousemove:f,globalout:g}),[f,g]);return t.jsx(x.Accordion,{id:e,title:"Grafico de Tareas",subtitle:"Distribución de tareas por estatus",defaultOpen:!0,children:t.jsxs("div",{className:"tm-min-h-[140px] tm-w-full tm-border tm-rounded-3xl tm-border-gray-50 tm-px-2 tm-py-2",style:{backgroundColor:"#F7F8FA"},children:[o&&t.jsx("h3",{className:"tm-flex tm-h-[140px] tm-items-center tm-justify-center tm-text-xl tm-font-medium tm-text-gray-500",children:"Cargando datos de progreso…"}),i&&r&&t.jsx("div",{className:"tm-flex tm-h-[140px] tm-items-center tm-justify-center tm-px-4 tm-text-center",children:t.jsx("span",{className:"tm-text-sm tm-font-medium tm-text-red-600",children:cn(r)})}),c&&m&&t.jsxs("div",{className:"tm-relative tm-h-[140px] tm-w-full",children:[t.jsx(Os,{option:h,style:{height:"100%",width:"100%"},onEvents:y}),l&&t.jsx("div",{className:"tm-pointer-events-none tm-absolute tm-z-[10]",style:{left:l.x,top:l.y,width:1,height:1,transform:"translate(-50%, -50%)"},"aria-hidden":!0,children:t.jsx(x.InlineTooltip,{isVisible:!0,label:l.label,position:"top"})})]})]})})},Dt="-";function Qe(e){const a=String(e??"").trim();return a.length>0?a:null}function Ke(e){const a=String(e??"").trim();return a.length>0?a:Dt}function fn(e){var i,r,c,m,l,d,p,h,f,g;if(!e)return;const a=(c=(r=(i=e.formats)==null?void 0:i.thumbnail)==null?void 0:r.url)==null?void 0:c.trim(),n=(d=(l=(m=e.formats)==null?void 0:m.small)==null?void 0:l.url)==null?void 0:d.trim(),s=(f=(h=(p=e.formats)==null?void 0:p.medium)==null?void 0:h.url)==null?void 0:f.trim(),o=(g=e.url)==null?void 0:g.trim();return a||n||s||o||void 0}function gn(e){if(!e)return!1;if(e.startsWith("data:")||e.startsWith("blob:"))return!0;try{const a=new URL(e);return a.protocol==="http:"||a.protocol==="https:"}catch{return!1}}function Ft(e,a){const n=(e.nombre??"").trim()||Dt,s=fn(e.imagen??null);let o;if(s){const r=s.startsWith("http")||s.startsWith("data:")||s.startsWith("blob:")?s:a(s);gn(r)&&(o=r)}const i=n.slice(0,1);return{name:n,src:o,letter:i}}function hn(e){return{tarea:Ke(e.tarea),categoria:Ke(e.categoria),nota:Ke(e.nota),clave:Ke(e.clave),tipo_medio:Ke(e.tipo_medio),ubicacion:Ke(e.ubicacion)}}function xn(e){return ln(e,Dt)}const Ia=4,aa=Ia-1,bn=120,yn=-8,sa=8;function jn(e){return e.length<=Ia?{visible:e,overflow:[]}:{visible:e.slice(0,aa),overflow:e.slice(aa)}}const tt="tm-h-8 tm-w-8 tm-min-h-[32px] tm-min-w-[32px] tm-max-h-[32px] tm-max-w-[32px] tm-shrink-0 tm-border tm-border-default",na="Sin responsable",Da="bottom",Fa="center",wn="tm-flex tm-max-w-xs tm-items-start tm-gap-2 tm-py-1",vn="tm-text-sm tm-font-semibold tm-leading-snug tm-text-gray-900";function oa(e,a){return e<a-1?{marginRight:`${yn}px`}:void 0}function _n({person:e,getImageOBP:a}){const{src:n,letter:s}=Ft(e,a);return n?t.jsx(x.Avatar,{type:"people",src:n,size:"xxs",className:tt}):t.jsx(x.Avatar,{type:"letter",text:s,size:"xxs",className:tt})}function Tn({person:e,getImageOBP:a}){const{name:n,src:s,letter:o}=Ft(e,a);return t.jsxs("div",{className:wn,children:[s?t.jsx(x.Avatar,{type:"people",src:s,size:"xxs",className:`tm-mt-0.5 ${tt}`}):t.jsx(x.Avatar,{type:"letter",text:o,size:"xxs",className:`tm-mt-0.5 ${tt}`}),t.jsx("span",{className:vn,children:n})]})}function Cn({popupId:e,trigger:a,children:n,popupBodyClassName:s="tm-p-3"}){const o=u.useRef(null),i=u.useRef(null),r=u.useRef(null),c=u.useCallback(()=>{r.current!==null&&(window.clearTimeout(r.current),r.current=null)},[]),m=u.useCallback(()=>{var d;c(),(d=i.current)==null||d.open()},[c]),l=u.useCallback(()=>{c(),r.current=window.setTimeout(()=>{var d;(d=i.current)==null||d.close(),r.current=null},bn)},[c]);return u.useEffect(()=>()=>c(),[c]),t.jsxs("div",{className:"tm-relative tm-inline-flex tm-shrink-0",children:[t.jsx("span",{ref:o,className:"tm-inline-flex tm-cursor-default",onMouseEnter:m,onMouseLeave:l,children:a}),t.jsx(x.Popup,{ref:i,popupId:e,triggerRef:o,closeOnClick:!1,position:"bottom-center",children:t.jsx("div",{className:s,onMouseEnter:m,onMouseLeave:l,children:n})})]})}function Nn(){return t.jsx(x.Tooltip,{label:na,position:Da,alignment:Fa,preserveLayout:!0,children:t.jsx("span",{className:"tm-inline-flex tm-shrink-0",role:"img","aria-label":na,children:t.jsx(x.Avatar,{type:"people",size:"xxs",className:tt,alt:""})})})}function Sn({person:e,getImageOBP:a}){const{name:n}=Ft(e,a);return t.jsx(x.Tooltip,{label:n,position:Da,alignment:Fa,preserveLayout:!0,children:t.jsx("span",{className:"tm-inline-flex tm-shrink-0",children:t.jsx(_n,{person:e,getImageOBP:a})})})}function En({overflow:e,getImageOBP:a,popupId:n}){return t.jsx(Cn,{popupId:n,popupBodyClassName:"tm-max-h-64 tm-overflow-y-auto tm-p-3",trigger:t.jsxs("span",{className:"tm-inline-flex tm-h-8 tm-w-8 tm-min-h-[32px] tm-min-w-[32px] tm-max-h-[32px] tm-max-w-[32px] tm-cursor-default tm-items-center tm-justify-center tm-rounded-control-pill tm-border tm-border-default tm-bg-fill-brand tm-text-xs tm-font-normal tm-leading-none tm-tracking-[0.5px] tm-text-on-color",children:["+",e.length]}),children:e.map((s,o)=>t.jsx(Tn,{person:s,getImageOBP:a},s.id!=null?`${s.id}-${o}`:o))})}const Pn=({responsables:e,getImageOBP:a,rowId:n})=>{const s=Array.isArray(e)?e:[];if(s.length===0)return t.jsx("div",{className:"tm-flex tm-min-w-0 tm-items-center",style:{paddingRight:`${sa}px`},children:t.jsx(Nn,{})});const{visible:o,overflow:i}=jn(s),r=o.length+(i.length>0?1:0);return t.jsxs("div",{className:"tm-flex tm-min-w-0 tm-items-center",style:{paddingRight:`${sa}px`},children:[o.map((c,m)=>{const l=c.id!=null?`r-${c.id}-${m}`:`r-${n}-${m}`;return t.jsx("div",{className:"tm-shrink-0",style:oa(m,r),children:t.jsx(Sn,{person:c,getImageOBP:a})},l)}),i.length>0?t.jsx("div",{className:"tm-shrink-0",style:oa(r-1,r),children:t.jsx(En,{overflow:i,getImageOBP:a,popupId:`listado-progreso-${n}-more`})}):null]})},An={name:de.faCircleSmall};function In({tags:e}){const a=Array.isArray(e)?e:[];return t.jsx("div",{className:"tm-inline-flex tm-min-w-0 tm-max-w-full tm-flex-wrap tm-content-start tm-items-center tm-gap-1",children:a.map((n,s)=>t.jsx("div",{className:"tm-min-w-0 tm-max-w-full tm-flex-shrink-0",children:t.jsx(x.Tag,{label:n.label,color:n.color,stroke:!1,truncateLabel:!0,truncateTooltip:!0,infoIcon:An})},`${n.label}-${s}`))})}const Dn=({listadoProgreso:e,listadoForUi:a,hideClaveColumn:n=!1})=>{var m,l;const{getImageOBP:s}=he(),o=u.useMemo(()=>{const d=[{id:"responsables",header:"Responsable",accessor:p=>p.responsables,width:140,minWidth:100,sortable:!1,filterable:!1,resizable:!1,render:(p,h)=>t.jsx(Pn,{responsables:h.responsables,getImageOBP:s,rowId:h.id})},{id:"tarea",header:"Tarea",accessor:"tarea",width:100,minWidth:90,sortable:!1,filterable:!1,resizable:!1},{id:"categoria",header:"Categoría",accessor:"categoria",width:110,minWidth:90,sortable:!1,filterable:!1,resizable:!1,contentAlign:"center"},{id:"estado",header:"Estado",accessor:p=>xn(p.estado),contentAlign:"center",width:110,minWidth:90,sortable:!1,filterable:!1,resizable:!1,render:p=>t.jsx(In,{tags:Array.isArray(p)?p:[]})},{id:"nota",header:"Notas",accessor:"nota",width:100,minWidth:90,sortable:!1,filterable:!1,resizable:!1},{id:"tipo_medio",header:"Grupo medio",accessor:"tipo_medio",width:130,minWidth:110,sortable:!1,filterable:!1,resizable:!1},{id:"ubicacion",header:"Ubicación",accessor:"ubicacion",width:120,minWidth:100,sortable:!1,filterable:!1,resizable:!1}];return n||d.splice(5,0,{id:"clave",header:"Código / Ruta",accessor:"clave",width:130,minWidth:100,sortable:!1,filterable:!1,resizable:!1,contentAlign:"center"}),d},[s,n]),i=u.useMemo(()=>{var p;const d=(a==null?void 0:a.data)??((p=e.data)==null?void 0:p.data);return Array.isArray(d)?d.map(h=>({...h,id:h.id,...hn(h)})):[]},[a==null?void 0:a.data,(m=e.data)==null?void 0:m.data]),r=e.isPending||e.isFetching&&i.length===0&&!e.isError,c=u.useMemo(()=>{var h,f;const d=(h=e.data)==null?void 0:h.data,p=Array.isArray(d)?d.length:0;if(e.isError)return{type:"empty",icon:ne.faBan,title:"No se pudo cargar el listado",description:((f=e.error)==null?void 0:f.message)??"Revisa la conexión o vuelve a intentar."};if(e.isSuccess){if(p===0&&i.length===0)return{type:"empty",icon:ne.faBan,title:"Esta campaña aún no tiene tareas",description:"Cuando asignes tareas a medios, aparecerán aquí con su estado y responsables."};if(p>0&&i.length===0)return{type:"no-filters",icon:ne.faBan,title:"No hay nada aquí...",description:"No hay tareas que coincidan con los filtros seleccionados."}}return{type:"empty",icon:ne.faBan,title:"No hay nada aquí..."}},[e.isError,e.isSuccess,e.error,(l=e.data)==null?void 0:l.data,i.length]);return t.jsx(t.Fragment,{children:t.jsx("div",{className:"tm-flex tm-min-h-0 tm-flex-col tm-mt-2 tm-h-[455px] tm-border tm-rounded-3xl tm-border-gray-300",children:t.jsx(x.Table,{columns:o,columnsLockable:!1,rows:i,loading:r,hoverable:!1,bordered:!1,borderable:!1,stickyHeader:!0,empty:c,resizable:!1,expandable:!1,striped:!1,stickyCheckbox:!1})})})},Fn={preventa:"Preventa",venta:"Venta"},Mn=({campaignName:e,phase:a,search:n,listado:s,filters:o})=>{const i=Fn[a],r=a==="preventa";return t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-4",children:[t.jsx(en,{campaignName:e,searchValue:n.value,onSearchChange:n.onChange}),t.jsx(an,{mediosOptions:o.mediosOptions,plazasOptions:o.plazasOptions,estadosOptions:o.estadosOptions,selectedMedios:o.selectedMedios,selectedPlazas:o.selectedPlazas,selectedEstados:o.selectedEstados,onlyDelayed:o.onlyDelayed,onChangeMedios:o.onChangeMedios,onChangePlazas:o.onChangePlazas,onChangeEstados:o.onChangeEstados,onChangeOnlyDelayed:o.onChangeOnlyDelayed}),t.jsx(pn,{id:`progress-chart-${i}`,listadoProgreso:s.query,phaseLabel:i,listadoForUi:s.dataForUi}),t.jsx(Dn,{listadoProgreso:s.query,listadoForUi:s.dataForUi,hideClaveColumn:r})]})};function kn(e){var i,r,c,m;const a=(i=e.types_media)==null?void 0:i.map(l=>l.trim()).filter(Boolean),n=(r=e.locations)==null?void 0:r.map(l=>l.trim()),s=(c=e.status)==null?void 0:c.map(l=>l.trim().toLowerCase()).filter(Boolean),o=((m=e.search)==null?void 0:m.trim().toLowerCase())||void 0;return{mediosSet:a&&a.length>0?new Set(a):void 0,locationsSet:n&&n.length>0?new Set(n):void 0,statusSet:s&&s.length>0?new Set(s):void 0,searchLower:o,onlyDelayed:e.onlyDelayed===!0}}function On(e,a){const{mediosSet:n,locationsSet:s,statusSet:o,searchLower:i,onlyDelayed:r}=a;if(n){const c=Qe(e.tipo_medio)??"";if(!n.has(c))return!1}if(s){const c=Qe(e.ubicacion)??"";if(!s.has(c))return!1}if(o){const c=(e.estado??"").trim().toLowerCase();if(!o.has(c))return!1}return!(r&&(e.estado??"").trim().toLowerCase()!==nn||i&&![(e.responsables??[]).flatMap(l=>[l.nombre??"",l.role??"",l.email??""]).join(" ").toLowerCase(),e.tarea??"",e.categoria??"",e.estado??"",e.nota??"",e.clave??"",e.tipo_medio??"",e.ubicacion??""].join(" ").toLowerCase().includes(i))}function Ln(e){const a=Object.fromEntries(ta.map(s=>[s,0]));for(const s of e){const o=on(s.estado??"");o&&(a[o]+=1)}const n=e.length;return ta.map(s=>({name:s,data:[n>0?a[s]/n*100:0]}))}function Bn(e,a){const n=kn(a);if(!(n.mediosSet!==void 0||n.locationsSet!==void 0||n.statusSet!==void 0||n.searchLower!==void 0||n.onlyDelayed))return e;const o=e.data.filter(i=>On(i,n));return{data:o,grafico:Ln(o)}}const Ma="__sin_ubicacion__";function ka(e,a){return String(e.label).localeCompare(String(a.label),"es",{sensitivity:"base"})}function ht(e,a,n){const s=new Map;return e.forEach(o=>{const i=a(o);!i||s.has(i)||s.set(i,{label:n?n(i):i,value:i})}),Array.from(s.values()).sort(ka)}function Rn(e){return e.map(a=>a===Ma?"":a)}function qn(e){const a=ht(e,r=>Qe(r.tipo_medio)),n=e.some(r=>Qe(r.ubicacion)===null),s=ht(e,r=>Qe(r.ubicacion)),o=[...n?[{label:"Sin ubicación",value:Ma}]:[],...s].sort(ka),i=ht(e,r=>{var c;return((c=Qe(r.estado))==null?void 0:c.toLowerCase())??null},r=>rn(r));return{medios:a,plazas:o,estados:i}}const zn=({isOpen:e,proyectoId:a,campaignName:n,onClose:s})=>{var k;const[r,c]=u.useState("preventa"),[m,l]=u.useState([]),[d,p]=u.useState([]),[h,f]=u.useState([]),[g,y]=u.useState(!1),[w,j]=u.useState(""),b=Ks(w,400),_=u.useMemo(()=>[{label:"Fase 1 (Preventa)",value:"preventa",leftSlot:ne.faHandHoldingHand},{label:"Fase 2 (Venta)",value:"venta",leftSlot:ne.faHandHoldingCircleDollar}],[]),M=()=>{l([]),p([]),f([]),y(!1)},F=()=>{c("preventa"),M(),j(""),s()},R=q=>{(q==="preventa"||q==="venta")&&(c(q),M(),j(""))},N=u.useMemo(()=>{const q=b.trim();if(q)return q.length>=2?q:void 0},[b,2]),D=Zs({proyectoId:a,fase:r,enabled:e,filters:{}}),v=u.useMemo(()=>({types_media:m.length>0?m:void 0,locations:d.length>0?Rn(d):void 0,status:h.length>0?h:void 0,search:N,onlyDelayed:g}),[m,d,h,N,g]),{medios:U,plazas:K,estados:J}=u.useMemo(()=>{var ee;const q=((ee=D.data)==null?void 0:ee.data)??[];return qn(q)},[(k=D.data)==null?void 0:k.data]),H=u.useMemo(()=>{const q=D.data;return q?Bn(q,v):null},[D.data,v]),O=u.useMemo(()=>({value:w,onChange:j}),[w]),S=u.useMemo(()=>({query:D,dataForUi:H}),[D,H]),B=u.useMemo(()=>({mediosOptions:U,plazasOptions:K,estadosOptions:J,selectedMedios:m,selectedPlazas:d,selectedEstados:h,onlyDelayed:g,onChangeMedios:l,onChangePlazas:p,onChangeEstados:f,onChangeOnlyDelayed:y}),[U,K,J,m,d,h,g]);return t.jsx(x.Modal,{isOpen:e,onClose:F,size:"xl",title:"Progreso",tabs:_,defaultValueTab:"preventa",onChangeTab:R,iconConfig:{icon:ne.faBullhorn},cancelButtonText:"Cerrar",showCancelButton:!0,closeAtCancel:!0,onCancel:F,showSuccessButton:!1,children:t.jsx("div",{style:{backgroundColor:"#F7F8FA",padding:"0px 16px 16px 16px"},children:t.jsx(x.Modal.Body,{children:t.jsx(Mn,{campaignName:n,phase:r,search:O,listado:S,filters:B})})})})},$n=({setPath:e,setProject:a})=>{var B;const[n,s]=u.useState([]),[o,i]=u.useState(!0),[r,c]=u.useState(0),[m,l]=u.useState(10),[d,p]=u.useState(0),[h,f]=u.useState(!1),[g,y]=u.useState(""),[w,j]=u.useState(0),{filters:b,defineFields:_}=De(),{tasks_api:M,getImageOBP:F}=he(),{user:R}=we(),N=u.useCallback(async(k,q)=>{var ee,W,re;try{i(!0);const Z={filters:{search:(b==null?void 0:b.search)??"",responsable:{idUser:R.id,responsableType:(ee=b==null?void 0:b.responsable)==null?void 0:ee.responsableType},ejecutivo:(b==null?void 0:b.ejecutivo)??"",cancelada:{$eq:!1}}},E=await M.get("/api/listado_campanias",{params:{pagination:{page:k,pageSize:q},...Z}}),z=be(E==null?void 0:E.data);s(z),p((re=(W=E==null?void 0:E.data)==null?void 0:W.meta)==null?void 0:re.total)}catch(Z){console.error("Error fetching data en Lista Campaña:",Z)}finally{i(!1)}},[b==null?void 0:b.ejecutivo,(B=b==null?void 0:b.responsable)==null?void 0:B.responsableType,b==null?void 0:b.search,M,R.id]),D=u.useCallback(async()=>{try{const k=await M.get("/api/obtener-comerciales");return[...Jt].map(ee=>(ee.id==="ejecutivo"&&(ee.options=k.data.map(W=>({id:W.nombre,name:W.nombre}))),ee))}catch(k){return console.error("Error fetching salesman data:",k),[...Jt]}},[M]);u.useEffect(()=>{(async()=>{const q=await D();_(q)})()},[_,D]),u.useEffect(()=>{const k=Math.floor(r/m)+1;N(k,m)},[r,m,b,N]);const v=k=>{c(k.first),l(k.rows)},U=Math.floor(r/m)+1,K=u.useMemo(()=>(R.role??"").trim().toLowerCase()==="project manager",[R.role]),J=u.useCallback(k=>{var q;y(((q=k.campania)==null?void 0:q.nombre)??k.nombre??""),j(Number(k.id)),f(!0)},[]),H=u.useMemo(()=>({label:"Ver progreso",leftSlot:ne.faEye,theme:"solid",color:"secondary",tooltip:"Ver progreso",onClick:k=>J(k)}),[J]),O=u.useMemo(()=>{const k=[{id:"nombre",header:"CAMPAÑA",accessor:q=>{var ee;return((ee=q.campania)==null?void 0:ee.nombre)??q.nombre??"-"},width:200,sortable:!1,filterable:!1,resizable:!1},{id:"inicia",header:"FECHA INICIO",accessor:q=>{var ee;return((ee=q.campania)==null?void 0:ee.inicia)??"-"},width:100,sortable:!1,filterable:!1,resizable:!1},{id:"termina",header:"FECHA FIN",accessor:q=>{var ee;return((ee=q.campania)==null?void 0:ee.termina)??"-"},width:100,sortable:!1,filterable:!1,resizable:!1},{id:"responsable",header:"RESPONSABLE",type:"primary",accessor:q=>{var ee,W;return((W=(ee=q.campania)==null?void 0:ee.responsable)==null?void 0:W.nombre)??"-"},width:150,sortable:!1,filterable:!1,resizable:!1,render:(q,ee)=>{var Q,I,A,G,P;const W=(Q=ee.campania)==null?void 0:Q.responsable,re=typeof q=="string"||typeof q=="number"?String(q):(W==null?void 0:W.nombre)??"-",Z=(W==null?void 0:W.role)??"-",E=((G=(A=(I=W==null?void 0:W.imagen)==null?void 0:I.formats)==null?void 0:A.thumbnail)==null?void 0:G.url)||((P=W==null?void 0:W.imagen)==null?void 0:P.url)||"",z=E?F(E):W==null?void 0:W.nombre;return{name:re,...z?{avatar:z}:{},...Z?{subtitle:Z}:{}}}},{id:"alertas",header:"ALERTAS",accessor:q=>zs(q.alertas),width:200,minWidth:100,filterable:!1,sortable:!1,resizable:!1,contentAlign:"center",render:q=>t.jsx(Hs,{tags:Array.isArray(q)?q:[]})}];return K&&k.push({id:"acciones",header:"ACCIONES",type:"button",sortable:!1,filterable:!1,resizable:!1,accessor:()=>H,width:190,minWidth:160}),k},[F,K,H]),S=u.useMemo(()=>(n??[]).map(k=>({...k,id:k.id})),[n]);return t.jsxs("div",{className:"tm-h-full tm-max-h-[100%] tm-overflow-y-auto tm-scrollbar-none",children:[t.jsx(x.Table,{columns:O,columnsLockable:!1,rows:S,loading:o,hoverable:!0,resizable:!1,pagination:{enabled:!0,currentPage:U,pageSize:m,total:d,pageSizes:[5,10,15,20,25,50],onPageChange:k=>c((k-1)*m),onPageSizeChange:k=>v({first:0,rows:k})},onRowClick:k=>{a({id:k.id,project:k.nombre}),e("kanban-campania")},empty:{type:"empty",title:"No hay campañas disponibles"}}),t.jsx(zn,{isOpen:h,proyectoId:w,campaignName:g,onClose:()=>f(!1)})]})},Oa=u.createContext(null),Un=()=>u.useContext(Oa),Hn=({children:e})=>{const a=u.useRef(null),n=u.useRef(null),s=()=>{var o;(o=n.current)==null||o.close()};return t.jsxs(t.Fragment,{children:[t.jsx(x.Button,{ref:a,leftSlot:ne.faFilter,color:"primary",theme:"solid",size:"sm",type:"button",children:"Filtrar"}),t.jsx(x.Popup,{ref:n,triggerRef:a,position:"bottom-right",offset:8,closeOnClickOutside:!0,closeOnEscape:!0,closeOnClick:!1,popoverArrow:!1,allowOverflow:!0,popupId:"tareas-filters-layout-popup",children:t.jsx(Oa.Provider,{value:s,children:e})})]})};function Kn(e,a=300,n={leading:!1,trailing:!0}){let s,o=null;return function(...i){const r=Date.now(),c=n.leading&&!o;clearTimeout(s),c&&e(...i),o=r,s=setTimeout(()=>{n.trailing&&(!n.leading||r-o>=a)&&(e(...i),o=null)},a)}}function Gn(e){return e!=null&&e.length?e.map(a=>({id:a.id,label:a.name,value:a.id})):[]}function Vn({field:e}){const{updateFilters:a,initialFilters:n}=De(),s=u.useMemo(()=>Gn(e.options),[e.options]),o=n==null?void 0:n[e.id],i=o??"";return t.jsx(x.Dropdown,{field:{label:e.label,placeholder:"Selecciona una opción",size:"xs"},items:{options:s,idName:"id"},values:{value:i},menuSearch:{searchable:!0,searchPlaceholder:"Buscar…"},popover:{fullWidth:!0,absolute:!1,closeOnClickOutside:!0,dropdownId:`filter-layout-${e.id}`,popoverZIndex:1300},events:{onValueChange:r=>{a({name:e.id,value:String(r)})}}})}const Wn=()=>{const{fields:e,updateFilters:a,cleanFilters:n,applyFilters:s,initialFilters:o}=De(),i=Un();return t.jsxs("div",{className:"tm-flex tm-min-w-[280px] tm-max-w-[400px] tm-flex-col tm-gap-8 tm-p-8",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-gap-2",children:[t.jsx("p",{className:"tm-m-0 tm-text-heading-h6 tm-font-heading-h6 tm-leading-heading-h6 tm-tracking-heading-h6 tm-text-primary",children:"Filtros"}),t.jsx(x.Button,{color:"secondary",size:"xxs",icon:ne.faXmark,type:"button",onClick:()=>{n(),i==null||i()},children:"Limpiar"})]}),t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-3",children:e==null?void 0:e.map((r,c)=>t.jsx("div",{className:"tm-relative",style:{zIndex:10-c},children:(r==null?void 0:r.type)==="select"?t.jsx("div",{className:"tm-relative tm-z-[10] tm-w-full",children:t.jsx(Vn,{field:r})}):t.jsxs(t.Fragment,{children:[t.jsx("p",{className:"z-[1] tm-text-xl",children:r.label}),t.jsx("input",{className:"tm-h-[30px] tm-w-full tm-rounded-lg tm-p-s tm-shadow-input",type:r.type,value:o==null?void 0:o[r==null?void 0:r.id],name:r.label.toLowerCase().replace(/ /g,"_"),onChange:Kn(m=>{var l,d;return a({name:(l=m==null?void 0:m.target)==null?void 0:l.name,value:(d=m==null?void 0:m.target)==null?void 0:d.value})},1e3)})]})},c))}),t.jsx(x.Button,{color:"primary",size:"xs",type:"button",fullWidth:!0,onClick:()=>{s(),i==null||i()},children:"Filtrar"})]})},Mt=e=>new Intl.DateTimeFormat("es-MX",{month:"long"}).format(e);function Qn(e){const a=["domingo","lunes","martes","miércoles","jueves","viernes","sábado"],n=new Date(e).getDay();return a[n]}const ra=e=>{let a=e||new Date,n=a.getDate(),s=Mt(a.getMonth()).slice(0,3),o=a.getFullYear().toString().slice(-2),i=Qn(a).slice(0,3);return`${i.charAt(0).toUpperCase()+i.slice(1)} ${n} ${s.charAt(0).toUpperCase()+s.slice(1)} ${o}`},kt=(e,a)=>({...e,image:e.image?`${a}${e.image}`:""}),at=e=>{var a,n;return e?(a=e.responsable)!=null&&a.nombre?e.responsable.nombre:(n=e.equipo)!=null&&n.nombre?e.equipo.nombre:null:null};class Xn{static toCampaignTasks(a){var i,r,c,m,l,d,p,h,f,g,y,w,j,b,_;const n=at(a==null?void 0:a.id_t_requerida),s=at(a==null?void 0:a.tarea_padre);let o=[];return a!=null&&a.responsable&&o.push({id:a.responsable.id,name:a.responsable.nombre,image:(l=(m=(c=(r=(i=a.responsable)==null?void 0:i.userOBP)==null?void 0:r.imagen)==null?void 0:c.formats)==null?void 0:m.thumbnail)==null?void 0:l.url,role:((d=a.responsable.userOBP)==null?void 0:d.role)||{id:0,name:""}}),(p=a==null?void 0:a.equipo)!=null&&p.miembros&&a.equipo.miembros.forEach(M=>{var F,R,N,D,v;o!=null&&o.find(U=>U.id===M.idUser.id)||M.idUser&&o.push({id:M.idUser.id,name:M.idUser.nombre,image:(D=(N=(R=(F=M==null?void 0:M.userOBP)==null?void 0:F.imagen)==null?void 0:R.formats)==null?void 0:N.thumbnail)==null?void 0:D.url,role:((v=M.userOBP)==null?void 0:v.role)||{id:0,name:""}})}),{paused:a==null?void 0:a.pausada,isPrincipalTask:(a==null?void 0:a.tarea_principal)??!1,orden:(a==null?void 0:a.orden)??null,id:(a==null?void 0:a.id)??null,task:(a==null?void 0:a.texto_corto)??null,status:(a==null?void 0:a.estatus)??null,difficulty:(a==null?void 0:a.nivel_dificultad)??null,priority:(a==null?void 0:a.prioridad)??0,endDate:new Date((a==null?void 0:a.ffin)??null),startDate:new Date((a==null?void 0:a.finicio)??null),users:o,repeatsToDo:(a==null?void 0:a.repeticiones)??null,repeats:(a==null?void 0:a.repeticiones_realizadas)??null,comments:((h=a==null?void 0:a.comentarios)==null?void 0:h.length)??null,willBePaused:a==null?void 0:a.es_pausable,nameProject:((f=a==null?void 0:a.proyecto)==null?void 0:f.nombre)??null,idProject:((g=a==null?void 0:a.proyecto)==null?void 0:g.id)??null,medioName:(a==null?void 0:a.nombre_medio)??null,statusRequiredTask:((y=a==null?void 0:a.id_t_requerida)==null?void 0:y.estatus)??null,nameRequiredTask:((w=a==null?void 0:a.id_t_requerida)==null?void 0:w.texto_corto)??null,nameRequiredTaskResponsible:n,name_father_required_task:((j=a==null?void 0:a.tarea_padre)==null?void 0:j.texto_corto)??null,name_father_required_task_responsible:s,responsible:((b=a==null?void 0:a.responsable)==null?void 0:b.id)??null,tasks:((_=a==null?void 0:a.tareas)==null?void 0:_.map(M=>({id:M.id,name:M.texto_corto,status:M.estatus})))??null,atraso:(a==null?void 0:a.atraso)??null,categoria:(a==null?void 0:a.categoria)??null,...(a==null?void 0:a.cambio_arte)&&{cambio_arte:a==null?void 0:a.cambio_arte}}}}const Yn=async({filters:e,tasks_api:a,project:n})=>{try{const s=await a.get("/api/listado_tareas_flujo",{params:{...e,project:{id:n},includeAllTasks:!0,populate:"*",cancelada:!1}}),o=be(s.data.tareas),i=Array.isArray(o)?o:[o],r=new Set;if(i.forEach(c=>{var m;(m=c==null?void 0:c.id_t_requerida)!=null&&m.id&&r.add(c.id_t_requerida.id)}),r.size>0){const c=Array.from(r),m=Pe.stringify({filters:{id:{$in:c}},populate:{responsable:{fields:["id","nombre"]},equipo:{fields:["id","nombre"]}}},{encodeValuesOnly:!0});try{const l=await a.get(`/api/tareas?${m}`),d=be(l.data.data||l.data),p=Array.isArray(d)?d:[d],h=new Map(p.map(f=>[f.id,f]));i.forEach(f=>{var g;if((g=f==null?void 0:f.id_t_requerida)!=null&&g.id){const y=h.get(f.id_t_requerida.id);y&&(f.id_t_requerida={...f.id_t_requerida,responsable:y.responsable||null,equipo:y.equipo||null})}})}catch{}}return i.map(Xn.toCampaignTasks)}catch(s){console.log(s)}},La=u.createContext({}),Jn=({children:e,project:a})=>{var j;const[n,s]=u.useState([]),[o,i]=u.useState(!1),[r,c]=u.useState([]),{tasks_api:m}=he(),{filters:l}=De(),{user:d}=we(),[p,h]=u.useState({owner:{user:d.id,config:((j=l==null?void 0:l.owner)==null?void 0:j.config)??"yo_y_mis_equipos"},project:{id:a}});u.useEffect(()=>{var b;if(Object.keys(l).length>0){const _={...l,owner:{user:d.id,config:((b=l==null?void 0:l.owner)==null?void 0:b.config)??"yo_y_mis_equipos"},project:{id:a}};h(_)}},[l,d.id,a]);const f=me.useQuery({queryKey:["tasksProject",p,a],queryFn:()=>{const b={...p,taskName:l==null?void 0:l.taskName,owner:{...p.owner,config:p.owner.config||"yo_y_mis_equipos"}};return Yn({filters:b,project:a,tasks_api:m})},refetchOnWindowFocus:!1}),g=b=>{s(_=>[..._,b])},y=b=>{c(_=>_.includes(b)?_.filter(M=>M!==b):[..._,b])},w=a??null;return t.jsx(La.Provider,{value:{tasksProject:f,selectedTasks:n,projectID:w,openTasks:r,selectTask:g,filtersToSend:p,openTask:y,isRefetching:o,project:a,filters:l,setIsRefetching:i},children:e})},Je=()=>u.useContext(La),Ba=u.createContext(void 0),ia=()=>({selectedTaskIds:[],baseColumn:null,isFullColumnSelected:!1});function Ra({children:e,invalidateAfterBulkSuccess:a}){const[n,s]=u.useState(ia),[o,i]=u.useState(null),[r,c]=u.useState(!1),{selectedTaskIds:m,baseColumn:l,isFullColumnSelected:d}=n,p=m.length>0,h=l!==null,f=u.useCallback(()=>{s(ia()),i(null),c(!1)},[]),g=u.useCallback(()=>{s(b=>({...b,selectedTaskIds:[],isFullColumnSelected:!1}))},[]),y=u.useCallback((b,_)=>{_!=="Completadas"&&s(M=>{if(M.baseColumn&&M.baseColumn!==_)return M;const F=new Set(M.selectedTaskIds);return F.has(b)?(F.delete(b),{selectedTaskIds:[...F],baseColumn:M.baseColumn,isFullColumnSelected:!1}):(F.add(b),{selectedTaskIds:[...F],baseColumn:M.baseColumn??_,isFullColumnSelected:!1})})},[]),w=u.useCallback(async(b,_)=>{if(b!=="Completadas"){c(!0);try{const M=await _(),F=[...new Set(M)];s(R=>R.baseColumn&&R.baseColumn!==b?R:{selectedTaskIds:F,baseColumn:R.baseColumn??b,isFullColumnSelected:F.length>0})}finally{c(!1)}}},[]);u.useEffect(()=>{m.length===0&&l!==null&&f()},[m.length,l,f]);const j=u.useMemo(()=>({selectedTaskIds:m,baseColumn:l,isMultiSelectActive:p,isBulkSessionActive:h,isFullColumnSelected:d,pendingTargetStatus:o,isBulkLoading:r,invalidateAfterBulkSuccess:a,toggleTaskSelection:y,deselectAllSelectedTasks:g,exitBulkSelectionMode:f,selectEntireColumn:w,setPendingTargetStatus:i,setIsBulkLoading:c}),[m,l,p,h,d,o,r,a,y,g,f,w,i,c]);return t.jsx(Ba.Provider,{value:j,children:e})}function Ot(){return u.useContext(Ba)}const Zn=()=>t.jsxs("div",{className:"tm-flex tm-h-[150px] tm-w-full tm-animate-pulse tm-flex-col tm-gap-[50px] tm-rounded-md tm-bg-gray-200 tm-p-4",children:[t.jsxs("div",{className:"tm-flex tm-h-[30px] tm-gap-3",children:[t.jsx("div",{className:"tm-h-full tm-w-[30px] tm-min-w-[30px] tm-rounded-full tm-bg-gray-300"}),t.jsx("div",{className:"tm-h-full tm-w-full tm-bg-gray-300"}),t.jsx("div",{className:"tm-h-full tm-w-[30px] tm-min-w-[30px] tm-rounded-full tm-bg-gray-300"})]}),t.jsxs("div",{className:"tm-flex tm-h-[30px] tm-w-full tm-justify-between tm-gap-[50px]",children:[t.jsx("div",{className:"tm-h-[30px] tm-w-full tm-bg-gray-300"}),t.jsx("div",{className:"tm-h-[30px] tm-w-full tm-bg-gray-300"})]})]});function Ie({trigger:e,children:a,enabled:n=!0,position:s="top",offset:o=8,closeOnClick:i=!1,popoverArrow:r="auto",className:c="tm-inline-flex tm-max-w-full",triggerWrapperClassName:m="tm-inline-flex tm-max-w-full"}){const l=u.useRef(null);return n?t.jsxs("span",{className:c,children:[t.jsx("span",{ref:l,className:m,children:e}),t.jsx(x.Popover,{triggerRef:l,openOnHover:!0,position:s,offset:o,closeOnClick:i,popoverArrow:r,children:a})]}):t.jsx(t.Fragment,{children:e})}const ge={texts:{DEFAULT:"#252525",subtext:"#4f4f4f",placeholder:"#929292"},primary:{regular:"#425CAC"},success:{dark:"#368156",regular:"#43B071"},danger:{dark:"#8C352C",regular:"#C34335"},warning:{dark:"#B4782F",regular:"#D38A31"}},qa=u.createContext(null),eo=({children:e})=>{const[a,n]=u.useState({message:"",type:"success"}),s=(o,i)=>{n({message:o,type:i}),setTimeout(()=>n({message:"",type:"success"}),3e3)};return t.jsx(qa.Provider,{value:{toast:a,showSuccess:o=>s(o,"success"),showError:o=>s(o,"error")},children:e})},Lt=()=>u.useContext(qa);class za{static toAtrasoReasons(a){return{id:a.id,motivo_imj:a.motivo_imj,categoria:a.categoria??null}}}const to=async({tasks_api:e})=>{try{const a=await e.get("/api/motivos",{params:{populate:{categoria:{fields:["id","nombre","tipo"]}},filters:{tipo:{$eq:"atraso"}}}});return be(a.data).map(za.toAtrasoReasons)}catch(a){throw console.log("Error al obtener los motivos de atraso",a),`Error al obtener los motivos de atraso: ${a}`}},$a=({enabled:e=!1}={})=>{const{tasks_api:a}=he(),{user:n}=we(),s=me.useQueryClient(),{showSuccess:o,showError:i}=Lt(),{filters:r,path:c}=De(),{data:m,isLoading:l}=me.useQuery({queryKey:["atraso_reasons"],queryFn:()=>to({tasks_api:a}),staleTime:1e3*60*60*24,enabled:e}),d=async()=>{const M=await a.get("/api/motivos",{params:{filters:{tipo:{$eq:"atraso"}}}});return be(M.data).map(za.toAtrasoReasons)},p=async({taskId:M,motivoId:F,projectID:R})=>{try{return(await a.post("/api/atrasos",{data:{inicio:new Date,fin:null,motivo:F,proyecto:R,tarea:M,creada_por:n==null?void 0:n.id}})).data}catch(N){console.log("error",N)}},h=async M=>{try{return(await a.delete(`/api/atrasos/${M}`)).data}catch(F){console.log("error",F)}},f=async M=>{try{return(await a.put(`/api/atrasos/${M}`,{data:{fin:new Date}})).data}catch(F){console.log("error",F)}},g=async({taskId:M,projectID:F,motivo:R})=>{await j({taskId:M,motivoId:R,projectID:F})},y=async M=>{await b(M)},w=async M=>{await _(M)},{mutateAsync:j}=me.useMutation({mutationFn:p,onSuccess:()=>{o("Atraso registrado correctamente"),c==="kanban-general"&&(s.invalidateQueries({queryKey:["to_do_tasks",r]}),s.invalidateQueries({queryKey:["working_tasks",r]})),c==="kanban-campania"&&s.invalidateQueries({queryKey:["tasksProject"]})},onError:()=>{i("Error al registrar el atraso")}}),{mutateAsync:b}=me.useMutation({mutationFn:h,onSuccess:()=>{o("Atraso eliminado correctamente"),c==="kanban-general"&&(s.invalidateQueries({queryKey:["to_do_tasks"]}),s.invalidateQueries({queryKey:["working_tasks"]}),s.invalidateQueries({queryKey:["done_tasks"]})),c==="kanban-campania"&&s.invalidateQueries({queryKey:["tasksProject"]})},onError:()=>{i("Error al eliminar el atraso")}}),{mutateAsync:_}=me.useMutation({mutationFn:f,onSuccess:()=>{o("Atraso finalizado correctamente")},onError:()=>{i("Error al finalizar el atraso")}});return{atrasoReasons:m,isLoading:l,createAtraso:g,getAtrasoReasons:d,deleteAtraso:y,finalizarAtraso:w}},He=()=>{const{tasks_api:e}=he(),{user:a}=we(),{filters:n,path:s}=De(),o=me.useQueryClient(),{projectID:i}=Je(),{showSuccess:r,showError:c}=Lt(),{finalizarAtraso:m}=$a({enabled:!1}),l=async({id:O})=>(await e.put(`/api/tareas/${O}`,{data:{estatus:1,responsable:a==null?void 0:a.id,updated_by:a==null?void 0:a.id}})).data,d=async({id:O})=>(await e.put(`/api/tareas/${O}`,{data:{estatus:0,responsable:a==null?void 0:a.id,updated_by:a==null?void 0:a.id}})).data,p=async({id:O,idAtraso:S})=>{const B=await e.post("/api/terminarTarea",{id_task:O,ended_at:new Date().toISOString(),id_user:a==null?void 0:a.id});return await m(S),B.data},h=async({id:O,repeats:S})=>(await e.put(`/api/tareas/${O}`,{data:{repeticiones_realizadas:S,updated_by:a==null?void 0:a.id}})).data,f=async({id:O,motiveId:S})=>{try{const B=await e.post("/api/pausarTarea",{taskId:O,userId:a==null?void 0:a.id,motivoId:S});return r("Tarea pausada correctamente"),B.data}catch(B){c("Error al pausar la tarea: "+B)}},g=async({id:O})=>{try{const S=await e.post("/api/reanudarTarea",{taskId:O});return r("Tarea reanudada correctamente"),S.data}catch(S){c("Error al reanudar la tarea: "+S)}},y=async({id:O,idNewResponsible:S,typeOfSelect:B})=>{let k={updated_by:a==null?void 0:a.id};return B==="responsible"&&(k={...k,responsable:S}),B==="team"&&(k={...k,responsable:null,equipo:S}),(await e.put(`/api/tareas/${O}`,{data:k})).data},w=async({id:O,data:S,user:B})=>{try{return(await e.put(`/api/tareas/${O}`,{data:{...S,updated_by:B==null?void 0:B.id}})).data}catch(k){console.error("Error updating the element:",k)}},j=async({id:O})=>{await M({id:O})},b=async({id:O,data:S,user:B})=>{await _({id:O,data:S,user:B})},{mutateAsync:_}=me.useMutation({mutationFn:w,onSuccess:()=>{r("Tarea actualizada correctamente");const O={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[O[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(S){console.error("Error invalidating queries:",S)}},onError:O=>{console.error("Failed to update the task.",O)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]})}}),{mutateAsync:M}=me.useMutation({mutationFn:l,onSuccess:()=>{const O={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[O[s],n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(S){console.error("Error updating the element:",S)}},onError:O=>{console.error("Failed to update the task.",O)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:F}=me.useMutation({mutationFn:p,onSuccess:()=>{const O={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{o.setQueryData([O[s],n],S=>{console.log({oldData:S})}),s==="kanban-general"&&(o.invalidateQueries({queryKey:[O[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(S){console.error("Error invalidating queries:",S)}},onError:O=>{console.error("Failed to update the task.",O)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:R}=me.useMutation({mutationFn:h,onSuccess:()=>{const O={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[O[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(S){console.error("Error invalidating queries:",S)}},onError:O=>{console.error("Failed to update the task.",O)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:N}=me.useMutation({mutationFn:y,onSuccess:()=>{const O={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[O[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(S){console.error("Error invalidating queries:",S)}},onError:O=>{console.error("Failed to reassign the task.",O)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:D}=me.useMutation({mutationFn:d,onSuccess:()=>{const O={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[O[s],n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(S){console.error("Error updating the element:",S)}},onError:O=>{console.error("Failed to update the task.",O)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}});return{updatingTask:b,updateTask:w,startTask:async({id:O})=>{await D({id:O})},startWorking:j,completeTask:async({id:O,idAtraso:S})=>{await F({id:O,idAtraso:S})},reasignResponsible:async({id:O,idNewResponsible:S,typeOfSelect:B})=>{await N({id:O,idNewResponsible:S,typeOfSelect:B})},updateUnitys:async({repeats:O,id:S})=>{await R({repeats:O,id:S})},pauseTask:async({id:O,motiveId:S})=>{console.log({taksId:O,motivoId:S,user:a==null?void 0:a.id})},postPauseTask:f,postReanudeTask:g}};function ao(e,a){const n=a??0;return(e??"")!==""&&n===2&&n===2||!(e??"")}function so(e){const a=e.repeatsToDo;return a==null||a<=0?!1:(e.repeats??0)!==a}function Bt(e){return e.status===2||so(e)?!1:ao(e.nameRequiredTask,e.statusRequiredTask)}const Ae=({imageUrl:e="https://www.uv.unach.mx/assets/img/prueba/directorio/userM.png",alt:a="avatar",size:n="s"})=>{const s={xs:"tm-w-[24px] tm-h-[24px] tm-min-w-[24px] tm-min-h-[24px]",s:"tm-w-[28px] tm-h-[28px] tm-min-w-[28px] tm-min-h-[28px]",m:"tm-w-[32px] tm-h-[32px] tm-min-w-[32px] tm-min-h-[32px]",l:"tm-w-[36px] tm-h-[36px] tm-min-w-[36px] tm-min-h-[36px]",xl:"tm-w-[40px] tm-h-[40px] tm-min-w-[40px] tm-min-h-[40px]",xxl:"tm-w-[44px] tm-h-[44px] tm-min-w-[44px] tm-min-h-[44px]"}[n];return t.jsx("img",{src:e===""?"https://www.uv.unach.mx/assets/img/prueba/directorio/userM.png":e,alt:a??"avatar",className:`${s} tm-bg-containers tm-rounded-full tm-border-2 tm-border-white`})},la=({trigger:e,user:a,showUser:n=!0})=>t.jsx(Ie,{trigger:e,enabled:n,children:t.jsxs("div",{className:"tm-flex tm-h-fit tm-w-fit tm-items-center tm-gap-2 tm-bg-bg-card tm-p-2",children:[t.jsx(Ae,{imageUrl:a.image??"",alt:a.name}),t.jsx("p",{className:"tm-text-sm tm-font-bold tm-text-texts-subtext",children:a.name})]})}),no=({options:e,onselect:a})=>{const[n,s]=u.useState(""),o=[...e].filter(i=>i.name.toLowerCase().includes(n.toLowerCase()));return t.jsxs("div",{className:"tm-h-fit tm-w-full tm-min-w-max",children:[t.jsx(x.Input,{size:"sm",fullWidth:!0,leftSlot:ne.faSearch,placeholder:"Buscar",value:n,onValueChange:s}),t.jsx("div",{className:"tm-border-cards tm-flex tm-max-h-[120px] tm-min-w-max tm-flex-col tm-gap-s tm-overflow-y-auto tm-rounded-lg tm-bg-bg-card tm-p-2 tm-mt-2",children:o.map(i=>t.jsxs("button",{type:"button",onClick:()=>{a(i)},className:"tm-flex tm-min-w-full tm-max-w-[200px] tm-cursor-pointer tm-items-center tm-gap-s hover:tm-bg-primary-light",children:[i.image&&t.jsx(Ae,{imageUrl:i.image,alt:i.name}),t.jsx("p",{className:"tm-min-w-0 tm-text-left tm-text-[14px] tm-truncate tm-py-m tm-font-normal tm-text-texts-subtext",children:i.name})]},i.id??i.name))})]})};class oo{static toDomain(a){return{id:a.id,name:a.nombre,color:a.color}}}const ro=()=>{const{tasks_api:e}=he();return{teams:me.useQuery({queryKey:["teams","all"],queryFn:async()=>{const n=await e.get("/api/equipos");return be(n.data).map(oo.toDomain)},refetchOnWindowFocus:!1})}};class Rt{static toUsers(a){var n,s,o;return{id:a.id,name:a.nombre,image:(o=(s=(n=a.imagen)==null?void 0:n.formats)==null?void 0:s.thumbnail)==null?void 0:o.url,tasksUser:{email:a.tasksUser.email,id:a.tasksUser.id,nombre:a.tasksUser.nombre},role:a.role}}static toUsersV2(a){var n,s,o;return{id:a.id,name:a.nombre,image:(o=(s=(n=a.imagen)==null?void 0:n.formats)==null?void 0:s.thumbnail)==null?void 0:o.url,role:a.role}}static toUsersWithIndex(a){var s,o,i;const n={};for(const r of a)n[r.email]={...r,image:(i=(o=(s=r.imagen)==null?void 0:s.formats)==null?void 0:o.thumbnail)==null?void 0:i.url};return n}}const io=async({tasks_api:e})=>{try{const a=await e.get("/api/getAllOBPusersMembers");return be(a.data).map(Rt.toUsers)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},lo=async({tasks_api:e})=>{try{const a={filters:{$and:[{role:{name:{$in:["Project Manager","Operation Manager","Administrador"]}}},{blocked:{$eq:!1}}]}},n=Pe.stringify(a,{encodeValuesOnly:!0}),s=await e.get(`/api/users?${n}`),i=be(s.data).map(m=>m.email),r=await e.get(`/api/getAllOBPusers?filters[name][$in]=${i}`);return be(r.data).map(Rt.toUsersV2)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},co=async({users:e})=>{try{const a=be(e);return Rt.toUsersWithIndex(a)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},mo=()=>{const{tasks_api:e}=he();return{users:me.useQuery({queryKey:["users"],queryFn:()=>io({tasks_api:e}),staleTime:1e3*60*60*24})}},uo=()=>{const{tasks_api:e}=he();return{users:me.useQuery({queryKey:["allUsers"],queryFn:()=>lo({tasks_api:e}),staleTime:1e3*60*60*24})}},ca="Project Manager",Ua=({users:e,onClick:a,responsible:n,role:s,status:o})=>{const{getOBPUrlApi:i}=he(),r=u.useRef(null),c=u.useRef(null),m=u.useId(),[l,d]=u.useState("team"),{teams:p}=ro(),{users:h}=mo(),f=s===ca||o===0&&s!==ca,g=()=>n?null:e.length>3&&t.jsx(Ie,{position:"top",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:t.jsx("div",{className:"tm-ml-[-8px] tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center tm-rounded-full tm-border-2 tm-border-white tm-bg-[var(--ui-color-bg-fill-brand-default)]",children:t.jsx("p",{className:"tm-text-sm tm-font-bold tm-text-white ",children:`+${e.length-3}`})}),children:t.jsx("div",{className:"tm-border-containers tm-h-fit tm-w-fit tm-rounded-lg tm-bg-bg-card tm-p-2",children:e==null?void 0:e.slice(3).map((b,_)=>t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2 ",children:[t.jsx(Ae,{imageUrl:b.image??"",alt:b.name},_),t.jsx("p",{className:"tm-text-sm tm-font-bold tm-text-texts-subtext",children:b.name})]},_))})}),y=()=>{if(n){const b=e.find(_=>_.id===n);return t.jsx("div",{children:f?t.jsx(x.Tooltip,{label:(b==null?void 0:b.name)??"",position:"top",children:t.jsx(Ae,{imageUrl:b==null?void 0:b.image,alt:b==null?void 0:b.name},n)}):t.jsx(la,{trigger:t.jsx(Ae,{imageUrl:b==null?void 0:b.image,alt:b==null?void 0:b.name},n),user:b,showUser:!0})})}return(e==null?void 0:e.length)>0&&e.slice(0,3).map((b,_)=>t.jsx("div",{className:`${_===0?"":"tm-ml-[-8px]"}`,children:f?t.jsx(x.Tooltip,{label:b.name,position:"top",children:t.jsx(Ae,{imageUrl:b.image,alt:b.name})}):t.jsx(la,{trigger:t.jsx(Ae,{imageUrl:b.image,alt:b.name}),user:b,showUser:!0})},b.id||_))},w=()=>{const b=[{id:"team",label:"Equipo"},{id:"responsible",label:"Responsable"}];return t.jsx("div",{className:"tm-flex tm-w-full tm-justify-center tm-gap-l tm-font-bold tm-text-texts-placeholder",children:b.map((_,M)=>t.jsx("button",{type:"button",className:`tm-w-full tm-border-texts-placeholder tm-text-center tm-text-[10px] ${l===_.id?"tm-text-primary-pastel":""} ${M===b.length-1?"tm-border-r-0":" tm-border-r-2"}`,onClick:()=>d(_.id),children:_.label},_.id))})},j=()=>t.jsxs("div",{className:"tm-border-cards tm-flex tm-max-h-[200px] tm-flex-col tm-gap-m tm-overflow-y-hidden tm-rounded-lg tm-bg-bg-card tm-p-2",style:{boxShadow:"0px 2px 16px 0px rgba(0, 0, 0, 0.25)"},children:[w(),t.jsx(no,{options:l==="team"?((p==null?void 0:p.data)??[]).map(b=>({id:b.id,name:b.name,image:""})):((h==null?void 0:h.data)??[]).map(b=>kt(b,i())),onselect:b=>{var _,M;(_=c.current)==null||_.close(),a((M=b.tasksUser)==null?void 0:M.id,l)}})]});return e.length===0?f?t.jsxs(t.Fragment,{children:[t.jsx("span",{ref:r,className:"tm-inline-flex tm-cursor-pointer tm-items-center",children:t.jsx(x.Icon,{name:ne.faUser,size:"xs",color:"current"})}),t.jsx(x.Popover,{ref:c,triggerRef:r,position:"bottom-left",offset:8,closeOnClick:!1,closeOnClickOutside:!0,closeOnEscape:!0,popoverArrow:!1,popupId:`assign-users-${m}`,children:j()})]}):t.jsx("span",{className:"tm-inline-flex tm-items-center",children:t.jsx(x.Icon,{name:ne.faUser,size:"xs",color:"current"})}):t.jsxs(t.Fragment,{children:[t.jsxs("span",{ref:r,className:"tm-flex tm-cursor-pointer tm-items-center",children:[y(),g()]}),f&&t.jsx(x.Popover,{ref:c,triggerRef:r,position:"bottom-left",offset:8,closeOnClick:!1,closeOnClickOutside:!0,closeOnEscape:!0,popoverArrow:!1,popupId:`assign-users-avatars-${m}`,children:j()})]})},Ha=({priority:e,id:a,withLabel:n=!1})=>{const{updatingTask:s}=He(),o=u.useId().replace(/:/g,""),[i,r]=u.useState(null),{user:c}=we(),[m,l]=u.useState(e);u.useEffect(()=>{l(e)},[e]);const d={0:{title:"Normal",color:ge.primary.regular},1:{title:"Baja",color:ge.success.regular},2:{title:"Media",color:ge.warning.regular},3:{title:"Alta",color:ge.danger.regular}},p={title:"Sin prioridad",color:ge.texts.subtext},f=(()=>{const j=m;if(typeof j!="number"||!Number.isFinite(j))return p;const b=Math.trunc(j);return b<0||b>3?p:d[b]??p})(),g=f.title??"Sin prioridad",y=()=>{if(!i)return null;const j=({priorityTask:b,text:_})=>{var M,F;return t.jsxs("button",{onClick:async()=>{r(null),await s({id:a,data:{prioridad:b},user:c==null?void 0:c.id}),l(b)},className:"tm-flex tm-items-center tm-gap-m tm-px-l tm-py-s hover:tm-bg-primary-light",children:[t.jsx(x.Icon,{name:ne.faFlag,size:"xs",style:{color:(M=d[b??0])==null?void 0:M.color},color:"current"}),t.jsx("p",{className:"tm-text-sm",style:{color:(F=d[b??0])==null?void 0:F.color},children:_})]})};return Na.createPortal(t.jsx("div",{onBlur:()=>{r(null)},id:`${o}-options`,style:{top:`${i.y+5}px`,left:`${i.x+5}px`,zIndex:50},className:`tm-absolute tm-flex tm-h-fit tm-w-max tm-flex-col tm-gap-2 tm-rounded-xl tm-bg-bg-card tm-p-m
|
|
2
|
-
tm-shadow-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("react/jsx-runtime"),de=require("@tanstack/react-query"),g=require("@imj_media/ui"),u=require("react"),Ye=require("axios"),Ce=require("qs"),ne=require("@fortawesome/pro-regular-svg-icons"),Os=require("echarts-for-react"),me=require("@fortawesome/pro-solid-svg-icons"),Sa=require("react-dom"),Ne=require("@fortawesome/free-solid-svg-icons"),ct=require("date-fns"),At=require("date-fns/locale"),Ee=require("react-hook-form"),oe=require("@xyflow/react"),Ue=require("zustand"),Nt=require("moment"),ze=require("@fortawesome/pro-duotone-svg-icons");require("@xyflow/react/dist/style.css");const Bs=require("react-pick-color"),Xt=e=>{const t={...e};return delete t.project,delete t["project.id"],t},Yt=e=>{let t={};return Object.entries(e).forEach(([n,s])=>{if(n.includes(".")){let[o,i]=n.split(".");t[o]=t[o]||{},t[o][i]=s}else t[n]=s}),t},Ea=u.createContext({}),Rs=({children:e})=>{const[t,n]=u.useState({}),[s,o]=u.useState({}),[i,r]=u.useState([]),[l,d]=u.useState(""),c=({name:p,value:h})=>{function y(j){return!isNaN(j)&&j!==null&&j!==""?parseFloat(j):null}let w=y(h);o(j=>{let b={...j},v=i==null?void 0:i.find(M=>M.label.toLowerCase().replace(/ /g,"_")===p);return v?b[v.id]=w??h:b[p]=w??h,((v==null?void 0:v.id)??p)==="owner.config"&&(b["project.id"]=null),b})};u.useEffect(()=>{let p=i.map(h=>h.id==="owner.config"?[h.id,"yo_y_mis_equipos"]:h.id==="dependency"?[h.id,"ambas"]:[h.id,null]);o(h=>{const y={search:h==null?void 0:h.search,taskName:h==null?void 0:h.taskName};return p.forEach(([w,j])=>{y[w]=(h==null?void 0:h[w])!==void 0?h==null?void 0:h[w]:j}),y})},[i]);const m=()=>{let p=i.map(h=>h.id==="owner.config"?[h.id,"yo_y_mis_equipos"]:h.id==="dependency"?[h.id,"ambas"]:[h.id,null]);o(Object.fromEntries(p)),n(Yt(Object.fromEntries(p)))},f=p=>({1:"Muy facil",2:"Facil",3:"Media",4:"Dificil",5:"Muy dificil"})[p],x=()=>{let p=Yt(s);p.difficulty&&(p.difficulty=f(p.difficulty)),n(p)};return a.jsx(Ea.Provider,{value:{fields:i,filters:t,path:l,defineFields:r,updateFilters:c,cleanFilters:m,applyFilters:x,initialFilters:s,selectPath:d},children:e})},De=()=>u.useContext(Ea),Pa=u.createContext({}),qs=({children:e,user:t,url:n,mode:s})=>{const o=s==="prod"?"https://services.imjmedia.com.mx":"https://devobp.imjmedia.com.mx",i=Ye.create({baseURL:n,headers:{Authorization:`Bearer ${t.accessToken}`},paramsSerializer:d=>Ce.stringify(d,{encodeValuesOnly:!0})}),r=()=>o,l=d=>d==="undefined"||d===void 0?"":`${o}${d}`;return a.jsx(Pa.Provider,{value:{tasks_api:i,getOBPUrlApi:r,getImageOBP:l},children:e})},ge=()=>u.useContext(Pa),Aa=u.createContext({}),zs=({children:e,user:t,url:n})=>{const s=Ye.create({baseURL:n,headers:{Authorization:`Bearer ${t.accessToken}`},paramsSerializer:o=>Ce.stringify(o,{encodeValuesOnly:!0})});return a.jsx(Aa.Provider,{value:{user:t,tasks_api:s},children:e})},je=()=>u.useContext(Aa),xe=e=>{const t=i=>Object.prototype.toString.call(i)==="[object Object]",n=i=>i&&typeof i=="object"&&("source"in i||"target"in i)&&!("attributes"in i),s=i=>i&&typeof i=="object"&&"position"in i&&typeof i.position=="object"&&("x"in i.position||"y"in i.position)&&!("attributes"in i),o=i=>i.attributes?{id:i.id,...i.attributes}:i;if(Array.isArray(e))return e.map(i=>xe(i));if(t(e)){if(n(e)){const i={};for(const r in e)i[r]=xe(e[r]);return i}if(s(e)){const i={};for(const r in e)i[r]=xe(e[r]);return i}Array.isArray(e.data)?e=[...e.data]:t(e.data)?e=o({...e.data}):e.data===null?e=null:e=o(e);for(const i in e)e[i]=xe(e[i]);return e}return e},Jt=[{label:"Tipo de dependencia",type:"select",id:"dependency",options:[{id:"con",name:"Con dependencia"},{id:"sin",name:"Sin dependencia"},{id:"ambas",name:"Ambas"}]},{label:"Por campaña",type:"select",id:"project.id",options:[]},{label:"Por responsable",type:"select",id:"owner.config",options:[{id:"yo",name:"Mis tareas"},{id:"yo_y_mis_equipos",name:"Tareas mías y de mis equipos"},{id:"mis_equipos",name:"Tareas de mis equipos"}]},{label:"Por ejecutivo comercial",type:"select",id:"salesman.id",options:[]},{label:"Por dificultad",type:"select",id:"difficulty",options:[{id:1,name:"Muy facil"},{id:2,name:"Facil"},{id:3,name:"Media"},{id:4,name:"Dificil"},{id:5,name:"Muy dificil"}]}],Zt=[{label:"Responsable",type:"select",id:"responsable.responsableType",options:[{id:"yo_y_mis_equipos",name:"Yo y mis equipos"},{id:"mis_equipos",name:"Mis equipos"},{id:"yo",name:"Yo"}]},{label:"Por Ejecutivo",type:"select",id:"ejecutivo",options:[]}],gt=(e,t,n)=>`${e} ${e===1?t:n}`;function $s(e){const t=e??{pausas:0,atrasos:0,vencidos:0};if((t.pausas??0)===0&&(t.atrasos??0)===0&&(t.vencidos??0)===0)return[{label:"Sin alertas",color:"gray",variant:"sin-alertas"}];const n=[];return(t.atrasos??0)>0&&n.push({label:gt(t.atrasos,"atrasada","atrasadas"),color:"danger",variant:"atrasos"}),(t.pausas??0)>0&&n.push({label:gt(t.pausas,"pausada","pausadas"),color:"warning",variant:"pausas"}),(t.vencidos??0)>0&&n.push({label:gt(t.vencidos,"vencida","vencidas"),color:"info",variant:"vencidos"}),n.slice(0,2)}const Us=ne.faLightEmergencyOn,Hs={name:Us},Ks=({tags:e})=>{const t=Array.isArray(e)?e:[];return a.jsx("div",{className:"tm-inline-flex tm-min-w-0 tm-max-w-full tm-flex-wrap tm-content-center tm-items-center tm-gap-1 tm-justify-center",children:t.map((n,s)=>a.jsx("div",{className:"tm-min-w-0 tm-max-w-full tm-flex-shrink-0",children:a.jsx(g.Tag,{label:n.label,color:n.color,stroke:!1,truncateLabel:!0,truncateTooltip:!0,infoIcon:n.variant==="atrasos"?Hs:void 0})},`${n.variant}-${n.label}-${s}`))})},Gs=(e,t=500)=>{const[n,s]=u.useState(e);return u.useEffect(()=>{const o=setTimeout(()=>{s(e)},t);return()=>{clearTimeout(o)}},[e,t]),n},Vs=async e=>{const t=Ce.stringify({fields:["id","nombre"],sort:["nombre:asc"]},{encodeValuesOnly:!0}),n=await e.get(`/api/equipos?${t}`);return n.data?{data:xe(n.data.data)}:{data:[]}},Ia=()=>{const{tasks_api:e}=ge();return de.useQuery({queryKey:["teams"],queryFn:()=>Vs(e),staleTime:1e3*60*60*24,select:n=>n.data.map(o=>({label:o.nombre,value:o.id}))})},Ws="/api/listado-progreso",Qs="/api/proyectos/listado-progreso";function Xs(e){return Ce.stringify(e,{encodeValuesOnly:!0,arrayFormat:"repeat"})}function Ys(e){var i,r,l;const t=Number(e.proyecto_id);if(!Number.isFinite(t)||t<=0||!Number.isInteger(t))throw new Error("listado-progreso: proyecto_id debe ser un entero positivo");const n=String(e.fase).trim().toLowerCase();if(n!=="preventa"&&n!=="venta")throw new Error('listado-progreso: fase debe ser "preventa" o "venta"');const s={proyecto_id:t,fase:n};(i=e.status)!=null&&i.length&&(s.status=e.status.map(d=>String(d).trim()).filter(Boolean)),(r=e.types_media)!=null&&r.length&&(s.types_media=e.types_media.map(d=>String(d).trim()).filter(Boolean)),(l=e.locations)!=null&&l.length&&(s.locations=e.locations.map(d=>String(d).trim()));const o=e.search!=null?String(e.search).trim():"";return o&&(s.search=o),e.blocked_only!==void 0&&(s.blocked_only=e.blocked_only===!0||e.blocked_only==="true"?"true":"false"),s}function ea(e){const t=Array.isArray(e.data)?e.data:[],n=e.grafico,s=e.graficos,o=Array.isArray(n)&&n.length>0?n:Array.isArray(s)?s:[];return{data:t,grafico:o}}async function ta(e,t,n){const{data:s}=await e.get(t,{params:n,paramsSerializer:Xs});return s??{}}async function Js(e,t){var s;const n=Ys(t);try{const o=await ta(e,Ws,n);return ea(o)}catch(o){if(Ye.isAxiosError(o)&&((s=o.response)==null?void 0:s.status)===404){const i=await ta(e,Qs,n);return ea(i)}throw o}}function Zs({proyectoId:e,fase:t,enabled:n,filters:s}){const{tasks_api:o}=ge(),i=n&&Number.isFinite(e)&&Number.isInteger(e)&&e>0;return de.useQuery({queryKey:["listado-progreso",e,t,s],queryFn:()=>Js(o,{proyecto_id:e,fase:t,...s}),enabled:i,staleTime:3e4})}const en=({campaignName:e,searchValue:t,onSearchChange:n})=>a.jsx("div",{className:"tm-border-b tm-border-default tm-pb-6 tm-pt-6",children:a.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-3",children:[a.jsx("h3",{className:"tm-text-[21px] tm-font-semibold tm-leading-tight tm-text-gray-800",children:e||"-"}),a.jsx("div",{className:"tm-w-full sm:tm-w-[260px] md:tm-w-[300px]",children:a.jsx(g.Input,{size:"sm",fullWidth:!0,leftSlot:ne.faSearch,placeholder:"Buscar...",value:t,onValueChange:n,clearable:!0,onClear:()=>n("")})})]})});function tn(e,t){Array.isArray(e)&&t(e.map(String))}function ht({options:e,selected:t,onChange:n,emptyPlaceholder:s,header:o,tagsOverflowPopoverTitle:i,panelSearch:r,panelSearchPlaceholder:l="Buscar…"}){return a.jsx(g.Dropdown,{field:{placeholder:s},items:{options:e},values:{value:t},events:{onValueChange:d=>tn(d,n)},multi:{multiple:!0,selectionSummary:"tags",tagsOverflow:"single-line",tagsOverflowPopoverTitle:i},popover:{fullWidth:!0},list:{listVariant:"search-multi-checkbox",searchMultiCheckbox:{header:o,search:{show:r,placeholder:l},showClearSelection:!1}},menuSearch:{searchable:!1}})}const an=({mediosOptions:e,plazasOptions:t,estadosOptions:n,selectedMedios:s,selectedPlazas:o,selectedEstados:i,onlyDelayed:r,onChangeMedios:l,onChangePlazas:d,onChangeEstados:c,onChangeOnlyDelayed:m})=>a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-2 tm-mt-5 tm-mb-5",children:a.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-3",children:[a.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-4 tm-flex-1",children:[a.jsx("div",{className:"tm-w-full sm:tm-w-[280px]",children:a.jsx(ht,{options:e,selected:s,onChange:l,emptyPlaceholder:"Todos los medios",header:{id:"listado-progreso-medios-all",label:"Todos los medios"},tagsOverflowPopoverTitle:"Medios seleccionados",panelSearch:!1})}),a.jsx("div",{className:"tm-w-full sm:tm-w-[280px]",children:a.jsx(ht,{options:t,selected:o,onChange:d,emptyPlaceholder:"Todas las plazas",header:{id:"listado-progreso-plazas-all",label:"Todas las plazas"},tagsOverflowPopoverTitle:"Plazas seleccionadas",panelSearch:!0,panelSearchPlaceholder:"Buscar…"})}),a.jsx("div",{className:"tm-w-full sm:tm-w-[280px]",children:a.jsx(ht,{options:n,selected:i,onChange:c,emptyPlaceholder:"Todos los estados",header:{id:"listado-progreso-estados-all",label:"Todos los estados"},tagsOverflowPopoverTitle:"Estados seleccionados",panelSearch:!1})})]}),a.jsx("div",{className:"tm-flex tm-items-center",children:a.jsx(g.Toggle,{label:"Solo Atrasadas",checked:r,onChange:m})})]})}),It=[{singular:"completada",serieApiName:"completadas",uiLabel:"Completada",chartLegendLabel:"Completadas",tagColor:"success",chartColorHex:"#22C55E"},{singular:"progresada",serieApiName:"progresadas",uiLabel:"En progreso",chartLegendLabel:"En progreso",tagColor:"accent",chartColorHex:"#3658C1"},{singular:"pausada",serieApiName:"pausadas",uiLabel:"Pausada",chartLegendLabel:"Pausadas",tagColor:"warning",chartColorHex:"#EAB308"},{singular:"atrasada",serieApiName:"atrasadas",uiLabel:"Atrasada",chartLegendLabel:"Atrasadas",tagColor:"danger",chartColorHex:"#EF4444"},{singular:"pendiente",serieApiName:"pendientes",uiLabel:"Pendiente",chartLegendLabel:"Pendientes",tagColor:"gray",chartColorHex:"#BABCBF"},{singular:"vencida",serieApiName:"vencidas",uiLabel:"Vencida",chartLegendLabel:"Vencidas",tagColor:"info",chartColorHex:"#0592AA"}],sn=Object.fromEntries(It.map(e=>[e.singular,e])),aa=It.map(e=>e.serieApiName),nn="atrasada";function Dt(e){return sn[e]}function on(e){var t;return(t=Dt(e.trim().toLowerCase()))==null?void 0:t.serieApiName}function Da(e){return e?e.charAt(0).toUpperCase()+e.slice(1):""}function rn(e){const t=Dt(e);return t?t.uiLabel:Da(e)}function ln(e,t){const n=(e??"").trim().toLowerCase();if(!n)return[{label:t,color:"gray"}];const s=Dt(n);return s?[{label:s.uiLabel,color:s.tagColor}]:[{label:Da(n),color:"gray"}]}function cn(e){var t,n;if(Ye.isAxiosError(e)){const s=(t=e.response)==null?void 0:t.data;if(typeof s=="string"&&s.trim())return s;if(s&&typeof s=="object"&&"message"in s){const i=s.message;if(typeof i=="string")return i}const o=(n=e.response)==null?void 0:n.status;if(o)return`Error del servidor (${o}). Revisa logs del backend o el body de la respuesta.`}return e.message||"No se pudieron cargar los datos de progreso."}function dn(e){if(!e||typeof e!="object")return null;const n=e.event;if(n&&typeof n=="object"){const s=n;if(typeof s.offsetX=="number"&&typeof s.offsetY=="number")return{x:s.offsetX,y:s.offsetY};const o=s.event;if(o&&typeof o.offsetX=="number"&&typeof o.offsetY=="number")return{x:o.offsetX,y:o.offsetY}}return null}function mn(e){if(!e||typeof e!="object")return 0;const t=e.value;return typeof t=="number"?t:Array.isArray(t)&&typeof t[0]=="number"?t[0]:0}function un(e){return(Number.isFinite(e)?e:0).toFixed(0)}const pn=({id:e,listadoProgreso:t,phaseLabel:n,listadoForUi:s})=>{const{isPending:o,isError:i,error:r,isSuccess:l,data:d}=t,[c,m]=u.useState(null),f=s??d,x=u.useMemo(()=>{const w=(f==null?void 0:f.grafico)??[],j=F=>{var R,C;return((C=(R=w.find(I=>I.name===F))==null?void 0:R.data)==null?void 0:C[0])??0},b=It.map(F=>({key:F.serieApiName,label:F.chartLegendLabel,color:F.chartColorHex})),v=b.map(F=>F.label),M={legendLabel:{color:"#6C6E73",fontSize:12,fontWeight:"bold",padding:[0,0,0,20]}};return b.forEach((F,R)=>{M[`legendDot${R}`]={color:F.color,fontSize:20,fontWeight:"bold",padding:[0,0,0,6]}}),{tooltip:{show:!1},grid:{top:"20%",bottom:"20%",left:"7%",right:"3%"},xAxis:{type:"value",max:100,splitLine:{show:!0},axisLine:{show:!1},axisTick:{show:!1}},yAxis:{type:"category",data:[n],axisLine:{show:!1},axisTick:{show:!1},axisLabel:{color:"#6C6E73",fontWeight:"bold",fontSize:12}},legend:{data:v,orient:"horizontal",top:"0%",left:"center",itemGap:30,icon:"none",itemWidth:0,itemHeight:0,formatter:F=>{const R=b.findIndex(C=>C.label===F);return R===-1?F:`{legendLabel|${F}}{legendDot${R}|●}`},textStyle:{rich:M}},series:b.map(F=>({name:F.label,type:"bar",stack:"total",itemStyle:{color:F.color},barWidth:"50%",data:[j(F.key)]}))}},[f==null?void 0:f.grafico,n]),p=u.useCallback(w=>{const j=w;if(j.componentType!=="series")return;const b=dn(w);if(!b)return;const v=mn(w),M=typeof j.seriesName=="string"?j.seriesName:"";m({x:b.x,y:b.y,label:`${un(v)}% ${M}`})},[]),h=u.useCallback(()=>{m(null)},[]),y=u.useMemo(()=>({mouseover:p,mousemove:p,globalout:h}),[p,h]);return a.jsx(g.Accordion,{id:e,title:"Grafico de Tareas",subtitle:"Distribución de tareas por estatus",defaultOpen:!0,children:a.jsxs("div",{className:"tm-min-h-[140px] tm-w-full tm-border tm-rounded-3xl tm-border-default tm-px-2 tm-py-2 tm-bg-surface-default",children:[o&&a.jsx("h3",{className:"tm-flex tm-h-[140px] tm-items-center tm-justify-center tm-text-xl tm-font-medium tm-text-gray-500",children:"Cargando datos de progreso…"}),i&&r&&a.jsx("div",{className:"tm-flex tm-h-[140px] tm-items-center tm-justify-center tm-px-4 tm-text-center",children:a.jsx("span",{className:"tm-text-sm tm-font-medium tm-text-red-600",children:cn(r)})}),l&&d&&a.jsxs("div",{className:"tm-relative tm-h-[140px] tm-w-full",children:[a.jsx(Os,{option:x,style:{height:"100%",width:"100%"},onEvents:y}),c&&a.jsx("div",{className:"tm-pointer-events-none tm-absolute tm-z-[10]",style:{left:c.x,top:c.y,width:1,height:1,transform:"translate(-50%, -50%)"},"aria-hidden":!0,children:a.jsx(g.InlineTooltip,{isVisible:!0,label:c.label,position:"top"})})]})]})})},Ft="-";function Qe(e){const t=String(e??"").trim();return t.length>0?t:null}function Ke(e){const t=String(e??"").trim();return t.length>0?t:Ft}function fn(e){var i,r,l,d,c,m,f,x,p,h;if(!e)return;const t=(l=(r=(i=e.formats)==null?void 0:i.thumbnail)==null?void 0:r.url)==null?void 0:l.trim(),n=(m=(c=(d=e.formats)==null?void 0:d.small)==null?void 0:c.url)==null?void 0:m.trim(),s=(p=(x=(f=e.formats)==null?void 0:f.medium)==null?void 0:x.url)==null?void 0:p.trim(),o=(h=e.url)==null?void 0:h.trim();return t||n||s||o||void 0}function gn(e){if(!e)return!1;if(e.startsWith("data:")||e.startsWith("blob:"))return!0;try{const t=new URL(e);return t.protocol==="http:"||t.protocol==="https:"}catch{return!1}}function Mt(e,t){const n=(e.nombre??"").trim()||Ft,s=fn(e.imagen??null);let o;if(s){const r=s.startsWith("http")||s.startsWith("data:")||s.startsWith("blob:")?s:t(s);gn(r)&&(o=r)}const i=n.slice(0,1);return{name:n,src:o,letter:i}}function hn(e){return{tarea:Ke(e.tarea),categoria:Ke(e.categoria),nota:Ke(e.nota),clave:Ke(e.clave),tipo_medio:Ke(e.tipo_medio),ubicacion:Ke(e.ubicacion)}}function xn(e){return ln(e,Ft)}const Fa=4,sa=Fa-1,bn=120,yn=-8,na=8;function jn(e){return e.length<=Fa?{visible:e,overflow:[]}:{visible:e.slice(0,sa),overflow:e.slice(sa)}}const tt="tm-h-8 tm-w-8 tm-min-h-[32px] tm-min-w-[32px] tm-max-h-[32px] tm-max-w-[32px] tm-shrink-0 tm-border tm-border-default",oa="Sin responsable",Ma="bottom",ka="center",wn="tm-flex tm-max-w-xs tm-items-start tm-gap-2 tm-py-1",vn="tm-text-sm tm-font-semibold tm-leading-snug tm-text-gray-900";function ra(e,t){return e<t-1?{marginRight:`${yn}px`}:void 0}function _n({person:e,getImageOBP:t}){const{src:n,letter:s}=Mt(e,t);return n?a.jsx(g.Avatar,{type:"people",src:n,size:"xxs",className:tt}):a.jsx(g.Avatar,{type:"letter",text:s,size:"xxs",className:tt})}function Tn({person:e,getImageOBP:t}){const{name:n,src:s,letter:o}=Mt(e,t);return a.jsxs("div",{className:wn,children:[s?a.jsx(g.Avatar,{type:"people",src:s,size:"xxs",className:`tm-mt-0.5 ${tt}`}):a.jsx(g.Avatar,{type:"letter",text:o,size:"xxs",className:`tm-mt-0.5 ${tt}`}),a.jsx("span",{className:vn,children:n})]})}function Nn({popupId:e,trigger:t,children:n,popupBodyClassName:s="tm-p-3"}){const o=u.useRef(null),i=u.useRef(null),r=u.useRef(null),l=u.useCallback(()=>{r.current!==null&&(window.clearTimeout(r.current),r.current=null)},[]),d=u.useCallback(()=>{var m;l(),(m=i.current)==null||m.open()},[l]),c=u.useCallback(()=>{l(),r.current=window.setTimeout(()=>{var m;(m=i.current)==null||m.close(),r.current=null},bn)},[l]);return u.useEffect(()=>()=>l(),[l]),a.jsxs("div",{className:"tm-relative tm-inline-flex tm-shrink-0",children:[a.jsx("span",{ref:o,className:"tm-inline-flex tm-cursor-default",onMouseEnter:d,onMouseLeave:c,children:t}),a.jsx(g.Popup,{ref:i,popupId:e,triggerRef:o,closeOnClick:!1,position:"bottom-center",children:a.jsx("div",{className:s,onMouseEnter:d,onMouseLeave:c,children:n})})]})}function Cn(){return a.jsx(g.Tooltip,{label:oa,position:Ma,alignment:ka,preserveLayout:!0,children:a.jsx("span",{className:"tm-inline-flex tm-shrink-0",role:"img","aria-label":oa,children:a.jsx(g.Avatar,{type:"people",size:"xxs",className:tt,alt:""})})})}function Sn({person:e,getImageOBP:t}){const{name:n}=Mt(e,t);return a.jsx(g.Tooltip,{label:n,position:Ma,alignment:ka,preserveLayout:!0,children:a.jsx("span",{className:"tm-inline-flex tm-shrink-0",children:a.jsx(_n,{person:e,getImageOBP:t})})})}function En({overflow:e,getImageOBP:t,popupId:n}){return a.jsx(Nn,{popupId:n,popupBodyClassName:"tm-max-h-64 tm-overflow-y-auto tm-p-3",trigger:a.jsxs("span",{className:"tm-inline-flex tm-h-8 tm-w-8 tm-min-h-[32px] tm-min-w-[32px] tm-max-h-[32px] tm-max-w-[32px] tm-cursor-default tm-items-center tm-justify-center tm-rounded-control-pill tm-border tm-border-default tm-bg-fill-brand tm-text-xs tm-font-normal tm-leading-none tm-tracking-[0.5px] tm-text-on-color",children:["+",e.length]}),children:e.map((s,o)=>a.jsx(Tn,{person:s,getImageOBP:t},s.id!=null?`${s.id}-${o}`:o))})}const Pn=({responsables:e,getImageOBP:t,rowId:n})=>{const s=Array.isArray(e)?e:[];if(s.length===0)return a.jsx("div",{className:"tm-flex tm-min-w-0 tm-items-center",style:{paddingRight:`${na}px`},children:a.jsx(Cn,{})});const{visible:o,overflow:i}=jn(s),r=o.length+(i.length>0?1:0);return a.jsxs("div",{className:"tm-flex tm-min-w-0 tm-items-center",style:{paddingRight:`${na}px`},children:[o.map((l,d)=>{const c=l.id!=null?`r-${l.id}-${d}`:`r-${n}-${d}`;return a.jsx("div",{className:"tm-shrink-0",style:ra(d,r),children:a.jsx(Sn,{person:l,getImageOBP:t})},c)}),i.length>0?a.jsx("div",{className:"tm-shrink-0",style:ra(r-1,r),children:a.jsx(En,{overflow:i,getImageOBP:t,popupId:`listado-progreso-${n}-more`})}):null]})},An={name:me.faCircleSmall};function In({tags:e}){const t=Array.isArray(e)?e:[];return a.jsx("div",{className:"tm-inline-flex tm-min-w-0 tm-max-w-full tm-flex-wrap tm-content-start tm-items-center tm-gap-1",children:t.map((n,s)=>a.jsx("div",{className:"tm-min-w-0 tm-max-w-full tm-flex-shrink-0",children:a.jsx(g.Tag,{label:n.label,color:n.color,stroke:!1,truncateLabel:!0,truncateTooltip:!0,infoIcon:An})},`${n.label}-${s}`))})}const Dn=({listadoProgreso:e,listadoForUi:t,hideClaveColumn:n=!1})=>{var d,c;const{getImageOBP:s}=ge(),o=u.useMemo(()=>{const m=[{id:"responsables",header:"Responsable",accessor:f=>f.responsables,width:140,minWidth:100,sortable:!1,filterable:!1,resizable:!1,render:(f,x)=>a.jsx(Pn,{responsables:x.responsables,getImageOBP:s,rowId:x.id})},{id:"tarea",header:"Tarea",accessor:"tarea",width:100,minWidth:90,sortable:!1,filterable:!1,resizable:!1},{id:"categoria",header:"Categoría",accessor:"categoria",width:110,minWidth:90,sortable:!1,filterable:!1,resizable:!1,contentAlign:"center"},{id:"estado",header:"Estado",accessor:f=>xn(f.estado),contentAlign:"center",width:110,minWidth:90,sortable:!1,filterable:!1,resizable:!1,render:f=>a.jsx(In,{tags:Array.isArray(f)?f:[]})},{id:"nota",header:"Notas",accessor:"nota",width:100,minWidth:90,sortable:!1,filterable:!1,resizable:!1},{id:"tipo_medio",header:"Grupo medio",accessor:"tipo_medio",width:130,minWidth:110,sortable:!1,filterable:!1,resizable:!1},{id:"ubicacion",header:"Ubicación",accessor:"ubicacion",width:120,minWidth:100,sortable:!1,filterable:!1,resizable:!1}];return n||m.splice(5,0,{id:"clave",header:"Código / Ruta",accessor:"clave",width:130,minWidth:100,sortable:!1,filterable:!1,resizable:!1,contentAlign:"center"}),m},[s,n]),i=u.useMemo(()=>{var f;const m=(t==null?void 0:t.data)??((f=e.data)==null?void 0:f.data);return Array.isArray(m)?m.map(x=>({...x,id:x.id,...hn(x)})):[]},[t==null?void 0:t.data,(d=e.data)==null?void 0:d.data]),r=e.isPending||e.isFetching&&i.length===0&&!e.isError,l=u.useMemo(()=>{var x,p;const m=(x=e.data)==null?void 0:x.data,f=Array.isArray(m)?m.length:0;if(e.isError)return{type:"empty",icon:ne.faBan,title:"No se pudo cargar el listado",description:((p=e.error)==null?void 0:p.message)??"Revisa la conexión o vuelve a intentar."};if(e.isSuccess){if(f===0&&i.length===0)return{type:"empty",icon:ne.faBan,title:"Esta campaña aún no tiene tareas",description:"Cuando asignes tareas a medios, aparecerán aquí con su estado y responsables."};if(f>0&&i.length===0)return{type:"no-filters",icon:ne.faBan,title:"No hay nada aquí...",description:"No hay tareas que coincidan con los filtros seleccionados."}}return{type:"empty",icon:ne.faBan,title:"No hay nada aquí..."}},[e.isError,e.isSuccess,e.error,(c=e.data)==null?void 0:c.data,i.length]);return a.jsx(a.Fragment,{children:a.jsx("div",{className:"tm-flex tm-min-h-0 tm-flex-col tm-mt-2 tm-h-[455px] tm-border tm-rounded-3xl tm-border-default",children:a.jsx(g.Table,{columns:o,columnsLockable:!1,rows:i,loading:r,hoverable:!1,bordered:!1,borderable:!1,stickyHeader:!0,empty:l,resizable:!1,expandable:!1,striped:!1,stickyCheckbox:!1})})})},Fn={preventa:"Preventa",venta:"Venta"},Mn=({campaignName:e,phase:t,search:n,listado:s,filters:o})=>{const i=Fn[t],r=t==="preventa";return a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-4",children:[a.jsx(en,{campaignName:e,searchValue:n.value,onSearchChange:n.onChange}),a.jsx(an,{mediosOptions:o.mediosOptions,plazasOptions:o.plazasOptions,estadosOptions:o.estadosOptions,selectedMedios:o.selectedMedios,selectedPlazas:o.selectedPlazas,selectedEstados:o.selectedEstados,onlyDelayed:o.onlyDelayed,onChangeMedios:o.onChangeMedios,onChangePlazas:o.onChangePlazas,onChangeEstados:o.onChangeEstados,onChangeOnlyDelayed:o.onChangeOnlyDelayed}),a.jsx(pn,{id:`progress-chart-${i}`,listadoProgreso:s.query,phaseLabel:i,listadoForUi:s.dataForUi}),a.jsx(Dn,{listadoProgreso:s.query,listadoForUi:s.dataForUi,hideClaveColumn:r})]})};function kn(e){var i,r,l,d;const t=(i=e.types_media)==null?void 0:i.map(c=>c.trim()).filter(Boolean),n=(r=e.locations)==null?void 0:r.map(c=>c.trim()),s=(l=e.status)==null?void 0:l.map(c=>c.trim().toLowerCase()).filter(Boolean),o=((d=e.search)==null?void 0:d.trim().toLowerCase())||void 0;return{mediosSet:t&&t.length>0?new Set(t):void 0,locationsSet:n&&n.length>0?new Set(n):void 0,statusSet:s&&s.length>0?new Set(s):void 0,searchLower:o,onlyDelayed:e.onlyDelayed===!0}}function Ln(e,t){const{mediosSet:n,locationsSet:s,statusSet:o,searchLower:i,onlyDelayed:r}=t;if(n){const l=Qe(e.tipo_medio)??"";if(!n.has(l))return!1}if(s){const l=Qe(e.ubicacion)??"";if(!s.has(l))return!1}if(o){const l=(e.estado??"").trim().toLowerCase();if(!o.has(l))return!1}return!(r&&(e.estado??"").trim().toLowerCase()!==nn||i&&![(e.responsables??[]).flatMap(c=>[c.nombre??"",c.role??"",c.email??""]).join(" ").toLowerCase(),e.tarea??"",e.categoria??"",e.estado??"",e.nota??"",e.clave??"",e.tipo_medio??"",e.ubicacion??""].join(" ").toLowerCase().includes(i))}function On(e){const t=Object.fromEntries(aa.map(s=>[s,0]));for(const s of e){const o=on(s.estado??"");o&&(t[o]+=1)}const n=e.length;return aa.map(s=>({name:s,data:[n>0?t[s]/n*100:0]}))}function Bn(e,t){const n=kn(t);if(!(n.mediosSet!==void 0||n.locationsSet!==void 0||n.statusSet!==void 0||n.searchLower!==void 0||n.onlyDelayed))return e;const o=e.data.filter(i=>Ln(i,n));return{data:o,grafico:On(o)}}const La="__sin_ubicacion__";function Oa(e,t){return String(e.label).localeCompare(String(t.label),"es",{sensitivity:"base"})}function xt(e,t,n){const s=new Map;return e.forEach(o=>{const i=t(o);!i||s.has(i)||s.set(i,{label:n?n(i):i,value:i})}),Array.from(s.values()).sort(Oa)}function Rn(e){return e.map(t=>t===La?"":t)}function qn(e){const t=xt(e,r=>Qe(r.tipo_medio)),n=e.some(r=>Qe(r.ubicacion)===null),s=xt(e,r=>Qe(r.ubicacion)),o=[...n?[{label:"Sin ubicación",value:La}]:[],...s].sort(Oa),i=xt(e,r=>{var l;return((l=Qe(r.estado))==null?void 0:l.toLowerCase())??null},r=>rn(r));return{medios:t,plazas:o,estados:i}}const zn=({isOpen:e,proyectoId:t,campaignName:n,onClose:s})=>{var B;const[r,l]=u.useState("preventa"),[d,c]=u.useState([]),[m,f]=u.useState([]),[x,p]=u.useState([]),[h,y]=u.useState(!1),[w,j]=u.useState(""),b=Gs(w,400),v=u.useMemo(()=>[{label:"Fase 1 (Preventa)",value:"preventa",leftSlot:ne.faHandHoldingHand},{label:"Fase 2 (Venta)",value:"venta",leftSlot:ne.faHandHoldingCircleDollar}],[]),M=()=>{c([]),f([]),p([]),y(!1)},F=()=>{l("preventa"),M(),j(""),s()},R=q=>{(q==="preventa"||q==="venta")&&(l(q),M(),j(""))},C=u.useMemo(()=>{const q=b.trim();if(q)return q.length>=2?q:void 0},[b,2]),I=Zs({proyectoId:t,fase:r,enabled:e,filters:{}}),T=u.useMemo(()=>({types_media:d.length>0?d:void 0,locations:m.length>0?Rn(m):void 0,status:x.length>0?x:void 0,search:C,onlyDelayed:h}),[d,m,x,C,h]),{medios:V,plazas:z,estados:ee}=u.useMemo(()=>{var X;const q=((X=I.data)==null?void 0:X.data)??[];return qn(q)},[(B=I.data)==null?void 0:B.data]),G=u.useMemo(()=>{const q=I.data;return q?Bn(q,T):null},[I.data,T]),k=u.useMemo(()=>({value:w,onChange:j}),[w]),E=u.useMemo(()=>({query:I,dataForUi:G}),[I,G]),L=u.useMemo(()=>({mediosOptions:V,plazasOptions:z,estadosOptions:ee,selectedMedios:d,selectedPlazas:m,selectedEstados:x,onlyDelayed:h,onChangeMedios:c,onChangePlazas:f,onChangeEstados:p,onChangeOnlyDelayed:y}),[V,z,ee,d,m,x,h]);return a.jsx(g.Modal,{isOpen:e,onClose:F,size:"xl",title:"Progreso",tabs:v,defaultValueTab:"preventa",onChangeTab:R,iconConfig:{icon:ne.faBullhorn},cancelButtonText:"Cerrar",showCancelButton:!0,closeAtCancel:!0,onCancel:F,showSuccessButton:!1,children:a.jsx("div",{className:"tm-bg-surface-default tm-p-16",children:a.jsx(g.Modal.Body,{children:a.jsx(Mn,{campaignName:n,phase:r,search:k,listado:E,filters:L})})})})},$n=({setPath:e,setProject:t})=>{var L;const[n,s]=u.useState([]),[o,i]=u.useState(!0),[r,l]=u.useState(0),[d,c]=u.useState(10),[m,f]=u.useState(0),[x,p]=u.useState(!1),[h,y]=u.useState(""),[w,j]=u.useState(0),{filters:b,defineFields:v}=De(),{tasks_api:M,getImageOBP:F}=ge(),{user:R}=je(),C=u.useCallback(async(B,q)=>{var X,H,re;try{i(!0);const Y={filters:{search:(b==null?void 0:b.search)??"",responsable:{idUser:R.id,responsableType:(X=b==null?void 0:b.responsable)==null?void 0:X.responsableType},ejecutivo:(b==null?void 0:b.ejecutivo)??"",cancelada:{$eq:!1}}},P=await M.get("/api/listado_campanias",{params:{pagination:{page:B,pageSize:q},...Y}}),$=xe(P==null?void 0:P.data);s($),f((re=(H=P==null?void 0:P.data)==null?void 0:H.meta)==null?void 0:re.total)}catch(Y){console.error("Error fetching data en Lista Campaña:",Y)}finally{i(!1)}},[b==null?void 0:b.ejecutivo,(L=b==null?void 0:b.responsable)==null?void 0:L.responsableType,b==null?void 0:b.search,M,R.id]),I=u.useCallback(async()=>{try{const B=await M.get("/api/obtener-comerciales");return[...Zt].map(X=>(X.id==="ejecutivo"&&(X.options=B.data.map(H=>({id:H.nombre,name:H.nombre}))),X))}catch(B){return console.error("Error fetching salesman data:",B),[...Zt]}},[M]);u.useEffect(()=>{(async()=>{const q=await I();v(q)})()},[v,I]),u.useEffect(()=>{const B=Math.floor(r/d)+1;C(B,d)},[r,d,b,C]);const T=B=>{l(B.first),c(B.rows)},V=Math.floor(r/d)+1,z=u.useMemo(()=>(R.role??"").trim().toLowerCase()==="project manager",[R.role]),ee=u.useCallback(B=>{var q;y(((q=B.campania)==null?void 0:q.nombre)??B.nombre??""),j(Number(B.id)),p(!0)},[]),G=u.useMemo(()=>({label:"Ver progreso",leftSlot:ne.faEye,theme:"solid",color:"secondary",tooltip:"Ver progreso",onClick:B=>ee(B)}),[ee]),k=u.useMemo(()=>{const B=[{id:"nombre",header:"CAMPAÑA",accessor:q=>{var X;return((X=q.campania)==null?void 0:X.nombre)??q.nombre??"-"},width:200,sortable:!1,filterable:!1,resizable:!1},{id:"inicia",header:"FECHA INICIO",accessor:q=>{var X;return((X=q.campania)==null?void 0:X.inicia)??"-"},width:100,sortable:!1,filterable:!1,resizable:!1},{id:"termina",header:"FECHA FIN",accessor:q=>{var X;return((X=q.campania)==null?void 0:X.termina)??"-"},width:100,sortable:!1,filterable:!1,resizable:!1},{id:"responsable",header:"RESPONSABLE",type:"primary",accessor:q=>{var X,H;return((H=(X=q.campania)==null?void 0:X.responsable)==null?void 0:H.nombre)??"-"},width:150,sortable:!1,filterable:!1,resizable:!1,render:(q,X)=>{var Q,D,A,K,S;const H=(Q=X.campania)==null?void 0:Q.responsable,re=typeof q=="string"||typeof q=="number"?String(q):(H==null?void 0:H.nombre)??"-",Y=(H==null?void 0:H.role)??"-",P=((K=(A=(D=H==null?void 0:H.imagen)==null?void 0:D.formats)==null?void 0:A.thumbnail)==null?void 0:K.url)||((S=H==null?void 0:H.imagen)==null?void 0:S.url)||"",$=P?F(P):H==null?void 0:H.nombre;return{name:re,...$?{avatar:$}:{},...Y?{subtitle:Y}:{}}}},{id:"alertas",header:"ALERTAS",accessor:q=>$s(q.alertas),width:200,minWidth:100,filterable:!1,sortable:!1,resizable:!1,contentAlign:"center",render:q=>a.jsx(Ks,{tags:Array.isArray(q)?q:[]})}];return z&&B.push({id:"acciones",header:"ACCIONES",type:"button",sortable:!1,filterable:!1,resizable:!1,accessor:()=>G,width:190,minWidth:160}),B},[F,z,G]),E=u.useMemo(()=>(n??[]).map(B=>({...B,id:B.id})),[n]);return a.jsxs("div",{className:"tm-h-full tm-max-h-[100%] tm-overflow-y-auto tm-scrollbar-none",children:[a.jsx(g.Table,{columns:k,columnsLockable:!1,rows:E,loading:o,hoverable:!0,resizable:!1,pagination:{enabled:!0,currentPage:V,pageSize:d,total:m,pageSizes:[5,10,15,20,25,50],onPageChange:B=>l((B-1)*d),onPageSizeChange:B=>T({first:0,rows:B})},onRowClick:B=>{t({id:B.id,project:B.nombre}),e("kanban-campania")},empty:{type:"empty",title:"No hay campañas disponibles"}}),a.jsx(zn,{isOpen:x,proyectoId:w,campaignName:h,onClose:()=>p(!1)})]})},Ba=u.createContext(null),Un=()=>u.useContext(Ba),Hn=({children:e})=>{const t=u.useRef(null),n=u.useRef(null),s=()=>{var o;(o=n.current)==null||o.close()};return a.jsxs(a.Fragment,{children:[a.jsx(g.Button,{ref:t,leftSlot:ne.faFilter,color:"primary",theme:"solid",size:"sm",type:"button",children:"Filtrar"}),a.jsx(g.Popup,{ref:n,triggerRef:t,position:"bottom-right",offset:8,closeOnClickOutside:!0,closeOnEscape:!0,closeOnClick:!1,popoverArrow:!1,allowOverflow:!0,popupId:"tareas-filters-layout-popup",children:a.jsx(Ba.Provider,{value:s,children:e})})]})};function Kn(e,t=300,n={leading:!1,trailing:!0}){let s,o=null;return function(...i){const r=Date.now(),l=n.leading&&!o;clearTimeout(s),l&&e(...i),o=r,s=setTimeout(()=>{n.trailing&&(!n.leading||r-o>=t)&&(e(...i),o=null)},t)}}function Gn(e){return e!=null&&e.length?e.map(t=>({id:t.id,label:t.name,value:t.id})):[]}function Vn({field:e}){const{updateFilters:t,initialFilters:n}=De(),s=u.useMemo(()=>Gn(e.options),[e.options]),o=n==null?void 0:n[e.id],i=o??"";return a.jsx(g.Dropdown,{field:{label:e.label,placeholder:"Selecciona una opción",size:"xs"},items:{options:s,idName:"id"},values:{value:i},menuSearch:{searchable:!0,searchPlaceholder:"Buscar…"},popover:{fullWidth:!0,absolute:!1,closeOnClickOutside:!0,dropdownId:`filter-layout-${e.id}`,popoverZIndex:1300},events:{onValueChange:r=>{t({name:e.id,value:String(r)})}}})}const Wn=()=>{const{fields:e,updateFilters:t,cleanFilters:n,applyFilters:s,initialFilters:o}=De(),i=Un();return a.jsxs("div",{className:"tm-flex tm-min-w-[280px] tm-max-w-[400px] tm-flex-col tm-gap-8 tm-p-8",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-gap-2",children:[a.jsx("p",{className:"tm-m-0 tm-text-heading-h6 tm-font-heading-h6 tm-leading-heading-h6 tm-tracking-heading-h6 tm-text-primary",children:"Filtros"}),a.jsx(g.Button,{color:"secondary",size:"xxs",icon:ne.faXmark,type:"button",onClick:()=>{n(),i==null||i()},children:"Limpiar"})]}),a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-3",children:e==null?void 0:e.map((r,l)=>a.jsx("div",{className:"tm-relative",style:{zIndex:10-l},children:(r==null?void 0:r.type)==="select"?a.jsx("div",{className:"tm-relative tm-z-[10] tm-w-full",children:a.jsx(Vn,{field:r})}):a.jsxs(a.Fragment,{children:[a.jsx("p",{className:"z-[1] tm-text-xl",children:r.label}),a.jsx("input",{className:"tm-h-[30px] tm-w-full tm-rounded-lg tm-p-s tm-shadow-input",type:r.type,value:o==null?void 0:o[r==null?void 0:r.id],name:r.label.toLowerCase().replace(/ /g,"_"),onChange:Kn(d=>{var c,m;return t({name:(c=d==null?void 0:d.target)==null?void 0:c.name,value:(m=d==null?void 0:d.target)==null?void 0:m.value})},1e3)})]})},l))}),a.jsx(g.Button,{color:"primary",size:"xs",type:"button",fullWidth:!0,onClick:()=>{s(),i==null||i()},children:"Filtrar"})]})},kt=e=>new Intl.DateTimeFormat("es-MX",{month:"long"}).format(e);function Qn(e){const t=["domingo","lunes","martes","miércoles","jueves","viernes","sábado"],n=new Date(e).getDay();return t[n]}const ia=e=>{let t=e||new Date,n=t.getDate(),s=kt(t.getMonth()).slice(0,3),o=t.getFullYear().toString().slice(-2),i=Qn(t).slice(0,3);return`${i.charAt(0).toUpperCase()+i.slice(1)} ${n} ${s.charAt(0).toUpperCase()+s.slice(1)} ${o}`},Lt=(e,t)=>({...e,image:e.image?`${t}${e.image}`:""}),at=e=>{var t,n;return e?(t=e.responsable)!=null&&t.nombre?e.responsable.nombre:(n=e.equipo)!=null&&n.nombre?e.equipo.nombre:null:null};class Xn{static toCampaignTasks(t){var i,r,l,d,c,m,f,x,p,h,y,w,j,b,v;const n=at(t==null?void 0:t.id_t_requerida),s=at(t==null?void 0:t.tarea_padre);let o=[];return t!=null&&t.responsable&&o.push({id:t.responsable.id,name:t.responsable.nombre,image:(c=(d=(l=(r=(i=t.responsable)==null?void 0:i.userOBP)==null?void 0:r.imagen)==null?void 0:l.formats)==null?void 0:d.thumbnail)==null?void 0:c.url,role:((m=t.responsable.userOBP)==null?void 0:m.role)||{id:0,name:""}}),(f=t==null?void 0:t.equipo)!=null&&f.miembros&&t.equipo.miembros.forEach(M=>{var F,R,C,I,T;o!=null&&o.find(V=>V.id===M.idUser.id)||M.idUser&&o.push({id:M.idUser.id,name:M.idUser.nombre,image:(I=(C=(R=(F=M==null?void 0:M.userOBP)==null?void 0:F.imagen)==null?void 0:R.formats)==null?void 0:C.thumbnail)==null?void 0:I.url,role:((T=M.userOBP)==null?void 0:T.role)||{id:0,name:""}})}),{paused:t==null?void 0:t.pausada,isPrincipalTask:(t==null?void 0:t.tarea_principal)??!1,orden:(t==null?void 0:t.orden)??null,id:(t==null?void 0:t.id)??null,task:(t==null?void 0:t.texto_corto)??null,status:(t==null?void 0:t.estatus)??null,difficulty:(t==null?void 0:t.nivel_dificultad)??null,priority:(t==null?void 0:t.prioridad)??0,endDate:new Date((t==null?void 0:t.ffin)??null),startDate:new Date((t==null?void 0:t.finicio)??null),users:o,repeatsToDo:(t==null?void 0:t.repeticiones)??null,repeats:(t==null?void 0:t.repeticiones_realizadas)??null,comments:((x=t==null?void 0:t.comentarios)==null?void 0:x.length)??null,willBePaused:t==null?void 0:t.es_pausable,nameProject:((p=t==null?void 0:t.proyecto)==null?void 0:p.nombre)??null,idProject:((h=t==null?void 0:t.proyecto)==null?void 0:h.id)??null,medioName:(t==null?void 0:t.nombre_medio)??null,statusRequiredTask:((y=t==null?void 0:t.id_t_requerida)==null?void 0:y.estatus)??null,nameRequiredTask:((w=t==null?void 0:t.id_t_requerida)==null?void 0:w.texto_corto)??null,nameRequiredTaskResponsible:n,name_father_required_task:((j=t==null?void 0:t.tarea_padre)==null?void 0:j.texto_corto)??null,name_father_required_task_responsible:s,responsible:((b=t==null?void 0:t.responsable)==null?void 0:b.id)??null,tasks:((v=t==null?void 0:t.tareas)==null?void 0:v.map(M=>({id:M.id,name:M.texto_corto,status:M.estatus})))??null,atraso:(t==null?void 0:t.atraso)??null,categoria:(t==null?void 0:t.categoria)??null,...(t==null?void 0:t.cambio_arte)&&{cambio_arte:t==null?void 0:t.cambio_arte}}}}const Yn=async({filters:e,tasks_api:t,project:n})=>{try{const s=await t.get("/api/listado_tareas_flujo",{params:{...e,project:{id:n},includeAllTasks:!0,populate:"*",cancelada:!1}}),o=xe(s.data.tareas),i=Array.isArray(o)?o:[o],r=new Set;if(i.forEach(l=>{var d;(d=l==null?void 0:l.id_t_requerida)!=null&&d.id&&r.add(l.id_t_requerida.id)}),r.size>0){const l=Array.from(r),d=Ce.stringify({filters:{id:{$in:l}},populate:{responsable:{fields:["id","nombre"]},equipo:{fields:["id","nombre"]}}},{encodeValuesOnly:!0});try{const c=await t.get(`/api/tareas?${d}`),m=xe(c.data.data||c.data),f=Array.isArray(m)?m:[m],x=new Map(f.map(p=>[p.id,p]));i.forEach(p=>{var h;if((h=p==null?void 0:p.id_t_requerida)!=null&&h.id){const y=x.get(p.id_t_requerida.id);y&&(p.id_t_requerida={...p.id_t_requerida,responsable:y.responsable||null,equipo:y.equipo||null})}})}catch{}}return i.map(Xn.toCampaignTasks)}catch(s){console.log(s)}},Ra=u.createContext({}),Jn=({children:e,project:t})=>{var j;const[n,s]=u.useState([]),[o,i]=u.useState(!1),[r,l]=u.useState([]),{tasks_api:d}=ge(),{filters:c}=De(),{user:m}=je(),[f,x]=u.useState({owner:{user:m.id,config:((j=c==null?void 0:c.owner)==null?void 0:j.config)??"yo_y_mis_equipos"},project:{id:t}});u.useEffect(()=>{var b;if(Object.keys(c).length>0){const v={...c,owner:{user:m.id,config:((b=c==null?void 0:c.owner)==null?void 0:b.config)??"yo_y_mis_equipos"},project:{id:t}};x(v)}},[c,m.id,t]);const p=de.useQuery({queryKey:["tasksProject",f,t],queryFn:()=>{const b={...f,taskName:c==null?void 0:c.taskName,owner:{...f.owner,config:f.owner.config||"yo_y_mis_equipos"}};return Yn({filters:b,project:t,tasks_api:d})},refetchOnWindowFocus:!1}),h=b=>{s(v=>[...v,b])},y=b=>{l(v=>v.includes(b)?v.filter(M=>M!==b):[...v,b])},w=t??null;return a.jsx(Ra.Provider,{value:{tasksProject:p,selectedTasks:n,projectID:w,openTasks:r,selectTask:h,filtersToSend:f,openTask:y,isRefetching:o,project:t,filters:c,setIsRefetching:i},children:e})},Je=()=>u.useContext(Ra),qa=u.createContext(void 0),la=()=>({selectedTaskIds:[],baseColumn:null,isFullColumnSelected:!1});function za({children:e,invalidateAfterBulkSuccess:t}){const[n,s]=u.useState(la),[o,i]=u.useState(null),[r,l]=u.useState(!1),{selectedTaskIds:d,baseColumn:c,isFullColumnSelected:m}=n,f=d.length>0,x=c!==null,p=u.useCallback(()=>{s(la()),i(null),l(!1)},[]),h=u.useCallback(()=>{s(b=>({...b,selectedTaskIds:[],isFullColumnSelected:!1}))},[]),y=u.useCallback((b,v)=>{v!=="Completadas"&&s(M=>{if(M.baseColumn&&M.baseColumn!==v)return M;const F=new Set(M.selectedTaskIds);return F.has(b)?(F.delete(b),{selectedTaskIds:[...F],baseColumn:M.baseColumn,isFullColumnSelected:!1}):(F.add(b),{selectedTaskIds:[...F],baseColumn:M.baseColumn??v,isFullColumnSelected:!1})})},[]),w=u.useCallback(async(b,v)=>{if(b!=="Completadas"){l(!0);try{const M=await v(),F=[...new Set(M)];s(R=>R.baseColumn&&R.baseColumn!==b?R:{selectedTaskIds:F,baseColumn:R.baseColumn??b,isFullColumnSelected:F.length>0})}finally{l(!1)}}},[]);u.useEffect(()=>{d.length===0&&c!==null&&p()},[d.length,c,p]);const j=u.useMemo(()=>({selectedTaskIds:d,baseColumn:c,isMultiSelectActive:f,isBulkSessionActive:x,isFullColumnSelected:m,pendingTargetStatus:o,isBulkLoading:r,invalidateAfterBulkSuccess:t,toggleTaskSelection:y,deselectAllSelectedTasks:h,exitBulkSelectionMode:p,selectEntireColumn:w,setPendingTargetStatus:i,setIsBulkLoading:l}),[d,c,f,x,m,o,r,t,y,h,p,w,i,l]);return a.jsx(qa.Provider,{value:j,children:e})}function Ot(){return u.useContext(qa)}const Zn=()=>a.jsxs("div",{className:"tm-flex tm-h-[150px] tm-w-full tm-animate-pulse tm-flex-col tm-gap-[50px] tm-rounded-md tm-bg-gray-200 tm-p-4",children:[a.jsxs("div",{className:"tm-flex tm-h-[30px] tm-gap-3",children:[a.jsx("div",{className:"tm-h-full tm-w-[30px] tm-min-w-[30px] tm-rounded-full tm-bg-gray-300"}),a.jsx("div",{className:"tm-h-full tm-w-full tm-bg-gray-300"}),a.jsx("div",{className:"tm-h-full tm-w-[30px] tm-min-w-[30px] tm-rounded-full tm-bg-gray-300"})]}),a.jsxs("div",{className:"tm-flex tm-h-[30px] tm-w-full tm-justify-between tm-gap-[50px]",children:[a.jsx("div",{className:"tm-h-[30px] tm-w-full tm-bg-gray-300"}),a.jsx("div",{className:"tm-h-[30px] tm-w-full tm-bg-gray-300"})]})]});function Ie({trigger:e,children:t,enabled:n=!0,position:s="top",offset:o=8,closeOnClick:i=!1,popoverArrow:r="auto",className:l="tm-inline-flex tm-max-w-full",triggerWrapperClassName:d="tm-inline-flex tm-max-w-full"}){const c=u.useRef(null);return n?a.jsxs("span",{className:l,children:[a.jsx("span",{ref:c,className:d,children:e}),a.jsx(g.Popover,{triggerRef:c,openOnHover:!0,position:s,offset:o,closeOnClick:i,popoverArrow:r,children:t})]}):a.jsx(a.Fragment,{children:e})}const $a=u.createContext(null),eo=({children:e})=>{const[t,n]=u.useState({message:"",type:"success"}),s=(o,i)=>{n({message:o,type:i}),setTimeout(()=>n({message:"",type:"success"}),3e3)};return a.jsx($a.Provider,{value:{toast:t,showSuccess:o=>s(o,"success"),showError:o=>s(o,"error")},children:e})},Bt=()=>u.useContext($a);class Ua{static toAtrasoReasons(t){return{id:t.id,motivo_imj:t.motivo_imj,categoria:t.categoria??null}}}const to=async({tasks_api:e})=>{try{const t=await e.get("/api/motivos",{params:{populate:{categoria:{fields:["id","nombre","tipo"]}},filters:{tipo:{$eq:"atraso"}}}});return xe(t.data).map(Ua.toAtrasoReasons)}catch(t){throw console.log("Error al obtener los motivos de atraso",t),`Error al obtener los motivos de atraso: ${t}`}},Ha=({enabled:e=!1}={})=>{const{tasks_api:t}=ge(),{user:n}=je(),s=de.useQueryClient(),{showSuccess:o,showError:i}=Bt(),{filters:r,path:l}=De(),{data:d,isLoading:c}=de.useQuery({queryKey:["atraso_reasons"],queryFn:()=>to({tasks_api:t}),staleTime:1e3*60*60*24,enabled:e}),m=async()=>{const M=await t.get("/api/motivos",{params:{filters:{tipo:{$eq:"atraso"}}}});return xe(M.data).map(Ua.toAtrasoReasons)},f=async({taskId:M,motivoId:F,projectID:R})=>{try{return(await t.post("/api/atrasos",{data:{inicio:new Date,fin:null,motivo:F,proyecto:R,tarea:M,creada_por:n==null?void 0:n.id}})).data}catch(C){console.log("error",C)}},x=async M=>{try{return(await t.delete(`/api/atrasos/${M}`)).data}catch(F){console.log("error",F)}},p=async M=>{try{return(await t.put(`/api/atrasos/${M}`,{data:{fin:new Date}})).data}catch(F){console.log("error",F)}},h=async({taskId:M,projectID:F,motivo:R})=>{await j({taskId:M,motivoId:R,projectID:F})},y=async M=>{await b(M)},w=async M=>{await v(M)},{mutateAsync:j}=de.useMutation({mutationFn:f,onSuccess:()=>{o("Atraso registrado correctamente"),l==="kanban-general"&&(s.invalidateQueries({queryKey:["to_do_tasks",r]}),s.invalidateQueries({queryKey:["working_tasks",r]})),l==="kanban-campania"&&s.invalidateQueries({queryKey:["tasksProject"]})},onError:()=>{i("Error al registrar el atraso")}}),{mutateAsync:b}=de.useMutation({mutationFn:x,onSuccess:()=>{o("Atraso eliminado correctamente"),l==="kanban-general"&&(s.invalidateQueries({queryKey:["to_do_tasks"]}),s.invalidateQueries({queryKey:["working_tasks"]}),s.invalidateQueries({queryKey:["done_tasks"]})),l==="kanban-campania"&&s.invalidateQueries({queryKey:["tasksProject"]})},onError:()=>{i("Error al eliminar el atraso")}}),{mutateAsync:v}=de.useMutation({mutationFn:p,onSuccess:()=>{o("Atraso finalizado correctamente")},onError:()=>{i("Error al finalizar el atraso")}});return{atrasoReasons:d,isLoading:c,createAtraso:h,getAtrasoReasons:m,deleteAtraso:y,finalizarAtraso:w}},He=()=>{const{tasks_api:e}=ge(),{user:t}=je(),{filters:n,path:s}=De(),o=de.useQueryClient(),{projectID:i}=Je(),{showSuccess:r,showError:l}=Bt(),{finalizarAtraso:d}=Ha({enabled:!1}),c=async({id:k})=>(await e.put(`/api/tareas/${k}`,{data:{estatus:1,responsable:t==null?void 0:t.id,updated_by:t==null?void 0:t.id}})).data,m=async({id:k})=>(await e.put(`/api/tareas/${k}`,{data:{estatus:0,responsable:t==null?void 0:t.id,updated_by:t==null?void 0:t.id}})).data,f=async({id:k,idAtraso:E})=>{const L=await e.post("/api/terminarTarea",{id_task:k,ended_at:new Date().toISOString(),id_user:t==null?void 0:t.id});return await d(E),L.data},x=async({id:k,repeats:E})=>(await e.put(`/api/tareas/${k}`,{data:{repeticiones_realizadas:E,updated_by:t==null?void 0:t.id}})).data,p=async({id:k,motiveId:E})=>{try{const L=await e.post("/api/pausarTarea",{taskId:k,userId:t==null?void 0:t.id,motivoId:E});return r("Tarea pausada correctamente"),L.data}catch(L){l("Error al pausar la tarea: "+L)}},h=async({id:k})=>{try{const E=await e.post("/api/reanudarTarea",{taskId:k});return r("Tarea reanudada correctamente"),E.data}catch(E){l("Error al reanudar la tarea: "+E)}},y=async({id:k,idNewResponsible:E,typeOfSelect:L})=>{let B={updated_by:t==null?void 0:t.id};return L==="responsible"&&(B={...B,responsable:E}),L==="team"&&(B={...B,responsable:null,equipo:E}),(await e.put(`/api/tareas/${k}`,{data:B})).data},w=async({id:k,data:E,user:L})=>{try{return(await e.put(`/api/tareas/${k}`,{data:{...E,updated_by:L==null?void 0:L.id}})).data}catch(B){console.error("Error updating the element:",B)}},j=async({id:k})=>{await M({id:k})},b=async({id:k,data:E,user:L})=>{await v({id:k,data:E,user:L})},{mutateAsync:v}=de.useMutation({mutationFn:w,onSuccess:()=>{r("Tarea actualizada correctamente");const k={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[k[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(E){console.error("Error invalidating queries:",E)}},onError:k=>{console.error("Failed to update the task.",k)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]})}}),{mutateAsync:M}=de.useMutation({mutationFn:c,onSuccess:()=>{const k={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[k[s],n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(E){console.error("Error updating the element:",E)}},onError:k=>{console.error("Failed to update the task.",k)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:F}=de.useMutation({mutationFn:f,onSuccess:()=>{const k={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{o.setQueryData([k[s],n],E=>{console.log({oldData:E})}),s==="kanban-general"&&(o.invalidateQueries({queryKey:[k[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(E){console.error("Error invalidating queries:",E)}},onError:k=>{console.error("Failed to update the task.",k)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:R}=de.useMutation({mutationFn:x,onSuccess:()=>{const k={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[k[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(E){console.error("Error invalidating queries:",E)}},onError:k=>{console.error("Failed to update the task.",k)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:C}=de.useMutation({mutationFn:y,onSuccess:()=>{const k={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[k[s],n]}),o.invalidateQueries({queryKey:["done_tasks",n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(E){console.error("Error invalidating queries:",E)}},onError:k=>{console.error("Failed to reassign the task.",k)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:I}=de.useMutation({mutationFn:m,onSuccess:()=>{const k={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[k[s],n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(E){console.error("Error updating the element:",E)}},onError:k=>{console.error("Failed to update the task.",k)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}});return{updatingTask:b,updateTask:w,startTask:async({id:k})=>{await I({id:k})},startWorking:j,completeTask:async({id:k,idAtraso:E})=>{await F({id:k,idAtraso:E})},reasignResponsible:async({id:k,idNewResponsible:E,typeOfSelect:L})=>{await C({id:k,idNewResponsible:E,typeOfSelect:L})},updateUnitys:async({repeats:k,id:E})=>{await R({repeats:k,id:E})},pauseTask:async({id:k,motiveId:E})=>{console.log({taksId:k,motivoId:E,user:t==null?void 0:t.id})},postPauseTask:p,postReanudeTask:h}};function ao(e,t){const n=t??0;return(e??"")!==""&&n===2&&n===2||!(e??"")}function so(e){const t=e.repeatsToDo;return t==null||t<=0?!1:(e.repeats??0)!==t}function Rt(e){return e.status===2||so(e)?!1:ao(e.nameRequiredTask,e.statusRequiredTask)}const Ae=({imageUrl:e="https://www.uv.unach.mx/assets/img/prueba/directorio/userM.png",alt:t="avatar",size:n="s"})=>{const s={xs:"tm-w-[24px] tm-h-[24px] tm-min-w-[24px] tm-min-h-[24px]",s:"tm-w-[28px] tm-h-[28px] tm-min-w-[28px] tm-min-h-[28px]",m:"tm-w-[32px] tm-h-[32px] tm-min-w-[32px] tm-min-h-[32px]",l:"tm-w-[36px] tm-h-[36px] tm-min-w-[36px] tm-min-h-[36px]",xl:"tm-w-[40px] tm-h-[40px] tm-min-w-[40px] tm-min-h-[40px]",xxl:"tm-w-[44px] tm-h-[44px] tm-min-w-[44px] tm-min-h-[44px]"}[n];return a.jsx("img",{src:e===""?"https://www.uv.unach.mx/assets/img/prueba/directorio/userM.png":e,alt:t??"avatar",className:`${s} tm-bg-surface-default tm-rounded-full tm-border-2 tm-border-default`})},ca=({trigger:e,user:t,showUser:n=!0})=>a.jsx(Ie,{trigger:e,enabled:n,children:a.jsxs("div",{className:"tm-flex tm-h-fit tm-w-fit tm-items-center tm-gap-2 tm-bg-bg-card tm-p-2",children:[a.jsx(Ae,{imageUrl:t.image??"",alt:t.name}),a.jsx("p",{className:"tm-text-sm tm-font-bold tm-text-texts-subtext",children:t.name})]})}),no=({options:e,onselect:t})=>{const[n,s]=u.useState(""),o=[...e].filter(i=>i.name.toLowerCase().includes(n.toLowerCase()));return a.jsxs("div",{className:"tm-h-fit tm-w-full tm-min-w-max",children:[a.jsx(g.Input,{size:"sm",fullWidth:!0,leftSlot:ne.faSearch,placeholder:"Buscar",value:n,onValueChange:s}),a.jsx("div",{className:"tm-border-cards tm-flex tm-max-h-[120px] tm-min-w-max tm-flex-col tm-gap-s tm-overflow-y-auto tm-rounded-lg tm-bg-bg-card tm-p-2 tm-mt-2",children:o.map(i=>a.jsxs("button",{type:"button",onClick:()=>{t(i)},className:"tm-flex tm-min-w-full tm-max-w-[200px] tm-cursor-pointer tm-items-center tm-gap-s hover:tm-bg-primary-light",children:[i.image&&a.jsx(Ae,{imageUrl:i.image,alt:i.name}),a.jsx("p",{className:"tm-min-w-0 tm-text-left tm-text-[14px] tm-truncate tm-py-m tm-font-normal tm-text-texts-subtext",children:i.name})]},i.id??i.name))})]})};class oo{static toDomain(t){return{id:t.id,name:t.nombre,color:t.color}}}const ro=()=>{const{tasks_api:e}=ge();return{teams:de.useQuery({queryKey:["teams","all"],queryFn:async()=>{const n=await e.get("/api/equipos");return xe(n.data).map(oo.toDomain)},refetchOnWindowFocus:!1})}};class qt{static toUsers(t){var n,s,o;return{id:t.id,name:t.nombre,image:(o=(s=(n=t.imagen)==null?void 0:n.formats)==null?void 0:s.thumbnail)==null?void 0:o.url,tasksUser:{email:t.tasksUser.email,id:t.tasksUser.id,nombre:t.tasksUser.nombre},role:t.role}}static toUsersV2(t){var n,s,o;return{id:t.id,name:t.nombre,image:(o=(s=(n=t.imagen)==null?void 0:n.formats)==null?void 0:s.thumbnail)==null?void 0:o.url,role:t.role}}static toUsersWithIndex(t){var s,o,i;const n={};for(const r of t)n[r.email]={...r,image:(i=(o=(s=r.imagen)==null?void 0:s.formats)==null?void 0:o.thumbnail)==null?void 0:i.url};return n}}const io=async({tasks_api:e})=>{try{const t=await e.get("/api/getAllOBPusersMembers");return xe(t.data).map(qt.toUsers)}catch(t){throw console.log("Error al obtener los usuarios comerciales",t),`Error al obtener los usuarios comerciales: ${t}`}},lo=async({tasks_api:e})=>{try{const t={filters:{$and:[{role:{name:{$in:["Project Manager","Operation Manager","Administrador"]}}},{blocked:{$eq:!1}}]}},n=Ce.stringify(t,{encodeValuesOnly:!0}),s=await e.get(`/api/users?${n}`),i=xe(s.data).map(d=>d.email),r=await e.get(`/api/getAllOBPusers?filters[name][$in]=${i}`);return xe(r.data).map(qt.toUsersV2)}catch(t){throw console.log("Error al obtener los usuarios comerciales",t),`Error al obtener los usuarios comerciales: ${t}`}},co=async({users:e})=>{try{const t=xe(e);return qt.toUsersWithIndex(t)}catch(t){throw console.log("Error al obtener los usuarios comerciales",t),`Error al obtener los usuarios comerciales: ${t}`}},mo=()=>{const{tasks_api:e}=ge();return{users:de.useQuery({queryKey:["users"],queryFn:()=>io({tasks_api:e}),staleTime:1e3*60*60*24})}},uo=()=>{const{tasks_api:e}=ge();return{users:de.useQuery({queryKey:["allUsers"],queryFn:()=>lo({tasks_api:e}),staleTime:1e3*60*60*24})}},da="Project Manager",Ka=({users:e,onClick:t,responsible:n,role:s,status:o})=>{const{getOBPUrlApi:i}=ge(),r=u.useRef(null),l=u.useRef(null),d=u.useId(),[c,m]=u.useState("team"),{teams:f}=ro(),{users:x}=mo(),p=s===da||o===0&&s!==da,h=()=>n?null:e.length>3&&a.jsx(Ie,{position:"top",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:a.jsx("div",{className:"tm-ml-[-8px] tm-flex tm-h-[32px] tm-w-[32px] tm-items-center tm-justify-center tm-rounded-full tm-border-2 tm-border-default tm-bg-surface-default",children:a.jsx(g.Text,{children:`+${e.length-3}`})}),children:a.jsx("div",{className:"tm-border-default tm-h-fit tm-w-fit tm-rounded-lg tm-bg-surface-default tm-p-8 tm-gap-8 tm-flex tm-flex-col",children:e==null?void 0:e.slice(3).map((b,v)=>a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8 ",children:[a.jsx(Ae,{imageUrl:b.image??"",alt:b.name},v),a.jsx(g.Text,{children:b.name})]},v))})}),y=()=>{if(n){const b=e.find(v=>v.id===n);return a.jsx("div",{children:p?a.jsx(g.Tooltip,{label:(b==null?void 0:b.name)??"",position:"top",children:a.jsx(Ae,{imageUrl:b==null?void 0:b.image,alt:b==null?void 0:b.name},n)}):a.jsx(ca,{trigger:a.jsx(Ae,{imageUrl:b==null?void 0:b.image,alt:b==null?void 0:b.name},n),user:b,showUser:!0})})}return(e==null?void 0:e.length)>0&&e.slice(0,3).map((b,v)=>a.jsx("div",{className:`${v===0?"":"tm-ml-[-8px]"}`,children:p?a.jsx(g.Tooltip,{label:b.name,position:"top",children:a.jsx(Ae,{imageUrl:b.image,alt:b.name})}):a.jsx(ca,{trigger:a.jsx(Ae,{imageUrl:b.image,alt:b.name}),user:b,showUser:!0})},b.id||v))},w=()=>{const b=[{id:"team",label:"Equipo"},{id:"responsible",label:"Responsable"}];return a.jsx("div",{className:"tm-flex tm-w-full tm-justify-center tm-gap-l tm-font-bold tm-text-texts-placeholder",children:b.map((v,M)=>a.jsx("button",{type:"button",className:`tm-w-full tm-border-texts-placeholder tm-text-center tm-text-[10px] ${c===v.id?"tm-text-primary-pastel":""} ${M===b.length-1?"tm-border-r-0":" tm-border-r-2"}`,onClick:()=>m(v.id),children:v.label},v.id))})},j=()=>a.jsxs("div",{className:"tm-border-cards tm-flex tm-max-h-[200px] tm-flex-col tm-gap-m tm-overflow-y-hidden tm-rounded-lg tm-bg-bg-card tm-p-2",style:{boxShadow:"0px 2px 16px 0px rgba(0, 0, 0, 0.25)"},children:[w(),a.jsx(no,{options:c==="team"?((f==null?void 0:f.data)??[]).map(b=>({id:b.id,name:b.name,image:""})):((x==null?void 0:x.data)??[]).map(b=>Lt(b,i())),onselect:b=>{var v,M;(v=l.current)==null||v.close(),t((M=b.tasksUser)==null?void 0:M.id,c)}})]});return e.length===0?p?a.jsxs(a.Fragment,{children:[a.jsx("span",{ref:r,className:"tm-inline-flex tm-cursor-pointer tm-items-center",children:a.jsx(g.Icon,{name:ne.faUser,size:"xs",color:"current"})}),a.jsx(g.Popover,{ref:l,triggerRef:r,position:"bottom-left",offset:8,closeOnClick:!1,closeOnClickOutside:!0,closeOnEscape:!0,popoverArrow:!1,popupId:`assign-users-${d}`,children:j()})]}):a.jsx("span",{className:"tm-inline-flex tm-items-center",children:a.jsx(g.Icon,{name:ne.faUser,size:"xs",color:"current"})}):a.jsxs(a.Fragment,{children:[a.jsxs("span",{ref:r,className:"tm-flex tm-cursor-pointer tm-items-center",children:[y(),h()]}),p&&a.jsx(g.Popover,{ref:l,triggerRef:r,position:"bottom-left",offset:8,closeOnClick:!1,closeOnClickOutside:!0,closeOnEscape:!0,popoverArrow:!1,popupId:`assign-users-avatars-${d}`,children:j()})]})},Ga=({priority:e,id:t,withLabel:n=!1})=>{const{updatingTask:s}=He(),o=u.useId().replace(/:/g,""),[i,r]=u.useState(null),{user:l}=je(),[d,c]=u.useState(e);u.useEffect(()=>{c(e)},[e]);const m={0:{title:"Normal",color:"brand"},1:{title:"Baja",color:"success"},2:{title:"Media",color:"warning"},3:{title:"Alta",color:"danger"}},f={title:"Sin prioridad",color:"primary"},p=(()=>{const j=d;if(typeof j!="number"||!Number.isFinite(j))return f;const b=Math.trunc(j);return b<0||b>3?f:m[b]??f})(),h=p.title??"Sin prioridad",y=()=>{if(!i)return null;const j=({priorityTask:b,text:v})=>{var M,F;return a.jsxs("button",{onClick:async()=>{r(null),await s({id:t,data:{prioridad:b},user:l==null?void 0:l.id}),c(b)},className:"tm-flex tm-items-center tm-gap-m tm-px-l tm-py-s hover:tm-bg-primary-light",children:[a.jsx(g.Icon,{name:ne.faFlag,size:"xs",style:{color:(M=m[b??0])==null?void 0:M.color},color:"current"}),a.jsx("p",{className:"tm-text-sm",style:{color:(F=m[b??0])==null?void 0:F.color},children:v})]})};return Sa.createPortal(a.jsx("div",{onBlur:()=>{r(null)},id:`${o}-options`,style:{top:`${i.y+5}px`,left:`${i.x+5}px`,zIndex:50},className:`tm-absolute tm-flex tm-h-fit tm-w-max tm-flex-col tm-gap-2 tm-rounded-xl tm-bg-bg-card tm-p-m
|
|
2
|
+
tm-shadow-02`,"data-portal-host":!0,children:Object.values(m).map((b,v)=>a.jsx(j,{priorityTask:v,text:b.title},v))}),document.body)},w=j=>{j.stopPropagation()};return a.jsxs("div",{className:"tm-relative",onClick:w,onPointerDown:w,children:[a.jsxs("label",{onBlur:()=>{r(null)},htmlFor:o,className:"tm-flex tm-cursor-pointer tm-items-center tm-gap-2 active:tm-opacity-50",children:[a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faFlag,size:"sm",style:{color:p.color},color:"current"}),children:a.jsx("div",{className:"tm-px-8 tm-py-4",children:a.jsx(g.Text,{color:p.color,children:`Prioridad: ${h}`})})}),n&&a.jsx("span",{style:{color:p.color},className:"tm-text-lg tm-font-normal",children:h})]}),a.jsx("button",{id:o,onClick:j=>{j.stopPropagation(),r(i?null:{x:j.clientX,y:j.clientY})},className:"tm-hidden"}),a.jsx(y,{})]})};function po(e,t){return((e==null?void 0:e.map(s=>{var o;return{id:s.id,nombre:s.motivo_imj??"",categoria:(o=s.categoria)==null?void 0:o.nombre}}).filter(s=>s.categoria===t))??[]).filter(s=>typeof s.id=="number"&&!Number.isNaN(s.id)&&s.nombre.length>0).map(s=>({id:s.id,nombre:s.nombre}))}function fo(e){return e.map(t=>({id:t.id,label:t.nombre}))}const Re={TO_SECOND:"task-move-first-to-second",TO_THIRD:"task-move-first-to-third",TO_FOURTH:"task-move-first-to-fourth"};function go(e,t){const n=[];return e===0&&n.push({id:Re.TO_SECOND,label:"Mover a trabajando",icon:Ne.faArrowRight}),e===1&&n.push({id:Re.TO_SECOND,label:"Mover a completada",icon:Ne.faArrowRight},{id:Re.TO_FOURTH,label:"Mover por hacer",icon:Ne.faArrowLeft}),t?n.push({id:Re.TO_THIRD,label:"Eliminar atraso"}):n.push({id:Re.TO_THIRD,label:"Agregar atraso"}),n}function ho(e){return e===0?{title:"Mover a trabajando"}:{title:"Mover a completada"}}function xo(){return{title:"Mover a por hacer"}}function ma({copy:e,onMove:t}){return a.jsxs("div",{className:"tm-flex tm-h-fit tm-w-max tm-max-w-[280px] tm-translate-x-0 tm-flex-col tm-gap-3 tm-rounded-lg tm-bg-bg-card tm-p-l tm-shadow-02 tm-transition-all tm-duration-200 tm-ease-in-out",children:[a.jsx("p",{className:"tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_medium",children:e.title}),a.jsx(g.Button,{type:"button",fullWidth:!0,size:"xs",color:"primary",onClick:t,children:"Mover"})]})}const bo=({status:e,nameRequiredTask:t,statusRequiredTask:n,id:s,statusLateTask:o=null,projectID:i,atrasoId:r,categoria:l,disabled:d=!1})=>{const c=u.useRef(null),m=u.useRef(null),f=u.useRef(null),{startWorking:x,completeTask:p,startTask:h}=He(),y=u.useRef(!1),[w,j]=u.useState(!1),[b,v]=u.useState(null),[M,F]=u.useState("first"),R=t!==""&&n===2,[C,I]=u.useState(null),{atrasoReasons:T,isLoading:V,createAtraso:z,deleteAtraso:ee}=Ha({enabled:!0}),[G,k]=u.useState(null),E=u.useCallback(()=>{var P;(P=c.current)==null||P.close()},[]);u.useEffect(()=>{o&&F("third")},[o]),u.useEffect(()=>{if(!w)return;const P=()=>{E()};return window.addEventListener("scroll",P,!0),document.addEventListener("scroll",P,!0),()=>{window.removeEventListener("scroll",P,!0),document.removeEventListener("scroll",P,!0)}},[w,E]);const L=P=>{F(P),P==="second"?v(e===0?"Trabajando":"Completadas"):P==="fourth"&&v("Por hacer")},B=()=>{if(y!=null&&y.current)return a.jsx("div",{className:"tm-hover:bg-primary-light tm-flex tm-h-fit tm-w-max tm-translate-x-0 tm-items-center tm-gap-2 tm-rounded-lg tm-bg-bg-card tm-p-l tm-shadow-02 tm-transition-all tm-duration-200 tm-ease-in-out",children:a.jsx("p",{className:"tm-font-regular tm-text-sm tm-font-normal tm-text-primary-pastel",children:"Moviendo..."})});const P=go(e,r);return a.jsx("div",{className:"tm-flex tm-h-fit tm-w-max tm-translate-x-0 tm-flex-col tm-gap-3 tm-rounded-lg tm-bg-bg-card tm-p-l tm-shadow-02 tm-transition-all tm-duration-200 tm-ease-in-out",children:a.jsx(g.ListBase,{variant:"default",list:{items:P},events:{onItemClick:$=>{switch($.id){case Re.TO_SECOND:L("second");break;case Re.TO_THIRD:L("third");break;case Re.TO_FOURTH:L("fourth");break}}}})})},q=()=>a.jsx(ma,{copy:ho(e),onMove:()=>{y.current=!0,b==="Trabajando"?x({id:s}):b==="Por hacer"?h({id:s}):p({id:s,idAtraso:r}),E()}}),X=()=>{if(V)return a.jsx("div",{children:"Cargando motivos..."});const P=po(T,l==null?void 0:l.nombre),$=fo(P);return P.length>0?a.jsxs("div",{className:"tm-flex tm-h-fit tm-w-[288px] tm-translate-x-0 tm-flex-col tm-gap-3 tm-rounded-lg tm-bg-bg-card tm-p-l tm-shadow-02 tm-transition-all tm-duration-200 tm-ease-in-out",children:[!C&&!r?a.jsxs(a.Fragment,{children:[a.jsx("p",{className:"tm-mb-[11px] tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_regular",children:"Atraso de tarea"}),a.jsx(g.Dropdown,{field:{placeholder:"Seleccione una opción"},items:{options:$,idName:"id"},values:{value:(G==null?void 0:G.id)??""},menuSearch:{searchable:!0,searchPlaceholder:"Buscar"},popover:{absolute:!1,closeOnClickOutside:!0,dropdownId:`task-atraso-motivo-${s}`,popoverZIndex:1200},events:{onValueChange:Q=>{const D=Number(Q);if(Number.isNaN(D))return;const A=P.find(K=>K.id===D);k({id:D,nombre:(A==null?void 0:A.nombre)??""})},onOptionSelect:Q=>{const D=Q.id;D==null||Number.isNaN(Number(D))||k({id:Number(D),nombre:String(Q.label??"")})}}})]}):a.jsxs(a.Fragment,{children:[a.jsx("p",{className:"tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_medium",children:"¿Estas seguro?"}),a.jsx("p",{className:"tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_medium",children:r?"Estás eliminando el atraso de la tarea seleccionada":`Esta tarea está atrasada debido a ${(C==null?void 0:C.nombre)??""}`})]}),a.jsxs("div",{className:"tm-my-[11px] tm-flex tm-justify-end tm-gap-3",children:[a.jsx(g.Button,{type:"button",size:"xs",color:"secondary",onClick:()=>{C?I(null):E()},children:C?"Regresar":"Cancelar"}),a.jsx(g.Button,{type:"button",size:"xs",color:"primary",onClick:()=>{I(G),r&&!C?ee(r):C&&Y()},children:"Aceptar"})]})]}):a.jsx("div",{className:"tm-flex tm-h-fit tm-w-[288px] tm-translate-x-0 tm-flex-col tm-gap-3 tm-rounded-lg tm-bg-bg-card tm-p-l tm-shadow-02 tm-transition-all tm-duration-200 tm-ease-in-out",children:"No hay motivos de atraso para ésta tarea"})},H=()=>a.jsx(ma,{copy:xo(),onMove:()=>{y.current=!0,h({id:s}),E()}}),re=()=>{if(M==="first")return B();if(M==="second")return q();if(M==="third")return X();if(M==="fourth")return H()},Y=async()=>{if(G)try{await z({taskId:s,projectID:i,motivo:(G==null?void 0:G.id)??null}),E()}catch(P){console.error("Error al crear atraso:",P)}};return a.jsx(a.Fragment,{children:(R&&n===2||!t)&&a.jsxs(a.Fragment,{children:[a.jsx(g.Button,{ref:m,type:"button","aria-label":"Más opciones para mover la tarea",color:"secondary",pill:"pill",size:"xxs",icon:Ne.faEllipsis,disabled:d}),a.jsx(g.Popup,{ref:c,triggerRef:m,popupId:`task-move-menu-${s}`,position:"bottom-right",offset:1,closeOnClick:!1,closeOnClickOutside:!1,popoverArrow:!1,onOpen:()=>{j(!0),F("first")},onClose:()=>j(!1),children:a.jsx("div",{ref:f,className:`
|
|
3
3
|
tm-ease tm-transition-all tm-duration-300
|
|
4
4
|
${M==="second"?"":"tm-translate-x-0"}
|
|
5
|
-
`,children:re()})})]})})},bo=({id:e,idAtraso:a})=>{const[n,s]=u.useState(!1),{completeTask:o}=He();return{checked:n,checkTask:()=>{s(!n),o({id:e,idAtraso:a})}}},ma={checked:"tm-mx-[2px] tm-flex tm-h-[20px] tm-w-[20px] tm-items-center tm-justify-center tm-rounded-full tm-bg-success-regular tm-transition-all",unchecked:"tm-transition-colors"},yo="tm-mx-[2px] tm-flex tm-items-center tm-justify-center tm-rounded-full tm-bg-success-regular tm-transition-all",ua="tm-text-sm tm-flex tm-w-fit tm-max-w-[400px] tm-flex-col tm-gap-m tm-rounded-lg tm-border-l-[5px] tm-border-warning-regular tm-bg-warning-light tm-p-l tm-text-warning-dark tm-shadow-xl",Ga=({id:e,nameRequiredTask:a,statusRequiredTask:n,status:s,idAtraso:o,nameRequiredTaskResponsible:i,name_father_required_task:r,name_father_required_task_responsible:c,repeatsAreCompleted:m=!1})=>{const l=u.useId(),d=`checkbox-${e}-${l}`,{checked:p,checkTask:h}=bo({id:e,idAtraso:o}),g=!!(a&&a!==""&&n===2)||!a,y=!!r,w=s===1&&m,j=()=>t.jsx("label",{htmlFor:d,className:p?ma.checked:ma.unchecked,children:p?t.jsx(x.Icon,{name:ne.faCheck,size:"xs",style:{color:"white"},color:"current"}):t.jsx(x.Icon,{name:ne.faCircle,size:"sm",style:{color:ge.texts.placeholder},color:"current"})});return s===2?t.jsx("div",{className:yo,children:t.jsx(x.Icon,{name:de.faCircleCheck,size:"xs",style:{color:"white"},color:"current"})}):y?t.jsxs(t.Fragment,{children:[t.jsxs("div",{className:"tm-flex tm-w-fit tm-shrink-0 tm-flex-row tm-flex-nowrap tm-items-center tm-gap-1",children:[t.jsx(Ie,{position:"bottom",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:t.jsx("span",{className:"tm-cursor-help tm-inline-flex","aria-hidden":!0,children:t.jsx(x.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:ge.warning.regular},color:"current"})}),children:t.jsxs("div",{className:ua,children:[t.jsx("p",{className:"tm-w-[210px] tm-font-bold",children:"Tarea padre:"}),t.jsx("p",{children:r}),c&&t.jsxs("p",{className:"tm-font-bold",children:["Responsable:"," ",t.jsx("span",{className:"tm-font-normal",children:c})]}),t.jsx("span",{className:"tm-font-normal tm-italic tm-text-[#919191]",children:"Esta tarea completa automáticamente la tarea padre."})]})}),w&&j()]}),t.jsx("input",{id:d,checked:p,onChange:h,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]}):g?t.jsxs(t.Fragment,{children:[s===1&&j(),t.jsx("input",{id:d,checked:p,onChange:h,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]}):t.jsxs(t.Fragment,{children:[t.jsx(Ie,{position:"bottom",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:t.jsx("span",{className:"tm-cursor-help tm-inline-flex","aria-hidden":!0,children:t.jsx(x.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:ge.warning.regular},color:"current"})}),children:t.jsxs("div",{className:ua,children:[t.jsx("p",{className:"tm-w-[210px] tm-font-bold",children:"Requiere completar su tarea:"}),t.jsx("p",{children:a}),i&&t.jsxs("p",{className:"tm-font-bold",children:["Responsable: ",t.jsx("span",{className:"tm-font-normal",children:i})]})]})}),t.jsx("input",{id:d,checked:p,onChange:h,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]})};function jo({items:e}){var s;const[a,n]=u.useState(1);return t.jsxs(t.Fragment,{children:[t.jsx("div",{className:"tm-mb-2 tm-mt-4 tm-flex tm-flex-row tm-border-b tm-border-black-light tm-bg-white",children:e.map((o,i)=>t.jsx("div",{className:"tm-border-r tm-border-black-light",children:t.jsx(x.Button,{color:"tertiary",pill:"none",size:"xs",active:a===o.id,onClick:()=>n(o.id),children:o.label},o.id)},o.id))}),t.jsx("div",{className:"tm-flex-1 tm-overflow-y-auto tm-bg-white tm-pt-4",children:(s=e.find(o=>o.id===a))==null?void 0:s.component})]})}function wo({comment:e}){var o,i,r,c,m;const{getImageOBP:a}=he(),n=(c=(r=(i=(o=e==null?void 0:e.autor)==null?void 0:o.imagen)==null?void 0:i.formats)==null?void 0:r.thumbnail)==null?void 0:c.url;function s(l){const d=ct.parseISO(l);return ct.formatDistanceToNow(d,{locale:Pt.es,addSuffix:!0})}return t.jsx("div",{children:t.jsxs("div",{className:"tm-flex tm-flex-row tm-items-start tm-gap-3",children:[t.jsx(Ae,{size:"xxl",imageUrl:n?a(n):"",alt:"@shadcn"}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-4",children:[t.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-4",children:[t.jsx(x.Text,{type:"title",size:"sm",weight:"medium",color:"secondary",children:(m=e==null?void 0:e.autor)==null?void 0:m.nombre}),t.jsx(x.Text,{children:s(e==null?void 0:e.createdAt)})]}),t.jsx(x.Text,{children:e==null?void 0:e.comentario})]})]})})}function vo({currentUser:e,data:a,taskId:n,onNewComment:s}){var f,g,y;const{tasks_api:o,getImageOBP:i}=he(),{control:r,handleSubmit:c,reset:m}=Se.useForm({defaultValues:{comment:""}}),[l,d]=u.useState([]),p=(y=(g=(f=e==null?void 0:e.imagen)==null?void 0:f.formats)==null?void 0:g.thumbnail)==null?void 0:y.url;u.useEffect(()=>{if(a!=null&&a.comentarios){const w=[...a.comentarios].sort((j,b)=>new Date(b.createdAt).getTime()-new Date(j.createdAt).getTime());d(w)}},[a]);const h=async w=>{try{const j={id:Date.now(),autor:{id:e==null?void 0:e.id,email:e==null?void 0:e.email,nombre:e==null?void 0:e.nombre,imagen:e==null?void 0:e.imagen},comentario:w.comment,createdAt:new Date().toISOString(),updatedAt:null};await o.post("/api/comentarios",{data:{autor:e==null?void 0:e.id,comentario:w.comment,tarea:n}}),s(!0),d(b=>[j,...b]),m()}catch(j){console.error("Error al agregar comentario:",j)}};return t.jsxs("div",{className:"tm-flex tm-h-full tm-flex-col tm-gap-4",children:[t.jsxs("form",{onSubmit:c(h),className:"tm-flex tm-flex-row tm-items-center tm-gap-3",children:[t.jsx(Ae,{size:"xxl",imageUrl:p?i(p):"",alt:"@shadcn"}),t.jsx("div",{className:"tm-min-w-0 tm-flex-1",children:t.jsx(Se.Controller,{name:"comment",control:r,rules:{required:"Escribe un comentario"},render:({field:w,fieldState:{error:j}})=>t.jsx(x.Input,{fullWidth:!0,placeholder:"Escribe un comentario",autoComplete:"off",size:"xs",error:j==null?void 0:j.message,...w,value:w.value??""})})})]}),l&&l.map((w,j)=>t.jsx(wo,{comment:w},j))]})}function _o({data:e}){const a={0:{color:"tm-bg-gray-400",label:"Sin estado"},1:{color:"tm-bg-primary-regular",label:"En curso"},2:{color:"tm-bg-success-regular",label:"Finalizada"},3:{color:"tm-bg-success-regular",label:"Finalizada"}},n=s=>s?ct.format(new Date(s),"d MMM",{locale:Pt.es}):"";return t.jsxs("div",{children:[t.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-4",children:[t.jsx(x.Text,{children:"Tareas dependientes"}),t.jsx(x.Text,{className:"tm-flex tm-h-24 tm-w-24 tm-items-center tm-justify-center tm-rounded-full tm-bg-[#E1EBF9] tm-text-xs tm-font-normal tm-text-primary",children:e==null?void 0:e.length})]}),t.jsx("div",{className:"tm-mt-3 tm-flex tm-flex-col tm-gap-2 tm-rounded-lg tm-border tm-border-light-gray-100",children:e==null?void 0:e.map(s=>{var o,i,r,c,m;return t.jsxs("div",{className:"tm-flex tm-w-full tm-flex-row tm-items-center tm-justify-between tm-gap-s tm-px-2 tm-py-1",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2",children:[t.jsx(Ae,{imageUrl:(c=(r=(i=(o=s.responsable)==null?void 0:o.image)==null?void 0:i.formats)==null?void 0:r.thumbnail)==null?void 0:c.url}),t.jsx(x.Text,{children:s==null?void 0:s.texto_corto})]}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-1",children:[t.jsx(x.Text,{children:n(s==null?void 0:s.createdAt)}),t.jsx("div",{className:`tm-block tm-h-4 tm-w-4 tm-rounded-full tm-bg-gray-400 ${((m=a[s==null?void 0:s.estatus])==null?void 0:m.color)??"tm-bg-gray-400"}`})]})]},s.id)})})]})}function To({id:e,texto_largo:a,user_id:n}){const[s,o]=u.useState(a),{updatingTask:i}=He(),r=async()=>{await i({id:e,data:{texto_largo:s},user:n})};return u.useEffect(()=>{o(a)},[a]),t.jsx("div",{className:"tm-mt-16 tm-flex tm-w-full tm-flex-col tm-gap-3",children:t.jsx(x.Input,{fullWidth:!0,label:"Descripción",size:"md",value:s,onChange:c=>o(c.target.value),onBlur:r,autoComplete:"off",placeholder:"Agregar descripción"})})}function Va({isOpen:e,setIsOpen:a,taskId:n}){var j,b,_,M,F,R,N,D,v;const[s,o]=u.useState(null),[i,r]=u.useState(!1),[c,m]=u.useState(!1),[l,d]=u.useState(null),p=(M=(_=(b=(j=s==null?void 0:s.responsable)==null?void 0:j.imagen)==null?void 0:b.formats)==null?void 0:_.thumbnail)==null?void 0:M.url,{tasks_api:h,getImageOBP:f}=he(),{user:g}=we();u.useEffect(()=>{if(e&&n||i){const U=async()=>{const J=await h.get(`/api/detalleTarea/${n}`);o(J==null?void 0:J.data)},K=async()=>{const J=await h.get(`/api/users/${g.id}`);d(J==null?void 0:J.data)};U(),K()}},[e,n,i,g.id,h]);const y=U=>U?ct.format(U,"d MMM yyyy, h:mmaaa",{locale:Pt.es}):"Fecha no disponible",w=[{id:1,label:"Todo",component:t.jsx(vo,{taskId:n,currentUser:l,data:s,onNewComment:r})},{id:2,label:"Dependencias",component:t.jsx(_o,{data:s==null?void 0:s.ids_t_dependientes})}];return e&&Na.createPortal(t.jsxs(t.Fragment,{children:[t.jsx("div",{className:`tm-fixed tm-inset-0 tm-z-20 tm-flex tm-items-center tm-justify-center tm-bg-transparent tm-bg-opacity-50 ${e?"tm-pointer-events-auto tm-block":"tm-pointer-events-none tm-hidden"}`,onClick:()=>a(!1)}),t.jsx("section",{className:`tm-fixed tm-bottom-0 tm-top-0 tm-z-50 tm-flex tm-h-screen tm-w-[550px] tm-items-center tm-justify-center tm-overflow-hidden tm-bg-white tm-bg-opacity-50 tm-shadow-2xl tm-transition-all tm-duration-500 tm-ease-in-out ${e?"tm-pointer-events-auto tm-right-0 tm-block":"tm-pointer-events-none tm-right-[-100%] tm-hidden"}`,children:t.jsxs("div",{className:"tm-flex tm-h-full tm-w-full tm-flex-col tm-overflow-y-scroll tm-border-none tm-bg-white tm-p-16 tm-shadow-xl",children:[t.jsxs("div",{className:"tm-flex tm-w-full tm-flex-row tm-items-center tm-justify-between tm-gap-10 tm-border-none tm-pb-4",children:[t.jsxs("div",{className:"tm-relative tm-flex tm-flex-row tm-items-start tm-gap-8",children:[((F=s==null?void 0:s.id_t_requerida)==null?void 0:F.id)&&t.jsxs(t.Fragment,{children:[t.jsx("div",{className:"tm-cursor-help",onMouseOver:()=>m(!0),onMouseLeave:()=>m(!1),children:t.jsx(x.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:ge.warning.regular},color:"current"})}),c&&(()=>{var K;const U=at(s==null?void 0:s.id_t_requerida);return t.jsxs("div",{style:{top:"25px"},className:"tm-absolute tm-flex tm-w-fit tm-max-w-[400px] tm-flex-col tm-gap-m tm-rounded-lg tm-border-l-[5px] tm-border-warning-regular tm-bg-warning-light tm-p-l tm-text-xs tm-text-warning-dark",children:[t.jsx("p",{className:"tm-font-bold",children:"Requiere completar su tarea:"}),t.jsx("p",{className:"tm-text-2xl tm-font-normal tm-text-neutral-600",children:(K=s==null?void 0:s.id_t_requerida)==null?void 0:K.texto_corto}),U&&t.jsxs("p",{className:"tm-font-bold",children:["Responsable: ",t.jsx("span",{className:"tm-font-normal",children:U})]})]})})()]}),t.jsx("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-8",children:t.jsxs("h3",{className:"tm-text-base tm-font-semibold tm-text-neutral-900",children:[s==null?void 0:s.texto_corto,(s==null?void 0:s.atraso)&&t.jsx(x.Tooltip,{label:(R=s==null?void 0:s.atraso)==null?void 0:R.motivo,position:"bottom",children:t.jsx("button",{className:"tm-ml-2 tm-inline-block tm-h-fit tm-align-middle",children:t.jsx(x.Icon,{name:ne.faTriangleExclamation,size:"md",style:{color:ge.warning.dark},color:"current"})})})]})})]}),t.jsx(x.Button,{color:"secondary",pill:"pill",size:"xs",onClick:()=>a(!1),icon:ne.faXmark})]}),t.jsx("div",{className:"tm-mt-6 tm-flex tm-w-full tm-flex-row tm-justify-between",children:t.jsxs("span",{className:"tm-text-xs tm-text-light-gray-700",children:[s==null?void 0:s.campania," / ",s==null?void 0:s.nombre_medio]})}),t.jsx(To,{id:n,texto_largo:s==null?void 0:s.texto_largo,user_id:g.id}),t.jsx(x.Accordion,{id:`details-task-detalles-${n}`,title:"Detalles",defaultOpen:!0,className:"tm-mt-6 tm-w-full",headerClassName:"tm-border-b tm-border-black-light tm-pb-4",children:t.jsxs("div",{className:"tm-gap-xy-details tm-grid tm-w-full tm-grid-cols-3 tm-p-4",children:[t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Responsable"}),(N=s==null?void 0:s.responsable)!=null&&N.nombre?t.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-8",children:[t.jsx(Ae,{size:"xxl",imageUrl:p?f(p):"",alt:"@shadcn"}),t.jsx(x.Text,{children:(D=s==null?void 0:s.responsable)==null?void 0:D.nombre})]}):t.jsx(x.Text,{children:"Sin responsable"})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Equipo asignado"}),t.jsx("div",{className:"tm-flex tm-flex-row tm-gap-8",children:t.jsx(x.Text,{children:((v=s==null?void 0:s.equipo)==null?void 0:v.nombre)??"Sin equipo"})})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Prioridad"}),t.jsx(Ha,{priority:parseInt(s==null?void 0:s.prioridad)||0,id:n,withLabel:!0})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Lista"}),t.jsx("div",{className:"tm-flex tm-flex-row tm-gap-8",children:t.jsx(x.Text,{children:(s==null?void 0:s.lista)??"Sin lista"})})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Fecha estimada de inicio"}),t.jsx(x.Text,{children:y(s==null?void 0:s.f_inicio_estimada)})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Fecha estimada de fin"}),t.jsx(x.Text,{children:y(s==null?void 0:s.f_fin_estimada)})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Fecha de fin"}),t.jsx(x.Text,{children:y(s==null?void 0:s.ffin)})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Creado"}),t.jsx(x.Text,{children:y(s==null?void 0:s.createdAt)})]}),t.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[t.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Última modificación"}),t.jsx(x.Text,{children:y(s==null?void 0:s.updatedAt)})]})]})}),t.jsx(jo,{items:w})]})})]}),document.body)}class Co{static toPauseReasons(a){return{id:a.id,motivo_imj:a.motivo_imj}}}const No=async({tasks_api:e})=>{try{const a=await e.get("/api/motivos");return be(a.data).map(Co.toPauseReasons)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},So=()=>{const{tasks_api:e}=he();return{pauseReasons:me.useQuery({queryKey:["pause_task_reasons"],queryFn:()=>No({tasks_api:e}),staleTime:1e3*60*60*24})}};class Eo{static toKanbanTasks(a){var i,r,c,m,l,d,p,h,f,g,y,w,j;const n=at(a==null?void 0:a.id_t_requerida),s=at(a==null?void 0:a.tarea_padre);let o=[];return a!=null&&a.responsable&&o.push({id:a.responsable.id,name:a.responsable.nombre,image:(l=(m=(c=(r=(i=a.responsable)==null?void 0:i.userOBP)==null?void 0:r.imagen)==null?void 0:c.formats)==null?void 0:m.thumbnail)==null?void 0:l.url,role:((d=a.responsable.userOBP)==null?void 0:d.role)||{id:0,name:""}}),(p=a==null?void 0:a.equipo)!=null&&p.miembros&&a.equipo.miembros.forEach(b=>{var _,M,F,R,N;o!=null&&o.find(D=>D.id===b.idUser.id)||b.idUser&&o.push({id:b.idUser.id,name:b.idUser.nombre,image:(R=(F=(M=(_=b==null?void 0:b.userOBP)==null?void 0:_.imagen)==null?void 0:M.formats)==null?void 0:F.thumbnail)==null?void 0:R.url,role:((N=b.userOBP)==null?void 0:N.role)||{id:0,name:""}})}),{paused:a==null?void 0:a.pausada,repeats:a==null?void 0:a.repeticiones_realizadas,repeatsToDo:a==null?void 0:a.repeticiones,comments:0,nameProject:(h=a==null?void 0:a.proyecto)==null?void 0:h.nombre,idProject:(f=a==null?void 0:a.proyecto)==null?void 0:f.id,willBePaused:a.es_pausable,difficulty:a.nivel_dificultad,endDate:new Date(a.ffin),id:a.id,priority:a.prioridad??0,status:a.estatus,task:a.texto_corto,users:o,responsible:((g=a==null?void 0:a.responsable)==null?void 0:g.id)??null,name_father_required_task:((y=a==null?void 0:a.tarea_padre)==null?void 0:y.texto_corto)??null,name_father_required_task_responsible:s,statusRequiredTask:((w=a.id_t_requerida)==null?void 0:w.estatus)??null,nameRequiredTask:((j=a.id_t_requerida)==null?void 0:j.texto_corto)??null,nameRequiredTaskResponsible:n,medioName:(a==null?void 0:a.nombre_medio)??null,atraso:(a==null?void 0:a.atraso)??null,categoria:(a==null?void 0:a.categoria)??null,...(a==null?void 0:a.cambio_arte)&&{cambio_arte:a==null?void 0:a.cambio_arte}}}}const dt=async({filters:e,tasks_api:a})=>{try{const s=(await a.get("/api/listado_tareas?populate=*",{params:{...e,cancelada:!1}})).data.tareas.map(be),o=new Set;if(s.forEach(i=>{var r;(r=i==null?void 0:i.id_t_requerida)!=null&&r.id&&o.add(i.id_t_requerida.id)}),o.size>0){const i=Array.from(o),r=Pe.stringify({filters:{id:{$in:i}},populate:{responsable:{fields:["id","nombre"]},equipo:{fields:["id","nombre"]}}},{encodeValuesOnly:!0});try{const c=await a.get(`/api/tareas?${r}`),m=be(c.data.data||c.data),l=Array.isArray(m)?m:[m],d=new Map(l.map(p=>[p.id,p]));s.forEach(p=>{var h;if((h=p==null?void 0:p.id_t_requerida)!=null&&h.id){const f=d.get(p.id_t_requerida.id);f&&(p.id_t_requerida={...p.id_t_requerida,responsable:f.responsable||null,equipo:f.equipo||null})}})}catch{}}return s.map(Eo.toKanbanTasks)}catch(n){throw console.log({error:n}),`Error al obtener las tareas: ${n}`}},qt=30,zt=e=>{var a;if(e!=null&&e.hasNextPage){const n=(a=e==null?void 0:e.data)==null?void 0:a.pages[e.data.pages.length-1];(n==null?void 0:n.length)===qt&&(e==null||e.fetchNextPage())}},$e=e=>({pagination:{page:e,pageSize:qt,withCount:!0}}),Wa=()=>{var l;const e=me.useQueryClient(),{tasks_api:a}=he(),{user:n}=we(),{filters:s}=De(),[o,i]=u.useState(0),[r,c]=u.useState({owner:{user:n.id,config:((l=s==null?void 0:s.owner)==null?void 0:l.config)??"yo_y_mis_equipos",role:n.role},status:"por_hacer"}),m=me.useInfiniteQuery({initialPageParam:1,queryKey:["to_do_tasks",r],queryFn:({pageParam:d})=>dt({filters:{...r,status:"por_hacer",...$e(d)},tasks_api:a}),staleTime:1e3*60*60*24,getNextPageParam:(d,p)=>p.length+1});return u.useEffect(()=>{var d;Object.keys(s).length>0&&c({...s,owner:{user:n.id,config:((d=s==null?void 0:s.owner)==null?void 0:d.config)??"yo_y_mis_equipos",role:n.role},status:"por_hacer"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["to_do_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const p=await a.get("/api/listado_tareas",{params:{...r,status:"por_hacer",cancelada:!1,...$e(1),tasks_api:a,justCount:!0}});i(p.data.total)})()},[r,m==null?void 0:m.data]),{toDoTasks:m,total:o,filtersToSend:r}};function Po(e){return(e??[]).map(a=>({id:a.id,label:a.motivo_imj}))}const Ao=({idTask:e,setOpen:a,paused:n})=>{const s=me.useQueryClient(),{toDoTasks:o,filtersToSend:i}=Wa(),[r,c]=u.useState(!1),[m,l]=u.useState(null),{tasksProject:d}=Je(),{postPauseTask:p,postReanudeTask:h}=He(),{pauseReasons:f}=So(),g=Po(f==null?void 0:f.data),y=async()=>{try{if(m==null)return;if(a(!1),await p({id:e,motiveId:m}),await s.invalidateQueries({queryKey:["to_do_tasks",i]}),await s.invalidateQueries({queryKey:["tasksProject"]}),o&&typeof o.refetch=="function"||d&&typeof d.refetch=="function"){const j=await o.refetch(),b=await d.refetch();return[j,b]}}catch(j){console.error("Error al pausar la tarea:",j)}},w=async()=>{try{if(a(!1),await h({id:e}),await s.invalidateQueries({queryKey:["to_do_tasks",i]}),await s.invalidateQueries({queryKey:["tasksProject"]}),o&&typeof o.refetch=="function"||d&&typeof d.refetch=="function"){const j=await o.refetch(),b=await d.refetch();return[j,b]}}catch(j){console.error("Error al reanudar la tarea:",j)}};return t.jsx("div",{className:"tm-flex tm-w-[300px] tm-max-w-[300px] tm-items-center !tm-p-4",children:t.jsxs("div",{className:"tm-flex tm-w-full tm-flex-col tm-gap-s ",children:[t.jsx("h6",{className:"tm-font-regular tm-text-texts-subtext tm-truncate tm-text-xl",children:"Pausar tarea:"}),r?t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-s",children:[t.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"Esta acción detendrá la campaña en curso."}),t.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"¿Estás seguro de continuar?"})]}):n?t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-s",children:[t.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"Esta acción reanudará la campaña en curso."}),t.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"¿Estás seguro de continuar?"})]}):t.jsx(x.Dropdown,{field:{placeholder:"Selecciona una razón"},items:{options:g,idName:"id"},values:{value:m??""},menuSearch:{searchable:!0,searchPlaceholder:"Buscar"},popover:{absolute:!1,closeOnClickOutside:!0,dropdownId:`task-pause-motivo-${e}`,popoverZIndex:1200},events:{onValueChange:j=>{const b=Number(j);Number.isNaN(b)||l(b)},onOptionSelect:j=>{const b=Number(j.id);Number.isNaN(b)||l(b)}}}),t.jsxs("div",{className:"tm-mt-5 tm-flex tm-w-full tm-justify-end tm-gap-m",children:[t.jsx(x.Button,{type:"button",onClick:()=>a(!1),size:"xs",color:"secondary",children:"Cancelar"}),n?t.jsx(x.Button,{type:"button",onClick:()=>w(),size:"xs",color:"primary",children:"Si, reanudar"}):t.jsx(x.Button,{type:"button",disabled:!m,onClick:()=>r?y():c(!0),size:"xs",color:"primary",children:"Aceptar"})]})]})})},Qa=({idTask:e,paused:a,popupId:n,children:s})=>{const o=u.useRef(null),i=u.useRef(null),[r,c]=u.useState(!1),[m,l]=u.useState(0),d=`task-pause-motivo-${e}`,p=u.useCallback(()=>{var h;(h=o.current)==null||h.close()},[]);return u.useEffect(()=>{if(!r)return;const h=f=>{const g=f.target;g instanceof Element&&(g.closest(`[data-popup-id="${n}"]`)||g.closest(`[data-dropdown-id="${d}"]`))||p()};return window.addEventListener("scroll",h,!0),document.addEventListener("scroll",h,!0),()=>{window.removeEventListener("scroll",h,!0),document.removeEventListener("scroll",h,!0)}},[r,p,n,d]),t.jsxs(t.Fragment,{children:[s(i),t.jsx(x.Popup,{ref:o,triggerRef:i,popupId:n,position:"bottom-left",offset:5,closeOnClick:!1,closeOnClickOutside:!1,popoverArrow:!1,onOpen:()=>{c(!0),l(h=>h+1)},onClose:()=>c(!1),children:t.jsx(Ao,{idTask:e,paused:a,setOpen:h=>{h||p()}},m)})]})},Io=({id:e,task:a,endDate:n,users:s,willBePaused:o,nameProject:i,comments:r,priority:c,difficulty:m,responsible:l,nameRequiredTask:d,nameRequiredTaskResponsible:p,statusRequiredTask:h,status:f,repeatsToDo:g,repeats:y,medioName:w,paused:j,idProject:b,atraso:_,categoria:M,cambio_arte:F,name_father_required_task:R,name_father_required_task_responsible:N,boardColumnTitle:D,isBulkColumnLocked:v=!1})=>{const[U,K]=u.useState(!1),J=u.useId(),{reasignResponsible:H,updateUnitys:O}=He(),{getOBPUrlApi:S}=he(),[B,k]=u.useState(y??0),q=!!(g&&y===g),ee=!g||g===1,W=f===0,{user:re}=we(),Z=Ot(),E=!!(Z!=null&&Z.selectedTaskIds.includes(e)),z=Bt({status:f,nameRequiredTask:d,statusRequiredTask:h,repeatsToDo:g,repeats:y}),Q=!!Z&&!!D&&D!=="Completadas"&&!v,I=Q&&z,A=Q&&!z&&!!(Z!=null&&Z.isBulkSessionActive),G=!!(Z!=null&&Z.isMultiSelectActive&&I),P=!I||!!(Z!=null&&Z.isBulkLoading),C=ie=>{!Z||!D||P||Z.toggleTaskSelection(e,D)},$=()=>t.jsxs("div",{className:"tm-relative tm-flex tm-h-fit tm-w-full tm-items-center tm-justify-between",children:[t.jsxs("div",{className:"tm-flex tm-min-w-0 tm-flex-1 tm-flex-row tm-items-start tm-gap-[8px]",children:[f<2&&(R||q||ee||W)&&t.jsx("span",{"data-prevent-bulk-select":!0,children:t.jsx(Ga,{id:e,nameRequiredTask:d??"",statusRequiredTask:h??0,status:f,idAtraso:_==null?void 0:_.atrasoId,nameRequiredTaskResponsible:p,name_father_required_task:R,name_father_required_task_responsible:N,repeatsAreCompleted:q})}),t.jsx("p",{className:"tm-w-full tm-overflow-hidden tm-text-ellipsis tm-text-nowrap tm-text-base tm-text-neutral-900","data-prevent-bulk-select":!0,onClick:ie=>{ie.stopPropagation(),K(!0)},children:a})]}),z&&t.jsxs("div",{className:"tm-flex tm-shrink-0 tm-items-center tm-gap-2","data-prevent-bulk-select":!0,children:[Z?t.jsx("div",{className:"tm-flex tm-items-center tm-pt-0.5 tm-pr-2",children:t.jsx(x.Checkbox,{id:`kanban-bulk-select-${e}-${J}`,size:"sm",checked:E,disabled:P,onChange:C})}):null,t.jsx(Ka,{id:e,nameRequiredTask:d,status:f,statusRequiredTask:h,projectID:b,atrasoId:_==null?void 0:_.atrasoId,categoria:M,disabled:G})]})]}),L={0:{title:"Muy fácil",color:ge.primary.regular},1:{title:"Fácil",color:ge.success.regular},2:{title:"Media",color:ge.warning.regular},3:{title:"Difícil",color:ge.danger.regular},4:{title:"Muy difícil",color:ge.danger.dark}},T={title:"Sin dato",color:ge.texts.subtext},Y=(()=>{const ie=m;if(typeof ie!="number"||!Number.isFinite(ie))return T;const te=Math.trunc(ie);return te<0||te>4?T:L[te]??T})(),ae=ie=>{k(te=>ie==="minus"?Math.max(0,te-1):Math.min(g,te+1))},le=ie=>{var te;return((te=ie==null?void 0:ie.charAt(0))==null?void 0:te.toUpperCase())??""},X=ie=>ie==="Venta"?"accent":"danger",se=v||!!(Z!=null&&Z.isBulkLoading),ce=A?"tm-cursor-not-allowed tm-opacity-60 hover:tm-border-cards hover:tm-bg-white":"tm-cursor-pointer hover:tm-border-light-gray-100 hover:tm-border-primary-regular hover:tm-bg-primary-light";return t.jsxs(t.Fragment,{children:[t.jsxs("div",{className:`tm-relative tm-h-fit tm-max-w-[350px] tm-rounded-lg tm-border tm-p-[12px_12px] tm-transition-all tm-duration-300 ${ce} ${E?"tm-border-blue-500 tm-bg-primary-light":"tm-border-transparent tm-bg-white"} ${se?"tm-pointer-events-none":""}`,children:[t.jsx($,{}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-[4px] tm-py-2",children:[t.jsx("p",{className:"tm-font-regular tm-max-w-[250px] tm-truncate tm-text-xs tm-text-texts-subtext",children:i}),w&&t.jsx("p",{className:"tm-text-xl",children:w})]}),F&&t.jsx(x.Badge,{label:F.nombre,color:"gray",icon:ne.faImage,size:"md",theme:"solid"}),t.jsxs("div",{"data-prevent-bulk-select":!0,className:"tm-relative tm-flex tm-h-fit tm-w-full tm-items-center tm-justify-between tm-pb-1 tm-pt-5",children:[t.jsxs("div",{className:"tm-relative tm-flex tm-items-center",children:[t.jsx(Ua,{responsible:l,role:re==null?void 0:re.role,status:f,users:s.filter(ie=>l?ie.id===l:!0).map(ie=>kt(ie,S())),onClick:async(ie,te)=>{await H({idNewResponsible:ie,id:e,typeOfSelect:te})}}),o&&t.jsx(Qa,{idTask:e,paused:j,popupId:`task-pause-menu-${e}`,children:ie=>t.jsx("button",{ref:ie,type:"button",className:"tm-font-regular tm-flex !tm-h-[32px] !tm-w-[32px] tm-items-center tm-justify-center tm-gap-2 tm-text-sm tm-text-gray-400",children:t.jsx(x.Icon,{name:j?ne.faPlay:ne.faPause,size:"xs",color:"current"})})})]}),t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-m",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2",children:[t.jsx(x.Badge,{label:le((M==null?void 0:M.tipo)??"P"),color:X((M==null?void 0:M.tipo)??"Preventa"),size:"sm",theme:"solid"}),_&&t.jsx(Ie,{trigger:t.jsx(x.Icon,{name:ne.faTriangleExclamation,size:"sm",style:{color:"#C62E1F"},color:"current"}),children:t.jsx("p",{className:"tm-font-regular tm-rounded-lg tm-bg-bg-card tm-p-5 tm-text-sm",style:{color:"#C62E1F"},children:`Tarea atrasada debido a: ${_==null?void 0:_.motivo}`})}),t.jsx(Ie,{trigger:t.jsx(x.Icon,{name:ne.faRhombus,size:"sm",style:{color:Y.color},color:"current"}),children:t.jsx("p",{className:"tm-font-regular tm-rounded-lg tm-bg-bg-card tm-p-5 tm-text-sm",style:{color:Y.color},children:`Dificultad ${Y.title}`})}),t.jsx(Ha,{priority:c,id:e}),!g||g&&f===0&&t.jsxs(t.Fragment,{children:[t.jsx(x.Icon,{name:ne.faCalendar,size:"xs",style:{color:ge.texts.subtext},color:"current"}),t.jsx("p",{className:"tm-font-regular tm-text-sm tm-text-texts-subtext",children:`${n.getDate()} ${Mt(n.getMonth()).slice(0,3)}`})]})]}),f===1&&g&&g>0&&t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-m",children:[t.jsx("p",{className:"tm-pr-[5px] tm-text-[10px] tm-text-texts-placeholder",children:"unidades"}),t.jsx("button",{onClick:()=>ae("minus"),className:"tm-mr-[4px] tm-flex tm-w-[0] tm-items-center tm-justify-center tm-rounded-full tm-bg-gray-200 hover:tm-bg-gray-400",children:t.jsx(x.Icon,{name:ne.faCircleMinus,size:"xs",style:{color:ge.texts.placeholder},color:"current"})}),t.jsx("p",{className:"tm-text-[10px] tm-text-texts-placeholder",children:`${B??0} / ${g??0}`}),t.jsx("button",{onClick:()=>ae("plus"),className:"tm-ml-[4px] tm-flex tm-w-[0] tm-items-center tm-justify-center tm-rounded-full tm-bg-gray-200 hover:tm-bg-gray-400",children:t.jsx(x.Icon,{name:ne.faCirclePlus,size:"xs",style:{color:ge.texts.placeholder},color:"current"})}),t.jsx("button",{className:"tm-ml-[4px] tm-rounded-md tm-bg-primary-medium tm-px-m tm-py-s tm-text-xs tm-text-brand",onClick:()=>{O({repeats:B,id:e})},children:"Agregar Unidad"})]})]})]}),r>0&&t.jsx("div",{className:"tm-mt-4 tm-border-t tm-border-light-gray-100 tm-pt-2",children:t.jsxs("button",{type:"button","data-prevent-bulk-select":!0,onClick:ie=>{ie.stopPropagation(),K(!0)},className:"tm-flex tm-items-center tm-gap-2",children:[t.jsx(x.Icon,{name:ne.faComment,size:"xs",color:"current"}),t.jsx("span",{className:"tm-font-regular tm-text-xl tm-text-gray-400",children:r})]})})]}),t.jsx(Va,{taskId:e,isOpen:U,setIsOpen:K})]})},mt=({title:e,tasks:a,loadNextPage:n,isFetching:s,total:o,bulkSelectAllIds:i})=>{const r=u.useRef(null),c=u.useRef(null),m=u.useRef(!1);u.useEffect(()=>{var w;r!=null&&r.current&&(c!=null&&c.current)&&(c.current.style.minHeight=`${((w=r==null?void 0:r.current)==null?void 0:w.clientHeight)-300}px`)},[r==null?void 0:r.current]);const l=w=>{if(m.current)return;const{scrollTop:j,clientHeight:b,scrollHeight:_}=w==null?void 0:w.target,M=j/(_-b)*100;M<=95||M>=95&&(m.current=!0,n&&n(),setTimeout(()=>{m.current=!1},200))},d={"Por hacer":"tm-border-texts-placeholder",Trabajando:"tm-border-primary-regular",Completadas:"tm-border-success-regular"},p=Ot(),h=e,f=!!(p!=null&&p.baseColumn&&p.baseColumn!==e),g=!!p&&e!=="Completadas"&&(p==null?void 0:p.isBulkSessionActive)&&p.baseColumn===e&&typeof i=="function",y=()=>{if(!(!p||!i)){if(p.isFullColumnSelected){p.deselectAllSelectedTasks();return}p.selectEntireColumn(h,i)}};return t.jsxs("div",{ref:r,className:`tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-fit tm-min-w-[400px] tm-max-w-[400px] tm-flex-col tm-overflow-hidden tm-rounded-lg tm-border-t-4 tm-bg-light-gray-50 tm-p-[16px] ${d[e]} ${f?"tm-opacity-40":""}`,children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-w-full",children:[t.jsx("p",{className:"tm-text-sm",children:e}),g&&t.jsx("button",{type:"button",className:"tm-text-base tm-text-brand disabled:tm-cursor-not-allowed disabled:tm-opacity-50 tm-mx-3",disabled:p==null?void 0:p.isBulkLoading,onClick:y,children:p!=null&&p.isBulkLoading?"Cargando…":p!=null&&p.isFullColumnSelected?"Quitar Selección":"Seleccionar todas"})]}),t.jsx("div",{className:"tm-flex tm-items-center tm-gap-[8px]",children:t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-[4px]",children:[t.jsx(x.Icon,{name:ne.faFiles,size:"sm",color:"secondary"}),t.jsx("p",{className:"tm-text-base tm-text-texts-placeholder",children:o??0})]})})]}),t.jsxs("div",{ref:c,className:"tm-flex tm-h-full tm-max-w-[350px] tm-flex-col tm-gap-[12px] tm-overflow-y-auto tm-pb-[200px] tm-pt-4 tm-scrollbar-none hover:tm-border-light-gray-100 hover:tm-bg-light-gray-50 focus:tm-border-light-gray-100 focus:tm-bg-light-gray-50 focus:tm-outline-none",onScroll:l,children:[a==null?void 0:a.map(w=>t.jsx(Io,{...w,boardColumnTitle:p?h:void 0,isBulkColumnLocked:!!(p&&f)},w.id)),s?t.jsx(Zn,{}):t.jsx("p",{className:"tm-text-center tm-text-sm tm-text-light-gray-900",children:"No hay más tareas por mostrar..."})]})]})},pa=[{label:"Tipo de dependencia 2",type:"select",id:"dependency",options:[{id:"con",name:"Con dependencia"},{id:"sin",name:"Sin dependencia"},{id:"ambas",name:"Ambas"}]},{label:"Por responsable",type:"select",id:"owner.config",options:[{id:"yo",name:"Mis tareas"},{id:"yo_y_mis_equipos",name:"Tareas mías y de mis equipos"},{id:"mis_equipos",name:"Tareas de mis equipos"}]},{label:"Por dificultad",type:"select",id:"difficulty",options:[{id:1,name:"Muy facil"},{id:2,name:"Facil"},{id:3,name:"Media"},{id:4,name:"Dificil"},{id:5,name:"Muy dificil"}]}],Do=()=>{const{user:e}=we(),[a,n]=u.useState([...pa]),s=[{roles:["Project Manager","Manager","Operation Manager"],id:"owner.config",filters:[{id:"todas",name:"Todas las tareas"}]}];return u.useEffect(()=>{const o=[...pa];s.forEach(c=>{if(c.roles.includes(e.role)){const m=o.find(l=>l.id===c.id);m&&(m.options.some(d=>d.id==="todas")||(m.options=[{id:"todas",name:"Todas las tareas"},...m.options]))}});const i=JSON.stringify(a),r=JSON.stringify(o);i!==r&&n(o)},[e.role]),{filters:a}},Fo="/api/tareas/bulk-update-status";async function Mo(e,a){const{data:n}=await e.post(Fo,a);return n}function ko(e){var a,n,s,o;if(Ye.isAxiosError(e)){const i=(a=e.response)==null?void 0:a.status,r=(n=e.response)==null?void 0:n.data;if(i===400){if(typeof r=="string"&&r.trim().length>0)return r.trim();if(r&&typeof r=="object"){const c=r.message;if(typeof c=="string"&&c.trim())return c.trim();const m=(s=r.details)==null?void 0:s.errors,l=(o=m==null?void 0:m[0])==null?void 0:o.message;if(typeof l=="string"&&l.trim())return l.trim()}return"Los datos enviados no son válidos. Revisa la selección e inténtalo de nuevo."}return typeof r=="string"&&r.trim().length>0?r.trim():e.message||"No se pudo actualizar las tareas."}return e instanceof Error?e.message:"No se pudo actualizar las tareas."}function Oo(){const{tasks_api:e}=he(),{user:a}=we();return me.useMutation({mutationKey:["tareas","bulk-update-status"],mutationFn:async n=>{const s=n.user_id??(a==null?void 0:a.id);if(s==null||s<1)throw new Error("No hay usuario válido para la actualización masiva.");try{return await Mo(e,{...n,user_id:s})}catch(o){throw new Error(ko(o))}}})}const xt={MOVE_TO_TRABAJANDO:"kanban-bulk-move-trabajando",MOVE_TO_POR_HACER:"kanban-bulk-move-por-hacer",MOVE_TO_COMPLETADAS:"kanban-bulk-move-completadas"};function Lo(e){const{isBulkLoading:a}=e;return[{type:"button",label:"Cancelar",icon:ne.faXmark,color:"secondary",pill:"pill",disabled:a,onClick:()=>{a||(e.setPendingTargetStatus(null),e.setActiveButtonId(null))}},{type:"button",label:"Confirmar",icon:ne.faCheck,color:"secondary",pill:"pill",disabled:a,onClick:()=>{a||e.onConfirmBulkMove()}}]}const bt="secondary";function Bo(e){const a=Lo({setActiveButtonId:e.setActiveButtonId,setPendingTargetStatus:e.setPendingTargetStatus,onConfirmBulkMove:e.onConfirmBulkMove,isBulkLoading:e.isBulkLoading});return e.baseColumn==="Por hacer"?[{id:xt.MOVE_TO_TRABAJANDO,label:"Mover a trabajando",icon:ne.faArrowRight,color:bt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(1)},addons:a}]:e.baseColumn==="Trabajando"?[{id:xt.MOVE_TO_POR_HACER,label:"Mover a por hacer",icon:ne.faArrowLeft,color:bt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(0)},addons:a},{id:xt.MOVE_TO_COMPLETADAS,label:"Mover a completadas",icon:ne.faArrowRight,color:bt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(2)},addons:a}]:[]}const Ro="Seleccionados";function Xa(){const e=Ot(),[a,n]=u.useState(null),s=a!==null,o=me.useQueryClient(),{mutate:i}=Oo(),r=(e==null?void 0:e.selectedTaskIds.length)??0;u.useEffect(()=>{r===0&&n(null)},[r]);const c=u.useCallback(()=>{e!=null&&e.isBulkLoading||e==null||e.setPendingTargetStatus(null)},[e]),m=u.useCallback(()=>{n(null),e==null||e.exitBulkSelectionMode()},[e]),l=u.useCallback(()=>{if(!e)return;const p=e.pendingTargetStatus,h=e.selectedTaskIds;if(p==null||h.length===0)return;const f={tasks_ids:[...h],estatus:p,...p===2?{ended_at:new Date().toISOString()}:{}};e.setIsBulkLoading(!0),i(f,{onSettled:()=>{e.setIsBulkLoading(!1)},onSuccess:async()=>{await e.invalidateAfterBulkSuccess(o),n(null),e.exitBulkSelectionMode()},onError:()=>{n(null),e.setPendingTargetStatus(null)}})},[e,i,o]),d=u.useMemo(()=>e?Bo({baseColumn:e.baseColumn,setPendingTargetStatus:e.setPendingTargetStatus,setActiveButtonId:n,onConfirmBulkMove:l,isBulkLoading:e.isBulkLoading}):[],[e,l]);return!e||r===0||e.baseColumn!=="Por hacer"&&e.baseColumn!=="Trabajando"?null:t.jsx(x.Toolbar,{visible:!0,count:r,text:Ro,activeButtonId:a,onActiveButtonIdChange:n,onBackClick:c,buttons:d,onClose:m,showCounterInButtonsView:!s,showBackButton:!s,showCloseButton:!s})}const Ya=["to_do_tasks","working_tasks","done_tasks"],qo="tasksProject";function zo(e){return Promise.all(Ya.map(a=>e.invalidateQueries({queryKey:[a]}))).then(()=>{})}function $o(e){return Promise.all(Ya.flatMap(a=>[e.invalidateQueries({queryKey:[a]}),e.refetchQueries({queryKey:[a]})])).then(()=>{})}function Uo(e){return e.invalidateQueries({queryKey:[qo]}).then(()=>{})}const Ho=["Por hacer","Trabajando","Completadas"],Ko=()=>{const{defineFields:e}=De(),{tasksProject:a}=Je(),{filters:n}=Do();u.useEffect(()=>{(async()=>{let i=[...n];e(i)})()},[]);const s=u.useMemo(()=>{var o;return(o=a==null?void 0:a.data)==null?void 0:o.filter(i=>{var r;return((r=i==null?void 0:i.tasks)==null?void 0:r.length)===0}).reduce((i,r)=>(i[r.status]=i[r.status]||[],i[r.status].push(r),i),{})},[a==null?void 0:a.data]);return t.jsxs(Ra,{invalidateAfterBulkSuccess:Uo,children:[t.jsx(Xa,{}),t.jsx("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-gap-4",children:Ho.map((o,i)=>{const r=(s==null?void 0:s[i])??[];return t.jsx(mt,{total:r.length,title:o,tasks:r,isFetching:a==null?void 0:a.isFetching,isLoadingData:a==null?void 0:a.isLoading,bulkSelectAllIds:()=>Promise.resolve(r.filter(c=>Bt({status:c.status,nameRequiredTask:c.nameRequiredTask,statusRequiredTask:c.statusRequiredTask,repeatsToDo:c.repeatsToDo,repeats:c.repeats})).map(c=>c.id))},o)})})]})};async function Ja(e){const a=[];let n=1;for(;;){const s=await dt({filters:{...e.filters,status:e.status,...$e(n)},tasks_api:e.tasks_api});for(const o of s)Bt({status:o.status,nameRequiredTask:o.nameRequiredTask,statusRequiredTask:o.statusRequiredTask,repeatsToDo:o.repeatsToDo,repeats:o.repeats})&&a.push(o.id);if(s.length<qt)break;n+=1}return a}const Go=()=>{var i,r;const{tasks_api:e}=he(),{toDoTasks:a,total:n,filtersToSend:s}=Wa(),o=[...((r=(i=a==null?void 0:a.data)==null?void 0:i.pages)==null?void 0:r.flat())??[]];return t.jsx(mt,{total:n,title:"Por hacer",tasks:o,loadNextPage:()=>zt(a),isFetching:a==null?void 0:a.isFetching,isLoadingData:a==null?void 0:a.isLoading,bulkSelectAllIds:()=>Ja({tasks_api:e,filters:s,status:"por_hacer"})})},Vo=()=>{var l;const e=me.useQueryClient(),{tasks_api:a}=he(),{user:n}=we(),{filters:s}=De(),[o,i]=u.useState(0),[r,c]=u.useState({owner:{user:n.id,config:((l=s==null?void 0:s.owner)==null?void 0:l.config)??"yo_y_mis_equipos",role:n.role},status:"trabajando"}),m=me.useInfiniteQuery({initialPageParam:1,queryKey:["working_tasks",r],queryFn:({pageParam:d})=>dt({filters:{...r,status:"trabajando",...$e(d)},tasks_api:a}),staleTime:1e3*60*60*24,getNextPageParam:(d,p)=>p.length+1});return u.useEffect(()=>{var d;Object.keys(s).length>0&&c({...s,owner:{user:n.id,config:((d=s==null?void 0:s.owner)==null?void 0:d.config)??"yo_y_mis_equipos",role:n.role},status:"trabajando"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["working_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const p=await a.get("/api/listado_tareas",{params:{...r,status:"trabajando",cancelada:!1,...$e(1),tasks_api:a,justCount:!0}});i(p.data.total)})()},[r,m==null?void 0:m.data]),{workingTasks:m,total:o,filtersToSend:r}},Wo=()=>{var i,r;const{tasks_api:e}=he(),{workingTasks:a,total:n,filtersToSend:s}=Vo(),o=[...((r=(i=a==null?void 0:a.data)==null?void 0:i.pages)==null?void 0:r.flat())??[]];return t.jsx(mt,{total:n,title:"Trabajando",tasks:o,loadNextPage:()=>zt(a),isFetching:a==null?void 0:a.isFetching,bulkSelectAllIds:()=>Ja({tasks_api:e,filters:s,status:"trabajando"})})},Qo=()=>{var l;const e=me.useQueryClient(),{user:a}=we(),{tasks_api:n}=he(),{filters:s}=De(),[o,i]=u.useState(0),[r,c]=u.useState({owner:{user:a.id,config:((l=s==null?void 0:s.owner)==null?void 0:l.config)??"yo_y_mis_equipos",role:a.role},status:"completadas"}),m=me.useInfiniteQuery({initialPageParam:1,queryKey:["done_tasks",r],queryFn:({pageParam:d})=>dt({filters:{...r,status:"completadas",...$e(d)},tasks_api:n}),staleTime:1e3*60*60*24,getNextPageParam:(d,p)=>p.length+1});return u.useEffect(()=>{var d;Object.keys(s).length>0&&c({...s,owner:{user:a.id,config:((d=s==null?void 0:s.owner)==null?void 0:d.config)??"yo_y_mis_equipos",role:a.role},status:"completadas"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["done_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const p=await n.get("/api/listado_tareas",{params:{...r,status:"completadas",cancelada:!1,...$e(1),justCount:!0,tasks_api:n}});i(p.data.total)})()},[m==null?void 0:m.data,r]),{doneTasks:m,total:o,filtersToSend:r}},Xo=()=>{var s,o;const{doneTasks:e,total:a}=Qo(),n=[...((o=(s=e==null?void 0:e.data)==null?void 0:s.pages)==null?void 0:o.flat())??[]];return t.jsx(mt,{title:"Completadas",tasks:n,loadNextPage:()=>zt(e),isFetching:e==null?void 0:e.isFetching,total:a})};class lt{static toSalesmanUsers(a){return{id:a.id,name:a.nombre}}}const Yo=()=>{const{tasks_api:e}=he(),{filters:a}=De(),{user:n}=we(),s=async()=>(await e.get("/api/obtener-comerciales")).data.map(lt.toSalesmanUsers),o=async()=>{var c;return(await e.get("/api/listado_tareas",{params:{...Qt(a),owner:{user:n.id,config:((c=a==null?void 0:a.owner)==null?void 0:c.config)??"yo_y_mis_equipos",role:n.role},justProjects:!0,cancelada:!1}})).data.map(lt.toSalesmanUsers)};return{getSalesmanAndProjects:u.useCallback(async(r={})=>{var f;const c={...a,...r},m=(r==null?void 0:r["owner.config"])??((f=a==null?void 0:a.owner)==null?void 0:f.config)??"yo_y_mis_equipos",l={...c};delete l["owner.config"];const d=Qt(l),[p,h]=await Promise.all([e.get("/api/obtener-comerciales"),e.get("/api/listado_tareas",{params:{...d,owner:{user:n==null?void 0:n.id,config:m,role:n.role},justProjects:!0,cancelada:!1}})]);return{salesmanUsers:p.data.map(lt.toSalesmanUsers),projects:h.data.map(lt.toSalesmanUsers)}},[e,a,n==null?void 0:n.id,n==null?void 0:n.role]),getProjects:o,getSalesmans:s}},Jo=()=>{const{user:e}=we(),[a,n]=u.useState([...Yt]),s=[{roles:["Project Manager","Manager","Operation Manager"],id:"owner.config",filters:[{id:"todas",name:"Todas las tareas"}]}];return u.useEffect(()=>{const o=[...Yt];s.forEach(c=>{if(c.roles.includes(e.role)){const m=o.find(l=>l.id===c.id);m&&(m.options.some(d=>d.id==="todas")||(m.options=[{id:"todas",name:"Todas las tareas"},...m.options]))}});const i=JSON.stringify(a),r=JSON.stringify(o);i!==r&&n(o)},[e.role]),{filters:a}},Zo=()=>{const{defineFields:e,initialFilters:a}=De(),{getSalesmanAndProjects:n}=Yo(),{filters:s}=Jo(),o=(a==null?void 0:a["owner.config"])??"yo_y_mis_equipos";return u.useEffect(()=>{let i=!1;return(async()=>{const{salesmanUsers:c,projects:m}=await n({"owner.config":o});i||e(s.map(l=>l.id==="project.id"?{...l,options:m}:l.id==="salesman.id"?{...l,options:c}:l))})(),()=>{i=!0}},[e,s,n,o]),t.jsxs(Ra,{invalidateAfterBulkSuccess:zo,children:[t.jsx(Xa,{}),t.jsxs("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-gap-4",children:[t.jsx(Go,{}),t.jsx(Wo,{}),t.jsx(Xo,{})]})]})},Za=u.createContext({}),er=({children:e})=>{const[a,n]=u.useState([]),s=o=>{n(i=>i.includes(o)?i.filter(r=>r!==o):[...i,o])};return t.jsx(Za.Provider,{value:{selectedTasks:a,selectTask:s},children:e})},tr=()=>u.useContext(Za),ar=()=>{const e=()=>t.jsxs("div",{className:"tm-flex tm-w-full tm-gap-m",children:[t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-full tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-w-[30%] tm-animate-pulse tm-rounded-md tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-w-[10%] tm-animate-pulse tm-rounded-md tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-w-[10%] tm-animate-pulse tm-rounded-md tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),t.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"})]});return t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-m",children:[t.jsx(e,{}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-m tm-pl-5",children:[t.jsx(e,{}),t.jsx("div",{className:"tm-pl-5",children:t.jsx(e,{})})]}),t.jsx(e,{}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-m tm-pl-5",children:[t.jsx(e,{}),t.jsx("div",{className:"tm-pl-5",children:t.jsx(e,{})})]})]})},es=({startDate:e,endDate:a})=>t.jsxs(t.Fragment,{children:[t.jsxs("div",{className:"tm-flex tm-h-[30px] tm-w-fit tm-items-center tm-justify-center tm-gap-s tm-rounded-md tm-bg-light-gray-50 tm-px-xl",children:[t.jsx(x.Icon,{name:ne.faCalendar,size:"xs",style:{color:ge.texts.subtext},color:"current"}),t.jsxs(x.Text,{children:[" ",ra(e)]})]}),t.jsx(x.Icon,{name:ne.faArrowRight,size:"xs",style:{color:ge.texts.DEFAULT},color:"current"}),t.jsxs("div",{className:"tm-flex tm-h-[30px] tm-w-fit tm-items-center tm-justify-center tm-gap-s tm-rounded-md tm-bg-light-gray-50 tm-px-xxxl",children:[t.jsx(x.Icon,{name:ne.faCalendar,size:"xs",style:{color:ge.texts.subtext},color:"current"}),t.jsxs(x.Text,{children:[" ",ra(a)]})]})]}),ts=({id:e,priority:a,difficulty:n,endDate:s,atraso:o})=>{const[i,r]=u.useState({priority:!1,difficulty:!1,atraso:!1}),c={0:{title:"N/A",color:ge.success.regular,bg:"tm-bg-texts-placeholder tm-border-texts-placeholder",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},1:{title:"Baja",color:ge.success.regular,bg:"tm-bg-success-medium tm-border-success-pastel",border:"tm-border-success-pastel",borderHover:"hover:tm-border-success-dark"},2:{title:"Media",color:ge.warning.regular,bg:"tm-bg-warning-light tm-border-warning-regular",border:"tm-border-warning-regular",borderHover:"hover:tm-border-warning-dark"},3:{title:"Alta",color:ge.danger.regular,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-regular",borderHover:"hover:tm-border-danger-dark"}},m={1:{title:"Muy fácil",color:ge.success.dark,bg:"tm-bg-success-medium tm-border-success-regular",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},2:{title:"Fácil",color:ge.success.regular,bg:"tm-bg-success-medium tm-border-success-pastel",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},3:{title:"Media",color:ge.warning.regular,bg:"tm-bg-warning-light tm-border-warning-regular",border:"tm-border-warning-medium",borderHover:"hover:tm-border-warning-dark"},4:{title:"Difícil",color:ge.danger.regular,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-medium",borderHover:"hover:tm-border-danger-dark"},5:{title:"Muy difícil",color:ge.danger.dark,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-medium",borderHover:"hover:tm-border-danger-dark"}},l=()=>{if(n==null||Number.isNaN(Number(n)))return 1;const g=Math.trunc(Number(n));return g===0?1:g>=1&&g<=5?g:1},d=()=>{if(a==null||Number.isNaN(Number(a)))return 0;const g=Math.trunc(Number(a));return g>=0&&g<=3?g:0},p=m[l()]??m[1],h=c[d()]??c[0],f=s instanceof Date&&!Number.isNaN(s.getTime())?`${s.getDate()} ${Mt(s.getMonth()).slice(0,3)}`:"—";return t.jsxs(t.Fragment,{children:[t.jsx("button",{type:"button",className:"tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center tm-gap-8 tm-rounded-[8px] tm-bg-light-gray-50 hover:tm-bg-gray-200",children:t.jsx(Ie,{trigger:t.jsx(x.Icon,{name:ne.faAlignCenter,size:"xs",style:{color:ge.texts.subtext},color:"current"}),children:t.jsx("p",{className:"tm-font-regular tm-rounded-lg tm-bg-bg-card tm-px-4 tm-py-2 tm-text-2xl",style:{color:"gray"},children:"Espéralo muy pronto..."})})}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[t.jsx("div",{onMouseEnter:()=>r({...i,difficulty:!0}),onMouseLeave:()=>r({...i,difficulty:!1}),className:`tm-gap-s ${p.border} ${p.borderHover} transition-all duration-300 tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center
|
|
6
|
-
tm-rounded-[8px] tm-border tm-shadow-[0px_0px_2px_0px_rgba(37,37,37,0.10)]`,children:
|
|
7
|
-
tm-border tm-border-success-medium tm-shadow-[0px_0px_2px_0px_rgba(37,37,37,0.10)] hover:tm-border-success-dark`,children:
|
|
8
|
-
tm-border tm-border-danger-medium tm-shadow-[0px_0px_2px_0px_rgba(37,37,37,0.10)] hover:tm-border-danger-dark`,children:t.jsx(Ie,{trigger:t.jsx(x.Icon,{name:ne.faTriangleExclamation,size:"xs",style:{color:i.atraso?ge.danger.dark:ge.danger.regular},color:"current"}),children:t.jsx("p",{className:"tm-font-regular tm-rounded-lg tm-bg-bg-card tm-p-5 tm-text-sm",style:{color:ge.danger.dark},children:o==null?void 0:o.motivo})})}),t.jsx(x.Icon,{name:ne.faCalendar,size:"xs",style:{color:ge.texts.subtext},color:"current"}),t.jsx("p",{className:"tm-font-regular tm-text-xs tm-text-texts-subtext",children:f})]})]})},sr=({id:e})=>{const{selectedTasks:a,selectTask:n}=tr();return t.jsxs(t.Fragment,{children:[t.jsx("label",{className:"tm-flex tm-h-[20px] tm-w-[20px] tm-cursor-pointer tm-items-center tm-justify-center tm-rounded-md tm-border-2 tm-border-light-gray-100",htmlFor:e.toString(),children:t.jsx("span",{className:`${a.includes(e)?"tm-opacity-100":"tm-opacity-0"} tm-transition-opacity tm-duration-500`,children:t.jsx(x.Icon,{name:ne.faCheck,size:"xs",style:{color:ge.primary.regular},color:"current"})})}),t.jsx("input",{className:"tm-hidden",id:e.toString(),type:"checkbox",onChange:()=>n(e)})]})},as=({task:e})=>t.jsx(Ie,{trigger:t.jsx(x.Text,{children:e}),children:t.jsx("div",{className:"tm-py-2 tm-px-4",children:t.jsx(x.Text,{children:e})})}),nr=({id:e})=>{var d,p,h,f,g;const[a,n]=u.useState(!1),{tasksProject:s}=Je(),{reasignResponsible:o}=He(),{getOBPUrlApi:i}=he(),r=(d=s==null?void 0:s.data)==null?void 0:d.find(y=>y.id===e),[c,m]=u.useState(null),{user:l}=we();return t.jsxs(t.Fragment,{children:[t.jsx("div",{className:"tm-border-b tm-border-light-gray-100 tm-pb-3",children:t.jsxs("div",{className:"tm-mb-3 tm-ml-[30px] tm-mt-1 tm-flex tm-flex-wrap tm-items-center tm-gap-xl tm-rounded-md tm-p-2 hover:tm-bg-light-gray-50",onMouseEnter:()=>{m(e)},onMouseLeave:()=>m(null),onClick:()=>n(!0),children:[!(r!=null&&r.nameRequiredTask)||(r==null?void 0:r.nameRequiredTask)!==""&&(r==null?void 0:r.statusRequiredTask)===2&&t.jsx(sr,{id:e}),t.jsx(Ga,{id:e,idAtraso:(p=r==null?void 0:r.atraso)==null?void 0:p.atrasoId,nameRequiredTask:(r==null?void 0:r.nameRequiredTask)??"",status:r==null?void 0:r.status,statusRequiredTask:(r==null?void 0:r.statusRequiredTask)??0,nameRequiredTaskResponsible:r==null?void 0:r.nameRequiredTaskResponsible},e),(r==null?void 0:r.willBePaused)&&t.jsx(Qa,{idTask:r.id,paused:r.paused,popupId:`child-task-pause-menu-${r.id}`,children:y=>t.jsx(x.Button,{ref:y,color:"tertiary",icon:r!=null&&r.paused?ne.faPause:ne.faPlay,className:"tm-font-regular tm-flex tm-items-center tm-gap-2 tm-text-sm tm-text-gray-400",size:"xs"})}),t.jsx(Ua,{role:l==null?void 0:l.role,status:r==null?void 0:r.status,onClick:async(y,w)=>{await o({idNewResponsible:y,id:e,typeOfSelect:w})},responsible:r==null?void 0:r.responsible,users:((h=r==null?void 0:r.users)==null?void 0:h.map(y=>kt(y,i())))??[]}),t.jsx(as,{task:(r==null?void 0:r.task)??""}),t.jsx(ts,{id:e,priority:r==null?void 0:r.priority,difficulty:r.difficulty,endDate:r==null?void 0:r.endDate,atraso:r==null?void 0:r.atraso}),t.jsx(es,{startDate:r==null?void 0:r.startDate,endDate:r==null?void 0:r.endDate}),c===e&&t.jsx("div",{className:"tm-flex tm-h-[30px] tm-items-center tm-justify-center tm-gap-2 tm-rounded-[12px] tm-rounded-md tm-bg-silver-silver_dark tm-p-[4px]",children:(r==null?void 0:r.status)!==2&&t.jsx("div",{onClick:y=>{y.stopPropagation()},children:t.jsx(Ka,{id:e,nameRequiredTask:r.nameRequiredTask,status:r.status,statusRequiredTask:r.statusRequiredTask,projectID:(f=s==null?void 0:s.data)==null?void 0:f.id,atrasoId:(g=r==null?void 0:r.atraso)==null?void 0:g.atrasoId,categoria:r==null?void 0:r.categoria})})})]})}),t.jsx(Va,{taskId:e,isOpen:a,setIsOpen:n})]})},ss=({id:e})=>{var c,m,l,d,p,h;const{tasksProject:a,openTasks:n,openTask:s}=Je(),o=(c=a==null?void 0:a.data)==null?void 0:c.find(f=>f.id===e),r=(()=>{var y;const f=a==null?void 0:a.data,g=[];return(y=o==null?void 0:o.tasks)==null||y.forEach(w=>{const j=f.find(b=>b.id===(w==null?void 0:w.id));j&&g.push(j)}),g})();return o?t.jsxs("div",{className:"tm-mb-2 tm-flex tm-flex-col tm-gap-m tm-overflow-y-auto",children:[t.jsxs("div",{className:"tm-flex tm-cursor-pointer tm-flex-wrap tm-items-center tm-gap-16 tm-rounded-md tm-p-2 hover:tm-bg-silver-silver_light",onClick:()=>s(e),children:[t.jsx("button",{type:"button",className:`${n.includes(e)?"":"tm--rotate-90"} tm-transition-all tm-duration-300`,children:t.jsx(x.Icon,{name:ne.faChevronDown,size:"sm",style:{color:ge.texts.subtext},color:"current"})}),t.jsx("div",{className:"tm-mx-1 tm-flex tm-h-[28px] tm-min-h-[28px] tm-w-fit tm-min-w-[28px] tm-items-center tm-justify-center tm-rounded-full tm-bg-slate-100",children:t.jsx("p",{className:"tm-text-primary tm-text-md",children:((m=o==null?void 0:o.tasks)==null?void 0:m.length)===0?1:r.length})}),t.jsx(as,{task:(o==null?void 0:o.task)??""}),t.jsx(ts,{id:e,priority:o==null?void 0:o.priority,difficulty:o==null?void 0:o.difficulty,endDate:o==null?void 0:o.endDate,atraso:o==null?void 0:o.atraso}),t.jsx(es,{startDate:o==null?void 0:o.startDate,endDate:o==null?void 0:o.endDate}),t.jsxs("button",{type:"button",className:"tm-flex tm-h-[30px] tm-w-fit tm-items-center tm-justify-center tm-gap-s tm-rounded-md tm-bg-light-gray-50 tm-px-m hover:tm-bg-gray-200",children:[t.jsx(x.Icon,{name:ne.faDiagramSubtask,size:"sm",style:{color:ge.texts.subtext},color:"current"}),t.jsx(x.Text,{children:((l=o==null?void 0:o.tasks)==null?void 0:l.length)===0?1:(d=o==null?void 0:o.tasks)==null?void 0:d.length})]})]}),n.includes(e)&&t.jsx("div",{className:"tm-ml-[30px]",children:((p=o==null?void 0:o.tasks)==null?void 0:p.length)>0?(h=o==null?void 0:o.tasks)==null?void 0:h.map(f=>t.jsx(ss,{id:f==null?void 0:f.id})):t.jsx(nr,{id:o==null?void 0:o.id})})]}):null},or=()=>{var s;const{tasksProject:e,projectID:a}=Je();if(e!=null&&e.isFetching||e!=null&&e.isLoading)return t.jsx(ar,{});let n=[...(s=e==null?void 0:e.data)==null?void 0:s.filter(o=>o.isPrincipalTask)];return t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-m",children:t.jsx(er,{project:a,children:n==null?void 0:n.sort((o,i)=>o.orden-i.orden).map(o=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-m tm-border-b tm-border-light-gray-100 tm-pb-m ",children:t.jsx(ss,{id:o.id})}))})})};function rr({title:e,color:a,icon:n}){return t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[t.jsx(x.Icon,{name:n,size:"md",colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotoneSecondary:.5}),t.jsx("p",{className:"tm-text-base tm-py-0.5 tm-font-body-sm-bold tm-text-body-sm-bold tm-leading-none tm-text-primary",children:e})]})}function ir({value:e,onChange:a}){return t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-4",children:[t.jsx("label",{className:"tm-text-body-sm-bold tm-text-primary",children:"Nombre del equipo"}),t.jsx(x.Input,{size:"xs",placeholder:"Creative",value:e,onChange:n=>a(n.target.value)})]})}const ns=({title:e})=>t.jsxs("div",{className:"flex-1 tm-flex tm-items-center tm-gap-x-8",children:[t.jsx(x.Icon,{background:!0,name:ne.faFilePen,color:"blue",size:"lg"}),t.jsx(x.Text,{size:"xl",weight:"bold",children:e})]}),Ge={search:"",debouncedSearch:"",filters:[]},lr={"kanban-general":{...Ge},"lista-campanias":{...Ge},"kanban-campania":{...Ge},"teams-container":{...Ge},"templates-container":{...Ge}},ut=Ue.create((e,a)=>({viewFilters:lr,currentPath:null,debounceTimeouts:{},setCurrentPath:n=>{const s=a().currentPath;e({currentPath:n}),s&&s!==n&&a().resetPathData(s)},setSearch:(n,s)=>{const o=s||a().currentPath;if(!o)return;const i=`search_${o}`,r=a().debounceTimeouts[i];r&&clearTimeout(r),e(m=>({viewFilters:{...m.viewFilters,[o]:{...m.viewFilters[o],search:n}}}));const c=setTimeout(()=>{e(m=>({viewFilters:{...m.viewFilters,[o]:{...m.viewFilters[o],debouncedSearch:n}},debounceTimeouts:{...m.debounceTimeouts,[i]:void 0}}))},500);e(m=>({debounceTimeouts:{...m.debounceTimeouts,[i]:c}}))},setFilters:(n,s)=>{const o=s||a().currentPath;o&&e(i=>({viewFilters:{...i.viewFilters,[o]:{...i.viewFilters[o],filters:n}}}))},getSearch:n=>{var o;const s=n||a().currentPath;return s&&((o=a().viewFilters[s])==null?void 0:o.search)||""},getDebouncedSearch:n=>{var o;const s=n||a().currentPath;return s&&((o=a().viewFilters[s])==null?void 0:o.debouncedSearch)||""},getFilters:n=>{var o;const s=n||a().currentPath;return s?((o=a().viewFilters[s])==null?void 0:o.filters)||[]:[]},resetPathData:n=>{const s=`search_${n}`,o=a().debounceTimeouts[s];o&&clearTimeout(o),e(i=>({viewFilters:{...i.viewFilters,[n]:{...Ge}},debounceTimeouts:{...i.debounceTimeouts,[s]:void 0}}))}}));function os({path:e}){const{getSearch:a,setSearch:n}=ut(),s=a(e);return t.jsx(x.Input,{leftSlot:ne.faSearch,placeholder:"Buscar...",size:"xs",value:s,onChange:o=>n(o.target.value,e)})}const fa={fase_plantilla:"",tipo_plantilla:"",modo_configuracion:"",categoria:"",formato_salida:"",tipo_medio:"",medio_especifico:"",responsable_impresion:"",pertenencia_medio:"",ubicacion_medio:""},cr={fase_plantilla:null,tipo_plantilla:null,modo_configuracion:null,categoria:null,formato_salida:null,tipo_medio:null,medio_especifico:null,responsable_impresion:null,pertenencia_medio:null,ubicacion_medio:null},dr={fase_plantilla:"",tipo_plantilla:"",categoria:"",tipo_medio:"",medio_especifico:"",modo_configuracion:"",responsable_impresion:"",pertenencia_medio:"",ubicacion_medio:""},ga={tipo_plantilla:!0,modo_configuracion:!0,categoria:!0,formato_salida:!0,tipo_medio:!0,medio_especifico:!0,responsable_impresion:!0,pertenencia_medio:!0,ubicacion_medio:!0},Fe=Ue.create(e=>({path:"",viewMode:"grid",isOpenModalLimit:!1,template:null,clave:"XX-XXX-XX-XXX-XX-X-X",templateFormData:fa,disabledFields:ga,claveParams:dr,paramsTipo:cr,isEditTemplate:!1,openModalCreateTemplate:!1,currentTemplateForEdit:null,refetch:null,openModalUnsavedChanges:!1,isDuplicateTemplate:!1,hasFormChanges:!1,openModalPublishTemplate:!1,currentTemplateId:null,openModalDeleteTemplate:!1,setPath:a=>e({path:a}),setViewMode:a=>e({viewMode:a}),setIsOpenModalLimit:a=>e({isOpenModalLimit:a}),setTemplate:a=>e({template:a}),setClave:a=>e({clave:a}),setTemplateFormData:a=>{e(n=>({templateFormData:{...n.templateFormData,...a}}))},resetTemplateFormData:()=>e({templateFormData:fa}),setDisableField:({fields:a,value:n})=>{for(const s of a)e(o=>({disabledFields:{...o.disabledFields,[s]:n}}))},resetDisabledFields:()=>e({disabledFields:ga}),setClaveParams:({field:a,value:n})=>{e(s=>({claveParams:{...s.claveParams,[a]:n}}))},resetClave:()=>e(a=>({clave:"XX-XXX-XX-XXX-XX-X-X"})),setParamTipo:a=>e(n=>({paramsTipo:{...n.paramsTipo,...a}})),setIsEditTemplate:a=>e({isEditTemplate:a}),setOpenModalCreateTemplate:a=>e({openModalCreateTemplate:a}),setCurrentTemplateForEdit:a=>e({currentTemplateForEdit:a}),setRefetch:a=>e({refetch:a}),setOpenModalUnsavedChanges:a=>e({openModalUnsavedChanges:a}),setIsDuplicateTemplate:a=>e({isDuplicateTemplate:a}),setHasFormChanges:a=>e({hasFormChanges:a}),setOpenModalPublishTemplate:a=>e({openModalPublishTemplate:a}),setCurrentTemplateId:a=>e({currentTemplateId:a}),setOpenModalDeleteTemplate:a=>e({openModalDeleteTemplate:a})})),rs=e=>{const{getSearch:a,getDebouncedSearch:n,setSearch:s,getFilters:o,setFilters:i,resetPathData:r}=ut();return{search:a(e),debouncedSearch:n(e),filters:o(e),setSearch:c=>s(c,e),setFilters:c=>i(c,e),resetData:()=>r(e)}},mr=()=>t.jsx(ns,{title:"Flujos de trabajo"}),Le=Ue.create(e=>({activeTemplate:null,setActiveTemplate:a=>e({activeTemplate:a}),clearActiveTemplate:()=>e({activeTemplate:null})})),Te=Ue.create((e,a)=>({mode:"grid",id:null,setMode:(n,s)=>{const o=a();if(n==="grid"||o.id!==null&&o.id!==s){const{clearAllGroupData:r}=a();r()}e({mode:n,id:s??null})},setId:n=>e({id:n}),reset:()=>{const{clearAllGroupData:n}=a();n(),e({mode:"grid",id:null})},addNode:null,addBranch:null,addNodeFromHandle:null,addNodeWithType:null,savePositions:null,loadPositions:null,clearPositions:null,activePlusNode:null,templateViewModes:{},setViewMode:(n,s)=>{const{templateViewModes:o}=a();e({templateViewModes:{...o,[n]:s}})},getViewMode:n=>{const{templateViewModes:s}=a();return s[n]??"readonly"},clearViewMode:n=>{const{templateViewModes:s}=a(),o={...s};delete o[n],e({templateViewModes:o})},expandedGroups:new Set,groupTemplateData:{},toggleGroupExpansion:n=>{const{expandedGroups:s}=a(),o=new Set(s);o.has(n)?o.delete(n):o.add(n),e({expandedGroups:o})},setGroupTemplateData:(n,s)=>{const{groupTemplateData:o}=a();e({groupTemplateData:{...o,[n]:s}})},clearGroupTemplateData:n=>{const{groupTemplateData:s}=a(),o={...s};delete o[n],e({groupTemplateData:o})},clearAllGroupData:()=>{e({expandedGroups:new Set,groupTemplateData:{}})},copiedNodes:[],setCopiedNodes:n=>e({copiedNodes:n}),clearCopiedNodes:()=>e({copiedNodes:[]}),expandGroup:null,collapseGroup:null})),is=()=>{const{tasks_api:e}=he();return{getTemplateWithTasks:async n=>{var s;try{const o=Pe.stringify({filters:{plantilla:{id:n}}},{encodeValuesOnly:!0}),i=await e.get(`/api/plantillas/plantilla-tareas-grafico?${o}`);if(i.data&&i.data.data)return i.data.data;throw new Error(`No se encontraron datos para la plantilla con ID ${n}`)}catch(o){throw console.error("Error en getTemplateWithTasks:",{error:o.message,status:(s=o.response)==null?void 0:s.status}),o}}}},ve={DIRTY:"dirty",IDLE:"idle",NEW:"new"},Ee={DRAFT:"draft",PUBLISHED:"published",DELETED:"deleted"},Ve="templates",We="templates_states";function ur(e,a){return Ue.create((n,s)=>{let o=null;const i=p=>n({isLoading:p}),r=p=>n({error:p}),c=p=>n({data:p}),m=()=>new Promise((p,h)=>{const f=indexedDB.open(e.name,e.version);f.onerror=()=>{r("Error al abrir la base de datos"),h(new Error("Error al abrir la base de datos"))},f.onsuccess=()=>{o=f.result,n({isConnected:!0,error:null}),p(o)},f.onupgradeneeded=g=>{const y=g.target.result;e.stores.forEach(w=>{var j;if(!y.objectStoreNames.contains(w.name)){const b=y.createObjectStore(w.name,{keyPath:w.keyPath,autoIncrement:w.autoIncrement??!1});(j=w.indexes)==null||j.forEach(_=>{b.createIndex(_.name,_.keyPath,_.options)})}})}}),l=(p="readonly")=>{if(!o)throw new Error("Base de datos no conectada");return o.transaction(a,p)},d=(p="readonly")=>l(p).objectStore(a);return{data:[],isLoading:!1,error:null,isConnected:!1,connect:async()=>{try{i(!0),r(null),await m(),await s().getAll()}catch(p){r(p instanceof Error?p.message:"Error desconocido")}finally{i(!1)}},disconnect:()=>{o&&(o.close(),o=null,n({isConnected:!1,data:[]}))},add:async p=>{try{i(!0),r(null);const h=d("readwrite");return new Promise((f,g)=>{const y=h.add(p);y.onsuccess=async()=>{await s().getAll(),f()},y.onerror=()=>{r("Error al agregar elemento"),g(new Error("Error al agregar elemento"))}})}finally{i(!1)}},addMany:async p=>{try{i(!0),r(null);const h=d("readwrite");return new Promise((f,g)=>{let y=0,w=!1;p.forEach(j=>{const b=h.add(j);b.onsuccess=()=>{y++,y===p.length&&!w&&s().getAll().then(()=>f())},b.onerror=()=>{w||(w=!0,r("Error al agregar elementos"),g(new Error("Error al agregar elementos")))}})})}finally{i(!1)}},get:async p=>{try{r(null);const h=d();return new Promise((f,g)=>{const y=h.get(p);y.onsuccess=()=>{f(y.result)},y.onerror=()=>{r("Error al obtener elemento"),g(new Error("Error al obtener elemento"))}})}catch(h){r(h instanceof Error?h.message:"Error desconocido");return}},getAll:async()=>{try{r(null);const p=d();return new Promise((h,f)=>{const g=p.getAll();g.onsuccess=()=>{const y=g.result;c(y),h(y)},g.onerror=()=>{r("Error al obtener elementos"),f(new Error("Error al obtener elementos"))}})}catch(p){return r(p instanceof Error?p.message:"Error desconocido"),[]}},update:async(p,h)=>{try{i(!0),r(null);const f=d("readwrite");return new Promise((g,y)=>{const w=f.get(p);w.onsuccess=()=>{const j=w.result;if(!j){r("Elemento no encontrado"),y(new Error("Elemento no encontrado"));return}const b={...j,...h},_=f.put(b);_.onsuccess=async()=>{await s().getAll(),g()},_.onerror=()=>{r("Error al actualizar elemento"),y(new Error("Error al actualizar elemento"))}},w.onerror=()=>{r("Error al obtener elemento para actualizar"),y(new Error("Error al obtener elemento para actualizar"))}})}finally{i(!1)}},delete:async p=>{try{i(!0),r(null);const h=d("readwrite");return new Promise((f,g)=>{const y=h.delete(p);y.onsuccess=async()=>{await s().getAll(),f()},y.onerror=()=>{r("Error al eliminar elemento"),g(new Error("Error al eliminar elemento"))}})}finally{i(!1)}},clear:async()=>{try{i(!0),r(null);const p=d("readwrite");return new Promise((h,f)=>{const g=p.clear();g.onsuccess=()=>{c([]),h()},g.onerror=()=>{r("Error al limpiar store"),f(new Error("Error al limpiar store"))}})}finally{i(!1)}},query:async(p,h)=>{try{r(null);const g=d().index(p);return new Promise((y,w)=>{const j=g.getAll(h);j.onsuccess=()=>{y(j.result)},j.onerror=()=>{r("Error en consulta"),w(new Error("Error en consulta"))}})}catch(f){return r(f instanceof Error?f.message:"Error desconocido"),[]}},queryRange:async(p,h,f)=>{try{r(null);const y=d().index(p);return new Promise((w,j)=>{const b=IDBKeyRange.bound(h,f),_=y.getAll(b);_.onsuccess=()=>{w(_.result)},_.onerror=()=>{r("Error en consulta por rango"),j(new Error("Error en consulta por rango"))}})}catch(g){return r(g instanceof Error?g.message:"Error desconocido"),[]}}}})}const yt=new Map;function ha(e,a,n=!0){const s=u.useMemo(()=>{const _=`${e.name}-${a}`;if(!yt.has(_)){const M=ur(e,a);yt.set(_,M)}return yt.get(_)},[e.name,a]);u.useEffect(()=>{n&&!s.getState().isConnected&&s.getState().connect()},[n,s]);const o=s(_=>_.data),i=s(_=>_.isLoading),r=s(_=>_.error),c=s(_=>_.isConnected),m=u.useCallback(()=>s.getState().connect(),[s]),l=u.useCallback(()=>s.getState().disconnect(),[s]),d=u.useCallback(_=>s.getState().add(_),[s]),p=u.useCallback(_=>s.getState().addMany(_),[s]),h=u.useCallback(_=>s.getState().get(_),[s]),f=u.useCallback(()=>s.getState().getAll(),[s]),g=u.useCallback((_,M)=>s.getState().update(_,M),[s]),y=u.useCallback(_=>s.getState().delete(_),[s]),w=u.useCallback(()=>s.getState().clear(),[s]),j=u.useCallback((_,M)=>s.getState().query(_,M),[s]),b=u.useCallback((_,M,F)=>s.getState().queryRange(_,M,F),[s]);return{data:o,isLoading:i,error:r,isConnected:c,connect:m,disconnect:l,add:d,addMany:p,get:h,getAll:f,update:g,delete:y,clear:w,query:j,queryRange:b}}const ls=u.createContext(void 0);function pr({children:e}){const[a,n]=u.useState(!1),[s,o]=u.useState(!0),[i,r]=u.useState(null),c={name:"template_tabs_v1",version:2,stores:[{name:Ve,keyPath:"id",autoIncrement:!1,indexes:[{name:"id",keyPath:"id",options:{unique:!0}}]},{name:We,keyPath:"id",autoIncrement:!1,indexes:[{name:"id",keyPath:"id",options:{unique:!0}}]}]},m=ha(c,Ve,!0),l=ha(c,We,!0),d=u.useRef(new Map);d.current.has(Ve)||d.current.set(Ve,m),d.current.has(We)||d.current.set(We,l);const p=m.isConnected,h=m.error;u.useEffect(()=>{d.current.set(Ve,m),d.current.set(We,l)},[m,l]);const f=u.useCallback(y=>{const w=d.current.get(y);if(!w)throw new Error(`Store ${y} no encontrado. Asegúrate de que esté configurada en indexedDBConfig.`);return{data:w.data,isLoading:w.isLoading,add:w.add,addMany:w.addMany,get:w.get,getAll:w.getAll,update:w.update,delete:w.delete,clear:w.clear,query:w.query,queryRange:w.queryRange,error:w.error}},[]);u.useEffect(()=>{(async()=>{try{if(o(!0),r(null),await m.connect(),p)n(!0);else throw new Error("No se pudo establecer la conexión con IndexedDB")}catch(w){r(w instanceof Error?w.message:"Error desconocido")}finally{o(!1)}})()},[m.connect,p]),u.useEffect(()=>{h&&r(h)},[h]);const g={isInitialized:a,isInitializing:s,error:i,isConnected:p,getStore:f};return t.jsx(ls.Provider,{value:g,children:e})}function cs(){const e=u.useContext(ls);if(e===void 0)throw new Error("useIndexedDBContext debe usarse dentro de IndexedDBProvider");return e}function $t(){const{getStore:e}=cs();return e(Ve)}function ds(){const{add:e}=$t(),a=async r=>{try{await e(r)}catch(c){console.error("Error al guardar plantilla a indexDB:",c)}},n=async r=>{const c={},m=l=>{l.id&&(c[l.id]=l),l.tareas&&Array.isArray(l.tareas)&&l.tareas.forEach(d=>{m(d)}),l.ids_t_dependientes&&Array.isArray(l.ids_t_dependientes)&&l.ids_t_dependientes.forEach(d=>{typeof d=="object"&&d.id&&m(d)}),l.plantilla_dependents&&Array.isArray(l.plantilla_dependents)&&l.plantilla_dependents.forEach(d=>{d.tarea_plantillas&&Array.isArray(d.tarea_plantillas)&&d.tarea_plantillas.forEach(p=>{m(p)})})};return r.tarea_plantillas.forEach(l=>{m(l)}),c},s=(r,c)=>{const m=c[r];if(!m)return[];const l=[m];return m.tareas&&Array.isArray(m.tareas)&&m.tareas.forEach(d=>{d.id&&l.push(...s(d.id,c))}),m.ids_t_dependientes&&Array.isArray(m.ids_t_dependientes)&&m.ids_t_dependientes.forEach(d=>{typeof d=="object"&&d.id?l.push(...s(d.id,c)):typeof d=="number"&&c[d]&&l.push(...s(d,c))}),l},o=(r,c)=>{const m=c[r];if(!m)return[];const l=[m];return m.tarea_padre&&c[m.tarea_padre]&&l.unshift(...o(m.tarea_padre,c)),l};return{hydrateTasks:async r=>{var l,d;const c=await n(r);return(d=(l=r==null?void 0:r.graph_layout)==null?void 0:l.snapshot)==null?void 0:d.nodes.map(p=>{if(p.type==="group")return{...p,data:{...p.data,type:"template"},type:"group",selected:!1};const h=p.data.tareaId?c[p.data.tareaId]:r;return h!=null&&h.start?{...p,data:{...h.plantilla,id:h.id},selected:!1}:{...p,data:{...h,type:"task"},selected:!1}})},initializeTemplateStore:a,indexedTasks:n,getTaskHierarchy:s,getTaskPath:o}}function ms(){const{getStore:e}=cs();return e(We)}const nt=()=>{const{add:e,get:a,delete:n,update:s}=ms(),{get:o}=$t(),i={created:[],updated:[],deleted:[]},r=async({templateId:f})=>{const g=await a(f);return g||null};return{addTaskToState:async({task:f})=>{const g=await r({templateId:f.plantilla.id}),y=await o(f.plantilla.id);if(console.log("🔄 template:",y),!g)e({...i,id:f.plantilla.id,created:[...i.created,f]});else{const w=g.created.findIndex(j=>j.id===f.id);if(w!==-1){const j=g.created[w];g.created[w]={...j,...f},await s(f.plantilla.id,g)}else g.created.push(f),await s(f.plantilla.id,g)}},getTaskFromState:r,removeTemplateStates:async f=>{await n(f)},updateTaskInState:async({task:f})=>{const g=await r({templateId:f.plantilla.id}),w=(await o(f.plantilla.id)).graph_layout.snapshot.nodes;if(console.log("🔄 nodes:",w),g){const j=g.updated.findIndex(b=>b.id===f.id);if(j!==-1){const b=g.updated[j];console.log("🔄 currentTask:",b),g.updated[j]={...b,...f}}else g.updated.push(f);await s(f.plantilla.id,g)}else e({...i,id:f.plantilla.id,updated:[...i.updated,f]})},removeTaskFromState:async({templateId:f,id:g})=>{const y=await r({templateId:f});if(y){if(g>0){const j=y.deleted.findIndex(b=>b===g);if(j!==-1){y.deleted.splice(j,1),await s(f,y);return}}const w=y.created.findIndex(j=>j.id===g);if(w!==-1){y.created.splice(w,1),await s(f,y);return}}else if(g>0){e({...i,id:f,deleted:[...i.deleted,g]});return}},removeParentIdFromNodes:async({templateId:f,id:g})=>{const y=await r({templateId:f});if(y){const w=y.created.findIndex(b=>b.id===g);if(w!==-1){y.created[w].tarea_padre=null,y.created[w].id_t_requerida=null,await s(f,y);return}const j=y.updated.findIndex(b=>b.id===g);if(j!==-1){y.updated[j].tarea_padre=null,y.updated[j].id_t_requerida=null,await s(f,y);return}}},updateNodeWithNewEdge:async({templateId:f,edge:g,task:y})=>{console.log("🔵 updateNodeWithNewEdge - Inicio",{templateId:f,taskId:y.id,taskData:y});const w=await r({templateId:f});if(console.log("🔵 updateNodeWithNewEdge - Estado actual:",w),w){console.log("🔵 updateNodeWithNewEdge - Estado existe, buscando tarea...");const j=w.created.findIndex(_=>_.id===y.id);if(console.log("🔵 updateNodeWithNewEdge - Índice en created:",j),j!==-1){console.log("🔵 updateNodeWithNewEdge - Actualizando en created"),w.created[j]=y,await s(f,w),console.log("✅ updateNodeWithNewEdge - Actualizado en created");return}const b=w.updated.findIndex(_=>_.id===y.id);if(console.log("🔵 updateNodeWithNewEdge - Índice en updated:",b),b!==-1){console.log("🔵 updateNodeWithNewEdge - Actualizando en updated"),w.updated[b]=y,await s(f,w),console.log("✅ updateNodeWithNewEdge - Actualizado en updated");return}if(console.log("🔵 updateNodeWithNewEdge - Tarea no encontrada en arrays"),y.id&&y.id!==0){const _=y.id<0;_?(console.log("🔵 updateNodeWithNewEdge - Agregando a created (tarea nueva)"),w.created.push(y)):(console.log("🔵 updateNodeWithNewEdge - Agregando a updated (tarea existente)"),w.updated.push(y)),await s(f,w),console.log("✅ updateNodeWithNewEdge - Tarea agregada exitosamente a",_?"created":"updated")}else console.error("❌ updateNodeWithNewEdge - task.id no válido para agregar:",y.id)}else if(console.log("🔵 updateNodeWithNewEdge - Creando nuevo estado"),y.id&&y.id!==0){const j=y.id<0,b={...i,id:f,created:j?[y]:[],updated:j?[]:[y]};console.log("🔵 updateNodeWithNewEdge - Nuevo estado:",b,j?"(created)":"(updated)"),e(b),console.log("✅ updateNodeWithNewEdge - Estado creado exitosamente")}else console.error("❌ updateNodeWithNewEdge - task.id no válido:",y.id);console.log("🔵 updateNodeWithNewEdge - Fin")}}};function Be(){const{activeTemplate:e,setActiveTemplate:a}=Le(),{mode:n,setMode:s,setViewMode:o,clearViewMode:i}=Te(),{template:r,setIsOpenModalLimit:c,setOpenModalUnsavedChanges:m,setOpenModalPublishTemplate:l,setOpenModalDeleteTemplate:d}=Fe(),{hydrateTasks:p}=ds(),{addTaskToState:h,removeTemplateStates:f}=nt(),g=me.useQueryClient(),{data:y,add:w,update:j,get:b,getAll:_,delete:M,isLoading:F,error:R}=$t(),{get:N}=ms(),{getTemplateWithTasks:D}=is(),{tasks_api:v}=he(),[U,K]=u.useState(!1),[J,H]=u.useState(!1),[O,S]=u.useState(!1),B=u.useMemo(()=>y.sort((C,$)=>C.order-$.order),[y]);u.useEffect(()=>{B.length===0&&n!=="grid"&&s("grid")},[B,n,s]);const k=async(P,C=ve.IDLE)=>{var $;try{const L=await D(P.id),T=await p(L),V={id:crypto.randomUUID(),data:L,type:"start",dragging:!1,measured:{width:171,height:48},position:{x:91,y:-24.5},selected:!1,deletable:!1},Y=T||[V],ae={...L,graph_layout:{...L==null?void 0:L.graph_layout,snapshot:{...($=L==null?void 0:L.graph_layout)==null?void 0:$.snapshot,nodes:Y}},estatus:C,estatusFromStrapi:L.estatus};await w(ae)}catch(L){console.warn("No se pudieron obtener los datos completos de la plantilla, creando versión básica:",L);const T=P,V={id:crypto.randomUUID(),data:T,type:"start",dragging:!1,measured:{width:171,height:48},position:{x:91,y:-24.5},selected:!1,deletable:!1},Y={id:T.id,snapshot:{nodes:[V],edges:[],viewport:{x:0,y:0,zoom:1}},history:null,zoom:1,position:{x:0,y:0}},ae={...T,graph_layout:T.graph_layout||Y,estatus:C,tarea_plantillas:T.tarea_plantillas||[]};await w(ae)}},q=async({template:P,checkTemplateInIndexedDB:C=!1,statusTemplate:$=ve.IDLE})=>{const L=B;if(!L.find(V=>V.id===P.id)){if(L.length===5){c(!0);return}if(C&&await b(P.id))return;await k({...P,order:L.length+1},$)}await W(P.id),await ee(P),s("create-edit",P==null?void 0:P.id)},ee=async P=>{const C=await b(P.id);a(C)},W=async P=>{try{let C=await _();C.sort((L,T)=>(L.order||0)-(T.order||0));const $=C.findIndex(L=>L.id===P);if($!==-1){const[L]=C.splice($,1);C.unshift(L),C.forEach((V,Y)=>{V.order=Y+1});const T=C.map(V=>j(V.id,V));await Promise.all(T)}else return}catch{}},re=async P=>{try{await M(P),i(P);const C=await _();C.forEach((L,T)=>{L.order=T+1});const $=C.map(L=>j(L.id,L));await Promise.all($)}catch{}};return{screens:B,isLoading:F,error:R,add:w,data:y,addScreen:k,openTemplate:q,update:j,delete:re,get:b,activeTemplate:e,activateTemplate:ee,reorderingTemplates:W,replaceTemplate:async()=>{try{const P=[...B],C={...P[P.length-1]};await M(C.id);const $={...r,order:C.order};await k($);const T=(await _()).sort((Y,ae)=>Y.order-ae.order);if(T.some((Y,ae)=>(Y.order||0)!==ae+1)){const Y=T.map((ae,le)=>({...ae,order:le+1}));for(const ae of Y)try{await j(ae.id,ae)}catch{}}}catch{}finally{c(!1)}},addTaskUpdatingTemplate:async(P,C,$="hija")=>{var Y,ae,le,X;const L=await b(C);if(!L)return null;const T={id:P.id,uuid:crypto.randomUUID(),reference_graph:P.reference_graph,texto_corto:P.title,texto_largo:P.description||"",prioridad:P.priority||null,nivel_dificultad:P.difficulty||1,duracion:P.duration||null,start:!1,type:"task",equipo:{id:Number(P.team)||null},responsable:{id:Number(P.responsible)||null},plantilla:{id:L.id,clave:L.clave,categoria:L.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:[],id_t_requerida:$==="dependiente"?(ae=(Y=P.parent)==null?void 0:Y.data)==null?void 0:ae.id:null,ids_t_dependientes:[],tarea_padre:$==="hija"?(X=(le=P.parent)==null?void 0:le.data)==null?void 0:X.id:null,tareas:[]},V={...L,estatus:ve.DIRTY};return await j(C,V),e&&e.id===C&&a(V),await h({task:T}),T},addTemplateUpdatingTemplate:async(P,C,$,L="hija")=>{let T=null;if(e&&e.id===C?T=e:T=await b(C),!T)return null;const V=(ae,le,X,se)=>{for(let ce=0;ce<ae.length;ce++){const ie=ae[ce];if(ie.id===le||ie.uuid===le)return se==="dependiente"?(ie.plantilla_dependents||(ie.plantilla_dependents=[]),ie.plantilla_dependents.push(X)):se==="hija"&&(ie.plantilla_dependents||(ie.plantilla_dependents=[]),ie.plantilla_dependents.push(X)),!0;if(ie.tareas&&ie.tareas.length>0){const te=V(ie.tareas,le,X,se);if(te)return te}}return!1};if(V(T.tarea_plantillas,$,P,L)){const ae={...T,estatus:ve.DIRTY,updatedAt:new Date().toISOString()};return await j(C,ae),e&&e.id===C&&a(ae),!0}else return!1},updateGraphLayout:async(P,C)=>{var $;if(!P){console.warn("⚠️ updateGraphLayout - Template ID no válido");return}try{const L=await b(P);if(!L){console.warn("⚠️ updateGraphLayout - Template no encontrado");return}const T=(C.nodes||[]).filter(se=>{var ce;return!((ce=se.data)!=null&&ce.isInternal)&&!se.parentId}).map(se=>{const{style:ce,measured:ie,data:te,...ue}=se,{expandedDimensions:fe,isExpanded:xe,needsReExpansion:pe,...ye}=te||{},Me=ce?{...ce,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...ue,style:Me,data:ye,position:se.position}}),V=(C.edges||[]).filter(se=>{var ce;return!((ce=se.data)!=null&&ce.isInternal)}).map(se=>{var ce;if((ce=se.data)!=null&&ce.redirectedToInternal){const{redirectedToInternal:ie,originalTarget:te,...ue}=se.data;return{...se,target:te||se.target,data:ue}}return se}),Y={...C,nodes:T,edges:V},ae=($=L.graph_layout)==null?void 0:$.snapshot;if(!(!ae||JSON.stringify(ae)!==JSON.stringify(Y)))return;const X={...L,graph_layout:{...L.graph_layout,snapshot:Y},estatus:ve.DIRTY,updatedAt:new Date().toISOString()};await j(P,X),e&&e.id===P&&a(X)}catch(L){console.error("❌ updateGraphLayout - Error:",L)}},saveTemplateChanges:async(P=!0)=>{try{if(e.estatus===ve.DIRTY){H(!0);const{id:C}=e,$=await b(C),L=await N(C),T=$.graph_layout.snapshot.nodes||[],V=T.filter(X=>{var se;return!((se=X.data)!=null&&se.isInternal)&&!X.parentId}),Y=T.length-V.length;Y>0&&console.warn(`💾 [saveTemplateChanges] Se filtraron ${Y} nodos internos al guardar plantilla ${C}`);const ae={graph_layout:{...$.graph_layout,snapshot:{...$.graph_layout.snapshot,nodes:V.map(X=>{const{style:se,measured:ce,selected:ie,...te}=X,ue=se?{...se,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return X.type==="group"?{...te,style:ue,data:{tareaId:X.data.id&&X.data.id>0?X.data.id:null,clave:X.data.clave,estatus:X.data.estatus,updatedAt:X.data.updatedAt,id:X.data.id}}:{...te,style:ue,data:{tareaId:X.data.id&&X.data.id>0?X.data.id:null}}}),edges:($.graph_layout.snapshot.edges||[]).filter(X=>{var se;return!((se=X.data)!=null&&se.isInternal)})}},tasks:{created:(L==null?void 0:L.created)||[],updated:(L==null?void 0:L.updated)||[],deleted:(L==null?void 0:L.deleted)||[]}},le=await v.post("/api/tareas/save-tareas-grafico",{data:ae});if(le.data&&le.status===200){try{const X=await D(C),se=await p(X),ce={...X,graph_layout:{...X.graph_layout,snapshot:{...X.graph_layout.snapshot,nodes:se}},estatus:ve.IDLE};await j(C,ce),P||a(ce)}catch{const se=await b(C);if(se&&!P){const ce={...se,estatus:ve.IDLE};await j(C,ce),a(ce)}}await g.invalidateQueries({queryKey:["template",C]}),await g.invalidateQueries({queryKey:["template"]}),f(C),P&&(re(C),m(!1)),o(C,"readonly")}}}catch(C){console.log(C)}finally{H(!1)}},publishTemplate:async P=>{try{K(!0);const C={estatus:Ee.PUBLISHED,publication_date:new Date},$=await v.put(`/api/plantillas/plantilla-update-estatus/${P}`,{data:C});$.data&&$.status===200&&(a({...e,estatusFromStrapi:Ee.PUBLISHED}),l(!1),x.toast.info("Se publicó correctamente el proceso"))}catch(C){console.log(C),x.toast.error("Surgió un error al publicar el proceso")}finally{K(!1)}},deleteTemplate:async P=>{try{S(!0);const C={estatus:Ee.DELETED,sjdaksd:0},$=await v.put(`/api/plantillas/plantilla-update-estatus/${P}`,{data:C});$.data&&$.status===200&&(d(!1),x.toast.info("Se eliminó correctamente el proceso"))}catch(C){console.error(C),x.toast.error("Surgión un error al eliminar el proceso")}finally{S(!1)}},loadingPublishTemplate:U,loadingSaveChanges:J,loadingDeleteTemplate:O}}const fr=async({tasks_api:e})=>{try{return(await e.get("/api/getAllOBPusers")).data}catch(a){throw console.log("Error al obtener los usuarios de OBP",a),`Error al obtener los usuarios de OBP: ${a}`}},gr=()=>{const{tasks_api:e}=he();return{users:me.useQuery({queryKey:["usersOBP"],queryFn:()=>fr({tasks_api:e}),staleTime:1e3*60*60*24})}},Ze=()=>{const{users:e}=gr(),a=me.useQuery({queryKey:["users_index",e.data],queryFn:()=>co({users:e.data||[]}),staleTime:1e3*60*60*24,enabled:!!e.data});return{users:a.data,isLoading:a.isLoading||e.isLoading}},us=()=>{const{users:e,isLoading:a}=Ze(),{getImageOBP:n}=he();return{getImageByEmail:i=>{const r=e==null?void 0:e[i];return n(r==null?void 0:r.image)},getNameByEmail:i=>{const r=e==null?void 0:e[i];return(r==null?void 0:r.nombre)||""},isLoading:a}},ot=({isLoading:e})=>e?t.jsxs("div",{className:"tm-fixed tm-inset-0 tm-z-50 tm-flex tm-items-center tm-justify-center",children:[t.jsx("div",{className:"tm-absolute tm-inset-0",style:{backgroundColor:"rgba(255, 255, 255, 0.5)"}}),t.jsx("div",{className:"tm-relative tm-flex tm-flex-col tm-items-center tm-justify-center tm-gap-4",children:t.jsx(x.Spinner,{})})]}):null,xa=({template:e,openModalPublishTemplate:a,onHadleClickEditTemplateParams:n,onEditTasks:s,canDuplicateAndDeleteTemplates:o,onHandleClickDuplicateTemplate:i,openModalDeleteTemplate:r})=>t.jsx(x.Popup,{color:"secondary",pill:"pill",icon:de.faEllipsis,stopPropagationList:!0,children:t.jsxs(x.List,{className:"tm-p-6 tm-gap-4",children:[e.estatus!==Ee.PUBLISHED&&e.counts_tasks>2&&t.jsx(x.ListItem,{icon:de.faArrowUp,onClick:a,children:"Publicar"}),t.jsx(x.ListItem,{icon:de.faEdit,onClick:()=>{n(e)},children:"Editar parámetros"}),t.jsx(x.ListItem,{icon:de.faEdit,onClick:()=>{s&&s(e)},children:"Editar tareas"}),o&&t.jsx(x.ListItem,{icon:de.faClone,onClick:c=>{c.stopPropagation(),i(e)},children:"Duplicar"}),o&&t.jsx(x.ListItem,{color:"red",icon:de.faTrash,onClick:r,children:"Eliminar"})]})}),ps=({fullWidth:e,mode:a="grid",onClick:n,active:s,template:o,withOptions:i=!0})=>{const{openTemplate:r}=Be(),{getImageByEmail:c,getNameByEmail:m}=us(),{setIsEditTemplate:l,setOpenModalCreateTemplate:d,setCurrentTemplateForEdit:p,setIsDuplicateTemplate:h,setOpenModalPublishTemplate:f,setCurrentTemplateId:g,setOpenModalDeleteTemplate:y}=Fe(),w={0:{color:"accent",theme:"solid"},1:{color:"accent",theme:"soft"},2:{color:"warning",theme:"solid"},3:{color:"info",theme:"solid"},4:{color:"gray",theme:"solid"},5:{color:"warning",theme:"soft"},6:{color:"danger",theme:"solid"},7:{color:"info",theme:"soft"},8:{color:"success",theme:"solid"},9:{color:"danger",theme:"solid"}},[j,b]=u.useState(!1),_=async()=>{if(b(!0),a==="grid")try{b(!0),await r({template:o,checkTemplateInIndexedDB:!0})}catch(q){console.error(q)}finally{b(!1)}else b(!1);n==null||n(o==null?void 0:o.id)},M=async()=>{if(!(a!=="grid"||!o)){b(!0);try{await r({template:o,checkTemplateInIndexedDB:!0}),n==null||n(o==null?void 0:o.id)}catch(q){console.error(q)}finally{b(!1)}}},F=q=>{l(!0),d(!0),p(q)},R=q=>{h(!0),d(!0),p(q)},N=()=>{g(o==null?void 0:o.id),f(!0)},D=()=>{g(o==null?void 0:o.id),y(!0)},v=(o==null?void 0:o.dias_duracion)===1?"Día":"Días",U=(o==null?void 0:o.counts_tasks)===1?"Tarea":"Tareas",K=(o==null?void 0:o.estatus)===Ee.PUBLISHED?Tt(o==null?void 0:o.publication_date).format("DD/MM/YYYY"):Tt(o==null?void 0:o.createdAt).format("DD/MM/YYYY"),J=(o==null?void 0:o.updated_by)||(o==null?void 0:o.created_by),H=c(J==null?void 0:J.email),O=m(J==null?void 0:J.email)||"",S=(o==null?void 0:o.estatus)===Ee.PUBLISHED?"Fecha de publicación":"Fecha de creación",B=(o==null?void 0:o.estatus)===Ee.DRAFT,k=q=>{const ee=q.split("-");return t.jsx(t.Fragment,{children:ee.map((W,re)=>t.jsxs("span",{children:[W,re<ee.length-1&&t.jsx("span",{className:"tm-text-neutral-200",children:"-"})]},re))})};return t.jsxs(x.Card,{active:s,fullWidth:e,onClick:_,className:`${e?"md:tm-flex-row":"tm-flex-col"}`,children:[t.jsx(ot,{isLoading:j}),t.jsx(x.Card.Header,{children:t.jsx("div",{className:"tm-flex tm-justify-between tm-items-start tm-gap-x-4",children:t.jsxs("div",{className:"tm-flex tm-justify-between tm-items-start tm-gap-4 tm-flex-1",children:[t.jsxs("div",{className:"tm-flex tm-place-items-start tm-gap-x-4",children:[t.jsx("div",{className:"tm-flex tm-items-center",children:t.jsx(x.Icon,{name:ze.faChartDiagram,colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,size:"lg"})}),t.jsxs("div",{className:"tm-flex tm-gap-x-1 tm-flex-col tm-gap-y-4",children:[t.jsx("h1",{className:"tm-text-base tm-py-0.5 tm-font-body-sm-bold tm-text-body-sm-bold tm-leading-none tm-text-primary",children:k((o==null?void 0:o.clave)||(o==null?void 0:o.nombre_plantilla))}),t.jsxs("div",{className:"tm-flex tm-items-baseline tm-gap-x-1",children:[t.jsx(x.Badge,{size:"sm",theme:"soft",color:(o==null?void 0:o.estatus)===Ee.PUBLISHED?"success":"gray",label:(o==null?void 0:o.estatus)===Ee.PUBLISHED?"Publicado":"Borrador"}),!(typeof K=="string"&&K==="Invalid date")&&t.jsx(x.Tooltip,{label:S,children:t.jsx("p",{className:"tm-text-body-sm-regular tm-text-tertiary tm-font-body-sm-semibold",children:K})})]})]})]}),!e&&t.jsx(xa,{template:o,openModalPublishTemplate:N,onHadleClickEditTemplateParams:F,onEditTasks:M,canDuplicateAndDeleteTemplates:B,onHandleClickDuplicateTemplate:R,openModalDeleteTemplate:D})]})})}),t.jsx(x.Card.Separator,{vertical:e}),t.jsx(x.Card.Body,{className:"tm-flex tm-flex-wrap tm-gap-x-4 tm-gap-y-1 tm-w-full md:tm-w-auto tm-flex-wrap tm-flex-1 tm-items-center",children:o==null?void 0:o.params_plantillas.map((q,ee)=>{const W=w[q.params_tipo.order-1];return t.jsx(x.Badge,{color:W.color,theme:W.theme,label:q.name,size:"sm"},q.name)})}),!e&&t.jsx(x.Card.Separator,{vertical:e}),t.jsxs(x.Card.Footer,{className:"tm-flex tm-justify-between tm-w-full md:tm-w-auto tm-gap-x-4",children:[t.jsxs("div",{className:`tm-flex tm-flex-1 ${e?"tm-gap-x-2 md:tm-gap-20 lg:tm-gap-32 2xl:tm-gap-44":""}`,children:[t.jsx("div",{className:`tm-flex tm-gap-x-1 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col":"tm-flex-row"}`,children:t.jsx(x.Tooltip,{label:"Tareas totales",children:t.jsxs("div",{className:`tm-flex tm-items-center tm-gap-2 ${e?"tm-flex-col":"tm-flex-row"}`,children:[t.jsx("p",{className:"tm-text-icon-all-colors-blue tm-text-xs tm-text-center tm-leading-none tm-font-semibold",children:(o==null?void 0:o.counts_tasks)||0}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:U})]})})}),t.jsx("div",{className:`tm-flex tm-gap-x-1 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col":"tm-flex-row"}`,children:t.jsx(x.Tooltip,{label:"Tareas totales",children:t.jsxs("div",{className:`tm-flex tm-items-center tm-gap-2 ${e?"tm-flex-col":"tm-flex-row"}`,children:[t.jsx("p",{className:"tm-text-icon-all-colors-blue tm-text-xs tm-text-center tm-leading-none tm-font-semibold",children:(o==null?void 0:o.dias_duracion)||0}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:v})]})})}),t.jsxs("div",{className:`tm-flex tm-gap-x-1 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col-reverse tm-gap-y-1":"tm-flex-row"}`,children:[t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Editor"}),t.jsx(x.Tooltip,{label:O,children:t.jsx(x.Avatar,{src:H,size:"xxs",type:"people"})})]})]}),e&&i&&t.jsx(x.Card.Separator,{vertical:e}),i&&t.jsx("div",{className:`tm-w-auto ${e?"tm-flex tm-items-center":""}`,children:e&&t.jsx(xa,{template:o,openModalPublishTemplate:N,onHadleClickEditTemplateParams:F,onEditTasks:M,canDuplicateAndDeleteTemplates:B,onHandleClickDuplicateTemplate:R,openModalDeleteTemplate:D})})]})]})},hr={1:"blue",2:"green",3:"red",4:"yellow"},xr=({difficulty:e})=>t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[t.jsx(x.Icon,{name:de.faRhombus,size:"md",color:hr[e]}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Dificultad"})]}),br=({duration:e})=>t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end",children:[t.jsx("p",{className:"tm-text-icon-all-colors-blue tm-text-body-lg-regular tm-leading-none tm-font-semibold",children:e}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Duración"})]}),yr={1:"neutral",2:"blue",3:"yellow",4:"red"},jr=({priority:e})=>t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[t.jsx(x.Icon,{name:de.faFlag,size:"md",color:yr[e]}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Prioridad"})]});class wr{static toUsers(a){return{id:a.id,name:a.nombre,image:a.image,email:a.email}}}const vr=async({tasks_api:e})=>{try{const a=Pe.stringify({filters:{blocked:!1}},{encodeValuesOnly:!0}),n=await e.get(`/api/users?${a}`);return be(n.data).map(wr.toUsers).sort((o,i)=>o.name.localeCompare(i.name))}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},Ut=()=>{const{tasks_api:e}=he(),a=me.useQuery({queryKey:["users-mt"],queryFn:()=>vr({tasks_api:e}),staleTime:1e3*60*60*24});return{isLoading:a.isLoading,users:a.data}},_r=({responsible:e})=>{const{isLoading:a}=Ut(),{getImageByEmail:n,isLoading:s}=us();return a||s?null:t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end",children:[t.jsx(x.Avatar,{size:"xs",src:n(e==null?void 0:e.email),type:"people"}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Responsable"})]})},Tr=[{label:"Muy alta",value:4,icon:de.faFlag,iconColor:"red"},{label:"Alta",value:3,icon:de.faFlag,iconColor:"yellow"},{label:"Media",value:2,icon:de.faFlag,iconColor:"blue"},{label:"Baja",value:1,icon:de.faFlag,iconColor:"neutral"}],Cr=[{label:"Muy alta",value:4,icon:de.faRhombus,iconColor:"red"},{label:"Alta",value:3,icon:de.faRhombus,iconColor:"yellow"},{label:"Media",value:2,icon:de.faRhombus,iconColor:"blue"},{label:"Baja",value:1,icon:de.faRhombus,iconColor:"neutral"}],Nr=[{label:"1 día",value:1},{label:"2 días",value:2},{label:"3 días",value:3},{label:"4 días",value:4},{label:"5 días",value:5}],fs=({isOpen:e,onClose:a,onSuccess:n,nodeDataType:s,parentNodeInfo:o,editMode:i=!1,taskToEdit:r})=>{const{data:c}=Vs(),{users:m}=Ut(),{users:l}=Ze(),{getImageOBP:d}=he(),p=u.useMemo(()=>{try{return!m||!l?[]:m.map(N=>{const D=l[N.email],v=D!=null&&D.image?d(D.image):"";return{label:N.name,value:N.id.toString(),icon:v}})}catch(N){return console.error("Error mapeando usuarios:",N),[]}},[m,l]),h=()=>{if(i&&r){const N=K=>{if(K==null)return"";const J=Number(K);return isNaN(J)?"":J},D=K=>K?typeof K=="string"?Number(K)||"":K.id||"":"",v=K=>{var J;return K?typeof K=="string"?K:((J=K.id)==null?void 0:J.toString())||K.name||K.nombre||"":""};return{title:r.texto_corto||"",description:r.texto_largo||"",priority:N(r.prioridad),difficulty:N(r.nivel_dificultad),duration:N(r.duracion),team:D(r.equipo),responsible:v(r.responsable),type:"tarea"}}return{title:"",description:"",priority:"",difficulty:"",duration:"",team:"",responsible:"",type:"tarea"}},{control:f,handleSubmit:g,formState:{errors:y,isValid:w},reset:j,watch:b}=Se.useForm({mode:"onChange",defaultValues:h()});u.useEffect(()=>{e&&j(h())},[e,i,r,j]);const _=b(),M=w&&_.title&&_.description&&_.priority&&_.difficulty&&_.duration&&_.team&&Object.keys(y).length===0,F=async N=>{try{if(["title","description","priority","difficulty","duration","team"].filter(U=>!N[U]).length>0)return;n&&n({...N,parent:o}),j()}catch{}},R=()=>{j(),a()};return t.jsx(x.Drawer,{titleIcon:de.faPencil,isOpen:e,onClose:R,onSuccess:()=>{g(N=>{F(N)},N=>{const D=Object.entries(N).map(([v,U])=>`${v}: ${U.message}`).join(`
|
|
5
|
+
`,children:re()})})]})})},Te={texts:{subtext:"#4f4f4f",placeholder:"#929292"},primary:{regular:"#425CAC"},success:{dark:"#368156",regular:"#43B071"},danger:{dark:"#8C352C",regular:"#C34335"},warning:{dark:"#B4782F",regular:"#D38A31"}},yo=({id:e,idAtraso:t})=>{const[n,s]=u.useState(!1),{completeTask:o}=He();return{checked:n,checkTask:()=>{s(!n),o({id:e,idAtraso:t})}}},ua={checked:"tm-mx-[2px] tm-flex tm-h-[20px] tm-w-[20px] tm-items-center tm-justify-center tm-rounded-full tm-bg-success-regular tm-transition-all",unchecked:"tm-transition-colors"},jo="tm-mx-[2px] tm-flex tm-items-center tm-justify-center tm-rounded-full tm-bg-success-regular tm-transition-all",pa="tm-text-sm tm-flex tm-w-fit tm-max-w-[400px] tm-flex-col tm-gap-m tm-rounded-lg tm-border-l-[5px] tm-border-warning-regular tm-bg-warning-light tm-p-l tm-text-warning-dark tm-shadow-04",Va=({id:e,nameRequiredTask:t,statusRequiredTask:n,status:s,idAtraso:o,nameRequiredTaskResponsible:i,name_father_required_task:r,name_father_required_task_responsible:l,repeatsAreCompleted:d=!1})=>{const c=u.useId(),m=`checkbox-${e}-${c}`,{checked:f,checkTask:x}=yo({id:e,idAtraso:o}),h=!!(t&&t!==""&&n===2)||!t,y=!!r,w=s===1&&d,j=()=>a.jsx("label",{htmlFor:m,className:f?ua.checked:ua.unchecked,children:f?a.jsx(g.Icon,{name:ne.faCheck,size:"xs",style:{color:"white"},color:"current"}):a.jsx(g.Icon,{name:ne.faCircle,size:"sm",style:{color:Te.texts.placeholder},color:"current"})});return s===2?a.jsx("div",{className:jo,children:a.jsx(g.Icon,{name:me.faCircleCheck,size:"xs",style:{color:"white"},color:"current"})}):y?a.jsxs(a.Fragment,{children:[a.jsxs("div",{className:"tm-flex tm-w-fit tm-shrink-0 tm-flex-row tm-flex-nowrap tm-items-center tm-gap-1",children:[a.jsx(Ie,{position:"bottom",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:a.jsx("span",{className:"tm-cursor-help tm-inline-flex","aria-hidden":!0,children:a.jsx(g.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:Te.warning.regular},color:"current"})}),children:a.jsxs("div",{className:pa,children:[a.jsx("p",{className:"tm-w-[210px] tm-font-bold",children:"Tarea padre:"}),a.jsx("p",{children:r}),l&&a.jsxs("p",{className:"tm-font-bold",children:["Responsable:"," ",a.jsx("span",{className:"tm-font-normal",children:l})]}),a.jsx("span",{className:"tm-font-normal tm-italic tm-text-[#919191]",children:"Esta tarea completa automáticamente la tarea padre."})]})}),w&&j()]}),a.jsx("input",{id:m,checked:f,onChange:x,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]}):h?a.jsxs(a.Fragment,{children:[s===1&&j(),a.jsx("input",{id:m,checked:f,onChange:x,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]}):a.jsxs(a.Fragment,{children:[a.jsx(Ie,{position:"bottom",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:a.jsx("span",{className:"tm-cursor-help tm-inline-flex","aria-hidden":!0,children:a.jsx(g.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:Te.warning.regular},color:"current"})}),children:a.jsxs("div",{className:pa,children:[a.jsx("p",{className:"tm-w-[210px] tm-font-bold",children:"Requiere completar su tarea:"}),a.jsx("p",{children:t}),i&&a.jsxs("p",{className:"tm-font-bold",children:["Responsable: ",a.jsx("span",{className:"tm-font-normal",children:i})]})]})}),a.jsx("input",{id:m,checked:f,onChange:x,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]})};function wo({items:e}){var s;const[t,n]=u.useState(1);return a.jsxs(a.Fragment,{children:[a.jsx("div",{className:"tm-mb-2 tm-mt-4 tm-flex tm-flex-row tm-border-b tm-border-black-light tm-bg-surface-default",children:e.map((o,i)=>a.jsx("div",{className:"tm-border-r tm-border-black-light",children:a.jsx(g.Button,{color:"tertiary",pill:"none",size:"xs",active:t===o.id,onClick:()=>n(o.id),children:o.label},o.id)},o.id))}),a.jsx("div",{className:"tm-flex-1 tm-overflow-y-auto tm-bg-surface-default tm-pt-4",children:(s=e.find(o=>o.id===t))==null?void 0:s.component})]})}function vo({comment:e}){var o,i,r,l,d;const{getImageOBP:t}=ge(),n=(l=(r=(i=(o=e==null?void 0:e.autor)==null?void 0:o.imagen)==null?void 0:i.formats)==null?void 0:r.thumbnail)==null?void 0:l.url;function s(c){const m=ct.parseISO(c);return ct.formatDistanceToNow(m,{locale:At.es,addSuffix:!0})}return a.jsx("div",{children:a.jsxs("div",{className:"tm-flex tm-flex-row tm-items-start tm-gap-3",children:[a.jsx(Ae,{size:"xxl",imageUrl:n?t(n):"",alt:"@shadcn"}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-4",children:[a.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-4",children:[a.jsx(g.Text,{type:"title",size:"sm",weight:"medium",color:"secondary",children:(d=e==null?void 0:e.autor)==null?void 0:d.nombre}),a.jsx(g.Text,{children:s(e==null?void 0:e.createdAt)})]}),a.jsx(g.Text,{children:e==null?void 0:e.comentario})]})]})})}function _o({currentUser:e,data:t,taskId:n,onNewComment:s}){var p,h,y;const{tasks_api:o,getImageOBP:i}=ge(),{control:r,handleSubmit:l,reset:d}=Ee.useForm({defaultValues:{comment:""}}),[c,m]=u.useState([]),f=(y=(h=(p=e==null?void 0:e.imagen)==null?void 0:p.formats)==null?void 0:h.thumbnail)==null?void 0:y.url;u.useEffect(()=>{if(t!=null&&t.comentarios){const w=[...t.comentarios].sort((j,b)=>new Date(b.createdAt).getTime()-new Date(j.createdAt).getTime());m(w)}},[t]);const x=async w=>{try{const j={id:Date.now(),autor:{id:e==null?void 0:e.id,email:e==null?void 0:e.email,nombre:e==null?void 0:e.nombre,imagen:e==null?void 0:e.imagen},comentario:w.comment,createdAt:new Date().toISOString(),updatedAt:null};await o.post("/api/comentarios",{data:{autor:e==null?void 0:e.id,comentario:w.comment,tarea:n}}),s(!0),m(b=>[j,...b]),d()}catch(j){console.error("Error al agregar comentario:",j)}};return a.jsxs("div",{className:"tm-flex tm-h-full tm-flex-col tm-gap-4",children:[a.jsxs("form",{onSubmit:l(x),className:"tm-flex tm-flex-row tm-items-center tm-gap-3",children:[a.jsx(Ae,{size:"xxl",imageUrl:f?i(f):"",alt:"@shadcn"}),a.jsx("div",{className:"tm-min-w-0 tm-flex-1",children:a.jsx(Ee.Controller,{name:"comment",control:r,rules:{required:"Escribe un comentario"},render:({field:w,fieldState:{error:j}})=>a.jsx(g.Input,{fullWidth:!0,placeholder:"Escribe un comentario",autoComplete:"off",size:"xs",error:j==null?void 0:j.message,...w,value:w.value??""})})})]}),c&&c.map((w,j)=>a.jsx(vo,{comment:w},j))]})}function To({data:e}){const t={0:{color:"tm-bg-gray-400",label:"Sin estado"},1:{color:"tm-bg-primary-regular",label:"En curso"},2:{color:"tm-bg-success-regular",label:"Finalizada"},3:{color:"tm-bg-success-regular",label:"Finalizada"}},n=s=>s?ct.format(new Date(s),"d MMM",{locale:At.es}):"";return a.jsxs("div",{children:[a.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-4",children:[a.jsx(g.Text,{children:"Tareas dependientes"}),a.jsx(g.Text,{className:"tm-flex tm-h-24 tm-w-24 tm-items-center tm-justify-center tm-rounded-full tm-bg-[#E1EBF9] tm-text-xs tm-font-normal tm-text-primary",children:e==null?void 0:e.length})]}),a.jsx("div",{className:"tm-mt-3 tm-flex tm-flex-col tm-gap-2 tm-rounded-lg tm-border tm-border-default",children:e==null?void 0:e.map(s=>{var o,i,r,l,d;return a.jsxs("div",{className:"tm-flex tm-w-full tm-flex-row tm-items-center tm-justify-between tm-gap-s tm-px-2 tm-py-1",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx(Ae,{imageUrl:(l=(r=(i=(o=s.responsable)==null?void 0:o.image)==null?void 0:i.formats)==null?void 0:r.thumbnail)==null?void 0:l.url}),a.jsx(g.Text,{children:s==null?void 0:s.texto_corto})]}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-1",children:[a.jsx(g.Text,{children:n(s==null?void 0:s.createdAt)}),a.jsx("div",{className:`tm-block tm-h-4 tm-w-4 tm-rounded-full tm-bg-gray-400 ${((d=t[s==null?void 0:s.estatus])==null?void 0:d.color)??"tm-bg-gray-400"}`})]})]},s.id)})})]})}function No({id:e,texto_largo:t,user_id:n}){const[s,o]=u.useState(t),{updatingTask:i}=He(),r=async()=>{await i({id:e,data:{texto_largo:s},user:n})};return u.useEffect(()=>{o(t)},[t]),a.jsx("div",{className:"tm-mt-16 tm-flex tm-w-full tm-flex-col tm-gap-3",children:a.jsx(g.Input,{fullWidth:!0,label:"Descripción",size:"md",value:s,onChange:l=>o(l.target.value),onBlur:r,autoComplete:"off",placeholder:"Agregar descripción"})})}function Wa({isOpen:e,setIsOpen:t,taskId:n}){var j,b,v,M,F,R,C,I,T;const[s,o]=u.useState(null),[i,r]=u.useState(!1),[l,d]=u.useState(!1),[c,m]=u.useState(null),f=(M=(v=(b=(j=s==null?void 0:s.responsable)==null?void 0:j.imagen)==null?void 0:b.formats)==null?void 0:v.thumbnail)==null?void 0:M.url,{tasks_api:x,getImageOBP:p}=ge(),{user:h}=je();u.useEffect(()=>{if(e&&n||i){const V=async()=>{const ee=await x.get(`/api/detalleTarea/${n}`);o(ee==null?void 0:ee.data)},z=async()=>{const ee=await x.get(`/api/users/${h.id}`);m(ee==null?void 0:ee.data)};V(),z()}},[e,n,i,h.id,x]);const y=V=>V?ct.format(V,"d MMM yyyy, h:mmaaa",{locale:At.es}):"Fecha no disponible",w=[{id:1,label:"Todo",component:a.jsx(_o,{taskId:n,currentUser:c,data:s,onNewComment:r})},{id:2,label:"Dependencias",component:a.jsx(To,{data:s==null?void 0:s.ids_t_dependientes})}];return e&&Sa.createPortal(a.jsxs(a.Fragment,{children:[a.jsx("div",{className:`tm-fixed tm-inset-0 tm-z-20 tm-flex tm-items-center tm-justify-center tm-bg-transparent tm-bg-opacity-50 ${e?"tm-pointer-events-auto tm-block":"tm-pointer-events-none tm-hidden"}`,onClick:()=>t(!1)}),a.jsx("section",{className:`tm-fixed tm-bottom-0 tm-top-0 tm-z-50 tm-flex tm-h-screen tm-w-[550px] tm-items-center tm-justify-center tm-overflow-hidden tm-bg-surface-default tm-bg-opacity-50 tm-shadow-2xl tm-transition-all tm-duration-500 tm-ease-in-out ${e?"tm-pointer-events-auto tm-right-0 tm-block":"tm-pointer-events-none tm-right-[-100%] tm-hidden"}`,children:a.jsxs("div",{className:"tm-flex tm-h-full tm-w-full tm-flex-col tm-overflow-y-scroll tm-border-none tm-bg-surface-default tm-p-16 tm-shadow-04",children:[a.jsxs("div",{className:"tm-flex tm-w-full tm-flex-row tm-items-center tm-justify-between tm-gap-10 tm-border-none tm-pb-4",children:[a.jsxs("div",{className:"tm-relative tm-flex tm-flex-row tm-items-start tm-gap-8",children:[((F=s==null?void 0:s.id_t_requerida)==null?void 0:F.id)&&a.jsxs(a.Fragment,{children:[a.jsx("div",{className:"tm-cursor-help",onMouseOver:()=>d(!0),onMouseLeave:()=>d(!1),children:a.jsx(g.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:Te.warning.regular},color:"current"})}),l&&(()=>{var z;const V=at(s==null?void 0:s.id_t_requerida);return a.jsxs("div",{style:{top:"25px"},className:"tm-absolute tm-flex tm-w-fit tm-max-w-[400px] tm-flex-col tm-gap-m tm-rounded-lg tm-border-l-[5px] tm-border-warning-regular tm-bg-warning-light tm-p-l tm-text-xs tm-text-warning-dark",children:[a.jsx("p",{className:"tm-font-bold",children:"Requiere completar su tarea:"}),a.jsx("p",{className:"tm-text-2xl tm-font-normal tm-text-neutral-600",children:(z=s==null?void 0:s.id_t_requerida)==null?void 0:z.texto_corto}),V&&a.jsxs("p",{className:"tm-font-bold",children:["Responsable: ",a.jsx("span",{className:"tm-font-normal",children:V})]})]})})()]}),a.jsx("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-8",children:a.jsxs("h3",{className:"tm-text-base tm-font-semibold tm-text-neutral-900",children:[s==null?void 0:s.texto_corto,(s==null?void 0:s.atraso)&&a.jsx(g.Tooltip,{label:(R=s==null?void 0:s.atraso)==null?void 0:R.motivo,position:"bottom",children:a.jsx("button",{className:"tm-ml-2 tm-inline-block tm-h-fit tm-align-middle",children:a.jsx(g.Icon,{name:ne.faTriangleExclamation,size:"md",style:{color:Te.warning.dark},color:"current"})})})]})})]}),a.jsx(g.Button,{color:"secondary",pill:"pill",size:"xs",onClick:()=>t(!1),icon:ne.faXmark})]}),a.jsx("div",{className:"tm-mt-6 tm-flex tm-w-full tm-flex-row tm-justify-between",children:a.jsxs("span",{className:"tm-text-xs tm-text-light-gray-700",children:[s==null?void 0:s.campania," / ",s==null?void 0:s.nombre_medio]})}),a.jsx(No,{id:n,texto_largo:s==null?void 0:s.texto_largo,user_id:h.id}),a.jsx(g.Accordion,{id:`details-task-detalles-${n}`,title:"Detalles",defaultOpen:!0,className:"tm-mt-6 tm-w-full",headerClassName:"tm-border-b tm-border-black-light tm-pb-4",children:a.jsxs("div",{className:"tm-gap-xy-details tm-grid tm-w-full tm-grid-cols-3 tm-p-4",children:[a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Responsable"}),(C=s==null?void 0:s.responsable)!=null&&C.nombre?a.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-8",children:[a.jsx(Ae,{size:"xxl",imageUrl:f?p(f):"",alt:"@shadcn"}),a.jsx(g.Text,{children:(I=s==null?void 0:s.responsable)==null?void 0:I.nombre})]}):a.jsx(g.Text,{children:"Sin responsable"})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Equipo asignado"}),a.jsx("div",{className:"tm-flex tm-flex-row tm-gap-8",children:a.jsx(g.Text,{children:((T=s==null?void 0:s.equipo)==null?void 0:T.nombre)??"Sin equipo"})})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Prioridad"}),a.jsx(Ga,{priority:parseInt(s==null?void 0:s.prioridad)||0,id:n,withLabel:!0})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Lista"}),a.jsx("div",{className:"tm-flex tm-flex-row tm-gap-8",children:a.jsx(g.Text,{children:(s==null?void 0:s.lista)??"Sin lista"})})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Fecha estimada de inicio"}),a.jsx(g.Text,{children:y(s==null?void 0:s.f_inicio_estimada)})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Fecha estimada de fin"}),a.jsx(g.Text,{children:y(s==null?void 0:s.f_fin_estimada)})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Fecha de fin"}),a.jsx(g.Text,{children:y(s==null?void 0:s.ffin)})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Creado"}),a.jsx(g.Text,{children:y(s==null?void 0:s.createdAt)})]}),a.jsxs("div",{className:"tm-flex tm-w-auto tm-flex-col tm-gap-8",children:[a.jsx("span",{className:" tm-text-sm tm-font-semibold tm-leading-[100%] tm-tracking-normal",children:"Última modificación"}),a.jsx(g.Text,{children:y(s==null?void 0:s.updatedAt)})]})]})}),a.jsx(wo,{items:w})]})})]}),document.body)}class Co{static toPauseReasons(t){return{id:t.id,motivo_imj:t.motivo_imj}}}const So=async({tasks_api:e})=>{try{const t=await e.get("/api/motivos");return xe(t.data).map(Co.toPauseReasons)}catch(t){throw console.log("Error al obtener los usuarios comerciales",t),`Error al obtener los usuarios comerciales: ${t}`}},Eo=()=>{const{tasks_api:e}=ge();return{pauseReasons:de.useQuery({queryKey:["pause_task_reasons"],queryFn:()=>So({tasks_api:e}),staleTime:1e3*60*60*24})}};class Po{static toKanbanTasks(t){var i,r,l,d,c,m,f,x,p,h,y,w,j;const n=at(t==null?void 0:t.id_t_requerida),s=at(t==null?void 0:t.tarea_padre);let o=[];return t!=null&&t.responsable&&o.push({id:t.responsable.id,name:t.responsable.nombre,image:(c=(d=(l=(r=(i=t.responsable)==null?void 0:i.userOBP)==null?void 0:r.imagen)==null?void 0:l.formats)==null?void 0:d.thumbnail)==null?void 0:c.url,role:((m=t.responsable.userOBP)==null?void 0:m.role)||{id:0,name:""}}),(f=t==null?void 0:t.equipo)!=null&&f.miembros&&t.equipo.miembros.forEach(b=>{var v,M,F,R,C;o!=null&&o.find(I=>I.id===b.idUser.id)||b.idUser&&o.push({id:b.idUser.id,name:b.idUser.nombre,image:(R=(F=(M=(v=b==null?void 0:b.userOBP)==null?void 0:v.imagen)==null?void 0:M.formats)==null?void 0:F.thumbnail)==null?void 0:R.url,role:((C=b.userOBP)==null?void 0:C.role)||{id:0,name:""}})}),{paused:t==null?void 0:t.pausada,repeats:t==null?void 0:t.repeticiones_realizadas,repeatsToDo:t==null?void 0:t.repeticiones,comments:0,nameProject:(x=t==null?void 0:t.proyecto)==null?void 0:x.nombre,idProject:(p=t==null?void 0:t.proyecto)==null?void 0:p.id,willBePaused:t.es_pausable,difficulty:t.nivel_dificultad,endDate:new Date(t.ffin),id:t.id,priority:t.prioridad??0,status:t.estatus,task:t.texto_corto,users:o,responsible:((h=t==null?void 0:t.responsable)==null?void 0:h.id)??null,name_father_required_task:((y=t==null?void 0:t.tarea_padre)==null?void 0:y.texto_corto)??null,name_father_required_task_responsible:s,statusRequiredTask:((w=t.id_t_requerida)==null?void 0:w.estatus)??null,nameRequiredTask:((j=t.id_t_requerida)==null?void 0:j.texto_corto)??null,nameRequiredTaskResponsible:n,medioName:(t==null?void 0:t.nombre_medio)??null,atraso:(t==null?void 0:t.atraso)??null,categoria:(t==null?void 0:t.categoria)??null,...(t==null?void 0:t.cambio_arte)&&{cambio_arte:t==null?void 0:t.cambio_arte}}}}const dt=async({filters:e,tasks_api:t})=>{try{const s=(await t.get("/api/listado_tareas?populate=*",{params:{...e,cancelada:!1}})).data.tareas.map(xe),o=new Set;if(s.forEach(i=>{var r;(r=i==null?void 0:i.id_t_requerida)!=null&&r.id&&o.add(i.id_t_requerida.id)}),o.size>0){const i=Array.from(o),r=Ce.stringify({filters:{id:{$in:i}},populate:{responsable:{fields:["id","nombre"]},equipo:{fields:["id","nombre"]}}},{encodeValuesOnly:!0});try{const l=await t.get(`/api/tareas?${r}`),d=xe(l.data.data||l.data),c=Array.isArray(d)?d:[d],m=new Map(c.map(f=>[f.id,f]));s.forEach(f=>{var x;if((x=f==null?void 0:f.id_t_requerida)!=null&&x.id){const p=m.get(f.id_t_requerida.id);p&&(f.id_t_requerida={...f.id_t_requerida,responsable:p.responsable||null,equipo:p.equipo||null})}})}catch{}}return s.map(Po.toKanbanTasks)}catch(n){throw console.log({error:n}),`Error al obtener las tareas: ${n}`}},zt=30,$t=e=>{var t;if(e!=null&&e.hasNextPage){const n=(t=e==null?void 0:e.data)==null?void 0:t.pages[e.data.pages.length-1];(n==null?void 0:n.length)===zt&&(e==null||e.fetchNextPage())}},$e=e=>({pagination:{page:e,pageSize:zt,withCount:!0}}),Qa=()=>{var c;const e=de.useQueryClient(),{tasks_api:t}=ge(),{user:n}=je(),{filters:s}=De(),[o,i]=u.useState(0),[r,l]=u.useState({owner:{user:n.id,config:((c=s==null?void 0:s.owner)==null?void 0:c.config)??"yo_y_mis_equipos",role:n.role},status:"por_hacer"}),d=de.useInfiniteQuery({initialPageParam:1,queryKey:["to_do_tasks",r],queryFn:({pageParam:m})=>dt({filters:{...r,status:"por_hacer",...$e(m)},tasks_api:t}),staleTime:1e3*60*60*24,getNextPageParam:(m,f)=>f.length+1});return u.useEffect(()=>{var m;Object.keys(s).length>0&&l({...s,owner:{user:n.id,config:((m=s==null?void 0:s.owner)==null?void 0:m.config)??"yo_y_mis_equipos",role:n.role},status:"por_hacer"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["to_do_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const f=await t.get("/api/listado_tareas",{params:{...r,status:"por_hacer",cancelada:!1,...$e(1),tasks_api:t,justCount:!0}});i(f.data.total)})()},[r,d==null?void 0:d.data]),{toDoTasks:d,total:o,filtersToSend:r}};function Ao(e){return(e??[]).map(t=>({id:t.id,label:t.motivo_imj}))}const Io=({idTask:e,setOpen:t,paused:n})=>{const s=de.useQueryClient(),{toDoTasks:o,filtersToSend:i}=Qa(),[r,l]=u.useState(!1),[d,c]=u.useState(null),{tasksProject:m}=Je(),{postPauseTask:f,postReanudeTask:x}=He(),{pauseReasons:p}=Eo(),h=Ao(p==null?void 0:p.data),y=async()=>{try{if(d==null)return;if(t(!1),await f({id:e,motiveId:d}),await s.invalidateQueries({queryKey:["to_do_tasks",i]}),await s.invalidateQueries({queryKey:["tasksProject"]}),o&&typeof o.refetch=="function"||m&&typeof m.refetch=="function"){const j=await o.refetch(),b=await m.refetch();return[j,b]}}catch(j){console.error("Error al pausar la tarea:",j)}},w=async()=>{try{if(t(!1),await x({id:e}),await s.invalidateQueries({queryKey:["to_do_tasks",i]}),await s.invalidateQueries({queryKey:["tasksProject"]}),o&&typeof o.refetch=="function"||m&&typeof m.refetch=="function"){const j=await o.refetch(),b=await m.refetch();return[j,b]}}catch(j){console.error("Error al reanudar la tarea:",j)}};return a.jsx("div",{className:"tm-flex tm-w-[300px] tm-max-w-[300px] tm-items-center !tm-p-4",children:a.jsxs("div",{className:"tm-flex tm-w-full tm-flex-col tm-gap-s ",children:[a.jsx("h6",{className:"tm-font-regular tm-text-texts-subtext tm-truncate tm-text-xl",children:"Pausar tarea:"}),r?a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-s",children:[a.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"Esta acción detendrá la campaña en curso."}),a.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"¿Estás seguro de continuar?"})]}):n?a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-s",children:[a.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"Esta acción reanudará la campaña en curso."}),a.jsx("p",{className:"tm-text-xl tm-font-medium tm-text-neutral-600",children:"¿Estás seguro de continuar?"})]}):a.jsx(g.Dropdown,{field:{placeholder:"Selecciona una razón"},items:{options:h,idName:"id"},values:{value:d??""},menuSearch:{searchable:!0,searchPlaceholder:"Buscar"},popover:{absolute:!1,closeOnClickOutside:!0,dropdownId:`task-pause-motivo-${e}`,popoverZIndex:1200},events:{onValueChange:j=>{const b=Number(j);Number.isNaN(b)||c(b)},onOptionSelect:j=>{const b=Number(j.id);Number.isNaN(b)||c(b)}}}),a.jsxs("div",{className:"tm-mt-5 tm-flex tm-w-full tm-justify-end tm-gap-m",children:[a.jsx(g.Button,{type:"button",onClick:()=>t(!1),size:"xs",color:"secondary",children:"Cancelar"}),n?a.jsx(g.Button,{type:"button",onClick:()=>w(),size:"xs",color:"primary",children:"Si, reanudar"}):a.jsx(g.Button,{type:"button",disabled:!d,onClick:()=>r?y():l(!0),size:"xs",color:"primary",children:"Aceptar"})]})]})})},Xa=({idTask:e,paused:t,popupId:n,children:s})=>{const o=u.useRef(null),i=u.useRef(null),[r,l]=u.useState(!1),[d,c]=u.useState(0),m=`task-pause-motivo-${e}`,f=u.useCallback(()=>{var x;(x=o.current)==null||x.close()},[]);return u.useEffect(()=>{if(!r)return;const x=p=>{const h=p.target;h instanceof Element&&(h.closest(`[data-popup-id="${n}"]`)||h.closest(`[data-dropdown-id="${m}"]`))||f()};return window.addEventListener("scroll",x,!0),document.addEventListener("scroll",x,!0),()=>{window.removeEventListener("scroll",x,!0),document.removeEventListener("scroll",x,!0)}},[r,f,n,m]),a.jsxs(a.Fragment,{children:[s(i),a.jsx(g.Popup,{ref:o,triggerRef:i,popupId:n,position:"bottom-left",offset:5,closeOnClick:!1,closeOnClickOutside:!1,popoverArrow:!1,onOpen:()=>{l(!0),c(x=>x+1)},onClose:()=>l(!1),children:a.jsx(Io,{idTask:e,paused:t,setOpen:x=>{x||f()}},d)})]})},Do=({id:e,task:t,endDate:n,users:s,willBePaused:o,nameProject:i,comments:r,priority:l,difficulty:d,responsible:c,nameRequiredTask:m,nameRequiredTaskResponsible:f,statusRequiredTask:x,status:p,repeatsToDo:h,repeats:y,medioName:w,paused:j,idProject:b,atraso:v,categoria:M,cambio_arte:F,name_father_required_task:R,name_father_required_task_responsible:C,boardColumnTitle:I,isBulkColumnLocked:T=!1})=>{const[V,z]=u.useState(!1),ee=u.useId(),{reasignResponsible:G,updateUnitys:k}=He(),{getOBPUrlApi:E}=ge(),[L,B]=u.useState(y??0),q=!!(h&&y===h),X=!h||h===1,H=p===0,{user:re}=je(),Y=Ot(),P=!!(Y!=null&&Y.selectedTaskIds.includes(e)),$=Rt({status:p,nameRequiredTask:m,statusRequiredTask:x,repeatsToDo:h,repeats:y}),Q=!!Y&&!!I&&I!=="Completadas"&&!T,D=Q&&$,A=Q&&!$&&!!(Y!=null&&Y.isBulkSessionActive),K=!!(Y!=null&&Y.isMultiSelectActive&&D),S=!D||!!(Y!=null&&Y.isBulkLoading),N=le=>{!Y||!I||S||Y.toggleTaskSelection(e,I)},U=()=>a.jsxs("div",{className:"tm-relative tm-flex tm-h-fit tm-w-full tm-items-center tm-justify-between",children:[a.jsxs("div",{className:"tm-flex tm-min-w-0 tm-flex-1 tm-flex-row tm-items-start tm-gap-[8px]",children:[p<2&&(R||q||X||H)&&a.jsx("span",{"data-prevent-bulk-select":!0,children:a.jsx(Va,{id:e,nameRequiredTask:m??"",statusRequiredTask:x??0,status:p,idAtraso:v==null?void 0:v.atrasoId,nameRequiredTaskResponsible:f,name_father_required_task:R,name_father_required_task_responsible:C,repeatsAreCompleted:q})}),a.jsx("p",{className:"tm-w-full tm-overflow-hidden tm-text-ellipsis tm-text-nowrap tm-text-base tm-text-neutral-900","data-prevent-bulk-select":!0,onClick:le=>{le.stopPropagation(),z(!0)},children:t})]}),$&&a.jsxs("div",{className:"tm-flex tm-shrink-0 tm-items-center tm-gap-2","data-prevent-bulk-select":!0,children:[Y?a.jsx("div",{className:"tm-flex tm-items-center tm-pt-0.5 tm-pr-2",children:a.jsx(g.Checkbox,{id:`kanban-bulk-select-${e}-${ee}`,size:"sm",checked:P,disabled:S,onChange:N})}):null,a.jsx(bo,{id:e,nameRequiredTask:m,status:p,statusRequiredTask:x,projectID:b,atrasoId:v==null?void 0:v.atrasoId,categoria:M,disabled:K})]})]}),O={0:{title:"Muy fácil",color:"brand"},1:{title:"Fácil",color:"success"},2:{title:"Media",color:"warning"},3:{title:"Difícil",color:"danger"},4:{title:"Muy difícil",color:"danger"}},_={title:"Sin dato",color:"primary"},Z=(()=>{const le=d;if(typeof le!="number"||!Number.isFinite(le))return _;const te=Math.trunc(le);return te<0||te>4?_:O[te]??_})(),ae=le=>{B(te=>le==="minus"?Math.max(0,te-1):Math.min(h,te+1))},ie=le=>{var te;return((te=le==null?void 0:le.charAt(0))==null?void 0:te.toUpperCase())??""},J=le=>le==="Venta"?"brand":"danger",se=T||!!(Y!=null&&Y.isBulkLoading),ce=A?"tm-cursor-not-allowed tm-opacity-60 hover:tm-border-cards hover:tm-bg-surface-default":"tm-cursor-pointer hover:tm-border-default hover:tm-border-primary-regular hover:tm-bg-primary-light";return a.jsxs(a.Fragment,{children:[a.jsxs("div",{className:`tm-relative tm-h-fit tm-max-w-[350px] tm-rounded-lg tm-border tm-p-[12px_12px] tm-transition-all tm-duration-300 ${ce} ${P?"tm-border-blue-500 tm-bg-primary-light":"tm-border-transparent tm-bg-surface-default"} ${se?"tm-pointer-events-none":""}`,children:[a.jsx(U,{}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-[4px] tm-py-2",children:[a.jsx("p",{className:"tm-font-regular tm-max-w-[250px] tm-truncate tm-text-xs tm-text-texts-subtext",children:i}),w&&a.jsx("p",{className:"tm-text-xl",children:w})]}),F&&a.jsx(g.Badge,{label:F.nombre,color:"gray",icon:ne.faImage,size:"md",theme:"solid"}),a.jsxs("div",{"data-prevent-bulk-select":!0,className:"tm-relative tm-flex tm-h-fit tm-w-full tm-items-center tm-justify-between tm-pb-1 tm-pt-5",children:[a.jsxs("div",{className:"tm-relative tm-flex tm-items-center",children:[a.jsx(Ka,{responsible:c,role:re==null?void 0:re.role,status:p,users:s.filter(le=>c?le.id===c:!0).map(le=>Lt(le,E())),onClick:async(le,te)=>{await G({idNewResponsible:le,id:e,typeOfSelect:te})}}),o&&a.jsx(Xa,{idTask:e,paused:j,popupId:`task-pause-menu-${e}`,children:le=>a.jsx("button",{ref:le,type:"button",className:"tm-font-regular tm-flex !tm-h-[32px] !tm-w-[32px] tm-items-center tm-justify-center tm-gap-2 tm-text-sm tm-text-gray-400",children:a.jsx(g.Icon,{name:j?ne.faPlay:ne.faPause,size:"xs",color:"current"})})})]}),a.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-8",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx(g.Badge,{label:ie((M==null?void 0:M.tipo)??"P"),color:J((M==null?void 0:M.tipo)??"Preventa"),size:"sm",theme:"solid"}),v&&a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faTriangleExclamation,size:"sm",color:"warning"}),children:a.jsx(g.Text,{color:"warning",children:`Tarea atrasada debido a: ${v==null?void 0:v.motivo}`})}),a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faRhombus,size:"sm",color:Z.color}),children:a.jsx("div",{className:"tm-px-8 tm-py-4",children:a.jsx(g.Text,{color:Z.color,children:`Dificultad ${Z.title}`})})}),a.jsx(Ga,{priority:l,id:e}),!h||h&&p===0&&a.jsxs(a.Fragment,{children:[a.jsx(g.Icon,{name:ne.faCalendar,size:"xs",color:"primary"}),a.jsx(g.Text,{color:"primary",children:`${n.getDate()} ${kt(n.getMonth()).slice(0,3)}`})]})]}),p===1&&h&&h>0&&a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-m",children:[a.jsx(g.Text,{color:"primary",children:"unidades"}),a.jsx("button",{onClick:()=>ae("minus"),className:"tm-mr-[4px] tm-flex tm-w-[0] tm-items-center tm-justify-center tm-rounded-full tm-bg-surface-default hover:tm-bg-surface-hover",children:a.jsx(g.Icon,{name:ne.faCircleMinus,size:"xs",color:"primary"})}),a.jsx(g.Text,{color:"primary",children:`${L??0} / ${h??0}`}),a.jsx("button",{onClick:()=>ae("plus"),className:"tm-ml-[4px] tm-flex tm-w-[0] tm-items-center tm-justify-center tm-rounded-full tm-bg-surface-default hover:tm-bg-surface-hover",children:a.jsx(g.Icon,{name:ne.faCirclePlus,size:"xs",color:"primary"})}),a.jsx("button",{className:"tm-ml-[4px] tm-rounded-md tm-bg-surface-brand-default tm-px-m tm-py-s tm-text-xs tm-text-on-color",onClick:()=>{k({repeats:L,id:e})},children:"Agregar Unidad"})]})]})]}),r>0&&a.jsx("div",{className:"tm-mt-4 tm-border-t tm-border-default tm-pt-2",children:a.jsxs("button",{type:"button","data-prevent-bulk-select":!0,onClick:le=>{le.stopPropagation(),z(!0)},className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx(g.Icon,{name:ne.faComment,size:"xs",color:"current"}),a.jsx("span",{className:"tm-font-regular tm-text-xl tm-text-gray-400",children:r})]})})]}),a.jsx(Wa,{taskId:e,isOpen:V,setIsOpen:z})]})},mt=({title:e,tasks:t,loadNextPage:n,isFetching:s,total:o,bulkSelectAllIds:i})=>{const r=u.useRef(null),l=u.useRef(null),d=u.useRef(!1);u.useEffect(()=>{var w;r!=null&&r.current&&(l!=null&&l.current)&&(l.current.style.minHeight=`${((w=r==null?void 0:r.current)==null?void 0:w.clientHeight)-300}px`)},[r==null?void 0:r.current]);const c=w=>{if(d.current)return;const{scrollTop:j,clientHeight:b,scrollHeight:v}=w==null?void 0:w.target,M=j/(v-b)*100;M<=95||M>=95&&(d.current=!0,n&&n(),setTimeout(()=>{d.current=!1},200))},m={"Por hacer":"tm-border-texts-placeholder",Trabajando:"tm-border-primary-regular",Completadas:"tm-border-success-regular"},f=Ot(),x=e,p=!!(f!=null&&f.baseColumn&&f.baseColumn!==e),h=!!f&&e!=="Completadas"&&(f==null?void 0:f.isBulkSessionActive)&&f.baseColumn===e&&typeof i=="function",y=()=>{if(!(!f||!i)){if(f.isFullColumnSelected){f.deselectAllSelectedTasks();return}f.selectEntireColumn(x,i)}};return a.jsxs("div",{ref:r,className:`tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-fit tm-min-w-[400px] tm-max-w-[400px] tm-flex-col tm-overflow-hidden tm-rounded-lg tm-border-t-4 tm-bg-canvas tm-p-[16px] ${m[e]} ${p?"tm-opacity-40":""}`,children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-w-full",children:[a.jsx("p",{className:"tm-text-sm",children:e}),h&&a.jsx("button",{type:"button",className:"tm-text-base tm-text-brand disabled:tm-cursor-not-allowed disabled:tm-opacity-50 tm-mx-3",disabled:f==null?void 0:f.isBulkLoading,onClick:y,children:f!=null&&f.isBulkLoading?"Cargando…":f!=null&&f.isFullColumnSelected?"Quitar Selección":"Seleccionar todas"})]}),a.jsx("div",{className:"tm-flex tm-items-center tm-gap-[8px]",children:a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-[4px]",children:[a.jsx(g.Icon,{name:ne.faFiles,size:"sm",color:"secondary"}),a.jsx("p",{className:"tm-text-base tm-text-texts-placeholder",children:o??0})]})})]}),a.jsxs("div",{ref:l,className:"tm-flex tm-h-full tm-max-w-[350px] tm-flex-col tm-gap-[12px] tm-overflow-y-auto tm-pb-[200px] tm-pt-4 tm-scrollbar-none hover:tm-border-default hover:tm-bg-surface-hover focus:tm-border-default focus:tm-bg-light-gray-50 focus:tm-outline-none",onScroll:c,children:[t==null?void 0:t.map(w=>a.jsx(Do,{...w,boardColumnTitle:f?x:void 0,isBulkColumnLocked:!!(f&&p)},w.id)),s?a.jsx(Zn,{}):a.jsx("p",{className:"tm-text-center tm-text-sm tm-text-light-gray-900",children:"No hay más tareas por mostrar..."})]})]})},fa=[{label:"Tipo de dependencia 2",type:"select",id:"dependency",options:[{id:"con",name:"Con dependencia"},{id:"sin",name:"Sin dependencia"},{id:"ambas",name:"Ambas"}]},{label:"Por responsable",type:"select",id:"owner.config",options:[{id:"yo",name:"Mis tareas"},{id:"yo_y_mis_equipos",name:"Tareas mías y de mis equipos"},{id:"mis_equipos",name:"Tareas de mis equipos"}]},{label:"Por dificultad",type:"select",id:"difficulty",options:[{id:1,name:"Muy facil"},{id:2,name:"Facil"},{id:3,name:"Media"},{id:4,name:"Dificil"},{id:5,name:"Muy dificil"}]}],Fo=()=>{const{user:e}=je(),[t,n]=u.useState([...fa]),s=[{roles:["Project Manager","Manager","Operation Manager"],id:"owner.config",filters:[{id:"todas",name:"Todas las tareas"}]}];return u.useEffect(()=>{const o=[...fa];s.forEach(l=>{if(l.roles.includes(e.role)){const d=o.find(c=>c.id===l.id);d&&(d.options.some(m=>m.id==="todas")||(d.options=[{id:"todas",name:"Todas las tareas"},...d.options]))}});const i=JSON.stringify(t),r=JSON.stringify(o);i!==r&&n(o)},[e.role]),{filters:t}},Mo="/api/tareas/bulk-update-status";async function ko(e,t){const{data:n}=await e.post(Mo,t);return n}function Lo(e){var t,n,s,o;if(Ye.isAxiosError(e)){const i=(t=e.response)==null?void 0:t.status,r=(n=e.response)==null?void 0:n.data;if(i===400){if(typeof r=="string"&&r.trim().length>0)return r.trim();if(r&&typeof r=="object"){const l=r.message;if(typeof l=="string"&&l.trim())return l.trim();const d=(s=r.details)==null?void 0:s.errors,c=(o=d==null?void 0:d[0])==null?void 0:o.message;if(typeof c=="string"&&c.trim())return c.trim()}return"Los datos enviados no son válidos. Revisa la selección e inténtalo de nuevo."}return typeof r=="string"&&r.trim().length>0?r.trim():e.message||"No se pudo actualizar las tareas."}return e instanceof Error?e.message:"No se pudo actualizar las tareas."}function Oo(){const{tasks_api:e}=ge(),{user:t}=je();return de.useMutation({mutationKey:["tareas","bulk-update-status"],mutationFn:async n=>{const s=n.user_id??(t==null?void 0:t.id);if(s==null||s<1)throw new Error("No hay usuario válido para la actualización masiva.");try{return await ko(e,{...n,user_id:s})}catch(o){throw new Error(Lo(o))}}})}const bt={MOVE_TO_TRABAJANDO:"kanban-bulk-move-trabajando",MOVE_TO_POR_HACER:"kanban-bulk-move-por-hacer",MOVE_TO_COMPLETADAS:"kanban-bulk-move-completadas"};function Bo(e){const{isBulkLoading:t}=e;return[{type:"button",label:"Cancelar",icon:ne.faXmark,color:"secondary",pill:"pill",disabled:t,onClick:()=>{t||(e.setPendingTargetStatus(null),e.setActiveButtonId(null))}},{type:"button",label:"Confirmar",icon:ne.faCheck,color:"secondary",pill:"pill",disabled:t,onClick:()=>{t||e.onConfirmBulkMove()}}]}const yt="secondary";function Ro(e){const t=Bo({setActiveButtonId:e.setActiveButtonId,setPendingTargetStatus:e.setPendingTargetStatus,onConfirmBulkMove:e.onConfirmBulkMove,isBulkLoading:e.isBulkLoading});return e.baseColumn==="Por hacer"?[{id:bt.MOVE_TO_TRABAJANDO,label:"Mover a trabajando",icon:ne.faArrowRight,color:yt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(1)},addons:t}]:e.baseColumn==="Trabajando"?[{id:bt.MOVE_TO_POR_HACER,label:"Mover a por hacer",icon:ne.faArrowLeft,color:yt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(0)},addons:t},{id:bt.MOVE_TO_COMPLETADAS,label:"Mover a completadas",icon:ne.faArrowRight,color:yt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(2)},addons:t}]:[]}const qo="Seleccionados";function Ya(){const e=Ot(),[t,n]=u.useState(null),s=t!==null,o=de.useQueryClient(),{mutate:i}=Oo(),r=(e==null?void 0:e.selectedTaskIds.length)??0;u.useEffect(()=>{r===0&&n(null)},[r]);const l=u.useCallback(()=>{e!=null&&e.isBulkLoading||e==null||e.setPendingTargetStatus(null)},[e]),d=u.useCallback(()=>{n(null),e==null||e.exitBulkSelectionMode()},[e]),c=u.useCallback(()=>{if(!e)return;const f=e.pendingTargetStatus,x=e.selectedTaskIds;if(f==null||x.length===0)return;const p={tasks_ids:[...x],estatus:f,...f===2?{ended_at:new Date().toISOString()}:{}};e.setIsBulkLoading(!0),i(p,{onSettled:()=>{e.setIsBulkLoading(!1)},onSuccess:async()=>{await e.invalidateAfterBulkSuccess(o),n(null),e.exitBulkSelectionMode()},onError:()=>{n(null),e.setPendingTargetStatus(null)}})},[e,i,o]),m=u.useMemo(()=>e?Ro({baseColumn:e.baseColumn,setPendingTargetStatus:e.setPendingTargetStatus,setActiveButtonId:n,onConfirmBulkMove:c,isBulkLoading:e.isBulkLoading}):[],[e,c]);return!e||r===0||e.baseColumn!=="Por hacer"&&e.baseColumn!=="Trabajando"?null:a.jsx(g.Toolbar,{visible:!0,count:r,text:qo,activeButtonId:t,onActiveButtonIdChange:n,onBackClick:l,buttons:m,onClose:d,showCounterInButtonsView:!s,showBackButton:!s,showCloseButton:!s})}const Ja=["to_do_tasks","working_tasks","done_tasks"],zo="tasksProject";function $o(e){return Promise.all(Ja.map(t=>e.invalidateQueries({queryKey:[t]}))).then(()=>{})}function Uo(e){return Promise.all(Ja.flatMap(t=>[e.invalidateQueries({queryKey:[t]}),e.refetchQueries({queryKey:[t]})])).then(()=>{})}function Ho(e){return e.invalidateQueries({queryKey:[zo]}).then(()=>{})}const Ko=["Por hacer","Trabajando","Completadas"],Go=()=>{const{defineFields:e}=De(),{tasksProject:t}=Je(),{filters:n}=Fo();u.useEffect(()=>{(async()=>{let i=[...n];e(i)})()},[]);const s=u.useMemo(()=>{var o;return(o=t==null?void 0:t.data)==null?void 0:o.filter(i=>{var r;return((r=i==null?void 0:i.tasks)==null?void 0:r.length)===0}).reduce((i,r)=>(i[r.status]=i[r.status]||[],i[r.status].push(r),i),{})},[t==null?void 0:t.data]);return a.jsxs(za,{invalidateAfterBulkSuccess:Ho,children:[a.jsx(Ya,{}),a.jsx("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-gap-8",children:Ko.map((o,i)=>{const r=(s==null?void 0:s[i])??[];return a.jsx(mt,{total:r.length,title:o,tasks:r,isFetching:t==null?void 0:t.isFetching,isLoadingData:t==null?void 0:t.isLoading,bulkSelectAllIds:()=>Promise.resolve(r.filter(l=>Rt({status:l.status,nameRequiredTask:l.nameRequiredTask,statusRequiredTask:l.statusRequiredTask,repeatsToDo:l.repeatsToDo,repeats:l.repeats})).map(l=>l.id))},o)})})]})};async function Za(e){const t=[];let n=1;for(;;){const s=await dt({filters:{...e.filters,status:e.status,...$e(n)},tasks_api:e.tasks_api});for(const o of s)Rt({status:o.status,nameRequiredTask:o.nameRequiredTask,statusRequiredTask:o.statusRequiredTask,repeatsToDo:o.repeatsToDo,repeats:o.repeats})&&t.push(o.id);if(s.length<zt)break;n+=1}return t}const Vo=()=>{var i,r;const{tasks_api:e}=ge(),{toDoTasks:t,total:n,filtersToSend:s}=Qa(),o=[...((r=(i=t==null?void 0:t.data)==null?void 0:i.pages)==null?void 0:r.flat())??[]];return a.jsx(mt,{total:n,title:"Por hacer",tasks:o,loadNextPage:()=>$t(t),isFetching:t==null?void 0:t.isFetching,isLoadingData:t==null?void 0:t.isLoading,bulkSelectAllIds:()=>Za({tasks_api:e,filters:s,status:"por_hacer"})})},Wo=()=>{var c;const e=de.useQueryClient(),{tasks_api:t}=ge(),{user:n}=je(),{filters:s}=De(),[o,i]=u.useState(0),[r,l]=u.useState({owner:{user:n.id,config:((c=s==null?void 0:s.owner)==null?void 0:c.config)??"yo_y_mis_equipos",role:n.role},status:"trabajando"}),d=de.useInfiniteQuery({initialPageParam:1,queryKey:["working_tasks",r],queryFn:({pageParam:m})=>dt({filters:{...r,status:"trabajando",...$e(m)},tasks_api:t}),staleTime:1e3*60*60*24,getNextPageParam:(m,f)=>f.length+1});return u.useEffect(()=>{var m;Object.keys(s).length>0&&l({...s,owner:{user:n.id,config:((m=s==null?void 0:s.owner)==null?void 0:m.config)??"yo_y_mis_equipos",role:n.role},status:"trabajando"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["working_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const f=await t.get("/api/listado_tareas",{params:{...r,status:"trabajando",cancelada:!1,...$e(1),tasks_api:t,justCount:!0}});i(f.data.total)})()},[r,d==null?void 0:d.data]),{workingTasks:d,total:o,filtersToSend:r}},Qo=()=>{var i,r;const{tasks_api:e}=ge(),{workingTasks:t,total:n,filtersToSend:s}=Wo(),o=[...((r=(i=t==null?void 0:t.data)==null?void 0:i.pages)==null?void 0:r.flat())??[]];return a.jsx(mt,{total:n,title:"Trabajando",tasks:o,loadNextPage:()=>$t(t),isFetching:t==null?void 0:t.isFetching,bulkSelectAllIds:()=>Za({tasks_api:e,filters:s,status:"trabajando"})})},Xo=()=>{var c;const e=de.useQueryClient(),{user:t}=je(),{tasks_api:n}=ge(),{filters:s}=De(),[o,i]=u.useState(0),[r,l]=u.useState({owner:{user:t.id,config:((c=s==null?void 0:s.owner)==null?void 0:c.config)??"yo_y_mis_equipos",role:t.role},status:"completadas"}),d=de.useInfiniteQuery({initialPageParam:1,queryKey:["done_tasks",r],queryFn:({pageParam:m})=>dt({filters:{...r,status:"completadas",...$e(m)},tasks_api:n}),staleTime:1e3*60*60*24,getNextPageParam:(m,f)=>f.length+1});return u.useEffect(()=>{var m;Object.keys(s).length>0&&l({...s,owner:{user:t.id,config:((m=s==null?void 0:s.owner)==null?void 0:m.config)??"yo_y_mis_equipos",role:t.role},status:"completadas"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["done_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const f=await n.get("/api/listado_tareas",{params:{...r,status:"completadas",cancelada:!1,...$e(1),justCount:!0,tasks_api:n}});i(f.data.total)})()},[d==null?void 0:d.data,r]),{doneTasks:d,total:o,filtersToSend:r}},Yo=()=>{var s,o;const{doneTasks:e,total:t}=Xo(),n=[...((o=(s=e==null?void 0:e.data)==null?void 0:s.pages)==null?void 0:o.flat())??[]];return a.jsx(mt,{title:"Completadas",tasks:n,loadNextPage:()=>$t(e),isFetching:e==null?void 0:e.isFetching,total:t})};class lt{static toSalesmanUsers(t){return{id:t.id,name:t.nombre}}}const Jo=()=>{const{tasks_api:e}=ge(),{filters:t}=De(),{user:n}=je(),s=async()=>(await e.get("/api/obtener-comerciales")).data.map(lt.toSalesmanUsers),o=async()=>{var l;return(await e.get("/api/listado_tareas",{params:{...Xt(t),owner:{user:n.id,config:((l=t==null?void 0:t.owner)==null?void 0:l.config)??"yo_y_mis_equipos",role:n.role},justProjects:!0,cancelada:!1}})).data.map(lt.toSalesmanUsers)};return{getSalesmanAndProjects:u.useCallback(async(r={})=>{var p;const l={...t,...r},d=(r==null?void 0:r["owner.config"])??((p=t==null?void 0:t.owner)==null?void 0:p.config)??"yo_y_mis_equipos",c={...l};delete c["owner.config"];const m=Xt(c),[f,x]=await Promise.all([e.get("/api/obtener-comerciales"),e.get("/api/listado_tareas",{params:{...m,owner:{user:n==null?void 0:n.id,config:d,role:n.role},justProjects:!0,cancelada:!1}})]);return{salesmanUsers:f.data.map(lt.toSalesmanUsers),projects:x.data.map(lt.toSalesmanUsers)}},[e,t,n==null?void 0:n.id,n==null?void 0:n.role]),getProjects:o,getSalesmans:s}},Zo=()=>{const{user:e}=je(),[t,n]=u.useState([...Jt]),s=[{roles:["Project Manager","Manager","Operation Manager"],id:"owner.config",filters:[{id:"todas",name:"Todas las tareas"}]}];return u.useEffect(()=>{const o=[...Jt];s.forEach(l=>{if(l.roles.includes(e.role)){const d=o.find(c=>c.id===l.id);d&&(d.options.some(m=>m.id==="todas")||(d.options=[{id:"todas",name:"Todas las tareas"},...d.options]))}});const i=JSON.stringify(t),r=JSON.stringify(o);i!==r&&n(o)},[e.role]),{filters:t}},er=()=>{const{defineFields:e,initialFilters:t}=De(),{getSalesmanAndProjects:n}=Jo(),{filters:s}=Zo(),o=(t==null?void 0:t["owner.config"])??"yo_y_mis_equipos";return u.useEffect(()=>{let i=!1;return(async()=>{const{salesmanUsers:l,projects:d}=await n({"owner.config":o});i||e(s.map(c=>c.id==="project.id"?{...c,options:d}:c.id==="salesman.id"?{...c,options:l}:c))})(),()=>{i=!0}},[e,s,n,o]),a.jsxs(za,{invalidateAfterBulkSuccess:$o,children:[a.jsx(Ya,{}),a.jsxs("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-gap-8",children:[a.jsx(Vo,{}),a.jsx(Qo,{}),a.jsx(Yo,{})]})]})},es=u.createContext({}),tr=({children:e})=>{const[t,n]=u.useState([]),s=o=>{n(i=>i.includes(o)?i.filter(r=>r!==o):[...i,o])};return a.jsx(es.Provider,{value:{selectedTasks:t,selectTask:s},children:e})},ar=()=>u.useContext(es),sr=()=>{const e=()=>a.jsxs("div",{className:"tm-flex tm-w-full tm-gap-m",children:[a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-full tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-w-[30%] tm-animate-pulse tm-rounded-md tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-w-[10%] tm-animate-pulse tm-rounded-md tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-w-[10%] tm-animate-pulse tm-rounded-md tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"}),a.jsx("div",{className:"tm-h-[30px] tm-min-h-[30px] tm-w-[30px] tm-min-w-[30px] tm-animate-pulse tm-rounded-lg tm-bg-gray-200"})]});return a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-m",children:[a.jsx(e,{}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-m tm-pl-5",children:[a.jsx(e,{}),a.jsx("div",{className:"tm-pl-5",children:a.jsx(e,{})})]}),a.jsx(e,{}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-m tm-pl-5",children:[a.jsx(e,{}),a.jsx("div",{className:"tm-pl-5",children:a.jsx(e,{})})]})]})},ts=({startDate:e,endDate:t})=>a.jsxs(a.Fragment,{children:[a.jsxs("div",{className:"tm-flex tm-h-[30px] tm-w-fit tm-items-center tm-justify-center tm-gap-s tm-rounded-md tm-bg-surface-default tm-px-xl",children:[a.jsx(g.Icon,{name:ne.faCalendar,size:"xs",color:"current"}),a.jsxs(g.Text,{children:[" ",ia(e)]})]}),a.jsx(g.Icon,{name:ne.faArrowRight,size:"xs",color:"current"}),a.jsxs("div",{className:"tm-flex tm-h-[30px] tm-w-fit tm-items-center tm-justify-center tm-gap-s tm-rounded-md tm-bg-surface-default tm-px-xxxl",children:[a.jsx(g.Icon,{name:ne.faCalendar,size:"xs",color:"current"}),a.jsxs(g.Text,{children:[" ",ia(t)]})]})]}),as=({id:e,priority:t,difficulty:n,endDate:s,atraso:o})=>{const[i,r]=u.useState({priority:!1,difficulty:!1,atraso:!1}),l={0:{title:"N/A",color:Te.success.regular,bg:"tm-bg-texts-placeholder tm-border-texts-placeholder",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},1:{title:"Baja",color:Te.success.regular,bg:"tm-bg-success-medium tm-border-success-pastel",border:"tm-border-success-pastel",borderHover:"hover:tm-border-success-dark"},2:{title:"Media",color:Te.warning.regular,bg:"tm-bg-warning-light tm-border-warning-regular",border:"tm-border-warning-regular",borderHover:"hover:tm-border-warning-dark"},3:{title:"Alta",color:Te.danger.regular,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-regular",borderHover:"hover:tm-border-danger-dark"}},d={1:{title:"Muy fácil",color:Te.success.dark,bg:"tm-bg-success-medium tm-border-success-regular",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},2:{title:"Fácil",color:Te.success.regular,bg:"tm-bg-success-medium tm-border-success-pastel",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},3:{title:"Media",color:Te.warning.regular,bg:"tm-bg-warning-light tm-border-warning-regular",border:"tm-border-warning-medium",borderHover:"hover:tm-border-warning-dark"},4:{title:"Difícil",color:Te.danger.regular,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-medium",borderHover:"hover:tm-border-danger-dark"},5:{title:"Muy difícil",color:Te.danger.dark,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-medium",borderHover:"hover:tm-border-danger-dark"}},c=()=>{if(n==null||Number.isNaN(Number(n)))return 1;const h=Math.trunc(Number(n));return h===0?1:h>=1&&h<=5?h:1},m=()=>{if(t==null||Number.isNaN(Number(t)))return 0;const h=Math.trunc(Number(t));return h>=0&&h<=3?h:0},f=d[c()]??d[1],x=l[m()]??l[0],p=s instanceof Date&&!Number.isNaN(s.getTime())?`${s.getDate()} ${kt(s.getMonth()).slice(0,3)}`:"—";return a.jsxs(a.Fragment,{children:[a.jsx("button",{type:"button",className:"tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center tm-gap-8 tm-rounded-[8px] tm-bg-surface-default hover:tm-bg-surface-hover",children:a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faAlignCenter,size:"xs",color:"current"}),children:a.jsx("div",{className:"tm-px-8 tm-py-4",children:a.jsx(g.Text,{children:"Espéralo muy pronto..."})})})}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx("div",{onMouseEnter:()=>r({...i,difficulty:!0}),onMouseLeave:()=>r({...i,difficulty:!1}),className:`tm-gap-s ${f.border} ${f.borderHover} transition-all duration-300 tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center
|
|
6
|
+
tm-rounded-[8px] tm-border tm-shadow-[0px_0px_2px_0px_rgba(37,37,37,0.10)]`,children:a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faRhombus,size:"sm",color:i.difficulty?"danger":"primary"}),children:a.jsx("div",{className:"tm-px-8 tm-py-4",children:a.jsx(g.Text,{children:f.title})})})}),a.jsx("div",{onMouseEnter:()=>r({...i,priority:!0}),onMouseLeave:()=>r({...i,priority:!1}),className:`tm-gap-s ${x.bg.replace(/\bbg-|border-/g,"tm-$&")??"tm-bg-light-gray-50"} transition-all duration-300 tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center tm-rounded-[8px]
|
|
7
|
+
tm-border tm-border-success-medium tm-shadow-[0px_0px_2px_0px_rgba(37,37,37,0.10)] hover:tm-border-success-dark`,children:a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faFlag,size:"sm",color:i.priority?"success":"primary"}),children:a.jsx("div",{className:"tm-px-8 tm-py-4",children:a.jsx(g.Text,{children:x.title})})})}),(o==null?void 0:o.activa)&&a.jsx("div",{onMouseEnter:()=>r({...i,atraso:!0}),onMouseLeave:()=>r({...i,atraso:!1}),className:`transition-all duration-300 tm-flex tm-h-[30px] tm-w-[30px] tm-items-center tm-justify-center tm-gap-s tm-rounded-[8px]
|
|
8
|
+
tm-border tm-border-danger-medium tm-shadow-[0px_0px_2px_0px_rgba(37,37,37,0.10)] hover:tm-border-danger-dark`,children:a.jsx(Ie,{trigger:a.jsx(g.Icon,{name:ne.faTriangleExclamation,size:"xs",color:i.atraso?"warning":"primary"}),children:a.jsx("div",{className:"tm-px-8 tm-py-4",children:a.jsx(g.Text,{children:o==null?void 0:o.motivo})})})}),a.jsx(g.Icon,{name:ne.faCalendar,size:"xs",color:"current"}),a.jsx(g.Text,{children:p})]})]})},nr=({id:e})=>{const{selectedTasks:t,selectTask:n}=ar();return a.jsxs(a.Fragment,{children:[a.jsx("label",{className:"tm-flex tm-h-[20px] tm-w-[20px] tm-cursor-pointer tm-items-center tm-justify-center tm-rounded-md tm-border-2 tm-border-default",htmlFor:e.toString(),children:a.jsx("span",{className:`${t.includes(e)?"tm-opacity-100":"tm-opacity-0"} tm-transition-opacity tm-duration-500`,children:a.jsx(g.Icon,{name:ne.faCheck,size:"xs",style:{color:Te.primary.regular},color:"current"})})}),a.jsx("input",{className:"tm-hidden",id:e.toString(),type:"checkbox",onChange:()=>n(e)})]})},ss=({task:e})=>a.jsx(Ie,{trigger:a.jsx(g.Text,{children:e}),children:a.jsx("div",{className:"tm-py-2 tm-px-4",children:a.jsx(g.Text,{children:e})})}),or=({id:e})=>{var m,f,x;const[t,n]=u.useState(!1),{tasksProject:s}=Je(),{reasignResponsible:o}=He(),{getOBPUrlApi:i}=ge(),r=(m=s==null?void 0:s.data)==null?void 0:m.find(p=>p.id===e),[l,d]=u.useState(null),{user:c}=je();return a.jsxs(a.Fragment,{children:[a.jsx("div",{className:"tm-border-b tm-border-default tm-pb-3",children:a.jsxs("div",{className:"tm-mb-3 tm-ml-[30px] tm-mt-1 tm-flex tm-flex-wrap tm-items-center tm-gap-xl tm-rounded-md tm-p-2 hover:tm-bg-surface-hover",onMouseEnter:()=>{d(e)},onMouseLeave:()=>d(null),onClick:()=>n(!0),children:[!(r!=null&&r.nameRequiredTask)||(r==null?void 0:r.nameRequiredTask)!==""&&(r==null?void 0:r.statusRequiredTask)===2&&a.jsx(nr,{id:e}),a.jsx(Va,{id:e,idAtraso:(f=r==null?void 0:r.atraso)==null?void 0:f.atrasoId,nameRequiredTask:(r==null?void 0:r.nameRequiredTask)??"",status:r==null?void 0:r.status,statusRequiredTask:(r==null?void 0:r.statusRequiredTask)??0,nameRequiredTaskResponsible:r==null?void 0:r.nameRequiredTaskResponsible},e),(r==null?void 0:r.willBePaused)&&a.jsx(Xa,{idTask:r.id,paused:r.paused,popupId:`child-task-pause-menu-${r.id}`,children:p=>a.jsx(g.Button,{ref:p,color:"tertiary",icon:r!=null&&r.paused?ne.faPause:ne.faPlay,className:"tm-font-regular tm-flex tm-items-center tm-gap-8 tm-text-sm tm-text-gray-400",size:"xs"})}),a.jsx(Ka,{role:c==null?void 0:c.role,status:r==null?void 0:r.status,onClick:async(p,h)=>{await o({idNewResponsible:p,id:e,typeOfSelect:h})},responsible:r==null?void 0:r.responsible,users:((x=r==null?void 0:r.users)==null?void 0:x.map(p=>Lt(p,i())))??[]}),a.jsx(ss,{task:(r==null?void 0:r.task)??""}),a.jsx(as,{id:e,priority:r==null?void 0:r.priority,difficulty:r.difficulty,endDate:r==null?void 0:r.endDate,atraso:r==null?void 0:r.atraso}),a.jsx(ts,{startDate:r==null?void 0:r.startDate,endDate:r==null?void 0:r.endDate})]})}),a.jsx(Wa,{taskId:e,isOpen:t,setIsOpen:n})]})},ns=({id:e})=>{var l,d,c,m,f,x;const{tasksProject:t,openTasks:n,openTask:s}=Je(),o=(l=t==null?void 0:t.data)==null?void 0:l.find(p=>p.id===e),r=(()=>{var y;const p=t==null?void 0:t.data,h=[];return(y=o==null?void 0:o.tasks)==null||y.forEach(w=>{const j=p.find(b=>b.id===(w==null?void 0:w.id));j&&h.push(j)}),h})();return o?a.jsxs("div",{className:"tm-mb-2 tm-flex tm-flex-col tm-gap-m tm-overflow-y-auto",children:[a.jsxs("div",{className:"tm-flex tm-cursor-pointer tm-flex-wrap tm-items-center tm-gap-16 tm-rounded-md tm-p-2 hover:tm-bg-surface-hover",onClick:()=>s(e),children:[a.jsx("button",{type:"button",className:`${n.includes(e)?"":"tm--rotate-90"} tm-transition-all tm-duration-300`,children:a.jsx(g.Icon,{name:ne.faChevronDown,size:"sm",style:{color:Te.texts.subtext},color:"current"})}),a.jsx("div",{className:"tm-mx-1 tm-flex tm-h-[28px] tm-min-h-[28px] tm-w-fit tm-min-w-[28px] tm-items-center tm-justify-center tm-rounded-full tm-bg-surface-default",children:a.jsx("p",{className:"tm-text-primary tm-text-md",children:((d=o==null?void 0:o.tasks)==null?void 0:d.length)===0?1:r.length})}),a.jsx(ss,{task:(o==null?void 0:o.task)??""}),a.jsx(as,{id:e,priority:o==null?void 0:o.priority,difficulty:o==null?void 0:o.difficulty,endDate:o==null?void 0:o.endDate,atraso:o==null?void 0:o.atraso}),a.jsx(ts,{startDate:o==null?void 0:o.startDate,endDate:o==null?void 0:o.endDate}),a.jsxs("button",{type:"button",className:"tm-flex tm-h-[30px] tm-w-fit tm-items-center tm-justify-center tm-gap-s tm-rounded-md tm-bg-surface-default tm-px-m hover:tm-bg-surface-hover",children:[a.jsx(g.Icon,{name:ne.faDiagramSubtask,size:"sm",color:"current"}),a.jsx(g.Text,{children:((c=o==null?void 0:o.tasks)==null?void 0:c.length)===0?1:(m=o==null?void 0:o.tasks)==null?void 0:m.length})]})]}),n.includes(e)&&a.jsx("div",{className:"tm-ml-[30px]",children:((f=o==null?void 0:o.tasks)==null?void 0:f.length)>0?(x=o==null?void 0:o.tasks)==null?void 0:x.map(p=>a.jsx(ns,{id:p==null?void 0:p.id})):a.jsx(or,{id:o==null?void 0:o.id})})]}):null},rr=()=>{var s;const{tasksProject:e,projectID:t}=Je();if(e!=null&&e.isFetching||e!=null&&e.isLoading)return a.jsx(sr,{});let n=[...(s=e==null?void 0:e.data)==null?void 0:s.filter(o=>o.isPrincipalTask)];return a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-m",children:a.jsx(tr,{project:t,children:n==null?void 0:n.sort((o,i)=>o.orden-i.orden).map(o=>a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-m tm-border-b tm-border-default tm-pb-m ",children:a.jsx(ns,{id:o.id})}))})})};function ir({title:e,color:t,icon:n}){return a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[a.jsx(g.Icon,{name:n,size:"md",colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotoneSecondary:.5}),a.jsx("p",{className:"tm-text-base tm-py-0.5 tm-font-body-sm-bold tm-text-body-sm-bold tm-leading-none tm-text-primary",children:e})]})}function lr({value:e,onChange:t}){return a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-4",children:[a.jsx("label",{className:"tm-text-body-sm-bold tm-text-primary",children:"Nombre del equipo"}),a.jsx(g.Input,{size:"xs",placeholder:"Creative",value:e,onChange:n=>t(n.target.value)})]})}const os=({title:e})=>a.jsxs("div",{className:"flex-1 tm-flex tm-items-center tm-gap-x-8",children:[a.jsx(g.Icon,{background:!0,name:ne.faFilePen,color:"blue",size:"lg"}),a.jsx(g.Text,{size:"xl",weight:"bold",children:e})]}),Ge={search:"",debouncedSearch:"",filters:[]},cr={"kanban-general":{...Ge},"lista-campanias":{...Ge},"kanban-campania":{...Ge},"teams-container":{...Ge},"templates-container":{...Ge}},ut=Ue.create((e,t)=>({viewFilters:cr,currentPath:null,debounceTimeouts:{},setCurrentPath:n=>{const s=t().currentPath;e({currentPath:n}),s&&s!==n&&t().resetPathData(s)},setSearch:(n,s)=>{const o=s||t().currentPath;if(!o)return;const i=`search_${o}`,r=t().debounceTimeouts[i];r&&clearTimeout(r),e(d=>({viewFilters:{...d.viewFilters,[o]:{...d.viewFilters[o],search:n}}}));const l=setTimeout(()=>{e(d=>({viewFilters:{...d.viewFilters,[o]:{...d.viewFilters[o],debouncedSearch:n}},debounceTimeouts:{...d.debounceTimeouts,[i]:void 0}}))},500);e(d=>({debounceTimeouts:{...d.debounceTimeouts,[i]:l}}))},setFilters:(n,s)=>{const o=s||t().currentPath;o&&e(i=>({viewFilters:{...i.viewFilters,[o]:{...i.viewFilters[o],filters:n}}}))},getSearch:n=>{var o;const s=n||t().currentPath;return s&&((o=t().viewFilters[s])==null?void 0:o.search)||""},getDebouncedSearch:n=>{var o;const s=n||t().currentPath;return s&&((o=t().viewFilters[s])==null?void 0:o.debouncedSearch)||""},getFilters:n=>{var o;const s=n||t().currentPath;return s?((o=t().viewFilters[s])==null?void 0:o.filters)||[]:[]},resetPathData:n=>{const s=`search_${n}`,o=t().debounceTimeouts[s];o&&clearTimeout(o),e(i=>({viewFilters:{...i.viewFilters,[n]:{...Ge}},debounceTimeouts:{...i.debounceTimeouts,[s]:void 0}}))}}));function rs({path:e}){const{getSearch:t,setSearch:n}=ut(),s=t(e);return a.jsx(g.Input,{leftSlot:ne.faSearch,placeholder:"Buscar...",size:"xs",value:s,onChange:o=>n(o.target.value,e)})}const ga={fase_plantilla:"",tipo_plantilla:"",modo_configuracion:"",categoria:"",formato_salida:"",tipo_medio:"",medio_especifico:"",responsable_impresion:"",pertenencia_medio:"",ubicacion_medio:""},dr={fase_plantilla:null,tipo_plantilla:null,modo_configuracion:null,categoria:null,formato_salida:null,tipo_medio:null,medio_especifico:null,responsable_impresion:null,pertenencia_medio:null,ubicacion_medio:null},mr={fase_plantilla:"",tipo_plantilla:"",categoria:"",tipo_medio:"",medio_especifico:"",modo_configuracion:"",responsable_impresion:"",pertenencia_medio:"",ubicacion_medio:""},ha={tipo_plantilla:!0,modo_configuracion:!0,categoria:!0,formato_salida:!0,tipo_medio:!0,medio_especifico:!0,responsable_impresion:!0,pertenencia_medio:!0,ubicacion_medio:!0},Fe=Ue.create(e=>({path:"",viewMode:"grid",isOpenModalLimit:!1,template:null,clave:"XX-XXX-XX-XXX-XX-X-X",templateFormData:ga,disabledFields:ha,claveParams:mr,paramsTipo:dr,isEditTemplate:!1,openModalCreateTemplate:!1,currentTemplateForEdit:null,refetch:null,openModalUnsavedChanges:!1,isDuplicateTemplate:!1,hasFormChanges:!1,openModalPublishTemplate:!1,currentTemplateId:null,openModalDeleteTemplate:!1,setPath:t=>e({path:t}),setViewMode:t=>e({viewMode:t}),setIsOpenModalLimit:t=>e({isOpenModalLimit:t}),setTemplate:t=>e({template:t}),setClave:t=>e({clave:t}),setTemplateFormData:t=>{e(n=>({templateFormData:{...n.templateFormData,...t}}))},resetTemplateFormData:()=>e({templateFormData:ga}),setDisableField:({fields:t,value:n})=>{for(const s of t)e(o=>({disabledFields:{...o.disabledFields,[s]:n}}))},resetDisabledFields:()=>e({disabledFields:ha}),setClaveParams:({field:t,value:n})=>{e(s=>({claveParams:{...s.claveParams,[t]:n}}))},resetClave:()=>e(t=>({clave:"XX-XXX-XX-XXX-XX-X-X"})),setParamTipo:t=>e(n=>({paramsTipo:{...n.paramsTipo,...t}})),setIsEditTemplate:t=>e({isEditTemplate:t}),setOpenModalCreateTemplate:t=>e({openModalCreateTemplate:t}),setCurrentTemplateForEdit:t=>e({currentTemplateForEdit:t}),setRefetch:t=>e({refetch:t}),setOpenModalUnsavedChanges:t=>e({openModalUnsavedChanges:t}),setIsDuplicateTemplate:t=>e({isDuplicateTemplate:t}),setHasFormChanges:t=>e({hasFormChanges:t}),setOpenModalPublishTemplate:t=>e({openModalPublishTemplate:t}),setCurrentTemplateId:t=>e({currentTemplateId:t}),setOpenModalDeleteTemplate:t=>e({openModalDeleteTemplate:t})})),is=e=>{const{getSearch:t,getDebouncedSearch:n,setSearch:s,getFilters:o,setFilters:i,resetPathData:r}=ut();return{search:t(e),debouncedSearch:n(e),filters:o(e),setSearch:l=>s(l,e),setFilters:l=>i(l,e),resetData:()=>r(e)}},ur=()=>a.jsx(os,{title:"Flujos de trabajo"}),Oe=Ue.create(e=>({activeTemplate:null,setActiveTemplate:t=>e({activeTemplate:t}),clearActiveTemplate:()=>e({activeTemplate:null})})),_e=Ue.create((e,t)=>({mode:"grid",id:null,setMode:(n,s)=>{const o=t();if(n==="grid"||o.id!==null&&o.id!==s){const{clearAllGroupData:r}=t();r()}e({mode:n,id:s??null})},setId:n=>e({id:n}),reset:()=>{const{clearAllGroupData:n}=t();n(),e({mode:"grid",id:null})},addNode:null,addBranch:null,addNodeFromHandle:null,addNodeWithType:null,savePositions:null,loadPositions:null,clearPositions:null,activePlusNode:null,templateViewModes:{},setViewMode:(n,s)=>{const{templateViewModes:o}=t();e({templateViewModes:{...o,[n]:s}})},getViewMode:n=>{const{templateViewModes:s}=t();return s[n]??"readonly"},clearViewMode:n=>{const{templateViewModes:s}=t(),o={...s};delete o[n],e({templateViewModes:o})},expandedGroups:new Set,groupTemplateData:{},toggleGroupExpansion:n=>{const{expandedGroups:s}=t(),o=new Set(s);o.has(n)?o.delete(n):o.add(n),e({expandedGroups:o})},setGroupTemplateData:(n,s)=>{const{groupTemplateData:o}=t();e({groupTemplateData:{...o,[n]:s}})},clearGroupTemplateData:n=>{const{groupTemplateData:s}=t(),o={...s};delete o[n],e({groupTemplateData:o})},clearAllGroupData:()=>{e({expandedGroups:new Set,groupTemplateData:{}})},copiedNodes:[],setCopiedNodes:n=>e({copiedNodes:n}),clearCopiedNodes:()=>e({copiedNodes:[]}),expandGroup:null,collapseGroup:null})),ls=()=>{const{tasks_api:e}=ge();return{getTemplateWithTasks:async n=>{var s;try{const o=Ce.stringify({filters:{plantilla:{id:n}}},{encodeValuesOnly:!0}),i=await e.get(`/api/plantillas/plantilla-tareas-grafico?${o}`);if(i.data&&i.data.data)return i.data.data;throw new Error(`No se encontraron datos para la plantilla con ID ${n}`)}catch(o){throw console.error("Error en getTemplateWithTasks:",{error:o.message,status:(s=o.response)==null?void 0:s.status}),o}}}},we={DIRTY:"dirty",IDLE:"idle",NEW:"new"},Pe={DRAFT:"draft",PUBLISHED:"published",DELETED:"deleted"},Ve="templates",We="templates_states";function pr(e,t){return Ue.create((n,s)=>{let o=null;const i=f=>n({isLoading:f}),r=f=>n({error:f}),l=f=>n({data:f}),d=()=>new Promise((f,x)=>{const p=indexedDB.open(e.name,e.version);p.onerror=()=>{r("Error al abrir la base de datos"),x(new Error("Error al abrir la base de datos"))},p.onsuccess=()=>{o=p.result,n({isConnected:!0,error:null}),f(o)},p.onupgradeneeded=h=>{const y=h.target.result;e.stores.forEach(w=>{var j;if(!y.objectStoreNames.contains(w.name)){const b=y.createObjectStore(w.name,{keyPath:w.keyPath,autoIncrement:w.autoIncrement??!1});(j=w.indexes)==null||j.forEach(v=>{b.createIndex(v.name,v.keyPath,v.options)})}})}}),c=(f="readonly")=>{if(!o)throw new Error("Base de datos no conectada");return o.transaction(t,f)},m=(f="readonly")=>c(f).objectStore(t);return{data:[],isLoading:!1,error:null,isConnected:!1,connect:async()=>{try{i(!0),r(null),await d(),await s().getAll()}catch(f){r(f instanceof Error?f.message:"Error desconocido")}finally{i(!1)}},disconnect:()=>{o&&(o.close(),o=null,n({isConnected:!1,data:[]}))},add:async f=>{try{i(!0),r(null);const x=m("readwrite");return new Promise((p,h)=>{const y=x.add(f);y.onsuccess=async()=>{await s().getAll(),p()},y.onerror=()=>{r("Error al agregar elemento"),h(new Error("Error al agregar elemento"))}})}finally{i(!1)}},addMany:async f=>{try{i(!0),r(null);const x=m("readwrite");return new Promise((p,h)=>{let y=0,w=!1;f.forEach(j=>{const b=x.add(j);b.onsuccess=()=>{y++,y===f.length&&!w&&s().getAll().then(()=>p())},b.onerror=()=>{w||(w=!0,r("Error al agregar elementos"),h(new Error("Error al agregar elementos")))}})})}finally{i(!1)}},get:async f=>{try{r(null);const x=m();return new Promise((p,h)=>{const y=x.get(f);y.onsuccess=()=>{p(y.result)},y.onerror=()=>{r("Error al obtener elemento"),h(new Error("Error al obtener elemento"))}})}catch(x){r(x instanceof Error?x.message:"Error desconocido");return}},getAll:async()=>{try{r(null);const f=m();return new Promise((x,p)=>{const h=f.getAll();h.onsuccess=()=>{const y=h.result;l(y),x(y)},h.onerror=()=>{r("Error al obtener elementos"),p(new Error("Error al obtener elementos"))}})}catch(f){return r(f instanceof Error?f.message:"Error desconocido"),[]}},update:async(f,x)=>{try{i(!0),r(null);const p=m("readwrite");return new Promise((h,y)=>{const w=p.get(f);w.onsuccess=()=>{const j=w.result;if(!j){r("Elemento no encontrado"),y(new Error("Elemento no encontrado"));return}const b={...j,...x},v=p.put(b);v.onsuccess=async()=>{await s().getAll(),h()},v.onerror=()=>{r("Error al actualizar elemento"),y(new Error("Error al actualizar elemento"))}},w.onerror=()=>{r("Error al obtener elemento para actualizar"),y(new Error("Error al obtener elemento para actualizar"))}})}finally{i(!1)}},delete:async f=>{try{i(!0),r(null);const x=m("readwrite");return new Promise((p,h)=>{const y=x.delete(f);y.onsuccess=async()=>{await s().getAll(),p()},y.onerror=()=>{r("Error al eliminar elemento"),h(new Error("Error al eliminar elemento"))}})}finally{i(!1)}},clear:async()=>{try{i(!0),r(null);const f=m("readwrite");return new Promise((x,p)=>{const h=f.clear();h.onsuccess=()=>{l([]),x()},h.onerror=()=>{r("Error al limpiar store"),p(new Error("Error al limpiar store"))}})}finally{i(!1)}},query:async(f,x)=>{try{r(null);const h=m().index(f);return new Promise((y,w)=>{const j=h.getAll(x);j.onsuccess=()=>{y(j.result)},j.onerror=()=>{r("Error en consulta"),w(new Error("Error en consulta"))}})}catch(p){return r(p instanceof Error?p.message:"Error desconocido"),[]}},queryRange:async(f,x,p)=>{try{r(null);const y=m().index(f);return new Promise((w,j)=>{const b=IDBKeyRange.bound(x,p),v=y.getAll(b);v.onsuccess=()=>{w(v.result)},v.onerror=()=>{r("Error en consulta por rango"),j(new Error("Error en consulta por rango"))}})}catch(h){return r(h instanceof Error?h.message:"Error desconocido"),[]}}}})}const jt=new Map;function xa(e,t,n=!0){const s=u.useMemo(()=>{const v=`${e.name}-${t}`;if(!jt.has(v)){const M=pr(e,t);jt.set(v,M)}return jt.get(v)},[e.name,t]);u.useEffect(()=>{n&&!s.getState().isConnected&&s.getState().connect()},[n,s]);const o=s(v=>v.data),i=s(v=>v.isLoading),r=s(v=>v.error),l=s(v=>v.isConnected),d=u.useCallback(()=>s.getState().connect(),[s]),c=u.useCallback(()=>s.getState().disconnect(),[s]),m=u.useCallback(v=>s.getState().add(v),[s]),f=u.useCallback(v=>s.getState().addMany(v),[s]),x=u.useCallback(v=>s.getState().get(v),[s]),p=u.useCallback(()=>s.getState().getAll(),[s]),h=u.useCallback((v,M)=>s.getState().update(v,M),[s]),y=u.useCallback(v=>s.getState().delete(v),[s]),w=u.useCallback(()=>s.getState().clear(),[s]),j=u.useCallback((v,M)=>s.getState().query(v,M),[s]),b=u.useCallback((v,M,F)=>s.getState().queryRange(v,M,F),[s]);return{data:o,isLoading:i,error:r,isConnected:l,connect:d,disconnect:c,add:m,addMany:f,get:x,getAll:p,update:h,delete:y,clear:w,query:j,queryRange:b}}const cs=u.createContext(void 0);function fr({children:e}){const[t,n]=u.useState(!1),[s,o]=u.useState(!0),[i,r]=u.useState(null),l={name:"template_tabs_v1",version:2,stores:[{name:Ve,keyPath:"id",autoIncrement:!1,indexes:[{name:"id",keyPath:"id",options:{unique:!0}}]},{name:We,keyPath:"id",autoIncrement:!1,indexes:[{name:"id",keyPath:"id",options:{unique:!0}}]}]},d=xa(l,Ve,!0),c=xa(l,We,!0),m=u.useRef(new Map);m.current.has(Ve)||m.current.set(Ve,d),m.current.has(We)||m.current.set(We,c);const f=d.isConnected,x=d.error;u.useEffect(()=>{m.current.set(Ve,d),m.current.set(We,c)},[d,c]);const p=u.useCallback(y=>{const w=m.current.get(y);if(!w)throw new Error(`Store ${y} no encontrado. Asegúrate de que esté configurada en indexedDBConfig.`);return{data:w.data,isLoading:w.isLoading,add:w.add,addMany:w.addMany,get:w.get,getAll:w.getAll,update:w.update,delete:w.delete,clear:w.clear,query:w.query,queryRange:w.queryRange,error:w.error}},[]);u.useEffect(()=>{(async()=>{try{if(o(!0),r(null),await d.connect(),f)n(!0);else throw new Error("No se pudo establecer la conexión con IndexedDB")}catch(w){r(w instanceof Error?w.message:"Error desconocido")}finally{o(!1)}})()},[d.connect,f]),u.useEffect(()=>{x&&r(x)},[x]);const h={isInitialized:t,isInitializing:s,error:i,isConnected:f,getStore:p};return a.jsx(cs.Provider,{value:h,children:e})}function ds(){const e=u.useContext(cs);if(e===void 0)throw new Error("useIndexedDBContext debe usarse dentro de IndexedDBProvider");return e}function Ut(){const{getStore:e}=ds();return e(Ve)}function ms(){const{add:e}=Ut(),t=async r=>{try{await e(r)}catch(l){console.error("Error al guardar plantilla a indexDB:",l)}},n=async r=>{const l={},d=c=>{c.id&&(l[c.id]=c),c.tareas&&Array.isArray(c.tareas)&&c.tareas.forEach(m=>{d(m)}),c.ids_t_dependientes&&Array.isArray(c.ids_t_dependientes)&&c.ids_t_dependientes.forEach(m=>{typeof m=="object"&&m.id&&d(m)}),c.plantilla_dependents&&Array.isArray(c.plantilla_dependents)&&c.plantilla_dependents.forEach(m=>{m.tarea_plantillas&&Array.isArray(m.tarea_plantillas)&&m.tarea_plantillas.forEach(f=>{d(f)})})};return r.tarea_plantillas.forEach(c=>{d(c)}),l},s=(r,l)=>{const d=l[r];if(!d)return[];const c=[d];return d.tareas&&Array.isArray(d.tareas)&&d.tareas.forEach(m=>{m.id&&c.push(...s(m.id,l))}),d.ids_t_dependientes&&Array.isArray(d.ids_t_dependientes)&&d.ids_t_dependientes.forEach(m=>{typeof m=="object"&&m.id?c.push(...s(m.id,l)):typeof m=="number"&&l[m]&&c.push(...s(m,l))}),c},o=(r,l)=>{const d=l[r];if(!d)return[];const c=[d];return d.tarea_padre&&l[d.tarea_padre]&&c.unshift(...o(d.tarea_padre,l)),c};return{hydrateTasks:async r=>{var c,m;const l=await n(r);return(m=(c=r==null?void 0:r.graph_layout)==null?void 0:c.snapshot)==null?void 0:m.nodes.map(f=>{if(f.type==="group")return{...f,data:{...f.data,type:"template"},type:"group",selected:!1};const x=f.data.tareaId?l[f.data.tareaId]:r;return x!=null&&x.start?{...f,data:{...x.plantilla,id:x.id},selected:!1}:{...f,data:{...x,type:"task"},selected:!1}})},initializeTemplateStore:t,indexedTasks:n,getTaskHierarchy:s,getTaskPath:o}}function us(){const{getStore:e}=ds();return e(We)}const nt=()=>{const{add:e,get:t,delete:n,update:s}=us(),{get:o}=Ut(),i={created:[],updated:[],deleted:[]},r=async({templateId:p})=>{const h=await t(p);return h||null};return{addTaskToState:async({task:p})=>{const h=await r({templateId:p.plantilla.id}),y=await o(p.plantilla.id);if(console.log("🔄 template:",y),!h)e({...i,id:p.plantilla.id,created:[...i.created,p]});else{const w=h.created.findIndex(j=>j.id===p.id);if(w!==-1){const j=h.created[w];h.created[w]={...j,...p},await s(p.plantilla.id,h)}else h.created.push(p),await s(p.plantilla.id,h)}},getTaskFromState:r,removeTemplateStates:async p=>{await n(p)},updateTaskInState:async({task:p})=>{const h=await r({templateId:p.plantilla.id}),w=(await o(p.plantilla.id)).graph_layout.snapshot.nodes;if(console.log("🔄 nodes:",w),h){const j=h.updated.findIndex(b=>b.id===p.id);if(j!==-1){const b=h.updated[j];console.log("🔄 currentTask:",b),h.updated[j]={...b,...p}}else h.updated.push(p);await s(p.plantilla.id,h)}else e({...i,id:p.plantilla.id,updated:[...i.updated,p]})},removeTaskFromState:async({templateId:p,id:h})=>{const y=await r({templateId:p});if(y){if(h>0){const j=y.deleted.findIndex(b=>b===h);if(j!==-1){y.deleted.splice(j,1),await s(p,y);return}}const w=y.created.findIndex(j=>j.id===h);if(w!==-1){y.created.splice(w,1),await s(p,y);return}}else if(h>0){e({...i,id:p,deleted:[...i.deleted,h]});return}},removeParentIdFromNodes:async({templateId:p,id:h})=>{const y=await r({templateId:p});if(y){const w=y.created.findIndex(b=>b.id===h);if(w!==-1){y.created[w].tarea_padre=null,y.created[w].id_t_requerida=null,await s(p,y);return}const j=y.updated.findIndex(b=>b.id===h);if(j!==-1){y.updated[j].tarea_padre=null,y.updated[j].id_t_requerida=null,await s(p,y);return}}},updateNodeWithNewEdge:async({templateId:p,edge:h,task:y})=>{console.log("🔵 updateNodeWithNewEdge - Inicio",{templateId:p,taskId:y.id,taskData:y});const w=await r({templateId:p});if(console.log("🔵 updateNodeWithNewEdge - Estado actual:",w),w){console.log("🔵 updateNodeWithNewEdge - Estado existe, buscando tarea...");const j=w.created.findIndex(v=>v.id===y.id);if(console.log("🔵 updateNodeWithNewEdge - Índice en created:",j),j!==-1){console.log("🔵 updateNodeWithNewEdge - Actualizando en created"),w.created[j]=y,await s(p,w),console.log("✅ updateNodeWithNewEdge - Actualizado en created");return}const b=w.updated.findIndex(v=>v.id===y.id);if(console.log("🔵 updateNodeWithNewEdge - Índice en updated:",b),b!==-1){console.log("🔵 updateNodeWithNewEdge - Actualizando en updated"),w.updated[b]=y,await s(p,w),console.log("✅ updateNodeWithNewEdge - Actualizado en updated");return}if(console.log("🔵 updateNodeWithNewEdge - Tarea no encontrada en arrays"),y.id&&y.id!==0){const v=y.id<0;v?(console.log("🔵 updateNodeWithNewEdge - Agregando a created (tarea nueva)"),w.created.push(y)):(console.log("🔵 updateNodeWithNewEdge - Agregando a updated (tarea existente)"),w.updated.push(y)),await s(p,w),console.log("✅ updateNodeWithNewEdge - Tarea agregada exitosamente a",v?"created":"updated")}else console.error("❌ updateNodeWithNewEdge - task.id no válido para agregar:",y.id)}else if(console.log("🔵 updateNodeWithNewEdge - Creando nuevo estado"),y.id&&y.id!==0){const j=y.id<0,b={...i,id:p,created:j?[y]:[],updated:j?[]:[y]};console.log("🔵 updateNodeWithNewEdge - Nuevo estado:",b,j?"(created)":"(updated)"),e(b),console.log("✅ updateNodeWithNewEdge - Estado creado exitosamente")}else console.error("❌ updateNodeWithNewEdge - task.id no válido:",y.id);console.log("🔵 updateNodeWithNewEdge - Fin")}}};function Be(){const{activeTemplate:e,setActiveTemplate:t}=Oe(),{mode:n,setMode:s,setViewMode:o,clearViewMode:i}=_e(),{template:r,setIsOpenModalLimit:l,setOpenModalUnsavedChanges:d,setOpenModalPublishTemplate:c,setOpenModalDeleteTemplate:m}=Fe(),{hydrateTasks:f}=ms(),{addTaskToState:x,removeTemplateStates:p}=nt(),h=de.useQueryClient(),{data:y,add:w,update:j,get:b,getAll:v,delete:M,isLoading:F,error:R}=Ut(),{get:C}=us(),{getTemplateWithTasks:I}=ls(),{tasks_api:T}=ge(),[V,z]=u.useState(!1),[ee,G]=u.useState(!1),[k,E]=u.useState(!1),L=u.useMemo(()=>y.sort((N,U)=>N.order-U.order),[y]);u.useEffect(()=>{L.length===0&&n!=="grid"&&s("grid")},[L,n,s]);const B=async(S,N=we.IDLE)=>{var U;try{const O=await I(S.id),_=await f(O),W={id:crypto.randomUUID(),data:O,type:"start",dragging:!1,measured:{width:171,height:48},position:{x:91,y:-24.5},selected:!1,deletable:!1},Z=_||[W],ae={...O,graph_layout:{...O==null?void 0:O.graph_layout,snapshot:{...(U=O==null?void 0:O.graph_layout)==null?void 0:U.snapshot,nodes:Z}},estatus:N,estatusFromStrapi:O.estatus};await w(ae)}catch(O){console.warn("No se pudieron obtener los datos completos de la plantilla, creando versión básica:",O);const _=S,W={id:crypto.randomUUID(),data:_,type:"start",dragging:!1,measured:{width:171,height:48},position:{x:91,y:-24.5},selected:!1,deletable:!1},Z={id:_.id,snapshot:{nodes:[W],edges:[],viewport:{x:0,y:0,zoom:1}},history:null,zoom:1,position:{x:0,y:0}},ae={..._,graph_layout:_.graph_layout||Z,estatus:N,tarea_plantillas:_.tarea_plantillas||[]};await w(ae)}},q=async({template:S,checkTemplateInIndexedDB:N=!1,statusTemplate:U=we.IDLE})=>{const O=L;if(!O.find(W=>W.id===S.id)){if(O.length===5){l(!0);return}if(N&&await b(S.id))return;await B({...S,order:O.length+1},U)}await H(S.id),await X(S),s("create-edit",S==null?void 0:S.id)},X=async S=>{const N=await b(S.id);t(N)},H=async S=>{try{let N=await v();N.sort((O,_)=>(O.order||0)-(_.order||0));const U=N.findIndex(O=>O.id===S);if(U!==-1){const[O]=N.splice(U,1);N.unshift(O),N.forEach((W,Z)=>{W.order=Z+1});const _=N.map(W=>j(W.id,W));await Promise.all(_)}else return}catch{}},re=async S=>{try{await M(S),i(S);const N=await v();N.forEach((O,_)=>{O.order=_+1});const U=N.map(O=>j(O.id,O));await Promise.all(U)}catch{}};return{screens:L,isLoading:F,error:R,add:w,data:y,addScreen:B,openTemplate:q,update:j,delete:re,get:b,activeTemplate:e,activateTemplate:X,reorderingTemplates:H,replaceTemplate:async()=>{try{const S=[...L],N={...S[S.length-1]};await M(N.id);const U={...r,order:N.order};await B(U);const _=(await v()).sort((Z,ae)=>Z.order-ae.order);if(_.some((Z,ae)=>(Z.order||0)!==ae+1)){const Z=_.map((ae,ie)=>({...ae,order:ie+1}));for(const ae of Z)try{await j(ae.id,ae)}catch{}}}catch{}finally{l(!1)}},addTaskUpdatingTemplate:async(S,N,U="hija")=>{var Z,ae,ie,J;const O=await b(N);if(!O)return null;const _={id:S.id,uuid:crypto.randomUUID(),reference_graph:S.reference_graph,texto_corto:S.title,texto_largo:S.description||"",prioridad:S.priority||null,nivel_dificultad:S.difficulty||1,duracion:S.duration||null,start:!1,type:"task",equipo:{id:Number(S.team)||null},responsable:{id:Number(S.responsible)||null},plantilla:{id:O.id,clave:O.clave,categoria:O.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:[],id_t_requerida:U==="dependiente"?(ae=(Z=S.parent)==null?void 0:Z.data)==null?void 0:ae.id:null,ids_t_dependientes:[],tarea_padre:U==="hija"?(J=(ie=S.parent)==null?void 0:ie.data)==null?void 0:J.id:null,tareas:[]},W={...O,estatus:we.DIRTY};return await j(N,W),e&&e.id===N&&t(W),await x({task:_}),_},addTemplateUpdatingTemplate:async(S,N,U,O="hija")=>{let _=null;if(e&&e.id===N?_=e:_=await b(N),!_)return null;const W=(ae,ie,J,se)=>{for(let ce=0;ce<ae.length;ce++){const le=ae[ce];if(le.id===ie||le.uuid===ie)return se==="dependiente"?(le.plantilla_dependents||(le.plantilla_dependents=[]),le.plantilla_dependents.push(J)):se==="hija"&&(le.plantilla_dependents||(le.plantilla_dependents=[]),le.plantilla_dependents.push(J)),!0;if(le.tareas&&le.tareas.length>0){const te=W(le.tareas,ie,J,se);if(te)return te}}return!1};if(W(_.tarea_plantillas,U,S,O)){const ae={..._,estatus:we.DIRTY,updatedAt:new Date().toISOString()};return await j(N,ae),e&&e.id===N&&t(ae),!0}else return!1},updateGraphLayout:async(S,N)=>{var U;if(!S){console.warn("⚠️ updateGraphLayout - Template ID no válido");return}try{const O=await b(S);if(!O){console.warn("⚠️ updateGraphLayout - Template no encontrado");return}const _=(N.nodes||[]).filter(se=>{var ce;return!((ce=se.data)!=null&&ce.isInternal)&&!se.parentId}).map(se=>{const{style:ce,measured:le,data:te,...ue}=se,{expandedDimensions:fe,isExpanded:he,needsReExpansion:pe,...be}=te||{},Me=ce?{...ce,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...ue,style:Me,data:be,position:se.position}}),W=(N.edges||[]).filter(se=>{var ce;return!((ce=se.data)!=null&&ce.isInternal)}).map(se=>{var ce;if((ce=se.data)!=null&&ce.redirectedToInternal){const{redirectedToInternal:le,originalTarget:te,...ue}=se.data;return{...se,target:te||se.target,data:ue}}return se}),Z={...N,nodes:_,edges:W},ae=(U=O.graph_layout)==null?void 0:U.snapshot;if(!(!ae||JSON.stringify(ae)!==JSON.stringify(Z)))return;const J={...O,graph_layout:{...O.graph_layout,snapshot:Z},estatus:we.DIRTY,updatedAt:new Date().toISOString()};await j(S,J),e&&e.id===S&&t(J)}catch(O){console.error("❌ updateGraphLayout - Error:",O)}},saveTemplateChanges:async(S=!0)=>{try{if(e.estatus===we.DIRTY){G(!0);const{id:N}=e,U=await b(N),O=await C(N),_=U.graph_layout.snapshot.nodes||[],W=_.filter(J=>{var se;return!((se=J.data)!=null&&se.isInternal)&&!J.parentId}),Z=_.length-W.length;Z>0&&console.warn(`💾 [saveTemplateChanges] Se filtraron ${Z} nodos internos al guardar plantilla ${N}`);const ae={graph_layout:{...U.graph_layout,snapshot:{...U.graph_layout.snapshot,nodes:W.map(J=>{const{style:se,measured:ce,selected:le,...te}=J,ue=se?{...se,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return J.type==="group"?{...te,style:ue,data:{tareaId:J.data.id&&J.data.id>0?J.data.id:null,clave:J.data.clave,estatus:J.data.estatus,updatedAt:J.data.updatedAt,id:J.data.id}}:{...te,style:ue,data:{tareaId:J.data.id&&J.data.id>0?J.data.id:null}}}),edges:(U.graph_layout.snapshot.edges||[]).filter(J=>{var se;return!((se=J.data)!=null&&se.isInternal)})}},tasks:{created:(O==null?void 0:O.created)||[],updated:(O==null?void 0:O.updated)||[],deleted:(O==null?void 0:O.deleted)||[]}},ie=await T.post("/api/tareas/save-tareas-grafico",{data:ae});if(ie.data&&ie.status===200){try{const J=await I(N),se=await f(J),ce={...J,graph_layout:{...J.graph_layout,snapshot:{...J.graph_layout.snapshot,nodes:se}},estatus:we.IDLE};await j(N,ce),S||t(ce)}catch{const se=await b(N);if(se&&!S){const ce={...se,estatus:we.IDLE};await j(N,ce),t(ce)}}await h.invalidateQueries({queryKey:["template",N]}),await h.invalidateQueries({queryKey:["template"]}),p(N),S&&(re(N),d(!1)),o(N,"readonly")}}}catch(N){console.log(N)}finally{G(!1)}},publishTemplate:async S=>{try{z(!0);const N={estatus:Pe.PUBLISHED,publication_date:new Date},U=await T.put(`/api/plantillas/plantilla-update-estatus/${S}`,{data:N});U.data&&U.status===200&&(t({...e,estatusFromStrapi:Pe.PUBLISHED}),c(!1),g.toast.info("Se publicó correctamente el proceso"))}catch(N){console.log(N),g.toast.error("Surgió un error al publicar el proceso")}finally{z(!1)}},deleteTemplate:async S=>{try{E(!0);const N={estatus:Pe.DELETED,sjdaksd:0},U=await T.put(`/api/plantillas/plantilla-update-estatus/${S}`,{data:N});U.data&&U.status===200&&(m(!1),g.toast.info("Se eliminó correctamente el proceso"))}catch(N){console.error(N),g.toast.error("Surgión un error al eliminar el proceso")}finally{E(!1)}},loadingPublishTemplate:V,loadingSaveChanges:ee,loadingDeleteTemplate:k}}const gr=async({tasks_api:e})=>{try{return(await e.get("/api/getAllOBPusers")).data}catch(t){throw console.log("Error al obtener los usuarios de OBP",t),`Error al obtener los usuarios de OBP: ${t}`}},hr=()=>{const{tasks_api:e}=ge();return{users:de.useQuery({queryKey:["usersOBP"],queryFn:()=>gr({tasks_api:e}),staleTime:1e3*60*60*24})}},Ze=()=>{const{users:e}=hr(),t=de.useQuery({queryKey:["users_index",e.data],queryFn:()=>co({users:e.data||[]}),staleTime:1e3*60*60*24,enabled:!!e.data});return{users:t.data,isLoading:t.isLoading||e.isLoading}},Ht=()=>{const{users:e,isLoading:t}=Ze(),{getImageOBP:n}=ge();return{getImageByEmail:i=>{const r=e==null?void 0:e[i];return n(r==null?void 0:r.image)},getNameByEmail:i=>{const r=e==null?void 0:e[i];return(r==null?void 0:r.nombre)||""},isLoading:t}},ot=({isLoading:e})=>e?a.jsxs("div",{className:"tm-fixed tm-inset-0 tm-z-50 tm-flex tm-items-center tm-justify-center",children:[a.jsx("div",{className:"tm-absolute tm-inset-0",style:{backgroundColor:"rgba(0, 0, 0, 0.5)"}}),a.jsx("div",{className:"tm-relative tm-flex tm-flex-col tm-items-center tm-justify-center tm-gap-4",children:a.jsx(g.Spinner,{})})]}):null,ba=({template:e,openModalPublishTemplate:t,onHadleClickEditTemplateParams:n,onEditTasks:s,canDuplicateAndDeleteTemplates:o,onHandleClickDuplicateTemplate:i,openModalDeleteTemplate:r})=>a.jsx(g.Popup,{color:"secondary",pill:"pill",icon:me.faEllipsis,stopPropagationList:!0,children:a.jsxs(g.List,{className:"tm-p-6 tm-gap-4",children:[e.estatus!==Pe.PUBLISHED&&e.counts_tasks>2&&a.jsx(g.ListItem,{icon:me.faArrowUp,onClick:t,children:"Publicar"}),a.jsx(g.ListItem,{icon:me.faEdit,onClick:()=>{n(e)},children:"Editar parámetros"}),a.jsx(g.ListItem,{icon:me.faEdit,onClick:()=>{s&&s(e)},children:"Editar tareas"}),o&&a.jsx(g.ListItem,{icon:me.faClone,onClick:l=>{l.stopPropagation(),i(e)},children:"Duplicar"}),o&&a.jsx(g.ListItem,{color:"red",icon:me.faTrash,onClick:r,children:"Eliminar"})]})}),ps=({fullWidth:e,mode:t="grid",onClick:n,active:s,template:o,withOptions:i=!0})=>{const{openTemplate:r}=Be(),{getImageByEmail:l,getNameByEmail:d}=Ht(),{setIsEditTemplate:c,setOpenModalCreateTemplate:m,setCurrentTemplateForEdit:f,setIsDuplicateTemplate:x,setOpenModalPublishTemplate:p,setCurrentTemplateId:h,setOpenModalDeleteTemplate:y}=Fe(),w={0:{color:"accent",theme:"solid"},1:{color:"accent",theme:"soft"},2:{color:"warning",theme:"solid"},3:{color:"info",theme:"solid"},4:{color:"gray",theme:"solid"},5:{color:"warning",theme:"soft"},6:{color:"danger",theme:"solid"},7:{color:"info",theme:"soft"},8:{color:"success",theme:"solid"},9:{color:"danger",theme:"solid"}},[j,b]=u.useState(!1),v=async()=>{if(b(!0),t==="grid")try{b(!0),await r({template:o,checkTemplateInIndexedDB:!0})}catch(q){console.error(q)}finally{b(!1)}else b(!1);n==null||n(o==null?void 0:o.id)},M=async()=>{if(!(t!=="grid"||!o)){b(!0);try{await r({template:o,checkTemplateInIndexedDB:!0}),n==null||n(o==null?void 0:o.id)}catch(q){console.error(q)}finally{b(!1)}}},F=q=>{c(!0),m(!0),f(q)},R=q=>{x(!0),m(!0),f(q)},C=()=>{h(o==null?void 0:o.id),p(!0)},I=()=>{h(o==null?void 0:o.id),y(!0)},T=(o==null?void 0:o.dias_duracion)===1?"Día":"Días",V=(o==null?void 0:o.counts_tasks)===1?"Tarea":"Tareas",z=(o==null?void 0:o.estatus)===Pe.PUBLISHED?Nt(o==null?void 0:o.publication_date).format("DD/MM/YYYY"):Nt(o==null?void 0:o.createdAt).format("DD/MM/YYYY"),ee=(o==null?void 0:o.updated_by)||(o==null?void 0:o.created_by),G=l(ee==null?void 0:ee.email),k=d(ee==null?void 0:ee.email)||"",E=(o==null?void 0:o.estatus)===Pe.PUBLISHED?"Fecha de publicación":"Fecha de creación",L=(o==null?void 0:o.estatus)===Pe.DRAFT,B=q=>{const X=q.split("-");return a.jsx(a.Fragment,{children:X.map((H,re)=>a.jsxs("span",{children:[H,re<X.length-1&&a.jsx("span",{className:"tm-text-neutral-200",children:"-"})]},re))})};return a.jsxs(g.Card,{active:s,fullWidth:e,onClick:v,className:`${e?"md:tm-flex-row":"tm-flex-col"}`,children:[a.jsx(ot,{isLoading:j}),a.jsx(g.Card.Header,{children:a.jsx("div",{className:"tm-flex tm-justify-between tm-items-start tm-gap-x-4",children:a.jsxs("div",{className:"tm-flex tm-justify-between tm-items-start tm-gap-4 tm-flex-1",children:[a.jsxs("div",{className:"tm-flex tm-place-items-start tm-gap-x-8",children:[a.jsx("div",{className:"tm-flex tm-items-center",children:a.jsx(g.Icon,{name:ze.faChartDiagram,colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,size:"lg"})}),a.jsxs("div",{className:"tm-flex tm-gap-x-8 tm-flex-col tm-gap-y-4",children:[a.jsx(g.Text,{size:"sm",weight:"semibold",color:"primary",truncateLabel:!0,children:B((o==null?void 0:o.clave)||(o==null?void 0:o.nombre_plantilla))}),a.jsxs("div",{className:"tm-flex tm-items-baseline tm-gap-x-1",children:[a.jsx(g.Badge,{size:"sm",theme:"soft",color:(o==null?void 0:o.estatus)===Pe.PUBLISHED?"success":"gray",label:(o==null?void 0:o.estatus)===Pe.PUBLISHED?"Publicado":"Borrador"}),!(typeof z=="string"&&z==="Invalid date")&&a.jsx(g.Tooltip,{label:E,children:a.jsx(g.Text,{size:"sm",weight:"medium",color:"tertiary",children:z})})]})]})]}),!e&&a.jsx(ba,{template:o,openModalPublishTemplate:C,onHadleClickEditTemplateParams:F,onEditTasks:M,canDuplicateAndDeleteTemplates:L,onHandleClickDuplicateTemplate:R,openModalDeleteTemplate:I})]})})}),a.jsx(g.Card.Separator,{vertical:e}),a.jsx(g.Card.Body,{className:"tm-flex tm-flex-wrap tm-gap-x-6 tm-gap-y-4 tm-w-full md:tm-w-auto tm-flex-1 tm-items-center",children:o==null?void 0:o.params_plantillas.map((q,X)=>{const H=w[q.params_tipo.order-1];return a.jsx(g.Badge,{color:H.color,theme:H.theme,label:q.name,size:"sm"},q.name)})}),!e&&a.jsx(g.Card.Separator,{vertical:e}),a.jsxs(g.Card.Footer,{className:"tm-flex tm-justify-between tm-w-full md:tm-w-auto tm-gap-x-4",children:[a.jsxs("div",{className:`tm-flex tm-flex-1 ${e?"tm-gap-x-2 md:tm-gap-20 lg:tm-gap-32 2xl:tm-gap-44":""}`,children:[a.jsx("div",{className:`tm-flex tm-gap-x-8 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col":"tm-flex-row"}`,children:a.jsx(g.Tooltip,{label:"Tareas totales",children:a.jsxs("div",{className:`tm-flex tm-items-center tm-gap-8 ${e?"tm-flex-col":"tm-flex-row"}`,children:[a.jsx(g.Text,{size:"xs",weight:"semibold",color:"brand",children:(o==null?void 0:o.counts_tasks)||0}),a.jsx(g.Text,{size:"xs",weight:"regular",color:"tertiary",children:V})]})})}),a.jsx("div",{className:`tm-flex tm-gap-x-8 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col":"tm-flex-row"}`,children:a.jsx(g.Tooltip,{label:"Tareas totales",children:a.jsxs("div",{className:`tm-flex tm-items-center tm-gap-8 ${e?"tm-flex-col":"tm-flex-row"}`,children:[a.jsx(g.Text,{size:"xs",weight:"semibold",color:"brand",children:(o==null?void 0:o.dias_duracion)||0}),a.jsx(g.Text,{size:"xs",weight:"regular",color:"tertiary",children:T})]})})}),a.jsxs("div",{className:`tm-flex tm-gap-x-8 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col-reverse tm-gap-y-1":"tm-flex-row"}`,children:[a.jsx(g.Text,{size:"xs",weight:"regular",color:"tertiary",children:"Editor"}),a.jsx(g.Tooltip,{label:k,children:a.jsx(g.Avatar,{src:G,size:"xxs",type:"people"})})]})]}),e&&i&&a.jsx(g.Card.Separator,{vertical:e}),i&&a.jsx("div",{className:`tm-w-auto ${e?"tm-flex tm-items-center":""}`,children:e&&a.jsx(ba,{template:o,openModalPublishTemplate:C,onHadleClickEditTemplateParams:F,onEditTasks:M,canDuplicateAndDeleteTemplates:L,onHandleClickDuplicateTemplate:R,openModalDeleteTemplate:I})})]})]})},fs=(e=7)=>{const t=(s,o)=>s>=o?{populate:"*"}:{miembro_padre:{fields:["id"]},idUser:{populate:"*"},miembros:{populate:t(s+1,o),filters:{idUser:{blocked:!1}}}};return{miembros:{populate:t(0,e),filters:{idUser:{blocked:!1}}}}},xr=e=>{const t=new Set,n=[],s=o=>{var i;if(Array.isArray(o))for(const r of o){const l=r,d=l==null?void 0:l.idUser;(d==null?void 0:d.id)!=null&&(d.email||d.nombre)&&(t.has(d.id)||(t.add(d.id),n.push({id:d.id,nombre:d.nombre??"",email:d.email??"",image:d.image}))),(i=l==null?void 0:l.miembros)!=null&&i.length&&s(l.miembros)}};return s(e),n},br=async(e,t)=>{var l;const n=Ce.stringify({fields:["nombre","id"],populate:fs(2)},{encodeValuesOnly:!0}),s=await e.get(`/api/equipos/${t}?${n}`),o=((l=s.data)==null?void 0:l.data)??s.data,i=xe(o),r=xr((i==null?void 0:i.miembros)??[]);return{team:{nombre:(i==null?void 0:i.nombre)??"",miembros:(i==null?void 0:i.miembros)??[]},members:r}},yr=e=>{const{tasks_api:t}=ge(),n=typeof e=="number"&&e>0&&!Number.isNaN(e)?e:null;return de.useQuery({queryKey:["equipo-flow-preview",n],queryFn:()=>br(t,n),enabled:n!=null,staleTime:300*1e3})},jr=3,wr=e=>{if(!(e!=null&&e.id)&&(e==null?void 0:e.id)!==0)return null;const t=Number(e.id);return!Number.isNaN(t)&&t>0?t:null},vr=({equipo:e})=>{var p;const t=wr(e),n=((p=e==null?void 0:e.nombre)==null?void 0:p.trim())??"",{data:s,isLoading:o,isError:i}=yr(t),{getImageByEmail:r,isLoading:l}=Ht();if(!t)return null;const d=((s==null?void 0:s.team.nombre)??n).trim()||"Equipo",c=(s==null?void 0:s.members)??[],m=d,f=[...c].map(h=>{var y;return{src:r(h.email),name:((y=h.nombre)==null?void 0:y.trim())||h.email}}).sort((h,y)=>+!!y.src-+!!h.src),x=a.jsx("div",{className:"tm-flex tm-items-center tm-justify-center",children:o||l?a.jsx("div",{className:"tm-flex tm-items-center",children:[0,1,2].map(h=>a.jsx("div",{className:`tm-h-7 tm-w-7 tm-shrink-0 tm-rounded-full tm-bg-neutral-100 tm-ring-2 tm-ring-white ${h>0?"tm-ml-[-12px]":""}`},h))}):c.length>0?a.jsx(g.Avatar,{counterColor:"blue",counterTheme:"solid",maxVisible:jr,size:"xs",stack:f,stroke:!0}):a.jsx(g.Avatar,{size:"xs",stroke:!0,type:"people"})});return a.jsxs("div",{className:"tm-flex tm-min-w-0 tm-shrink-0 tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[a.jsx(g.Tooltip,{preserveLayout:!0,label:i&&!n?"Equipo":m,children:x}),a.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Equipo"})]})},_r={1:"blue",2:"green",3:"red",4:"yellow"},Tr=({difficulty:e})=>a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[a.jsx(g.Icon,{name:me.faRhombus,size:"md",color:_r[e]}),a.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Dificultad"})]}),Nr=({duration:e})=>a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end",children:[a.jsx("p",{className:"tm-text-icon-all-colors-blue tm-text-body-lg-regular tm-leading-none tm-font-semibold",children:e}),a.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Duración"})]}),Cr={1:"neutral",2:"blue",3:"yellow",4:"red"},Sr=({priority:e})=>a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[a.jsx(g.Icon,{name:me.faFlag,size:"md",color:Cr[e]}),a.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Prioridad"})]});class Er{static toUsers(t){return{id:t.id,name:t.nombre,image:t.image,email:t.email}}}const Pr=async({tasks_api:e})=>{try{const t=Ce.stringify({filters:{blocked:!1}},{encodeValuesOnly:!0}),n=await e.get(`/api/users?${t}`);return xe(n.data).map(Er.toUsers).sort((o,i)=>o.name.localeCompare(i.name))}catch(t){throw console.log("Error al obtener los usuarios comerciales",t),`Error al obtener los usuarios comerciales: ${t}`}},pt=()=>{const{tasks_api:e}=ge(),t=de.useQuery({queryKey:["users-mt"],queryFn:()=>Pr({tasks_api:e}),staleTime:1e3*60*60*24});return{isLoading:t.isLoading,users:t.data}},Ar=(e,t,n)=>{var r;const s=(r=e==null?void 0:e.email)==null?void 0:r.trim();if(s){const l=t(s);return l||s}const o=e==null?void 0:e.id,i=o!==""&&o!=null&&!Number.isNaN(Number(o))?Number(o):NaN;if(!Number.isNaN(i)&&(n!=null&&n.length)){const l=n.find(d=>d.id===i);if(l!=null&&l.name)return l.name}return""},Ir=({responsible:e})=>{const{isLoading:t,users:n}=pt(),{getImageByEmail:s,getNameByEmail:o,isLoading:i}=Ht();if(t||i)return null;const r=Ar(e,o,n),l=a.jsx(g.Avatar,{size:"xs",src:s((e==null?void 0:e.email)??""),type:"people"});return a.jsxs("div",{className:"tw-flex tw-flex-col tw-items-center tw-justify-end",children:[r?a.jsx(g.Tooltip,{label:r,children:l}):l,a.jsx("p",{className:"ui-text-body-xs-regular ui-text-tertiary ui-font-body-xs-normal",children:"Responsable"})]})},Dr=[{label:"Muy alta",value:4,icon:me.faFlag,iconColor:"red"},{label:"Alta",value:3,icon:me.faFlag,iconColor:"yellow"},{label:"Media",value:2,icon:me.faFlag,iconColor:"blue"},{label:"Baja",value:1,icon:me.faFlag,iconColor:"neutral"}],Fr=[{label:"Muy alta",value:4,icon:me.faRhombus,iconColor:"red"},{label:"Alta",value:3,icon:me.faRhombus,iconColor:"yellow"},{label:"Media",value:2,icon:me.faRhombus,iconColor:"blue"},{label:"Baja",value:1,icon:me.faRhombus,iconColor:"neutral"}],Mr=[{label:"1 día",value:1},{label:"2 días",value:2},{label:"3 días",value:3},{label:"4 días",value:4},{label:"5 días",value:5}],gs=({isOpen:e,onClose:t,onSuccess:n,nodeDataType:s,parentNodeInfo:o,editMode:i=!1,taskToEdit:r})=>{const{data:l}=Ia(),{users:d}=pt(),{users:c}=Ze(),{getImageOBP:m}=ge(),f=u.useMemo(()=>{try{return!d||!c?[]:d.map(C=>{const I=c[C.email],T=I!=null&&I.image?m(I.image):"";return{label:C.name,value:C.id.toString(),icon:T}})}catch(C){return console.error("Error mapeando usuarios:",C),[]}},[d,c]),x=()=>{if(i&&r){const C=z=>{if(z==null)return"";const ee=Number(z);return isNaN(ee)?"":ee},I=z=>z?typeof z=="string"?Number(z)||"":z.id||"":"",T=z=>{var ee;return z?typeof z=="string"?z:((ee=z.id)==null?void 0:ee.toString())||z.name||z.nombre||"":""};return{title:r.texto_corto||"",description:r.texto_largo||"",priority:C(r.prioridad),difficulty:C(r.nivel_dificultad),duration:C(r.duracion),team:I(r.equipo),responsible:T(r.responsable),type:"tarea"}}return{title:"",description:"",priority:"",difficulty:"",duration:"",team:"",responsible:"",type:"tarea"}},{control:p,handleSubmit:h,formState:{errors:y,isValid:w},reset:j,watch:b}=Ee.useForm({mode:"onChange",defaultValues:x()});u.useEffect(()=>{e&&j(x())},[e,i,r,j]);const v=b(),M=w&&v.title&&v.description&&v.priority&&v.difficulty&&v.duration&&v.team&&Object.keys(y).length===0,F=async C=>{try{if(["title","description","priority","difficulty","duration","team"].filter(V=>!C[V]).length>0)return;n&&await n({...C,parent:o}),i||j()}catch{}},R=()=>{j(),t()};return a.jsx(g.Drawer,{titleIcon:me.faPencil,isOpen:e,onClose:R,onSuccess:()=>{h(C=>{F(C)},C=>{const I=Object.entries(C).map(([T,V])=>`${T}: ${V.message}`).join(`
|
|
9
9
|
`);console.log(`📝 Por favor, completa los siguientes campos:
|
|
10
|
-
`+D)})()},title:i?"Editar tarea":"Nueva tarea",successButtonText:i?"Actualizar":"Crear",disabledSuccessButton:!M,children:t.jsxs("form",{className:"tm-flex tm-flex-col tm-gap-4",children:[t.jsx(Se.Controller,{control:f,name:"title",rules:{required:"El título es obligatorio",minLength:{value:3,message:"El título debe tener al menos 3 caracteres"}},render:({field:N})=>{var D;return t.jsx(x.Input,{fullWidth:!0,label:"Título",placeholder:"Ingresa el título de la tarea...",error:(D=y.title)==null?void 0:D.message,...N})}}),t.jsx(Se.Controller,{control:f,name:"description",rules:{required:"La descripción es obligatoria",minLength:{value:10,message:"La descripción debe tener al menos 10 caracteres"}},render:({field:N})=>{var D;return t.jsx(x.Textarea,{className:"tm-w-full tm-w-full",placeholder:"Describe la tarea a realizar...",label:"Descripción",error:(D=y.description)==null?void 0:D.message,...N})}}),t.jsx(x.Separator,{}),t.jsx(Se.Controller,{control:f,name:"priority",rules:{required:"La prioridad es obligatoria"},render:({field:N,fieldState:{error:D}})=>t.jsx(x.Dropdown,{fullWidth:!0,label:"Prioridad",placeholder:"Selecciona la prioridad...",options:Tr,error:D==null?void 0:D.message,value:N.value,onValueChange:v=>{N.onChange(v)}})}),t.jsx(Se.Controller,{control:f,name:"difficulty",rules:{required:"La dificultad es obligatoria"},render:({field:N,fieldState:{error:D}})=>t.jsx(x.Dropdown,{fullWidth:!0,label:"Dificultad",placeholder:"Selecciona la dificultad...",options:Cr,error:D==null?void 0:D.message,value:N.value,onValueChange:v=>{N.onChange(v)}})}),t.jsx(Se.Controller,{control:f,name:"duration",rules:{required:"La duración es obligatoria"},render:({field:N,fieldState:{error:D}})=>t.jsx(x.Dropdown,{fullWidth:!0,label:"Duración",placeholder:"Selecciona la duración...",options:Nr,error:D==null?void 0:D.message,value:N.value,onValueChange:v=>{N.onChange(v)}})}),t.jsx(x.Separator,{}),t.jsx(Se.Controller,{control:f,name:"team",rules:{required:"El equipo es obligatorio"},render:({field:N,fieldState:{error:D}})=>t.jsx(x.Dropdown,{fullWidth:!0,label:"Equipo",placeholder:"Selecciona el equipo...",options:c,error:D==null?void 0:D.message,value:N.value,onValueChange:v=>{N.onChange(v)}})}),t.jsx(Se.Controller,{control:f,name:"responsible",render:({field:N,fieldState:{error:D}})=>t.jsx(x.Dropdown,{fullWidth:!0,absolute:!0,label:"Responsable",placeholder:"Selecciona el responsable...",options:p,error:D==null?void 0:D.message,value:N.value,onValueChange:v=>{N.onChange(v)}})})]})})},Sr=()=>{const{get:e}=Be(),a=Le(i=>i.activeTemplate),{updateTaskInState:n,addTaskToState:s}=nt();return{updateTaskInTemplate:async(i,r)=>{if(!a)return console.error("No hay plantilla activa"),!1;try{const c=await e(a.id);if(!c)return console.error("Flujo de trabajo no encontrado"),!1;const m={id:i,uuid:r.uuid||crypto.randomUUID(),reference_graph:r.reference_graph||null,texto_corto:r.texto_corto||"",texto_largo:r.texto_largo||"",prioridad:r.prioridad||null,nivel_dificultad:r.nivel_dificultad||1,duracion:r.duracion||null,start:r.start||!1,equipo:r.equipo||null,responsable:r.responsable||null,plantilla:{id:c.id,clave:c.clave,categoria:c.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:r.plantilla_dependents||[],id_t_requerida:r.id_t_requerida||null,ids_t_dependientes:r.ids_t_dependientes||[],tarea_padre:r.tarea_padre||null,tareas:r.tareas||[]};i>0?await n({task:m}):await s({task:m})}catch(c){return console.error("❌ Error al actualizar tarea en plantilla:",c),!1}}}},_e={DEFAULT_CHILD_WIDTH:260,DEFAULT_CHILD_HEIGHT:80,MAGNETIC_CONNECTION_DISTANCE:800,GRAPH_LAYOUT_UPDATE_DELAY:100,START_NODE_ID:"start",DEFAULT_SOURCE_HANDLE:"bottom-source",DEFAULT_TARGET_HANDLE:"top-target"},ba={dependiente:{stroke:"#3B82F6",strokeDasharray:"5,5",strokeWidth:2},normal:{stroke:"#6B7280",strokeWidth:2}},jt=e=>{const a=e.map(n=>({...n}));return a.filter(n=>n.type==="group").forEach(n=>{const s=a.filter(d=>d.parentId===n.id);if(s.length===0)return;const o=Math.min(...s.map(d=>d.position.x)),r=Math.max(...s.map(d=>{var p;return d.position.x+(typeof((p=d.style)==null?void 0:p.width)=="number"?d.style.width:_e.DEFAULT_CHILD_WIDTH)}))-o,c=Math.min(...s.map(d=>d.position.y)),l=Math.max(...s.map(d=>{var p;return d.position.y+(typeof((p=d.style)==null?void 0:p.height)=="number"?d.style.height:_e.DEFAULT_CHILD_HEIGHT)}))-c;n.style={...n.style??{},width:r,height:l}}),a},wt=e=>e.source===_e.START_NODE_ID||e.target===_e.START_NODE_ID,Xe=e=>e===_e.START_NODE_ID,Er=e=>e==="dependiente"?ba.dependiente:ba.normal,Pr=(e,a,n)=>({id:e,type:"main",position:a,selected:!1,deletable:!0,data:n}),vt=(e,a,n,s,o,i=!1,r=null,c=null)=>{const m=Er(s),l=i?_e.DEFAULT_SOURCE_HANDLE:n;return{id:`edge-${e}-${a}`,source:e,sourceHandle:l,target:a,targetHandle:_e.DEFAULT_TARGET_HANDLE,type:"smoothstep",deletable:!0,style:m,markerEnd:{type:"arrowclosed",width:12,height:12,color:m.stroke,strokeWidth:1},data:{connectionType:s,nodeType:o,isFromStartNode:i,parentId:r,childId:c}}},Ar=(e,a)=>!(!e||!a||e===a),Ir=e=>{const{clientX:a,clientY:n}="changedTouches"in e?e.changedTouches[0]:e;return{x:a,y:n}},Dr=e=>e.filter(a=>a.type==="position"&&a.dragging===!1),gs=e=>e.map(a=>a.id),hs=({nodes:e,edges:a,setNodes:n,setEdges:s,newNodePopup:o,connectionPopup:i,closeNewNodePopup:r,closeConnectionPopup:c,setIsConnectingExistingNodes:m})=>{const{screenToFlowPosition:l,getNode:d,setViewport:p,fitView:h}=oe.useReactFlow(),{get:f,update:g,addTaskUpdatingTemplate:y,addTemplateUpdatingTemplate:w}=Be(),j=Le(H=>H.activeTemplate),b=me.useQueryClient(),_=Le(H=>H.setActiveTemplate),{removeTaskFromState:M,updateNodeWithNewEdge:F,updateTaskInState:R}=nt(),N=u.useCallback(async H=>{const O=e.find(B=>B.id===H);if(!(O!=null&&O.data))return null;if(O.id===_e.START_NODE_ID){if(!j)return null;try{const B=await f(j.id),k=B.tarea_plantillas.find(q=>q.start===!0);return k!=null&&k.id?k.id:B.tarea_plantillas.length>0?B.tarea_plantillas[0].id:null}catch{return null}}const S=O.data.id;if(!S&&S!==0)return null;if(typeof S=="string"){if(S.includes("-"))return S;{const B=parseInt(S,10);return isNaN(B)?null:B}}else if(typeof S=="number")return S;return null},[e,j,f]),D=u.useCallback(async(H=e,O=a)=>{var S,B,k,q,ee,W,re;if(!j){x.toast.warning("No hay template activo para actualizar layout");return}try{const Z=await f(j.id);if(!Z){x.toast.warning("Template no encontrado en IndexedDB");return}const E=(S=Z.graph_layout)==null?void 0:S.snapshot;if(!(!E||JSON.stringify(E.nodes)!==JSON.stringify(H)||JSON.stringify(E.edges)!==JSON.stringify(O))){console.log("🔄 No hay cambios en el layout, omitiendo actualización");return}const Q=H.filter(G=>{var P;return!((P=G.data)!=null&&P.isInternal)&&!G.parentId}).map(G=>{const{style:P,measured:C,data:$,selected:L,...T}=G,{expandedDimensions:V,isExpanded:Y,needsReExpansion:ae,...le}=$||{},X=P?{...P,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...T,style:X,data:le}}),I=O.filter(G=>{var P;return!((P=G.data)!=null&&P.isInternal)}),A={...Z,graph_layout:{id:((B=Z.graph_layout)==null?void 0:B.id)||0,snapshot:{nodes:Q,edges:I,viewport:((q=(k=Z.graph_layout)==null?void 0:k.snapshot)==null?void 0:q.viewport)||{x:0,y:0,zoom:1}},history:((ee=Z.graph_layout)==null?void 0:ee.history)||[],zoom:((W=Z.graph_layout)==null?void 0:W.zoom)||1,position:((re=Z.graph_layout)==null?void 0:re.position)||{x:0,y:0}},estatus:ve.DIRTY,updatedAt:new Date().toISOString()};await g(j.id,A),console.log("🗑️ [useFlowActions] Invalidando caché de la plantilla:",j.id),await b.invalidateQueries({queryKey:["template",j.id]}),await b.invalidateQueries({queryKey:["template"]}),console.log("✅ [useFlowActions] Caché invalidado exitosamente"),_(A)}catch(Z){console.error("❌ Error al actualizar template layout:",Z)}},[j,f,g,e,a,_]),v=u.useCallback(async(H=[],O=[],S,B)=>{var q,ee,W,re,Z,E,z,Q,I,A,G,P;const k=S||(j==null?void 0:j.id);if(!k){x.toast.warning("No hay template ID disponible para actualizar");return}try{const C=await f(k);if(!C)return;const $=(W=(ee=(q=C.graph_layout)==null?void 0:q.snapshot)==null?void 0:ee.nodes)==null?void 0:W.filter(V=>{var Y;return!H.includes(V.id)&&!((Y=V.data)!=null&&Y.isInternal)&&!V.parentId}).map(V=>{const{style:Y,measured:ae,data:le,...X}=V,{expandedDimensions:se,...ce}=le||{},ie=Y?{...Y,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...X,style:ie,data:ce}}),L=((E=(Z=(re=C.graph_layout)==null?void 0:re.snapshot)==null?void 0:Z.edges)==null?void 0:E.filter(V=>{var Y;return!H.includes(V.source)&&!H.includes(V.target)&&!((Y=V.data)!=null&&Y.isInternal)}))||[],T={...C,graph_layout:{id:((z=C.graph_layout)==null?void 0:z.id)||0,snapshot:{nodes:$,edges:L,viewport:((I=(Q=C.graph_layout)==null?void 0:Q.snapshot)==null?void 0:I.viewport)||{x:0,y:0,zoom:1}},history:((A=C.graph_layout)==null?void 0:A.history)||[],zoom:((G=C.graph_layout)==null?void 0:G.zoom)||1,position:((P=C.graph_layout)==null?void 0:P.position)||{x:0,y:0}},estatus:ve.DIRTY,updatedAt:new Date().toISOString()};await M({templateId:k,id:B||0}),await g(k,T),await b.invalidateQueries({queryKey:["template",k]}),await b.invalidateQueries({queryKey:["template"]}),k===(j==null?void 0:j.id)&&_(T)}catch(C){console.error("❌ updateAfterDeleted - Error al actualizar template layout:",C)}},[j,f,g,a,e,M,_]),U=u.useCallback(async(H,O,S)=>{if(!o||!j)return;const{nodeId:B,sourceNodeId:k,sourceHandleId:q}=o;if(k)try{const ee=await N(k);if(!ee)return;if(H==="plantilla"){const W=S;if(!(W!=null&&W.templateId))return;if(!await w(W.templateId,j.id,ee,O)){x.toast.error("No se pudo agregar la plantilla. Intenta nuevamente."),r();return}try{const G=await f(j.id);if(G){const P=($,L)=>{for(const T of $){if(T.id===L||T.uuid===L)return T;if(T.tareas&&T.tareas.length>0){const V=P(T.tareas,L);if(V)return V}}return null},C=P(G.tarea_plantillas,ee);if(C&&C.id){const $=(C.plantilla_dependents||[]).map(T=>typeof T=="object"&&T.id?{id:T.id}:typeof T=="number"?{id:T}:T),L={...C,plantilla_dependents:$,plantilla:{id:j.id,clave:G.clave,categoria:G.categoria||{id:0,nombre:"Sin categoría"}}};await R({task:L}),console.log("✅ Tarea padre agregada a templates_states.updated con plantilla_dependents:",C.id,L.plantilla_dependents)}}}catch(G){console.error("❌ Error al actualizar tarea padre en templates_states:",G)}const Z=l({x:o.position.x,y:o.position.y}),E=W.templateData||{id:W.templateId,nombre_plantilla:`Flujo de trabajo ${W.templateId}`,clave:`TPL-${W.templateId}`,estatus:"activo",categoria:null,counts_tasks:0,dias_duracion:0},z={id:B,type:"group",position:Z,selected:!1,deletable:!0,data:{id:W.templateId,templateId:W.templateId,type:"template",nombre_plantilla:E.nombre_plantilla||`Flujo de trabajo ${W.templateId}`,clave:E.clave||`TPL-${W.templateId}`,estatus:E.estatus||"activo",categoria:E.categoria||null,counts_tasks:E.counts_tasks||0,dias_duracion:E.dias_duracion||0,tarea_plantillas:E.tarea_plantillas||[],params_plantillas:E.params_plantillas||[],createdAt:E.createdAt||new Date().toISOString(),updatedAt:E.updatedAt||new Date().toISOString(),created_by:E.created_by||null,updated_by:E.updated_by||null}};n(G=>[...G,z]);const Q=q||_e.DEFAULT_SOURCE_HANDLE,I=Xe(k),A=vt(k,B,Q,O,"plantilla",I,ee);s(G=>[...G,A]);try{const G=[...e,z],P=[...a,A];await D(G,P)}catch(G){console.error("❌ Error al actualizar layout después de agregar plantilla:",G)}}else if(H==="tarea"){const W=S;if(!W)return;const re=l({x:o.position.x,y:o.position.y}),Z=-new Date().getTime(),E={id:Z,reference_graph:B,title:W.title,description:W.description,priority:W.priority,difficulty:W.difficulty,duration:W.duration,team:W.team,responsible:W.responsible,parent:{data:{id:ee}}},z=await y(E,j.id,O),Q=Pr(B,re,z);n(P=>[...P,Q]);const I=q||_e.DEFAULT_SOURCE_HANDLE,A=Xe(k),G=vt(k,B,I,O,H,A,ee,Z);s(P=>[...P,G]);try{const P=[...e,Q],C=[...a,G];await D(P,C)}catch(P){console.error("❌ Error al actualizar layout después de agregar tarea:",P)}setTimeout(()=>{try{const P=d(B);if(P){const C=window.innerWidth,$=window.innerHeight,L=C/2,T=$/2;p({x:L-P.position.x-130,y:T-P.position.y-40,zoom:1},{duration:800})}else h({padding:.1,duration:800})}catch{try{h({padding:.1,duration:800})}catch{}}},200)}r()}catch(ee){console.error("❌ Error en createNodeFromPopup:",ee)}},[o,j,y,w,N,l,n,s,r,D,e,a]),K=u.useCallback(async(H,O)=>{var q,ee;if(console.log("🟢 createConnectionFromPopup - INICIO",{nodeType:H,connectionType:O}),!i){console.warn("⚠️ createConnectionFromPopup - No hay connectionPopup");return}const{sourceNodeId:S,sourceHandleId:B,targetNodeId:k}=i;console.log("🟢 createConnectionFromPopup - Datos de conexión:",{sourceNodeId:S,targetNodeId:k,sourceHandleId:B});try{if(!(window.validConnectionTypes||{dependiente:!0,hija:!0})[O]){console.warn("⚠️ createConnectionFromPopup - Tipo de conexión no válido:",O),x.toast.warning("Tipo de conexión no válido"),m(!1),c();return}const re=e.find(L=>L.id===S),Z=e.find(L=>L.id===k);console.log("🟢 createConnectionFromPopup - Nodos encontrados:",{sourceNode:re==null?void 0:re.id,targetNode:Z==null?void 0:Z.id,sourceData:re==null?void 0:re.data,targetData:Z==null?void 0:Z.data});const E=Z==null?void 0:Z.data,z=((q=re==null?void 0:re.data)==null?void 0:q.id)||S,Q=((ee=Z==null?void 0:Z.data)==null?void 0:ee.id)||k;console.log("🟢 createConnectionFromPopup - IDs extraídos:",{parentId:z,childId:Q});const I=vt(S,k,B||_e.DEFAULT_SOURCE_HANDLE,O,H,Xe(S),z,Q);console.log("🟢 createConnectionFromPopup - Nuevo edge creado:",I),s(L=>[...L,I]);const A=[...a,I],G=E.id||-Date.now(),P=E.reference_graph||k,C={id:G,uuid:E.uuid||crypto.randomUUID(),reference_graph:P,texto_corto:E.texto_corto||"",texto_largo:E.texto_largo||"",prioridad:E.prioridad||null,nivel_dificultad:E.nivel_dificultad||1,duracion:E.duracion||null,start:E.start||!1,equipo:E.equipo||null,responsable:E.responsable||null,plantilla:{id:E.plantilla.id,clave:E.plantilla.clave,categoria:E.plantilla.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:E.plantilla_dependents||[],ids_t_dependientes:E.ids_t_dependientes||[],tarea_padre:O==="hija"?{id:I.data.parentId}:null,id_t_requerida:O==="dependiente"?{id:I.data.parentId}:null,tareas:E.tareas||[],type:"task"};console.log("🟢 createConnectionFromPopup - taskForState creado:",C),console.log("🟢 createConnectionFromPopup - currentTemplate.id:",j.id);const $=e.map(L=>L.id===k?{...L,data:C}:L);console.log("🟢 createConnectionFromPopup - Actualizando nodos en React Flow..."),n($),console.log("✅ createConnectionFromPopup - Nodos actualizados en React Flow"),console.log("🟢 createConnectionFromPopup - Actualizando template layout..."),await D($,A),console.log("✅ createConnectionFromPopup - Template layout actualizado"),console.log("🟢 createConnectionFromPopup - Llamando a updateNodeWithNewEdge..."),await F({templateId:j.id,edge:I,task:C}),console.log("✅ createConnectionFromPopup - updateNodeWithNewEdge completado")}catch(W){console.error("❌ createConnectionFromPopup - Error al crear conexión:",W),console.error("❌ createConnectionFromPopup - Stack:",W.stack)}finally{console.log("🟢 createConnectionFromPopup - Limpiando estado..."),m(!1),c(),console.log("🟢 createConnectionFromPopup - FIN")}},[i,s,m,c,a,e,D]),J=u.useCallback(async H=>{if(!o||!j){x.toast.warning("No hay newNodePopup o template activo para actualizar el nodo");return}const{nodeId:O}=o;if(!O){x.toast.warning("No se encontró nodeId en newNodePopup");return}try{const S=e.find(k=>k.id===O);if(!S){x.toast.warning(`No se encontró el nodo con ID: ${O}`);return}const B={...S,data:{...S.data,...H,id:S.data.id||S.id,type:S.data.type||S.data.type,updatedAt:new Date().toISOString()}};n(k=>k.map(q=>q.id===O?B:q));try{const k=e.map(q=>q.id===O?B:q);await D(k,a)}catch(k){x.toast.error("Error al actualizar layout después de actualizar nodo:",k)}r()}catch(S){x.toast.error("Error al actualizar el nodo:",S)}},[o,j,e,n,a,D,r]);return{createNodeFromPopup:U,createConnectionFromPopup:K,updateNodeFromPopup:J,updateAfterDeleted:v}},Fr=({data:e,id:a,isConnectable:n,selected:s})=>{const o=Te(v=>v.getViewMode),[i,r]=u.useState(!1),[c,m]=u.useState(e),l=Le(v=>v.activeTemplate),d=Le(v=>v.setActiveTemplate),{get:p,update:h}=Be(),f=l!=null&&l.id?o(l.id):"readonly",{updateTaskInTemplate:g}=Sr(),{setNodes:y,setEdges:w,getNodes:j,getEdges:b}=oe.useReactFlow(),_=me.useQueryClient(),{updateAfterDeleted:M}=hs({nodes:j(),edges:b(),setNodes:y,setEdges:w,newNodePopup:null,connectionPopup:null,closeNewNodePopup:()=>{},closeConnectionPopup:()=>{},setIsConnectingExistingNodes:()=>{}}),F=()=>{r(!0)},R=u.useCallback(async()=>{var O,S,B;const v=j().find(k=>k.id===a);if(!v){console.warn("⚠️ Nodo no encontrado para eliminar");return}const U=[v],K=gs(U),J=U.length>0?(S=(O=U[0])==null?void 0:O.data)==null?void 0:S.id:0;w(k=>k.filter(q=>!K.includes(q.source)&&!K.includes(q.target))),y(k=>k.filter(q=>q.id!==a));let H;for(const k of U)try{const q=k.data;if((B=q==null?void 0:q.plantilla)!=null&&B.id){H=q.plantilla.id;break}}catch{}try{w(k=>((async()=>{await M(K,k,H,J)})().catch(q=>{console.error("❌ Error en updateAfterDeleted:",q)}),k))}catch(k){console.error("❌ Error en handleDeleteNode:",k)}},[a,j,b,y,w,M]),N=u.useCallback(async v=>{var U,K,J,H,O,S,B,k,q,ee;if(!l){console.warn("⚠️ MainNode.updateTemplateLayout - No hay template activo");return}try{const W=await p(l.id);if(!W){console.warn("⚠️ MainNode.updateTemplateLayout - Template no encontrado en IndexedDB");return}const re=(U=W.graph_layout)==null?void 0:U.snapshot;if(!(!re||JSON.stringify(re.nodes)!==JSON.stringify(v))){console.log("🔄 MainNode.updateTemplateLayout - No hay cambios en nodos, omitiendo actualización");return}const E=v.filter(I=>{var A;return!((A=I.data)!=null&&A.isInternal)&&!I.parentId}).map(I=>{const{style:A,measured:G,data:P,selected:C,...$}=I,{expandedDimensions:L,isExpanded:T,needsReExpansion:V,...Y}=P||{},ae=A?{...A,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...$,style:ae,data:Y}}),z=(((J=(K=W.graph_layout)==null?void 0:K.snapshot)==null?void 0:J.edges)||[]).filter(I=>{var A;return!((A=I.data)!=null&&A.isInternal)}),Q={...W,graph_layout:{id:((H=W.graph_layout)==null?void 0:H.id)||0,snapshot:{...(O=W.graph_layout)==null?void 0:O.snapshot,nodes:E,edges:z,viewport:((B=(S=W.graph_layout)==null?void 0:S.snapshot)==null?void 0:B.viewport)||{x:0,y:0,zoom:1}},history:((k=W.graph_layout)==null?void 0:k.history)||[],zoom:((q=W.graph_layout)==null?void 0:q.zoom)||1,position:((ee=W.graph_layout)==null?void 0:ee.position)||{x:0,y:0}},estatus:ve.DIRTY,updatedAt:new Date().toISOString()};await h(l.id,Q),await _.invalidateQueries({queryKey:["template",l.id]}),await _.invalidateQueries({queryKey:["template"]}),l&&l.id===Q.id&&d(Q)}catch(W){console.error("❌ MainNode.updateTemplateLayout - Error al actualizar template layout:",W)}},[l,p,h,d,_]),D=async v=>{if(r(!1),l){const U={...e,texto_corto:v.title,texto_largo:v.description,prioridad:v.priority?typeof v.priority=="number"?v.priority:parseInt(v.priority.toString()):null,nivel_dificultad:v.difficulty?typeof v.difficulty=="number"?v.difficulty:parseInt(v.difficulty.toString()):1,duracion:v.duration?typeof v.duration=="number"?v.duration:parseInt(v.duration.toString()):null,equipo:{id:Number(v.team)||null},responsable:{id:Number(v.responsible)||null}};await g(e.id,U),y(K=>{const J=K.map(H=>H.id===a?{...H,data:{...H.data,...U,tarea_padre:e.tarea_padre,id_t_requerida:e.id_t_requerida,updatedAt:new Date().toISOString()}}:H);return console.log("🔄 updatedNodes:",J),setTimeout(()=>N(J),0),J})}};return u.useEffect(()=>{m(e)},[e]),t.jsxs("div",{className:`tm-border-[1px] tm-bg-white tm-px-4 tm-py-2 tm-rounded-lg tm-transition-all tm-duration-200 tm-max-w-[423px] ${s?"tm-border-brand tm-shadow-lg tm-ring-2 tm-ring-blue-300 tm-ring-opacity-50":e.main?"tm-border-success tm-shadow-sm":"tm-border-default tm-shadow-sm"}`,children:[t.jsx(oe.Handle,{isConnectable:n,id:"top-target",type:"target",position:oe.Position.Top,className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white"}),t.jsx(oe.Handle,{isConnectable:n,id:"right-target",type:"target",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Right}),t.jsx(oe.Handle,{isConnectable:n,id:"bottom-target",type:"target",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Bottom}),t.jsx(oe.Handle,{isConnectable:n,id:"left-target",type:"target",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Left}),t.jsxs("div",{className:"tm-flex tm-h-full tm-flex-col tm-gap-y-8 tm-p-12 ",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-gap-x-4 ",children:[t.jsx("p",{className:"tm-text-primary tm-font-bold tm-leading-none tm-text-body-lg-regular tm-truncate",children:c.texto_corto}),!e.isInternal&&l.estatusFromStrapi!==Ee.PUBLISHED&&f!=="readonly"&&t.jsx("div",{children:e.type==="task"?t.jsx(x.Popup,{position:"right",absolute:!0,size:"xxs",pill:"pill",color:"secondary",icon:de.faEllipsis,containerClassName:"nopan nodrag",buttonClassName:"nopan nodrag",children:t.jsxs(x.List,{className:"tm-p-8 tm-gap-4",children:[t.jsx(x.ListItem,{icon:de.faEdit,onClick:F,children:"Editar"}),t.jsx(x.ListItem,{icon:de.faPlus,color:"red",onClick:R,children:"Eliminar"})]})}):t.jsx(x.Button,{size:"xxs",color:"secondary",pill:"pill",icon:de.faMaximize,className:"nopan"})})]}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-sm-normal ",children:c.texto_largo}),t.jsxs("div",{className:"tm-flex tm-gap-x-6 tm-justify-between",children:[t.jsx(br,{duration:c.duracion}),t.jsx(xr,{difficulty:c.nivel_dificultad}),t.jsx(jr,{priority:c.prioridad}),t.jsx(_r,{responsible:c.responsable})]})]}),t.jsx(oe.Handle,{isConnectable:n,id:"top-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Top}),t.jsx(oe.Handle,{isConnectable:n,id:"right-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Right}),t.jsx(oe.Handle,{isConnectable:n,id:"bottom-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Bottom}),t.jsx(oe.Handle,{isConnectable:n,id:"left-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white",position:oe.Position.Left}),e.type==="task"&&i&&t.jsx(fs,{isOpen:i,onClose:()=>r(!1),onSuccess:D,editMode:!0,taskToEdit:c})]})},Mr=async({tasks_api:e,page:a=1,pageSize:n=10,search:s="",filters:o={}})=>{const i={clave:{$notNull:!0},estatus:{$ne:Ee.DELETED},...s?{$or:[{nombre_plantilla:{$containsi:s}},{clave:{$containsi:s}}]}:{},...Object.keys(o).reduce((m,l)=>(Array.isArray(o[l])?m[l]={id:{$in:o[l]}}:m[l]=o[l],m),{})},r=Pe.stringify({filters:i,fields:["id","clave","estatus","dias_duracion","createdAt","publication_date"],count_tasks:!0,tarea_plantillas:!1,populate:{updated_by:{fields:["id","nombre","username","email"]},created_by:{fields:["id","nombre","username","email"]},params_plantillas:{fields:["id","name"],populate:{params_tipo:{fields:["id","key","label","order"]}}},tarea_plantillas:{fields:["id"],filters:{start:!0},populate:{tareas:{fields:["id"]},ids_t_dependientes:{fields:["id"]}}}},sort:{createdAt:"asc"},pagination:{page:a,pageSize:n}},{encodeValuesOnly:!0}),c=await e.get(`/api/plantillas/all-plantillas?${r}`);return c.data?{data:be(c.data.data),meta:c.data.meta}:{data:[],meta:{pagination:{page:a,pageSize:n,pageCount:0,total:0}}}},xs=({page:e=1,pageSize:a=10,search:n="",filters:s={}})=>{const{tasks_api:o}=he();return me.useQuery({queryKey:["templates",e,a,n,s],queryFn:()=>Mr({tasks_api:o,page:e,pageSize:a,search:n,filters:s}),staleTime:1e3*60*60*24,placeholderData:me.keepPreviousData,select:i=>({data:(i==null?void 0:i.data)||[],meta:i==null?void 0:i.meta})})},bs=({isOpen:e,onClose:a,onSuccess:n,nodeDataType:s,parentNodeInfo:o})=>{var _,M,F,R;const i=Te(N=>N.addNodeWithType),[r,c]=u.useState(0),m=5,[l,d]=u.useState(1),[p,h]=u.useState("");u.useEffect(()=>{e&&(d(1),h(""),c(0))},[e]),u.useEffect(()=>{d(1)},[p]);const{data:f,isLoading:g}=xs({page:l,pageSize:m,search:p}),y=N=>{h(N.target.value)},w=()=>{var D;if(r===0)return;const N=(D=f==null?void 0:f.data)==null?void 0:D.find(v=>v.id===r);if(!N){console.error("No se encontró el flujo de trabajo seleccionado en los datos");return}n?n({templateId:r,templateData:N}):i&&i(s.id,s.type,s.connectionType)};if(g)return t.jsx("div",{children:"Cargando..."});if(!(f!=null&&f.data))return t.jsx("div",{children:"No hay datos disponibles"});const j=((M=(_=f.meta)==null?void 0:_.pagination)==null?void 0:M.total)||0,b=j===1?"flujo encontrado":"flujos encontrados";return t.jsx(x.Modal,{iconConfig:{icon:Ce.faPencil},isOpen:e,size:"lg",onSuccess:w,onClose:a,title:"Agregar flujo de trabajo",successButtonText:"Agregar",disableSuccessButton:r===0,closeAtSuccess:!0,children:t.jsxs(x.Modal.Body,{withPadding:!1,children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-gap-6 tm-px-12 tm-py-3",children:[t.jsxs("p",{className:"tm-flex-1 tm-text-[14px] tm-text-neutral-500",children:[j," ",b]}),t.jsx(x.Input,{className:"tm-flex-1",leftSlot:Ce.faSearch,fullWidth:!0,placeholder:"Buscar por nombre, parámetros o estado...",value:p,onChange:y})]}),t.jsx(x.Separator,{}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-6 tm-p-12",children:[f.data.map(N=>t.jsx(ps,{mode:"modal",template:N,active:r===N.id,fullWidth:!0,onClick:c,withOptions:!1},N.id)),f.data.length===0&&t.jsx("div",{className:"tm-flex tm-items-center tm-justify-center tm-h-full",children:t.jsx("p",{className:"tm-text-[14px] tm-text-neutral-500",children:"No se encontraron flujos de trabajo con ese criterio de búsqueda"})})]}),t.jsx(x.Separator,{}),t.jsx("div",{className:"tm-mt-6",children:t.jsx(x.Pagination,{className:"tm-pt-0",pageSize:m,pageCount:((R=(F=f==null?void 0:f.meta)==null?void 0:F.pagination)==null?void 0:R.pageCount)||1,currentPage:l,onPageChange:N=>d(N)})})]})})},kr=({data:e,id:a})=>{const n=Te(d=>d.addNodeWithType),[s,o]=u.useState(!1),[i,r]=u.useState(!1),[c,m]=u.useState({id:a,type:"tarea",connectionType:"dependiente"}),l=({type:d,connectionType:p})=>{n&&(m({id:a,type:d,connectionType:p}),d==="tarea"?o(!0):d==="plantilla"&&r(!0))};return console.log({data:e,id:a}),t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-center",children:[c.type==="plantilla"&&t.jsx(bs,{isOpen:i,onClose:()=>r(!1),nodeDataType:c}),t.jsx(oe.Handle,{id:"top-target",type:"target",position:oe.Position.Top}),t.jsx(oe.Handle,{id:"right-target",type:"target",position:oe.Position.Right}),t.jsx(oe.Handle,{id:"bottom-target",type:"target",position:oe.Position.Bottom}),t.jsx(oe.Handle,{id:"left-target",type:"target",position:oe.Position.Left}),t.jsx(oe.Handle,{id:"top-source",type:"source",position:oe.Position.Top}),t.jsx(oe.Handle,{id:"right-source",type:"source",position:oe.Position.Right}),t.jsx(oe.Handle,{id:"bottom-source",type:"source",position:oe.Position.Bottom}),t.jsx(oe.Handle,{id:"left-source",type:"source",position:oe.Position.Left}),t.jsx(x.Popup,{position:"right",absolute:!0,size:"md",rounded:!0,icon:de.faPlus,containerClassName:"nopan",buttonClassName:"nopan",children:t.jsxs(x.List,{className:"nopan nodrag",children:[t.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Tarea"}),t.jsx(x.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>l({type:"tarea",connectionType:"dependiente"}),children:"Dependiente"}),t.jsx(x.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>l({type:"tarea",connectionType:"hija"}),children:"Hija"}),t.jsx(x.ListSeparator,{}),t.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Flujo de trabajo"}),t.jsx(x.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>l({type:"plantilla",connectionType:"dependiente"}),children:"Dependiente"}),t.jsx(x.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>l({type:"plantilla",connectionType:"hija"}),children:"Hija"})]})})]})},Or=({isOpen:e,position:a,onClose:n,createNodeFromPopup:s,parentNodeInfo:o})=>{const[i,r]=u.useState(!1),[c,m]=u.useState(!1),[l,d]=u.useState(null);if(!e)return null;const p=(w,j)=>{d({type:w,connectionType:j}),w==="tarea"?r(!0):w==="plantilla"&&m(!0)},h=()=>{r(!1),d(null),n()},f=()=>{m(!1),d(null),n()},g=w=>{l&&s(l.type,l.connectionType,w),h()},y=w=>{l&&w&&s(l.type,l.connectionType,w),f()};return t.jsxs(t.Fragment,{children:[!i&&!c&&t.jsx("div",{className:"tm-fixed tm-inset-0 tm-z-50",onClick:n}),!i&&!c&&t.jsx("div",{className:"tm-fixed tm-z-50 tm-bg-white tm-rounded-lg tm-shadow-lg tm-border tm-border-black-light tm-min-w-[200px]",style:{left:a.x+50,top:a.y-100},children:t.jsx("div",{className:"tm-p-2",children:t.jsxs(x.List,{children:[t.jsx("p",{className:"tm-text-sm tm-p-4 tm-gap-4 tm-font-medium tm-text-neutral-300",children:"Tarea"}),t.jsx(x.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>p("tarea","dependiente"),children:"Dependiente"}),t.jsx(x.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>p("tarea","hija"),children:"Hija"}),t.jsx(x.ListSeparator,{}),t.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Flujo de trabajo"}),t.jsx(x.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>p("plantilla","dependiente"),children:"Dependiente"})]})})}),i&&l&&t.jsx(fs,{isOpen:i,onClose:h,onSuccess:g,nodeDataType:{id:"",type:l.type,connectionType:l.connectionType},parentNodeInfo:o}),c&&l&&t.jsx(bs,{isOpen:c,onClose:f,onSuccess:y,nodeDataType:{id:"",type:l.type,connectionType:l.connectionType},parentNodeInfo:o})]})};function Lr({reactFlowWrapper:e,nodes:a}){const{setViewport:n,getViewport:s}=oe.useReactFlow(),{zoom:o}=oe.useViewport(),i=Math.round(o*100),[r,c]=u.useState([]),[m,l]=u.useState(-1),[d,p]=u.useState(!1),[h,f]=u.useState(0);u.useLayoutEffect(()=>{const F=e==null?void 0:e.current;if(F){const R=F.getBoundingClientRect();f(R.width)}},[e]);const g=u.useMemo(()=>{var D;if(!a||a.length===0)return{x:0,y:0,zoom:1};const F=a.find(v=>{var U;return(U=v==null?void 0:v.data)==null?void 0:U.main})??a[0];return{x:(h||(typeof window<"u"?window.innerWidth:0))/2-(((D=F==null?void 0:F.position)==null?void 0:D.x)??0),y:20,zoom:1}},[a,h]),y=u.useCallback(F=>{if(!d){const R=[...r.slice(0,m+1),F];c(R),l(R.length-1)}},[r,m,d]),w=u.useCallback(()=>{if(d)return;const F=s(),R=Math.min(F.zoom*1.2,2);y(F),p(!0),n({x:F.x,y:F.y,zoom:R}),setTimeout(()=>p(!1),100)},[s,n,y,d]),j=u.useCallback(()=>{if(d)return;const F=s(),R=Math.max(F.zoom/1.2,.5);y(F),p(!0),n({x:F.x,y:F.y,zoom:R}),setTimeout(()=>p(!1),100)},[s,n,y,d]),b=u.useCallback(()=>{if(d)return;const F=s();Math.abs(F.zoom-1)>.01&&y(F),p(!0),n({x:F.x,y:F.y,zoom:1}),setTimeout(()=>p(!1),100)},[s,n,y,d]),_=u.useCallback(()=>{if(d||m<=0)return;const F=r[m-1];p(!0),n(F),l(m-1),setTimeout(()=>p(!1),100)},[m,r,n,d]);return u.useEffect(()=>{r.length===0&&(c([{zoom:1,x:0,y:0}]),l(0))},[r.length]),{isReady:h!==0&&Array.isArray(a)&&a.length>0,defaultViewport:g,zoomPercentage:i,handleZoomIn:w,handleZoomOut:j,handleZoomTo100:b,handleDoubleClick:_}}const Br=e=>{var i,r;const a=((i=e.data)==null?void 0:i.isInternal)||!1,n=(r=e.data)==null?void 0:r.originalGroupId,s=e.selected||!1,o=c=>{if(c.preventDefault(),c.stopPropagation(),n){const l=Te.getState().collapseGroup;l&&l(n)}};return t.jsxs("div",{className:`tm-flex tm-flex-col tm-border-[1px] tm-gap-y-2 tm-rounded-lg tm-bg-white tm-p-3 tm-transition-all tm-duration-200 ${s?"tm-border-blue-500 tm-shadow-lg tm-ring-2 tm-ring-blue-300 tm-ring-opacity-50":"tm-border-black-light tm-shadow-sm"}`,children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-2",children:[t.jsx(x.Icon,{name:ze.faFlag,size:"sm",colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,background:!0,padding:"md"}),t.jsx("p",{className:"tm-text-primary tm-font-body-sm-semibold tm-leading-none tm-text-body-sm-regular tm-truncate tm-tracking-wider",children:e.data.clave}),a&&t.jsx(x.Button,{size:"sm",color:"secondary",onClick:o,className:"tm-p-2 nopan nodrag",icon:de.faMinimize,pill:"pill"})]}),a&&t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-2",children:[t.jsx(x.Tag,{color:e.data.estatus==="published"?"success":"warning",label:e.data.estatus==="published"?"Publicado":"Borrador"}),(e.data.updatedAt||e.data.updated_at)&&t.jsx("p",{className:"tm-text-sm tm-text-neutral-500 tm-font-medium",children:new Date(e.data.updatedAt||e.data.updated_at).toLocaleDateString("es-ES")})]}),t.jsx(oe.Handle,{id:"bottom-source",type:"source",position:oe.Position.Bottom,className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white tm-cursor-crosshair"}),t.jsx(oe.Handle,{id:"top-target",type:"target",position:oe.Position.Top,className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white tm-cursor-crosshair"})]})},Rr=()=>{const e=u.useCallback((o,i,r,c)=>{const m=(p,h)=>{const f=p.position.x,g=p.position.y,y=120,w=60,j=15;switch(h){case"top-source":case"top-target":return{x:f,y:g-w/2-j};case"bottom-source":case"bottom-target":return{x:f,y:g+w/2+j};case"left-source":case"left-target":return{x:f-y/2-j,y:g};case"right-source":case"right-target":return{x:f+y/2+j,y:g};default:return{x:f,y:g}}},l=m(o,r),d=m(i,c);return Math.sqrt(Math.pow(d.x-l.x,2)+Math.pow(d.y-l.y,2))},[]),a=u.useCallback((o,i)=>{if(o.includes("source")===i.includes("source"))return!1;const r=d=>d.includes("top")?"top":d.includes("bottom")?"bottom":d.includes("left")?"left":d.includes("right")?"right":null,c=r(o),m=r(i);return{top:"bottom",bottom:"top",left:"right",right:"left"}[c]===m},[]),n=u.useCallback((o,i)=>{const r=["top-source","bottom-source","left-source","right-source"],c=["top-target","bottom-target","left-target","right-target"];let m=1/0,l={handle1:r[0],handle2:c[0]};for(const d of r)for(const p of c){if(!a(d,p))continue;const h=e(o,i,d,p);h<m&&(m=h,l={handle1:d,handle2:p})}return l},[e,a]),s=u.useCallback((o,i,r=800)=>Math.sqrt(Math.pow(i.position.x-o.position.x,2)+Math.pow(i.position.y-o.position.y,2))<r,[]);return{findClosestHandles:n,calculateHandleDistance:e,areHandlesCompatible:a,shouldApplyMagneticConnection:s}},qr=e=>{const[a,n]=u.useState(null),[s,o]=u.useState(null),[i,r]=u.useState(!1),c=u.useCallback((h,f,g,y)=>{n({isOpen:!0,nodeId:h,position:f,sourceNodeId:g,sourceHandleId:y})},[]),m=u.useCallback(()=>{n(null)},[]),l=u.useCallback((h,f,g,y,w)=>{r(!0),o({isOpen:!0,sourceNodeId:h,sourceHandleId:g,targetNodeId:f,targetHandleId:y,position:w})},[]),d=u.useCallback(()=>{r(!1),o(null)},[]),p=u.useCallback(()=>{var f,g,y;if(!(a!=null&&a.sourceNodeId))return null;const h=e.find(w=>w.id===a.sourceNodeId);return h?{id:h.id,label:(f=h.data)==null?void 0:f.label,nodeType:(g=h.data)==null?void 0:g.nodeType,connectionType:(y=h.data)==null?void 0:y.connectionType,data:h.data}:null},[a,e]);return{newNodePopup:a,connectionPopup:s,isConnectingExistingNodes:i,openNewNodePopup:c,closeNewNodePopup:m,openConnectionPopup:l,closeConnectionPopup:d,getParentNodeInfo:p,setIsConnectingExistingNodes:r}},zr=({initialNodes:e,initialEdges:a})=>{const[n,s,o]=oe.useNodesState(jt(e)),[i,r,c]=oe.useEdgesState(a),[m,l]=u.useState(!1),d=u.useCallback(I=>{r(I)},[r]),{toObject:p}=oe.useReactFlow(),{findClosestHandles:h,shouldApplyMagneticConnection:f}=Rr(),{updateGraphLayout:g,get:y,update:w}=Be(),j=Le(I=>I.activeTemplate),b=Le(I=>I.setActiveTemplate),_=me.useQueryClient(),{removeParentIdFromNodes:M}=nt(),{newNodePopup:F,connectionPopup:R,isConnectingExistingNodes:N,openNewNodePopup:D,closeNewNodePopup:v,openConnectionPopup:U,closeConnectionPopup:K,getParentNodeInfo:J,setIsConnectingExistingNodes:H}=qr(n),{createNodeFromPopup:O,createConnectionFromPopup:S,updateNodeFromPopup:B,updateAfterDeleted:k}=hs({nodes:n,edges:i,setNodes:s,setEdges:d,newNodePopup:F,connectionPopup:R,closeNewNodePopup:v,closeConnectionPopup:K,setIsConnectingExistingNodes:H});u.useEffect(()=>{if(e&&e.length>0){if(!(e.some((L,T)=>{const V=n[T];return V?L.id!==V.id||JSON.stringify(L.position)!==JSON.stringify(V.position)||JSON.stringify(L.data)!==JSON.stringify(V.data):!0})||e.length!==n.filter(L=>{var T;return!((T=L.data)!=null&&T.isInternal)}).length)&&n.length>0)return;const{expandedGroups:A,groupTemplateData:G}=Te.getState(),P=jt(e),C=new Set(P.map(L=>L.id));let $=n.filter(L=>{var T,V;return((T=L.data)==null?void 0:T.isInternal)&&typeof((V=L.data)==null?void 0:V.originalGroupId)=="string"&&A.has(L.data.originalGroupId)&&C.has(L.data.originalGroupId)});if($.length>0){const L=P.map(T=>{var V;if(A.has(T.id)){const Y=n.find(le=>le.id===T.id),ae=(V=Y==null?void 0:Y.data)==null?void 0:V.expandedDimensions;if(ae)return{...T,style:{...T.style,width:ae.width,height:ae.height},data:{...T.data,isExpanded:!0,expandedDimensions:ae}}}return T});s([...L,...$])}else if(A.size>0){const L=P.map(T=>A.has(T.id)&&G[T.id]?{...T,data:{...T.data,isExpanded:!0,needsReExpansion:!0}}:T);s(L)}else s(P)}else s([])},[e,s]),u.useEffect(()=>{if(!m&&a&&a.length>0){const{expandedGroups:I}=Te.getState(),A=jt(e),G=new Set(A.map($=>$.id)),P=i.filter($=>{var L,T;return((L=$.data)==null?void 0:L.isInternal)&&typeof((T=$.data)==null?void 0:T.originalGroupId)=="string"&&I.has($.data.originalGroupId)&&G.has($.data.originalGroupId)}),C=i.filter($=>{var L,T;return((L=$.data)==null?void 0:L.redirectedToInternal)&&typeof((T=$.data)==null?void 0:T.originalTarget)=="string"&&I.has($.data.originalTarget)&&G.has($.data.originalTarget)});if(P.length>0||C.length>0){const $=a.filter(L=>!C.some(T=>{var V;return((V=T.data)==null?void 0:V.originalTarget)===L.target}));d([...$,...P,...C])}else d(a)}},[a,d,m]);const q=u.useCallback((I,A,G=!1)=>{const C=i.filter(T=>T.target===A).length>0;if(i.some(T=>T.source===I&&T.target===A||T.source===A&&T.target===I)&&!G)return x.toast.warning("La tarea destino ya tiene una conexión"),!1;const L=!C;return typeof window<"u"&&(window.validConnectionTypes={dependiente:L,hija:L}),L?!0:(x.toast.warning("La tarea destino ya tiene una conexión de entrada"),!1)},[i]),ee=u.useCallback(I=>{if(!Ar(I.source,I.target))return;Xe(I.source)&&!I.sourceHandle&&(I.sourceHandle=_e.DEFAULT_SOURCE_HANDLE);const A=n.find(P=>P.id===I.source),G=n.find(P=>P.id===I.target);if(A&&G){if(!q(I.source,I.target))return;U(I.source,I.target,I.sourceHandle,I.targetHandle);return}return d(P=>oe.addEdge(I,P))},[n,U,d,q]),W=u.useCallback((I,A)=>{var G;if(!N&&!A.isValid&&A.fromNode){const P=n.find(ae=>ae.id===A.fromNode.id);if((P==null?void 0:P.type)==="group"){x.toast.warning("En una plantilla, no se puede crear una conexión");return}const C=Ir(I),$=document.elementFromPoint(C.x,C.y);if($!=null&&$.closest(".react-flow__node"))return;const L=crypto.randomUUID(),T=((G=A.fromHandle)==null?void 0:G.id)||_e.DEFAULT_SOURCE_HANDLE,Y=Xe(A.fromNode.id)?_e.DEFAULT_SOURCE_HANDLE:T;D(L,C,A.fromNode.id,Y)}},[N,D,n]),re=u.useCallback(async I=>{var C,$,L;const A=gs(I),G=I.length>0?($=(C=I[0])==null?void 0:C.data)==null?void 0:$.id:0;d(T=>T.filter(V=>!A.includes(V.source)&&!A.includes(V.target)));let P;for(const T of I)try{const V=T.data;if((L=V==null?void 0:V.plantilla)!=null&&L.id){P=V.plantilla.id;break}}catch{}try{d(T=>((async()=>{await k(A,T,P,G)})().catch(V=>{console.error("❌ Error en updateAfterDeleted:",V)}),T))}catch(T){console.error("❌ Error en onDeleteNode:",T)}},[d,k]),Z=u.useCallback(async I=>{var G,P,C,$,L,T,V,Y,ae,le,X,se,ce,ie;if(!I||I.length===0)return;let A;if(j!=null&&j.id)A=j.id;else for(const te of I){const ue=n.find(xe=>xe.id===te.source),fe=n.find(xe=>xe.id===te.target);if(ue!=null&&ue.data&&typeof ue.data=="object"&&"plantilla"in ue.data){const xe=ue.data.plantilla;if(xe!=null&&xe.id){A=xe.id;break}}if(fe!=null&&fe.data&&typeof fe.data=="object"&&"plantilla"in fe.data){const xe=fe.data.plantilla;if(xe!=null&&xe.id){A=xe.id;break}}}if(!A){console.warn("⚠️ onEdgesDelete - No se pudo obtener templateId");return}try{const te=await y(A);if(!te){console.warn("⚠️ onEdgesDelete - Template no encontrado en IndexedDB");return}const ue=I.map(je=>je.id),fe=((C=(P=(G=te.graph_layout)==null?void 0:G.snapshot)==null?void 0:P.edges)==null?void 0:C.filter(je=>{var ke;return!ue.includes(je.id)&&!((ke=je.data)!=null&&ke.isInternal)}))||[],pe=(((T=(L=($=te.graph_layout)==null?void 0:$.snapshot)==null?void 0:L.nodes)==null?void 0:T.filter(je=>{var ke;return!((ke=je.data)!=null&&ke.isInternal)&&!je.parentId}))||[]).map(je=>{const{style:ke,measured:pt,data:rt,...it}=je,{expandedDimensions:et,isExpanded:Vt,needsReExpansion:pl,...Wt}=rt||{},Ms=ke?{...ke,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0,ks=je.data.id===I[0].data.childId?{...Wt,tarea_padre:null,id_t_requerida:null}:Wt;return{...it,style:Ms,data:ks}}),ye=((Y=(V=te.graph_layout)==null?void 0:V.snapshot)==null?void 0:Y.edges)||[];if(!(JSON.stringify(ye)!==JSON.stringify(fe)))return;const Ne={...te,graph_layout:{id:((ae=te.graph_layout)==null?void 0:ae.id)||0,snapshot:{nodes:pe,edges:fe,viewport:((X=(le=te.graph_layout)==null?void 0:le.snapshot)==null?void 0:X.viewport)||{x:0,y:0,zoom:1}},history:((se=te.graph_layout)==null?void 0:se.history)||[],zoom:((ce=te.graph_layout)==null?void 0:ce.zoom)||1,position:((ie=te.graph_layout)==null?void 0:ie.position)||{x:0,y:0}},estatus:ve.DIRTY,updatedAt:new Date().toISOString()};await M({templateId:A,id:I[0].data.childId}),await w(A,Ne),console.log("🗑️ [useFlow] Invalidando caché de la plantilla:",A),await _.invalidateQueries({queryKey:["template",A]}),await _.invalidateQueries({queryKey:["template"]}),console.log("✅ [useFlow] Caché invalidado exitosamente"),A===(j==null?void 0:j.id)&&b(Ne)}catch(te){console.error("❌ onEdgesDelete - Error al actualizar template layout:",te)}},[n,j,y,w,b,M]),E=u.useCallback(async I=>!I.nodes.some(G=>G.type==="start"||G.id===_e.START_NODE_ID),[]),z=u.useCallback((I,A,G)=>{var L,T,V;const P=n.find(Y=>Y.id===A.id);if(!P)return;if(P.type==="group"&&((L=P.data)!=null&&L.isExpanded)){d(Y=>Y.map(ae=>{if(ae.hidden&&ae.target===A.id){const{hidden:le,...X}=ae;return X}return ae}));return}let C;if(P.type==="group"?C=j==null?void 0:j.id:(V=(T=A==null?void 0:A.data)==null?void 0:T.plantilla)!=null&&V.id&&(C=A.data.plantilla.id),!C)return;const $=i.map(Y=>{var X,se,ce,ie,te;if(wt(Y))return Y;const ae=n.find(ue=>ue.id===Y.source),le=n.find(ue=>ue.id===Y.target);if(ae&&le){const ue=ae.type==="group"&&((X=ae.data)==null?void 0:X.isExpanded),fe=le.type==="group"&&((se=le.data)==null?void 0:se.isExpanded),xe=(ce=ae.data)==null?void 0:ce.isInternal,pe=(ie=le.data)==null?void 0:ie.isInternal,ye=(te=Y.data)==null?void 0:te.redirectedToInternal;if(ue||fe||xe||pe||ye)return Y;if(ae.id===A.id||le.id===A.id||f(ae,le,_e.MAGNETIC_CONNECTION_DISTANCE)){const Ne=h(ae,le);if(Ne!=null&&Ne.handle1&&(Ne!=null&&Ne.handle2))return{...Y,sourceHandle:Ne.handle1,targetHandle:Ne.handle2}}}return Y});if(JSON.stringify(i)!==JSON.stringify($))d($),setTimeout(()=>{const Y=p();g(C,Y)},100);else{const Y=p();g(C,Y)}},[n,i,j,g,p,d,h,f]),Q=u.useCallback(I=>{o(I);const A=Dr(I);if(A.length>0){const G=A.filter(P=>{var $;const C=n.find(L=>L.id===P);return(C==null?void 0:C.type)==="group"&&(($=C==null?void 0:C.data)==null?void 0:$.isExpanded)});if(G.length>0){d(P=>P.map(C=>{var T;const $=G.includes(C.target),L=!((T=C.data)!=null&&T.redirectedToInternal);return $&&L?{...C,hidden:!0}:C}));return}l(!0),setTimeout(()=>{const P=i.map($=>{var V,Y,ae,le;if(wt($))return{...$};const L=n.find(X=>X.id===$.source),T=n.find(X=>X.id===$.target);if(L&&T){const X=L.type==="group"&&((V=L.data)==null?void 0:V.isExpanded),se=T.type==="group"&&((Y=T.data)==null?void 0:Y.isExpanded),ce=(ae=L.data)==null?void 0:ae.isInternal,ie=(le=T.data)==null?void 0:le.isInternal;if(X||se||ce||ie)return{...$};if(f(L,T,_e.MAGNETIC_CONNECTION_DISTANCE)){const te=h(L,T);if(te!=null&&te.handle1&&(te!=null&&te.handle2)&&($.sourceHandle!==te.handle1||$.targetHandle!==te.handle2))return{...$,sourceHandle:te.handle1,targetHandle:te.handle2}}}return{...$}});if(i.some(($,L)=>{const T=P[L];return $.sourceHandle!==T.sourceHandle||$.targetHandle!==T.targetHandle})){const $=P.map(L=>({...L,id:L.id}));d($)}setTimeout(()=>{l(!1)},200)},0)}},[o,i,n,d,h,f,l]);return{nodes:n,edges:i,newNodePopup:F,connectionPopup:R,setNodes:s,setEdges:d,onEdgesChange:c,onConnect:ee,onConnectEnd:W,onDeleteNode:re,onEdgesDelete:Z,onBeforeDelete:E,handleNodesChange:Q,onDragEnd:z,getParentNodeInfo:J,isProtectedConnection:wt,isStartNode:Xe,createNodeFromPopup:O,updateNodeFromPopup:B,closeNewNodePopup:v,createConnectionFromPopup:S,closeConnectionPopup:K}},$r=({isOpen:e,onClose:a,createConnectionFromPopup:n,availableConnections:s})=>{if(!e)return null;const o=s||{tarea:{dependiente:!0,hija:!0},plantilla:{dependiente:!0}},i=(r,c)=>{(r==="tarea"?o.tarea[c]:o.plantilla[c])&&n(r,c)};return t.jsx(t.Fragment,{children:t.jsxs("div",{className:"tm-fixed tm-inset-0 tm-z-50 tm-flex tm-items-center tm-justify-center",children:[t.jsx("div",{className:"tm-bg-black/20 tm-absolute tm-inset-0",onClick:a}),t.jsx("div",{className:"tm-shadow-lg tm-border-default tm-border-1 tm-relative tm-rounded-lg tm-bg-white tm-p-4",children:t.jsx("div",{children:t.jsxs(x.List,{children:[t.jsx("p",{className:"tm-text-sm tm-px-4 tm-font-medium tm-text-neutral-300",children:"Tarea"}),t.jsxs(x.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>i("tarea","dependiente"),children:["Dependiente ",!o.tarea.dependiente&&"(No disponible)"]}),t.jsxs(x.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>i("tarea","hija"),children:["Hija ",!o.tarea.hija&&"(No disponible)"]}),t.jsx(x.ListSeparator,{}),t.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Flujo de trabajo"}),t.jsxs(x.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>i("plantilla","dependiente"),children:["Dependiente ",!o.plantilla.dependiente&&"(No disponible)"]})]})})})]})})},Ur=({data:e,id:a,selected:n})=>{const{expandedGroups:s}=Te(),[o,i]=u.useState(!1),r=u.useRef(!1);u.useEffect(()=>{const p=(e==null?void 0:e.needsReExpansion)&&s.has(a),h=(e==null?void 0:e.templateId)||(e==null?void 0:e.id);if(p&&h&&!r.current){r.current=!0;const g=Te.getState().expandGroup;g&&g(a,h).catch(y=>{console.error("Error al re-expandir grupo:",y),r.current=!1})}s.has(a)||(r.current=!1)},[e,a,s]);const c=async p=>{p.preventDefault(),p.stopPropagation();const h=(e==null?void 0:e.templateId)||(e==null?void 0:e.id);if(h){i(!0);try{const f=Te.getState(),g=f.expandGroup,y=f.collapseGroup,w=s.has(a);w&&y?y(a):!w&&g&&await g(a,h)}catch{}finally{i(!1)}}},m=s.has(a),l=e==null?void 0:e.expandedDimensions,d=m&&l?{width:l.width,height:l.height,minWidth:l.width,minHeight:l.height}:{minWidth:268,minHeight:80};return t.jsxs("div",{className:`tm-rounded-lg tm-relative tm-transition-all tm-duration-200 ${n?"tm-bg-white tm-border-[1px] tm-border-blue-500 tm-shadow-lg tm-ring-2 tm-ring-blue-300 tm-ring-opacity-50":m?"tm-bg-neutral-50 tm-border-2 tm-border-blue-300 tm-shadow-lg":"tm-bg-white tm-border-2 tm-border-black-light"}`,style:d,children:[t.jsx(ot,{isLoading:o}),t.jsx(oe.Handle,{id:"top-target",type:"target",position:oe.Position.Top,className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white ${m?"tm-opacity-0 tm-pointer-events-none":""}`,isConnectable:!m}),t.jsx(oe.Handle,{id:"right-target",type:"target",className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white ${m?"tm-opacity-0 tm-pointer-events-none":""}`,position:oe.Position.Right,isConnectable:!m}),t.jsx(oe.Handle,{id:"bottom-target",type:"target",className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white ${m?"tm-opacity-0 tm-pointer-events-none":""}`,position:oe.Position.Bottom,isConnectable:!m}),t.jsx(oe.Handle,{id:"left-target",type:"target",className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-white ${m?"tm-opacity-0 tm-pointer-events-none":""}`,position:oe.Position.Left,isConnectable:!m}),!m&&t.jsxs("div",{className:"tm-flex tm-justify-between tm-gap-x-8 tm-p-16",children:[t.jsx(x.Icon,{name:de.faChartDiagram,color:"brand",size:"lg"}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:[t.jsx("p",{className:"tm-text-primary tm-font-bold tm-leading-none tm-text-body-lg-regular tm-truncate tm-tracking-wider",children:e.clave||e.nombre_plantilla||"N/A"}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-4",children:[t.jsx(x.Badge,{size:"sm",theme:"soft",color:e.estatus==="published"?"success":"warning",label:e.estatus==="published"?"Publicado":"Borrador"}),e.updatedAt&&t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-semibold",children:new Date(e.updatedAt).toLocaleDateString("es-ES")})]})]}),t.jsx("div",{children:t.jsx(x.Button,{size:"sm",color:"secondary",pill:"pill",onClick:c,disabled:o,className:`tm-p-2 ${o?"tm-opacity-50":""} nopan nodrag`,icon:m?Ce.faCompress:Ce.faExpand})})]})]})},Hr=(e,a,n,s)=>{const o=u.useRef(e),i=u.useRef(a);u.useEffect(()=>{o.current=e},[e]),u.useEffect(()=>{i.current=a},[a]);const{expandedGroups:r,groupTemplateData:c,toggleGroupExpansion:m,setGroupTemplateData:l,clearGroupTemplateData:d}=Te(),p=me.useQueryClient(),{getTemplateWithTasks:h}=is(),{hydrateTasks:f}=ds(),g=u.useCallback(async(b,_)=>{var M,F,R,N;try{await p.invalidateQueries({queryKey:["template",_]});const D=await h(_),v=(R=(F=(M=D==null?void 0:D.graph_layout)==null?void 0:M.snapshot)==null?void 0:F.nodes)==null?void 0:R.filter(T=>{var V,Y;return((V=T.data)==null?void 0:V.isInternal)||T.parentId||((Y=T.id)==null?void 0:Y.includes("-internal-"))});if(v&&v.length>0&&console.warn("⚠️ [expandGroup] Nodos sospechosos en API para plantilla",_,":",v),!((N=D==null?void 0:D.graph_layout)!=null&&N.snapshot))throw new Error(`No se encontraron datos de graph_layout en la plantilla: ${_}`);const U=D.graph_layout.snapshot.nodes||[],K=U.filter(T=>{var X,se;const V=(X=T.data)==null?void 0:X.isInternal,Y=!!T.parentId,ae=(se=T.id)==null?void 0:se.includes("-internal-"),le=V||Y||ae;return le&&console.warn("🗑️ [expandGroup] Filtrando nodo corrupto:",{id:T.id,type:T.type,esInterno:V,tieneParentId:Y,tieneInternalEnId:ae}),!le}),J={...D,graph_layout:{...D.graph_layout,snapshot:{...D.graph_layout.snapshot,nodes:K,edges:(D.graph_layout.snapshot.edges||[]).filter(T=>{var V,Y;return!((V=T.data)!=null&&V.isInternal)&&!((Y=T.id)!=null&&Y.includes("-internal-"))})}}},H=U.length-K.length;H>0?console.warn(`⚠️ [expandGroup] Se filtraron ${H} nodos internos corruptos de la BD para plantilla ${_}`):console.log(`✅ [expandGroup] No se encontraron nodos corruptos en plantilla ${_}`);const O=await f(J),S={...J,hydratedNodes:O,nodes:O||J.graph_layout.snapshot.nodes||[],edges:J.graph_layout.snapshot.edges||[]},B=S.nodes,k=S.edges;if(!B||!k){console.error("❌ No se encontraron nodos o edges en la plantilla:",_);return}l(b,{nodes:B,edges:k,viewport:S.graph_layout.snapshot.viewport||{x:0,y:0,zoom:1}});const q=o.current.find(T=>T.id===b);if(!q){console.error("❌ No se encontró el nodo grupo:",b);return}const ee=B.filter(T=>T.id!==b);let W=1/0,re=1/0,Z=-1/0,E=-1/0;ee.forEach(T=>{var te,ue,fe,xe,pe,ye;const V=((te=T.position)==null?void 0:te.x)||0,Y=((ue=T.position)==null?void 0:ue.y)||0,ae=typeof((fe=T.style)==null?void 0:fe.width)=="number"?T.style.width:((xe=T.measured)==null?void 0:xe.width)||268,le=typeof((pe=T.style)==null?void 0:pe.height)=="number"?T.style.height:((ye=T.measured)==null?void 0:ye.height)||111,X=V-ae/2,se=V+ae/2,ce=Y,ie=Y+le;W=Math.min(W,X),re=Math.min(re,ce),Z=Math.max(Z,se),E=Math.max(E,ie)});const z=80,Q=60,I=Z-W,A=E-re,G=I+z*2,P=A+z*2+Q,C=B.map((T,V)=>{var te,ue;if(T.id===b)return null;const Y=((te=T.position)==null?void 0:te.x)||0,ae=((ue=T.position)==null?void 0:ue.y)||0,le=Y-W+z,X=ae-re+z+Q,se=T.type==="start"||T.id==="start",ce=se?{...T.data,estatus:q.data.estatus,updatedAt:q.data.updatedAt,createdAt:q.data.createdAt,isInternal:!0,originalGroupId:b,originalNodeId:T.id}:{...T.data,isInternal:!0,originalGroupId:b,originalNodeId:T.id};return{...T,id:`${b}-internal-${T.id}`,parentId:b,extent:"parent",type:T.type==="group"?"main":T.type,position:{x:le,y:X},style:{...T.style},data:ce,draggable:!1,selectable:se,selected:!1,deletable:!1,connectable:!1,focusable:se,zIndex:999}}).filter(Boolean),$=k.map(T=>{const V=C.some(le=>le&&le.id===`${b}-internal-${T.source}`),Y=C.some(le=>le&&le.id===`${b}-internal-${T.target}`);return!V||!Y?null:{...T,id:`${b}-internal-${T.id}`,source:`${b}-internal-${T.source}`,target:`${b}-internal-${T.target}`,style:{...T.style},data:{...T.data,isInternal:!0,originalGroupId:b}}}).filter(Boolean),L=C.find(T=>{var V;return T&&((V=T.data)==null?void 0:V.originalNodeId)==="start"});L&&s(T=>T.map(V=>V.target===b?{...V,target:L.id,targetHandle:"top-target",data:{...V.data,redirectedToInternal:!0,originalTarget:b,originalTargetHandle:V.targetHandle}}:V)),m(b),n(T=>[...T.map(Y=>{if(Y.id===b){const{needsReExpansion:ae,...le}=Y.data||{};return{...Y,style:{...Y.style,width:G,height:P},data:{...le,isExpanded:!0,expandedDimensions:{width:G,height:P}},zIndex:1e3}}return Y}),...C]),s(T=>[...T,...$])}catch(D){console.error("❌ Error al expandir el grupo:",D)}},[p,h,f,l,m,n,s]),y=u.useCallback(b=>{var v,U;const _=o.current,M=i.current,F=_.find(K=>K.id===b),R=((v=F==null?void 0:F.data)==null?void 0:v.templateId)||((U=F==null?void 0:F.data)==null?void 0:U.id),N=_.filter(K=>!K.id.startsWith(`${b}-internal-`)&&K.parentId!==b).map(K=>K.id===b?{...K,style:{...K.style,width:void 0,height:void 0},data:{...K.data,isExpanded:!1,expandedDimensions:void 0},zIndex:void 0}:K),D=M.filter(K=>!K.id.startsWith(`${b}-internal-`)).map(K=>{var J,H;if((J=K.data)!=null&&J.redirectedToInternal&&((H=K.data)==null?void 0:H.originalTarget)===b){const{redirectedToInternal:O,originalTarget:S,originalTargetHandle:B,...k}=K.data;return{...K,target:b,targetHandle:B||K.targetHandle,data:k}}return K});n(N),s(D),m(b),d(b),R&&p.invalidateQueries({queryKey:["template",R]})},[n,s,m,d,p]),w=u.useCallback(async(b,_)=>{r.has(b)?y(b):await g(b,_)},[r,g,y]),j=u.useCallback(b=>r.has(b),[r]);return{expandGroup:g,collapseGroup:y,toggleGroup:w,isGroupExpanded:j,groupTemplateData:c}},Kr=()=>{const{getNodes:e,setNodes:a,screenToFlowPosition:n,setCenter:s}=oe.useReactFlow(),{copiedNodes:o,setCopiedNodes:i,getViewMode:r}=Te(),{activeTemplate:c,setActiveTemplate:m}=Le(),{updateGraphLayout:l,get:d,update:p}=Be(),h=c!=null&&c.id?r(c.id):"readonly",f=u.useCallback(()=>`node-${Date.now()}-${Math.random().toString(36).substr(2,9)}`,[]),g=u.useCallback(()=>e().filter(N=>N.selected).filter(N=>!(N.type==="start"||N.id==="start"||N.type==="group")),[e]),y=u.useCallback(()=>{if(h==="readonly"){x.toast.error("No puedes copiar tareas en modo solo lectura");return}if(!c){x.toast.error("No hay una plantilla activa");return}const M=g();if(M.length===0){const R=e().filter(N=>N.selected);if(R.length>0){const N=R.some(v=>v.type==="group"),D=R.some(v=>v.type==="start"||v.id==="start");N?x.toast.error("Las plantillas conectadas no pueden ser copiadas"):D&&x.toast.error("El nodo de inicio no puede ser copiado")}else x.toast.error("No hay tareas seleccionadas para copiar");return}const F=M.map(R=>{const{selected:N,...D}=R;return{...D,data:{...D.data,_originalTemplateId:c.id}}});i(F),x.toast.success(`${M.length} ${M.length===1?"tarea copiada":"tareas copiadas"} con éxito`)},[h,c,g,e,i]),w=u.useCallback(async M=>{if(h==="readonly"){x.toast.error("No puedes pegar tareas en modo solo lectura");return}if(!c){x.toast.error("No hay una plantilla activa");return}if(o.length===0){x.toast.error("No hay tareas copiadas para pegar");return}const F=e();let R={x:0,y:0};if(M)R=n({x:M.x,y:M.y});else if(F.length>0){const H=F.reduce((S,B)=>S+B.position.x,0)/F.length,O=F.reduce((S,B)=>S+B.position.y,0)/F.length;R={x:H+50,y:O+100}}const N=o[0],D=R.x-N.position.x,v=R.y-N.position.y,U=o.map((H,O)=>{const S=f(),B=-(Date.now()+O),k=H.data.plantilla&&typeof H.data.plantilla=="object"?{...H.data.plantilla,id:c.id}:{id:c.id},{id:q,...ee}=H.data,W={...ee,id:B,reference_graph:S,plantilla:k,parent:{data:{id:null}},_originalTemplateId:void 0};return{...H,id:S,position:{x:H.position.x+D,y:H.position.y+v},data:W,selected:!0}}),J=[...F.map(H=>({...H,selected:!1})),...U];if(a(J),c.id)try{const H=await d(c.id);if(!H)return;const O=U.filter(B=>B.type!=="start"&&B.type!=="group").map(B=>{const k=B.data;return{id:k.id,reference_graph:B.id,nombre:k.nombre||k.texto_corto||"Tarea sin nombre",texto_corto:k.texto_corto||"",texto_largo:k.texto_largo||"",prioridad:k.prioridad??0,nivel_dificultad:k.nivel_dificultad??0,dias_duracion:k.dias_duracion??0,plantilla:{id:c.id},parent:{data:{id:null}},tareas:[],plantilla_dependents:k.plantilla_dependents||[],start:k.start||!1,es_grupo:k.es_grupo||!1,optional:k.optional||!1,subtask_completadas:k.subtask_completadas||0,subtask_totales:k.subtask_totales||0}}),S={...H,tarea_plantillas:[...H.tarea_plantillas,...O],estatus:"dirty",updatedAt:new Date().toISOString()};await p(c.id,S),m(S),setTimeout(async()=>{await l(c.id,{nodes:J,edges:[]})},50)}catch(H){console.error("Error al actualizar template en IndexedDB:",H)}if(U.length>0){const H=U.reduce((S,B)=>S+B.position.x,0)/U.length,O=U.reduce((S,B)=>S+B.position.y,0)/U.length;s(H,O,{zoom:1,duration:800})}x.toast.success(`${U.length} ${U.length===1?"tarea pegada":"tareas pegadas"} con éxito`)},[h,c,o,e,a,n,s,f,l,d,p,m]),j=u.useCallback(()=>o.length>0,[o]),_=g().length>0;return{handleCopy:y,handlePaste:w,hasCopiedNodes:j,hasSelectableNodes:_,copiedNodesCount:o.length}},Gr={main:Fr,plus:kr,start:Br,group:Ur},Vr=[.5,0],Wr=({initialNodes:e,initialEdges:a,debugEvents:n=!1})=>{const s=u.useRef(null),{nodes:o,edges:i,onEdgesChange:r,onConnect:c,onConnectEnd:m,onBeforeDelete:l,onDeleteNode:d,onEdgesDelete:p,handleNodesChange:h,newNodePopup:f,getParentNodeInfo:g,createNodeFromPopup:y,closeNewNodePopup:w,connectionPopup:j,createConnectionFromPopup:b,closeConnectionPopup:_,onDragEnd:M,setNodes:F,setEdges:R}=zr({initialNodes:e,initialEdges:a}),{expandGroup:N,collapseGroup:D}=Hr(o,i,F,R),{handleCopy:v,handlePaste:U,hasCopiedNodes:K,copiedNodesCount:J}=Kr();u.useEffect(()=>{if(!n)return;const te=pe=>{console.log("🔍 [DEBUG] KeyDown:",{key:pe.key,code:pe.code,shiftKey:pe.shiftKey,ctrlKey:pe.ctrlKey,metaKey:pe.metaKey,altKey:pe.altKey,target:pe.target,defaultPrevented:pe.defaultPrevented,bubbles:pe.bubbles,timestamp:new Date().toISOString()})},ue=pe=>{console.log("🔍 [DEBUG] KeyUp:",{key:pe.key,code:pe.code,shiftKey:pe.shiftKey,timestamp:new Date().toISOString()})},fe=pe=>{var ye,Me;console.log("🔍 [DEBUG] Click:",{button:pe.button,shiftKey:pe.shiftKey,ctrlKey:pe.ctrlKey,metaKey:pe.metaKey,altKey:pe.altKey,target:(ye=pe.target)==null?void 0:ye.tagName,targetClass:(Me=pe.target)==null?void 0:Me.className,defaultPrevented:pe.defaultPrevented,bubbles:pe.bubbles,timestamp:new Date().toISOString()})},xe=pe=>{console.log("🔍 [DEBUG] MouseDown:",{button:pe.button,shiftKey:pe.shiftKey,ctrlKey:pe.ctrlKey,metaKey:pe.metaKey,defaultPrevented:pe.defaultPrevented,timestamp:new Date().toISOString()})};return document.addEventListener("keydown",te,!0),document.addEventListener("keyup",ue,!0),document.addEventListener("click",fe,!0),document.addEventListener("mousedown",xe,!0),console.log("🔍 [DEBUG] Event listeners activados. Presiona Shift + Click en un nodo para ver los eventos."),()=>{document.removeEventListener("keydown",te,!0),document.removeEventListener("keyup",ue,!0),document.removeEventListener("click",fe,!0),document.removeEventListener("mousedown",xe,!0),console.log("🔍 [DEBUG] Event listeners desactivados.")}},[n]);const O=o.filter(te=>!(!te.selected||te.type==="start"||te.id==="start"||te.type==="group")).length,S=O>0,B=u.useRef(N),k=u.useRef(D);u.useEffect(()=>{B.current=N,k.current=D},[N,D]),u.useEffect(()=>{const te=async(fe,xe)=>{B.current&&await B.current(fe,xe)},ue=fe=>{k.current&&k.current(fe)};Te.setState({expandGroup:te,collapseGroup:ue})},[]);const{zoomPercentage:q,handleZoomIn:ee,handleZoomOut:W,handleZoomTo100:re,handleDoubleClick:Z}=Lr({reactFlowWrapper:s,nodes:o}),{getViewMode:E}=Te(),{activeTemplate:z}=Le(),I=(z!=null&&z.id?E(z.id):"readonly")==="readonly";u.useEffect(()=>{if(I)return;const te=ue=>{const fe=ue.target;fe.tagName==="INPUT"||fe.tagName==="TEXTAREA"||fe.isContentEditable||((ue.ctrlKey||ue.metaKey)&&ue.key==="c"&&(ue.preventDefault(),v()),(ue.ctrlKey||ue.metaKey)&&ue.key==="v"&&(ue.preventDefault(),U()))};return document.addEventListener("keydown",te),()=>{document.removeEventListener("keydown",te)}},[v,U,I]);const A=u.useCallback((te,ue)=>{const fe=te.target;fe.tagName==="BUTTON"||fe.closest("button")||fe.closest('[role="button"]')||fe.classList.contains("nopan")||fe.classList.contains("nodrag")},[]),G=u.useCallback(te=>{const ue=te.filter(fe=>{var xe,pe;if(fe.type==="position"&&fe.dragging===!1){const ye=o.find(Me=>Me.id===fe.id);if(ye&&fe.position){const Me=Math.abs((fe.position.x||0)-(((xe=ye.position)==null?void 0:xe.x)||0)),Ne=Math.abs((fe.position.y||0)-(((pe=ye.position)==null?void 0:pe.y)||0));if(Me<3&&Ne<3)return!1}}return!0});ue.length>0&&h(ue)},[h,o]),P=I?void 0:r,C=I?void 0:G,$=I?void 0:c,L=I?void 0:m,T=I?void 0:l,V=I?void 0:M,Y=I?void 0:d,ae=I?void 0:p,le=I?null:["Backspace","Delete"],ce=I?{nodesDraggable:!1,nodesConnectable:!1,elementsSelectable:!0,edgesFocusable:!1,nodesFocusable:!1,draggable:!1,connectOnClick:!1}:{nodesDraggable:!0,nodesConnectable:!0,elementsSelectable:!0,edgesFocusable:!0,nodesFocusable:!0,draggable:!1,connectOnClick:!0,elevateNodesOnSelect:!0},ie=()=>{if(j)return{tarea:{dependiente:!0,hija:!0},plantilla:{dependiente:!0}}};return t.jsxs("div",{className:"wrapper",ref:s,style:{width:"100%",height:"100vh"},children:[t.jsxs(oe.ReactFlow,{nodes:o,edges:i,nodeTypes:Gr,onEdgesChange:P,onNodesChange:C,onConnect:$,onConnectEnd:L,onBeforeDelete:T,onNodeDragStop:V,onNodesDelete:Y,onEdgesDelete:ae,onNodeClick:A,...ce,fitView:!0,fitViewOptions:{padding:2},nodeOrigin:Vr,defaultEdgeOptions:{type:"smoothstep"},connectionLineType:oe.ConnectionLineType.SmoothStep,deleteKeyCode:le,multiSelectionKeyCode:I?null:"Shift",selectionOnDrag:!1,panOnDrag:I?!0:[0],nodeClickDistance:15,selectNodesOnDrag:!1,nodeDragThreshold:10,autoPanOnNodeDrag:!1,autoPanOnConnect:!1,noDragClassName:"nodrag",noWheelClassName:"nowheel",noPanClassName:"nopan",children:[t.jsx(oe.Background,{}),!I&&t.jsx(oe.Panel,{position:"bottom-left",className:"tm-m-0",children:t.jsxs("div",{className:"tm-bg-white tm-border tm-border-black-light tm-rounded-lg tm-p-3 tm-shadow-sm tm-text-sm tm-text-neutral-500",children:[t.jsx("div",{className:"tm-font-semibold tm-text-neutral-900 tm-mb-2",children:"Atajos de teclado"}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-1",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2",children:[t.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"Shift"}),t.jsx("span",{children:"+ clic para seleccionar múltiples tareas"})]}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2",children:[t.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"Ctrl"}),t.jsx("span",{children:"+"}),t.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"C"}),t.jsx("span",{children:"Copiar"})]}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2",children:[t.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"Ctrl"}),t.jsx("span",{children:"+"}),t.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"V"}),t.jsx("span",{children:"Ppegar"})]})]})]})}),t.jsx(oe.Panel,{position:"top-left",className:"tm-m-0",children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-2",children:[t.jsxs("div",{children:[z.estatusFromStrapi===Ee.PUBLISHED&&t.jsx(x.Tag,{color:"success",label:"Publicado"}),z.estatusFromStrapi===Ee.DRAFT&&t.jsx(x.Tag,{color:"warning",label:"Borrador"})]}),!I&&O>0&&t.jsxs("p",{className:"tm-text-blue-dark-500 tm-text-xs tm-font-medium",children:[O," ",O===1?"tarea seleccionada":"tareas seleccionadas"]})]})}),t.jsx(oe.Panel,{position:"top-right",className:"tm-m-0",children:t.jsxs("div",{className:"tm-flex tm-gap-4",children:[!I&&t.jsxs(x.ButtonGroup,{children:[t.jsxs(x.Button,{leftSlot:de.faCopy,onClick:v,disabled:!S,size:"xxs",color:S?"primary":"secondary",title:S?`Copiar ${O} ${O===1?"tarea":"tareas"} (Ctrl+C)`:"Selecciona tareas para copiar (mantén Shift y haz clic)",children:["Copiar ",O>0&&`(${O})`]}),t.jsxs(x.Button,{leftSlot:de.faFile,size:"xxs",onClick:()=>U(),disabled:!K(),color:K()?"primary":"secondary",title:K()?`Pegar ${J} ${J===1?"tarea":"tareas"} (Ctrl+V)`:"No hay tareas copiadas",children:["Pegar ",J>0&&`(${J})`]})]}),t.jsxs(x.ButtonGroup,{color:"secondary",size:"xxs",children:[t.jsx(x.Button,{icon:de.faMinus,onClick:W,color:"secondary"}),t.jsxs(x.Button,{onClick:re,onDoubleClick:Z,color:"secondary",children:[q,"%"]}),t.jsx(x.Button,{icon:de.faPlus,onClick:ee})]})]})})]}),f&&t.jsx(Or,{isOpen:f.isOpen,position:f.position,onClose:w,createNodeFromPopup:y,parentNodeInfo:g()}),j&&t.jsx($r,{isOpen:j.isOpen,onClose:_,createConnectionFromPopup:b,availableConnections:ie()})]})},Qr=({initialNodes:e,initialEdges:a,debugEvents:n})=>t.jsx(oe.ReactFlowProvider,{children:t.jsx(Wr,{initialNodes:e,initialEdges:a,debugEvents:n})}),st=Ue.create(e=>({step:1,setStep:a=>e({step:a}),reset:()=>e({step:1})})),Xr=({limit:e})=>{const a=st(r=>r.step),n=st(r=>r.setStep),s=u.useCallback(()=>{a<e&&n(a+1)},[a,n,e]),o=u.useCallback(()=>{a>1&&a<=e&&n(a-1)},[a,n,e]),i=u.useCallback(r=>{r>0&&r<=e&&n(r)},[n,e]);return u.useMemo(()=>({step:a,nextStep:s,prevStep:o,onStepChange:i}),[a,s,o,i])},ya=["fase_plantilla","tipo_plantilla","categoria","tipo_medio","medio_especifico","pertenencia_medio","ubicacion_medio","responsable_impresion"],ja=["fase_plantilla","modo_configuracion","tipo_medio","formato_salida"],wa=["tipo_medio","formato_salida","medio_especifico"],va={fase_plantilla:{Preventa:{fieldsToClear:["modo_configuracion","formato_salida","medio_especifico","tipo_plantilla","categoria"]},Venta:{fieldsToClear:["tipo_medio","medio_especifico","modo_configuracion"]}},modo_configuracion:{Default:{fieldsToClear:["formato_salida","medio_especifico","tipo_medio"]},Especifico:{fieldsToClear:["formato_salida","medio_especifico","tipo_medio"]}},tipo_medio:{"Sitios Fijos":{fieldsToClear:["medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"]},Indoors:{fieldsToClear:["medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"]},"Vallas Móviles":{fieldsToClear:["responsable_impresion","pertenencia_medio","ubicacion_medio"]},Camiones:{fieldsToClear:["responsable_impresion","pertenencia_medio","ubicacion_medio"]},"Brand Riders":{fieldsToClear:["responsable_impresion","pertenencia_medio","ubicacion_medio"]}},formato_salida:{Digital:{fieldsToClear:["pertenencia_medio","ubicacion_medio"]},Impreso:{fieldsToClear:["pertenencia_medio","ubicacion_medio"]}}},_a={fase_plantilla:{Venta:{fieldsToEnableDisable:["tipo_plantilla","modo_configuracion","categoria","pertenencia_medio","ubicacion_medio"]},Preventa:{fieldsToEnableDisable:["modo_configuracion"]}},modo_configuracion:{Preventa:{Default:{fieldsToEnableDisable:["tipo_medio"]},Especifico:{fieldsToEnableDisable:["tipo_medio"]}},Venta:{Default:{fieldsToEnableDisable:["tipo_medio","formato_salida"]},Especifico:{fieldsToEnableDisable:["tipo_medio"]}}},tipo_plantilla:{General:{fieldsToEnableDisable:["medio_especifico"]},Individual:{fieldsToEnableDisable:[]}},formato_salida:{Digital:{fieldsToEnableDisable:["responsable_impresion"]},Impreso:{fieldsToEnableDisable:["responsable_impresion"]}}};function Ht(e){const[a,n]=u.useState([]),[s,o]=u.useState({}),{setClaveParams:i,templateFormData:r,setTemplateFormData:c,resetTemplateFormData:m,setDisableField:l,setClave:d,claveParams:p,setParamTipo:h}=Fe(),{tasks_api:f}=he(),g=st(E=>E.step),{data:y,error:w,isSuccess:j,isError:b}=me.useQuery({queryKey:["paramsTipoPlantilla"],queryFn:async()=>{const E=Pe.stringify({populate:{params_plantillas:{fields:["id","abbreviation","name","active","tipomedio_nombre","reference_id"]}},sort:["order:asc"],fields:["id","step","key","label","order"]},{encodeValuesOnly:!0}),z=await f.get(`/api/params-tipos?${E}`);return z.data?{paramsTiposPlantilla:be(z.data.data)}:{paramsTiposPlantilla:[]}},refetchOnWindowFocus:!1});u.useEffect(()=>{w&&b&&console.log(w)},[w,b]),u.useEffect(()=>{if(y&&j){const E=y.paramsTiposPlantilla;n(E)}},[y,j]);const _={fase_plantilla:(E,z)=>{c({fase_plantilla:E}),h({fase_plantilla:z})},tipo_plantilla:(E,z)=>{c({tipo_plantilla:E}),h({tipo_plantilla:z})},modo_configuracion:(E,z)=>{c({modo_configuracion:E}),h({modo_configuracion:z})},categoria:(E,z)=>{c({categoria:E}),h({categoria:z})},formato_salida:(E,z)=>{c({formato_salida:E}),h({formato_salida:z})},tipo_medio:(E,z)=>{c({tipo_medio:E}),h({tipo_medio:z})},medio_especifico:(E,z)=>{c({medio_especifico:E}),h({medio_especifico:z})},responsable_impresion:(E,z)=>{c({responsable_impresion:E}),h({responsable_impresion:z})},pertenencia_medio:(E,z)=>{c({pertenencia_medio:E}),h({pertenencia_medio:z})},ubicacion_medio:(E,z)=>{c({ubicacion_medio:E}),h({ubicacion_medio:z})}},M={fase_plantilla:(E,z)=>i({field:E,value:z}),tipo_plantilla:(E,z)=>i({field:E,value:z}),categoria:(E,z)=>i({field:E,value:z}),tipo_medio:(E,z)=>i({field:E,value:z}),medio_especifico:(E,z)=>i({field:E,value:z}),responsable_impresion:(E,z)=>i({field:E,value:z}),pertenencia_medio:(E,z)=>i({field:E,value:z}),ubicacion_medio:(E,z)=>i({field:E,value:z})},F={Digital:{execute:()=>{const E=a.filter(I=>I.step===3).find(I=>I.key==="responsable_impresion").params_plantillas.find(I=>I.name==="N/A").id,z="step3.responsable_impresion",Q=["responsable_impresion"];c({responsable_impresion:"N/A"}),e(z,E),l({fields:Q,value:!0}),i({field:"responsable_impresion",value:"NA"})}},Impreso:{execute:()=>{const E="step3.responsable_impresion",z=["responsable_impresion"];c({responsable_impresion:""}),e(E,""),l({fields:z,value:!1}),i({field:"responsable_impresion",value:""})}}},R={"Sitios Fijos":{execute:()=>J()},"Vallas Móviles":{execute:()=>H()},Indoors:{execute:()=>J()},Camiones:{execute:()=>O()},"Brand Riders":{execute:()=>O()}},N={"Sitios Fijos":{execute:()=>K()},"Vallas Móviles":{execute:()=>K()},Indoors:{execute:()=>K()},Camiones:{execute:()=>{U(),F.Impreso.execute()}},"Brand Riders":{execute:()=>{U(),F.Impreso.execute()}}},D={"Sitios Fijos":{execute:()=>v()},"Vallas Móviles":{execute:()=>U()},Indoors:{execute:()=>v()},Camiones:{execute:()=>U()},"Brand Riders":{execute:()=>U()}},v=()=>{const E=["medio_especifico"],z=r.modo_configuracion,Q=`step${g}.medio_especifico`,I=`step${g}.formato_salida`;l({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0}),l(z==="Default"?{fields:E,value:!0}:{fields:E,value:!1}),c({medio_especifico:""}),c({formato_salida:""}),e(Q,""),e(I,""),i({field:"medio_especifico",value:""}),i({field:"formato_salida",value:""})},U=()=>{const E=a.filter(G=>G.step===g).find(G=>G.key==="formato_salida").params_plantillas.find(G=>G.name==="Impreso").id;l({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0});const Q=`step${g}.formato_salida`,I=["formato_salida","medio_especifico"],A=`step${g}.medio_especifico`;c({medio_especifico:""}),c({formato_salida:"Impreso"}),e(Q,E),e(A,""),i({field:"medio_especifico",value:""}),i({field:"tipo_medio",value:r.tipo_medio}),l({fields:I,value:!0})},K=()=>{const E=["formato_salida"],z=`step${g}.formato_salida`,Q={};Q.formato_salida="",c(Q),e(z,""),l({fields:E,value:!1})},J=()=>{const E=["formato_salida","medio_especifico"],z=`step${g}.formato_salida`,Q={};Q.formato_salida="",c(Q),e(z,""),l({fields:E,value:!1})},H=()=>{const E=["formato_salida"],z=["medio_especifico"],Q=`step${g}.formato_salida`,I=`step${g}.medio_especifico`,A={};A.formato_salida="",A.medio_especifico="",c(A),e(Q,""),e(I,""),l({fields:E,value:!1}),l({fields:z,value:!0})},O=()=>{const E=a.filter(A=>A.step===g).find(A=>A.key==="formato_salida").params_plantillas.find(A=>A.name==="Impreso").id,z=`step${g}.formato_salida`,Q=`step${g}.medio_especifico`,I=["formato_salida","medio_especifico"];c({formato_salida:"Impreso"}),e(z,E),e(Q,""),l({fields:I,value:!0}),F.Impreso.execute()},S=(E,z)=>{Object.keys(va).includes(E)&&va[E][z].fieldsToClear.forEach(A=>{const G={};G[A]="",c(G),i({field:A,value:""}),e&&[...new Set(a.map(C=>C.step))].forEach(C=>{const $=`step${C}.${A}`;e($,"")})})},B=(E,z,Q)=>E==="modo_configuracion"&&Q?_a[E][Q][z].fieldsToEnableDisable:_a[E][z].fieldsToEnableDisable,k=E=>a.filter(z=>z.step===E),q=E=>{var z;return s[E]||((z=a.find(Q=>Q.key===E))==null?void 0:z.params_plantillas)},ee=(E,z)=>{var I,A,G,P;let Q=[];E==="Sitios Fijos"?z==="Preventa"?Q=(I=a.find(C=>C.key==="medio_especifico"))==null?void 0:I.params_plantillas.filter(C=>C.tipomedio_nombre==="OOH"&&C.name==="PANTALLA DIGITAL"):z==="Venta"&&(Q=(A=a.find(C=>C.key==="medio_especifico"))==null?void 0:A.params_plantillas.filter(C=>C.tipomedio_nombre==="OOH")):E==="Indoors"?Q=(G=a.find(C=>C.key==="medio_especifico"))==null?void 0:G.params_plantillas.filter(C=>C.tipomedio_nombre==="InDoor"):Q=(P=a.find(C=>C.key==="medio_especifico"))==null?void 0:P.params_plantillas,o(C=>({...C,medio_especifico:Q}))},W=(E,z)=>{const Q=E.key;if(wa.includes(Q)&&Q==="tipo_medio"){const I=z.label,A=r.fase_plantilla,G=r.modo_configuracion;if(A==="Preventa"){ee(I,A);return}else if(G==="Especifico"){ee(I,A);return}}},re=(E,z,Q)=>{const I=E.params_plantillas.find(A=>E.key==="categoria"?A.reference_id===z.value:A.id===z.value);if(I){const A=E.key,G=z.label;if(_[A](G,Q),ja.includes(A))if(S(A,G),A==="fase_plantilla"){const P=G,C=B(A,P);l({fields:["categoria","modo_configuracion","tipo_plantilla"],value:!0}),C.length>0&&l({fields:C,value:!1}),P==="Preventa"&&l({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0})}else if(A==="modo_configuracion"){const P=G,C=r.fase_plantilla,$=B(A,P,C);l({fields:["medio_especifico","formato_salida"],value:!0}),$.length>0&&l({fields:$,value:!1}),C==="Preventa"&&l({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0})}else if(A==="tipo_medio"){const P=G,C=r.modo_configuracion;r.fase_plantilla==="Venta"?C==="Especifico"?R[P].execute():N[P].execute():D[P].execute()}else if(A==="formato_salida")F[G].execute();else{const P=B(A,G);P.length>0&&l({fields:P,value:!1})}if(ya.includes(A)){let P="",C="";if(A==="formato_salida"){const $=r.modo_configuracion,L=G;C="tipo_medio",P=$==="Default"&&L==="Digital"?P="DDG":P="DRP"}else C=A,P=I.abbreviation;M[C](C,P)}wa.includes(A)&&W(E,z)}},Z=()=>{if(r){const E=r.fase_plantilla;if(E==="Preventa"){const z=r.modo_configuracion,Q=p.fase_plantilla||"XX";let I=null;if(z==="Default")I=p.tipo_medio||"XXX";else{const G=r.tipo_medio;["Vallas Móviles","Camiones","Brand Riders"].includes(G)?I=p.tipo_medio||"XXX":I=p.medio_especifico||"XXX"}const A=`${Q}-${I}`;d(A)}if(E==="Venta"){const z=p.fase_plantilla||"XX",Q=p.tipo_plantilla||"XXX",I=p.categoria||"XX",A=p.medio_especifico||p.tipo_medio||p.modo_configuracion||"XXX",G=p.responsable_impresion||"XX",P=p.pertenencia_medio||"X",C=p.ubicacion_medio||"X",$=`${z}-${Q}-${I}-${A}-${G}-${P}-${C}`;d($)}}};return u.useEffect(()=>{Z()},[p]),{templateFields:a,getFieldsByStep:k,dropdownFunctionsUpdateClave:M,fieldsForUpdateClave:ya,resetTemplateFormData:m,fieldsWithDisableTrigger:ja,getFieldsToDisable:B,handleOptionSelected:re,getFilteredOptions:q,dropdownFunctionsUpdateFormData:_}}const Kt=()=>{const{control:e,setValue:a}=Se.useFormContext(),n=st(l=>l.step),{getFieldsByStep:s,handleOptionSelected:o,getFilteredOptions:i}=Ht(a),{disabledFields:r}=Fe(),c=u.useMemo(()=>s(n),[n,s]),m=l=>`El campo ${l.charAt(0).toLocaleLowerCase()+l.slice(1)} es requerido`;return c.map(l=>{const d=`step${l.step}.${l.key}`,p=l.label,f=i(l.key).map(g=>({label:g.name,value:l.key==="categoria"?g.reference_id:g.id}));return t.jsx(Se.Controller,{name:d,control:e,rules:{required:{value:!r[l.key],message:m(p)},validate:g=>r[l.key]||g?!0:m(p)},render:({field:g,fieldState:{error:y}})=>t.jsx("div",{children:t.jsx(x.Dropdown,{label:p,value:g.value,onValueChange:w=>{g.onChange(w)},error:y==null?void 0:y.message,options:f,onOptionSelect:w=>{o(l,w,l.id)},disabled:r[l.key]||!1})})},l.id)})},Yr=()=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:t.jsx(Kt,{})}),Jr=()=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:t.jsx(Kt,{})}),Zr=()=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:t.jsx(Kt,{})}),ei=({step:e})=>t.jsxs("div",{className:"tm-flex tm-min-h-[270px] tm-flex-col tm-gap-y-4",children:[e===1&&t.jsx(Yr,{}),e===2&&t.jsx(Jr,{}),e===3&&t.jsx(Zr,{})]}),ti=e=>{const a={step1:["fase_plantilla","tipo_plantilla","modo_configuracion","categoria"],step2:["tipo_medio","formato_salida","medio_especifico"],step3:["responsable_impresion","pertenencia_medio","ubicacion_medio"]};return e.reduce((n,s)=>{const o=`step${s.step}`,i=a[o];return i&&i.includes(s.key)&&(n[o]||(n[o]={}),n[o][s.key]=""),n},{})},ai=e=>{const a={step1:["fase_plantilla","tipo_plantilla","modo_configuracion","categoria"],step2:["tipo_medio","formato_salida","medio_especifico"],step3:["responsable_impresion","pertenencia_medio","ubicacion_medio"]},n={};return Object.keys(a).forEach(s=>{n[s]={},a[s].forEach(o=>{var r;const i=(r=e[s])==null?void 0:r[o];n[s][o]=i!==void 0?i:""})}),n},si=e=>e&&e.status===400?{failureLevel:"strapi",errorMessage:"Error al procesar la solicitud",technicalDetails:e.message}:e&&e.status===401?{failureLevel:"authentication",errorMessage:"Error de autenticación",technicalDetails:`Token expirado o inválido: ${e.message}`}:e&&e.status===500?{failureLevel:"strapi",errorMessage:"Error de servidor",technicalDetails:`Error en el servidor de Strapi: ${e.message}`}:{failureLevel:"unknown",errorMessage:"Error inesperado al crear la plantilla",technicalDetails:`Error desconocido: ${e.message}`};function ni(e,a){const{clave:n,paramsTipo:s,currentTemplateForEdit:o,isEditTemplate:i,setDisableField:r,setClaveParams:c,isDuplicateTemplate:m,templateFormData:l}=Fe(),{tasks_api:d}=he(),{getFieldsByStep:p,dropdownFunctionsUpdateFormData:h,templateFields:f}=Ht(),g=()=>{var R;try{const N={},D=e(),v=ai(D),{step1:U}=v,K=[];N.clave=n,U.categoria!=""&&(N.categoria=U.categoria);for(const[J,H]of Object.entries(v))for(const[O,S]of Object.entries(H)){const B={id:null,params_tipo:{id:null}};if(S!=""){const k=s[O];if(O==="categoria"){const q=f.find(W=>W.key==="categoria"),ee=(R=q==null?void 0:q.params_plantillas)==null?void 0:R.find(W=>W.reference_id===S);B.id=ee==null?void 0:ee.id}else B.id=S;B.params_tipo.id=k,K.push(B)}}return Object.keys(K).length>0&&(N.params_plantillas=K),N}catch(N){console.log(N)}},y=async R=>{var N;try{let D=null;return i?D=await d.put(`/api/plantillas/${o.id}`,{data:R}):D=await d.post("/api/plantillas",{data:R}),D.data?be(D.data):null}catch(D){throw console.error("Error en saveTemplateToStrapi:",{error:D.message,status:(N=D.response)==null?void 0:N.status}),D}},w=async R=>{var N;try{const D=Pe.stringify({filters:{plantilla:{id:R}},populate:{graph_layout:!0}},{encodeValuesOnly:!0}),v=await d.get(`/api/plantillas/plantilla-tareas-grafico?${D}`);return v.data?be(v.data.data):null}catch(D){throw console.error("Error en getTemplateWithTasks:",{error:D.message,status:(N=D.response)==null?void 0:N.status}),D}},j=async(R,N,D)=>{var v,U,K,J,H,O,S;try{const B=await w(R),k=await w(N);if(!B||!B.tarea_plantillas)return console.warn("No se encontraron tareas para duplicar en la plantilla original"),null;const q=new Map,ee=new Map;let W=1;B.tarea_plantillas.forEach(Q=>{let I=null;Q.start?I=D:I=-(Date.now()+W++),q.set(Q.id,I)}),(U=(v=B.graph_layout)==null?void 0:v.snapshot)!=null&&U.nodes&&B.graph_layout.snapshot.nodes.forEach(Q=>{const I=`node-${Date.now()}-${Math.random().toString(36).substr(2,9)}`;ee.set(Q.id,I)});const re=B.tarea_plantillas.filter(Q=>!Q.start).map(Q=>{var A,G,P,C;return{id:q.get(Q.id),uuid:crypto.randomUUID(),reference_graph:Q.reference_graph,texto_corto:Q.texto_corto,texto_largo:Q.texto_largo||null,prioridad:Q.prioridad,nivel_dificultad:Q.nivel_dificultad,duracion:Q.duracion,start:Q.start,type:Q.type||"task",equipo:((A=Q.equipo)==null?void 0:A.id)||null,responsable:((G=Q.responsable)==null?void 0:G.id)||null,plantilla:{id:N,clave:B.clave,categoria:B.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:[],id_t_requerida:q.get((P=Q.id_t_requerida)==null?void 0:P.id)||null,ids_t_dependientes:[],tarea_padre:q.get((C=Q.tarea_padre)==null?void 0:C.id)||null,tareas:[]}});let Z=null;if(B.graph_layout){const Q=k.tarea_plantillas.find(I=>I.start===!0);Z={...B.graph_layout,id:(K=k.graph_layout)==null?void 0:K.id,snapshot:{...B.graph_layout.snapshot,edges:B.graph_layout.snapshot.edges.map(I=>{if(I.source==="start")return{...I,data:{...I.data,childId:re.find(A=>A.reference_graph===I.target).id,parentId:Q.id}};{const A=re.find(G=>G.reference_graph===I.target);return{...I,data:{...I.data,childId:A==null?void 0:A.id,parentId:(A==null?void 0:A.id_t_requerida)||(A==null?void 0:A.tarea_padre)}}}}),nodes:((H=(J=B.graph_layout.snapshot)==null?void 0:J.nodes)==null?void 0:H.map(I=>{let A={};return I.type==="start"?A={...I,data:{...I.data,tareaId:Q.id}}:A={...I,data:{tareaId:null}},A}))||[]}}}if(!Z)throw console.error("Error: duplicatedGraphLayout es null, no se puede guardar"),new Error("No se pudo crear el graph_layout para la plantilla duplicada");const E={graph_layout:Z,tasks:{created:re,updated:[],deleted:[]}},z=await d.post("/api/tareas/save-tareas-grafico",{data:E});if(z.data&&z.status===200){const Q=await w(N),I=new Map;Q.tarea_plantillas.forEach(P=>I.set(P.reference_graph,P.id));let A=Q.graph_layout;return(!((O=A==null?void 0:A.snapshot)!=null&&O.nodes)||A.snapshot.nodes.length===0)&&(console.log("Graph layout vacío, reconstruyendo desde el original..."),A=Z),(S=A==null?void 0:A.snapshot)!=null&&S.nodes&&(A.snapshot.nodes=A.snapshot.nodes.map(P=>{var T;const C={...P,position:P.position||{x:0,y:0}},$=C.id,L=I.get($);if(L)return{...C,data:{...C.data,id:L,tareaId:L}};if((T=C.data)!=null&&T.tareaId){const V=Q.tarea_plantillas.find(Y=>Y.reference_graph===$);if(V)return{...C,data:{...C.data,id:V.id,tareaId:V.id}}}return C})),await d.put(`/api/plantillas/${N}`,{data:{graph_layout:A}}),await w(N)}return null}catch(B){throw console.error("Error al duplicar las tareas de la plantilla:",B),B}},b=async()=>{var R,N;try{let D=g();const v=await y(D);if(!v)return{success:!1,message:"No se pudo guardar el flujo de trabajo en Strapi",error:"templateData es null"};const U=Pe.stringify({filters:{id:{$eq:v.id}},populate:{tarea_plantillas:{filters:{start:{$eq:!0}}}}},{encodeValuesOnly:!0}),{data:K}=await d.get(`/api/plantillas?${U}`),H=be(K.data)[0].tarea_plantillas[0].id;if(m&&(o!=null&&o.id))try{const S=await j(o.id,v.id,H);return S?{success:!0,message:"Flujo de trabajo duplicado completamente con todas sus tareas",data:S}:{success:!0,message:"Flujo de trabajo creado, pero no se pudieron duplicar las tareas",data:await w(v.id)}}catch(S){return console.error("Error al duplicar tareas:",S),{success:!0,message:"Flujo de trabajo creado, pero hubo un error al duplicar las tareas",data:await w(v.id)}}const O=await w(v.id);return O?{success:!0,message:"Flujo de trabajo creado y sincronizado completamente",data:O}:{success:!1,message:"No se pudieron obtener los datos completos del flujo de trabajo",error:"completeData es null"}}catch(D){const v=si(((N=(R=D==null?void 0:D.response)==null?void 0:R.data)==null?void 0:N.error)||D);return console.error("Error al guardar el flujo de trabajo: ",{level:v.failureLevel,message:v.errorMessage,technicalDetails:v.technicalDetails}),{success:!1,message:v.errorMessage||"Error al guardar el flujo de trabajo",error:v.technicalDetails||D.message}}},_=()=>{const R=o==null?void 0:o.params_plantillas;if(!(R!=null&&R.length))return;let N={};[1,2,3].forEach(v=>{const U=`step${v}`;N[U]={},p(v).forEach(J=>{var O;const H=R.find(S=>S.params_tipo.key===J.key);if(H){let S=null;if(J.key==="categoria"){const B=(O=J.params_plantillas)==null?void 0:O.find(k=>k.id===H.id);S=(B==null?void 0:B.reference_id)||H.id}else S=H.id;N[U][J.key]=S}})}),a(N)},M=()=>{var N;const R=o==null?void 0:o.params_plantillas;if(R!=null&&R.length)for(const D of R){const{params_tipo:{id:v,key:U},name:K,id:J}=D,H=f.find(S=>S.key===U),O=(N=H==null?void 0:H.params_plantillas)==null?void 0:N.find(S=>S.id===J);h[U]&&h[U](K,v),O&&c({field:U,value:O.abbreviation})}},F=()=>{try{const{fase_plantilla:R,modo_configuracion:N,formato_salida:D,tipo_medio:v}=l;if(R==="Venta")r({fields:["fase_plantilla","tipo_plantilla","modo_configuracion","categoria","tipo_medio"],value:!1}),N==="Default"?(r({fields:["tipo_medio","formato_salida"],value:!1}),r({fields:["medio_especifico"],value:!0}),["Sitios Fijos","Vallas Móviles","Indoors"].includes(v)||r({fields:["formato_salida","medio_especifico"],value:!0}),D==="Digital"?(r({fields:["responsable_impresion"],value:!0}),r({fields:["pertenencia_medio","ubicacion_medio"],value:!1})):r({fields:["responsable_impresion","pertenencia_medio","ubicacion_medio"],value:!1})):(["Sitios Fijos","Indoors"].includes(v)&&r({fields:["formato_salida","medio_especifico"],value:!1}),["Vallas Móviles"].includes(v)&&(r({fields:["formato_salida"],value:!1}),r({fields:["medio_especifico"],value:!0})),["Camiones","Brand Riders"].includes(v)&&r({fields:["formato_salida","medio_especifico"],value:!0}),D==="Digital"?(r({fields:["responsable_impresion"],value:!0}),r({fields:["pertenencia_medio","ubicacion_medio"],value:!1})):r({fields:["responsable_impresion","pertenencia_medio","ubicacion_medio"],value:!1}));else if(r({fields:["modo_configuracion"],value:!1}),r({fields:["tipo_plantilla","categoria"],value:!0}),N=="Default"){const U=["formato_salida","medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"];r({fields:["tipo_medio"],value:!1}),r({fields:U,value:!0})}else["Sitios Fijos","Indoors"].includes(v)?(r({fields:["formato_salida"],value:!0}),r({fields:["medio_especifico"],value:!1})):r({fields:["responsable_impresion","pertenencia_medio","ubicacion_medio"],value:!0})}catch(R){console.error("Error al aplicar reglas de habilitar y deshabilitar campos",R)}};return u.useEffect(()=>{(i||m)&&o&&(_(),M())},[i,m,o]),u.useEffect(()=>{(i||m)&&l&&F()},[i,l,m]),{savePlantilla:b,getTemplateWithTasks:w}}const oi=()=>{const{watch:e,getValues:a}=Se.useFormContext(),{templateFormData:n,isDuplicateTemplate:s,currentTemplateForEdit:o}=Fe(),[i,r]=u.useState(!1),c=u.useRef(null),m=u.useRef(null),l=u.useRef(!1),d=e();return u.useEffect(()=>{if(!l.current&&s&&o){const h=setTimeout(()=>{c.current=a(),m.current={...n},l.current=!0,r(!1)},500);return()=>clearTimeout(h)}},[s,o,a,n]),u.useEffect(()=>{if(c.current&&m.current&&l.current){const h=a(),f=n,g=JSON.stringify(h)!==JSON.stringify(c.current),y=JSON.stringify(f)!==JSON.stringify(m.current);r(g||y)}},[d,n,a]),{hasChanges:i,resetChanges:()=>{c.current=null,m.current=null,l.current=!1,r(!1)}}},ri=({onReset:e})=>{const{hasChanges:a,resetChanges:n}=oi(),{setHasFormChanges:s}=Fe();return u.useEffect(()=>{s(a)},[a,s]),u.useEffect(()=>{e(n)},[e,n]),null},ii=({isOpen:e,onClose:a})=>{const{step:n,nextStep:s,prevStep:o,onStepChange:i}=Xr({limit:3}),r=st(A=>A.reset),{templateFields:c,resetTemplateFormData:m}=Ht(),{clave:l,resetClave:d,resetDisabledFields:p,isEditTemplate:h,setIsEditTemplate:f,refetch:g,isDuplicateTemplate:y,hasFormChanges:w,setIsDuplicateTemplate:j,setCurrentTemplateForEdit:b}=Fe(),{openTemplate:_}=Be(),[M,F]=u.useState(!1),[R,N]=u.useState(""),[D,v]=u.useState(!1),U=u.useRef(null),K=A=>{U.current=A},J=u.useMemo(()=>ti(c),[c]),H=n===1,O=n===3,S=H?"Cancelar":"Atrás",B=Se.useForm({mode:"onChange",defaultValues:J}),{trigger:k,reset:q,clearErrors:ee,getValues:W}=B,{savePlantilla:re}=ni(W,q),Z=u.useRef(!1);u.useEffect(()=>{e&&(r(),Z.current=!1)},[e,r]),u.useEffect(()=>{e&&!h&&!y&&!Z.current&&(q(J),m(),Z.current=!0)},[e,h,y,q,J,m]);const E=async()=>{if(await k()){if(n===3){if(!w&&y){N("Ya existe un proceso con éstos parámetros. Modifica al menos uno para poder duplicarlo."),v(!0);return}try{F(!0);const G=await re();if(G.success){const P=G.data;if(I(),Q(),v(!1),!h)try{await _({template:P,statusTemplate:ve.NEW})}catch(C){console.warn("La plantilla se creó exitosamente pero hubo un problema al abrirla:",C)}g()}else{const{error:P}=G;N(P),v(!0)}}catch(G){console.error("Error inesperado al guardar la plantilla:",G);return}finally{F(!1)}}s()}},z=()=>{N(""),v(!1)},Q=()=>{ee(),q(J),m(),p(),d(),z(),f(!1),j(!1),b(null),U.current&&U.current()},I=()=>{Q(),Z.current=!1,a(),console.log("cerrar modal")};return M?t.jsx(ot,{isLoading:M}):t.jsxs(Se.FormProvider,{...B,children:[t.jsx(ri,{onReset:K}),t.jsx(x.Modal,{isOpen:e,closeAtCancel:!1,onSuccess:E,cancelButtonText:S,successButtonText:O?h?"Guardar":"Crear":"Continuar",onCancel:H?I:o,onClose:I,size:"sm",iconConfig:{icon:ne.faFilePen},title:h?"Editar flujo de trabajo":"Nuevo flujo de trabajo",children:t.jsxs(x.Modal.Body,{children:[t.jsx("div",{className:"tm-flex tm-w-full tm-overflow-x-auto tm-pb-16 tm-pt-12",children:t.jsx("div",{className:"tm-flex tm-w-full",style:{justifyContent:"center",minWidth:"fit-content"},children:t.jsx(x.Stepper,{currentStep:n-1,onStepChange:A=>i(A+1),steps:[{title:"Paso 1",description:"INFORMACIÓN"},{title:"Paso 2",description:"DETALLES"},{title:"Paso 3",description:"PRODUCCIÓN"}]})})}),t.jsx("div",{className:"tm-flex tm-w-full tm-justify-center",children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-gap-0",children:[t.jsx("div",{className:"tm-bg-[#F0F0F0] tm-rounded-[100px] tm-p-2",style:{width:"fit-content",minWidth:"fit-content"},children:t.jsx("div",{className:"tm-font-bold tm-py-1 tm-p-[90px]",children:l})}),t.jsx("div",{className:"tm-bg-blue-500 tm-text-white tm-px-3 tm-py-1.5 tm-font-medium tm--mt-4",style:{borderRadius:"100px",fontSize:"10px"},children:"CLAVE"})]})}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-4 tm-p-16",children:[D&&t.jsx(x.Alert,{open:!0,color:"danger",message:R,className:"tm-mb-6",onClose:z}),t.jsx(ei,{step:n})]})]})})]})},li=({isOpen:e,onClose:a,replaceTemplate:n})=>t.jsx(t.Fragment,{children:t.jsx(x.Modal,{isOpen:e,closeAtCancel:!1,cancelButtonText:"Cancelar",successButtonText:"Abrir",onCancel:a,onClose:a,onSuccess:n,size:"sm",iconConfig:{icon:de.faExclamationTriangle},title:"Límite de flujos de trabajo",children:t.jsx(x.Modal.Body,{children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-overflow-auto tm-w-full tm-p-4 tm-gap-8",children:[t.jsx("div",{className:"tm-flex tm-justify-center tm-w-full",style:{minWidth:"fit-content"},children:t.jsx("div",{className:"tm-flex tm-justify-center tm-items-center tm-gap-[10px] tm-rounded-full tm-p-16",style:{backgroundColor:"#EBEEF9"},children:t.jsx(x.Icon,{name:de.faExclamationTriangle,size:"lg",color:"blue"})})}),t.jsx("div",{className:"tm-text-center tm-mt-6",children:t.jsx("h2",{className:"tm-text-[24px] tm-font-bold tm-text-brand tm-leading-tight",children:"¿Quieres continuar?"})}),t.jsx("div",{className:"tm-text-center tm-mt-2",children:t.jsx("div",{className:"tm-text-[12px] tm-font-normal tm-text-[#6B6B6B]",children:"Ya tienes 5 flujos de trabajo abiertos, si abres uno nuevo, se cerrará automáticamente el que lleva más tiempo sin usarse."})})]})})})}),ci=Ue.create(e=>({cachedTemplate:null,canCreateTemplate:!1,setCachedTemplate:a=>e({cachedTemplate:a}),clearCachedTemplate:()=>e({cachedTemplate:null}),setCanCreateTemplate:a=>{const n=!(a<5);e({canCreateTemplate:n})}})),di=({isOpen:e,onClose:a,discardChanges:n,saveAndExit:s})=>t.jsx("div",{children:t.jsx(x.Modal,{isOpen:e,closeAtCancel:!0,cancelButtonText:"Cancelar",successButtonText:"Guardar y salir",onCancel:a,onClose:a,onSuccess:s,size:"sm",iconConfig:{icon:de.faExclamationTriangle},title:"Cambios sin guardar",children:t.jsx(x.Modal.Body,{children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-overflow-auto tm-w-full tm-p-4 tm-gap-8",children:[t.jsx("div",{className:"tm-flex tm-justify-center tm-w-full",style:{minWidth:"fit-content"},children:t.jsx("div",{className:"tm-flex tm-justify-center tm-items-center tm-gap-[10px] tm-rounded-full tm-p-16",style:{backgroundColor:"#EBEEF9"},children:t.jsx(x.Icon,{name:de.faSave,size:"lg",color:"brand"})})}),t.jsx("div",{className:"tm-flex tm-flex-col tm-mx-6",children:t.jsx(x.Alert,{open:!0,variant:"outlined",color:"danger",showCloseButton:!1,message:"Tienes cambios sin guardar en este flujo de trabajo",title:"No has guardado",className:"tm-mt-8"})}),t.jsx("div",{className:"tm-text-center tm-mt-5",children:t.jsx("h2",{className:"tm-text-[24px] tm-font-bold tm-text-brand",children:"¿Qué deseas hacer antes de salir?"})}),t.jsx("div",{className:"tm-text-center tm-mt-1",children:t.jsx("div",{className:"tm-text-[12px] tm-font-normal tm-text-[#6B6B6B]",children:"Si sales ahora sin guardar se perderán los cambios actuales."})}),t.jsx("div",{className:"tm-flex tm-justify-center tm-mt-4",children:t.jsx(x.Button,{size:"xs",color:"secondary",onClick:()=>{n(),a()},children:"Descartar cambios"})})]})})})}),ys=({isOpen:e,onClose:a,publishTemplate:n})=>t.jsx(x.Modal,{isOpen:e,closeAtCancel:!0,cancelButtonText:"Cancelar",successButtonText:"Confirmar",onCancel:a,onClose:a,onSuccess:n,size:"sm",iconConfig:{icon:de.faArrowUp},title:"Publicar",children:t.jsx(x.Modal.Body,{children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-overflow-auto tm-w-full tm-p-8 tm-gap-16",children:[t.jsx("div",{className:"tm-flex tm-justify-center tm-w-full",style:{minWidth:"fit-content"},children:t.jsx(x.Icon,{name:de.faArrowUp,size:"lg",color:"blue",background:!0,padding:"lg"})}),t.jsx("div",{className:"tm-text-center",children:t.jsx("h2",{className:"tm-text-[24px] tm-font-bold tm-text-[#3658C1] tm-leading-tight",children:"¿Estás seguro de que deseas publicar este proceso?"})}),t.jsx("div",{className:"tm-text-center",children:t.jsx("div",{className:"tm-text-[12px] tm-font-normal tm-text-[#6B6B6B]",children:"Al publicar este proceso, estará disponible para su uso en los flujos correspondientes. Asegúrate de que toda la información sea correcta antes de continuar."})})]})})}),mi=()=>{const e="grid",a="create-edit",n=u.useRef(null),{isOpenModalLimit:s,setIsOpenModalLimit:o,setOpenModalCreateTemplate:i,openModalCreateTemplate:r,setOpenModalUnsavedChanges:c,openModalUnsavedChanges:m,openModalPublishTemplate:l,setOpenModalPublishTemplate:d,setCurrentTemplateForEdit:p,setIsDuplicateTemplate:h,setIsEditTemplate:f}=Fe(),{removeTemplateStates:g}=nt(),{mode:y,setMode:w,setViewMode:j,getViewMode:b}=Te(),{setCanCreateTemplate:_,canCreateTemplate:M}=ci(),F=y===e,{screens:R,get:N,delete:D,activeTemplate:v,activateTemplate:U,reorderingTemplates:K,replaceTemplate:J,saveTemplateChanges:H,publishTemplate:O,loadingPublishTemplate:S,loadingSaveChanges:B}=Be(),k=178,[q,ee]=u.useState([]),[W,re]=u.useState([]),[Z,E]=u.useState(null),[z,Q]=u.useState(!1),I=v!=null&&v.id?b(v.id):"readonly";u.useEffect(()=>{const X=()=>{if(!n.current)return;const ce=n.current.offsetWidth;let ie=0;const te=[],ue=[],fe=10,xe=n.current.querySelector("button:not([data-screen])"),pe=n.current.querySelector(".tm-mx-1");let ye=0;xe&&(ye+=xe.getBoundingClientRect().width),pe&&R.length>0&&(ye+=pe.getBoundingClientRect().width,ye+=fe);const Me=(je,ke)=>{const et=ke?54:0,Vt=(je==null?void 0:je.length)*8;return Math.max(80,Vt+40+et)},Ne=ce-k-ye;R.forEach((je,ke)=>{const pt=!!(je.isNew||je.badgeLabel),rt=Me(je.clave,pt),it=ke>0?fe:0,et=rt+it;ie+et<=Ne?(te.push(je),ie+=et):ue.push(je)}),ee(te),re(ue)},se=()=>{const ce=R.length;_(ce)};return R.length>0&&(X(),se(),window.addEventListener("resize",X)),()=>{window.removeEventListener("resize",X)}},[R,y]);const A=X=>X.estatus===ve.DIRTY||X.estatus===ve.NEW,G=async X=>{A(X)?(E(X.id),c(!0)):await D(X.id)},P=()=>d(!0),C=async()=>{await D(Z),await g(Z)},$=async()=>{await H(!1)},L=async()=>{await H()},T=()=>{var se,ce;const X=(ce=(se=v==null?void 0:v.graph_layout)==null?void 0:se.snapshot)==null?void 0:ce.nodes.length;Q(()=>X-1>=1)};u.useEffect(()=>{T()},[v,I]);const V=()=>!((v==null?void 0:v.estatus)==ve.IDLE&&z&&v.estatusFromStrapi!==Ee.PUBLISHED),Y=()=>{var se;const{nodes:X}=(se=v==null?void 0:v.graph_layout)==null?void 0:se.snapshot;return X==null?void 0:X.some(ce=>ce.type!=="start"&&(ce==null?void 0:ce.data.tarea_padre)===null&&(ce==null?void 0:ce.data.id_t_requerida)===null)},ae=()=>(v==null?void 0:v.estatus)===ve.IDLE||Y()?!0:!z,le=async()=>{await O(v.id)};return B||S?t.jsx(ot,{isLoading:B||S}):t.jsxs("div",{className:"tm-flex tm-gap-4 tm-justify-between tm-items-center tm-flex-wrap",children:[r&&t.jsx(ii,{isOpen:r,onClose:()=>i(!1)}),s&&t.jsx(li,{isOpen:s,onClose:()=>o(!1),replaceTemplate:J}),m&&t.jsx(di,{isOpen:m,onClose:()=>c(!1),discardChanges:C,saveAndExit:L}),l&&t.jsx(ys,{isOpen:l,onClose:()=>d(!1),publishTemplate:le}),t.jsxs("div",{className:"tm-flex tm-gap-2.5 tm-items-center tm-justify-between tm-flex-1 tm-flex-wrap",ref:n,children:[t.jsxs("div",{className:"tm-flex tm-gap-2.5 tm-items-center tm-justify-start tm-flex-1 tm-flex-wrap",children:[t.jsx(x.Button,{size:"xs",color:F?"primary":"secondary",onClick:()=>w(e),children:"Listado de flujos"}),R.length>0&&t.jsx(x.Separator,{vertical:!0,className:"tm-mx-1"}),R.filter(X=>q.some(se=>se.clave===X.clave)).map(X=>{const se=(v==null?void 0:v.clave)===X.clave&&y===a;return t.jsxs(x.Button,{"data-screen":X.clave,size:"xs",onClick:async()=>{await U(X),w(a,X.id)},color:se?"primary":"secondary",leftSlot:Ce.faFilePen,badgeColor:A(X)?"warning":void 0,onClickRightSlot:()=>G(X),rightSlot:Ce.faXmark,children:[X.clave," ",X.status]},X.id)})]}),W.length>0&&t.jsx(x.Popup,{absolute:!0,rightSlot:Ce.faAngleDown,label:`${W.length}+`,size:"xs",color:"secondary",children:t.jsx("div",{className:"tm-py-2 tm-gap-4",style:{minWidth:"280px"},children:t.jsx(x.List,{icon:Ce.faFilePen,items:W.map(X=>({id:X.id,label:X.clave})),className:"tm-p-8 tm-gap-4",onClick:async X=>{const se=await N(X.id);await K(se.id),await U(se),w("create-edit",se.id)}})})})]}),y===a?t.jsx("div",{className:"tm-flex tm-gap-4 tm-items-center tm-justify-end tm-flex-wrap",children:v.estatusFromStrapi!==Ee.PUBLISHED&&t.jsxs(t.Fragment,{children:[t.jsx(x.Button,{color:"secondary",size:"xs",leftSlot:Ce.faArrowUp,disabled:V(),onClick:P,children:"Publicar"}),I=="readonly"&&t.jsx(x.Button,{size:"xs",color:"primary",leftSlot:Ce.faEdit,onClick:()=>(v==null?void 0:v.id)&&j(v.id,"edit"),children:"Editar"}),I==="edit"&&t.jsx(x.Button,{size:"xs",color:"primary",leftSlot:Ce.faSave,onClick:$,disabled:ae(),children:"Guardar"})]})}):t.jsx(x.Button,{disabled:M,tooltip:M?"Límite de 5 plantillas con cambios sin guardar. Guarda y cierra alguna para crear una nueva.":"",leftSlot:Ce.faPlus,size:"xs",color:"primary",onClick:()=>{p(null),h(!1),f(!1),i(!0)},children:"Nuevo flujo"})]})},ui=({isOpen:e,onClose:a,deleteTemplate:n})=>t.jsx(x.AlertDialog,{title:"Eliminar Borrador",iconContent:de.faBan,heading:"¿Estás seguro?",subheading:"Si eliminas este borrador, también se borrarán todas sus tareas y conexiones con otros borradores.",icon:de.faBan,label:"Escribe 'Eliminar' para continuar",confirmationText:"Eliminar",isOpen:e,onClose:a,onConfirm:n,placeholder:""}),pi=()=>{const{viewMode:e,setRefetch:a,openModalPublishTemplate:n,setOpenModalPublishTemplate:s,currentTemplateId:o,setOpenModalDeleteTemplate:i,openModalDeleteTemplate:r}=Fe(),{publishTemplate:c,deleteTemplate:m}=Be(),{debouncedSearch:l,filters:d}=rs("templates-container"),p=e==="list",[h,f]=u.useState(1),g=9,{data:y,isLoading:w,isFetching:j,refetch:b}=xs({page:h,pageSize:g,search:l,filters:d});u.useEffect(()=>{a(b)},[]),u.useEffect(()=>{f(1)},[d,l]);const{users:_}=Ze(),{getImageOBP:M}=he(),F=v=>{if(!(v!=null&&v.email))return"";const U=_==null?void 0:_[v==null?void 0:v.email];return U!=null&&U.image?M(U==null?void 0:U.image):""},R=u.useMemo(()=>{try{return!y||!_?[]:y.data.map(v=>{const U=F((v==null?void 0:v.updated_by)||(v==null?void 0:v.created_by));return{...v,updated_by:{...v.updated_by,image:U}}})}catch(v){return console.error("Error al mapear las plantillas:",v),[]}},[y,_]),N=async()=>{await c(o),await b()},D=async()=>{await m(o),await b()};return w||j?t.jsx(ot,{isLoading:w||j}):t.jsxs("div",{className:"tm-flex tm-flex-col tm-justify-between tm-gap-y-4 tm-h-full",children:[t.jsx(ys,{isOpen:n,onClose:()=>s(!1),publishTemplate:N}),t.jsx(ui,{isOpen:r,onClose:()=>i(!1),deleteTemplate:D}),t.jsx("div",{className:`tm-grid tm-gap-4 ${p?"tm-grid-cols-1":"tm-grid-cols-1 md:tm-grid-cols-2 lg:tm-grid-cols-3"}`,children:R.map(v=>t.jsx(ps,{fullWidth:p,template:v},v.id))}),t.jsx("div",{children:t.jsx(x.Pagination,{pageSize:g,pageCount:y==null?void 0:y.meta.pagination.pageCount,currentPage:h,onPageChange:v=>f(v)})})]})},js=()=>{var r,c,m,l;const e="grid",a="create-edit",{mode:n}=Te(),s=n===e,o=n===a,i=Le(d=>d.activeTemplate);return t.jsxs("div",{className:"tm-h-full tm-flex tm-flex-col tm-gap-y-6",children:[t.jsx(mi,{}),s&&t.jsx(pi,{}),o&&t.jsx(Qr,{initialNodes:((c=(r=i==null?void 0:i.graph_layout)==null?void 0:r.snapshot)==null?void 0:c.nodes)||[],initialEdges:((l=(m=i==null?void 0:i.graph_layout)==null?void 0:m.snapshot)==null?void 0:l.edges)||[]})]})},fi=()=>({header:t.jsx(mr,{}),body:t.jsx(js,{})});function gi(e){const{users:a}=uo(),{tasks_api:n,getImageOBP:s}=he(),o=u.useMemo(()=>a.data?a.data.map(c=>{const{image:m,id:l,name:d}=c,p=s(m);return{value:l,label:d,icon:p}}):[],[a.data]),i=async c=>{const m=Pe.stringify({populate:{params_plantillas:{fields:["id","abbreviation","name","active","tipomedio_nombre","reference_id"]}},sort:["order:asc"],fields:["id","step","key","label","order"]},{encodeValuesOnly:!0}),{data:l}=await c.get(`/api/params-tipos?${m}`);return be(l.data).flatMap((p,h)=>{const f={id:`group-${h+1}`,label:p.label,value:`group-${h+1}`,isGroupTitle:!0},g=p.params_plantillas.map(y=>({id:y.id,label:y.name,value:y.id,checked:!1,icon:"CheckCircleOutlined",iconColor:"blue"}));return[f,...g]})},r=me.useQuery({queryKey:["paramsPlantilla"],queryFn:()=>i(n),enabled:e==="templates-container",staleTime:1e3*60*30});return{userOptions:o,paramsPlantillasOptions:r.data||[]}}const hi={estatus:{label:"Estatus del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[{value:"draft",label:"Borrador"},{value:"published",label:"Publicada"}],keyName:"estatus"},publication_date:{label:"Fecha de publicación",placeholder:"Ingresa una fecha...",type:"date",keyName:"publication_date"},propietario:{label:"Encargado del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[],keyName:"propietario"},created_by:{label:"Creador del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[],keyName:"created_by"},updated_by:{label:"Editor del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[],keyName:"updated_by"},params_plantillas:{label:"Parámetro del flujo",type:"group",placeholder:"Selecciona uno o varios...",options:[],keyName:"params_plantillas"}},xi={createdAt:{label:"Fecha de creación",placeholder:"Selecciona una fecha...",type:"date",keyName:"createdAt"},integrantes_min:{label:"Mínimo de integrantes",type:"input",placeholder:"Ej: 1",keyName:"integrantes_min"},integrantes_max:{label:"Máximo de integrantes",type:"input",placeholder:"Ej: 10",keyName:"integrantes_max"}},bi={"templates-container":hi,"teams-container":xi,"kanban-general":null,"lista-campanias":null,"kanban-campania":null},yi=e=>({inputFilters:bi[e]||null}),ji=e=>{const{inputFilters:a}=yi(e),{userOptions:n,paramsPlantillasOptions:s}=gi(e);return{inputFilters:u.useMemo(()=>{if(a&&n.length>0&&s.length>0){const i=a;return[{...i.estatus},{...i.publication_date},{...i.propietario,options:n},{...i.created_by,options:n},{...i.updated_by,options:n},{...i.params_plantillas,options:s}]}return null},[e,a,n,s])}};function wi(){const{setFilters:e}=ut(),{refetch:a}=Fe();return{handleApplyFilters:s=>{let o={...s};o=Object.fromEntries(Object.entries(o).filter(([i,r])=>!(r===""||r===null||Array.isArray(r)&&r.length===0))),"publication_date"in o&&o.publication_date!==""&&(o={...o,publication_date:Tt(o.publication_date).format("YYYY-MM-DD")}),e(o,"templates-container"),a&&a()}}}const Ta="templates-container";function vi(){const{mode:e}=Te(),{inputFilters:a}=ji(Ta),{handleApplyFilters:n}=wi(),{viewMode:s,setViewMode:o}=Fe();return e!=="grid"?null:t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-2.5 md:tm-flex-nowrap",children:[t.jsx(os,{path:Ta}),t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-x-2.5 md:tm-flex-nowrap",children:[a&&t.jsx(x.Filters,{filters:a,onApply:n}),t.jsx(x.Button,{size:"xs",color:"secondary",colorIcon:"neutral",icon:s==="list"?ne.faGrid2:ne.faList,className:"tm-min-w-fit",onClick:()=>o(s==="list"?"grid":"list")})]})]})}const Ct={id:null,uid:0,esEncargado:!1,idUser:{id:0,username:"",email:"",provider:"",confirmed:!1,blocked:!1,createdAt:"",updatedAt:"",nombre:""},miembros:[],miembro_padre:null,createdAt:new Date().toISOString(),updatedAt:new Date().toISOString()},Gt="Project Manager",ws=({open:e,handleChange:a,children:n,title:s="¿Estás seguro?",onConfirm:o,contentLabel:i="",confirmLabel:r="Aceptar",cancelLabel:c="Regresar",isLoading:m=!1})=>t.jsx(x.Modal,{isOpen:e,onClose:()=>a(!1),onCancel:()=>a(!1),onSuccess:o,size:"xs",title:s,disableEscapeClose:!0,disableOutsideClick:!0,disableOutsideTab:!0,children:t.jsxs(x.Modal.Body,{children:[t.jsx(x.Text,{children:i}),n&&n]})}),_i=({member:e,level:a,isUpdate:n=!1,addHandler:s,updateHandler:o,removeHandler:i,updateMemberHandler:r})=>{var J,H,O;const{users:c,isLoading:m}=Ut(),{users:l,isLoading:d}=Ze(),{getImageOBP:p}=he(),[h,f]=u.useState(!1),[g,y]=u.useState(n?e:{...Ct,miembro_padre:a>1?e:null}),[w,j]=u.useState(null),[b,_]=u.useState({id:0,nombre:"",email:""}),[M,F]=u.useState(!1);u.useEffect(()=>{var S;j(l==null?void 0:l[(S=g==null?void 0:g.idUser)==null?void 0:S.email])},[g,l]),u.useEffect(()=>{e&&y({...e,miembro_padre:a>1?e.miembro_padre:null})},[e,a]);const R=u.useMemo(()=>(c||[]).map(S=>{var q,ee;const B=l==null?void 0:l[S.email??""],k=B!=null&&B.image?p(B.image):"";return{...S,label:S.name,value:S.id,subtitle:S.email??"",avatar:((ee=(q=S.name)==null?void 0:q.slice(0,2))==null?void 0:ee.toUpperCase())??"",avatarUrl:k}}),[c,l,p]),N=()=>{f(!1),_({id:0,nombre:"",email:""})},D=({id:S,name:B,email:k})=>{const q={...g,idUser:{...g.idUser,id:S,nombre:B,email:k}};y(q),o(q),_({id:S,nombre:B,email:k})},v=async()=>{if(!b.nombre&&!b.email){N();return}try{g.id&&r({user_id:b.id,miembro_id:e.id});const S={...g,idUser:{...g.idUser,id:b.id,nombre:b.nombre,email:b.email}};y(S),o(S),j(l==null?void 0:l[b.email]),N()}catch(S){x.toast.error(S instanceof Error?S.message:"Error al actualizar el colaborador")}},U=()=>{const S={...Ct,uid:new Date().getTime()+Math.floor(Math.random()*1e3),miembro_padre:e,miembros:[]};s(S)},K=()=>{i(e),F(!1)};return d||m?null:t.jsxs("div",{className:"tm-flex tm-items-baseline tm-justify-between",children:[M&&t.jsx(ws,{open:M,handleChange:F,onConfirm:K,contentLabel:"Estás eliminando el colaborador seleccionado"}),t.jsxs("div",{className:"tm-flex tm-flex-1 tm-justify-between tm-gap-y-4 tm-mb-2",children:[t.jsxs("div",{children:[t.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-6 tm-mb-2",children:(J=g==null?void 0:g.idUser)!=null&&J.email&&!h?t.jsxs(t.Fragment,{children:[t.jsx(Ae,{size:"m",alt:((H=g==null?void 0:g.idUser)==null?void 0:H.nombre)??"Avatar",imageUrl:w!=null&&w.image?p(w.image):""}),t.jsx("p",{className:"tm-text-body-sm-regular tm-font-body-sm-regular tm-leading-body-sm-regular tm-tracking-body-sm",children:(O=g==null?void 0:g.idUser)==null?void 0:O.nombre})]}):t.jsx(x.Dropdown,{placeholder:"Seleccionar colaborador",options:R,valueName:"name",idName:"id",listVariant:"user",absolute:!0,closeOnClickOutside:!0,searchable:!0,searchPlaceholder:"Buscar colaborador...",onOptionSelect:S=>{D({id:S.id,name:S.name,email:S.email})}})}),t.jsx(x.Button,{onClick:U,leftSlot:ne.faPlus,size:"xxs",color:"tertiary",children:"Añadir colaborador"})]}),t.jsxs("div",{className:"tm-flex tm-gap-x-4",children:[h?t.jsxs(t.Fragment,{children:[t.jsx(x.Button,{onClick:N,icon:ne.faXmark,size:"xs",color:"secondary",tooltip:"Cancelar"}),t.jsx(x.Button,{onClick:v,icon:ze.faCheck,size:"xs",color:"primary",tooltip:"Guardar"})]}):t.jsx(x.Button,{onClick:()=>f(!0),icon:ne.faPencil,size:"xs",color:"tertiary",tooltip:"Editar"}),t.jsx(x.Button,{onClick:()=>F(!0),icon:ne.faTrash,size:"xs",color:"destructive",tooltip:"Eliminar"})]})]})]})},vs=({members:e,level:a=1,isUpdate:n=!1,setData:s})=>{const o=()=>{s(i=>({...i,miembros:[...i.miembros,{...Ct,uid:new Date().getTime()+Math.floor(Math.random()*1e3)}]}))};return t.jsxs("div",{children:[(e==null?void 0:e.length)===0&&a===1&&t.jsx("div",{className:"tm-flex tm-justify-end",children:t.jsx(x.Button,{size:"xxs",color:"tertiary",leftSlot:ze.faPlus,onClick:o,children:" Agregar miembro del equipo "})}),(e==null?void 0:e.length)>0&&(e==null?void 0:e.map(i=>t.jsx(Ti,{isUpdate:n,member:i,level:a,setData:s},i.uid)))]})},Ti=({member:e,level:a,isUpdate:n=!1,setData:s})=>{const o=l=>{s(d=>{if(!l.miembro_padre)return{...d,miembros:[...d.miembros,l]};const p=h=>h==null?void 0:h.map(f=>f.uid===l.miembro_padre.uid?{...f,miembros:[...f.miembros||[],l]}:f.miembros&&f.miembros.length>0?{...f,miembros:p(f.miembros)}:f);return{...d,miembros:p(d.miembros)}})},i=l=>{s(d=>{const p=h=>h.map(f=>f.uid===l.uid?(f.miembros&&f.miembros.length>0&&f.miembros.forEach(g=>{g.miembro_padre=l}),{...l,miembros:f.miembros||[]}):f.miembros&&f.miembros.length>0?{...f,miembros:p(f.miembros)}:f);return{...d,miembros:p(d.miembros)}})},r=l=>{var p;const d=[];return l.id&&d.push(l.id),(p=l.miembros)!=null&&p.length&&l.miembros.forEach(h=>{d.push(...r(h))}),d},c=l=>{s(d=>{const p=r(l),h=g=>g.filter(y=>y.uid!==l.uid).map(y=>({...y,miembros:y.miembros?h(y.miembros):[]})),f=d.miembros_actualizar.filter(g=>!p.includes(g.miembro_id));return{...d,miembros:h(d.miembros),miembros_eliminar:[...d.miembros_eliminar,...p],miembros_actualizar:f}})},m=l=>{s(d=>d.miembros_actualizar.some(h=>h.miembro_id===l.miembro_id)?d:{...d,miembros_actualizar:[...d.miembros_actualizar,l]})};return t.jsxs("div",{"data-id":e.uid,style:{paddingLeft:a===1?0:"30px",marginTop:a===1?"15px":"0px",paddingBottom:"5px"},children:[t.jsx(_i,{isUpdate:n,level:a,member:e,addHandler:o,updateHandler:i,removeHandler:c,updateMemberHandler:m}),Array.isArray(e.miembros)&&e.miembros.length>0&&t.jsx(vs,{isUpdate:n,members:e.miembros,level:a+1,setData:s})]},e.uid)},Ci=(e=7)=>{const a=(s,o)=>s>=o?{populate:"*"}:{miembro_padre:{fields:["id"]},idUser:{populate:"*"},miembros:{populate:a(s+1,o),filters:{idUser:{blocked:!1}}}};return{miembros:{populate:a(0,e),filters:{idUser:{blocked:!1}}}}},Ni=()=>"#"+Math.floor(Math.random()*16777215).toString(16),Si=({search:e,filters:a})=>{const n={};return e!=null&&e.trim()&&(n.nombre={$containsi:e.trim()}),a!=null&&a.createdAt&&(n.createdAt={$eq:a.createdAt}),n},Ei=({items:e})=>{if(!e)return{members:[],allMembers:[]};const a={};for(const r of e)a[r.uid]=r;const n=[],s=new Set,o=r=>{const c={...r};if(c.id&&(c.uid=c.id),c.uid&&!s.has(c.uid)&&(n.push(c),s.add(c.uid)),!c.miembros)return c;const m=c.miembros.map(l=>{const d={...l};d.id&&(d.uid=d.id);const p=a[d.uid];return o(p||d)}).filter(Boolean);return{...c,miembros:m}};return{members:e.filter(r=>r.miembro_padre===null).map(o),allMembers:n}},Pi=({items:e})=>e?e.map(a=>{const n=Ei({items:a.miembros});return{...a,integrantes:n.allMembers.length,miembros:n.members,miembros_planos:n.allMembers,miembros_eliminar:[],miembros_actualizar:[]}}):[],Ai=async({tasks_api:e,page:a=1,pageSize:n=10,search:s="",filters:o={}})=>{const i=Pe.stringify({filters:Si({search:s,filters:o}),populate:Ci(),sort:["createdAt:asc"],pagination:{page:a,pageSize:n}},{encodeValuesOnly:!0}),r=await e.get(`/api/equipos?${i}`);return r.data?{data:be(r.data.data),meta:r.data.meta}:{data:[],meta:{pagination:{page:a,pageSize:n,pageCount:0,total:0}}}},Ii=({page:e=1,pageSize:a=10,search:n="",filters:s={}})=>{const{tasks_api:o}=he();return me.useQuery({queryKey:["teams",e,a,n,s],queryFn:()=>Ai({tasks_api:o,page:e,pageSize:a,search:n,filters:s}),staleTime:1e3*60*60*24,placeholderData:me.keepPreviousData,select:i=>({data:Pi({items:(i==null?void 0:i.data)||[]}),meta:i==null?void 0:i.meta})})},Nt=e=>({...e,miembro_padre:e.miembro_padre?{id:e.miembro_padre.id,uid:e.miembro_padre.uid}:null,idUser:e.idUser?{id:e.idUser.id,nombre:e.idUser.nombre,email:e.idUser.email,image:e.idUser.image}:null,miembros:e.miembros?e.miembros.map(Nt):[]}),_s=()=>{const{tasks_api:e}=he(),a=me.useQueryClient(),n=async h=>{const f={...h,id:void 0,miembros:h.miembros.map(Nt)};return(await e.post("/api/registrar-equipo-miembros",{data:f})).data},s=async h=>(await e.delete(`/api/equipos/${h}`)).data,o=async(h,f)=>{const g={...f,id:void 0,miembros:f.miembros.map(Nt)};return(await e.patch(`/api/actualizar-equipo-miembros/${h}`,{data:g})).data},i=async(h,f,g)=>{const y=await e.put(`/api/miembros/${h}`,{data:{[f]:g}});if(!y.data)throw new Error("Error al actualizar el miembro");return y.data},{mutateAsync:r,isPending:c}=me.useMutation({mutationFn:s,onSuccess:()=>{a.invalidateQueries({queryKey:["teams"]})},onError:h=>{throw console.error("Failed to delete the team.",h),h}}),{mutateAsync:m}=me.useMutation({mutationFn:n,onSuccess:()=>{a.invalidateQueries({queryKey:["teams"]})},onError:h=>{throw console.error("Failed to update the team.",h),h},onMutate:async()=>{await a.cancelQueries({queryKey:["teams"]})}}),{mutateAsync:l}=me.useMutation({mutationFn:h=>o(h.teamId,h.data),onSuccess:()=>{a.invalidateQueries({queryKey:["teams"]})},onError:h=>{throw console.error("Failed to update the team.",h),h},onMutate:async()=>{await a.cancelQueries({queryKey:["teams"]})}}),{mutateAsync:d}=me.useMutation({mutationFn:h=>i(h.memberId,h.field,h.value),onError:h=>{throw console.error("Failed to update the member.",h),new Error("Error al actualizar el miembro")}});return{addTeamHandler:m,deleteTeamHandler:r,updateTeamHandler:l,updateMemberHandler:d,invalidateTeams:()=>{a.invalidateQueries({queryKey:["teams"]})},isLoadingDeleteTeam:c}},Di=(e,a,n)=>{const s=u.useCallback(o=>{e.current&&!e.current.contains(o.target)&&a(!1)},[e,a]);u.useEffect(()=>(n&&document.addEventListener("mousedown",s),()=>{document.removeEventListener("mousedown",s)}),[s,n])},Fi=({color:e,onChange:a})=>t.jsxs(t.Fragment,{children:[t.jsx("style",{children:`
|
|
10
|
+
`+I)})()},title:i?"Editar tarea":"Nueva tarea",successButtonText:i?"Actualizar":"Crear",disabledSuccessButton:!M,children:a.jsxs("form",{className:"tm-flex tm-flex-col tm-gap-4",children:[a.jsx(Ee.Controller,{control:p,name:"title",rules:{required:"El título es obligatorio",minLength:{value:3,message:"El título debe tener al menos 3 caracteres"}},render:({field:C})=>{var I;return a.jsx(g.Input,{fullWidth:!0,label:"Título",placeholder:"Ingresa el título de la tarea...",error:(I=y.title)==null?void 0:I.message,...C})}}),a.jsx(Ee.Controller,{control:p,name:"description",rules:{required:"La descripción es obligatoria",minLength:{value:10,message:"La descripción debe tener al menos 10 caracteres"}},render:({field:C})=>{var I;return a.jsx(g.Textarea,{className:"ui-w-full tw-w-full",placeholder:"Describe la tarea a realizar...",label:"Descripción",error:(I=y.description)==null?void 0:I.message,...C})}}),a.jsx(g.Separator,{}),a.jsx(Ee.Controller,{control:p,name:"priority",rules:{required:"La prioridad es obligatoria"},render:({field:C,fieldState:{error:I}})=>a.jsx(g.Dropdown,{fullWidth:!0,label:"Prioridad",placeholder:"Selecciona la prioridad...",options:Dr,error:I==null?void 0:I.message,value:C.value,onValueChange:T=>{C.onChange(T)}})}),a.jsx(Ee.Controller,{control:p,name:"difficulty",rules:{required:"La dificultad es obligatoria"},render:({field:C,fieldState:{error:I}})=>a.jsx(g.Dropdown,{fullWidth:!0,label:"Dificultad",placeholder:"Selecciona la dificultad...",options:Fr,error:I==null?void 0:I.message,value:C.value,onValueChange:T=>{C.onChange(T)}})}),a.jsx(Ee.Controller,{control:p,name:"duration",rules:{required:"La duración es obligatoria"},render:({field:C,fieldState:{error:I}})=>a.jsx(g.Dropdown,{fullWidth:!0,label:"Duración",placeholder:"Selecciona la duración...",options:Mr,error:I==null?void 0:I.message,value:C.value,onValueChange:T=>{C.onChange(T)}})}),a.jsx(g.Separator,{}),a.jsx(Ee.Controller,{control:p,name:"team",rules:{required:"El equipo es obligatorio"},render:({field:C,fieldState:{error:I}})=>a.jsx(g.Dropdown,{fullWidth:!0,label:"Equipo",placeholder:"Selecciona el equipo...",options:l,error:I==null?void 0:I.message,value:C.value,onValueChange:T=>{C.onChange(T)}})}),a.jsx(Ee.Controller,{control:p,name:"responsible",render:({field:C,fieldState:{error:I}})=>a.jsx(g.Dropdown,{fullWidth:!0,absolute:!0,label:"Responsable",placeholder:"Selecciona el responsable...",options:f,error:I==null?void 0:I.message,value:C.value,onValueChange:T=>{C.onChange(T)}})})]})})},kr=()=>{const{get:e}=Be(),t=Oe(i=>i.activeTemplate),{updateTaskInState:n,addTaskToState:s}=nt();return{updateTaskInTemplate:async(i,r)=>{if(!t)return console.error("No hay plantilla activa"),!1;try{const l=await e(t.id);if(!l)return console.error("Flujo de trabajo no encontrado"),!1;const d={id:i,uuid:r.uuid||crypto.randomUUID(),reference_graph:r.reference_graph||null,texto_corto:r.texto_corto||"",texto_largo:r.texto_largo||"",prioridad:r.prioridad||null,nivel_dificultad:r.nivel_dificultad||1,duracion:r.duracion||null,start:r.start||!1,equipo:r.equipo||null,responsable:r.responsable||null,plantilla:{id:l.id,clave:l.clave,categoria:l.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:r.plantilla_dependents||[],id_t_requerida:r.id_t_requerida||null,ids_t_dependientes:r.ids_t_dependientes||[],tarea_padre:r.tarea_padre||null,tareas:r.tareas||[]};i>0?await n({task:d}):await s({task:d})}catch(l){return console.error("❌ Error al actualizar tarea en plantilla:",l),!1}}}},ve={DEFAULT_CHILD_WIDTH:260,DEFAULT_CHILD_HEIGHT:80,MAGNETIC_CONNECTION_DISTANCE:800,GRAPH_LAYOUT_UPDATE_DELAY:100,START_NODE_ID:"start",DEFAULT_SOURCE_HANDLE:"bottom-source",DEFAULT_TARGET_HANDLE:"top-target"},ya={dependiente:{stroke:"#3B82F6",strokeDasharray:"5,5",strokeWidth:2},normal:{stroke:"#6B7280",strokeWidth:2}},wt=e=>{const t=e.map(n=>({...n}));return t.filter(n=>n.type==="group").forEach(n=>{const s=t.filter(m=>m.parentId===n.id);if(s.length===0)return;const o=Math.min(...s.map(m=>m.position.x)),r=Math.max(...s.map(m=>{var f;return m.position.x+(typeof((f=m.style)==null?void 0:f.width)=="number"?m.style.width:ve.DEFAULT_CHILD_WIDTH)}))-o,l=Math.min(...s.map(m=>m.position.y)),c=Math.max(...s.map(m=>{var f;return m.position.y+(typeof((f=m.style)==null?void 0:f.height)=="number"?m.style.height:ve.DEFAULT_CHILD_HEIGHT)}))-l;n.style={...n.style??{},width:r,height:c}}),t},vt=e=>e.source===ve.START_NODE_ID||e.target===ve.START_NODE_ID,Xe=e=>e===ve.START_NODE_ID,Lr=e=>e==="dependiente"?ya.dependiente:ya.normal,Or=(e,t,n)=>({id:e,type:"main",position:t,selected:!1,deletable:!0,data:n}),_t=(e,t,n,s,o,i=!1,r=null,l=null)=>{const d=Lr(s),c=i?ve.DEFAULT_SOURCE_HANDLE:n;return{id:`edge-${e}-${t}`,source:e,sourceHandle:c,target:t,targetHandle:ve.DEFAULT_TARGET_HANDLE,type:"smoothstep",deletable:!0,style:d,markerEnd:{type:"arrowclosed",width:12,height:12,color:d.stroke,strokeWidth:1},data:{connectionType:s,nodeType:o,isFromStartNode:i,parentId:r,childId:l}}},Br=(e,t)=>!(!e||!t||e===t),Rr=e=>{const{clientX:t,clientY:n}="changedTouches"in e?e.changedTouches[0]:e;return{x:t,y:n}},qr=e=>e.filter(t=>t.type==="position"&&t.dragging===!1),hs=e=>e.map(t=>t.id),xs=({nodes:e,edges:t,setNodes:n,setEdges:s,newNodePopup:o,connectionPopup:i,closeNewNodePopup:r,closeConnectionPopup:l,setIsConnectingExistingNodes:d})=>{const{screenToFlowPosition:c,getNode:m,setViewport:f,fitView:x}=oe.useReactFlow(),{get:p,update:h,addTaskUpdatingTemplate:y,addTemplateUpdatingTemplate:w}=Be(),j=Oe(G=>G.activeTemplate),b=de.useQueryClient(),v=Oe(G=>G.setActiveTemplate),{removeTaskFromState:M,updateNodeWithNewEdge:F,updateTaskInState:R}=nt(),C=u.useCallback(async G=>{const k=e.find(L=>L.id===G);if(!(k!=null&&k.data))return null;if(k.id===ve.START_NODE_ID){if(!j)return null;try{const L=await p(j.id),B=L.tarea_plantillas.find(q=>q.start===!0);return B!=null&&B.id?B.id:L.tarea_plantillas.length>0?L.tarea_plantillas[0].id:null}catch{return null}}const E=k.data.id;if(!E&&E!==0)return null;if(typeof E=="string"){if(E.includes("-"))return E;{const L=parseInt(E,10);return isNaN(L)?null:L}}else if(typeof E=="number")return E;return null},[e,j,p]),I=u.useCallback(async(G=e,k=t)=>{var E,L,B,q,X,H,re;if(!j){g.toast.warning("No hay template activo para actualizar layout");return}try{const Y=await p(j.id);if(!Y){g.toast.warning("Template no encontrado en IndexedDB");return}const P=(E=Y.graph_layout)==null?void 0:E.snapshot;if(!(!P||JSON.stringify(P.nodes)!==JSON.stringify(G)||JSON.stringify(P.edges)!==JSON.stringify(k))){console.log("🔄 No hay cambios en el layout, omitiendo actualización");return}const Q=G.filter(K=>{var S;return!((S=K.data)!=null&&S.isInternal)&&!K.parentId}).map(K=>{const{style:S,measured:N,data:U,selected:O,..._}=K,{expandedDimensions:W,isExpanded:Z,needsReExpansion:ae,...ie}=U||{},J=S?{...S,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{..._,style:J,data:ie}}),D=k.filter(K=>{var S;return!((S=K.data)!=null&&S.isInternal)}),A={...Y,graph_layout:{id:((L=Y.graph_layout)==null?void 0:L.id)||0,snapshot:{nodes:Q,edges:D,viewport:((q=(B=Y.graph_layout)==null?void 0:B.snapshot)==null?void 0:q.viewport)||{x:0,y:0,zoom:1}},history:((X=Y.graph_layout)==null?void 0:X.history)||[],zoom:((H=Y.graph_layout)==null?void 0:H.zoom)||1,position:((re=Y.graph_layout)==null?void 0:re.position)||{x:0,y:0}},estatus:we.DIRTY,updatedAt:new Date().toISOString()};await h(j.id,A),console.log("🗑️ [useFlowActions] Invalidando caché de la plantilla:",j.id),await b.invalidateQueries({queryKey:["template",j.id]}),await b.invalidateQueries({queryKey:["template"]}),console.log("✅ [useFlowActions] Caché invalidado exitosamente"),v(A)}catch(Y){console.error("❌ Error al actualizar template layout:",Y)}},[j,p,h,e,t,v]),T=u.useCallback(async(G=[],k=[],E,L)=>{var q,X,H,re,Y,P,$,Q,D,A,K,S;const B=E||(j==null?void 0:j.id);if(!B){g.toast.warning("No hay template ID disponible para actualizar");return}try{const N=await p(B);if(!N)return;const U=(H=(X=(q=N.graph_layout)==null?void 0:q.snapshot)==null?void 0:X.nodes)==null?void 0:H.filter(W=>{var Z;return!G.includes(W.id)&&!((Z=W.data)!=null&&Z.isInternal)&&!W.parentId}).map(W=>{const{style:Z,measured:ae,data:ie,...J}=W,{expandedDimensions:se,...ce}=ie||{},le=Z?{...Z,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...J,style:le,data:ce}}),O=((P=(Y=(re=N.graph_layout)==null?void 0:re.snapshot)==null?void 0:Y.edges)==null?void 0:P.filter(W=>{var Z;return!G.includes(W.source)&&!G.includes(W.target)&&!((Z=W.data)!=null&&Z.isInternal)}))||[],_={...N,graph_layout:{id:(($=N.graph_layout)==null?void 0:$.id)||0,snapshot:{nodes:U,edges:O,viewport:((D=(Q=N.graph_layout)==null?void 0:Q.snapshot)==null?void 0:D.viewport)||{x:0,y:0,zoom:1}},history:((A=N.graph_layout)==null?void 0:A.history)||[],zoom:((K=N.graph_layout)==null?void 0:K.zoom)||1,position:((S=N.graph_layout)==null?void 0:S.position)||{x:0,y:0}},estatus:we.DIRTY,updatedAt:new Date().toISOString()};await M({templateId:B,id:L||0}),await h(B,_),await b.invalidateQueries({queryKey:["template",B]}),await b.invalidateQueries({queryKey:["template"]}),B===(j==null?void 0:j.id)&&v(_)}catch(N){console.error("❌ updateAfterDeleted - Error al actualizar template layout:",N)}},[j,p,h,t,e,M,v]),V=u.useCallback(async(G,k,E)=>{if(!o||!j)return;const{nodeId:L,sourceNodeId:B,sourceHandleId:q}=o;if(B)try{const X=await C(B);if(!X)return;if(G==="plantilla"){const H=E;if(!(H!=null&&H.templateId))return;if(!await w(H.templateId,j.id,X,k)){g.toast.error("No se pudo agregar la plantilla. Intenta nuevamente."),r();return}try{const K=await p(j.id);if(K){const S=(U,O)=>{for(const _ of U){if(_.id===O||_.uuid===O)return _;if(_.tareas&&_.tareas.length>0){const W=S(_.tareas,O);if(W)return W}}return null},N=S(K.tarea_plantillas,X);if(N&&N.id){const U=(N.plantilla_dependents||[]).map(_=>typeof _=="object"&&_.id?{id:_.id}:typeof _=="number"?{id:_}:_),O={...N,plantilla_dependents:U,plantilla:{id:j.id,clave:K.clave,categoria:K.categoria||{id:0,nombre:"Sin categoría"}}};await R({task:O}),console.log("✅ Tarea padre agregada a templates_states.updated con plantilla_dependents:",N.id,O.plantilla_dependents)}}}catch(K){console.error("❌ Error al actualizar tarea padre en templates_states:",K)}const Y=c({x:o.position.x,y:o.position.y}),P=H.templateData||{id:H.templateId,nombre_plantilla:`Flujo de trabajo ${H.templateId}`,clave:`TPL-${H.templateId}`,estatus:"activo",categoria:null,counts_tasks:0,dias_duracion:0},$={id:L,type:"group",position:Y,selected:!1,deletable:!0,data:{id:H.templateId,templateId:H.templateId,type:"template",nombre_plantilla:P.nombre_plantilla||`Flujo de trabajo ${H.templateId}`,clave:P.clave||`TPL-${H.templateId}`,estatus:P.estatus||"activo",categoria:P.categoria||null,counts_tasks:P.counts_tasks||0,dias_duracion:P.dias_duracion||0,tarea_plantillas:P.tarea_plantillas||[],params_plantillas:P.params_plantillas||[],createdAt:P.createdAt||new Date().toISOString(),updatedAt:P.updatedAt||new Date().toISOString(),created_by:P.created_by||null,updated_by:P.updated_by||null}};n(K=>[...K,$]);const Q=q||ve.DEFAULT_SOURCE_HANDLE,D=Xe(B),A=_t(B,L,Q,k,"plantilla",D,X);s(K=>[...K,A]);try{const K=[...e,$],S=[...t,A];await I(K,S)}catch(K){console.error("❌ Error al actualizar layout después de agregar plantilla:",K)}}else if(G==="tarea"){const H=E;if(!H)return;const re=c({x:o.position.x,y:o.position.y}),Y=-new Date().getTime(),P={id:Y,reference_graph:L,title:H.title,description:H.description,priority:H.priority,difficulty:H.difficulty,duration:H.duration,team:H.team,responsible:H.responsible,parent:{data:{id:X}}},$=await y(P,j.id,k),Q=Or(L,re,$);n(S=>[...S,Q]);const D=q||ve.DEFAULT_SOURCE_HANDLE,A=Xe(B),K=_t(B,L,D,k,G,A,X,Y);s(S=>[...S,K]);try{const S=[...e,Q],N=[...t,K];await I(S,N)}catch(S){console.error("❌ Error al actualizar layout después de agregar tarea:",S)}setTimeout(()=>{try{const S=m(L);if(S){const N=window.innerWidth,U=window.innerHeight,O=N/2,_=U/2;f({x:O-S.position.x-130,y:_-S.position.y-40,zoom:1},{duration:800})}else x({padding:.1,duration:800})}catch{try{x({padding:.1,duration:800})}catch{}}},200)}r()}catch(X){console.error("❌ Error en createNodeFromPopup:",X)}},[o,j,y,w,C,c,n,s,r,I,e,t]),z=u.useCallback(async(G,k)=>{var q,X;if(console.log("🟢 createConnectionFromPopup - INICIO",{nodeType:G,connectionType:k}),!i){console.warn("⚠️ createConnectionFromPopup - No hay connectionPopup");return}const{sourceNodeId:E,sourceHandleId:L,targetNodeId:B}=i;console.log("🟢 createConnectionFromPopup - Datos de conexión:",{sourceNodeId:E,targetNodeId:B,sourceHandleId:L});try{if(!(window.validConnectionTypes||{dependiente:!0,hija:!0})[k]){console.warn("⚠️ createConnectionFromPopup - Tipo de conexión no válido:",k),g.toast.warning("Tipo de conexión no válido"),d(!1),l();return}const re=e.find(O=>O.id===E),Y=e.find(O=>O.id===B);console.log("🟢 createConnectionFromPopup - Nodos encontrados:",{sourceNode:re==null?void 0:re.id,targetNode:Y==null?void 0:Y.id,sourceData:re==null?void 0:re.data,targetData:Y==null?void 0:Y.data});const P=Y==null?void 0:Y.data,$=((q=re==null?void 0:re.data)==null?void 0:q.id)||E,Q=((X=Y==null?void 0:Y.data)==null?void 0:X.id)||B;console.log("🟢 createConnectionFromPopup - IDs extraídos:",{parentId:$,childId:Q});const D=_t(E,B,L||ve.DEFAULT_SOURCE_HANDLE,k,G,Xe(E),$,Q);console.log("🟢 createConnectionFromPopup - Nuevo edge creado:",D),s(O=>[...O,D]);const A=[...t,D],K=P.id||-Date.now(),S=P.reference_graph||B,N={id:K,uuid:P.uuid||crypto.randomUUID(),reference_graph:S,texto_corto:P.texto_corto||"",texto_largo:P.texto_largo||"",prioridad:P.prioridad||null,nivel_dificultad:P.nivel_dificultad||1,duracion:P.duracion||null,start:P.start||!1,equipo:P.equipo||null,responsable:P.responsable||null,plantilla:{id:P.plantilla.id,clave:P.plantilla.clave,categoria:P.plantilla.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:P.plantilla_dependents||[],ids_t_dependientes:P.ids_t_dependientes||[],tarea_padre:k==="hija"?{id:D.data.parentId}:null,id_t_requerida:k==="dependiente"?{id:D.data.parentId}:null,tareas:P.tareas||[],type:"task"};console.log("🟢 createConnectionFromPopup - taskForState creado:",N),console.log("🟢 createConnectionFromPopup - currentTemplate.id:",j.id);const U=e.map(O=>O.id===B?{...O,data:N}:O);console.log("🟢 createConnectionFromPopup - Actualizando nodos en React Flow..."),n(U),console.log("✅ createConnectionFromPopup - Nodos actualizados en React Flow"),console.log("🟢 createConnectionFromPopup - Actualizando template layout..."),await I(U,A),console.log("✅ createConnectionFromPopup - Template layout actualizado"),console.log("🟢 createConnectionFromPopup - Llamando a updateNodeWithNewEdge..."),await F({templateId:j.id,edge:D,task:N}),console.log("✅ createConnectionFromPopup - updateNodeWithNewEdge completado")}catch(H){console.error("❌ createConnectionFromPopup - Error al crear conexión:",H),console.error("❌ createConnectionFromPopup - Stack:",H.stack)}finally{console.log("🟢 createConnectionFromPopup - Limpiando estado..."),d(!1),l(),console.log("🟢 createConnectionFromPopup - FIN")}},[i,s,d,l,t,e,I]),ee=u.useCallback(async G=>{if(!o||!j){g.toast.warning("No hay newNodePopup o template activo para actualizar el nodo");return}const{nodeId:k}=o;if(!k){g.toast.warning("No se encontró nodeId en newNodePopup");return}try{const E=e.find(B=>B.id===k);if(!E){g.toast.warning(`No se encontró el nodo con ID: ${k}`);return}const L={...E,data:{...E.data,...G,id:E.data.id||E.id,type:E.data.type||E.data.type,updatedAt:new Date().toISOString()}};n(B=>B.map(q=>q.id===k?L:q));try{const B=e.map(q=>q.id===k?L:q);await I(B,t)}catch(B){g.toast.error("Error al actualizar layout después de actualizar nodo:",B)}r()}catch(E){g.toast.error("Error al actualizar el nodo:",E)}},[o,j,e,n,t,I,r]);return{createNodeFromPopup:V,createConnectionFromPopup:z,updateNodeFromPopup:ee,updateAfterDeleted:T}},zr=({data:e,id:t,isConnectable:n,selected:s})=>{const o=_e(z=>z.getViewMode),[i,r]=u.useState(!1),[l,d]=u.useState(e),c=Oe(z=>z.activeTemplate),m=Oe(z=>z.setActiveTemplate),{get:f,update:x}=Be(),{data:p}=Ia(),{users:h}=pt(),y=c!=null&&c.id?o(c.id):"readonly",{updateTaskInTemplate:w}=kr(),{setNodes:j,setEdges:b,getNodes:v,getEdges:M}=oe.useReactFlow(),F=de.useQueryClient(),{updateAfterDeleted:R}=xs({nodes:v(),edges:M(),setNodes:j,setEdges:b,newNodePopup:null,connectionPopup:null,closeNewNodePopup:()=>{},closeConnectionPopup:()=>{},setIsConnectingExistingNodes:()=>{}}),C=()=>{r(!0)},I=u.useCallback(async()=>{var L,B,q;const z=v().find(X=>X.id===t);if(!z){console.warn("⚠️ Nodo no encontrado para eliminar");return}const ee=[z],G=hs(ee),k=ee.length>0?(B=(L=ee[0])==null?void 0:L.data)==null?void 0:B.id:0;b(X=>X.filter(H=>!G.includes(H.source)&&!G.includes(H.target))),j(X=>X.filter(H=>H.id!==t));let E;for(const X of ee)try{const H=X.data;if((q=H==null?void 0:H.plantilla)!=null&&q.id){E=H.plantilla.id;break}}catch{}try{b(X=>((async()=>{await R(G,X,E,k)})().catch(H=>{console.error("❌ Error en updateAfterDeleted:",H)}),X))}catch(X){console.error("❌ Error en handleDeleteNode:",X)}},[t,v,M,j,b,R]),T=u.useCallback(async z=>{var ee,G,k,E,L,B,q,X,H,re;if(!c){console.warn("⚠️ MainNode.updateTemplateLayout - No hay template activo");return}try{const Y=await f(c.id);if(!Y){console.warn("⚠️ MainNode.updateTemplateLayout - Template no encontrado en IndexedDB");return}const P=(ee=Y.graph_layout)==null?void 0:ee.snapshot;if(!(!P||JSON.stringify(P.nodes)!==JSON.stringify(z))){console.log("🔄 MainNode.updateTemplateLayout - No hay cambios en nodos, omitiendo actualización");return}const Q=z.filter(K=>{var S;return!((S=K.data)!=null&&S.isInternal)&&!K.parentId}).map(K=>{const{style:S,measured:N,data:U,selected:O,..._}=K,{expandedDimensions:W,isExpanded:Z,needsReExpansion:ae,...ie}=U||{},J=S?{...S,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{..._,style:J,data:ie}}),D=(((k=(G=Y.graph_layout)==null?void 0:G.snapshot)==null?void 0:k.edges)||[]).filter(K=>{var S;return!((S=K.data)!=null&&S.isInternal)}),A={...Y,graph_layout:{id:((E=Y.graph_layout)==null?void 0:E.id)||0,snapshot:{...(L=Y.graph_layout)==null?void 0:L.snapshot,nodes:Q,edges:D,viewport:((q=(B=Y.graph_layout)==null?void 0:B.snapshot)==null?void 0:q.viewport)||{x:0,y:0,zoom:1}},history:((X=Y.graph_layout)==null?void 0:X.history)||[],zoom:((H=Y.graph_layout)==null?void 0:H.zoom)||1,position:((re=Y.graph_layout)==null?void 0:re.position)||{x:0,y:0}},estatus:we.DIRTY,updatedAt:new Date().toISOString()};await x(c.id,A),await F.invalidateQueries({queryKey:["template",c.id]}),await F.invalidateQueries({queryKey:["template"]}),c&&c.id===A.id&&m(A)}catch(Y){console.error("❌ MainNode.updateTemplateLayout - Error al actualizar template layout:",Y)}},[c,f,x,m,F]),V=async z=>{if(c){const ee=z.responsible,G=ee!==""&&ee!=null&&!Number.isNaN(Number(ee))?Number(ee):null,k=G!=null?h==null?void 0:h.find(q=>q.id===G):void 0,E=e.responsable&&typeof e.responsable=="object"&&"email"in e.responsable&&typeof e.responsable.email=="string"?e.responsable.email:"",L=G!=null?{id:G,email:(k==null?void 0:k.email)??E}:{id:null,email:""},B={...e,texto_corto:z.title,texto_largo:z.description,prioridad:z.priority?typeof z.priority=="number"?z.priority:parseInt(z.priority.toString()):null,nivel_dificultad:z.difficulty?typeof z.difficulty=="number"?z.difficulty:parseInt(z.difficulty.toString()):1,duracion:z.duration?typeof z.duration=="number"?z.duration:parseInt(z.duration.toString()):null,equipo:(()=>{var H;const q=Number(z.team)||null;if(!q)return{id:null};const X=(H=p==null?void 0:p.find(re=>re.value===q))==null?void 0:H.label;return{id:q,...X?{nombre:X}:{}}})(),responsable:L};await w(e.id,B),j(q=>{const X=q.map(H=>H.id===t?{...H,data:{...H.data,...B,tarea_padre:e.tarea_padre,id_t_requerida:e.id_t_requerida,updatedAt:new Date().toISOString()}}:H);return setTimeout(()=>T(X),0),X})}r(!1)};return u.useEffect(()=>{d(e)},[e]),a.jsxs("div",{className:`tm-border-[1px] tm-bg-surface-default tm-px-4 tm-py-2 tm-rounded-lg tm-transition-all tm-duration-200 tm-max-w-[423px] ${s?"tm-border-brand tm-shadow-02 tm-ring-2 tm-ring-blue-300 tm-ring-opacity-50":e.main?"tm-border-success tm-shadow-02":"tm-border-default tm-shadow-02"}`,children:[a.jsx(oe.Handle,{isConnectable:n,id:"top-target",type:"target",position:oe.Position.Top,className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default"}),a.jsx(oe.Handle,{isConnectable:n,id:"right-target",type:"target",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Right}),a.jsx(oe.Handle,{isConnectable:n,id:"bottom-target",type:"target",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Bottom}),a.jsx(oe.Handle,{isConnectable:n,id:"left-target",type:"target",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Left}),a.jsxs("div",{className:"tm-flex tm-h-full tm-flex-col tm-gap-y-8 tm-p-12 ",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-gap-x-4 ",children:[a.jsx(g.Text,{size:"lg",weight:"semibold",color:"primary",truncateLabel:!0,children:l.texto_corto}),!e.isInternal&&c.estatusFromStrapi!==Pe.PUBLISHED&&y!=="readonly"&&a.jsx("div",{children:e.type==="task"?a.jsx(g.Popup,{position:"right",absolute:!0,size:"xxs",pill:"pill",color:"secondary",icon:me.faEllipsis,containerClassName:"nopan nodrag",buttonClassName:"nopan nodrag",children:a.jsxs(g.List,{className:"tm-p-8 tm-gap-4",children:[a.jsx(g.ListItem,{icon:me.faEdit,onClick:C,children:"Editar"}),a.jsx(g.ListItem,{icon:me.faPlus,color:"red",onClick:I,children:"Eliminar"})]})}):a.jsx(g.Button,{size:"xxs",color:"secondary",pill:"pill",icon:me.faMaximize,className:"nopan"})})]}),a.jsx(g.Text,{size:"xs",weight:"regular",color:"tertiary",children:l.texto_largo}),a.jsxs("div",{className:"tm-flex tm-flex-row tm-flex-nowrap tm-items-center tm-gap-x-4 tm-justify-between md:tm-gap-x-6",children:[a.jsx(Nr,{duration:l.duracion}),a.jsx(Tr,{difficulty:l.nivel_dificultad}),a.jsx(Sr,{priority:l.prioridad}),a.jsx(vr,{equipo:l.equipo}),a.jsx(Ir,{responsible:l.responsable})]})]}),a.jsx(oe.Handle,{isConnectable:n,id:"top-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Top}),a.jsx(oe.Handle,{isConnectable:n,id:"right-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Right}),a.jsx(oe.Handle,{isConnectable:n,id:"bottom-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Bottom}),a.jsx(oe.Handle,{isConnectable:n,id:"left-source",type:"source",className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default",position:oe.Position.Left}),e.type==="task"&&i&&a.jsx(gs,{isOpen:i,onClose:()=>r(!1),onSuccess:V,editMode:!0,taskToEdit:l})]})},$r=async({tasks_api:e,page:t=1,pageSize:n=10,search:s="",filters:o={}})=>{const i={clave:{$notNull:!0},estatus:{$ne:Pe.DELETED},...s?{$or:[{nombre_plantilla:{$containsi:s}},{clave:{$containsi:s}}]}:{},...Object.keys(o).reduce((d,c)=>(Array.isArray(o[c])?d[c]={id:{$in:o[c]}}:d[c]=o[c],d),{})},r=Ce.stringify({filters:i,fields:["id","clave","estatus","dias_duracion","createdAt","publication_date"],count_tasks:!0,tarea_plantillas:!1,populate:{updated_by:{fields:["id","nombre","username","email"]},created_by:{fields:["id","nombre","username","email"]},params_plantillas:{fields:["id","name"],populate:{params_tipo:{fields:["id","key","label","order"]}}},tarea_plantillas:{fields:["id"],filters:{start:!0},populate:{tareas:{fields:["id"]},ids_t_dependientes:{fields:["id"]}}}},sort:{createdAt:"asc"},pagination:{page:t,pageSize:n}},{encodeValuesOnly:!0}),l=await e.get(`/api/plantillas/all-plantillas?${r}`);return l.data?{data:xe(l.data.data),meta:l.data.meta}:{data:[],meta:{pagination:{page:t,pageSize:n,pageCount:0,total:0}}}},bs=({page:e=1,pageSize:t=10,search:n="",filters:s={}})=>{const{tasks_api:o}=ge();return de.useQuery({queryKey:["templates",e,t,n,s],queryFn:()=>$r({tasks_api:o,page:e,pageSize:t,search:n,filters:s}),staleTime:1e3*60*60*24,placeholderData:de.keepPreviousData,select:i=>({data:(i==null?void 0:i.data)||[],meta:i==null?void 0:i.meta})})},ys=({isOpen:e,onClose:t,onSuccess:n,nodeDataType:s,parentNodeInfo:o})=>{var v,M,F,R;const i=_e(C=>C.addNodeWithType),[r,l]=u.useState(0),d=5,[c,m]=u.useState(1),[f,x]=u.useState("");u.useEffect(()=>{e&&(m(1),x(""),l(0))},[e]),u.useEffect(()=>{m(1)},[f]);const{data:p,isLoading:h}=bs({page:c,pageSize:d,search:f}),y=C=>{x(C.target.value)},w=()=>{var I;if(r===0)return;const C=(I=p==null?void 0:p.data)==null?void 0:I.find(T=>T.id===r);if(!C){console.error("No se encontró el flujo de trabajo seleccionado en los datos");return}n?n({templateId:r,templateData:C}):i&&i(s.id,s.type,s.connectionType)};if(h)return a.jsx("div",{children:"Cargando..."});if(!(p!=null&&p.data))return a.jsx("div",{children:"No hay datos disponibles"});const j=((M=(v=p.meta)==null?void 0:v.pagination)==null?void 0:M.total)||0,b=j===1?"flujo encontrado":"flujos encontrados";return a.jsx(g.Modal,{iconConfig:{icon:Ne.faPencil},isOpen:e,size:"lg",onSuccess:w,onClose:t,title:"Agregar flujo de trabajo",successButtonText:"Agregar",disableSuccessButton:r===0,closeAtSuccess:!0,children:a.jsxs(g.Modal.Body,{withPadding:!1,children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-justify-between tm-gap-6 tm-px-12 tm-py-3",children:[a.jsxs("p",{className:"tm-flex-1 tm-text-[14px] tm-text-neutral-500",children:[j," ",b]}),a.jsx(g.Input,{className:"tm-flex-1",leftSlot:Ne.faSearch,fullWidth:!0,placeholder:"Buscar por nombre, parámetros o estado...",value:f,onChange:y})]}),a.jsx(g.Separator,{}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-6 tm-p-12",children:[p.data.map(C=>a.jsx(ps,{mode:"modal",template:C,active:r===C.id,fullWidth:!0,onClick:l,withOptions:!1},C.id)),p.data.length===0&&a.jsx("div",{className:"tm-flex tm-items-center tm-justify-center tm-h-full",children:a.jsx("p",{className:"tm-text-[14px] tm-text-neutral-500",children:"No se encontraron flujos de trabajo con ese criterio de búsqueda"})})]}),a.jsx(g.Separator,{}),a.jsx("div",{className:"tm-mt-6",children:a.jsx(g.Pagination,{className:"tm-pt-0",pageSize:d,pageCount:((R=(F=p==null?void 0:p.meta)==null?void 0:F.pagination)==null?void 0:R.pageCount)||1,currentPage:c,onPageChange:C=>m(C)})})]})})},Ur=({data:e,id:t})=>{const n=_e(m=>m.addNodeWithType),[s,o]=u.useState(!1),[i,r]=u.useState(!1),[l,d]=u.useState({id:t,type:"tarea",connectionType:"dependiente"}),c=({type:m,connectionType:f})=>{n&&(d({id:t,type:m,connectionType:f}),m==="tarea"?o(!0):m==="plantilla"&&r(!0))};return console.log({data:e,id:t}),a.jsxs("div",{className:"tm-flex tm-items-center tm-justify-center",children:[l.type==="plantilla"&&a.jsx(ys,{isOpen:i,onClose:()=>r(!1),nodeDataType:l}),a.jsx(oe.Handle,{id:"top-target",type:"target",position:oe.Position.Top}),a.jsx(oe.Handle,{id:"right-target",type:"target",position:oe.Position.Right}),a.jsx(oe.Handle,{id:"bottom-target",type:"target",position:oe.Position.Bottom}),a.jsx(oe.Handle,{id:"left-target",type:"target",position:oe.Position.Left}),a.jsx(oe.Handle,{id:"top-source",type:"source",position:oe.Position.Top}),a.jsx(oe.Handle,{id:"right-source",type:"source",position:oe.Position.Right}),a.jsx(oe.Handle,{id:"bottom-source",type:"source",position:oe.Position.Bottom}),a.jsx(oe.Handle,{id:"left-source",type:"source",position:oe.Position.Left}),a.jsx(g.Popup,{position:"right",absolute:!0,size:"md",rounded:!0,icon:me.faPlus,containerClassName:"nopan",buttonClassName:"nopan",children:a.jsxs(g.List,{className:"nopan nodrag",children:[a.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Tarea"}),a.jsx(g.ListItem,{icon:me.faArrowUpLeft,iconColor:"neutral",onClick:()=>c({type:"tarea",connectionType:"dependiente"}),children:"Dependiente"}),a.jsx(g.ListItem,{icon:me.faArrowDownRight,iconColor:"neutral",onClick:()=>c({type:"tarea",connectionType:"hija"}),children:"Hija"}),a.jsx(g.ListSeparator,{}),a.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Flujo de trabajo"}),a.jsx(g.ListItem,{icon:me.faArrowUpLeft,iconColor:"neutral",onClick:()=>c({type:"plantilla",connectionType:"dependiente"}),children:"Dependiente"}),a.jsx(g.ListItem,{icon:me.faArrowDownRight,iconColor:"neutral",onClick:()=>c({type:"plantilla",connectionType:"hija"}),children:"Hija"})]})})]})},Hr=({isOpen:e,position:t,onClose:n,createNodeFromPopup:s,parentNodeInfo:o})=>{const[i,r]=u.useState(!1),[l,d]=u.useState(!1),[c,m]=u.useState(null);if(!e)return null;const f=(w,j)=>{m({type:w,connectionType:j}),w==="tarea"?r(!0):w==="plantilla"&&d(!0)},x=()=>{r(!1),m(null),n()},p=()=>{d(!1),m(null),n()},h=w=>{c&&s(c.type,c.connectionType,w),x()},y=w=>{c&&w&&s(c.type,c.connectionType,w),p()};return a.jsxs(a.Fragment,{children:[!i&&!l&&a.jsx("div",{className:"tm-fixed tm-inset-0 tm-z-50",onClick:n}),!i&&!l&&a.jsx("div",{className:"tm-fixed tm-z-50 tm-bg-surface-default tm-rounded-lg tm-shadow-02 tm-border tm-border-black-light tm-min-w-[200px]",style:{left:t.x+50,top:t.y-100},children:a.jsx("div",{className:"tm-p-2",children:a.jsxs(g.List,{children:[a.jsx("p",{className:"tm-text-sm tm-p-4 tm-gap-4 tm-font-medium tm-text-neutral-300",children:"Tarea"}),a.jsx(g.ListItem,{icon:me.faArrowUpLeft,iconColor:"neutral",onClick:()=>f("tarea","dependiente"),children:"Dependiente"}),a.jsx(g.ListItem,{icon:me.faArrowDownRight,iconColor:"neutral",onClick:()=>f("tarea","hija"),children:"Hija"}),a.jsx(g.ListSeparator,{}),a.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Flujo de trabajo"}),a.jsx(g.ListItem,{icon:me.faArrowUpLeft,iconColor:"neutral",onClick:()=>f("plantilla","dependiente"),children:"Dependiente"})]})})}),i&&c&&a.jsx(gs,{isOpen:i,onClose:x,onSuccess:h,nodeDataType:{id:"",type:c.type,connectionType:c.connectionType},parentNodeInfo:o}),l&&c&&a.jsx(ys,{isOpen:l,onClose:p,onSuccess:y,nodeDataType:{id:"",type:c.type,connectionType:c.connectionType},parentNodeInfo:o})]})};function Kr({reactFlowWrapper:e,nodes:t}){const{setViewport:n,getViewport:s}=oe.useReactFlow(),{zoom:o}=oe.useViewport(),i=Math.round(o*100),[r,l]=u.useState([]),[d,c]=u.useState(-1),[m,f]=u.useState(!1),[x,p]=u.useState(0);u.useLayoutEffect(()=>{const F=e==null?void 0:e.current;if(F){const R=F.getBoundingClientRect();p(R.width)}},[e]);const h=u.useMemo(()=>{var I;if(!t||t.length===0)return{x:0,y:0,zoom:1};const F=t.find(T=>{var V;return(V=T==null?void 0:T.data)==null?void 0:V.main})??t[0];return{x:(x||(typeof window<"u"?window.innerWidth:0))/2-(((I=F==null?void 0:F.position)==null?void 0:I.x)??0),y:20,zoom:1}},[t,x]),y=u.useCallback(F=>{if(!m){const R=[...r.slice(0,d+1),F];l(R),c(R.length-1)}},[r,d,m]),w=u.useCallback(()=>{if(m)return;const F=s(),R=Math.min(F.zoom*1.2,2);y(F),f(!0),n({x:F.x,y:F.y,zoom:R}),setTimeout(()=>f(!1),100)},[s,n,y,m]),j=u.useCallback(()=>{if(m)return;const F=s(),R=Math.max(F.zoom/1.2,.5);y(F),f(!0),n({x:F.x,y:F.y,zoom:R}),setTimeout(()=>f(!1),100)},[s,n,y,m]),b=u.useCallback(()=>{if(m)return;const F=s();Math.abs(F.zoom-1)>.01&&y(F),f(!0),n({x:F.x,y:F.y,zoom:1}),setTimeout(()=>f(!1),100)},[s,n,y,m]),v=u.useCallback(()=>{if(m||d<=0)return;const F=r[d-1];f(!0),n(F),c(d-1),setTimeout(()=>f(!1),100)},[d,r,n,m]);return u.useEffect(()=>{r.length===0&&(l([{zoom:1,x:0,y:0}]),c(0))},[r.length]),{isReady:x!==0&&Array.isArray(t)&&t.length>0,defaultViewport:h,zoomPercentage:i,handleZoomIn:w,handleZoomOut:j,handleZoomTo100:b,handleDoubleClick:v}}const Gr=e=>{var i,r;const t=((i=e.data)==null?void 0:i.isInternal)||!1,n=(r=e.data)==null?void 0:r.originalGroupId,s=e.selected||!1,o=l=>{if(l.preventDefault(),l.stopPropagation(),n){const c=_e.getState().collapseGroup;c&&c(n)}};return a.jsxs("div",{className:`tm-flex tm-flex-col tm-border-1 tm-border-default tm-gap-y-2 tm-rounded-lg tm-bg-surface-default tm-p-8 tm-transition-all tm-duration-200 ${s?"tm-border-brand tm-shadow-02 tm-ring-2 tm-ring-blue-300 tm-ring-opacity-50":"tm-border-default tm-shadow-02"}`,children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[a.jsx(g.Icon,{name:ze.faFlag,size:"sm",colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,background:!0,padding:"md"}),a.jsx("p",{className:"tm-text-primary tm-font-body-sm-semibold tm-leading-none tm-text-body-sm-regular tm-truncate tm-tracking-wider",children:e.data.clave}),t&&a.jsx(g.Button,{size:"sm",color:"secondary",onClick:o,className:"tm-p-2 nopan nodrag",icon:me.faMinimize,pill:"pill"})]}),t&&a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[a.jsx(g.Tag,{color:e.data.estatus==="published"?"success":"warning",label:e.data.estatus==="published"?"Publicado":"Borrador"}),(e.data.updatedAt||e.data.updated_at)&&a.jsx("p",{className:"tm-text-sm tm-text-neutral-500 tm-font-medium",children:new Date(e.data.updatedAt||e.data.updated_at).toLocaleDateString("es-ES")})]}),a.jsx(oe.Handle,{id:"bottom-source",type:"source",position:oe.Position.Bottom,className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default tm-cursor-crosshair"}),a.jsx(oe.Handle,{id:"top-target",type:"target",position:oe.Position.Top,className:"tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default tm-cursor-crosshair"})]})},Vr=()=>{const e=u.useCallback((o,i,r,l)=>{const d=(f,x)=>{const p=f.position.x,h=f.position.y,y=120,w=60,j=15;switch(x){case"top-source":case"top-target":return{x:p,y:h-w/2-j};case"bottom-source":case"bottom-target":return{x:p,y:h+w/2+j};case"left-source":case"left-target":return{x:p-y/2-j,y:h};case"right-source":case"right-target":return{x:p+y/2+j,y:h};default:return{x:p,y:h}}},c=d(o,r),m=d(i,l);return Math.sqrt(Math.pow(m.x-c.x,2)+Math.pow(m.y-c.y,2))},[]),t=u.useCallback((o,i)=>{if(o.includes("source")===i.includes("source"))return!1;const r=m=>m.includes("top")?"top":m.includes("bottom")?"bottom":m.includes("left")?"left":m.includes("right")?"right":null,l=r(o),d=r(i);return{top:"bottom",bottom:"top",left:"right",right:"left"}[l]===d},[]),n=u.useCallback((o,i)=>{const r=["top-source","bottom-source","left-source","right-source"],l=["top-target","bottom-target","left-target","right-target"];let d=1/0,c={handle1:r[0],handle2:l[0]};for(const m of r)for(const f of l){if(!t(m,f))continue;const x=e(o,i,m,f);x<d&&(d=x,c={handle1:m,handle2:f})}return c},[e,t]),s=u.useCallback((o,i,r=800)=>Math.sqrt(Math.pow(i.position.x-o.position.x,2)+Math.pow(i.position.y-o.position.y,2))<r,[]);return{findClosestHandles:n,calculateHandleDistance:e,areHandlesCompatible:t,shouldApplyMagneticConnection:s}},Wr=e=>{const[t,n]=u.useState(null),[s,o]=u.useState(null),[i,r]=u.useState(!1),l=u.useCallback((x,p,h,y)=>{n({isOpen:!0,nodeId:x,position:p,sourceNodeId:h,sourceHandleId:y})},[]),d=u.useCallback(()=>{n(null)},[]),c=u.useCallback((x,p,h,y,w)=>{r(!0),o({isOpen:!0,sourceNodeId:x,sourceHandleId:h,targetNodeId:p,targetHandleId:y,position:w})},[]),m=u.useCallback(()=>{r(!1),o(null)},[]),f=u.useCallback(()=>{var p,h,y;if(!(t!=null&&t.sourceNodeId))return null;const x=e.find(w=>w.id===t.sourceNodeId);return x?{id:x.id,label:(p=x.data)==null?void 0:p.label,nodeType:(h=x.data)==null?void 0:h.nodeType,connectionType:(y=x.data)==null?void 0:y.connectionType,data:x.data}:null},[t,e]);return{newNodePopup:t,connectionPopup:s,isConnectingExistingNodes:i,openNewNodePopup:l,closeNewNodePopup:d,openConnectionPopup:c,closeConnectionPopup:m,getParentNodeInfo:f,setIsConnectingExistingNodes:r}},Qr=({initialNodes:e,initialEdges:t})=>{const[n,s,o]=oe.useNodesState(wt(e)),[i,r,l]=oe.useEdgesState(t),[d,c]=u.useState(!1),m=u.useCallback(D=>{r(D)},[r]),{toObject:f}=oe.useReactFlow(),{findClosestHandles:x,shouldApplyMagneticConnection:p}=Vr(),{updateGraphLayout:h,get:y,update:w}=Be(),j=Oe(D=>D.activeTemplate),b=Oe(D=>D.setActiveTemplate),v=de.useQueryClient(),{removeParentIdFromNodes:M}=nt(),{newNodePopup:F,connectionPopup:R,isConnectingExistingNodes:C,openNewNodePopup:I,closeNewNodePopup:T,openConnectionPopup:V,closeConnectionPopup:z,getParentNodeInfo:ee,setIsConnectingExistingNodes:G}=Wr(n),{createNodeFromPopup:k,createConnectionFromPopup:E,updateNodeFromPopup:L,updateAfterDeleted:B}=xs({nodes:n,edges:i,setNodes:s,setEdges:m,newNodePopup:F,connectionPopup:R,closeNewNodePopup:T,closeConnectionPopup:z,setIsConnectingExistingNodes:G});u.useEffect(()=>{if(e&&e.length>0){if(!(e.some((O,_)=>{const W=n[_];return W?O.id!==W.id||JSON.stringify(O.position)!==JSON.stringify(W.position)||JSON.stringify(O.data)!==JSON.stringify(W.data):!0})||e.length!==n.filter(O=>{var _;return!((_=O.data)!=null&&_.isInternal)}).length)&&n.length>0)return;const{expandedGroups:A,groupTemplateData:K}=_e.getState(),S=wt(e),N=new Set(S.map(O=>O.id));let U=n.filter(O=>{var _,W;return((_=O.data)==null?void 0:_.isInternal)&&typeof((W=O.data)==null?void 0:W.originalGroupId)=="string"&&A.has(O.data.originalGroupId)&&N.has(O.data.originalGroupId)});if(U.length>0){const O=S.map(_=>{var W;if(A.has(_.id)){const Z=n.find(ie=>ie.id===_.id),ae=(W=Z==null?void 0:Z.data)==null?void 0:W.expandedDimensions;if(ae)return{..._,style:{..._.style,width:ae.width,height:ae.height},data:{..._.data,isExpanded:!0,expandedDimensions:ae}}}return _});s([...O,...U])}else if(A.size>0){const O=S.map(_=>A.has(_.id)&&K[_.id]?{..._,data:{..._.data,isExpanded:!0,needsReExpansion:!0}}:_);s(O)}else s(S)}else s([])},[e,s]),u.useEffect(()=>{if(!d&&t&&t.length>0){const{expandedGroups:D}=_e.getState(),A=wt(e),K=new Set(A.map(U=>U.id)),S=i.filter(U=>{var O,_;return((O=U.data)==null?void 0:O.isInternal)&&typeof((_=U.data)==null?void 0:_.originalGroupId)=="string"&&D.has(U.data.originalGroupId)&&K.has(U.data.originalGroupId)}),N=i.filter(U=>{var O,_;return((O=U.data)==null?void 0:O.redirectedToInternal)&&typeof((_=U.data)==null?void 0:_.originalTarget)=="string"&&D.has(U.data.originalTarget)&&K.has(U.data.originalTarget)});if(S.length>0||N.length>0){const U=t.filter(O=>!N.some(_=>{var W;return((W=_.data)==null?void 0:W.originalTarget)===O.target}));m([...U,...S,...N])}else m(t)}},[t,m,d]);const q=u.useCallback((D,A,K=!1)=>{const N=i.filter(_=>_.target===A).length>0;if(i.some(_=>_.source===D&&_.target===A||_.source===A&&_.target===D)&&!K)return g.toast.warning("La tarea destino ya tiene una conexión"),!1;const O=!N;return typeof window<"u"&&(window.validConnectionTypes={dependiente:O,hija:O}),O?!0:(g.toast.warning("La tarea destino ya tiene una conexión de entrada"),!1)},[i]),X=u.useCallback(D=>{if(!Br(D.source,D.target))return;Xe(D.source)&&!D.sourceHandle&&(D.sourceHandle=ve.DEFAULT_SOURCE_HANDLE);const A=n.find(S=>S.id===D.source),K=n.find(S=>S.id===D.target);if(A&&K){if(!q(D.source,D.target))return;V(D.source,D.target,D.sourceHandle,D.targetHandle);return}return m(S=>oe.addEdge(D,S))},[n,V,m,q]),H=u.useCallback((D,A)=>{var K;if(!C&&!A.isValid&&A.fromNode){const S=n.find(ae=>ae.id===A.fromNode.id);if((S==null?void 0:S.type)==="group"){g.toast.warning("En una plantilla, no se puede crear una conexión");return}const N=Rr(D),U=document.elementFromPoint(N.x,N.y);if(U!=null&&U.closest(".react-flow__node"))return;const O=crypto.randomUUID(),_=((K=A.fromHandle)==null?void 0:K.id)||ve.DEFAULT_SOURCE_HANDLE,Z=Xe(A.fromNode.id)?ve.DEFAULT_SOURCE_HANDLE:_;I(O,N,A.fromNode.id,Z)}},[C,I,n]),re=u.useCallback(async D=>{var N,U,O;const A=hs(D),K=D.length>0?(U=(N=D[0])==null?void 0:N.data)==null?void 0:U.id:0;m(_=>_.filter(W=>!A.includes(W.source)&&!A.includes(W.target)));let S;for(const _ of D)try{const W=_.data;if((O=W==null?void 0:W.plantilla)!=null&&O.id){S=W.plantilla.id;break}}catch{}try{m(_=>((async()=>{await B(A,_,S,K)})().catch(W=>{console.error("❌ Error en updateAfterDeleted:",W)}),_))}catch(_){console.error("❌ Error en onDeleteNode:",_)}},[m,B]),Y=u.useCallback(async D=>{var K,S,N,U,O,_,W,Z,ae,ie,J,se,ce,le;if(!D||D.length===0)return;let A;if(j!=null&&j.id)A=j.id;else for(const te of D){const ue=n.find(he=>he.id===te.source),fe=n.find(he=>he.id===te.target);if(ue!=null&&ue.data&&typeof ue.data=="object"&&"plantilla"in ue.data){const he=ue.data.plantilla;if(he!=null&&he.id){A=he.id;break}}if(fe!=null&&fe.data&&typeof fe.data=="object"&&"plantilla"in fe.data){const he=fe.data.plantilla;if(he!=null&&he.id){A=he.id;break}}}if(!A){console.warn("⚠️ onEdgesDelete - No se pudo obtener templateId");return}try{const te=await y(A);if(!te){console.warn("⚠️ onEdgesDelete - Template no encontrado en IndexedDB");return}const ue=D.map(ye=>ye.id),fe=((N=(S=(K=te.graph_layout)==null?void 0:K.snapshot)==null?void 0:S.edges)==null?void 0:N.filter(ye=>{var ke;return!ue.includes(ye.id)&&!((ke=ye.data)!=null&&ke.isInternal)}))||[],pe=(((_=(O=(U=te.graph_layout)==null?void 0:U.snapshot)==null?void 0:O.nodes)==null?void 0:_.filter(ye=>{var ke;return!((ke=ye.data)!=null&&ke.isInternal)&&!ye.parentId}))||[]).map(ye=>{const{style:ke,measured:ft,data:rt,...it}=ye,{expandedDimensions:et,isExpanded:Wt,needsReExpansion:jl,...Qt}=rt||{},ks=ke?{...ke,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0,Ls=ye.data.id===D[0].data.childId?{...Qt,tarea_padre:null,id_t_requerida:null}:Qt;return{...it,style:ks,data:Ls}}),be=((Z=(W=te.graph_layout)==null?void 0:W.snapshot)==null?void 0:Z.edges)||[];if(!(JSON.stringify(be)!==JSON.stringify(fe)))return;const Se={...te,graph_layout:{id:((ae=te.graph_layout)==null?void 0:ae.id)||0,snapshot:{nodes:pe,edges:fe,viewport:((J=(ie=te.graph_layout)==null?void 0:ie.snapshot)==null?void 0:J.viewport)||{x:0,y:0,zoom:1}},history:((se=te.graph_layout)==null?void 0:se.history)||[],zoom:((ce=te.graph_layout)==null?void 0:ce.zoom)||1,position:((le=te.graph_layout)==null?void 0:le.position)||{x:0,y:0}},estatus:we.DIRTY,updatedAt:new Date().toISOString()};await M({templateId:A,id:D[0].data.childId}),await w(A,Se),console.log("🗑️ [useFlow] Invalidando caché de la plantilla:",A),await v.invalidateQueries({queryKey:["template",A]}),await v.invalidateQueries({queryKey:["template"]}),console.log("✅ [useFlow] Caché invalidado exitosamente"),A===(j==null?void 0:j.id)&&b(Se)}catch(te){console.error("❌ onEdgesDelete - Error al actualizar template layout:",te)}},[n,j,y,w,b,M]),P=u.useCallback(async D=>!D.nodes.some(K=>K.type==="start"||K.id===ve.START_NODE_ID),[]),$=u.useCallback((D,A,K)=>{var O,_,W;const S=n.find(Z=>Z.id===A.id);if(!S)return;if(S.type==="group"&&((O=S.data)!=null&&O.isExpanded)){m(Z=>Z.map(ae=>{if(ae.hidden&&ae.target===A.id){const{hidden:ie,...J}=ae;return J}return ae}));return}let N;if(S.type==="group"?N=j==null?void 0:j.id:(W=(_=A==null?void 0:A.data)==null?void 0:_.plantilla)!=null&&W.id&&(N=A.data.plantilla.id),!N)return;const U=i.map(Z=>{var J,se,ce,le,te;if(vt(Z))return Z;const ae=n.find(ue=>ue.id===Z.source),ie=n.find(ue=>ue.id===Z.target);if(ae&&ie){const ue=ae.type==="group"&&((J=ae.data)==null?void 0:J.isExpanded),fe=ie.type==="group"&&((se=ie.data)==null?void 0:se.isExpanded),he=(ce=ae.data)==null?void 0:ce.isInternal,pe=(le=ie.data)==null?void 0:le.isInternal,be=(te=Z.data)==null?void 0:te.redirectedToInternal;if(ue||fe||he||pe||be)return Z;if(ae.id===A.id||ie.id===A.id||p(ae,ie,ve.MAGNETIC_CONNECTION_DISTANCE)){const Se=x(ae,ie);if(Se!=null&&Se.handle1&&(Se!=null&&Se.handle2))return{...Z,sourceHandle:Se.handle1,targetHandle:Se.handle2}}}return Z});if(JSON.stringify(i)!==JSON.stringify(U))m(U),setTimeout(()=>{const Z=f();h(N,Z)},100);else{const Z=f();h(N,Z)}},[n,i,j,h,f,m,x,p]),Q=u.useCallback(D=>{o(D);const A=qr(D);if(A.length>0){const K=A.filter(S=>{var U;const N=n.find(O=>O.id===S);return(N==null?void 0:N.type)==="group"&&((U=N==null?void 0:N.data)==null?void 0:U.isExpanded)});if(K.length>0){m(S=>S.map(N=>{var _;const U=K.includes(N.target),O=!((_=N.data)!=null&&_.redirectedToInternal);return U&&O?{...N,hidden:!0}:N}));return}c(!0),setTimeout(()=>{const S=i.map(U=>{var W,Z,ae,ie;if(vt(U))return{...U};const O=n.find(J=>J.id===U.source),_=n.find(J=>J.id===U.target);if(O&&_){const J=O.type==="group"&&((W=O.data)==null?void 0:W.isExpanded),se=_.type==="group"&&((Z=_.data)==null?void 0:Z.isExpanded),ce=(ae=O.data)==null?void 0:ae.isInternal,le=(ie=_.data)==null?void 0:ie.isInternal;if(J||se||ce||le)return{...U};if(p(O,_,ve.MAGNETIC_CONNECTION_DISTANCE)){const te=x(O,_);if(te!=null&&te.handle1&&(te!=null&&te.handle2)&&(U.sourceHandle!==te.handle1||U.targetHandle!==te.handle2))return{...U,sourceHandle:te.handle1,targetHandle:te.handle2}}}return{...U}});if(i.some((U,O)=>{const _=S[O];return U.sourceHandle!==_.sourceHandle||U.targetHandle!==_.targetHandle})){const U=S.map(O=>({...O,id:O.id}));m(U)}setTimeout(()=>{c(!1)},200)},0)}},[o,i,n,m,x,p,c]);return{nodes:n,edges:i,newNodePopup:F,connectionPopup:R,setNodes:s,setEdges:m,onEdgesChange:l,onConnect:X,onConnectEnd:H,onDeleteNode:re,onEdgesDelete:Y,onBeforeDelete:P,handleNodesChange:Q,onDragEnd:$,getParentNodeInfo:ee,isProtectedConnection:vt,isStartNode:Xe,createNodeFromPopup:k,updateNodeFromPopup:L,closeNewNodePopup:T,createConnectionFromPopup:E,closeConnectionPopup:z}},Xr=({isOpen:e,onClose:t,createConnectionFromPopup:n,availableConnections:s})=>{if(!e)return null;const o=s||{tarea:{dependiente:!0,hija:!0},plantilla:{dependiente:!0}},i=(r,l)=>{(r==="tarea"?o.tarea[l]:o.plantilla[l])&&n(r,l)};return a.jsx(a.Fragment,{children:a.jsxs("div",{className:"tm-fixed tm-inset-0 tm-z-50 tm-flex tm-items-center tm-justify-center",children:[a.jsx("div",{className:"tm-bg-black/20 tm-absolute tm-inset-0",onClick:t}),a.jsx("div",{className:"tm-shadow-lg tm-border-default tm-border-1 tm-relative tm-rounded-lg tm-bg-surface-default tm-p-4",children:a.jsx("div",{children:a.jsxs(g.List,{children:[a.jsx("p",{className:"tm-text-sm tm-px-4 tm-font-medium tm-text-neutral-300",children:"Tarea"}),a.jsxs(g.ListItem,{icon:me.faArrowUpLeft,iconColor:"neutral",onClick:()=>i("tarea","dependiente"),children:["Dependiente ",!o.tarea.dependiente&&"(No disponible)"]}),a.jsxs(g.ListItem,{icon:me.faArrowDownRight,iconColor:"neutral",onClick:()=>i("tarea","hija"),children:["Hija ",!o.tarea.hija&&"(No disponible)"]}),a.jsx(g.ListSeparator,{}),a.jsx("p",{className:"tm-text-sm tm-px-4 tm-py-2 tm-font-medium tm-text-neutral-300",children:"Flujo de trabajo"}),a.jsxs(g.ListItem,{icon:me.faArrowUpLeft,iconColor:"neutral",onClick:()=>i("plantilla","dependiente"),children:["Dependiente ",!o.plantilla.dependiente&&"(No disponible)"]})]})})})]})})},Yr=({data:e,id:t,selected:n})=>{const{expandedGroups:s}=_e(),[o,i]=u.useState(!1),r=u.useRef(!1);u.useEffect(()=>{const f=(e==null?void 0:e.needsReExpansion)&&s.has(t),x=(e==null?void 0:e.templateId)||(e==null?void 0:e.id);if(f&&x&&!r.current){r.current=!0;const h=_e.getState().expandGroup;h&&h(t,x).catch(y=>{console.error("Error al re-expandir grupo:",y),r.current=!1})}s.has(t)||(r.current=!1)},[e,t,s]);const l=async f=>{f.preventDefault(),f.stopPropagation();const x=(e==null?void 0:e.templateId)||(e==null?void 0:e.id);if(x){i(!0);try{const p=_e.getState(),h=p.expandGroup,y=p.collapseGroup,w=s.has(t);w&&y?y(t):!w&&h&&await h(t,x)}catch{}finally{i(!1)}}},d=s.has(t),c=e==null?void 0:e.expandedDimensions,m=d&&c?{width:c.width,height:c.height,minWidth:c.width,minHeight:c.height}:{minWidth:268,minHeight:80};return a.jsxs("div",{className:`tm-rounded-lg tm-shadow-02 tm-bg-surface-default tm-relative tm-transition-all tm-duration-200 ${n?"tm-border-1 tm-border-brand tm-shadow-02 tm-ring-2 tm-ring-brand-default tm-ring-opacity-50":d?"tm-border-2 tm-border-brand tm-shadow-02":"tm-border-2 tm-border-default"}`,style:m,children:[a.jsx(ot,{isLoading:o}),a.jsx(oe.Handle,{id:"top-target",type:"target",position:oe.Position.Top,className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default ${d?"tm-opacity-0 tm-pointer-events-none":""}`,isConnectable:!d}),a.jsx(oe.Handle,{id:"right-target",type:"target",className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default ${d?"tm-opacity-0 tm-pointer-events-none":""}`,position:oe.Position.Right,isConnectable:!d}),a.jsx(oe.Handle,{id:"bottom-target",type:"target",className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default ${d?"tm-opacity-0 tm-pointer-events-none":""}`,position:oe.Position.Bottom,isConnectable:!d}),a.jsx(oe.Handle,{id:"left-target",type:"target",className:`tm-h-[16px] tm-w-[16px] tm-border-black-light !tm-bg-surface-default ${d?"tm-opacity-0 tm-pointer-events-none":""}`,position:oe.Position.Left,isConnectable:!d}),!d&&a.jsxs("div",{className:"tm-flex tm-justify-between tm-gap-x-8 tm-p-16",children:[a.jsx(g.Icon,{name:me.faChartDiagram,color:"brand",size:"lg"}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:[a.jsx("p",{className:"tm-text-primary tm-font-bold tm-leading-none tm-text-body-lg-regular tm-truncate tm-tracking-wider",children:e.clave||e.nombre_plantilla||"N/A"}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-4",children:[a.jsx(g.Badge,{size:"sm",theme:"soft",color:e.estatus==="published"?"success":"warning",label:e.estatus==="published"?"Publicado":"Borrador"}),e.updatedAt&&a.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-semibold",children:new Date(e.updatedAt).toLocaleDateString("es-ES")})]})]}),a.jsx("div",{children:a.jsx(g.Button,{size:"sm",color:"secondary",pill:"pill",onClick:l,disabled:o,className:`tm-p-2 ${o?"tm-opacity-50":""} nopan nodrag`,icon:d?Ne.faCompress:Ne.faExpand})})]})]})},Jr=(e,t,n,s)=>{const o=u.useRef(e),i=u.useRef(t);u.useEffect(()=>{o.current=e},[e]),u.useEffect(()=>{i.current=t},[t]);const{expandedGroups:r,groupTemplateData:l,toggleGroupExpansion:d,setGroupTemplateData:c,clearGroupTemplateData:m}=_e(),f=de.useQueryClient(),{getTemplateWithTasks:x}=ls(),{hydrateTasks:p}=ms(),h=u.useCallback(async(b,v)=>{var M,F,R,C;try{await f.invalidateQueries({queryKey:["template",v]});const I=await x(v),T=(R=(F=(M=I==null?void 0:I.graph_layout)==null?void 0:M.snapshot)==null?void 0:F.nodes)==null?void 0:R.filter(_=>{var W,Z;return((W=_.data)==null?void 0:W.isInternal)||_.parentId||((Z=_.id)==null?void 0:Z.includes("-internal-"))});if(T&&T.length>0&&console.warn("⚠️ [expandGroup] Nodos sospechosos en API para plantilla",v,":",T),!((C=I==null?void 0:I.graph_layout)!=null&&C.snapshot))throw new Error(`No se encontraron datos de graph_layout en la plantilla: ${v}`);const V=I.graph_layout.snapshot.nodes||[],z=V.filter(_=>{var J,se;const W=(J=_.data)==null?void 0:J.isInternal,Z=!!_.parentId,ae=(se=_.id)==null?void 0:se.includes("-internal-"),ie=W||Z||ae;return ie&&console.warn("🗑️ [expandGroup] Filtrando nodo corrupto:",{id:_.id,type:_.type,esInterno:W,tieneParentId:Z,tieneInternalEnId:ae}),!ie}),ee={...I,graph_layout:{...I.graph_layout,snapshot:{...I.graph_layout.snapshot,nodes:z,edges:(I.graph_layout.snapshot.edges||[]).filter(_=>{var W,Z;return!((W=_.data)!=null&&W.isInternal)&&!((Z=_.id)!=null&&Z.includes("-internal-"))})}}},G=V.length-z.length;G>0?console.warn(`⚠️ [expandGroup] Se filtraron ${G} nodos internos corruptos de la BD para plantilla ${v}`):console.log(`✅ [expandGroup] No se encontraron nodos corruptos en plantilla ${v}`);const k=await p(ee),E={...ee,hydratedNodes:k,nodes:k||ee.graph_layout.snapshot.nodes||[],edges:ee.graph_layout.snapshot.edges||[]},L=E.nodes,B=E.edges;if(!L||!B){console.error("❌ No se encontraron nodos o edges en la plantilla:",v);return}c(b,{nodes:L,edges:B,viewport:E.graph_layout.snapshot.viewport||{x:0,y:0,zoom:1}});const q=o.current.find(_=>_.id===b);if(!q){console.error("❌ No se encontró el nodo grupo:",b);return}const X=L.filter(_=>_.id!==b);let H=1/0,re=1/0,Y=-1/0,P=-1/0;X.forEach(_=>{var te,ue,fe,he,pe,be;const W=((te=_.position)==null?void 0:te.x)||0,Z=((ue=_.position)==null?void 0:ue.y)||0,ae=typeof((fe=_.style)==null?void 0:fe.width)=="number"?_.style.width:((he=_.measured)==null?void 0:he.width)||268,ie=typeof((pe=_.style)==null?void 0:pe.height)=="number"?_.style.height:((be=_.measured)==null?void 0:be.height)||111,J=W-ae/2,se=W+ae/2,ce=Z,le=Z+ie;H=Math.min(H,J),re=Math.min(re,ce),Y=Math.max(Y,se),P=Math.max(P,le)});const $=80,Q=60,D=Y-H,A=P-re,K=D+$*2,S=A+$*2+Q,N=L.map((_,W)=>{var te,ue;if(_.id===b)return null;const Z=((te=_.position)==null?void 0:te.x)||0,ae=((ue=_.position)==null?void 0:ue.y)||0,ie=Z-H+$,J=ae-re+$+Q,se=_.type==="start"||_.id==="start",ce=se?{..._.data,estatus:q.data.estatus,updatedAt:q.data.updatedAt,createdAt:q.data.createdAt,isInternal:!0,originalGroupId:b,originalNodeId:_.id}:{..._.data,isInternal:!0,originalGroupId:b,originalNodeId:_.id};return{..._,id:`${b}-internal-${_.id}`,parentId:b,extent:"parent",type:_.type==="group"?"main":_.type,position:{x:ie,y:J},style:{..._.style},data:ce,draggable:!1,selectable:se,selected:!1,deletable:!1,connectable:!1,focusable:se,zIndex:999}}).filter(Boolean),U=B.map(_=>{const W=N.some(ie=>ie&&ie.id===`${b}-internal-${_.source}`),Z=N.some(ie=>ie&&ie.id===`${b}-internal-${_.target}`);return!W||!Z?null:{..._,id:`${b}-internal-${_.id}`,source:`${b}-internal-${_.source}`,target:`${b}-internal-${_.target}`,style:{..._.style},data:{..._.data,isInternal:!0,originalGroupId:b}}}).filter(Boolean),O=N.find(_=>{var W;return _&&((W=_.data)==null?void 0:W.originalNodeId)==="start"});O&&s(_=>_.map(W=>W.target===b?{...W,target:O.id,targetHandle:"top-target",data:{...W.data,redirectedToInternal:!0,originalTarget:b,originalTargetHandle:W.targetHandle}}:W)),d(b),n(_=>[..._.map(Z=>{if(Z.id===b){const{needsReExpansion:ae,...ie}=Z.data||{};return{...Z,style:{...Z.style,width:K,height:S},data:{...ie,isExpanded:!0,expandedDimensions:{width:K,height:S}},zIndex:1e3}}return Z}),...N]),s(_=>[..._,...U])}catch(I){console.error("❌ Error al expandir el grupo:",I)}},[f,x,p,c,d,n,s]),y=u.useCallback(b=>{var T,V;const v=o.current,M=i.current,F=v.find(z=>z.id===b),R=((T=F==null?void 0:F.data)==null?void 0:T.templateId)||((V=F==null?void 0:F.data)==null?void 0:V.id),C=v.filter(z=>!z.id.startsWith(`${b}-internal-`)&&z.parentId!==b).map(z=>z.id===b?{...z,style:{...z.style,width:void 0,height:void 0},data:{...z.data,isExpanded:!1,expandedDimensions:void 0},zIndex:void 0}:z),I=M.filter(z=>!z.id.startsWith(`${b}-internal-`)).map(z=>{var ee,G;if((ee=z.data)!=null&&ee.redirectedToInternal&&((G=z.data)==null?void 0:G.originalTarget)===b){const{redirectedToInternal:k,originalTarget:E,originalTargetHandle:L,...B}=z.data;return{...z,target:b,targetHandle:L||z.targetHandle,data:B}}return z});n(C),s(I),d(b),m(b),R&&f.invalidateQueries({queryKey:["template",R]})},[n,s,d,m,f]),w=u.useCallback(async(b,v)=>{r.has(b)?y(b):await h(b,v)},[r,h,y]),j=u.useCallback(b=>r.has(b),[r]);return{expandGroup:h,collapseGroup:y,toggleGroup:w,isGroupExpanded:j,groupTemplateData:l}},Zr=()=>{const{getNodes:e,setNodes:t,screenToFlowPosition:n,setCenter:s}=oe.useReactFlow(),{copiedNodes:o,setCopiedNodes:i,getViewMode:r}=_e(),{activeTemplate:l,setActiveTemplate:d}=Oe(),{updateGraphLayout:c,get:m,update:f}=Be(),x=l!=null&&l.id?r(l.id):"readonly",p=u.useCallback(()=>`node-${Date.now()}-${Math.random().toString(36).substr(2,9)}`,[]),h=u.useCallback(()=>e().filter(C=>C.selected).filter(C=>!(C.type==="start"||C.id==="start"||C.type==="group")),[e]),y=u.useCallback(()=>{if(x==="readonly"){g.toast.error("No puedes copiar tareas en modo solo lectura");return}if(!l){g.toast.error("No hay una plantilla activa");return}const M=h();if(M.length===0){const R=e().filter(C=>C.selected);if(R.length>0){const C=R.some(T=>T.type==="group"),I=R.some(T=>T.type==="start"||T.id==="start");C?g.toast.error("Las plantillas conectadas no pueden ser copiadas"):I&&g.toast.error("El nodo de inicio no puede ser copiado")}else g.toast.error("No hay tareas seleccionadas para copiar");return}const F=M.map(R=>{const{selected:C,...I}=R;return{...I,data:{...I.data,_originalTemplateId:l.id}}});i(F),g.toast.success(`${M.length} ${M.length===1?"tarea copiada":"tareas copiadas"} con éxito`)},[x,l,h,e,i]),w=u.useCallback(async M=>{if(x==="readonly"){g.toast.error("No puedes pegar tareas en modo solo lectura");return}if(!l){g.toast.error("No hay una plantilla activa");return}if(o.length===0){g.toast.error("No hay tareas copiadas para pegar");return}const F=e();let R={x:0,y:0};if(M)R=n({x:M.x,y:M.y});else if(F.length>0){const G=F.reduce((E,L)=>E+L.position.x,0)/F.length,k=F.reduce((E,L)=>E+L.position.y,0)/F.length;R={x:G+50,y:k+100}}const C=o[0],I=R.x-C.position.x,T=R.y-C.position.y,V=o.map((G,k)=>{const E=p(),L=-(Date.now()+k),B=G.data.plantilla&&typeof G.data.plantilla=="object"?{...G.data.plantilla,id:l.id}:{id:l.id},{id:q,...X}=G.data,H={...X,id:L,reference_graph:E,plantilla:B,parent:{data:{id:null}},_originalTemplateId:void 0};return{...G,id:E,position:{x:G.position.x+I,y:G.position.y+T},data:H,selected:!0}}),ee=[...F.map(G=>({...G,selected:!1})),...V];if(t(ee),l.id)try{const G=await m(l.id);if(!G)return;const k=V.filter(L=>L.type!=="start"&&L.type!=="group").map(L=>{const B=L.data;return{id:B.id,reference_graph:L.id,nombre:B.nombre||B.texto_corto||"Tarea sin nombre",texto_corto:B.texto_corto||"",texto_largo:B.texto_largo||"",prioridad:B.prioridad??0,nivel_dificultad:B.nivel_dificultad??0,dias_duracion:B.dias_duracion??0,plantilla:{id:l.id},parent:{data:{id:null}},tareas:[],plantilla_dependents:B.plantilla_dependents||[],start:B.start||!1,es_grupo:B.es_grupo||!1,optional:B.optional||!1,subtask_completadas:B.subtask_completadas||0,subtask_totales:B.subtask_totales||0}}),E={...G,tarea_plantillas:[...G.tarea_plantillas,...k],estatus:"dirty",updatedAt:new Date().toISOString()};await f(l.id,E),d(E),setTimeout(async()=>{await c(l.id,{nodes:ee,edges:[]})},50)}catch(G){console.error("Error al actualizar template en IndexedDB:",G)}if(V.length>0){const G=V.reduce((E,L)=>E+L.position.x,0)/V.length,k=V.reduce((E,L)=>E+L.position.y,0)/V.length;s(G,k,{zoom:1,duration:800})}g.toast.success(`${V.length} ${V.length===1?"tarea pegada":"tareas pegadas"} con éxito`)},[x,l,o,e,t,n,s,p,c,m,f,d]),j=u.useCallback(()=>o.length>0,[o]),v=h().length>0;return{handleCopy:y,handlePaste:w,hasCopiedNodes:j,hasSelectableNodes:v,copiedNodesCount:o.length}},ei={main:zr,plus:Ur,start:Gr,group:Yr},ti=[.5,0],ai=({initialNodes:e,initialEdges:t,debugEvents:n=!1})=>{const s=u.useRef(null),{nodes:o,edges:i,onEdgesChange:r,onConnect:l,onConnectEnd:d,onBeforeDelete:c,onDeleteNode:m,onEdgesDelete:f,handleNodesChange:x,newNodePopup:p,getParentNodeInfo:h,createNodeFromPopup:y,closeNewNodePopup:w,connectionPopup:j,createConnectionFromPopup:b,closeConnectionPopup:v,onDragEnd:M,setNodes:F,setEdges:R}=Qr({initialNodes:e,initialEdges:t}),{expandGroup:C,collapseGroup:I}=Jr(o,i,F,R),{handleCopy:T,handlePaste:V,hasCopiedNodes:z,copiedNodesCount:ee}=Zr();u.useEffect(()=>{if(!n)return;const te=pe=>{console.log("🔍 [DEBUG] KeyDown:",{key:pe.key,code:pe.code,shiftKey:pe.shiftKey,ctrlKey:pe.ctrlKey,metaKey:pe.metaKey,altKey:pe.altKey,target:pe.target,defaultPrevented:pe.defaultPrevented,bubbles:pe.bubbles,timestamp:new Date().toISOString()})},ue=pe=>{console.log("🔍 [DEBUG] KeyUp:",{key:pe.key,code:pe.code,shiftKey:pe.shiftKey,timestamp:new Date().toISOString()})},fe=pe=>{var be,Me;console.log("🔍 [DEBUG] Click:",{button:pe.button,shiftKey:pe.shiftKey,ctrlKey:pe.ctrlKey,metaKey:pe.metaKey,altKey:pe.altKey,target:(be=pe.target)==null?void 0:be.tagName,targetClass:(Me=pe.target)==null?void 0:Me.className,defaultPrevented:pe.defaultPrevented,bubbles:pe.bubbles,timestamp:new Date().toISOString()})},he=pe=>{console.log("🔍 [DEBUG] MouseDown:",{button:pe.button,shiftKey:pe.shiftKey,ctrlKey:pe.ctrlKey,metaKey:pe.metaKey,defaultPrevented:pe.defaultPrevented,timestamp:new Date().toISOString()})};return document.addEventListener("keydown",te,!0),document.addEventListener("keyup",ue,!0),document.addEventListener("click",fe,!0),document.addEventListener("mousedown",he,!0),console.log("🔍 [DEBUG] Event listeners activados. Presiona Shift + Click en un nodo para ver los eventos."),()=>{document.removeEventListener("keydown",te,!0),document.removeEventListener("keyup",ue,!0),document.removeEventListener("click",fe,!0),document.removeEventListener("mousedown",he,!0),console.log("🔍 [DEBUG] Event listeners desactivados.")}},[n]);const k=o.filter(te=>!(!te.selected||te.type==="start"||te.id==="start"||te.type==="group")).length,E=k>0,L=u.useRef(C),B=u.useRef(I);u.useEffect(()=>{L.current=C,B.current=I},[C,I]),u.useEffect(()=>{const te=async(fe,he)=>{L.current&&await L.current(fe,he)},ue=fe=>{B.current&&B.current(fe)};_e.setState({expandGroup:te,collapseGroup:ue})},[]);const{zoomPercentage:q,handleZoomIn:X,handleZoomOut:H,handleZoomTo100:re,handleDoubleClick:Y}=Kr({reactFlowWrapper:s,nodes:o}),{getViewMode:P}=_e(),{activeTemplate:$}=Oe(),D=($!=null&&$.id?P($.id):"readonly")==="readonly";u.useEffect(()=>{if(D)return;const te=ue=>{const fe=ue.target;fe.tagName==="INPUT"||fe.tagName==="TEXTAREA"||fe.isContentEditable||((ue.ctrlKey||ue.metaKey)&&ue.key==="c"&&(ue.preventDefault(),T()),(ue.ctrlKey||ue.metaKey)&&ue.key==="v"&&(ue.preventDefault(),V()))};return document.addEventListener("keydown",te),()=>{document.removeEventListener("keydown",te)}},[T,V,D]);const A=u.useCallback((te,ue)=>{const fe=te.target;fe.tagName==="BUTTON"||fe.closest("button")||fe.closest('[role="button"]')||fe.classList.contains("nopan")||fe.classList.contains("nodrag")},[]),K=u.useCallback(te=>{const ue=te.filter(fe=>{var he,pe;if(fe.type==="position"&&fe.dragging===!1){const be=o.find(Me=>Me.id===fe.id);if(be&&fe.position){const Me=Math.abs((fe.position.x||0)-(((he=be.position)==null?void 0:he.x)||0)),Se=Math.abs((fe.position.y||0)-(((pe=be.position)==null?void 0:pe.y)||0));if(Me<3&&Se<3)return!1}}return!0});ue.length>0&&x(ue)},[x,o]),S=D?void 0:r,N=D?void 0:K,U=D?void 0:l,O=D?void 0:d,_=D?void 0:c,W=D?void 0:M,Z=D?void 0:m,ae=D?void 0:f,ie=D?null:["Backspace","Delete"],ce=D?{nodesDraggable:!1,nodesConnectable:!1,elementsSelectable:!0,edgesFocusable:!1,nodesFocusable:!1,draggable:!1,connectOnClick:!1}:{nodesDraggable:!0,nodesConnectable:!0,elementsSelectable:!0,edgesFocusable:!0,nodesFocusable:!0,draggable:!1,connectOnClick:!0,elevateNodesOnSelect:!0},le=()=>{if(j)return{tarea:{dependiente:!0,hija:!0},plantilla:{dependiente:!0}}};return a.jsxs("div",{className:"wrapper",ref:s,style:{width:"100%",height:"100vh"},children:[a.jsxs(oe.ReactFlow,{nodes:o,edges:i,nodeTypes:ei,onEdgesChange:S,onNodesChange:N,onConnect:U,onConnectEnd:O,onBeforeDelete:_,onNodeDragStop:W,onNodesDelete:Z,onEdgesDelete:ae,onNodeClick:A,...ce,fitView:!0,fitViewOptions:{padding:2},nodeOrigin:ti,defaultEdgeOptions:{type:"smoothstep"},connectionLineType:oe.ConnectionLineType.SmoothStep,deleteKeyCode:ie,multiSelectionKeyCode:D?null:"Shift",selectionOnDrag:!1,panOnDrag:D?!0:[0],nodeClickDistance:15,selectNodesOnDrag:!1,nodeDragThreshold:10,autoPanOnNodeDrag:!1,autoPanOnConnect:!1,noDragClassName:"nodrag",noWheelClassName:"nowheel",noPanClassName:"nopan",children:[a.jsx(oe.Background,{}),!D&&a.jsx(oe.Panel,{position:"bottom-left",className:"tm-m-0",children:a.jsxs("div",{className:"tm-bg-surface-default tm-border tm-border-black-light tm-rounded-lg tm-p-3 tm-shadow-02 tm-text-sm tm-text-neutral-500",children:[a.jsx("div",{className:"tm-font-semibold tm-text-neutral-900 tm-mb-2",children:"Atajos de teclado"}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-1",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"Shift"}),a.jsx("span",{children:"+ clic para seleccionar múltiples tareas"})]}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"Ctrl"}),a.jsx("span",{children:"+"}),a.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"C"}),a.jsx("span",{children:"Copiar"})]}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[a.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"Ctrl"}),a.jsx("span",{children:"+"}),a.jsx("kbd",{className:"tm-px-2 tm-pt-0.5 tm-bg-neutral-100 tm-rounded tm-text-sm",children:"V"}),a.jsx("span",{children:"Ppegar"})]})]})]})}),a.jsx(oe.Panel,{position:"top-left",className:"tm-m-0",children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-2",children:[a.jsxs("div",{children:[$.estatusFromStrapi===Pe.PUBLISHED&&a.jsx(g.Tag,{color:"success",label:"Publicado"}),$.estatusFromStrapi===Pe.DRAFT&&a.jsx(g.Tag,{color:"warning",label:"Borrador"})]}),!D&&k>0&&a.jsxs("p",{className:"tm-text-blue-dark-500 tm-text-xs tm-font-medium",children:[k," ",k===1?"tarea seleccionada":"tareas seleccionadas"]})]})}),a.jsx(oe.Panel,{position:"top-right",className:"tm-m-0",children:a.jsxs("div",{className:"tm-flex tm-gap-4",children:[!D&&a.jsxs(g.ButtonGroup,{children:[a.jsxs(g.Button,{leftSlot:me.faCopy,onClick:T,disabled:!E,size:"xxs",color:E?"primary":"secondary",title:E?`Copiar ${k} ${k===1?"tarea":"tareas"} (Ctrl+C)`:"Selecciona tareas para copiar (mantén Shift y haz clic)",children:["Copiar ",k>0&&`(${k})`]}),a.jsxs(g.Button,{leftSlot:me.faFile,size:"xxs",onClick:()=>V(),disabled:!z(),color:z()?"primary":"secondary",title:z()?`Pegar ${ee} ${ee===1?"tarea":"tareas"} (Ctrl+V)`:"No hay tareas copiadas",children:["Pegar ",ee>0&&`(${ee})`]})]}),a.jsxs(g.ButtonGroup,{color:"secondary",size:"xxs",children:[a.jsx(g.Button,{icon:me.faMinus,onClick:H,color:"secondary"}),a.jsxs(g.Button,{onClick:re,onDoubleClick:Y,color:"secondary",children:[q,"%"]}),a.jsx(g.Button,{icon:me.faPlus,onClick:X})]})]})})]}),p&&a.jsx(Hr,{isOpen:p.isOpen,position:p.position,onClose:w,createNodeFromPopup:y,parentNodeInfo:h()}),j&&a.jsx(Xr,{isOpen:j.isOpen,onClose:v,createConnectionFromPopup:b,availableConnections:le()})]})},si=({initialNodes:e,initialEdges:t,debugEvents:n})=>a.jsx(oe.ReactFlowProvider,{children:a.jsx(ai,{initialNodes:e,initialEdges:t,debugEvents:n})}),st=Ue.create(e=>({step:1,setStep:t=>e({step:t}),reset:()=>e({step:1})})),ni=({limit:e})=>{const t=st(r=>r.step),n=st(r=>r.setStep),s=u.useCallback(()=>{t<e&&n(t+1)},[t,n,e]),o=u.useCallback(()=>{t>1&&t<=e&&n(t-1)},[t,n,e]),i=u.useCallback(r=>{r>0&&r<=e&&n(r)},[n,e]);return u.useMemo(()=>({step:t,nextStep:s,prevStep:o,onStepChange:i}),[t,s,o,i])},ja=["fase_plantilla","tipo_plantilla","categoria","tipo_medio","medio_especifico","pertenencia_medio","ubicacion_medio","responsable_impresion"],wa=["fase_plantilla","modo_configuracion","tipo_medio","formato_salida"],va=["tipo_medio","formato_salida","medio_especifico"],_a={fase_plantilla:{Preventa:{fieldsToClear:["modo_configuracion","formato_salida","medio_especifico","tipo_plantilla","categoria"]},Venta:{fieldsToClear:["tipo_medio","medio_especifico","modo_configuracion"]}},modo_configuracion:{Default:{fieldsToClear:["formato_salida","medio_especifico","tipo_medio"]},Especifico:{fieldsToClear:["formato_salida","medio_especifico","tipo_medio"]}},tipo_medio:{"Sitios Fijos":{fieldsToClear:["medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"]},Indoors:{fieldsToClear:["medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"]},"Vallas Móviles":{fieldsToClear:["responsable_impresion","pertenencia_medio","ubicacion_medio"]},Camiones:{fieldsToClear:["responsable_impresion","pertenencia_medio","ubicacion_medio"]},"Brand Riders":{fieldsToClear:["responsable_impresion","pertenencia_medio","ubicacion_medio"]}},formato_salida:{Digital:{fieldsToClear:["pertenencia_medio","ubicacion_medio"]},Impreso:{fieldsToClear:["pertenencia_medio","ubicacion_medio"]}}},Ta={fase_plantilla:{Venta:{fieldsToEnableDisable:["tipo_plantilla","modo_configuracion","categoria","pertenencia_medio","ubicacion_medio"]},Preventa:{fieldsToEnableDisable:["modo_configuracion"]}},modo_configuracion:{Preventa:{Default:{fieldsToEnableDisable:["tipo_medio"]},Especifico:{fieldsToEnableDisable:["tipo_medio"]}},Venta:{Default:{fieldsToEnableDisable:["tipo_medio","formato_salida"]},Especifico:{fieldsToEnableDisable:["tipo_medio"]}}},tipo_plantilla:{General:{fieldsToEnableDisable:["medio_especifico"]},Individual:{fieldsToEnableDisable:[]}},formato_salida:{Digital:{fieldsToEnableDisable:["responsable_impresion"]},Impreso:{fieldsToEnableDisable:["responsable_impresion"]}}};function Kt(e){const[t,n]=u.useState([]),[s,o]=u.useState({}),{setClaveParams:i,templateFormData:r,setTemplateFormData:l,resetTemplateFormData:d,setDisableField:c,setClave:m,claveParams:f,setParamTipo:x}=Fe(),{tasks_api:p}=ge(),h=st(P=>P.step),{data:y,error:w,isSuccess:j,isError:b}=de.useQuery({queryKey:["paramsTipoPlantilla"],queryFn:async()=>{const P=Ce.stringify({populate:{params_plantillas:{fields:["id","abbreviation","name","active","tipomedio_nombre","reference_id"]}},sort:["order:asc"],fields:["id","step","key","label","order"]},{encodeValuesOnly:!0}),$=await p.get(`/api/params-tipos?${P}`);return $.data?{paramsTiposPlantilla:xe($.data.data)}:{paramsTiposPlantilla:[]}},refetchOnWindowFocus:!1});u.useEffect(()=>{w&&b&&console.log(w)},[w,b]),u.useEffect(()=>{if(y&&j){const P=y.paramsTiposPlantilla;n(P)}},[y,j]);const v={fase_plantilla:(P,$)=>{l({fase_plantilla:P}),x({fase_plantilla:$})},tipo_plantilla:(P,$)=>{l({tipo_plantilla:P}),x({tipo_plantilla:$})},modo_configuracion:(P,$)=>{l({modo_configuracion:P}),x({modo_configuracion:$})},categoria:(P,$)=>{l({categoria:P}),x({categoria:$})},formato_salida:(P,$)=>{l({formato_salida:P}),x({formato_salida:$})},tipo_medio:(P,$)=>{l({tipo_medio:P}),x({tipo_medio:$})},medio_especifico:(P,$)=>{l({medio_especifico:P}),x({medio_especifico:$})},responsable_impresion:(P,$)=>{l({responsable_impresion:P}),x({responsable_impresion:$})},pertenencia_medio:(P,$)=>{l({pertenencia_medio:P}),x({pertenencia_medio:$})},ubicacion_medio:(P,$)=>{l({ubicacion_medio:P}),x({ubicacion_medio:$})}},M={fase_plantilla:(P,$)=>i({field:P,value:$}),tipo_plantilla:(P,$)=>i({field:P,value:$}),categoria:(P,$)=>i({field:P,value:$}),tipo_medio:(P,$)=>i({field:P,value:$}),medio_especifico:(P,$)=>i({field:P,value:$}),responsable_impresion:(P,$)=>i({field:P,value:$}),pertenencia_medio:(P,$)=>i({field:P,value:$}),ubicacion_medio:(P,$)=>i({field:P,value:$})},F={Digital:{execute:()=>{const P=t.filter(D=>D.step===3).find(D=>D.key==="responsable_impresion").params_plantillas.find(D=>D.name==="N/A").id,$="step3.responsable_impresion",Q=["responsable_impresion"];l({responsable_impresion:"N/A"}),e($,P),c({fields:Q,value:!0}),i({field:"responsable_impresion",value:"NA"})}},Impreso:{execute:()=>{const P="step3.responsable_impresion",$=["responsable_impresion"];l({responsable_impresion:""}),e(P,""),c({fields:$,value:!1}),i({field:"responsable_impresion",value:""})}}},R={"Sitios Fijos":{execute:()=>ee()},"Vallas Móviles":{execute:()=>G()},Indoors:{execute:()=>ee()},Camiones:{execute:()=>k()},"Brand Riders":{execute:()=>k()}},C={"Sitios Fijos":{execute:()=>z()},"Vallas Móviles":{execute:()=>z()},Indoors:{execute:()=>z()},Camiones:{execute:()=>{V(),F.Impreso.execute()}},"Brand Riders":{execute:()=>{V(),F.Impreso.execute()}}},I={"Sitios Fijos":{execute:()=>T()},"Vallas Móviles":{execute:()=>V()},Indoors:{execute:()=>T()},Camiones:{execute:()=>V()},"Brand Riders":{execute:()=>V()}},T=()=>{const P=["medio_especifico"],$=r.modo_configuracion,Q=`step${h}.medio_especifico`,D=`step${h}.formato_salida`;c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0}),c($==="Default"?{fields:P,value:!0}:{fields:P,value:!1}),l({medio_especifico:""}),l({formato_salida:""}),e(Q,""),e(D,""),i({field:"medio_especifico",value:""}),i({field:"formato_salida",value:""})},V=()=>{const P=t.filter(K=>K.step===h).find(K=>K.key==="formato_salida").params_plantillas.find(K=>K.name==="Impreso").id;c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0});const Q=`step${h}.formato_salida`,D=["formato_salida","medio_especifico"],A=`step${h}.medio_especifico`;l({medio_especifico:""}),l({formato_salida:"Impreso"}),e(Q,P),e(A,""),i({field:"medio_especifico",value:""}),i({field:"tipo_medio",value:r.tipo_medio}),c({fields:D,value:!0})},z=()=>{const P=["formato_salida"],$=`step${h}.formato_salida`,Q={};Q.formato_salida="",l(Q),e($,""),c({fields:P,value:!1})},ee=()=>{const P=["formato_salida","medio_especifico"],$=`step${h}.formato_salida`,Q={};Q.formato_salida="",l(Q),e($,""),c({fields:P,value:!1})},G=()=>{const P=["formato_salida"],$=["medio_especifico"],Q=`step${h}.formato_salida`,D=`step${h}.medio_especifico`,A={};A.formato_salida="",A.medio_especifico="",l(A),e(Q,""),e(D,""),c({fields:P,value:!1}),c({fields:$,value:!0})},k=()=>{const P=t.filter(A=>A.step===h).find(A=>A.key==="formato_salida").params_plantillas.find(A=>A.name==="Impreso").id,$=`step${h}.formato_salida`,Q=`step${h}.medio_especifico`,D=["formato_salida","medio_especifico"];l({formato_salida:"Impreso"}),e($,P),e(Q,""),c({fields:D,value:!0}),F.Impreso.execute()},E=(P,$)=>{Object.keys(_a).includes(P)&&_a[P][$].fieldsToClear.forEach(A=>{const K={};K[A]="",l(K),i({field:A,value:""}),e&&[...new Set(t.map(N=>N.step))].forEach(N=>{const U=`step${N}.${A}`;e(U,"")})})},L=(P,$,Q)=>P==="modo_configuracion"&&Q?Ta[P][Q][$].fieldsToEnableDisable:Ta[P][$].fieldsToEnableDisable,B=P=>t.filter($=>$.step===P),q=P=>{var $;return s[P]||(($=t.find(Q=>Q.key===P))==null?void 0:$.params_plantillas)},X=(P,$)=>{var D,A,K,S;let Q=[];P==="Sitios Fijos"?$==="Preventa"?Q=(D=t.find(N=>N.key==="medio_especifico"))==null?void 0:D.params_plantillas.filter(N=>N.tipomedio_nombre==="OOH"&&N.name==="PANTALLA DIGITAL"):$==="Venta"&&(Q=(A=t.find(N=>N.key==="medio_especifico"))==null?void 0:A.params_plantillas.filter(N=>N.tipomedio_nombre==="OOH")):P==="Indoors"?Q=(K=t.find(N=>N.key==="medio_especifico"))==null?void 0:K.params_plantillas.filter(N=>N.tipomedio_nombre==="InDoor"):Q=(S=t.find(N=>N.key==="medio_especifico"))==null?void 0:S.params_plantillas,o(N=>({...N,medio_especifico:Q}))},H=(P,$)=>{const Q=P.key;if(va.includes(Q)&&Q==="tipo_medio"){const D=$.label,A=r.fase_plantilla,K=r.modo_configuracion;if(A==="Preventa"){X(D,A);return}else if(K==="Especifico"){X(D,A);return}}},re=(P,$,Q)=>{const D=P.params_plantillas.find(A=>P.key==="categoria"?A.reference_id===$.value:A.id===$.value);if(D){const A=P.key,K=$.label;if(v[A](K,Q),wa.includes(A))if(E(A,K),A==="fase_plantilla"){const S=K,N=L(A,S);c({fields:["categoria","modo_configuracion","tipo_plantilla"],value:!0}),N.length>0&&c({fields:N,value:!1}),S==="Preventa"&&c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0})}else if(A==="modo_configuracion"){const S=K,N=r.fase_plantilla,U=L(A,S,N);c({fields:["medio_especifico","formato_salida"],value:!0}),U.length>0&&c({fields:U,value:!1}),N==="Preventa"&&c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0})}else if(A==="tipo_medio"){const S=K,N=r.modo_configuracion;r.fase_plantilla==="Venta"?N==="Especifico"?R[S].execute():C[S].execute():I[S].execute()}else if(A==="formato_salida")F[K].execute();else{const S=L(A,K);S.length>0&&c({fields:S,value:!1})}if(ja.includes(A)){let S="",N="";if(A==="formato_salida"){const U=r.modo_configuracion,O=K;N="tipo_medio",S=U==="Default"&&O==="Digital"?S="DDG":S="DRP"}else N=A,S=D.abbreviation;M[N](N,S)}va.includes(A)&&H(P,$)}},Y=()=>{if(r){const P=r.fase_plantilla;if(P==="Preventa"){const $=r.modo_configuracion,Q=f.fase_plantilla||"XX";let D=null;if($==="Default")D=f.tipo_medio||"XXX";else{const K=r.tipo_medio;["Vallas Móviles","Camiones","Brand Riders"].includes(K)?D=f.tipo_medio||"XXX":D=f.medio_especifico||"XXX"}const A=`${Q}-${D}`;m(A)}if(P==="Venta"){const $=f.fase_plantilla||"XX",Q=f.tipo_plantilla||"XXX",D=f.categoria||"XX",A=f.medio_especifico||f.tipo_medio||f.modo_configuracion||"XXX",K=f.responsable_impresion||"XX",S=f.pertenencia_medio||"X",N=f.ubicacion_medio||"X",U=`${$}-${Q}-${D}-${A}-${K}-${S}-${N}`;m(U)}}};return u.useEffect(()=>{Y()},[f]),{templateFields:t,getFieldsByStep:B,dropdownFunctionsUpdateClave:M,fieldsForUpdateClave:ja,resetTemplateFormData:d,fieldsWithDisableTrigger:wa,getFieldsToDisable:L,handleOptionSelected:re,getFilteredOptions:q,dropdownFunctionsUpdateFormData:v}}const Gt=()=>{const{control:e,setValue:t}=Ee.useFormContext(),n=st(c=>c.step),{getFieldsByStep:s,handleOptionSelected:o,getFilteredOptions:i}=Kt(t),{disabledFields:r}=Fe(),l=u.useMemo(()=>s(n),[n,s]),d=c=>`El campo ${c.charAt(0).toLocaleLowerCase()+c.slice(1)} es requerido`;return l.map(c=>{const m=`step${c.step}.${c.key}`,f=c.label,p=i(c.key).map(h=>({label:h.name,value:c.key==="categoria"?h.reference_id:h.id}));return a.jsx(Ee.Controller,{name:m,control:e,rules:{required:{value:!r[c.key],message:d(f)},validate:h=>r[c.key]||h?!0:d(f)},render:({field:h,fieldState:{error:y}})=>a.jsx("div",{children:a.jsx(g.Dropdown,{label:f,value:h.value,onValueChange:w=>{h.onChange(w)},error:y==null?void 0:y.message,options:p,onOptionSelect:w=>{o(c,w,c.id)},disabled:r[c.key]||!1})})},c.id)})},oi=()=>a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:a.jsx(Gt,{})}),ri=()=>a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:a.jsx(Gt,{})}),ii=()=>a.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:a.jsx(Gt,{})}),li=({step:e})=>a.jsxs("div",{className:"tm-flex tm-min-h-[270px] tm-flex-col tm-gap-y-4",children:[e===1&&a.jsx(oi,{}),e===2&&a.jsx(ri,{}),e===3&&a.jsx(ii,{})]}),ci=e=>{const t={step1:["fase_plantilla","tipo_plantilla","modo_configuracion","categoria"],step2:["tipo_medio","formato_salida","medio_especifico"],step3:["responsable_impresion","pertenencia_medio","ubicacion_medio"]};return e.reduce((n,s)=>{const o=`step${s.step}`,i=t[o];return i&&i.includes(s.key)&&(n[o]||(n[o]={}),n[o][s.key]=""),n},{})},di=e=>{const t={step1:["fase_plantilla","tipo_plantilla","modo_configuracion","categoria"],step2:["tipo_medio","formato_salida","medio_especifico"],step3:["responsable_impresion","pertenencia_medio","ubicacion_medio"]},n={};return Object.keys(t).forEach(s=>{n[s]={},t[s].forEach(o=>{var r;const i=(r=e[s])==null?void 0:r[o];n[s][o]=i!==void 0?i:""})}),n},mi=e=>e&&e.status===400?{failureLevel:"strapi",errorMessage:"Error al procesar la solicitud",technicalDetails:e.message}:e&&e.status===401?{failureLevel:"authentication",errorMessage:"Error de autenticación",technicalDetails:`Token expirado o inválido: ${e.message}`}:e&&e.status===500?{failureLevel:"strapi",errorMessage:"Error de servidor",technicalDetails:`Error en el servidor de Strapi: ${e.message}`}:{failureLevel:"unknown",errorMessage:"Error inesperado al crear la plantilla",technicalDetails:`Error desconocido: ${e.message}`};function ui(e,t){const{clave:n,paramsTipo:s,currentTemplateForEdit:o,isEditTemplate:i,setDisableField:r,setClaveParams:l,isDuplicateTemplate:d,templateFormData:c}=Fe(),{tasks_api:m}=ge(),{getFieldsByStep:f,dropdownFunctionsUpdateFormData:x,templateFields:p}=Kt(),h=()=>{var R;try{const C={},I=e(),T=di(I),{step1:V}=T,z=[];C.clave=n,V.categoria!=""&&(C.categoria=V.categoria);for(const[ee,G]of Object.entries(T))for(const[k,E]of Object.entries(G)){const L={id:null,params_tipo:{id:null}};if(E!=""){const B=s[k];if(k==="categoria"){const q=p.find(H=>H.key==="categoria"),X=(R=q==null?void 0:q.params_plantillas)==null?void 0:R.find(H=>H.reference_id===E);L.id=X==null?void 0:X.id}else L.id=E;L.params_tipo.id=B,z.push(L)}}return Object.keys(z).length>0&&(C.params_plantillas=z),C}catch(C){console.log(C)}},y=async R=>{var C;try{let I=null;return i?I=await m.put(`/api/plantillas/${o.id}`,{data:R}):I=await m.post("/api/plantillas",{data:R}),I.data?xe(I.data):null}catch(I){throw console.error("Error en saveTemplateToStrapi:",{error:I.message,status:(C=I.response)==null?void 0:C.status}),I}},w=async R=>{var C;try{const I=Ce.stringify({filters:{plantilla:{id:R}},populate:{graph_layout:!0}},{encodeValuesOnly:!0}),T=await m.get(`/api/plantillas/plantilla-tareas-grafico?${I}`);return T.data?xe(T.data.data):null}catch(I){throw console.error("Error en getTemplateWithTasks:",{error:I.message,status:(C=I.response)==null?void 0:C.status}),I}},j=async(R,C,I)=>{var T,V,z,ee,G,k,E;try{const L=await w(R),B=await w(C);if(!L||!L.tarea_plantillas)return console.warn("No se encontraron tareas para duplicar en la plantilla original"),null;const q=new Map,X=new Map;let H=1;L.tarea_plantillas.forEach(Q=>{let D=null;Q.start?D=I:D=-(Date.now()+H++),q.set(Q.id,D)}),(V=(T=L.graph_layout)==null?void 0:T.snapshot)!=null&&V.nodes&&L.graph_layout.snapshot.nodes.forEach(Q=>{const D=`node-${Date.now()}-${Math.random().toString(36).substr(2,9)}`;X.set(Q.id,D)});const re=L.tarea_plantillas.filter(Q=>!Q.start).map(Q=>{var A,K,S,N;return{id:q.get(Q.id),uuid:crypto.randomUUID(),reference_graph:Q.reference_graph,texto_corto:Q.texto_corto,texto_largo:Q.texto_largo||null,prioridad:Q.prioridad,nivel_dificultad:Q.nivel_dificultad,duracion:Q.duracion,start:Q.start,type:Q.type||"task",equipo:((A=Q.equipo)==null?void 0:A.id)||null,responsable:((K=Q.responsable)==null?void 0:K.id)||null,plantilla:{id:C,clave:L.clave,categoria:L.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:[],id_t_requerida:q.get((S=Q.id_t_requerida)==null?void 0:S.id)||null,ids_t_dependientes:[],tarea_padre:q.get((N=Q.tarea_padre)==null?void 0:N.id)||null,tareas:[]}});let Y=null;if(L.graph_layout){const Q=B.tarea_plantillas.find(D=>D.start===!0);Y={...L.graph_layout,id:(z=B.graph_layout)==null?void 0:z.id,snapshot:{...L.graph_layout.snapshot,edges:L.graph_layout.snapshot.edges.map(D=>{if(D.source==="start")return{...D,data:{...D.data,childId:re.find(A=>A.reference_graph===D.target).id,parentId:Q.id}};{const A=re.find(K=>K.reference_graph===D.target);return{...D,data:{...D.data,childId:A==null?void 0:A.id,parentId:(A==null?void 0:A.id_t_requerida)||(A==null?void 0:A.tarea_padre)}}}}),nodes:((G=(ee=L.graph_layout.snapshot)==null?void 0:ee.nodes)==null?void 0:G.map(D=>{let A={};return D.type==="start"?A={...D,data:{...D.data,tareaId:Q.id}}:A={...D,data:{tareaId:null}},A}))||[]}}}if(!Y)throw console.error("Error: duplicatedGraphLayout es null, no se puede guardar"),new Error("No se pudo crear el graph_layout para la plantilla duplicada");const P={graph_layout:Y,tasks:{created:re,updated:[],deleted:[]}},$=await m.post("/api/tareas/save-tareas-grafico",{data:P});if($.data&&$.status===200){const Q=await w(C),D=new Map;Q.tarea_plantillas.forEach(S=>D.set(S.reference_graph,S.id));let A=Q.graph_layout;return(!((k=A==null?void 0:A.snapshot)!=null&&k.nodes)||A.snapshot.nodes.length===0)&&(console.log("Graph layout vacío, reconstruyendo desde el original..."),A=Y),(E=A==null?void 0:A.snapshot)!=null&&E.nodes&&(A.snapshot.nodes=A.snapshot.nodes.map(S=>{var _;const N={...S,position:S.position||{x:0,y:0}},U=N.id,O=D.get(U);if(O)return{...N,data:{...N.data,id:O,tareaId:O}};if((_=N.data)!=null&&_.tareaId){const W=Q.tarea_plantillas.find(Z=>Z.reference_graph===U);if(W)return{...N,data:{...N.data,id:W.id,tareaId:W.id}}}return N})),await m.put(`/api/plantillas/${C}`,{data:{graph_layout:A}}),await w(C)}return null}catch(L){throw console.error("Error al duplicar las tareas de la plantilla:",L),L}},b=async()=>{var R,C;try{let I=h();const T=await y(I);if(!T)return{success:!1,message:"No se pudo guardar el flujo de trabajo en Strapi",error:"templateData es null"};const V=Ce.stringify({filters:{id:{$eq:T.id}},populate:{tarea_plantillas:{filters:{start:{$eq:!0}}}}},{encodeValuesOnly:!0}),{data:z}=await m.get(`/api/plantillas?${V}`),G=xe(z.data)[0].tarea_plantillas[0].id;if(d&&(o!=null&&o.id))try{const E=await j(o.id,T.id,G);return E?{success:!0,message:"Flujo de trabajo duplicado completamente con todas sus tareas",data:E}:{success:!0,message:"Flujo de trabajo creado, pero no se pudieron duplicar las tareas",data:await w(T.id)}}catch(E){return console.error("Error al duplicar tareas:",E),{success:!0,message:"Flujo de trabajo creado, pero hubo un error al duplicar las tareas",data:await w(T.id)}}const k=await w(T.id);return k?{success:!0,message:"Flujo de trabajo creado y sincronizado completamente",data:k}:{success:!1,message:"No se pudieron obtener los datos completos del flujo de trabajo",error:"completeData es null"}}catch(I){const T=mi(((C=(R=I==null?void 0:I.response)==null?void 0:R.data)==null?void 0:C.error)||I);return console.error("Error al guardar el flujo de trabajo: ",{level:T.failureLevel,message:T.errorMessage,technicalDetails:T.technicalDetails}),{success:!1,message:T.errorMessage||"Error al guardar el flujo de trabajo",error:T.technicalDetails||I.message}}},v=()=>{const R=o==null?void 0:o.params_plantillas;if(!(R!=null&&R.length))return;let C={};[1,2,3].forEach(T=>{const V=`step${T}`;C[V]={},f(T).forEach(ee=>{var k;const G=R.find(E=>E.params_tipo.key===ee.key);if(G){let E=null;if(ee.key==="categoria"){const L=(k=ee.params_plantillas)==null?void 0:k.find(B=>B.id===G.id);E=(L==null?void 0:L.reference_id)||G.id}else E=G.id;C[V][ee.key]=E}})}),t(C)},M=()=>{var C;const R=o==null?void 0:o.params_plantillas;if(R!=null&&R.length)for(const I of R){const{params_tipo:{id:T,key:V},name:z,id:ee}=I,G=p.find(E=>E.key===V),k=(C=G==null?void 0:G.params_plantillas)==null?void 0:C.find(E=>E.id===ee);x[V]&&x[V](z,T),k&&l({field:V,value:k.abbreviation})}},F=()=>{try{const{fase_plantilla:R,modo_configuracion:C,formato_salida:I,tipo_medio:T}=c;if(R==="Venta")r({fields:["fase_plantilla","tipo_plantilla","modo_configuracion","categoria","tipo_medio"],value:!1}),C==="Default"?(r({fields:["tipo_medio","formato_salida"],value:!1}),r({fields:["medio_especifico"],value:!0}),["Sitios Fijos","Vallas Móviles","Indoors"].includes(T)||r({fields:["formato_salida","medio_especifico"],value:!0}),I==="Digital"?(r({fields:["responsable_impresion"],value:!0}),r({fields:["pertenencia_medio","ubicacion_medio"],value:!1})):r({fields:["responsable_impresion","pertenencia_medio","ubicacion_medio"],value:!1})):(["Sitios Fijos","Indoors"].includes(T)&&r({fields:["formato_salida","medio_especifico"],value:!1}),["Vallas Móviles"].includes(T)&&(r({fields:["formato_salida"],value:!1}),r({fields:["medio_especifico"],value:!0})),["Camiones","Brand Riders"].includes(T)&&r({fields:["formato_salida","medio_especifico"],value:!0}),I==="Digital"?(r({fields:["responsable_impresion"],value:!0}),r({fields:["pertenencia_medio","ubicacion_medio"],value:!1})):r({fields:["responsable_impresion","pertenencia_medio","ubicacion_medio"],value:!1}));else if(r({fields:["modo_configuracion"],value:!1}),r({fields:["tipo_plantilla","categoria"],value:!0}),C=="Default"){const V=["formato_salida","medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"];r({fields:["tipo_medio"],value:!1}),r({fields:V,value:!0})}else["Sitios Fijos","Indoors"].includes(T)?(r({fields:["formato_salida"],value:!0}),r({fields:["medio_especifico"],value:!1})):r({fields:["responsable_impresion","pertenencia_medio","ubicacion_medio"],value:!0})}catch(R){console.error("Error al aplicar reglas de habilitar y deshabilitar campos",R)}};return u.useEffect(()=>{(i||d)&&o&&(v(),M())},[i,d,o]),u.useEffect(()=>{(i||d)&&c&&F()},[i,c,d]),{savePlantilla:b,getTemplateWithTasks:w}}const pi=()=>{const{watch:e,getValues:t}=Ee.useFormContext(),{templateFormData:n,isDuplicateTemplate:s,currentTemplateForEdit:o}=Fe(),[i,r]=u.useState(!1),l=u.useRef(null),d=u.useRef(null),c=u.useRef(!1),m=e();return u.useEffect(()=>{if(!c.current&&s&&o){const x=setTimeout(()=>{l.current=t(),d.current={...n},c.current=!0,r(!1)},500);return()=>clearTimeout(x)}},[s,o,t,n]),u.useEffect(()=>{if(l.current&&d.current&&c.current){const x=t(),p=n,h=JSON.stringify(x)!==JSON.stringify(l.current),y=JSON.stringify(p)!==JSON.stringify(d.current);r(h||y)}},[m,n,t]),{hasChanges:i,resetChanges:()=>{l.current=null,d.current=null,c.current=!1,r(!1)}}},fi=({onReset:e})=>{const{hasChanges:t,resetChanges:n}=pi(),{setHasFormChanges:s}=Fe();return u.useEffect(()=>{s(t)},[t,s]),u.useEffect(()=>{e(n)},[e,n]),null},gi=({isOpen:e,onClose:t})=>{const{step:n,nextStep:s,prevStep:o,onStepChange:i}=ni({limit:3}),r=st(A=>A.reset),{templateFields:l,resetTemplateFormData:d}=Kt(),{clave:c,resetClave:m,resetDisabledFields:f,isEditTemplate:x,setIsEditTemplate:p,refetch:h,isDuplicateTemplate:y,hasFormChanges:w,setIsDuplicateTemplate:j,setCurrentTemplateForEdit:b}=Fe(),{openTemplate:v}=Be(),[M,F]=u.useState(!1),[R,C]=u.useState(""),[I,T]=u.useState(!1),V=u.useRef(null),z=A=>{V.current=A},ee=u.useMemo(()=>ci(l),[l]),G=n===1,k=n===3,E=G?"Cancelar":"Atrás",L=Ee.useForm({mode:"onChange",defaultValues:ee}),{trigger:B,reset:q,clearErrors:X,getValues:H}=L,{savePlantilla:re}=ui(H,q),Y=u.useRef(!1);u.useEffect(()=>{e&&(r(),Y.current=!1)},[e,r]),u.useEffect(()=>{e&&!x&&!y&&!Y.current&&(q(ee),d(),Y.current=!0)},[e,x,y,q,ee,d]);const P=async()=>{if(await B()){if(n===3){if(!w&&y){C("Ya existe un proceso con éstos parámetros. Modifica al menos uno para poder duplicarlo."),T(!0);return}try{F(!0);const K=await re();if(K.success){const S=K.data;if(D(),Q(),T(!1),!x)try{await v({template:S,statusTemplate:we.NEW})}catch(N){console.warn("La plantilla se creó exitosamente pero hubo un problema al abrirla:",N)}h()}else{const{error:S}=K;C(S),T(!0)}}catch(K){console.error("Error inesperado al guardar la plantilla:",K);return}finally{F(!1)}}s()}},$=()=>{C(""),T(!1)},Q=()=>{X(),q(ee),d(),f(),m(),$(),p(!1),j(!1),b(null),V.current&&V.current()},D=()=>{Q(),Y.current=!1,t(),console.log("cerrar modal")};return M?a.jsx(ot,{isLoading:M}):a.jsxs(Ee.FormProvider,{...L,children:[a.jsx(fi,{onReset:z}),a.jsx(g.Modal,{isOpen:e,closeAtCancel:!1,onSuccess:P,cancelButtonText:E,successButtonText:k?x?"Guardar":"Crear":"Continuar",onCancel:G?D:o,onClose:D,size:"sm",iconConfig:{icon:ne.faFilePen},title:x?"Editar flujo de trabajo":"Nuevo flujo de trabajo",children:a.jsxs(g.Modal.Body,{children:[a.jsx("div",{className:"tm-flex tm-w-full tm-overflow-x-auto tm-pb-16 tm-pt-12",children:a.jsx("div",{className:"tm-flex tm-w-full",style:{justifyContent:"center",minWidth:"fit-content"},children:a.jsx(g.Stepper,{currentStep:n-1,onStepChange:A=>i(A+1),steps:[{title:"Paso 1",description:"INFORMACIÓN"},{title:"Paso 2",description:"DETALLES"},{title:"Paso 3",description:"PRODUCCIÓN"}]})})}),a.jsx("div",{className:"tm-flex tm-w-full tm-justify-center",children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-gap-0",children:[a.jsx("div",{className:"tm-bg-canvas-default tm-rounded-[100px] tm-p-2",style:{width:"fit-content",minWidth:"fit-content"},children:a.jsx("div",{className:"tm-font-bold tm-py-1 tm-p-[90px]",children:c})}),a.jsx("div",{className:"tm-bg-blue-500 tm-text-white tm-px-3 tm-py-1.5 tm-font-medium tm--mt-4",style:{borderRadius:"100px",fontSize:"10px"},children:"CLAVE"})]})}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-4 tm-p-16",children:[I&&a.jsx(g.Alert,{open:!0,color:"danger",message:R,className:"tm-mb-6",onClose:$}),a.jsx(li,{step:n})]})]})})]})},hi=({isOpen:e,onClose:t,replaceTemplate:n})=>a.jsx(a.Fragment,{children:a.jsx(g.Modal,{isOpen:e,closeAtCancel:!1,cancelButtonText:"Cancelar",successButtonText:"Abrir",onCancel:t,onClose:t,onSuccess:n,size:"sm",iconConfig:{icon:me.faExclamationTriangle},title:"Límite de flujos de trabajo",children:a.jsx(g.Modal.Body,{children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-overflow-auto tm-w-full tm-p-4 tm-gap-8",children:[a.jsx("div",{className:"tm-flex tm-justify-center tm-w-full",style:{minWidth:"fit-content"},children:a.jsx("div",{className:"tm-flex tm-justify-center tm-items-center tm-gap-[10px] tm-rounded-full tm-p-16",style:{backgroundColor:"#EBEEF9"},children:a.jsx(g.Icon,{name:me.faExclamationTriangle,size:"lg",color:"blue"})})}),a.jsx("div",{className:"tm-text-center tm-mt-6",children:a.jsx("h2",{className:"tm-text-[24px] tm-font-bold tm-text-brand tm-leading-tight",children:"¿Quieres continuar?"})}),a.jsx("div",{className:"tm-text-center tm-mt-2",children:a.jsx("div",{className:"tm-text-[12px] tm-font-normal tm-text-[#6B6B6B]",children:"Ya tienes 5 flujos de trabajo abiertos, si abres uno nuevo, se cerrará automáticamente el que lleva más tiempo sin usarse."})})]})})})}),xi=Ue.create(e=>({cachedTemplate:null,canCreateTemplate:!1,setCachedTemplate:t=>e({cachedTemplate:t}),clearCachedTemplate:()=>e({cachedTemplate:null}),setCanCreateTemplate:t=>{const n=!(t<5);e({canCreateTemplate:n})}})),bi=({isOpen:e,onClose:t,discardChanges:n,saveAndExit:s})=>a.jsx("div",{children:a.jsx(g.Modal,{isOpen:e,closeAtCancel:!0,cancelButtonText:"Cancelar",successButtonText:"Guardar y salir",onCancel:t,onClose:t,onSuccess:s,size:"sm",iconConfig:{icon:me.faExclamationTriangle},title:"Cambios sin guardar",children:a.jsx(g.Modal.Body,{children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-overflow-auto tm-w-full tm-p-4 tm-gap-8",children:[a.jsx("div",{className:"tm-flex tm-justify-center tm-w-full",style:{minWidth:"fit-content"},children:a.jsx("div",{className:"tm-flex tm-justify-center tm-items-center tm-gap-[10px] tm-rounded-full tm-p-16 tm-bg-canvas-default",children:a.jsx(g.Icon,{name:me.faSave,size:"lg",color:"brand"})})}),a.jsx("div",{className:"tm-flex tm-flex-col tm-mx-6",children:a.jsx(g.Alert,{open:!0,variant:"outlined",color:"danger",showCloseButton:!1,message:"Tienes cambios sin guardar en este flujo de trabajo",title:"No has guardado",className:"tm-mt-8"})}),a.jsx("div",{className:"tm-text-center tm-mt-5",children:a.jsx("h2",{className:"tm-text-[24px] tm-font-bold tm-text-brand",children:"¿Qué deseas hacer antes de salir?"})}),a.jsx("div",{className:"tm-text-center tm-mt-1",children:a.jsx("div",{className:"tm-text-[12px] tm-font-normal tm-text-[#6B6B6B]",children:"Si sales ahora sin guardar se perderán los cambios actuales."})}),a.jsx("div",{className:"tm-flex tm-justify-center tm-mt-4",children:a.jsx(g.Button,{size:"xs",color:"secondary",onClick:()=>{n(),t()},children:"Descartar cambios"})})]})})})}),js=({isOpen:e,onClose:t,publishTemplate:n})=>a.jsx(g.Modal,{isOpen:e,closeAtCancel:!0,cancelButtonText:"Cancelar",successButtonText:"Confirmar",onCancel:t,onClose:t,onSuccess:n,size:"sm",iconConfig:{icon:me.faArrowUp},title:"Publicar",children:a.jsx(g.Modal.Body,{children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-overflow-auto tm-w-full tm-p-8 tm-gap-16",children:[a.jsx("div",{className:"tm-flex tm-justify-center tm-w-full",style:{minWidth:"fit-content"},children:a.jsx(g.Icon,{name:me.faArrowUp,size:"lg",color:"blue",background:!0,padding:"lg"})}),a.jsx("div",{className:"tm-text-center",children:a.jsx("h2",{className:"tm-text-[24px] tm-font-bold tm-text-[#3658C1] tm-leading-tight",children:"¿Estás seguro de que deseas publicar este proceso?"})}),a.jsx("div",{className:"tm-text-center",children:a.jsx("div",{className:"tm-text-[12px] tm-font-normal tm-text-[#6B6B6B]",children:"Al publicar este proceso, estará disponible para su uso en los flujos correspondientes. Asegúrate de que toda la información sea correcta antes de continuar."})})]})})}),yi=()=>{const e="grid",t="create-edit",n=u.useRef(null),{isOpenModalLimit:s,setIsOpenModalLimit:o,setOpenModalCreateTemplate:i,openModalCreateTemplate:r,setOpenModalUnsavedChanges:l,openModalUnsavedChanges:d,openModalPublishTemplate:c,setOpenModalPublishTemplate:m,setCurrentTemplateForEdit:f,setIsDuplicateTemplate:x,setIsEditTemplate:p}=Fe(),{removeTemplateStates:h}=nt(),{mode:y,setMode:w,setViewMode:j,getViewMode:b}=_e(),{setCanCreateTemplate:v,canCreateTemplate:M}=xi(),F=y===e,{screens:R,get:C,delete:I,activeTemplate:T,activateTemplate:V,reorderingTemplates:z,replaceTemplate:ee,saveTemplateChanges:G,publishTemplate:k,loadingPublishTemplate:E,loadingSaveChanges:L}=Be(),B=178,[q,X]=u.useState([]),[H,re]=u.useState([]),[Y,P]=u.useState(null),[$,Q]=u.useState(!1),D=T!=null&&T.id?b(T.id):"readonly";u.useEffect(()=>{const J=()=>{if(!n.current)return;const ce=n.current.offsetWidth;let le=0;const te=[],ue=[],fe=10,he=n.current.querySelector("button:not([data-screen])"),pe=n.current.querySelector(".tm-mx-1");let be=0;he&&(be+=he.getBoundingClientRect().width),pe&&R.length>0&&(be+=pe.getBoundingClientRect().width,be+=fe);const Me=(ye,ke)=>{const et=ke?54:0,Wt=(ye==null?void 0:ye.length)*8;return Math.max(80,Wt+40+et)},Se=ce-B-be;R.forEach((ye,ke)=>{const ft=!!(ye.isNew||ye.badgeLabel),rt=Me(ye.clave,ft),it=ke>0?fe:0,et=rt+it;le+et<=Se?(te.push(ye),le+=et):ue.push(ye)}),X(te),re(ue)},se=()=>{const ce=R.length;v(ce)};return R.length>0&&(J(),se(),window.addEventListener("resize",J)),()=>{window.removeEventListener("resize",J)}},[R,y]);const A=J=>J.estatus===we.DIRTY||J.estatus===we.NEW,K=async J=>{A(J)?(P(J.id),l(!0)):await I(J.id)},S=()=>m(!0),N=async()=>{await I(Y),await h(Y)},U=async()=>{await G(!1)},O=async()=>{await G()},_=()=>{var se,ce;const J=(ce=(se=T==null?void 0:T.graph_layout)==null?void 0:se.snapshot)==null?void 0:ce.nodes.length;Q(()=>J-1>=1)};u.useEffect(()=>{_()},[T,D]);const W=()=>!((T==null?void 0:T.estatus)==we.IDLE&&$&&T.estatusFromStrapi!==Pe.PUBLISHED),Z=()=>{var se;const{nodes:J}=(se=T==null?void 0:T.graph_layout)==null?void 0:se.snapshot;return J==null?void 0:J.some(ce=>ce.type!=="start"&&(ce==null?void 0:ce.data.tarea_padre)===null&&(ce==null?void 0:ce.data.id_t_requerida)===null)},ae=()=>(T==null?void 0:T.estatus)===we.IDLE||Z()?!0:!$,ie=async()=>{await k(T.id)};return L||E?a.jsx(ot,{isLoading:L||E}):a.jsxs("div",{className:"tm-flex tm-gap-4 tm-justify-between tm-items-center tm-flex-wrap",children:[r&&a.jsx(gi,{isOpen:r,onClose:()=>i(!1)}),s&&a.jsx(hi,{isOpen:s,onClose:()=>o(!1),replaceTemplate:ee}),d&&a.jsx(bi,{isOpen:d,onClose:()=>l(!1),discardChanges:N,saveAndExit:O}),c&&a.jsx(js,{isOpen:c,onClose:()=>m(!1),publishTemplate:ie}),a.jsxs("div",{className:"tm-flex tm-gap-2.5 tm-items-center tm-justify-between tm-flex-1 tm-flex-wrap",ref:n,children:[a.jsxs("div",{className:"tm-flex tm-gap-2.5 tm-items-center tm-justify-start tm-flex-1 tm-flex-wrap",children:[a.jsx(g.Button,{size:"xs",color:F?"primary":"secondary",onClick:()=>w(e),children:"Listado de flujos"}),R.length>0&&a.jsx(g.Separator,{vertical:!0,className:"tm-mx-1"}),R.filter(J=>q.some(se=>se.clave===J.clave)).map(J=>{const se=(T==null?void 0:T.clave)===J.clave&&y===t;return a.jsxs(g.Button,{"data-screen":J.clave,size:"xs",onClick:async()=>{await V(J),w(t,J.id)},color:se?"primary":"secondary",leftSlot:Ne.faFilePen,badgeColor:A(J)?"warning":void 0,onClickRightSlot:()=>K(J),rightSlot:Ne.faXmark,children:[J.clave," ",J.status]},J.id)})]}),H.length>0&&a.jsx(g.Popup,{absolute:!0,rightSlot:Ne.faAngleDown,label:`${H.length}+`,size:"xs",color:"secondary",children:a.jsx("div",{className:"tm-py-2 tm-gap-4",style:{minWidth:"280px"},children:a.jsx(g.List,{icon:Ne.faFilePen,items:H.map(J=>({id:J.id,label:J.clave})),className:"tm-p-8 tm-gap-4",onClick:async J=>{const se=await C(J.id);await z(se.id),await V(se),w("create-edit",se.id)}})})})]}),y===t?a.jsx("div",{className:"tm-flex tm-gap-4 tm-items-center tm-justify-end tm-flex-wrap",children:T.estatusFromStrapi!==Pe.PUBLISHED&&a.jsxs(a.Fragment,{children:[a.jsx(g.Button,{color:"secondary",size:"xs",leftSlot:Ne.faArrowUp,disabled:W(),onClick:S,children:"Publicar"}),D=="readonly"&&a.jsx(g.Button,{size:"xs",color:"primary",leftSlot:Ne.faEdit,onClick:()=>(T==null?void 0:T.id)&&j(T.id,"edit"),children:"Editar"}),D==="edit"&&a.jsx(g.Button,{size:"xs",color:"primary",leftSlot:Ne.faSave,onClick:U,disabled:ae(),children:"Guardar"})]})}):a.jsx(g.Button,{disabled:M,tooltip:M?"Límite de 5 plantillas con cambios sin guardar. Guarda y cierra alguna para crear una nueva.":"",leftSlot:Ne.faPlus,size:"xs",color:"primary",onClick:()=>{f(null),x(!1),p(!1),i(!0)},children:"Nuevo flujo"})]})},ji=({isOpen:e,onClose:t,deleteTemplate:n})=>a.jsx(g.AlertDialog,{title:"Eliminar Borrador",iconContent:me.faBan,heading:"¿Estás seguro?",subheading:"Si eliminas este borrador, también se borrarán todas sus tareas y conexiones con otros borradores.",icon:me.faBan,label:"Escribe 'Eliminar' para continuar",confirmationText:"Eliminar",isOpen:e,onClose:t,onConfirm:n,placeholder:""}),wi=()=>{const{viewMode:e,setRefetch:t,openModalPublishTemplate:n,setOpenModalPublishTemplate:s,currentTemplateId:o,setOpenModalDeleteTemplate:i,openModalDeleteTemplate:r}=Fe(),{publishTemplate:l,deleteTemplate:d}=Be(),{debouncedSearch:c,filters:m}=is("templates-container"),f=e==="list",[x,p]=u.useState(1),h=9,{data:y,isLoading:w,isFetching:j,refetch:b}=bs({page:x,pageSize:h,search:c,filters:m});u.useEffect(()=>{t(b)},[]),u.useEffect(()=>{p(1)},[m,c]);const{users:v}=Ze(),{getImageOBP:M}=ge(),F=T=>{if(!(T!=null&&T.email))return"";const V=v==null?void 0:v[T==null?void 0:T.email];return V!=null&&V.image?M(V==null?void 0:V.image):""},R=u.useMemo(()=>{try{return!y||!v?[]:y.data.map(T=>{const V=F((T==null?void 0:T.updated_by)||(T==null?void 0:T.created_by));return{...T,updated_by:{...T.updated_by,image:V}}})}catch(T){return console.error("Error al mapear las plantillas:",T),[]}},[y,v]),C=async()=>{await l(o),await b()},I=async()=>{await d(o),await b()};return w||j?a.jsx(ot,{isLoading:w||j}):a.jsxs("div",{className:"tm-flex tm-flex-col tm-justify-between tm-gap-y-4 tm-h-full",children:[a.jsx(js,{isOpen:n,onClose:()=>s(!1),publishTemplate:C}),a.jsx(ji,{isOpen:r,onClose:()=>i(!1),deleteTemplate:I}),a.jsx("div",{className:`tm-grid tm-gap-12 ${f?"tm-grid-cols-1":"tm-grid-cols-1 md:tm-grid-cols-2 lg:tm-grid-cols-3"}`,children:R.map(T=>a.jsx(ps,{fullWidth:f,template:T},T.id))}),a.jsx("div",{children:a.jsx(g.Pagination,{pageSize:h,pageCount:y==null?void 0:y.meta.pagination.pageCount,currentPage:x,onPageChange:T=>p(T)})})]})},ws=()=>{var r,l,d,c;const e="grid",t="create-edit",{mode:n}=_e(),s=n===e,o=n===t,i=Oe(m=>m.activeTemplate);return a.jsxs("div",{className:"tm-h-full tm-flex tm-flex-col tm-gap-y-6",children:[a.jsx(yi,{}),s&&a.jsx(wi,{}),o&&a.jsx(si,{initialNodes:((l=(r=i==null?void 0:i.graph_layout)==null?void 0:r.snapshot)==null?void 0:l.nodes)||[],initialEdges:((c=(d=i==null?void 0:i.graph_layout)==null?void 0:d.snapshot)==null?void 0:c.edges)||[]})]})},vi=()=>({header:a.jsx(ur,{}),body:a.jsx(ws,{})});function _i(e){const{users:t}=uo(),{tasks_api:n,getImageOBP:s}=ge(),o=u.useMemo(()=>t.data?t.data.map(l=>{const{image:d,id:c,name:m}=l,f=s(d);return{value:c,label:m,icon:f}}):[],[t.data]),i=async l=>{const d=Ce.stringify({populate:{params_plantillas:{fields:["id","abbreviation","name","active","tipomedio_nombre","reference_id"]}},sort:["order:asc"],fields:["id","step","key","label","order"]},{encodeValuesOnly:!0}),{data:c}=await l.get(`/api/params-tipos?${d}`);return xe(c.data).flatMap((f,x)=>{const p={id:`group-${x+1}`,label:f.label,value:`group-${x+1}`,isGroupTitle:!0},h=f.params_plantillas.map(y=>({id:y.id,label:y.name,value:y.id,checked:!1,icon:"CheckCircleOutlined",iconColor:"blue"}));return[p,...h]})},r=de.useQuery({queryKey:["paramsPlantilla"],queryFn:()=>i(n),enabled:e==="templates-container",staleTime:1e3*60*30});return{userOptions:o,paramsPlantillasOptions:r.data||[]}}const Ti={estatus:{label:"Estatus del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[{value:"draft",label:"Borrador"},{value:"published",label:"Publicada"}],keyName:"estatus"},publication_date:{label:"Fecha de publicación",placeholder:"Ingresa una fecha...",type:"date",keyName:"publication_date"},propietario:{label:"Encargado del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[],keyName:"propietario"},created_by:{label:"Creador del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[],keyName:"created_by"},updated_by:{label:"Editor del flujo",type:"dropdown",placeholder:"Selecciona uno...",options:[],keyName:"updated_by"},params_plantillas:{label:"Parámetro del flujo",type:"group",placeholder:"Selecciona uno o varios...",options:[],keyName:"params_plantillas"}},Ni={createdAt:{label:"Fecha de creación",placeholder:"Selecciona una fecha...",type:"date",keyName:"createdAt"},integrantes_min:{label:"Mínimo de integrantes",type:"input",placeholder:"Ej: 1",keyName:"integrantes_min"},integrantes_max:{label:"Máximo de integrantes",type:"input",placeholder:"Ej: 10",keyName:"integrantes_max"}},Ci={"templates-container":Ti,"teams-container":Ni,"kanban-general":null,"lista-campanias":null,"kanban-campania":null},Si=e=>({inputFilters:Ci[e]||null}),Ei=e=>{const{inputFilters:t}=Si(e),{userOptions:n,paramsPlantillasOptions:s}=_i(e);return{inputFilters:u.useMemo(()=>{if(t&&n.length>0&&s.length>0){const i=t;return[{...i.estatus},{...i.publication_date},{...i.propietario,options:n},{...i.created_by,options:n},{...i.updated_by,options:n},{...i.params_plantillas,options:s}]}return null},[e,t,n,s])}};function Pi(){const{setFilters:e}=ut(),{refetch:t}=Fe();return{handleApplyFilters:s=>{let o={...s};o=Object.fromEntries(Object.entries(o).filter(([i,r])=>!(r===""||r===null||Array.isArray(r)&&r.length===0))),"publication_date"in o&&o.publication_date!==""&&(o={...o,publication_date:Nt(o.publication_date).format("YYYY-MM-DD")}),e(o,"templates-container"),t&&t()}}}const Na="templates-container";function Ai(){const{mode:e}=_e(),{inputFilters:t}=Ei(Na),{handleApplyFilters:n}=Pi(),{viewMode:s,setViewMode:o}=Fe();return e!=="grid"?null:a.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-2.5 md:tm-flex-nowrap",children:[a.jsx(rs,{path:Na}),a.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-x-8 md:tm-flex-nowrap",children:[t&&a.jsx(g.Filters,{filters:t,onApply:n}),a.jsx(g.Button,{size:"xs",color:"secondary",icon:s==="list"?ne.faGrid2:ne.faList,className:"tm-min-w-fit",onClick:()=>o(s==="list"?"grid":"list")})]})]})}const Ct={id:null,uid:0,esEncargado:!1,idUser:{id:0,username:"",email:"",provider:"",confirmed:!1,blocked:!1,createdAt:"",updatedAt:"",nombre:""},miembros:[],miembro_padre:null,createdAt:new Date().toISOString(),updatedAt:new Date().toISOString()},Vt="Project Manager",vs=({open:e,handleChange:t,children:n,title:s="¿Estás seguro?",onConfirm:o,contentLabel:i="",confirmLabel:r="Aceptar",cancelLabel:l="Regresar",isLoading:d=!1})=>a.jsx(g.Modal,{isOpen:e,onClose:()=>t(!1),onCancel:()=>t(!1),onSuccess:o,size:"xs",title:s,disableEscapeClose:!0,disableOutsideClick:!0,disableOutsideTab:!0,children:a.jsxs(g.Modal.Body,{children:[a.jsx(g.Text,{children:i}),n&&n]})}),Ii=({member:e,level:t,isUpdate:n=!1,addHandler:s,updateHandler:o,removeHandler:i,updateMemberHandler:r})=>{var ee,G,k;const{users:l,isLoading:d}=pt(),{users:c,isLoading:m}=Ze(),{getImageOBP:f}=ge(),[x,p]=u.useState(!1),[h,y]=u.useState(n?e:{...Ct,miembro_padre:t>1?e:null}),[w,j]=u.useState(null),[b,v]=u.useState({id:0,nombre:"",email:""}),[M,F]=u.useState(!1);u.useEffect(()=>{var E;j(c==null?void 0:c[(E=h==null?void 0:h.idUser)==null?void 0:E.email])},[h,c]),u.useEffect(()=>{e&&y({...e,miembro_padre:t>1?e.miembro_padre:null})},[e,t]);const R=u.useMemo(()=>(l||[]).map(E=>{var q,X;const L=c==null?void 0:c[E.email??""],B=L!=null&&L.image?f(L.image):"";return{...E,label:E.name,value:E.id,subtitle:E.email??"",avatar:((X=(q=E.name)==null?void 0:q.slice(0,2))==null?void 0:X.toUpperCase())??"",avatarUrl:B}}),[l,c,f]),C=()=>{p(!1),v({id:0,nombre:"",email:""})},I=({id:E,name:L,email:B})=>{const q={...h,idUser:{...h.idUser,id:E,nombre:L,email:B}};y(q),o(q),v({id:E,nombre:L,email:B})},T=async()=>{if(!b.nombre&&!b.email){C();return}try{h.id&&r({user_id:b.id,miembro_id:e.id});const E={...h,idUser:{...h.idUser,id:b.id,nombre:b.nombre,email:b.email}};y(E),o(E),j(c==null?void 0:c[b.email]),C()}catch(E){g.toast.error(E instanceof Error?E.message:"Error al actualizar el colaborador")}},V=()=>{const E={...Ct,uid:new Date().getTime()+Math.floor(Math.random()*1e3),miembro_padre:e,miembros:[]};s(E)},z=()=>{i(e),F(!1)};return m||d?null:a.jsxs("div",{className:"tm-flex tm-items-baseline tm-justify-between",children:[M&&a.jsx(vs,{open:M,handleChange:F,onConfirm:z,contentLabel:"Estás eliminando el colaborador seleccionado"}),a.jsxs("div",{className:"tm-flex tm-flex-1 tm-justify-between tm-gap-y-4 tm-mb-2",children:[a.jsxs("div",{children:[a.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-6 tm-mb-2",children:(ee=h==null?void 0:h.idUser)!=null&&ee.email&&!x?a.jsxs(a.Fragment,{children:[a.jsx(Ae,{size:"m",alt:((G=h==null?void 0:h.idUser)==null?void 0:G.nombre)??"Avatar",imageUrl:w!=null&&w.image?f(w.image):""}),a.jsx("p",{className:"tm-text-body-sm-regular tm-font-body-sm-regular tm-leading-body-sm-regular tm-tracking-body-sm",children:(k=h==null?void 0:h.idUser)==null?void 0:k.nombre})]}):a.jsx(g.Dropdown,{placeholder:"Seleccionar colaborador",options:R,valueName:"name",idName:"id",listVariant:"user",absolute:!0,closeOnClickOutside:!0,searchable:!0,searchPlaceholder:"Buscar colaborador...",onOptionSelect:E=>{I({id:E.id,name:E.name,email:E.email})}})}),a.jsx(g.Button,{onClick:V,leftSlot:ne.faPlus,size:"xxs",color:"tertiary",children:"Añadir colaborador"})]}),a.jsxs("div",{className:"tm-flex tm-gap-x-4",children:[x?a.jsxs(a.Fragment,{children:[a.jsx(g.Button,{onClick:C,icon:ne.faXmark,size:"xs",color:"secondary",tooltip:"Cancelar"}),a.jsx(g.Button,{onClick:T,icon:ze.faCheck,size:"xs",color:"primary",tooltip:"Guardar"})]}):a.jsx(g.Button,{onClick:()=>p(!0),icon:ne.faPencil,size:"xs",color:"tertiary",tooltip:"Editar"}),a.jsx(g.Button,{onClick:()=>F(!0),icon:ne.faTrash,size:"xs",color:"destructive",tooltip:"Eliminar"})]})]})]})},_s=({members:e,level:t=1,isUpdate:n=!1,setData:s})=>{const o=()=>{s(i=>({...i,miembros:[...i.miembros,{...Ct,uid:new Date().getTime()+Math.floor(Math.random()*1e3)}]}))};return a.jsxs("div",{children:[(e==null?void 0:e.length)===0&&t===1&&a.jsx("div",{className:"tm-flex tm-justify-end",children:a.jsx(g.Button,{size:"xxs",color:"tertiary",leftSlot:ze.faPlus,onClick:o,children:" Agregar miembro del equipo "})}),(e==null?void 0:e.length)>0&&(e==null?void 0:e.map(i=>a.jsx(Di,{isUpdate:n,member:i,level:t,setData:s},i.uid)))]})},Di=({member:e,level:t,isUpdate:n=!1,setData:s})=>{const o=c=>{s(m=>{if(!c.miembro_padre)return{...m,miembros:[...m.miembros,c]};const f=x=>x==null?void 0:x.map(p=>p.uid===c.miembro_padre.uid?{...p,miembros:[...p.miembros||[],c]}:p.miembros&&p.miembros.length>0?{...p,miembros:f(p.miembros)}:p);return{...m,miembros:f(m.miembros)}})},i=c=>{s(m=>{const f=x=>x.map(p=>p.uid===c.uid?(p.miembros&&p.miembros.length>0&&p.miembros.forEach(h=>{h.miembro_padre=c}),{...c,miembros:p.miembros||[]}):p.miembros&&p.miembros.length>0?{...p,miembros:f(p.miembros)}:p);return{...m,miembros:f(m.miembros)}})},r=c=>{var f;const m=[];return c.id&&m.push(c.id),(f=c.miembros)!=null&&f.length&&c.miembros.forEach(x=>{m.push(...r(x))}),m},l=c=>{s(m=>{const f=r(c),x=h=>h.filter(y=>y.uid!==c.uid).map(y=>({...y,miembros:y.miembros?x(y.miembros):[]})),p=m.miembros_actualizar.filter(h=>!f.includes(h.miembro_id));return{...m,miembros:x(m.miembros),miembros_eliminar:[...m.miembros_eliminar,...f],miembros_actualizar:p}})},d=c=>{s(m=>m.miembros_actualizar.some(x=>x.miembro_id===c.miembro_id)?m:{...m,miembros_actualizar:[...m.miembros_actualizar,c]})};return a.jsxs("div",{"data-id":e.uid,style:{paddingLeft:t===1?0:"30px",marginTop:t===1?"15px":"0px",paddingBottom:"5px"},children:[a.jsx(Ii,{isUpdate:n,level:t,member:e,addHandler:o,updateHandler:i,removeHandler:l,updateMemberHandler:d}),Array.isArray(e.miembros)&&e.miembros.length>0&&a.jsx(_s,{isUpdate:n,members:e.miembros,level:t+1,setData:s})]},e.uid)},Fi=()=>"#"+Math.floor(Math.random()*16777215).toString(16),Mi=({search:e,filters:t})=>{const n={};return e!=null&&e.trim()&&(n.nombre={$containsi:e.trim()}),t!=null&&t.createdAt&&(n.createdAt={$eq:t.createdAt}),n},ki=({items:e})=>{if(!e)return{members:[],allMembers:[]};const t={};for(const r of e)t[r.uid]=r;const n=[],s=new Set,o=r=>{const l={...r};if(l.id&&(l.uid=l.id),l.uid&&!s.has(l.uid)&&(n.push(l),s.add(l.uid)),!l.miembros)return l;const d=l.miembros.map(c=>{const m={...c};m.id&&(m.uid=m.id);const f=t[m.uid];return o(f||m)}).filter(Boolean);return{...l,miembros:d}};return{members:e.filter(r=>r.miembro_padre===null).map(o),allMembers:n}},Li=({items:e})=>e?e.map(t=>{const n=ki({items:t.miembros});return{...t,integrantes:n.allMembers.length,miembros:n.members,miembros_planos:n.allMembers,miembros_eliminar:[],miembros_actualizar:[]}}):[],Oi=async({tasks_api:e,page:t=1,pageSize:n=10,search:s="",filters:o={}})=>{const i=Ce.stringify({filters:Mi({search:s,filters:o}),populate:fs(),sort:["createdAt:asc"],pagination:{page:t,pageSize:n}},{encodeValuesOnly:!0}),r=await e.get(`/api/equipos?${i}`);return r.data?{data:xe(r.data.data),meta:r.data.meta}:{data:[],meta:{pagination:{page:t,pageSize:n,pageCount:0,total:0}}}},Bi=({page:e=1,pageSize:t=10,search:n="",filters:s={}})=>{const{tasks_api:o}=ge();return de.useQuery({queryKey:["teams",e,t,n,s],queryFn:()=>Oi({tasks_api:o,page:e,pageSize:t,search:n,filters:s}),staleTime:1e3*60*60*24,placeholderData:de.keepPreviousData,select:i=>({data:Li({items:(i==null?void 0:i.data)||[]}),meta:i==null?void 0:i.meta})})},St=e=>({...e,miembro_padre:e.miembro_padre?{id:e.miembro_padre.id,uid:e.miembro_padre.uid}:null,idUser:e.idUser?{id:e.idUser.id,nombre:e.idUser.nombre,email:e.idUser.email,image:e.idUser.image}:null,miembros:e.miembros?e.miembros.map(St):[]}),Ts=()=>{const{tasks_api:e}=ge(),t=de.useQueryClient(),n=async x=>{const p={...x,id:void 0,miembros:x.miembros.map(St)};return(await e.post("/api/registrar-equipo-miembros",{data:p})).data},s=async x=>(await e.delete(`/api/equipos/${x}`)).data,o=async(x,p)=>{const h={...p,id:void 0,miembros:p.miembros.map(St)};return(await e.patch(`/api/actualizar-equipo-miembros/${x}`,{data:h})).data},i=async(x,p,h)=>{const y=await e.put(`/api/miembros/${x}`,{data:{[p]:h}});if(!y.data)throw new Error("Error al actualizar el miembro");return y.data},{mutateAsync:r,isPending:l}=de.useMutation({mutationFn:s,onSuccess:()=>{t.invalidateQueries({queryKey:["teams"]})},onError:x=>{throw console.error("Failed to delete the team.",x),x}}),{mutateAsync:d}=de.useMutation({mutationFn:n,onSuccess:()=>{t.invalidateQueries({queryKey:["teams"]})},onError:x=>{throw console.error("Failed to update the team.",x),x},onMutate:async()=>{await t.cancelQueries({queryKey:["teams"]})}}),{mutateAsync:c}=de.useMutation({mutationFn:x=>o(x.teamId,x.data),onSuccess:()=>{t.invalidateQueries({queryKey:["teams"]})},onError:x=>{throw console.error("Failed to update the team.",x),x},onMutate:async()=>{await t.cancelQueries({queryKey:["teams"]})}}),{mutateAsync:m}=de.useMutation({mutationFn:x=>i(x.memberId,x.field,x.value),onError:x=>{throw console.error("Failed to update the member.",x),new Error("Error al actualizar el miembro")}});return{addTeamHandler:d,deleteTeamHandler:r,updateTeamHandler:c,updateMemberHandler:m,invalidateTeams:()=>{t.invalidateQueries({queryKey:["teams"]})},isLoadingDeleteTeam:l}},Ri=(e,t,n)=>{const s=u.useCallback(o=>{e.current&&!e.current.contains(o.target)&&t(!1)},[e,t]);u.useEffect(()=>(n&&document.addEventListener("mousedown",s),()=>{document.removeEventListener("mousedown",s)}),[s,n])},qi=({color:e,onChange:t})=>a.jsxs(a.Fragment,{children:[a.jsx("style",{children:`
|
|
11
11
|
.react-pick-color div button {
|
|
12
12
|
border-radius: 50% !important;
|
|
13
13
|
width: 20px;
|
|
@@ -24,4 +24,4 @@
|
|
|
24
24
|
.react-pick-color div label > span {
|
|
25
25
|
display: none !important;
|
|
26
26
|
}
|
|
27
|
-
`}),t.jsx("div",{className:"react-pick-color tm-overflow-hidden tm-rounded-lg tm-shadow-lg",children:t.jsx(Ls.ColorPicker,{color:e,theme:{inputBackground:"#FFF"},combinations:["monochromatic"],onChange:n=>a(n)})})]});function Mi({color:e,setColor:a,label:n="Elige el color",className:s=""}){const[o,i]=u.useState(!1),r=u.useRef(null);return Di(r,i,o),t.jsxs("div",{className:"tm-relative tm-w-full",children:[t.jsx("button",{onClick:c=>{c.stopPropagation(),i(!o)},style:{backgroundColor:e},className:`tm-h-control-xs tm-w-full tm-rounded-control-sm tm-border-[1px] tm-border-default tm-px-8 tm-text-body-sm-bold tm-text-primary tm-text-left tm-text-white ${s}`,children:n}),o&&t.jsx("div",{ref:r,className:"tm-absolute tm-z-50 tm-mt-2",children:t.jsx(Fi,{color:e,onChange:c=>a(c.hex)})})]})}const _t="Ha ocurrido un error inesperado. Por favor, intente nuevamente.",ki={"This field is required":"El campo {field} es requerido","must be defined":"El campo {field} es requerido","This attribute must be unique":"El campo {field} debe ser único","must be a string":"El campo {field} debe ser texto","must be a number":"El campo {field} debe ser un número","must be a boolean":"El campo {field} debe ser verdadero o falso","must be an array":"El campo {field} debe ser una lista","must be a valid email":"El campo {field} debe ser un correo electrónico válido","must be a valid date":"El campo {field} debe ser una fecha válida","must be a valid URL":"El campo {field} debe ser una URL válida","must be at least X characters long":"El campo {field} debe tener al menos {min} caracteres","must be less than or equal to X characters long":"El campo {field} debe tener máximo {max} caracteres","This value is too long":"El campo {field} excede el máximo de caracteres","This value is too short":"El campo {field} no cumple con el mínimo de caracteres","must be greater than or equal to X":"El campo {field} debe ser mayor o igual a {min}","must be less than or equal to X":"El campo {field} debe ser menor o igual a {max}","must be greater than X":"El campo {field} debe ser mayor a {min}","must be less than X":"El campo {field} debe ser menor a {max}","must be between X and Y":"El campo {field} debe estar entre {min} y {max}","must be an existing record":"El registro relacionado en {field} no existe","User not found":"El usuario no fue encontrado","Member not found":"El miembro no fue encontrado"},Ts=()=>({handleApiError:a=>{var n,s,o,i,r;if(a instanceof Ye.AxiosError&&((n=a.response)==null?void 0:n.status)===400){const c=a.response.data;if(((o=(s=c.details)==null?void 0:s.errors)==null?void 0:o.length)>0){const m=c.details.errors[0];let l=ki[m.message]||_t;return l=l.replace("{field}",m.path.join(".")),((i=m.params)==null?void 0:i.min)!==void 0&&(l=l.replace("{min}",m.params.min.toString())),((r=m.params)==null?void 0:r.max)!==void 0&&(l=l.replace("{max}",m.params.max.toString())),l}return c.message||_t}return _t}});function Cs({open:e,handleChange:a,team:n}){const{addTeamHandler:s,updateTeamHandler:o}=_s(),{handleApiError:i}=Ts(),[r,c]=u.useState(""),[m,l]=u.useState(n||{id:0,nombre:"",color:Ni(),miembros:[],miembros_planos:[],integrantes:0,miembros_eliminar:[],miembros_actualizar:[]}),d=m.id>0,p=async()=>{if(m.nombre.length===0){c("El nombre del equipo es requerido");return}if(m.miembros.length===0){c("El equipo debe tener al menos un miembro");return}const h=async()=>d?await o({data:m,teamId:m.id}):await s(m);try{await h(),c(""),a(!1);const f=d?"Equipo actualizado correctamente":"Equipo creado correctamente";x.toast.success(f)}catch(f){c(i(f))}};return t.jsx(x.Modal,{onCancel:()=>a(!1),onSuccess:p,title:"Información del equipo",icon:ze.faUser,showCloseButton:!0,showCancelButton:!0,showSuccessButton:!0,closeAtSuccess:!0,closeAtCancel:!0,isOpen:e,onClose:()=>a(!1),size:"lg",children:t.jsxs(x.Modal.Body,{children:[t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-8",children:[t.jsxs("div",{className:"tm-flex tm-w-full tm-items-center tm-gap-8 tm-flex-wrap",children:[t.jsx(ir,{value:m.nombre,onChange:h=>l({...m,nombre:h})}),t.jsxs("div",{className:"tm-flex tm-flex-1 tm-items-center tm-gap-x-8",children:[t.jsx("label",{className:"tm-text-body-sm-bold tm-text-primary tm-flex-1 tm-min-w-fit",children:"Color del equipo"}),t.jsx(Mi,{color:m.color,setColor:h=>l({...m,color:h})})]})]}),r&&t.jsx("p",{className:"tm-mt-4 tm-text-sm tm-text-danger-pastel",children:r})]}),t.jsxs("div",{className:"tm-mt-8",children:[t.jsx(rr,{title:"Miembros del equipo",icon:ze.faUsers}),t.jsx(vs,{members:m.miembros,setData:l,isUpdate:d})]})]})})}const Oe=384,Oi=80,Li=180,St=20,Bi=2,Ns=4,Et=.8;function Ri({data:e}){const{getImageOBP:a}=he();return t.jsxs("div",{className:"tm-w-[290px] tm-rounded-md tm-border-[0.5px] tm-border-silver-silver_regular tm-bg-white tm-px-4 tm-py-2 tm-shadow-xl",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4",children:[t.jsx("div",{className:"tm-flex tm-items-center tm-justify-center tm-rounded-full tm-bg-light-gray-50",children:t.jsx(Ae,{size:"xxl",alt:"@shadcn",imageUrl:e!=null&&e.image?a(e==null?void 0:e.image):void 0})}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-2",children:[t.jsx(x.Text,{size:"xs",weight:"bold",children:e.name}),t.jsx(x.Text,{children:e.job||"Puesto no asignado"})]})]}),t.jsx(oe.Handle,{type:"target",position:oe.Position.Top,className:"tm-bg-transparent",isConnectable:!1}),t.jsx(oe.Handle,{type:"source",position:oe.Position.Bottom,className:"tm-w-16 tm-border-none tm-bg-transparent",isConnectable:!1})]})}const qi={custom:Ri},zi={style:{stroke:"#6366f1",strokeWidth:2}},Ss=(e,a=0)=>e?e.map(n=>{const s=n.miembros?Ss(n.miembros,a+1):[];return{width:Oe,height:Oi,children:s,x:0,y:a*Li,totalWidth:0,depth:a}}):[],Es=e=>{if(e.children.length===0)return e.totalWidth=Oe,Oe;const a=e.children.reduce((o,i)=>o+Es(i),0),n=e.children.length>Ns?Et:1,s=(e.children.length-1)*St*n;return e.totalWidth=Math.max(Oe,a+s),e.totalWidth},Ps=(e,a=0)=>{let n=a;return e.forEach(s=>{s.totalWidth===0&&Es(s);const o=s.children.length>Bi,i=s.children.length>Ns;if(s.children.length>0){if(Ps(s.children,n),i){const p=(s.totalWidth-Oe)/(s.children.length-1)*Et;s.children.forEach((h,f)=>{h.x=n+f*p})}else if(o){const p=(s.totalWidth-Oe)/(s.children.length-1);s.children.forEach((h,f)=>{h.x=n+f*p})}const c=s.children[0].x,m=s.children[s.children.length-1].x+Oe,l=i?Oe*.1:0;s.x=(c+m-Oe)/2+l}else s.x=n;const r=i?Et:1;n=Math.max(n+Oe+St*r,s.x+Oe+St*r)}),n},As=(e,a,n,s)=>{const o=[],i=[];return e.forEach((r,c)=>{var d,p,h,f,g,y;const m=a[c],l=m.id.toString();if(o.push({id:l,type:"custom",data:{name:(d=m.idUser)==null?void 0:d.nombre,image:(h=n==null?void 0:n[(p=m.idUser)==null?void 0:p.email])==null?void 0:h.image,job:((y=(g=n==null?void 0:n[(f=m.idUser)==null?void 0:f.email])==null?void 0:g.role)==null?void 0:y.name)||""},position:{x:r.x,y:r.y}}),s&&i.push({id:`e-${s}-${l}`,source:s,target:l,style:{stroke:"#6366f1",strokeWidth:2}}),m.miembros&&m.miembros.length>0){const w=As(r.children,m.miembros,n,l);o.push(...w.nodes),i.push(...w.edges)}}),{nodes:o,edges:i}};function $i({members:e}){const[a,n]=u.useState([]),[s,o]=u.useState([]),{users:i,isLoading:r}=Ze();return u.useEffect(()=>{if(e&&!r){const c=Ss(e);Ps(c);const{nodes:m,edges:l}=As(c,e,i);n(m),o(l)}},[e,i,r]),r?null:t.jsx(oe.ReactFlow,{nodeTypes:qi,nodes:a,edges:s,draggable:!1,fitView:!0,defaultViewport:{x:0,y:0,zoom:1},minZoom:.5,maxZoom:2,defaultEdgeOptions:zi})}function Ui({open:e,handleChange:a,members:n}){return t.jsx(x.Modal,{showCancelButton:!1,showSuccessButton:!1,hideFooter:!0,isOpen:e,onClose:()=>a(!1),size:"xl",title:"Organigrama de equipo",children:t.jsx("div",{className:"tm-mx-auto tm-bg-white",style:{width:"100%",height:"600px"},children:t.jsx(oe.ReactFlowProvider,{children:t.jsx($i,{members:n})})})})}const Is="tm-grid tm-w-full tm-grid-cols-1 tm-items-baseline tm-gap-x-8 tm-gap-y-8 md:tm-grid-cols-2 lg:tm-grid-cols-3 lg:tm-gap-x-8 xl:tm-grid-cols-4",Hi="tm-relative tm-block tm-overflow-hidden tm-rounded-md tm-bg-gray-200 tm-bg-gradient-to-r tm-from-gray-200 tm-via-gray-50 tm-to-gray-200 tm-bg-[length:200%_100%] tm-animate-skeleton-shimmer";function qe({className:e="",rounded:a="md"}){const n=a==="full"?"tm-rounded-full":"tm-rounded-md";return t.jsx("span",{className:`${Hi} ${n} ${e}`.trim(),"aria-hidden":!0})}function Ds(){return t.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-2",children:Array.from({length:2},(e,a)=>t.jsx(qe,{className:"tm-h-8 tm-w-8 tm-shrink-0",rounded:"full"},a))})}function Ki(){const{user:e}=we(),a=(e==null?void 0:e.role)===Gt;return t.jsxs(x.Card,{className:"tm-w-full",children:[t.jsxs(x.Card.Header,{className:"tm-flex tm-items-center justify-between",children:[t.jsx("div",{className:"tm-flex tm-flex-col tm-justify-start tm-items-start tm-gap-y-2",children:t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[t.jsx(qe,{className:"tm-h-2.5 tm-w-2.5 tm-shrink-0",rounded:"full"}),t.jsx(qe,{className:"tm-h-8 tm-w-8 tm-shrink-0"}),t.jsx(qe,{className:"tm-h-5 tm-min-h-[1.25rem] tm-w-40 tm-max-w-[min(100%,10rem)]"})]})}),t.jsx("div",{children:a?t.jsx(qe,{className:"tm-h-8 tm-w-8 tm-shrink-0",rounded:"full"}):null})]}),t.jsx(x.Card.Separator,{}),t.jsxs(x.Card.Body,{scrollable:!1,children:[t.jsx(Ds,{}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4 tm-mt-2",children:[t.jsx(qe,{className:"tm-h-4 tm-w-6"}),t.jsx(qe,{className:"tm-h-4 tm-w-28"})]})]})]})}function Gi({length:e}){const n=e??10;return t.jsx("div",{"aria-busy":"true","aria-live":"polite",className:Is,children:Array.from({length:n},(s,o)=>t.jsx(Ki,{},o))})}function Vi({members:e}){const{getImageOBP:a}=he(),{users:n,isLoading:s}=Ze();if(s)return t.jsx(Ds,{});const o=e.filter(i=>{var r,c;return(c=n[(r=i.idUser)==null?void 0:r.email])==null?void 0:c.image}).slice(0,3);return t.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-2",children:t.jsx(x.Avatar,{maxVisible:2,stroke:!0,stack:o.map(i=>{var c;const r=n[(c=i.idUser)==null?void 0:c.email];return{src:a(r.image),name:r.name}}),size:"sm"})})}function Wi({team:e}){const[a,n]=u.useState(!1),[s,o]=u.useState(!1),{user:i}=we(),[r,c]=u.useState(!1),{handleApiError:m}=Ts(),{deleteTeamHandler:l,isLoadingDeleteTeam:d}=_s(),p=async()=>{try{await l(e.id),x.toast.success("Equipo eliminado correctamente")}catch(h){x.toast.error(m(h))}};return t.jsxs(x.Card,{children:[a&&t.jsx(Cs,{handleChange:n,open:a,team:e}),r&&t.jsx(ws,{isLoading:d,open:r,handleChange:c,onConfirm:p,contentLabel:"Estás eliminando el equipo seleccionado"}),s&&t.jsx(Ui,{handleChange:o,open:s,members:e.miembros}),t.jsxs(x.Card.Header,{className:"tm-flex tm-items-center tm-justify-between tm-w-full",children:[t.jsx("div",{className:"tm-flex tm-flex-col tm-justify-start tm-items-start tm-gap-y-2",children:t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8 tm-justify-between tm-w-full",children:[t.jsx(x.Badge,{size:"dot",customColor:e.color,theme:"solid"}),t.jsx(x.Icon,{name:ze.faPeopleGroup,colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,size:"md"}),t.jsx("h1",{className:"tm-py-0.5 tm-font-body-sm-bold tm-text-body-sm-bold tm-leading-none tm-text-primary",children:e.nombre})]})}),t.jsx("div",{children:(i==null?void 0:i.role)==Gt&&t.jsx(x.Popup,{size:"xs",color:"secondary",pill:"pill",icon:ne.faEllipsis,stopPropagationList:!0,children:t.jsxs(x.List,{className:"tm-gap-4",padding:"sm",children:[t.jsx(x.ListItem,{icon:ne.faPencil,onClick:()=>n(!0),children:"Editar"}),t.jsx(x.ListItem,{icon:ne.faEye,onClick:()=>o(!0),children:"Ver organigrama"}),t.jsx(x.ListItem,{color:"red",icon:ne.faTrash,onClick:()=>c(!0),children:"Eliminar"})]})})})]}),t.jsx(x.Card.Separator,{}),t.jsxs(x.Card.Body,{children:[t.jsx(Vi,{members:e.miembros_planos}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4 tm-mt-2",children:[t.jsx("p",{className:"tm-text-icon-all-colors-blue tm-text-xs tm-text-center tm-leading-none tm-font-semibold",children:e.integrantes||0}),t.jsxs("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:["Integrante",e.integrantes>1?"s":""]})]})]})]})}function Qi({teams:e}){return t.jsx("div",{className:Is,children:e==null?void 0:e.map(a=>t.jsx(Wi,{team:a},a.id))})}const Xi="teams-container";function Yi(){return t.jsx("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-2.5 md:tm-flex-nowrap",children:t.jsx(os,{path:Xi})})}function Fs(){var b,_,M,F,R;const[e,a]=u.useState(!1),[n,s]=u.useState(1),[o,i]=u.useState(10),{user:r}=we(),{debouncedSearch:c,filters:m}=rs("teams-container"),l=Array.isArray(m)?m:[];u.useEffect(()=>{s(1)},[c,m]);const{data:d,isLoading:p}=Ii({page:n,pageSize:o,search:c,filters:{nombre:"",createdAt:(b=l.find(N=>N.keyName==="createdAt"))==null?void 0:b.value,integrantes_min:(_=l.find(N=>N.keyName==="integrantes_min"))==null?void 0:_.value,integrantes_max:(M=l.find(N=>N.keyName==="integrantes_max"))==null?void 0:M.value}}),h=(d==null?void 0:d.data)||[],f=d==null?void 0:d.meta,g=((F=f==null?void 0:f.pagination)==null?void 0:F.pageCount)||0,y=((R=f==null?void 0:f.pagination)==null?void 0:R.total)||0,w=N=>{s(N)},j=N=>{i(N),s(1)};return t.jsxs("div",{className:"tm-grid tm-h-full tm-grid-rows-[auto,1fr] tm-gap-y-8",children:[e&&t.jsx(Cs,{handleChange:a,open:e}),(r==null?void 0:r.role)===Gt&&t.jsx("div",{className:"tm-flex tm-items-center tm-justify-end",children:t.jsx(x.Button,{size:"xs",color:"primary",leftSlot:ne.faPlus,onClick:()=>a(!0),children:" Nuevo equipo "})}),t.jsx("div",{className:"custom-scrollbar",style:{scrollbarGutter:"stable",paddingRight:"4px"},children:h.length===0&&!p?t.jsx("div",{className:"flex tm-h-full tm-items-center tm-justify-center",children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-center tm-gap-y-6",children:[t.jsx("p",{className:"tm-text-3xl tm-font-bold",children:c?"No se encontraron equipos con ese nombre":"¡Parece que aún no has creado un equipo!"}),!c&&t.jsx(x.Button,{color:"primary",onClick:()=>a(!0),children:"¡Empieza ahora!"})]})}):p?t.jsx("div",{className:"tm-pb-16 tm-opacity-100 tm-transition tm-duration-300",children:t.jsx(Gi,{length:o})}):t.jsx("div",{className:`tm-pb-16 ${p?"tm-opacity-0 tm-transition tm-duration-300":"tm-opacity-100 tm-transition tm-duration-300"}`,children:t.jsx(Qi,{teams:h})})}),g>0&&t.jsx(x.Pagination,{currentPage:n,pageCount:g,pageSize:o,total:y,onPageChange:w,handlePageSize:j,showVisiblePages:!0,showPagesSelector:!0})]})}const Ji=()=>({header:t.jsx(sl,{}),body:t.jsx(Fs,{})}),Zi={"templates-container":vi,"teams-container":Yi};function el({path:e}){const a=e?Zi[e]:null;return a?t.jsx(a,{}):null}function tl({path:e}){return e==="templates-container"?fi():e==="teams-container"?Ji():{header:null,body:null}}const al=({startPath:e})=>{const{path:a,setPath:n}=Fe(),{setCurrentPath:s}=ut();u.useEffect(()=>{n(e),s(e)},[e,n,s]);const{header:o,body:i}=tl({path:a});return t.jsxs(x.Card,{fullWidth:!0,className:"tm-h-full",children:[t.jsxs(x.Card.Header,{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-16 tm-justify-between",children:[o,t.jsx(el,{path:a})]}),t.jsx(x.Card.Separator,{}),t.jsx(x.Card.Body,{fullHeight:!0,className:"tm-flex tm-flex-1 tm-flex-col tm-gap-y-4",children:i})]})},sl=()=>t.jsx(ns,{title:"Equipos"}),nl=({path:e,tab:a,setPath:n,project:s,setProject:o})=>{const i={"kanban-general":{kanban:t.jsx(Zo,{})},"teams-container":{teams:t.jsx(Fs,{})},"lista-campanias":{lista:t.jsx($n,{setPath:n,setProject:o}),gantt:t.jsx("div",{children:"gantt-campanias"})},"kanban-campania":{kanban:t.jsx(Ko,{}),lista:t.jsx(or,{}),gantt:t.jsx("div",{children:"kanban-campania-gantt"})},"templates-container":{templates:t.jsx(js,{})}};return e==="kanban-campania"?t.jsx(Jn,{project:s==null?void 0:s.id,children:i[e][a]}):i[e][a]},ol=({label:e,active:a,onClick:n,disabled:s})=>s?t.jsx(Ie,{position:"bottom",trigger:t.jsx("button",{type:"button",className:"tm-cursor-help tm-text-xs tm-font-semibold tm-text-texts-placeholder",children:e}),children:t.jsx("div",{className:"tm-px-4 tm-py-2",children:t.jsx(x.Text,{children:"Espéralo muy pronto..."})})}):t.jsx("button",{type:"button",disabled:s,onClick:n,className:`${a?" tm-text-black-regular":""} tm-text-xs ${s?"tm-cursor-not-allowed tm-text-lg tm-text-black-regular":"tm-text-black-regular"}`,children:e}),rl=({tabs:e,renderItem:a,initialTab:n})=>{const[s,o]=u.useState(n??e[0].toLowerCase());u.useEffect(()=>{n&&o(n)},[n]);const i=r=>{o(r),a(r)};return t.jsx("div",{className:"tm-flex",children:e.map((r,c)=>t.jsx("div",{className:`${c===0?"tm-border-l-2":""} tm-border-r-2 tm-border-light-gray-100 tm-px-m`,children:t.jsx(ol,{onClick:()=>i(r.toLowerCase()),label:r,active:r.toLowerCase()===s,disabled:["gantt"].includes(r.toLowerCase())},c)}))})};function il(){const{toast:e}=Lt();if(!e.message)return null;const a=e.type==="success";return t.jsx("div",{className:`tm-bg-black tm-fixed tm-right-10 tm-top-[10%] tm-z-[200] tm-h-[30px] tm-w-[300px] tm-rounded-md tm-text-lg tm-shadow-md ${a?"tm-bg-success-medium":"tm-bg-danger-medium"} tm-flex tm-items-center`,children:t.jsxs("div",{className:"relative tm-flex tm-h-full tm-w-full tm-items-center",children:[t.jsx("div",{className:`tm-h-full tm-w-[5px] ${a?"tm-bg-success-dark":"tm-bg-danger-regular"} tm-absolute tm-left-0 tm-rounded-full`}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-2 tm-pl-4",children:[t.jsx(x.Icon,{name:a?de.faCircleCheck:de.faCircleXmark,size:"sm",style:{color:a?"#368156":"#DC2626"},color:"current"}),t.jsx("p",{className:`${a?"tm-text-success-dark":"tm-text-danger-dark"} tm-text-xl tm-font-semibold`,children:e.message})]})]})})}const Ca="tasksProject",ll=({path:e})=>{const a=()=>{const n=me.useQueryClient(),{selectPath:s,updateFilters:o,applyFilters:i,filters:r,fields:c}=De(),[m,l]=u.useState("kanban"),[d,p]=u.useState(e),[h,f]=u.useState({id:1704,project:"Kanban de Campania"}),[g,y]=u.useState([{path:"lista-campanias",search:(r==null?void 0:r.search)??""},{path:"kanban-campania",search:(r==null?void 0:r.taskName)??""},{path:"kanban-general",search:(r==null?void 0:r.taskName)??""},{path:"teams-container",search:(r==null?void 0:r.taskName)??""},{path:"templates-container",search:(r==null?void 0:r.taskName)??""}]),[w,j]=u.useState();u.useEffect(()=>{var v;l(d==="lista-campanias"?"lista":d==="kanban-campania"?"kanban":d==="teams-container"?"teams":d==="templates-container"?"templates":"kanban"),s(d),j(((v=g.find(U=>U.path===d))==null?void 0:v.search)??"")},[e,d]),u.useEffect(()=>{var v;((v=R())==null?void 0:v.trim())===""&&o({name:d==="lista-campanias"||d==="teams-container"||d==="templates-container"?"search":"taskName",value:null}),i()},[g]);const b=v=>({"kanban-general":"Kanban General","lista-campanias":"Campanias","teams-container":"Equipos","kanban-campania":`Kanban de ${h.project}`,"templates-container":"Flujos de trabajo"})[v],_=v=>{p(v)},M=["lista-campanias","kanban-campania"],F={"lista-campanias":["lista","gantt"],"kanban-campania":["kanban","lista","gantt"],"teams-container":["teams"],"templates-container":["templates"]},R=()=>{var v;return((v=g.find(U=>U.path===d))==null?void 0:v.search)??""},N=()=>{d==="kanban-general"?$o(n):d==="kanban-campania"&&(n.invalidateQueries({queryKey:[Ca]}),n.refetchQueries({queryKey:[Ca]}))},D=v=>{y(U=>U.map(K=>K.path===d?{...K,search:v}:K))};return u.useEffect(()=>{const v=setTimeout(()=>{o({name:d==="lista-campanias"||d==="teams-container"||d==="templates-container"?"search":"taskName",value:w==null?void 0:w.trim()}),D(w)},500);return()=>{clearTimeout(v)}},[w]),t.jsxs("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-flex-col tm-gap-m tm-overflow-hidden tm-rounded-lg tm-border tm-border-light-gray-100 tm-bg-bg-card tm-p-m",children:[t.jsxs("div",{className:"tm-flex tm-w-full tm-flex-wrap tm-items-end tm-justify-between tm-gap-l tm-border-b tm-border-light-gray-100 tm-pb-m",children:[t.jsxs("div",{className:"tm-flex tm-gap-xl",children:[d==="kanban-campania"&&t.jsx("button",{onClick:()=>_("lista-campanias"),className:"tm-text-primary hover:tm-text-primary/80 tm-flex tm-items-center tm-transition-colors",children:t.jsx(x.Icon,{name:ne.faArrowLeft,size:"xs",style:{color:"#4464C3"},color:"current",className:"tm-shrink-0"})}),t.jsx("h2",{className:"tm-text-base tm-font-medium tm-text-texts ",children:b(d)}),M.includes(d)&&t.jsx(rl,{tabs:F[d],renderItem:v=>{l(v)},initialTab:m})]}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-s !tm-text-[16px]",children:[t.jsx(x.Input,{leftSlot:de.faSearch,onChange:v=>{j(v.target.value)},placeholder:`Buscar por ${d==="lista-campanias"?"campaña":"campaña / tarea"}`,value:w,fullWidth:!0,className:"tm-min-w-[280px]"}),c.length>0&&t.jsx(Hn,{children:t.jsx(Wn,{})}),(d==="kanban-general"||d==="kanban-campania")&&t.jsx(x.Button,{icon:ne.faRotate,onClick:N,color:"secondary",pill:"pill",size:"xs"})]})]}),t.jsx("div",{className:"tm-h-full tm-max-h-[100%] tm-overflow-y-auto tm-scrollbar-none",children:t.jsx(nl,{path:d,tab:m,setPath:_,project:h,setProject:f})})]})};return t.jsx(Bs,{children:t.jsxs(eo,{children:[t.jsx(a,{}),t.jsx(il,{})]})})},cl=({path:e})=>["templates-container","teams-container"].includes(e)?t.jsx(al,{startPath:e}):t.jsx(ll,{path:e}),dl=()=>t.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:t.jsx("div",{className:"tm-flex tm-h-full tm-items-center tm-justify-center",children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-text-2xl tm-font-bold",children:[t.jsx("div",{className:"tm-h-10 tm-w-10 tm-animate-pulse tm-rounded-full tm-bg-primary-regular"}),t.jsx("p",{className:"tm-text-l tm-text-texts-enfasis",children:"No encontramos tu acceso"}),t.jsx("p",{className:"tm-text-sm tm-text-texts-placeholder",children:"por favor, contacta al administrador"})]})})}),ml=()=>t.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:t.jsx("div",{className:"tm-flex tm-h-full tm-items-center tm-justify-center",children:t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-text-2xl tm-font-bold",children:[t.jsx("div",{className:"tm-h-10 tm-w-10 tm-animate-pulse tm-rounded-full tm-bg-primary-regular"}),t.jsx("p",{className:"tm-text-l tm-text-texts-enfasis",children:"un momento..."}),t.jsx("p",{className:"tm-text-sm tm-text-texts-placeholder",children:"estamos buscando tu usuario"})]})})}),ul=({path:e,user:a,url:n,mode:s})=>{const o=new me.QueryClient;if(!a)return t.jsx(ml,{});if(!a.accessToken)return t.jsx(dl,{});let i={user:a,url:n,mode:s};return t.jsxs(pr,{children:[t.jsx(x.Toaster,{}),t.jsx(qs,{...i,children:t.jsx(Rs,{...i,children:t.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:t.jsxs(me.QueryClientProvider,{client:o,children:[t.jsx(cl,{path:e})," "]})})})})]})};exports.AppTasks=ul;
|
|
27
|
+
`}),a.jsx("div",{className:"react-pick-color tm-overflow-hidden tm-rounded-lg tm-shadow-02",children:a.jsx(Bs.ColorPicker,{color:e,theme:{inputBackground:"#FFF"},combinations:["monochromatic"],onChange:n=>t(n)})})]});function zi({color:e,setColor:t,label:n="Elige el color",className:s=""}){const[o,i]=u.useState(!1),r=u.useRef(null);return Ri(r,i,o),a.jsxs("div",{className:"tm-relative tm-w-full",children:[a.jsx("button",{onClick:l=>{l.stopPropagation(),i(!o)},style:{backgroundColor:e},className:`tm-h-control-xs tm-w-full tm-rounded-control-sm tm-border-[1px] tm-border-default tm-px-8 tm-text-body-sm-bold tm-text-primary tm-text-left tm-text-white ${s}`,children:n}),o&&a.jsx("div",{ref:r,className:"tm-absolute tm-z-50 tm-mt-2",children:a.jsx(qi,{color:e,onChange:l=>t(l.hex)})})]})}const Tt="Ha ocurrido un error inesperado. Por favor, intente nuevamente.",$i={"This field is required":"El campo {field} es requerido","must be defined":"El campo {field} es requerido","This attribute must be unique":"El campo {field} debe ser único","must be a string":"El campo {field} debe ser texto","must be a number":"El campo {field} debe ser un número","must be a boolean":"El campo {field} debe ser verdadero o falso","must be an array":"El campo {field} debe ser una lista","must be a valid email":"El campo {field} debe ser un correo electrónico válido","must be a valid date":"El campo {field} debe ser una fecha válida","must be a valid URL":"El campo {field} debe ser una URL válida","must be at least X characters long":"El campo {field} debe tener al menos {min} caracteres","must be less than or equal to X characters long":"El campo {field} debe tener máximo {max} caracteres","This value is too long":"El campo {field} excede el máximo de caracteres","This value is too short":"El campo {field} no cumple con el mínimo de caracteres","must be greater than or equal to X":"El campo {field} debe ser mayor o igual a {min}","must be less than or equal to X":"El campo {field} debe ser menor o igual a {max}","must be greater than X":"El campo {field} debe ser mayor a {min}","must be less than X":"El campo {field} debe ser menor a {max}","must be between X and Y":"El campo {field} debe estar entre {min} y {max}","must be an existing record":"El registro relacionado en {field} no existe","User not found":"El usuario no fue encontrado","Member not found":"El miembro no fue encontrado"},Ns=()=>({handleApiError:t=>{var n,s,o,i,r;if(t instanceof Ye.AxiosError&&((n=t.response)==null?void 0:n.status)===400){const l=t.response.data;if(((o=(s=l.details)==null?void 0:s.errors)==null?void 0:o.length)>0){const d=l.details.errors[0];let c=$i[d.message]||Tt;return c=c.replace("{field}",d.path.join(".")),((i=d.params)==null?void 0:i.min)!==void 0&&(c=c.replace("{min}",d.params.min.toString())),((r=d.params)==null?void 0:r.max)!==void 0&&(c=c.replace("{max}",d.params.max.toString())),c}return l.message||Tt}return Tt}});function Cs({open:e,handleChange:t,team:n}){const{addTeamHandler:s,updateTeamHandler:o}=Ts(),{handleApiError:i}=Ns(),[r,l]=u.useState(""),[d,c]=u.useState(n||{id:0,nombre:"",color:Fi(),miembros:[],miembros_planos:[],integrantes:0,miembros_eliminar:[],miembros_actualizar:[]}),m=d.id>0,f=async()=>{if(d.nombre.length===0){l("El nombre del equipo es requerido");return}if(d.miembros.length===0){l("El equipo debe tener al menos un miembro");return}const x=async()=>m?await o({data:d,teamId:d.id}):await s(d);try{await x(),l(""),t(!1);const p=m?"Equipo actualizado correctamente":"Equipo creado correctamente";g.toast.success(p)}catch(p){l(i(p))}};return a.jsx(g.Modal,{onCancel:()=>t(!1),onSuccess:f,title:"Información del equipo",icon:ze.faUser,showCloseButton:!0,showCancelButton:!0,showSuccessButton:!0,closeAtSuccess:!0,closeAtCancel:!0,isOpen:e,onClose:()=>t(!1),size:"lg",children:a.jsxs(g.Modal.Body,{children:[a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-8",children:[a.jsxs("div",{className:"tm-flex tm-w-full tm-items-center tm-gap-8 tm-flex-wrap",children:[a.jsx(lr,{value:d.nombre,onChange:x=>c({...d,nombre:x})}),a.jsxs("div",{className:"tm-flex tm-flex-1 tm-items-center tm-gap-x-8",children:[a.jsx("label",{className:"tm-text-body-sm-bold tm-text-primary tm-flex-1 tm-min-w-fit",children:"Color del equipo"}),a.jsx(zi,{color:d.color,setColor:x=>c({...d,color:x})})]})]}),r&&a.jsx("p",{className:"tm-mt-4 tm-text-sm tm-text-danger-pastel",children:r})]}),a.jsxs("div",{className:"tm-mt-8",children:[a.jsx(ir,{title:"Miembros del equipo",icon:ze.faUsers}),a.jsx(_s,{members:d.miembros,setData:c,isUpdate:m})]})]})})}const Le=384,Ui=80,Hi=180,Et=20,Ki=2,Ss=4,Pt=.8;function Gi({data:e}){const{getImageOBP:t}=ge();return a.jsxs("div",{className:"tm-w-[290px] tm-rounded-md tm-border-[0.5px] tm-border-default tm-bg-surface-default tm-px-8 tm-py-4 tm-shadow-04",children:[a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4",children:[a.jsx("div",{className:"tm-flex tm-items-center tm-justify-center tm-rounded-full tm-bg-surface-default",children:a.jsx(Ae,{size:"xxl",alt:"@shadcn",imageUrl:e!=null&&e.image?t(e==null?void 0:e.image):void 0})}),a.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-y-2",children:[a.jsx(g.Text,{size:"xs",weight:"bold",children:e.name}),a.jsx(g.Text,{children:e.job||"Puesto no asignado"})]})]}),a.jsx(oe.Handle,{type:"target",position:oe.Position.Top,className:"tm-bg-transparent",isConnectable:!1}),a.jsx(oe.Handle,{type:"source",position:oe.Position.Bottom,className:"tm-w-16 tm-border-none tm-bg-transparent",isConnectable:!1})]})}const Vi={custom:Gi},Wi={style:{stroke:"#6366f1",strokeWidth:2}},Es=(e,t=0)=>e?e.map(n=>{const s=n.miembros?Es(n.miembros,t+1):[];return{width:Le,height:Ui,children:s,x:0,y:t*Hi,totalWidth:0,depth:t}}):[],Ps=e=>{if(e.children.length===0)return e.totalWidth=Le,Le;const t=e.children.reduce((o,i)=>o+Ps(i),0),n=e.children.length>Ss?Pt:1,s=(e.children.length-1)*Et*n;return e.totalWidth=Math.max(Le,t+s),e.totalWidth},As=(e,t=0)=>{let n=t;return e.forEach(s=>{s.totalWidth===0&&Ps(s);const o=s.children.length>Ki,i=s.children.length>Ss;if(s.children.length>0){if(As(s.children,n),i){const f=(s.totalWidth-Le)/(s.children.length-1)*Pt;s.children.forEach((x,p)=>{x.x=n+p*f})}else if(o){const f=(s.totalWidth-Le)/(s.children.length-1);s.children.forEach((x,p)=>{x.x=n+p*f})}const l=s.children[0].x,d=s.children[s.children.length-1].x+Le,c=i?Le*.1:0;s.x=(l+d-Le)/2+c}else s.x=n;const r=i?Pt:1;n=Math.max(n+Le+Et*r,s.x+Le+Et*r)}),n},Is=(e,t,n,s)=>{const o=[],i=[];return e.forEach((r,l)=>{var m,f,x,p,h,y;const d=t[l],c=d.id.toString();if(o.push({id:c,type:"custom",data:{name:(m=d.idUser)==null?void 0:m.nombre,image:(x=n==null?void 0:n[(f=d.idUser)==null?void 0:f.email])==null?void 0:x.image,job:((y=(h=n==null?void 0:n[(p=d.idUser)==null?void 0:p.email])==null?void 0:h.role)==null?void 0:y.name)||""},position:{x:r.x,y:r.y}}),s&&i.push({id:`e-${s}-${c}`,source:s,target:c,style:{stroke:"#6366f1",strokeWidth:2}}),d.miembros&&d.miembros.length>0){const w=Is(r.children,d.miembros,n,c);o.push(...w.nodes),i.push(...w.edges)}}),{nodes:o,edges:i}};function Qi({members:e}){const[t,n]=u.useState([]),[s,o]=u.useState([]),{users:i,isLoading:r}=Ze();return u.useEffect(()=>{if(e&&!r){const l=Es(e);As(l);const{nodes:d,edges:c}=Is(l,e,i);n(d),o(c)}},[e,i,r]),r?null:a.jsx(oe.ReactFlow,{nodeTypes:Vi,nodes:t,edges:s,draggable:!1,fitView:!0,defaultViewport:{x:0,y:0,zoom:1},minZoom:.5,maxZoom:2,defaultEdgeOptions:Wi})}function Xi({open:e,handleChange:t,members:n}){return a.jsx(g.Modal,{showCancelButton:!1,showSuccessButton:!1,hideFooter:!0,isOpen:e,onClose:()=>t(!1),size:"xl",title:"Organigrama de equipo",children:a.jsx("div",{className:"tm-mx-auto tm-bg-surface-default",style:{width:"100%",height:"600px"},children:a.jsx(oe.ReactFlowProvider,{children:a.jsx(Qi,{members:n})})})})}const Ds="tm-grid tm-w-full tm-grid-cols-1 tm-items-baseline tm-gap-x-12 tm-gap-y-12 md:tm-grid-cols-2 lg:tm-grid-cols-3 lg:tm-gap-x-8 xl:tm-grid-cols-4",Yi="tm-relative tm-block tm-overflow-hidden tm-rounded-md tm-bg-gray-200 tm-bg-gradient-to-r tm-from-gray-200 tm-via-gray-50 tm-to-gray-200 tm-bg-[length:200%_100%] tm-animate-skeleton-shimmer";function qe({className:e="",rounded:t="md"}){const n=t==="full"?"tm-rounded-full":"tm-rounded-md";return a.jsx("span",{className:`${Yi} ${n} ${e}`.trim(),"aria-hidden":!0})}function Fs(){return a.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:Array.from({length:2},(e,t)=>a.jsx(qe,{className:"tm-h-8 tm-w-8 tm-shrink-0",rounded:"full"},t))})}function Ji(){const{user:e}=je(),t=(e==null?void 0:e.role)===Vt;return a.jsxs(g.Card,{className:"tm-w-full",children:[a.jsxs(g.Card.Header,{className:"tm-flex tm-items-center justify-between",children:[a.jsx("div",{className:"tm-flex tm-flex-col tm-justify-start tm-items-start tm-gap-y-2",children:a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[a.jsx(qe,{className:"tm-h-2.5 tm-w-2.5 tm-shrink-0",rounded:"full"}),a.jsx(qe,{className:"tm-h-8 tm-w-8 tm-shrink-0"}),a.jsx(qe,{className:"tm-h-5 tm-min-h-[1.25rem] tm-w-40 tm-max-w-[min(100%,10rem)]"})]})}),a.jsx("div",{children:t?a.jsx(qe,{className:"tm-h-8 tm-w-8 tm-shrink-0",rounded:"full"}):null})]}),a.jsx(g.Card.Separator,{}),a.jsxs(g.Card.Body,{scrollable:!1,children:[a.jsx(Fs,{}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4 tm-mt-2",children:[a.jsx(qe,{className:"tm-h-4 tm-w-6"}),a.jsx(qe,{className:"tm-h-4 tm-w-28"})]})]})]})}function Zi({length:e}){const n=e??10;return a.jsx("div",{"aria-busy":"true","aria-live":"polite",className:Ds,children:Array.from({length:n},(s,o)=>a.jsx(Ji,{},o))})}function el({members:e}){const{getImageOBP:t}=ge(),{users:n,isLoading:s}=Ze();if(s)return a.jsx(Fs,{});const o=e.filter(i=>{var r,l;return(l=n[(r=i.idUser)==null?void 0:r.email])==null?void 0:l.image}).slice(0,3);return a.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:a.jsx(g.Avatar,{maxVisible:2,stroke:!0,stack:o.map(i=>{var l;const r=n[(l=i.idUser)==null?void 0:l.email];return{src:t(r.image),name:r.name}}),size:"sm"})})}function tl({team:e}){const[t,n]=u.useState(!1),[s,o]=u.useState(!1),{user:i}=je(),[r,l]=u.useState(!1),{handleApiError:d}=Ns(),{deleteTeamHandler:c,isLoadingDeleteTeam:m}=Ts(),f=async()=>{try{await c(e.id),g.toast.success("Equipo eliminado correctamente")}catch(x){g.toast.error(d(x))}};return a.jsxs(g.Card,{children:[t&&a.jsx(Cs,{handleChange:n,open:t,team:e}),r&&a.jsx(vs,{isLoading:m,open:r,handleChange:l,onConfirm:f,contentLabel:"Estás eliminando el equipo seleccionado"}),s&&a.jsx(Xi,{handleChange:o,open:s,members:e.miembros}),a.jsxs(g.Card.Header,{className:"tm-flex tm-items-center tm-justify-between tm-w-full",children:[a.jsx("div",{className:"tm-flex tm-flex-col tm-justify-start tm-items-start tm-gap-y-2",children:a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8 tm-justify-between tm-w-full",children:[a.jsx(g.Badge,{size:"dot",customColor:e.color,theme:"solid"}),a.jsx(g.Icon,{name:ze.faPeopleGroup,colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,size:"md"}),a.jsx("h1",{className:"tm-py-0.5 tm-font-body-sm-bold tm-text-body-sm-bold tm-leading-none tm-text-primary",children:e.nombre})]})}),a.jsx("div",{children:(i==null?void 0:i.role)==Vt&&a.jsx(g.Popup,{size:"xs",color:"secondary",pill:"pill",icon:ne.faEllipsis,stopPropagationList:!0,children:a.jsxs(g.List,{className:"tm-gap-4",padding:"sm",children:[a.jsx(g.ListItem,{icon:ne.faPencil,onClick:()=>n(!0),children:"Editar"}),a.jsx(g.ListItem,{icon:ne.faEye,onClick:()=>o(!0),children:"Ver organigrama"}),a.jsx(g.ListItem,{color:"red",icon:ne.faTrash,onClick:()=>l(!0),children:"Eliminar"})]})})})]}),a.jsx(g.Card.Separator,{}),a.jsxs(g.Card.Body,{children:[a.jsx(el,{members:e.miembros_planos}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4 tm-mt-2",children:[a.jsx("p",{className:"tm-text-icon-all-colors-blue tm-text-xs tm-text-center tm-leading-none tm-font-semibold",children:e.integrantes||0}),a.jsxs("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:["Integrante",e.integrantes>1?"s":""]})]})]})]})}function al({teams:e}){return a.jsx("div",{className:Ds,children:e==null?void 0:e.map(t=>a.jsx(tl,{team:t},t.id))})}const sl="teams-container";function nl(){return a.jsx("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-justify-between tm-gap-2.5 md:tm-flex-nowrap",children:a.jsx(rs,{path:sl})})}function Ms(){var b,v,M,F,R;const[e,t]=u.useState(!1),[n,s]=u.useState(1),[o,i]=u.useState(10),{user:r}=je(),{debouncedSearch:l,filters:d}=is("teams-container"),c=Array.isArray(d)?d:[];u.useEffect(()=>{s(1)},[l,d]);const{data:m,isLoading:f}=Bi({page:n,pageSize:o,search:l,filters:{nombre:"",createdAt:(b=c.find(C=>C.keyName==="createdAt"))==null?void 0:b.value,integrantes_min:(v=c.find(C=>C.keyName==="integrantes_min"))==null?void 0:v.value,integrantes_max:(M=c.find(C=>C.keyName==="integrantes_max"))==null?void 0:M.value}}),x=(m==null?void 0:m.data)||[],p=m==null?void 0:m.meta,h=((F=p==null?void 0:p.pagination)==null?void 0:F.pageCount)||0,y=((R=p==null?void 0:p.pagination)==null?void 0:R.total)||0,w=C=>{s(C)},j=C=>{i(C),s(1)};return a.jsxs("div",{className:"tm-grid tm-h-full tm-grid-rows-[auto,1fr] tm-gap-y-8",children:[e&&a.jsx(Cs,{handleChange:t,open:e}),(r==null?void 0:r.role)===Vt&&a.jsx("div",{className:"tm-flex tm-items-center tm-justify-end",children:a.jsx(g.Button,{size:"xs",color:"primary",leftSlot:ne.faPlus,onClick:()=>t(!0),children:" Nuevo equipo "})}),a.jsx("div",{className:"custom-scrollbar",style:{scrollbarGutter:"stable",paddingRight:"4px"},children:x.length===0&&!f?a.jsx("div",{className:"flex tm-h-full tm-items-center tm-justify-center",children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-center tm-gap-y-6",children:[a.jsx("p",{className:"tm-text-3xl tm-font-bold",children:l?"No se encontraron equipos con ese nombre":"¡Parece que aún no has creado un equipo!"}),!l&&a.jsx(g.Button,{color:"primary",onClick:()=>t(!0),children:"¡Empieza ahora!"})]})}):f?a.jsx("div",{className:"tm-pb-16 tm-opacity-100 tm-transition tm-duration-300",children:a.jsx(Zi,{length:o})}):a.jsx("div",{className:`tm-pb-16 ${f?"tm-opacity-0 tm-transition tm-duration-300":"tm-opacity-100 tm-transition tm-duration-300"}`,children:a.jsx(al,{teams:x})})}),h>0&&a.jsx(g.Pagination,{currentPage:n,pageCount:h,pageSize:o,total:y,onPageChange:w,handlePageSize:j,showVisiblePages:!0,showPagesSelector:!0})]})}const ol=()=>({header:a.jsx(dl,{}),body:a.jsx(Ms,{})}),rl={"templates-container":Ai,"teams-container":nl};function il({path:e}){const t=e?rl[e]:null;return t?a.jsx(t,{}):null}function ll({path:e}){return e==="templates-container"?vi():e==="teams-container"?ol():{header:null,body:null}}const cl=({startPath:e})=>{const{path:t,setPath:n}=Fe(),{setCurrentPath:s}=ut();u.useEffect(()=>{n(e),s(e)},[e,n,s]);const{header:o,body:i}=ll({path:t});return a.jsxs(g.Card,{fullWidth:!0,className:"tm-h-full",children:[a.jsxs(g.Card.Header,{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-16 tm-justify-between",children:[o,a.jsx(il,{path:t})]}),a.jsx(g.Card.Separator,{}),a.jsx(g.Card.Body,{fullHeight:!0,className:"tm-flex tm-flex-1 tm-flex-col tm-gap-y-4",children:i})]})},dl=()=>a.jsx(os,{title:"Equipos"}),ml=({path:e,tab:t,setPath:n,project:s,setProject:o})=>{const i={"kanban-general":{kanban:a.jsx(er,{})},"teams-container":{teams:a.jsx(Ms,{})},"lista-campanias":{lista:a.jsx($n,{setPath:n,setProject:o}),gantt:a.jsx("div",{children:"gantt-campanias"})},"kanban-campania":{kanban:a.jsx(Go,{}),lista:a.jsx(rr,{}),gantt:a.jsx("div",{children:"kanban-campania-gantt"})},"templates-container":{templates:a.jsx(ws,{})}};return e==="kanban-campania"?a.jsx(Jn,{project:s==null?void 0:s.id,children:i[e][t]}):i[e][t]},ul=({label:e,active:t,onClick:n,disabled:s})=>s?a.jsx(Ie,{position:"bottom",trigger:a.jsx("button",{type:"button",className:"tm-cursor-help tm-text-xs tm-font-semibold tm-text-texts-placeholder",children:e}),children:a.jsx("div",{className:"tm-px-4 tm-py-2",children:a.jsx(g.Text,{children:"Espéralo muy pronto..."})})}):a.jsx("button",{type:"button",disabled:s,onClick:n,className:`${t?" tm-text-black-regular":""} tm-text-xs ${s?"tm-cursor-not-allowed tm-text-lg tm-text-black-regular":"tm-text-black-regular"}`,children:e}),pl=({tabs:e,renderItem:t,initialTab:n})=>{const[s,o]=u.useState(n??e[0].toLowerCase());u.useEffect(()=>{n&&o(n)},[n]);const i=r=>{o(r),t(r)};return a.jsx("div",{className:"tm-flex",children:e.map((r,l)=>a.jsx("div",{className:`${l===0?"tm-border-l-2":""} tm-border-r-2 tm-border-default tm-px-m`,children:a.jsx(ul,{onClick:()=>i(r.toLowerCase()),label:r,active:r.toLowerCase()===s,disabled:["gantt"].includes(r.toLowerCase())},l)}))})};function fl(){const{toast:e}=Bt();if(!e.message)return null;const t=e.type==="success";return a.jsx("div",{className:`tm-bg-black tm-fixed tm-right-10 tm-top-[10%] tm-z-[200] tm-h-[30px] tm-w-[300px] tm-rounded-md tm-text-lg tm-shadow-02 ${t?"tm-bg-success-medium":"tm-bg-danger-medium"} tm-flex tm-items-center`,children:a.jsxs("div",{className:"relative tm-flex tm-h-full tm-w-full tm-items-center",children:[a.jsx("div",{className:`tm-h-full tm-w-[5px] ${t?"tm-bg-success-dark":"tm-bg-danger-regular"} tm-absolute tm-left-0 tm-rounded-full`}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8 tm-pl-4",children:[a.jsx(g.Icon,{name:t?me.faCircleCheck:me.faCircleXmark,size:"sm",style:{color:t?"#368156":"#DC2626"},color:"current"}),a.jsx("p",{className:`${t?"tm-text-success-dark":"tm-text-danger-dark"} tm-text-xl tm-font-semibold`,children:e.message})]})]})})}const Ca="tasksProject",gl=({path:e})=>{const t=()=>{const n=de.useQueryClient(),{selectPath:s,updateFilters:o,applyFilters:i,filters:r,fields:l}=De(),[d,c]=u.useState("kanban"),[m,f]=u.useState(e),[x,p]=u.useState({id:1704,project:"Kanban de Campania"}),[h,y]=u.useState([{path:"lista-campanias",search:(r==null?void 0:r.search)??""},{path:"kanban-campania",search:(r==null?void 0:r.taskName)??""},{path:"kanban-general",search:(r==null?void 0:r.taskName)??""},{path:"teams-container",search:(r==null?void 0:r.taskName)??""},{path:"templates-container",search:(r==null?void 0:r.taskName)??""}]),[w,j]=u.useState();u.useEffect(()=>{var T;c(m==="lista-campanias"?"lista":m==="kanban-campania"?"kanban":m==="teams-container"?"teams":m==="templates-container"?"templates":"kanban"),s(m),j(((T=h.find(V=>V.path===m))==null?void 0:T.search)??"")},[e,m]),u.useEffect(()=>{var T;((T=R())==null?void 0:T.trim())===""&&o({name:m==="lista-campanias"||m==="teams-container"||m==="templates-container"?"search":"taskName",value:null}),i()},[h]);const b=T=>({"kanban-general":"Kanban General","lista-campanias":"Campanias","teams-container":"Equipos","kanban-campania":`Kanban de ${x.project}`,"templates-container":"Flujos de trabajo"})[T],v=T=>{f(T)},M=["lista-campanias","kanban-campania"],F={"lista-campanias":["lista","gantt"],"kanban-campania":["kanban","lista","gantt"],"teams-container":["teams"],"templates-container":["templates"]},R=()=>{var T;return((T=h.find(V=>V.path===m))==null?void 0:T.search)??""},C=()=>{m==="kanban-general"?Uo(n):m==="kanban-campania"&&(n.invalidateQueries({queryKey:[Ca]}),n.refetchQueries({queryKey:[Ca]}))},I=T=>{y(V=>V.map(z=>z.path===m?{...z,search:T}:z))};return u.useEffect(()=>{const T=setTimeout(()=>{o({name:m==="lista-campanias"||m==="teams-container"||m==="templates-container"?"search":"taskName",value:w==null?void 0:w.trim()}),I(w)},500);return()=>{clearTimeout(T)}},[w]),a.jsxs("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-flex-col tm-gap-m tm-overflow-hidden tm-rounded-lg tm-border tm-border-default tm-bg-surface-default tm-p-m",children:[a.jsxs("div",{className:"tm-flex tm-w-full tm-flex-wrap tm-items-end tm-justify-between tm-gap-l tm-border-b tm-border-default tm-pb-m",children:[a.jsxs("div",{className:"tm-flex tm-gap-xl tm-items-center",children:[m==="kanban-campania"&&a.jsx(g.Button,{icon:ne.faArrowLeft,onClick:()=>v("lista-campanias"),color:"secondary",pill:"pill",size:"xxs"}),a.jsx(g.Text,{size:"lg",weight:"medium",color:"primary",children:b(m)}),M.includes(m)&&a.jsx(pl,{tabs:F[m],renderItem:T=>{c(T)},initialTab:d})]}),a.jsxs("div",{className:"tm-flex tm-items-center tm-gap-s !tm-text-[16px]",children:[a.jsx(g.Input,{leftSlot:me.faSearch,onChange:T=>{j(T.target.value)},placeholder:`Buscar por ${m==="lista-campanias"?"campaña":"campaña / tarea"}`,value:w,fullWidth:!0,className:"tm-min-w-[280px]"}),l.length>0&&a.jsx(Hn,{children:a.jsx(Wn,{})}),(m==="kanban-general"||m==="kanban-campania")&&a.jsx(g.Button,{icon:ne.faRotate,onClick:C,color:"secondary",pill:"pill",size:"xs"})]})]}),a.jsx("div",{className:"tm-h-full tm-max-h-[100%] tm-overflow-y-auto tm-scrollbar-none",children:a.jsx(ml,{path:m,tab:d,setPath:v,project:x,setProject:p})})]})};return a.jsx(Rs,{children:a.jsxs(eo,{children:[a.jsx(t,{}),a.jsx(fl,{})]})})},hl=({path:e})=>["templates-container","teams-container"].includes(e)?a.jsx(cl,{startPath:e}):a.jsx(gl,{path:e}),xl=()=>a.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:a.jsx("div",{className:"tm-flex tm-h-full tm-items-center tm-justify-center",children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-text-2xl tm-font-bold",children:[a.jsx("div",{className:"tm-h-10 tm-w-10 tm-animate-pulse tm-rounded-full tm-bg-primary-regular"}),a.jsx("p",{className:"tm-text-l tm-text-texts-enfasis",children:"No encontramos tu acceso"}),a.jsx("p",{className:"tm-text-sm tm-text-texts-placeholder",children:"por favor, contacta al administrador"})]})})}),bl=()=>a.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:a.jsx("div",{className:"tm-flex tm-h-full tm-items-center tm-justify-center",children:a.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-text-2xl tm-font-bold",children:[a.jsx("div",{className:"tm-h-10 tm-w-10 tm-animate-pulse tm-rounded-full tm-bg-primary-regular"}),a.jsx("p",{className:"tm-text-l tm-text-texts-enfasis",children:"un momento..."}),a.jsx("p",{className:"tm-text-sm tm-text-texts-placeholder",children:"estamos buscando tu usuario"})]})})}),yl=({path:e,user:t,url:n,mode:s})=>{const o=new de.QueryClient;if(!t)return a.jsx(bl,{});if(!t.accessToken)return a.jsx(xl,{});let i={user:t,url:n,mode:s};return a.jsxs(fr,{children:[a.jsx(g.Toaster,{}),a.jsx(zs,{...i,children:a.jsx(qs,{...i,children:a.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:a.jsxs(de.QueryClientProvider,{client:o,children:[a.jsx(hl,{path:e})," "]})})})})]})};exports.AppTasks=yl;
|