"use strict";(self.webpackChunkmantis_material_react=self.webpackChunkmantis_material_react||[]).push([[8012],{34815:(e,s,t)=>{t.r(s),t.d(s,{default:()=>pe});var a=t(80045),i=t(89379),r=t(9950),n=t(98007),l=t(47113),c=t(82215),d=t(99810),o=t(49029),u=t(33516),p=t(48513),m=t(37119),h=t(2527),v=t.n(h);t(55392);v().PolylineOffset={translatePoint:(e,s,t)=>v().point(e.x+s*Math.cos(t),e.y+s*Math.sin(t)),offsetPointLine(e,s){const t=e.length;if(t<2)throw new Error("Line should be defined by at least 2 points");let a,i=e[0];const r=Math.PI/2,n=[];for(let l=1;l=0&&l<=1&&c>=0&&c<=1?v().point(e.x+c*i.x,e.y+c*i.y):null},segmentAsVector:(e,s)=>v().point(s.x-e.x,s.y-e.y),joinLineSegments(e){const s=[];let t=e[0].offset;s.push(t[0]);for(let a=1;ae.latLngToLayerPoint(s)));return this.offsetPoints(a,t).map((s=>e.layerPointToLatLng(s)))}};const x=v().Polyline.prototype._projectLatlngs;v().Polyline.prototype._projectLatlngs=function(e,s,t){const a=this.options.offset;if(!a||"number"!==typeof a)return x.call(this,e,s,t);if(!(e[0]instanceof v().LatLng)){for(let a=0;athis._map.latLngToLayerPoint(e))),r=v().PolylineOffset.offsetPoints(i,a);for(let n=0;nw[String(e||"").toLowerCase()]||{label:e||"Unknown",bg:"#64748b",fg:"#fff"},z=new Set(["delivered"]),M=new Set(["cancelled","skipped"]),C=["#2563eb","#dc2626","#16a34a","#ea580c","#9333ea","#0891b2","#ca8a04","#db2777","#0f766e","#7c3aed","#65a30d","#0284c7","#b91c1c","#15803d","#a16207","#86198f"],A=e=>C[(e%C.length+C.length)%C.length],D=e=>{if(null==e)return"";const s=["th","st","nd","rd"],t=e%100;return e+(s[(t-20)%10]||s[t]||s[0])};var P=t(44414);const q=function(e){let{focusedRider:s,compareDeltas:t,compareSummary:a,actualOrdered:i,focusedCompareStep:n,setFocusedCompareStep:l,sequenceOpen:c,setSequenceOpen:d,expandedSeqGroups:o,setExpandedSeqGroups:u,onClose:p}=e;const m=(0,r.useMemo)((()=>{const e=a,r=e.onTime+e.late,n=s.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),l=n<0,c=t.filter((e=>e.anomaly)),d=t.filter((e=>z.has(String(e.orderstatus||"").toLowerCase()))).length,o=t.filter((e=>M.has(String(e.orderstatus||"").toLowerCase()))).length,u=null==e.kmDeltaPct?"":e.kmDeltaPct>25?"is-over":e.kmDeltaPct<-5?"is-under":"",p=t.length||1,m=e.onTime+e.late||1,h=Math.round(d/p*60+e.onTime/m*25+(p-e.anomalies)/p*15),v=h>=85?"#16a34a":h>=65?"#f59e0b":"#dc2626",x=h>=85?"Excellent":h>=65?"Acceptable":"Needs review",j=t.filter((e=>e.actualTs)),g=j.reduce(((e,s)=>!e||s.actualTs.isBefore(e)?s.actualTs:e),null),N=j.reduce(((e,s)=>!e||s.actualTs.isAfter(e)?s.actualTs:e),null),f=g&&N?Math.max(0,N.diff(g,"minute")):0,b=t.length>1?Math.round(f/(t.length-1)):0,y=f>0?(e.actualKm/(f/60)).toFixed(1):null,k=t.filter((e=>!e.isLoading&&e.coordsCount>0)),S=k.filter((e=>null!=e.timeDeltaMin&&!e.anomaly)).sort(((e,s)=>e.timeDeltaMin-s.timeDeltaMin))[0]||null,w=k.filter((e=>e.anomaly)).sort(((e,s)=>{const t=Math.abs(e.kmDeltaPct||0)+(e.timeDeltaMin>0?e.timeDeltaMin:0);return Math.abs(s.kmDeltaPct||0)+(s.timeDeltaMin>0?s.timeDeltaMin:0)-t}))[0]||null,F=i.filter(((e,s)=>{var t;const a=null===(t=e.order)||void 0===t?void 0:t.step;return null!=a&&a!==s+1})),C=[];F.forEach((e=>{var s;const t=null===(s=e.order)||void 0===s?void 0:s.step,a=i.findIndex((s=>s.sequenceStep===e.sequenceStep))+1,r=a-t,n=C[C.length-1];n&&n.delta===r&&n.lastActualPos+1===a?(n.items.push({d:e,planned:t,actualPos:a,delta:r}),n.lastActualPos=a):C.push({delta:r,items:[{d:e,planned:t,actualPos:a,delta:r}],lastActualPos:a})}));const A={};s.orders.forEach((e=>{const s=e.trip_number||1;A[s]||(A[s]=[]),A[s].push(e)}));const D=Object.entries(A).sort(((e,s)=>{let[t]=e,[a]=s;return Number(t)-Number(a)})).map((e=>{let[s,t]=e;return{tNum:s,count:t.length,plannedKm:t.reduce(((e,s)=>e+parseFloat(s.kms||0)),0),actualKm:t.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:t.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),delivered:t.filter((e=>z.has(String(e.orderstatus||"").toLowerCase()))).length}}));return{sum:e,totalSteps:r,totalProfit:n,isLoss:l,deviations:c,delivered:d,skipped:o,stepDeltaPct:u,score:h,scoreColor:v,scoreLabel:x,firstDelivery:g,lastDelivery:N,activeMin:f,avgPerStop:b,avgSpeed:y,bestStep:S,worstStep:w,outOfOrderSteps:F,seqRuns:C,tripList:D}}),[s,t,a,i]),h=null!=n?t.find((e=>e.sequenceStep===n)):null,v=e=>{l((s=>s===e?null:e))},x=function(e){let s=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];const{d:t,planned:a,actualPos:i,delta:r}=e;return(0,P.jsxs)("li",{className:"cdp-seq-diff".concat(n===t.sequenceStep?" is-focused":"").concat(s?"":" is-nested"),onClick:()=>v(t.sequenceStep),children:[(0,P.jsx)("span",{className:"cdp-seq-diff-num",style:{background:A((a||t.sequenceStep)-1)},children:a||t.sequenceStep}),(0,P.jsxs)("div",{className:"cdp-seq-diff-body",children:[(0,P.jsx)("div",{className:"cdp-seq-diff-title",children:t.deliverycustomer||"Step ".concat(a||t.sequenceStep)}),(0,P.jsxs)("div",{className:"cdp-seq-diff-sub",children:["Visited ",(0,P.jsx)("strong",{children:D(i)})," ","\xb7 planned ",(0,P.jsx)("strong",{children:D(a)})]})]}),(0,P.jsx)("span",{className:"cdp-seq-diff-tag",children:r>0?"+".concat(r):"".concat(r)})]},"diff-".concat(t.sequenceStep))},{sum:j,totalSteps:g,totalProfit:N,isLoss:f,deviations:b,delivered:y,skipped:S,stepDeltaPct:w,score:C,scoreColor:q,scoreLabel:L,firstDelivery:E,lastDelivery:_,activeMin:O,avgPerStop:I,avgSpeed:R,bestStep:T,worstStep:H,outOfOrderSteps:V,seqRuns:K,tripList:Y}=m;return(0,P.jsxs)("aside",{id:"compare-data-panel",className:"compare-data-panel",children:[(0,P.jsxs)("div",{className:"cdp-head",children:[(0,P.jsxs)("div",{className:"cdp-head-title",children:[(0,P.jsx)("span",{className:"cdp-rider-dot",style:{background:s.color}}),(0,P.jsxs)("div",{className:"cdp-head-text",children:[(0,P.jsx)("div",{className:"cdp-rider-name",children:s.riderName}),(0,P.jsx)("div",{className:"cdp-head-badge",children:"PLANNED vs ACTUAL"})]})]}),(0,P.jsx)("button",{type:"button",className:"cdp-close",onClick:p,title:"Exit compare","aria-label":"Exit compare",children:(0,P.jsx)(k.m6K,{})})]}),(0,P.jsxs)("div",{className:"cdp-scroll",children:[(0,P.jsx)("section",{className:"cdp-section cdp-score-section",children:(0,P.jsxs)("div",{className:"cdp-score-wrap",children:[(0,P.jsx)("div",{className:"cdp-score-ring",style:{background:"conic-gradient(".concat(q," ").concat(3.6*C,"deg, rgba(15,23,42,0.08) 0deg)")},children:(0,P.jsxs)("div",{className:"cdp-score-inner",children:[(0,P.jsx)("div",{className:"cdp-score-value",style:{color:q},children:C}),(0,P.jsx)("div",{className:"cdp-score-unit",children:"/100"})]})}),(0,P.jsxs)("div",{className:"cdp-score-body",children:[(0,P.jsx)("div",{className:"cdp-score-label",style:{color:q},children:L}),(0,P.jsx)("div",{className:"cdp-score-title",children:"Compliance score"}),(0,P.jsxs)("div",{className:"cdp-score-sub",children:[y,"/",t.length," delivered",j.anomalies>0?" \xb7 ".concat(j.anomalies," deviation").concat(j.anomalies>1?"s":""):"",j.late>0?" \xb7 ".concat(j.late," late"):"",S>0?" \xb7 ".concat(S," skipped"):""]})]})]})}),(0,P.jsxs)("section",{className:"cdp-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.Zs6,{})}),(0,P.jsx)("span",{className:"cdp-section-title",children:"Day overview"})]}),(0,P.jsxs)("div",{className:"cdp-tiles",children:[(0,P.jsxs)("div",{className:"cdp-tile",children:[(0,P.jsxs)("div",{className:"cdp-tile-label",children:[(0,P.jsx)(k.xI$,{})," Distance"]}),(0,P.jsxs)("div",{className:"cdp-tile-value",children:[j.actualKm.toFixed(1),(0,P.jsx)("span",{className:"cdp-tile-unit",children:"km"})]}),(0,P.jsxs)("div",{className:"cdp-tile-sub",children:["planned ",j.plannedKm.toFixed(1)," km"]})]}),(0,P.jsxs)("div",{className:"cdp-tile".concat(j.anomalies>0?" is-warn":""),children:[(0,P.jsxs)("div",{className:"cdp-tile-label",children:[(0,P.jsx)(k.Wux,{})," Deviation"]}),(0,P.jsx)("div",{className:"cdp-tile-value ".concat(w),children:null!=j.kmDeltaPct?"".concat(j.kmDeltaPct>0?"+":"").concat(j.kmDeltaPct.toFixed(0),"%"):"\u2014"}),(0,P.jsx)("div",{className:"cdp-tile-sub",children:j.anomalies>0?"".concat(j.anomalies," flagged"):"within plan"})]}),(0,P.jsxs)("div",{className:"cdp-tile".concat(j.late>0?" is-warn":""),children:[(0,P.jsxs)("div",{className:"cdp-tile-label",children:[(0,P.jsx)(k.VP9,{})," On-time"]}),(0,P.jsxs)("div",{className:"cdp-tile-value",children:[j.onTime,g>0&&(0,P.jsxs)("span",{className:"cdp-tile-unit",children:["/",g]})]}),(0,P.jsx)("div",{className:"cdp-tile-sub",children:j.late>0?"".concat(j.late," late"):"all on schedule"})]}),(0,P.jsxs)("div",{className:"cdp-tile ".concat(f?"is-loss":"is-gain"),children:[(0,P.jsxs)("div",{className:"cdp-tile-label",children:[f?(0,P.jsx)(k.Rod,{}):(0,P.jsx)(k.imn,{})," ",f?"Loss":"Profit"]}),(0,P.jsxs)("div",{className:"cdp-tile-value",children:[f?"-":"","\u20b9",Math.abs(N).toFixed(0)]}),(0,P.jsxs)("div",{className:"cdp-tile-sub",children:[s.orders.length," ",1===s.orders.length?"order":"orders"," \xb7 ",y," delivered"]})]})]})]}),t.length>0&&(0,P.jsxs)("section",{className:"cdp-section cdp-seq-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head cdp-section-head-clickable",onClick:()=>d((e=>!e)),role:"button","aria-expanded":c,title:c?"Collapse route sequence":"Expand route sequence",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.$G1,{})}),(0,P.jsx)("span",{className:"cdp-section-title",children:"Route sequence"}),(0,P.jsx)("span",{className:"cdp-seq-status".concat(V.length>0?" is-warn":" is-good"),children:V.length>0?"".concat(V.length," out of order"):"In order"}),(0,P.jsx)("span",{className:"cdp-seq-toggle".concat(c?" is-open":""),children:(0,P.jsx)(k.j1Q,{})})]}),c&&(0,P.jsx)("div",{className:"cdp-seq",children:V.length>0?(0,P.jsx)("ul",{className:"cdp-seq-diffs",children:K.map(((e,s)=>{if(1===e.items.length)return x(e.items[0]);const t=e.items[0],a=e.items[e.items.length-1],i=o.has(s),l=e.delta>0?"+".concat(e.delta):"".concat(e.delta),c=e.items.some((e=>e.d.sequenceStep===n));return(0,P.jsxs)(r.Fragment,{children:[(0,P.jsxs)("li",{className:"cdp-seq-diff is-group".concat(i?" is-expanded":"").concat(c?" is-focused":""),onClick:()=>{return e=s,void u((s=>{const t=new Set(s);return t.has(e)?t.delete(e):t.add(e),t}));var e},"aria-expanded":i,children:[(0,P.jsxs)("span",{className:"cdp-seq-group-num",children:[(0,P.jsx)("span",{className:"cdp-seq-group-num-bg",style:{background:"linear-gradient(135deg, ".concat(A((t.planned||1)-1),", ").concat(A((a.planned||1)-1),")")}}),(0,P.jsxs)("span",{className:"cdp-seq-group-num-label",children:[e.items.length,"\xd7"]})]}),(0,P.jsxs)("div",{className:"cdp-seq-diff-body",children:[(0,P.jsxs)("div",{className:"cdp-seq-diff-title",children:[e.items.length," consecutive steps shifted"," ",(0,P.jsx)("span",{className:"cdp-seq-group-delta",children:l})]}),(0,P.jsxs)("div",{className:"cdp-seq-diff-sub",children:["Planned ",D(t.planned),"\u2013",D(a.planned)," ","visited"," ",(0,P.jsxs)("strong",{children:[D(t.actualPos),"\u2013",D(a.actualPos)]})]})]}),(0,P.jsx)("span",{className:"cdp-seq-diff-tag",children:l}),(0,P.jsx)("span",{className:"cdp-seq-group-toggle".concat(i?" is-open":""),"aria-hidden":"true",children:(0,P.jsx)(k.j1Q,{})})]}),i&&(0,P.jsx)("li",{className:"cdp-seq-group-children-wrap",children:(0,P.jsx)("ul",{className:"cdp-seq-group-children",children:e.items.map((e=>x(e,!1)))})})]},"run-".concat(s,"-").concat(t.d.sequenceStep))}))}):(0,P.jsxs)("div",{className:"cdp-seq-good",children:[(0,P.jsx)(k.mU9,{})," Rider followed the planned route in order."]})})]}),(E||_)&&(0,P.jsxs)("section",{className:"cdp-section cdp-timing-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.pWE,{})}),(0,P.jsx)("span",{className:"cdp-section-title",children:"Timing"}),O>0&&(0,P.jsxs)("span",{className:"cdp-timing-active-tag",children:[(0,P.jsx)("span",{className:"cdp-timing-active-pulse"}),"Day window"]})]}),(0,P.jsxs)("div",{className:"cdp-timing-clock",children:[(0,P.jsxs)("div",{className:"cdp-clock-card is-start",children:[(0,P.jsxs)("div",{className:"cdp-clock-label",children:[(0,P.jsx)(k.WVj,{})," First delivery"]}),(0,P.jsxs)("div",{className:"cdp-clock-face",children:[(0,P.jsx)("span",{className:"cdp-clock-time",children:E?E.format("hh:mm"):"\u2014"}),(0,P.jsx)("span",{className:"cdp-clock-period",children:E?E.format("A"):""})]}),(0,P.jsx)("div",{className:"cdp-clock-caption",children:"Started"})]}),(0,P.jsxs)("div",{className:"cdp-clock-track","aria-hidden":"true",children:[(0,P.jsx)("span",{className:"cdp-clock-track-line"}),(0,P.jsx)("span",{className:"cdp-clock-track-dot is-start"}),(0,P.jsx)("span",{className:"cdp-clock-track-dot is-end"}),(0,P.jsxs)("div",{className:"cdp-clock-duration",children:[(0,P.jsx)("span",{className:"cdp-clock-duration-icon",children:(0,P.jsx)(k.DZH,{})}),(0,P.jsx)("span",{className:"cdp-clock-duration-val",children:O>0?O>=60?"".concat(Math.floor(O/60),"h ").concat(O%60,"m"):"".concat(O,"m"):"\u2014"}),(0,P.jsx)("span",{className:"cdp-clock-duration-sub",children:"active"})]})]}),(0,P.jsxs)("div",{className:"cdp-clock-card is-end",children:[(0,P.jsxs)("div",{className:"cdp-clock-label",children:[(0,P.jsx)(k.mU9,{})," Last delivery"]}),(0,P.jsxs)("div",{className:"cdp-clock-face",children:[(0,P.jsx)("span",{className:"cdp-clock-time",children:_?_.format("hh:mm"):"\u2014"}),(0,P.jsx)("span",{className:"cdp-clock-period",children:_?_.format("A"):""})]}),(0,P.jsx)("div",{className:"cdp-clock-caption",children:"Finished"})]})]}),(0,P.jsxs)("div",{className:"cdp-timing-stats",children:[(0,P.jsxs)("div",{className:"cdp-timing-stat",children:[(0,P.jsxs)("div",{className:"cdp-timing-stat-head",children:[(0,P.jsx)("div",{className:"cdp-timing-stat-icon",children:(0,P.jsx)(k.VP9,{})}),(0,P.jsxs)("div",{className:"cdp-timing-stat-body",children:[(0,P.jsxs)("div",{className:"cdp-timing-stat-value",children:[I>0?"".concat(I):"\u2014",I>0&&(0,P.jsx)("span",{className:"cdp-timing-stat-unit",children:"min"})]}),(0,P.jsx)("div",{className:"cdp-timing-stat-label",children:"Avg / stop"})]})]}),t.length>0&&(0,P.jsxs)("div",{className:"cdp-timing-stat-viz cdp-stops-dots","aria-hidden":"true",children:[Array.from({length:Math.min(t.length,12)}).map(((e,s)=>(0,P.jsx)("span",{className:"cdp-stop-dot"},"dot-".concat(s)))),(0,P.jsxs)("span",{className:"cdp-timing-stat-viz-label",children:[t.length," stop",1===t.length?"":"s"]})]})]}),null!=R&&(0,P.jsxs)("div",{className:"cdp-timing-stat",children:[(0,P.jsxs)("div",{className:"cdp-timing-stat-head",children:[(0,P.jsx)("div",{className:"cdp-timing-stat-icon",children:(0,P.jsx)(k.BJM,{})}),(0,P.jsxs)("div",{className:"cdp-timing-stat-body",children:[(0,P.jsxs)("div",{className:"cdp-timing-stat-value",children:[R,(0,P.jsx)("span",{className:"cdp-timing-stat-unit",children:"km/h"})]}),(0,P.jsx)("div",{className:"cdp-timing-stat-label",children:"Avg speed"})]})]}),(0,P.jsxs)("div",{className:"cdp-timing-stat-viz cdp-speed-gauge","aria-hidden":"true",children:[(0,P.jsx)("div",{className:"cdp-speed-gauge-track",children:(0,P.jsx)("div",{className:"cdp-speed-gauge-fill",style:{width:"".concat(Math.min(100,parseFloat(R)/60*100),"%")}})}),(0,P.jsxs)("div",{className:"cdp-speed-gauge-scale",children:[(0,P.jsx)("span",{children:"0"}),(0,P.jsx)("span",{children:"30"}),(0,P.jsx)("span",{children:"60 km/h"})]})]})]})]})]}),(T||H)&&(0,P.jsxs)("section",{className:"cdp-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.SeC,{})}),(0,P.jsx)("span",{className:"cdp-section-title",children:"Highlights"})]}),(0,P.jsxs)("div",{className:"cdp-highlights",children:[T&&(0,P.jsxs)("div",{className:"cdp-highlight is-best",onClick:()=>v(T.sequenceStep),role:"button",title:"Focus this step",children:[(0,P.jsx)("span",{className:"cdp-highlight-rail","aria-hidden":"true"}),(0,P.jsxs)("div",{className:"cdp-highlight-content",children:[(0,P.jsxs)("div",{className:"cdp-highlight-top",children:[(0,P.jsxs)("span",{className:"cdp-highlight-label",children:[(0,P.jsx)("span",{className:"cdp-highlight-chip",children:(0,P.jsx)(k.mU9,{})}),"Fastest stop"]}),(0,P.jsxs)("span",{className:"cdp-highlight-step-chip",style:{background:A(T.sequenceStep-1)},children:["Step ",T.sequenceStep]})]}),(0,P.jsx)("div",{className:"cdp-highlight-title",children:T.deliverycustomer||"Step ".concat(T.sequenceStep)}),(0,P.jsx)("div",{className:"cdp-highlight-meta",children:(0,P.jsx)("span",{className:"cdp-highlight-pill is-good",children:null!=T.timeDeltaMin?0===T.timeDeltaMin?"On schedule":"".concat(T.timeDeltaMin>0?"+":"").concat(T.timeDeltaMin," min vs plan"):"On schedule"})})]})]}),H&&(0,P.jsxs)("div",{className:"cdp-highlight is-worst",onClick:()=>v(H.sequenceStep),role:"button",title:"Focus this step",children:[(0,P.jsx)("span",{className:"cdp-highlight-rail","aria-hidden":"true"}),(0,P.jsxs)("div",{className:"cdp-highlight-content",children:[(0,P.jsxs)("div",{className:"cdp-highlight-top",children:[(0,P.jsxs)("span",{className:"cdp-highlight-label",children:[(0,P.jsx)("span",{className:"cdp-highlight-chip",children:(0,P.jsx)(k.Wux,{})}),"Biggest deviation"]}),(0,P.jsxs)("span",{className:"cdp-highlight-step-chip",style:{background:A(H.sequenceStep-1)},children:["Step ",H.sequenceStep]})]}),(0,P.jsx)("div",{className:"cdp-highlight-title",children:H.deliverycustomer||"Step ".concat(H.sequenceStep)}),(0,P.jsxs)("div",{className:"cdp-highlight-meta",children:[null!=H.kmDeltaPct&&(0,P.jsxs)("span",{className:"cdp-highlight-pill is-bad",children:[H.kmDeltaPct>0?"+":"",H.kmDeltaPct.toFixed(0),"% route"]}),null!=H.timeDeltaMin&&H.timeDeltaMin>0&&(0,P.jsxs)("span",{className:"cdp-highlight-pill is-bad",children:["+",H.timeDeltaMin,"m late"]})]})]})]})]})]}),Y.length>1&&(0,P.jsxs)("section",{className:"cdp-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.$G1,{})}),(0,P.jsxs)("span",{className:"cdp-section-title",children:["Trips (",Y.length,")"]})]}),(0,P.jsx)("div",{className:"cdp-trips",children:Y.map((e=>{const s=e.profit<0;return(0,P.jsxs)("div",{className:"cdp-trip",children:[(0,P.jsxs)("div",{className:"cdp-trip-head",children:[(0,P.jsxs)("span",{className:"cdp-trip-badge",children:["Trip ",e.tNum]}),(0,P.jsxs)("span",{className:"cdp-trip-meta",children:[e.delivered,"/",e.count," delivered"]})]}),(0,P.jsxs)("div",{className:"cdp-trip-stats",children:[(0,P.jsxs)("span",{title:"Distance",children:[(0,P.jsx)(k.xI$,{}),e.actualKm.toFixed(1),"km",(0,P.jsxs)("small",{children:[" / ",e.plannedKm.toFixed(1)]})]}),(0,P.jsxs)("span",{className:s?"is-over":"",title:s?"Loss":"Profit",children:[(0,P.jsx)(k.ohY,{}),s?"-":"","\u20b9",Math.abs(e.profit).toFixed(0)]})]})]},"trip-".concat(e.tNum))}))})]}),h&&(e=>{const s=A(h.sequenceStep-1),t=h.kmDelta>=0?"+":"",a=h.anomaly?"is-over":h.kmDelta<-.1?"is-under":"",i=null!=h.timeDeltaMin?h.timeDeltaMin>10?"is-over":h.timeDeltaMin<-2?"is-under":"":"",r=F(h.orderstatus),n=parseFloat((null===(e=h.order)||void 0===e?void 0:e.profit)||0);return(0,P.jsxs)("section",{className:"cdp-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.$G1,{})}),(0,P.jsxs)("span",{className:"cdp-section-title",children:["Step ",h.sequenceStep," details"]}),(0,P.jsx)("button",{type:"button",className:"cdp-section-clear",onClick:()=>l(null),title:"Clear step focus",children:"Show all"})]}),(0,P.jsxs)("div",{className:"compare-delta".concat(h.anomaly?" is-anomaly":""),children:[(0,P.jsxs)("div",{className:"compare-delta-title",children:[(0,P.jsx)("span",{className:"compare-delta-step-badge",style:{background:s},children:h.sequenceStep}),(0,P.jsxs)("div",{className:"compare-delta-title-text",children:[(0,P.jsx)("div",{className:"compare-delta-title-main",children:h.deliverycustomer||"Step ".concat(h.sequenceStep)}),(0,P.jsxs)("div",{className:"compare-delta-title-sub",children:[h.pickupcustomer?"from ".concat(h.pickupcustomer," \xb7 "):"","Order #",h.orderid]})]}),h.orderstatus&&(0,P.jsx)("span",{className:"compare-delta-status",style:{background:r.bg,color:r.fg},children:r.label})]}),(0,P.jsxs)("div",{className:"compare-delta-grid",children:[(0,P.jsxs)("div",{className:"compare-delta-cell".concat(h.anomaly?" is-anomaly":""),children:[(0,P.jsx)("span",{className:"compare-delta-cell-label",children:"Distance"}),(0,P.jsxs)("span",{className:"compare-delta-cell-val",children:[h.actualKm.toFixed(2)," ",(0,P.jsx)("span",{className:"compare-delta-cell-unit",children:"km"})]}),(0,P.jsxs)("span",{className:"compare-delta-cell-sub",children:["planned ",h.plannedKm.toFixed(2)," km"]})]}),(0,P.jsxs)("div",{className:"compare-delta-cell",children:[(0,P.jsx)("span",{className:"compare-delta-cell-label",children:"\u0394 Route"}),(0,P.jsxs)("span",{className:"compare-delta-cell-val ".concat(a),children:[t,h.kmDelta.toFixed(2)," km"]}),(0,P.jsx)("span",{className:"compare-delta-cell-sub",children:null!=h.kmDeltaPct?"".concat(t).concat(h.kmDeltaPct.toFixed(0),"% vs plan"):"no planned km"})]}),(0,P.jsxs)("div",{className:"compare-delta-cell",children:[(0,P.jsx)("span",{className:"compare-delta-cell-label",children:"Time"}),(0,P.jsx)("span",{className:"compare-delta-cell-val ".concat(i),children:null!=h.timeDeltaMin?"".concat(h.timeDeltaMin>0?"+":"").concat(h.timeDeltaMin," min"):"\u2014"}),(0,P.jsx)("span",{className:"compare-delta-cell-sub",children:h.actualTs&&h.expectedTs?"".concat(h.actualTs.format("HH:mm")," vs ").concat(h.expectedTs.format("HH:mm")):h.actualTs?"delivered ".concat(h.actualTs.format("HH:mm")):"in flight"})]}),!Number.isNaN(n)&&0!==n&&(0,P.jsxs)("div",{className:"compare-delta-cell".concat(n<0?" is-anomaly":""),children:[(0,P.jsx)("span",{className:"compare-delta-cell-label",children:n<0?"Loss":"Profit"}),(0,P.jsxs)("span",{className:"compare-delta-cell-val ".concat(n<0?"is-over":"is-under"),children:[n<0?"-":"","\u20b9",Math.abs(n).toFixed(0)]}),(0,P.jsx)("span",{className:"compare-delta-cell-sub",children:"order revenue"})]})]})]})]})})(),b.length>0&&(0,P.jsxs)("section",{className:"cdp-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon cdp-icon-warn",children:(0,P.jsx)(k.ItP,{})}),(0,P.jsxs)("span",{className:"cdp-section-title",children:["Deviations (",b.length,")"]})]}),(0,P.jsx)("ul",{className:"cdp-dev-list",children:b.map((e=>{const s=A(e.sequenceStep-1),t=e.kmDelta>=0?"+":"";return(0,P.jsxs)("li",{className:"cdp-dev-item".concat(n===e.sequenceStep?" is-focused":""),onClick:()=>v(e.sequenceStep),children:[(0,P.jsx)("span",{className:"cdp-dev-num",style:{background:s},children:e.sequenceStep}),(0,P.jsxs)("div",{className:"cdp-dev-body",children:[(0,P.jsx)("div",{className:"cdp-dev-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),(0,P.jsxs)("div",{className:"cdp-dev-meta",children:[null!=e.kmDeltaPct&&(0,P.jsxs)("span",{className:"cdp-dev-chip is-over",children:[t,e.kmDeltaPct.toFixed(0),"% route"]}),null!=e.timeDeltaMin&&e.timeDeltaMin>10&&(0,P.jsxs)("span",{className:"cdp-dev-chip is-over",children:["+",e.timeDeltaMin,"m late"]})]})]})]},"dev-".concat(e.sequenceStep))}))})]}),(0,P.jsxs)("section",{className:"cdp-section",children:[(0,P.jsxs)("div",{className:"cdp-section-head",children:[(0,P.jsx)("span",{className:"cdp-section-icon",children:(0,P.jsx)(k.EgJ,{})}),(0,P.jsxs)("span",{className:"cdp-section-title",children:["Steps (",t.length,")"]}),(0,P.jsxs)("span",{className:"cdp-section-sub",children:[y,"/",t.length," delivered"]})]}),(0,P.jsx)("ul",{className:"cdp-step-list",children:t.map((e=>{var s;const t=A(e.sequenceStep-1),a=String(e.orderstatus||"").toLowerCase(),i=z.has(a),r=M.has(a),l=i&&!e.anomaly,c=n===e.sequenceStep,d=F(e.orderstatus),o=parseFloat((null===(s=e.order)||void 0===s?void 0:s.profit)||0),u=e.kmDelta>=0?"+":"",p=null!=e.timeDeltaMin?e.timeDeltaMin>10?"is-over":e.timeDeltaMin<-2?"is-under":"":"",m=["cdp-step",c?"is-focused":"",e.anomaly?"is-anomaly":"",l?"is-correct":"",r?"is-skipped":"",e.isLoading?"is-loading":""].filter(Boolean).join(" ");return(0,P.jsxs)("li",{className:m,onClick:()=>v(e.sequenceStep),children:[(0,P.jsxs)("span",{className:"cdp-step-num",style:{background:t},children:[e.sequenceStep,l&&(0,P.jsx)("span",{className:"cdp-step-check",children:(0,P.jsx)(k.mU9,{})}),e.anomaly&&(0,P.jsx)("span",{className:"cdp-step-flag",children:(0,P.jsx)(k.ItP,{})})]}),(0,P.jsxs)("div",{className:"cdp-step-body",children:[(0,P.jsxs)("div",{className:"cdp-step-title-row",children:[(0,P.jsx)("span",{className:"cdp-step-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),e.orderstatus&&(0,P.jsx)("span",{className:"cdp-step-status",style:{background:d.bg,color:d.fg},children:d.label})]}),(0,P.jsxs)("div",{className:"cdp-step-sub",children:[e.pickupcustomer?"from ".concat(e.pickupcustomer," \xb7 "):"","Order #",e.orderid]}),(0,P.jsxs)("div",{className:"cdp-step-deltas",children:[(0,P.jsxs)("span",{className:"cdp-step-delta",title:"Distance",children:[(0,P.jsx)(k.xI$,{}),e.actualKm.toFixed(1),"km",e.plannedKm>0&&(0,P.jsxs)("small",{className:e.anomaly?"is-over":"",children:[" ",u,e.kmDelta.toFixed(1)]})]}),(0,P.jsxs)("span",{className:"cdp-step-delta ".concat(p),title:"Delivery time",children:[(0,P.jsx)(k.VP9,{}),e.actualTs?e.actualTs.format("HH:mm"):"\u2014",null!=e.timeDeltaMin&&(0,P.jsxs)("small",{children:[" ",e.timeDeltaMin>0?"+":"",e.timeDeltaMin,"m"]})]}),!Number.isNaN(o)&&0!==o&&(0,P.jsxs)("span",{className:"cdp-step-delta".concat(o<0?" is-over":""),title:o<0?"Loss":"Profit",children:[(0,P.jsx)(k.ohY,{}),o<0?"-":"","\u20b9",Math.abs(o).toFixed(0)]})]})]})]},"step-".concat(e.sequenceStep))}))})]})]})]})};var L=t(85571);const E=["_ts"],_="#6366f1",O="#10b981",I=e=>{const s=parseFloat(e);return Number.isFinite(s)?s:NaN},R=e=>{if(!e)return"";const s=String(e).trim();if(!s)return"";if(s.includes(",")){const e=s.split(",").map((e=>e.trim())).filter(Boolean);return 0===e.length?s:e.length<=2?e.join(", "):e.slice(-2).join(", ")}const t=s.split(/\s+/).filter(Boolean),a=t.length>6?t.slice(-6).join(" "):s;return a.length>40?"".concat(a.slice(0,40).trim(),"\u2026"):a},T=e=>Number.isFinite(I(e.droplat||e.deliverylat))&&Number.isFinite(I(e.droplon||e.deliverylong)),H=e=>e.pickuplat||e.pickuplatitude||e.pickup_lat,V=e=>e.pickuplong||e.pickuplongitude||e.picklongitude||e.pickup_lon,K=e=>Number.isFinite(I(H(e)))&&Number.isFinite(I(V(e))),Y=[{id:"morning",name:"Morning Batch",startHour:0,endHour:8},{id:"afternoon",name:"Afternoon Batch",startHour:9,endHour:12},{id:"evening",name:"Evening Batch",startHour:16,endHour:19}],B="dispatch.slots.v7",U=["dispatch.slots.v1","dispatch.slots.v2","dispatch.slots.v3","dispatch.slots.v4","dispatch.slots.v5","dispatch.slots.v6"],G=(e,s)=>"Slot ".concat(e+1," \xb7 ").concat(J(s)),J=e=>{const s=Math.floor(e),t=Math.round(60*(e-s)),a=(s+11)%12+1,i=s>=12&&s<24?"PM":"AM";if(0===t)return"".concat(a," ").concat(i);const r=String(t).padStart(2,"0");return"".concat(a,":").concat(r," ").concat(i)},W=(e,s)=>s>=24?"After ".concat(J(e)):"".concat(J(e),"\u2013").concat(J(s)),Z=Y.map(((e,s)=>(0,i.A)((0,i.A)({},e),{},{label:e.name||G(s,e.startHour),range:W(e.startHour,e.endHour)}))),$=(e,s)=>{for(const t of s)if(e>=t.startHour&&e2&&void 0!==arguments[2]?arguments[2]:Z;const t=((e,s)=>{const t=Q.find((e=>e.id===s))||Q[0];for(const a of t.keys)if(null!==e&&void 0!==e&&e[a])return e[a];return null})(e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:"all");if(!t)return null;const a=String(t).trim();if(/^\d{4}-\d{2}-\d{2}$/.test(a))return null;const i=g()(t);return i.isValid()?$(i.hour()+i.minute()/60,s):null};function ee(e){let{targetRef:s}=e;const t=(0,n.ko)();return(0,r.useEffect)((()=>(s.current=t,()=>{s.current=null})),[t]),null}function se(e,s){const t=e=>e*Math.PI/180,a=t(e[0]),i=t(s[0]),r=t(s[0]-e[0]),n=t(s[1]-e[1]),l=Math.sin(r/2)**2+Math.cos(a)*Math.cos(i)*Math.sin(n/2)**2;return 12742*Math.asin(Math.min(1,Math.sqrt(l)))}function te(e){if(!Array.isArray(e)||e.length<2)return 0;let s=0;for(let t=1;t{let t=0,a=1/0;for(let i=0;i{const t=Math.max(s,i);a.push(e.slice(i,t+1)),i=t})),a}const ie=e=>{if(!e)return null;const s=g()(e);return s.isValid()?s.format("HH:mm:ss"):String(e)},re=[{key:"assigntime",label:"Assigned"},{key:"acceptedtime",label:"Accepted"},{key:"arrivaltime",label:"Arrived"},{key:"pickuptime",label:"Pickup"},{key:"starttime",label:"Started"},{key:"deliverytime",label:"Delivered",final:!0}],ne=e=>{const s=[...e.orders].sort(((e,s)=>{const t=e.trip_number||1,a=s.trip_number||1;return t!==a?t-a:(e.step||0)-(s.step||0)})),t=s.findIndex((e=>{const s=String(e.orderstatus||"").toLowerCase();return!z.has(s)&&!M.has(s)}));if(-1===t)return null;const a=s[t];if(!T(a))return null;const i=I(a.droplat||a.deliverylat),r=I(a.droplon||a.deliverylong);let n,l;const c=t>0?s[t-1]:null;if(c&&T(c))n=I(c.droplat||c.deliverylat),l=I(c.droplon||c.deliverylong);else{if(!K(a))return null;n=I(H(a)),l=I(V(a))}const d=(n+i)/2,o=(l+r)/2,u=s.filter((e=>z.has(String(e.orderstatus||"").toLowerCase()))).length;return{id:e.id,color:e.color,riderName:e.riderName,aerialLat:d,aerialLon:o,prevLat:n,prevLon:l,nextLat:i,nextLon:r,completedCount:u,totalCount:s.length,nextStep:a.step||t+1,nextCustomer:a.deliverycustomer||""}},le=e=>{const s=e.filter(T);if(!s.length)return[];const t=e.find(K),a=[];return t&&a.push([I(H(t)),I(V(t))]),s.forEach((e=>a.push([I(e.droplat||e.deliverylat),I(e.droplon||e.deliverylong)]))),a};delete v().Icon.Default.prototype._getIconUrl,v().Icon.Default.mergeOptions({iconRetinaUrl:"https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/images/marker-icon-2x.png",iconUrl:"https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/images/marker-icon.png",shadowUrl:"https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.7.1/images/marker-shadow.png"});const ce=["#0055FF","#00D82C","#FF6B00","#9D00FF","#FF00A8","#00C2B2","#FF9900","#FF0000"],de=e=>{const s=String(null!==e&&void 0!==e?e:"");if(!s)return ce[0];let t=0;for(let a=0;a>>0;return ce[t%ce.length]},oe=e=>{let{focusedItem:s,viewMode:t,orders:a,kitchens:i,locationKey:l}=e;const c=(0,n.ko)(),d=(0,r.useRef)(""),o=(0,r.useMemo)((()=>{const e=null!=l?"loc:".concat(l,"|"):"",r=e=>{let s=0,t=0,a=0;for(const i of e)Number.isFinite(i[0])&&Number.isFinite(i[1])&&(s+=i[0],t+=i[1],a+=1);return 0===a?"0":"".concat((s/a).toFixed(1),",").concat((t/a).toFixed(1))};if(s){var n,c,d;const t=null!==(n=null!==(c=null!==(d=s.id)&&void 0!==d?d:s.kitchenName)&&void 0!==c?c:s.name)&&void 0!==n?n:null!=s.lat?"".concat(s.lat,",").concat(s.lon):"item",a=s.orders?s.orders.length:0;return"".concat(e,"f|").concat(t,"|").concat(a)}const o=(i||[]).map((e=>[e.lat,e.lon])),u=r(o);if("kitchens"===t){const s=o.filter((e=>Number.isFinite(e[0])&&Number.isFinite(e[1]))).length;return"".concat(e,"k|").concat(s,"|").concat(u)}if("all"===t){const s=(a||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]));return"".concat(e,"a|").concat(s.length,"|").concat(r(s))}return"".concat(e,"m|").concat(t||"","|").concat(o.length,"|").concat(u)}),[s,t,a,i,l]);return(0,r.useEffect)((()=>{if(d.current===o)return;let e=[];s?s.orders?(e=s.orders.map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])),s.orders.forEach((s=>e.push([I(H(s)),I(V(s))])))):e=[[s.lat,s.lon]]:"kitchens"===t?(e=(i||[]).filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lon))).map((e=>[e.lat,e.lon])),0===e.length&&(e=(a||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])))):"all"===t?e=(a||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])):(e=(i||[]).filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lon))).map((e=>[e.lat,e.lon])),0===e.length&&(e=(a||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]))));const r=e.filter((e=>Number.isFinite(e[0])&&Number.isFinite(e[1])));if(r.length>0){const e=v().latLngBounds(r);if(e.isValid()){1===r.length||e.getNorthEast().equals(e.getSouthWest())?c.setView(r[0],15,{animate:!0,duration:.6}):c.flyToBounds(e,{padding:[60,60],duration:.6,maxZoom:16}),d.current=o}}else;}),[o,s,t,a,i,c]),null},ue=e=>{let{children:s}=e;return(0,P.jsx)("span",{className:"ico-inline",style:{display:"inline-flex",alignItems:"center",verticalAlign:"-2px",marginRight:4},children:s})},pe=e=>{let{data:s,embedded:t=!1,selectedRiderId:n,onRiderSelect:h,pulseOrderId:x}=e;const j=null!==s&&void 0!==s&&s.zones&&s.zones.length>0?"zones":"riders",[w,D]=(0,r.useState)(j),[J,Q]=(0,r.useState)(new Set),[se,pe]=(0,r.useState)(null),[me,he]=(0,r.useState)(null),[ve,xe]=(0,r.useState)(null),[je,ge]=(0,r.useState)(null),Ne=(0,r.useRef)({}),fe=(0,r.useRef)(new Set),be=((0,r.useRef)(null),(0,r.useRef)(null)),[ye,ke]=(0,r.useState)(null),Se=void 0!==n,[we,Fe]=(0,r.useState)(""),{data:ze}=(0,N.I)({queryKey:["appLocations"],queryFn:S.aL,staleTime:3e5}),Me="undefined"!==typeof window?localStorage.getItem("applocationid"):null,[Ce,Ae]=(0,r.useState)(null!=Me?Number(Me):0),[De,Pe]=(0,r.useState)(!1),qe=(0,r.useRef)(null),[Le,Ee]=(0,r.useState)("assigned"),[_e,Oe]=(0,r.useState)(!1),Ie=(0,r.useRef)(null),[Re,Te]=(0,r.useState)((()=>{if("undefined"===typeof window)return Z;try{const e=window.localStorage.getItem(B);if(!e)return Z;const s=JSON.parse(e);return Array.isArray(s)&&s.length===Y.length?s.map(((e,s)=>{const t=e.id||"slot-".concat(s+1),a=Number(e.startHour)||0,i=Number(e.endHour)||24,r=Z.find((e=>e.id===t));return{id:t,startHour:a,endHour:i,label:(null===r||void 0===r?void 0:r.name)||G(s,a),range:W(a,i)}})):Z}catch(e){return Z}})),He=Re,[Ve,Ke]=(0,r.useState)(!1),Ye=(0,r.useRef)(null);(0,r.useEffect)((()=>{if("undefined"!==typeof window)try{U.forEach((e=>window.localStorage.removeItem(e)))}catch(e){}}),[]);const Be=(0,r.useRef)(!1);(0,r.useEffect)((()=>{if(Be.current){if("undefined"!==typeof window)try{window.localStorage.setItem(B,JSON.stringify(Re.map((e=>{let{id:s,startHour:t,endHour:a}=e;return{id:s,startHour:t,endHour:a}}))))}catch(e){}}else Be.current=!0}),[Re]),(0,r.useEffect)((()=>{if(!De)return;const e=e=>{qe.current&&!qe.current.contains(e.target)&&Pe(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[De]),(0,r.useEffect)((()=>{if(!_e)return;const e=e=>{Ie.current&&!Ie.current.contains(e.target)&&Oe(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[_e]),(0,r.useEffect)((()=>{if(!Ve)return;const e=e=>{Ye.current&&!Ye.current.contains(e.target)&&Ke(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[Ve]);const[Ue,Ge]=(0,r.useState)(null),[Je,We]=(0,r.useState)(""),{data:Ze,isFetching:$e,isError:Qe,error:Xe}=(0,N.I)({queryKey:["riderPeriodicLog",Ue],queryFn:()=>(0,S.ne)(Ue),enabled:"rider-info"===w&&null!=Ue,refetchInterval:"rider-info"===w&&null!=Ue&&3e4,refetchIntervalInBackground:!1,staleTime:15e3,refetchOnWindowFocus:!1}),es=(0,r.useMemo)((()=>{const e=parseFloat(null===Ze||void 0===Ze?void 0:Ze.latitude),s=parseFloat(null===Ze||void 0===Ze?void 0:Ze.longitude);return Number.isFinite(e)&&Number.isFinite(s)?{lat:e.toFixed(4),lon:s.toFixed(4)}:null}),[null===Ze||void 0===Ze?void 0:Ze.latitude,null===Ze||void 0===Ze?void 0:Ze.longitude]),{data:ss}=(0,N.I)({queryKey:["reverseGeocode",null===es||void 0===es?void 0:es.lat,null===es||void 0===es?void 0:es.lon],queryFn:async()=>{const e=await fetch("https://nominatim.openstreetmap.org/reverse?lat=".concat(es.lat,"&lon=").concat(es.lon,"&format=json&zoom=16&addressdetails=1"),{headers:{Accept:"application/json"}});if(!e.ok)return null;const s=await e.json(),t=(null===s||void 0===s?void 0:s.address)||{};return{area:t.suburb||t.neighbourhood||t.village||t.hamlet||t.city_district||t.town||t.city||t.county||t.state||"",display:(null===s||void 0===s?void 0:s.display_name)||""}},enabled:"rider-info"===w&&!!es,staleTime:3e5,refetchOnWindowFocus:!1,retry:1}),ts=(0,r.useMemo)((()=>{if(!ze)return null;const e=ze.find((e=>String(e.applocationid)===String(Ce)));return(null===e||void 0===e?void 0:e.locationname)||null}),[ze,Ce]),[as,is]=(0,r.useState)({}),rs=(0,r.useRef)({}),[ns,ls]=(0,r.useState)({}),cs=(0,r.useRef)({}),[ds,os]=(0,r.useState)(!1),[us,ps]=(0,r.useState)([]),[ms,hs]=(0,r.useState)({}),vs=(0,r.useRef)(!1),[xs,js]=(0,r.useState)(g()().format("YYYY-MM-DD")),[gs,Ns]=(0,r.useState)(!1),[fs,bs]=(0,r.useState)((()=>g()(xs).isValid()?g()(xs).startOf("month"):g()().startOf("month"))),ys=(0,r.useRef)(null);(0,r.useEffect)((()=>{if(!gs)return;const e=e=>{ys.current&&(ys.current.contains(e.target)||Ns(!1))},s=e=>{"Escape"===e.key&&Ns(!1)};return document.addEventListener("mousedown",e),document.addEventListener("keydown",s),()=>{document.removeEventListener("mousedown",e),document.removeEventListener("keydown",s)}}),[gs]),(0,r.useEffect)((()=>{if(gs){const e=g()(xs);e.isValid()&&bs(e.startOf("month"))}}),[gs,xs]);const[ks,Ss]=(0,r.useState)(!1),[ws,Fs]=(0,r.useState)("combined"),[zs,Ms]=(0,r.useState)(!0),[Cs,As]=(0,r.useState)(!0),[Ds,Ps]=(0,r.useState)((()=>new Set)),qs=(0,r.useRef)(!1),[Ls,Es]=(0,r.useState)(!1),_s=(0,r.useRef)(!1),Os=(0,r.useRef)(!1),[Is,Rs]=(0,r.useState)(null),Ts=(0,r.useRef)(null),Hs=(0,r.useRef)(null);Hs.current||(Hs.current=v().canvas({padding:1.5,tolerance:5}));const{data:Vs}=(0,N.I)({queryKey:[Ce,xs,""],queryFn:S.zb,refetchInterval:3e4,refetchIntervalInBackground:!1,staleTime:15e3,refetchOnWindowFocus:!1}),Ks=(0,r.useMemo)((()=>(Vs||[]).map((e=>{var s;const t=parseFloat(null===e||void 0===e?void 0:e.latitude),a=parseFloat(null===e||void 0===e?void 0:e.longitude);return Number.isFinite(t)&&Number.isFinite(a)?{id:String(null!==(s=e.userid)&&void 0!==s?s:""),userid:e.userid,username:e.username||"Rider #".concat(e.userid),status:String(e.status||"").toLowerCase(),contactno:e.contactno,orderid:e.orderid,logdate:e.logdate,lat:t,lon:a}:null})).filter(Boolean)),[Vs]),[Ys,Bs]=(0,r.useState)((()=>{const e=g()();return $(e.hour()+e.minute()/60,Z)||Z[0].id}));(0,r.useEffect)((()=>{var e;"all"!==Ys&&(He.some((e=>e.id===Ys))||Bs((null===(e=He[0])||void 0===e?void 0:e.id)||"all"))}),[He,Ys]);const Us=(0,r.useRef)(null),Gs=!s,Js="undefined"!==typeof window&&localStorage.getItem("userid")||0,{data:Ws,isFetching:Zs,isError:$s,fetchNextPage:Qs,hasNextPage:Xs,isFetchingNextPage:et}=(0,f.q)({queryKey:["dispatchDeliveries",Ce,Js,"all",xs,xs,50,"",0,0,0],queryFn:S.tL,getNextPageParam:e=>{var s;return null!==(s=e.nextPage)&&void 0!==s?s:void 0},enabled:Gs});(0,r.useEffect)((()=>{Gs&&Xs&&!et&&Qs()}),[Gs,Xs,et,Qs]);const st=(0,r.useMemo)((()=>{const e=((null===Ws||void 0===Ws?void 0:Ws.pages)||[]).flatMap((e=>e.rows||[])),s=new Set,t=[];for(const a of e){const e=null!=a.orderid?String(a.orderid):null;e&&s.has(e)||(e&&s.add(e),t.push(a))}return t}),[Ws]),tt=(0,r.useMemo)((()=>{const e=new Map;return st.forEach((s=>{const t=String(s.userid||s.rider_id||"");t&&"unassigned"!==t&&"0"!==t&&(e.has(t)||e.set(t,{id:t,riderName:s.ridername||s.rider_name||s.username||"Rider ".concat(t)}))})),Array.from(e.values()).sort(((e,s)=>String(e.riderName).localeCompare(String(s.riderName))))}),[st]),at=(0,r.useMemo)((()=>{const e={all:st.length};return He.forEach((s=>{e[s.id]=0})),st.forEach((s=>{const t=X(s,Le,He);t&&(e[t]=(e[t]||0)+1)})),e}),[st,Le,He]),it=(0,r.useMemo)((()=>"all"===Ys?st:st.filter((e=>X(e,Le,He)===Ys))),[st,Ys,Le,He]),rt=(0,r.useMemo)((()=>{if(!Gs)return null;if(!it.length)return{code:200,zone_summary:[],zones:[]};const e=e=>String(e||"").trim(),s={};it.forEach((t=>{const a=e(t.deliverysuburb)||e(t.locationsuburb)||e(t.zone_name)||"Unzoned",i=a.toLowerCase(),r=String(t.userid||t.rider_id||"unassigned"),n=t.ridername||t.rider_name||t.username||("unassigned"===r?"Unassigned":"Rider ".concat(r));s[i]||(s[i]={zone_name:a,riders:{}}),s[i].riders[r]||(s[i].riders[r]={rider_id:r,rider_name:n,orders:[]}),s[i].riders[r].orders.push(t)}));const t=Object.values(s).map((e=>{const s=Object.values(e.riders).map((e=>{const s=[...e.orders].sort(((e,s)=>g()(e.deliverydate||e.assigntime||0).valueOf()-g()(s.deliverydate||s.assigntime||0).valueOf()));return(0,i.A)((0,i.A)({},e),{},{orders:s.map(((e,s)=>(0,i.A)((0,i.A)({},e),{},{trip_number:e.trip_number||1,step:e.step||s+1})))})}));return{zone_name:e.zone_name,riders:s}}));return{code:200,zone_summary:t.map((e=>{const s=e.riders.flatMap((e=>e.orders)),t=s.filter((e=>e.userid||e.rider_id)).length;return{zone_name:e.zone_name,total_orders:s.length,assigned_orders:t,unassigned_orders_count:s.length-t,active_riders_count:e.riders.filter((e=>"unassigned"!==e.rider_id)).length,total_delivery_kms:s.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),total_profit:s.reduce(((e,s)=>e+parseFloat(s.profit||0)),0)}})),zones:t}}),[Gs,it]),nt=(0,r.useMemo)((()=>{const e=s||rt||{zones:[],zone_summary:[]},t=e.zones||[],a={};(e.zone_summary||[]).forEach((e=>{a[e.zone_name]=e}));const i=(e,s)=>{const t={};return e.forEach((e=>{const a=s(e);a&&(t[a]=(t[a]||0)+1)})),Object.entries(t).map((e=>{let[s,t]=e;return{name:s,count:t}})).sort(((e,s)=>s.count-e.count))};return t.map((e=>{var s,t,r,n;const l=a[e.zone_name]||{},c=(e.riders||[]).flatMap((e=>e.orders||[])),d=(e.riders||[]).filter((e=>e.rider_id&&"unassigned"!==e.rider_id)).length,o=i(c,(e=>e.deliverysuburb||e.locationsuburb)),u=i(c,(e=>e.pickupcustomer||e.kitchen_key)),p={};return c.forEach((e=>{const s=String(e.orderstatus||"unknown").toLowerCase();p[s]=(p[s]||0)+1})),{id:e.zone_name,name:e.zone_name,riders:e.riders||[],orders:c,totalOrders:null!==(s=l.total_orders)&&void 0!==s?s:c.length,activeRidersCount:null!==(t=l.active_riders_count)&&void 0!==t?t:d,totalKms:null!==(r=l.total_delivery_kms)&&void 0!==r?r:c.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),totalProfit:null!==(n=l.total_profit)&&void 0!==n?n:c.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),suburbs:o,kitchens:u,statusCounts:p}}))}),[s,rt]),{riders:lt,kitchens:ct,allOrders:dt,stats:ot}=(0,r.useMemo)((()=>{const e=[];((s||rt||{zones:[],zone_summary:[]}).zones||[]).forEach((s=>{(s.riders||[]).forEach((t=>{t.orders.forEach((a=>{e.push((0,i.A)((0,i.A)({},a),{},{zone_name:s.zone_name,rider_name:t.rider_name,rider_id:t.rider_id}))}))}))}));const t={};e.forEach((e=>{const s=e.rider_id||e.userid||"unknown";t[s]||(t[s]={id:s,riderName:e.rider_name||e.username||e.rider||s,orders:[],color:ce[Object.keys(t).length%ce.length]}),t[s].orders.push(e)}));const a={};e.forEach((e=>{const s=e.pickupcustomer||e.kitchen_key||"Unknown",t=s.toLowerCase().trim();a[t]?!Number.isFinite(a[t].lat)&&K(e)&&(a[t].lat=I(H(e)),a[t].lon=I(V(e))):a[t]={id:t,kitchenName:s,lat:I(H(e)),lon:I(V(e)),orders:[],riders:new Set},a[t].orders.push(e),e.rider_id&&a[t].riders.add(e.rider_id)}));const r=e.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),n=e.reduce(((e,s)=>e+parseFloat(s.profit||0)),0);return{riders:Object.values(t).map((e=>(0,i.A)((0,i.A)({},e),{},{orders:[...e.orders].sort(((e,s)=>{const t=e.trip_number||1,a=s.trip_number||1;return t!==a?t-a:(e.step||0)-(s.step||0)}))}))).sort(((e,s)=>s.orders.length-e.orders.length)),kitchens:Object.values(a).sort(((e,s)=>s.orders.length-e.orders.length)),allOrders:e,stats:{totalOrders:e.length,totalKms:r,totalProfit:n,totalRiders:Object.keys(t).length}}}),[s,rt]),ut=Se?n&<.find((e=>e.id===n))||null:se,pt=(0,r.useCallback)((e=>{h&&h(e?e.id:null),Se||pe(e),ge(null)}),[Se,h]),mt=(0,r.useRef)(null);(0,r.useEffect)((()=>{const e=ut?ut.id:null;e!==mt.current&&(ut?L.A.info("Focused rider changed to: ".concat(ut.riderName," (").concat(ut.orders.length," orders)")):L.A.info("Focused rider reset to: None"),mt.current=e)}),[ut]),(0,r.useEffect)((()=>{je?L.A.info("Focused order updated: ID ".concat(je.orderid)):L.A.debug("Focused order selection cleared")}),[je]);const ht=(0,r.useRef)(0);(0,r.useEffect)((()=>{dt&&dt.length!==ht.current&&(L.A.info("Orders database updated: ".concat(dt.length," orders actively tracked")),ht.current=dt.length)}),[dt]);const vt=(0,r.useRef)(0);(0,r.useEffect)((()=>{Ks&&Ks.length!==vt.current&&(L.A.info("Live riders list updated: ".concat(Ks.length," active riders mapped")),vt.current=Ks.length)}),[Ks]);const xt=(0,r.useMemo)((()=>ut?{orders:ut.orders.length,riders:1,km:ut.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:ut.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),label:"Focused Rider"}:me?{orders:me.orders.length,riders:me.riders.size,km:me.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:me.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),label:"Focused Kitchen"}:{orders:ot.totalOrders,riders:ot.totalRiders,km:ot.totalKms,profit:ot.totalProfit,label:"Total Fleet"}),[ut,me,ot]),jt=(0,r.useMemo)((()=>lt.map(ne).filter(Boolean)),[lt]),gt=(0,r.useMemo)((()=>{if(!ut)return[];const e=new Set;return ut.orders.forEach((s=>{null!=s.deliveryid&&""!==s.deliveryid&&0!==s.deliveryid&&e.add(String(s.deliveryid))})),Array.from(e)}),[ut]),Nt=(0,b.E)({queries:gt.map((e=>({queryKey:["deliveryLogs",e],queryFn:async()=>{var s,t;const i=await y.A.get("".concat("https://jupiter.nearle.app/live/api/v3","/deliveries/getdeliverylogs/?deliveryid=").concat(e));return function(e){let s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!Array.isArray(e)||0===e.length)return[];if(1===e.length)return[{lat:e[0].lat,lng:e[0].lng,logdate:e[0].logdate}];const t=null!=s.processNoise?s.processNoise:1e-9,a=null!=s.measurementNoise?s.measurementNoise:1e-7,i=e=>e._ts||(e.logdate?new Date(e.logdate).getTime():0),r=s=>{let r=e[0][s],n=0,l=1,c=0,d=0,o=1;const u=[r];let p=i(e[0]);for(let m=1;m({lat:n[s],lng:l[s],logdate:e.logdate,_ts:e._ts})))}(([null===i||void 0===i||null===(s=i.data)||void 0===s?void 0:s.details,null===i||void 0===i||null===(t=i.data)||void 0===t?void 0:t.data,null===i||void 0===i?void 0:i.data,i].find((e=>Array.isArray(e)))||[]).map((e=>{var s,t,a;const i=null!==e&&void 0!==e&&e.logdate?g()(e.logdate):null;return{lat:parseFloat(null!==(s=null===e||void 0===e?void 0:e.latitude)&&void 0!==s?s:null===e||void 0===e?void 0:e.lat),lng:parseFloat(null!==(t=null!==(a=null===e||void 0===e?void 0:e.longitude)&&void 0!==a?a:null===e||void 0===e?void 0:e.lng)&&void 0!==t?t:null===e||void 0===e?void 0:e.lon),logdate:null===e||void 0===e?void 0:e.logdate,_ts:i&&i.isValid()?i.valueOf():Number.MAX_SAFE_INTEGER}})).filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lng))).sort(((e,s)=>e._ts-s._ts))).map((e=>{let{_ts:s}=e;return(0,a.A)(e,E)}))},enabled:ks&&null!=ut,staleTime:3e5,refetchOnWindowFocus:!1,retry:1})))}),ft=(0,r.useMemo)((()=>{if(!ut)return[];const e=e=>{const s=e.deliverytime||e.expecteddeliverytime;if(!s)return Number.MAX_SAFE_INTEGER;const t=g()(s);return t.isValid()?t.valueOf():Number.MAX_SAFE_INTEGER};return ut.orders.filter((e=>null!=e.deliveryid&&""!==e.deliveryid&&0!==e.deliveryid)).sort(((s,t)=>{const a=e(s)-e(t);return 0!==a?a:(s.step||0)-(t.step||0)})).map(((e,s)=>{const t=gt.indexOf(String(e.deliveryid)),a=t>=0?Nt[t]:null;return{sequenceStep:s+1,orderid:e.orderid,deliveryid:e.deliveryid,deliverycustomer:e.deliverycustomer,pickupcustomer:e.pickupcustomer,step:e.step,tripNumber:e.trip_number||1,deliverytime:e.deliverytime||e.expecteddeliverytime,kms:parseFloat(e.actualkms||e.kms||0)||0,profit:parseFloat(e.profit||0)||0,orderstatus:e.orderstatus,isLoading:(null===a||void 0===a?void 0:a.isLoading)||(null===a||void 0===a?void 0:a.isFetching),isError:null===a||void 0===a?void 0:a.isError,coords:(null===a||void 0===a?void 0:a.data)||[]}}))}),[ut,gt,Nt]),bt=(0,r.useMemo)((()=>ut?ft.map((e=>{const s=ut.orders.find((s=>String(s.deliveryid)===String(e.deliveryid))),t=parseFloat((null===s||void 0===s?void 0:s.kms)||0)||0,a=ns[e.deliveryid];let i=0;Array.isArray(a)&&a.length>=2?i=te(a):null!=(null===s||void 0===s?void 0:s.actualkms)&&""!==s.actualkms?i=parseFloat(s.actualkms)||0:e.coords.length>=2&&(i=te(e.coords.map((e=>[e.lat,e.lng]))));const r=i-t,n=t>0?r/t*100:null,l=null!==s&&void 0!==s&&s.expecteddeliverytime?g()(s.expecteddeliverytime):null,c=null!==s&&void 0!==s&&s.deliverytime?g()(s.deliverytime):null,d=null!==l&&void 0!==l&&l.isValid()&&null!==c&&void 0!==c&&c.isValid()?c.diff(l,"minute"):null,o=t>0&&i>1.25*t||null!=d&&d>15;return{sequenceStep:e.sequenceStep,deliveryid:e.deliveryid,orderid:e.orderid,order:s,plannedKm:t,actualKm:i,kmDelta:r,kmDeltaPct:n,expectedTs:null!==l&&void 0!==l&&l.isValid()?l:null,actualTs:null!==c&&void 0!==c&&c.isValid()?c:null,timeDeltaMin:d,anomaly:o,orderstatus:e.orderstatus,deliverycustomer:e.deliverycustomer,pickupcustomer:null===s||void 0===s?void 0:s.pickupcustomer,isLoading:e.isLoading,coordsCount:e.coords.length}})):[]),[ft,ut,ns]),yt=(0,r.useMemo)((()=>{if(0===bt.length)return{plannedKm:0,actualKm:0,kmDeltaPct:null,anomalies:0,late:0,onTime:0};const e=bt.filter((e=>!e.isLoading&&e.coordsCount>0)),s=e.reduce(((e,s)=>e+s.plannedKm),0),t=e.reduce(((e,s)=>e+s.actualKm),0);return{plannedKm:s,actualKm:t,kmDeltaPct:s>0?(t-s)/s*100:null,anomalies:e.filter((e=>e.anomaly)).length,late:e.filter((e=>null!=e.timeDeltaMin&&e.timeDeltaMin>5)).length,onTime:e.filter((e=>null!=e.timeDeltaMin&&e.timeDeltaMin<=5)).length}}),[bt]),kt=(0,r.useMemo)((()=>[...bt].sort(((e,s)=>{var t,a;return((null===(t=e.order)||void 0===t?void 0:t.step)||e.sequenceStep)-((null===(a=s.order)||void 0===a?void 0:a.step)||s.sequenceStep)}))),[bt]),St=(0,r.useMemo)((()=>[...bt].sort(((e,s)=>e.sequenceStep-s.sequenceStep))),[bt]),wt=(0,r.useMemo)((()=>{if(!ks||!Is||!ut)return null;const e=ft.find((e=>e.sequenceStep===Is));if(!e)return null;const s=ut.orders.find((s=>String(s.deliveryid)===String(e.deliveryid)));return s?{orders:[s],id:"cmp-step-".concat(Is,"-").concat(s.orderid)}:null}),[ks,Is,ut,ft]);(0,r.useEffect)((()=>{Rs(null),Ps(new Set),Fs("combined")}),[ks,null===ut||void 0===ut?void 0:ut.id]),(0,r.useEffect)((()=>{!ut&&ks&&Ss(!1)}),[ut,ks]),(0,r.useEffect)((()=>{qs.current&&ut&&(qs.current=!1,Ss(!0))}),[ut]),(0,r.useEffect)((()=>{ks&&!Os.current?(_s.current=Ls,Es(!0)):!ks&&Os.current&&Es(_s.current),Os.current=ks}),[ks]);const Ft=(0,r.useCallback)((async(e,s,t)=>{const a="".concat(e,"-").concat(s);if(void 0!==rs.current[a])return;if(t.length<2)return;rs.current[a]=null,is((e=>(0,i.A)((0,i.A)({},e),{},{[a]:null})));const r=t.map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),n="https://router.project-osrm.org/route/v1/driving/".concat(r,"?overview=full&geometries=geojson");try{const e=await fetch(n),s=await e.json();if(s.routes&&s.routes[0]){const e=s.routes[0].geometry.coordinates.map((e=>[e[1],e[0]]));rs.current[a]=e,is((s=>(0,i.A)((0,i.A)({},s),{},{[a]:e})))}else rs.current[a]=!1,is((e=>(0,i.A)((0,i.A)({},e),{},{[a]:!1})))}catch(l){console.error("OSRM Fetch error:",l),rs.current[a]=!1,is((e=>(0,i.A)((0,i.A)({},e),{},{[a]:!1})))}}),[]);(0,r.useEffect)((()=>{rs.current={},is({}),cs.current={},ls({})}),[xs,Ys]);const zt=(0,r.useCallback)((async(e,s)=>{if(void 0!==cs.current[e])return;if(!Array.isArray(s)||s.length<2)return;cs.current[e]=null,ls((s=>(0,i.A)((0,i.A)({},s),{},{[e]:null})));const t=s=>{cs.current[e]=s,ls((t=>(0,i.A)((0,i.A)({},t),{},{[e]:s})))},a=()=>{cs.current[e]=!1,ls((s=>(0,i.A)((0,i.A)({},s),{},{[e]:!1})))},r=(e,s)=>{if(e.length<=s)return e;const t=Math.ceil(e.length/s),a=e.filter(((e,s)=>s%t===0)),i=e[e.length-1];return a[a.length-1]!==i&&a.push(i),a};try{const e=r(s,90).map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),a="https://router.project-osrm.org/match/v1/driving/".concat(e,"?overview=full&geometries=geojson&gaps=ignore&tidy=true"),i=await fetch(a),n=await i.json();if(n.matchings&&n.matchings.length>0){const e=n.matchings.flatMap((e=>{var s;return((null===(s=e.geometry)||void 0===s?void 0:s.coordinates)||[]).map((e=>[e[1],e[0]]))}));if(e.length>=2)return void t(e)}}catch(n){console.warn("OSRM Match error, trying route fallback:",n)}try{const e=r(s,25).map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),i="https://router.project-osrm.org/route/v1/driving/".concat(e,"?overview=full&geometries=geojson"),n=await fetch(i),l=await n.json();if(l.routes&&l.routes[0]){const e=l.routes[0].geometry.coordinates.map((e=>[e[1],e[0]]));if(e.length>=2)return void t(e)}a()}catch(n){console.error("OSRM Route fallback error:",n),a()}}),[]);(0,r.useEffect)((()=>{ks&&ut&&ft.forEach((e=>{if(!e.deliveryid||e.coords.length<2)return;const s=e.coords.map((e=>[e.lat,e.lng]));zt(e.deliveryid,s)}))}),[ft,ks,ut,zt]),(0,r.useEffect)((()=>{vs.current=ds}),[ds]),(0,r.useEffect)((()=>{if(t)return;const e=()=>{const e=new Date;Fe([e.getHours(),e.getMinutes(),e.getSeconds()].map((e=>String(e).padStart(2,"0"))).join(":"))},s=setInterval(e,1e3);return e(),()=>clearInterval(s)}),[t]),(0,r.useEffect)((()=>{Q(new Set(lt.map((e=>e.id))))}),[lt]),(0,r.useEffect)((()=>{lt.forEach((e=>{if(!J.has(e.id))return;if(ut&&ut.id!==e.id)return;const s={};e.orders.forEach((e=>{const t=e.trip_number||1;s[t]||(s[t]=[]),s[t].push(e)})),Object.entries(s).forEach((s=>{let[t,a]=s;const i=[...a].sort(((e,s)=>(e.step||0)-(s.step||0))),r=le(i);r.length>=2&&Ft(e.id,t,r)}))}))}),[lt,J,ut,Ft]),(0,r.useEffect)((()=>{jt.forEach((e=>{if(me)return;if(ut&&ut.id!==e.id)return;if(!J.has(e.id))return;const s=[[e.prevLat,e.prevLon],[e.nextLat,e.nextLon]];Ft(e.id,"seg-".concat(e.nextStep),s)}))}),[jt,ut,me,J,Ft]);const Mt=(0,r.useRef)(null);(0,r.useEffect)((()=>{if(!Gs)return;const e=()=>{const e=g()();return e.hour()+e.minute()/60};null===Mt.current&&(Mt.current=e());const s=setInterval((()=>{const s=e(),t=$(Mt.current,He),a=$(s,He);Mt.current=s,a&&a!==t&&Bs((e=>e===t?a:e))}),3e4);return()=>clearInterval(s)}),[Gs,He]),(0,r.useEffect)((()=>{ge(null)}),[null===me||void 0===me?void 0:me.id]),(0,r.useEffect)((()=>{const e=Us.current;e&&"function"===typeof e.scrollIntoView&&e.scrollIntoView({behavior:"smooth",block:"nearest",inline:"center"})}),[Ys]),(0,r.useEffect)((()=>{if(!je)return;const e=setTimeout((()=>{var e;const s=null===dt||void 0===dt||null===(e=dt.find)||void 0===e?void 0:e.call(dt,(e=>String(e.orderid)===String(je.orderid)));s&&ke(s)}),350);return()=>clearTimeout(e)}),[je,dt]);const Ct=function(e){let s=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return v().divIcon({className:"",iconSize:s?[56,56]:[46,46],iconAnchor:s?[28,28]:[23,23],popupAnchor:[0,s?-30:-24],html:'
').concat((e||"K").charAt(0).toUpperCase(),"
")})},At=e=>{var s;return(null===(s=lt.find((s=>s.id===e)))||void 0===s?void 0:s.color)||"#475569"};return(0,P.jsxs)("div",{className:"dispatch-container".concat(t?" embedded":"").concat(ks?" compare-open":""),children:[!t&&(0,P.jsxs)("div",{id:"hdr",children:[(0,P.jsxs)("div",{className:"logo",children:[(0,P.jsx)("div",{className:"logo-badge",children:"D"}),(0,P.jsx)("div",{className:"logo-name",children:"Dispatch"}),ze&&ze.length>0&&(0,P.jsxs)("div",{className:"logo-city-wrap",ref:qe,children:[(0,P.jsxs)("button",{type:"button",className:"logo-city ".concat(De?"open":""),onClick:()=>Pe((e=>!e)),"aria-haspopup":"listbox","aria-expanded":De,title:"Switch hub",children:[(0,P.jsx)(k.JFD,{}),(0,P.jsx)("span",{className:"logo-city-text",children:ts||"All locations"}),(0,P.jsx)(k.j1Q,{className:"logo-city-caret"})]}),De&&(0,P.jsx)("div",{className:"logo-city-menu",role:"listbox",children:ze.map((e=>{const s=String(e.applocationid)===String(Ce);return(0,P.jsxs)("button",{type:"button",role:"option","aria-selected":s,className:"logo-city-option ".concat(s?"active":""),onClick:()=>(e=>{if(L.A.info("Switching hub/location ID:",e),Ae(Number(e)),Pe(!1),"undefined"!==typeof window)try{localStorage.setItem("applocationid",String(e))}catch(s){}pt(null),he(null),xe(null)})(e.applocationid),children:[(0,P.jsx)(k.JFD,{className:"logo-city-option-icon"}),(0,P.jsx)("span",{children:e.locationname}),s&&(0,P.jsx)("span",{className:"logo-city-option-check",children:"\u2713"})]},e.applocationid)}))})]})]}),(0,P.jsxs)("div",{className:"hdr-stats",children:[(()=>{const e=xt.profit<0,s=Math.abs(xt.profit);return(0,P.jsxs)("span",{className:"strat-stat ".concat(e?"strat-stat-loss":"strat-stat-profit"),title:"".concat(e?"Loss":"Profit"," (").concat(xt.label,")"),children:[(0,P.jsx)("span",{className:"strat-stat-icon",children:e?(0,P.jsx)(k.Rod,{}):(0,P.jsx)(k.imn,{})}),(0,P.jsx)("span",{className:"strat-stat-label",children:e?"Loss":"Profit"}),(0,P.jsxs)("span",{className:"strat-stat-value",children:[e?"-":"","\u20b9",s.toFixed(0)]})]})})(),Gs&&(0,P.jsxs)(P.Fragment,{children:[Zs&&(0,P.jsxs)("span",{className:"live-status",children:[(0,P.jsx)("span",{className:"live-dot"})," Loading ",st.length?"\xb7 ".concat(st.length," loaded"):""]}),!Zs&&!$s&&(0,P.jsxs)("span",{className:"live-status live-status-ready",children:[(0,P.jsx)("span",{className:"live-dot ready"})," ",it.length," orders",(0,P.jsxs)("span",{className:"live-status-sub",children:[" / ",st.length," total"]})]}),$s&&(0,P.jsxs)("span",{className:"live-status live-status-error",children:[(0,P.jsx)("span",{className:"live-dot error"})," Failed to load"]}),(()=>{const e=g()().startOf("day"),s=e.format("YYYY-MM-DD"),t=g()(xs),a=xs===s,i=t.isAfter(e,"day"),r=s=>{if(!s)return;const t=s.format("YYYY-MM-DD");t!==xs?s.isAfter(e,"day")||(js(t),pt(null),he(null),xe(null),Ns(!1)):Ns(!1)},n=fs.startOf("month"),l=n.subtract(n.day(),"day"),c=Array.from({length:42},((e,s)=>l.add(s,"day"))),d=!fs.add(1,"month").startOf("month").isAfter(e,"month");return(0,P.jsxs)("div",{className:"date-chip".concat(a?" is-today":"").concat(gs?" is-open":""),ref:ys,children:[(0,P.jsx)("button",{type:"button",className:"date-chip-nav",onClick:()=>r(t.subtract(1,"day")),"aria-label":"Previous day",title:"Previous day",children:(0,P.jsx)(k.E_E,{})}),(0,P.jsxs)("button",{type:"button",className:"date-chip-main",onClick:()=>Ns((e=>!e)),"aria-haspopup":"dialog","aria-expanded":gs,children:[(0,P.jsx)("span",{className:"date-chip-icon","aria-hidden":"true",children:(0,P.jsx)(k.dDC,{})}),(0,P.jsxs)("span",{className:"date-chip-text",children:[(0,P.jsxs)("span",{className:"date-chip-label",children:["Date",a&&(0,P.jsx)("span",{className:"date-chip-today-pill",children:"Today"})]}),(0,P.jsx)("span",{className:"date-chip-value",children:t.isValid()?t.format("ddd, MMM D, YYYY"):"\u2014"})]}),(0,P.jsx)("span",{className:"date-chip-chevron".concat(gs?" is-open":""),"aria-hidden":"true",children:(0,P.jsx)(k.j1Q,{})})]}),(0,P.jsx)("button",{type:"button",className:"date-chip-nav",onClick:()=>{a||i||r(t.add(1,"day"))},disabled:a||i,"aria-label":"Next day",title:a?"You're viewing today":"Next day",children:(0,P.jsx)(k.xVu,{})}),gs&&(0,P.jsxs)("div",{className:"date-cal-popover",role:"dialog","aria-label":"Pick a date",children:[(0,P.jsxs)("div",{className:"date-cal-header",children:[(0,P.jsx)("button",{type:"button",className:"date-cal-nav",onClick:()=>bs((e=>e.subtract(1,"month"))),"aria-label":"Previous month",children:(0,P.jsx)(k.E_E,{})}),(0,P.jsx)("div",{className:"date-cal-title",children:fs.format("MMMM YYYY")}),(0,P.jsx)("button",{type:"button",className:"date-cal-nav",onClick:()=>{const s=fs.add(1,"month");s.startOf("month").isAfter(e,"month")||bs(s)},disabled:!d,"aria-label":"Next month",children:(0,P.jsx)(k.xVu,{})})]}),(0,P.jsx)("div",{className:"date-cal-weekdays",children:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"].map((e=>(0,P.jsx)("div",{className:"date-cal-weekday",children:e},e)))}),(0,P.jsx)("div",{className:"date-cal-grid",children:c.map((t=>{const a=t.month()===fs.month(),i=t.format("YYYY-MM-DD")===xs,n=t.format("YYYY-MM-DD")===s,l=t.isAfter(e,"day"),c=["date-cal-day",!a&&"is-other-month",i&&"is-selected",n&&"is-today",l&&"is-disabled"].filter(Boolean).join(" ");return(0,P.jsx)("button",{type:"button",className:c,disabled:l,onClick:()=>r(t),"aria-current":n?"date":void 0,"aria-pressed":i,children:t.date()},t.format("YYYY-MM-DD"))}))}),(0,P.jsxs)("div",{className:"date-cal-presets",children:[(0,P.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>r(e),children:"Today"}),(0,P.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>r(e.subtract(1,"day")),children:"Yesterday"}),(0,P.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>r(e.subtract(7,"day")),children:"\u22127 days"})]})]})]})})()]})]}),(0,P.jsx)("div",{id:"clock",children:we})]}),(0,P.jsxs)("div",{id:"strat-row",children:[(0,P.jsxs)("button",{className:"sbt ".concat("kitchens"===w?"active":""),onClick:()=>{L.A.info("View mode changed: By Location"),D("kitchens"),pt(null),he(null),xe(null)},children:[(0,P.jsx)("span",{className:"sbt-icon",children:(0,P.jsx)(k.JFD,{})})," By Location"]}),(0,P.jsxs)("button",{className:"sbt ".concat("zones"===w?"active":""),onClick:()=>{L.A.info("View mode changed: By Zone"),D("zones"),pt(null),he(null),xe(null)},children:[(0,P.jsx)("span",{className:"sbt-icon",children:(0,P.jsx)(k.Cd7,{})})," By Zone"]}),(0,P.jsxs)("button",{className:"sbt ".concat("riders"===w?"active":""),onClick:()=>{L.A.info("View mode changed: By Rider"),D("riders"),pt(null),he(null),xe(null)},children:[(0,P.jsx)("span",{className:"sbt-icon",children:(0,P.jsx)(k.bsz,{})})," By Rider"]}),(0,P.jsxs)("button",{className:"sbt ".concat("all"===w?"active":""),onClick:()=>{L.A.info("View mode changed: All Routes"),D("all"),pt(null),he(null),xe(null)},children:[(0,P.jsx)("span",{className:"sbt-icon",children:(0,P.jsx)(k.Zs6,{})})," All Routes"]}),(0,P.jsxs)("button",{type:"button",className:"sbt sbt-rider-info ".concat("rider-info"===w?"active":""),onClick:()=>{D("rider-info"),pt(null),he(null),xe(null)},title:"Live GPS / battery / status snapshot for a rider",children:[(0,P.jsx)("span",{className:"sbt-icon",children:(0,P.jsx)(k.k4P,{})})," Rider Info"]})]}),Gs&&"rider-info"!==w&&(0,P.jsxs)("div",{id:"batch-row",children:[(0,P.jsx)("span",{className:"batch-label",children:"Batch"}),(0,P.jsx)("div",{className:"batch-scroll",children:He.map((e=>{var s;const t=Ys===e.id;return(0,P.jsxs)("button",{ref:t?Us:null,className:"batch-btn batch-slot ".concat(t?"active":""),onClick:()=>{Bs(e.id),pt(null),he(null),xe(null)},title:"".concat(e.label," (").concat(e.range,")"),children:[(0,P.jsx)("span",{className:"batch-btn-label",children:e.label}),(0,P.jsx)("span",{className:"batch-btn-count",children:null!==(s=at[e.id])&&void 0!==s?s:0})]},e.id)}))})]}),"rider-info"===w?(0,P.jsxs)("div",{className:"rider-info-mode",children:[(0,P.jsxs)("div",{className:"ri-sidebar",children:[(0,P.jsxs)("div",{className:"ri-sb-head",children:[(0,P.jsx)("div",{className:"ri-sb-title",children:"Riders"}),(0,P.jsxs)("div",{className:"ri-sb-sub",children:[tt.length," ",1===tt.length?"rider":"riders"," today"]})]}),(0,P.jsxs)("div",{className:"ri-search",children:[(0,P.jsx)(k.gZ7,{className:"ri-search-icon"}),(0,P.jsx)("input",{type:"text",className:"ri-search-input",placeholder:"Search by name or ID",value:Je,onChange:e=>We(e.target.value)})]}),(()=>{const e=Je.trim().toLowerCase(),s=tt.filter((s=>!e||(String(s.riderName||"").toLowerCase().includes(e)||String(s.id).includes(e))));return 0===s.length?(0,P.jsx)("div",{className:"ri-empty",children:Je?'No riders match "'.concat(Je,'"'):"No riders have orders today"}):(0,P.jsx)("div",{className:"ri-rider-list",children:s.map((e=>{const s=String(Ue)===String(e.id);return(0,P.jsxs)("button",{type:"button",className:"ri-rider-item ".concat(s?"active":""),onClick:()=>Ge(e.id),children:[(0,P.jsx)("span",{className:"ri-rider-dot",style:{background:de(e.id)}}),(0,P.jsxs)("span",{className:"ri-rider-info-block",children:[(0,P.jsx)("span",{className:"ri-rider-name",children:e.riderName}),(0,P.jsxs)("span",{className:"ri-rider-meta",children:["#",e.id]})]}),(0,P.jsx)("span",{className:"ri-rider-arrow",children:"\u2192"})]},e.id)}))})})()]}),(0,P.jsx)("div",{className:"ri-main",children:null==Ue?(0,P.jsxs)("div",{className:"ri-placeholder",children:[(0,P.jsx)("div",{className:"ri-placeholder-icon",children:(0,P.jsx)(k.k4P,{})}),(0,P.jsx)("div",{className:"ri-placeholder-title",children:"Pick a rider"}),(0,P.jsx)("div",{className:"ri-placeholder-sub",children:"Select a rider from the list on the left to see their live GPS, battery, connection, and current order snapshot."})]}):(0,P.jsxs)(P.Fragment,{children:[$e&&!Ze&&(0,P.jsx)("div",{className:"ri-loading",children:"Loading rider snapshot\u2026"}),Qe&&(0,P.jsxs)("div",{className:"ri-error",children:["Couldn't load this rider's log. ",(null===Xe||void 0===Xe?void 0:Xe.message)||""]}),Ze&&(()=>{const e=Ze,s=parseFloat(e.latitude),t=parseFloat(e.longitude),a=Number.isFinite(s)&&Number.isFinite(t),i=parseInt(String(e.battery||"").replace("%",""),10),r=Number.isFinite(i)&&i<=20,n=parseFloat(e.speed),c=String(e.status||"").toLowerCase();return(0,P.jsxs)("div",{className:"ri-snapshot",children:[(0,P.jsxs)("div",{className:"ri-snap-head",children:[(0,P.jsx)("div",{className:"ri-snap-name",children:e.username||"Rider #".concat(e.userid)}),(0,P.jsxs)("div",{className:"ri-snap-meta",children:[(0,P.jsxs)("span",{children:["#",e.userid]}),e.status&&(0,P.jsx)("span",{className:"ri-status ri-status-".concat(c),children:e.status}),(0,P.jsxs)("span",{className:"ri-live ".concat($e?"is-refetching":""),children:[(0,P.jsx)("span",{className:"ri-live-dot"}),$e?"Updating\u2026":"Live"]})]}),e.logdate&&(0,P.jsxs)("div",{className:"ri-snap-time",children:[(0,P.jsx)(k.VP9,{})," Last seen ",e.logdate]})]}),(0,P.jsxs)("div",{className:"ri-snap-grid",children:[(0,P.jsxs)("div",{className:"ri-stat ".concat(r?"ri-stat-warn":""),children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.wZm,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"Battery"}),(0,P.jsxs)("div",{className:"ri-stat-value",children:[e.battery||"\u2014",e.is_charging&&(0,P.jsx)("span",{className:"ri-stat-tag",children:"Charging"})]})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.Xh5,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"Connection"}),(0,P.jsx)("div",{className:"ri-stat-value",children:e.connection||"\u2014"})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.HPi,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"GPS Accuracy"}),(0,P.jsx)("div",{className:"ri-stat-value",children:e.accuracy?"".concat(e.accuracy," m"):"\u2014"})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.o8z,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"Location Service"}),(0,P.jsx)("div",{className:"ri-stat-value",children:e.location_service||"\u2014"})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.BJM,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"Speed"}),(0,P.jsx)("div",{className:"ri-stat-value",children:Number.isFinite(n)?"".concat(n.toFixed(2)," km/h"):"\u2014"})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.bqQ,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"Heading"}),(0,P.jsx)("div",{className:"ri-stat-value",children:null!=e.heading?"".concat(e.heading,"\xb0"):"\u2014"})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.pSF,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"App State"}),(0,P.jsx)("div",{className:"ri-stat-value",children:e.is_background?"Background":"Foreground"})]})]}),(0,P.jsxs)("div",{className:"ri-stat",children:[(0,P.jsx)("div",{className:"ri-stat-icon",children:(0,P.jsx)(k.gsJ,{})}),(0,P.jsxs)("div",{className:"ri-stat-body",children:[(0,P.jsx)("div",{className:"ri-stat-label",children:"Current Order"}),(0,P.jsx)("div",{className:"ri-stat-value",children:e.orderid||"\u2014"})]})]})]}),a&&(0,P.jsxs)("div",{className:"ri-map-section",children:[(0,P.jsxs)("div",{className:"ri-coords-label",children:[(0,P.jsx)(k.gwi,{})," ",s.toFixed(6),", ",t.toFixed(6)]}),(0,P.jsx)("div",{className:"ri-map",children:(0,P.jsxs)(d.W,{center:[s,t],zoom:13,scrollWheelZoom:!1,style:{height:"100%",width:"100%"},children:[(0,P.jsx)(o.e,{url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",attribution:"\xa9 OpenStreetMap contributors"}),(0,P.jsxs)(l.p,{position:[s,t],children:[(0,P.jsx)(u.m,{direction:"top",offset:[0,-10],permanent:!0,className:"ri-area-banner",children:(null===ss||void 0===ss?void 0:ss.area)||"Locating area\u2026"}),(0,P.jsxs)(p.z,{children:[(0,P.jsx)("div",{style:{fontWeight:700,marginBottom:2},children:e.username||"Rider #".concat(e.userid)}),(null===ss||void 0===ss?void 0:ss.area)&&(0,P.jsx)("div",{style:{fontSize:12,color:"#0f172a",marginBottom:4},children:ss.area}),(0,P.jsx)("div",{style:{fontSize:11,color:"#64748b"},children:e.logdate?"Last seen ".concat(e.logdate):"".concat(s.toFixed(6),", ").concat(t.toFixed(6))})]})]})]},"".concat(e.userid,"-").concat(s,"-").concat(t))})]})]})})()]})})]}):(0,P.jsxs)("div",{id:"body",className:"".concat(Ls?"sidebar-collapsed":""," ").concat(ks?"compare-mode":"").trim(),children:[(0,P.jsx)("button",{type:"button",className:"sidebar-toggle-tab".concat(Ls?" is-collapsed":""),onClick:()=>Es((e=>!e)),title:Ls?"Show sidebar":"Hide sidebar","aria-label":Ls?"Show sidebar":"Hide sidebar",children:Ls?(0,P.jsx)(k.xVu,{}):(0,P.jsx)(k.E_E,{})}),(0,P.jsxs)("div",{id:"sidebar",children:[!ut&&(0,P.jsxs)("div",{className:"sb-header",children:[(0,P.jsxs)("div",{className:"sb-header-top",children:[(0,P.jsxs)("div",{className:"sb-header-title",children:[(0,P.jsx)("span",{className:"sb-title-bar","aria-hidden":"true"}),(0,P.jsx)("span",{className:"sb-title-text",children:"RIDER DISPATCH"})]}),(0,P.jsxs)("span",{className:"sb-header-scope",title:xt.label,children:[(0,P.jsx)("span",{className:"sb-scope-dot"}),xt.label]})]}),(0,P.jsxs)("div",{className:"sb-header-tiles",children:[(0,P.jsxs)("div",{className:"sb-tile sb-tile-orders",children:[(0,P.jsx)("span",{className:"sb-tile-icon",children:(0,P.jsx)(k.gsJ,{})}),(0,P.jsxs)("div",{className:"sb-tile-body",children:[(0,P.jsx)("div",{className:"sb-tile-value",children:xt.orders}),(0,P.jsx)("div",{className:"sb-tile-label",children:1===xt.orders?"Order":"Orders"})]})]}),(0,P.jsxs)("div",{className:"sb-tile sb-tile-riders",children:[(0,P.jsx)("span",{className:"sb-tile-icon",children:(0,P.jsx)(k.aVM,{})}),(0,P.jsxs)("div",{className:"sb-tile-body",children:[(0,P.jsx)("div",{className:"sb-tile-value",children:xt.riders}),(0,P.jsx)("div",{className:"sb-tile-label",children:1===xt.riders?"Rider":"Riders"})]})]})]})]}),ut||me?(0,P.jsxs)("div",{id:"route-detail",children:[(0,P.jsxs)("button",{className:"rd-back",onClick:()=>{pt(null),he(null)},children:["\u2190 Back to ",ve?ve.name:"list"]}),ut?(0,P.jsxs)(P.Fragment,{children:[(0,P.jsx)("div",{className:"rd-rider-name",style:{color:ut.color},children:ut.riderName}),(()=>{const e=ut.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),s=ut.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),t=s<0;return(0,P.jsxs)("div",{className:"rd-stats-grid",children:[(0,P.jsxs)("div",{className:"rd-stat rd-stat-orders",children:[(0,P.jsx)("div",{className:"rd-stat-icon",children:(0,P.jsx)(k.gsJ,{})}),(0,P.jsx)("div",{className:"rd-stat-value",children:ut.orders.length}),(0,P.jsx)("div",{className:"rd-stat-label",children:"Orders"})]}),(0,P.jsxs)("div",{className:"rd-stat rd-stat-distance",children:[(0,P.jsx)("div",{className:"rd-stat-icon",children:(0,P.jsx)(k.xI$,{})}),(0,P.jsxs)("div",{className:"rd-stat-value",children:[e.toFixed(1),(0,P.jsx)("span",{className:"rd-stat-unit",children:"km"})]}),(0,P.jsx)("div",{className:"rd-stat-label",children:"Distance"})]}),(0,P.jsxs)("div",{className:"rd-stat rd-stat-profit ".concat(t?"is-loss":"is-gain"),children:[(0,P.jsx)("div",{className:"rd-stat-icon",children:t?(0,P.jsx)(k.Rod,{}):(0,P.jsx)(k.imn,{})}),(0,P.jsxs)("div",{className:"rd-stat-value",children:[t?"-":"","\u20b9",Math.abs(s).toFixed(0)]}),(0,P.jsx)("div",{className:"rd-stat-label",children:t?"Loss":"Profit"})]})]})})(),(()=>{const e={};ut.orders.forEach((s=>{const t=s.trip_number||1;e[t]||(e[t]=[]),e[t].push(s)}));const s=[...ut.orders].sort(((e,s)=>{const t=e.trip_number||1,a=s.trip_number||1;return t!==a?t-a:(e.step||0)-(s.step||0)})).find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!z.has(s)&&!M.has(s)})),t=s?s.orderid:null;let a=null;return Object.entries(e).sort(((e,s)=>{let[t]=e,[a]=s;return Number(t)-Number(a)})).map((e=>{let[s,i]=e;return(0,P.jsxs)("div",{className:"trip-block",children:[(0,P.jsxs)("div",{className:"trip-header",style:{background:"".concat(ut.color,"12"),borderColor:"".concat(ut.color,"30")},children:[(0,P.jsxs)("span",{className:"th-badge",style:{background:ut.color},children:["Trip ",s]}),(0,P.jsxs)("span",{className:"trip-stats",children:[(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.gwi,{})}),i.length," stops"]}),(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.xI$,{})}),i.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]})]})]}),(0,P.jsx)("div",{className:"zone-order-grid",children:i.map(((e,i)=>{const n=(e.kitchen_key||e.pickupcustomer||"Unknown").toLowerCase().trim(),l=null!==a&&n!==a;a=n;const c=je&&je.orderid===e.orderid,d=t&&e.orderid===t,o=parseFloat(e.droplat||e.deliverylat),u=parseFloat(e.droplon||e.deliverylong),p=Number.isFinite(o)&&Number.isFinite(u),m=F(e.orderstatus),h=parseFloat(e.profit||0),v=h<0;return(0,P.jsxs)(r.Fragment,{children:[l&&(0,P.jsxs)("div",{className:"kitchen-transition",children:[(0,P.jsx)("span",{className:"kt-ico",children:(0,P.jsx)(k.$G1,{})})," Switch to ",(0,P.jsx)("strong",{children:e.pickupcustomer})]}),(0,P.jsxs)("div",{className:"zone-order-card ".concat(p?"clickable":""," ").concat(c?"active":""," ").concat(d?"going-on":""),role:p?"button":void 0,tabIndex:p?0:void 0,onClick:p?()=>ge(c?null:{orderid:e.orderid,lat:o,lon:u}):void 0,onKeyDown:p?s=>{"Enter"!==s.key&&" "!==s.key||(s.preventDefault(),ge(c?null:{orderid:e.orderid,lat:o,lon:u}))}:void 0,title:p?c?"Click to show full trip":"Show ".concat(e.deliverycustomer||"order #".concat(e.orderid)," on map"):void 0,children:[(0,P.jsxs)("div",{className:"zone-order-card-head",children:[(0,P.jsx)("div",{className:"zone-order-num",children:e.step||i+1}),(0,P.jsx)("div",{className:"zone-order-id-block",children:(0,P.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]})}),(()=>{const s=ie(e.deliverytime),t=ie(e.expecteddeliverytime);return e.orderstatus||s||t?(0,P.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,P.jsx)("span",{className:"zone-order-status",style:{background:m.bg,color:m.fg},children:m.label}),(s||t)&&(0,P.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(t),children:[(0,P.jsx)(k.VP9,{}),s||t]})]}):null})()]}),(0,P.jsxs)("div",{className:"zone-order-customer",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,P.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,P.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.gwi,{})}),e.deliverysuburb||R(e.deliveryaddress)]}),e.ordernotes&&(0,P.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.dKO,{})}),e.ordernotes]}),(0,P.jsxs)("div",{className:"zone-order-stats",children:[(0,P.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,P.jsxs)("span",{className:"zone-order-chip ".concat(v?"is-loss":"is-profit"),title:"Profit",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.ohY,{})}),v?"-":"","\u20b9",Math.abs(h).toFixed(0)]}),null!=e.deliverycharge&&(0,P.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,P.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,P.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||s," \xb7 S",e.step||i+1]})]})]})]},e.orderid)}))})]},s)}))})()]}):(0,P.jsxs)(P.Fragment,{children:[(0,P.jsx)("div",{className:"rd-rider-name",style:{color:"#f59e0b"},children:me.kitchenName}),(0,P.jsxs)("div",{className:"rd-rider-sub",children:[(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.gsJ,{})}),me.orders.length," orders"]}),(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.aVM,{})}),me.riders.size," riders"]})]}),(0,P.jsxs)("div",{className:"zone-detail-section",children:[(0,P.jsxs)("div",{className:"zone-section-label",children:["Orders ",(0,P.jsxs)("span",{className:"section-count",children:["(",me.orders.length,")"]})]}),0===me.orders.length?(0,P.jsx)("div",{className:"zone-suburb-panel-empty",children:"No orders for this kitchen."}):(0,P.jsx)("div",{className:"zone-order-grid",children:me.orders.map(((e,s)=>{const t=parseFloat(e.droplat||e.deliverylat),a=parseFloat(e.droplon||e.deliverylong),i=Number.isFinite(t)&&Number.isFinite(a),r=je&&je.orderid===e.orderid,n=F(e.orderstatus),l=parseFloat(e.profit||0),c=l<0;return(0,P.jsxs)("div",{className:"zone-order-card ".concat(i?"clickable":""," ").concat(r?"active":""),role:i?"button":void 0,tabIndex:i?0:void 0,onClick:i?()=>ge(r?null:{orderid:e.orderid,lat:t,lon:a}):void 0,children:[(0,P.jsxs)("div",{className:"zone-order-card-head",children:[(0,P.jsx)("div",{className:"zone-order-num",children:s+1}),(0,P.jsxs)("div",{className:"zone-order-id-block",children:[(0,P.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]}),(0,P.jsxs)("div",{className:"zone-order-rider",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.aVM,{})}),e.rider_name||e.ridername||"Unassigned"]})]}),e.orderstatus&&(0,P.jsx)("span",{className:"zone-order-status",style:{background:n.bg,color:n.fg},children:n.label})]}),(0,P.jsxs)("div",{className:"zone-order-customer",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.u9F,{})}),e.deliverycustomer||"\u2014"]}),(e.deliverysuburb||e.deliveryaddress)&&(0,P.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.gwi,{})}),e.deliverysuburb||R(e.deliveryaddress)]}),e.ordernotes&&(0,P.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.dKO,{})}),e.ordernotes]}),(0,P.jsxs)("div",{className:"zone-order-stats",children:[(0,P.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,P.jsxs)("span",{className:"zone-order-chip ".concat(c?"is-loss":"is-profit"),title:"Profit",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.ohY,{})}),c?"-":"","\u20b9",Math.abs(l).toFixed(0)]}),null!=e.deliverycharge&&(0,P.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,P.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,P.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||"-"," \xb7 S",e.step||"-"]})]})]},e.orderid)}))})]})]})]}):ve?(0,P.jsxs)("div",{id:"route-detail",children:[(0,P.jsx)("button",{className:"rd-back",onClick:()=>xe(null),children:"\u2190 Back to zones"}),(0,P.jsx)("div",{className:"rd-rider-name",style:{color:"#3b82f6"},children:ve.name}),(0,P.jsx)("div",{className:"rd-rider-sub",children:(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.gsJ,{})}),ve.totalOrders," ",1===ve.totalOrders?"order":"orders"]})}),(0,P.jsxs)("div",{className:"zone-detail-section",children:[(0,P.jsxs)("div",{className:"zone-section-label",children:["Orders ",(0,P.jsxs)("span",{className:"section-count",children:["(",ve.orders.length,")"]})]}),0===ve.orders.length?(0,P.jsx)("div",{className:"zone-suburb-panel-empty",children:"No orders in this zone."}):(0,P.jsx)("div",{className:"zone-order-grid",children:ve.orders.map(((e,s)=>{const t=parseFloat(e.droplat||e.deliverylat),a=parseFloat(e.droplon||e.deliverylong),i=Number.isFinite(t)&&Number.isFinite(a),r=je&&je.orderid===e.orderid,n=F(e.orderstatus),l=parseFloat(e.profit||0),c=l<0;return(0,P.jsxs)("div",{className:"zone-order-card ".concat(i?"clickable":""," ").concat(r?"active":""),role:i?"button":void 0,tabIndex:i?0:void 0,onClick:i?()=>ge(r?null:{orderid:e.orderid,lat:t,lon:a}):void 0,children:[(0,P.jsxs)("div",{className:"zone-order-card-head",children:[(0,P.jsx)("div",{className:"zone-order-num",children:s+1}),(0,P.jsxs)("div",{className:"zone-order-id-block",children:[(0,P.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]}),(0,P.jsxs)("div",{className:"zone-order-rider",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.aVM,{})}),e.rider_name||e.ridername||"Unassigned"]})]}),e.orderstatus&&(0,P.jsx)("span",{className:"zone-order-status",style:{background:n.bg,color:n.fg},children:n.label})]}),(0,P.jsxs)("div",{className:"zone-order-customer",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,P.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,P.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.gwi,{})}),e.deliverysuburb||R(e.deliveryaddress)]}),e.ordernotes&&(0,P.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.dKO,{})}),e.ordernotes]}),(0,P.jsxs)("div",{className:"zone-order-stats",children:[(0,P.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,P.jsxs)("span",{className:"zone-order-chip ".concat(c?"is-loss":"is-profit"),title:"Profit",children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.ohY,{})}),c?"-":"","\u20b9",Math.abs(l).toFixed(0)]}),null!=e.deliverycharge&&(0,P.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,P.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,P.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||"-"," \xb7 S",e.step||"-"]})]})]},e.orderid)}))})]})]}):(0,P.jsxs)("div",{id:"riders-panel",children:[(0,P.jsx)("div",{className:"ph",children:"zones"===w?"Zone dispatch":"kitchens"===w?"Kitchen dispatch":"Rider dispatch"}),(0,P.jsx)("div",{id:"rider-cards",children:0!==dt.length||Zs?"zones"===w?nt.map(((e,s)=>{const t=e.statusCounts.delivered||0,a=e.totalProfit<0;return(0,P.jsxs)("div",{className:"rcard zone-card",onClick:()=>xe(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,P.jsxs)("div",{className:"zone-card-header",children:[(0,P.jsx)("div",{className:"zone-card-emoji",children:(0,P.jsx)(k.Cd7,{})}),(0,P.jsxs)("div",{className:"zone-card-titles",children:[(0,P.jsx)("div",{className:"zone-card-name",children:e.name}),(0,P.jsxs)("div",{className:"zone-card-sub",children:[e.activeRidersCount," ",1===e.activeRidersCount?"rider":"riders"," \xb7 ",e.totalOrders," ",1===e.totalOrders?"order":"orders"]})]}),(0,P.jsx)("span",{className:"zone-card-arrow","aria-hidden":"true",children:"\u2192"})]}),e.totalOrders>0&&(0,P.jsxs)("div",{className:"zone-progress-row",children:[(0,P.jsx)("div",{className:"zone-status-bar",title:Object.entries(e.statusCounts).map((e=>{let[s,t]=e;return"".concat(F(s).label,": ").concat(t)})).join(" \xb7 "),children:Object.entries(e.statusCounts).map((s=>{let[t,a]=s;const i=F(t),r=a/e.totalOrders*100;return(0,P.jsx)("div",{className:"zone-status-seg",style:{width:"".concat(r,"%"),background:i.bg}},t)}))}),(0,P.jsxs)("div",{className:"zone-progress-label",children:[t,"/",e.totalOrders]})]}),(0,P.jsxs)("div",{className:"zone-stat-pills",children:[(0,P.jsxs)("span",{className:"zone-stat-pill",title:"Areas covered",children:[(0,P.jsx)("span",{className:"zone-stat-icon",children:(0,P.jsx)(k.gwi,{})}),(0,P.jsx)("span",{className:"zone-stat-value",children:e.suburbs.length}),(0,P.jsx)("span",{className:"zone-stat-label",children:1===e.suburbs.length?"area":"areas"})]}),(0,P.jsxs)("span",{className:"zone-stat-pill",title:"Total distance",children:[(0,P.jsx)("span",{className:"zone-stat-icon",children:(0,P.jsx)(k.xI$,{})}),(0,P.jsx)("span",{className:"zone-stat-value",children:e.totalKms.toFixed(1)}),(0,P.jsx)("span",{className:"zone-stat-label",children:"km"})]}),(0,P.jsxs)("span",{className:"zone-stat-pill",title:"Kitchens",children:[(0,P.jsx)("span",{className:"zone-stat-icon",children:(0,P.jsx)(k.NtI,{})}),(0,P.jsx)("span",{className:"zone-stat-value",children:e.kitchens.length}),(0,P.jsx)("span",{className:"zone-stat-label",children:1===e.kitchens.length?"kitchen":"kitchens"})]}),(0,P.jsxs)("span",{className:"zone-stat-pill ".concat(a?"profit-negative":"profit-positive"),title:"Total profit",children:[(0,P.jsx)("span",{className:"zone-stat-icon",children:(0,P.jsx)(k.ohY,{})}),(0,P.jsx)("span",{className:"zone-stat-value",children:a?"-\u20b9".concat(Math.abs(e.totalProfit).toFixed(0)):"\u20b9".concat(e.totalProfit.toFixed(0))})]})]}),e.suburbs.length>0&&(0,P.jsxs)("div",{className:"zone-card-suburbs",children:[(0,P.jsx)("span",{className:"zone-card-suburbs-text",children:e.suburbs.slice(0,3).map((e=>e.name)).join(" \xb7 ")}),e.suburbs.length>3&&(0,P.jsxs)("span",{className:"zone-card-suburbs-more",children:["+",e.suburbs.length-3]})]})]},e.id)})):"kitchens"===w?ct.map(((e,s)=>(0,P.jsxs)("div",{className:"rcard",onClick:()=>he(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,P.jsxs)("div",{className:"rcard-top",children:[(0,P.jsx)("div",{className:"rcard-emo",style:{background:"#f59e0b18",borderColor:"#f59e0b50",color:"#f59e0b"},children:(0,P.jsx)(k.NtI,{})}),(0,P.jsxs)("div",{className:"rcard-info",children:[(0,P.jsx)("div",{className:"rcard-name",children:e.kitchenName}),(0,P.jsxs)("div",{className:"rcard-zone",children:[e.riders.size," riders \xb7 ",(0,P.jsx)(ue,{children:(0,P.jsx)(k.ohY,{})}),"\u20b9",e.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0).toFixed(0)]})]}),(0,P.jsx)("div",{className:"rcard-badge",style:{background:"#f59e0b18",color:"#f59e0b"},children:e.orders.length})]}),(0,P.jsx)("div",{className:"bar-bg",children:(0,P.jsx)("div",{className:"bar-fg",style:{width:"".concat(Math.min(100,e.orders.length/20*100),"%"),background:"#f59e0b"}})}),(0,P.jsxs)("div",{className:"rcard-meta",children:[(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.xI$,{})}),e.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]}),(0,P.jsxs)("span",{children:[e.riders.size," riders"]})]}),(0,P.jsx)("div",{className:"step-ids",children:Array.from(e.riders).slice(0,10).map((e=>{var s;return(0,P.jsx)("span",{className:"step-id",style:{color:At(e)},children:null===(s=lt.find((s=>s.id===e)))||void 0===s?void 0:s.riderName.split(" ")[0]},e)}))})]},e.id))):lt.map(((e,s)=>{var t;const a=e.orders.length,i=e.orders.filter((e=>z.has(String(e.orderstatus||"").toLowerCase()))).length,r=a>0&&i>=a;return(0,P.jsxs)("div",{className:"rcard",onClick:()=>pt(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,P.jsxs)("div",{className:"rcard-top",children:[(0,P.jsx)("div",{className:"rcard-emo",style:{background:"".concat(e.color,"18"),borderColor:"".concat(e.color,"50"),color:e.color},children:(0,P.jsx)(k.aVM,{})}),(0,P.jsxs)("div",{className:"rcard-info",children:[(0,P.jsx)("div",{className:"rcard-name",children:e.riderName}),(0,P.jsxs)("div",{className:"rcard-zone",children:[(null===(t=e.orders[0])||void 0===t?void 0:t.zone_name)||ts||"Local"," \xb7 ",new Set(e.orders.map((e=>e.trip_number||1))).size," trips"]})]}),(0,P.jsxs)("div",{className:"rcard-badge ".concat(r?"is-done":""),style:r?void 0:{background:"".concat(e.color,"18"),color:e.color},title:"".concat(i," delivered of ").concat(a," total"),children:[i,"/",a]})]}),(0,P.jsx)("div",{className:"bar-bg",children:(0,P.jsx)("div",{className:"bar-fg",style:{width:"".concat(Math.min(100,a/15*100),"%"),background:e.color}})}),(0,P.jsxs)("div",{className:"rcard-meta",children:[(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.xI$,{})}),e.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]}),(0,P.jsxs)("span",{children:[(0,P.jsx)(ue,{children:(0,P.jsx)(k.ohY,{})}),"\u20b9",e.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0).toFixed(0)]})]}),(0,P.jsx)("div",{className:"step-ids",children:e.orders.slice(0,15).map((e=>(0,P.jsxs)("span",{className:"step-id",children:["S",e.step]},e.orderid)))})]},e.id)})):(e=>{const s=null===(e=He.find((e=>e.id===Ys)))||void 0===e?void 0:e.label,t=Gs&&st.length>0;return(0,P.jsxs)("div",{className:"empty-slot",children:[(0,P.jsx)("div",{className:"empty-slot-icon",children:(0,P.jsx)(k.gsJ,{})}),(0,P.jsx)("div",{className:"empty-slot-title",children:s?"No orders in ".concat(s):"No orders"}),(0,P.jsx)("div",{className:"empty-slot-sub",children:t?"".concat(st.length," order").concat(1===st.length?"":"s"," exist in other slots today"):"No deliveries found for this date"})]})})()})]})]}),(0,P.jsxs)("div",{id:"map-wrap",className:"".concat("kitchens"===w?"view-mode-kitchens":""," ").concat(ks?"compare-split":"").trim(),children:[(0,P.jsxs)(d.W,{center:[11.022,76.982],zoom:12,scrollWheelZoom:!0,style:{height:"100%",width:"100%"},zoomControl:!1,renderer:Hs.current,inertia:!0,inertiaDeceleration:2400,inertiaMaxSpeed:2e3,wheelDebounceTime:20,wheelPxPerZoomLevel:80,zoomSnap:.25,children:[(0,P.jsx)(o.e,{url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",attribution:"\xa9 OpenStreetMap contributors"}),(0,P.jsx)(m.p,{position:"bottomright"}),ks&&(0,P.jsx)(ee,{targetRef:Ts}),(0,P.jsx)(oe,{focusedItem:wt||(ut||me)&&je||ut||me||ve,viewMode:w,orders:dt,kitchens:ct,locationKey:Ce}),ct.filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lon))).filter((e=>!ut||e.riders.has(ut.id))).map(((e,s)=>(0,P.jsx)(l.p,{position:[e.lat,e.lon],icon:Ct(e.kitchenName,(null===me||void 0===me?void 0:me.id)===e.id),zIndexOffset:(null===me||void 0===me?void 0:me.id)===e.id?4e3:2e3,eventHandlers:{click:()=>he(e),mouseover:e=>e.target.openPopup(),mouseout:e=>e.target.closePopup()},children:(0,P.jsxs)(p.z,{className:"kitchen-popup",maxWidth:220,minWidth:200,autoPan:!0,autoPanPadding:[20,20],children:[(0,P.jsx)("div",{className:"kp-header",children:"KITCHEN"}),(0,P.jsx)("div",{className:"kp-name",children:e.kitchenName}),(0,P.jsxs)("div",{className:"kp-stat",children:[(0,P.jsx)("span",{className:"kp-stat-lbl",children:"Orders"}),(0,P.jsx)("span",{className:"kp-stat-val",children:e.orders.length})]})]})},"k-".concat(s)))),(()=>{if(ks&&ut&&"actual"===ws)return null;let e=dt;ve&&(e=ve.orders),ut&&(e=ut.orders),me&&(e=me.orders),e=e.filter(T);const s=ks&&ut?new Map(ft.map((e=>[String(e.deliveryid),e.sequenceStep]))):null;return e.map(((t,a)=>{const i=t.rider_id,r=!i||J.has(i);let n,c=At(i);if(s&&i===ut.id&&null!=t.deliveryid){const e=s.get(String(t.deliveryid));e&&(c=A(e-1),n=e)}const d=n||t.step||(ut||me?e.indexOf(t)+1:0),o=32,u=F(t.orderstatus),p="delivered"===String(t.orderstatus||"").toLowerCase(),m=x&&String(x)===String(t.orderid),h=t.orderstatus?'\n \n \n ').concat(p?'':"","\n "):"",j=v().divIcon({className:"",iconSize:[o,o],iconAnchor:[16,16],popupAnchor:[0,-28],html:'
9?12:14,"px;opacity:").concat(r?1:.75,'">').concat(d>0?d:"").concat(h,"
")});return(0,P.jsx)(l.p,{position:[parseFloat(t.droplat||t.deliverylat),parseFloat(t.droplon||t.deliverylong)],icon:j,zIndexOffset:i?100:0,ref:e=>{e?Ne.current[String(t.orderid)]=e:delete Ne.current[String(t.orderid)]},eventHandlers:{mouseover:()=>{be.current&&(clearTimeout(be.current),be.current=null),ke(t)},mouseout:()=>{fe.current.has(String(t.orderid))||(be.current&&clearTimeout(be.current),be.current=setTimeout((()=>{ke((e=>e&&String(e.orderid)===String(t.orderid)?null:e)),be.current=null}),200))},click:()=>{const e=String(t.orderid);fe.current.has(e)?(fe.current.delete(e),ke(null)):(fe.current.add(e),ke(t))}}},t.orderid)}))})(),(()=>{const e=ks&&ut&&"actual"===ws;if(ds)return e?[]:us.map(((e,s)=>(0,P.jsx)(c.R,{positions:[e.from,e.to],pathOptions:{color:e.color,weight:6,opacity:.9,lineJoin:"round",lineCap:"round"}},s)));const s=[],t=ve?new Set(ve.riders.map((e=>String(e.rider_id)))):null;return e||lt.forEach((e=>{const a=J.has(e.id);if(ut&&ut.id!==e.id)return;if(me&&!me.riders.has(e.id))return;if(t&&!t.has(String(e.id)))return;const i=e.orders,n={};i.forEach((e=>{const s=e.trip_number||1;n[s]||(n[s]=[]),n[s].push(e)})),Object.entries(n).forEach((t=>{let[i,n]=t;const l=me?n.filter((e=>(e.pickupcustomer||e.kitchen_key||"Unknown").toLowerCase().trim()===me.id)):n;if(0===l.length)return;const d="".concat(e.id,"-").concat(i),o=as[d],u=[...l].sort(((e,s)=>(e.step||0)-(s.step||0))),p=Array.isArray(o)&&o.length>=2,m=!1===o;if(!p&&!m)return;const h=p?o:le(u);if(!h||h.length<2)return;const v=a?1:.1,x="kitchens"===w||me?7:6,j=ks&&ut&&e.id===ut.id,g=m?"8 6":j&&"combined"===ws?"6 5":void 0;if(ks&&ut&&e.id===ut.id){const t=new Map(ft.map((e=>[String(e.deliveryid),e.sequenceStep]))),a=u.filter(T),r=a.map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]));let n;if(p)n=ae(h,r);else{const e=h.length>r.length;n=[];for(let s=0;s=h.length||a>=h.length?n.push([]):n.push([h[t],h[a]])}}const l="combined"===ws?5:0;return s.push((0,P.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:x+4,opacity:.5*v,lineJoin:"round",lineCap:"round",offset:l}},"".concat(e.id,"-").concat(i,"-halo"))),void n.forEach(((r,n)=>{if(!r||r.length<2)return;const d=a[n],o=d?t.get(String(d.deliveryid)):null,u="combined"===ws?_:o?A(o-1):e.color,p=null!=Is&&Is===o,m=p?x+1.5:x,h=p?1:Is?.5*v:v;s.push((0,P.jsx)(c.R,{positions:r,pathOptions:{color:u,weight:m,opacity:h,lineJoin:"round",lineCap:"round",dashArray:g,offset:l}},"".concat(e.id,"-").concat(i,"-step-").concat(n,"-").concat((null===d||void 0===d?void 0:d.deliveryid)||n)))}))}s.push((0,P.jsxs)(r.Fragment,{children:[(0,P.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:x+4,opacity:.5*v,lineJoin:"round",lineCap:"round"}}),(0,P.jsx)(c.R,{positions:h,pathOptions:{color:e.color,weight:x,opacity:v,lineJoin:"round",lineCap:"round",dashArray:g}})]},"".concat(e.id,"-").concat(i)))}))})),s})(),!me&&jt.filter((e=>J.has(e.id))).filter((e=>!ut||ut.id===e.id)).map((e=>{const s=(e=>{if(!e||e.length<2)return null;const s=[];let t=0;for(let r=0;r=a){const t=(a-i)/s[r];return[e[r][0]+t*(e[r+1][0]-e[r][0]),e[r][1]+t*(e[r+1][1]-e[r][1])]}i+=s[r]}return e[e.length-1]})(as["".concat(e.id,"-seg-").concat(e.nextStep)]),t=s||[e.aerialLat,e.aerialLon],a=Boolean(s),i=v().divIcon({className:"",iconSize:[44,44],iconAnchor:[22,22],popupAnchor:[0,-22],html:'
\n
\n
').concat('','
\n
').concat(e.completedCount,"/").concat(e.totalCount,"
\n
")});return(0,P.jsx)(l.p,{position:t,icon:i,zIndexOffset:3e3,eventHandlers:{click:()=>pt(lt.find((s=>s.id===e.id))||null),mouseover:e=>e.target.openPopup(),mouseout:e=>e.target.closePopup()},children:(0,P.jsxs)(p.z,{maxWidth:240,autoPan:!0,autoPanPadding:[20,20],className:"dispatch-popup route-rider-popup",children:[(0,P.jsx)("div",{className:"pu-hdr-live",children:(0,P.jsx)("div",{className:"pu-hdr-left",children:(0,P.jsx)("span",{className:"pu-hdr-title",children:"RIDER ROUTE"})})}),(0,P.jsxs)("div",{className:"pu-rider-profile",children:[(0,P.jsx)("div",{className:"pu-avatar",style:{backgroundColor:"".concat(e.color,"12"),color:e.color},children:(0,P.jsx)(k.bsz,{})}),(0,P.jsxs)("div",{className:"pu-rider-info-text",children:[(0,P.jsx)("div",{className:"pu-rider-name",style:{color:e.color},children:e.riderName}),(0,P.jsx)("div",{className:"pu-rider-meta",children:"Active route details"})]})]}),(0,P.jsxs)("div",{className:"pu-body-content",children:[(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Progress"}),(0,P.jsxs)("span",{className:"pu-info-value",children:[(0,P.jsx)("strong",{children:e.completedCount})," / ",e.totalCount," delivered"]})]}),(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Next Stop"}),(0,P.jsxs)("span",{className:"pu-info-value text-indigo",style:{color:"#4f46e5"},children:["#",e.nextStep," \xb7 ",e.nextCustomer||"\u2014"]})]}),(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Position"}),(0,P.jsx)("span",{className:"pu-info-value",style:{color:"#64748b"},children:a?"On road":"Estimating\u2026"})]})]})]})},"bike-".concat(e.id))})),Ks.filter((e=>lt.some((s=>String(s.id)===String(e.id))))).filter((e=>!ut||String(ut.id)===String(e.id))).map((e=>{const s="active"===e.status?"#16a34a":"#dc2626",t=v().divIcon({className:"",iconSize:[140,56],iconAnchor:[12,41],popupAnchor:[58,-40],html:'
\n
\n
').concat((e.username||"").replace(/[<>&"']/g,"")).concat(e.orderid?" #".concat(String(e.orderid).replace(/[<>&"']/g,""),""):"","
\n
")});return(0,P.jsx)(l.p,{position:[e.lat,e.lon],icon:t,zIndexOffset:2500,eventHandlers:{click:()=>{const s=lt.find((s=>String(s.id)===String(e.id)));s&&pt(s)},mouseover:e=>e.target.openPopup(),mouseout:e=>e.target.closePopup()},children:(0,P.jsxs)(p.z,{maxWidth:260,autoPan:!0,autoPanPadding:[20,20],className:"dispatch-popup live-rider-popup",children:[(0,P.jsxs)("div",{className:"pu-hdr-live",children:[(0,P.jsxs)("div",{className:"pu-hdr-left",children:[(0,P.jsx)("span",{className:"pu-live-indicator",style:{"--pulse-color":s},children:(0,P.jsx)("span",{className:"pu-live-dot"})}),(0,P.jsx)("span",{className:"pu-hdr-title",children:"LIVE GPS"})]}),e.status&&(0,P.jsx)("span",{className:"pu-status-badge ".concat("active"===e.status.toLowerCase()?"active":"idle"),children:e.status})]}),(0,P.jsxs)("div",{className:"pu-rider-profile",children:[(0,P.jsx)("div",{className:"pu-avatar",style:{backgroundColor:"".concat(s,"12"),color:s},children:(0,P.jsx)(k.bsz,{})}),(0,P.jsxs)("div",{className:"pu-rider-info-text",children:[(0,P.jsx)("div",{className:"pu-rider-name",children:e.username||"Rider #".concat(e.id)}),(0,P.jsxs)("div",{className:"pu-rider-meta",children:["Rider ID: #",e.id]})]})]}),(0,P.jsxs)("div",{className:"pu-body-content",children:[e.orderid&&(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Active Order"}),(0,P.jsxs)("span",{className:"pu-info-value pu-order-badge",children:["#",e.orderid]})]}),e.contactno&&(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Phone"}),(0,P.jsx)("a",{href:"tel:".concat(e.contactno),className:"pu-info-value pu-phone-link",children:e.contactno})]}),e.logdate&&(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Last Seen"}),(0,P.jsxs)("span",{className:"pu-info-value pu-time-stamp",children:[(0,P.jsx)(k.VP9,{className:"inline-icon"})," ",g()(e.logdate).isValid()?g()(e.logdate).format("hh:mm:ss A"):e.logdate]})]}),(0,P.jsxs)("div",{className:"pu-info-row",children:[(0,P.jsx)("span",{className:"pu-info-label",children:"Position"}),(0,P.jsxs)("span",{className:"pu-info-value pu-coordinates",children:[e.lat.toFixed(5),", ",e.lon.toFixed(5)]})]})]})]})},"live-".concat(e.id))})),ks&&ut&&"planned"!==ws&&ft.map(((e,s)=>{var t,a;if(0===e.coords.length)return null;const i=A(s),n="combined"===ws?O:i,d=[e.coords[0].lat,e.coords[0].lng],o=[e.coords[e.coords.length-1].lat,e.coords[e.coords.length-1].lng],p=ns[e.deliveryid],m=Array.isArray(p)&&p.length>=2?p:e.coords.map((e=>[e.lat,e.lng]));let h=m,x=!0;if(ds){const s=ms[e.sequenceStep]||0;s<2?x=!1:h=m.slice(0,Math.min(s,m.length))}const j=Is===e.sequenceStep,N=String(e.orderstatus||"").toLowerCase(),f=z.has(N),b=M.has(N),y=bt.find((s=>s.sequenceStep===e.sequenceStep)),S=!(null===y||void 0===y||!y.anomaly),w=null===ut||void 0===ut||null===(t=ut.orders)||void 0===t?void 0:t.find((s=>null!=s.deliveryid&&String(s.deliveryid)===String(e.deliveryid))),C=["compare-step-pin"];j&&C.push("is-focused"),f&&C.push("is-delivered"),b&&C.push("is-skipped"),S&&C.push("is-anomaly");const D='
')+''.concat(e.sequenceStep,"")+(f?'':"")+"
",q=v().divIcon({className:"",iconSize:[36,36],iconAnchor:[18,18],popupAnchor:[0,-22],html:D}),L=1===e.sequenceStep,E=L?v().divIcon({className:"",iconSize:[40,40],iconAnchor:[20,20],html:'
')+'
'}):null,_=s=>{s.originalEvent&&s.originalEvent.stopPropagation(),Rs((s=>s===e.sequenceStep?null:e.sequenceStep)),w&&s.target&&"function"===typeof s.target.openPopup&&s.target.openPopup()},I="combined"===ws?-5:0;return(0,P.jsxs)(r.Fragment,{children:[x&&(0,P.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:j?11:9,opacity:j?.75:.55,lineJoin:"round",lineCap:"round",offset:I}}),x&&(0,P.jsx)(c.R,{positions:h,pathOptions:{color:n,weight:j?6.5:5,opacity:j?1:Is?.55:.95,lineJoin:"round",lineCap:"round",offset:I}}),L&&(0,P.jsx)(l.p,{position:d,icon:E,zIndexOffset:j?900:100,eventHandlers:{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),Rs((s=>s===e.sequenceStep?null:e.sequenceStep))}},children:(0,P.jsx)(u.m,{direction:"top",offset:[0,-12],opacity:1,className:"compare-tooltip",children:(0,P.jsxs)("div",{className:"cmp-tip",children:[(0,P.jsxs)("div",{className:"cmp-tip-header",children:[(0,P.jsx)("span",{className:"cmp-tip-step",style:{background:i},children:(0,P.jsx)(k.zPd,{})}),(0,P.jsxs)("div",{className:"cmp-tip-title-stack",children:[(0,P.jsx)("div",{className:"cmp-tip-title",children:e.pickupcustomer||"Pickup"}),(0,P.jsx)("div",{className:"cmp-tip-sub",children:null!==(a=e.coords[0])&&void 0!==a&&a.logdate?"Picked up \xb7 ".concat(g()(e.coords[0].logdate).format("hh:mm A")):"Rider trip origin"})]})]}),(0,P.jsx)("div",{className:"cmp-tip-action",children:"Click for step 1 details"})]})})}),(0,P.jsx)(l.p,{position:o,icon:q,zIndexOffset:j?1e3:200,eventHandlers:w?{mouseover:()=>{be.current&&(clearTimeout(be.current),be.current=null),ke(w)},mouseout:()=>{Is!==e.sequenceStep&&(be.current&&clearTimeout(be.current),be.current=setTimeout((()=>{ke((e=>e&&String(e.orderid)===String(w.orderid)?null:e)),be.current=null}),200))},click:_}:{click:_},children:!w&&(0,P.jsx)(u.m,{direction:"top",offset:[0,-20],opacity:1,className:"compare-tooltip",children:(()=>{const s=F(e.orderstatus);return(0,P.jsxs)("div",{className:"cmp-tip",children:[(0,P.jsxs)("div",{className:"cmp-tip-header",children:[(0,P.jsx)("span",{className:"cmp-tip-step",style:{background:i},children:e.sequenceStep}),(0,P.jsxs)("div",{className:"cmp-tip-title-stack",children:[(0,P.jsx)("div",{className:"cmp-tip-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),(0,P.jsx)("div",{className:"cmp-tip-sub",children:e.deliverytime?"Delivered ".concat(g()(e.deliverytime).format("hh:mm A")):"".concat(e.coords.length," GPS pings")})]}),e.orderstatus&&(0,P.jsx)("span",{className:"cmp-tip-tag",style:{background:s.bg,color:s.fg},children:s.label})]}),S&&(0,P.jsx)("div",{className:"cmp-tip-anomaly",children:"Deviation flagged \u2014 see details below"}),(0,P.jsx)("div",{className:"cmp-tip-action",children:j?"Click to deselect":"Click for details"})]})})()})})]},"actual-".concat(e.deliveryid))}))]}),ks&&ut&&(0,P.jsxs)("div",{className:"compare-view-switcher",role:"group","aria-label":"Compare view layer",children:[(0,P.jsx)("button",{type:"button",className:"actual"===ws?"is-active":"",onClick:()=>Fs("actual"),title:"Show only the rider's actual GPS trail",children:"Actual"}),(0,P.jsx)("button",{type:"button",className:"planned"===ws?"is-active":"",onClick:()=>Fs("planned"),title:"Show only the dispatched planned route",children:"Planned"}),(0,P.jsx)("button",{type:"button",className:"combined"===ws?"is-active":"",onClick:()=>Fs("combined"),title:"Overlay planned (dashed) and actual (solid) on one map",children:"Combined"})]}),(0,P.jsx)("div",{id:"ov-tl"}),(0,P.jsxs)("div",{id:"ov-br",children:[(0,P.jsxs)("button",{className:"sbt ".concat(ds?"active":""),onClick:()=>{if(ds)return os(!1),ps([]),void hs({});os(!0),ps([]),hs({});const e=ks&&ut,s=e?new Map(ft.map((e=>[String(e.deliveryid),e.sequenceStep]))):null,t=[];if(lt.forEach((a=>{if(!J.has(a.id))return;if(ut&&ut.id!==a.id)return;if(me&&!me.riders.has(a.id))return;const i={};a.orders.forEach((e=>{const s=e.trip_number||1;i[s]||(i[s]=[]),i[s].push(e)})),Object.entries(i).forEach((i=>{let[r,n]=i;const l=me?n.filter((e=>(e.pickupcustomer||e.kitchen_key||"Unknown").toLowerCase().trim()===me.id)):n;if(0===l.length)return;const c="".concat(a.id,"-").concat(r),d=as[c],o=[...l].sort(((e,s)=>(e.step||0)-(s.step||0))),u=le(o),p="kitchens"===w||me,m=d||u;if(m.length<2)return;let h=()=>a.color;if(e&&a.id===ut.id){const e=o.filter(T).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])),t=d?ae(d,e):(()=>{const s=u.length>e.length,t=[];for(let a=0;a=u.length||i>=u.length?t.push([]):t.push([u[e],u[i]])}return t})(),i=[];let r=0;t.forEach(((e,s)=>{const t=Math.max(0,((null===e||void 0===e?void 0:e.length)||0)-1);for(let a=0;a{const t=i[e];if(null==t)return a.color;const r=o.filter(T)[t],n=r?s.get(String(r.deliveryid)):null;return n?A(n-1):a.color}}for(let e=0;ee.delay-s.delay)),t.forEach(((e,s)=>{setTimeout((()=>{ps((s=>[...s,e])),s===t.length-1&&setTimeout((()=>{os(!1),hs({})}),1e3)}),e.delay)})),e&&ft.length>0){const e=[...ft],s=e.map((e=>{const s=ns[e.deliveryid];return Array.isArray(s)&&s.length>=2?s:e.coords.map((e=>[e.lat,e.lng]))})),a=t.length>0?t[t.length-1].delay:800*e.length,i=Math.max(a,600*e.length),r=i/Math.max(1,e.length),n=Date.now(),l=()=>{if(!vs.current)return;const t=Date.now()-n,a={};e.forEach(((e,i)=>{const n=s[i];if(!n||n.length<2)return;const l=i*r;if(t>=l+r)a[e.sequenceStep]=n.length;else if(t>=l){const s=(t-l)/r;a[e.sequenceStep]=Math.max(2,Math.ceil(s*n.length))}})),hs(a),t{if(ks)Ss(!1);else{if(!ut){const e=lt.find((e=>(e.orders||[]).some((e=>null!=e.deliveryid&&""!==e.deliveryid&&0!==e.deliveryid)))),s=lt.find((e=>e.orders&&e.orders.length>0)),t=e||s;if(t&&(pt(t),Se))return void(qs.current=!0)}Ss(!0)}},title:ut?"Compare planned vs. actual route for ".concat(ut.riderName):"Compare planned vs. actual route (will focus the first rider)",style:{boxShadow:"var(--shadow-lg)",background:ks?"linear-gradient(135deg, #6366f1, #3b82f6)":"#fff",marginLeft:8,color:ks?"#fff":void 0},children:[(0,P.jsx)("span",{className:"sbt-icon",children:(0,P.jsx)(k.$G1,{})}),ks?"Exit Compare":"Compare"]})]})]}),ks&&ut&&(0,P.jsx)("div",{id:"compare-map-wrap",children:(()=>{const e=ft.length,s=ft.filter((e=>e.coords.length>0)).length,t=ft.filter((e=>e.isLoading)).length,a=e>0?Math.round(s/e*100):0,i=e>0&&s===e&&0===t,n=null!=Is?bt.find((e=>e.sequenceStep===Is)):null;return(0,P.jsxs)("div",{className:"compare-header-v2",children:[(0,P.jsxs)("div",{className:"compare-header-row",children:[(0,P.jsxs)("div",{className:"compare-title",children:[(0,P.jsx)("span",{className:"compare-title-dot",style:{background:ut.color}}),(0,P.jsx)("span",{className:"compare-title-name",children:ut.riderName}),(0,P.jsx)("span",{className:"compare-title-badge",children:"ACTUAL vs PLANNED"})]}),(0,P.jsxs)("div",{className:"compare-header-tools",children:[null!=Is&&(0,P.jsxs)("button",{type:"button",className:"compare-overall-btn",onClick:()=>Rs(null),title:"Zoom out to the whole day",children:[(0,P.jsx)(k.Zs6,{})," Overall"]}),(0,P.jsx)("button",{type:"button",className:"compare-timeline-toggle".concat(Cs?" is-open":""),onClick:()=>As((e=>!e)),title:Cs?"Hide planned/actual timeline":"Show planned/actual timeline","aria-expanded":Cs,children:(0,P.jsx)(k.j1Q,{})})]})]}),Cs&&(0,P.jsxs)(P.Fragment,{children:[(0,P.jsxs)("div",{className:"compare-timeline-wrap",children:[(0,P.jsxs)("div",{className:"compare-timeline-container",children:[(0,P.jsxs)("div",{className:"compare-timeline-labels",children:[(0,P.jsx)("div",{className:"compare-timeline-label",children:"Planned"}),(0,P.jsx)("div",{className:"compare-timeline-label",children:"Actual"})]}),(0,P.jsxs)("div",{className:"compare-timeline-scrollable",children:[(0,P.jsx)("div",{className:"compare-timeline-track is-planned",children:kt.map(((e,s)=>{var t;const a=String(e.orderstatus||"").toLowerCase(),i=z.has(a),n=M.has(a),l=Is===e.sequenceStep,c=e.isLoading&&0===e.coordsCount,d=!e.isLoading&&0===e.coordsCount,o=(null===(t=e.order)||void 0===t?void 0:t.step)||e.sequenceStep,u=A(o-1),p=["compare-step",l&&"is-focused",i&&"is-delivered",n&&"is-skipped",!i&&!n&&"is-pending",c&&"is-loading",d&&"is-no-data",e.anomaly&&"is-anomaly"].filter(Boolean).join(" ");return(0,P.jsxs)(r.Fragment,{children:[s>0&&(0,P.jsx)("span",{className:"compare-step-spacer"}),(0,P.jsx)("button",{type:"button",className:p,style:{"--step-color":u},onClick:()=>Rs((s=>s===e.sequenceStep?null:e.sequenceStep)),title:"Planned Step ".concat(o)+(e.deliverycustomer?" \xb7 ".concat(e.deliverycustomer):"")+(e.anomaly?" \xb7 deviation flagged":""),children:(0,P.jsx)("span",{className:"compare-step-circle",children:c?(0,P.jsx)("span",{className:"compare-step-spin"}):o})})]},"step-p-".concat(e.deliveryid))}))}),(0,P.jsx)("div",{className:"compare-timeline-track is-actual",children:St.map(((e,s)=>{var t;const a=String(e.orderstatus||"").toLowerCase(),i=z.has(a),n=M.has(a),l=Is===e.sequenceStep,c=e.isLoading&&0===e.coordsCount,d=!e.isLoading&&0===e.coordsCount,o=(null===(t=e.order)||void 0===t?void 0:t.step)||e.sequenceStep,u=A(o-1),p=["compare-step",l&&"is-focused",i&&"is-delivered",n&&"is-skipped",!i&&!n&&"is-pending",c&&"is-loading",d&&"is-no-data",e.anomaly&&"is-anomaly"].filter(Boolean).join(" ");return(0,P.jsxs)(r.Fragment,{children:[s>0&&(0,P.jsx)("span",{className:"compare-step-spacer"}),(0,P.jsxs)("button",{type:"button",className:p,style:{"--step-color":u},onClick:()=>Rs((s=>s===e.sequenceStep?null:e.sequenceStep)),title:"Actual Visit ".concat(s+1," (Planned Step ").concat(o,")")+(e.deliverycustomer?" \xb7 ".concat(e.deliverycustomer):"")+(e.actualTs?" \xb7 ".concat(e.actualTs.format("hh:mm A")):"")+(e.anomaly?" \xb7 deviation flagged":""),children:[(0,P.jsx)("span",{className:"compare-step-circle",children:c?(0,P.jsx)("span",{className:"compare-step-spin"}):o}),e.actualTs&&(0,P.jsx)("span",{className:"compare-step-tick",children:e.actualTs.format("HH:mm")}),e.anomaly&&(0,P.jsx)("span",{className:"compare-step-flag",title:"Deviation flagged"})]})]},"step-a-".concat(e.deliveryid))}))})]})]}),(0,P.jsxs)("div",{className:"compare-progress-strip",children:[(0,P.jsx)("div",{className:"compare-progress-bar-wrap",children:(0,P.jsx)("div",{className:"compare-progress-bar-fill".concat(i?" is-done":""),style:{width:"".concat(a,"%")}})}),(0,P.jsx)("span",{className:"compare-progress-text",children:t>0?"Loading GPS\u2026 ".concat(s,"/").concat(e):"".concat(s,"/").concat(e," tracks")})]})]}),(()=>{const e="combined"===ws,s=n?A(n.sequenceStep-1):"linear-gradient(90deg, ".concat(C.slice(0,6).join(", "),")"),t=e?_:s,a=e?O:s;return(0,P.jsxs)("div",{className:"compare-legend",children:[(0,P.jsxs)("span",{className:"compare-legend-item",children:[(0,P.jsx)("span",{className:"compare-legend-swatch is-step-color is-dashed",style:{background:t}}),"Planned (dashed)"]}),(0,P.jsxs)("span",{className:"compare-legend-item",children:[(0,P.jsx)("span",{className:"compare-legend-swatch is-step-color",style:{background:a}}),"Actual GPS (solid)"]}),(0,P.jsx)("span",{className:"compare-legend-note",children:"Kalman-smoothed GPS \xb7 OSRM road-snapped"})]})})()]})]})})()}),ks&&ut&&(0,P.jsx)(q,{focusedRider:ut,compareDeltas:bt,compareSummary:yt,actualOrdered:St,focusedCompareStep:Is,setFocusedCompareStep:Rs,sequenceOpen:zs,setSequenceOpen:Ms,expandedSeqGroups:Ds,setExpandedSeqGroups:Ps,onClose:()=>Ss(!1)})]}),ye&&(0,P.jsx)("div",{className:"dispatch-popup-center",role:"dialog","aria-label":"Order ".concat(ye.orderid," details"),onMouseEnter:()=>{be.current&&(clearTimeout(be.current),be.current=null)},onMouseLeave:()=>{(e=>{if(!e)return!1;if(fe.current.has(String(e.orderid)))return!0;if(ks&&ut&&null!=e.deliveryid){const s=ft.find((s=>String(s.deliveryid)===String(e.deliveryid)));if(s&&Is===s.sequenceStep)return!0}return!1})(ye)||(be.current&&clearTimeout(be.current),be.current=setTimeout((()=>{ke(null),be.current=null}),200))},children:(0,P.jsxs)("div",{className:"dispatch-popup-card dispatch-popup",children:[(0,P.jsx)("button",{type:"button",className:"dispatch-popup-center-close","aria-label":"Close order details",onClick:()=>{fe.current.delete(String(ye.orderid)),ke(null)},children:"\xd7"}),(e=>{const s=F(e.orderstatus);return(0,P.jsxs)("div",{style:{height:"100%",width:"100%"},children:[(0,P.jsxs)("div",{className:"pu-header",children:[(0,P.jsxs)("div",{className:"pu-header-top",children:[(0,P.jsxs)("div",{className:"pu-id",children:["ORDER #",e.orderid]}),e.orderstatus&&(0,P.jsx)("span",{className:"pu-status-chip",style:{background:s.bg,color:s.fg},children:s.label})]}),(0,P.jsxs)("div",{className:"pu-rider",children:[(0,P.jsx)(k.aVM,{})," ",(0,P.jsx)("span",{children:e.rider_name||e.ridername||"Unassigned"})]}),null!=e.deliveryid&&(0,P.jsxs)("div",{className:"pu-delivery-id",children:["Delivery #",e.deliveryid]})]}),(0,P.jsxs)("div",{className:"pu-body",children:[re.some((s=>e[s.key]))&&(0,P.jsxs)("div",{className:"pu-section",children:[(0,P.jsx)("div",{className:"pu-section-label",children:"Timeline"}),(0,P.jsx)("div",{className:"pu-timeline",children:re.map((s=>{const t=ie(e[s.key]);return t?(0,P.jsxs)("div",{className:"pu-tl-row ".concat(s.final?"delivered":""),children:[(0,P.jsx)("span",{className:"pu-tl-dot"}),(0,P.jsx)("span",{className:"pu-tl-label",children:s.label}),(0,P.jsx)("span",{className:"pu-tl-time",children:t})]},s.key):null}))})]}),(0,P.jsxs)("div",{className:"pu-section",children:[(0,P.jsx)("div",{className:"pu-section-label",children:"Details"}),(0,P.jsxs)("div",{className:"pu-details-grid",children:[(e.pickupcustomer||e.locationname||e.pickuplocation)&&(0,P.jsxs)("div",{className:"pu-detail",children:[(0,P.jsx)("div",{className:"pu-detail-icon",children:(0,P.jsx)(k.NtI,{})}),(0,P.jsxs)("div",{className:"pu-detail-body",children:[(0,P.jsx)("div",{className:"pu-detail-label",children:"Pickup"}),(0,P.jsx)("div",{className:"pu-detail-value",title:e.pickupcustomer||e.locationname||e.pickuplocation,children:e.pickupcustomer||e.locationname||e.pickuplocation})]})]}),(e.deliverysuburb||e.deliveryaddress)&&(0,P.jsxs)("div",{className:"pu-detail",children:[(0,P.jsx)("div",{className:"pu-detail-icon",children:(0,P.jsx)(k.JFD,{})}),(0,P.jsxs)("div",{className:"pu-detail-body",children:[(0,P.jsx)("div",{className:"pu-detail-label",children:"Drop"}),(0,P.jsx)("div",{className:"pu-detail-value",title:e.deliveryaddress||e.deliverysuburb,children:e.deliverysuburb||R(e.deliveryaddress)})]})]}),e.zone_name&&(0,P.jsxs)("div",{className:"pu-detail",children:[(0,P.jsx)("div",{className:"pu-detail-icon",children:(0,P.jsx)(k.Cd7,{})}),(0,P.jsxs)("div",{className:"pu-detail-body",children:[(0,P.jsx)("div",{className:"pu-detail-label",children:"Zone"}),(0,P.jsx)("div",{className:"pu-detail-value",title:e.zone_name,children:e.zone_name})]})]}),(e.rider_id||e.userid)&&(0,P.jsxs)("div",{className:"pu-detail",children:[(0,P.jsx)("div",{className:"pu-detail-icon",children:(0,P.jsx)(k.aVM,{})}),(0,P.jsxs)("div",{className:"pu-detail-body",children:[(0,P.jsx)("div",{className:"pu-detail-label",children:"Rider ID"}),(0,P.jsxs)("div",{className:"pu-detail-value",children:["#",e.rider_id||e.userid]})]})]})]}),(null!=e.kms||null!=e.actualkms||null!=e.riderkms)&&(0,P.jsxs)("div",{className:"pu-distance-row",children:[null!=e.kms&&""!==e.kms&&(0,P.jsxs)("div",{className:"pu-distance-chip",children:[(0,P.jsx)("span",{className:"pu-distance-icon",children:(0,P.jsx)(k.xI$,{})}),(0,P.jsx)("span",{className:"pu-distance-label",children:"Planned"}),(0,P.jsxs)("span",{className:"pu-distance-value",children:[e.kms," km"]})]}),null!=e.actualkms&&""!==e.actualkms&&(0,P.jsxs)("div",{className:"pu-distance-chip",children:[(0,P.jsx)("span",{className:"pu-distance-icon",children:(0,P.jsx)(k.xI$,{})}),(0,P.jsx)("span",{className:"pu-distance-label",children:"Actual"}),(0,P.jsxs)("span",{className:"pu-distance-value",children:[e.actualkms," km"]})]}),null!=e.riderkms&&""!==e.riderkms&&(0,P.jsxs)("div",{className:"pu-distance-chip",children:[(0,P.jsx)("span",{className:"pu-distance-icon",children:(0,P.jsx)(k.bsz,{})}),(0,P.jsx)("span",{className:"pu-distance-label",children:"Rider"}),(0,P.jsxs)("span",{className:"pu-distance-value",children:[parseFloat(e.riderkms).toFixed(2)," km"]})]})]})]})]})]})})(ye)]})})]})}}}]);