Files
Express_console_build/build/static/js/6666.d98d718f.chunk.js

1 line
151 KiB
JavaScript

"use strict";(self.webpackChunkmantis_material_react=self.webpackChunkmantis_material_react||[]).push([[6666],{54413:(e,s,a)=>{a.r(s),a.d(s,{default:()=>pe});var t=a(80045),i=a(89379),n=a(9950),r=a(98007),l=a(47113),c=a(82215),d=a(99810),o=a(49029),u=a(33516),m=a(48513),p=a(37119),h=a(2527),x=a.n(h);a(55392);x().PolylineOffset={translatePoint:(e,s,a)=>x().point(e.x+s*Math.cos(a),e.y+s*Math.sin(a)),offsetPointLine(e,s){const a=e.length;if(a<2)throw new Error("Line should be defined by at least 2 points");let t,i=e[0];const n=Math.PI/2,r=[];for(let l=1;l<a;l++){t=e[l];const a=Math.atan2(t.y-i.y,t.x-i.x);r.push({offsetAngle:a-n,original:[i,t],offset:[this.translatePoint(i,s,a-n),this.translatePoint(t,s,a-n)]}),i=t}return r},intersection(e,s,a,t){const i=this.segmentAsVector(e,s),n=this.segmentAsVector(a,t),r=-n.x*i.y+i.x*n.y;if(0===r)return null;const l=(-i.y*(e.x-a.x)+i.x*(e.y-a.y))/r,c=(n.x*(e.y-a.y)-n.y*(e.x-a.x))/r;return l>=0&&l<=1&&c>=0&&c<=1?x().point(e.x+c*i.x,e.y+c*i.y):null},segmentAsVector:(e,s)=>x().point(s.x-e.x,s.y-e.y),joinLineSegments(e){const s=[];let a=e[0].offset;s.push(a[0]);for(let t=1;t<e.length;t++){const i=e[t].offset,n=this.intersection(a[0],a[1],i[0],i[1]);n?s.push(n):s.push(a[1]),a=i}return s.push(a[1]),s},offsetPoints(e,s){if(!e||e.length<2)return e;const a=this.offsetPointLine(e,s);return this.joinLineSegments(a)},offsetLatLngs(e,s,a){const t=s.map((s=>e.latLngToLayerPoint(s)));return this.offsetPoints(t,a).map((s=>e.layerPointToLatLng(s)))}};const v=x().Polyline.prototype._projectLatlngs;x().Polyline.prototype._projectLatlngs=function(e,s,a){const t=this.options.offset;if(!t||"number"!==typeof t)return v.call(this,e,s,a);if(!(e[0]instanceof x().LatLng)){for(let t=0;t<e.length;t++)this._projectLatlngs(e[t],s,a);return}const i=e.map((e=>this._map.latLngToLayerPoint(e))),n=x().PolylineOffset.offsetPoints(i,t);for(let r=0;r<n.length;r++)a.extend(n[r]);s.push(n)};var j=a(4159),g=a.n(j),f=a(51778),N=a(36150),b=a(60010),y=a(36687),k=a(26910),S=a(31222),_=a(81425),w=a(84702),F=a(14857),M=a(47223),C=a(44414);const z=function(e){let{focusedRider:s,compareDeltas:a,compareSummary:t,actualOrdered:i,focusedCompareStep:r,setFocusedCompareStep:l,sequenceOpen:c,setSequenceOpen:d,expandedSeqGroups:o,setExpandedSeqGroups:u,onClose:m}=e;const p=(0,F.A)(),h=(0,M.A)(p.breakpoints.down("md")),x=(0,n.useMemo)((()=>{const e=t,n=e.onTime+e.late,r=s.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),l=r<0,c=a.filter((e=>e.anomaly)),d=a.filter((e=>w.Ys.has(String(e.orderstatus||"").toLowerCase()))).length,o=a.filter((e=>w.yP.has(String(e.orderstatus||"").toLowerCase()))).length,u=null==e.kmDeltaPct?"":e.kmDeltaPct>25?"is-over":e.kmDeltaPct<-5?"is-under":"",m=a.length||1,p=e.onTime+e.late||1,h=Math.round(d/m*60+e.onTime/p*25+(m-e.anomalies)/m*15),x=h>=85?"#16a34a":h>=65?"#f59e0b":"#dc2626",v=h>=85?"Excellent":h>=65?"Acceptable":"Needs review",j=a.filter((e=>e.actualTs)),g=j.reduce(((e,s)=>!e||s.actualTs.isBefore(e)?s.actualTs:e),null),f=j.reduce(((e,s)=>!e||s.actualTs.isAfter(e)?s.actualTs:e),null),N=g&&f?Math.max(0,f.diff(g,"minute")):0,b=a.length>1?Math.round(N/(a.length-1)):0,y=N>0?(e.actualKm/(N/60)).toFixed(1):null,k=a.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,_=k.filter((e=>e.anomaly)).sort(((e,s)=>{const a=Math.abs(e.kmDeltaPct||0)+(e.timeDeltaMin>0?e.timeDeltaMin:0);return Math.abs(s.kmDeltaPct||0)+(s.timeDeltaMin>0?s.timeDeltaMin:0)-a}))[0]||null,F=i.filter(((e,s)=>{var a;const t=null===(a=e.order)||void 0===a?void 0:a.step;return null!=t&&t!==s+1})),M=[];F.forEach((e=>{var s;const a=null===(s=e.order)||void 0===s?void 0:s.step,t=i.findIndex((s=>s.sequenceStep===e.sequenceStep))+1,n=t-a,r=M[M.length-1];r&&r.delta===n&&r.lastActualPos+1===t?(r.items.push({d:e,planned:a,actualPos:t,delta:n}),r.lastActualPos=t):M.push({delta:n,items:[{d:e,planned:a,actualPos:t,delta:n}],lastActualPos:t})}));const C={};s.orders.forEach((e=>{const s=e.trip_number||1;C[s]||(C[s]=[]),C[s].push(e)}));const z=Object.entries(C).sort(((e,s)=>{let[a]=e,[t]=s;return Number(a)-Number(t)})).map((e=>{let[s,a]=e;return{tNum:s,count:a.length,plannedKm:a.reduce(((e,s)=>e+parseFloat(s.kms||0)),0),actualKm:a.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:a.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),delivered:a.filter((e=>w.Ys.has(String(e.orderstatus||"").toLowerCase()))).length}}));return{sum:e,totalSteps:n,totalProfit:r,isLoss:l,deviations:c,delivered:d,skipped:o,stepDeltaPct:u,score:h,scoreColor:x,scoreLabel:v,firstDelivery:g,lastDelivery:f,activeMin:N,avgPerStop:b,avgSpeed:y,bestStep:S,worstStep:_,outOfOrderSteps:F,seqRuns:M,tripList:z}}),[s,a,t,i]),v=null!=r?a.find((e=>e.sequenceStep===r)):null,j=e=>{l((s=>s===e?null:e))},g=function(e){let s=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];const{d:a,planned:t,actualPos:i,delta:n}=e;return(0,C.jsxs)("li",{className:"cdp-seq-diff".concat(r===a.sequenceStep?" is-focused":"").concat(s?"":" is-nested"),onClick:()=>j(a.sequenceStep),children:[(0,C.jsx)("span",{className:"cdp-seq-diff-num",style:{background:(0,w.gM)((t||a.sequenceStep)-1)},children:t||a.sequenceStep}),(0,C.jsxs)("div",{className:"cdp-seq-diff-body",children:[(0,C.jsx)("div",{className:"cdp-seq-diff-title",children:a.deliverycustomer||"Step ".concat(t||a.sequenceStep)}),(0,C.jsxs)("div",{className:"cdp-seq-diff-sub",children:["Visited ",(0,C.jsx)("strong",{children:(0,w.IE)(i)})," ","\xb7 planned ",(0,C.jsx)("strong",{children:(0,w.IE)(t)})]})]}),(0,C.jsx)("span",{className:"cdp-seq-diff-tag",children:n>0?"+".concat(n):"".concat(n)})]},"diff-".concat(a.sequenceStep))},{sum:f,totalSteps:N,totalProfit:b,isLoss:y,deviations:k,delivered:_,skipped:z,stepDeltaPct:A,score:P,scoreColor:E,scoreLabel:D,firstDelivery:L,lastDelivery:q,activeMin:I,avgPerStop:O,avgSpeed:R,bestStep:T,worstStep:H,outOfOrderSteps:Y,seqRuns:V,tripList:K}=x;return(0,C.jsxs)("aside",{id:"compare-data-panel",className:"compare-data-panel".concat(h?" cdp-is-mobile":""),children:[(0,C.jsxs)("div",{className:"cdp-head",children:[(0,C.jsxs)("div",{className:"cdp-head-title",children:[(0,C.jsx)("span",{className:"cdp-rider-dot",style:{background:s.color}}),(0,C.jsxs)("div",{className:"cdp-head-text",children:[(0,C.jsx)("div",{className:"cdp-rider-name",children:s.riderName}),(0,C.jsx)("div",{className:"cdp-head-badge",children:"PLANNED vs ACTUAL"})]})]}),(0,C.jsx)("button",{type:"button",className:"cdp-close",onClick:m,title:"Exit compare","aria-label":"Exit compare",children:(0,C.jsx)(S.m6K,{})})]}),(0,C.jsxs)("div",{className:"cdp-scroll",children:[(0,C.jsx)("section",{className:"cdp-section cdp-score-section",children:(0,C.jsxs)("div",{className:"cdp-score-wrap",children:[(0,C.jsx)("div",{className:"cdp-score-ring",style:{background:"conic-gradient(".concat(E," ").concat(3.6*P,"deg, rgba(15,23,42,0.08) 0deg)")},children:(0,C.jsxs)("div",{className:"cdp-score-inner",children:[(0,C.jsx)("div",{className:"cdp-score-value",style:{color:E},children:P}),(0,C.jsx)("div",{className:"cdp-score-unit",children:"/100"})]})}),(0,C.jsxs)("div",{className:"cdp-score-body",children:[(0,C.jsx)("div",{className:"cdp-score-label",style:{color:E},children:D}),(0,C.jsx)("div",{className:"cdp-score-title",children:"Compliance score"}),(0,C.jsxs)("div",{className:"cdp-score-sub",children:[_,"/",a.length," delivered",f.anomalies>0?" \xb7 ".concat(f.anomalies," deviation").concat(f.anomalies>1?"s":""):"",f.late>0?" \xb7 ".concat(f.late," late"):"",z>0?" \xb7 ".concat(z," skipped"):""]})]})]})}),(0,C.jsxs)("section",{className:"cdp-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.Zs6,{})}),(0,C.jsx)("span",{className:"cdp-section-title",children:"Day overview"})]}),(0,C.jsxs)("div",{className:"cdp-tiles",children:[(0,C.jsxs)("div",{className:"cdp-tile",children:[(0,C.jsxs)("div",{className:"cdp-tile-label",children:[(0,C.jsx)(S.xI$,{})," Distance"]}),(0,C.jsxs)("div",{className:"cdp-tile-value",children:[f.actualKm.toFixed(1),(0,C.jsx)("span",{className:"cdp-tile-unit",children:"km"})]}),(0,C.jsxs)("div",{className:"cdp-tile-sub",children:["planned ",f.plannedKm.toFixed(1)," km"]})]}),(0,C.jsxs)("div",{className:"cdp-tile".concat(f.anomalies>0?" is-warn":""),children:[(0,C.jsxs)("div",{className:"cdp-tile-label",children:[(0,C.jsx)(S.Wux,{})," Deviation"]}),(0,C.jsx)("div",{className:"cdp-tile-value ".concat(A),children:null!=f.kmDeltaPct?"".concat(f.kmDeltaPct>0?"+":"").concat(f.kmDeltaPct.toFixed(0),"%"):"\u2014"}),(0,C.jsx)("div",{className:"cdp-tile-sub",children:f.anomalies>0?"".concat(f.anomalies," flagged"):"within plan"})]}),(0,C.jsxs)("div",{className:"cdp-tile".concat(f.late>0?" is-warn":""),children:[(0,C.jsxs)("div",{className:"cdp-tile-label",children:[(0,C.jsx)(S.VP9,{})," On-time"]}),(0,C.jsxs)("div",{className:"cdp-tile-value",children:[f.onTime,N>0&&(0,C.jsxs)("span",{className:"cdp-tile-unit",children:["/",N]})]}),(0,C.jsx)("div",{className:"cdp-tile-sub",children:f.late>0?"".concat(f.late," late"):"all on schedule"})]}),(0,C.jsxs)("div",{className:"cdp-tile ".concat(y?"is-loss":"is-gain"),children:[(0,C.jsxs)("div",{className:"cdp-tile-label",children:[y?(0,C.jsx)(S.Rod,{}):(0,C.jsx)(S.imn,{})," ",y?"Loss":"Profit"]}),(0,C.jsxs)("div",{className:"cdp-tile-value",children:[y?"-":"","\u20b9",Math.abs(b).toFixed(0)]}),(0,C.jsxs)("div",{className:"cdp-tile-sub",children:[s.orders.length," ",1===s.orders.length?"order":"orders"," \xb7 ",_," delivered"]})]})]})]}),a.length>0&&(0,C.jsxs)("section",{className:"cdp-section cdp-seq-section",children:[(0,C.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,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.$G1,{})}),(0,C.jsx)("span",{className:"cdp-section-title",children:"Route sequence"}),(0,C.jsx)("span",{className:"cdp-seq-status".concat(Y.length>0?" is-warn":" is-good"),children:Y.length>0?"".concat(Y.length," out of order"):"In order"}),(0,C.jsx)("span",{className:"cdp-seq-toggle".concat(c?" is-open":""),children:(0,C.jsx)(S.j1Q,{})})]}),c&&(0,C.jsx)("div",{className:"cdp-seq",children:Y.length>0?(0,C.jsx)("ul",{className:"cdp-seq-diffs",children:V.map(((e,s)=>{if(1===e.items.length)return g(e.items[0]);const a=e.items[0],t=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===r));return(0,C.jsxs)(n.Fragment,{children:[(0,C.jsxs)("li",{className:"cdp-seq-diff is-group".concat(i?" is-expanded":"").concat(c?" is-focused":""),onClick:()=>{return e=s,void u((s=>{const a=new Set(s);return a.has(e)?a.delete(e):a.add(e),a}));var e},"aria-expanded":i,children:[(0,C.jsxs)("span",{className:"cdp-seq-group-num",children:[(0,C.jsx)("span",{className:"cdp-seq-group-num-bg",style:{background:"linear-gradient(135deg, ".concat((0,w.gM)((a.planned||1)-1),", ").concat((0,w.gM)((t.planned||1)-1),")")}}),(0,C.jsxs)("span",{className:"cdp-seq-group-num-label",children:[e.items.length,"\xd7"]})]}),(0,C.jsxs)("div",{className:"cdp-seq-diff-body",children:[(0,C.jsxs)("div",{className:"cdp-seq-diff-title",children:[e.items.length," consecutive steps shifted"," ",(0,C.jsx)("span",{className:"cdp-seq-group-delta",children:l})]}),(0,C.jsxs)("div",{className:"cdp-seq-diff-sub",children:["Planned ",(0,w.IE)(a.planned),"\u2013",(0,w.IE)(t.planned)," ","visited"," ",(0,C.jsxs)("strong",{children:[(0,w.IE)(a.actualPos),"\u2013",(0,w.IE)(t.actualPos)]})]})]}),(0,C.jsx)("span",{className:"cdp-seq-diff-tag",children:l}),(0,C.jsx)("span",{className:"cdp-seq-group-toggle".concat(i?" is-open":""),"aria-hidden":"true",children:(0,C.jsx)(S.j1Q,{})})]}),i&&(0,C.jsx)("li",{className:"cdp-seq-group-children-wrap",children:(0,C.jsx)("ul",{className:"cdp-seq-group-children",children:e.items.map((e=>g(e,!1)))})})]},"run-".concat(s,"-").concat(a.d.sequenceStep))}))}):(0,C.jsxs)("div",{className:"cdp-seq-good",children:[(0,C.jsx)(S.mU9,{})," Rider followed the planned route in order."]})})]}),(L||q)&&(0,C.jsxs)("section",{className:"cdp-section cdp-timing-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.pWE,{})}),(0,C.jsx)("span",{className:"cdp-section-title",children:"Timing"}),I>0&&(0,C.jsxs)("span",{className:"cdp-timing-active-tag",children:[(0,C.jsx)("span",{className:"cdp-timing-active-pulse"}),"Day window"]})]}),(0,C.jsxs)("div",{className:"cdp-timing-clock",children:[(0,C.jsxs)("div",{className:"cdp-clock-card is-start",children:[(0,C.jsxs)("div",{className:"cdp-clock-label",children:[(0,C.jsx)(S.WVj,{})," First delivery"]}),(0,C.jsxs)("div",{className:"cdp-clock-face",children:[(0,C.jsx)("span",{className:"cdp-clock-time",children:L?L.format("hh:mm"):"\u2014"}),(0,C.jsx)("span",{className:"cdp-clock-period",children:L?L.format("A"):""})]}),(0,C.jsx)("div",{className:"cdp-clock-caption",children:"Started"})]}),(0,C.jsxs)("div",{className:"cdp-clock-track","aria-hidden":"true",children:[(0,C.jsx)("span",{className:"cdp-clock-track-line"}),(0,C.jsx)("span",{className:"cdp-clock-track-dot is-start"}),(0,C.jsx)("span",{className:"cdp-clock-track-dot is-end"}),(0,C.jsxs)("div",{className:"cdp-clock-duration",children:[(0,C.jsx)("span",{className:"cdp-clock-duration-icon",children:(0,C.jsx)(S.DZH,{})}),(0,C.jsx)("span",{className:"cdp-clock-duration-val",children:I>0?I>=60?"".concat(Math.floor(I/60),"h ").concat(I%60,"m"):"".concat(I,"m"):"\u2014"}),(0,C.jsx)("span",{className:"cdp-clock-duration-sub",children:"active"})]})]}),(0,C.jsxs)("div",{className:"cdp-clock-card is-end",children:[(0,C.jsxs)("div",{className:"cdp-clock-label",children:[(0,C.jsx)(S.mU9,{})," Last delivery"]}),(0,C.jsxs)("div",{className:"cdp-clock-face",children:[(0,C.jsx)("span",{className:"cdp-clock-time",children:q?q.format("hh:mm"):"\u2014"}),(0,C.jsx)("span",{className:"cdp-clock-period",children:q?q.format("A"):""})]}),(0,C.jsx)("div",{className:"cdp-clock-caption",children:"Finished"})]})]}),(0,C.jsxs)("div",{className:"cdp-timing-stats",children:[(0,C.jsxs)("div",{className:"cdp-timing-stat",children:[(0,C.jsxs)("div",{className:"cdp-timing-stat-head",children:[(0,C.jsx)("div",{className:"cdp-timing-stat-icon",children:(0,C.jsx)(S.VP9,{})}),(0,C.jsxs)("div",{className:"cdp-timing-stat-body",children:[(0,C.jsxs)("div",{className:"cdp-timing-stat-value",children:[O>0?"".concat(O):"\u2014",O>0&&(0,C.jsx)("span",{className:"cdp-timing-stat-unit",children:"min"})]}),(0,C.jsx)("div",{className:"cdp-timing-stat-label",children:"Avg / stop"})]})]}),a.length>0&&(0,C.jsxs)("div",{className:"cdp-timing-stat-viz cdp-stops-dots","aria-hidden":"true",children:[Array.from({length:Math.min(a.length,12)}).map(((e,s)=>(0,C.jsx)("span",{className:"cdp-stop-dot"},"dot-".concat(s)))),(0,C.jsxs)("span",{className:"cdp-timing-stat-viz-label",children:[a.length," stop",1===a.length?"":"s"]})]})]}),null!=R&&(0,C.jsxs)("div",{className:"cdp-timing-stat",children:[(0,C.jsxs)("div",{className:"cdp-timing-stat-head",children:[(0,C.jsx)("div",{className:"cdp-timing-stat-icon",children:(0,C.jsx)(S.BJM,{})}),(0,C.jsxs)("div",{className:"cdp-timing-stat-body",children:[(0,C.jsxs)("div",{className:"cdp-timing-stat-value",children:[R,(0,C.jsx)("span",{className:"cdp-timing-stat-unit",children:"km/h"})]}),(0,C.jsx)("div",{className:"cdp-timing-stat-label",children:"Avg speed"})]})]}),(0,C.jsxs)("div",{className:"cdp-timing-stat-viz cdp-speed-gauge","aria-hidden":"true",children:[(0,C.jsx)("div",{className:"cdp-speed-gauge-track",children:(0,C.jsx)("div",{className:"cdp-speed-gauge-fill",style:{width:"".concat(Math.min(100,parseFloat(R)/60*100),"%")}})}),(0,C.jsxs)("div",{className:"cdp-speed-gauge-scale",children:[(0,C.jsx)("span",{children:"0"}),(0,C.jsx)("span",{children:"30"}),(0,C.jsx)("span",{children:"60 km/h"})]})]})]})]})]}),(T||H)&&(0,C.jsxs)("section",{className:"cdp-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.SeC,{})}),(0,C.jsx)("span",{className:"cdp-section-title",children:"Highlights"})]}),(0,C.jsxs)("div",{className:"cdp-highlights",children:[T&&(0,C.jsxs)("div",{className:"cdp-highlight is-best",onClick:()=>j(T.sequenceStep),role:"button",title:"Focus this step",children:[(0,C.jsx)("span",{className:"cdp-highlight-rail","aria-hidden":"true"}),(0,C.jsxs)("div",{className:"cdp-highlight-content",children:[(0,C.jsxs)("div",{className:"cdp-highlight-top",children:[(0,C.jsxs)("span",{className:"cdp-highlight-label",children:[(0,C.jsx)("span",{className:"cdp-highlight-chip",children:(0,C.jsx)(S.mU9,{})}),"Fastest stop"]}),(0,C.jsxs)("span",{className:"cdp-highlight-step-chip",style:{background:(0,w.gM)(T.sequenceStep-1)},children:["Step ",T.sequenceStep]})]}),(0,C.jsx)("div",{className:"cdp-highlight-title",children:T.deliverycustomer||"Step ".concat(T.sequenceStep)}),(0,C.jsx)("div",{className:"cdp-highlight-meta",children:(0,C.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,C.jsxs)("div",{className:"cdp-highlight is-worst",onClick:()=>j(H.sequenceStep),role:"button",title:"Focus this step",children:[(0,C.jsx)("span",{className:"cdp-highlight-rail","aria-hidden":"true"}),(0,C.jsxs)("div",{className:"cdp-highlight-content",children:[(0,C.jsxs)("div",{className:"cdp-highlight-top",children:[(0,C.jsxs)("span",{className:"cdp-highlight-label",children:[(0,C.jsx)("span",{className:"cdp-highlight-chip",children:(0,C.jsx)(S.Wux,{})}),"Biggest deviation"]}),(0,C.jsxs)("span",{className:"cdp-highlight-step-chip",style:{background:(0,w.gM)(H.sequenceStep-1)},children:["Step ",H.sequenceStep]})]}),(0,C.jsx)("div",{className:"cdp-highlight-title",children:H.deliverycustomer||"Step ".concat(H.sequenceStep)}),(0,C.jsxs)("div",{className:"cdp-highlight-meta",children:[null!=H.kmDeltaPct&&(0,C.jsxs)("span",{className:"cdp-highlight-pill is-bad",children:[H.kmDeltaPct>0?"+":"",H.kmDeltaPct.toFixed(0),"% route"]}),null!=H.timeDeltaMin&&H.timeDeltaMin>0&&(0,C.jsxs)("span",{className:"cdp-highlight-pill is-bad",children:["+",H.timeDeltaMin,"m late"]})]})]})]})]})]}),K.length>1&&(0,C.jsxs)("section",{className:"cdp-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.$G1,{})}),(0,C.jsxs)("span",{className:"cdp-section-title",children:["Trips (",K.length,")"]})]}),(0,C.jsx)("div",{className:"cdp-trips",children:K.map((e=>{const s=e.profit<0;return(0,C.jsxs)("div",{className:"cdp-trip",children:[(0,C.jsxs)("div",{className:"cdp-trip-head",children:[(0,C.jsxs)("span",{className:"cdp-trip-badge",children:["Trip ",e.tNum]}),(0,C.jsxs)("span",{className:"cdp-trip-meta",children:[e.delivered,"/",e.count," delivered"]})]}),(0,C.jsxs)("div",{className:"cdp-trip-stats",children:[(0,C.jsxs)("span",{title:"Distance",children:[(0,C.jsx)(S.xI$,{}),e.actualKm.toFixed(1),"km",(0,C.jsxs)("small",{children:[" / ",e.plannedKm.toFixed(1)]})]}),(0,C.jsxs)("span",{className:s?"is-over":"",title:s?"Loss":"Profit",children:[(0,C.jsx)(S.ohY,{}),s?"-":"","\u20b9",Math.abs(e.profit).toFixed(0)]})]})]},"trip-".concat(e.tNum))}))})]}),v&&(e=>{const s=(0,w.gM)(v.sequenceStep-1),a=v.kmDelta>=0?"+":"",t=v.anomaly?"is-over":v.kmDelta<-.1?"is-under":"",i=null!=v.timeDeltaMin?v.timeDeltaMin>10?"is-over":v.timeDeltaMin<-2?"is-under":"":"",n=(0,w.Cx)(v.orderstatus),r=parseFloat((null===(e=v.order)||void 0===e?void 0:e.profit)||0);return(0,C.jsxs)("section",{className:"cdp-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.$G1,{})}),(0,C.jsxs)("span",{className:"cdp-section-title",children:["Step ",v.sequenceStep," details"]}),(0,C.jsx)("button",{type:"button",className:"cdp-section-clear",onClick:()=>l(null),title:"Clear step focus",children:"Show all"})]}),(0,C.jsxs)("div",{className:"compare-delta".concat(v.anomaly?" is-anomaly":""),children:[(0,C.jsxs)("div",{className:"compare-delta-title",children:[(0,C.jsx)("span",{className:"compare-delta-step-badge",style:{background:s},children:v.sequenceStep}),(0,C.jsxs)("div",{className:"compare-delta-title-text",children:[(0,C.jsx)("div",{className:"compare-delta-title-main",children:v.deliverycustomer||"Step ".concat(v.sequenceStep)}),(0,C.jsxs)("div",{className:"compare-delta-title-sub",children:[v.pickupcustomer?"from ".concat(v.pickupcustomer," \xb7 "):"","Order #",v.orderid]})]}),v.orderstatus&&(0,C.jsx)("span",{className:"compare-delta-status",style:{background:n.bg,color:n.fg},children:n.label})]}),(0,C.jsxs)("div",{className:"compare-delta-grid",children:[(0,C.jsxs)("div",{className:"compare-delta-cell".concat(v.anomaly?" is-anomaly":""),children:[(0,C.jsx)("span",{className:"compare-delta-cell-label",children:"Distance"}),(0,C.jsxs)("span",{className:"compare-delta-cell-val",children:[v.actualKm.toFixed(2)," ",(0,C.jsx)("span",{className:"compare-delta-cell-unit",children:"km"})]}),(0,C.jsxs)("span",{className:"compare-delta-cell-sub",children:["planned ",v.plannedKm.toFixed(2)," km"]})]}),(0,C.jsxs)("div",{className:"compare-delta-cell",children:[(0,C.jsx)("span",{className:"compare-delta-cell-label",children:"\u0394 Route"}),(0,C.jsxs)("span",{className:"compare-delta-cell-val ".concat(t),children:[a,v.kmDelta.toFixed(2)," km"]}),(0,C.jsx)("span",{className:"compare-delta-cell-sub",children:null!=v.kmDeltaPct?"".concat(a).concat(v.kmDeltaPct.toFixed(0),"% vs plan"):"no planned km"})]}),(0,C.jsxs)("div",{className:"compare-delta-cell",children:[(0,C.jsx)("span",{className:"compare-delta-cell-label",children:"Time"}),(0,C.jsx)("span",{className:"compare-delta-cell-val ".concat(i),children:null!=v.timeDeltaMin?"".concat(v.timeDeltaMin>0?"+":"").concat(v.timeDeltaMin," min"):"\u2014"}),(0,C.jsx)("span",{className:"compare-delta-cell-sub",children:v.actualTs&&v.expectedTs?"".concat(v.actualTs.format("HH:mm")," vs ").concat(v.expectedTs.format("HH:mm")):v.actualTs?"delivered ".concat(v.actualTs.format("HH:mm")):"in flight"})]}),!Number.isNaN(r)&&0!==r&&(0,C.jsxs)("div",{className:"compare-delta-cell".concat(r<0?" is-anomaly":""),children:[(0,C.jsx)("span",{className:"compare-delta-cell-label",children:r<0?"Loss":"Profit"}),(0,C.jsxs)("span",{className:"compare-delta-cell-val ".concat(r<0?"is-over":"is-under"),children:[r<0?"-":"","\u20b9",Math.abs(r).toFixed(0)]}),(0,C.jsx)("span",{className:"compare-delta-cell-sub",children:"order revenue"})]})]})]})]})})(),k.length>0&&(0,C.jsxs)("section",{className:"cdp-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon cdp-icon-warn",children:(0,C.jsx)(S.ItP,{})}),(0,C.jsxs)("span",{className:"cdp-section-title",children:["Deviations (",k.length,")"]})]}),(0,C.jsx)("ul",{className:"cdp-dev-list",children:k.map((e=>{const s=(0,w.gM)(e.sequenceStep-1),a=e.kmDelta>=0?"+":"";return(0,C.jsxs)("li",{className:"cdp-dev-item".concat(r===e.sequenceStep?" is-focused":""),onClick:()=>j(e.sequenceStep),children:[(0,C.jsx)("span",{className:"cdp-dev-num",style:{background:s},children:e.sequenceStep}),(0,C.jsxs)("div",{className:"cdp-dev-body",children:[(0,C.jsx)("div",{className:"cdp-dev-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),(0,C.jsxs)("div",{className:"cdp-dev-meta",children:[null!=e.kmDeltaPct&&(0,C.jsxs)("span",{className:"cdp-dev-chip is-over",children:[a,e.kmDeltaPct.toFixed(0),"% route"]}),null!=e.timeDeltaMin&&e.timeDeltaMin>10&&(0,C.jsxs)("span",{className:"cdp-dev-chip is-over",children:["+",e.timeDeltaMin,"m late"]})]})]})]},"dev-".concat(e.sequenceStep))}))})]}),(0,C.jsxs)("section",{className:"cdp-section",children:[(0,C.jsxs)("div",{className:"cdp-section-head",children:[(0,C.jsx)("span",{className:"cdp-section-icon",children:(0,C.jsx)(S.EgJ,{})}),(0,C.jsxs)("span",{className:"cdp-section-title",children:["Steps (",a.length,")"]}),(0,C.jsxs)("span",{className:"cdp-section-sub",children:[_,"/",a.length," delivered"]})]}),(0,C.jsx)("ul",{className:"cdp-step-list",children:a.map((e=>{var s;const a=(0,w.gM)(e.sequenceStep-1),t=String(e.orderstatus||"").toLowerCase(),i=w.Ys.has(t),n=w.yP.has(t),l=i&&!e.anomaly,c=r===e.sequenceStep,d=(0,w.Cx)(e.orderstatus),o=parseFloat((null===(s=e.order)||void 0===s?void 0:s.profit)||0),u=e.kmDelta>=0?"+":"",m=null!=e.timeDeltaMin?e.timeDeltaMin>10?"is-over":e.timeDeltaMin<-2?"is-under":"":"",p=["cdp-step",c?"is-focused":"",e.anomaly?"is-anomaly":"",l?"is-correct":"",n?"is-skipped":"",e.isLoading?"is-loading":""].filter(Boolean).join(" ");return(0,C.jsxs)("li",{className:p,onClick:()=>j(e.sequenceStep),children:[(0,C.jsxs)("span",{className:"cdp-step-num",style:{background:a},children:[e.sequenceStep,l&&(0,C.jsx)("span",{className:"cdp-step-check",children:(0,C.jsx)(S.mU9,{})}),e.anomaly&&(0,C.jsx)("span",{className:"cdp-step-flag",children:(0,C.jsx)(S.ItP,{})})]}),(0,C.jsxs)("div",{className:"cdp-step-body",children:[(0,C.jsxs)("div",{className:"cdp-step-title-row",children:[(0,C.jsx)("span",{className:"cdp-step-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),e.orderstatus&&(0,C.jsx)("span",{className:"cdp-step-status",style:{background:d.bg,color:d.fg},children:d.label})]}),(0,C.jsxs)("div",{className:"cdp-step-sub",children:[e.pickupcustomer?"from ".concat(e.pickupcustomer," \xb7 "):"","Order #",e.orderid]}),(0,C.jsxs)("div",{className:"cdp-step-deltas",children:[(0,C.jsxs)("span",{className:"cdp-step-delta",title:"Distance",children:[(0,C.jsx)(S.xI$,{}),e.actualKm.toFixed(1),"km",e.plannedKm>0&&(0,C.jsxs)("small",{className:e.anomaly?"is-over":"",children:[" ",u,e.kmDelta.toFixed(1)]})]}),(0,C.jsxs)("span",{className:"cdp-step-delta ".concat(m),title:"Delivery time",children:[(0,C.jsx)(S.VP9,{}),e.actualTs?e.actualTs.format("HH:mm"):"\u2014",null!=e.timeDeltaMin&&(0,C.jsxs)("small",{children:[" ",e.timeDeltaMin>0?"+":"",e.timeDeltaMin,"m"]})]}),!Number.isNaN(o)&&0!==o&&(0,C.jsxs)("span",{className:"cdp-step-delta".concat(o<0?" is-over":""),title:o<0?"Loss":"Profit",children:[(0,C.jsx)(S.ohY,{}),o<0?"-":"","\u20b9",Math.abs(o).toFixed(0)]})]})]})]},"step-".concat(e.sequenceStep))}))})]})]})]})};var A=a(85571);const P=["_ts"],E="#6366f1",D="#10b981",L=e=>{const s=parseFloat(e);return Number.isFinite(s)?s:NaN},q=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 a=s.split(/\s+/).filter(Boolean),t=a.length>6?a.slice(-6).join(" "):s;return t.length>40?"".concat(t.slice(0,40).trim(),"\u2026"):t},I=e=>Number.isFinite(L(e.droplat||e.deliverylat))&&Number.isFinite(L(e.droplon||e.deliverylong)),O=e=>e.pickuplat||e.pickuplatitude||e.pickup_lat,R=e=>e.pickuplong||e.pickuplongitude||e.picklongitude||e.pickup_lon,T=e=>Number.isFinite(L(O(e)))&&Number.isFinite(L(R(e))),H=[{id:"morning",name:"Morning Batch",startHour:0,endHour:8},{id:"afternoon",name:"Afternoon Batch",startHour:9,endHour:12.5},{id:"evening",name:"Evening Batch",startHour:16,endHour:19}],Y="dispatch.slots.v9",V=["dispatch.slots.v1","dispatch.slots.v2","dispatch.slots.v3","dispatch.slots.v4","dispatch.slots.v5","dispatch.slots.v6","dispatch.slots.v7","dispatch.slots.v8"],K=(e,s)=>"Slot ".concat(e+1," \xb7 ").concat(B(s)),B=e=>{const s=Math.floor(e),a=Math.round(60*(e-s)),t=(s+11)%12+1,i=s>=12&&s<24?"PM":"AM";if(0===a)return"".concat(t," ").concat(i);const n=String(a).padStart(2,"0");return"".concat(t,":").concat(n," ").concat(i)},U=(e,s)=>s>=24?"After ".concat(B(e)):"".concat(B(e),"\u2013").concat(B(s)),G=H.map(((e,s)=>(0,i.A)((0,i.A)({},e),{},{label:e.name||K(s,e.startHour),range:U(e.startHour,e.endHour)}))),J=(e,s)=>{for(const a of s)if(e>=a.startHour&&e<a.endHour)return a.id;return null},W=[{id:"delivered",label:"Delivered",keys:["deliverytime"]},{id:"pending",label:"Pending",keys:["expecteddeliverytime"]},{id:"assigned",label:"Assigned",keys:["assigntime"]},{id:"accepted",label:"Accepted",keys:["acceptedtime"]},{id:"started",label:"Started",keys:["starttime"]},{id:"arrived",label:"Arrived",keys:["arrivaltime"]},{id:"pickup",label:"Pickup",keys:["pickuptime"]},{id:"all",label:"All",keys:["deliverytime","expecteddeliverytime","assigntime","acceptedtime","arrivaltime","pickuptime","starttime"]}],$=function(e){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:G;const a=((e,s)=>{const a=W.find((e=>e.id===s))||W[0];for(const t of a.keys)if(null!==e&&void 0!==e&&e[t])return e[t];return null})(e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:"all");if(!a)return null;const t=String(a).trim();if(/^\d{4}-\d{2}-\d{2}$/.test(t))return null;const i=g()(a);return i.isValid()?J(i.hour()+i.minute()/60,s):null};function Z(e){let{targetRef:s}=e;const a=(0,r.ko)();return(0,n.useEffect)((()=>(s.current=a,()=>{s.current=null})),[a]),null}function X(e){let{trigger:s}=e;const a=(0,r.ko)();return(0,n.useEffect)((()=>{const e=[0,60,120,200,300,380].map((e=>setTimeout((()=>a.invalidateSize({animate:!1})),e)));return()=>e.forEach(clearTimeout)}),[s,a]),null}function Q(e,s){const a=e=>e*Math.PI/180,t=a(e[0]),i=a(s[0]),n=a(s[0]-e[0]),r=a(s[1]-e[1]),l=Math.sin(n/2)**2+Math.cos(t)*Math.cos(i)*Math.sin(r/2)**2;return 12742*Math.asin(Math.min(1,Math.sqrt(l)))}function ee(e){if(!Array.isArray(e)||e.length<2)return 0;let s=0;for(let a=1;a<e.length;a++)s+=Q(e[a-1],e[a]);return s}function se(e,s){if(!Array.isArray(e)||e.length<2||!s||!s.length)return[];const a=s.map((s=>{let a=0,t=1/0;for(let i=0;i<e.length;i++){const n=e[i][0]-s[0],r=e[i][1]-s[1],l=n*n+r*r;l<t&&(t=l,a=i)}return a}));for(let n=1;n<a.length;n++)a[n]<a[n-1]&&(a[n]=a[n-1]);const t=[];let i=0;return a.forEach((s=>{const a=Math.max(s,i);t.push(e.slice(i,a+1)),i=a})),t}const ae=e=>{if(!e)return null;const s=g()(e);return s.isValid()?s.format("HH:mm:ss"):String(e)},te=[{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}],ie=e=>{const s=e.filter(I);if(!s.length)return[];const a=e.find(T),t=[];return a&&t.push([L(O(a)),L(R(a))]),s.forEach((e=>t.push([L(e.droplat||e.deliverylat),L(e.droplon||e.deliverylong)]))),t},ne=(e,s,a)=>{if(!a||0===a.length)return"".concat(e,"-").concat(s);const t=a.map((e=>"".concat(e[0].toFixed(5),",").concat(e[1].toFixed(5)))).join("|");return"".concat(e,"-").concat(s,"-").concat(t)};delete x().Icon.Default.prototype._getIconUrl,x().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 re=["#0055FF","#00D82C","#FF6B00","#9D00FF","#FF00A8","#00C2B2","#FF9900","#FF0000"],le=e=>{const s=String(null!==e&&void 0!==e?e:"");if(!s)return re[0];let a=0;for(let t=0;t<s.length;t++)a=31*a+s.charCodeAt(t)>>>0;return re[a%re.length]},ce=e=>{let{focusedItem:s,viewMode:a,orders:t,kitchens:i,locationKey:l}=e;const c=(0,r.ko)(),d=(0,n.useRef)(""),o=(0,n.useMemo)((()=>{const e=null!=l?"loc:".concat(l,"|"):"",n=e=>{let s=0,a=0,t=0;for(const i of e)Number.isFinite(i[0])&&Number.isFinite(i[1])&&(s+=i[0],a+=i[1],t+=1);return 0===t?"0":"".concat((s/t).toFixed(1),",").concat((a/t).toFixed(1))};if(s){var r,c,d;const a=null!==(r=null!==(c=null!==(d=s.id)&&void 0!==d?d:s.kitchenName)&&void 0!==c?c:s.name)&&void 0!==r?r:null!=s.lat?"".concat(s.lat,",").concat(s.lon):"item",t=s.orders?s.orders.length:0;return"".concat(e,"f|").concat(a,"|").concat(t)}const o=(i||[]).map((e=>[e.lat,e.lon])),u=n(o);if("kitchens"===a){const s=o.filter((e=>Number.isFinite(e[0])&&Number.isFinite(e[1]))).length;return"".concat(e,"k|").concat(s,"|").concat(u)}if("all"===a){const s=(t||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]));return"".concat(e,"a|").concat(s.length,"|").concat(n(s))}return"".concat(e,"m|").concat(a||"","|").concat(o.length,"|").concat(u)}),[s,a,t,i,l]);return(0,n.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([L(O(s)),L(R(s))])))):e=[[s.lat,s.lon]]:"kitchens"===a?(e=(i||[]).filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lon))).map((e=>[e.lat,e.lon])),0===e.length&&(e=(t||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])))):"all"===a?e=(t||[]).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=(t||[]).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]))));const n=e.filter((e=>Number.isFinite(e[0])&&Number.isFinite(e[1])));if(n.length>0){const e=x().latLngBounds(n);if(e.isValid()){1===n.length||e.getNorthEast().equals(e.getSouthWest())?c.setView(n[0],15,{animate:!0,duration:.6}):c.flyToBounds(e,{padding:[60,60],duration:.6,maxZoom:16}),d.current=o}}else;}),[o,s,a,t,i,c]),null},de=e=>{let{children:s}=e;return(0,C.jsx)("span",{className:"ico-inline",style:{display:"inline-flex",alignItems:"center",verticalAlign:"-2px",marginRight:4},children:s})},oe=[{key:"morning",label:"Morning",timeRange:"12:00 AM \u2013 8:00 AM",sub:"Early shift orders",color:"#f59e0b",bg:"#fffbeb",border:"#fde68a"},{key:"afternoon",label:"Noon",timeRange:"9:00 AM \u2013 12:30 PM",sub:"Lunch rush window",color:"#10b981",bg:"#ecfdf5",border:"#a7f3d0"},{key:"evening",label:"Evening",timeRange:"4:00 PM \u2013 7:00 PM",sub:"Dinner & end-of-day",color:"#6366f1",bg:"#eef2ff",border:"#c7d2fe"}],ue=e=>{if(null==e)return"\u2014";if("number"===typeof e)return e.toLocaleString("en-IN");const s=parseFloat(e);return Number.isFinite(s)?s.toLocaleString("en-IN"):String(e)},me=e=>{if(!e||"string"!==typeof e)return null;const s=e.split(":").map(Number);if(s.length<2||s.some((e=>!Number.isFinite(e))))return null;const[a,t,i=0]=s;return 3600*a+60*t+i},pe=e=>{let{data:s,embedded:a=!1,selectedRiderId:r,onRiderSelect:h,pulseOrderId:v,onChangeRider:j}=e;const F=null!==s&&void 0!==s&&s.zones&&s.zones.length>0?"zones":"riders",[M,B]=(0,n.useState)(F),[W,pe]=(0,n.useState)("live"),[he,xe]=(0,n.useState)({}),[ve,je]=(0,n.useState)(null),[ge,fe]=(0,n.useState)(null),[Ne,be]=(0,n.useState)(null);(0,n.useEffect)((()=>{if(!Ne)return;const e=e=>{"Escape"===e.key&&be(null)};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)}),[Ne]);const ye=(0,f.n)({mutationFn:_.W0,onMutate:e=>je(e.batch),onSuccess:(e,s)=>{xe((a=>(0,i.A)((0,i.A)({},a),{},{[s.batch]:{data:e,fetchedAt:g()().format("HH:mm:ss")}})))},onSettled:()=>je(null)}),ke=e=>{fe(e);const s=he[e];s&&s.data&&!1!==s.data.success||ye.mutate({batch:e,tenantId:916})},Se=15e3,_e=(0,n.useRef)(null);(0,n.useEffect)((()=>{_e.current=ve}),[ve]),(0,n.useEffect)((()=>{if("analysis"!==W)return;if(!ge)return;const e=setInterval((()=>{_e.current||"undefined"!==typeof document&&document.hidden||ye.mutate({batch:ge,tenantId:916})}),Se);return()=>clearInterval(e)}),[W,ge]);const[we,Fe]=(0,n.useState)(new Set),[Me,Ce]=(0,n.useState)(null),[ze,Ae]=(0,n.useState)(null),[Pe,Ee]=(0,n.useState)(null),[De,Le]=(0,n.useState)(null),[qe,Ie]=(0,n.useState)("planned"),Oe=(0,n.useRef)({}),Re=(0,n.useRef)(new Set),Te=(0,n.useRef)(new Set),He=((0,n.useRef)(null),(0,n.useRef)(null)),[Ye,Ve]=(0,n.useState)(null),Ke=void 0!==r,[Be,Ue]=(0,n.useState)(""),{data:Ge}=(0,N.I)({queryKey:["appLocations"],queryFn:_.aL,staleTime:3e5}),Je="undefined"!==typeof window?localStorage.getItem("applocationid"):null,[We,$e]=(0,n.useState)(null!=Je?Number(Je):0),[Ze,Xe]=(0,n.useState)(!1),Qe=(0,n.useRef)(null),[es,ss]=(0,n.useState)("assigned"),[as,ts]=(0,n.useState)(!1),is=(0,n.useRef)(null),[ns,rs]=(0,n.useState)((()=>{if("undefined"===typeof window)return G;try{const e=window.localStorage.getItem(Y);if(!e)return G;const s=JSON.parse(e);return Array.isArray(s)&&s.length===H.length?s.map(((e,s)=>{const a=e.id||"slot-".concat(s+1),t=Number(e.startHour)||0,i=Number(e.endHour)||24,n=G.find((e=>e.id===a));return{id:a,startHour:t,endHour:i,label:(null===n||void 0===n?void 0:n.name)||K(s,t),range:U(t,i)}})):G}catch(e){return G}})),ls=ns,[cs,ds]=(0,n.useState)(!1),os=(0,n.useRef)(null);(0,n.useEffect)((()=>{if("undefined"!==typeof window)try{V.forEach((e=>window.localStorage.removeItem(e)))}catch(e){}}),[]);const us=(0,n.useRef)(!1);(0,n.useEffect)((()=>{if(us.current){if("undefined"!==typeof window)try{window.localStorage.setItem(Y,JSON.stringify(ns.map((e=>{let{id:s,startHour:a,endHour:t}=e;return{id:s,startHour:a,endHour:t}}))))}catch(e){}}else us.current=!0}),[ns]),(0,n.useEffect)((()=>{if(!Ze)return;const e=e=>{Qe.current&&!Qe.current.contains(e.target)&&Xe(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[Ze]),(0,n.useEffect)((()=>{if(!as)return;const e=e=>{is.current&&!is.current.contains(e.target)&&ts(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[as]),(0,n.useEffect)((()=>{if(!cs)return;const e=e=>{os.current&&!os.current.contains(e.target)&&ds(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[cs]);const[ms,ps]=(0,n.useState)(null),[hs,xs]=(0,n.useState)(""),{data:vs,isFetching:js,isError:gs,error:fs}=(0,N.I)({queryKey:["riderPeriodicLog",ms],queryFn:()=>(0,_.ne)(ms),enabled:"rider-info"===M&&null!=ms,refetchInterval:"rider-info"===M&&null!=ms&&15e3,refetchIntervalInBackground:!1,staleTime:5e3,refetchOnWindowFocus:!1}),Ns=(0,n.useMemo)((()=>{const e=parseFloat(null===vs||void 0===vs?void 0:vs.latitude),s=parseFloat(null===vs||void 0===vs?void 0:vs.longitude);return Number.isFinite(e)&&Number.isFinite(s)?{lat:e.toFixed(4),lon:s.toFixed(4)}:null}),[null===vs||void 0===vs?void 0:vs.latitude,null===vs||void 0===vs?void 0:vs.longitude]),{data:bs}=(0,N.I)({queryKey:["reverseGeocode",null===Ns||void 0===Ns?void 0:Ns.lat,null===Ns||void 0===Ns?void 0:Ns.lon],queryFn:async()=>{const e=await fetch("https://nominatim.openstreetmap.org/reverse?lat=".concat(Ns.lat,"&lon=").concat(Ns.lon,"&format=json&zoom=16&addressdetails=1"),{headers:{Accept:"application/json"}});if(!e.ok)return null;const s=await e.json(),a=(null===s||void 0===s?void 0:s.address)||{};return{area:a.suburb||a.neighbourhood||a.village||a.hamlet||a.city_district||a.town||a.city||a.county||a.state||"",display:(null===s||void 0===s?void 0:s.display_name)||""}},enabled:"rider-info"===M&&!!Ns,staleTime:3e5,refetchOnWindowFocus:!1,retry:1}),ys=(0,n.useMemo)((()=>{if(!Ge)return null;const e=Ge.find((e=>String(e.applocationid)===String(We)));return(null===e||void 0===e?void 0:e.locationname)||null}),[Ge,We]),[ks,Ss]=(0,n.useState)({}),_s=(0,n.useRef)({}),[ws,Fs]=(0,n.useState)({}),Ms=(0,n.useRef)({}),[Cs,zs]=(0,n.useState)(!1),[As,Ps]=(0,n.useState)([]),[Es,Ds]=(0,n.useState)({}),Ls=(0,n.useRef)(!1),[qs,Is]=(0,n.useState)(g()().format("YYYY-MM-DD")),[Os,Rs]=(0,n.useState)(!1),[Ts,Hs]=(0,n.useState)((()=>g()(qs).isValid()?g()(qs).startOf("month"):g()().startOf("month"))),Ys=(0,n.useRef)(null);(0,n.useEffect)((()=>{if(!Os)return;const e=e=>{Ys.current&&(Ys.current.contains(e.target)||Rs(!1))},s=e=>{"Escape"===e.key&&Rs(!1)};return document.addEventListener("mousedown",e),document.addEventListener("keydown",s),()=>{document.removeEventListener("mousedown",e),document.removeEventListener("keydown",s)}}),[Os]),(0,n.useEffect)((()=>{if(Os){const e=g()(qs);e.isValid()&&Hs(e.startOf("month"))}}),[Os,qs]);const[Vs,Ks]=(0,n.useState)(!1),[Bs,Us]=(0,n.useState)("combined"),[Gs,Js]=(0,n.useState)(!0),[Ws,$s]=(0,n.useState)(!0),[Zs,Xs]=(0,n.useState)((()=>new Set)),Qs=(0,n.useRef)(!1),[ea,sa]=(0,n.useState)(!1),aa=(0,n.useRef)(!1),ta=(0,n.useRef)(!1),[ia,na]=(0,n.useState)(!1),[ra,la]=(0,n.useState)(null),ca=(0,n.useRef)(null),da=(0,n.useRef)(null);da.current||(da.current=x().canvas({padding:1.5,tolerance:5}));const{data:oa}=(0,N.I)({queryKey:[We,qs,""],queryFn:_.zb,refetchInterval:15e3,refetchIntervalInBackground:!1,staleTime:5e3,refetchOnWindowFocus:!1}),ua=(0,n.useMemo)((()=>(oa||[]).map((e=>{var s;const a=parseFloat(null===e||void 0===e?void 0:e.latitude),t=parseFloat(null===e||void 0===e?void 0:e.longitude);return Number.isFinite(a)&&Number.isFinite(t)?{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:a,lon:t}:null})).filter(Boolean)),[oa]),[ma,pa]=(0,n.useState)((()=>{const e=g()();return J(e.hour()+e.minute()/60,G)||G[0].id}));(0,n.useEffect)((()=>{var e;"all"!==ma&&(ls.some((e=>e.id===ma))||pa((null===(e=ls[0])||void 0===e?void 0:e.id)||"all"))}),[ls,ma]);const ha=(0,n.useRef)(null),xa=!s,va="undefined"!==typeof window&&localStorage.getItem("userid")||0,{data:ja,isFetching:ga,isError:fa,fetchNextPage:Na,hasNextPage:ba,isFetchingNextPage:ya}=(0,b.q)({queryKey:["dispatchDeliveries",We,va,"all",qs,qs,50,"",0,0,0],queryFn:_.tL,getNextPageParam:e=>{var s;return null!==(s=e.nextPage)&&void 0!==s?s:void 0},enabled:xa});(0,n.useEffect)((()=>{xa&&ba&&!ya&&Na()}),[xa,ba,ya,Na]);const ka=(0,n.useMemo)((()=>{const e=((null===ja||void 0===ja?void 0:ja.pages)||[]).flatMap((e=>e.rows||[])),s=new Set,a=[];for(const t of e){const e=null!=t.orderid?String(t.orderid):null;e&&s.has(e)||(e&&s.add(e),a.push(t))}return a}),[ja]),Sa=(0,n.useMemo)((()=>{const e=new Map;return ka.forEach((s=>{const a=String(s.userid||s.rider_id||"");a&&"unassigned"!==a&&"0"!==a&&(e.has(a)||e.set(a,{id:a,riderName:s.ridername||s.rider_name||s.username||"Rider ".concat(a)}))})),Array.from(e.values()).sort(((e,s)=>String(e.riderName).localeCompare(String(s.riderName))))}),[ka]),_a=(0,n.useMemo)((()=>{const e={all:ka.length};return ls.forEach((s=>{e[s.id]=0})),ka.forEach((s=>{const a=$(s,es,ls);a&&(e[a]=(e[a]||0)+1)})),e}),[ka,es,ls]),wa=(0,n.useMemo)((()=>"all"===ma?ka:ka.filter((e=>$(e,es,ls)===ma))),[ka,ma,es,ls]),Fa=(0,n.useMemo)((()=>{if(!xa)return null;if(!wa.length)return{code:200,zone_summary:[],zones:[]};const e=e=>String(e||"").trim(),s={};wa.forEach((a=>{const t=e(a.deliverysuburb)||e(a.locationsuburb)||e(a.zone_name)||"Unzoned",i=t.toLowerCase(),n=String(a.userid||a.rider_id||"unassigned"),r=a.ridername||a.rider_name||a.username||("unassigned"===n?"Unassigned":"Rider ".concat(n));s[i]||(s[i]={zone_name:t,riders:{}}),s[i].riders[n]||(s[i].riders[n]={rider_id:n,rider_name:r,orders:[]}),s[i].riders[n].orders.push(a)}));const a=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:a.map((e=>{const s=e.riders.flatMap((e=>e.orders)),a=s.filter((e=>e.userid||e.rider_id)).length;return{zone_name:e.zone_name,total_orders:s.length,assigned_orders:a,unassigned_orders_count:s.length-a,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:a}}),[xa,wa]),Ma=(0,n.useMemo)((()=>{const e=s||Fa||{zones:[],zone_summary:[]},a=e.zones||[],t={};(e.zone_summary||[]).forEach((e=>{t[e.zone_name]=e}));const i=(e,s)=>{const a={};return e.forEach((e=>{const t=s(e);t&&(a[t]=(a[t]||0)+1)})),Object.entries(a).map((e=>{let[s,a]=e;return{name:s,count:a}})).sort(((e,s)=>s.count-e.count))};return a.map((e=>{var s,a,n,r;const l=t[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)),m={};return c.forEach((e=>{const s=String(e.orderstatus||"unknown").toLowerCase();m[s]=(m[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!==(a=l.active_riders_count)&&void 0!==a?a:d,totalKms:null!==(n=l.total_delivery_kms)&&void 0!==n?n:c.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),totalProfit:null!==(r=l.total_profit)&&void 0!==r?r:c.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),suburbs:o,kitchens:u,statusCounts:m}}))}),[s,Fa]),{riders:Ca,kitchens:za,allOrders:Aa,stats:Pa}=(0,n.useMemo)((()=>{const e=[];((s||Fa||{zones:[],zone_summary:[]}).zones||[]).forEach((s=>{(s.riders||[]).forEach((a=>{a.orders.forEach((t=>{e.push((0,i.A)((0,i.A)({},t),{},{zone_name:s.zone_name,rider_name:a.rider_name,rider_id:a.rider_id}))}))}))}));const a={};e.forEach((e=>{const s=e.rider_id||e.userid||"unknown";a[s]||(a[s]={id:s,riderName:e.rider_name||e.username||e.rider||s,orders:[],color:re[Object.keys(a).length%re.length]}),a[s].orders.push(e)}));const t={};e.forEach((e=>{const s=e.pickupcustomer||e.kitchen_key||"Unknown",a=s.toLowerCase().trim();t[a]?!Number.isFinite(t[a].lat)&&T(e)&&(t[a].lat=L(O(e)),t[a].lon=L(R(e))):t[a]={id:a,kitchenName:s,lat:L(O(e)),lon:L(R(e)),orders:[],riders:new Set},t[a].orders.push(e),e.rider_id&&t[a].riders.add(e.rider_id)}));const n=e.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),r=e.reduce(((e,s)=>e+parseFloat(s.profit||0)),0);return{riders:Object.values(a).map((e=>(0,i.A)((0,i.A)({},e),{},{orders:[...e.orders].sort(((e,s)=>{const a=e.trip_number||1,t=s.trip_number||1;return a!==t?a-t:(e.step||0)-(s.step||0)}))}))).sort(((e,s)=>s.orders.length-e.orders.length)),kitchens:Object.values(t).sort(((e,s)=>s.orders.length-e.orders.length)),allOrders:e,stats:{totalOrders:e.length,totalKms:n,totalProfit:r,totalRiders:Object.keys(a).length}}}),[s,Fa]),Ea=Ke?r&&Ca.find((e=>e.id===r))||null:Me,Da=(0,n.useCallback)((e=>{h&&h(e?e.id:null),Ke||Ce(e),Le(null)}),[Ke,h]),La=(0,n.useRef)(null);(0,n.useEffect)((()=>{const e=Ea?Ea.id:null;e!==La.current&&(Ea?A.A.info("Focused rider changed to: ".concat(Ea.riderName," (").concat(Ea.orders.length," orders)")):A.A.info("Focused rider reset to: None"),La.current=e)}),[Ea]),(0,n.useEffect)((()=>{De?A.A.info("Focused order updated: ID ".concat(De.orderid)):A.A.debug("Focused order selection cleared")}),[De]);const qa=(0,n.useRef)(0);(0,n.useEffect)((()=>{Aa&&Aa.length!==qa.current&&(A.A.info("Orders database updated: ".concat(Aa.length," orders actively tracked")),qa.current=Aa.length)}),[Aa]);const Ia=(0,n.useRef)(0);(0,n.useEffect)((()=>{ua&&ua.length!==Ia.current&&(A.A.info("Live riders list updated: ".concat(ua.length," active riders mapped")),Ia.current=ua.length)}),[ua]);const Oa=(0,n.useMemo)((()=>Ea?{orders:Ea.orders.length,riders:1,km:Ea.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:Ea.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),label:"Focused Rider"}:ze?{orders:ze.orders.length,riders:ze.riders.size,km:ze.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:ze.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),label:"Focused Kitchen"}:{orders:Pa.totalOrders,riders:Pa.totalRiders,km:Pa.totalKms,profit:Pa.totalProfit,label:"Total Fleet"}),[Ea,ze,Pa]),Ra=(0,n.useMemo)((()=>{if(!Ea)return[];const e=new Set;return Ea.orders.forEach((s=>{null!=s.deliveryid&&""!==s.deliveryid&&0!==s.deliveryid&&e.add(String(s.deliveryid))})),Array.from(e)}),[Ea]),Ta=(0,y.E)({queries:Ra.map((e=>({queryKey:["deliveryLogs",e],queryFn:async()=>{var s,a;const i=await k.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[];const a=e.filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lng)&&(Math.abs(e.lat)>.1||Math.abs(e.lng)>.1)));if(0===a.length)return[];if(1===a.length)return[{lat:a[0].lat,lng:a[0].lng,logdate:a[0].logdate,_ts:a[0]._ts}];const t=null!=s.processNoise?s.processNoise:1e-10,i=null!=s.measurementNoise?s.measurementNoise:2e-9,n=null!=s.outlierGate?s.outlierGate:9,r=null!=s.maxSpeedKmh?s.maxSpeedKmh:120,l=e=>e._ts||(e.logdate?new Date(e.logdate).getTime():0);let c=0;for(;c<a.length-1;){const e=a[c],s=a[c+1],t=l(e),i=l(s)||t+1e3,n=Math.max(.001,(i-t)/1e3);if(Q([e.lat,e.lng],[s.lat,s.lng])/n*3600<=r)break;if(c+2<a.length){const e=a[c+2],t=l(e)||i+1e3,n=Math.max(.001,(t-i)/1e3);if(Q([s.lat,s.lng],[e.lat,e.lng])/n*3600<=r){c+=1;continue}}c++}const d=[a[c]];let o=l(a[c]);for(let h=c+1;h<a.length;h++){const e=a[h],s=l(e)||o+1e3,t=Math.max(.001,(s-o)/1e3),i=d[d.length-1];Q([i.lat,i.lng],[e.lat,e.lng])/t*3600>r||(d.push(e),o=s)}if(d.length<2)return d.map((e=>({lat:e.lat,lng:e.lng,logdate:e.logdate,_ts:e._ts})));const u=e=>{const s=d.length,a=new Array(s),r=new Array(s),c=new Array(s),o=new Array(s),u=new Array(s),m=l(d[0]),p=l(d[1]),h=Math.max(.1,(p-m)/1e3),x=(d[1][e]-d[0][e])/h;a[0]=[d[0][e],x],r[0]=[i,0,0,1],c[0]=a[0].slice(),o[0]=r[0].slice(),u[0]=0;let v=m;for(let g=1;g<s;g++){const s=l(d[g])||v+1e3,m=Math.max(.1,(s-v)/1e3);v=s,u[g]=m;const[p,h]=a[g-1],x=p+h*m,j=h,[f,N,b,y]=r[g-1],k=m*m,S=k*m,_=f+m*(N+b)+k*y+S*m/4*t,w=N+m*y+S/2*t,F=b+m*y+S/2*t,M=y+k*t;c[g]=[x,j],o[g]=[_,w,F,M];const C=d[g][e]-x,z=_+i;if(C*C/z>n){a[g]=[x,j],r[g]=[_,w,F,M];continue}const A=_/z,P=F/z,E=x+A*C,D=j+P*C;a[g]=[E,D],r[g]=[(1-A)*_,(1-A)*w,F-P*_,M-P*w]}const j=new Array(s);j[s-1]=a[s-1].slice();for(let t=s-2;t>=0;t--){const e=u[t+1],[s,i,n,l]=r[t],d=s+e*i,m=i,p=n+e*l,h=l,[x,v,g,f]=o[t+1],N=x*f-v*g;if(!Number.isFinite(N)||Math.abs(N)<1e-30){j[t]=a[t].slice();continue}const b=f/N,y=-v/N,k=-g/N,S=x/N,_=d*b+m*k,w=d*y+m*S,F=p*b+h*k,M=p*y+h*S,C=j[t+1][0]-c[t+1][0],z=j[t+1][1]-c[t+1][1];j[t]=[a[t][0]+_*C+w*z,a[t][1]+F*C+M*z]}return j.map((e=>e[0]))},m=u("lat"),p=u("lng");return d.map(((e,s)=>({lat:m[s],lng:p[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===(a=i.data)||void 0===a?void 0:a.data,null===i||void 0===i?void 0:i.data,i].find((e=>Array.isArray(e)))||[]).map((e=>{var s,a,t;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!==(a=null!==(t=null===e||void 0===e?void 0:e.longitude)&&void 0!==t?t:null===e||void 0===e?void 0:e.lng)&&void 0!==a?a: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,t.A)(e,P)}))},enabled:Vs&&null!=Ea,staleTime:3e5,refetchOnWindowFocus:!1,retry:1})))}),Ha=(0,n.useMemo)((()=>{if(!Ea)return[];const e=e=>{const s=e.deliverytime||e.expecteddeliverytime;if(!s)return Number.MAX_SAFE_INTEGER;const a=g()(s);return a.isValid()?a.valueOf():Number.MAX_SAFE_INTEGER};return Ea.orders.filter((e=>null!=e.deliveryid&&""!==e.deliveryid&&0!==e.deliveryid)).sort(((s,a)=>{const t=e(s)-e(a);return 0!==t?t:(s.step||0)-(a.step||0)})).map(((e,s)=>{const a=Ra.indexOf(String(e.deliveryid)),t=a>=0?Ta[a]: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===t||void 0===t?void 0:t.isLoading)||(null===t||void 0===t?void 0:t.isFetching),isError:null===t||void 0===t?void 0:t.isError,coords:(null===t||void 0===t?void 0:t.data)||[]}}))}),[Ea,Ra,Ta]),Ya=(0,n.useMemo)((()=>Ea?Ha.map((e=>{const s=Ea.orders.find((s=>String(s.deliveryid)===String(e.deliveryid))),a=parseFloat((null===s||void 0===s?void 0:s.kms)||0)||0,t=ws[e.deliveryid];let i=0;Array.isArray(t)&&t.length>=2?i=ee(t):null!=(null===s||void 0===s?void 0:s.actualkms)&&""!==s.actualkms?i=parseFloat(s.actualkms)||0:e.coords.length>=2&&(i=ee(e.coords.map((e=>[e.lat,e.lng]))));const n=i-a,r=a>0?n/a*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=a>0&&i>1.25*a||null!=d&&d>15;return{sequenceStep:e.sequenceStep,deliveryid:e.deliveryid,orderid:e.orderid,order:s,plannedKm:a,actualKm:i,kmDelta:n,kmDeltaPct:r,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}})):[]),[Ha,Ea,ws]),Va=(0,n.useMemo)((()=>{if(0===Ya.length)return{plannedKm:0,actualKm:0,kmDeltaPct:null,anomalies:0,late:0,onTime:0};const e=Ya.filter((e=>!e.isLoading&&e.coordsCount>0)),s=e.reduce(((e,s)=>e+s.plannedKm),0),a=e.reduce(((e,s)=>e+s.actualKm),0);return{plannedKm:s,actualKm:a,kmDeltaPct:s>0?(a-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}}),[Ya]),Ka=(0,n.useMemo)((()=>[...Ya].sort(((e,s)=>{var a,t;return((null===(a=e.order)||void 0===a?void 0:a.step)||e.sequenceStep)-((null===(t=s.order)||void 0===t?void 0:t.step)||s.sequenceStep)}))),[Ya]),Ba=(0,n.useMemo)((()=>[...Ya].sort(((e,s)=>e.sequenceStep-s.sequenceStep))),[Ya]),Ua=(0,n.useMemo)((()=>{if(!Vs||!ra||!Ea)return null;const e=Ha.find((e=>e.sequenceStep===ra));if(!e)return null;const s=Ea.orders.find((s=>String(s.deliveryid)===String(e.deliveryid)));return s?{orders:[s],id:"cmp-step-".concat(ra,"-").concat(s.orderid)}:null}),[Vs,ra,Ea,Ha]);(0,n.useEffect)((()=>{la(null),Xs(new Set),Us("combined")}),[Vs,null===Ea||void 0===Ea?void 0:Ea.id]),(0,n.useEffect)((()=>{!Ea&&Vs&&Ks(!1)}),[Ea,Vs]),(0,n.useEffect)((()=>{Qs.current&&Ea&&(Qs.current=!1,Ks(!0))}),[Ea]),(0,n.useEffect)((()=>{Vs&&!ta.current?(aa.current=ea,sa(!0),na(!1)):!Vs&&ta.current&&sa(aa.current),ta.current=Vs}),[Vs]);const Ga=(0,n.useCallback)((async(e,s,a)=>{if(a.length<2)return;const t=ne(e,s,a);if(void 0!==_s.current[t])return;_s.current[t]=null,Ss((e=>(0,i.A)((0,i.A)({},e),{},{[t]:null})));const n=a.map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),r="https://router.project-osrm.org/route/v1/driving/".concat(n,"?overview=full&geometries=geojson");try{const e=await fetch(r),s=await e.json();if(s.routes&&s.routes[0]){const e=s.routes[0].geometry.coordinates.map((e=>[e[1],e[0]]));_s.current[t]=e,Ss((s=>(0,i.A)((0,i.A)({},s),{},{[t]:e})))}else _s.current[t]=!1,Ss((e=>(0,i.A)((0,i.A)({},e),{},{[t]:!1})))}catch(l){console.error("OSRM Fetch error:",l),_s.current[t]=!1,Ss((e=>(0,i.A)((0,i.A)({},e),{},{[t]:!1})))}}),[]);(0,n.useEffect)((()=>{_s.current={},Ss({}),Ms.current={},Fs({})}),[qs,ma]);const Ja=(0,n.useCallback)((async(e,s)=>{if(void 0!==Ms.current[e])return;if(!Array.isArray(s)||s.length<2)return;Ms.current[e]=null,Fs((s=>(0,i.A)((0,i.A)({},s),{},{[e]:null})));const a=s=>{Ms.current[e]=s,Fs((a=>(0,i.A)((0,i.A)({},a),{},{[e]:s})))},t=()=>{Ms.current[e]=!1,Fs((s=>(0,i.A)((0,i.A)({},s),{},{[e]:!1})))},n=(e,s)=>{if(e.length<=s)return e;const a=Math.ceil(e.length/s),t=e.filter(((e,s)=>s%a===0)),i=e[e.length-1];return t[t.length-1]!==i&&t.push(i),t};try{const e=n(s,90).map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),t="https://router.project-osrm.org/match/v1/driving/".concat(e,"?overview=full&geometries=geojson&gaps=ignore&tidy=true"),i=await fetch(t),r=await i.json();if(r.matchings&&r.matchings.length>0){const e=r.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 a(e)}}catch(r){console.warn("OSRM Match error, trying route fallback:",r)}try{const e=n(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"),r=await fetch(i),l=await r.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 a(e)}t()}catch(r){console.error("OSRM Route fallback error:",r),t()}}),[]);(0,n.useEffect)((()=>{Vs&&Ea&&Ha.forEach((e=>{if(!e.deliveryid||e.coords.length<2)return;const s=e.coords.map((e=>[e.lat,e.lng]));Ja(e.deliveryid,s)}))}),[Ha,Vs,Ea,Ja]),(0,n.useEffect)((()=>{Ls.current=Cs}),[Cs]),(0,n.useEffect)((()=>{if(a)return;const e=()=>{const e=new Date;Ue([e.getHours(),e.getMinutes(),e.getSeconds()].map((e=>String(e).padStart(2,"0"))).join(":"))},s=setInterval(e,1e3);return e(),()=>clearInterval(s)}),[a]),(0,n.useEffect)((()=>{Fe(new Set(Ca.map((e=>e.id))))}),[Ca]),(0,n.useEffect)((()=>{Ca.forEach((e=>{if(!we.has(e.id))return;if(Ea&&Ea.id!==e.id)return;const s={};e.orders.forEach((e=>{const a=e.trip_number||1;s[a]||(s[a]=[]),s[a].push(e)})),Object.entries(s).forEach((s=>{let[a,t]=s;const i=[...t].sort(((e,s)=>(e.step||0)-(s.step||0))),n=ie(i);n.length>=2&&Ga(e.id,a,n)}))}))}),[Ca,we,Ea,Ga]);const Wa=(0,n.useRef)(null);(0,n.useEffect)((()=>{if(!xa)return;const e=()=>{const e=g()();return e.hour()+e.minute()/60};null===Wa.current&&(Wa.current=e());const s=setInterval((()=>{const s=e(),a=J(Wa.current,ls),t=J(s,ls);Wa.current=s,t&&t!==a&&pa((e=>e===a?t:e))}),3e4);return()=>clearInterval(s)}),[xa,ls]),(0,n.useEffect)((()=>{Le(null)}),[null===ze||void 0===ze?void 0:ze.id]),(0,n.useEffect)((()=>{const e=ha.current;e&&"function"===typeof e.scrollIntoView&&e.scrollIntoView({behavior:"smooth",block:"nearest",inline:"center"})}),[ma]),(0,n.useEffect)((()=>{if(!De)return;const e=setTimeout((()=>{var e;const s=null===Aa||void 0===Aa||null===(e=Aa.find)||void 0===e?void 0:e.call(Aa,(e=>String(e.orderid)===String(De.orderid)));s&&Ve(s)}),350);return()=>clearTimeout(e)}),[De,Aa]);const $a=function(e){let s=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return x().divIcon({className:"",iconSize:s?[56,56]:[46,46],iconAnchor:s?[28,28]:[23,23],popupAnchor:[0,s?-30:-24],html:'<div class="kitchen-mark'.concat(s?" is-focused":"",'">').concat((e||"K").charAt(0).toUpperCase(),"</div>")})},Za=e=>{var s;return(null===(s=Ca.find((s=>s.id===e)))||void 0===s?void 0:s.color)||"#475569"},Xa=(e,s)=>{if(!e||!s||!I(s))return null;const a=ua.find((s=>String(s.id)===String(e)));if(!a)return null;const t=L(s.droplat||s.deliverylat),i=L(s.droplon||s.deliverylong);if(!Number.isFinite(t)||!Number.isFinite(i))return null;const n=Q([a.lat,a.lon],[t,i]);return Math.round(1e3*n)},Qa=e=>null===e||void 0===e?"":e>=1e3?"".concat((e/1e3).toFixed(1)," km"):"".concat(e," m");return(0,C.jsxs)("div",{className:"dispatch-container".concat(a?" embedded":"").concat(Vs?" compare-open":""),children:[!a&&(0,C.jsxs)("div",{id:"hdr",children:[(0,C.jsxs)("div",{className:"logo",children:[(0,C.jsx)("div",{className:"logo-badge",children:"D"}),(0,C.jsx)("div",{className:"logo-name",children:"Dispatch"}),Ge&&Ge.length>0&&(0,C.jsxs)("div",{className:"logo-city-wrap",ref:Qe,children:[(0,C.jsxs)("button",{type:"button",className:"logo-city ".concat(Ze?"open":""),onClick:()=>Xe((e=>!e)),"aria-haspopup":"listbox","aria-expanded":Ze,title:"Switch hub",children:[(0,C.jsx)(S.JFD,{}),(0,C.jsx)("span",{className:"logo-city-text",children:ys||"All locations"}),(0,C.jsx)(S.j1Q,{className:"logo-city-caret"})]}),Ze&&(0,C.jsx)("div",{className:"logo-city-menu",role:"listbox",children:Ge.map((e=>{const s=String(e.applocationid)===String(We);return(0,C.jsxs)("button",{type:"button",role:"option","aria-selected":s,className:"logo-city-option ".concat(s?"active":""),onClick:()=>(e=>{if(A.A.info("Switching hub/location ID:",e),$e(Number(e)),Xe(!1),"undefined"!==typeof window)try{localStorage.setItem("applocationid",String(e))}catch(s){}Da(null),Ae(null),Ee(null)})(e.applocationid),children:[(0,C.jsx)(S.JFD,{className:"logo-city-option-icon"}),(0,C.jsx)("span",{children:e.locationname}),s&&(0,C.jsx)("span",{className:"logo-city-option-check",children:"\u2713"})]},e.applocationid)}))})]}),(0,C.jsxs)("div",{id:"dispatch-top-tabs",className:"dtt-inline",children:[(0,C.jsxs)("button",{type:"button",className:"dtt-tab ".concat("live"===W?"active":""),onClick:()=>pe("live"),children:[(0,C.jsx)("span",{className:"dtt-icon",children:(0,C.jsx)(S.Cd7,{})}),"Live"]}),(0,C.jsxs)("button",{type:"button",className:"dtt-tab ".concat("analysis"===W?"active":""),onClick:()=>pe("analysis"),children:[(0,C.jsx)("span",{className:"dtt-icon",children:(0,C.jsx)(S.DX0,{})}),"Analysis"]})]})]}),(0,C.jsxs)("div",{className:"hdr-stats",children:[(()=>{const e=Oa.profit<0,s=Math.abs(Oa.profit);return(0,C.jsxs)("span",{className:"strat-stat ".concat(e?"strat-stat-loss":"strat-stat-profit"),title:"".concat(e?"Loss":"Profit"," (").concat(Oa.label,")"),children:[(0,C.jsx)("span",{className:"strat-stat-icon",children:e?(0,C.jsx)(S.Rod,{}):(0,C.jsx)(S.imn,{})}),(0,C.jsx)("span",{className:"strat-stat-label",children:e?"Loss":"Profit"}),(0,C.jsxs)("span",{className:"strat-stat-value",children:[e?"-":"","\u20b9",s.toFixed(0)]})]})})(),xa&&(0,C.jsxs)(C.Fragment,{children:[ga&&(0,C.jsxs)("span",{className:"live-status",children:[(0,C.jsx)("span",{className:"live-dot"})," Loading ",ka.length?"\xb7 ".concat(ka.length," loaded"):""]}),!ga&&!fa&&(0,C.jsxs)("span",{className:"live-status live-status-ready",children:[(0,C.jsx)("span",{className:"live-dot ready"})," ",wa.length," orders",(0,C.jsxs)("span",{className:"live-status-sub",children:[" / ",ka.length," total"]})]}),fa&&(0,C.jsxs)("span",{className:"live-status live-status-error",children:[(0,C.jsx)("span",{className:"live-dot error"})," Failed to load"]}),(()=>{const e=g()().startOf("day"),s=e.format("YYYY-MM-DD"),a=g()(qs),t=qs===s,i=a.isAfter(e,"day"),n=s=>{if(!s)return;const a=s.format("YYYY-MM-DD");a!==qs?s.isAfter(e,"day")||(Is(a),Da(null),Ae(null),Ee(null),Rs(!1)):Rs(!1)},r=Ts.startOf("month"),l=r.subtract(r.day(),"day"),c=Array.from({length:42},((e,s)=>l.add(s,"day"))),d=!Ts.add(1,"month").startOf("month").isAfter(e,"month");return(0,C.jsxs)("div",{className:"date-chip".concat(t?" is-today":"").concat(Os?" is-open":""),ref:Ys,children:[(0,C.jsx)("button",{type:"button",className:"date-chip-nav",onClick:()=>n(a.subtract(1,"day")),"aria-label":"Previous day",title:"Previous day",children:(0,C.jsx)(S.E_E,{})}),(0,C.jsxs)("button",{type:"button",className:"date-chip-main",onClick:()=>Rs((e=>!e)),"aria-haspopup":"dialog","aria-expanded":Os,children:[(0,C.jsx)("span",{className:"date-chip-icon","aria-hidden":"true",children:(0,C.jsx)(S.dDC,{})}),(0,C.jsxs)("span",{className:"date-chip-text",children:[(0,C.jsxs)("span",{className:"date-chip-label",children:["Date",t&&(0,C.jsx)("span",{className:"date-chip-today-pill",children:"Today"})]}),(0,C.jsx)("span",{className:"date-chip-value",children:a.isValid()?a.format("ddd, MMM D, YYYY"):"\u2014"})]}),(0,C.jsx)("span",{className:"date-chip-chevron".concat(Os?" is-open":""),"aria-hidden":"true",children:(0,C.jsx)(S.j1Q,{})})]}),(0,C.jsx)("button",{type:"button",className:"date-chip-nav",onClick:()=>{t||i||n(a.add(1,"day"))},disabled:t||i,"aria-label":"Next day",title:t?"You're viewing today":"Next day",children:(0,C.jsx)(S.xVu,{})}),Os&&(0,C.jsxs)("div",{className:"date-cal-popover",role:"dialog","aria-label":"Pick a date",children:[(0,C.jsxs)("div",{className:"date-cal-header",children:[(0,C.jsx)("button",{type:"button",className:"date-cal-nav",onClick:()=>Hs((e=>e.subtract(1,"month"))),"aria-label":"Previous month",children:(0,C.jsx)(S.E_E,{})}),(0,C.jsx)("div",{className:"date-cal-title",children:Ts.format("MMMM YYYY")}),(0,C.jsx)("button",{type:"button",className:"date-cal-nav",onClick:()=>{const s=Ts.add(1,"month");s.startOf("month").isAfter(e,"month")||Hs(s)},disabled:!d,"aria-label":"Next month",children:(0,C.jsx)(S.xVu,{})})]}),(0,C.jsx)("div",{className:"date-cal-weekdays",children:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"].map((e=>(0,C.jsx)("div",{className:"date-cal-weekday",children:e},e)))}),(0,C.jsx)("div",{className:"date-cal-grid",children:c.map((a=>{const t=a.month()===Ts.month(),i=a.format("YYYY-MM-DD")===qs,r=a.format("YYYY-MM-DD")===s,l=a.isAfter(e,"day"),c=["date-cal-day",!t&&"is-other-month",i&&"is-selected",r&&"is-today",l&&"is-disabled"].filter(Boolean).join(" ");return(0,C.jsx)("button",{type:"button",className:c,disabled:l,onClick:()=>n(a),"aria-current":r?"date":void 0,"aria-pressed":i,children:a.date()},a.format("YYYY-MM-DD"))}))}),(0,C.jsxs)("div",{className:"date-cal-presets",children:[(0,C.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>n(e),children:"Today"}),(0,C.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>n(e.subtract(1,"day")),children:"Yesterday"}),(0,C.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>n(e.subtract(7,"day")),children:"\u22127 days"})]})]})]})})()]})]}),(0,C.jsx)("div",{id:"clock",children:Be})]}),(a||"live"===W)&&(0,C.jsxs)(C.Fragment,{children:[(0,C.jsxs)("div",{id:"strat-row",children:[(0,C.jsxs)("button",{className:"sbt ".concat("kitchens"===M?"active":""),onClick:()=>{A.A.info("View mode changed: By Location"),B("kitchens"),Da(null),Ae(null),Ee(null)},children:[(0,C.jsx)("span",{className:"sbt-icon",children:(0,C.jsx)(S.JFD,{})})," By Location"]}),(0,C.jsxs)("button",{className:"sbt ".concat("zones"===M?"active":""),onClick:()=>{A.A.info("View mode changed: By Zone"),B("zones"),Da(null),Ae(null),Ee(null)},children:[(0,C.jsx)("span",{className:"sbt-icon",children:(0,C.jsx)(S.Cd7,{})})," By Zone"]}),(0,C.jsxs)("button",{className:"sbt ".concat("riders"===M?"active":""),onClick:()=>{A.A.info("View mode changed: By Rider"),B("riders"),Da(null),Ae(null),Ee(null)},children:[(0,C.jsx)("span",{className:"sbt-icon",children:(0,C.jsx)(S.bsz,{})})," By Rider"]}),(0,C.jsxs)("button",{className:"sbt ".concat("all"===M?"active":""),onClick:()=>{A.A.info("View mode changed: All Routes"),B("all"),Da(null),Ae(null),Ee(null)},children:[(0,C.jsx)("span",{className:"sbt-icon",children:(0,C.jsx)(S.Zs6,{})})," All Routes"]}),(0,C.jsxs)("button",{type:"button",className:"sbt sbt-rider-info ".concat("rider-info"===M?"active":""),onClick:()=>{B("rider-info"),Da(null),Ae(null),Ee(null)},title:"Live GPS / battery / status snapshot for a rider",children:[(0,C.jsx)("span",{className:"sbt-icon",children:(0,C.jsx)(S.k4P,{})})," Rider Info"]})]}),xa&&"rider-info"!==M&&(0,C.jsxs)("div",{id:"batch-row",children:[(0,C.jsx)("span",{className:"batch-label",children:"Batch"}),(0,C.jsx)("div",{className:"batch-scroll",children:ls.map((e=>{var s;const a=ma===e.id;return(0,C.jsxs)("button",{ref:a?ha:null,className:"batch-btn batch-slot ".concat(a?"active":""),onClick:()=>{pa(e.id),Da(null),Ae(null),Ee(null)},title:"".concat(e.label," (").concat(e.range,")"),children:[(0,C.jsx)("span",{className:"batch-btn-label",children:e.label}),(0,C.jsx)("span",{className:"batch-btn-count",children:null!==(s=_a[e.id])&&void 0!==s?s:0})]},e.id)}))})]}),"rider-info"===M?(0,C.jsxs)("div",{className:"rider-info-mode",children:[(0,C.jsxs)("div",{className:"ri-sidebar",children:[(0,C.jsxs)("div",{className:"ri-sb-head",children:[(0,C.jsx)("div",{className:"ri-sb-title",children:"Riders"}),(0,C.jsxs)("div",{className:"ri-sb-sub",children:[Sa.length," ",1===Sa.length?"rider":"riders"," today"]})]}),(0,C.jsxs)("div",{className:"ri-search",children:[(0,C.jsx)(S.gZ7,{className:"ri-search-icon"}),(0,C.jsx)("input",{type:"text",className:"ri-search-input",placeholder:"Search by name or ID",value:hs,onChange:e=>xs(e.target.value)})]}),(()=>{const e=hs.trim().toLowerCase(),s=Sa.filter((s=>!e||(String(s.riderName||"").toLowerCase().includes(e)||String(s.id).includes(e))));return 0===s.length?(0,C.jsx)("div",{className:"ri-empty",children:hs?'No riders match "'.concat(hs,'"'):"No riders have orders today"}):(0,C.jsx)("div",{className:"ri-rider-list",children:s.map((e=>{const s=String(ms)===String(e.id);return(0,C.jsxs)("button",{type:"button",className:"ri-rider-item ".concat(s?"active":""),onClick:()=>ps(e.id),children:[(0,C.jsx)("span",{className:"ri-rider-dot",style:{background:le(e.id)}}),(0,C.jsxs)("span",{className:"ri-rider-info-block",children:[(0,C.jsx)("span",{className:"ri-rider-name",children:e.riderName}),(0,C.jsxs)("span",{className:"ri-rider-meta",children:["#",e.id]})]}),(0,C.jsx)("span",{className:"ri-rider-arrow",children:"\u2192"})]},e.id)}))})})()]}),(0,C.jsx)("div",{className:"ri-main",children:null==ms?(0,C.jsxs)("div",{className:"ri-placeholder",children:[(0,C.jsx)("div",{className:"ri-placeholder-icon",children:(0,C.jsx)(S.k4P,{})}),(0,C.jsx)("div",{className:"ri-placeholder-title",children:"Pick a rider"}),(0,C.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,C.jsxs)(C.Fragment,{children:[js&&!vs&&(0,C.jsx)("div",{className:"ri-loading",children:"Loading rider snapshot\u2026"}),gs&&(0,C.jsxs)("div",{className:"ri-error",children:["Couldn't load this rider's log. ",(null===fs||void 0===fs?void 0:fs.message)||""]}),vs&&(()=>{const e=vs,s=parseFloat(e.latitude),a=parseFloat(e.longitude),t=Number.isFinite(s)&&Number.isFinite(a),i=parseInt(String(e.battery||"").replace("%",""),10),n=Number.isFinite(i)&&i<=20,r=parseFloat(e.speed),c=String(e.status||"").toLowerCase();return(0,C.jsxs)("div",{className:"ri-snapshot",children:[(0,C.jsxs)("div",{className:"ri-snap-head",children:[(0,C.jsx)("div",{className:"ri-snap-name",children:e.username||"Rider #".concat(e.userid)}),(0,C.jsxs)("div",{className:"ri-snap-meta",children:[(0,C.jsxs)("span",{children:["#",e.userid]}),e.status&&(0,C.jsx)("span",{className:"ri-status ri-status-".concat(c),children:e.status}),(0,C.jsxs)("span",{className:"ri-live ".concat(js?"is-refetching":""),children:[(0,C.jsx)("span",{className:"ri-live-dot"}),js?"Updating\u2026":"Live"]})]}),e.logdate&&(0,C.jsxs)("div",{className:"ri-snap-time",children:[(0,C.jsx)(S.VP9,{})," Last seen ",e.logdate]})]}),(0,C.jsxs)("div",{className:"ri-snap-grid",children:[(0,C.jsxs)("div",{className:"ri-stat ".concat(n?"ri-stat-warn":""),children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.wZm,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"Battery"}),(0,C.jsxs)("div",{className:"ri-stat-value",children:[e.battery||"\u2014",e.is_charging&&(0,C.jsx)("span",{className:"ri-stat-tag",children:"Charging"})]})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.Xh5,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"Connection"}),(0,C.jsx)("div",{className:"ri-stat-value",children:e.connection||"\u2014"})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.HPi,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"GPS Accuracy"}),(0,C.jsx)("div",{className:"ri-stat-value",children:e.accuracy?"".concat(e.accuracy," m"):"\u2014"})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.o8z,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"Location Service"}),(0,C.jsx)("div",{className:"ri-stat-value",children:e.location_service||"\u2014"})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.BJM,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"Speed"}),(0,C.jsx)("div",{className:"ri-stat-value",children:Number.isFinite(r)?"".concat(r.toFixed(2)," km/h"):"\u2014"})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.bqQ,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"Heading"}),(0,C.jsx)("div",{className:"ri-stat-value",children:null!=e.heading?"".concat(e.heading,"\xb0"):"\u2014"})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.pSF,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"App State"}),(0,C.jsx)("div",{className:"ri-stat-value",children:e.is_background?"Background":"Foreground"})]})]}),(0,C.jsxs)("div",{className:"ri-stat",children:[(0,C.jsx)("div",{className:"ri-stat-icon",children:(0,C.jsx)(S.gsJ,{})}),(0,C.jsxs)("div",{className:"ri-stat-body",children:[(0,C.jsx)("div",{className:"ri-stat-label",children:"Current Order"}),(0,C.jsx)("div",{className:"ri-stat-value",children:e.orderid||"\u2014"})]})]})]}),t&&(0,C.jsxs)("div",{className:"ri-map-section",children:[(0,C.jsxs)("div",{className:"ri-coords-label",children:[(0,C.jsx)(S.gwi,{})," ",s.toFixed(6),", ",a.toFixed(6)]}),(0,C.jsx)("div",{className:"ri-map",children:(0,C.jsxs)(d.W,{center:[s,a],zoom:13,scrollWheelZoom:!1,style:{height:"100%",width:"100%"},children:[(0,C.jsx)(o.e,{url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",attribution:"\xa9 OpenStreetMap contributors"}),(0,C.jsxs)(l.p,{position:[s,a],children:[(0,C.jsx)(u.m,{direction:"top",offset:[0,-10],permanent:!0,className:"ri-area-banner",children:(null===bs||void 0===bs?void 0:bs.area)||"Locating area\u2026"}),(0,C.jsxs)(m.z,{children:[(0,C.jsx)("div",{style:{fontWeight:700,marginBottom:2},children:e.username||"Rider #".concat(e.userid)}),(null===bs||void 0===bs?void 0:bs.area)&&(0,C.jsx)("div",{style:{fontSize:12,color:"#0f172a",marginBottom:4},children:bs.area}),(0,C.jsx)("div",{style:{fontSize:11,color:"#64748b"},children:e.logdate?"Last seen ".concat(e.logdate):"".concat(s.toFixed(6),", ").concat(a.toFixed(6))})]})]})]},"".concat(e.userid,"-").concat(s,"-").concat(a))})]})]})})()]})})]}):(0,C.jsxs)("div",{id:"body",className:"".concat(ea?"sidebar-collapsed":""," ").concat(Vs?"compare-mode":""," ").concat(Vs&&ia?"compare-data-collapsed":"").trim(),children:[(0,C.jsx)("button",{type:"button",className:"sidebar-toggle-tab".concat(ea?" is-collapsed":""),onClick:()=>sa((e=>!e)),title:ea?"Show sidebar":"Hide sidebar","aria-label":ea?"Show sidebar":"Hide sidebar",children:ea?(0,C.jsx)(S.xVu,{}):(0,C.jsx)(S.E_E,{})}),Vs&&Ea&&(0,C.jsx)("button",{type:"button",className:"compare-data-toggle-tab".concat(ia?" is-collapsed":""),onClick:()=>na((e=>!e)),title:ia?"Show details panel":"Hide details panel","aria-label":ia?"Show details panel":"Hide details panel",children:ia?(0,C.jsx)(S.E_E,{}):(0,C.jsx)(S.xVu,{})}),(0,C.jsxs)("div",{id:"sidebar",children:[!Ea&&(0,C.jsxs)("div",{className:"sb-header",children:[(0,C.jsxs)("div",{className:"sb-header-top",children:[(0,C.jsxs)("div",{className:"sb-header-title",children:[(0,C.jsx)("span",{className:"sb-title-bar","aria-hidden":"true"}),(0,C.jsx)("span",{className:"sb-title-text",children:"RIDER DISPATCH"})]}),(0,C.jsxs)("span",{className:"sb-header-scope",title:Oa.label,children:[(0,C.jsx)("span",{className:"sb-scope-dot"}),Oa.label]})]}),(0,C.jsxs)("div",{className:"sb-header-tiles",children:[(0,C.jsxs)("div",{className:"sb-tile sb-tile-orders",children:[(0,C.jsx)("span",{className:"sb-tile-icon",children:(0,C.jsx)(S.gsJ,{})}),(0,C.jsxs)("div",{className:"sb-tile-body",children:[(0,C.jsx)("div",{className:"sb-tile-value",children:Oa.orders}),(0,C.jsx)("div",{className:"sb-tile-label",children:1===Oa.orders?"Order":"Orders"})]})]}),(0,C.jsxs)("div",{className:"sb-tile sb-tile-riders",children:[(0,C.jsx)("span",{className:"sb-tile-icon",children:(0,C.jsx)(S.aVM,{})}),(0,C.jsxs)("div",{className:"sb-tile-body",children:[(0,C.jsx)("div",{className:"sb-tile-value",children:Oa.riders}),(0,C.jsx)("div",{className:"sb-tile-label",children:1===Oa.riders?"Rider":"Riders"})]})]})]})]}),Ea||ze?(0,C.jsxs)("div",{id:"route-detail",children:[(0,C.jsxs)("button",{className:"rd-back",onClick:()=>{Da(null),Ae(null)},children:["\u2190 Back to ",Pe?Pe.name:"list"]}),Ea?(0,C.jsxs)(C.Fragment,{children:[(0,C.jsx)("div",{className:"rd-rider-name",style:{color:Ea.color},children:Ea.riderName}),(()=>{const e=Ea.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),s=Ea.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),a=s<0;return(0,C.jsxs)("div",{className:"rd-stats-grid",children:[(0,C.jsxs)("div",{className:"rd-stat rd-stat-orders",children:[(0,C.jsx)("div",{className:"rd-stat-icon",children:(0,C.jsx)(S.gsJ,{})}),(0,C.jsx)("div",{className:"rd-stat-value",children:Ea.orders.length}),(0,C.jsx)("div",{className:"rd-stat-label",children:"Orders"})]}),(0,C.jsxs)("div",{className:"rd-stat rd-stat-distance",children:[(0,C.jsx)("div",{className:"rd-stat-icon",children:(0,C.jsx)(S.xI$,{})}),(0,C.jsxs)("div",{className:"rd-stat-value",children:[e.toFixed(1),(0,C.jsx)("span",{className:"rd-stat-unit",children:"km"})]}),(0,C.jsx)("div",{className:"rd-stat-label",children:"Distance"})]}),(0,C.jsxs)("div",{className:"rd-stat rd-stat-profit ".concat(a?"is-loss":"is-gain"),children:[(0,C.jsx)("div",{className:"rd-stat-icon",children:a?(0,C.jsx)(S.Rod,{}):(0,C.jsx)(S.imn,{})}),(0,C.jsxs)("div",{className:"rd-stat-value",children:[a?"-":"","\u20b9",Math.abs(s).toFixed(0)]}),(0,C.jsx)("div",{className:"rd-stat-label",children:a?"Loss":"Profit"})]})]})})(),(()=>{const e={};Ea.orders.forEach((s=>{const a=s.trip_number||1;e[a]||(e[a]=[]),e[a].push(s)}));const s=[...Ea.orders].sort(((e,s)=>{const a=e.trip_number||1,t=s.trip_number||1;return a!==t?a-t:(e.step||0)-(s.step||0)})).find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!w.Ys.has(s)&&!w.yP.has(s)})),a=s?s.orderid:null,t=e=>{const s=e.deliverytime||e.expecteddeliverytime;if(!s)return Number.MAX_SAFE_INTEGER;const a=g()(s);return a.isValid()?a.valueOf():Number.MAX_SAFE_INTEGER},i="time"===qe;let r=null;return Object.entries(e).sort(((e,s)=>{let[a]=e,[t]=s;return Number(a)-Number(t)})).map((e=>{let[s,l]=e;const c=i?[...l].sort(((e,s)=>{const a=t(e)-t(s);return 0!==a?a:(e.step||0)-(s.step||0)})):l;return(0,C.jsxs)("div",{className:"trip-block",children:[(0,C.jsxs)("div",{className:"trip-header",style:{background:"".concat(Ea.color,"12"),borderColor:"".concat(Ea.color,"30")},children:[(0,C.jsxs)("span",{className:"th-badge",style:{background:Ea.color},children:["Trip ",s]}),(0,C.jsxs)("span",{className:"trip-stats",children:[(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.gwi,{})}),l.length," stops"]}),(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.xI$,{})}),l.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]})]}),(0,C.jsxs)("div",{className:"trip-sort-toggle",role:"group","aria-label":"Sort stops by","data-mode":i?"time":"planned",children:[(0,C.jsxs)("button",{type:"button",className:"trip-sort-pill ".concat(i?"":"is-active"),"aria-pressed":!i,onClick:()=>Ie("planned"),title:"Sort stops by planned step (dispatched order)",children:[(0,C.jsx)(S.EgJ,{"aria-hidden":"true"}),(0,C.jsx)("span",{children:"Planned"})]}),(0,C.jsxs)("button",{type:"button",className:"trip-sort-pill ".concat(i?"is-active":""),"aria-pressed":i,onClick:()=>Ie("time"),title:"Sort stops by completion time (which delivery was done first)",children:[(0,C.jsx)(S.VP9,{"aria-hidden":"true"}),(0,C.jsx)("span",{children:"By time"})]})]})]}),(0,C.jsx)("div",{className:"zone-order-grid",children:c.map(((e,t)=>{const l=(e.kitchen_key||e.pickupcustomer||"Unknown").toLowerCase().trim(),c=null!==r&&l!==r;r=l;const d=De&&De.orderid===e.orderid,o=a&&e.orderid===a,u=parseFloat(e.droplat||e.deliverylat),m=parseFloat(e.droplon||e.deliverylong),p=Number.isFinite(u)&&Number.isFinite(m),h=(0,w.Cx)(e.orderstatus),x=parseFloat(e.profit||0),v=x<0,g=Xa(Ea.id,e),f=e.step||t+1,N=i&&!e.deliverytime;return(0,C.jsxs)(n.Fragment,{children:[c&&(0,C.jsxs)("div",{className:"kitchen-transition",children:[(0,C.jsx)("span",{className:"kt-ico",children:(0,C.jsx)(S.$G1,{})})," Switch to ",(0,C.jsx)("strong",{children:e.pickupcustomer})]}),(0,C.jsxs)("div",{className:"zone-order-card ".concat(p?"clickable":""," ").concat(d?"active":""," ").concat(o?"going-on":""," ").concat(N?"is-pending-time":""),role:p?"button":void 0,tabIndex:p?0:void 0,onClick:p?()=>Le(d?null:{orderid:e.orderid,lat:u,lon:m}):void 0,onKeyDown:p?s=>{"Enter"!==s.key&&" "!==s.key||(s.preventDefault(),Le(d?null:{orderid:e.orderid,lat:u,lon:m}))}:void 0,title:p?d?"Click to show full trip":"Show ".concat(e.deliverycustomer||"order #".concat(e.orderid)," on map"):void 0,children:[(0,C.jsxs)("div",{className:"zone-order-card-head",children:[(0,C.jsx)("div",{className:"zone-order-num",title:"Planned step ".concat(e.step||t+1),children:f}),(0,C.jsx)("div",{className:"zone-order-id-block",children:(0,C.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]})}),(()=>{const s=ae(e.deliverytime),a=ae(e.expecteddeliverytime),t=!w.Ys.has(String(e.orderstatus||"").toLowerCase())&&null!==g;return e.orderstatus||s||a||t?(0,C.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,C.jsx)("span",{className:"zone-order-status",style:{background:h.bg,color:h.fg},children:h.label}),(s||a)&&(0,C.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(a),children:[(0,C.jsx)(S.VP9,{}),s||a]}),t&&(0,C.jsxs)("span",{className:"zone-order-est-drop",title:"Estimated distance to drop location",children:[(0,C.jsx)(S.HPi,{}),Qa(g)]})]}):null})(),j&&(0,C.jsx)("button",{type:"button",className:"zone-order-change-rider",title:"Change rider",onClick:s=>{s.stopPropagation(),j(e,Ea)},children:(0,C.jsx)(S.$G1,{})})]}),(0,C.jsxs)("div",{className:"zone-order-customer",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,C.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,C.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.gwi,{})}),e.deliverysuburb||q(e.deliveryaddress)]}),e.ordernotes&&(0,C.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.dKO,{})}),e.ordernotes]}),(0,C.jsxs)("div",{className:"zone-order-stats",children:[(0,C.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,C.jsxs)("span",{className:"zone-order-chip ".concat(v?"is-loss":"is-profit"),title:"Profit",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.ohY,{})}),v?"-":"","\u20b9",Math.abs(x).toFixed(0)]}),null!=e.deliverycharge&&(0,C.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,C.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,C.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||s," \xb7 S",e.step||t+1]})]})]})]},e.orderid)}))})]},s)}))})()]}):(0,C.jsxs)(C.Fragment,{children:[(0,C.jsx)("div",{className:"rd-rider-name",style:{color:"#f59e0b"},children:ze.kitchenName}),(0,C.jsxs)("div",{className:"rd-rider-sub",children:[(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.gsJ,{})}),ze.orders.length," orders"]}),(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.aVM,{})}),ze.riders.size," riders"]})]}),(0,C.jsxs)("div",{className:"zone-detail-section",children:[(0,C.jsxs)("div",{className:"zone-section-label",children:["Orders ",(0,C.jsxs)("span",{className:"section-count",children:["(",ze.orders.length,")"]})]}),0===ze.orders.length?(0,C.jsx)("div",{className:"zone-suburb-panel-empty",children:"No orders for this kitchen."}):(0,C.jsx)("div",{className:"zone-order-grid",children:ze.orders.map(((e,s)=>{const a=parseFloat(e.droplat||e.deliverylat),t=parseFloat(e.droplon||e.deliverylong),i=Number.isFinite(a)&&Number.isFinite(t),n=De&&De.orderid===e.orderid,r=(0,w.Cx)(e.orderstatus),l=parseFloat(e.profit||0),c=l<0,d=e.rider_id||e.userid,o=d?Ca.find((e=>String(e.id)===String(d))):null,u=(()=>{if(!o)return null;const e=[...o.orders].sort(((e,s)=>{const a=e.trip_number||1,t=s.trip_number||1;return a!==t?a-t:(e.step||0)-(s.step||0)})).find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!w.Ys.has(s)&&!w.yP.has(s)}));return e?e.orderid:null})(),m=u&&e.orderid===u,p=d?Xa(d,e):null;return(0,C.jsxs)("div",{className:"zone-order-card ".concat(i?"clickable":""," ").concat(n?"active":""," ").concat(m?"going-on":""),role:i?"button":void 0,tabIndex:i?0:void 0,onClick:i?()=>Le(n?null:{orderid:e.orderid,lat:a,lon:t}):void 0,children:[(0,C.jsxs)("div",{className:"zone-order-card-head",children:[(0,C.jsx)("div",{className:"zone-order-num",children:e.step||s+1}),(0,C.jsxs)("div",{className:"zone-order-id-block",children:[(0,C.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]}),(0,C.jsxs)("div",{className:"zone-order-rider",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.aVM,{})}),e.rider_name||e.ridername||"Unassigned"]})]}),(()=>{const s=ae(e.deliverytime),a=ae(e.expecteddeliverytime),t=!w.Ys.has(String(e.orderstatus||"").toLowerCase())&&null!==p;return e.orderstatus||s||a||t?(0,C.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,C.jsx)("span",{className:"zone-order-status",style:{background:r.bg,color:r.fg},children:r.label}),(s||a)&&(0,C.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(a),children:[(0,C.jsx)(S.VP9,{}),s||a]}),t&&(0,C.jsxs)("span",{className:"zone-order-est-drop",title:"Estimated distance to drop location",children:[(0,C.jsx)(S.HPi,{}),Qa(p)]})]}):null})()]}),(0,C.jsxs)("div",{className:"zone-order-customer",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,C.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,C.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.gwi,{})}),e.deliverysuburb||q(e.deliveryaddress)]}),e.ordernotes&&(0,C.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.dKO,{})}),e.ordernotes]}),(0,C.jsxs)("div",{className:"zone-order-stats",children:[(0,C.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,C.jsxs)("span",{className:"zone-order-chip ".concat(c?"is-loss":"is-profit"),title:"Profit",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.ohY,{})}),c?"-":"","\u20b9",Math.abs(l).toFixed(0)]}),null!=e.deliverycharge&&(0,C.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,C.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,C.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||"-"," \xb7 S",e.step||s+1]})]})]},e.orderid)}))})]})]})]}):Pe?(0,C.jsxs)("div",{id:"route-detail",children:[(0,C.jsx)("button",{className:"rd-back",onClick:()=>Ee(null),children:"\u2190 Back to zones"}),(0,C.jsx)("div",{className:"rd-rider-name",style:{color:"#3b82f6"},children:Pe.name}),(0,C.jsx)("div",{className:"rd-rider-sub",children:(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.gsJ,{})}),Pe.totalOrders," ",1===Pe.totalOrders?"order":"orders"]})}),(0,C.jsxs)("div",{className:"zone-detail-section",children:[(0,C.jsxs)("div",{className:"zone-section-label",children:["Orders ",(0,C.jsxs)("span",{className:"section-count",children:["(",Pe.orders.length,")"]})]}),0===Pe.orders.length?(0,C.jsx)("div",{className:"zone-suburb-panel-empty",children:"No orders in this zone."}):(0,C.jsx)("div",{className:"zone-order-grid",children:Pe.orders.map(((e,s)=>{const a=parseFloat(e.droplat||e.deliverylat),t=parseFloat(e.droplon||e.deliverylong),i=Number.isFinite(a)&&Number.isFinite(t),n=De&&De.orderid===e.orderid,r=(0,w.Cx)(e.orderstatus),l=parseFloat(e.profit||0),c=l<0,d=e.rider_id||e.userid,o=d?Ca.find((e=>String(e.id)===String(d))):null,u=(()=>{if(!o)return null;const e=[...o.orders].sort(((e,s)=>{const a=e.trip_number||1,t=s.trip_number||1;return a!==t?a-t:(e.step||0)-(s.step||0)})).find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!w.Ys.has(s)&&!w.yP.has(s)}));return e?e.orderid:null})(),m=u&&e.orderid===u,p=d?Xa(d,e):null;return(0,C.jsxs)("div",{className:"zone-order-card ".concat(i?"clickable":""," ").concat(n?"active":""," ").concat(m?"going-on":""),role:i?"button":void 0,tabIndex:i?0:void 0,onClick:i?()=>Le(n?null:{orderid:e.orderid,lat:a,lon:t}):void 0,children:[(0,C.jsxs)("div",{className:"zone-order-card-head",children:[(0,C.jsx)("div",{className:"zone-order-num",children:e.step||s+1}),(0,C.jsxs)("div",{className:"zone-order-id-block",children:[(0,C.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]}),(0,C.jsxs)("div",{className:"zone-order-rider",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.aVM,{})}),e.rider_name||e.ridername||"Unassigned"]})]}),(()=>{const s=ae(e.deliverytime),a=ae(e.expecteddeliverytime),t=!w.Ys.has(String(e.orderstatus||"").toLowerCase())&&null!==p;return e.orderstatus||s||a||t?(0,C.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,C.jsx)("span",{className:"zone-order-status",style:{background:r.bg,color:r.fg},children:r.label}),(s||a)&&(0,C.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(a),children:[(0,C.jsx)(S.VP9,{}),s||a]}),t&&(0,C.jsxs)("span",{className:"zone-order-est-drop",title:"Estimated distance to drop location",children:[(0,C.jsx)(S.HPi,{}),Qa(p)]})]}):null})()]}),(0,C.jsxs)("div",{className:"zone-order-customer",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,C.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,C.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.gwi,{})}),e.deliverysuburb||q(e.deliveryaddress)]}),e.ordernotes&&(0,C.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.dKO,{})}),e.ordernotes]}),(0,C.jsxs)("div",{className:"zone-order-stats",children:[(0,C.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,C.jsxs)("span",{className:"zone-order-chip ".concat(c?"is-loss":"is-profit"),title:"Profit",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.ohY,{})}),c?"-":"","\u20b9",Math.abs(l).toFixed(0)]}),null!=e.deliverycharge&&(0,C.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,C.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,C.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||"-"," \xb7 S",e.step||s+1]})]})]},e.orderid)}))})]})]}):(0,C.jsxs)("div",{id:"riders-panel",children:[(0,C.jsx)("div",{className:"ph",children:"zones"===M?"Zone dispatch":"kitchens"===M?"Kitchen dispatch":"Rider dispatch"}),(0,C.jsx)("div",{id:"rider-cards",children:0!==Aa.length||ga?"zones"===M?Ma.map(((e,s)=>{const a=e.statusCounts.delivered||0,t=e.totalProfit<0;return(0,C.jsxs)("div",{className:"rcard zone-card",onClick:()=>Ee(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,C.jsxs)("div",{className:"zone-card-header",children:[(0,C.jsx)("div",{className:"zone-card-emoji",children:(0,C.jsx)(S.Cd7,{})}),(0,C.jsxs)("div",{className:"zone-card-titles",children:[(0,C.jsx)("div",{className:"zone-card-name",children:e.name}),(0,C.jsxs)("div",{className:"zone-card-sub",children:[e.activeRidersCount," ",1===e.activeRidersCount?"rider":"riders"," \xb7 ",e.totalOrders," ",1===e.totalOrders?"order":"orders"]})]}),(0,C.jsx)("span",{className:"zone-card-arrow","aria-hidden":"true",children:"\u2192"})]}),e.totalOrders>0&&(0,C.jsxs)("div",{className:"zone-progress-row",children:[(0,C.jsx)("div",{className:"zone-status-bar",title:Object.entries(e.statusCounts).map((e=>{let[s,a]=e;return"".concat((0,w.Cx)(s).label,": ").concat(a)})).join(" \xb7 "),children:Object.entries(e.statusCounts).map((s=>{let[a,t]=s;const i=(0,w.Cx)(a),n=t/e.totalOrders*100;return(0,C.jsx)("div",{className:"zone-status-seg",style:{width:"".concat(n,"%"),background:i.bg}},a)}))}),(0,C.jsxs)("div",{className:"zone-progress-label",children:[a,"/",e.totalOrders]})]}),(0,C.jsxs)("div",{className:"zone-stat-pills",children:[(0,C.jsxs)("span",{className:"zone-stat-pill",title:"Areas covered",children:[(0,C.jsx)("span",{className:"zone-stat-icon",children:(0,C.jsx)(S.gwi,{})}),(0,C.jsx)("span",{className:"zone-stat-value",children:e.suburbs.length}),(0,C.jsx)("span",{className:"zone-stat-label",children:1===e.suburbs.length?"area":"areas"})]}),(0,C.jsxs)("span",{className:"zone-stat-pill",title:"Total distance",children:[(0,C.jsx)("span",{className:"zone-stat-icon",children:(0,C.jsx)(S.xI$,{})}),(0,C.jsx)("span",{className:"zone-stat-value",children:e.totalKms.toFixed(1)}),(0,C.jsx)("span",{className:"zone-stat-label",children:"km"})]}),(0,C.jsxs)("span",{className:"zone-stat-pill",title:"Kitchens",children:[(0,C.jsx)("span",{className:"zone-stat-icon",children:(0,C.jsx)(S.NtI,{})}),(0,C.jsx)("span",{className:"zone-stat-value",children:e.kitchens.length}),(0,C.jsx)("span",{className:"zone-stat-label",children:1===e.kitchens.length?"kitchen":"kitchens"})]}),(0,C.jsxs)("span",{className:"zone-stat-pill ".concat(t?"profit-negative":"profit-positive"),title:"Total profit",children:[(0,C.jsx)("span",{className:"zone-stat-icon",children:(0,C.jsx)(S.ohY,{})}),(0,C.jsx)("span",{className:"zone-stat-value",children:t?"-\u20b9".concat(Math.abs(e.totalProfit).toFixed(0)):"\u20b9".concat(e.totalProfit.toFixed(0))})]})]}),e.suburbs.length>0&&(0,C.jsxs)("div",{className:"zone-card-suburbs",children:[(0,C.jsx)("span",{className:"zone-card-suburbs-text",children:e.suburbs.slice(0,3).map((e=>e.name)).join(" \xb7 ")}),e.suburbs.length>3&&(0,C.jsxs)("span",{className:"zone-card-suburbs-more",children:["+",e.suburbs.length-3]})]})]},e.id)})):"kitchens"===M?za.map(((e,s)=>(0,C.jsxs)("div",{className:"rcard",onClick:()=>Ae(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,C.jsxs)("div",{className:"rcard-top",children:[(0,C.jsx)("div",{className:"rcard-emo",style:{background:"#f59e0b18",borderColor:"#f59e0b50",color:"#f59e0b"},children:(0,C.jsx)(S.NtI,{})}),(0,C.jsxs)("div",{className:"rcard-info",children:[(0,C.jsx)("div",{className:"rcard-name",children:e.kitchenName}),(0,C.jsxs)("div",{className:"rcard-zone",children:[e.riders.size," riders \xb7 ",(0,C.jsx)(de,{children:(0,C.jsx)(S.ohY,{})}),"\u20b9",e.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0).toFixed(0)]})]}),(0,C.jsx)("div",{className:"rcard-badge",style:{background:"#f59e0b18",color:"#f59e0b"},children:e.orders.length})]}),(0,C.jsx)("div",{className:"bar-bg",children:(0,C.jsx)("div",{className:"bar-fg",style:{width:"".concat(Math.min(100,e.orders.length/20*100),"%"),background:"#f59e0b"}})}),(0,C.jsxs)("div",{className:"rcard-meta",children:[(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.xI$,{})}),e.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]}),(0,C.jsxs)("span",{children:[e.riders.size," riders"]})]}),(0,C.jsx)("div",{className:"step-ids",children:Array.from(e.riders).slice(0,10).map((e=>{var s;return(0,C.jsx)("span",{className:"step-id",style:{color:Za(e)},children:null===(s=Ca.find((s=>s.id===e)))||void 0===s?void 0:s.riderName.split(" ")[0]},e)}))})]},e.id))):Ca.map(((e,s)=>{var a;const t=e.orders.length,i=e.orders.filter((e=>w.Ys.has(String(e.orderstatus||"").toLowerCase()))).length,n=t>0&&i>=t,r=e.orders.find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!w.Ys.has(s)&&!w.yP.has(s)})),l=r?Xa(e.id,r):null;return(0,C.jsxs)("div",{className:"rcard",onClick:()=>Da(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,C.jsxs)("div",{className:"rcard-top",children:[(0,C.jsx)("div",{className:"rcard-emo",style:{background:"".concat(e.color,"18"),borderColor:"".concat(e.color,"50"),color:e.color},children:(0,C.jsx)(S.aVM,{})}),(0,C.jsxs)("div",{className:"rcard-info",children:[(0,C.jsx)("div",{className:"rcard-name",children:e.riderName}),(0,C.jsxs)("div",{className:"rcard-zone",children:[(null===(a=e.orders[0])||void 0===a?void 0:a.zone_name)||ys||"Local"," \xb7 ",new Set(e.orders.map((e=>e.trip_number||1))).size," trips"]})]}),(0,C.jsxs)("div",{className:"rcard-badge ".concat(n?"is-done":""),style:n?void 0:{background:"".concat(e.color,"18"),color:e.color},title:"".concat(i," delivered of ").concat(t," total"),children:[i,"/",t]})]}),(0,C.jsx)("div",{className:"bar-bg",children:(0,C.jsx)("div",{className:"bar-fg",style:{width:"".concat(Math.min(100,t/15*100),"%"),background:e.color}})}),(0,C.jsxs)("div",{className:"rcard-meta",children:[(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.xI$,{})}),e.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]}),null!==l&&(0,C.jsxs)("span",{className:"rcard-est-meters",title:"Estimated distance to next drop location",children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.HPi,{})}),Qa(l)," to drop"]}),(0,C.jsxs)("span",{children:[(0,C.jsx)(de,{children:(0,C.jsx)(S.ohY,{})}),"\u20b9",e.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0).toFixed(0)]})]}),(0,C.jsx)("div",{className:"step-ids",children:e.orders.slice(0,15).map((e=>(0,C.jsxs)("span",{className:"step-id",children:["S",e.step]},e.orderid)))})]},e.id)})):(e=>{const s=null===(e=ls.find((e=>e.id===ma)))||void 0===e?void 0:e.label,a=xa&&ka.length>0;return(0,C.jsxs)("div",{className:"empty-slot",children:[(0,C.jsx)("div",{className:"empty-slot-icon",children:(0,C.jsx)(S.gsJ,{})}),(0,C.jsx)("div",{className:"empty-slot-title",children:s?"No orders in ".concat(s):"No orders"}),(0,C.jsx)("div",{className:"empty-slot-sub",children:a?"".concat(ka.length," order").concat(1===ka.length?"":"s"," exist in other slots today"):"No deliveries found for this date"})]})})()})]})]}),(0,C.jsxs)("div",{id:"map-wrap",className:"".concat("kitchens"===M?"view-mode-kitchens":""," ").concat(Vs?"compare-split":"").trim(),children:[(0,C.jsxs)(d.W,{center:[11.022,76.982],zoom:12,scrollWheelZoom:!0,style:{height:"100%",width:"100%"},zoomControl:!1,renderer:da.current,inertia:!0,inertiaDeceleration:2400,inertiaMaxSpeed:2e3,wheelDebounceTime:20,wheelPxPerZoomLevel:80,zoomSnap:.25,children:[(0,C.jsx)(o.e,{url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",attribution:"\xa9 OpenStreetMap contributors"}),(0,C.jsx)(p.p,{position:"bottomright"}),Vs&&(0,C.jsx)(Z,{targetRef:ca}),(0,C.jsx)(X,{trigger:"".concat(ea,"|").concat(Vs,"|").concat(ia)}),(0,C.jsx)(ce,{focusedItem:Ua||(Ea||ze)&&De||Ea||ze||Pe,viewMode:M,orders:Aa,kitchens:za,locationKey:We}),za.filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lon))).filter((e=>!Ea||e.riders.has(Ea.id))).map(((e,s)=>(0,C.jsx)(l.p,{position:[e.lat,e.lon],icon:$a(e.kitchenName,(null===ze||void 0===ze?void 0:ze.id)===e.id),zIndexOffset:(null===ze||void 0===ze?void 0:ze.id)===e.id?4e3:2e3,eventHandlers:{click:()=>Ae(e),mouseover:e=>e.target.openPopup(),mouseout:e=>e.target.closePopup()},children:(0,C.jsxs)(m.z,{className:"kitchen-popup",maxWidth:220,minWidth:200,autoPan:!0,autoPanPadding:[20,20],children:[(0,C.jsx)("div",{className:"kp-header",children:"KITCHEN"}),(0,C.jsx)("div",{className:"kp-name",children:e.kitchenName}),(0,C.jsxs)("div",{className:"kp-stat",children:[(0,C.jsx)("span",{className:"kp-stat-lbl",children:"Orders"}),(0,C.jsx)("span",{className:"kp-stat-val",children:e.orders.length})]})]})},"k-".concat(s)))),(()=>{if(Vs&&Ea&&"actual"===Bs)return null;let e=Aa;Pe&&(e=Pe.orders),ze&&(e=ze.orders),Ea&&(e=Ea.orders),e=e.filter(I);const s=Vs&&Ea?new Map(Ha.map((e=>[String(e.deliveryid),e.sequenceStep]))):null;return e.map(((a,t)=>{const i=a.rider_id,n=!i||we.has(i);let r,c=Za(i);if(s&&i===Ea.id&&null!=a.deliveryid){const e=s.get(String(a.deliveryid));e&&(c=(0,w.gM)(e-1),r=e)}const d=!!Ea||!!ze,o=(0,w.Cx)(a.orderstatus),u="delivered"===String(a.orderstatus||"").toLowerCase(),m=v&&String(v)===String(a.orderid),p=a.orderstatus?'<svg class="cmark-flag" viewBox="0 0 18 22" xmlns="http://www.w3.org/2000/svg">\n <line x1="1.5" y1="0" x2="1.5" y2="22" stroke="#0f172a" stroke-width="1.6" stroke-linecap="round"/>\n <polygon points="2,1 17,1 13.5,5.5 17,10 2,10" fill="'.concat(o.bg,'" stroke="#0f172a" stroke-width="0.6" stroke-linejoin="round"/>\n ').concat(u?'<polyline points="5,5.5 7,7.5 11,3.5" fill="none" stroke="#fff" stroke-width="1.4" stroke-linecap="round" stroke-linejoin="round"/>':"","\n </svg>"):"",h=d?(()=>{const s=r||a.step||e.indexOf(a)+1,t=32;return x().divIcon({className:"",iconSize:[t,t],iconAnchor:[16,16],popupAnchor:[0,-28],html:'<div class="cmark is-rider-focused'.concat(m?" pulse":"",'" style="background:').concat(c,";width:").concat(t,"px;height:").concat(t,"px;font-size:").concat(s>9?12:14,"px;opacity:").concat(n?1:.75,'">').concat(s>0?s:"").concat(p,"</div>")})})():x().divIcon({className:"",iconSize:[24,30],iconAnchor:[2,30],popupAnchor:[10,-25],html:'<div class="cmark'.concat(m?" pulse":"",'" style="width:24px;height:30px;opacity:').concat(n?1:.75,'">').concat(p,"</div>")});return(0,C.jsx)(l.p,{position:[parseFloat(a.droplat||a.deliverylat),parseFloat(a.droplon||a.deliverylong)],icon:h,zIndexOffset:i?100:0,ref:e=>{e?Oe.current[String(a.orderid)]=e:delete Oe.current[String(a.orderid)]},eventHandlers:{click:()=>{const e=String(a.orderid);Re.current.has(e)?(Re.current.delete(e),Ve(null)):(Re.current.add(e),Ve(a))}}},"".concat(a.orderid,"-").concat(d?"num":"flag"))}))})(),(()=>{const e=Vs&&Ea&&"actual"===Bs;if(Cs)return e?[]:As.map(((e,s)=>(0,C.jsx)(c.R,{positions:[e.from,e.to],pathOptions:{color:e.color,weight:6,opacity:.9,lineJoin:"round",lineCap:"round"}},s)));const s=[],a=Pe?new Set(Pe.riders.map((e=>String(e.rider_id)))):null;return e||Ca.forEach((e=>{const t=we.has(e.id);if(Ea&&Ea.id!==e.id)return;if(ze&&!ze.riders.has(e.id))return;if(a&&!a.has(String(e.id)))return;const i=e.orders,r={};i.forEach((e=>{const s=e.trip_number||1;r[s]||(r[s]=[]),r[s].push(e)})),Object.entries(r).forEach((a=>{let[i,r]=a;const l=ze?r.filter((e=>(e.pickupcustomer||e.kitchen_key||"Unknown").toLowerCase().trim()===ze.id)):r;if(0===l.length)return;const d=[...r].sort(((e,s)=>(e.step||0)-(s.step||0))),o=ie(d),u=ne(e.id,i,o),m=ks[u],p=[...l].sort(((e,s)=>(e.step||0)-(s.step||0))),h=Array.isArray(m)&&m.length>=2,x=!1===m;if(!h&&!x)return;const v=h?m:ie(p);if(!v||v.length<2)return;const j=t?1:.1,g="kitchens"===M||ze?7:6,f=Vs&&Ea&&e.id===Ea.id,N=x?"8 6":f&&"combined"===Bs?"6 5":void 0;if(Vs&&Ea&&e.id===Ea.id){const a=new Map(Ha.map((e=>[String(e.deliveryid),e.sequenceStep]))),t=p.filter(I),n=t.map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]));let r;if(h)r=se(v,n);else{const e=v.length>n.length;r=[];for(let s=0;s<n.length;s++){const a=e?s:s-1,t=e?s+1:s;a<0||a>=v.length||t>=v.length?r.push([]):r.push([v[a],v[t]])}}const l="combined"===Bs?5:0;return s.push((0,C.jsx)(c.R,{positions:v,pathOptions:{color:"#ffffff",weight:g+4,opacity:.5*j,lineJoin:"round",lineCap:"round",offset:l}},"".concat(e.id,"-").concat(i,"-halo"))),void r.forEach(((n,r)=>{if(!n||n.length<2)return;const d=t[r],o=d?a.get(String(d.deliveryid)):null,u="combined"===Bs?E:o?(0,w.gM)(o-1):e.color,m=null!=ra&&ra===o,p=m?g+1.5:g,h=m?1:ra?.5*j:j;s.push((0,C.jsx)(c.R,{positions:n,pathOptions:{color:u,weight:p,opacity:h,lineJoin:"round",lineCap:"round",dashArray:N,offset:l}},"".concat(e.id,"-").concat(i,"-step-").concat(r,"-").concat((null===d||void 0===d?void 0:d.deliveryid)||r)))}))}s.push((0,C.jsxs)(n.Fragment,{children:[(0,C.jsx)(c.R,{positions:v,pathOptions:{color:"#ffffff",weight:g+4,opacity:.5*j,lineJoin:"round",lineCap:"round"}}),(0,C.jsx)(c.R,{positions:v,pathOptions:{color:e.color,weight:g,opacity:j,lineJoin:"round",lineCap:"round",dashArray:N}})]},"".concat(e.id,"-").concat(i)))}))})),s})(),ua.filter((e=>Ca.some((s=>String(s.id)===String(e.id))))).filter((e=>!Ea||String(Ea.id)===String(e.id))).map((e=>{var s;const a="active"===e.status?"#16a34a":"#dc2626",t=Ca.find((s=>String(s.id)===String(e.id))),i=null===t||void 0===t||null===(s=t.orders)||void 0===s?void 0:s.slice().sort(((e,s)=>{const a=e.trip_number||1,t=s.trip_number||1;return a!==t?a-t:(e.step||0)-(s.step||0)})).find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!w.Ys.has(s)&&!w.yP.has(s)})),n=i?i.deliverysuburb||q(i.deliveryaddress):null,r=x().divIcon({className:"",iconSize:[140,56],iconAnchor:[12,41],popupAnchor:[58,-40],html:'<div class="live-rider-pin" style="--pin-color:'.concat(a,'">\n <div class="live-rider-pin-marker"></div>\n <div class="live-rider-pin-label">').concat((e.username||"").replace(/[<>&"']/g,"")).concat(e.orderid?" <span>#".concat(String(e.orderid).replace(/[<>&"']/g,""),"</span>"):"","</div>\n </div>")});return(0,C.jsx)(l.p,{position:[e.lat,e.lon],icon:r,zIndexOffset:2500,eventHandlers:{click:s=>{const a=String(e.id);Te.current.has(a)?(Te.current.delete(a),s.target.closePopup()):(Te.current.add(a),s.target.openPopup());const t=Ca.find((e=>String(e.id)===a));t&&Da(t)},popupclose:()=>{Te.current.delete(String(e.id))}},children:(0,C.jsxs)(m.z,{maxWidth:260,autoPan:!0,autoPanPadding:[20,20],className:"dispatch-popup live-rider-popup",children:[(0,C.jsx)("div",{className:"pu-hdr-live",children:(0,C.jsxs)("div",{className:"pu-hdr-left",children:[(0,C.jsx)("span",{className:"pu-live-indicator",style:{"--pulse-color":a},children:(0,C.jsx)("span",{className:"pu-live-dot"})}),(0,C.jsx)("span",{className:"pu-hdr-title",children:"LIVE GPS"})]})}),(0,C.jsxs)("div",{className:"pu-rider-profile",children:[(0,C.jsx)("div",{className:"pu-avatar",style:{backgroundColor:"".concat(a,"12"),color:a},children:(0,C.jsx)(S.bsz,{})}),(0,C.jsxs)("div",{className:"pu-rider-info-text",children:[(0,C.jsxs)("div",{className:"pu-rider-name-row",children:[(0,C.jsx)("span",{className:"pu-rider-name",children:e.username||"Rider #".concat(e.id)}),e.status&&(0,C.jsx)("span",{className:"pu-status-badge ".concat("active"===e.status.toLowerCase()?"active":"idle"),children:e.status})]}),(0,C.jsxs)("div",{className:"pu-rider-meta",children:["Rider ID: #",e.id]})]})]}),(0,C.jsxs)("div",{className:"pu-body-content",children:[e.orderid&&(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Active Order"}),(0,C.jsxs)("span",{className:"pu-info-value pu-order-badge",children:["#",e.orderid]})]}),i&&(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Next Stop"}),(0,C.jsxs)("span",{className:"pu-info-value",style:{color:"#4f46e5"},children:["#",i.step||"?"," \xb7 ",i.deliverycustomer||"\u2014"]})]}),n&&(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Next Location"}),(0,C.jsx)("span",{className:"pu-info-value",title:i.deliveryaddress||n,children:n})]}),(null===i||void 0===i?void 0:i.pickupcustomer)&&(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Pickup"}),(0,C.jsx)("span",{className:"pu-info-value",title:i.pickupcustomer,children:i.pickupcustomer})]}),e.contactno&&(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Phone"}),(0,C.jsx)("a",{href:"tel:".concat(e.contactno),className:"pu-info-value pu-phone-link",children:e.contactno})]}),e.logdate&&(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Last Seen"}),(0,C.jsxs)("span",{className:"pu-info-value pu-time-stamp",children:[(0,C.jsx)(S.VP9,{className:"inline-icon"})," ",g()(e.logdate).isValid()?g()(e.logdate).format("hh:mm:ss A"):e.logdate]})]}),(0,C.jsxs)("div",{className:"pu-info-row",children:[(0,C.jsx)("span",{className:"pu-info-label",children:"Position"}),(0,C.jsxs)("span",{className:"pu-info-value pu-coordinates",children:[e.lat.toFixed(5),", ",e.lon.toFixed(5)]})]})]})]})},"live-".concat(e.id))})),Vs&&Ea&&"planned"!==Bs&&Ha.map(((e,s)=>{var a,t;if(0===e.coords.length)return null;const i=(0,w.gM)(s),r="combined"===Bs?D: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],m=ws[e.deliveryid],p=Array.isArray(m)&&m.length>=2?m:e.coords.map((e=>[e.lat,e.lng]));let h=p,v=!0;if(Cs){const s=Es[e.sequenceStep]||0;s<2?v=!1:h=p.slice(0,Math.min(s,p.length))}const j=ra===e.sequenceStep,f=String(e.orderstatus||"").toLowerCase(),N=w.Ys.has(f),b=w.yP.has(f),y=Ya.find((s=>s.sequenceStep===e.sequenceStep)),k=!(null===y||void 0===y||!y.anomaly),_=null===Ea||void 0===Ea||null===(a=Ea.orders)||void 0===a?void 0:a.find((s=>null!=s.deliveryid&&String(s.deliveryid)===String(e.deliveryid))),F=(0,w.Cx)(e.orderstatus),M=(e.orderstatus&&'<svg class="cmark-flag" viewBox="0 0 18 22" xmlns="http://www.w3.org/2000/svg">\n <line x1="1.5" y1="0" x2="1.5" y2="22" stroke="#0f172a" stroke-width="1.6" stroke-linecap="round"/>\n <polygon points="2,1 17,1 13.5,5.5 17,10 2,10" fill="'.concat(F.bg,'" stroke="#0f172a" stroke-width="0.6" stroke-linejoin="round"/>\n ').concat(N?'<polyline points="5,5.5 7,7.5 11,3.5" fill="none" stroke="#fff" stroke-width="1.4" stroke-linecap="round" stroke-linejoin="round"/>':"","\n </svg>"),["compare-step-pin"]);j&&M.push("is-focused"),N&&M.push("is-delivered"),b&&M.push("is-skipped"),k&&M.push("is-anomaly");const z='<div class="'.concat(M.join(" "),'" style="--pin-color:').concat(i,'">')+'<span class="compare-step-pin-num">'.concat(e.sequenceStep,"</span>")+(N?'<svg class="compare-step-pin-check" viewBox="0 0 12 12" xmlns="http://www.w3.org/2000/svg" aria-hidden="true"><path d="M2.5 6.5 L5 9 L9.5 3.5" stroke="white" stroke-width="2" fill="none" stroke-linecap="round" stroke-linejoin="round"/></svg>':"")+"</div>",A=x().divIcon({className:"",iconSize:[36,36],iconAnchor:[18,18],popupAnchor:[0,-22],html:z}),P=1===e.sequenceStep,E=P?x().divIcon({className:"",iconSize:[40,40],iconAnchor:[20,20],html:'<div class="compare-start-pin" style="--pin-color:'.concat(i,'">')+'<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg" aria-hidden="true"><path d="M19 6h-2c0-2.76-2.24-5-5-5S7 3.24 7 6H5c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm-7-3c1.66 0 3 1.34 3 3H9c0-1.66 1.34-3 3-3zm0 10c-2.76 0-5-2.24-5-5h2c0 1.66 1.34 3 3 3s3-1.34 3-3h2c0 2.76-2.24 5-5 5z" fill="currentColor"/></svg></div>'}):null,L="combined"===Bs?-5:0;return(0,C.jsxs)(n.Fragment,{children:[v&&(0,C.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:j?11:9,opacity:j?.75:.55,lineJoin:"round",lineCap:"round",offset:L}}),v&&(0,C.jsx)(c.R,{positions:h,pathOptions:{color:r,weight:j?6.5:5,opacity:j?1:ra?.55:.95,lineJoin:"round",lineCap:"round",offset:L}}),P&&(0,C.jsx)(l.p,{position:d,icon:E,zIndexOffset:j?900:100,eventHandlers:{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),la((s=>s===e.sequenceStep?null:e.sequenceStep))}},children:(0,C.jsx)(u.m,{direction:"top",offset:[0,-12],opacity:1,className:"compare-tooltip",children:(0,C.jsxs)("div",{className:"cmp-tip",children:[(0,C.jsxs)("div",{className:"cmp-tip-header",children:[(0,C.jsx)("span",{className:"cmp-tip-step",style:{background:i},children:(0,C.jsx)(S.zPd,{})}),(0,C.jsxs)("div",{className:"cmp-tip-title-stack",children:[(0,C.jsx)("div",{className:"cmp-tip-title",children:e.pickupcustomer||"Pickup"}),(0,C.jsx)("div",{className:"cmp-tip-sub",children:null!==(t=e.coords[0])&&void 0!==t&&t.logdate?"Picked up \xb7 ".concat(g()(e.coords[0].logdate).format("hh:mm A")):"Rider trip origin"})]})]}),(0,C.jsx)("div",{className:"cmp-tip-action",children:"Click for step 1 details"})]})})}),(0,C.jsx)(l.p,{position:o,icon:A,zIndexOffset:j?1e3:200,eventHandlers:_?{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),la((s=>s===e.sequenceStep?null:e.sequenceStep)),He.current&&(clearTimeout(He.current),He.current=null);const a=String(_.orderid);Re.current.has(a)?(Re.current.delete(a),Ve(null)):(Re.current.add(a),Ve(_))}}:{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),la((s=>s===e.sequenceStep?null:e.sequenceStep)),_&&s.target&&"function"===typeof s.target.openPopup&&s.target.openPopup()}},children:!_&&(0,C.jsx)(u.m,{direction:"top",offset:[0,-20],opacity:1,className:"compare-tooltip",children:(()=>{const s=(0,w.Cx)(e.orderstatus);return(0,C.jsxs)("div",{className:"cmp-tip",children:[(0,C.jsxs)("div",{className:"cmp-tip-header",children:[(0,C.jsx)("span",{className:"cmp-tip-step",style:{background:i},children:e.sequenceStep}),(0,C.jsxs)("div",{className:"cmp-tip-title-stack",children:[(0,C.jsx)("div",{className:"cmp-tip-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),(0,C.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,C.jsx)("span",{className:"cmp-tip-tag",style:{background:s.bg,color:s.fg},children:s.label})]}),k&&(0,C.jsx)("div",{className:"cmp-tip-anomaly",children:"Deviation flagged \u2014 see details below"}),(0,C.jsx)("div",{className:"cmp-tip-action",children:j?"Click to deselect":"Click for details"})]})})()})})]},"actual-".concat(e.deliveryid))}))]}),Vs&&Ea&&(0,C.jsxs)("div",{className:"compare-view-switcher",role:"group","aria-label":"Compare view layer",children:[(0,C.jsx)("button",{type:"button",className:"actual"===Bs?"is-active":"",onClick:()=>Us("actual"),title:"Show only the rider's actual GPS trail",children:"Actual"}),(0,C.jsx)("button",{type:"button",className:"planned"===Bs?"is-active":"",onClick:()=>Us("planned"),title:"Show only the dispatched planned route",children:"Planned"}),(0,C.jsx)("button",{type:"button",className:"combined"===Bs?"is-active":"",onClick:()=>Us("combined"),title:"Overlay planned (dashed) and actual (solid) on one map",children:"Combined"})]}),(0,C.jsx)("div",{id:"ov-tl"}),(0,C.jsxs)("div",{id:"ov-br",children:[(0,C.jsxs)("button",{className:"sbt ".concat(Cs?"active":""),onClick:()=>{if(Cs)return zs(!1),Ps([]),void Ds({});zs(!0),Ps([]),Ds({});const e=Vs&&Ea,s=e?new Map(Ha.map((e=>[String(e.deliveryid),e.sequenceStep]))):null,a=[];if(Ca.forEach((t=>{if(!we.has(t.id))return;if(Ea&&Ea.id!==t.id)return;if(ze&&!ze.riders.has(t.id))return;const i={};t.orders.forEach((e=>{const s=e.trip_number||1;i[s]||(i[s]=[]),i[s].push(e)})),Object.entries(i).forEach((i=>{let[n,r]=i;const l=ze?r.filter((e=>(e.pickupcustomer||e.kitchen_key||"Unknown").toLowerCase().trim()===ze.id)):r;if(0===l.length)return;const c=[...r].sort(((e,s)=>(e.step||0)-(s.step||0))),d=ie(c),o=ne(t.id,n,d),u=ks[o],m=[...l].sort(((e,s)=>(e.step||0)-(s.step||0))),p=ie(m),h="kitchens"===M||ze,x=u||p;if(x.length<2)return;let v=()=>t.color;if(e&&t.id===Ea.id){const e=m.filter(I).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])),a=u?se(u,e):(()=>{const s=p.length>e.length,a=[];for(let t=0;t<e.length;t++){const e=s?t:t-1,i=s?t+1:t;e<0||e>=p.length||i>=p.length?a.push([]):a.push([p[e],p[i]])}return a})(),i=[];let n=0;a.forEach(((e,s)=>{const a=Math.max(0,((null===e||void 0===e?void 0:e.length)||0)-1);for(let t=0;t<a;t++)i[n+t]=s;n+=a})),v=e=>{const a=i[e];if(null==a)return t.color;const n=m.filter(I)[a],r=n?s.get(String(n.deliveryid)):null;return r?(0,w.gM)(r-1):t.color}}for(let e=0;e<x.length-1;e++)a.push({from:x[e],to:x[e+1],color:v(e),delay:.05*(parseInt(t.id.slice(-3))||0)+40*parseInt(n)+e*(h?40:8)})}))})),a.sort(((e,s)=>e.delay-s.delay)),a.forEach(((e,s)=>{setTimeout((()=>{Ps((s=>[...s,e])),s===a.length-1&&setTimeout((()=>{zs(!1),Ds({})}),1e3)}),e.delay)})),e&&Ha.length>0){const e=[...Ha],s=e.map((e=>{const s=ws[e.deliveryid];return Array.isArray(s)&&s.length>=2?s:e.coords.map((e=>[e.lat,e.lng]))})),t=a.length>0?a[a.length-1].delay:800*e.length,i=Math.max(t,600*e.length),n=i/Math.max(1,e.length),r=Date.now(),l=()=>{if(!Ls.current)return;const a=Date.now()-r,t={};e.forEach(((e,i)=>{const r=s[i];if(!r||r.length<2)return;const l=i*n;if(a>=l+n)t[e.sequenceStep]=r.length;else if(a>=l){const s=(a-l)/n;t[e.sequenceStep]=Math.max(2,Math.ceil(s*r.length))}})),Ds(t),a<i+200&&requestAnimationFrame(l)};requestAnimationFrame(l)}},style:{boxShadow:"var(--shadow-lg)",background:Cs?"var(--accent)":"#fff"},children:[(0,C.jsx)("span",{children:Cs?"\u23f9":"\u25b6"})," ",Cs?"Stop":"Animate Routes"]}),(0,C.jsxs)("button",{type:"button",className:"sbt ".concat(Vs?"active":""),onClick:()=>{if(Vs)Ks(!1);else{if(!Ea){const e=Ca.find((e=>(e.orders||[]).some((e=>null!=e.deliveryid&&""!==e.deliveryid&&0!==e.deliveryid)))),s=Ca.find((e=>e.orders&&e.orders.length>0)),a=e||s;if(a&&(Da(a),Ke))return void(Qs.current=!0)}Ks(!0)}},title:Ea?"Compare planned vs. actual route for ".concat(Ea.riderName):"Compare planned vs. actual route (will focus the first rider)",style:{boxShadow:"var(--shadow-lg)",background:Vs?"linear-gradient(135deg, #6366f1, #3b82f6)":"#fff",marginLeft:8,color:Vs?"#fff":void 0},children:[(0,C.jsx)("span",{className:"sbt-icon",children:(0,C.jsx)(S.$G1,{})}),Vs?"Exit Compare":"Compare"]})]})]}),Vs&&Ea&&(0,C.jsx)("div",{id:"compare-map-wrap",children:(()=>{const e=Ha.length,s=Ha.filter((e=>e.coords.length>0)).length,a=Ha.filter((e=>e.isLoading)).length,t=e>0?Math.round(s/e*100):0,i=e>0&&s===e&&0===a,r=null!=ra?Ya.find((e=>e.sequenceStep===ra)):null;return(0,C.jsxs)("div",{className:"compare-header-v2",children:[(0,C.jsxs)("div",{className:"compare-header-row",children:[(0,C.jsxs)("div",{className:"compare-title",children:[(0,C.jsx)("span",{className:"compare-title-dot",style:{background:Ea.color}}),(0,C.jsx)("span",{className:"compare-title-name",children:Ea.riderName}),(0,C.jsx)("span",{className:"compare-title-badge",children:"ACTUAL vs PLANNED"})]}),(0,C.jsxs)("div",{className:"compare-header-tools",children:[null!=ra&&(0,C.jsxs)("button",{type:"button",className:"compare-overall-btn",onClick:()=>la(null),title:"Zoom out to the whole day",children:[(0,C.jsx)(S.Zs6,{})," Overall"]}),(0,C.jsx)("button",{type:"button",className:"compare-timeline-toggle".concat(Ws?" is-open":""),onClick:()=>$s((e=>!e)),title:Ws?"Hide planned/actual timeline":"Show planned/actual timeline","aria-expanded":Ws,children:(0,C.jsx)(S.j1Q,{})})]})]}),Ws&&(0,C.jsxs)(C.Fragment,{children:[(0,C.jsxs)("div",{className:"compare-timeline-wrap",children:[(0,C.jsxs)("div",{className:"compare-timeline-container",children:[(0,C.jsxs)("div",{className:"compare-timeline-labels",children:[(0,C.jsx)("div",{className:"compare-timeline-label",children:"Planned"}),(0,C.jsx)("div",{className:"compare-timeline-label",children:"Actual"})]}),(0,C.jsxs)("div",{className:"compare-timeline-scrollable",children:[(0,C.jsx)("div",{className:"compare-timeline-track is-planned",children:Ka.map(((e,s)=>{var a;const t=String(e.orderstatus||"").toLowerCase(),i=w.Ys.has(t),r=w.yP.has(t),l=ra===e.sequenceStep,c=e.isLoading&&0===e.coordsCount,d=!e.isLoading&&0===e.coordsCount,o=(null===(a=e.order)||void 0===a?void 0:a.step)||e.sequenceStep,u=(0,w.gM)(o-1),m=["compare-step",l&&"is-focused",i&&"is-delivered",r&&"is-skipped",!i&&!r&&"is-pending",c&&"is-loading",d&&"is-no-data",e.anomaly&&"is-anomaly"].filter(Boolean).join(" ");return(0,C.jsxs)(n.Fragment,{children:[s>0&&(0,C.jsx)("span",{className:"compare-step-spacer"}),(0,C.jsxs)("button",{type:"button",className:m,style:{"--step-color":u},onClick:()=>la((s=>s===e.sequenceStep?null:e.sequenceStep)),title:"Planned Step ".concat(o)+(e.deliverycustomer?" \xb7 ".concat(e.deliverycustomer):"")+(e.expectedTs?" \xb7 ".concat(e.expectedTs.format("hh:mm A")):"")+(e.anomaly?" \xb7 deviation flagged":""),children:[(0,C.jsx)("span",{className:"compare-step-circle",children:c?(0,C.jsx)("span",{className:"compare-step-spin"}):o}),e.expectedTs&&(0,C.jsx)("span",{className:"compare-step-tick",children:e.expectedTs.format("HH:mm")})]})]},"step-p-".concat(e.deliveryid))}))}),(0,C.jsx)("div",{className:"compare-timeline-track is-actual",children:Ba.map(((e,s)=>{var a;const t=String(e.orderstatus||"").toLowerCase(),i=w.Ys.has(t),r=w.yP.has(t),l=ra===e.sequenceStep,c=e.isLoading&&0===e.coordsCount,d=!e.isLoading&&0===e.coordsCount,o=(null===(a=e.order)||void 0===a?void 0:a.step)||e.sequenceStep,u=(0,w.gM)(o-1),m=["compare-step",l&&"is-focused",i&&"is-delivered",r&&"is-skipped",!i&&!r&&"is-pending",c&&"is-loading",d&&"is-no-data",e.anomaly&&"is-anomaly"].filter(Boolean).join(" ");return(0,C.jsxs)(n.Fragment,{children:[s>0&&(0,C.jsx)("span",{className:"compare-step-spacer"}),(0,C.jsxs)("button",{type:"button",className:m,style:{"--step-color":u},onClick:()=>la((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,C.jsx)("span",{className:"compare-step-circle",children:c?(0,C.jsx)("span",{className:"compare-step-spin"}):o}),e.actualTs&&(0,C.jsx)("span",{className:"compare-step-tick",children:e.actualTs.format("HH:mm")}),e.anomaly&&(0,C.jsx)("span",{className:"compare-step-flag",title:"Deviation flagged"})]})]},"step-a-".concat(e.deliveryid))}))})]})]}),(0,C.jsxs)("div",{className:"compare-progress-strip",children:[(0,C.jsx)("div",{className:"compare-progress-bar-wrap",children:(0,C.jsx)("div",{className:"compare-progress-bar-fill".concat(i?" is-done":""),style:{width:"".concat(t,"%")}})}),(0,C.jsx)("span",{className:"compare-progress-text",children:a>0?"Loading GPS\u2026 ".concat(s,"/").concat(e):"".concat(s,"/").concat(e," tracks")})]})]}),(()=>{const e="combined"===Bs,s=r?(0,w.gM)(r.sequenceStep-1):"linear-gradient(90deg, ".concat(w.Z3.slice(0,6).join(", "),")"),a=e?E:s,t=e?D:s;return(0,C.jsxs)("div",{className:"compare-legend",children:[(0,C.jsxs)("span",{className:"compare-legend-item",children:[(0,C.jsx)("span",{className:"compare-legend-swatch is-step-color is-dashed",style:{background:a}}),"Planned (dashed)"]}),(0,C.jsxs)("span",{className:"compare-legend-item",children:[(0,C.jsx)("span",{className:"compare-legend-swatch is-step-color",style:{background:t}}),"Actual GPS (solid)"]}),(0,C.jsx)("span",{className:"compare-legend-note",children:"Kalman-smoothed GPS \xb7 OSRM road-snapped"})]})})()]})]})})()}),Vs&&Ea&&(0,C.jsx)(z,{focusedRider:Ea,compareDeltas:Ya,compareSummary:Va,actualOrdered:Ba,focusedCompareStep:ra,setFocusedCompareStep:la,sequenceOpen:Gs,setSequenceOpen:Js,expandedSeqGroups:Zs,setExpandedSeqGroups:Xs,onClose:()=>Ks(!1)})]}),Ye&&(0,C.jsx)("div",{className:"dispatch-popup-center",role:"dialog","aria-label":"Order ".concat(Ye.orderid," details"),onMouseEnter:()=>{He.current&&(clearTimeout(He.current),He.current=null)},onMouseLeave:()=>{(e=>{if(!e)return!1;if(Re.current.has(String(e.orderid)))return!0;if(Vs&&Ea&&null!=e.deliveryid){const s=Ha.find((s=>String(s.deliveryid)===String(e.deliveryid)));if(s&&ra===s.sequenceStep)return!0}return!1})(Ye)||(He.current&&clearTimeout(He.current),He.current=setTimeout((()=>{Ve(null),He.current=null}),200))},children:(0,C.jsxs)("div",{className:"dispatch-popup-card dispatch-popup",children:[(0,C.jsx)("button",{type:"button",className:"dispatch-popup-center-close","aria-label":"Close order details",onClick:()=>{Re.current.delete(String(Ye.orderid)),Ve(null)},children:"\xd7"}),(e=>{const s=(0,w.Cx)(e.orderstatus),a=e.rider_id||e.userid,t=w.Ys.has(String(e.orderstatus||"").toLowerCase()),i=t?null:Xa(a,e);return(0,C.jsxs)("div",{style:{height:"100%",width:"100%"},children:[(0,C.jsxs)("div",{className:"pu-header",children:[(0,C.jsxs)("div",{className:"pu-header-top",children:[(0,C.jsxs)("div",{className:"pu-id",children:["ORDER #",e.orderid]}),e.orderstatus&&(0,C.jsx)("span",{className:"pu-status-chip",style:{background:s.bg,color:s.fg},children:s.label})]}),(0,C.jsxs)("div",{className:"pu-rider",children:[(0,C.jsx)(S.aVM,{})," ",(0,C.jsx)("span",{children:e.rider_name||e.ridername||"Unassigned"})]}),(e.deliverycustomer||e.customername)&&(0,C.jsxs)("div",{className:"pu-customer",title:e.deliverycustomer||e.customername,children:[(0,C.jsx)(S.u9F,{}),(0,C.jsx)("span",{children:e.deliverycustomer||e.customername})]}),null!=e.deliveryid&&(0,C.jsxs)("div",{className:"pu-delivery-id",children:["Delivery #",e.deliveryid]})]}),(0,C.jsxs)("div",{className:"pu-body",children:[te.some((s=>e[s.key]))&&(0,C.jsxs)("div",{className:"pu-section",children:[(0,C.jsx)("div",{className:"pu-section-label",children:"Timeline"}),(0,C.jsx)("div",{className:"pu-timeline",children:te.map((s=>{const a=ae(e[s.key]);return a?(0,C.jsxs)("div",{className:"pu-tl-row ".concat(s.final?"delivered":""),children:[(0,C.jsx)("span",{className:"pu-tl-dot"}),(0,C.jsx)("span",{className:"pu-tl-label",children:s.label}),(0,C.jsx)("span",{className:"pu-tl-time",children:a})]},s.key):null}))})]}),(0,C.jsxs)("div",{className:"pu-section",children:[(0,C.jsx)("div",{className:"pu-section-label",children:"Details"}),(0,C.jsxs)("div",{className:"pu-details-grid",children:[(e.pickupcustomer||e.locationname||e.pickuplocation)&&(0,C.jsxs)("div",{className:"pu-detail",children:[(0,C.jsx)("div",{className:"pu-detail-icon",children:(0,C.jsx)(S.NtI,{})}),(0,C.jsxs)("div",{className:"pu-detail-body",children:[(0,C.jsx)("div",{className:"pu-detail-label",children:"Pickup"}),(0,C.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,C.jsxs)("div",{className:"pu-detail",children:[(0,C.jsx)("div",{className:"pu-detail-icon",children:(0,C.jsx)(S.JFD,{})}),(0,C.jsxs)("div",{className:"pu-detail-body",children:[(0,C.jsx)("div",{className:"pu-detail-label",children:"Drop"}),(0,C.jsx)("div",{className:"pu-detail-value",title:e.deliveryaddress||e.deliverysuburb,children:e.deliverysuburb||q(e.deliveryaddress)})]})]}),e.zone_name&&(0,C.jsxs)("div",{className:"pu-detail",children:[(0,C.jsx)("div",{className:"pu-detail-icon",children:(0,C.jsx)(S.Cd7,{})}),(0,C.jsxs)("div",{className:"pu-detail-body",children:[(0,C.jsx)("div",{className:"pu-detail-label",children:"Zone"}),(0,C.jsx)("div",{className:"pu-detail-value",title:e.zone_name,children:e.zone_name})]})]}),(e.rider_id||e.userid)&&(0,C.jsxs)("div",{className:"pu-detail",children:[(0,C.jsx)("div",{className:"pu-detail-icon",children:(0,C.jsx)(S.aVM,{})}),(0,C.jsxs)("div",{className:"pu-detail-body",children:[(0,C.jsx)("div",{className:"pu-detail-label",children:"Rider ID"}),(0,C.jsxs)("div",{className:"pu-detail-value",children:["#",e.rider_id||e.userid]})]})]})]}),(null!=e.kms||null!=e.actualkms||!t&&null!=e.riderkms||null!==i)&&(0,C.jsxs)("div",{className:"pu-distance-row",children:[null!=e.kms&&""!==e.kms&&(0,C.jsxs)("div",{className:"pu-distance-chip",children:[(0,C.jsx)("span",{className:"pu-distance-icon",children:(0,C.jsx)(S.xI$,{})}),(0,C.jsx)("span",{className:"pu-distance-label",children:"Planned"}),(0,C.jsxs)("span",{className:"pu-distance-value",children:[e.kms," km"]})]}),null!=e.actualkms&&""!==e.actualkms&&(0,C.jsxs)("div",{className:"pu-distance-chip",children:[(0,C.jsx)("span",{className:"pu-distance-icon",children:(0,C.jsx)(S.xI$,{})}),(0,C.jsx)("span",{className:"pu-distance-label",children:"Actual"}),(0,C.jsxs)("span",{className:"pu-distance-value",children:[e.actualkms," km"]})]}),!t&&null!=e.riderkms&&""!==e.riderkms&&(0,C.jsxs)("div",{className:"pu-distance-chip",children:[(0,C.jsx)("span",{className:"pu-distance-icon",children:(0,C.jsx)(S.bsz,{})}),(0,C.jsx)("span",{className:"pu-distance-label",children:"Rider"}),(0,C.jsxs)("span",{className:"pu-distance-value",children:[parseFloat(e.riderkms).toFixed(2)," km"]})]}),null!==i&&(0,C.jsxs)("div",{className:"pu-distance-chip pu-est-meters",title:"Estimated distance to drop location",children:[(0,C.jsx)("span",{className:"pu-distance-icon",children:(0,C.jsx)(S.HPi,{})}),(0,C.jsx)("span",{className:"pu-distance-label",children:"Est. to Drop"}),(0,C.jsx)("span",{className:"pu-distance-value",children:Qa(i)})]})]})]})]})]})})(Ye)]})})]}),!a&&"analysis"===W&&(0,C.jsxs)("div",{id:"dispatch-analysis",children:[(0,C.jsx)("div",{className:"da-picker-row",children:oe.map((e=>{var s;const a=he[e.key],t=ve===e.key,i=!1===(null===a||void 0===a||null===(s=a.data)||void 0===s?void 0:s.success),n=i?"#fee2e2":a?"".concat(e.color,"22"):"#f1f5f9",r=i?"#dc2626":a?e.color:"#64748b",l=t?"Loading\u2026":i?"! Failed":a?"\u2713 ".concat(a.fetchedAt):"Fetch",c=ge===e.key;return(0,C.jsxs)("button",{type:"button",className:"da-picker ".concat(a?"has-data":""," ").concat(t?"is-loading":""," ").concat(c?"is-active":""),onClick:()=>!t&&ke(e.key),style:{borderColor:c?e.color:i?"#fecaca":a?e.border:"#e2e8f0",background:i?"#fef2f2":a?e.bg:"#ffffff",boxShadow:c?"0 0 0 2px ".concat(e.color,"33"):void 0},disabled:t,children:[(0,C.jsxs)("div",{className:"da-picker-head",children:[(0,C.jsx)("div",{className:"da-picker-badge",style:{background:"".concat(e.color,"22"),color:e.color},children:e.label[0]}),(0,C.jsxs)("div",{className:"da-picker-meta",children:[(0,C.jsx)("div",{className:"da-picker-name",children:e.label}),(0,C.jsx)("div",{className:"da-picker-range",children:e.timeRange})]}),(0,C.jsx)("span",{className:"da-picker-status",style:{background:n,color:r},children:l})]}),(0,C.jsx)("div",{className:"da-picker-sub",children:e.sub})]},e.key)}))}),((e,s,a)=>{if(!ge)return(0,C.jsx)("div",{className:"da-empty",children:"Pick a batch above to view its efficiency analysis."});const t=oe.find((e=>e.key===ge)),n=he[ge],r=ve===ge;if(r&&!n)return(0,C.jsxs)("div",{className:"da-empty",children:["Loading ",t.label," batch\u2026"]});if(!n)return null;const l=n.data||{};var c,d;if(!1===l.success)return(0,C.jsxs)("div",{className:"da-result-card da-result-card-error",style:{borderColor:"#fecaca",borderTopColor:"#ef4444"},children:[(0,C.jsxs)("div",{className:"da-result-head",children:[(0,C.jsxs)("div",{children:[(0,C.jsxs)("div",{className:"da-result-title",children:[t.label," Batch"]}),(0,C.jsxs)("div",{className:"da-result-sub",children:[t.timeRange," \xb7 Fetched at ",n.fetchedAt]})]}),(0,C.jsx)("button",{type:"button",className:"da-result-refresh",title:"Retry",onClick:()=>ke(ge),disabled:r,style:{background:"#fee2e2",color:"#dc2626"},children:(0,C.jsx)(S.joZ,{})})]}),(0,C.jsxs)("div",{className:"da-error",children:[(0,C.jsxs)("div",{className:"da-error-title",children:[(0,C.jsx)(S.ItP,{}),(0,C.jsx)("span",{children:(null===l||void 0===l||null===(c=l.error)||void 0===c?void 0:c.code)||"Request failed"})]}),(0,C.jsx)("div",{className:"da-error-msg",children:(null===l||void 0===l||null===(d=l.error)||void 0===d?void 0:d.message)||"The server returned an error."}),(null===l||void 0===l?void 0:l.request_id)&&(0,C.jsxs)("div",{className:"da-error-meta",children:["request_id: ",l.request_id]})]})]});const o=l.fleet_summary||{},u=Array.isArray(l.rider_timelines)?l.rider_timelines:[],m=Array.isArray(l.substitution_opportunities)?l.substitution_opportunities:[],p=l.top_recommendation,h=!(!p||!p.idle_rider_name&&!p.idle_rider_id),x=!!(p&&p.action&&"none"!==p.action&&h),v=l.window||{},j=(e,s)=>{const a=String(null!==e&&void 0!==e?e:"").trim();if(!a)return s||"\u2014";const t="string"===typeof s&&/^Rider\s+\d+$/i.test(s.trim()),i=Array.isArray(Ca)?Ca.find((e=>String(e.id)===a)):null;if(i&&i.riderName)return i.riderName;const n=Array.isArray(Sa)?Sa.find((e=>String(e.id)===a)):null;return n&&n.riderName?n.riderName:!t&&s?s:"Rider ".concat(a)},g=me(o.fleet_start),f=me(o.fleet_done),N=null!=g&&null!=f&&f>g?f-g:null,b=parseFloat(o.avg_utilisation_pct),y=Number.isFinite(b)?b:null,k=null==y?"unknown":y>=85?"good":y>=70?"ok":"low",_="good"===k?"#10b981":"ok"===k?"#f59e0b":"low"===k?"#ef4444":"#94a3b8",w=(e=>{let{assessment:s,spreadMin:a,stdev:t}=e;const i=String(s||"").toLowerCase();return/high imbalance|severe|critical/.test(i)||/imbalance|recommend/.test(i)||null!=a&&a>30||null!=t&&t>1?"warn":/balanced|excellent|good/.test(i)?"success":"info"})({assessment:null===p||void 0===p?void 0:p.fleet_balance_assessment,spreadMin:parseFloat(o.finish_time_spread_minutes),stdev:parseFloat(o.load_balance_stdev)}),F=u.map((e=>{const s=me(e.started_at),a=me(e.finished_at);let t=0,n=100;null!=g&&N&&(null!=s&&(t=Math.max(0,Math.min(100,(s-g)/N*100))),null!=a&&(n=Math.max(0,Math.min(100,(a-g)/N*100))));const r=Math.max(0,n-t),l=parseFloat(e.active_minutes),c=parseFloat(e.idle_minutes),d=(Number.isFinite(l)?l:0)+(Number.isFinite(c)?c:0),o=d>0?l/d*100:y,u=null==o?"unknown":o>=85?"good":o>=70?"ok":"low",m="good"===u?"#10b981":"ok"===u?"#f59e0b":"low"===u?"#ef4444":"#94a3b8",p=j(e.userid,e.name);return(0,i.A)((0,i.A)({},e),{},{displayName:p,_startPct:t,_endPct:n,_activePct:r,_riderUtilPct:o,_riderColor:m})}));return F.sort(((e,s)=>(me(s.finished_at)||0)-(me(e.finished_at)||0))),(0,C.jsxs)("div",{className:"da-detail",children:[(0,C.jsxs)("div",{className:"da-detail-head",style:{borderTopColor:t.color,background:t.bg},children:[(0,C.jsxs)("div",{children:[(0,C.jsxs)("div",{className:"da-detail-title",children:[t.label," Batch",(0,C.jsxs)("span",{className:"da-detail-sub-inline",children:[l.date?" \xb7 ".concat(l.date):"",v.from&&v.to?" \xb7 ".concat(v.from," \u2013 ").concat(v.to):""]})]}),(0,C.jsxs)("div",{className:"da-detail-sub",children:["Fetched at ",n.fetchedAt," \xb7 Input deliveries: ",null!==(e=l.input_delivery_count)&&void 0!==e?e:"\u2014"]})]}),(0,C.jsxs)("div",{className:"da-detail-actions",children:[(0,C.jsxs)("span",{className:"da-live-tag ".concat(r?"is-active":""),title:"Auto-refreshing every ".concat(Math.round(15),"s"),children:[(0,C.jsx)("span",{className:"da-live-dot"}),"Live \xb7 ",Math.round(15),"s"]}),(0,C.jsx)("button",{type:"button",className:"da-result-refresh",title:"Refresh now",onClick:()=>{xe((e=>{const s=(0,i.A)({},e);return delete s[ge],s})),ye.mutate({batch:ge,tenantId:916})},disabled:r,style:{background:"".concat(t.color,"22"),color:t.color},children:(0,C.jsx)(S.joZ,{})})]})]}),(0,C.jsx)("div",{className:"da-section",children:(0,C.jsxs)("div",{className:"da-hero-row",children:[(0,C.jsxs)("div",{className:"da-hero-card",style:{borderTopColor:t.color},children:[(0,C.jsx)("div",{className:"da-hero-icon",style:{background:"".concat(t.color,"22"),color:t.color},children:(0,C.jsx)(S.gsJ,{})}),(0,C.jsx)("div",{className:"da-hero-value",children:ue(o.total_orders)}),(0,C.jsx)("div",{className:"da-hero-label",children:"Total Orders"}),null!=l.input_delivery_count&&l.input_delivery_count!==o.total_orders&&(0,C.jsxs)("div",{className:"da-hero-sub",children:[l.input_delivery_count," input"]})]}),(0,C.jsxs)("div",{className:"da-hero-card",style:{borderTopColor:"#0ea5e9"},children:[(0,C.jsx)("div",{className:"da-hero-icon",style:{background:"#0ea5e922",color:"#0ea5e9"},children:(0,C.jsx)(S.aVM,{})}),(0,C.jsx)("div",{className:"da-hero-value",children:ue(o.total_riders)}),(0,C.jsx)("div",{className:"da-hero-label",children:"Active Riders"}),null!=o.orders_per_rider_avg&&(0,C.jsxs)("div",{className:"da-hero-sub",children:[o.orders_per_rider_avg," avg orders / rider"]})]}),(0,C.jsxs)("div",{className:"da-hero-card",style:{borderTopColor:"#8b5cf6"},children:[(0,C.jsx)("div",{className:"da-hero-icon",style:{background:"#8b5cf622",color:"#8b5cf6"},children:(0,C.jsx)(S.VP9,{})}),(0,C.jsxs)("div",{className:"da-hero-value",children:[null!=o.total_duration_minutes?"".concat(o.total_duration_minutes):"\u2014",null!=o.total_duration_minutes&&(0,C.jsx)("span",{className:"da-hero-unit",children:" min"})]}),(0,C.jsx)("div",{className:"da-hero-label",children:"Fleet Window"}),o.fleet_start&&o.fleet_done&&(0,C.jsxs)("div",{className:"da-hero-sub",children:[o.fleet_start," \u2192 ",o.fleet_done]})]})]})}),(0,C.jsxs)("div",{className:"da-section",children:[(0,C.jsx)("div",{className:"da-section-label",children:"Fleet Health"}),(0,C.jsxs)("div",{className:"da-health-row",children:[(0,C.jsxs)("div",{className:"da-health-card",children:[(0,C.jsx)("div",{className:"da-ring",style:{"--ring-color":_,"--ring-pct":null!=y?Math.max(0,Math.min(100,y)):0},children:(0,C.jsxs)("span",{className:"da-ring-num",children:[null!=y?"".concat(y.toFixed(0)):"\u2014",null!=y&&(0,C.jsx)("span",{className:"da-ring-unit",children:"%"})]})}),(0,C.jsxs)("div",{className:"da-health-meta",children:[(0,C.jsx)("div",{className:"da-health-label",children:"Avg Utilisation"}),(0,C.jsx)("div",{className:"da-health-sub",style:{color:_},children:"good"===k?"Strong":"ok"===k?"Moderate":"low"===k?"Low":"\u2014"})]})]}),(0,C.jsxs)("div",{className:"da-health-card da-health-card-stat",children:[(0,C.jsx)("div",{className:"da-health-value",children:null!=o.load_balance_stdev?parseFloat(o.load_balance_stdev).toFixed(2):"\u2014"}),(0,C.jsx)("div",{className:"da-health-label",children:"Load Balance \u03c3"}),(0,C.jsx)("div",{className:"da-health-sub",children:null!=o.load_balance_stdev?parseFloat(o.load_balance_stdev)>1?"Uneven workload":"Workload balanced":"Stdev of orders / rider"})]}),(0,C.jsxs)("div",{className:"da-health-card da-health-card-stat",children:[(0,C.jsxs)("div",{className:"da-health-value",children:[null!=o.finish_time_spread_minutes?"".concat(o.finish_time_spread_minutes):"\u2014",null!=o.finish_time_spread_minutes&&(0,C.jsx)("span",{className:"da-health-unit",children:" min"})]}),(0,C.jsx)("div",{className:"da-health-label",children:"Finish Spread"}),(0,C.jsx)("div",{className:"da-health-sub",children:null!=o.finish_time_stdev_minutes?"\u03c3 ".concat(parseFloat(o.finish_time_stdev_minutes).toFixed(1)," min"):"First \u2192 last finish"})]}),(0,C.jsxs)("div",{className:"da-health-card da-health-card-stat",children:[(0,C.jsxs)("div",{className:"da-health-value",children:[null!=o.avg_active_minutes?"".concat(parseFloat(o.avg_active_minutes).toFixed(0)):"\u2014",null!=o.avg_active_minutes&&(0,C.jsx)("span",{className:"da-health-unit",children:" min"})]}),(0,C.jsx)("div",{className:"da-health-label",children:"Avg Active"}),(0,C.jsx)("div",{className:"da-health-sub",children:"Per rider, this batch"})]})]})]}),(0,C.jsxs)("div",{className:"da-section",children:[(0,C.jsx)("div",{className:"da-section-label",children:"Top Recommendation"}),x?(0,C.jsxs)("div",{className:"da-rec-banner is-action",children:[(0,C.jsx)("div",{className:"da-rec-banner-icon",children:(0,C.jsx)(S.DX0,{})}),(0,C.jsxs)("div",{className:"da-rec-banner-body",children:[(0,C.jsxs)("div",{className:"da-rec-head",children:[(0,C.jsx)("div",{className:"da-rec-action",children:(0,C.jsx)("span",{children:(p.action||"recommendation").replaceAll("_"," ")})}),null!=p.fleet_improvement_minutes&&(0,C.jsxs)("span",{className:"da-rec-improve",style:p.fleet_improvement_minutes>0?{background:"#dcfce7",color:"#166534"}:{background:"#f1f5f9",color:"#475569"},children:[p.fleet_improvement_minutes>0?"\u2191":"\u2022"," Fleet improves by ",p.fleet_improvement_minutes," min"]})]}),(0,C.jsxs)("div",{className:"da-rec-line",children:[(0,C.jsx)("strong",{children:j(p.idle_rider_id,p.idle_rider_name)}),p.primary_kitchen&&(0,C.jsxs)(C.Fragment,{children:[" \xb7 primary kitchen ",(0,C.jsx)("strong",{children:p.primary_kitchen})]}),p.second_kitchen&&(0,C.jsxs)(C.Fragment,{children:[" \u2192 also serve ",(0,C.jsx)("strong",{children:p.second_kitchen})," after ",p.second_kitchen_dispatch_after||"\u2014"]})]}),p.description&&(0,C.jsx)("div",{className:"da-rec-desc",children:p.description}),(null===p||void 0===p?void 0:p.fleet_balance_assessment)&&(0,C.jsx)("div",{className:"da-rec-assess",children:p.fleet_balance_assessment}),(null===(s=p.activate_when)||void 0===s||null===(a=s.rules)||void 0===a?void 0:a.length)>0&&(0,C.jsxs)("div",{className:"da-rec-rules",children:[(0,C.jsxs)("div",{className:"da-rec-rules-head",children:["Activate when (",p.activate_when.condition||"AND","):"]}),p.activate_when.rules.map(((e,s)=>(0,C.jsxs)("div",{className:"da-rec-rule",children:[(0,C.jsxs)("code",{children:[e.field," ",e.operator," ",e.value]}),e.reason&&(0,C.jsxs)("span",{className:"da-rec-rule-why",children:[" \u2014 ",e.reason]})]},s)))]})]})]}):(0,C.jsxs)("div",{className:"da-rec-banner is-".concat(w),children:[(0,C.jsx)("div",{className:"da-rec-banner-icon",children:"warn"===w?(0,C.jsx)(S.Wux,{}):"success"===w?(0,C.jsx)(S.mU9,{}):(0,C.jsx)(S.DX0,{})}),(0,C.jsxs)("div",{className:"da-rec-banner-body",children:[(0,C.jsx)("div",{className:"da-rec-action",children:(0,C.jsx)("span",{children:"warn"===w?"Fleet imbalance detected \u2014 no feasible substitution":"success"===w?"Fleet ran balanced \u2014 no reassignment needed":"No action recommended"})}),(null===p||void 0===p?void 0:p.reason)&&(0,C.jsx)("div",{className:"da-rec-desc",children:p.reason}),(null===p||void 0===p?void 0:p.fleet_balance_assessment)&&(0,C.jsx)("div",{className:"da-rec-assess",children:p.fleet_balance_assessment})]})]})]}),F.length>0&&(0,C.jsxs)("div",{className:"da-section",children:[(0,C.jsxs)("div",{className:"da-section-label",children:["Rider Timelines ",(0,C.jsxs)("span",{className:"da-section-count",children:["(",F.length,")"]}),(0,C.jsx)("span",{className:"da-section-hint",children:"Sorted by latest finish \u2014 bottleneck riders first"})]}),(0,C.jsxs)("div",{className:"da-gantt-axis",children:[(0,C.jsx)("span",{children:o.fleet_start||"\u2014"}),(0,C.jsx)("span",{className:"da-gantt-axis-mid",children:null!=o.total_duration_minutes?"".concat(o.total_duration_minutes," min batch"):"Batch window"}),(0,C.jsx)("span",{children:o.fleet_done||"\u2014"})]}),(0,C.jsx)("div",{className:"da-timeline-list",children:F.map((e=>{var s,a,t;const i="active"===String(e.status||"").toLowerCase(),n=null!==(s=e.completed_orders)&&void 0!==s?s:e.order_count,r=null!==(a=e.pending_orders)&&void 0!==a?a:0,l=null!=n&&e.order_count>0?Math.max(0,Math.min(100,n/e.order_count*100)):0,c=null!=e.idle_minutes&&e.idle_minutes>30,d=null!=e.kitchen_confidence&&e.kitchen_confidence<.7;return(0,C.jsxs)("div",{className:"da-timeline-card",children:[(0,C.jsxs)("div",{className:"da-timeline-top",children:[(0,C.jsxs)("div",{className:"da-timeline-name",children:[(0,C.jsx)(S.aVM,{style:{color:e._riderColor}}),(0,C.jsx)("span",{title:e.name&&e.name!==e.displayName?"API name: ".concat(e.name):void 0,children:e.displayName}),(0,C.jsxs)("span",{className:"da-timeline-id",children:["#",e.userid]})]}),(0,C.jsx)("span",{className:"da-pill ".concat(i?"is-active":"is-idle"),children:e.status})]}),(0,C.jsxs)("div",{className:"da-gantt-row",children:[(0,C.jsxs)("div",{className:"da-gantt-track",title:"".concat(e.started_at," \u2192 ").concat(e.finished_at),children:[(0,C.jsxs)("div",{className:"da-gantt-fill",style:{left:"".concat(e._startPct,"%"),width:"".concat(Math.max(2,e._activePct),"%"),background:e._riderColor},children:[(0,C.jsx)("span",{className:"da-gantt-fill-start",children:e.started_at}),(0,C.jsx)("span",{className:"da-gantt-fill-end",children:e.finished_at})]}),e._endPct<99&&(0,C.jsx)("div",{className:"da-gantt-idle",style:{left:"".concat(e._endPct,"%"),width:"".concat(100-e._endPct,"%")},title:"Idle ".concat(e.idle_minutes," min after finishing")})]}),(0,C.jsx)("span",{className:"da-gantt-util",style:{background:"".concat(e._riderColor,"22"),color:e._riderColor},title:"Per-rider utilisation: ".concat(null!=e._riderUtilPct?e._riderUtilPct.toFixed(0):"\u2014","%"),children:null!=e._riderUtilPct?"".concat(e._riderUtilPct.toFixed(0),"%"):"\u2014"})]}),(0,C.jsxs)("div",{className:"da-timeline-mid",children:[e.kitchen?(0,C.jsxs)("span",{className:"da-chip",title:null!=e.kitchen_confidence?"Kitchen confidence: ".concat((100*e.kitchen_confidence).toFixed(0),"%"):void 0,children:[(0,C.jsx)(S.NtI,{})," ",e.kitchen,null!=e.kitchen_confidence&&(0,C.jsx)("span",{className:"da-conf-dot ".concat(d?"is-low":"is-ok"),"aria-label":"Confidence ".concat((100*e.kitchen_confidence).toFixed(0),"%")})]}):(0,C.jsxs)("span",{className:"da-chip",style:{background:"#f8fafc",color:"#64748b",borderColor:"#e2e8f0",borderStyle:"dashed"},title:"Solver did not identify a primary kitchen for this rider",children:[(0,C.jsx)(S.NtI,{})," Unassigned"]}),(0,C.jsxs)("span",{className:"da-chip da-chip-orders",title:"Completed ".concat(n," of ").concat(e.order_count),children:[(0,C.jsx)(S.gsJ,{}),(0,C.jsxs)("span",{className:"da-orders-label",children:[n,"/",e.order_count]}),(0,C.jsx)("span",{className:"da-orders-bar",children:(0,C.jsx)("span",{className:"da-orders-bar-fill",style:{width:"".concat(l,"%")}})}),r>0&&(0,C.jsxs)("span",{className:"da-orders-pending",children:[r," pending"]})]}),null!=e.pace_orders_per_hour&&(0,C.jsxs)("span",{className:"da-chip",title:"Delivery pace this batch",children:[(0,C.jsx)(S.BJM,{})," ",parseFloat(e.pace_orders_per_hour).toFixed(1)," / hr"]}),null!=e.active_minutes&&(0,C.jsxs)("span",{className:"da-chip",title:"Time actively delivering",children:[(0,C.jsx)(S.pWE,{})," ",parseFloat(e.active_minutes).toFixed(0)," min active"]}),(0,C.jsxs)("span",{className:"da-chip",style:c?{background:"#fef3c7",color:"#92400e",borderColor:"#fde68a"}:void 0,title:"Idle time after this rider finished \u2014 fleet kept running",children:[(0,C.jsx)(S.VP9,{})," ",null!==(t=e.idle_minutes)&&void 0!==t?t:0," min idle"]}),null!=e.free_window_minutes&&(0,C.jsxs)("span",{className:"da-chip",style:e.free_window_minutes>=30?{background:"#ecfdf5",color:"#065f46",borderColor:"#a7f3d0"}:e.free_window_minutes>0?{background:"#fefce8",color:"#854d0e",borderColor:"#fde68a"}:{background:"#fef2f2",color:"#991b1b",borderColor:"#fecaca"},title:"Free window before the next batch \u2014 capacity available for a follow-up run",children:[(0,C.jsx)(S.pWE,{})," ",parseFloat(e.free_window_minutes).toFixed(0)," min free"]})]})]},e.userid)}))})]}),m.length>0&&(0,C.jsxs)("div",{className:"da-section",children:[(0,C.jsxs)("div",{className:"da-section-label",children:["Substitution Opportunities ",(0,C.jsxs)("span",{className:"da-section-count",children:["(",m.length,")"]})]}),(0,C.jsx)("div",{className:"da-sub-list",children:m.map(((e,s)=>{var a;const t=e.idle_rider||{},i=e.most_relieved_rider||{},n=null!==(a=e.fleet_improvement_minutes)&&void 0!==a?a:0;return(0,C.jsxs)("div",{className:"da-sub-card",children:[(0,C.jsxs)("div",{className:"da-sub-head",children:[(0,C.jsxs)("div",{className:"da-sub-title",children:[(0,C.jsx)("strong",{children:j(t.userid,t.name)})," ","covers ",(0,C.jsx)("strong",{children:e.target_kitchen})]}),(0,C.jsxs)("span",{className:"da-sub-improve",style:n>0?{background:"#dcfce7",color:"#166534"}:{background:"#f1f5f9",color:"#475569"},children:["Fleet ",n>0?"\u2191":"\u2022"," ",n," min"]})]}),(0,C.jsxs)("div",{className:"da-sub-meta",children:[(0,C.jsxs)("span",{className:"da-chip",children:[(0,C.jsx)(S.xI$,{})," ",e.travel_to_kitchen_km," km"]}),(0,C.jsxs)("span",{className:"da-chip",children:[(0,C.jsx)(S.pWE,{})," ",e.travel_to_kitchen_minutes," min travel"]}),(0,C.jsxs)("span",{className:"da-chip",children:[(0,C.jsx)(S.VP9,{})," arrives ",e.arrive_at_kitchen]}),(0,C.jsxs)("span",{className:"da-chip",children:[(0,C.jsx)(S.gsJ,{})," ",e.total_orders_transferred," orders"]}),(0,C.jsxs)("span",{className:"da-chip",children:[(0,C.jsx)(S.xI$,{})," +",e.extra_km_for_idle_rider," km for idle rider"]})]}),(i.name||null!=i.userid)&&(0,C.jsxs)("div",{className:"da-sub-relieved",children:[(0,C.jsx)(S.imn,{}),"Most relieved: ",(0,C.jsx)("strong",{children:j(i.userid,i.name)})," ","(",i.original_finish," \u2192 ",i.new_finish,", saves"," ",i.time_saved_minutes," min)"]}),Array.isArray(e.orders_to_transfer)&&e.orders_to_transfer.length>0&&(0,C.jsxs)("div",{className:"da-sub-transfers",children:[(0,C.jsx)("div",{className:"da-sub-transfers-head",children:"Orders transferred"}),e.orders_to_transfer.map((e=>{var s;const a=null!==(s=e.improvement_minutes)&&void 0!==s?s:0;return(0,C.jsxs)("div",{className:"da-transfer-row",children:[(0,C.jsxs)("span",{className:"da-transfer-id",children:["#",e.deliveryid]}),(0,C.jsxs)("span",{className:"da-transfer-from",children:["from ",j(e.from_rider_id||e.from_userid,e.from_rider_name)]}),(0,C.jsxs)("span",{className:"da-transfer-time",children:[e.original_delivery_time," \u2192 ",e.estimated_delivery_time]}),(0,C.jsxs)("span",{className:"da-transfer-imp",style:a>0?{background:"#dcfce7",color:"#166534"}:a<0?{background:"#fee2e2",color:"#991b1b"}:{background:"#f1f5f9",color:"#475569"},children:[a>0?"+":"",a," min"]})]},e.deliveryid)}))]})]},s)}))})]})]})})()]}),Ne&&(0,C.jsx)("div",{className:"da-pos-modal-backdrop",role:"dialog","aria-modal":"true","aria-label":"Last known position of ".concat(Ne.name),onClick:e=>{e.target===e.currentTarget&&be(null)},children:(0,C.jsxs)("div",{className:"da-pos-modal-card",children:[(0,C.jsxs)("div",{className:"da-pos-modal-head",children:[(0,C.jsxs)("div",{className:"da-pos-modal-title-wrap",children:[(0,C.jsx)("div",{className:"da-pos-modal-avatar",style:{background:"".concat(Ne.color||"#662582","22"),color:Ne.color||"#662582"},children:(0,C.jsx)(S.aVM,{})}),(0,C.jsxs)("div",{children:[(0,C.jsx)("div",{className:"da-pos-modal-title",children:Ne.name}),(0,C.jsxs)("div",{className:"da-pos-modal-sub",children:["#",Ne.userid,Ne.kitchen&&(0,C.jsxs)(C.Fragment,{children:[" \xb7 ",Ne.kitchen]}),Ne.finished_at&&(0,C.jsxs)(C.Fragment,{children:[" \xb7 finished ",Ne.finished_at]})]})]})]}),(0,C.jsxs)("div",{className:"da-pos-modal-actions",children:[(0,C.jsx)("span",{className:"da-pill ".concat("active"===String(Ne.status||"").toLowerCase()?"is-active":"is-idle"),children:Ne.status||"\u2014"}),(0,C.jsx)("button",{type:"button",className:"da-pos-modal-close","aria-label":"Close",onClick:()=>be(null),children:(0,C.jsx)(S.m6K,{})})]})]}),(0,C.jsx)("div",{className:"da-pos-modal-map",children:(0,C.jsxs)(d.W,{center:[Ne.lat,Ne.lon],zoom:13,scrollWheelZoom:!0,style:{width:"100%",height:"100%"},whenReady:e=>{const s=e.target;requestAnimationFrame((()=>s.invalidateSize())),setTimeout((()=>s.invalidateSize()),260)},children:[(0,C.jsx)(o.e,{attribution:'\xa9 <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a>',url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"}),(0,C.jsx)(l.p,{position:[Ne.lat,Ne.lon],children:(0,C.jsxs)(m.z,{children:[(0,C.jsx)("strong",{children:Ne.name}),(0,C.jsx)("br",{}),Ne.lat.toFixed(6),", ",Ne.lon.toFixed(6)]})})]},"".concat(Ne.userid,"-").concat(Ne.lat,"-").concat(Ne.lon))}),(0,C.jsxs)("div",{className:"da-pos-modal-foot",children:[(0,C.jsxs)("div",{className:"da-pos-modal-coord",children:[(0,C.jsx)(S.gwi,{}),(0,C.jsxs)("span",{children:[(0,C.jsx)("strong",{children:"Lat:"})," ",Ne.lat.toFixed(6),(0,C.jsx)("span",{className:"da-pos-modal-sep",children:"\xb7"}),(0,C.jsx)("strong",{children:"Lon:"})," ",Ne.lon.toFixed(6)]})]}),(0,C.jsx)("button",{type:"button",className:"da-pos-modal-copy",onClick:()=>{var e,s;const a="".concat(Ne.lat.toFixed(6),", ").concat(Ne.lon.toFixed(6));null!==(e=navigator)&&void 0!==e&&null!==(s=e.clipboard)&&void 0!==s&&s.writeText&&navigator.clipboard.writeText(a)},title:"Copy coordinates",children:"Copy"})]})]})})]})}},84702:(e,s,a)=>{a.d(s,{Cx:()=>i,IE:()=>d,Ys:()=>n,Z3:()=>l,gM:()=>c,yP:()=>r});const t={created:{label:"Created",bg:"#3b82f6",fg:"#fff"},pending:{label:"Pending",bg:"#f59e0b",fg:"#fff"},accepted:{label:"Accepted",bg:"#8b5cf6",fg:"#fff"},arrived:{label:"Arrived",bg:"#ea580c",fg:"#fff"},picked:{label:"Picked",bg:"#0ea5e9",fg:"#fff"},active:{label:"Active",bg:"#0ea5e9",fg:"#fff"},delivered:{label:"Delivered",bg:"#22c55e",fg:"#fff"},skipped:{label:"Skipped",bg:"#94a3b8",fg:"#fff"},cancelled:{label:"Cancelled",bg:"#ef4444",fg:"#fff"}},i=e=>t[String(e||"").toLowerCase()]||{label:e||"Unknown",bg:"#64748b",fg:"#fff"},n=new Set(["delivered"]),r=new Set(["cancelled","skipped"]),l=["#2563eb","#dc2626","#16a34a","#ea580c","#9333ea","#0891b2","#ca8a04","#db2777","#0f766e","#7c3aed","#65a30d","#0284c7","#b91c1c","#15803d","#a16207","#86198f"],c=e=>l[(e%l.length+l.length)%l.length],d=e=>{if(null==e)return"";const s=["th","st","nd","rd"],a=e%100;return e+(s[(a-20)%10]||s[a]||s[0])}}}]);