@imj_media/tareas 1.6.0 → 1.6.2
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/components/lista-campania/ActionsTaskList.d.ts +3 -1
- package/dist/src/components/tasks/DifficultyButton.d.ts +10 -0
- package/dist/src/components/tasks/PriorityButton.d.ts +3 -1
- package/dist/src/components/templates/progress-modal/config/estadoTareaProgreso.config.d.ts +2 -2
- package/dist/src/modules/teams/ui/organisms/TeamsGridSkeleton.d.ts +1 -1
- package/dist/src/modules/teams/utils/teams.utils.d.ts +24 -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/useTeamFlowPreview.d.ts +34 -0
- package/dist/src/modules/templates/hooks/useZoomAndCenter.d.ts +6 -1
- package/dist/src/modules/templates/store/useTemplateGrid.d.ts +11 -0
- package/dist/src/types/index.d.ts +2 -0
- package/dist/src/utils/canEditTaskFields.d.ts +6 -0
- package/dist/src/utils/taskKanbanBulkEligibility.d.ts +8 -7
- package/dist/tareas.cjs +9 -9
- package/dist/tareas.css +1 -1
- package/dist/tareas.es.js +5714 -5631
- package/package.json +1 -1
- package/dist/src/components/atoms/Toast.d.ts +0 -1
- package/dist/src/context/toastContext.d.ts +0 -14
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 t=require("react/jsx-runtime"),le=require("@tanstack/react-query"),f=require("@imj_media/ui"),u=require("react"),tt=require("axios"),Ee=require("qs"),ne=require("@fortawesome/pro-regular-svg-icons"),qs=require("echarts-for-react"),de=require("@fortawesome/pro-solid-svg-icons"),Ft=require("react-dom"),Se=require("@fortawesome/free-solid-svg-icons"),mt=require("date-fns"),Mt=require("date-fns/locale"),Pe=require("react-hook-form"),oe=require("@xyflow/react"),We=require("zustand"),Et=require("moment"),Ve=require("@fortawesome/pro-duotone-svg-icons");require("@xyflow/react/dist/style.css");const zs=require("react-pick-color"),Zt=e=>{const a={...e};return delete a.project,delete a["project.id"],a},ea=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},Ia=u.createContext({}),$s=({children:e})=>{const[a,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(O=>O.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(ea(Object.fromEntries(p)))},g=p=>({1:"Muy facil",2:"Facil",3:"Media",4:"Dificil",5:"Muy dificil"})[p],x=()=>{let p=ea(s);p.difficulty&&(p.difficulty=g(p.difficulty)),n(p)};return t.jsx(Ia.Provider,{value:{fields:i,filters:a,path:l,defineFields:r,updateFilters:c,cleanFilters:m,applyFilters:x,initialFilters:s,selectPath:d},children:e})},Me=()=>u.useContext(Ia),Da=u.createContext({}),Us=({children:e,user:a,url:n,mode:s})=>{const o=s==="prod"?"https://services.imjmedia.com.mx":"https://devobp.imjmedia.com.mx",i=tt.create({baseURL:n,headers:{Authorization:`Bearer ${a.accessToken}`},paramsSerializer:d=>Ee.stringify(d,{encodeValuesOnly:!0})}),r=()=>o,l=d=>d==="undefined"||d===void 0?"":`${o}${d}`;return t.jsx(Da.Provider,{value:{tasks_api:i,getOBPUrlApi:r,getImageOBP:l},children:e})},pe=()=>u.useContext(Da),Fa=u.createContext({}),Hs=({children:e,user:a,url:n})=>{const s=tt.create({baseURL:n,headers:{Authorization:`Bearer ${a.accessToken}`},paramsSerializer:o=>Ee.stringify(o,{encodeValuesOnly:!0})});return t.jsx(Fa.Provider,{value:{user:a,tasks_api:s},children:e})},je=()=>u.useContext(Fa),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},ta=[{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"}]}],aa=[{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:[]}],xt=(e,a,n)=>`${e} ${e===1?a:n}`;function Ks(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:xt(a.atrasos,"atrasada","atrasadas"),color:"danger",variant:"atrasos"}),(a.pausas??0)>0&&n.push({label:xt(a.pausas,"pausada","pausadas"),color:"warning",variant:"pausas"}),(a.vencidos??0)>0&&n.push({label:xt(a.vencidos,"vencida","vencidas"),color:"info",variant:"vencidos"}),n.slice(0,2)}const Vs=ne.faLightEmergencyOn,Gs={name:Vs},Ws=({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(f.Tag,{label:n.label,color:n.color,stroke:!1,truncateLabel:!0,truncateTooltip:!0,infoIcon:n.variant==="atrasos"?Gs:void 0})},`${n.variant}-${n.label}-${s}`))})},Qs=(e,a=500)=>{const[n,s]=u.useState(e);return u.useEffect(()=>{const o=setTimeout(()=>{s(e)},a);return()=>{clearTimeout(o)}},[e,a]),n},Xs=async e=>{const a=Ee.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:[]}},Ma=()=>{const{tasks_api:e}=pe();return le.useQuery({queryKey:["teams"],queryFn:()=>Xs(e),staleTime:1e3*60*60*24,select:n=>n.data.map(o=>({label:o.nombre,value:o.id}))})},Ys="/api/listado-progreso",Js="/api/proyectos/listado-progreso";function Zs(e){return Ee.stringify(e,{encodeValuesOnly:!0,arrayFormat:"repeat"})}function en(e){var i,r,l;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(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 sa(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 na(e,a,n){const{data:s}=await e.get(a,{params:n,paramsSerializer:Zs});return s??{}}async function tn(e,a){var s;const n=en(a);try{const o=await na(e,Ys,n);return sa(o)}catch(o){if(tt.isAxiosError(o)&&((s=o.response)==null?void 0:s.status)===404){const i=await na(e,Js,n);return sa(i)}throw o}}function an({proyectoId:e,fase:a,enabled:n,filters:s}){const{tasks_api:o}=pe(),i=n&&Number.isFinite(e)&&Number.isInteger(e)&&e>0;return le.useQuery({queryKey:["listado-progreso",e,a,s],queryFn:()=>tn(o,{proyecto_id:e,fase:a,...s}),enabled:i,staleTime:3e4})}const sn=({campaignName:e,searchValue:a,onSearchChange:n})=>t.jsx("div",{className:"tm-border-b tm-border-default 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(f.Input,{size:"sm",fullWidth:!0,leftSlot:ne.faSearch,placeholder:"Buscar...",value:a,onValueChange:n,clearable:!0,onClear:()=>n("")})})]})});function nn(e,a){Array.isArray(e)&&a(e.map(String))}function bt({options:e,selected:a,onChange:n,emptyPlaceholder:s,header:o,tagsOverflowPopoverTitle:i,panelSearch:r,panelSearchPlaceholder:l="Buscar…"}){return t.jsx(f.Dropdown,{field:{placeholder:s},items:{options:e},values:{value:a},events:{onValueChange:d=>nn(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 on=({mediosOptions:e,plazasOptions:a,estadosOptions:n,selectedMedios:s,selectedPlazas:o,selectedEstados:i,onlyDelayed:r,onChangeMedios:l,onChangePlazas:d,onChangeEstados:c,onChangeOnlyDelayed:m})=>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-[250px]",children:t.jsx(bt,{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})}),t.jsx("div",{className:"tm-w-full sm:tm-w-[250px]",children:t.jsx(bt,{options:a,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…"})}),t.jsx("div",{className:"tm-w-full sm:tm-w-[250px]",children:t.jsx(bt,{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})})]}),t.jsx("div",{className:"tm-flex tm-items-center",children:t.jsx(f.Toggle,{label:"Solo atrasadas y vencidas",checked:r,onChange:m})})]})}),kt=[{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"}],rn=Object.fromEntries(kt.map(e=>[e.singular,e])),oa=kt.map(e=>e.serieApiName),ln=new Set(["atrasada","vencida"]);function Ot(e){return rn[e]}function cn(e){var a;return(a=Ot(e.trim().toLowerCase()))==null?void 0:a.serieApiName}function ka(e){return e?e.charAt(0).toUpperCase()+e.slice(1):""}function dn(e){const a=Ot(e);return a?a.uiLabel:ka(e)}function mn(e,a){const n=(e??"").trim().toLowerCase();if(!n)return[{label:a,color:"gray"}];const s=Ot(n);return s?[{label:s.uiLabel,color:s.tagColor}]:[{label:ka(n),color:"gray"}]}function un(e){var a,n;if(tt.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 pn(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 fn(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 gn(e){return(Number.isFinite(e)?e:0).toFixed(0)}const hn=({id:e,listadoProgreso:a,phaseLabel:n,listadoForUi:s})=>{const{isPending:o,isError:i,error:r,isSuccess:l,data:d}=a,[c,m]=u.useState(null),g=s??d,x=u.useMemo(()=>{const w=(g==null?void 0:g.grafico)??[],j=H=>{var M,N;return((N=(M=w.find(A=>A.name===H))==null?void 0:M.data)==null?void 0:N[0])??0},b=kt.map(H=>({key:H.serieApiName,label:H.chartLegendLabel,color:H.chartColorHex})),v=b.map(H=>H.label),O={legendLabel:{color:"#6C6E73",fontSize:12,fontWeight:"bold",padding:[0,0,0,20]}};return b.forEach((H,M)=>{O[`legendDot${M}`]={color:H.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:H=>{const M=b.findIndex(N=>N.label===H);return M===-1?H:`{legendLabel|${H}}{legendDot${M}|●}`},textStyle:{rich:O}},series:b.map(H=>({name:H.label,type:"bar",stack:"total",itemStyle:{color:H.color},barWidth:"50%",data:[j(H.key)]}))}},[g==null?void 0:g.grafico,n]),p=u.useCallback(w=>{const j=w;if(j.componentType!=="series")return;const b=pn(w);if(!b)return;const v=fn(w),O=typeof j.seriesName=="string"?j.seriesName:"";m({x:b.x,y:b.y,label:`${gn(v)}% ${O}`})},[]),h=u.useCallback(()=>{m(null)},[]),y=u.useMemo(()=>({mouseover:p,mousemove:p,globalout:h}),[p,h]);return t.jsx(f.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-default tm-px-2 tm-py-2 tm-bg-surface-default",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:un(r)})}),l&&d&&t.jsxs("div",{className:"tm-relative tm-h-[140px] tm-w-full",children:[t.jsx(qs,{option:x,style:{height:"100%",width:"100%"},onEvents:y}),c&&t.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:t.jsx(f.InlineTooltip,{isVisible:!0,label:c.label,position:"top"})})]})]})})},Lt="-";function Ze(e){const a=String(e??"").trim();return a.length>0?a:null}function Qe(e){const a=String(e??"").trim();return a.length>0?a:Lt}function xn(e){var i,r,l,d,c,m,g,x,p,h;if(!e)return;const a=(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=(g=e.formats)==null?void 0:g.medium)==null?void 0:x.url)==null?void 0:p.trim(),o=(h=e.url)==null?void 0:h.trim();return a||n||s||o||void 0}function bn(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 Bt(e,a){const n=(e.nombre??"").trim()||Lt,s=xn(e.imagen??null);let o;if(s){const r=s.startsWith("http")||s.startsWith("data:")||s.startsWith("blob:")?s:a(s);bn(r)&&(o=r)}const i=n.slice(0,1);return{name:n,src:o,letter:i}}function yn(e){return{tarea:Qe(e.tarea),categoria:Qe(e.categoria),nota:Qe(e.nota),clave:Qe(e.clave),tipo_medio:Qe(e.tipo_medio),ubicacion:Qe(e.ubicacion)}}function jn(e){return mn(e,Lt)}const Oa=4,ra=Oa-1,wn=120,vn=-8,ia=8;function _n(e){return e.length<=Oa?{visible:e,overflow:[]}:{visible:e.slice(0,ra),overflow:e.slice(ra)}}const nt="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",la="Sin responsable",La="bottom",Ba="center",Tn="tm-flex tm-max-w-xs tm-items-start tm-gap-2 tm-py-1",Nn="tm-text-sm tm-font-semibold tm-leading-snug tm-text-gray-900";function ca(e,a){return e<a-1?{marginRight:`${vn}px`}:void 0}function Cn({person:e,getImageOBP:a}){const{src:n,letter:s}=Bt(e,a);return n?t.jsx(f.Avatar,{type:"people",src:n,size:"xxs",className:nt}):t.jsx(f.Avatar,{type:"letter",text:s,size:"xxs",className:nt})}function Sn({person:e,getImageOBP:a}){const{name:n,src:s,letter:o}=Bt(e,a);return t.jsxs("div",{className:Tn,children:[s?t.jsx(f.Avatar,{type:"people",src:s,size:"xxs",className:`tm-mt-0.5 ${nt}`}):t.jsx(f.Avatar,{type:"letter",text:o,size:"xxs",className:`tm-mt-0.5 ${nt}`}),t.jsx("span",{className:Nn,children:n})]})}function En({popupId:e,trigger:a,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},wn)},[l]);return u.useEffect(()=>()=>l(),[l]),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:d,onMouseLeave:c,children:a}),t.jsx(f.Popup,{ref:i,popupId:e,triggerRef:o,closeOnClick:!1,position:"bottom-center",children:t.jsx("div",{className:s,onMouseEnter:d,onMouseLeave:c,children:n})})]})}function Pn(){return t.jsx(f.Tooltip,{label:la,position:La,alignment:Ba,preserveLayout:!0,children:t.jsx("span",{className:"tm-inline-flex tm-shrink-0",role:"img","aria-label":la,children:t.jsx(f.Avatar,{type:"people",size:"xxs",className:nt,alt:""})})})}function An({person:e,getImageOBP:a}){const{name:n}=Bt(e,a);return t.jsx(f.Tooltip,{label:n,position:La,alignment:Ba,preserveLayout:!0,children:t.jsx("span",{className:"tm-inline-flex tm-shrink-0",children:t.jsx(Cn,{person:e,getImageOBP:a})})})}function In({overflow:e,getImageOBP:a,popupId:n}){return t.jsx(En,{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(Sn,{person:s,getImageOBP:a},s.id!=null?`${s.id}-${o}`:o))})}const Dn=({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:`${ia}px`},children:t.jsx(Pn,{})});const{visible:o,overflow:i}=_n(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:`${ia}px`},children:[o.map((l,d)=>{const c=l.id!=null?`r-${l.id}-${d}`:`r-${n}-${d}`;return t.jsx("div",{className:"tm-shrink-0",style:ca(d,r),children:t.jsx(An,{person:l,getImageOBP:a})},c)}),i.length>0?t.jsx("div",{className:"tm-shrink-0",style:ca(r-1,r),children:t.jsx(In,{overflow:i,getImageOBP:a,popupId:`listado-progreso-${n}-more`})}):null]})},Fn={name:de.faCircleSmall};function Mn({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(f.Tag,{label:n.label,color:n.color,stroke:!1,truncateLabel:!0,truncateTooltip:!0,infoIcon:Fn})},`${n.label}-${s}`))})}const kn=({listadoProgreso:e,listadoForUi:a,hideClaveColumn:n=!1})=>{var d,c;const{getImageOBP:s}=pe(),o=u.useMemo(()=>{const m=[{id:"responsables",header:"Responsable",accessor:g=>g.responsables,width:140,minWidth:100,sortable:!1,filterable:!1,resizable:!1,render:(g,x)=>t.jsx(Dn,{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:g=>jn(g.estado),contentAlign:"center",width:110,minWidth:90,sortable:!1,filterable:!1,resizable:!1,render:g=>t.jsx(Mn,{tags:Array.isArray(g)?g:[]})},{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 g;const m=(a==null?void 0:a.data)??((g=e.data)==null?void 0:g.data);return Array.isArray(m)?m.map(x=>({...x,id:x.id,...yn(x)})):[]},[a==null?void 0:a.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,g=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(g===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(g>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 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-default",children:t.jsx(f.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})})})},On={preventa:"Preventa",venta:"Venta"},Ln=({campaignName:e,phase:a,search:n,listado:s,filters:o})=>{const i=On[a],r=a==="preventa";return t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-4",children:[t.jsx(sn,{campaignName:e,searchValue:n.value,onSearchChange:n.onChange}),t.jsx(on,{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(hn,{id:`progress-chart-${i}`,listadoProgreso:s.query,phaseLabel:i,listadoForUi:s.dataForUi}),t.jsx(kn,{listadoProgreso:s.query,listadoForUi:s.dataForUi,hideClaveColumn:r})]})};function Bn(e){var i,r,l,d;const a=(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: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 Rn(e,a){const{mediosSet:n,locationsSet:s,statusSet:o,searchLower:i,onlyDelayed:r}=a;if(n){const l=Ze(e.tipo_medio)??"";if(!n.has(l))return!1}if(s){const l=Ze(e.ubicacion)??"";if(!s.has(l))return!1}if(o){const l=(e.estado??"").trim().toLowerCase();if(!o.has(l))return!1}if(r){const l=(e.estado??"").trim().toLowerCase();if(!ln.has(l))return!1}return!(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 qn(e){const a=Object.fromEntries(oa.map(s=>[s,0]));for(const s of e){const o=cn(s.estado??"");o&&(a[o]+=1)}const n=e.length;return oa.map(s=>({name:s,data:[n>0?a[s]/n*100:0]}))}function zn(e,a){const n=Bn(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=>Rn(i,n));return{data:o,grafico:qn(o)}}const Ra="__sin_ubicacion__";function qa(e,a){return String(e.label).localeCompare(String(a.label),"es",{sensitivity:"base"})}function yt(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(qa)}function $n(e){return e.map(a=>a===Ra?"":a)}function Un(e){const a=yt(e,r=>Ze(r.tipo_medio)),n=e.some(r=>Ze(r.ubicacion)===null),s=yt(e,r=>Ze(r.ubicacion)),o=[...n?[{label:"Sin ubicación",value:Ra}]:[],...s].sort(qa),i=yt(e,r=>{var l;return((l=Ze(r.estado))==null?void 0:l.toLowerCase())??null},r=>dn(r));return{medios:a,plazas:o,estados:i}}const Hn=({isOpen:e,proyectoId:a,campaignName:n,onClose:s})=>{var B;const[r,l]=u.useState("preventa"),[d,c]=u.useState([]),[m,g]=u.useState([]),[x,p]=u.useState([]),[h,y]=u.useState(!1),[w,j]=u.useState(""),b=Qs(w,400),v=u.useMemo(()=>[{label:"Fase 1 (Preventa)",value:"preventa",leftSlot:ne.faHandHoldingHand},{label:"Fase 2 (Venta)",value:"venta",leftSlot:ne.faHandHoldingCircleDollar}],[]),O=()=>{c([]),g([]),p([]),y(!1)},H=()=>{l("preventa"),O(),j(""),s()},M=$=>{($==="preventa"||$==="venta")&&(l($),O(),j(""))},N=u.useMemo(()=>{const $=b.trim();if($)return $.length>=2?$:void 0},[b,2]),A=an({proyectoId:a,fase:r,enabled:e,filters:{}}),T=u.useMemo(()=>({types_media:d.length>0?d:void 0,locations:m.length>0?$n(m):void 0,status:x.length>0?x:void 0,search:N,onlyDelayed:h}),[d,m,x,N,h]),{medios:X,plazas:U,estados:L}=u.useMemo(()=>{var Y;const $=((Y=A.data)==null?void 0:Y.data)??[];return Un($)},[(B=A.data)==null?void 0:B.data]),I=u.useMemo(()=>{const $=A.data;return $?zn($,T):null},[A.data,T]),V=u.useMemo(()=>({value:w,onChange:j}),[w]),D=u.useMemo(()=>({query:A,dataForUi:I}),[A,I]),q=u.useMemo(()=>({mediosOptions:X,plazasOptions:U,estadosOptions:L,selectedMedios:d,selectedPlazas:m,selectedEstados:x,onlyDelayed:h,onChangeMedios:c,onChangePlazas:g,onChangeEstados:p,onChangeOnlyDelayed:y}),[X,U,L,d,m,x,h]);return t.jsx(f.Modal,{isOpen:e,onClose:H,size:"xl",title:"Progreso",tabs:v,defaultValueTab:"preventa",onChangeTab:M,iconConfig:{icon:ne.faBullhorn},cancelButtonText:"Cerrar",showCancelButton:!0,closeAtCancel:!0,onCancel:H,showSuccessButton:!1,children:t.jsx("div",{className:"tm-bg-surface-default tm-p-16",children:t.jsx(f.Modal.Body,{children:t.jsx(Ln,{campaignName:n,phase:r,search:V,listado:D,filters:q})})})})},Kn=({setPath:e,setProject:a})=>{var q;const[n,s]=u.useState([]),[o,i]=u.useState(!0),[r,l]=u.useState(0),[d,c]=u.useState(10),[m,g]=u.useState(0),[x,p]=u.useState(!1),[h,y]=u.useState(""),[w,j]=u.useState(0),{filters:b,defineFields:v}=Me(),{tasks_api:O,getImageOBP:H}=pe(),{user:M}=je(),N=u.useCallback(async(B,$)=>{var Y,z,re;try{i(!0);const ee={filters:{search:(b==null?void 0:b.search)??"",responsable:{idUser:M.id,responsableType:(Y=b==null?void 0:b.responsable)==null?void 0:Y.responsableType},ejecutivo:(b==null?void 0:b.ejecutivo)??"",cancelada:{$eq:!1}}},S=await O.get("/api/listado_campanias",{params:{pagination:{page:B,pageSize:$},...ee}}),K=be(S==null?void 0:S.data);s(K),g((re=(z=S==null?void 0:S.data)==null?void 0:z.meta)==null?void 0:re.total)}catch(ee){console.error("Error fetching data en Lista Campaña:",ee)}finally{i(!1)}},[b==null?void 0:b.ejecutivo,(q=b==null?void 0:b.responsable)==null?void 0:q.responsableType,b==null?void 0:b.search,O,M.id]),A=u.useCallback(async()=>{try{const B=await O.get("/api/obtener-comerciales");return[...aa].map(Y=>(Y.id==="ejecutivo"&&(Y.options=B.data.map(z=>({id:z.nombre,name:z.nombre}))),Y))}catch(B){return console.error("Error fetching salesman data:",B),[...aa]}},[O]);u.useEffect(()=>{(async()=>{const $=await A();v($)})()},[v,A]),u.useEffect(()=>{const B=Math.floor(r/d)+1;N(B,d)},[r,d,b,N]);const T=B=>{l(B.first),c(B.rows)},X=Math.floor(r/d)+1,U=u.useMemo(()=>(M.role??"").trim().toLowerCase()==="project manager",[M.role]),L=u.useCallback(B=>{var $;y((($=B.campania)==null?void 0:$.nombre)??B.nombre??""),j(Number(B.id)),p(!0)},[]),I=u.useMemo(()=>({label:"Ver progreso",leftSlot:ne.faEye,theme:"solid",color:"secondary",tooltip:"Ver progreso",onClick:B=>L(B)}),[L]),V=u.useMemo(()=>{const B=[{id:"nombre",header:"CAMPAÑA",accessor:$=>{var Y;return((Y=$.campania)==null?void 0:Y.nombre)??$.nombre??"-"},width:200,sortable:!1,filterable:!1,resizable:!1},{id:"inicia",header:"FECHA INICIO",accessor:$=>{var Y;return((Y=$.campania)==null?void 0:Y.inicia)??"-"},width:100,sortable:!1,filterable:!1,resizable:!1},{id:"termina",header:"FECHA FIN",accessor:$=>{var Y;return((Y=$.campania)==null?void 0:Y.termina)??"-"},width:100,sortable:!1,filterable:!1,resizable:!1},{id:"responsable",header:"RESPONSABLE",type:"primary",accessor:$=>{var Y,z;return((z=(Y=$.campania)==null?void 0:Y.responsable)==null?void 0:z.nombre)??"-"},width:150,sortable:!1,filterable:!1,resizable:!1,render:($,Y)=>{var G,k,P,W,E;const z=(G=Y.campania)==null?void 0:G.responsable,re=typeof $=="string"||typeof $=="number"?String($):(z==null?void 0:z.nombre)??"-",ee=(z==null?void 0:z.role)??"-",S=((W=(P=(k=z==null?void 0:z.imagen)==null?void 0:k.formats)==null?void 0:P.thumbnail)==null?void 0:W.url)||((E=z==null?void 0:z.imagen)==null?void 0:E.url)||"",K=S?H(S):z==null?void 0:z.nombre;return{name:re,...K?{avatar:K}:{},...ee?{subtitle:ee}:{}}}},{id:"alertas",header:"ALERTAS",accessor:$=>Ks($.alertas),width:200,minWidth:100,filterable:!1,sortable:!1,resizable:!1,contentAlign:"center",render:$=>t.jsx(Ws,{tags:Array.isArray($)?$:[]})}];return U&&B.push({id:"acciones",header:"ACCIONES",type:"button",sortable:!1,filterable:!1,resizable:!1,accessor:()=>I,width:190,minWidth:160}),B},[H,U,I]),D=u.useMemo(()=>(n??[]).map(B=>({...B,id:B.id})),[n]);return t.jsxs("div",{className:"tm-h-full tm-max-h-[100%] tm-overflow-y-auto tm-scrollbar-none",children:[t.jsx(f.Table,{columns:V,columnsLockable:!1,rows:D,loading:o,hoverable:!0,resizable:!1,pagination:{enabled:!0,currentPage:X,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=>{a({id:B.id,project:B.nombre}),e("kanban-campania")},empty:{type:"empty",title:"No hay campañas disponibles"}}),t.jsx(Hn,{isOpen:x,proyectoId:w,campaignName:h,onClose:()=>p(!1)})]})},za=u.createContext(null),Vn=()=>u.useContext(za),Gn=({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(f.Button,{ref:a,leftSlot:ne.faFilter,color:"primary",theme:"solid",size:"sm",type:"button",children:"Filtrar"}),t.jsx(f.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(za.Provider,{value:s,children:e})})]})};function Wn(e,a=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>=a)&&(e(...i),o=null)},a)}}function Qn(e){return e!=null&&e.length?e.map(a=>({id:a.id,label:a.name,value:a.id})):[]}function Xn({field:e}){const{updateFilters:a,initialFilters:n}=Me(),s=u.useMemo(()=>Qn(e.options),[e.options]),o=n==null?void 0:n[e.id],i=o??"";return t.jsx(f.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 Yn=()=>{const{fields:e,updateFilters:a,cleanFilters:n,applyFilters:s,initialFilters:o}=Me(),i=Vn();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(f.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,l)=>t.jsx("div",{className:"tm-relative",style:{zIndex:10-l},children:(r==null?void 0:r.type)==="select"?t.jsx("div",{className:"tm-relative tm-z-[10] tm-w-full",children:t.jsx(Xn,{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:Wn(d=>{var c,m;return a({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))}),t.jsx(f.Button,{color:"primary",size:"xs",type:"button",fullWidth:!0,onClick:()=>{s(),i==null||i()},children:"Filtrar"})]})},Rt=e=>new Intl.DateTimeFormat("es-MX",{month:"long"}).format(e);function Jn(e){const a=["domingo","lunes","martes","miércoles","jueves","viernes","sábado"],n=new Date(e).getDay();return a[n]}const da=e=>{let a=e||new Date,n=a.getDate(),s=Rt(a.getMonth()).slice(0,3),o=a.getFullYear().toString().slice(-2),i=Jn(a).slice(0,3);return`${i.charAt(0).toUpperCase()+i.slice(1)} ${n} ${s.charAt(0).toUpperCase()+s.slice(1)} ${o}`},qt=(e,a)=>({...e,image:e.image?`${a}${e.image}`:""}),ot=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 Zn{static toCampaignTasks(a){var i,r,l,d,c,m,g,x,p,h,y,w,j,b,v;const n=ot(a==null?void 0:a.id_t_requerida),s=ot(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:(c=(d=(l=(r=(i=a.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=a.responsable.userOBP)==null?void 0:m.role)||{id:0,name:""}}),(g=a==null?void 0:a.equipo)!=null&&g.miembros&&a.equipo.miembros.forEach(O=>{var H,M,N,A,T;o!=null&&o.find(X=>X.id===O.idUser.id)||O.idUser&&o.push({id:O.idUser.id,name:O.idUser.nombre,image:(A=(N=(M=(H=O==null?void 0:O.userOBP)==null?void 0:H.imagen)==null?void 0:M.formats)==null?void 0:N.thumbnail)==null?void 0:A.url,role:((T=O.userOBP)==null?void 0:T.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:((x=a==null?void 0:a.comentarios)==null?void 0:x.length)??null,willBePaused:a==null?void 0:a.es_pausable,nameProject:((p=a==null?void 0:a.proyecto)==null?void 0:p.nombre)??null,idProject:((h=a==null?void 0:a.proyecto)==null?void 0:h.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:((v=a==null?void 0:a.tareas)==null?void 0:v.map(O=>({id:O.id,name:O.texto_corto,status:O.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 eo=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(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=Ee.stringify({filters:{id:{$in:l}},populate:{responsable:{fields:["id","nombre"]},equipo:{fields:["id","nombre"]}}},{encodeValuesOnly:!0});try{const c=await a.get(`/api/tareas?${d}`),m=be(c.data.data||c.data),g=Array.isArray(m)?m:[m],x=new Map(g.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(Zn.toCampaignTasks)}catch(s){console.log(s)}},$a=u.createContext({}),to=({children:e,project:a})=>{var j;const[n,s]=u.useState([]),[o,i]=u.useState(!1),[r,l]=u.useState([]),{tasks_api:d}=pe(),{filters:c}=Me(),{user:m}=je(),[g,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:a}});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:a}};x(v)}},[c,m.id,a]);const p=le.useQuery({queryKey:["tasksProject",g,a],queryFn:()=>{const b={...g,taskName:c==null?void 0:c.taskName,owner:{...g.owner,config:g.owner.config||"yo_y_mis_equipos"}};return eo({filters:b,project:a,tasks_api:d})},refetchOnWindowFocus:!1}),h=b=>{s(v=>[...v,b])},y=b=>{l(v=>v.includes(b)?v.filter(O=>O!==b):[...v,b])},w=a??null;return t.jsx($a.Provider,{value:{tasksProject:p,selectedTasks:n,projectID:w,openTasks:r,selectTask:h,filtersToSend:g,openTask:y,isRefetching:o,project:a,filters:c,setIsRefetching:i},children:e})},at=()=>u.useContext($a),Ua=u.createContext(void 0),ma=()=>({selectedTaskIds:[],baseColumn:null,isFullColumnSelected:!1});function Ha({children:e,invalidateAfterBulkSuccess:a}){const[n,s]=u.useState(ma),[o,i]=u.useState(null),[r,l]=u.useState(!1),{selectedTaskIds:d,baseColumn:c,isFullColumnSelected:m}=n,g=d.length>0,x=c!==null,p=u.useCallback(()=>{s(ma()),i(null),l(!1)},[]),h=u.useCallback(()=>{s(b=>({...b,selectedTaskIds:[],isFullColumnSelected:!1}))},[]),y=u.useCallback((b,v)=>{v!=="Completadas"&&s(O=>{if(O.baseColumn&&O.baseColumn!==v)return O;const H=new Set(O.selectedTaskIds);return H.has(b)?(H.delete(b),{selectedTaskIds:[...H],baseColumn:O.baseColumn,isFullColumnSelected:!1}):(H.add(b),{selectedTaskIds:[...H],baseColumn:O.baseColumn??v,isFullColumnSelected:!1})})},[]),w=u.useCallback(async(b,v)=>{if(b!=="Completadas"){l(!0);try{const O=await v(),H=[...new Set(O)];s(M=>M.baseColumn&&M.baseColumn!==b?M:{selectedTaskIds:H,baseColumn:M.baseColumn??b,isFullColumnSelected:H.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:g,isBulkSessionActive:x,isFullColumnSelected:m,pendingTargetStatus:o,isBulkLoading:r,invalidateAfterBulkSuccess:a,toggleTaskSelection:y,deselectAllSelectedTasks:h,exitBulkSelectionMode:p,selectEntireColumn:w,setPendingTargetStatus:i,setIsBulkLoading:l}),[d,c,g,x,m,o,r,a,y,h,p,w,i,l]);return t.jsx(Ua.Provider,{value:j,children:e})}function zt(){return u.useContext(Ua)}const ao=()=>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"})]})]});class Ka{static toAtrasoReasons(a){return{id:a.id,motivo_imj:a.motivo_imj,categoria:a.categoria??null}}}const so=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(Ka.toAtrasoReasons)}catch(a){throw console.log("Error al obtener los motivos de atraso",a),`Error al obtener los motivos de atraso: ${a}`}},Va=({enabled:e=!1}={})=>{const{tasks_api:a}=pe(),{user:n}=je(),s=le.useQueryClient(),{filters:o,path:i}=Me(),{data:r,isLoading:l}=le.useQuery({queryKey:["atraso_reasons"],queryFn:()=>so({tasks_api:a}),staleTime:1e3*60*60*24,enabled:e}),d=async()=>{const b=await a.get("/api/motivos",{params:{filters:{tipo:{$eq:"atraso"}}}});return be(b.data).map(Ka.toAtrasoReasons)},c=async({taskId:b,motivoId:v,projectID:O})=>{try{return(await a.post("/api/atrasos",{data:{inicio:new Date,fin:null,motivo:v,proyecto:O,tarea:b,creada_por:n==null?void 0:n.id}})).data}catch(H){console.log("error",H)}},m=async b=>{try{return(await a.delete(`/api/atrasos/${b}`)).data}catch(v){console.log("error",v)}},g=async b=>{try{return(await a.put(`/api/atrasos/${b}`,{data:{fin:new Date}})).data}catch(v){console.log("error",v)}},x=async({taskId:b,projectID:v,motivo:O})=>{await y({taskId:b,motivoId:O,projectID:v})},p=async b=>{await w(b)},h=async b=>{await j(b)},{mutateAsync:y}=le.useMutation({mutationFn:c,onSuccess:()=>{f.messageService.success("Atraso registrado correctamente"),i==="kanban-general"&&(s.invalidateQueries({queryKey:["to_do_tasks",o]}),s.invalidateQueries({queryKey:["working_tasks",o]})),i==="kanban-campania"&&s.invalidateQueries({queryKey:["tasksProject"]})},onError:()=>{f.messageService.error("Error al registrar el atraso")}}),{mutateAsync:w}=le.useMutation({mutationFn:m,onSuccess:()=>{f.messageService.success("Atraso eliminado correctamente"),i==="kanban-general"&&(s.invalidateQueries({queryKey:["to_do_tasks"]}),s.invalidateQueries({queryKey:["working_tasks"]}),s.invalidateQueries({queryKey:["done_tasks"]})),i==="kanban-campania"&&s.invalidateQueries({queryKey:["tasksProject"]})},onError:()=>{f.messageService.error("Error al eliminar el atraso")}}),{mutateAsync:j}=le.useMutation({mutationFn:g,onSuccess:()=>{f.messageService.success("Atraso finalizado correctamente")},onError:()=>{f.messageService.error("Error al finalizar el atraso")}});return{atrasoReasons:r,isLoading:l,createAtraso:x,getAtrasoReasons:d,deleteAtraso:p,finalizarAtraso:h}},He=()=>{const{tasks_api:e}=pe(),{user:a}=je(),{filters:n,path:s}=Me(),o=le.useQueryClient(),{projectID:i}=at(),{finalizarAtraso:r}=Va({enabled:!1}),l=async({id:L})=>(await e.put(`/api/tareas/${L}`,{data:{estatus:1,responsable:a==null?void 0:a.id,updated_by:a==null?void 0:a.id}})).data,d=async({id:L})=>(await e.put(`/api/tareas/${L}`,{data:{estatus:0,responsable:a==null?void 0:a.id,updated_by:a==null?void 0:a.id}})).data,c=async({id:L,idAtraso:I})=>{const V=await e.post("/api/terminarTarea",{id_task:L,ended_at:new Date().toISOString(),id_user:a==null?void 0:a.id});return await r(I),V.data},m=async({id:L,repeats:I})=>(await e.put(`/api/tareas/${L}`,{data:{repeticiones_realizadas:I,updated_by:a==null?void 0:a.id}})).data,g=async({id:L,motiveId:I})=>{try{const V=await e.post("/api/pausarTarea",{taskId:L,userId:a==null?void 0:a.id,motivoId:I});return f.messageService.success("Tarea pausada correctamente"),V.data}catch(V){f.messageService.error(`Error al pausar la tarea: ${V}`)}},x=async({id:L})=>{try{const I=await e.post("/api/reanudarTarea",{taskId:L});return f.messageService.success("Tarea reanudada correctamente"),I.data}catch(I){f.messageService.error(`Error al reanudar la tarea: ${I}`)}},p=async({id:L,idNewResponsible:I,typeOfSelect:V})=>{let D={updated_by:a==null?void 0:a.id};return V==="responsible"&&(D={...D,responsable:I}),V==="team"&&(D={...D,responsable:null,equipo:I}),(await e.put(`/api/tareas/${L}`,{data:D})).data},h=async({id:L,data:I,user:V})=>{try{return(await e.put(`/api/tareas/${L}`,{data:{...I,updated_by:V==null?void 0:V.id}})).data}catch(D){console.error("Error updating the element:",D)}},y=async({id:L})=>{await b({id:L})},w=async({id:L,data:I,user:V})=>{await j({id:L,data:I,user:V})},{mutateAsync:j}=le.useMutation({mutationFn:h,onSuccess:()=>{f.messageService.success("Tarea actualizada correctamente");const L={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[L[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(I){console.error("Error invalidating queries:",I)}},onError:L=>{console.error("Failed to update the task.",L)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]})}}),{mutateAsync:b}=le.useMutation({mutationFn:l,onSuccess:()=>{const L={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[L[s],n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(I){console.error("Error updating the element:",I)}},onError:L=>{console.error("Failed to update the task.",L)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:v}=le.useMutation({mutationFn:c,onSuccess:()=>{const L={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{o.setQueryData([L[s],n],I=>{console.log({oldData:I})}),s==="kanban-general"&&(o.invalidateQueries({queryKey:[L[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(I){console.error("Error invalidating queries:",I)}},onError:L=>{console.error("Failed to update the task.",L)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:O}=le.useMutation({mutationFn:m,onSuccess:()=>{const L={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[L[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(I){console.error("Error invalidating queries:",I)}},onError:L=>{console.error("Failed to update the task.",L)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:H}=le.useMutation({mutationFn:p,onSuccess:()=>{const L={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[L[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(I){console.error("Error invalidating queries:",I)}},onError:L=>{console.error("Failed to reassign the task.",L)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["done_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}}),{mutateAsync:M}=le.useMutation({mutationFn:d,onSuccess:()=>{const L={"kanban-general":"to_do_tasks","kanban-campania":"tasksProject"};try{s==="kanban-general"&&(o.invalidateQueries({queryKey:[L[s],n]}),o.invalidateQueries({queryKey:["working_tasks",n]})),s==="kanban-campania"&&(o.invalidateQueries({queryKey:["tasksProject"]}),o.invalidateQueries({queryKey:["tasksProject",n,i]}))}catch(I){console.error("Error updating the element:",I)}},onError:L=>{console.error("Failed to update the task.",L)},onMutate:async()=>{await o.cancelQueries({queryKey:["working_tasks"]}),await o.cancelQueries({queryKey:["to_do_tasks"]})}});return{updatingTask:w,updateTask:h,startTask:async({id:L})=>{await M({id:L})},startWorking:y,completeTask:async({id:L,idAtraso:I})=>{await v({id:L,idAtraso:I})},reasignResponsible:async({id:L,idNewResponsible:I,typeOfSelect:V})=>{await H({id:L,idNewResponsible:I,typeOfSelect:V})},updateUnitys:async({repeats:L,id:I})=>{await O({repeats:L,id:I})},pauseTask:async({id:L,motiveId:I})=>{console.log({taksId:L,motivoId:I,user:a==null?void 0:a.id})},postPauseTask:g,postReanudeTask:x}},no="Project Manager";function ut(e,a){return e===no?!0:Number.isFinite(a)?a===0:!1}function Fe({trigger:e,children:a,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?t.jsxs("span",{className:l,children:[t.jsx("span",{ref:c,className:d,children:e}),t.jsx(f.Popover,{triggerRef:c,openOnHover:!0,position:s,offset:o,closeOnClick:i,popoverArrow:r,children:a})]}):t.jsx(t.Fragment,{children:e})}const De=({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-surface-default tm-rounded-full tm-border-2 tm-border-default`})},ua=({trigger:e,user:a,showUser:n=!0})=>t.jsx(Fe,{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(De,{imageUrl:a.image??"",alt:a.name}),t.jsx("p",{className:"tm-text-sm tm-font-bold tm-text-texts-subtext",children:a.name})]})}),oo=({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(f.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(De,{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 ro{static toDomain(a){return{id:a.id,name:a.nombre,color:a.color}}}const io=()=>{const{tasks_api:e}=pe();return{teams:le.useQuery({queryKey:["teams","all"],queryFn:async()=>{const n=await e.get("/api/equipos");return be(n.data).map(ro.toDomain)},refetchOnWindowFocus:!1})}};class $t{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 lo=async({tasks_api:e})=>{try{const a=await e.get("/api/getAllOBPusersMembers");return be(a.data).map($t.toUsers)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},co=async({tasks_api:e})=>{try{const a={filters:{$and:[{role:{name:{$in:["Project Manager","Operation Manager","Administrador"]}}},{blocked:{$eq:!1}}]}},n=Ee.stringify(a,{encodeValuesOnly:!0}),s=await e.get(`/api/users?${n}`),i=be(s.data).map(d=>d.email),r=await e.get(`/api/getAllOBPusers?filters[name][$in]=${i}`);return be(r.data).map($t.toUsersV2)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},mo=async({users:e})=>{try{const a=be(e);return $t.toUsersWithIndex(a)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},uo=()=>{const{tasks_api:e}=pe();return{users:le.useQuery({queryKey:["users"],queryFn:()=>lo({tasks_api:e}),staleTime:1e3*60*60*24})}},po=()=>{const{tasks_api:e}=pe();return{users:le.useQuery({queryKey:["allUsers"],queryFn:()=>co({tasks_api:e}),staleTime:1e3*60*60*24})}},Ga=({users:e,onClick:a,responsible:n,role:s,status:o})=>{const{getOBPUrlApi:i}=pe(),r=u.useRef(null),l=u.useRef(null),d=u.useId(),[c,m]=u.useState("team"),{teams:g}=io(),{users:x}=uo(),p=ut(s,o),h=()=>n?null:e.length>3&&t.jsx(Fe,{position:"top",popoverArrow:!1,triggerWrapperClassName:"tm-inline-flex tm-items-center",trigger:t.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:t.jsx(f.Text,{children:`+${e.length-3}`})}),children:t.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)=>t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8 ",children:[t.jsx(De,{imageUrl:b.image??"",alt:b.name},v),t.jsx(f.Text,{children:b.name})]},v))})}),y=()=>{if(n){const b=e.find(v=>v.id===n);return t.jsx("div",{children:p?t.jsx(f.Tooltip,{label:(b==null?void 0:b.name)??"",position:"top",children:t.jsx(De,{imageUrl:b==null?void 0:b.image,alt:b==null?void 0:b.name},n)}):t.jsx(ua,{trigger:t.jsx(De,{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)=>t.jsx("div",{className:`${v===0?"":"tm-ml-[-8px]"}`,children:p?t.jsx(f.Tooltip,{label:b.name,position:"top",children:t.jsx(De,{imageUrl:b.image,alt:b.name})}):t.jsx(ua,{trigger:t.jsx(De,{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 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((v,O)=>t.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":""} ${O===b.length-1?"tm-border-r-0":" tm-border-r-2"}`,onClick:()=>m(v.id),children:v.label},v.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(oo,{options:c==="team"?((g==null?void 0:g.data)??[]).map(b=>({id:b.id,name:b.name,image:""})):((x==null?void 0:x.data)??[]).map(b=>qt(b,i())),onselect:b=>{var v,O;(v=l.current)==null||v.close(),a((O=b.tasksUser)==null?void 0:O.id,c)}})]});return e.length===0?p?t.jsxs(t.Fragment,{children:[t.jsx("span",{ref:r,className:"tm-inline-flex tm-cursor-pointer tm-items-center",children:t.jsx(f.Icon,{name:ne.faUser,size:"xs",color:"current"})}),t.jsx(f.Popover,{ref:l,triggerRef:r,position:"bottom-left",offset:8,closeOnClick:!1,closeOnClickOutside:!0,closeOnEscape:!0,popoverArrow:!1,popupId:`assign-users-${d}`,children:j()})]}):t.jsx("span",{className:"tm-inline-flex tm-items-center",children:t.jsx(f.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(),h()]}),p&&t.jsx(f.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()})]})},fo=[1,2,3,4,5],jt={1:{title:"Muy fácil",color:"brand"},2:{title:"Fácil",color:"success"},3:{title:"Media",color:"warning"},4:{title:"Difícil",color:"danger"},5:{title:"Muy difícil",color:"danger"}};function pa(e){const a=Number(e);if(e==null||Number.isNaN(a)||!Number.isFinite(a))return 1;let n=Math.trunc(a);return n===0&&(n=1),n<1||n>5?1:n}const Ut=({difficulty:e,id:a,withLabel:n=!1,canEdit:s=!0})=>{const{updatingTask:o}=He(),i=u.useId().replace(/:/g,""),[r,l]=u.useState(null),{user:d}=je(),[c,m]=u.useState(()=>pa(e));u.useEffect(()=>{m(pa(e))},[e]);const g={title:"Sin dato",color:"primary"},x=jt[c]??g,p=x.title??"Sin dato",h=()=>{if(!r)return null;const w=({level:j,text:b,itemColor:v})=>t.jsxs("button",{type:"button",onClick:async()=>{l(null),await o({id:a,data:{nivel_dificultad:j},user:d==null?void 0:d.id}),m(j)},className:"tm-flex tm-items-center tm-gap-m tm-px-l tm-py-s hover:tm-bg-primary-light",children:[t.jsx(f.Icon,{name:ne.faRhombus,size:"xs",color:v}),t.jsx(f.Text,{type:"body",size:"sm",color:v,children:b})]});return Ft.createPortal(t.jsx("div",{onBlur:()=>{l(null)},id:`${i}-difficulty-options`,style:{top:`${r.y+5}px`,left:`${r.x+5}px`,zIndex:200},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 tm-shadow-02","data-portal-host":!0,children:fo.map(j=>t.jsx(w,{level:j,text:jt[j].title,itemColor:jt[j].color},j))}),document.body)},y=w=>{w.stopPropagation()};return s?t.jsxs("div",{className:"tm-relative",onClick:y,onPointerDown:y,children:[t.jsxs("label",{htmlFor:i,onBlur:()=>{l(null)},className:"tm-flex tm-cursor-pointer tm-items-center tm-gap-2 active:tm-opacity-50",children:[t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faRhombus,size:"sm",color:x.color}),children:t.jsx("div",{className:"tm-px-8 tm-py-4",children:t.jsx(f.Text,{color:x.color,children:`Dificultad: ${p}`})})}),n&&t.jsx(f.Text,{as:"span",color:x.color,children:p})]}),t.jsx("button",{id:i,type:"button",onClick:w=>{w.stopPropagation(),l(r?null:{x:w.clientX,y:w.clientY})},className:"tm-hidden"}),t.jsx(h,{})]}):t.jsxs("div",{className:"tm-relative tm-flex tm-items-center tm-gap-2",onClick:y,onPointerDown:y,children:[t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faRhombus,size:"sm",color:x.color}),children:t.jsx("div",{className:"tm-px-8 tm-py-4",children:t.jsx(f.Text,{color:x.color,children:`Dificultad: ${p}`})})}),n&&t.jsx(f.Text,{as:"span",color:x.color,className:"tm-text-lg tm-font-normal",children:p})]})},Ht=({priority:e,id:a,withLabel:n=!1,canEdit:s=!0})=>{const{updatingTask:o}=He(),i=u.useId().replace(/:/g,""),[r,l]=u.useState(null),{user:d}=je(),[c,m]=u.useState(e);u.useEffect(()=>{m(e)},[e]);const g={0:{title:"Normal",color:"brand"},1:{title:"Baja",color:"success"},2:{title:"Media",color:"warning"},3:{title:"Alta",color:"danger"}},x={title:"Sin prioridad",color:"primary"},h=(()=>{const b=c;if(typeof b!="number"||!Number.isFinite(b))return x;const v=Math.trunc(b);return v<0||v>3?x:g[v]??x})(),y=h.title??"Sin prioridad",w=()=>{if(!r)return null;const b=({priorityTask:v,text:O,itemColor:H})=>t.jsxs("button",{type:"button",onClick:async()=>{l(null),await o({id:a,data:{prioridad:v},user:d==null?void 0:d.id}),m(v)},className:"tm-flex tm-items-center tm-gap-m tm-px-l tm-py-s hover:tm-bg-primary-light",children:[t.jsx(f.Icon,{name:ne.faFlag,size:"xs",color:H}),t.jsx(f.Text,{type:"body",size:"sm",color:H,children:O})]});return Ft.createPortal(t.jsx("div",{onBlur:()=>{l(null)},id:`${i}-options`,style:{top:`${r.y+5}px`,left:`${r.x+5}px`,zIndex:200},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(g).map((v,O)=>t.jsx(b,{priorityTask:O,text:v.title,itemColor:v.color},O))}),document.body)},j=b=>{b.stopPropagation()};return s?t.jsxs("div",{className:"tm-relative",onClick:j,onPointerDown:j,children:[t.jsxs("label",{onBlur:()=>{l(null)},htmlFor:i,className:"tm-flex tm-cursor-pointer tm-items-center tm-gap-2 active:tm-opacity-50",children:[t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faFlag,size:"sm",color:h.color}),children:t.jsx("div",{className:"tm-px-8 tm-py-4",children:t.jsx(f.Text,{color:h.color,children:`Prioridad: ${y}`})})}),n&&t.jsx(f.Text,{as:"span",color:h.color,className:" tm-font-normal",children:y})]}),t.jsx("button",{id:i,type:"button",onClick:b=>{b.stopPropagation(),l(r?null:{x:b.clientX,y:b.clientY})},className:"tm-hidden"}),t.jsx(w,{})]}):t.jsxs("div",{className:"tm-relative tm-flex tm-items-center tm-gap-2",onClick:j,onPointerDown:j,children:[t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faFlag,size:"sm",color:h.color}),children:t.jsx("div",{className:"tm-px-8 tm-py-4",children:t.jsx(f.Text,{color:h.color,children:`Prioridad: ${y}`})})}),n&&t.jsx(f.Text,{as:"span",color:h.color,className:"tm-text-lg tm-font-normal",children:y})]})};function go(e,a){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===a))??[]).filter(s=>typeof s.id=="number"&&!Number.isNaN(s.id)&&s.nombre.length>0).map(s=>({id:s.id,nombre:s.nombre}))}function ho(e){return e.map(a=>({id:a.id,label:a.nombre}))}const Ue={TO_SECOND:"task-move-first-to-second",TO_THIRD:"task-move-first-to-third",TO_FOURTH:"task-move-first-to-fourth"};function xo(e,a){const n=[];return e===0&&n.push({id:Ue.TO_SECOND,label:"Mover a trabajando",icon:Se.faArrowRight}),e===1&&n.push({id:Ue.TO_SECOND,label:"Mover a completada",icon:Se.faArrowRight},{id:Ue.TO_FOURTH,label:"Mover por hacer",icon:Se.faArrowLeft}),a?n.push({id:Ue.TO_THIRD,label:"Eliminar atraso"}):n.push({id:Ue.TO_THIRD,label:"Agregar atraso"}),n}function bo(e){return e===0?{title:"Mover a trabajando"}:{title:"Mover a completada"}}function yo(){return{title:"Mover a por hacer"}}function fa({copy:e,onMove:a}){return t.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:[t.jsx("p",{className:"tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_medium",children:e.title}),t.jsx(f.Button,{type:"button",fullWidth:!0,size:"xs",color:"primary",onClick:a,children:"Mover"})]})}const jo=({status:e,nameRequiredTask:a,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),g=u.useRef(null),{startWorking:x,completeTask:p,startTask:h}=He(),y=u.useRef(!1),[w,j]=u.useState(!1),[b,v]=u.useState(null),[O,H]=u.useState("first"),M=a!==""&&n===2,[N,A]=u.useState(null),{atrasoReasons:T,isLoading:X,createAtraso:U,deleteAtraso:L}=Va({enabled:!0}),[I,V]=u.useState(null),D=u.useCallback(()=>{var S;(S=c.current)==null||S.close()},[]);u.useEffect(()=>{o&&H("third")},[o]),u.useEffect(()=>{if(!w)return;const S=()=>{D()};return window.addEventListener("scroll",S,!0),document.addEventListener("scroll",S,!0),()=>{window.removeEventListener("scroll",S,!0),document.removeEventListener("scroll",S,!0)}},[w,D]);const q=S=>{H(S),S==="second"?v(e===0?"Trabajando":"Completadas"):S==="fourth"&&v("Por hacer")},B=()=>{if(y!=null&&y.current)return t.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:t.jsx("p",{className:"tm-font-regular tm-text-sm tm-font-normal tm-text-primary-pastel",children:"Moviendo..."})});const S=xo(e,r);return t.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:t.jsx(f.ListBase,{variant:"default",list:{items:S},events:{onItemClick:K=>{switch(K.id){case Ue.TO_SECOND:q("second");break;case Ue.TO_THIRD:q("third");break;case Ue.TO_FOURTH:q("fourth");break}}}})})},$=()=>t.jsx(fa,{copy:bo(e),onMove:()=>{y.current=!0,b==="Trabajando"?x({id:s}):b==="Por hacer"?h({id:s}):p({id:s,idAtraso:r}),D()}}),Y=()=>{if(X)return t.jsx("div",{children:"Cargando motivos..."});const S=go(T,l==null?void 0:l.nombre),K=ho(S);return S.length>0?t.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:[!N&&!r?t.jsxs(t.Fragment,{children:[t.jsx("p",{className:"tm-mb-[11px] tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_regular",children:"Atraso de tarea"}),t.jsx(f.Dropdown,{field:{placeholder:"Seleccione una opción"},items:{options:K,idName:"id"},values:{value:(I==null?void 0:I.id)??""},menuSearch:{searchable:!0,searchPlaceholder:"Buscar"},popover:{absolute:!1,closeOnClickOutside:!0,dropdownId:`task-atraso-motivo-${s}`,popoverZIndex:1200},events:{onValueChange:G=>{const k=Number(G);if(Number.isNaN(k))return;const P=S.find(W=>W.id===k);V({id:k,nombre:(P==null?void 0:P.nombre)??""})},onOptionSelect:G=>{const k=G.id;k==null||Number.isNaN(Number(k))||V({id:Number(k),nombre:String(G.label??"")})}}})]}):t.jsxs(t.Fragment,{children:[t.jsx("p",{className:"tm-text-left tm-text-[14px] tm-font-semibold tm-text-ink-black_medium",children:"¿Estas seguro?"}),t.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 ${(N==null?void 0:N.nombre)??""}`})]}),t.jsxs("div",{className:"tm-my-[11px] tm-flex tm-justify-end tm-gap-3",children:[t.jsx(f.Button,{type:"button",size:"xs",color:"secondary",onClick:()=>{N?A(null):D()},children:N?"Regresar":"Cancelar"}),t.jsx(f.Button,{type:"button",size:"xs",color:"primary",onClick:()=>{A(I),r&&!N?L(r):N&&ee()},children:"Aceptar"})]})]}):t.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"})},z=()=>t.jsx(fa,{copy:yo(),onMove:()=>{y.current=!0,h({id:s}),D()}}),re=()=>{if(O==="first")return B();if(O==="second")return $();if(O==="third")return Y();if(O==="fourth")return z()},ee=async()=>{if(I)try{await U({taskId:s,projectID:i,motivo:(I==null?void 0:I.id)??null}),D()}catch(S){console.error("Error al crear atraso:",S)}};return t.jsx(t.Fragment,{children:(M&&n===2||!a)&&t.jsxs(t.Fragment,{children:[t.jsx(f.Button,{ref:m,type:"button","aria-label":"Más opciones para mover la tarea",color:"secondary",pill:"pill",size:"xxs",icon:Se.faEllipsis,disabled:d}),t.jsx(f.Popup,{ref:c,triggerRef:m,popupId:`task-move-menu-${s}`,position:"bottom-right",offset:1,closeOnClick:!1,closeOnClickOutside:!1,popoverArrow:!1,onOpen:()=>{j(!0),H("first")},onClose:()=>j(!1),children:t.jsx("div",{ref:g,className:`
|
|
3
3
|
tm-ease tm-transition-all tm-duration-300
|
|
4
|
-
${
|
|
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:t.jsx(
|
|
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:t.jsx(
|
|
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(`
|
|
4
|
+
${O==="second"?"":"tm-translate-x-0"}
|
|
5
|
+
`,children:re()})})]})})},Ce={texts:{subtext:"#4f4f4f",placeholder:"#929292"},primary:{regular:"#425CAC"},success:{dark:"#368156",regular:"#43B071"},danger:{dark:"#8C352C",regular:"#C34335"},warning:{dark:"#B4782F",regular:"#D38A31"}},wo=({id:e,idAtraso:a})=>{const[n,s]=u.useState(!1),{completeTask:o}=He();return{checked:n,checkTask:()=>{s(!n),o({id:e,idAtraso:a})}}},ga={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"},vo="tm-mx-[2px] tm-flex tm-items-center tm-justify-center tm-rounded-full tm-bg-success-regular tm-transition-all",ha="tm-text-sm tm-flex tm-w-fit tm-max-w-[400px] tm-flex-col tm-gap-m tm-rounded-lg tm-bg-surface-warning-default tm-p-l tm-text-primary",Wa=({id:e,nameRequiredTask:a,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:g,checkTask:x}=wo({id:e,idAtraso:o}),h=!!(a&&a!==""&&n===2)||!a,y=!!r,w=s===1&&d,j=()=>t.jsx("label",{htmlFor:m,className:g?ga.checked:ga.unchecked,children:g?t.jsx(f.Icon,{name:ne.faCheck,size:"xs",style:{color:"white"},color:"current"}):t.jsx(f.Icon,{name:ne.faCircle,size:"sm",style:{color:Ce.texts.placeholder},color:"current"})});return s===2?t.jsx("div",{className:vo,children:t.jsx(f.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(Fe,{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(f.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:Ce.warning.regular},color:"current"})}),children:t.jsxs("div",{className:ha,children:[t.jsx("p",{className:"tm-w-[210px] tm-font-bold",children:"Tarea padre:"}),t.jsx("p",{children:r}),l&&t.jsxs("p",{className:"tm-font-bold",children:["Responsable:"," ",t.jsx("span",{className:"tm-font-normal",children:l})]}),t.jsx(f.Text,{children:"Esta tarea completa automáticamente la tarea padre."})]})}),w&&j()]}),t.jsx("input",{id:m,checked:g,onChange:x,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]}):h?t.jsxs(t.Fragment,{children:[s===1&&j(),t.jsx("input",{id:m,checked:g,onChange:x,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]}):t.jsxs(t.Fragment,{children:[t.jsx(Fe,{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(f.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:Ce.warning.regular},color:"current"})}),children:t.jsxs("div",{className:ha,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:m,checked:g,onChange:x,type:"checkbox",className:"tm-hidden","aria-hidden":!0})]})};function _o({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-surface-default",children:e.map((o,i)=>t.jsx("div",{className:"tm-border-r tm-border-black-light",children:t.jsx(f.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-surface-default tm-pt-4",children:(s=e.find(o=>o.id===a))==null?void 0:s.component})]})}function To({comment:e}){var o,i,r,l,d;const{getImageOBP:a}=pe(),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=mt.parseISO(c);return mt.formatDistanceToNow(m,{locale:Mt.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(De,{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(f.Text,{type:"title",size:"sm",weight:"medium",color:"secondary",children:(d=e==null?void 0:e.autor)==null?void 0:d.nombre}),t.jsx(f.Text,{children:s(e==null?void 0:e.createdAt)})]}),t.jsx(f.Text,{children:e==null?void 0:e.comentario})]})]})})}function No({currentUser:e,data:a,taskId:n,onNewComment:s}){var p,h,y;const{tasks_api:o,getImageOBP:i}=pe(),{control:r,handleSubmit:l,reset:d}=Pe.useForm({defaultValues:{comment:""}}),[c,m]=u.useState([]),g=(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(a!=null&&a.comentarios){const w=[...a.comentarios].sort((j,b)=>new Date(b.createdAt).getTime()-new Date(j.createdAt).getTime());m(w)}},[a]);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 t.jsxs("div",{className:"tm-flex tm-h-full tm-flex-col tm-gap-4",children:[t.jsxs("form",{onSubmit:l(x),className:"tm-flex tm-flex-row tm-items-center tm-gap-3",children:[t.jsx(De,{size:"xxl",imageUrl:g?i(g):"",alt:"@shadcn"}),t.jsx("div",{className:"tm-min-w-0 tm-flex-1",children:t.jsx(Pe.Controller,{name:"comment",control:r,rules:{required:"Escribe un comentario"},render:({field:w,fieldState:{error:j}})=>t.jsx(f.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)=>t.jsx(To,{comment:w},j))]})}function Co({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?mt.format(new Date(s),"d MMM",{locale:Mt.es}):"";return t.jsxs("div",{children:[t.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-4",children:[t.jsx(f.Text,{children:"Tareas dependientes"}),t.jsx(f.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-default",children:e==null?void 0:e.map(s=>{var o,i,r,l,d;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-8",children:[t.jsx(De,{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}),t.jsx(f.Text,{children:s==null?void 0:s.texto_corto})]}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-1",children:[t.jsx(f.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 ${((d=a[s==null?void 0:s.estatus])==null?void 0:d.color)??"tm-bg-gray-400"}`})]})]},s.id)})})]})}function So({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(f.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 Qa({isOpen:e,setIsOpen:a,taskId:n}){var O,H,M,N,A,T,X,U,L;const[s,o]=u.useState(null),[i,r]=u.useState(!1),[l,d]=u.useState(!1),[c,m]=u.useState(null),g=(N=(M=(H=(O=s==null?void 0:s.responsable)==null?void 0:O.imagen)==null?void 0:H.formats)==null?void 0:M.thumbnail)==null?void 0:N.url,{tasks_api:x,getImageOBP:p}=pe(),{user:h}=je(),y=Number(s==null?void 0:s.estatus),w=Number.isFinite(y)?y:-1,j=ut(h==null?void 0:h.role,w);u.useEffect(()=>{if(e&&n||i){const I=async()=>{const D=await x.get(`/api/detalleTarea/${n}`);o(D==null?void 0:D.data)},V=async()=>{const D=await x.get(`/api/users/${h.id}`);m(D==null?void 0:D.data)};I(),V()}},[e,n,i,h.id,x]);const b=I=>I?mt.format(I,"d MMM yyyy, h:mmaaa",{locale:Mt.es}):"Fecha no disponible",v=[{id:1,label:"Todo",component:t.jsx(No,{taskId:n,currentUser:c,data:s,onNewComment:r})},{id:2,label:"Dependencias",component:t.jsx(Co,{data:s==null?void 0:s.ids_t_dependientes})}];return e&&Ft.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-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:t.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:[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:[((A=s==null?void 0:s.id_t_requerida)==null?void 0:A.id)&&t.jsxs(t.Fragment,{children:[t.jsx("div",{className:"tm-cursor-help",onMouseOver:()=>d(!0),onMouseLeave:()=>d(!1),children:t.jsx(f.Icon,{name:ne.faCircleInfo,size:"sm",style:{color:Ce.warning.regular},color:"current"})}),l&&(()=>{var V;const I=ot(s==null?void 0:s.id_t_requerida);return t.jsxs("div",{style:{top:"25px"},className:"tm-absolute tm-z-50 tm-flex tm-w-fit tm-max-w-[400px] tm-flex-col tm-gap-m tm-rounded-lg tm-bg-surface-warning-default tm-p-l tm-text-xs tm-text-primary",children:[t.jsx(f.Text,{type:"body",size:"sm",weight:"bold",children:"Requiere completar su tarea:"}),t.jsx(f.Text,{type:"body",size:"xs",weight:"medium",children:(V=s==null?void 0:s.id_t_requerida)==null?void 0:V.texto_corto}),I&&t.jsxs(f.Text,{type:"body",size:"xs",weight:"medium",children:["Responsable: ",t.jsx("span",{className:"tm-font-normal",children:I})]})]})})()]}),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(f.Tooltip,{label:(T=s==null?void 0:s.atraso)==null?void 0:T.motivo,position:"bottom",children:t.jsx("button",{className:"tm-ml-2 tm-inline-block tm-h-fit tm-align-middle",children:t.jsx(f.Icon,{name:ne.faTriangleExclamation,size:"md",style:{color:Ce.warning.dark},color:"current"})})})]})})]}),t.jsx(f.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(So,{id:n,texto_largo:s==null?void 0:s.texto_largo,user_id:h.id}),t.jsx(f.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-8 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"}),(X=s==null?void 0:s.responsable)!=null&&X.nombre?t.jsxs("div",{className:"tm-flex tm-flex-row tm-items-center tm-gap-8",children:[t.jsx(De,{size:"xxl",imageUrl:g?p(g):"",alt:"@shadcn"}),t.jsx(f.Text,{children:(U=s==null?void 0:s.responsable)==null?void 0:U.nombre})]}):t.jsx(f.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(f.Text,{children:((L=s==null?void 0:s.equipo)==null?void 0:L.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(Ht,{priority:parseInt(String(s==null?void 0:s.prioridad),10)||0,id:n,withLabel:!0,canEdit:j})]}),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:"Dificultad"}),t.jsx(Ut,{difficulty:(s==null?void 0:s.nivel_dificultad)!=null&&(s==null?void 0:s.nivel_dificultad)!==""?Number(s.nivel_dificultad):void 0,id:n,withLabel:!0,canEdit:j})]}),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(f.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(f.Text,{children:b(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(f.Text,{children:b(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(f.Text,{children:b(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(f.Text,{children:b(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(f.Text,{children:b(s==null?void 0:s.updatedAt)})]})]})}),t.jsx(_o,{items:v})]})})]}),document.body)}class Eo{static toPauseReasons(a){return{id:a.id,motivo_imj:a.motivo_imj}}}const Po=async({tasks_api:e})=>{try{const a=await e.get("/api/motivos");return be(a.data).map(Eo.toPauseReasons)}catch(a){throw console.log("Error al obtener los usuarios comerciales",a),`Error al obtener los usuarios comerciales: ${a}`}},Ao=()=>{const{tasks_api:e}=pe();return{pauseReasons:le.useQuery({queryKey:["pause_task_reasons"],queryFn:()=>Po({tasks_api:e}),staleTime:1e3*60*60*24})}};class Io{static toKanbanTasks(a){var i,r,l,d,c,m,g,x,p,h,y,w,j;const n=ot(a==null?void 0:a.id_t_requerida),s=ot(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:(c=(d=(l=(r=(i=a.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=a.responsable.userOBP)==null?void 0:m.role)||{id:0,name:""}}),(g=a==null?void 0:a.equipo)!=null&&g.miembros&&a.equipo.miembros.forEach(b=>{var v,O,H,M,N;o!=null&&o.find(A=>A.id===b.idUser.id)||b.idUser&&o.push({id:b.idUser.id,name:b.idUser.nombre,image:(M=(H=(O=(v=b==null?void 0:b.userOBP)==null?void 0:v.imagen)==null?void 0:O.formats)==null?void 0:H.thumbnail)==null?void 0:M.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:(x=a==null?void 0:a.proyecto)==null?void 0:x.nombre,idProject:(p=a==null?void 0:a.proyecto)==null?void 0:p.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:((h=a==null?void 0:a.responsable)==null?void 0:h.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 pt=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=Ee.stringify({filters:{id:{$in:i}},populate:{responsable:{fields:["id","nombre"]},equipo:{fields:["id","nombre"]}}},{encodeValuesOnly:!0});try{const l=await a.get(`/api/tareas?${r}`),d=be(l.data.data||l.data),c=Array.isArray(d)?d:[d],m=new Map(c.map(g=>[g.id,g]));s.forEach(g=>{var x;if((x=g==null?void 0:g.id_t_requerida)!=null&&x.id){const p=m.get(g.id_t_requerida.id);p&&(g.id_t_requerida={...g.id_t_requerida,responsable:p.responsable||null,equipo:p.equipo||null})}})}catch{}}return s.map(Io.toKanbanTasks)}catch(n){throw console.log({error:n}),`Error al obtener las tareas: ${n}`}},Kt=30,Vt=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)===Kt&&(e==null||e.fetchNextPage())}},Ge=e=>({pagination:{page:e,pageSize:Kt,withCount:!0}}),Xa=()=>{var c;const e=le.useQueryClient(),{tasks_api:a}=pe(),{user:n}=je(),{filters:s}=Me(),[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=le.useInfiniteQuery({initialPageParam:1,queryKey:["to_do_tasks",r],queryFn:({pageParam:m})=>pt({filters:{...r,status:"por_hacer",...Ge(m)},tasks_api:a}),staleTime:1e3*60*60*24,getNextPageParam:(m,g)=>g.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 g=await a.get("/api/listado_tareas",{params:{...r,status:"por_hacer",cancelada:!1,...Ge(1),tasks_api:a,justCount:!0}});i(g.data.total)})()},[r,d==null?void 0:d.data]),{toDoTasks:d,total:o,filtersToSend:r}};function Do(e){return(e??[]).map(a=>({id:a.id,label:a.motivo_imj}))}const Fo=({idTask:e,setOpen:a,paused:n})=>{const s=le.useQueryClient(),{toDoTasks:o,filtersToSend:i}=Xa(),[r,l]=u.useState(!1),[d,c]=u.useState(null),{tasksProject:m}=at(),{postPauseTask:g,postReanudeTask:x}=He(),{pauseReasons:p}=Ao(),h=Do(p==null?void 0:p.data),y=async()=>{try{if(d==null)return;if(a(!1),await g({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(a(!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 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(f.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)}}}),t.jsxs("div",{className:"tm-mt-5 tm-flex tm-w-full tm-justify-end tm-gap-m",children:[t.jsx(f.Button,{type:"button",onClick:()=>a(!1),size:"xs",color:"secondary",children:"Cancelar"}),n?t.jsx(f.Button,{type:"button",onClick:()=>w(),size:"xs",color:"primary",children:"Si, reanudar"}):t.jsx(f.Button,{type:"button",disabled:!d,onClick:()=>r?y():l(!0),size:"xs",color:"primary",children:"Aceptar"})]})]})})},Ya=({idTask:e,paused:a,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}`,g=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}"]`))||g()};return window.addEventListener("scroll",x,!0),document.addEventListener("scroll",x,!0),()=>{window.removeEventListener("scroll",x,!0),document.removeEventListener("scroll",x,!0)}},[r,g,n,m]),t.jsxs(t.Fragment,{children:[s(i),t.jsx(f.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:t.jsx(Fo,{idTask:e,paused:a,setOpen:x=>{x||g()}},d)})]})},Mo=({id:e,task:a,endDate:n,users:s,willBePaused:o,nameProject:i,comments:r,priority:l,difficulty:d,responsible:c,nameRequiredTask:m,nameRequiredTaskResponsible:g,statusRequiredTask:x,status:p,repeatsToDo:h,repeats:y,medioName:w,paused:j,idProject:b,atraso:v,categoria:O,cambio_arte:H,name_father_required_task:M,name_father_required_task_responsible:N,boardColumnTitle:A,isBulkColumnLocked:T=!1})=>{const[X,U]=u.useState(!1),L=u.useId(),{reasignResponsible:I,updateUnitys:V}=He(),{getOBPUrlApi:D}=pe(),[q,B]=u.useState(y??0),$=!!(h&&y===h),Y=!h||h===1,z=p===0,re=($||Y||z)&&p!==2,ee=(m??"")!==""&&x===2,{user:S}=je(),K=ut(S==null?void 0:S.role,p),G=zt(),k=!!(G!=null&&G.selectedTaskIds.includes(e)),P=re&&(ee||!m),W=!!G&&!!A&&A!=="Completadas"&&!T,E=W&&P,C=W&&!P&&!!(G!=null&&G.isBulkSessionActive),R=!!(G!=null&&G.isMultiSelectActive&&E&&ee),F=!E||!!(G!=null&&G.isBulkLoading),_=te=>{!G||!A||F||G.toggleTaskSelection(e,A)},Q=()=>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:[p<2&&(M||$||Y||z)&&t.jsx("span",{"data-prevent-bulk-select":!0,children:t.jsx(Wa,{id:e,nameRequiredTask:m??"",statusRequiredTask:x??0,status:p,idAtraso:v==null?void 0:v.atrasoId,nameRequiredTaskResponsible:g,name_father_required_task:M,name_father_required_task_responsible:N,repeatsAreCompleted:$})}),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:te=>{te.stopPropagation(),U(!0)},children:a})]}),P&&t.jsxs("div",{className:"tm-flex tm-shrink-0 tm-items-center tm-gap-2","data-prevent-bulk-select":!0,children:[G?t.jsx("div",{className:"tm-flex tm-items-center tm-pt-0.5 tm-pr-2",children:t.jsx(f.Checkbox,{id:`kanban-bulk-select-${e}-${L}`,size:"sm",checked:k,disabled:F,onChange:_})}):null,t.jsx(jo,{id:e,nameRequiredTask:m,status:p,statusRequiredTask:x,projectID:b,atrasoId:v==null?void 0:v.atrasoId,categoria:O,disabled:R})]})]}),Z=te=>{B(fe=>te==="minus"?Math.max(0,fe-1):Math.min(h,fe+1))},ae=te=>{var fe;return((fe=te==null?void 0:te.charAt(0))==null?void 0:fe.toUpperCase())??""},ie=te=>te==="Venta"?"accent":"danger",J=T||!!(G!=null&&G.isBulkLoading),se=C?"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 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 ${se} ${k?"tm-border-blue-500 tm-bg-primary-light":"tm-border-transparent tm-bg-surface-default"} ${J?"tm-pointer-events-none":""}`,children:[t.jsx(Q,{}),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(f.Text,{type:"body",size:"sm",weight:"medium",children:w})]}),H&&t.jsx(f.Badge,{label:H.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(Ga,{responsible:c,role:S==null?void 0:S.role,status:p,users:s.filter(te=>c?te.id===c:!0).map(te=>qt(te,D())),onClick:async(te,fe)=>{await I({idNewResponsible:te,id:e,typeOfSelect:fe})}}),o&&t.jsx(Ya,{idTask:e,paused:j,popupId:`task-pause-menu-${e}`,children:te=>t.jsx("button",{ref:te,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(f.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-8",children:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[t.jsx(f.Badge,{label:ae((O==null?void 0:O.tipo)??"P"),color:ie((O==null?void 0:O.tipo)??"Preventa"),size:"sm",theme:"solid"}),v&&t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faTriangleExclamation,size:"sm",color:"warning"}),children:t.jsx(f.Text,{color:"warning",children:`Tarea atrasada debido a: ${v==null?void 0:v.motivo}`})}),t.jsx(Ut,{difficulty:d,id:e,canEdit:K}),t.jsx(Ht,{priority:l,id:e,canEdit:K}),!h||h&&p===0&&t.jsxs(t.Fragment,{children:[t.jsx(f.Icon,{name:ne.faCalendar,size:"xs",color:"primary"}),t.jsx(f.Text,{color:"primary",children:`${n.getDate()} ${Rt(n.getMonth()).slice(0,3)}`})]})]}),p===1&&h&&h>0&&t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-m",children:[t.jsx(f.Text,{color:"primary",children:"unidades"}),t.jsx("button",{onClick:()=>Z("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:t.jsx(f.Icon,{name:ne.faCircleMinus,size:"xs",color:"primary"})}),t.jsx(f.Text,{color:"primary",children:`${q??0} / ${h??0}`}),t.jsx("button",{onClick:()=>Z("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:t.jsx(f.Icon,{name:ne.faCirclePlus,size:"xs",color:"primary"})}),t.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:()=>{V({repeats:q,id:e})},children:"Agregar Unidad"})]})]})]}),r>0&&t.jsx("div",{className:"tm-mt-4 tm-border-t tm-border-default tm-pt-2",children:t.jsxs("button",{type:"button","data-prevent-bulk-select":!0,onClick:te=>{te.stopPropagation(),U(!0)},className:"tm-flex tm-items-center tm-gap-8",children:[t.jsx(f.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(Qa,{taskId:e,isOpen:X,setIsOpen:U})]})},ft=({title:e,tasks:a,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,O=j/(v-b)*100;O<=95||O>=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"},g=zt(),x=e,p=!!(g!=null&&g.baseColumn&&g.baseColumn!==e),h=!!g&&e!=="Completadas"&&(g==null?void 0:g.isBulkSessionActive)&&g.baseColumn===e&&typeof i=="function",y=()=>{if(!(!g||!i)){if(g.isFullColumnSelected){g.deselectAllSelectedTasks();return}g.selectEntireColumn(x,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-canvas tm-p-[16px] ${m[e]} ${p?"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}),h&&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:g==null?void 0:g.isBulkLoading,onClick:y,children:g!=null&&g.isBulkLoading?"Cargando…":g!=null&&g.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(f.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: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:[a==null?void 0:a.map(w=>t.jsx(Mo,{...w,boardColumnTitle:g?x:void 0,isBulkColumnLocked:!!(g&&p)},w.id)),s?t.jsx(ao,{}):t.jsx("p",{className:"tm-text-center tm-text-sm tm-text-light-gray-900",children:"No hay más tareas por mostrar..."})]})]})},xa=[{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"}]}],ko=()=>{const{user:e}=je(),[a,n]=u.useState([...xa]),s=[{roles:["Project Manager","Manager","Operation Manager"],id:"owner.config",filters:[{id:"todas",name:"Todas las tareas"}]}];return u.useEffect(()=>{const o=[...xa];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(a),r=JSON.stringify(o);i!==r&&n(o)},[e.role]),{filters:a}},Oo="/api/tareas/bulk-update-status";async function Lo(e,a){const{data:n}=await e.post(Oo,a);return n}function Bo(e){var a,n,s,o;if(tt.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 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 Ro(){const{tasks_api:e}=pe(),{user:a}=je();return le.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 Lo(e,{...n,user_id:s})}catch(o){throw new Error(Bo(o))}}})}const wt={MOVE_TO_TRABAJANDO:"kanban-bulk-move-trabajando",MOVE_TO_POR_HACER:"kanban-bulk-move-por-hacer",MOVE_TO_COMPLETADAS:"kanban-bulk-move-completadas"};function qo(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 vt="secondary";function zo(e){const a=qo({setActiveButtonId:e.setActiveButtonId,setPendingTargetStatus:e.setPendingTargetStatus,onConfirmBulkMove:e.onConfirmBulkMove,isBulkLoading:e.isBulkLoading});return e.baseColumn==="Por hacer"?[{id:wt.MOVE_TO_TRABAJANDO,label:"Mover a trabajando",icon:ne.faArrowRight,color:vt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(1)},addons:a}]:e.baseColumn==="Trabajando"?[{id:wt.MOVE_TO_POR_HACER,label:"Mover a por hacer",icon:ne.faArrowLeft,color:vt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(0)},addons:a},{id:wt.MOVE_TO_COMPLETADAS,label:"Mover a completadas",icon:ne.faArrowRight,color:vt,disabled:e.isBulkLoading,onClick:()=>{e.isBulkLoading||e.setPendingTargetStatus(2)},addons:a}]:[]}const $o="Seleccionados";function Ja(){const e=zt(),[a,n]=u.useState(null),s=a!==null,o=le.useQueryClient(),{mutate:i}=Ro(),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 g=e.pendingTargetStatus,x=e.selectedTaskIds;if(g==null||x.length===0)return;const p={tasks_ids:[...x],estatus:g,...g===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?zo({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:t.jsx(f.Toolbar,{visible:!0,count:r,text:$o,activeButtonId:a,onActiveButtonIdChange:n,onBackClick:l,buttons:m,onClose:d,showCounterInButtonsView:!s,showBackButton:!s,showCloseButton:!s})}const Za=["to_do_tasks","working_tasks","done_tasks"],Uo="tasksProject";function Ho(e){return Promise.all(Za.map(a=>e.invalidateQueries({queryKey:[a]}))).then(()=>{})}function Ko(e){return Promise.all(Za.flatMap(a=>[e.invalidateQueries({queryKey:[a]}),e.refetchQueries({queryKey:[a]})])).then(()=>{})}function Vo(e){return e.invalidateQueries({queryKey:[Uo]}).then(()=>{})}function Go(e){const a=!!(e.repeatsToDo&&e.repeats===e.repeatsToDo),n=!e.repeatsToDo||e.repeatsToDo===1,s=e.status===0;return a||n||s}function Wo(e,a){return(e??"")!==""&&(a??0)===2||!(e??"")}function es(e){return e.status===2||!Go(e)?!1:Wo(e.nameRequiredTask,e.statusRequiredTask)}const Qo=["Por hacer","Trabajando","Completadas"],Xo=()=>{const{defineFields:e}=Me(),{tasksProject:a}=at(),{filters:n}=ko();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(Ha,{invalidateAfterBulkSuccess:Vo,children:[t.jsx(Ja,{}),t.jsx("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-gap-8",children:Qo.map((o,i)=>{const r=(s==null?void 0:s[i])??[];return t.jsx(ft,{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(l=>es({status:l.status,nameRequiredTask:l.nameRequiredTask,statusRequiredTask:l.statusRequiredTask,repeatsToDo:l.repeatsToDo,repeats:l.repeats})).map(l=>l.id))},o)})})]})};async function ts(e){const a=[];let n=1;for(;;){const s=await pt({filters:{...e.filters,status:e.status,...Ge(n)},tasks_api:e.tasks_api});for(const o of s)es({status:o.status,nameRequiredTask:o.nameRequiredTask,statusRequiredTask:o.statusRequiredTask,repeatsToDo:o.repeatsToDo,repeats:o.repeats})&&a.push(o.id);if(s.length<Kt)break;n+=1}return a}const Yo=()=>{var i,r;const{tasks_api:e}=pe(),{toDoTasks:a,total:n,filtersToSend:s}=Xa(),o=[...((r=(i=a==null?void 0:a.data)==null?void 0:i.pages)==null?void 0:r.flat())??[]];return t.jsx(ft,{total:n,title:"Por hacer",tasks:o,loadNextPage:()=>Vt(a),isFetching:a==null?void 0:a.isFetching,isLoadingData:a==null?void 0:a.isLoading,bulkSelectAllIds:()=>ts({tasks_api:e,filters:s,status:"por_hacer"})})},Jo=()=>{var c;const e=le.useQueryClient(),{tasks_api:a}=pe(),{user:n}=je(),{filters:s}=Me(),[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=le.useInfiniteQuery({initialPageParam:1,queryKey:["working_tasks",r],queryFn:({pageParam:m})=>pt({filters:{...r,status:"trabajando",...Ge(m)},tasks_api:a}),staleTime:1e3*60*60*24,getNextPageParam:(m,g)=>g.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 g=await a.get("/api/listado_tareas",{params:{...r,status:"trabajando",cancelada:!1,...Ge(1),tasks_api:a,justCount:!0}});i(g.data.total)})()},[r,d==null?void 0:d.data]),{workingTasks:d,total:o,filtersToSend:r}},Zo=()=>{var i,r;const{tasks_api:e}=pe(),{workingTasks:a,total:n,filtersToSend:s}=Jo(),o=[...((r=(i=a==null?void 0:a.data)==null?void 0:i.pages)==null?void 0:r.flat())??[]];return t.jsx(ft,{total:n,title:"Trabajando",tasks:o,loadNextPage:()=>Vt(a),isFetching:a==null?void 0:a.isFetching,bulkSelectAllIds:()=>ts({tasks_api:e,filters:s,status:"trabajando"})})},er=()=>{var c;const e=le.useQueryClient(),{user:a}=je(),{tasks_api:n}=pe(),{filters:s}=Me(),[o,i]=u.useState(0),[r,l]=u.useState({owner:{user:a.id,config:((c=s==null?void 0:s.owner)==null?void 0:c.config)??"yo_y_mis_equipos",role:a.role},status:"completadas"}),d=le.useInfiniteQuery({initialPageParam:1,queryKey:["done_tasks",r],queryFn:({pageParam:m})=>pt({filters:{...r,status:"completadas",...Ge(m)},tasks_api:n}),staleTime:1e3*60*60*24,getNextPageParam:(m,g)=>g.length+1});return u.useEffect(()=>{var m;Object.keys(s).length>0&&l({...s,owner:{user:a.id,config:((m=s==null?void 0:s.owner)==null?void 0:m.config)??"yo_y_mis_equipos",role:a.role},status:"completadas"})},[s]),u.useEffect(()=>{e.invalidateQueries({queryKey:["done_tasks",r]})},[r]),u.useEffect(()=>{(async()=>{const g=await n.get("/api/listado_tareas",{params:{...r,status:"completadas",cancelada:!1,...Ge(1),justCount:!0,tasks_api:n}});i(g.data.total)})()},[d==null?void 0:d.data,r]),{doneTasks:d,total:o,filtersToSend:r}},tr=()=>{var s,o;const{doneTasks:e,total:a}=er(),n=[...((o=(s=e==null?void 0:e.data)==null?void 0:s.pages)==null?void 0:o.flat())??[]];return t.jsx(ft,{title:"Completadas",tasks:n,loadNextPage:()=>Vt(e),isFetching:e==null?void 0:e.isFetching,total:a})};class dt{static toSalesmanUsers(a){return{id:a.id,name:a.nombre}}}const ar=()=>{const{tasks_api:e}=pe(),{filters:a}=Me(),{user:n}=je(),s=async()=>(await e.get("/api/obtener-comerciales")).data.map(dt.toSalesmanUsers),o=async()=>{var l;return(await e.get("/api/listado_tareas",{params:{...Zt(a),owner:{user:n.id,config:((l=a==null?void 0:a.owner)==null?void 0:l.config)??"yo_y_mis_equipos",role:n.role},justProjects:!0,cancelada:!1}})).data.map(dt.toSalesmanUsers)};return{getSalesmanAndProjects:u.useCallback(async(r={})=>{var p;const l={...a,...r},d=(r==null?void 0:r["owner.config"])??((p=a==null?void 0:a.owner)==null?void 0:p.config)??"yo_y_mis_equipos",c={...l};delete c["owner.config"];const m=Zt(c),[g,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:g.data.map(dt.toSalesmanUsers),projects:x.data.map(dt.toSalesmanUsers)}},[e,a,n==null?void 0:n.id,n==null?void 0:n.role]),getProjects:o,getSalesmans:s}},sr=()=>{const{user:e}=je(),[a,n]=u.useState([...ta]),s=[{roles:["Project Manager","Manager","Operation Manager"],id:"owner.config",filters:[{id:"todas",name:"Todas las tareas"}]}];return u.useEffect(()=>{const o=[...ta];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(a),r=JSON.stringify(o);i!==r&&n(o)},[e.role]),{filters:a}},nr=()=>{const{defineFields:e,initialFilters:a}=Me(),{getSalesmanAndProjects:n}=ar(),{filters:s}=sr(),o=(a==null?void 0:a["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]),t.jsxs(Ha,{invalidateAfterBulkSuccess:Ho,children:[t.jsx(Ja,{}),t.jsxs("div",{className:"tm-relative tm-flex tm-h-full tm-min-h-[100%] tm-w-full tm-gap-8",children:[t.jsx(Yo,{}),t.jsx(Zo,{}),t.jsx(tr,{})]})]})},as=u.createContext({}),or=({children:e})=>{const[a,n]=u.useState([]),s=o=>{n(i=>i.includes(o)?i.filter(r=>r!==o):[...i,o])};return t.jsx(as.Provider,{value:{selectedTasks:a,selectTask:s},children:e})},rr=()=>u.useContext(as),ir=()=>{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,{})})]})]})},ss=({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-surface-default tm-px-xl",children:[t.jsx(f.Icon,{name:ne.faCalendar,size:"xs",color:"current"}),t.jsxs(f.Text,{children:[" ",da(e)]})]}),t.jsx(f.Icon,{name:ne.faArrowRight,size:"xs",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-surface-default tm-px-xxxl",children:[t.jsx(f.Icon,{name:ne.faCalendar,size:"xs",color:"current"}),t.jsxs(f.Text,{children:[" ",da(a)]})]})]}),ns=({id:e,priority:a,difficulty:n,endDate:s,atraso:o,role:i,status:r})=>{const[l,d]=u.useState(!1),c=ut(i,r),m={0:{title:"N/A",color:Ce.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:Ce.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:Ce.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:Ce.danger.regular,bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-regular",borderHover:"hover:tm-border-danger-dark"}},g={1:{title:"Muy fácil",color:Ce.success.dark,iconColor:"brand",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:Ce.success.regular,iconColor:"success",bg:"tm-bg-success-medium tm-border-success-pastel",border:"tm-border-success-medium",borderHover:"hover:tm-border-success-dark"},3:{title:"Media",color:Ce.warning.regular,iconColor:"warning",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:Ce.danger.regular,iconColor:"danger",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:Ce.danger.dark,iconColor:"danger",bg:"tm-bg-danger-light tm-border-danger-regular",border:"tm-border-danger-medium",borderHover:"hover:tm-border-danger-dark"}},x=()=>{if(n==null||Number.isNaN(Number(n)))return 1;const j=Math.trunc(Number(n));return j===0?1:j>=1&&j<=5?j:1},p=()=>{if(a==null||Number.isNaN(Number(a)))return 0;const j=Math.trunc(Number(a));return j>=0&&j<=3?j:0},h=g[x()]??g[1],y=m[p()]??m[0],w=s instanceof Date&&!Number.isNaN(s.getTime())?`${s.getDate()} ${Rt(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-surface-default hover:tm-bg-surface-hover",children:t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faAlignCenter,size:"xs",color:"current"}),children:t.jsx("div",{className:"tm-px-8 tm-py-4",children:t.jsx(f.Text,{children:"Espéralo muy pronto..."})})})}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-8",children:[t.jsx("div",{className:`tm-gap-s ${h.border} ${h.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:t.jsx(Ut,{difficulty:n,id:e,canEdit:c})}),t.jsx("div",{className:`tm-gap-s ${y.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:t.jsx(Ht,{priority:p(),id:e,canEdit:c})}),(o==null?void 0:o.activa)&&t.jsx("div",{onMouseEnter:()=>d(!0),onMouseLeave:()=>d(!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:t.jsx(Fe,{trigger:t.jsx(f.Icon,{name:ne.faTriangleExclamation,size:"xs",color:l?"warning":"primary"}),children:t.jsx("div",{className:"tm-px-8 tm-py-4",children:t.jsx(f.Text,{children:o==null?void 0:o.motivo})})})}),t.jsx(f.Icon,{name:ne.faCalendar,size:"xs",color:"current"}),t.jsx(f.Text,{children:w})]})]})},lr=({id:e})=>{const{selectedTasks:a,selectTask:n}=rr();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-default",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(f.Icon,{name:ne.faCheck,size:"xs",style:{color:Ce.primary.regular},color:"current"})})}),t.jsx("input",{className:"tm-hidden",id:e.toString(),type:"checkbox",onChange:()=>n(e)})]})},os=({task:e})=>t.jsx(Fe,{trigger:t.jsx(f.Text,{children:e}),children:t.jsx("div",{className:"tm-py-2 tm-px-4",children:t.jsx(f.Text,{children:e})})}),cr=({id:e})=>{var m,g,x;const[a,n]=u.useState(!1),{tasksProject:s}=at(),{reasignResponsible:o}=He(),{getOBPUrlApi:i}=pe(),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 t.jsxs(t.Fragment,{children:[t.jsx("div",{className:"tm-border-b tm-border-default 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-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&&t.jsx(lr,{id:e}),t.jsx(Wa,{id:e,idAtraso:(g=r==null?void 0:r.atraso)==null?void 0:g.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(Ya,{idTask:r.id,paused:r.paused,popupId:`child-task-pause-menu-${r.id}`,children:p=>t.jsx(f.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"})}),t.jsx(Ga,{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=>qt(p,i())))??[]}),t.jsx(os,{task:(r==null?void 0:r.task)??""}),t.jsx(ns,{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,role:c==null?void 0:c.role,status:(r==null?void 0:r.status)??-1}),t.jsx(ss,{startDate:r==null?void 0:r.startDate,endDate:r==null?void 0:r.endDate})]})}),t.jsx(Qa,{taskId:e,isOpen:a,setIsOpen:n})]})},rs=({id:e})=>{var d,c,m,g,x,p;const{user:a}=je(),{tasksProject:n,openTasks:s,openTask:o}=at(),i=(d=n==null?void 0:n.data)==null?void 0:d.find(h=>h.id===e),l=(()=>{var w;const h=n==null?void 0:n.data,y=[];return(w=i==null?void 0:i.tasks)==null||w.forEach(j=>{const b=h.find(v=>v.id===(j==null?void 0:j.id));b&&y.push(b)}),y})();return i?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-surface-hover",onClick:()=>o(e),children:[t.jsx("button",{type:"button",className:`${s.includes(e)?"":"tm--rotate-90"} tm-transition-all tm-duration-300`,children:t.jsx(f.Icon,{name:ne.faChevronDown,size:"sm",style:{color:Ce.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-surface-default",children:t.jsx("p",{className:"tm-text-primary tm-text-md",children:((c=i==null?void 0:i.tasks)==null?void 0:c.length)===0?1:l.length})}),t.jsx(os,{task:(i==null?void 0:i.task)??""}),t.jsx(ns,{id:e,priority:i==null?void 0:i.priority,difficulty:i==null?void 0:i.difficulty,endDate:i==null?void 0:i.endDate,atraso:i==null?void 0:i.atraso,role:a==null?void 0:a.role,status:(i==null?void 0:i.status)??-1}),t.jsx(ss,{startDate:i==null?void 0:i.startDate,endDate:i==null?void 0:i.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-surface-default tm-px-m hover:tm-bg-surface-hover",children:[t.jsx(f.Icon,{name:ne.faDiagramSubtask,size:"sm",color:"current"}),t.jsx(f.Text,{children:((m=i==null?void 0:i.tasks)==null?void 0:m.length)===0?1:(g=i==null?void 0:i.tasks)==null?void 0:g.length})]})]}),s.includes(e)&&t.jsx("div",{className:"tm-ml-[30px]",children:((x=i==null?void 0:i.tasks)==null?void 0:x.length)>0?(p=i==null?void 0:i.tasks)==null?void 0:p.map(h=>t.jsx(rs,{id:h==null?void 0:h.id})):t.jsx(cr,{id:i==null?void 0:i.id})})]}):null},dr=()=>{var s;const{tasksProject:e,projectID:a}=at();if(e!=null&&e.isFetching||e!=null&&e.isLoading)return t.jsx(ir,{});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(or,{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-default tm-pb-m ",children:t.jsx(rs,{id:o.id})}))})})};function mr({title:e,color:a,icon:n}){return t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[t.jsx(f.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 ur({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(f.Input,{size:"xs",placeholder:"Creative",value:e,onChange:n=>a(n.target.value)})]})}const is=({title:e})=>t.jsxs("div",{className:"flex-1 tm-flex tm-items-center tm-gap-x-8",children:[t.jsx(f.Icon,{background:!0,name:ne.faFilePen,color:"blue",size:"lg"}),t.jsx(f.Text,{size:"xl",weight:"bold",children:e})]}),Xe={search:"",debouncedSearch:"",filters:[]},pr={"kanban-general":{...Xe},"lista-campanias":{...Xe},"kanban-campania":{...Xe},"teams-container":{...Xe},"templates-container":{...Xe}},gt=We.create((e,a)=>({viewFilters:pr,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(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||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]:{...Xe}},debounceTimeouts:{...i.debounceTimeouts,[s]:void 0}}))}}));function ls({path:e}){const{getSearch:a,setSearch:n}=gt(),s=a(e);return t.jsx(f.Input,{leftSlot:ne.faSearch,placeholder:"Buscar...",size:"xs",value:s,onChange:o=>n(o.target.value,e)})}const ba={fase_plantilla:"",tipo_plantilla:"",modo_configuracion:"",categoria:"",formato_salida:"",tipo_medio:"",medio_especifico:"",responsable_impresion:"",pertenencia_medio:"",ubicacion_medio:""},fr={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},gr={fase_plantilla:"",tipo_plantilla:"",categoria:"",tipo_medio:"",medio_especifico:"",modo_configuracion:"",responsable_impresion:"",pertenencia_medio:"",ubicacion_medio:""},ya={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},ke=We.create(e=>({path:"",viewMode:"grid",isOpenModalLimit:!1,template:null,clave:"XX-XXX-XX-XXX-XX-X-X",templateFormData:ba,disabledFields:ya,claveParams:gr,paramsTipo:fr,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:ba}),setDisableField:({fields:a,value:n})=>{for(const s of a)e(o=>({disabledFields:{...o.disabledFields,[s]:n}}))},resetDisabledFields:()=>e({disabledFields:ya}),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})})),cs=e=>{const{getSearch:a,getDebouncedSearch:n,setSearch:s,getFilters:o,setFilters:i,resetPathData:r}=gt();return{search:a(e),debouncedSearch:n(e),filters:o(e),setSearch:l=>s(l,e),setFilters:l=>i(l,e),resetData:()=>r(e)}},hr=()=>t.jsx(is,{title:"Flujos de trabajo"}),qe=We.create(e=>({activeTemplate:null,setActiveTemplate:a=>e({activeTemplate:a}),clearActiveTemplate:()=>e({activeTemplate:null})})),ve=We.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})},flowViewportByTemplateId:{},setFlowViewportForTemplate:(n,s)=>{const{flowViewportByTemplateId:o}=a();e({flowViewportByTemplateId:{...o,[n]:{x:s.x,y:s.y,zoom:s.zoom}}})},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})),ds=()=>{const{tasks_api:e}=pe();return{getTemplateWithTasks:async n=>{var s;try{const o=Ee.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}}}},_e={DIRTY:"dirty",IDLE:"idle",NEW:"new"},Ae={DRAFT:"draft",PUBLISHED:"published",DELETED:"deleted"},Ye="templates",Je="templates_states";function xr(e,a){return We.create((n,s)=>{let o=null;const i=g=>n({isLoading:g}),r=g=>n({error:g}),l=g=>n({data:g}),d=()=>new Promise((g,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}),g(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=(g="readonly")=>{if(!o)throw new Error("Base de datos no conectada");return o.transaction(a,g)},m=(g="readonly")=>c(g).objectStore(a);return{data:[],isLoading:!1,error:null,isConnected:!1,connect:async()=>{try{i(!0),r(null),await d(),await s().getAll()}catch(g){r(g instanceof Error?g.message:"Error desconocido")}finally{i(!1)}},disconnect:()=>{o&&(o.close(),o=null,n({isConnected:!1,data:[]}))},add:async g=>{try{i(!0),r(null);const x=m("readwrite");return new Promise((p,h)=>{const y=x.add(g);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 g=>{try{i(!0),r(null);const x=m("readwrite");return new Promise((p,h)=>{let y=0,w=!1;g.forEach(j=>{const b=x.add(j);b.onsuccess=()=>{y++,y===g.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 g=>{try{r(null);const x=m();return new Promise((p,h)=>{const y=x.get(g);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 g=m();return new Promise((x,p)=>{const h=g.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(g){return r(g instanceof Error?g.message:"Error desconocido"),[]}},update:async(g,x)=>{try{i(!0),r(null);const p=m("readwrite");return new Promise((h,y)=>{const w=p.get(g);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 g=>{try{i(!0),r(null);const x=m("readwrite");return new Promise((p,h)=>{const y=x.delete(g);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 g=m("readwrite");return new Promise((x,p)=>{const h=g.clear();h.onsuccess=()=>{l([]),x()},h.onerror=()=>{r("Error al limpiar store"),p(new Error("Error al limpiar store"))}})}finally{i(!1)}},query:async(g,x)=>{try{r(null);const h=m().index(g);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(g,x,p)=>{try{r(null);const y=m().index(g);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 _t=new Map;function ja(e,a,n=!0){const s=u.useMemo(()=>{const v=`${e.name}-${a}`;if(!_t.has(v)){const O=xr(e,a);_t.set(v,O)}return _t.get(v)},[e.name,a]);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]),g=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,O)=>s.getState().update(v,O),[s]),y=u.useCallback(v=>s.getState().delete(v),[s]),w=u.useCallback(()=>s.getState().clear(),[s]),j=u.useCallback((v,O)=>s.getState().query(v,O),[s]),b=u.useCallback((v,O,H)=>s.getState().queryRange(v,O,H),[s]);return{data:o,isLoading:i,error:r,isConnected:l,connect:d,disconnect:c,add:m,addMany:g,get:x,getAll:p,update:h,delete:y,clear:w,query:j,queryRange:b}}const ms=u.createContext(void 0);function br({children:e}){const[a,n]=u.useState(!1),[s,o]=u.useState(!0),[i,r]=u.useState(null),l={name:"template_tabs_v1",version:2,stores:[{name:Ye,keyPath:"id",autoIncrement:!1,indexes:[{name:"id",keyPath:"id",options:{unique:!0}}]},{name:Je,keyPath:"id",autoIncrement:!1,indexes:[{name:"id",keyPath:"id",options:{unique:!0}}]}]},d=ja(l,Ye,!0),c=ja(l,Je,!0),m=u.useRef(new Map);m.current.has(Ye)||m.current.set(Ye,d),m.current.has(Je)||m.current.set(Je,c);const g=d.isConnected,x=d.error;u.useEffect(()=>{m.current.set(Ye,d),m.current.set(Je,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(),g)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,g]),u.useEffect(()=>{x&&r(x)},[x]);const h={isInitialized:a,isInitializing:s,error:i,isConnected:g,getStore:p};return t.jsx(ms.Provider,{value:h,children:e})}function us(){const e=u.useContext(ms);if(e===void 0)throw new Error("useIndexedDBContext debe usarse dentro de IndexedDBProvider");return e}function Gt(){const{getStore:e}=us();return e(Ye)}function ps(){const{add:e}=Gt(),a=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(g=>{d(g)})})};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(g=>{if(g.type==="group")return{...g,data:{...g.data,type:"template"},type:"group",selected:!1};const x=g.data.tareaId?l[g.data.tareaId]:r;return x!=null&&x.start?{...g,data:{...x.plantilla,id:x.id},selected:!1}:{...g,data:{...x,type:"task"},selected:!1}})},initializeTemplateStore:a,indexedTasks:n,getTaskHierarchy:s,getTaskPath:o}}function fs(){const{getStore:e}=us();return e(Je)}const it=()=>{const{add:e,get:a,delete:n,update:s}=fs(),{get:o}=Gt(),i={created:[],updated:[],deleted:[]},r=async({templateId:p})=>{const h=await a(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 ze(){const{activeTemplate:e,setActiveTemplate:a}=qe(),{mode:n,setMode:s,setViewMode:o,clearViewMode:i}=ve(),{template:r,setIsOpenModalLimit:l,setOpenModalUnsavedChanges:d,setOpenModalPublishTemplate:c,setOpenModalDeleteTemplate:m}=ke(),{hydrateTasks:g}=ps(),{addTaskToState:x,removeTemplateStates:p}=it(),h=le.useQueryClient(),{data:y,add:w,update:j,get:b,getAll:v,delete:O,isLoading:H,error:M}=Gt(),{get:N}=fs(),{getTemplateWithTasks:A}=ds(),{tasks_api:T}=pe(),[X,U]=u.useState(!1),[L,I]=u.useState(!1),[V,D]=u.useState(!1),q=u.useMemo(()=>y.sort((C,R)=>C.order-R.order),[y]);u.useEffect(()=>{q.length===0&&n!=="grid"&&s("grid")},[q,n,s]);const B=async(E,C=_e.IDLE)=>{var R;try{const F=await A(E.id),_=await g(F),Q={id:crypto.randomUUID(),data:F,type:"start",dragging:!1,measured:{width:171,height:48},position:{x:91,y:-24.5},selected:!1,deletable:!1},Z=_||[Q],ae={...F,graph_layout:{...F==null?void 0:F.graph_layout,snapshot:{...(R=F==null?void 0:F.graph_layout)==null?void 0:R.snapshot,nodes:Z}},estatus:C,estatusFromStrapi:F.estatus};await w(ae)}catch(F){console.warn("No se pudieron obtener los datos completos de la plantilla, creando versión básica:",F);const _=E,Q={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:[Q],edges:[],viewport:{x:0,y:0,zoom:1}},history:null,zoom:1,position:{x:0,y:0}},ae={..._,graph_layout:_.graph_layout||Z,estatus:C,tarea_plantillas:_.tarea_plantillas||[]};await w(ae)}},$=async({template:E,checkTemplateInIndexedDB:C=!1,statusTemplate:R=_e.IDLE})=>{const F=q;if(!F.find(Q=>Q.id===E.id)){if(F.length===5){l(!0);return}if(C&&await b(E.id))return;await B({...E,order:F.length+1},R)}await z(E.id),await Y(E),s("create-edit",E==null?void 0:E.id)},Y=async E=>{const C=await b(E.id);a(C)},z=async E=>{try{let C=await v();C.sort((F,_)=>(F.order||0)-(_.order||0));const R=C.findIndex(F=>F.id===E);if(R!==-1){const[F]=C.splice(R,1);C.unshift(F),C.forEach((Q,Z)=>{Q.order=Z+1});const _=C.map(Q=>j(Q.id,Q));await Promise.all(_)}else return}catch{}},re=async E=>{try{await O(E),i(E);const C=await v();C.forEach((F,_)=>{F.order=_+1});const R=C.map(F=>j(F.id,F));await Promise.all(R)}catch{}};return{screens:q,isLoading:H,error:M,add:w,data:y,addScreen:B,openTemplate:$,update:j,delete:re,get:b,activeTemplate:e,activateTemplate:Y,reorderingTemplates:z,replaceTemplate:async()=>{try{const E=[...q],C={...E[E.length-1]};await O(C.id);const R={...r,order:C.order};await B(R);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(E,C,R="hija")=>{var Z,ae,ie,J;const F=await b(C);if(!F)return null;const _={id:E.id,uuid:crypto.randomUUID(),reference_graph:E.reference_graph,texto_corto:E.title,texto_largo:E.description||"",prioridad:E.priority||null,nivel_dificultad:E.difficulty||1,duracion:E.duration||null,start:!1,type:"task",equipo:{id:Number(E.team)||null},responsable:{id:Number(E.responsible)||null},plantilla:{id:F.id,clave:F.clave,categoria:F.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:[],id_t_requerida:R==="dependiente"?(ae=(Z=E.parent)==null?void 0:Z.data)==null?void 0:ae.id:null,ids_t_dependientes:[],tarea_padre:R==="hija"?(J=(ie=E.parent)==null?void 0:ie.data)==null?void 0:J.id:null,tareas:[]},Q={...F,estatus:_e.DIRTY};return await j(C,Q),e&&e.id===C&&a(Q),await x({task:_}),_},addTemplateUpdatingTemplate:async(E,C,R,F="hija")=>{let _=null;if(e&&e.id===C?_=e:_=await b(C),!_)return null;const Q=(ae,ie,J,se)=>{for(let te=0;te<ae.length;te++){const fe=ae[te];if(fe.id===ie||fe.uuid===ie)return se==="dependiente"?(fe.plantilla_dependents||(fe.plantilla_dependents=[]),fe.plantilla_dependents.push(J)):se==="hija"&&(fe.plantilla_dependents||(fe.plantilla_dependents=[]),fe.plantilla_dependents.push(J)),!0;if(fe.tareas&&fe.tareas.length>0){const ce=Q(fe.tareas,ie,J,se);if(ce)return ce}}return!1};if(Q(_.tarea_plantillas,R,E,F)){const ae={..._,estatus:_e.DIRTY,updatedAt:new Date().toISOString()};return await j(C,ae),e&&e.id===C&&a(ae),!0}else return!1},updateGraphLayout:async(E,C)=>{var R;if(!E){console.warn("⚠️ updateGraphLayout - Template ID no válido");return}try{const F=await b(E);if(!F){console.warn("⚠️ updateGraphLayout - Template no encontrado");return}const _=(C.nodes||[]).filter(se=>{var te;return!((te=se.data)!=null&&te.isInternal)&&!se.parentId}).map(se=>{const{style:te,measured:fe,data:ce,...xe}=se,{expandedDimensions:we,isExpanded:ye,needsReExpansion:Oe,...Ne}=ce||{},$e=te?{...te,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...xe,style:$e,data:Ne,position:se.position}}),Q=(C.edges||[]).filter(se=>{var te;return!((te=se.data)!=null&&te.isInternal)}).map(se=>{var te;if((te=se.data)!=null&&te.redirectedToInternal){const{redirectedToInternal:fe,originalTarget:ce,...xe}=se.data;return{...se,target:ce||se.target,data:xe}}return se}),Z={...C,nodes:_,edges:Q},ae=(R=F.graph_layout)==null?void 0:R.snapshot;if(!(!ae||JSON.stringify(ae)!==JSON.stringify(Z)))return;const J={...F,graph_layout:{...F.graph_layout,snapshot:Z},estatus:_e.DIRTY,updatedAt:new Date().toISOString()};await j(E,J),e&&e.id===E&&a(J)}catch(F){console.error("❌ updateGraphLayout - Error:",F)}},saveTemplateChanges:async(E=!0)=>{try{if(e.estatus===_e.DIRTY){I(!0);const{id:C}=e,R=await b(C),F=await N(C),_=R.graph_layout.snapshot.nodes||[],Q=_.filter(J=>{var se;return!((se=J.data)!=null&&se.isInternal)&&!J.parentId}),Z=_.length-Q.length;Z>0&&console.warn(`💾 [saveTemplateChanges] Se filtraron ${Z} nodos internos al guardar plantilla ${C}`);const ae={graph_layout:{...R.graph_layout,snapshot:{...R.graph_layout.snapshot,nodes:Q.map(J=>{const{style:se,measured:te,selected:fe,...ce}=J,xe=se?{...se,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return J.type==="group"?{...ce,style:xe,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}}:{...ce,style:xe,data:{tareaId:J.data.id&&J.data.id>0?J.data.id:null}}}),edges:(R.graph_layout.snapshot.edges||[]).filter(J=>{var se;return!((se=J.data)!=null&&se.isInternal)})}},tasks:{created:(F==null?void 0:F.created)||[],updated:(F==null?void 0:F.updated)||[],deleted:(F==null?void 0:F.deleted)||[]}},ie=await T.post("/api/tareas/save-tareas-grafico",{data:ae});if(ie.data&&ie.status===200){try{const J=await A(C),se=await g(J),te={...J,graph_layout:{...J.graph_layout,snapshot:{...J.graph_layout.snapshot,nodes:se}},estatus:_e.IDLE};await j(C,te),E||a(te)}catch{const se=await b(C);if(se&&!E){const te={...se,estatus:_e.IDLE};await j(C,te),a(te)}}await h.invalidateQueries({queryKey:["template",C]}),await h.invalidateQueries({queryKey:["template"]}),p(C),E&&(re(C),d(!1)),o(C,"readonly")}}}catch(C){console.log(C)}finally{I(!1)}},publishTemplate:async E=>{try{U(!0);const C={estatus:Ae.PUBLISHED,publication_date:new Date},R=await T.put(`/api/plantillas/plantilla-update-estatus/${E}`,{data:C});R.data&&R.status===200&&(a({...e,estatusFromStrapi:Ae.PUBLISHED}),c(!1),f.toast.info("Se publicó correctamente el proceso"))}catch(C){console.log(C),f.toast.error("Surgió un error al publicar el proceso")}finally{U(!1)}},deleteTemplate:async E=>{try{D(!0);const C={estatus:Ae.DELETED,sjdaksd:0},R=await T.put(`/api/plantillas/plantilla-update-estatus/${E}`,{data:C});R.data&&R.status===200&&(m(!1),f.toast.info("Se eliminó correctamente el proceso"))}catch(C){console.error(C),f.toast.error("Surgión un error al eliminar el proceso")}finally{D(!1)}},loadingPublishTemplate:X,loadingSaveChanges:L,loadingDeleteTemplate:V}}const yr=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}`}},jr=()=>{const{tasks_api:e}=pe();return{users:le.useQuery({queryKey:["usersOBP"],queryFn:()=>yr({tasks_api:e}),staleTime:1e3*60*60*24})}},st=()=>{const{users:e}=jr(),a=le.useQuery({queryKey:["users_index",e.data],queryFn:()=>mo({users:e.data||[]}),staleTime:1e3*60*60*24,enabled:!!e.data});return{users:a.data,isLoading:a.isLoading||e.isLoading}},Wt=()=>{const{users:e,isLoading:a}=st(),{getImageOBP:n}=pe();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}},lt=({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(0, 0, 0, 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(f.Spinner,{})})]}):null,wa=({template:e,openModalPublishTemplate:a,onHadleClickEditTemplateParams:n,onEditTasks:s,canDuplicateAndDeleteTemplates:o,onHandleClickDuplicateTemplate:i,openModalDeleteTemplate:r})=>t.jsx(f.Popup,{color:"secondary",pill:"pill",icon:de.faEllipsis,stopPropagationList:!0,children:t.jsxs(f.List,{className:"tm-p-6 tm-gap-4",children:[e.estatus!==Ae.PUBLISHED&&e.counts_tasks>2&&t.jsx(f.ListItem,{icon:de.faArrowUp,onClick:a,children:"Publicar"}),t.jsx(f.ListItem,{icon:de.faEdit,onClick:()=>{n(e)},children:"Editar parámetros"}),t.jsx(f.ListItem,{icon:de.faEdit,onClick:()=>{s&&s(e)},children:"Editar tareas"}),o&&t.jsx(f.ListItem,{icon:de.faClone,onClick:l=>{l.stopPropagation(),i(e)},children:"Duplicar"}),o&&t.jsx(f.ListItem,{color:"red",icon:de.faTrash,onClick:r,children:"Eliminar"})]})}),gs=({fullWidth:e,mode:a="grid",onClick:n,active:s,template:o,withOptions:i=!0})=>{const{openTemplate:r}=ze(),{getImageByEmail:l,getNameByEmail:d}=Wt(),{setIsEditTemplate:c,setOpenModalCreateTemplate:m,setCurrentTemplateForEdit:g,setIsDuplicateTemplate:x,setOpenModalPublishTemplate:p,setCurrentTemplateId:h,setOpenModalDeleteTemplate:y}=ke(),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),a==="grid")try{b(!0),await r({template:o,checkTemplateInIndexedDB:!0})}catch($){console.error($)}finally{b(!1)}else b(!1);n==null||n(o==null?void 0:o.id)},O=async()=>{if(!(a!=="grid"||!o)){b(!0);try{await r({template:o,checkTemplateInIndexedDB:!0}),n==null||n(o==null?void 0:o.id)}catch($){console.error($)}finally{b(!1)}}},H=$=>{c(!0),m(!0),g($)},M=$=>{x(!0),m(!0),g($)},N=()=>{h(o==null?void 0:o.id),p(!0)},A=()=>{h(o==null?void 0:o.id),y(!0)},T=(o==null?void 0:o.dias_duracion)===1?"Día":"Días",X=(o==null?void 0:o.counts_tasks)===1?"Tarea":"Tareas",U=(o==null?void 0:o.estatus)===Ae.PUBLISHED?Et(o==null?void 0:o.publication_date).format("DD/MM/YYYY"):Et(o==null?void 0:o.createdAt).format("DD/MM/YYYY"),L=(o==null?void 0:o.updated_by)||(o==null?void 0:o.created_by),I=l(L==null?void 0:L.email),V=d(L==null?void 0:L.email)||"",D=(o==null?void 0:o.estatus)===Ae.PUBLISHED?"Fecha de publicación":"Fecha de creación",q=(o==null?void 0:o.estatus)===Ae.DRAFT,B=$=>{const Y=$.split("-");return t.jsx(t.Fragment,{children:Y.map((z,re)=>t.jsxs("span",{children:[z,re<Y.length-1&&t.jsx("span",{className:"tm-text-neutral-200",children:"-"})]},re))})};return t.jsxs(f.Card,{active:s,fullWidth:e,onClick:v,className:`${e?"md:tm-flex-row":"tm-flex-col"}`,children:[t.jsx(lt,{isLoading:j}),t.jsx(f.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-8",children:[t.jsx("div",{className:"tm-flex tm-items-center",children:t.jsx(f.Icon,{name:Ve.faChartDiagram,colorDuotonePrimary:"blue",colorDuotoneSecondary:"blue",opacityDuotonePrimary:.5,size:"lg"})}),t.jsxs("div",{className:"tm-flex tm-gap-x-8 tm-flex-col tm-gap-y-4",children:[t.jsx(f.Text,{size:"sm",weight:"semibold",color:"primary",truncateLabel:!0,children:B((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(f.Badge,{size:"sm",theme:"soft",color:(o==null?void 0:o.estatus)===Ae.PUBLISHED?"success":"gray",label:(o==null?void 0:o.estatus)===Ae.PUBLISHED?"Publicado":"Borrador"}),!(typeof U=="string"&&U==="Invalid date")&&t.jsx(f.Tooltip,{label:D,children:t.jsx(f.Text,{size:"sm",weight:"medium",color:"tertiary",children:U})})]})]})]}),!e&&t.jsx(wa,{template:o,openModalPublishTemplate:N,onHadleClickEditTemplateParams:H,onEditTasks:O,canDuplicateAndDeleteTemplates:q,onHandleClickDuplicateTemplate:M,openModalDeleteTemplate:A})]})})}),t.jsx(f.Card.Separator,{vertical:e}),t.jsx(f.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(($,Y)=>{const z=w[$.params_tipo.order-1];return t.jsx(f.Badge,{color:z.color,theme:z.theme,label:$.name,size:"sm"},$.name)})}),!e&&t.jsx(f.Card.Separator,{vertical:e}),t.jsxs(f.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-8 tm-justify-center tm-items-center tm-flex-1 ${e?"tm-flex-col":"tm-flex-row"}`,children:t.jsx(f.Tooltip,{label:"Tareas totales",children:t.jsxs("div",{className:`tm-flex tm-items-center tm-gap-8 ${e?"tm-flex-col":"tm-flex-row"}`,children:[t.jsx(f.Text,{size:"xs",weight:"semibold",color:"brand",children:(o==null?void 0:o.counts_tasks)||0}),t.jsx(f.Text,{size:"xs",weight:"regular",color:"tertiary",children:X})]})})}),t.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:t.jsx(f.Tooltip,{label:"Tareas totales",children:t.jsxs("div",{className:`tm-flex tm-items-center tm-gap-8 ${e?"tm-flex-col":"tm-flex-row"}`,children:[t.jsx(f.Text,{size:"xs",weight:"semibold",color:"brand",children:(o==null?void 0:o.dias_duracion)||0}),t.jsx(f.Text,{size:"xs",weight:"regular",color:"tertiary",children:T})]})})}),t.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:[t.jsx(f.Text,{size:"xs",weight:"regular",color:"tertiary",children:"Editor"}),t.jsx(f.Tooltip,{label:V,children:t.jsx(f.Avatar,{src:I,size:"xxs",type:"people"})})]})]}),e&&i&&t.jsx(f.Card.Separator,{vertical:e}),i&&t.jsx("div",{className:`tm-w-auto ${e?"tm-flex tm-items-center":""}`,children:e&&t.jsx(wa,{template:o,openModalPublishTemplate:N,onHadleClickEditTemplateParams:H,onEditTasks:O,canDuplicateAndDeleteTemplates:q,onHandleClickDuplicateTemplate:M,openModalDeleteTemplate:A})})]})]})},hs=(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}}}}},wr=e=>{const a=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)&&(a.has(d.id)||(a.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},vr=async(e,a)=>{var l;const n=Ee.stringify({fields:["nombre","id"],populate:hs(2)},{encodeValuesOnly:!0}),s=await e.get(`/api/equipos/${a}?${n}`),o=((l=s.data)==null?void 0:l.data)??s.data,i=be(o),r=wr((i==null?void 0:i.miembros)??[]);return{team:{nombre:(i==null?void 0:i.nombre)??"",miembros:(i==null?void 0:i.miembros)??[]},members:r}},_r=e=>{const{tasks_api:a}=pe(),n=typeof e=="number"&&e>0&&!Number.isNaN(e)?e:null;return le.useQuery({queryKey:["equipo-flow-preview",n],queryFn:()=>vr(a,n),enabled:n!=null,staleTime:300*1e3})},Tr=3,Nr=e=>{if(!(e!=null&&e.id)&&(e==null?void 0:e.id)!==0)return null;const a=Number(e.id);return!Number.isNaN(a)&&a>0?a:null},Cr=({equipo:e})=>{var p;const a=Nr(e),n=((p=e==null?void 0:e.nombre)==null?void 0:p.trim())??"",{data:s,isLoading:o,isError:i}=_r(a),{getImageByEmail:r,isLoading:l}=Wt();if(!a)return null;const d=((s==null?void 0:s.team.nombre)??n).trim()||"Equipo",c=(s==null?void 0:s.members)??[],m=d,g=[...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=t.jsx("div",{className:"tm-flex tm-items-center tm-justify-center",children:o||l?t.jsx("div",{className:"tm-flex tm-items-center",children:[0,1,2].map(h=>t.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?t.jsx(f.Avatar,{counterColor:"blue",counterTheme:"solid",maxVisible:Tr,size:"xs",stack:g,stroke:!0}):t.jsx(f.Avatar,{size:"xs",stroke:!0,type:"people"})});return t.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:[t.jsx(f.Tooltip,{preserveLayout:!0,label:i&&!n?"Equipo":m,children:x}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Equipo"})]})},Sr={1:"blue",2:"green",3:"red",4:"yellow"},Er=({difficulty:e})=>t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[t.jsx(f.Icon,{name:de.faRhombus,size:"md",color:Sr[e]}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Dificultad"})]}),Pr=({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"})]}),Ar={1:"neutral",2:"blue",3:"yellow",4:"red"},Ir=({priority:e})=>t.jsxs("div",{className:"tm-flex tm-flex-col tm-items-center tm-justify-end tm-gap-2",children:[t.jsx(f.Icon,{name:de.faFlag,size:"md",color:Ar[e]}),t.jsx("p",{className:"tm-text-body-xs-regular tm-text-tertiary tm-font-body-xs-normal",children:"Prioridad"})]});class Dr{static toUsers(a){return{id:a.id,name:a.nombre,image:a.image,email:a.email}}}const Fr=async({tasks_api:e})=>{try{const a=Ee.stringify({filters:{blocked:!1}},{encodeValuesOnly:!0}),n=await e.get(`/api/users?${a}`);return be(n.data).map(Dr.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}`}},ht=()=>{const{tasks_api:e}=pe(),a=le.useQuery({queryKey:["users-mt"],queryFn:()=>Fr({tasks_api:e}),staleTime:1e3*60*60*24});return{isLoading:a.isLoading,users:a.data}},Mr=(e,a,n)=>{var r;const s=(r=e==null?void 0:e.email)==null?void 0:r.trim();if(s){const l=a(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""},kr=({responsible:e})=>{const{isLoading:a,users:n}=ht(),{getImageByEmail:s,getNameByEmail:o,isLoading:i}=Wt();if(a||i)return null;const r=Mr(e,o,n),l=t.jsx(f.Avatar,{size:"xs",src:s((e==null?void 0:e.email)??""),type:"people"});return t.jsxs("div",{className:"tw-flex tw-flex-col tw-items-center tw-justify-end",children:[r?t.jsx(f.Tooltip,{label:r,children:l}):l,t.jsx("p",{className:"ui-text-body-xs-regular ui-text-tertiary ui-font-body-xs-normal",children:"Responsable"})]})},Or=[{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"}],Lr=[{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"}],Br=[{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},{label:"6 días",value:6},{label:"7 días",value:7}],xs=({isOpen:e,onClose:a,onSuccess:n,nodeDataType:s,parentNodeInfo:o,editMode:i=!1,taskToEdit:r})=>{const{data:l}=Ma(),{users:d}=ht(),{users:c}=st(),{getImageOBP:m}=pe(),g=u.useMemo(()=>{try{return!d||!c?[]:d.map(N=>{const A=c[N.email],T=A!=null&&A.image?m(A.image):"";return{label:N.name,value:N.id.toString(),icon:T}})}catch(N){return console.error("Error mapeando usuarios:",N),[]}},[d,c]),x=()=>{if(i&&r){const N=U=>{if(U==null)return"";const L=Number(U);return isNaN(L)?"":L},A=U=>U?typeof U=="string"?Number(U)||"":U.id||"":"",T=U=>{var L;return U?typeof U=="string"?U:((L=U.id)==null?void 0:L.toString())||U.name||U.nombre||"":""};return{title:r.texto_corto||"",description:r.texto_largo||"",priority:N(r.prioridad),difficulty:N(r.nivel_dificultad),duration:N(r.duracion),team:A(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}=Pe.useForm({mode:"onChange",defaultValues:x()});u.useEffect(()=>{e&&j(x())},[e,i,r,j]);const v=b(),O=w&&v.title&&v.description&&v.priority&&v.difficulty&&v.duration&&v.team&&Object.keys(y).length===0,H=async N=>{try{if(["title","description","priority","difficulty","duration","team"].filter(X=>!N[X]).length>0)return;n&&await n({...N,parent:o}),i||j()}catch{}},M=()=>{j(),a()};return t.jsx(f.Drawer,{titleIcon:de.faPencil,isOpen:e,onClose:M,onSuccess:()=>{h(N=>{H(N)},N=>{const A=Object.entries(N).map(([T,X])=>`${T}: ${X.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
|
+
`+A)})()},title:i?"Editar tarea":"Nueva tarea",successButtonText:i?"Actualizar":"Crear",disabledSuccessButton:!O,children:t.jsxs("form",{className:"tm-flex tm-flex-col tm-gap-4",children:[t.jsx(Pe.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:N})=>{var A;return t.jsx(f.Input,{fullWidth:!0,label:"Título",placeholder:"Ingresa el título de la tarea...",error:(A=y.title)==null?void 0:A.message,...N})}}),t.jsx(Pe.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:N})=>{var A;return t.jsx(f.Textarea,{className:"ui-w-full tw-w-full",placeholder:"Describe la tarea a realizar...",label:"Descripción",error:(A=y.description)==null?void 0:A.message,...N})}}),t.jsx(f.Separator,{}),t.jsx(Pe.Controller,{control:p,name:"priority",rules:{required:"La prioridad es obligatoria"},render:({field:N,fieldState:{error:A}})=>t.jsx(f.Dropdown,{fullWidth:!0,label:"Prioridad",placeholder:"Selecciona la prioridad...",options:Or,error:A==null?void 0:A.message,value:N.value,onValueChange:T=>{N.onChange(T)}})}),t.jsx(Pe.Controller,{control:p,name:"difficulty",rules:{required:"La dificultad es obligatoria"},render:({field:N,fieldState:{error:A}})=>t.jsx(f.Dropdown,{fullWidth:!0,label:"Dificultad",placeholder:"Selecciona la dificultad...",options:Lr,error:A==null?void 0:A.message,value:N.value,onValueChange:T=>{N.onChange(T)}})}),t.jsx(Pe.Controller,{control:p,name:"duration",rules:{required:"La duración es obligatoria"},render:({field:N,fieldState:{error:A}})=>t.jsx(f.Dropdown,{fullWidth:!0,label:"Duración",placeholder:"Selecciona la duración...",options:Br,error:A==null?void 0:A.message,value:N.value,onValueChange:T=>{N.onChange(T)}})}),t.jsx(f.Separator,{}),t.jsx(Pe.Controller,{control:p,name:"team",rules:{required:"El equipo es obligatorio"},render:({field:N,fieldState:{error:A}})=>t.jsx(f.Dropdown,{fullWidth:!0,label:"Equipo",placeholder:"Selecciona el equipo...",options:l,error:A==null?void 0:A.message,value:N.value,onValueChange:T=>{N.onChange(T)}})}),t.jsx(Pe.Controller,{control:p,name:"responsible",render:({field:N,fieldState:{error:A}})=>t.jsx(f.Dropdown,{fullWidth:!0,absolute:!0,label:"Responsable",placeholder:"Selecciona el responsable...",options:g,error:A==null?void 0:A.message,value:N.value,onValueChange:T=>{N.onChange(T)}})})]})})},Rr=()=>{const{get:e}=ze(),a=qe(i=>i.activeTemplate),{updateTaskInState:n,addTaskToState:s}=it();return{updateTaskInTemplate:async(i,r)=>{if(!a)return console.error("No hay plantilla activa"),!1;try{const l=await e(a.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}}}},Te={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"},va={dependiente:{stroke:"#3B82F6",strokeDasharray:"5,5",strokeWidth:2},normal:{stroke:"#6B7280",strokeWidth:2}},Tt=e=>{const a=e.map(n=>({...n}));return a.filter(n=>n.type==="group").forEach(n=>{const s=a.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 g;return m.position.x+(typeof((g=m.style)==null?void 0:g.width)=="number"?m.style.width:Te.DEFAULT_CHILD_WIDTH)}))-o,l=Math.min(...s.map(m=>m.position.y)),c=Math.max(...s.map(m=>{var g;return m.position.y+(typeof((g=m.style)==null?void 0:g.height)=="number"?m.style.height:Te.DEFAULT_CHILD_HEIGHT)}))-l;n.style={...n.style??{},width:r,height:c}}),a},Nt=e=>e.source===Te.START_NODE_ID||e.target===Te.START_NODE_ID,et=e=>e===Te.START_NODE_ID,qr=e=>e==="dependiente"?va.dependiente:va.normal,zr=(e,a,n)=>({id:e,type:"main",position:a,selected:!1,deletable:!0,data:n}),Ct=(e,a,n,s,o,i=!1,r=null,l=null)=>{const d=qr(s),c=i?Te.DEFAULT_SOURCE_HANDLE:n;return{id:`edge-${e}-${a}`,source:e,sourceHandle:c,target:a,targetHandle:Te.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}}},$r=(e,a)=>!(!e||!a||e===a),Ur=e=>{const{clientX:a,clientY:n}="changedTouches"in e?e.changedTouches[0]:e;return{x:a,y:n}},Hr=e=>e.filter(a=>a.type==="position"&&a.dragging===!1),bs=e=>e.map(a=>a.id),ys=({nodes:e,edges:a,setNodes:n,setEdges:s,newNodePopup:o,connectionPopup:i,closeNewNodePopup:r,closeConnectionPopup:l,setIsConnectingExistingNodes:d})=>{const{screenToFlowPosition:c,getNode:m,setViewport:g,fitView:x}=oe.useReactFlow(),{get:p,update:h,addTaskUpdatingTemplate:y,addTemplateUpdatingTemplate:w}=ze(),j=qe(I=>I.activeTemplate),b=le.useQueryClient(),v=qe(I=>I.setActiveTemplate),{removeTaskFromState:O,updateNodeWithNewEdge:H,updateTaskInState:M}=it(),N=u.useCallback(async I=>{const V=e.find(q=>q.id===I);if(!(V!=null&&V.data))return null;if(V.id===Te.START_NODE_ID){if(!j)return null;try{const q=await p(j.id),B=q.tarea_plantillas.find($=>$.start===!0);return B!=null&&B.id?B.id:q.tarea_plantillas.length>0?q.tarea_plantillas[0].id:null}catch{return null}}const D=V.data.id;if(!D&&D!==0)return null;if(typeof D=="string"){if(D.includes("-"))return D;{const q=parseInt(D,10);return isNaN(q)?null:q}}else if(typeof D=="number")return D;return null},[e,j,p]),A=u.useCallback(async(I=e,V=a)=>{var D,q,B,$,Y,z,re;if(!j){f.toast.warning("No hay template activo para actualizar layout");return}try{const ee=await p(j.id);if(!ee){f.toast.warning("Template no encontrado en IndexedDB");return}const S=(D=ee.graph_layout)==null?void 0:D.snapshot;if(!(!S||JSON.stringify(S.nodes)!==JSON.stringify(I)||JSON.stringify(S.edges)!==JSON.stringify(V))){console.log("🔄 No hay cambios en el layout, omitiendo actualización");return}const G=I.filter(W=>{var E;return!((E=W.data)!=null&&E.isInternal)&&!W.parentId}).map(W=>{const{style:E,measured:C,data:R,selected:F,..._}=W,{expandedDimensions:Q,isExpanded:Z,needsReExpansion:ae,...ie}=R||{},J=E?{...E,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{..._,style:J,data:ie}}),k=V.filter(W=>{var E;return!((E=W.data)!=null&&E.isInternal)}),P={...ee,graph_layout:{id:((q=ee.graph_layout)==null?void 0:q.id)||0,snapshot:{nodes:G,edges:k,viewport:(($=(B=ee.graph_layout)==null?void 0:B.snapshot)==null?void 0:$.viewport)||{x:0,y:0,zoom:1}},history:((Y=ee.graph_layout)==null?void 0:Y.history)||[],zoom:((z=ee.graph_layout)==null?void 0:z.zoom)||1,position:((re=ee.graph_layout)==null?void 0:re.position)||{x:0,y:0}},estatus:_e.DIRTY,updatedAt:new Date().toISOString()};await h(j.id,P),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(P)}catch(ee){console.error("❌ Error al actualizar template layout:",ee)}},[j,p,h,e,a,v]),T=u.useCallback(async(I=[],V=[],D,q)=>{var $,Y,z,re,ee,S,K,G,k,P,W,E;const B=D||(j==null?void 0:j.id);if(!B){f.toast.warning("No hay template ID disponible para actualizar");return}try{const C=await p(B);if(!C)return;const R=(z=(Y=($=C.graph_layout)==null?void 0:$.snapshot)==null?void 0:Y.nodes)==null?void 0:z.filter(Q=>{var Z;return!I.includes(Q.id)&&!((Z=Q.data)!=null&&Z.isInternal)&&!Q.parentId}).map(Q=>{const{style:Z,measured:ae,data:ie,...J}=Q,{expandedDimensions:se,...te}=ie||{},fe=Z?{...Z,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{...J,style:fe,data:te}}),F=((S=(ee=(re=C.graph_layout)==null?void 0:re.snapshot)==null?void 0:ee.edges)==null?void 0:S.filter(Q=>{var Z;return!I.includes(Q.source)&&!I.includes(Q.target)&&!((Z=Q.data)!=null&&Z.isInternal)}))||[],_={...C,graph_layout:{id:((K=C.graph_layout)==null?void 0:K.id)||0,snapshot:{nodes:R,edges:F,viewport:((k=(G=C.graph_layout)==null?void 0:G.snapshot)==null?void 0:k.viewport)||{x:0,y:0,zoom:1}},history:((P=C.graph_layout)==null?void 0:P.history)||[],zoom:((W=C.graph_layout)==null?void 0:W.zoom)||1,position:((E=C.graph_layout)==null?void 0:E.position)||{x:0,y:0}},estatus:_e.DIRTY,updatedAt:new Date().toISOString()};await O({templateId:B,id:q||0}),await h(B,_),await b.invalidateQueries({queryKey:["template",B]}),await b.invalidateQueries({queryKey:["template"]}),B===(j==null?void 0:j.id)&&v(_)}catch(C){console.error("❌ updateAfterDeleted - Error al actualizar template layout:",C)}},[j,p,h,a,e,O,v]),X=u.useCallback(async(I,V,D)=>{if(!o||!j)return;const{nodeId:q,sourceNodeId:B,sourceHandleId:$}=o;if(B)try{const Y=await N(B);if(!Y)return;if(I==="plantilla"){const z=D;if(!(z!=null&&z.templateId))return;if(!await w(z.templateId,j.id,Y,V)){f.toast.error("No se pudo agregar la plantilla. Intenta nuevamente."),r();return}try{const W=await p(j.id);if(W){const E=(R,F)=>{for(const _ of R){if(_.id===F||_.uuid===F)return _;if(_.tareas&&_.tareas.length>0){const Q=E(_.tareas,F);if(Q)return Q}}return null},C=E(W.tarea_plantillas,Y);if(C&&C.id){const R=(C.plantilla_dependents||[]).map(_=>typeof _=="object"&&_.id?{id:_.id}:typeof _=="number"?{id:_}:_),F={...C,plantilla_dependents:R,plantilla:{id:j.id,clave:W.clave,categoria:W.categoria||{id:0,nombre:"Sin categoría"}}};await M({task:F}),console.log("✅ Tarea padre agregada a templates_states.updated con plantilla_dependents:",C.id,F.plantilla_dependents)}}}catch(W){console.error("❌ Error al actualizar tarea padre en templates_states:",W)}const ee=c({x:o.position.x,y:o.position.y}),S=z.templateData||{id:z.templateId,nombre_plantilla:`Flujo de trabajo ${z.templateId}`,clave:`TPL-${z.templateId}`,estatus:"activo",categoria:null,counts_tasks:0,dias_duracion:0},K={id:q,type:"group",position:ee,selected:!1,deletable:!0,data:{id:z.templateId,templateId:z.templateId,type:"template",nombre_plantilla:S.nombre_plantilla||`Flujo de trabajo ${z.templateId}`,clave:S.clave||`TPL-${z.templateId}`,estatus:S.estatus||"activo",categoria:S.categoria||null,counts_tasks:S.counts_tasks||0,dias_duracion:S.dias_duracion||0,tarea_plantillas:S.tarea_plantillas||[],params_plantillas:S.params_plantillas||[],createdAt:S.createdAt||new Date().toISOString(),updatedAt:S.updatedAt||new Date().toISOString(),created_by:S.created_by||null,updated_by:S.updated_by||null}};n(W=>[...W,K]);const G=$||Te.DEFAULT_SOURCE_HANDLE,k=et(B),P=Ct(B,q,G,V,"plantilla",k,Y);s(W=>[...W,P]);try{const W=[...e,K],E=[...a,P];await A(W,E)}catch(W){console.error("❌ Error al actualizar layout después de agregar plantilla:",W)}}else if(I==="tarea"){const z=D;if(!z)return;const re=c({x:o.position.x,y:o.position.y}),ee=-new Date().getTime(),S={id:ee,reference_graph:q,title:z.title,description:z.description,priority:z.priority,difficulty:z.difficulty,duration:z.duration,team:z.team,responsible:z.responsible,parent:{data:{id:Y}}},K=await y(S,j.id,V),G=zr(q,re,K);n(E=>[...E,G]);const k=$||Te.DEFAULT_SOURCE_HANDLE,P=et(B),W=Ct(B,q,k,V,I,P,Y,ee);s(E=>[...E,W]);try{const E=[...e,G],C=[...a,W];await A(E,C)}catch(E){console.error("❌ Error al actualizar layout después de agregar tarea:",E)}setTimeout(()=>{try{const E=m(q);if(E){const C=window.innerWidth,R=window.innerHeight,F=C/2,_=R/2;g({x:F-E.position.x-130,y:_-E.position.y-40,zoom:1},{duration:800})}else x({padding:.1,duration:800})}catch{try{x({padding:.1,duration:800})}catch{}}},200)}r()}catch(Y){console.error("❌ Error en createNodeFromPopup:",Y)}},[o,j,y,w,N,c,n,s,r,A,e,a]),U=u.useCallback(async(I,V)=>{var $,Y;if(console.log("🟢 createConnectionFromPopup - INICIO",{nodeType:I,connectionType:V}),!i){console.warn("⚠️ createConnectionFromPopup - No hay connectionPopup");return}const{sourceNodeId:D,sourceHandleId:q,targetNodeId:B}=i;console.log("🟢 createConnectionFromPopup - Datos de conexión:",{sourceNodeId:D,targetNodeId:B,sourceHandleId:q});try{if(!(window.validConnectionTypes||{dependiente:!0,hija:!0})[V]){console.warn("⚠️ createConnectionFromPopup - Tipo de conexión no válido:",V),f.toast.warning("Tipo de conexión no válido"),d(!1),l();return}const re=e.find(F=>F.id===D),ee=e.find(F=>F.id===B);console.log("🟢 createConnectionFromPopup - Nodos encontrados:",{sourceNode:re==null?void 0:re.id,targetNode:ee==null?void 0:ee.id,sourceData:re==null?void 0:re.data,targetData:ee==null?void 0:ee.data});const S=ee==null?void 0:ee.data,K=(($=re==null?void 0:re.data)==null?void 0:$.id)||D,G=((Y=ee==null?void 0:ee.data)==null?void 0:Y.id)||B;console.log("🟢 createConnectionFromPopup - IDs extraídos:",{parentId:K,childId:G});const k=Ct(D,B,q||Te.DEFAULT_SOURCE_HANDLE,V,I,et(D),K,G);console.log("🟢 createConnectionFromPopup - Nuevo edge creado:",k),s(F=>[...F,k]);const P=[...a,k],W=S.id||-Date.now(),E=S.reference_graph||B,C={id:W,uuid:S.uuid||crypto.randomUUID(),reference_graph:E,texto_corto:S.texto_corto||"",texto_largo:S.texto_largo||"",prioridad:S.prioridad||null,nivel_dificultad:S.nivel_dificultad||1,duracion:S.duracion||null,start:S.start||!1,equipo:S.equipo||null,responsable:S.responsable||null,plantilla:{id:S.plantilla.id,clave:S.plantilla.clave,categoria:S.plantilla.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:S.plantilla_dependents||[],ids_t_dependientes:S.ids_t_dependientes||[],tarea_padre:V==="hija"?{id:k.data.parentId}:null,id_t_requerida:V==="dependiente"?{id:k.data.parentId}:null,tareas:S.tareas||[],type:"task"};console.log("🟢 createConnectionFromPopup - taskForState creado:",C),console.log("🟢 createConnectionFromPopup - currentTemplate.id:",j.id);const R=e.map(F=>F.id===B?{...F,data:C}:F);console.log("🟢 createConnectionFromPopup - Actualizando nodos en React Flow..."),n(R),console.log("✅ createConnectionFromPopup - Nodos actualizados en React Flow"),console.log("🟢 createConnectionFromPopup - Actualizando template layout..."),await A(R,P),console.log("✅ createConnectionFromPopup - Template layout actualizado"),console.log("🟢 createConnectionFromPopup - Llamando a updateNodeWithNewEdge..."),await H({templateId:j.id,edge:k,task:C}),console.log("✅ createConnectionFromPopup - updateNodeWithNewEdge completado")}catch(z){console.error("❌ createConnectionFromPopup - Error al crear conexión:",z),console.error("❌ createConnectionFromPopup - Stack:",z.stack)}finally{console.log("🟢 createConnectionFromPopup - Limpiando estado..."),d(!1),l(),console.log("🟢 createConnectionFromPopup - FIN")}},[i,s,d,l,a,e,A]),L=u.useCallback(async I=>{if(!o||!j){f.toast.warning("No hay newNodePopup o template activo para actualizar el nodo");return}const{nodeId:V}=o;if(!V){f.toast.warning("No se encontró nodeId en newNodePopup");return}try{const D=e.find(B=>B.id===V);if(!D){f.toast.warning(`No se encontró el nodo con ID: ${V}`);return}const q={...D,data:{...D.data,...I,id:D.data.id||D.id,type:D.data.type||D.data.type,updatedAt:new Date().toISOString()}};n(B=>B.map($=>$.id===V?q:$));try{const B=e.map($=>$.id===V?q:$);await A(B,a)}catch(B){f.toast.error("Error al actualizar layout después de actualizar nodo:",B)}r()}catch(D){f.toast.error("Error al actualizar el nodo:",D)}},[o,j,e,n,a,A,r]);return{createNodeFromPopup:X,createConnectionFromPopup:U,updateNodeFromPopup:L,updateAfterDeleted:T}},Kr=({data:e,id:a,isConnectable:n,selected:s})=>{const o=ve(U=>U.getViewMode),[i,r]=u.useState(!1),[l,d]=u.useState(e),c=qe(U=>U.activeTemplate),m=qe(U=>U.setActiveTemplate),{get:g,update:x}=ze(),{data:p}=Ma(),{users:h}=ht(),y=c!=null&&c.id?o(c.id):"readonly",{updateTaskInTemplate:w}=Rr(),{setNodes:j,setEdges:b,getNodes:v,getEdges:O}=oe.useReactFlow(),H=le.useQueryClient(),{updateAfterDeleted:M}=ys({nodes:v(),edges:O(),setNodes:j,setEdges:b,newNodePopup:null,connectionPopup:null,closeNewNodePopup:()=>{},closeConnectionPopup:()=>{},setIsConnectingExistingNodes:()=>{}}),N=()=>{r(!0)},A=u.useCallback(async()=>{var q,B,$;const U=v().find(Y=>Y.id===a);if(!U){console.warn("⚠️ Nodo no encontrado para eliminar");return}const L=[U],I=bs(L),V=L.length>0?(B=(q=L[0])==null?void 0:q.data)==null?void 0:B.id:0;b(Y=>Y.filter(z=>!I.includes(z.source)&&!I.includes(z.target))),j(Y=>Y.filter(z=>z.id!==a));let D;for(const Y of L)try{const z=Y.data;if(($=z==null?void 0:z.plantilla)!=null&&$.id){D=z.plantilla.id;break}}catch{}try{b(Y=>((async()=>{await M(I,Y,D,V)})().catch(z=>{console.error("❌ Error en updateAfterDeleted:",z)}),Y))}catch(Y){console.error("❌ Error en handleDeleteNode:",Y)}},[a,v,O,j,b,M]),T=u.useCallback(async U=>{var L,I,V,D,q,B,$,Y,z,re;if(!c){console.warn("⚠️ MainNode.updateTemplateLayout - No hay template activo");return}try{const ee=await g(c.id);if(!ee){console.warn("⚠️ MainNode.updateTemplateLayout - Template no encontrado en IndexedDB");return}const S=(L=ee.graph_layout)==null?void 0:L.snapshot;if(!(!S||JSON.stringify(S.nodes)!==JSON.stringify(U))){console.log("🔄 MainNode.updateTemplateLayout - No hay cambios en nodos, omitiendo actualización");return}const G=U.filter(W=>{var E;return!((E=W.data)!=null&&E.isInternal)&&!W.parentId}).map(W=>{const{style:E,measured:C,data:R,selected:F,..._}=W,{expandedDimensions:Q,isExpanded:Z,needsReExpansion:ae,...ie}=R||{},J=E?{...E,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0;return{..._,style:J,data:ie}}),k=(((V=(I=ee.graph_layout)==null?void 0:I.snapshot)==null?void 0:V.edges)||[]).filter(W=>{var E;return!((E=W.data)!=null&&E.isInternal)}),P={...ee,graph_layout:{id:((D=ee.graph_layout)==null?void 0:D.id)||0,snapshot:{...(q=ee.graph_layout)==null?void 0:q.snapshot,nodes:G,edges:k,viewport:(($=(B=ee.graph_layout)==null?void 0:B.snapshot)==null?void 0:$.viewport)||{x:0,y:0,zoom:1}},history:((Y=ee.graph_layout)==null?void 0:Y.history)||[],zoom:((z=ee.graph_layout)==null?void 0:z.zoom)||1,position:((re=ee.graph_layout)==null?void 0:re.position)||{x:0,y:0}},estatus:_e.DIRTY,updatedAt:new Date().toISOString()};await x(c.id,P),await H.invalidateQueries({queryKey:["template",c.id]}),await H.invalidateQueries({queryKey:["template"]}),c&&c.id===P.id&&m(P)}catch(ee){console.error("❌ MainNode.updateTemplateLayout - Error al actualizar template layout:",ee)}},[c,g,x,m,H]),X=async U=>{if(c){const L=U.responsible,I=L!==""&&L!=null&&!Number.isNaN(Number(L))?Number(L):null,V=I!=null?h==null?void 0:h.find($=>$.id===I):void 0,D=e.responsable&&typeof e.responsable=="object"&&"email"in e.responsable&&typeof e.responsable.email=="string"?e.responsable.email:"",q=I!=null?{id:I,email:(V==null?void 0:V.email)??D}:{id:null,email:""},B={...e,texto_corto:U.title,texto_largo:U.description,prioridad:U.priority?typeof U.priority=="number"?U.priority:parseInt(U.priority.toString()):null,nivel_dificultad:U.difficulty?typeof U.difficulty=="number"?U.difficulty:parseInt(U.difficulty.toString()):1,duracion:U.duration?typeof U.duration=="number"?U.duration:parseInt(U.duration.toString()):null,equipo:(()=>{var z;const $=Number(U.team)||null;if(!$)return{id:null};const Y=(z=p==null?void 0:p.find(re=>re.value===$))==null?void 0:z.label;return{id:$,...Y?{nombre:Y}:{}}})(),responsable:q};await w(e.id,B),j($=>{const Y=$.map(z=>z.id===a?{...z,data:{...z.data,...B,tarea_padre:e.tarea_padre,id_t_requerida:e.id_t_requerida,updatedAt:new Date().toISOString()}}:z);return setTimeout(()=>T(Y),0),Y})}r(!1)};return u.useEffect(()=>{d(e)},[e]),t.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:[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-surface-default"}),t.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}),t.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}),t.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}),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(f.Text,{size:"lg",weight:"semibold",color:"primary",truncateLabel:!0,children:l.texto_corto}),!e.isInternal&&c.estatusFromStrapi!==Ae.PUBLISHED&&y!=="readonly"&&t.jsx("div",{children:e.type==="task"?t.jsx(f.Popup,{position:"right",absolute:!0,size:"xxs",pill:"pill",color:"secondary",icon:de.faEllipsis,containerClassName:"nopan nodrag",buttonClassName:"nopan nodrag",children:t.jsxs(f.List,{className:"tm-p-8 tm-gap-4",children:[t.jsx(f.ListItem,{icon:de.faEdit,onClick:N,children:"Editar"}),t.jsx(f.ListItem,{icon:de.faPlus,color:"red",onClick:A,children:"Eliminar"})]})}):t.jsx(f.Button,{size:"xxs",color:"secondary",pill:"pill",icon:de.faMaximize,className:"nopan"})})]}),t.jsx(f.Text,{size:"xs",weight:"regular",color:"tertiary",children:l.texto_largo}),t.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:[t.jsx(Pr,{duration:l.duracion}),t.jsx(Er,{difficulty:l.nivel_dificultad}),t.jsx(Ir,{priority:l.prioridad}),t.jsx(Cr,{equipo:l.equipo}),t.jsx(kr,{responsible:l.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-surface-default",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-surface-default",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-surface-default",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-surface-default",position:oe.Position.Left}),e.type==="task"&&i&&t.jsx(xs,{isOpen:i,onClose:()=>r(!1),onSuccess:X,editMode:!0,taskToEdit:l})]})},Vr=async({tasks_api:e,page:a=1,pageSize:n=10,search:s="",filters:o={}})=>{const i={clave:{$notNull:!0},estatus:{$ne:Ae.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=Ee.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}),l=await e.get(`/api/plantillas/all-plantillas?${r}`);return l.data?{data:be(l.data.data),meta:l.data.meta}:{data:[],meta:{pagination:{page:a,pageSize:n,pageCount:0,total:0}}}},js=({page:e=1,pageSize:a=10,search:n="",filters:s={}})=>{const{tasks_api:o}=pe();return le.useQuery({queryKey:["templates",e,a,n,s],queryFn:()=>Vr({tasks_api:o,page:e,pageSize:a,search:n,filters:s}),staleTime:1e3*60*60*24,placeholderData:le.keepPreviousData,select:i=>({data:(i==null?void 0:i.data)||[],meta:i==null?void 0:i.meta})})},ws=({isOpen:e,onClose:a,onSuccess:n,nodeDataType:s,parentNodeInfo:o})=>{var v,O,H,M;const i=ve(N=>N.addNodeWithType),[r,l]=u.useState(0),d=5,[c,m]=u.useState(1),[g,x]=u.useState("");u.useEffect(()=>{e&&(m(1),x(""),l(0))},[e]),u.useEffect(()=>{m(1)},[g]);const{data:p,isLoading:h}=js({page:c,pageSize:d,search:g}),y=N=>{x(N.target.value)},w=()=>{var A;if(r===0)return;const N=(A=p==null?void 0:p.data)==null?void 0:A.find(T=>T.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(h)return t.jsx("div",{children:"Cargando..."});if(!(p!=null&&p.data))return t.jsx("div",{children:"No hay datos disponibles"});const j=((O=(v=p.meta)==null?void 0:v.pagination)==null?void 0:O.total)||0,b=j===1?"flujo encontrado":"flujos encontrados";return t.jsx(f.Modal,{iconConfig:{icon:Se.faPencil},isOpen:e,size:"lg",onSuccess:w,onClose:a,title:"Agregar flujo de trabajo",successButtonText:"Agregar",disableSuccessButton:r===0,closeAtSuccess:!0,children:t.jsxs(f.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(f.Input,{className:"tm-flex-1",leftSlot:Se.faSearch,fullWidth:!0,placeholder:"Buscar por nombre, parámetros o estado...",value:g,onChange:y})]}),t.jsx(f.Separator,{}),t.jsxs("div",{className:"tm-flex tm-flex-col tm-gap-6 tm-p-12",children:[p.data.map(N=>t.jsx(gs,{mode:"modal",template:N,active:r===N.id,fullWidth:!0,onClick:l,withOptions:!1},N.id)),p.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(f.Separator,{}),t.jsx("div",{className:"tm-mt-6",children:t.jsx(f.Pagination,{className:"tm-pt-0",pageSize:d,pageCount:((M=(H=p==null?void 0:p.meta)==null?void 0:H.pagination)==null?void 0:M.pageCount)||1,currentPage:c,onPageChange:N=>m(N)})})]})})},Gr=({data:e,id:a})=>{const n=ve(m=>m.addNodeWithType),[s,o]=u.useState(!1),[i,r]=u.useState(!1),[l,d]=u.useState({id:a,type:"tarea",connectionType:"dependiente"}),c=({type:m,connectionType:g})=>{n&&(d({id:a,type:m,connectionType:g}),m==="tarea"?o(!0):m==="plantilla"&&r(!0))};return console.log({data:e,id:a}),t.jsxs("div",{className:"tm-flex tm-items-center tm-justify-center",children:[l.type==="plantilla"&&t.jsx(ws,{isOpen:i,onClose:()=>r(!1),nodeDataType:l}),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(f.Popup,{position:"right",absolute:!0,size:"md",rounded:!0,icon:de.faPlus,containerClassName:"nopan",buttonClassName:"nopan",children:t.jsxs(f.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(f.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>c({type:"tarea",connectionType:"dependiente"}),children:"Dependiente"}),t.jsx(f.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>c({type:"tarea",connectionType:"hija"}),children:"Hija"}),t.jsx(f.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(f.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>c({type:"plantilla",connectionType:"dependiente"}),children:"Dependiente"}),t.jsx(f.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>c({type:"plantilla",connectionType:"hija"}),children:"Hija"})]})})]})},Wr=({isOpen:e,position:a,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 g=(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 t.jsxs(t.Fragment,{children:[!i&&!l&&t.jsx("div",{className:"tm-fixed tm-inset-0 tm-z-50",onClick:n}),!i&&!l&&t.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:a.x+50,top:a.y-100},children:t.jsx("div",{className:"tm-p-2",children:t.jsxs(f.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(f.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>g("tarea","dependiente"),children:"Dependiente"}),t.jsx(f.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>g("tarea","hija"),children:"Hija"}),t.jsx(f.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(f.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>g("plantilla","dependiente"),children:"Dependiente"})]})})}),i&&c&&t.jsx(xs,{isOpen:i,onClose:x,onSuccess:h,nodeDataType:{id:"",type:c.type,connectionType:c.connectionType},parentNodeInfo:o}),l&&c&&t.jsx(ws,{isOpen:l,onClose:p,onSuccess:y,nodeDataType:{id:"",type:c.type,connectionType:c.connectionType},parentNodeInfo:o})]})};function Qr({reactFlowWrapper:e,nodes:a,resetZoomHistoryKey:n}){const{setViewport:s,getViewport:o}=oe.useReactFlow(),{zoom:i}=oe.useViewport(),r=Math.round(i*100),[l,d]=u.useState([]),[c,m]=u.useState(-1),[g,x]=u.useState(!1),[p,h]=u.useState(0);u.useLayoutEffect(()=>{const M=e==null?void 0:e.current;if(M){const N=M.getBoundingClientRect();h(N.width)}},[e]);const y=u.useMemo(()=>{var T;if(!a||a.length===0)return{x:0,y:0,zoom:1};const M=a.find(X=>{var U;return(U=X==null?void 0:X.data)==null?void 0:U.main})??a[0];return{x:(p||(typeof window<"u"?window.innerWidth:0))/2-(((T=M==null?void 0:M.position)==null?void 0:T.x)??0),y:20,zoom:1}},[a,p]),w=u.useCallback(M=>{if(!g){const N=[...l.slice(0,c+1),M];d(N),m(N.length-1)}},[l,c,g]),j=u.useCallback(()=>{if(g)return;const M=o(),N=Math.min(M.zoom*1.2,2);w(M),x(!0),s({x:M.x,y:M.y,zoom:N}),setTimeout(()=>x(!1),100)},[o,s,w,g]),b=u.useCallback(()=>{if(g)return;const M=o(),N=Math.max(M.zoom/1.2,.5);w(M),x(!0),s({x:M.x,y:M.y,zoom:N}),setTimeout(()=>x(!1),100)},[o,s,w,g]),v=u.useCallback(()=>{if(g)return;const M=o();Math.abs(M.zoom-1)>.01&&w(M),x(!0),s({x:M.x,y:M.y,zoom:1}),setTimeout(()=>x(!1),100)},[o,s,w,g]),O=u.useCallback(()=>{if(g||c<=0)return;const M=l[c-1];x(!0),s(M),m(c-1),setTimeout(()=>x(!1),100)},[c,l,s,g]);return u.useEffect(()=>{l.length===0&&(d([{zoom:1,x:0,y:0}]),m(0))},[l.length]),u.useEffect(()=>{n!=null&&(d([{zoom:1,x:0,y:0}]),m(0))},[n]),{isReady:p!==0&&Array.isArray(a)&&a.length>0,defaultViewport:y,zoomPercentage:r,handleZoomIn:j,handleZoomOut:b,handleZoomTo100:v,handleDoubleClick:O}}const Xr=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=l=>{if(l.preventDefault(),l.stopPropagation(),n){const c=ve.getState().collapseGroup;c&&c(n)}};return t.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:[t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:[t.jsx(f.Icon,{name:Ve.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(f.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-8",children:[t.jsx(f.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-surface-default 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-surface-default tm-cursor-crosshair"})]})},Yr=()=>{const e=u.useCallback((o,i,r,l)=>{const d=(g,x)=>{const p=g.position.x,h=g.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))},[]),a=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 g of l){if(!a(m,g))continue;const x=e(o,i,m,g);x<d&&(d=x,c={handle1:m,handle2:g})}return c},[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}},Jr=e=>{const[a,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)},[]),g=u.useCallback(()=>{var p,h,y;if(!(a!=null&&a.sourceNodeId))return null;const x=e.find(w=>w.id===a.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},[a,e]);return{newNodePopup:a,connectionPopup:s,isConnectingExistingNodes:i,openNewNodePopup:l,closeNewNodePopup:d,openConnectionPopup:c,closeConnectionPopup:m,getParentNodeInfo:g,setIsConnectingExistingNodes:r}},Zr=({initialNodes:e,initialEdges:a})=>{const[n,s,o]=oe.useNodesState(Tt(e)),[i,r,l]=oe.useEdgesState(a),[d,c]=u.useState(!1),m=u.useCallback(k=>{r(k)},[r]),{toObject:g}=oe.useReactFlow(),{findClosestHandles:x,shouldApplyMagneticConnection:p}=Yr(),{updateGraphLayout:h,get:y,update:w}=ze(),j=qe(k=>k.activeTemplate),b=qe(k=>k.setActiveTemplate),v=le.useQueryClient(),{removeParentIdFromNodes:O}=it(),{newNodePopup:H,connectionPopup:M,isConnectingExistingNodes:N,openNewNodePopup:A,closeNewNodePopup:T,openConnectionPopup:X,closeConnectionPopup:U,getParentNodeInfo:L,setIsConnectingExistingNodes:I}=Jr(n),{createNodeFromPopup:V,createConnectionFromPopup:D,updateNodeFromPopup:q,updateAfterDeleted:B}=ys({nodes:n,edges:i,setNodes:s,setEdges:m,newNodePopup:H,connectionPopup:M,closeNewNodePopup:T,closeConnectionPopup:U,setIsConnectingExistingNodes:I});u.useEffect(()=>{if(e&&e.length>0){if(!(e.some((F,_)=>{const Q=n[_];return Q?F.id!==Q.id||JSON.stringify(F.position)!==JSON.stringify(Q.position)||JSON.stringify(F.data)!==JSON.stringify(Q.data):!0})||e.length!==n.filter(F=>{var _;return!((_=F.data)!=null&&_.isInternal)}).length)&&n.length>0)return;const{expandedGroups:P,groupTemplateData:W}=ve.getState(),E=Tt(e),C=new Set(E.map(F=>F.id));let R=n.filter(F=>{var _,Q;return((_=F.data)==null?void 0:_.isInternal)&&typeof((Q=F.data)==null?void 0:Q.originalGroupId)=="string"&&P.has(F.data.originalGroupId)&&C.has(F.data.originalGroupId)});if(R.length>0){const F=E.map(_=>{var Q;if(P.has(_.id)){const Z=n.find(ie=>ie.id===_.id),ae=(Q=Z==null?void 0:Z.data)==null?void 0:Q.expandedDimensions;if(ae)return{..._,style:{..._.style,width:ae.width,height:ae.height},data:{..._.data,isExpanded:!0,expandedDimensions:ae}}}return _});s([...F,...R])}else if(P.size>0){const F=E.map(_=>P.has(_.id)&&W[_.id]?{..._,data:{..._.data,isExpanded:!0,needsReExpansion:!0}}:_);s(F)}else s(E)}else s([])},[e,s]),u.useEffect(()=>{if(!d&&a&&a.length>0){const{expandedGroups:k}=ve.getState(),P=Tt(e),W=new Set(P.map(R=>R.id)),E=i.filter(R=>{var F,_;return((F=R.data)==null?void 0:F.isInternal)&&typeof((_=R.data)==null?void 0:_.originalGroupId)=="string"&&k.has(R.data.originalGroupId)&&W.has(R.data.originalGroupId)}),C=i.filter(R=>{var F,_;return((F=R.data)==null?void 0:F.redirectedToInternal)&&typeof((_=R.data)==null?void 0:_.originalTarget)=="string"&&k.has(R.data.originalTarget)&&W.has(R.data.originalTarget)});if(E.length>0||C.length>0){const R=a.filter(F=>!C.some(_=>{var Q;return((Q=_.data)==null?void 0:Q.originalTarget)===F.target}));m([...R,...E,...C])}else m(a)}},[a,m,d]);const $=u.useCallback((k,P,W=!1)=>{const C=i.filter(_=>_.target===P).length>0;if(i.some(_=>_.source===k&&_.target===P||_.source===P&&_.target===k)&&!W)return f.toast.warning("La tarea destino ya tiene una conexión"),!1;const F=!C;return typeof window<"u"&&(window.validConnectionTypes={dependiente:F,hija:F}),F?!0:(f.toast.warning("La tarea destino ya tiene una conexión de entrada"),!1)},[i]),Y=u.useCallback(k=>{if(!$r(k.source,k.target))return;et(k.source)&&!k.sourceHandle&&(k.sourceHandle=Te.DEFAULT_SOURCE_HANDLE);const P=n.find(E=>E.id===k.source),W=n.find(E=>E.id===k.target);if(P&&W){if(!$(k.source,k.target))return;X(k.source,k.target,k.sourceHandle,k.targetHandle);return}return m(E=>oe.addEdge(k,E))},[n,X,m,$]),z=u.useCallback((k,P)=>{var W;if(!N&&!P.isValid&&P.fromNode){const E=n.find(ae=>ae.id===P.fromNode.id);if((E==null?void 0:E.type)==="group"){f.toast.warning("En una plantilla, no se puede crear una conexión");return}const C=Ur(k),R=document.elementFromPoint(C.x,C.y);if(R!=null&&R.closest(".react-flow__node"))return;const F=crypto.randomUUID(),_=((W=P.fromHandle)==null?void 0:W.id)||Te.DEFAULT_SOURCE_HANDLE,Z=et(P.fromNode.id)?Te.DEFAULT_SOURCE_HANDLE:_;A(F,C,P.fromNode.id,Z)}},[N,A,n]),re=u.useCallback(async k=>{var C,R,F;const P=bs(k),W=k.length>0?(R=(C=k[0])==null?void 0:C.data)==null?void 0:R.id:0;m(_=>_.filter(Q=>!P.includes(Q.source)&&!P.includes(Q.target)));let E;for(const _ of k)try{const Q=_.data;if((F=Q==null?void 0:Q.plantilla)!=null&&F.id){E=Q.plantilla.id;break}}catch{}try{m(_=>((async()=>{await B(P,_,E,W)})().catch(Q=>{console.error("❌ Error en updateAfterDeleted:",Q)}),_))}catch(_){console.error("❌ Error en onDeleteNode:",_)}},[m,B]),ee=u.useCallback(async k=>{var W,E,C,R,F,_,Q,Z,ae,ie,J,se,te,fe;if(!k||k.length===0)return;let P;if(j!=null&&j.id)P=j.id;else for(const ce of k){const xe=n.find(ye=>ye.id===ce.source),we=n.find(ye=>ye.id===ce.target);if(xe!=null&&xe.data&&typeof xe.data=="object"&&"plantilla"in xe.data){const ye=xe.data.plantilla;if(ye!=null&&ye.id){P=ye.id;break}}if(we!=null&&we.data&&typeof we.data=="object"&&"plantilla"in we.data){const ye=we.data.plantilla;if(ye!=null&&ye.id){P=ye.id;break}}}if(!P){console.warn("⚠️ onEdgesDelete - No se pudo obtener templateId");return}try{const ce=await y(P);if(!ce){console.warn("⚠️ onEdgesDelete - Template no encontrado en IndexedDB");return}const xe=k.map(me=>me.id),we=((C=(E=(W=ce.graph_layout)==null?void 0:W.snapshot)==null?void 0:E.edges)==null?void 0:C.filter(me=>{var ge;return!xe.includes(me.id)&&!((ge=me.data)!=null&&ge.isInternal)}))||[],Oe=(((_=(F=(R=ce.graph_layout)==null?void 0:R.snapshot)==null?void 0:F.nodes)==null?void 0:_.filter(me=>{var ge;return!((ge=me.data)!=null&&ge.isInternal)&&!me.parentId}))||[]).map(me=>{const{style:ge,measured:Ie,data:he,...Be}=me,{expandedDimensions:Le,isExpanded:ct,needsReExpansion:_l,...Jt}=he||{},Bs=ge?{...ge,width:void 0,height:void 0,minWidth:void 0,minHeight:void 0}:void 0,Rs=me.data.id===k[0].data.childId?{...Jt,tarea_padre:null,id_t_requerida:null}:Jt;return{...Be,style:Bs,data:Rs}}),Ne=((Z=(Q=ce.graph_layout)==null?void 0:Q.snapshot)==null?void 0:Z.edges)||[];if(!(JSON.stringify(Ne)!==JSON.stringify(we)))return;const ue={...ce,graph_layout:{id:((ae=ce.graph_layout)==null?void 0:ae.id)||0,snapshot:{nodes:Oe,edges:we,viewport:((J=(ie=ce.graph_layout)==null?void 0:ie.snapshot)==null?void 0:J.viewport)||{x:0,y:0,zoom:1}},history:((se=ce.graph_layout)==null?void 0:se.history)||[],zoom:((te=ce.graph_layout)==null?void 0:te.zoom)||1,position:((fe=ce.graph_layout)==null?void 0:fe.position)||{x:0,y:0}},estatus:_e.DIRTY,updatedAt:new Date().toISOString()};await O({templateId:P,id:k[0].data.childId}),await w(P,ue),console.log("🗑️ [useFlow] Invalidando caché de la plantilla:",P),await v.invalidateQueries({queryKey:["template",P]}),await v.invalidateQueries({queryKey:["template"]}),console.log("✅ [useFlow] Caché invalidado exitosamente"),P===(j==null?void 0:j.id)&&b(ue)}catch(ce){console.error("❌ onEdgesDelete - Error al actualizar template layout:",ce)}},[n,j,y,w,b,O]),S=u.useCallback(async k=>!k.nodes.some(W=>W.type==="start"||W.id===Te.START_NODE_ID),[]),K=u.useCallback((k,P,W)=>{var F,_,Q;const E=n.find(Z=>Z.id===P.id);if(!E)return;if(E.type==="group"&&((F=E.data)!=null&&F.isExpanded)){m(Z=>Z.map(ae=>{if(ae.hidden&&ae.target===P.id){const{hidden:ie,...J}=ae;return J}return ae}));return}let C;if(E.type==="group"?C=j==null?void 0:j.id:(Q=(_=P==null?void 0:P.data)==null?void 0:_.plantilla)!=null&&Q.id&&(C=P.data.plantilla.id),!C)return;const R=i.map(Z=>{var J,se,te,fe,ce;if(Nt(Z))return Z;const ae=n.find(xe=>xe.id===Z.source),ie=n.find(xe=>xe.id===Z.target);if(ae&&ie){const xe=ae.type==="group"&&((J=ae.data)==null?void 0:J.isExpanded),we=ie.type==="group"&&((se=ie.data)==null?void 0:se.isExpanded),ye=(te=ae.data)==null?void 0:te.isInternal,Oe=(fe=ie.data)==null?void 0:fe.isInternal,Ne=(ce=Z.data)==null?void 0:ce.redirectedToInternal;if(xe||we||ye||Oe||Ne)return Z;if(ae.id===P.id||ie.id===P.id||p(ae,ie,Te.MAGNETIC_CONNECTION_DISTANCE)){const ue=x(ae,ie);if(ue!=null&&ue.handle1&&(ue!=null&&ue.handle2))return{...Z,sourceHandle:ue.handle1,targetHandle:ue.handle2}}}return Z});if(JSON.stringify(i)!==JSON.stringify(R))m(R),setTimeout(()=>{const Z=g();h(C,Z)},100);else{const Z=g();h(C,Z)}},[n,i,j,h,g,m,x,p]),G=u.useCallback(k=>{o(k);const P=Hr(k);if(P.length>0){const W=P.filter(E=>{var R;const C=n.find(F=>F.id===E);return(C==null?void 0:C.type)==="group"&&((R=C==null?void 0:C.data)==null?void 0:R.isExpanded)});if(W.length>0){m(E=>E.map(C=>{var _;const R=W.includes(C.target),F=!((_=C.data)!=null&&_.redirectedToInternal);return R&&F?{...C,hidden:!0}:C}));return}c(!0),setTimeout(()=>{const E=i.map(R=>{var Q,Z,ae,ie;if(Nt(R))return{...R};const F=n.find(J=>J.id===R.source),_=n.find(J=>J.id===R.target);if(F&&_){const J=F.type==="group"&&((Q=F.data)==null?void 0:Q.isExpanded),se=_.type==="group"&&((Z=_.data)==null?void 0:Z.isExpanded),te=(ae=F.data)==null?void 0:ae.isInternal,fe=(ie=_.data)==null?void 0:ie.isInternal;if(J||se||te||fe)return{...R};if(p(F,_,Te.MAGNETIC_CONNECTION_DISTANCE)){const ce=x(F,_);if(ce!=null&&ce.handle1&&(ce!=null&&ce.handle2)&&(R.sourceHandle!==ce.handle1||R.targetHandle!==ce.handle2))return{...R,sourceHandle:ce.handle1,targetHandle:ce.handle2}}}return{...R}});if(i.some((R,F)=>{const _=E[F];return R.sourceHandle!==_.sourceHandle||R.targetHandle!==_.targetHandle})){const R=E.map(F=>({...F,id:F.id}));m(R)}setTimeout(()=>{c(!1)},200)},0)}},[o,i,n,m,x,p,c]);return{nodes:n,edges:i,newNodePopup:H,connectionPopup:M,setNodes:s,setEdges:m,onEdgesChange:l,onConnect:Y,onConnectEnd:z,onDeleteNode:re,onEdgesDelete:ee,onBeforeDelete:S,handleNodesChange:G,onDragEnd:K,getParentNodeInfo:L,isProtectedConnection:Nt,isStartNode:et,createNodeFromPopup:V,updateNodeFromPopup:q,closeNewNodePopup:T,createConnectionFromPopup:D,closeConnectionPopup:U}},ei=({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,l)=>{(r==="tarea"?o.tarea[l]:o.plantilla[l])&&n(r,l)};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-surface-default tm-p-4",children:t.jsx("div",{children:t.jsxs(f.List,{children:[t.jsx("p",{className:"tm-text-sm tm-px-4 tm-font-medium tm-text-neutral-300",children:"Tarea"}),t.jsxs(f.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>i("tarea","dependiente"),children:["Dependiente ",!o.tarea.dependiente&&"(No disponible)"]}),t.jsxs(f.ListItem,{icon:de.faArrowDownRight,iconColor:"neutral",onClick:()=>i("tarea","hija"),children:["Hija ",!o.tarea.hija&&"(No disponible)"]}),t.jsx(f.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(f.ListItem,{icon:de.faArrowUpLeft,iconColor:"neutral",onClick:()=>i("plantilla","dependiente"),children:["Dependiente ",!o.plantilla.dependiente&&"(No disponible)"]})]})})})]})})},ti=({data:e,id:a,selected:n})=>{const{expandedGroups:s}=ve(),[o,i]=u.useState(!1),r=u.useRef(!1);u.useEffect(()=>{const g=(e==null?void 0:e.needsReExpansion)&&s.has(a),x=(e==null?void 0:e.templateId)||(e==null?void 0:e.id);if(g&&x&&!r.current){r.current=!0;const h=ve.getState().expandGroup;h&&h(a,x).catch(y=>{console.error("Error al re-expandir grupo:",y),r.current=!1})}s.has(a)||(r.current=!1)},[e,a,s]);const l=async g=>{g.preventDefault(),g.stopPropagation();const x=(e==null?void 0:e.templateId)||(e==null?void 0:e.id);if(x){i(!0);try{const p=ve.getState(),h=p.expandGroup,y=p.collapseGroup,w=s.has(a);w&&y?y(a):!w&&h&&await h(a,x)}catch{}finally{i(!1)}}},d=s.has(a),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 t.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:[t.jsx(lt,{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-surface-default ${d?"tm-opacity-0 tm-pointer-events-none":""}`,isConnectable:!d}),t.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}),t.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}),t.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&&t.jsxs("div",{className:"tm-flex tm-justify-between tm-gap-x-8 tm-p-16",children:[t.jsx(f.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(f.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(f.Button,{size:"sm",color:"secondary",pill:"pill",onClick:l,disabled:o,className:`tm-p-2 ${o?"tm-opacity-50":""} nopan nodrag`,icon:d?Se.faCompress:Se.faExpand})})]})]})},ai=(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:l,toggleGroupExpansion:d,setGroupTemplateData:c,clearGroupTemplateData:m}=ve(),g=le.useQueryClient(),{getTemplateWithTasks:x}=ds(),{hydrateTasks:p}=ps(),h=u.useCallback(async(b,v)=>{var O,H,M,N;try{await g.invalidateQueries({queryKey:["template",v]});const A=await x(v),T=(M=(H=(O=A==null?void 0:A.graph_layout)==null?void 0:O.snapshot)==null?void 0:H.nodes)==null?void 0:M.filter(_=>{var Q,Z;return((Q=_.data)==null?void 0:Q.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),!((N=A==null?void 0:A.graph_layout)!=null&&N.snapshot))throw new Error(`No se encontraron datos de graph_layout en la plantilla: ${v}`);const X=A.graph_layout.snapshot.nodes||[],U=X.filter(_=>{var J,se;const Q=(J=_.data)==null?void 0:J.isInternal,Z=!!_.parentId,ae=(se=_.id)==null?void 0:se.includes("-internal-"),ie=Q||Z||ae;return ie&&console.warn("🗑️ [expandGroup] Filtrando nodo corrupto:",{id:_.id,type:_.type,esInterno:Q,tieneParentId:Z,tieneInternalEnId:ae}),!ie}),L={...A,graph_layout:{...A.graph_layout,snapshot:{...A.graph_layout.snapshot,nodes:U,edges:(A.graph_layout.snapshot.edges||[]).filter(_=>{var Q,Z;return!((Q=_.data)!=null&&Q.isInternal)&&!((Z=_.id)!=null&&Z.includes("-internal-"))})}}},I=X.length-U.length;I>0?console.warn(`⚠️ [expandGroup] Se filtraron ${I} nodos internos corruptos de la BD para plantilla ${v}`):console.log(`✅ [expandGroup] No se encontraron nodos corruptos en plantilla ${v}`);const V=await p(L),D={...L,hydratedNodes:V,nodes:V||L.graph_layout.snapshot.nodes||[],edges:L.graph_layout.snapshot.edges||[]},q=D.nodes,B=D.edges;if(!q||!B){console.error("❌ No se encontraron nodos o edges en la plantilla:",v);return}c(b,{nodes:q,edges:B,viewport:D.graph_layout.snapshot.viewport||{x:0,y:0,zoom:1}});const $=o.current.find(_=>_.id===b);if(!$){console.error("❌ No se encontró el nodo grupo:",b);return}const Y=q.filter(_=>_.id!==b);let z=1/0,re=1/0,ee=-1/0,S=-1/0;Y.forEach(_=>{var ce,xe,we,ye,Oe,Ne;const Q=((ce=_.position)==null?void 0:ce.x)||0,Z=((xe=_.position)==null?void 0:xe.y)||0,ae=typeof((we=_.style)==null?void 0:we.width)=="number"?_.style.width:((ye=_.measured)==null?void 0:ye.width)||268,ie=typeof((Oe=_.style)==null?void 0:Oe.height)=="number"?_.style.height:((Ne=_.measured)==null?void 0:Ne.height)||111,J=Q-ae/2,se=Q+ae/2,te=Z,fe=Z+ie;z=Math.min(z,J),re=Math.min(re,te),ee=Math.max(ee,se),S=Math.max(S,fe)});const K=80,G=60,k=ee-z,P=S-re,W=k+K*2,E=P+K*2+G,C=q.map((_,Q)=>{var ce,xe;if(_.id===b)return null;const Z=((ce=_.position)==null?void 0:ce.x)||0,ae=((xe=_.position)==null?void 0:xe.y)||0,ie=Z-z+K,J=ae-re+K+G,se=_.type==="start"||_.id==="start",te=se?{..._.data,estatus:$.data.estatus,updatedAt:$.data.updatedAt,createdAt:$.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:te,draggable:!1,selectable:se,selected:!1,deletable:!1,connectable:!1,focusable:se,zIndex:999}}).filter(Boolean),R=B.map(_=>{const Q=C.some(ie=>ie&&ie.id===`${b}-internal-${_.source}`),Z=C.some(ie=>ie&&ie.id===`${b}-internal-${_.target}`);return!Q||!Z?null:{..._,id:`${b}-internal-${_.id}`,source:`${b}-internal-${_.source}`,target:`${b}-internal-${_.target}`,style:{..._.style},data:{..._.data,isInternal:!0,originalGroupId:b}}}).filter(Boolean),F=C.find(_=>{var Q;return _&&((Q=_.data)==null?void 0:Q.originalNodeId)==="start"});F&&s(_=>_.map(Q=>Q.target===b?{...Q,target:F.id,targetHandle:"top-target",data:{...Q.data,redirectedToInternal:!0,originalTarget:b,originalTargetHandle:Q.targetHandle}}:Q)),d(b),n(_=>[..._.map(Z=>{if(Z.id===b){const{needsReExpansion:ae,...ie}=Z.data||{};return{...Z,style:{...Z.style,width:W,height:E},data:{...ie,isExpanded:!0,expandedDimensions:{width:W,height:E}},zIndex:1e3}}return Z}),...C]),s(_=>[..._,...R])}catch(A){console.error("❌ Error al expandir el grupo:",A)}},[g,x,p,c,d,n,s]),y=u.useCallback(b=>{var T,X;const v=o.current,O=i.current,H=v.find(U=>U.id===b),M=((T=H==null?void 0:H.data)==null?void 0:T.templateId)||((X=H==null?void 0:H.data)==null?void 0:X.id),N=v.filter(U=>!U.id.startsWith(`${b}-internal-`)&&U.parentId!==b).map(U=>U.id===b?{...U,style:{...U.style,width:void 0,height:void 0},data:{...U.data,isExpanded:!1,expandedDimensions:void 0},zIndex:void 0}:U),A=O.filter(U=>!U.id.startsWith(`${b}-internal-`)).map(U=>{var L,I;if((L=U.data)!=null&&L.redirectedToInternal&&((I=U.data)==null?void 0:I.originalTarget)===b){const{redirectedToInternal:V,originalTarget:D,originalTargetHandle:q,...B}=U.data;return{...U,target:b,targetHandle:q||U.targetHandle,data:B}}return U});n(N),s(A),d(b),m(b),M&&g.invalidateQueries({queryKey:["template",M]})},[n,s,d,m,g]),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}},si=()=>{const{getNodes:e,setNodes:a,screenToFlowPosition:n,setCenter:s}=oe.useReactFlow(),{copiedNodes:o,setCopiedNodes:i,getViewMode:r}=ve(),{activeTemplate:l,setActiveTemplate:d}=qe(),{updateGraphLayout:c,get:m,update:g}=ze(),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(N=>N.selected).filter(N=>!(N.type==="start"||N.id==="start"||N.type==="group")),[e]),y=u.useCallback(()=>{if(x==="readonly"){f.toast.error("No puedes copiar tareas en modo solo lectura");return}if(!l){f.toast.error("No hay una plantilla activa");return}const O=h();if(O.length===0){const M=e().filter(N=>N.selected);if(M.length>0){const N=M.some(T=>T.type==="group"),A=M.some(T=>T.type==="start"||T.id==="start");N?f.toast.error("Las plantillas conectadas no pueden ser copiadas"):A&&f.toast.error("El nodo de inicio no puede ser copiado")}else f.toast.error("No hay tareas seleccionadas para copiar");return}const H=O.map(M=>{const{selected:N,...A}=M;return{...A,data:{...A.data,_originalTemplateId:l.id}}});i(H),f.toast.success(`${O.length} ${O.length===1?"tarea copiada":"tareas copiadas"} con éxito`)},[x,l,h,e,i]),w=u.useCallback(async O=>{if(x==="readonly"){f.toast.error("No puedes pegar tareas en modo solo lectura");return}if(!l){f.toast.error("No hay una plantilla activa");return}if(o.length===0){f.toast.error("No hay tareas copiadas para pegar");return}const H=e();let M={x:0,y:0};if(O)M=n({x:O.x,y:O.y});else if(H.length>0){const I=H.reduce((D,q)=>D+q.position.x,0)/H.length,V=H.reduce((D,q)=>D+q.position.y,0)/H.length;M={x:I+50,y:V+100}}const N=o[0],A=M.x-N.position.x,T=M.y-N.position.y,X=o.map((I,V)=>{const D=p(),q=-(Date.now()+V),B=I.data.plantilla&&typeof I.data.plantilla=="object"?{...I.data.plantilla,id:l.id}:{id:l.id},{id:$,...Y}=I.data,z={...Y,id:q,reference_graph:D,plantilla:B,parent:{data:{id:null}},_originalTemplateId:void 0};return{...I,id:D,position:{x:I.position.x+A,y:I.position.y+T},data:z,selected:!0}}),L=[...H.map(I=>({...I,selected:!1})),...X];if(a(L),l.id)try{const I=await m(l.id);if(!I)return;const V=X.filter(q=>q.type!=="start"&&q.type!=="group").map(q=>{const B=q.data;return{id:B.id,reference_graph:q.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}}),D={...I,tarea_plantillas:[...I.tarea_plantillas,...V],estatus:"dirty",updatedAt:new Date().toISOString()};await g(l.id,D),d(D),setTimeout(async()=>{await c(l.id,{nodes:L,edges:[]})},50)}catch(I){console.error("Error al actualizar template en IndexedDB:",I)}if(X.length>0){const I=X.reduce((D,q)=>D+q.position.x,0)/X.length,V=X.reduce((D,q)=>D+q.position.y,0)/X.length;s(I,V,{zoom:1,duration:800})}f.toast.success(`${X.length} ${X.length===1?"tarea pegada":"tareas pegadas"} con éxito`)},[x,l,o,e,a,n,s,p,c,m,g,d]),j=u.useCallback(()=>o.length>0,[o]),v=h().length>0;return{handleCopy:y,handlePaste:w,hasCopiedNodes:j,hasSelectableNodes:v,copiedNodesCount:o.length}},ni={main:Kr,plus:Gr,start:Xr,group:ti},oi=[.5,0],ri=({initialNodes:e,initialEdges:a,debugEvents:n=!1})=>{var Ne,$e;const s=u.useRef(null),{nodes:o,edges:i,onEdgesChange:r,onConnect:l,onConnectEnd:d,onBeforeDelete:c,onDeleteNode:m,onEdgesDelete:g,handleNodesChange:x,newNodePopup:p,getParentNodeInfo:h,createNodeFromPopup:y,closeNewNodePopup:w,connectionPopup:j,createConnectionFromPopup:b,closeConnectionPopup:v,onDragEnd:O,setNodes:H,setEdges:M}=Zr({initialNodes:e,initialEdges:a}),{expandGroup:N,collapseGroup:A}=ai(o,i,H,M),{handleCopy:T,handlePaste:X,hasCopiedNodes:U,copiedNodesCount:L}=si();u.useEffect(()=>{if(!n)return;const ue=he=>{console.log("🔍 [DEBUG] KeyDown:",{key:he.key,code:he.code,shiftKey:he.shiftKey,ctrlKey:he.ctrlKey,metaKey:he.metaKey,altKey:he.altKey,target:he.target,defaultPrevented:he.defaultPrevented,bubbles:he.bubbles,timestamp:new Date().toISOString()})},me=he=>{console.log("🔍 [DEBUG] KeyUp:",{key:he.key,code:he.code,shiftKey:he.shiftKey,timestamp:new Date().toISOString()})},ge=he=>{var Be,Le;console.log("🔍 [DEBUG] Click:",{button:he.button,shiftKey:he.shiftKey,ctrlKey:he.ctrlKey,metaKey:he.metaKey,altKey:he.altKey,target:(Be=he.target)==null?void 0:Be.tagName,targetClass:(Le=he.target)==null?void 0:Le.className,defaultPrevented:he.defaultPrevented,bubbles:he.bubbles,timestamp:new Date().toISOString()})},Ie=he=>{console.log("🔍 [DEBUG] MouseDown:",{button:he.button,shiftKey:he.shiftKey,ctrlKey:he.ctrlKey,metaKey:he.metaKey,defaultPrevented:he.defaultPrevented,timestamp:new Date().toISOString()})};return document.addEventListener("keydown",ue,!0),document.addEventListener("keyup",me,!0),document.addEventListener("click",ge,!0),document.addEventListener("mousedown",Ie,!0),console.log("🔍 [DEBUG] Event listeners activados. Presiona Shift + Click en un nodo para ver los eventos."),()=>{document.removeEventListener("keydown",ue,!0),document.removeEventListener("keyup",me,!0),document.removeEventListener("click",ge,!0),document.removeEventListener("mousedown",Ie,!0),console.log("🔍 [DEBUG] Event listeners desactivados.")}},[n]);const V=o.filter(ue=>!(!ue.selected||ue.type==="start"||ue.id==="start"||ue.type==="group")).length,D=V>0,q=u.useRef(N),B=u.useRef(A);u.useEffect(()=>{q.current=N,B.current=A},[N,A]),u.useEffect(()=>{const ue=async(ge,Ie)=>{q.current&&await q.current(ge,Ie)},me=ge=>{B.current&&B.current(ge)};ve.setState({expandGroup:ue,collapseGroup:me})},[]);const{getViewMode:$,setFlowViewportForTemplate:Y}=ve(),{activeTemplate:z}=qe(),re=(z==null?void 0:z.id)??null,ee=ve(ue=>re!=null?ue.flowViewportByTemplateId[re]:void 0),S=u.useMemo(()=>{var me,ge;if(re==null)return;if(ee)return ee;const ue=(ge=(me=z==null?void 0:z.graph_layout)==null?void 0:me.snapshot)==null?void 0:ge.viewport;if(ue&&typeof ue.x=="number"&&typeof ue.y=="number"&&typeof ue.zoom=="number")return{x:ue.x,y:ue.y,zoom:ue.zoom}},[re,ee,($e=(Ne=z==null?void 0:z.graph_layout)==null?void 0:Ne.snapshot)==null?void 0:$e.viewport]),K=u.useCallback((ue,me)=>{re!=null&&Y(re,me)},[re,Y]),{zoomPercentage:G,handleZoomIn:k,handleZoomOut:P,handleZoomTo100:W,handleDoubleClick:E}=Qr({reactFlowWrapper:s,nodes:o,resetZoomHistoryKey:re}),R=(z!=null&&z.id?$(z.id):"readonly")==="readonly";u.useEffect(()=>{if(R)return;const ue=me=>{const ge=me.target;ge.tagName==="INPUT"||ge.tagName==="TEXTAREA"||ge.isContentEditable||((me.ctrlKey||me.metaKey)&&me.key==="c"&&(me.preventDefault(),T()),(me.ctrlKey||me.metaKey)&&me.key==="v"&&(me.preventDefault(),X()))};return document.addEventListener("keydown",ue),()=>{document.removeEventListener("keydown",ue)}},[T,X,R]);const F=u.useCallback((ue,me)=>{const ge=ue.target;ge.tagName==="BUTTON"||ge.closest("button")||ge.closest('[role="button"]')||ge.classList.contains("nopan")||ge.classList.contains("nodrag")},[]),_=u.useCallback(ue=>{const me=ue.filter(ge=>{var Ie,he;if(ge.type==="position"&&ge.dragging===!1){const Be=o.find(Le=>Le.id===ge.id);if(Be&&ge.position){const Le=Math.abs((ge.position.x||0)-(((Ie=Be.position)==null?void 0:Ie.x)||0)),ct=Math.abs((ge.position.y||0)-(((he=Be.position)==null?void 0:he.y)||0));if(Le<3&&ct<3)return!1}}return!0});me.length>0&&x(me)},[x,o]),Q=R?void 0:r,Z=R?void 0:_,ae=R?void 0:l,ie=R?void 0:d,J=R?void 0:c,se=R?void 0:O,te=R?void 0:m,fe=R?void 0:g,ce=R?null:["Backspace","Delete"],ye=R?{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},Oe=()=>{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:ni,onEdgesChange:Q,onNodesChange:Z,onConnect:ae,onConnectEnd:ie,onBeforeDelete:J,onNodeDragStop:se,onNodesDelete:te,onEdgesDelete:fe,onNodeClick:F,onMoveEnd:K,...ye,...S?{defaultViewport:S,fitView:!1}:{fitView:!0,fitViewOptions:{padding:2}},nodeOrigin:oi,defaultEdgeOptions:{type:"smoothstep"},connectionLineType:oe.ConnectionLineType.SmoothStep,deleteKeyCode:ce,multiSelectionKeyCode:R?null:"Shift",selectionOnDrag:!1,panOnDrag:R?!0:[0],nodeClickDistance:15,selectNodesOnDrag:!1,nodeDragThreshold:10,autoPanOnNodeDrag:!1,autoPanOnConnect:!1,noDragClassName:"nodrag",noWheelClassName:"nowheel",noPanClassName:"nopan",children:[t.jsx(oe.Background,{}),!R&&t.jsx(oe.Panel,{position:"bottom-left",className:"tm-m-0",children:t.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:[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-8",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-8",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-8",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===Ae.PUBLISHED&&t.jsx(f.Tag,{color:"success",label:"Publicado"}),z.estatusFromStrapi===Ae.DRAFT&&t.jsx(f.Tag,{color:"warning",label:"Borrador"})]}),!R&&V>0&&t.jsxs("p",{className:"tm-text-blue-dark-500 tm-text-xs tm-font-medium",children:[V," ",V===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:[!R&&t.jsxs(f.ButtonGroup,{children:[t.jsxs(f.Button,{leftSlot:de.faCopy,onClick:T,disabled:!D,size:"xxs",color:D?"primary":"secondary",title:D?`Copiar ${V} ${V===1?"tarea":"tareas"} (Ctrl+C)`:"Selecciona tareas para copiar (mantén Shift y haz clic)",children:["Copiar ",V>0&&`(${V})`]}),t.jsxs(f.Button,{leftSlot:de.faFile,size:"xxs",onClick:()=>X(),disabled:!U(),color:U()?"primary":"secondary",title:U()?`Pegar ${L} ${L===1?"tarea":"tareas"} (Ctrl+V)`:"No hay tareas copiadas",children:["Pegar ",L>0&&`(${L})`]})]}),t.jsxs(f.ButtonGroup,{color:"secondary",size:"xxs",children:[t.jsx(f.Button,{icon:de.faMinus,onClick:P,color:"secondary"}),t.jsxs(f.Button,{onClick:W,onDoubleClick:E,color:"secondary",children:[G,"%"]}),t.jsx(f.Button,{icon:de.faPlus,onClick:k})]})]})})]},re??"flow-none"),p&&t.jsx(Wr,{isOpen:p.isOpen,position:p.position,onClose:w,createNodeFromPopup:y,parentNodeInfo:h()}),j&&t.jsx(ei,{isOpen:j.isOpen,onClose:v,createConnectionFromPopup:b,availableConnections:Oe()})]})},ii=({initialNodes:e,initialEdges:a,debugEvents:n})=>t.jsx(oe.ReactFlowProvider,{children:t.jsx(ri,{initialNodes:e,initialEdges:a,debugEvents:n})}),rt=We.create(e=>({step:1,setStep:a=>e({step:a}),reset:()=>e({step:1})})),li=({limit:e})=>{const a=rt(r=>r.step),n=rt(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])},_a=["fase_plantilla","tipo_plantilla","categoria","tipo_medio","medio_especifico","pertenencia_medio","ubicacion_medio","responsable_impresion"],Ta=["fase_plantilla","modo_configuracion","tipo_medio","formato_salida"],Na=["tipo_medio","formato_salida","medio_especifico"],Ca={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"]}}},Sa={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 Qt(e){const[a,n]=u.useState([]),[s,o]=u.useState({}),{setClaveParams:i,templateFormData:r,setTemplateFormData:l,resetTemplateFormData:d,setDisableField:c,setClave:m,claveParams:g,setParamTipo:x}=ke(),{tasks_api:p}=pe(),h=rt(S=>S.step),{data:y,error:w,isSuccess:j,isError:b}=le.useQuery({queryKey:["paramsTipoPlantilla"],queryFn:async()=>{const S=Ee.stringify({populate:{params_plantillas:{fields:["id","abbreviation","name","active","tipomedio_nombre","reference_id"]}},sort:["order:asc"],fields:["id","step","key","label","order"]},{encodeValuesOnly:!0}),K=await p.get(`/api/params-tipos?${S}`);return K.data?{paramsTiposPlantilla:be(K.data.data)}:{paramsTiposPlantilla:[]}},refetchOnWindowFocus:!1});u.useEffect(()=>{w&&b&&console.log(w)},[w,b]),u.useEffect(()=>{if(y&&j){const S=y.paramsTiposPlantilla;n(S)}},[y,j]);const v={fase_plantilla:(S,K)=>{l({fase_plantilla:S}),x({fase_plantilla:K})},tipo_plantilla:(S,K)=>{l({tipo_plantilla:S}),x({tipo_plantilla:K})},modo_configuracion:(S,K)=>{l({modo_configuracion:S}),x({modo_configuracion:K})},categoria:(S,K)=>{l({categoria:S}),x({categoria:K})},formato_salida:(S,K)=>{l({formato_salida:S}),x({formato_salida:K})},tipo_medio:(S,K)=>{l({tipo_medio:S}),x({tipo_medio:K})},medio_especifico:(S,K)=>{l({medio_especifico:S}),x({medio_especifico:K})},responsable_impresion:(S,K)=>{l({responsable_impresion:S}),x({responsable_impresion:K})},pertenencia_medio:(S,K)=>{l({pertenencia_medio:S}),x({pertenencia_medio:K})},ubicacion_medio:(S,K)=>{l({ubicacion_medio:S}),x({ubicacion_medio:K})}},O={fase_plantilla:(S,K)=>i({field:S,value:K}),tipo_plantilla:(S,K)=>i({field:S,value:K}),categoria:(S,K)=>i({field:S,value:K}),tipo_medio:(S,K)=>i({field:S,value:K}),medio_especifico:(S,K)=>i({field:S,value:K}),responsable_impresion:(S,K)=>i({field:S,value:K}),pertenencia_medio:(S,K)=>i({field:S,value:K}),ubicacion_medio:(S,K)=>i({field:S,value:K})},H={Digital:{execute:()=>{const S=a.filter(k=>k.step===3).find(k=>k.key==="responsable_impresion").params_plantillas.find(k=>k.name==="N/A").id,K="step3.responsable_impresion",G=["responsable_impresion"];l({responsable_impresion:"N/A"}),e(K,S),c({fields:G,value:!0}),i({field:"responsable_impresion",value:"NA"})}},Impreso:{execute:()=>{const S="step3.responsable_impresion",K=["responsable_impresion"];l({responsable_impresion:""}),e(S,""),c({fields:K,value:!1}),i({field:"responsable_impresion",value:""})}}},M={"Sitios Fijos":{execute:()=>L()},"Vallas Móviles":{execute:()=>I()},Indoors:{execute:()=>L()},Camiones:{execute:()=>V()},"Brand Riders":{execute:()=>V()}},N={"Sitios Fijos":{execute:()=>U()},"Vallas Móviles":{execute:()=>U()},Indoors:{execute:()=>U()},Camiones:{execute:()=>{X(),H.Impreso.execute()}},"Brand Riders":{execute:()=>{X(),H.Impreso.execute()}}},A={"Sitios Fijos":{execute:()=>T()},"Vallas Móviles":{execute:()=>X()},Indoors:{execute:()=>T()},Camiones:{execute:()=>X()},"Brand Riders":{execute:()=>X()}},T=()=>{const S=["medio_especifico"],K=r.modo_configuracion,G=`step${h}.medio_especifico`,k=`step${h}.formato_salida`;c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0}),c(K==="Default"?{fields:S,value:!0}:{fields:S,value:!1}),l({medio_especifico:""}),l({formato_salida:""}),e(G,""),e(k,""),i({field:"medio_especifico",value:""}),i({field:"formato_salida",value:""})},X=()=>{const S=a.filter(W=>W.step===h).find(W=>W.key==="formato_salida").params_plantillas.find(W=>W.name==="Impreso").id;c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0});const G=`step${h}.formato_salida`,k=["formato_salida","medio_especifico"],P=`step${h}.medio_especifico`;l({medio_especifico:""}),l({formato_salida:"Impreso"}),e(G,S),e(P,""),i({field:"medio_especifico",value:""}),i({field:"tipo_medio",value:r.tipo_medio}),c({fields:k,value:!0})},U=()=>{const S=["formato_salida"],K=`step${h}.formato_salida`,G={};G.formato_salida="",l(G),e(K,""),c({fields:S,value:!1})},L=()=>{const S=["formato_salida","medio_especifico"],K=`step${h}.formato_salida`,G={};G.formato_salida="",l(G),e(K,""),c({fields:S,value:!1})},I=()=>{const S=["formato_salida"],K=["medio_especifico"],G=`step${h}.formato_salida`,k=`step${h}.medio_especifico`,P={};P.formato_salida="",P.medio_especifico="",l(P),e(G,""),e(k,""),c({fields:S,value:!1}),c({fields:K,value:!0})},V=()=>{const S=a.filter(P=>P.step===h).find(P=>P.key==="formato_salida").params_plantillas.find(P=>P.name==="Impreso").id,K=`step${h}.formato_salida`,G=`step${h}.medio_especifico`,k=["formato_salida","medio_especifico"];l({formato_salida:"Impreso"}),e(K,S),e(G,""),c({fields:k,value:!0}),H.Impreso.execute()},D=(S,K)=>{Object.keys(Ca).includes(S)&&Ca[S][K].fieldsToClear.forEach(P=>{const W={};W[P]="",l(W),i({field:P,value:""}),e&&[...new Set(a.map(C=>C.step))].forEach(C=>{const R=`step${C}.${P}`;e(R,"")})})},q=(S,K,G)=>S==="modo_configuracion"&&G?Sa[S][G][K].fieldsToEnableDisable:Sa[S][K].fieldsToEnableDisable,B=S=>a.filter(K=>K.step===S),$=S=>{var K;return s[S]||((K=a.find(G=>G.key===S))==null?void 0:K.params_plantillas)},Y=(S,K)=>{var k,P,W,E;let G=[];S==="Sitios Fijos"?K==="Preventa"?G=(k=a.find(C=>C.key==="medio_especifico"))==null?void 0:k.params_plantillas.filter(C=>C.tipomedio_nombre==="OOH"&&C.name==="PANTALLA DIGITAL"):K==="Venta"&&(G=(P=a.find(C=>C.key==="medio_especifico"))==null?void 0:P.params_plantillas.filter(C=>C.tipomedio_nombre==="OOH")):S==="Indoors"?G=(W=a.find(C=>C.key==="medio_especifico"))==null?void 0:W.params_plantillas.filter(C=>C.tipomedio_nombre==="InDoor"):G=(E=a.find(C=>C.key==="medio_especifico"))==null?void 0:E.params_plantillas,o(C=>({...C,medio_especifico:G}))},z=(S,K)=>{const G=S.key;if(Na.includes(G)&&G==="tipo_medio"){const k=K.label,P=r.fase_plantilla,W=r.modo_configuracion;if(P==="Preventa"){Y(k,P);return}else if(W==="Especifico"){Y(k,P);return}}},re=(S,K,G)=>{const k=S.params_plantillas.find(P=>S.key==="categoria"?P.reference_id===K.value:P.id===K.value);if(k){const P=S.key,W=K.label;if(v[P](W,G),Ta.includes(P))if(D(P,W),P==="fase_plantilla"){const E=W,C=q(P,E);c({fields:["categoria","modo_configuracion","tipo_plantilla"],value:!0}),C.length>0&&c({fields:C,value:!1}),E==="Preventa"&&c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0})}else if(P==="modo_configuracion"){const E=W,C=r.fase_plantilla,R=q(P,E,C);c({fields:["medio_especifico","formato_salida"],value:!0}),R.length>0&&c({fields:R,value:!1}),C==="Preventa"&&c({fields:["pertenencia_medio","ubicacion_medio","responsable_impresion"],value:!0})}else if(P==="tipo_medio"){const E=W,C=r.modo_configuracion;r.fase_plantilla==="Venta"?C==="Especifico"?M[E].execute():N[E].execute():A[E].execute()}else if(P==="formato_salida")H[W].execute();else{const E=q(P,W);E.length>0&&c({fields:E,value:!1})}if(_a.includes(P)){let E="",C="";if(P==="formato_salida"){const R=r.modo_configuracion,F=W;C="tipo_medio",E=R==="Default"&&F==="Digital"?E="DDG":E="DRP"}else C=P,E=k.abbreviation;O[C](C,E)}Na.includes(P)&&z(S,K)}},ee=()=>{if(r){const S=r.fase_plantilla;if(S==="Preventa"){const K=r.modo_configuracion,G=g.fase_plantilla||"XX";let k=null;if(K==="Default")k=g.tipo_medio||"XXX";else{const W=r.tipo_medio;["Vallas Móviles","Camiones","Brand Riders"].includes(W)?k=g.tipo_medio||"XXX":k=g.medio_especifico||"XXX"}const P=`${G}-${k}`;m(P)}if(S==="Venta"){const K=g.fase_plantilla||"XX",G=g.tipo_plantilla||"XXX",k=g.categoria||"XX",P=g.medio_especifico||g.tipo_medio||g.modo_configuracion||"XXX",W=g.responsable_impresion||"XX",E=g.pertenencia_medio||"X",C=g.ubicacion_medio||"X",R=`${K}-${G}-${k}-${P}-${W}-${E}-${C}`;m(R)}}};return u.useEffect(()=>{ee()},[g]),{templateFields:a,getFieldsByStep:B,dropdownFunctionsUpdateClave:O,fieldsForUpdateClave:_a,resetTemplateFormData:d,fieldsWithDisableTrigger:Ta,getFieldsToDisable:q,handleOptionSelected:re,getFilteredOptions:$,dropdownFunctionsUpdateFormData:v}}const Xt=()=>{const{control:e,setValue:a}=Pe.useFormContext(),n=rt(c=>c.step),{getFieldsByStep:s,handleOptionSelected:o,getFilteredOptions:i}=Qt(a),{disabledFields:r}=ke(),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}`,g=c.label,p=i(c.key).map(h=>({label:h.name,value:c.key==="categoria"?h.reference_id:h.id}));return t.jsx(Pe.Controller,{name:m,control:e,rules:{required:{value:!r[c.key],message:d(g)},validate:h=>r[c.key]||h?!0:d(g)},render:({field:h,fieldState:{error:y}})=>t.jsx("div",{children:t.jsx(f.Dropdown,{label:g,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)})},ci=()=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:t.jsx(Xt,{})}),di=()=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:t.jsx(Xt,{})}),mi=()=>t.jsx("div",{className:"tm-flex tm-flex-col tm-gap-y-4",children:t.jsx(Xt,{})}),ui=({step:e})=>t.jsxs("div",{className:"tm-flex tm-min-h-[270px] tm-flex-col tm-gap-y-4",children:[e===1&&t.jsx(ci,{}),e===2&&t.jsx(di,{}),e===3&&t.jsx(mi,{})]}),pi=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},{})},fi=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},gi=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 hi(e,a){const{clave:n,paramsTipo:s,currentTemplateForEdit:o,isEditTemplate:i,setDisableField:r,setClaveParams:l,isDuplicateTemplate:d,templateFormData:c}=ke(),{tasks_api:m}=pe(),{getFieldsByStep:g,dropdownFunctionsUpdateFormData:x,templateFields:p}=Qt(),h=()=>{var M;try{const N={},A=e(),T=fi(A),{step1:X}=T,U=[];N.clave=n,X.categoria!=""&&(N.categoria=X.categoria);for(const[L,I]of Object.entries(T))for(const[V,D]of Object.entries(I)){const q={id:null,params_tipo:{id:null}};if(D!=""){const B=s[V];if(V==="categoria"){const $=p.find(z=>z.key==="categoria"),Y=(M=$==null?void 0:$.params_plantillas)==null?void 0:M.find(z=>z.reference_id===D);q.id=Y==null?void 0:Y.id}else q.id=D;q.params_tipo.id=B,U.push(q)}}return Object.keys(U).length>0&&(N.params_plantillas=U),N}catch(N){console.log(N)}},y=async M=>{var N;try{let A=null;return i?A=await m.put(`/api/plantillas/${o.id}`,{data:M}):A=await m.post("/api/plantillas",{data:M}),A.data?be(A.data):null}catch(A){throw console.error("Error en saveTemplateToStrapi:",{error:A.message,status:(N=A.response)==null?void 0:N.status}),A}},w=async M=>{var N;try{const A=Ee.stringify({filters:{plantilla:{id:M}},populate:{graph_layout:!0}},{encodeValuesOnly:!0}),T=await m.get(`/api/plantillas/plantilla-tareas-grafico?${A}`);return T.data?be(T.data.data):null}catch(A){throw console.error("Error en getTemplateWithTasks:",{error:A.message,status:(N=A.response)==null?void 0:N.status}),A}},j=async(M,N,A)=>{var T,X,U,L,I,V,D;try{const q=await w(M),B=await w(N);if(!q||!q.tarea_plantillas)return console.warn("No se encontraron tareas para duplicar en la plantilla original"),null;const $=new Map,Y=new Map;let z=1;q.tarea_plantillas.forEach(G=>{let k=null;G.start?k=A:k=-(Date.now()+z++),$.set(G.id,k)}),(X=(T=q.graph_layout)==null?void 0:T.snapshot)!=null&&X.nodes&&q.graph_layout.snapshot.nodes.forEach(G=>{const k=`node-${Date.now()}-${Math.random().toString(36).substr(2,9)}`;Y.set(G.id,k)});const re=q.tarea_plantillas.filter(G=>!G.start).map(G=>{var P,W,E,C;return{id:$.get(G.id),uuid:crypto.randomUUID(),reference_graph:G.reference_graph,texto_corto:G.texto_corto,texto_largo:G.texto_largo||null,prioridad:G.prioridad,nivel_dificultad:G.nivel_dificultad,duracion:G.duracion,start:G.start,type:G.type||"task",equipo:((P=G.equipo)==null?void 0:P.id)||null,responsable:((W=G.responsable)==null?void 0:W.id)||null,plantilla:{id:N,clave:q.clave,categoria:q.categoria||{id:0,nombre:"Sin categoría"}},plantilla_dependents:[],id_t_requerida:$.get((E=G.id_t_requerida)==null?void 0:E.id)||null,ids_t_dependientes:[],tarea_padre:$.get((C=G.tarea_padre)==null?void 0:C.id)||null,tareas:[]}});let ee=null;if(q.graph_layout){const G=B.tarea_plantillas.find(k=>k.start===!0);ee={...q.graph_layout,id:(U=B.graph_layout)==null?void 0:U.id,snapshot:{...q.graph_layout.snapshot,edges:q.graph_layout.snapshot.edges.map(k=>{if(k.source==="start")return{...k,data:{...k.data,childId:re.find(P=>P.reference_graph===k.target).id,parentId:G.id}};{const P=re.find(W=>W.reference_graph===k.target);return{...k,data:{...k.data,childId:P==null?void 0:P.id,parentId:(P==null?void 0:P.id_t_requerida)||(P==null?void 0:P.tarea_padre)}}}}),nodes:((I=(L=q.graph_layout.snapshot)==null?void 0:L.nodes)==null?void 0:I.map(k=>{let P={};return k.type==="start"?P={...k,data:{...k.data,tareaId:G.id}}:P={...k,data:{tareaId:null}},P}))||[]}}}if(!ee)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 S={graph_layout:ee,tasks:{created:re,updated:[],deleted:[]}},K=await m.post("/api/tareas/save-tareas-grafico",{data:S});if(K.data&&K.status===200){const G=await w(N),k=new Map;G.tarea_plantillas.forEach(E=>k.set(E.reference_graph,E.id));let P=G.graph_layout;return(!((V=P==null?void 0:P.snapshot)!=null&&V.nodes)||P.snapshot.nodes.length===0)&&(console.log("Graph layout vacío, reconstruyendo desde el original..."),P=ee),(D=P==null?void 0:P.snapshot)!=null&&D.nodes&&(P.snapshot.nodes=P.snapshot.nodes.map(E=>{var _;const C={...E,position:E.position||{x:0,y:0}},R=C.id,F=k.get(R);if(F)return{...C,data:{...C.data,id:F,tareaId:F}};if((_=C.data)!=null&&_.tareaId){const Q=G.tarea_plantillas.find(Z=>Z.reference_graph===R);if(Q)return{...C,data:{...C.data,id:Q.id,tareaId:Q.id}}}return C})),await m.put(`/api/plantillas/${N}`,{data:{graph_layout:P}}),await w(N)}return null}catch(q){throw console.error("Error al duplicar las tareas de la plantilla:",q),q}},b=async()=>{var M,N;try{let A=h();const T=await y(A);if(!T)return{success:!1,message:"No se pudo guardar el flujo de trabajo en Strapi",error:"templateData es null"};const X=Ee.stringify({filters:{id:{$eq:T.id}},populate:{tarea_plantillas:{filters:{start:{$eq:!0}}}}},{encodeValuesOnly:!0}),{data:U}=await m.get(`/api/plantillas?${X}`),I=be(U.data)[0].tarea_plantillas[0].id;if(d&&(o!=null&&o.id))try{const D=await j(o.id,T.id,I);return D?{success:!0,message:"Flujo de trabajo duplicado completamente con todas sus tareas",data:D}:{success:!0,message:"Flujo de trabajo creado, pero no se pudieron duplicar las tareas",data:await w(T.id)}}catch(D){return console.error("Error al duplicar tareas:",D),{success:!0,message:"Flujo de trabajo creado, pero hubo un error al duplicar las tareas",data:await w(T.id)}}const V=await w(T.id);return V?{success:!0,message:"Flujo de trabajo creado y sincronizado completamente",data:V}:{success:!1,message:"No se pudieron obtener los datos completos del flujo de trabajo",error:"completeData es null"}}catch(A){const T=gi(((N=(M=A==null?void 0:A.response)==null?void 0:M.data)==null?void 0:N.error)||A);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||A.message}}},v=()=>{const M=o==null?void 0:o.params_plantillas;if(!(M!=null&&M.length))return;let N={};[1,2,3].forEach(T=>{const X=`step${T}`;N[X]={},g(T).forEach(L=>{var V;const I=M.find(D=>D.params_tipo.key===L.key);if(I){let D=null;if(L.key==="categoria"){const q=(V=L.params_plantillas)==null?void 0:V.find(B=>B.id===I.id);D=(q==null?void 0:q.reference_id)||I.id}else D=I.id;N[X][L.key]=D}})}),a(N)},O=()=>{var N;const M=o==null?void 0:o.params_plantillas;if(M!=null&&M.length)for(const A of M){const{params_tipo:{id:T,key:X},name:U,id:L}=A,I=p.find(D=>D.key===X),V=(N=I==null?void 0:I.params_plantillas)==null?void 0:N.find(D=>D.id===L);x[X]&&x[X](U,T),V&&l({field:X,value:V.abbreviation})}},H=()=>{try{const{fase_plantilla:M,modo_configuracion:N,formato_salida:A,tipo_medio:T}=c;if(M==="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(T)||r({fields:["formato_salida","medio_especifico"],value:!0}),A==="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}),A==="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 X=["formato_salida","medio_especifico","responsable_impresion","pertenencia_medio","ubicacion_medio"];r({fields:["tipo_medio"],value:!1}),r({fields:X,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(M){console.error("Error al aplicar reglas de habilitar y deshabilitar campos",M)}};return u.useEffect(()=>{(i||d)&&o&&(v(),O())},[i,d,o]),u.useEffect(()=>{(i||d)&&c&&H()},[i,c,d]),{savePlantilla:b,getTemplateWithTasks:w}}const xi=()=>{const{watch:e,getValues:a}=Pe.useFormContext(),{templateFormData:n,isDuplicateTemplate:s,currentTemplateForEdit:o}=ke(),[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=a(),d.current={...n},c.current=!0,r(!1)},500);return()=>clearTimeout(x)}},[s,o,a,n]),u.useEffect(()=>{if(l.current&&d.current&&c.current){const x=a(),p=n,h=JSON.stringify(x)!==JSON.stringify(l.current),y=JSON.stringify(p)!==JSON.stringify(d.current);r(h||y)}},[m,n,a]),{hasChanges:i,resetChanges:()=>{l.current=null,d.current=null,c.current=!1,r(!1)}}},bi=({onReset:e})=>{const{hasChanges:a,resetChanges:n}=xi(),{setHasFormChanges:s}=ke();return u.useEffect(()=>{s(a)},[a,s]),u.useEffect(()=>{e(n)},[e,n]),null},yi=({isOpen:e,onClose:a})=>{const{step:n,nextStep:s,prevStep:o,onStepChange:i}=li({limit:3}),r=rt(P=>P.reset),{templateFields:l,resetTemplateFormData:d}=Qt(),{clave:c,resetClave:m,resetDisabledFields:g,isEditTemplate:x,setIsEditTemplate:p,refetch:h,isDuplicateTemplate:y,hasFormChanges:w,setIsDuplicateTemplate:j,setCurrentTemplateForEdit:b}=ke(),{openTemplate:v}=ze(),[O,H]=u.useState(!1),[M,N]=u.useState(""),[A,T]=u.useState(!1),X=u.useRef(null),U=P=>{X.current=P},L=u.useMemo(()=>pi(l),[l]),I=n===1,V=n===3,D=I?"Cancelar":"Atrás",q=Pe.useForm({mode:"onChange",defaultValues:L}),{trigger:B,reset:$,clearErrors:Y,getValues:z}=q,{savePlantilla:re}=hi(z,$),ee=u.useRef(!1);u.useEffect(()=>{e&&(r(),ee.current=!1)},[e,r]),u.useEffect(()=>{e&&!x&&!y&&!ee.current&&($(L),d(),ee.current=!0)},[e,x,y,$,L,d]);const S=async()=>{if(await B()){if(n===3){if(!w&&y){N("Ya existe un proceso con éstos parámetros. Modifica al menos uno para poder duplicarlo."),T(!0);return}try{H(!0);const W=await re();if(W.success){const E=W.data;if(k(),G(),T(!1),!x)try{await v({template:E,statusTemplate:_e.NEW})}catch(C){console.warn("La plantilla se creó exitosamente pero hubo un problema al abrirla:",C)}h()}else{const{error:E}=W;N(E),T(!0)}}catch(W){console.error("Error inesperado al guardar la plantilla:",W);return}finally{H(!1)}}s()}},K=()=>{N(""),T(!1)},G=()=>{Y(),$(L),d(),g(),m(),K(),p(!1),j(!1),b(null),X.current&&X.current()},k=()=>{G(),ee.current=!1,a(),console.log("cerrar modal")};return O?t.jsx(lt,{isLoading:O}):t.jsxs(Pe.FormProvider,{...q,children:[t.jsx(bi,{onReset:U}),t.jsx(f.Modal,{isOpen:e,closeAtCancel:!1,onSuccess:S,cancelButtonText:D,successButtonText:V?x?"Guardar":"Crear":"Continuar",onCancel:I?k:o,onClose:k,size:"sm",iconConfig:{icon:ne.faFilePen},title:x?"Editar flujo de trabajo":"Nuevo flujo de trabajo",children:t.jsxs(f.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(f.Stepper,{currentStep:n-1,onStepChange:P=>i(P+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-canvas-default 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:c})}),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:[A&&t.jsx(f.Alert,{open:!0,color:"danger",message:M,className:"tm-mb-6",onClose:K}),t.jsx(ui,{step:n})]})]})})]})},ji=({isOpen:e,onClose:a,replaceTemplate:n})=>t.jsx(t.Fragment,{children:t.jsx(f.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(f.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(f.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."})})]})})})}),wi=We.create(e=>({cachedTemplate:null,canCreateTemplate:!1,setCachedTemplate:a=>e({cachedTemplate:a}),clearCachedTemplate:()=>e({cachedTemplate:null}),setCanCreateTemplate:a=>{const n=!(a<5);e({canCreateTemplate:n})}})),vi=({isOpen:e,onClose:a,discardChanges:n,saveAndExit:s})=>t.jsx("div",{children:t.jsx(f.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(f.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 tm-bg-canvas-default",children:t.jsx(f.Icon,{name:de.faSave,size:"lg",color:"brand"})})}),t.jsx("div",{className:"tm-flex tm-flex-col tm-mx-6",children:t.jsx(f.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(f.Button,{size:"xs",color:"secondary",onClick:()=>{n(),a()},children:"Descartar cambios"})})]})})})}),vs=({isOpen:e,onClose:a,publishTemplate:n})=>t.jsx(f.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(f.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(f.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."})})]})})}),_i=()=>{const e="grid",a="create-edit",n=u.useRef(null),{isOpenModalLimit:s,setIsOpenModalLimit:o,setOpenModalCreateTemplate:i,openModalCreateTemplate:r,setOpenModalUnsavedChanges:l,openModalUnsavedChanges:d,openModalPublishTemplate:c,setOpenModalPublishTemplate:m,setCurrentTemplateForEdit:g,setIsDuplicateTemplate:x,setIsEditTemplate:p}=ke(),{removeTemplateStates:h}=it(),{mode:y,setMode:w,setViewMode:j,getViewMode:b}=ve(),{setCanCreateTemplate:v,canCreateTemplate:O}=wi(),H=y===e,{screens:M,get:N,delete:A,activeTemplate:T,activateTemplate:X,reorderingTemplates:U,replaceTemplate:L,saveTemplateChanges:I,publishTemplate:V,loadingPublishTemplate:D,loadingSaveChanges:q}=ze(),B=178,[$,Y]=u.useState([]),[z,re]=u.useState([]),[ee,S]=u.useState(null),[K,G]=u.useState(!1),k=T!=null&&T.id?b(T.id):"readonly";u.useEffect(()=>{const J=()=>{if(!n.current)return;const te=n.current.offsetWidth;let fe=0;const ce=[],xe=[],we=10,ye=n.current.querySelector("button:not([data-screen])"),Oe=n.current.querySelector(".tm-mx-1");let Ne=0;ye&&(Ne+=ye.getBoundingClientRect().width),Oe&&M.length>0&&(Ne+=Oe.getBoundingClientRect().width,Ne+=we);const $e=(me,ge)=>{const Le=ge?54:0,ct=(me==null?void 0:me.length)*8;return Math.max(80,ct+40+Le)},ue=te-B-Ne;M.forEach((me,ge)=>{const Ie=!!(me.isNew||me.badgeLabel),he=$e(me.clave,Ie),Be=ge>0?we:0,Le=he+Be;fe+Le<=ue?(ce.push(me),fe+=Le):xe.push(me)}),Y(ce),re(xe)},se=()=>{const te=M.length;v(te)};return M.length>0&&(J(),se(),window.addEventListener("resize",J)),()=>{window.removeEventListener("resize",J)}},[M,y]);const P=J=>J.estatus===_e.DIRTY||J.estatus===_e.NEW,W=async J=>{P(J)?(S(J.id),l(!0)):await A(J.id)},E=()=>m(!0),C=async()=>{await A(ee),await h(ee)},R=async()=>{await I(!1)},F=async()=>{await I()},_=()=>{var se,te;const J=(te=(se=T==null?void 0:T.graph_layout)==null?void 0:se.snapshot)==null?void 0:te.nodes.length;G(()=>J-1>=1)};u.useEffect(()=>{_()},[T,k]);const Q=()=>!((T==null?void 0:T.estatus)==_e.IDLE&&K&&T.estatusFromStrapi!==Ae.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(te=>te.type!=="start"&&(te==null?void 0:te.data.tarea_padre)===null&&(te==null?void 0:te.data.id_t_requerida)===null)},ae=()=>(T==null?void 0:T.estatus)===_e.IDLE||Z()?!0:!K,ie=async()=>{await V(T.id)};return q||D?t.jsx(lt,{isLoading:q||D}):t.jsxs("div",{className:"tm-flex tm-gap-4 tm-justify-between tm-items-center tm-flex-wrap",children:[r&&t.jsx(yi,{isOpen:r,onClose:()=>i(!1)}),s&&t.jsx(ji,{isOpen:s,onClose:()=>o(!1),replaceTemplate:L}),d&&t.jsx(vi,{isOpen:d,onClose:()=>l(!1),discardChanges:C,saveAndExit:F}),c&&t.jsx(vs,{isOpen:c,onClose:()=>m(!1),publishTemplate:ie}),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(f.Button,{size:"xs",color:H?"primary":"secondary",onClick:()=>w(e),children:"Listado de flujos"}),M.length>0&&t.jsx(f.Separator,{vertical:!0,className:"tm-mx-1"}),M.filter(J=>$.some(se=>se.clave===J.clave)).map(J=>{const se=(T==null?void 0:T.clave)===J.clave&&y===a;return t.jsxs(f.Button,{"data-screen":J.clave,size:"xs",onClick:async()=>{await X(J),w(a,J.id)},color:se?"primary":"secondary",leftSlot:Se.faFilePen,badgeColor:P(J)?"warning":void 0,onClickRightSlot:()=>W(J),rightSlot:Se.faXmark,children:[J.clave," ",J.status]},J.id)})]}),z.length>0&&t.jsx(f.Popup,{absolute:!0,rightSlot:Se.faAngleDown,label:`${z.length}+`,size:"xs",color:"secondary",children:t.jsx("div",{className:"tm-py-2 tm-gap-4",style:{minWidth:"280px"},children:t.jsx(f.List,{icon:Se.faFilePen,items:z.map(J=>({id:J.id,label:J.clave})),className:"tm-p-8 tm-gap-4",onClick:async J=>{const se=await N(J.id);await U(se.id),await X(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:T.estatusFromStrapi!==Ae.PUBLISHED&&t.jsxs(t.Fragment,{children:[t.jsx(f.Button,{color:"secondary",size:"xs",leftSlot:Se.faArrowUp,disabled:Q(),onClick:E,children:"Publicar"}),k=="readonly"&&t.jsx(f.Button,{size:"xs",color:"primary",leftSlot:Se.faEdit,onClick:()=>(T==null?void 0:T.id)&&j(T.id,"edit"),children:"Editar"}),k==="edit"&&t.jsx(f.Button,{size:"xs",color:"primary",leftSlot:Se.faSave,onClick:R,disabled:ae(),children:"Guardar"})]})}):t.jsx(f.Button,{disabled:O,tooltip:O?"Límite de 5 plantillas con cambios sin guardar. Guarda y cierra alguna para crear una nueva.":"",leftSlot:Se.faPlus,size:"xs",color:"primary",onClick:()=>{g(null),x(!1),p(!1),i(!0)},children:"Nuevo flujo"})]})},Ti=({isOpen:e,onClose:a,deleteTemplate:n})=>t.jsx(f.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:""}),Ni=()=>{const{viewMode:e,setRefetch:a,openModalPublishTemplate:n,setOpenModalPublishTemplate:s,currentTemplateId:o,setOpenModalDeleteTemplate:i,openModalDeleteTemplate:r}=ke(),{publishTemplate:l,deleteTemplate:d}=ze(),{debouncedSearch:c,filters:m}=cs("templates-container"),g=e==="list",[x,p]=u.useState(1),h=9,{data:y,isLoading:w,isFetching:j,refetch:b}=js({page:x,pageSize:h,search:c,filters:m});u.useEffect(()=>{a(b)},[]),u.useEffect(()=>{p(1)},[m,c]);const{users:v}=st(),{getImageOBP:O}=pe(),H=T=>{if(!(T!=null&&T.email))return"";const X=v==null?void 0:v[T==null?void 0:T.email];return X!=null&&X.image?O(X==null?void 0:X.image):""},M=u.useMemo(()=>{try{return!y||!v?[]:y.data.map(T=>{const X=H((T==null?void 0:T.updated_by)||(T==null?void 0:T.created_by));return{...T,updated_by:{...T.updated_by,image:X}}})}catch(T){return console.error("Error al mapear las plantillas:",T),[]}},[y,v]),N=async()=>{await l(o),await b()},A=async()=>{await d(o),await b()};return w||j?t.jsx(lt,{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(vs,{isOpen:n,onClose:()=>s(!1),publishTemplate:N}),t.jsx(Ti,{isOpen:r,onClose:()=>i(!1),deleteTemplate:A}),t.jsx("div",{className:`tm-grid tm-gap-12 ${g?"tm-grid-cols-1":"tm-grid-cols-1 md:tm-grid-cols-2 lg:tm-grid-cols-3"}`,children:M.map(T=>t.jsx(gs,{fullWidth:g,template:T},T.id))}),t.jsx("div",{children:t.jsx(f.Pagination,{pageSize:h,pageCount:y==null?void 0:y.meta.pagination.pageCount,currentPage:x,onPageChange:T=>p(T)})})]})},_s=()=>{var r,l,d,c;const e="grid",a="create-edit",{mode:n}=ve(),s=n===e,o=n===a,i=qe(m=>m.activeTemplate);return t.jsxs("div",{className:"tm-h-full tm-flex tm-flex-col tm-gap-y-6",children:[t.jsx(_i,{}),s&&t.jsx(Ni,{}),o&&t.jsx(ii,{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)||[]})]})},Ci=()=>({header:t.jsx(hr,{}),body:t.jsx(_s,{})});function Si(e){const{users:a}=po(),{tasks_api:n,getImageOBP:s}=pe(),o=u.useMemo(()=>a.data?a.data.map(l=>{const{image:d,id:c,name:m}=l,g=s(d);return{value:c,label:m,icon:g}}):[],[a.data]),i=async l=>{const d=Ee.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 be(c.data).flatMap((g,x)=>{const p={id:`group-${x+1}`,label:g.label,value:`group-${x+1}`,isGroupTitle:!0},h=g.params_plantillas.map(y=>({id:y.id,label:y.name,value:y.id,checked:!1,icon:"CheckCircleOutlined",iconColor:"blue"}));return[p,...h]})},r=le.useQuery({queryKey:["paramsPlantilla"],queryFn:()=>i(n),enabled:e==="templates-container",staleTime:1e3*60*30});return{userOptions:o,paramsPlantillasOptions:r.data||[]}}const Ei={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"}},Pi={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"}},Ai={"templates-container":Ei,"teams-container":Pi,"kanban-general":null,"lista-campanias":null,"kanban-campania":null},Ii=e=>({inputFilters:Ai[e]||null}),Di=e=>{const{inputFilters:a}=Ii(e),{userOptions:n,paramsPlantillasOptions:s}=Si(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 Fi(){const{setFilters:e}=gt(),{refetch:a}=ke();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:Et(o.publication_date).format("YYYY-MM-DD")}),e(o,"templates-container"),a&&a()}}}const Ea="templates-container";function Mi(){const{mode:e}=ve(),{inputFilters:a}=Di(Ea),{handleApplyFilters:n}=Fi(),{viewMode:s,setViewMode:o}=ke();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(ls,{path:Ea}),t.jsxs("div",{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-x-8 md:tm-flex-nowrap",children:[a&&t.jsx(f.Filters,{filters:a,onApply:n}),t.jsx(f.Button,{size:"xs",color:"secondary",icon:s==="list"?ne.faGrid2:ne.faList,className:"tm-min-w-fit",onClick:()=>o(s==="list"?"grid":"list")})]})]})}const Pt={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()},Yt="Project Manager",Ts=({open:e,handleChange:a,children:n,title:s="¿Estás seguro?",onConfirm:o,contentLabel:i="",confirmLabel:r="Aceptar",cancelLabel:l="Regresar",isLoading:d=!1})=>t.jsx(f.Modal,{isOpen:e,onClose:()=>a(!1),onCancel:()=>a(!1),onSuccess:o,size:"xs",title:s,disableEscapeClose:!0,disableOutsideClick:!0,disableOutsideTab:!0,children:t.jsxs(f.Modal.Body,{children:[t.jsx(f.Text,{children:i}),n&&n]})}),ki=({member:e,level:a,isUpdate:n=!1,addHandler:s,updateHandler:o,removeHandler:i,updateMemberHandler:r})=>{var L,I,V;const{users:l,isLoading:d}=ht(),{users:c,isLoading:m}=st(),{getImageOBP:g}=pe(),[x,p]=u.useState(!1),[h,y]=u.useState(n?e:{...Pt,miembro_padre:a>1?e:null}),[w,j]=u.useState(null),[b,v]=u.useState({id:0,nombre:"",email:""}),[O,H]=u.useState(!1);u.useEffect(()=>{var D;j(c==null?void 0:c[(D=h==null?void 0:h.idUser)==null?void 0:D.email])},[h,c]),u.useEffect(()=>{e&&y({...e,miembro_padre:a>1?e.miembro_padre:null})},[e,a]);const M=u.useMemo(()=>(l||[]).map(D=>{var $,Y;const q=c==null?void 0:c[D.email??""],B=q!=null&&q.image?g(q.image):"";return{...D,label:D.name,value:D.id,subtitle:D.email??"",avatar:((Y=($=D.name)==null?void 0:$.slice(0,2))==null?void 0:Y.toUpperCase())??"",avatarUrl:B}}),[l,c,g]),N=()=>{p(!1),v({id:0,nombre:"",email:""})},A=({id:D,name:q,email:B})=>{const $={...h,idUser:{...h.idUser,id:D,nombre:q,email:B}};y($),o($),v({id:D,nombre:q,email:B})},T=async()=>{if(!b.nombre&&!b.email){N();return}try{h.id&&r({user_id:b.id,miembro_id:e.id});const D={...h,idUser:{...h.idUser,id:b.id,nombre:b.nombre,email:b.email}};y(D),o(D),j(c==null?void 0:c[b.email]),N()}catch(D){f.toast.error(D instanceof Error?D.message:"Error al actualizar el colaborador")}},X=()=>{const D={...Pt,uid:new Date().getTime()+Math.floor(Math.random()*1e3),miembro_padre:e,miembros:[]};s(D)},U=()=>{i(e),H(!1)};return m||d?null:t.jsxs("div",{className:"tm-flex tm-items-baseline tm-justify-between",children:[O&&t.jsx(Ts,{open:O,handleChange:H,onConfirm:U,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:(L=h==null?void 0:h.idUser)!=null&&L.email&&!x?t.jsxs(t.Fragment,{children:[t.jsx(De,{size:"m",alt:((I=h==null?void 0:h.idUser)==null?void 0:I.nombre)??"Avatar",imageUrl:w!=null&&w.image?g(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:(V=h==null?void 0:h.idUser)==null?void 0:V.nombre})]}):t.jsx(f.Dropdown,{placeholder:"Seleccionar colaborador",options:M,valueName:"name",idName:"id",listVariant:"user",absolute:!0,closeOnClickOutside:!0,searchable:!0,searchPlaceholder:"Buscar colaborador...",onOptionSelect:D=>{A({id:D.id,name:D.name,email:D.email})}})}),t.jsx(f.Button,{onClick:X,leftSlot:ne.faPlus,size:"xxs",color:"tertiary",children:"Añadir colaborador"})]}),t.jsxs("div",{className:"tm-flex tm-gap-x-4",children:[x?t.jsxs(t.Fragment,{children:[t.jsx(f.Button,{onClick:N,icon:ne.faXmark,size:"xs",color:"secondary",tooltip:"Cancelar"}),t.jsx(f.Button,{onClick:T,icon:Ve.faCheck,size:"xs",color:"primary",tooltip:"Guardar"})]}):t.jsx(f.Button,{onClick:()=>p(!0),icon:ne.faPencil,size:"xs",color:"tertiary",tooltip:"Editar"}),t.jsx(f.Button,{onClick:()=>H(!0),icon:ne.faTrash,size:"xs",color:"destructive",tooltip:"Eliminar"})]})]})]})},Ns=({members:e,level:a=1,isUpdate:n=!1,setData:s})=>{const o=()=>{s(i=>({...i,miembros:[...i.miembros,{...Pt,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(f.Button,{size:"xxs",color:"tertiary",leftSlot:Ve.faPlus,onClick:o,children:" Agregar miembro del equipo "})}),(e==null?void 0:e.length)>0&&(e==null?void 0:e.map(i=>t.jsx(Oi,{isUpdate:n,member:i,level:a,setData:s},i.uid)))]})},Oi=({member:e,level:a,isUpdate:n=!1,setData:s})=>{const o=c=>{s(m=>{if(!c.miembro_padre)return{...m,miembros:[...m.miembros,c]};const g=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:g(p.miembros)}:p);return{...m,miembros:g(m.miembros)}})},i=c=>{s(m=>{const g=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:g(p.miembros)}:p);return{...m,miembros:g(m.miembros)}})},r=c=>{var g;const m=[];return c.id&&m.push(c.id),(g=c.miembros)!=null&&g.length&&c.miembros.forEach(x=>{m.push(...r(x))}),m},l=c=>{s(m=>{const g=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=>!g.includes(h.miembro_id));return{...m,miembros:x(m.miembros),miembros_eliminar:[...m.miembros_eliminar,...g],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 t.jsxs("div",{"data-id":e.uid,style:{paddingLeft:a===1?0:"30px",marginTop:a===1?"15px":"0px",paddingBottom:"5px"},children:[t.jsx(ki,{isUpdate:n,level:a,member:e,addHandler:o,updateHandler:i,removeHandler:l,updateMemberHandler:d}),Array.isArray(e.miembros)&&e.miembros.length>0&&t.jsx(Ns,{isUpdate:n,members:e.miembros,level:a+1,setData:s})]},e.uid)};function Pa(e){var l;const a=e.miembros;if(!(a!=null&&a.length))return e;const[n,...s]=a,o=n.miembros??[],i=new Set;for(const d of s){const c=(l=d.idUser)==null?void 0:l.id;typeof c=="number"&&c>0&&i.add(c)}const r=o.filter(d=>{var m;const c=(m=d.idUser)==null?void 0:m.id;return typeof c!="number"||c<=0?!0:!i.has(c)}).map(d=>({...d,esEncargado:!1,miembros:[],miembro_padre:null}));return{...e,miembros:[{...n},...r,...s]}}function Cs(e){const a=e??[],n=a.filter(s=>s.esEncargado);return n.length>0?n:a}const Li=()=>"#"+Math.floor(Math.random()*16777215).toString(16),Bi=({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},Ri=({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 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 g=a[m.uid];return o(g||m)}).filter(Boolean);return{...l,miembros:d}};return{members:e.filter(r=>r.miembro_padre===null).map(o),allMembers:n}},qi=({items:e})=>e?e.map(a=>{const n=Ri({items:a.miembros});return{...a,integrantes:n.allMembers.length,miembros:n.members,miembros_planos:n.allMembers,miembros_eliminar:[],miembros_actualizar:[]}}):[],zi=async({tasks_api:e,page:a=1,pageSize:n=10,search:s="",filters:o={}})=>{const i=Ee.stringify({filters:Bi({search:s,filters:o}),populate:hs(),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}}}},$i=({page:e=1,pageSize:a=10,search:n="",filters:s={}})=>{const{tasks_api:o}=pe();return le.useQuery({queryKey:["teams",e,a,n,s],queryFn:()=>zi({tasks_api:o,page:e,pageSize:a,search:n,filters:s}),staleTime:1e3*60*60*24,placeholderData:le.keepPreviousData,select:i=>({data:qi({items:(i==null?void 0:i.data)||[]}),meta:i==null?void 0:i.meta})})},At=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(At):[]}),Ss=()=>{const{tasks_api:e}=pe(),a=le.useQueryClient(),n=async x=>{const p=Pa(x),h={...p,id:void 0,miembros:p.miembros.map(At)};return(await e.post("/api/registrar-equipo-miembros",{data:h})).data},s=async x=>(await e.delete(`/api/equipos/${x}`)).data,o=async(x,p)=>{const h=Pa(p),y={...h,id:void 0,miembros:h.miembros.map(At)};return(await e.patch(`/api/actualizar-equipo-miembros/${x}`,{data:y})).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}=le.useMutation({mutationFn:s,onSuccess:()=>{a.invalidateQueries({queryKey:["teams"]})},onError:x=>{throw console.error("Failed to delete the team.",x),x}}),{mutateAsync:d}=le.useMutation({mutationFn:n,onSuccess:()=>{a.invalidateQueries({queryKey:["teams"]})},onError:x=>{throw console.error("Failed to update the team.",x),x},onMutate:async()=>{await a.cancelQueries({queryKey:["teams"]})}}),{mutateAsync:c}=le.useMutation({mutationFn:x=>o(x.teamId,x.data),onSuccess:()=>{a.invalidateQueries({queryKey:["teams"]})},onError:x=>{throw console.error("Failed to update the team.",x),x},onMutate:async()=>{await a.cancelQueries({queryKey:["teams"]})}}),{mutateAsync:m}=le.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:()=>{a.invalidateQueries({queryKey:["teams"]})},isLoadingDeleteTeam:l}},Ui=(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])},Hi=({color:e,onChange:a})=>t.jsxs(t.Fragment,{children:[t.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
|
+
`}),t.jsx("div",{className:"react-pick-color tm-overflow-hidden tm-rounded-lg tm-shadow-02",children:t.jsx(zs.ColorPicker,{color:e,theme:{inputBackground:"#FFF"},combinations:["monochromatic"],onChange:n=>a(n)})})]});function Ki({color:e,setColor:a,label:n="Elige el color",className:s=""}){const[o,i]=u.useState(!1),r=u.useRef(null);return Ui(r,i,o),t.jsxs("div",{className:"tm-relative tm-w-full",children:[t.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&&t.jsx("div",{ref:r,className:"tm-absolute tm-z-50 tm-mt-2",children:t.jsx(Hi,{color:e,onChange:l=>a(l.hex)})})]})}const St="Ha ocurrido un error inesperado. Por favor, intente nuevamente.",Vi={"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"},Es=()=>({handleApiError:a=>{var n,s,o,i,r;if(a instanceof tt.AxiosError&&((n=a.response)==null?void 0:n.status)===400){const l=a.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=Vi[d.message]||St;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||St}return St}});function Ps({open:e,handleChange:a,team:n}){const{addTeamHandler:s,updateTeamHandler:o}=Ss(),{handleApiError:i}=Es(),[r,l]=u.useState(""),[d,c]=u.useState(n||{id:0,nombre:"",color:Li(),miembros:[],miembros_planos:[],integrantes:0,miembros_eliminar:[],miembros_actualizar:[]}),m=d.id>0,g=u.useMemo(()=>Cs(d.miembros),[d.miembros]),x=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 p=async()=>m?await o({data:d,teamId:d.id}):await s(d);try{await p(),l(""),a(!1);const h=m?"Equipo actualizado correctamente":"Equipo creado correctamente";f.toast.success(h)}catch(h){l(i(h))}};return t.jsx(f.Modal,{onCancel:()=>a(!1),onSuccess:x,title:"Información del equipo",icon:Ve.faUser,showCloseButton:!0,showCancelButton:!0,showSuccessButton:!0,closeAtSuccess:!0,closeAtCancel:!0,isOpen:e,onClose:()=>a(!1),size:"lg",children:t.jsxs(f.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(ur,{value:d.nombre,onChange:p=>c({...d,nombre:p})}),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(Ki,{color:d.color,setColor:p=>c({...d,color:p})})]})]}),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(mr,{title:"Miembros del equipo",icon:Ve.faUsers}),t.jsx(Ns,{members:g,setData:c,isUpdate:m})]})]})})}const Re=384,Gi=80,Wi=180,It=20,Qi=2,As=4,Dt=.8;function Xi({data:e}){const{getImageOBP:a}=pe();return t.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:[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-surface-default",children:t.jsx(De,{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(f.Text,{size:"xs",weight:"bold",children:e.name}),t.jsx(f.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 Yi={custom:Xi},Ji={style:{stroke:"#6366f1",strokeWidth:2}},Is=(e,a=0)=>e?e.map(n=>{const s=n.miembros?Is(n.miembros,a+1):[];return{width:Re,height:Gi,children:s,x:0,y:a*Wi,totalWidth:0,depth:a}}):[],Ds=e=>{if(e.children.length===0)return e.totalWidth=Re,Re;const a=e.children.reduce((o,i)=>o+Ds(i),0),n=e.children.length>As?Dt:1,s=(e.children.length-1)*It*n;return e.totalWidth=Math.max(Re,a+s),e.totalWidth},Fs=(e,a=0)=>{let n=a;return e.forEach(s=>{s.totalWidth===0&&Ds(s);const o=s.children.length>Qi,i=s.children.length>As;if(s.children.length>0){if(Fs(s.children,n),i){const g=(s.totalWidth-Re)/(s.children.length-1)*Dt;s.children.forEach((x,p)=>{x.x=n+p*g})}else if(o){const g=(s.totalWidth-Re)/(s.children.length-1);s.children.forEach((x,p)=>{x.x=n+p*g})}const l=s.children[0].x,d=s.children[s.children.length-1].x+Re,c=i?Re*.1:0;s.x=(l+d-Re)/2+c}else s.x=n;const r=i?Dt:1;n=Math.max(n+Re+It*r,s.x+Re+It*r)}),n},Ms=(e,a,n,s)=>{const o=[],i=[];return e.forEach((r,l)=>{var m,g,x,p,h,y;const d=a[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[(g=d.idUser)==null?void 0:g.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=Ms(r.children,d.miembros,n,c);o.push(...w.nodes),i.push(...w.edges)}}),{nodes:o,edges:i}};function Zi({members:e}){const[a,n]=u.useState([]),[s,o]=u.useState([]),{users:i,isLoading:r}=st();return u.useEffect(()=>{if(e&&!r){const l=Is(e);Fs(l);const{nodes:d,edges:c}=Ms(l,e,i);n(d),o(c)}},[e,i,r]),r?null:t.jsx(oe.ReactFlow,{nodeTypes:Yi,nodes:a,edges:s,draggable:!1,fitView:!0,defaultViewport:{x:0,y:0,zoom:1},minZoom:.5,maxZoom:2,defaultEdgeOptions:Ji})}function el({open:e,handleChange:a,members:n}){const s=u.useMemo(()=>Cs(n??[]),[n]);return t.jsx(f.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-surface-default",style:{width:"100%",height:"600px"},children:t.jsx(oe.ReactFlowProvider,{children:t.jsx(Zi,{members:s})})})})}const ks="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",tl="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 Ke({className:e="",rounded:a="md"}){const n=a==="full"?"tm-rounded-full":"tm-rounded-md";return t.jsx("span",{className:`${tl} ${n} ${e}`.trim(),"aria-hidden":!0})}function Os(){return t.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:Array.from({length:2},(e,a)=>t.jsx(Ke,{className:"tm-h-8 tm-w-8 tm-shrink-0",rounded:"full"},a))})}function al(){const{user:e}=je(),a=(e==null?void 0:e.role)===Yt;return t.jsxs(f.Card,{className:"tm-w-full",children:[t.jsxs(f.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(Ke,{className:"tm-h-2.5 tm-w-2.5 tm-shrink-0",rounded:"full"}),t.jsx(Ke,{className:"tm-h-8 tm-w-8 tm-shrink-0"}),t.jsx(Ke,{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(Ke,{className:"tm-h-8 tm-w-8 tm-shrink-0",rounded:"full"}):null})]}),t.jsx(f.Card.Separator,{}),t.jsxs(f.Card.Body,{scrollable:!1,children:[t.jsx(Os,{}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-4 tm-mt-2",children:[t.jsx(Ke,{className:"tm-h-4 tm-w-6"}),t.jsx(Ke,{className:"tm-h-4 tm-w-28"})]})]})]})}function sl({length:e}){const n=e??10;return t.jsx("div",{"aria-busy":"true","aria-live":"polite",className:ks,children:Array.from({length:n},(s,o)=>t.jsx(al,{},o))})}function nl({members:e}){const{getImageOBP:a}=pe(),{users:n,isLoading:s}=st();if(s)return t.jsx(Os,{});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 t.jsx("div",{className:"tm-flex tm-items-center tm-gap-x-8",children:t.jsx(f.Avatar,{maxVisible:2,stroke:!0,stack:o.map(i=>{var l;const r=n[(l=i.idUser)==null?void 0:l.email];return{src:a(r.image),name:r.name}}),size:"sm"})})}function ol({team:e}){const[a,n]=u.useState(!1),[s,o]=u.useState(!1),{user:i}=je(),[r,l]=u.useState(!1),{handleApiError:d}=Es(),{deleteTeamHandler:c,isLoadingDeleteTeam:m}=Ss(),g=async()=>{try{await c(e.id),f.toast.success("Equipo eliminado correctamente")}catch(x){f.toast.error(d(x))}};return t.jsxs(f.Card,{children:[a&&t.jsx(Ps,{handleChange:n,open:a,team:e}),r&&t.jsx(Ts,{isLoading:m,open:r,handleChange:l,onConfirm:g,contentLabel:"Estás eliminando el equipo seleccionado"}),s&&t.jsx(el,{handleChange:o,open:s,members:e.miembros}),t.jsxs(f.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(f.Badge,{size:"dot",customColor:e.color,theme:"solid"}),t.jsx(f.Icon,{name:Ve.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)==Yt&&t.jsx(f.Popup,{size:"xs",color:"secondary",pill:"pill",icon:ne.faEllipsis,stopPropagationList:!0,children:t.jsxs(f.List,{className:"tm-gap-4",padding:"sm",children:[t.jsx(f.ListItem,{icon:ne.faPencil,onClick:()=>n(!0),children:"Editar"}),t.jsx(f.ListItem,{icon:ne.faEye,onClick:()=>o(!0),children:"Ver organigrama"}),t.jsx(f.ListItem,{color:"red",icon:ne.faTrash,onClick:()=>l(!0),children:"Eliminar"})]})})})]}),t.jsx(f.Card.Separator,{}),t.jsxs(f.Card.Body,{children:[t.jsx(nl,{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 rl({teams:e}){return t.jsx("div",{className:ks,children:e==null?void 0:e.map(a=>t.jsx(ol,{team:a},a.id))})}const il="teams-container";function ll(){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(ls,{path:il})})}function Ls(){var b,v,O,H,M;const[e,a]=u.useState(!1),[n,s]=u.useState(1),[o,i]=u.useState(10),{user:r}=je(),{debouncedSearch:l,filters:d}=cs("teams-container"),c=Array.isArray(d)?d:[];u.useEffect(()=>{s(1)},[l,d]);const{data:m,isLoading:g}=$i({page:n,pageSize:o,search:l,filters:{nombre:"",createdAt:(b=c.find(N=>N.keyName==="createdAt"))==null?void 0:b.value,integrantes_min:(v=c.find(N=>N.keyName==="integrantes_min"))==null?void 0:v.value,integrantes_max:(O=c.find(N=>N.keyName==="integrantes_max"))==null?void 0:O.value}}),x=(m==null?void 0:m.data)||[],p=m==null?void 0:m.meta,h=((H=p==null?void 0:p.pagination)==null?void 0:H.pageCount)||0,y=((M=p==null?void 0:p.pagination)==null?void 0:M.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(Ps,{handleChange:a,open:e}),(r==null?void 0:r.role)===Yt&&t.jsx("div",{className:"tm-flex tm-items-center tm-justify-end",children:t.jsx(f.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:x.length===0&&!g?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:l?"No se encontraron equipos con ese nombre":"¡Parece que aún no has creado un equipo!"}),!l&&t.jsx(f.Button,{color:"primary",onClick:()=>a(!0),children:"¡Empieza ahora!"})]})}):g?t.jsx("div",{className:"tm-pb-16 tm-opacity-100 tm-transition tm-duration-300",children:t.jsx(sl,{length:o})}):t.jsx("div",{className:`tm-pb-16 ${g?"tm-opacity-0 tm-transition tm-duration-300":"tm-opacity-100 tm-transition tm-duration-300"}`,children:t.jsx(rl,{teams:x})})}),h>0&&t.jsx(f.Pagination,{currentPage:n,pageCount:h,pageSize:o,total:y,onPageChange:w,handlePageSize:j,showVisiblePages:!0,showPagesSelector:!0})]})}const cl=()=>({header:t.jsx(fl,{}),body:t.jsx(Ls,{})}),dl={"templates-container":Mi,"teams-container":ll};function ml({path:e}){const a=e?dl[e]:null;return a?t.jsx(a,{}):null}function ul({path:e}){return e==="templates-container"?Ci():e==="teams-container"?cl():{header:null,body:null}}const pl=({startPath:e})=>{const{path:a,setPath:n}=ke(),{setCurrentPath:s}=gt();u.useEffect(()=>{n(e),s(e)},[e,n,s]);const{header:o,body:i}=ul({path:a});return t.jsxs(f.Card,{fullWidth:!0,className:"tm-h-full",children:[t.jsxs(f.Card.Header,{className:"tm-flex tm-flex-wrap tm-items-center tm-gap-16 tm-justify-between",children:[o,t.jsx(ml,{path:a})]}),t.jsx(f.Card.Separator,{}),t.jsx(f.Card.Body,{fullHeight:!0,className:"tm-flex tm-flex-1 tm-flex-col tm-gap-y-4",children:i})]})},fl=()=>t.jsx(is,{title:"Equipos"}),gl=({path:e,tab:a,setPath:n,project:s,setProject:o})=>{const i={"kanban-general":{kanban:t.jsx(nr,{})},"teams-container":{teams:t.jsx(Ls,{})},"lista-campanias":{lista:t.jsx(Kn,{setPath:n,setProject:o}),gantt:t.jsx("div",{children:"gantt-campanias"})},"kanban-campania":{kanban:t.jsx(Xo,{}),lista:t.jsx(dr,{}),gantt:t.jsx("div",{children:"kanban-campania-gantt"})},"templates-container":{templates:t.jsx(_s,{})}};return e==="kanban-campania"?t.jsx(to,{project:s==null?void 0:s.id,children:i[e][a]}):i[e][a]},hl=({label:e,active:a,onClick:n,disabled:s})=>s?t.jsx(Fe,{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(f.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}),xl=({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,l)=>t.jsx("div",{className:`${l===0?"tm-border-l-2":""} tm-border-r-2 tm-border-default tm-px-m`,children:t.jsx(hl,{onClick:()=>i(r.toLowerCase()),label:r,active:r.toLowerCase()===s,disabled:["gantt"].includes(r.toLowerCase())},l)}))})},Aa="tasksProject",bl=({path:e})=>{const a=()=>{const n=le.useQueryClient(),{selectPath:s,updateFilters:o,applyFilters:i,filters:r,fields:l}=Me(),[d,c]=u.useState("kanban"),[m,g]=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(X=>X.path===m))==null?void 0:T.search)??"")},[e,m]),u.useEffect(()=>{var T;((T=M())==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=>{g(T)},O=["lista-campanias","kanban-campania"],H={"lista-campanias":["lista","gantt"],"kanban-campania":["kanban","lista","gantt"],"teams-container":["teams"],"templates-container":["templates"]},M=()=>{var T;return((T=h.find(X=>X.path===m))==null?void 0:T.search)??""},N=()=>{m==="kanban-general"?Ko(n):m==="kanban-campania"&&(n.invalidateQueries({queryKey:[Aa]}),n.refetchQueries({queryKey:[Aa]}))},A=T=>{y(X=>X.map(U=>U.path===m?{...U,search:T}:U))};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()}),A(w)},500);return()=>{clearTimeout(T)}},[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-default tm-bg-surface-default 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-default tm-pb-m",children:[t.jsxs("div",{className:"tm-flex tm-gap-xl tm-items-center",children:[m==="kanban-campania"&&t.jsx(f.Button,{icon:ne.faArrowLeft,onClick:()=>v("lista-campanias"),color:"secondary",pill:"pill",size:"xxs"}),t.jsx(f.Text,{size:"lg",weight:"medium",color:"primary",children:b(m)}),O.includes(m)&&t.jsx(xl,{tabs:H[m],renderItem:T=>{c(T)},initialTab:d})]}),t.jsxs("div",{className:"tm-flex tm-items-center tm-gap-s !tm-text-[16px]",children:[t.jsx(f.Input,{leftSlot:de.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&&t.jsx(Gn,{children:t.jsx(Yn,{})}),(m==="kanban-general"||m==="kanban-campania")&&t.jsx(f.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(gl,{path:m,tab:d,setPath:v,project:x,setProject:p})})]})};return t.jsx($s,{children:t.jsx(a,{})})},yl=({path:e})=>["templates-container","teams-container"].includes(e)?t.jsx(pl,{startPath:e}):t.jsx(bl,{path:e}),jl=()=>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"})]})})}),wl=()=>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"})]})})}),vl=({path:e,user:a,url:n,mode:s})=>{const o=new le.QueryClient;if(!a)return t.jsx(wl,{});if(!a.accessToken)return t.jsx(jl,{});let i={user:a,url:n,mode:s};return t.jsxs(br,{children:[t.jsx(f.Messaging,{}),t.jsx(Hs,{...i,children:t.jsx(Us,{...i,children:t.jsx("div",{className:"tm-relative tm-h-full tm-min-h-[100%] tm-w-full",children:t.jsxs(le.QueryClientProvider,{client:o,children:[t.jsx(yl,{path:e})," "]})})})})]})};exports.AppTasks=vl;
|