Files
Express_console_build/build/static/js/6666.2d15bf94.chunk.js

1 line
138 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:()=>ce});var t=a(80045),i=a(89379),r=a(9950),n=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 r=Math.PI/2,n=[];for(let l=1;l<a;l++){t=e[l];const a=Math.atan2(t.y-i.y,t.x-i.x);n.push({offsetAngle:a-r,original:[i,t],offset:[this.translatePoint(i,s,a-r),this.translatePoint(t,s,a-r)]}),i=t}return n},intersection(e,s,a,t){const i=this.segmentAsVector(e,s),r=this.segmentAsVector(a,t),n=-r.x*i.y+i.x*r.y;if(0===n)return null;const l=(-i.y*(e.x-a.x)+i.x*(e.y-a.y))/n,c=(r.x*(e.y-a.y)-r.y*(e.x-a.x))/n;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,r=this.intersection(a[0],a[1],i[0],i[1]);r?s.push(r):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))),r=x().PolylineOffset.offsetPoints(i,t);for(let n=0;n<r.length;n++)a.extend(r[n]);s.push(r)};var j=a(4159),g=a.n(j),N=a(51778),f=a(36150),b=a(60010),y=a(36687),k=a(26910),S=a(31222),w=a(81425),F=a(84702),_=a(44414);const M=function(e){let{focusedRider:s,compareDeltas:a,compareSummary:t,actualOrdered:i,focusedCompareStep:n,setFocusedCompareStep:l,sequenceOpen:c,setSequenceOpen:d,expandedSeqGroups:o,setExpandedSeqGroups:u,onClose:m}=e;const p=(0,r.useMemo)((()=>{const e=t,r=e.onTime+e.late,n=s.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),l=n<0,c=a.filter((e=>e.anomaly)),d=a.filter((e=>F.Ys.has(String(e.orderstatus||"").toLowerCase()))).length,o=a.filter((e=>F.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),N=j.reduce(((e,s)=>!e||s.actualTs.isAfter(e)?s.actualTs:e),null),f=g&&N?Math.max(0,N.diff(g,"minute")):0,b=a.length>1?Math.round(f/(a.length-1)):0,y=f>0?(e.actualKm/(f/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,w=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,_=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=[];_.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,r=t-a,n=M[M.length-1];n&&n.delta===r&&n.lastActualPos+1===t?(n.items.push({d:e,planned:a,actualPos:t,delta:r}),n.lastActualPos=t):M.push({delta:r,items:[{d:e,planned:a,actualPos:t,delta:r}],lastActualPos:t})}));const z={};s.orders.forEach((e=>{const s=e.trip_number||1;z[s]||(z[s]=[]),z[s].push(e)}));const C=Object.entries(z).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=>F.Ys.has(String(e.orderstatus||"").toLowerCase()))).length}}));return{sum:e,totalSteps:r,totalProfit:n,isLoss:l,deviations:c,delivered:d,skipped:o,stepDeltaPct:u,score:h,scoreColor:x,scoreLabel:v,firstDelivery:g,lastDelivery:N,activeMin:f,avgPerStop:b,avgSpeed:y,bestStep:S,worstStep:w,outOfOrderSteps:_,seqRuns:M,tripList:C}}),[s,a,t,i]),h=null!=n?a.find((e=>e.sequenceStep===n)):null,x=e=>{l((s=>s===e?null:e))},v=function(e){let s=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];const{d:a,planned:t,actualPos:i,delta:r}=e;return(0,_.jsxs)("li",{className:"cdp-seq-diff".concat(n===a.sequenceStep?" is-focused":"").concat(s?"":" is-nested"),onClick:()=>x(a.sequenceStep),children:[(0,_.jsx)("span",{className:"cdp-seq-diff-num",style:{background:(0,F.gM)((t||a.sequenceStep)-1)},children:t||a.sequenceStep}),(0,_.jsxs)("div",{className:"cdp-seq-diff-body",children:[(0,_.jsx)("div",{className:"cdp-seq-diff-title",children:a.deliverycustomer||"Step ".concat(t||a.sequenceStep)}),(0,_.jsxs)("div",{className:"cdp-seq-diff-sub",children:["Visited ",(0,_.jsx)("strong",{children:(0,F.IE)(i)})," ","\xb7 planned ",(0,_.jsx)("strong",{children:(0,F.IE)(t)})]})]}),(0,_.jsx)("span",{className:"cdp-seq-diff-tag",children:r>0?"+".concat(r):"".concat(r)})]},"diff-".concat(a.sequenceStep))},{sum:j,totalSteps:g,totalProfit:N,isLoss:f,deviations:b,delivered:y,skipped:k,stepDeltaPct:w,score:M,scoreColor:z,scoreLabel:C,firstDelivery:A,lastDelivery:P,activeMin:D,avgPerStop:E,avgSpeed:q,bestStep:L,worstStep:O,outOfOrderSteps:I,seqRuns:R,tripList:T}=p;return(0,_.jsxs)("aside",{id:"compare-data-panel",className:"compare-data-panel",children:[(0,_.jsxs)("div",{className:"cdp-head",children:[(0,_.jsxs)("div",{className:"cdp-head-title",children:[(0,_.jsx)("span",{className:"cdp-rider-dot",style:{background:s.color}}),(0,_.jsxs)("div",{className:"cdp-head-text",children:[(0,_.jsx)("div",{className:"cdp-rider-name",children:s.riderName}),(0,_.jsx)("div",{className:"cdp-head-badge",children:"PLANNED vs ACTUAL"})]})]}),(0,_.jsx)("button",{type:"button",className:"cdp-close",onClick:m,title:"Exit compare","aria-label":"Exit compare",children:(0,_.jsx)(S.m6K,{})})]}),(0,_.jsxs)("div",{className:"cdp-scroll",children:[(0,_.jsx)("section",{className:"cdp-section cdp-score-section",children:(0,_.jsxs)("div",{className:"cdp-score-wrap",children:[(0,_.jsx)("div",{className:"cdp-score-ring",style:{background:"conic-gradient(".concat(z," ").concat(3.6*M,"deg, rgba(15,23,42,0.08) 0deg)")},children:(0,_.jsxs)("div",{className:"cdp-score-inner",children:[(0,_.jsx)("div",{className:"cdp-score-value",style:{color:z},children:M}),(0,_.jsx)("div",{className:"cdp-score-unit",children:"/100"})]})}),(0,_.jsxs)("div",{className:"cdp-score-body",children:[(0,_.jsx)("div",{className:"cdp-score-label",style:{color:z},children:C}),(0,_.jsx)("div",{className:"cdp-score-title",children:"Compliance score"}),(0,_.jsxs)("div",{className:"cdp-score-sub",children:[y,"/",a.length," delivered",j.anomalies>0?" \xb7 ".concat(j.anomalies," deviation").concat(j.anomalies>1?"s":""):"",j.late>0?" \xb7 ".concat(j.late," late"):"",k>0?" \xb7 ".concat(k," skipped"):""]})]})]})}),(0,_.jsxs)("section",{className:"cdp-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.Zs6,{})}),(0,_.jsx)("span",{className:"cdp-section-title",children:"Day overview"})]}),(0,_.jsxs)("div",{className:"cdp-tiles",children:[(0,_.jsxs)("div",{className:"cdp-tile",children:[(0,_.jsxs)("div",{className:"cdp-tile-label",children:[(0,_.jsx)(S.xI$,{})," Distance"]}),(0,_.jsxs)("div",{className:"cdp-tile-value",children:[j.actualKm.toFixed(1),(0,_.jsx)("span",{className:"cdp-tile-unit",children:"km"})]}),(0,_.jsxs)("div",{className:"cdp-tile-sub",children:["planned ",j.plannedKm.toFixed(1)," km"]})]}),(0,_.jsxs)("div",{className:"cdp-tile".concat(j.anomalies>0?" is-warn":""),children:[(0,_.jsxs)("div",{className:"cdp-tile-label",children:[(0,_.jsx)(S.Wux,{})," Deviation"]}),(0,_.jsx)("div",{className:"cdp-tile-value ".concat(w),children:null!=j.kmDeltaPct?"".concat(j.kmDeltaPct>0?"+":"").concat(j.kmDeltaPct.toFixed(0),"%"):"\u2014"}),(0,_.jsx)("div",{className:"cdp-tile-sub",children:j.anomalies>0?"".concat(j.anomalies," flagged"):"within plan"})]}),(0,_.jsxs)("div",{className:"cdp-tile".concat(j.late>0?" is-warn":""),children:[(0,_.jsxs)("div",{className:"cdp-tile-label",children:[(0,_.jsx)(S.VP9,{})," On-time"]}),(0,_.jsxs)("div",{className:"cdp-tile-value",children:[j.onTime,g>0&&(0,_.jsxs)("span",{className:"cdp-tile-unit",children:["/",g]})]}),(0,_.jsx)("div",{className:"cdp-tile-sub",children:j.late>0?"".concat(j.late," late"):"all on schedule"})]}),(0,_.jsxs)("div",{className:"cdp-tile ".concat(f?"is-loss":"is-gain"),children:[(0,_.jsxs)("div",{className:"cdp-tile-label",children:[f?(0,_.jsx)(S.Rod,{}):(0,_.jsx)(S.imn,{})," ",f?"Loss":"Profit"]}),(0,_.jsxs)("div",{className:"cdp-tile-value",children:[f?"-":"","\u20b9",Math.abs(N).toFixed(0)]}),(0,_.jsxs)("div",{className:"cdp-tile-sub",children:[s.orders.length," ",1===s.orders.length?"order":"orders"," \xb7 ",y," delivered"]})]})]})]}),a.length>0&&(0,_.jsxs)("section",{className:"cdp-section cdp-seq-section",children:[(0,_.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,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.$G1,{})}),(0,_.jsx)("span",{className:"cdp-section-title",children:"Route sequence"}),(0,_.jsx)("span",{className:"cdp-seq-status".concat(I.length>0?" is-warn":" is-good"),children:I.length>0?"".concat(I.length," out of order"):"In order"}),(0,_.jsx)("span",{className:"cdp-seq-toggle".concat(c?" is-open":""),children:(0,_.jsx)(S.j1Q,{})})]}),c&&(0,_.jsx)("div",{className:"cdp-seq",children:I.length>0?(0,_.jsx)("ul",{className:"cdp-seq-diffs",children:R.map(((e,s)=>{if(1===e.items.length)return v(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===n));return(0,_.jsxs)(r.Fragment,{children:[(0,_.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,_.jsxs)("span",{className:"cdp-seq-group-num",children:[(0,_.jsx)("span",{className:"cdp-seq-group-num-bg",style:{background:"linear-gradient(135deg, ".concat((0,F.gM)((a.planned||1)-1),", ").concat((0,F.gM)((t.planned||1)-1),")")}}),(0,_.jsxs)("span",{className:"cdp-seq-group-num-label",children:[e.items.length,"\xd7"]})]}),(0,_.jsxs)("div",{className:"cdp-seq-diff-body",children:[(0,_.jsxs)("div",{className:"cdp-seq-diff-title",children:[e.items.length," consecutive steps shifted"," ",(0,_.jsx)("span",{className:"cdp-seq-group-delta",children:l})]}),(0,_.jsxs)("div",{className:"cdp-seq-diff-sub",children:["Planned ",(0,F.IE)(a.planned),"\u2013",(0,F.IE)(t.planned)," ","visited"," ",(0,_.jsxs)("strong",{children:[(0,F.IE)(a.actualPos),"\u2013",(0,F.IE)(t.actualPos)]})]})]}),(0,_.jsx)("span",{className:"cdp-seq-diff-tag",children:l}),(0,_.jsx)("span",{className:"cdp-seq-group-toggle".concat(i?" is-open":""),"aria-hidden":"true",children:(0,_.jsx)(S.j1Q,{})})]}),i&&(0,_.jsx)("li",{className:"cdp-seq-group-children-wrap",children:(0,_.jsx)("ul",{className:"cdp-seq-group-children",children:e.items.map((e=>v(e,!1)))})})]},"run-".concat(s,"-").concat(a.d.sequenceStep))}))}):(0,_.jsxs)("div",{className:"cdp-seq-good",children:[(0,_.jsx)(S.mU9,{})," Rider followed the planned route in order."]})})]}),(A||P)&&(0,_.jsxs)("section",{className:"cdp-section cdp-timing-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.pWE,{})}),(0,_.jsx)("span",{className:"cdp-section-title",children:"Timing"}),D>0&&(0,_.jsxs)("span",{className:"cdp-timing-active-tag",children:[(0,_.jsx)("span",{className:"cdp-timing-active-pulse"}),"Day window"]})]}),(0,_.jsxs)("div",{className:"cdp-timing-clock",children:[(0,_.jsxs)("div",{className:"cdp-clock-card is-start",children:[(0,_.jsxs)("div",{className:"cdp-clock-label",children:[(0,_.jsx)(S.WVj,{})," First delivery"]}),(0,_.jsxs)("div",{className:"cdp-clock-face",children:[(0,_.jsx)("span",{className:"cdp-clock-time",children:A?A.format("hh:mm"):"\u2014"}),(0,_.jsx)("span",{className:"cdp-clock-period",children:A?A.format("A"):""})]}),(0,_.jsx)("div",{className:"cdp-clock-caption",children:"Started"})]}),(0,_.jsxs)("div",{className:"cdp-clock-track","aria-hidden":"true",children:[(0,_.jsx)("span",{className:"cdp-clock-track-line"}),(0,_.jsx)("span",{className:"cdp-clock-track-dot is-start"}),(0,_.jsx)("span",{className:"cdp-clock-track-dot is-end"}),(0,_.jsxs)("div",{className:"cdp-clock-duration",children:[(0,_.jsx)("span",{className:"cdp-clock-duration-icon",children:(0,_.jsx)(S.DZH,{})}),(0,_.jsx)("span",{className:"cdp-clock-duration-val",children:D>0?D>=60?"".concat(Math.floor(D/60),"h ").concat(D%60,"m"):"".concat(D,"m"):"\u2014"}),(0,_.jsx)("span",{className:"cdp-clock-duration-sub",children:"active"})]})]}),(0,_.jsxs)("div",{className:"cdp-clock-card is-end",children:[(0,_.jsxs)("div",{className:"cdp-clock-label",children:[(0,_.jsx)(S.mU9,{})," Last delivery"]}),(0,_.jsxs)("div",{className:"cdp-clock-face",children:[(0,_.jsx)("span",{className:"cdp-clock-time",children:P?P.format("hh:mm"):"\u2014"}),(0,_.jsx)("span",{className:"cdp-clock-period",children:P?P.format("A"):""})]}),(0,_.jsx)("div",{className:"cdp-clock-caption",children:"Finished"})]})]}),(0,_.jsxs)("div",{className:"cdp-timing-stats",children:[(0,_.jsxs)("div",{className:"cdp-timing-stat",children:[(0,_.jsxs)("div",{className:"cdp-timing-stat-head",children:[(0,_.jsx)("div",{className:"cdp-timing-stat-icon",children:(0,_.jsx)(S.VP9,{})}),(0,_.jsxs)("div",{className:"cdp-timing-stat-body",children:[(0,_.jsxs)("div",{className:"cdp-timing-stat-value",children:[E>0?"".concat(E):"\u2014",E>0&&(0,_.jsx)("span",{className:"cdp-timing-stat-unit",children:"min"})]}),(0,_.jsx)("div",{className:"cdp-timing-stat-label",children:"Avg / stop"})]})]}),a.length>0&&(0,_.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,_.jsx)("span",{className:"cdp-stop-dot"},"dot-".concat(s)))),(0,_.jsxs)("span",{className:"cdp-timing-stat-viz-label",children:[a.length," stop",1===a.length?"":"s"]})]})]}),null!=q&&(0,_.jsxs)("div",{className:"cdp-timing-stat",children:[(0,_.jsxs)("div",{className:"cdp-timing-stat-head",children:[(0,_.jsx)("div",{className:"cdp-timing-stat-icon",children:(0,_.jsx)(S.BJM,{})}),(0,_.jsxs)("div",{className:"cdp-timing-stat-body",children:[(0,_.jsxs)("div",{className:"cdp-timing-stat-value",children:[q,(0,_.jsx)("span",{className:"cdp-timing-stat-unit",children:"km/h"})]}),(0,_.jsx)("div",{className:"cdp-timing-stat-label",children:"Avg speed"})]})]}),(0,_.jsxs)("div",{className:"cdp-timing-stat-viz cdp-speed-gauge","aria-hidden":"true",children:[(0,_.jsx)("div",{className:"cdp-speed-gauge-track",children:(0,_.jsx)("div",{className:"cdp-speed-gauge-fill",style:{width:"".concat(Math.min(100,parseFloat(q)/60*100),"%")}})}),(0,_.jsxs)("div",{className:"cdp-speed-gauge-scale",children:[(0,_.jsx)("span",{children:"0"}),(0,_.jsx)("span",{children:"30"}),(0,_.jsx)("span",{children:"60 km/h"})]})]})]})]})]}),(L||O)&&(0,_.jsxs)("section",{className:"cdp-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.SeC,{})}),(0,_.jsx)("span",{className:"cdp-section-title",children:"Highlights"})]}),(0,_.jsxs)("div",{className:"cdp-highlights",children:[L&&(0,_.jsxs)("div",{className:"cdp-highlight is-best",onClick:()=>x(L.sequenceStep),role:"button",title:"Focus this step",children:[(0,_.jsx)("span",{className:"cdp-highlight-rail","aria-hidden":"true"}),(0,_.jsxs)("div",{className:"cdp-highlight-content",children:[(0,_.jsxs)("div",{className:"cdp-highlight-top",children:[(0,_.jsxs)("span",{className:"cdp-highlight-label",children:[(0,_.jsx)("span",{className:"cdp-highlight-chip",children:(0,_.jsx)(S.mU9,{})}),"Fastest stop"]}),(0,_.jsxs)("span",{className:"cdp-highlight-step-chip",style:{background:(0,F.gM)(L.sequenceStep-1)},children:["Step ",L.sequenceStep]})]}),(0,_.jsx)("div",{className:"cdp-highlight-title",children:L.deliverycustomer||"Step ".concat(L.sequenceStep)}),(0,_.jsx)("div",{className:"cdp-highlight-meta",children:(0,_.jsx)("span",{className:"cdp-highlight-pill is-good",children:null!=L.timeDeltaMin?0===L.timeDeltaMin?"On schedule":"".concat(L.timeDeltaMin>0?"+":"").concat(L.timeDeltaMin," min vs plan"):"On schedule"})})]})]}),O&&(0,_.jsxs)("div",{className:"cdp-highlight is-worst",onClick:()=>x(O.sequenceStep),role:"button",title:"Focus this step",children:[(0,_.jsx)("span",{className:"cdp-highlight-rail","aria-hidden":"true"}),(0,_.jsxs)("div",{className:"cdp-highlight-content",children:[(0,_.jsxs)("div",{className:"cdp-highlight-top",children:[(0,_.jsxs)("span",{className:"cdp-highlight-label",children:[(0,_.jsx)("span",{className:"cdp-highlight-chip",children:(0,_.jsx)(S.Wux,{})}),"Biggest deviation"]}),(0,_.jsxs)("span",{className:"cdp-highlight-step-chip",style:{background:(0,F.gM)(O.sequenceStep-1)},children:["Step ",O.sequenceStep]})]}),(0,_.jsx)("div",{className:"cdp-highlight-title",children:O.deliverycustomer||"Step ".concat(O.sequenceStep)}),(0,_.jsxs)("div",{className:"cdp-highlight-meta",children:[null!=O.kmDeltaPct&&(0,_.jsxs)("span",{className:"cdp-highlight-pill is-bad",children:[O.kmDeltaPct>0?"+":"",O.kmDeltaPct.toFixed(0),"% route"]}),null!=O.timeDeltaMin&&O.timeDeltaMin>0&&(0,_.jsxs)("span",{className:"cdp-highlight-pill is-bad",children:["+",O.timeDeltaMin,"m late"]})]})]})]})]})]}),T.length>1&&(0,_.jsxs)("section",{className:"cdp-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.$G1,{})}),(0,_.jsxs)("span",{className:"cdp-section-title",children:["Trips (",T.length,")"]})]}),(0,_.jsx)("div",{className:"cdp-trips",children:T.map((e=>{const s=e.profit<0;return(0,_.jsxs)("div",{className:"cdp-trip",children:[(0,_.jsxs)("div",{className:"cdp-trip-head",children:[(0,_.jsxs)("span",{className:"cdp-trip-badge",children:["Trip ",e.tNum]}),(0,_.jsxs)("span",{className:"cdp-trip-meta",children:[e.delivered,"/",e.count," delivered"]})]}),(0,_.jsxs)("div",{className:"cdp-trip-stats",children:[(0,_.jsxs)("span",{title:"Distance",children:[(0,_.jsx)(S.xI$,{}),e.actualKm.toFixed(1),"km",(0,_.jsxs)("small",{children:[" / ",e.plannedKm.toFixed(1)]})]}),(0,_.jsxs)("span",{className:s?"is-over":"",title:s?"Loss":"Profit",children:[(0,_.jsx)(S.ohY,{}),s?"-":"","\u20b9",Math.abs(e.profit).toFixed(0)]})]})]},"trip-".concat(e.tNum))}))})]}),h&&(e=>{const s=(0,F.gM)(h.sequenceStep-1),a=h.kmDelta>=0?"+":"",t=h.anomaly?"is-over":h.kmDelta<-.1?"is-under":"",i=null!=h.timeDeltaMin?h.timeDeltaMin>10?"is-over":h.timeDeltaMin<-2?"is-under":"":"",r=(0,F.Cx)(h.orderstatus),n=parseFloat((null===(e=h.order)||void 0===e?void 0:e.profit)||0);return(0,_.jsxs)("section",{className:"cdp-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.$G1,{})}),(0,_.jsxs)("span",{className:"cdp-section-title",children:["Step ",h.sequenceStep," details"]}),(0,_.jsx)("button",{type:"button",className:"cdp-section-clear",onClick:()=>l(null),title:"Clear step focus",children:"Show all"})]}),(0,_.jsxs)("div",{className:"compare-delta".concat(h.anomaly?" is-anomaly":""),children:[(0,_.jsxs)("div",{className:"compare-delta-title",children:[(0,_.jsx)("span",{className:"compare-delta-step-badge",style:{background:s},children:h.sequenceStep}),(0,_.jsxs)("div",{className:"compare-delta-title-text",children:[(0,_.jsx)("div",{className:"compare-delta-title-main",children:h.deliverycustomer||"Step ".concat(h.sequenceStep)}),(0,_.jsxs)("div",{className:"compare-delta-title-sub",children:[h.pickupcustomer?"from ".concat(h.pickupcustomer," \xb7 "):"","Order #",h.orderid]})]}),h.orderstatus&&(0,_.jsx)("span",{className:"compare-delta-status",style:{background:r.bg,color:r.fg},children:r.label})]}),(0,_.jsxs)("div",{className:"compare-delta-grid",children:[(0,_.jsxs)("div",{className:"compare-delta-cell".concat(h.anomaly?" is-anomaly":""),children:[(0,_.jsx)("span",{className:"compare-delta-cell-label",children:"Distance"}),(0,_.jsxs)("span",{className:"compare-delta-cell-val",children:[h.actualKm.toFixed(2)," ",(0,_.jsx)("span",{className:"compare-delta-cell-unit",children:"km"})]}),(0,_.jsxs)("span",{className:"compare-delta-cell-sub",children:["planned ",h.plannedKm.toFixed(2)," km"]})]}),(0,_.jsxs)("div",{className:"compare-delta-cell",children:[(0,_.jsx)("span",{className:"compare-delta-cell-label",children:"\u0394 Route"}),(0,_.jsxs)("span",{className:"compare-delta-cell-val ".concat(t),children:[a,h.kmDelta.toFixed(2)," km"]}),(0,_.jsx)("span",{className:"compare-delta-cell-sub",children:null!=h.kmDeltaPct?"".concat(a).concat(h.kmDeltaPct.toFixed(0),"% vs plan"):"no planned km"})]}),(0,_.jsxs)("div",{className:"compare-delta-cell",children:[(0,_.jsx)("span",{className:"compare-delta-cell-label",children:"Time"}),(0,_.jsx)("span",{className:"compare-delta-cell-val ".concat(i),children:null!=h.timeDeltaMin?"".concat(h.timeDeltaMin>0?"+":"").concat(h.timeDeltaMin," min"):"\u2014"}),(0,_.jsx)("span",{className:"compare-delta-cell-sub",children:h.actualTs&&h.expectedTs?"".concat(h.actualTs.format("HH:mm")," vs ").concat(h.expectedTs.format("HH:mm")):h.actualTs?"delivered ".concat(h.actualTs.format("HH:mm")):"in flight"})]}),!Number.isNaN(n)&&0!==n&&(0,_.jsxs)("div",{className:"compare-delta-cell".concat(n<0?" is-anomaly":""),children:[(0,_.jsx)("span",{className:"compare-delta-cell-label",children:n<0?"Loss":"Profit"}),(0,_.jsxs)("span",{className:"compare-delta-cell-val ".concat(n<0?"is-over":"is-under"),children:[n<0?"-":"","\u20b9",Math.abs(n).toFixed(0)]}),(0,_.jsx)("span",{className:"compare-delta-cell-sub",children:"order revenue"})]})]})]})]})})(),b.length>0&&(0,_.jsxs)("section",{className:"cdp-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon cdp-icon-warn",children:(0,_.jsx)(S.ItP,{})}),(0,_.jsxs)("span",{className:"cdp-section-title",children:["Deviations (",b.length,")"]})]}),(0,_.jsx)("ul",{className:"cdp-dev-list",children:b.map((e=>{const s=(0,F.gM)(e.sequenceStep-1),a=e.kmDelta>=0?"+":"";return(0,_.jsxs)("li",{className:"cdp-dev-item".concat(n===e.sequenceStep?" is-focused":""),onClick:()=>x(e.sequenceStep),children:[(0,_.jsx)("span",{className:"cdp-dev-num",style:{background:s},children:e.sequenceStep}),(0,_.jsxs)("div",{className:"cdp-dev-body",children:[(0,_.jsx)("div",{className:"cdp-dev-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),(0,_.jsxs)("div",{className:"cdp-dev-meta",children:[null!=e.kmDeltaPct&&(0,_.jsxs)("span",{className:"cdp-dev-chip is-over",children:[a,e.kmDeltaPct.toFixed(0),"% route"]}),null!=e.timeDeltaMin&&e.timeDeltaMin>10&&(0,_.jsxs)("span",{className:"cdp-dev-chip is-over",children:["+",e.timeDeltaMin,"m late"]})]})]})]},"dev-".concat(e.sequenceStep))}))})]}),(0,_.jsxs)("section",{className:"cdp-section",children:[(0,_.jsxs)("div",{className:"cdp-section-head",children:[(0,_.jsx)("span",{className:"cdp-section-icon",children:(0,_.jsx)(S.EgJ,{})}),(0,_.jsxs)("span",{className:"cdp-section-title",children:["Steps (",a.length,")"]}),(0,_.jsxs)("span",{className:"cdp-section-sub",children:[y,"/",a.length," delivered"]})]}),(0,_.jsx)("ul",{className:"cdp-step-list",children:a.map((e=>{var s;const a=(0,F.gM)(e.sequenceStep-1),t=String(e.orderstatus||"").toLowerCase(),i=F.Ys.has(t),r=F.yP.has(t),l=i&&!e.anomaly,c=n===e.sequenceStep,d=(0,F.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":"",r?"is-skipped":"",e.isLoading?"is-loading":""].filter(Boolean).join(" ");return(0,_.jsxs)("li",{className:p,onClick:()=>x(e.sequenceStep),children:[(0,_.jsxs)("span",{className:"cdp-step-num",style:{background:a},children:[e.sequenceStep,l&&(0,_.jsx)("span",{className:"cdp-step-check",children:(0,_.jsx)(S.mU9,{})}),e.anomaly&&(0,_.jsx)("span",{className:"cdp-step-flag",children:(0,_.jsx)(S.ItP,{})})]}),(0,_.jsxs)("div",{className:"cdp-step-body",children:[(0,_.jsxs)("div",{className:"cdp-step-title-row",children:[(0,_.jsx)("span",{className:"cdp-step-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),e.orderstatus&&(0,_.jsx)("span",{className:"cdp-step-status",style:{background:d.bg,color:d.fg},children:d.label})]}),(0,_.jsxs)("div",{className:"cdp-step-sub",children:[e.pickupcustomer?"from ".concat(e.pickupcustomer," \xb7 "):"","Order #",e.orderid]}),(0,_.jsxs)("div",{className:"cdp-step-deltas",children:[(0,_.jsxs)("span",{className:"cdp-step-delta",title:"Distance",children:[(0,_.jsx)(S.xI$,{}),e.actualKm.toFixed(1),"km",e.plannedKm>0&&(0,_.jsxs)("small",{className:e.anomaly?"is-over":"",children:[" ",u,e.kmDelta.toFixed(1)]})]}),(0,_.jsxs)("span",{className:"cdp-step-delta ".concat(m),title:"Delivery time",children:[(0,_.jsx)(S.VP9,{}),e.actualTs?e.actualTs.format("HH:mm"):"\u2014",null!=e.timeDeltaMin&&(0,_.jsxs)("small",{children:[" ",e.timeDeltaMin>0?"+":"",e.timeDeltaMin,"m"]})]}),!Number.isNaN(o)&&0!==o&&(0,_.jsxs)("span",{className:"cdp-step-delta".concat(o<0?" is-over":""),title:o<0?"Loss":"Profit",children:[(0,_.jsx)(S.ohY,{}),o<0?"-":"","\u20b9",Math.abs(o).toFixed(0)]})]})]})]},"step-".concat(e.sequenceStep))}))})]})]})]})};var z=a(85571);const C=["_ts"],A="#6366f1",P="#10b981",D=e=>{const s=parseFloat(e);return Number.isFinite(s)?s:NaN},E=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},q=e=>Number.isFinite(D(e.droplat||e.deliverylat))&&Number.isFinite(D(e.droplon||e.deliverylong)),L=e=>e.pickuplat||e.pickuplatitude||e.pickup_lat,O=e=>e.pickuplong||e.pickuplongitude||e.picklongitude||e.pickup_lon,I=e=>Number.isFinite(D(L(e)))&&Number.isFinite(D(O(e))),R=[{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}],T="dispatch.slots.v9",H=["dispatch.slots.v1","dispatch.slots.v2","dispatch.slots.v3","dispatch.slots.v4","dispatch.slots.v5","dispatch.slots.v6","dispatch.slots.v7","dispatch.slots.v8"],Y=(e,s)=>"Slot ".concat(e+1," \xb7 ").concat(V(s)),V=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 r=String(a).padStart(2,"0");return"".concat(t,":").concat(r," ").concat(i)},K=(e,s)=>s>=24?"After ".concat(V(e)):"".concat(V(e),"\u2013").concat(V(s)),B=R.map(((e,s)=>(0,i.A)((0,i.A)({},e),{},{label:e.name||Y(s,e.startHour),range:K(e.startHour,e.endHour)}))),G=(e,s)=>{for(const a of s)if(e>=a.startHour&&e<a.endHour)return a.id;return null},J=[{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"]}],U=function(e){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:B;const a=((e,s)=>{const a=J.find((e=>e.id===s))||J[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()?G(i.hour()+i.minute()/60,s):null};function $(e){let{targetRef:s}=e;const a=(0,n.ko)();return(0,r.useEffect)((()=>(s.current=a,()=>{s.current=null})),[a]),null}function W(e,s){const a=e=>e*Math.PI/180,t=a(e[0]),i=a(s[0]),r=a(s[0]-e[0]),n=a(s[1]-e[1]),l=Math.sin(r/2)**2+Math.cos(t)*Math.cos(i)*Math.sin(n/2)**2;return 12742*Math.asin(Math.min(1,Math.sqrt(l)))}function Z(e){if(!Array.isArray(e)||e.length<2)return 0;let s=0;for(let a=1;a<e.length;a++)s+=W(e[a-1],e[a]);return s}function X(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 r=e[i][0]-s[0],n=e[i][1]-s[1],l=r*r+n*n;l<t&&(t=l,a=i)}return a}));for(let r=1;r<a.length;r++)a[r]<a[r-1]&&(a[r]=a[r-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 Q=e=>{if(!e)return null;const s=g()(e);return s.isValid()?s.format("HH:mm:ss"):String(e)},ee=[{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}],se=e=>{const s=e.filter(q);if(!s.length)return[];const a=e.find(I),t=[];return a&&t.push([D(L(a)),D(O(a))]),s.forEach((e=>t.push([D(e.droplat||e.deliverylat),D(e.droplon||e.deliverylong)]))),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 ae=["#0055FF","#00D82C","#FF6B00","#9D00FF","#FF00A8","#00C2B2","#FF9900","#FF0000"],te=e=>{const s=String(null!==e&&void 0!==e?e:"");if(!s)return ae[0];let a=0;for(let t=0;t<s.length;t++)a=31*a+s.charCodeAt(t)>>>0;return ae[a%ae.length]},ie=e=>{let{focusedItem:s,viewMode:a,orders:t,kitchens:i,locationKey:l}=e;const c=(0,n.ko)(),d=(0,r.useRef)(""),o=(0,r.useMemo)((()=>{const e=null!=l?"loc:".concat(l,"|"):"",r=e=>{let s=0,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 n,c,d;const a=null!==(n=null!==(c=null!==(d=s.id)&&void 0!==d?d:s.kitchenName)&&void 0!==c?c:s.name)&&void 0!==n?n:null!=s.lat?"".concat(s.lat,",").concat(s.lon):"item",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=r(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(r(s))}return"".concat(e,"m|").concat(a||"","|").concat(o.length,"|").concat(u)}),[s,a,t,i,l]);return(0,r.useEffect)((()=>{if(d.current===o)return;let e=[];s?s.orders?(e=s.orders.map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])),s.orders.forEach((s=>e.push([D(L(s)),D(O(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 r=e.filter((e=>Number.isFinite(e[0])&&Number.isFinite(e[1])));if(r.length>0){const e=x().latLngBounds(r);if(e.isValid()){1===r.length||e.getNorthEast().equals(e.getSouthWest())?c.setView(r[0],15,{animate:!0,duration:.6}):c.flyToBounds(e,{padding:[60,60],duration:.6,maxZoom:16}),d.current=o}}else;}),[o,s,a,t,i,c]),null},re=e=>{let{children:s}=e;return(0,_.jsx)("span",{className:"ico-inline",style:{display:"inline-flex",alignItems:"center",verticalAlign:"-2px",marginRight:4},children:s})},ne=[{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"}],le=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)},ce=e=>{let{data:s,embedded:a=!1,selectedRiderId:n,onRiderSelect:h,pulseOrderId:v,onChangeRider:j}=e;const V=null!==s&&void 0!==s&&s.zones&&s.zones.length>0?"zones":"riders",[J,ce]=(0,r.useState)(V),[de,oe]=(0,r.useState)("live"),[ue,me]=(0,r.useState)({}),[pe,he]=(0,r.useState)(null),[xe,ve]=(0,r.useState)(null),je=(0,N.n)({mutationFn:w.W0,onMutate:e=>he(e.batch),onSuccess:(e,s)=>{me((a=>(0,i.A)((0,i.A)({},a),{},{[s.batch]:{data:e,fetchedAt:g()().format("HH:mm:ss")}})))},onSettled:()=>he(null)}),ge=e=>{ve(e);const s=ue[e];s&&s.data&&!1!==s.data.success||je.mutate({batch:e,tenantId:916})},[Ne,fe]=(0,r.useState)(new Set),[be,ye]=(0,r.useState)(null),[ke,Se]=(0,r.useState)(null),[we,Fe]=(0,r.useState)(null),[_e,Me]=(0,r.useState)(null),[ze,Ce]=(0,r.useState)("planned"),Ae=(0,r.useRef)({}),Pe=(0,r.useRef)(new Set),De=(0,r.useRef)(new Set),Ee=((0,r.useRef)(null),(0,r.useRef)(null)),[qe,Le]=(0,r.useState)(null),Oe=void 0!==n,[Ie,Re]=(0,r.useState)(""),{data:Te}=(0,f.I)({queryKey:["appLocations"],queryFn:w.aL,staleTime:3e5}),He="undefined"!==typeof window?localStorage.getItem("applocationid"):null,[Ye,Ve]=(0,r.useState)(null!=He?Number(He):0),[Ke,Be]=(0,r.useState)(!1),Ge=(0,r.useRef)(null),[Je,Ue]=(0,r.useState)("assigned"),[$e,We]=(0,r.useState)(!1),Ze=(0,r.useRef)(null),[Xe,Qe]=(0,r.useState)((()=>{if("undefined"===typeof window)return B;try{const e=window.localStorage.getItem(T);if(!e)return B;const s=JSON.parse(e);return Array.isArray(s)&&s.length===R.length?s.map(((e,s)=>{const a=e.id||"slot-".concat(s+1),t=Number(e.startHour)||0,i=Number(e.endHour)||24,r=B.find((e=>e.id===a));return{id:a,startHour:t,endHour:i,label:(null===r||void 0===r?void 0:r.name)||Y(s,t),range:K(t,i)}})):B}catch(e){return B}})),es=Xe,[ss,as]=(0,r.useState)(!1),ts=(0,r.useRef)(null);(0,r.useEffect)((()=>{if("undefined"!==typeof window)try{H.forEach((e=>window.localStorage.removeItem(e)))}catch(e){}}),[]);const is=(0,r.useRef)(!1);(0,r.useEffect)((()=>{if(is.current){if("undefined"!==typeof window)try{window.localStorage.setItem(T,JSON.stringify(Xe.map((e=>{let{id:s,startHour:a,endHour:t}=e;return{id:s,startHour:a,endHour:t}}))))}catch(e){}}else is.current=!0}),[Xe]),(0,r.useEffect)((()=>{if(!Ke)return;const e=e=>{Ge.current&&!Ge.current.contains(e.target)&&Be(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[Ke]),(0,r.useEffect)((()=>{if(!$e)return;const e=e=>{Ze.current&&!Ze.current.contains(e.target)&&We(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[$e]),(0,r.useEffect)((()=>{if(!ss)return;const e=e=>{ts.current&&!ts.current.contains(e.target)&&as(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)}),[ss]);const[rs,ns]=(0,r.useState)(null),[ls,cs]=(0,r.useState)(""),{data:ds,isFetching:os,isError:us,error:ms}=(0,f.I)({queryKey:["riderPeriodicLog",rs],queryFn:()=>(0,w.ne)(rs),enabled:"rider-info"===J&&null!=rs,refetchInterval:"rider-info"===J&&null!=rs&&15e3,refetchIntervalInBackground:!1,staleTime:5e3,refetchOnWindowFocus:!1}),ps=(0,r.useMemo)((()=>{const e=parseFloat(null===ds||void 0===ds?void 0:ds.latitude),s=parseFloat(null===ds||void 0===ds?void 0:ds.longitude);return Number.isFinite(e)&&Number.isFinite(s)?{lat:e.toFixed(4),lon:s.toFixed(4)}:null}),[null===ds||void 0===ds?void 0:ds.latitude,null===ds||void 0===ds?void 0:ds.longitude]),{data:hs}=(0,f.I)({queryKey:["reverseGeocode",null===ps||void 0===ps?void 0:ps.lat,null===ps||void 0===ps?void 0:ps.lon],queryFn:async()=>{const e=await fetch("https://nominatim.openstreetmap.org/reverse?lat=".concat(ps.lat,"&lon=").concat(ps.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"===J&&!!ps,staleTime:3e5,refetchOnWindowFocus:!1,retry:1}),xs=(0,r.useMemo)((()=>{if(!Te)return null;const e=Te.find((e=>String(e.applocationid)===String(Ye)));return(null===e||void 0===e?void 0:e.locationname)||null}),[Te,Ye]),[vs,js]=(0,r.useState)({}),gs=(0,r.useRef)({}),[Ns,fs]=(0,r.useState)({}),bs=(0,r.useRef)({}),[ys,ks]=(0,r.useState)(!1),[Ss,ws]=(0,r.useState)([]),[Fs,_s]=(0,r.useState)({}),Ms=(0,r.useRef)(!1),[zs,Cs]=(0,r.useState)(g()().format("YYYY-MM-DD")),[As,Ps]=(0,r.useState)(!1),[Ds,Es]=(0,r.useState)((()=>g()(zs).isValid()?g()(zs).startOf("month"):g()().startOf("month"))),qs=(0,r.useRef)(null);(0,r.useEffect)((()=>{if(!As)return;const e=e=>{qs.current&&(qs.current.contains(e.target)||Ps(!1))},s=e=>{"Escape"===e.key&&Ps(!1)};return document.addEventListener("mousedown",e),document.addEventListener("keydown",s),()=>{document.removeEventListener("mousedown",e),document.removeEventListener("keydown",s)}}),[As]),(0,r.useEffect)((()=>{if(As){const e=g()(zs);e.isValid()&&Es(e.startOf("month"))}}),[As,zs]);const[Ls,Os]=(0,r.useState)(!1),[Is,Rs]=(0,r.useState)("combined"),[Ts,Hs]=(0,r.useState)(!0),[Ys,Vs]=(0,r.useState)(!0),[Ks,Bs]=(0,r.useState)((()=>new Set)),Gs=(0,r.useRef)(!1),[Js,Us]=(0,r.useState)(!1),$s=(0,r.useRef)(!1),Ws=(0,r.useRef)(!1),[Zs,Xs]=(0,r.useState)(!1),[Qs,ea]=(0,r.useState)(null),sa=(0,r.useRef)(null),aa=(0,r.useRef)(null);aa.current||(aa.current=x().canvas({padding:1.5,tolerance:5}));const{data:ta}=(0,f.I)({queryKey:[Ye,zs,""],queryFn:w.zb,refetchInterval:15e3,refetchIntervalInBackground:!1,staleTime:5e3,refetchOnWindowFocus:!1}),ia=(0,r.useMemo)((()=>(ta||[]).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)),[ta]),[ra,na]=(0,r.useState)((()=>{const e=g()();return G(e.hour()+e.minute()/60,B)||B[0].id}));(0,r.useEffect)((()=>{var e;"all"!==ra&&(es.some((e=>e.id===ra))||na((null===(e=es[0])||void 0===e?void 0:e.id)||"all"))}),[es,ra]);const la=(0,r.useRef)(null),ca=!s,da="undefined"!==typeof window&&localStorage.getItem("userid")||0,{data:oa,isFetching:ua,isError:ma,fetchNextPage:pa,hasNextPage:ha,isFetchingNextPage:xa}=(0,b.q)({queryKey:["dispatchDeliveries",Ye,da,"all",zs,zs,50,"",0,0,0],queryFn:w.tL,getNextPageParam:e=>{var s;return null!==(s=e.nextPage)&&void 0!==s?s:void 0},enabled:ca});(0,r.useEffect)((()=>{ca&&ha&&!xa&&pa()}),[ca,ha,xa,pa]);const va=(0,r.useMemo)((()=>{const e=((null===oa||void 0===oa?void 0:oa.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}),[oa]),ja=(0,r.useMemo)((()=>{const e=new Map;return va.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))))}),[va]),ga=(0,r.useMemo)((()=>{const e={all:va.length};return es.forEach((s=>{e[s.id]=0})),va.forEach((s=>{const a=U(s,Je,es);a&&(e[a]=(e[a]||0)+1)})),e}),[va,Je,es]),Na=(0,r.useMemo)((()=>"all"===ra?va:va.filter((e=>U(e,Je,es)===ra))),[va,ra,Je,es]),fa=(0,r.useMemo)((()=>{if(!ca)return null;if(!Na.length)return{code:200,zone_summary:[],zones:[]};const e=e=>String(e||"").trim(),s={};Na.forEach((a=>{const t=e(a.deliverysuburb)||e(a.locationsuburb)||e(a.zone_name)||"Unzoned",i=t.toLowerCase(),r=String(a.userid||a.rider_id||"unassigned"),n=a.ridername||a.rider_name||a.username||("unassigned"===r?"Unassigned":"Rider ".concat(r));s[i]||(s[i]={zone_name:t,riders:{}}),s[i].riders[r]||(s[i].riders[r]={rider_id:r,rider_name:n,orders:[]}),s[i].riders[r].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}}),[ca,Na]),ba=(0,r.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,r,n;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!==(r=l.total_delivery_kms)&&void 0!==r?r:c.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),totalProfit:null!==(n=l.total_profit)&&void 0!==n?n:c.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),suburbs:o,kitchens:u,statusCounts:m}}))}),[s,fa]),{riders:ya,kitchens:ka,allOrders:Sa,stats:wa}=(0,r.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:ae[Object.keys(a).length%ae.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)&&I(e)&&(t[a].lat=D(L(e)),t[a].lon=D(O(e))):t[a]={id:a,kitchenName:s,lat:D(L(e)),lon:D(O(e)),orders:[],riders:new Set},t[a].orders.push(e),e.rider_id&&t[a].riders.add(e.rider_id)}));const r=e.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),n=e.reduce(((e,s)=>e+parseFloat(s.profit||0)),0);return{riders:Object.values(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:r,totalProfit:n,totalRiders:Object.keys(a).length}}}),[s,fa]),Fa=Oe?n&&ya.find((e=>e.id===n))||null:be,_a=(0,r.useCallback)((e=>{h&&h(e?e.id:null),Oe||ye(e),Me(null)}),[Oe,h]),Ma=(0,r.useRef)(null);(0,r.useEffect)((()=>{const e=Fa?Fa.id:null;e!==Ma.current&&(Fa?z.A.info("Focused rider changed to: ".concat(Fa.riderName," (").concat(Fa.orders.length," orders)")):z.A.info("Focused rider reset to: None"),Ma.current=e)}),[Fa]),(0,r.useEffect)((()=>{_e?z.A.info("Focused order updated: ID ".concat(_e.orderid)):z.A.debug("Focused order selection cleared")}),[_e]);const za=(0,r.useRef)(0);(0,r.useEffect)((()=>{Sa&&Sa.length!==za.current&&(z.A.info("Orders database updated: ".concat(Sa.length," orders actively tracked")),za.current=Sa.length)}),[Sa]);const Ca=(0,r.useRef)(0);(0,r.useEffect)((()=>{ia&&ia.length!==Ca.current&&(z.A.info("Live riders list updated: ".concat(ia.length," active riders mapped")),Ca.current=ia.length)}),[ia]);const Aa=(0,r.useMemo)((()=>Fa?{orders:Fa.orders.length,riders:1,km:Fa.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:Fa.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),label:"Focused Rider"}:ke?{orders:ke.orders.length,riders:ke.riders.size,km:ke.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),profit:ke.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),label:"Focused Kitchen"}:{orders:wa.totalOrders,riders:wa.totalRiders,km:wa.totalKms,profit:wa.totalProfit,label:"Total Fleet"}),[Fa,ke,wa]),Pa=(0,r.useMemo)((()=>{if(!Fa)return[];const e=new Set;return Fa.orders.forEach((s=>{null!=s.deliveryid&&""!==s.deliveryid&&0!==s.deliveryid&&e.add(String(s.deliveryid))})),Array.from(e)}),[Fa]),Da=(0,y.E)({queries:Pa.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,r=null!=s.outlierGate?s.outlierGate:9,n=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,r=Math.max(.001,(i-t)/1e3);if(W([e.lat,e.lng],[s.lat,s.lng])/r*3600<=n)break;if(c+2<a.length){const e=a[c+2],t=l(e)||i+1e3,r=Math.max(.001,(t-i)/1e3);if(W([s.lat,s.lng],[e.lat,e.lng])/r*3600<=n){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];W([i.lat,i.lng],[e.lat,e.lng])/t*3600>n||(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),n=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],n[0]=[i,0,0,1],c[0]=a[0].slice(),o[0]=n[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,[N,f,b,y]=n[g-1],k=m*m,S=k*m,w=N+m*(f+b)+k*y+S*m/4*t,F=f+m*y+S/2*t,_=b+m*y+S/2*t,M=y+k*t;c[g]=[x,j],o[g]=[w,F,_,M];const z=d[g][e]-x,C=w+i;if(z*z/C>r){a[g]=[x,j],n[g]=[w,F,_,M];continue}const A=w/C,P=_/C,D=x+A*z,E=j+P*z;a[g]=[D,E],n[g]=[(1-A)*w,(1-A)*F,_-P*w,M-P*F]}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,r,l]=n[t],d=s+e*i,m=i,p=r+e*l,h=l,[x,v,g,N]=o[t+1],f=x*N-v*g;if(!Number.isFinite(f)||Math.abs(f)<1e-30){j[t]=a[t].slice();continue}const b=N/f,y=-v/f,k=-g/f,S=x/f,w=d*b+m*k,F=d*y+m*S,_=p*b+h*k,M=p*y+h*S,z=j[t+1][0]-c[t+1][0],C=j[t+1][1]-c[t+1][1];j[t]=[a[t][0]+w*z+F*C,a[t][1]+_*z+M*C]}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,C)}))},enabled:Ls&&null!=Fa,staleTime:3e5,refetchOnWindowFocus:!1,retry:1})))}),Ea=(0,r.useMemo)((()=>{if(!Fa)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 Fa.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=Pa.indexOf(String(e.deliveryid)),t=a>=0?Da[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)||[]}}))}),[Fa,Pa,Da]),qa=(0,r.useMemo)((()=>Fa?Ea.map((e=>{const s=Fa.orders.find((s=>String(s.deliveryid)===String(e.deliveryid))),a=parseFloat((null===s||void 0===s?void 0:s.kms)||0)||0,t=Ns[e.deliveryid];let i=0;Array.isArray(t)&&t.length>=2?i=Z(t):null!=(null===s||void 0===s?void 0:s.actualkms)&&""!==s.actualkms?i=parseFloat(s.actualkms)||0:e.coords.length>=2&&(i=Z(e.coords.map((e=>[e.lat,e.lng]))));const r=i-a,n=a>0?r/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:r,kmDeltaPct:n,expectedTs:null!==l&&void 0!==l&&l.isValid()?l:null,actualTs:null!==c&&void 0!==c&&c.isValid()?c:null,timeDeltaMin:d,anomaly:o,orderstatus:e.orderstatus,deliverycustomer:e.deliverycustomer,pickupcustomer:null===s||void 0===s?void 0:s.pickupcustomer,isLoading:e.isLoading,coordsCount:e.coords.length}})):[]),[Ea,Fa,Ns]),La=(0,r.useMemo)((()=>{if(0===qa.length)return{plannedKm:0,actualKm:0,kmDeltaPct:null,anomalies:0,late:0,onTime:0};const e=qa.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}}),[qa]),Oa=(0,r.useMemo)((()=>[...qa].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)}))),[qa]),Ia=(0,r.useMemo)((()=>[...qa].sort(((e,s)=>e.sequenceStep-s.sequenceStep))),[qa]),Ra=(0,r.useMemo)((()=>{if(!Ls||!Qs||!Fa)return null;const e=Ea.find((e=>e.sequenceStep===Qs));if(!e)return null;const s=Fa.orders.find((s=>String(s.deliveryid)===String(e.deliveryid)));return s?{orders:[s],id:"cmp-step-".concat(Qs,"-").concat(s.orderid)}:null}),[Ls,Qs,Fa,Ea]);(0,r.useEffect)((()=>{ea(null),Bs(new Set),Rs("combined")}),[Ls,null===Fa||void 0===Fa?void 0:Fa.id]),(0,r.useEffect)((()=>{!Fa&&Ls&&Os(!1)}),[Fa,Ls]),(0,r.useEffect)((()=>{Gs.current&&Fa&&(Gs.current=!1,Os(!0))}),[Fa]),(0,r.useEffect)((()=>{Ls&&!Ws.current?($s.current=Js,Us(!0),Xs(!1)):!Ls&&Ws.current&&Us($s.current),Ws.current=Ls}),[Ls]);const Ta=(0,r.useCallback)((async(e,s,a)=>{const t="".concat(e,"-").concat(s);if(void 0!==gs.current[t])return;if(a.length<2)return;gs.current[t]=null,js((e=>(0,i.A)((0,i.A)({},e),{},{[t]:null})));const r=a.map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),n="https://router.project-osrm.org/route/v1/driving/".concat(r,"?overview=full&geometries=geojson");try{const e=await fetch(n),s=await e.json();if(s.routes&&s.routes[0]){const e=s.routes[0].geometry.coordinates.map((e=>[e[1],e[0]]));gs.current[t]=e,js((s=>(0,i.A)((0,i.A)({},s),{},{[t]:e})))}else gs.current[t]=!1,js((e=>(0,i.A)((0,i.A)({},e),{},{[t]:!1})))}catch(l){console.error("OSRM Fetch error:",l),gs.current[t]=!1,js((e=>(0,i.A)((0,i.A)({},e),{},{[t]:!1})))}}),[]);(0,r.useEffect)((()=>{gs.current={},js({}),bs.current={},fs({})}),[zs,ra]);const Ha=(0,r.useCallback)((async(e,s)=>{if(void 0!==bs.current[e])return;if(!Array.isArray(s)||s.length<2)return;bs.current[e]=null,fs((s=>(0,i.A)((0,i.A)({},s),{},{[e]:null})));const a=s=>{bs.current[e]=s,fs((a=>(0,i.A)((0,i.A)({},a),{},{[e]:s})))},t=()=>{bs.current[e]=!1,fs((s=>(0,i.A)((0,i.A)({},s),{},{[e]:!1})))},r=(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=r(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),n=await i.json();if(n.matchings&&n.matchings.length>0){const e=n.matchings.flatMap((e=>{var s;return((null===(s=e.geometry)||void 0===s?void 0:s.coordinates)||[]).map((e=>[e[1],e[0]]))}));if(e.length>=2)return void a(e)}}catch(n){console.warn("OSRM Match error, trying route fallback:",n)}try{const e=r(s,25).map((e=>"".concat(e[1],",").concat(e[0]))).join(";"),i="https://router.project-osrm.org/route/v1/driving/".concat(e,"?overview=full&geometries=geojson"),n=await fetch(i),l=await n.json();if(l.routes&&l.routes[0]){const e=l.routes[0].geometry.coordinates.map((e=>[e[1],e[0]]));if(e.length>=2)return void a(e)}t()}catch(n){console.error("OSRM Route fallback error:",n),t()}}),[]);(0,r.useEffect)((()=>{Ls&&Fa&&Ea.forEach((e=>{if(!e.deliveryid||e.coords.length<2)return;const s=e.coords.map((e=>[e.lat,e.lng]));Ha(e.deliveryid,s)}))}),[Ea,Ls,Fa,Ha]),(0,r.useEffect)((()=>{Ms.current=ys}),[ys]),(0,r.useEffect)((()=>{if(a)return;const e=()=>{const e=new Date;Re([e.getHours(),e.getMinutes(),e.getSeconds()].map((e=>String(e).padStart(2,"0"))).join(":"))},s=setInterval(e,1e3);return e(),()=>clearInterval(s)}),[a]),(0,r.useEffect)((()=>{fe(new Set(ya.map((e=>e.id))))}),[ya]),(0,r.useEffect)((()=>{ya.forEach((e=>{if(!Ne.has(e.id))return;if(Fa&&Fa.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))),r=se(i);r.length>=2&&Ta(e.id,a,r)}))}))}),[ya,Ne,Fa,Ta]);const Ya=(0,r.useRef)(null);(0,r.useEffect)((()=>{if(!ca)return;const e=()=>{const e=g()();return e.hour()+e.minute()/60};null===Ya.current&&(Ya.current=e());const s=setInterval((()=>{const s=e(),a=G(Ya.current,es),t=G(s,es);Ya.current=s,t&&t!==a&&na((e=>e===a?t:e))}),3e4);return()=>clearInterval(s)}),[ca,es]),(0,r.useEffect)((()=>{Me(null)}),[null===ke||void 0===ke?void 0:ke.id]),(0,r.useEffect)((()=>{const e=la.current;e&&"function"===typeof e.scrollIntoView&&e.scrollIntoView({behavior:"smooth",block:"nearest",inline:"center"})}),[ra]),(0,r.useEffect)((()=>{if(!_e)return;const e=setTimeout((()=>{var e;const s=null===Sa||void 0===Sa||null===(e=Sa.find)||void 0===e?void 0:e.call(Sa,(e=>String(e.orderid)===String(_e.orderid)));s&&Le(s)}),350);return()=>clearTimeout(e)}),[_e,Sa]);const Va=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>")})},Ka=e=>{var s;return(null===(s=ya.find((s=>s.id===e)))||void 0===s?void 0:s.color)||"#475569"},Ba=(e,s)=>{if(!e||!s||!q(s))return null;const a=ia.find((s=>String(s.id)===String(e)));if(!a)return null;const t=D(s.droplat||s.deliverylat),i=D(s.droplon||s.deliverylong);if(!Number.isFinite(t)||!Number.isFinite(i))return null;const r=W([a.lat,a.lon],[t,i]);return Math.round(1e3*r)},Ga=e=>null===e||void 0===e?"":e>=1e3?"".concat((e/1e3).toFixed(1)," km"):"".concat(e," m");return(0,_.jsxs)("div",{className:"dispatch-container".concat(a?" embedded":"").concat(Ls?" compare-open":""),children:[!a&&(0,_.jsxs)("div",{id:"hdr",children:[(0,_.jsxs)("div",{className:"logo",children:[(0,_.jsx)("div",{className:"logo-badge",children:"D"}),(0,_.jsx)("div",{className:"logo-name",children:"Dispatch"}),Te&&Te.length>0&&(0,_.jsxs)("div",{className:"logo-city-wrap",ref:Ge,children:[(0,_.jsxs)("button",{type:"button",className:"logo-city ".concat(Ke?"open":""),onClick:()=>Be((e=>!e)),"aria-haspopup":"listbox","aria-expanded":Ke,title:"Switch hub",children:[(0,_.jsx)(S.JFD,{}),(0,_.jsx)("span",{className:"logo-city-text",children:xs||"All locations"}),(0,_.jsx)(S.j1Q,{className:"logo-city-caret"})]}),Ke&&(0,_.jsx)("div",{className:"logo-city-menu",role:"listbox",children:Te.map((e=>{const s=String(e.applocationid)===String(Ye);return(0,_.jsxs)("button",{type:"button",role:"option","aria-selected":s,className:"logo-city-option ".concat(s?"active":""),onClick:()=>(e=>{if(z.A.info("Switching hub/location ID:",e),Ve(Number(e)),Be(!1),"undefined"!==typeof window)try{localStorage.setItem("applocationid",String(e))}catch(s){}_a(null),Se(null),Fe(null)})(e.applocationid),children:[(0,_.jsx)(S.JFD,{className:"logo-city-option-icon"}),(0,_.jsx)("span",{children:e.locationname}),s&&(0,_.jsx)("span",{className:"logo-city-option-check",children:"\u2713"})]},e.applocationid)}))})]}),(0,_.jsxs)("div",{id:"dispatch-top-tabs",className:"dtt-inline",children:[(0,_.jsxs)("button",{type:"button",className:"dtt-tab ".concat("live"===de?"active":""),onClick:()=>oe("live"),children:[(0,_.jsx)("span",{className:"dtt-icon",children:(0,_.jsx)(S.Cd7,{})}),"Live"]}),(0,_.jsxs)("button",{type:"button",className:"dtt-tab ".concat("analysis"===de?"active":""),onClick:()=>oe("analysis"),children:[(0,_.jsx)("span",{className:"dtt-icon",children:(0,_.jsx)(S.DX0,{})}),"Analysis"]})]})]}),(0,_.jsxs)("div",{className:"hdr-stats",children:[(()=>{const e=Aa.profit<0,s=Math.abs(Aa.profit);return(0,_.jsxs)("span",{className:"strat-stat ".concat(e?"strat-stat-loss":"strat-stat-profit"),title:"".concat(e?"Loss":"Profit"," (").concat(Aa.label,")"),children:[(0,_.jsx)("span",{className:"strat-stat-icon",children:e?(0,_.jsx)(S.Rod,{}):(0,_.jsx)(S.imn,{})}),(0,_.jsx)("span",{className:"strat-stat-label",children:e?"Loss":"Profit"}),(0,_.jsxs)("span",{className:"strat-stat-value",children:[e?"-":"","\u20b9",s.toFixed(0)]})]})})(),ca&&(0,_.jsxs)(_.Fragment,{children:[ua&&(0,_.jsxs)("span",{className:"live-status",children:[(0,_.jsx)("span",{className:"live-dot"})," Loading ",va.length?"\xb7 ".concat(va.length," loaded"):""]}),!ua&&!ma&&(0,_.jsxs)("span",{className:"live-status live-status-ready",children:[(0,_.jsx)("span",{className:"live-dot ready"})," ",Na.length," orders",(0,_.jsxs)("span",{className:"live-status-sub",children:[" / ",va.length," total"]})]}),ma&&(0,_.jsxs)("span",{className:"live-status live-status-error",children:[(0,_.jsx)("span",{className:"live-dot error"})," Failed to load"]}),(()=>{const e=g()().startOf("day"),s=e.format("YYYY-MM-DD"),a=g()(zs),t=zs===s,i=a.isAfter(e,"day"),r=s=>{if(!s)return;const a=s.format("YYYY-MM-DD");a!==zs?s.isAfter(e,"day")||(Cs(a),_a(null),Se(null),Fe(null),Ps(!1)):Ps(!1)},n=Ds.startOf("month"),l=n.subtract(n.day(),"day"),c=Array.from({length:42},((e,s)=>l.add(s,"day"))),d=!Ds.add(1,"month").startOf("month").isAfter(e,"month");return(0,_.jsxs)("div",{className:"date-chip".concat(t?" is-today":"").concat(As?" is-open":""),ref:qs,children:[(0,_.jsx)("button",{type:"button",className:"date-chip-nav",onClick:()=>r(a.subtract(1,"day")),"aria-label":"Previous day",title:"Previous day",children:(0,_.jsx)(S.E_E,{})}),(0,_.jsxs)("button",{type:"button",className:"date-chip-main",onClick:()=>Ps((e=>!e)),"aria-haspopup":"dialog","aria-expanded":As,children:[(0,_.jsx)("span",{className:"date-chip-icon","aria-hidden":"true",children:(0,_.jsx)(S.dDC,{})}),(0,_.jsxs)("span",{className:"date-chip-text",children:[(0,_.jsxs)("span",{className:"date-chip-label",children:["Date",t&&(0,_.jsx)("span",{className:"date-chip-today-pill",children:"Today"})]}),(0,_.jsx)("span",{className:"date-chip-value",children:a.isValid()?a.format("ddd, MMM D, YYYY"):"\u2014"})]}),(0,_.jsx)("span",{className:"date-chip-chevron".concat(As?" is-open":""),"aria-hidden":"true",children:(0,_.jsx)(S.j1Q,{})})]}),(0,_.jsx)("button",{type:"button",className:"date-chip-nav",onClick:()=>{t||i||r(a.add(1,"day"))},disabled:t||i,"aria-label":"Next day",title:t?"You're viewing today":"Next day",children:(0,_.jsx)(S.xVu,{})}),As&&(0,_.jsxs)("div",{className:"date-cal-popover",role:"dialog","aria-label":"Pick a date",children:[(0,_.jsxs)("div",{className:"date-cal-header",children:[(0,_.jsx)("button",{type:"button",className:"date-cal-nav",onClick:()=>Es((e=>e.subtract(1,"month"))),"aria-label":"Previous month",children:(0,_.jsx)(S.E_E,{})}),(0,_.jsx)("div",{className:"date-cal-title",children:Ds.format("MMMM YYYY")}),(0,_.jsx)("button",{type:"button",className:"date-cal-nav",onClick:()=>{const s=Ds.add(1,"month");s.startOf("month").isAfter(e,"month")||Es(s)},disabled:!d,"aria-label":"Next month",children:(0,_.jsx)(S.xVu,{})})]}),(0,_.jsx)("div",{className:"date-cal-weekdays",children:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"].map((e=>(0,_.jsx)("div",{className:"date-cal-weekday",children:e},e)))}),(0,_.jsx)("div",{className:"date-cal-grid",children:c.map((a=>{const t=a.month()===Ds.month(),i=a.format("YYYY-MM-DD")===zs,n=a.format("YYYY-MM-DD")===s,l=a.isAfter(e,"day"),c=["date-cal-day",!t&&"is-other-month",i&&"is-selected",n&&"is-today",l&&"is-disabled"].filter(Boolean).join(" ");return(0,_.jsx)("button",{type:"button",className:c,disabled:l,onClick:()=>r(a),"aria-current":n?"date":void 0,"aria-pressed":i,children:a.date()},a.format("YYYY-MM-DD"))}))}),(0,_.jsxs)("div",{className:"date-cal-presets",children:[(0,_.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>r(e),children:"Today"}),(0,_.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>r(e.subtract(1,"day")),children:"Yesterday"}),(0,_.jsx)("button",{type:"button",className:"date-cal-preset",onClick:()=>r(e.subtract(7,"day")),children:"\u22127 days"})]})]})]})})()]})]}),(0,_.jsx)("div",{id:"clock",children:Ie})]}),(a||"live"===de)&&(0,_.jsxs)(_.Fragment,{children:[(0,_.jsxs)("div",{id:"strat-row",children:[(0,_.jsxs)("button",{className:"sbt ".concat("kitchens"===J?"active":""),onClick:()=>{z.A.info("View mode changed: By Location"),ce("kitchens"),_a(null),Se(null),Fe(null)},children:[(0,_.jsx)("span",{className:"sbt-icon",children:(0,_.jsx)(S.JFD,{})})," By Location"]}),(0,_.jsxs)("button",{className:"sbt ".concat("zones"===J?"active":""),onClick:()=>{z.A.info("View mode changed: By Zone"),ce("zones"),_a(null),Se(null),Fe(null)},children:[(0,_.jsx)("span",{className:"sbt-icon",children:(0,_.jsx)(S.Cd7,{})})," By Zone"]}),(0,_.jsxs)("button",{className:"sbt ".concat("riders"===J?"active":""),onClick:()=>{z.A.info("View mode changed: By Rider"),ce("riders"),_a(null),Se(null),Fe(null)},children:[(0,_.jsx)("span",{className:"sbt-icon",children:(0,_.jsx)(S.bsz,{})})," By Rider"]}),(0,_.jsxs)("button",{className:"sbt ".concat("all"===J?"active":""),onClick:()=>{z.A.info("View mode changed: All Routes"),ce("all"),_a(null),Se(null),Fe(null)},children:[(0,_.jsx)("span",{className:"sbt-icon",children:(0,_.jsx)(S.Zs6,{})})," All Routes"]}),(0,_.jsxs)("button",{type:"button",className:"sbt sbt-rider-info ".concat("rider-info"===J?"active":""),onClick:()=>{ce("rider-info"),_a(null),Se(null),Fe(null)},title:"Live GPS / battery / status snapshot for a rider",children:[(0,_.jsx)("span",{className:"sbt-icon",children:(0,_.jsx)(S.k4P,{})})," Rider Info"]})]}),ca&&"rider-info"!==J&&(0,_.jsxs)("div",{id:"batch-row",children:[(0,_.jsx)("span",{className:"batch-label",children:"Batch"}),(0,_.jsx)("div",{className:"batch-scroll",children:es.map((e=>{var s;const a=ra===e.id;return(0,_.jsxs)("button",{ref:a?la:null,className:"batch-btn batch-slot ".concat(a?"active":""),onClick:()=>{na(e.id),_a(null),Se(null),Fe(null)},title:"".concat(e.label," (").concat(e.range,")"),children:[(0,_.jsx)("span",{className:"batch-btn-label",children:e.label}),(0,_.jsx)("span",{className:"batch-btn-count",children:null!==(s=ga[e.id])&&void 0!==s?s:0})]},e.id)}))})]}),"rider-info"===J?(0,_.jsxs)("div",{className:"rider-info-mode",children:[(0,_.jsxs)("div",{className:"ri-sidebar",children:[(0,_.jsxs)("div",{className:"ri-sb-head",children:[(0,_.jsx)("div",{className:"ri-sb-title",children:"Riders"}),(0,_.jsxs)("div",{className:"ri-sb-sub",children:[ja.length," ",1===ja.length?"rider":"riders"," today"]})]}),(0,_.jsxs)("div",{className:"ri-search",children:[(0,_.jsx)(S.gZ7,{className:"ri-search-icon"}),(0,_.jsx)("input",{type:"text",className:"ri-search-input",placeholder:"Search by name or ID",value:ls,onChange:e=>cs(e.target.value)})]}),(()=>{const e=ls.trim().toLowerCase(),s=ja.filter((s=>!e||(String(s.riderName||"").toLowerCase().includes(e)||String(s.id).includes(e))));return 0===s.length?(0,_.jsx)("div",{className:"ri-empty",children:ls?'No riders match "'.concat(ls,'"'):"No riders have orders today"}):(0,_.jsx)("div",{className:"ri-rider-list",children:s.map((e=>{const s=String(rs)===String(e.id);return(0,_.jsxs)("button",{type:"button",className:"ri-rider-item ".concat(s?"active":""),onClick:()=>ns(e.id),children:[(0,_.jsx)("span",{className:"ri-rider-dot",style:{background:te(e.id)}}),(0,_.jsxs)("span",{className:"ri-rider-info-block",children:[(0,_.jsx)("span",{className:"ri-rider-name",children:e.riderName}),(0,_.jsxs)("span",{className:"ri-rider-meta",children:["#",e.id]})]}),(0,_.jsx)("span",{className:"ri-rider-arrow",children:"\u2192"})]},e.id)}))})})()]}),(0,_.jsx)("div",{className:"ri-main",children:null==rs?(0,_.jsxs)("div",{className:"ri-placeholder",children:[(0,_.jsx)("div",{className:"ri-placeholder-icon",children:(0,_.jsx)(S.k4P,{})}),(0,_.jsx)("div",{className:"ri-placeholder-title",children:"Pick a rider"}),(0,_.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,_.jsxs)(_.Fragment,{children:[os&&!ds&&(0,_.jsx)("div",{className:"ri-loading",children:"Loading rider snapshot\u2026"}),us&&(0,_.jsxs)("div",{className:"ri-error",children:["Couldn't load this rider's log. ",(null===ms||void 0===ms?void 0:ms.message)||""]}),ds&&(()=>{const e=ds,s=parseFloat(e.latitude),a=parseFloat(e.longitude),t=Number.isFinite(s)&&Number.isFinite(a),i=parseInt(String(e.battery||"").replace("%",""),10),r=Number.isFinite(i)&&i<=20,n=parseFloat(e.speed),c=String(e.status||"").toLowerCase();return(0,_.jsxs)("div",{className:"ri-snapshot",children:[(0,_.jsxs)("div",{className:"ri-snap-head",children:[(0,_.jsx)("div",{className:"ri-snap-name",children:e.username||"Rider #".concat(e.userid)}),(0,_.jsxs)("div",{className:"ri-snap-meta",children:[(0,_.jsxs)("span",{children:["#",e.userid]}),e.status&&(0,_.jsx)("span",{className:"ri-status ri-status-".concat(c),children:e.status}),(0,_.jsxs)("span",{className:"ri-live ".concat(os?"is-refetching":""),children:[(0,_.jsx)("span",{className:"ri-live-dot"}),os?"Updating\u2026":"Live"]})]}),e.logdate&&(0,_.jsxs)("div",{className:"ri-snap-time",children:[(0,_.jsx)(S.VP9,{})," Last seen ",e.logdate]})]}),(0,_.jsxs)("div",{className:"ri-snap-grid",children:[(0,_.jsxs)("div",{className:"ri-stat ".concat(r?"ri-stat-warn":""),children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.wZm,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"Battery"}),(0,_.jsxs)("div",{className:"ri-stat-value",children:[e.battery||"\u2014",e.is_charging&&(0,_.jsx)("span",{className:"ri-stat-tag",children:"Charging"})]})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.Xh5,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"Connection"}),(0,_.jsx)("div",{className:"ri-stat-value",children:e.connection||"\u2014"})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.HPi,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"GPS Accuracy"}),(0,_.jsx)("div",{className:"ri-stat-value",children:e.accuracy?"".concat(e.accuracy," m"):"\u2014"})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.o8z,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"Location Service"}),(0,_.jsx)("div",{className:"ri-stat-value",children:e.location_service||"\u2014"})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.BJM,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"Speed"}),(0,_.jsx)("div",{className:"ri-stat-value",children:Number.isFinite(n)?"".concat(n.toFixed(2)," km/h"):"\u2014"})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.bqQ,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"Heading"}),(0,_.jsx)("div",{className:"ri-stat-value",children:null!=e.heading?"".concat(e.heading,"\xb0"):"\u2014"})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.pSF,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"App State"}),(0,_.jsx)("div",{className:"ri-stat-value",children:e.is_background?"Background":"Foreground"})]})]}),(0,_.jsxs)("div",{className:"ri-stat",children:[(0,_.jsx)("div",{className:"ri-stat-icon",children:(0,_.jsx)(S.gsJ,{})}),(0,_.jsxs)("div",{className:"ri-stat-body",children:[(0,_.jsx)("div",{className:"ri-stat-label",children:"Current Order"}),(0,_.jsx)("div",{className:"ri-stat-value",children:e.orderid||"\u2014"})]})]})]}),t&&(0,_.jsxs)("div",{className:"ri-map-section",children:[(0,_.jsxs)("div",{className:"ri-coords-label",children:[(0,_.jsx)(S.gwi,{})," ",s.toFixed(6),", ",a.toFixed(6)]}),(0,_.jsx)("div",{className:"ri-map",children:(0,_.jsxs)(d.W,{center:[s,a],zoom:13,scrollWheelZoom:!1,style:{height:"100%",width:"100%"},children:[(0,_.jsx)(o.e,{url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",attribution:"\xa9 OpenStreetMap contributors"}),(0,_.jsxs)(l.p,{position:[s,a],children:[(0,_.jsx)(u.m,{direction:"top",offset:[0,-10],permanent:!0,className:"ri-area-banner",children:(null===hs||void 0===hs?void 0:hs.area)||"Locating area\u2026"}),(0,_.jsxs)(m.z,{children:[(0,_.jsx)("div",{style:{fontWeight:700,marginBottom:2},children:e.username||"Rider #".concat(e.userid)}),(null===hs||void 0===hs?void 0:hs.area)&&(0,_.jsx)("div",{style:{fontSize:12,color:"#0f172a",marginBottom:4},children:hs.area}),(0,_.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,_.jsxs)("div",{id:"body",className:"".concat(Js?"sidebar-collapsed":""," ").concat(Ls?"compare-mode":""," ").concat(Ls&&Zs?"compare-data-collapsed":"").trim(),children:[(0,_.jsx)("button",{type:"button",className:"sidebar-toggle-tab".concat(Js?" is-collapsed":""),onClick:()=>Us((e=>!e)),title:Js?"Show sidebar":"Hide sidebar","aria-label":Js?"Show sidebar":"Hide sidebar",children:Js?(0,_.jsx)(S.xVu,{}):(0,_.jsx)(S.E_E,{})}),Ls&&Fa&&(0,_.jsx)("button",{type:"button",className:"compare-data-toggle-tab".concat(Zs?" is-collapsed":""),onClick:()=>Xs((e=>!e)),title:Zs?"Show details panel":"Hide details panel","aria-label":Zs?"Show details panel":"Hide details panel",children:Zs?(0,_.jsx)(S.E_E,{}):(0,_.jsx)(S.xVu,{})}),(0,_.jsxs)("div",{id:"sidebar",children:[!Fa&&(0,_.jsxs)("div",{className:"sb-header",children:[(0,_.jsxs)("div",{className:"sb-header-top",children:[(0,_.jsxs)("div",{className:"sb-header-title",children:[(0,_.jsx)("span",{className:"sb-title-bar","aria-hidden":"true"}),(0,_.jsx)("span",{className:"sb-title-text",children:"RIDER DISPATCH"})]}),(0,_.jsxs)("span",{className:"sb-header-scope",title:Aa.label,children:[(0,_.jsx)("span",{className:"sb-scope-dot"}),Aa.label]})]}),(0,_.jsxs)("div",{className:"sb-header-tiles",children:[(0,_.jsxs)("div",{className:"sb-tile sb-tile-orders",children:[(0,_.jsx)("span",{className:"sb-tile-icon",children:(0,_.jsx)(S.gsJ,{})}),(0,_.jsxs)("div",{className:"sb-tile-body",children:[(0,_.jsx)("div",{className:"sb-tile-value",children:Aa.orders}),(0,_.jsx)("div",{className:"sb-tile-label",children:1===Aa.orders?"Order":"Orders"})]})]}),(0,_.jsxs)("div",{className:"sb-tile sb-tile-riders",children:[(0,_.jsx)("span",{className:"sb-tile-icon",children:(0,_.jsx)(S.aVM,{})}),(0,_.jsxs)("div",{className:"sb-tile-body",children:[(0,_.jsx)("div",{className:"sb-tile-value",children:Aa.riders}),(0,_.jsx)("div",{className:"sb-tile-label",children:1===Aa.riders?"Rider":"Riders"})]})]})]})]}),Fa||ke?(0,_.jsxs)("div",{id:"route-detail",children:[(0,_.jsxs)("button",{className:"rd-back",onClick:()=>{_a(null),Se(null)},children:["\u2190 Back to ",we?we.name:"list"]}),Fa?(0,_.jsxs)(_.Fragment,{children:[(0,_.jsx)("div",{className:"rd-rider-name",style:{color:Fa.color},children:Fa.riderName}),(()=>{const e=Fa.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0),s=Fa.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0),a=s<0;return(0,_.jsxs)("div",{className:"rd-stats-grid",children:[(0,_.jsxs)("div",{className:"rd-stat rd-stat-orders",children:[(0,_.jsx)("div",{className:"rd-stat-icon",children:(0,_.jsx)(S.gsJ,{})}),(0,_.jsx)("div",{className:"rd-stat-value",children:Fa.orders.length}),(0,_.jsx)("div",{className:"rd-stat-label",children:"Orders"})]}),(0,_.jsxs)("div",{className:"rd-stat rd-stat-distance",children:[(0,_.jsx)("div",{className:"rd-stat-icon",children:(0,_.jsx)(S.xI$,{})}),(0,_.jsxs)("div",{className:"rd-stat-value",children:[e.toFixed(1),(0,_.jsx)("span",{className:"rd-stat-unit",children:"km"})]}),(0,_.jsx)("div",{className:"rd-stat-label",children:"Distance"})]}),(0,_.jsxs)("div",{className:"rd-stat rd-stat-profit ".concat(a?"is-loss":"is-gain"),children:[(0,_.jsx)("div",{className:"rd-stat-icon",children:a?(0,_.jsx)(S.Rod,{}):(0,_.jsx)(S.imn,{})}),(0,_.jsxs)("div",{className:"rd-stat-value",children:[a?"-":"","\u20b9",Math.abs(s).toFixed(0)]}),(0,_.jsx)("div",{className:"rd-stat-label",children:a?"Loss":"Profit"})]})]})})(),(()=>{const e={};Fa.orders.forEach((s=>{const a=s.trip_number||1;e[a]||(e[a]=[]),e[a].push(s)}));const s=[...Fa.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!F.Ys.has(s)&&!F.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"===ze;let n=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,_.jsxs)("div",{className:"trip-block",children:[(0,_.jsxs)("div",{className:"trip-header",style:{background:"".concat(Fa.color,"12"),borderColor:"".concat(Fa.color,"30")},children:[(0,_.jsxs)("span",{className:"th-badge",style:{background:Fa.color},children:["Trip ",s]}),(0,_.jsxs)("span",{className:"trip-stats",children:[(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.gwi,{})}),l.length," stops"]}),(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.xI$,{})}),l.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]})]}),(0,_.jsxs)("div",{className:"trip-sort-toggle",role:"group","aria-label":"Sort stops by","data-mode":i?"time":"planned",children:[(0,_.jsxs)("button",{type:"button",className:"trip-sort-pill ".concat(i?"":"is-active"),"aria-pressed":!i,onClick:()=>Ce("planned"),title:"Sort stops by planned step (dispatched order)",children:[(0,_.jsx)(S.EgJ,{"aria-hidden":"true"}),(0,_.jsx)("span",{children:"Planned"})]}),(0,_.jsxs)("button",{type:"button",className:"trip-sort-pill ".concat(i?"is-active":""),"aria-pressed":i,onClick:()=>Ce("time"),title:"Sort stops by completion time (which delivery was done first)",children:[(0,_.jsx)(S.VP9,{"aria-hidden":"true"}),(0,_.jsx)("span",{children:"By time"})]})]})]}),(0,_.jsx)("div",{className:"zone-order-grid",children:c.map(((e,t)=>{const l=(e.kitchen_key||e.pickupcustomer||"Unknown").toLowerCase().trim(),c=null!==n&&l!==n;n=l;const d=_e&&_e.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,F.Cx)(e.orderstatus),x=parseFloat(e.profit||0),v=x<0,g=Ba(Fa.id,e),N=i?t+1:e.step||t+1,f=i&&!e.deliverytime;return(0,_.jsxs)(r.Fragment,{children:[c&&(0,_.jsxs)("div",{className:"kitchen-transition",children:[(0,_.jsx)("span",{className:"kt-ico",children:(0,_.jsx)(S.$G1,{})})," Switch to ",(0,_.jsx)("strong",{children:e.pickupcustomer})]}),(0,_.jsxs)("div",{className:"zone-order-card ".concat(p?"clickable":""," ").concat(d?"active":""," ").concat(o?"going-on":""," ").concat(f?"is-pending-time":""),role:p?"button":void 0,tabIndex:p?0:void 0,onClick:p?()=>Me(d?null:{orderid:e.orderid,lat:u,lon:m}):void 0,onKeyDown:p?s=>{"Enter"!==s.key&&" "!==s.key||(s.preventDefault(),Me(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,_.jsxs)("div",{className:"zone-order-card-head",children:[(0,_.jsx)("div",{className:"zone-order-num ".concat(i?"is-time-rank":""),title:i?"Delivered #".concat(t+1," in this trip"):"Planned step ".concat(e.step||t+1),children:N}),(0,_.jsx)("div",{className:"zone-order-id-block",children:(0,_.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]})}),(()=>{const s=Q(e.deliverytime),a=Q(e.expecteddeliverytime),t=!F.Ys.has(String(e.orderstatus||"").toLowerCase())&&null!==g;return e.orderstatus||s||a||t?(0,_.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,_.jsx)("span",{className:"zone-order-status",style:{background:h.bg,color:h.fg},children:h.label}),(s||a)&&(0,_.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(a),children:[(0,_.jsx)(S.VP9,{}),s||a]}),t&&(0,_.jsxs)("span",{className:"zone-order-est-drop",title:"Estimated distance to drop location",children:[(0,_.jsx)(S.HPi,{}),Ga(g)]})]}):null})(),j&&(0,_.jsx)("button",{type:"button",className:"zone-order-change-rider",title:"Change rider",onClick:s=>{s.stopPropagation(),j(e,Fa)},children:(0,_.jsx)(S.$G1,{})})]}),(0,_.jsxs)("div",{className:"zone-order-customer",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,_.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,_.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.gwi,{})}),e.deliverysuburb||E(e.deliveryaddress)]}),e.ordernotes&&(0,_.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.dKO,{})}),e.ordernotes]}),(0,_.jsxs)("div",{className:"zone-order-stats",children:[(0,_.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,_.jsxs)("span",{className:"zone-order-chip ".concat(v?"is-loss":"is-profit"),title:"Profit",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.ohY,{})}),v?"-":"","\u20b9",Math.abs(x).toFixed(0)]}),null!=e.deliverycharge&&(0,_.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,_.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,_.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,_.jsxs)(_.Fragment,{children:[(0,_.jsx)("div",{className:"rd-rider-name",style:{color:"#f59e0b"},children:ke.kitchenName}),(0,_.jsxs)("div",{className:"rd-rider-sub",children:[(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.gsJ,{})}),ke.orders.length," orders"]}),(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.aVM,{})}),ke.riders.size," riders"]})]}),(0,_.jsxs)("div",{className:"zone-detail-section",children:[(0,_.jsxs)("div",{className:"zone-section-label",children:["Orders ",(0,_.jsxs)("span",{className:"section-count",children:["(",ke.orders.length,")"]})]}),0===ke.orders.length?(0,_.jsx)("div",{className:"zone-suburb-panel-empty",children:"No orders for this kitchen."}):(0,_.jsx)("div",{className:"zone-order-grid",children:ke.orders.map(((e,s)=>{const a=parseFloat(e.droplat||e.deliverylat),t=parseFloat(e.droplon||e.deliverylong),i=Number.isFinite(a)&&Number.isFinite(t),r=_e&&_e.orderid===e.orderid,n=(0,F.Cx)(e.orderstatus),l=parseFloat(e.profit||0),c=l<0,d=e.rider_id||e.userid,o=d?ya.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!F.Ys.has(s)&&!F.yP.has(s)}));return e?e.orderid:null})(),m=u&&e.orderid===u,p=d?Ba(d,e):null;return(0,_.jsxs)("div",{className:"zone-order-card ".concat(i?"clickable":""," ").concat(r?"active":""," ").concat(m?"going-on":""),role:i?"button":void 0,tabIndex:i?0:void 0,onClick:i?()=>Me(r?null:{orderid:e.orderid,lat:a,lon:t}):void 0,children:[(0,_.jsxs)("div",{className:"zone-order-card-head",children:[(0,_.jsx)("div",{className:"zone-order-num",children:e.step||s+1}),(0,_.jsxs)("div",{className:"zone-order-id-block",children:[(0,_.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]}),(0,_.jsxs)("div",{className:"zone-order-rider",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.aVM,{})}),e.rider_name||e.ridername||"Unassigned"]})]}),(()=>{const s=Q(e.deliverytime),a=Q(e.expecteddeliverytime),t=!F.Ys.has(String(e.orderstatus||"").toLowerCase())&&null!==p;return e.orderstatus||s||a||t?(0,_.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,_.jsx)("span",{className:"zone-order-status",style:{background:n.bg,color:n.fg},children:n.label}),(s||a)&&(0,_.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(a),children:[(0,_.jsx)(S.VP9,{}),s||a]}),t&&(0,_.jsxs)("span",{className:"zone-order-est-drop",title:"Estimated distance to drop location",children:[(0,_.jsx)(S.HPi,{}),Ga(p)]})]}):null})()]}),(0,_.jsxs)("div",{className:"zone-order-customer",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,_.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,_.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.gwi,{})}),e.deliverysuburb||E(e.deliveryaddress)]}),e.ordernotes&&(0,_.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.dKO,{})}),e.ordernotes]}),(0,_.jsxs)("div",{className:"zone-order-stats",children:[(0,_.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,_.jsxs)("span",{className:"zone-order-chip ".concat(c?"is-loss":"is-profit"),title:"Profit",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.ohY,{})}),c?"-":"","\u20b9",Math.abs(l).toFixed(0)]}),null!=e.deliverycharge&&(0,_.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,_.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,_.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||"-"," \xb7 S",e.step||s+1]})]})]},e.orderid)}))})]})]})]}):we?(0,_.jsxs)("div",{id:"route-detail",children:[(0,_.jsx)("button",{className:"rd-back",onClick:()=>Fe(null),children:"\u2190 Back to zones"}),(0,_.jsx)("div",{className:"rd-rider-name",style:{color:"#3b82f6"},children:we.name}),(0,_.jsx)("div",{className:"rd-rider-sub",children:(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.gsJ,{})}),we.totalOrders," ",1===we.totalOrders?"order":"orders"]})}),(0,_.jsxs)("div",{className:"zone-detail-section",children:[(0,_.jsxs)("div",{className:"zone-section-label",children:["Orders ",(0,_.jsxs)("span",{className:"section-count",children:["(",we.orders.length,")"]})]}),0===we.orders.length?(0,_.jsx)("div",{className:"zone-suburb-panel-empty",children:"No orders in this zone."}):(0,_.jsx)("div",{className:"zone-order-grid",children:we.orders.map(((e,s)=>{const a=parseFloat(e.droplat||e.deliverylat),t=parseFloat(e.droplon||e.deliverylong),i=Number.isFinite(a)&&Number.isFinite(t),r=_e&&_e.orderid===e.orderid,n=(0,F.Cx)(e.orderstatus),l=parseFloat(e.profit||0),c=l<0,d=e.rider_id||e.userid,o=d?ya.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!F.Ys.has(s)&&!F.yP.has(s)}));return e?e.orderid:null})(),m=u&&e.orderid===u,p=d?Ba(d,e):null;return(0,_.jsxs)("div",{className:"zone-order-card ".concat(i?"clickable":""," ").concat(r?"active":""," ").concat(m?"going-on":""),role:i?"button":void 0,tabIndex:i?0:void 0,onClick:i?()=>Me(r?null:{orderid:e.orderid,lat:a,lon:t}):void 0,children:[(0,_.jsxs)("div",{className:"zone-order-card-head",children:[(0,_.jsx)("div",{className:"zone-order-num",children:e.step||s+1}),(0,_.jsxs)("div",{className:"zone-order-id-block",children:[(0,_.jsxs)("div",{className:"zone-order-id",children:["Order #",e.orderid]}),(0,_.jsxs)("div",{className:"zone-order-rider",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.aVM,{})}),e.rider_name||e.ridername||"Unassigned"]})]}),(()=>{const s=Q(e.deliverytime),a=Q(e.expecteddeliverytime),t=!F.Ys.has(String(e.orderstatus||"").toLowerCase())&&null!==p;return e.orderstatus||s||a||t?(0,_.jsxs)("div",{className:"zone-order-status-stack",children:[e.orderstatus&&(0,_.jsx)("span",{className:"zone-order-status",style:{background:n.bg,color:n.fg},children:n.label}),(s||a)&&(0,_.jsxs)("span",{className:"zone-order-time ".concat(s?"":"is-expected"),title:s?"Delivered at ".concat(s):"Expected at ".concat(a),children:[(0,_.jsx)(S.VP9,{}),s||a]}),t&&(0,_.jsxs)("span",{className:"zone-order-est-drop",title:"Estimated distance to drop location",children:[(0,_.jsx)(S.HPi,{}),Ga(p)]})]}):null})()]}),(0,_.jsxs)("div",{className:"zone-order-customer",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.u9F,{})}),e.deliverycustomer||"\u2014"]}),e.pickupcustomer&&(0,_.jsxs)("div",{className:"zone-order-line",title:"Kitchen: ".concat(e.pickupcustomer),children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.NtI,{})}),e.pickupcustomer]}),(e.deliverysuburb||e.deliveryaddress)&&(0,_.jsxs)("div",{className:"zone-order-line",title:e.deliveryaddress||e.deliverysuburb,children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.gwi,{})}),e.deliverysuburb||E(e.deliveryaddress)]}),e.ordernotes&&(0,_.jsxs)("div",{className:"zone-order-line zone-order-notes",title:e.ordernotes,children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.dKO,{})}),e.ordernotes]}),(0,_.jsxs)("div",{className:"zone-order-stats",children:[(0,_.jsxs)("span",{className:"zone-order-chip",title:"Distance",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.xI$,{})}),e.actualkms||e.kms||0," km"]}),(0,_.jsxs)("span",{className:"zone-order-chip ".concat(c?"is-loss":"is-profit"),title:"Profit",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.ohY,{})}),c?"-":"","\u20b9",Math.abs(l).toFixed(0)]}),null!=e.deliverycharge&&(0,_.jsxs)("span",{className:"zone-order-chip",title:"Delivery charge",children:["\u20b9",parseFloat(e.deliverycharge).toFixed(0)," chg"]}),e.ordertype&&(0,_.jsx)("span",{className:"zone-order-chip zone-order-type type-".concat(String(e.ordertype).toLowerCase()),children:e.ordertype}),(0,_.jsxs)("span",{className:"zone-order-chip zone-order-trip",children:["T",e.trip_number||"-"," \xb7 S",e.step||s+1]})]})]},e.orderid)}))})]})]}):(0,_.jsxs)("div",{id:"riders-panel",children:[(0,_.jsx)("div",{className:"ph",children:"zones"===J?"Zone dispatch":"kitchens"===J?"Kitchen dispatch":"Rider dispatch"}),(0,_.jsx)("div",{id:"rider-cards",children:0!==Sa.length||ua?"zones"===J?ba.map(((e,s)=>{const a=e.statusCounts.delivered||0,t=e.totalProfit<0;return(0,_.jsxs)("div",{className:"rcard zone-card",onClick:()=>Fe(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,_.jsxs)("div",{className:"zone-card-header",children:[(0,_.jsx)("div",{className:"zone-card-emoji",children:(0,_.jsx)(S.Cd7,{})}),(0,_.jsxs)("div",{className:"zone-card-titles",children:[(0,_.jsx)("div",{className:"zone-card-name",children:e.name}),(0,_.jsxs)("div",{className:"zone-card-sub",children:[e.activeRidersCount," ",1===e.activeRidersCount?"rider":"riders"," \xb7 ",e.totalOrders," ",1===e.totalOrders?"order":"orders"]})]}),(0,_.jsx)("span",{className:"zone-card-arrow","aria-hidden":"true",children:"\u2192"})]}),e.totalOrders>0&&(0,_.jsxs)("div",{className:"zone-progress-row",children:[(0,_.jsx)("div",{className:"zone-status-bar",title:Object.entries(e.statusCounts).map((e=>{let[s,a]=e;return"".concat((0,F.Cx)(s).label,": ").concat(a)})).join(" \xb7 "),children:Object.entries(e.statusCounts).map((s=>{let[a,t]=s;const i=(0,F.Cx)(a),r=t/e.totalOrders*100;return(0,_.jsx)("div",{className:"zone-status-seg",style:{width:"".concat(r,"%"),background:i.bg}},a)}))}),(0,_.jsxs)("div",{className:"zone-progress-label",children:[a,"/",e.totalOrders]})]}),(0,_.jsxs)("div",{className:"zone-stat-pills",children:[(0,_.jsxs)("span",{className:"zone-stat-pill",title:"Areas covered",children:[(0,_.jsx)("span",{className:"zone-stat-icon",children:(0,_.jsx)(S.gwi,{})}),(0,_.jsx)("span",{className:"zone-stat-value",children:e.suburbs.length}),(0,_.jsx)("span",{className:"zone-stat-label",children:1===e.suburbs.length?"area":"areas"})]}),(0,_.jsxs)("span",{className:"zone-stat-pill",title:"Total distance",children:[(0,_.jsx)("span",{className:"zone-stat-icon",children:(0,_.jsx)(S.xI$,{})}),(0,_.jsx)("span",{className:"zone-stat-value",children:e.totalKms.toFixed(1)}),(0,_.jsx)("span",{className:"zone-stat-label",children:"km"})]}),(0,_.jsxs)("span",{className:"zone-stat-pill",title:"Kitchens",children:[(0,_.jsx)("span",{className:"zone-stat-icon",children:(0,_.jsx)(S.NtI,{})}),(0,_.jsx)("span",{className:"zone-stat-value",children:e.kitchens.length}),(0,_.jsx)("span",{className:"zone-stat-label",children:1===e.kitchens.length?"kitchen":"kitchens"})]}),(0,_.jsxs)("span",{className:"zone-stat-pill ".concat(t?"profit-negative":"profit-positive"),title:"Total profit",children:[(0,_.jsx)("span",{className:"zone-stat-icon",children:(0,_.jsx)(S.ohY,{})}),(0,_.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,_.jsxs)("div",{className:"zone-card-suburbs",children:[(0,_.jsx)("span",{className:"zone-card-suburbs-text",children:e.suburbs.slice(0,3).map((e=>e.name)).join(" \xb7 ")}),e.suburbs.length>3&&(0,_.jsxs)("span",{className:"zone-card-suburbs-more",children:["+",e.suburbs.length-3]})]})]},e.id)})):"kitchens"===J?ka.map(((e,s)=>(0,_.jsxs)("div",{className:"rcard",onClick:()=>Se(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,_.jsxs)("div",{className:"rcard-top",children:[(0,_.jsx)("div",{className:"rcard-emo",style:{background:"#f59e0b18",borderColor:"#f59e0b50",color:"#f59e0b"},children:(0,_.jsx)(S.NtI,{})}),(0,_.jsxs)("div",{className:"rcard-info",children:[(0,_.jsx)("div",{className:"rcard-name",children:e.kitchenName}),(0,_.jsxs)("div",{className:"rcard-zone",children:[e.riders.size," riders \xb7 ",(0,_.jsx)(re,{children:(0,_.jsx)(S.ohY,{})}),"\u20b9",e.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0).toFixed(0)]})]}),(0,_.jsx)("div",{className:"rcard-badge",style:{background:"#f59e0b18",color:"#f59e0b"},children:e.orders.length})]}),(0,_.jsx)("div",{className:"bar-bg",children:(0,_.jsx)("div",{className:"bar-fg",style:{width:"".concat(Math.min(100,e.orders.length/20*100),"%"),background:"#f59e0b"}})}),(0,_.jsxs)("div",{className:"rcard-meta",children:[(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.xI$,{})}),e.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]}),(0,_.jsxs)("span",{children:[e.riders.size," riders"]})]}),(0,_.jsx)("div",{className:"step-ids",children:Array.from(e.riders).slice(0,10).map((e=>{var s;return(0,_.jsx)("span",{className:"step-id",style:{color:Ka(e)},children:null===(s=ya.find((s=>s.id===e)))||void 0===s?void 0:s.riderName.split(" ")[0]},e)}))})]},e.id))):ya.map(((e,s)=>{var a;const t=e.orders.length,i=e.orders.filter((e=>F.Ys.has(String(e.orderstatus||"").toLowerCase()))).length,r=t>0&&i>=t,n=e.orders.find((e=>{const s=String(e.orderstatus||"").toLowerCase();return!F.Ys.has(s)&&!F.yP.has(s)})),l=n?Ba(e.id,n):null;return(0,_.jsxs)("div",{className:"rcard",onClick:()=>_a(e),style:{animationDelay:"".concat(.05*s,"s")},children:[(0,_.jsxs)("div",{className:"rcard-top",children:[(0,_.jsx)("div",{className:"rcard-emo",style:{background:"".concat(e.color,"18"),borderColor:"".concat(e.color,"50"),color:e.color},children:(0,_.jsx)(S.aVM,{})}),(0,_.jsxs)("div",{className:"rcard-info",children:[(0,_.jsx)("div",{className:"rcard-name",children:e.riderName}),(0,_.jsxs)("div",{className:"rcard-zone",children:[(null===(a=e.orders[0])||void 0===a?void 0:a.zone_name)||xs||"Local"," \xb7 ",new Set(e.orders.map((e=>e.trip_number||1))).size," trips"]})]}),(0,_.jsxs)("div",{className:"rcard-badge ".concat(r?"is-done":""),style:r?void 0:{background:"".concat(e.color,"18"),color:e.color},title:"".concat(i," delivered of ").concat(t," total"),children:[i,"/",t]})]}),(0,_.jsx)("div",{className:"bar-bg",children:(0,_.jsx)("div",{className:"bar-fg",style:{width:"".concat(Math.min(100,t/15*100),"%"),background:e.color}})}),(0,_.jsxs)("div",{className:"rcard-meta",children:[(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.xI$,{})}),e.orders.reduce(((e,s)=>e+parseFloat(s.actualkms||s.kms||0)),0).toFixed(1)," km"]}),null!==l&&(0,_.jsxs)("span",{className:"rcard-est-meters",title:"Estimated distance to next drop location",children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.HPi,{})}),Ga(l)," to drop"]}),(0,_.jsxs)("span",{children:[(0,_.jsx)(re,{children:(0,_.jsx)(S.ohY,{})}),"\u20b9",e.orders.reduce(((e,s)=>e+parseFloat(s.profit||0)),0).toFixed(0)]})]}),(0,_.jsx)("div",{className:"step-ids",children:e.orders.slice(0,15).map((e=>(0,_.jsxs)("span",{className:"step-id",children:["S",e.step]},e.orderid)))})]},e.id)})):(e=>{const s=null===(e=es.find((e=>e.id===ra)))||void 0===e?void 0:e.label,a=ca&&va.length>0;return(0,_.jsxs)("div",{className:"empty-slot",children:[(0,_.jsx)("div",{className:"empty-slot-icon",children:(0,_.jsx)(S.gsJ,{})}),(0,_.jsx)("div",{className:"empty-slot-title",children:s?"No orders in ".concat(s):"No orders"}),(0,_.jsx)("div",{className:"empty-slot-sub",children:a?"".concat(va.length," order").concat(1===va.length?"":"s"," exist in other slots today"):"No deliveries found for this date"})]})})()})]})]}),(0,_.jsxs)("div",{id:"map-wrap",className:"".concat("kitchens"===J?"view-mode-kitchens":""," ").concat(Ls?"compare-split":"").trim(),children:[(0,_.jsxs)(d.W,{center:[11.022,76.982],zoom:12,scrollWheelZoom:!0,style:{height:"100%",width:"100%"},zoomControl:!1,renderer:aa.current,inertia:!0,inertiaDeceleration:2400,inertiaMaxSpeed:2e3,wheelDebounceTime:20,wheelPxPerZoomLevel:80,zoomSnap:.25,children:[(0,_.jsx)(o.e,{url:"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",attribution:"\xa9 OpenStreetMap contributors"}),(0,_.jsx)(p.p,{position:"bottomright"}),Ls&&(0,_.jsx)($,{targetRef:sa}),(0,_.jsx)(ie,{focusedItem:Ra||(Fa||ke)&&_e||Fa||ke||we,viewMode:J,orders:Sa,kitchens:ka,locationKey:Ye}),ka.filter((e=>Number.isFinite(e.lat)&&Number.isFinite(e.lon))).filter((e=>!Fa||e.riders.has(Fa.id))).map(((e,s)=>(0,_.jsx)(l.p,{position:[e.lat,e.lon],icon:Va(e.kitchenName,(null===ke||void 0===ke?void 0:ke.id)===e.id),zIndexOffset:(null===ke||void 0===ke?void 0:ke.id)===e.id?4e3:2e3,eventHandlers:{click:()=>Se(e),mouseover:e=>e.target.openPopup(),mouseout:e=>e.target.closePopup()},children:(0,_.jsxs)(m.z,{className:"kitchen-popup",maxWidth:220,minWidth:200,autoPan:!0,autoPanPadding:[20,20],children:[(0,_.jsx)("div",{className:"kp-header",children:"KITCHEN"}),(0,_.jsx)("div",{className:"kp-name",children:e.kitchenName}),(0,_.jsxs)("div",{className:"kp-stat",children:[(0,_.jsx)("span",{className:"kp-stat-lbl",children:"Orders"}),(0,_.jsx)("span",{className:"kp-stat-val",children:e.orders.length})]})]})},"k-".concat(s)))),(()=>{if(Ls&&Fa&&"actual"===Is)return null;let e=Sa;we&&(e=we.orders),ke&&(e=ke.orders),Fa&&(e=Fa.orders),e=e.filter(q);const s=Ls&&Fa?new Map(Ea.map((e=>[String(e.deliveryid),e.sequenceStep]))):null;return e.map(((a,t)=>{const i=a.rider_id,r=!i||Ne.has(i);let n,c=Ka(i);if(s&&i===Fa.id&&null!=a.deliveryid){const e=s.get(String(a.deliveryid));e&&(c=(0,F.gM)(e-1),n=e)}const d=!!Fa||!!ke,o=(0,F.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=n||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(r?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(r?1:.75,'">').concat(p,"</div>")});return(0,_.jsx)(l.p,{position:[parseFloat(a.droplat||a.deliverylat),parseFloat(a.droplon||a.deliverylong)],icon:h,zIndexOffset:i?100:0,ref:e=>{e?Ae.current[String(a.orderid)]=e:delete Ae.current[String(a.orderid)]},eventHandlers:{click:()=>{const e=String(a.orderid);Pe.current.has(e)?(Pe.current.delete(e),Le(null)):(Pe.current.add(e),Le(a))}}},"".concat(a.orderid,"-").concat(d?"num":"flag"))}))})(),(()=>{const e=Ls&&Fa&&"actual"===Is;if(ys)return e?[]:Ss.map(((e,s)=>(0,_.jsx)(c.R,{positions:[e.from,e.to],pathOptions:{color:e.color,weight:6,opacity:.9,lineJoin:"round",lineCap:"round"}},s)));const s=[],a=we?new Set(we.riders.map((e=>String(e.rider_id)))):null;return e||ya.forEach((e=>{const t=Ne.has(e.id);if(Fa&&Fa.id!==e.id)return;if(ke&&!ke.riders.has(e.id))return;if(a&&!a.has(String(e.id)))return;const i=e.orders,n={};i.forEach((e=>{const s=e.trip_number||1;n[s]||(n[s]=[]),n[s].push(e)})),Object.entries(n).forEach((a=>{let[i,n]=a;const l=ke?n.filter((e=>(e.pickupcustomer||e.kitchen_key||"Unknown").toLowerCase().trim()===ke.id)):n;if(0===l.length)return;const d="".concat(e.id,"-").concat(i),o=vs[d],u=[...l].sort(((e,s)=>(e.step||0)-(s.step||0))),m=Array.isArray(o)&&o.length>=2,p=!1===o;if(!m&&!p)return;const h=m?o:se(u);if(!h||h.length<2)return;const x=t?1:.1,v="kitchens"===J||ke?7:6,j=Ls&&Fa&&e.id===Fa.id,g=p?"8 6":j&&"combined"===Is?"6 5":void 0;if(Ls&&Fa&&e.id===Fa.id){const a=new Map(Ea.map((e=>[String(e.deliveryid),e.sequenceStep]))),t=u.filter(q),r=t.map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)]));let n;if(m)n=X(h,r);else{const e=h.length>r.length;n=[];for(let s=0;s<r.length;s++){const a=e?s:s-1,t=e?s+1:s;a<0||a>=h.length||t>=h.length?n.push([]):n.push([h[a],h[t]])}}const l="combined"===Is?5:0;return s.push((0,_.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:v+4,opacity:.5*x,lineJoin:"round",lineCap:"round",offset:l}},"".concat(e.id,"-").concat(i,"-halo"))),void n.forEach(((r,n)=>{if(!r||r.length<2)return;const d=t[n],o=d?a.get(String(d.deliveryid)):null,u="combined"===Is?A:o?(0,F.gM)(o-1):e.color,m=null!=Qs&&Qs===o,p=m?v+1.5:v,h=m?1:Qs?.5*x:x;s.push((0,_.jsx)(c.R,{positions:r,pathOptions:{color:u,weight:p,opacity:h,lineJoin:"round",lineCap:"round",dashArray:g,offset:l}},"".concat(e.id,"-").concat(i,"-step-").concat(n,"-").concat((null===d||void 0===d?void 0:d.deliveryid)||n)))}))}s.push((0,_.jsxs)(r.Fragment,{children:[(0,_.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:v+4,opacity:.5*x,lineJoin:"round",lineCap:"round"}}),(0,_.jsx)(c.R,{positions:h,pathOptions:{color:e.color,weight:v,opacity:x,lineJoin:"round",lineCap:"round",dashArray:g}})]},"".concat(e.id,"-").concat(i)))}))})),s})(),ia.filter((e=>ya.some((s=>String(s.id)===String(e.id))))).filter((e=>!Fa||String(Fa.id)===String(e.id))).map((e=>{var s;const a="active"===e.status?"#16a34a":"#dc2626",t=ya.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!F.Ys.has(s)&&!F.yP.has(s)})),r=i?i.deliverysuburb||E(i.deliveryaddress):null,n=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,_.jsx)(l.p,{position:[e.lat,e.lon],icon:n,zIndexOffset:2500,eventHandlers:{click:s=>{const a=String(e.id);De.current.has(a)?(De.current.delete(a),s.target.closePopup()):(De.current.add(a),s.target.openPopup());const t=ya.find((e=>String(e.id)===a));t&&_a(t)},popupclose:()=>{De.current.delete(String(e.id))}},children:(0,_.jsxs)(m.z,{maxWidth:260,autoPan:!0,autoPanPadding:[20,20],className:"dispatch-popup live-rider-popup",children:[(0,_.jsx)("div",{className:"pu-hdr-live",children:(0,_.jsxs)("div",{className:"pu-hdr-left",children:[(0,_.jsx)("span",{className:"pu-live-indicator",style:{"--pulse-color":a},children:(0,_.jsx)("span",{className:"pu-live-dot"})}),(0,_.jsx)("span",{className:"pu-hdr-title",children:"LIVE GPS"})]})}),(0,_.jsxs)("div",{className:"pu-rider-profile",children:[(0,_.jsx)("div",{className:"pu-avatar",style:{backgroundColor:"".concat(a,"12"),color:a},children:(0,_.jsx)(S.bsz,{})}),(0,_.jsxs)("div",{className:"pu-rider-info-text",children:[(0,_.jsxs)("div",{className:"pu-rider-name-row",children:[(0,_.jsx)("span",{className:"pu-rider-name",children:e.username||"Rider #".concat(e.id)}),e.status&&(0,_.jsx)("span",{className:"pu-status-badge ".concat("active"===e.status.toLowerCase()?"active":"idle"),children:e.status})]}),(0,_.jsxs)("div",{className:"pu-rider-meta",children:["Rider ID: #",e.id]})]})]}),(0,_.jsxs)("div",{className:"pu-body-content",children:[e.orderid&&(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Active Order"}),(0,_.jsxs)("span",{className:"pu-info-value pu-order-badge",children:["#",e.orderid]})]}),i&&(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Next Stop"}),(0,_.jsxs)("span",{className:"pu-info-value",style:{color:"#4f46e5"},children:["#",i.step||"?"," \xb7 ",i.deliverycustomer||"\u2014"]})]}),r&&(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Next Location"}),(0,_.jsx)("span",{className:"pu-info-value",title:i.deliveryaddress||r,children:r})]}),(null===i||void 0===i?void 0:i.pickupcustomer)&&(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Pickup"}),(0,_.jsx)("span",{className:"pu-info-value",title:i.pickupcustomer,children:i.pickupcustomer})]}),e.contactno&&(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Phone"}),(0,_.jsx)("a",{href:"tel:".concat(e.contactno),className:"pu-info-value pu-phone-link",children:e.contactno})]}),e.logdate&&(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Last Seen"}),(0,_.jsxs)("span",{className:"pu-info-value pu-time-stamp",children:[(0,_.jsx)(S.VP9,{className:"inline-icon"})," ",g()(e.logdate).isValid()?g()(e.logdate).format("hh:mm:ss A"):e.logdate]})]}),(0,_.jsxs)("div",{className:"pu-info-row",children:[(0,_.jsx)("span",{className:"pu-info-label",children:"Position"}),(0,_.jsxs)("span",{className:"pu-info-value pu-coordinates",children:[e.lat.toFixed(5),", ",e.lon.toFixed(5)]})]})]})]})},"live-".concat(e.id))})),Ls&&Fa&&"planned"!==Is&&Ea.map(((e,s)=>{var a,t;if(0===e.coords.length)return null;const i=(0,F.gM)(s),n="combined"===Is?P: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=Ns[e.deliveryid],p=Array.isArray(m)&&m.length>=2?m:e.coords.map((e=>[e.lat,e.lng]));let h=p,v=!0;if(ys){const s=Fs[e.sequenceStep]||0;s<2?v=!1:h=p.slice(0,Math.min(s,p.length))}const j=Qs===e.sequenceStep,N=String(e.orderstatus||"").toLowerCase(),f=F.Ys.has(N),b=F.yP.has(N),y=qa.find((s=>s.sequenceStep===e.sequenceStep)),k=!(null===y||void 0===y||!y.anomaly),w=null===Fa||void 0===Fa||null===(a=Fa.orders)||void 0===a?void 0:a.find((s=>null!=s.deliveryid&&String(s.deliveryid)===String(e.deliveryid))),M=(0,F.Cx)(e.orderstatus),z=(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(M.bg,'" stroke="#0f172a" stroke-width="0.6" stroke-linejoin="round"/>\n ').concat(f?'<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&&z.push("is-focused"),f&&z.push("is-delivered"),b&&z.push("is-skipped"),k&&z.push("is-anomaly");const C='<div class="'.concat(z.join(" "),'" style="--pin-color:').concat(i,'">')+'<span class="compare-step-pin-num">'.concat(e.sequenceStep,"</span>")+(f?'<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:C}),D=1===e.sequenceStep,E=D?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,q="combined"===Is?-5:0;return(0,_.jsxs)(r.Fragment,{children:[v&&(0,_.jsx)(c.R,{positions:h,pathOptions:{color:"#ffffff",weight:j?11:9,opacity:j?.75:.55,lineJoin:"round",lineCap:"round",offset:q}}),v&&(0,_.jsx)(c.R,{positions:h,pathOptions:{color:n,weight:j?6.5:5,opacity:j?1:Qs?.55:.95,lineJoin:"round",lineCap:"round",offset:q}}),D&&(0,_.jsx)(l.p,{position:d,icon:E,zIndexOffset:j?900:100,eventHandlers:{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),ea((s=>s===e.sequenceStep?null:e.sequenceStep))}},children:(0,_.jsx)(u.m,{direction:"top",offset:[0,-12],opacity:1,className:"compare-tooltip",children:(0,_.jsxs)("div",{className:"cmp-tip",children:[(0,_.jsxs)("div",{className:"cmp-tip-header",children:[(0,_.jsx)("span",{className:"cmp-tip-step",style:{background:i},children:(0,_.jsx)(S.zPd,{})}),(0,_.jsxs)("div",{className:"cmp-tip-title-stack",children:[(0,_.jsx)("div",{className:"cmp-tip-title",children:e.pickupcustomer||"Pickup"}),(0,_.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,_.jsx)("div",{className:"cmp-tip-action",children:"Click for step 1 details"})]})})}),(0,_.jsx)(l.p,{position:o,icon:A,zIndexOffset:j?1e3:200,eventHandlers:w?{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),ea((s=>s===e.sequenceStep?null:e.sequenceStep)),Ee.current&&(clearTimeout(Ee.current),Ee.current=null);const a=String(w.orderid);Pe.current.has(a)?(Pe.current.delete(a),Le(null)):(Pe.current.add(a),Le(w))}}:{click:s=>{s.originalEvent&&s.originalEvent.stopPropagation(),ea((s=>s===e.sequenceStep?null:e.sequenceStep)),w&&s.target&&"function"===typeof s.target.openPopup&&s.target.openPopup()}},children:!w&&(0,_.jsx)(u.m,{direction:"top",offset:[0,-20],opacity:1,className:"compare-tooltip",children:(()=>{const s=(0,F.Cx)(e.orderstatus);return(0,_.jsxs)("div",{className:"cmp-tip",children:[(0,_.jsxs)("div",{className:"cmp-tip-header",children:[(0,_.jsx)("span",{className:"cmp-tip-step",style:{background:i},children:e.sequenceStep}),(0,_.jsxs)("div",{className:"cmp-tip-title-stack",children:[(0,_.jsx)("div",{className:"cmp-tip-title",children:e.deliverycustomer||"Step ".concat(e.sequenceStep)}),(0,_.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,_.jsx)("span",{className:"cmp-tip-tag",style:{background:s.bg,color:s.fg},children:s.label})]}),k&&(0,_.jsx)("div",{className:"cmp-tip-anomaly",children:"Deviation flagged \u2014 see details below"}),(0,_.jsx)("div",{className:"cmp-tip-action",children:j?"Click to deselect":"Click for details"})]})})()})})]},"actual-".concat(e.deliveryid))}))]}),Ls&&Fa&&(0,_.jsxs)("div",{className:"compare-view-switcher",role:"group","aria-label":"Compare view layer",children:[(0,_.jsx)("button",{type:"button",className:"actual"===Is?"is-active":"",onClick:()=>Rs("actual"),title:"Show only the rider's actual GPS trail",children:"Actual"}),(0,_.jsx)("button",{type:"button",className:"planned"===Is?"is-active":"",onClick:()=>Rs("planned"),title:"Show only the dispatched planned route",children:"Planned"}),(0,_.jsx)("button",{type:"button",className:"combined"===Is?"is-active":"",onClick:()=>Rs("combined"),title:"Overlay planned (dashed) and actual (solid) on one map",children:"Combined"})]}),(0,_.jsx)("div",{id:"ov-tl"}),(0,_.jsxs)("div",{id:"ov-br",children:[(0,_.jsxs)("button",{className:"sbt ".concat(ys?"active":""),onClick:()=>{if(ys)return ks(!1),ws([]),void _s({});ks(!0),ws([]),_s({});const e=Ls&&Fa,s=e?new Map(Ea.map((e=>[String(e.deliveryid),e.sequenceStep]))):null,a=[];if(ya.forEach((t=>{if(!Ne.has(t.id))return;if(Fa&&Fa.id!==t.id)return;if(ke&&!ke.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[r,n]=i;const l=ke?n.filter((e=>(e.pickupcustomer||e.kitchen_key||"Unknown").toLowerCase().trim()===ke.id)):n;if(0===l.length)return;const c="".concat(t.id,"-").concat(r),d=vs[c],o=[...l].sort(((e,s)=>(e.step||0)-(s.step||0))),u=se(o),m="kitchens"===J||ke,p=d||u;if(p.length<2)return;let h=()=>t.color;if(e&&t.id===Fa.id){const e=o.filter(q).map((e=>[parseFloat(e.droplat||e.deliverylat),parseFloat(e.droplon||e.deliverylong)])),a=d?X(d,e):(()=>{const s=u.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>=u.length||i>=u.length?a.push([]):a.push([u[e],u[i]])}return a})(),i=[];let r=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[r+t]=s;r+=a})),h=e=>{const a=i[e];if(null==a)return t.color;const r=o.filter(q)[a],n=r?s.get(String(r.deliveryid)):null;return n?(0,F.gM)(n-1):t.color}}for(let e=0;e<p.length-1;e++)a.push({from:p[e],to:p[e+1],color:h(e),delay:.05*(parseInt(t.id.slice(-3))||0)+40*parseInt(r)+e*(m?40:8)})}))})),a.sort(((e,s)=>e.delay-s.delay)),a.forEach(((e,s)=>{setTimeout((()=>{ws((s=>[...s,e])),s===a.length-1&&setTimeout((()=>{ks(!1),_s({})}),1e3)}),e.delay)})),e&&Ea.length>0){const e=[...Ea],s=e.map((e=>{const s=Ns[e.deliveryid];return Array.isArray(s)&&s.length>=2?s:e.coords.map((e=>[e.lat,e.lng]))})),t=a.length>0?a[a.length-1].delay:800*e.length,i=Math.max(t,600*e.length),r=i/Math.max(1,e.length),n=Date.now(),l=()=>{if(!Ms.current)return;const a=Date.now()-n,t={};e.forEach(((e,i)=>{const n=s[i];if(!n||n.length<2)return;const l=i*r;if(a>=l+r)t[e.sequenceStep]=n.length;else if(a>=l){const s=(a-l)/r;t[e.sequenceStep]=Math.max(2,Math.ceil(s*n.length))}})),_s(t),a<i+200&&requestAnimationFrame(l)};requestAnimationFrame(l)}},style:{boxShadow:"var(--shadow-lg)",background:ys?"var(--accent)":"#fff"},children:[(0,_.jsx)("span",{children:ys?"\u23f9":"\u25b6"})," ",ys?"Stop":"Animate Routes"]}),(0,_.jsxs)("button",{type:"button",className:"sbt ".concat(Ls?"active":""),onClick:()=>{if(Ls)Os(!1);else{if(!Fa){const e=ya.find((e=>(e.orders||[]).some((e=>null!=e.deliveryid&&""!==e.deliveryid&&0!==e.deliveryid)))),s=ya.find((e=>e.orders&&e.orders.length>0)),a=e||s;if(a&&(_a(a),Oe))return void(Gs.current=!0)}Os(!0)}},title:Fa?"Compare planned vs. actual route for ".concat(Fa.riderName):"Compare planned vs. actual route (will focus the first rider)",style:{boxShadow:"var(--shadow-lg)",background:Ls?"linear-gradient(135deg, #6366f1, #3b82f6)":"#fff",marginLeft:8,color:Ls?"#fff":void 0},children:[(0,_.jsx)("span",{className:"sbt-icon",children:(0,_.jsx)(S.$G1,{})}),Ls?"Exit Compare":"Compare"]})]})]}),Ls&&Fa&&(0,_.jsx)("div",{id:"compare-map-wrap",children:(()=>{const e=Ea.length,s=Ea.filter((e=>e.coords.length>0)).length,a=Ea.filter((e=>e.isLoading)).length,t=e>0?Math.round(s/e*100):0,i=e>0&&s===e&&0===a,n=null!=Qs?qa.find((e=>e.sequenceStep===Qs)):null;return(0,_.jsxs)("div",{className:"compare-header-v2",children:[(0,_.jsxs)("div",{className:"compare-header-row",children:[(0,_.jsxs)("div",{className:"compare-title",children:[(0,_.jsx)("span",{className:"compare-title-dot",style:{background:Fa.color}}),(0,_.jsx)("span",{className:"compare-title-name",children:Fa.riderName}),(0,_.jsx)("span",{className:"compare-title-badge",children:"ACTUAL vs PLANNED"})]}),(0,_.jsxs)("div",{className:"compare-header-tools",children:[null!=Qs&&(0,_.jsxs)("button",{type:"button",className:"compare-overall-btn",onClick:()=>ea(null),title:"Zoom out to the whole day",children:[(0,_.jsx)(S.Zs6,{})," Overall"]}),(0,_.jsx)("button",{type:"button",className:"compare-timeline-toggle".concat(Ys?" is-open":""),onClick:()=>Vs((e=>!e)),title:Ys?"Hide planned/actual timeline":"Show planned/actual timeline","aria-expanded":Ys,children:(0,_.jsx)(S.j1Q,{})})]})]}),Ys&&(0,_.jsxs)(_.Fragment,{children:[(0,_.jsxs)("div",{className:"compare-timeline-wrap",children:[(0,_.jsxs)("div",{className:"compare-timeline-container",children:[(0,_.jsxs)("div",{className:"compare-timeline-labels",children:[(0,_.jsx)("div",{className:"compare-timeline-label",children:"Planned"}),(0,_.jsx)("div",{className:"compare-timeline-label",children:"Actual"})]}),(0,_.jsxs)("div",{className:"compare-timeline-scrollable",children:[(0,_.jsx)("div",{className:"compare-timeline-track is-planned",children:Oa.map(((e,s)=>{var a;const t=String(e.orderstatus||"").toLowerCase(),i=F.Ys.has(t),n=F.yP.has(t),l=Qs===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,F.gM)(o-1),m=["compare-step",l&&"is-focused",i&&"is-delivered",n&&"is-skipped",!i&&!n&&"is-pending",c&&"is-loading",d&&"is-no-data",e.anomaly&&"is-anomaly"].filter(Boolean).join(" ");return(0,_.jsxs)(r.Fragment,{children:[s>0&&(0,_.jsx)("span",{className:"compare-step-spacer"}),(0,_.jsxs)("button",{type:"button",className:m,style:{"--step-color":u},onClick:()=>ea((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,_.jsx)("span",{className:"compare-step-circle",children:c?(0,_.jsx)("span",{className:"compare-step-spin"}):o}),e.expectedTs&&(0,_.jsx)("span",{className:"compare-step-tick",children:e.expectedTs.format("HH:mm")})]})]},"step-p-".concat(e.deliveryid))}))}),(0,_.jsx)("div",{className:"compare-timeline-track is-actual",children:Ia.map(((e,s)=>{var a;const t=String(e.orderstatus||"").toLowerCase(),i=F.Ys.has(t),n=F.yP.has(t),l=Qs===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,F.gM)(o-1),m=["compare-step",l&&"is-focused",i&&"is-delivered",n&&"is-skipped",!i&&!n&&"is-pending",c&&"is-loading",d&&"is-no-data",e.anomaly&&"is-anomaly"].filter(Boolean).join(" ");return(0,_.jsxs)(r.Fragment,{children:[s>0&&(0,_.jsx)("span",{className:"compare-step-spacer"}),(0,_.jsxs)("button",{type:"button",className:m,style:{"--step-color":u},onClick:()=>ea((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,_.jsx)("span",{className:"compare-step-circle",children:c?(0,_.jsx)("span",{className:"compare-step-spin"}):o}),e.actualTs&&(0,_.jsx)("span",{className:"compare-step-tick",children:e.actualTs.format("HH:mm")}),e.anomaly&&(0,_.jsx)("span",{className:"compare-step-flag",title:"Deviation flagged"})]})]},"step-a-".concat(e.deliveryid))}))})]})]}),(0,_.jsxs)("div",{className:"compare-progress-strip",children:[(0,_.jsx)("div",{className:"compare-progress-bar-wrap",children:(0,_.jsx)("div",{className:"compare-progress-bar-fill".concat(i?" is-done":""),style:{width:"".concat(t,"%")}})}),(0,_.jsx)("span",{className:"compare-progress-text",children:a>0?"Loading GPS\u2026 ".concat(s,"/").concat(e):"".concat(s,"/").concat(e," tracks")})]})]}),(()=>{const e="combined"===Is,s=n?(0,F.gM)(n.sequenceStep-1):"linear-gradient(90deg, ".concat(F.Z3.slice(0,6).join(", "),")"),a=e?A:s,t=e?P:s;return(0,_.jsxs)("div",{className:"compare-legend",children:[(0,_.jsxs)("span",{className:"compare-legend-item",children:[(0,_.jsx)("span",{className:"compare-legend-swatch is-step-color is-dashed",style:{background:a}}),"Planned (dashed)"]}),(0,_.jsxs)("span",{className:"compare-legend-item",children:[(0,_.jsx)("span",{className:"compare-legend-swatch is-step-color",style:{background:t}}),"Actual GPS (solid)"]}),(0,_.jsx)("span",{className:"compare-legend-note",children:"Kalman-smoothed GPS \xb7 OSRM road-snapped"})]})})()]})]})})()}),Ls&&Fa&&(0,_.jsx)(M,{focusedRider:Fa,compareDeltas:qa,compareSummary:La,actualOrdered:Ia,focusedCompareStep:Qs,setFocusedCompareStep:ea,sequenceOpen:Ts,setSequenceOpen:Hs,expandedSeqGroups:Ks,setExpandedSeqGroups:Bs,onClose:()=>Os(!1)})]}),qe&&(0,_.jsx)("div",{className:"dispatch-popup-center",role:"dialog","aria-label":"Order ".concat(qe.orderid," details"),onMouseEnter:()=>{Ee.current&&(clearTimeout(Ee.current),Ee.current=null)},onMouseLeave:()=>{(e=>{if(!e)return!1;if(Pe.current.has(String(e.orderid)))return!0;if(Ls&&Fa&&null!=e.deliveryid){const s=Ea.find((s=>String(s.deliveryid)===String(e.deliveryid)));if(s&&Qs===s.sequenceStep)return!0}return!1})(qe)||(Ee.current&&clearTimeout(Ee.current),Ee.current=setTimeout((()=>{Le(null),Ee.current=null}),200))},children:(0,_.jsxs)("div",{className:"dispatch-popup-card dispatch-popup",children:[(0,_.jsx)("button",{type:"button",className:"dispatch-popup-center-close","aria-label":"Close order details",onClick:()=>{Pe.current.delete(String(qe.orderid)),Le(null)},children:"\xd7"}),(e=>{const s=(0,F.Cx)(e.orderstatus),a=e.rider_id||e.userid,t=F.Ys.has(String(e.orderstatus||"").toLowerCase()),i=t?null:Ba(a,e);return(0,_.jsxs)("div",{style:{height:"100%",width:"100%"},children:[(0,_.jsxs)("div",{className:"pu-header",children:[(0,_.jsxs)("div",{className:"pu-header-top",children:[(0,_.jsxs)("div",{className:"pu-id",children:["ORDER #",e.orderid]}),e.orderstatus&&(0,_.jsx)("span",{className:"pu-status-chip",style:{background:s.bg,color:s.fg},children:s.label})]}),(0,_.jsxs)("div",{className:"pu-rider",children:[(0,_.jsx)(S.aVM,{})," ",(0,_.jsx)("span",{children:e.rider_name||e.ridername||"Unassigned"})]}),(e.deliverycustomer||e.customername)&&(0,_.jsxs)("div",{className:"pu-customer",title:e.deliverycustomer||e.customername,children:[(0,_.jsx)(S.u9F,{}),(0,_.jsx)("span",{children:e.deliverycustomer||e.customername})]}),null!=e.deliveryid&&(0,_.jsxs)("div",{className:"pu-delivery-id",children:["Delivery #",e.deliveryid]})]}),(0,_.jsxs)("div",{className:"pu-body",children:[ee.some((s=>e[s.key]))&&(0,_.jsxs)("div",{className:"pu-section",children:[(0,_.jsx)("div",{className:"pu-section-label",children:"Timeline"}),(0,_.jsx)("div",{className:"pu-timeline",children:ee.map((s=>{const a=Q(e[s.key]);return a?(0,_.jsxs)("div",{className:"pu-tl-row ".concat(s.final?"delivered":""),children:[(0,_.jsx)("span",{className:"pu-tl-dot"}),(0,_.jsx)("span",{className:"pu-tl-label",children:s.label}),(0,_.jsx)("span",{className:"pu-tl-time",children:a})]},s.key):null}))})]}),(0,_.jsxs)("div",{className:"pu-section",children:[(0,_.jsx)("div",{className:"pu-section-label",children:"Details"}),(0,_.jsxs)("div",{className:"pu-details-grid",children:[(e.pickupcustomer||e.locationname||e.pickuplocation)&&(0,_.jsxs)("div",{className:"pu-detail",children:[(0,_.jsx)("div",{className:"pu-detail-icon",children:(0,_.jsx)(S.NtI,{})}),(0,_.jsxs)("div",{className:"pu-detail-body",children:[(0,_.jsx)("div",{className:"pu-detail-label",children:"Pickup"}),(0,_.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,_.jsxs)("div",{className:"pu-detail",children:[(0,_.jsx)("div",{className:"pu-detail-icon",children:(0,_.jsx)(S.JFD,{})}),(0,_.jsxs)("div",{className:"pu-detail-body",children:[(0,_.jsx)("div",{className:"pu-detail-label",children:"Drop"}),(0,_.jsx)("div",{className:"pu-detail-value",title:e.deliveryaddress||e.deliverysuburb,children:e.deliverysuburb||E(e.deliveryaddress)})]})]}),e.zone_name&&(0,_.jsxs)("div",{className:"pu-detail",children:[(0,_.jsx)("div",{className:"pu-detail-icon",children:(0,_.jsx)(S.Cd7,{})}),(0,_.jsxs)("div",{className:"pu-detail-body",children:[(0,_.jsx)("div",{className:"pu-detail-label",children:"Zone"}),(0,_.jsx)("div",{className:"pu-detail-value",title:e.zone_name,children:e.zone_name})]})]}),(e.rider_id||e.userid)&&(0,_.jsxs)("div",{className:"pu-detail",children:[(0,_.jsx)("div",{className:"pu-detail-icon",children:(0,_.jsx)(S.aVM,{})}),(0,_.jsxs)("div",{className:"pu-detail-body",children:[(0,_.jsx)("div",{className:"pu-detail-label",children:"Rider ID"}),(0,_.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,_.jsxs)("div",{className:"pu-distance-row",children:[null!=e.kms&&""!==e.kms&&(0,_.jsxs)("div",{className:"pu-distance-chip",children:[(0,_.jsx)("span",{className:"pu-distance-icon",children:(0,_.jsx)(S.xI$,{})}),(0,_.jsx)("span",{className:"pu-distance-label",children:"Planned"}),(0,_.jsxs)("span",{className:"pu-distance-value",children:[e.kms," km"]})]}),null!=e.actualkms&&""!==e.actualkms&&(0,_.jsxs)("div",{className:"pu-distance-chip",children:[(0,_.jsx)("span",{className:"pu-distance-icon",children:(0,_.jsx)(S.xI$,{})}),(0,_.jsx)("span",{className:"pu-distance-label",children:"Actual"}),(0,_.jsxs)("span",{className:"pu-distance-value",children:[e.actualkms," km"]})]}),!t&&null!=e.riderkms&&""!==e.riderkms&&(0,_.jsxs)("div",{className:"pu-distance-chip",children:[(0,_.jsx)("span",{className:"pu-distance-icon",children:(0,_.jsx)(S.bsz,{})}),(0,_.jsx)("span",{className:"pu-distance-label",children:"Rider"}),(0,_.jsxs)("span",{className:"pu-distance-value",children:[parseFloat(e.riderkms).toFixed(2)," km"]})]}),null!==i&&(0,_.jsxs)("div",{className:"pu-distance-chip pu-est-meters",title:"Estimated distance to drop location",children:[(0,_.jsx)("span",{className:"pu-distance-icon",children:(0,_.jsx)(S.HPi,{})}),(0,_.jsx)("span",{className:"pu-distance-label",children:"Est. to Drop"}),(0,_.jsx)("span",{className:"pu-distance-value",children:Ga(i)})]})]})]})]})]})})(qe)]})})]}),!a&&"analysis"===de&&(0,_.jsxs)("div",{id:"dispatch-analysis",children:[(0,_.jsx)("div",{className:"da-picker-row",children:ne.map((e=>{var s;const a=ue[e.key],t=pe===e.key,i=!1===(null===a||void 0===a||null===(s=a.data)||void 0===s?void 0:s.success),r=i?"#fee2e2":a?"".concat(e.color,"22"):"#f1f5f9",n=i?"#dc2626":a?e.color:"#64748b",l=t?"Loading\u2026":i?"! Failed":a?"\u2713 ".concat(a.fetchedAt):"Fetch",c=xe===e.key;return(0,_.jsxs)("button",{type:"button",className:"da-picker ".concat(a?"has-data":""," ").concat(t?"is-loading":""," ").concat(c?"is-active":""),onClick:()=>!t&&ge(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,_.jsxs)("div",{className:"da-picker-head",children:[(0,_.jsx)("div",{className:"da-picker-badge",style:{background:"".concat(e.color,"22"),color:e.color},children:e.label[0]}),(0,_.jsxs)("div",{className:"da-picker-meta",children:[(0,_.jsx)("div",{className:"da-picker-name",children:e.label}),(0,_.jsx)("div",{className:"da-picker-range",children:e.timeRange})]}),(0,_.jsx)("span",{className:"da-picker-status",style:{background:r,color:n},children:l})]}),(0,_.jsx)("div",{className:"da-picker-sub",children:e.sub})]},e.key)}))}),((e,s,a,t)=>{if(!xe)return(0,_.jsx)("div",{className:"da-empty",children:"Pick a batch above to view its efficiency analysis."});const r=ne.find((e=>e.key===xe)),n=ue[xe],l=pe===xe;if(l&&!n)return(0,_.jsxs)("div",{className:"da-empty",children:["Loading ",r.label," batch\u2026"]});if(!n)return null;const c=n.data||{};var d,o;if(!1===c.success)return(0,_.jsxs)("div",{className:"da-result-card da-result-card-error",style:{borderColor:"#fecaca",borderTopColor:"#ef4444"},children:[(0,_.jsxs)("div",{className:"da-result-head",children:[(0,_.jsxs)("div",{children:[(0,_.jsxs)("div",{className:"da-result-title",children:[r.label," Batch"]}),(0,_.jsxs)("div",{className:"da-result-sub",children:[r.timeRange," \xb7 Fetched at ",n.fetchedAt]})]}),(0,_.jsx)("button",{type:"button",className:"da-result-refresh",title:"Retry",onClick:()=>ge(xe),disabled:l,style:{background:"#fee2e2",color:"#dc2626"},children:(0,_.jsx)(S.joZ,{})})]}),(0,_.jsxs)("div",{className:"da-error",children:[(0,_.jsxs)("div",{className:"da-error-title",children:[(0,_.jsx)(S.ItP,{}),(0,_.jsx)("span",{children:(null===c||void 0===c||null===(d=c.error)||void 0===d?void 0:d.code)||"Request failed"})]}),(0,_.jsx)("div",{className:"da-error-msg",children:(null===c||void 0===c||null===(o=c.error)||void 0===o?void 0:o.message)||"The server returned an error."}),(null===c||void 0===c?void 0:c.request_id)&&(0,_.jsxs)("div",{className:"da-error-meta",children:["request_id: ",c.request_id]})]})]});const u=c.fleet_summary||{},m=Array.isArray(c.rider_timelines)?c.rider_timelines:[],p=Array.isArray(c.substitution_opportunities)?c.substitution_opportunities:[],h=c.top_recommendation,x=!(!h||!h.idle_rider_name&&!h.idle_rider_id),v=!!(h&&h.action&&"none"!==h.action&&x),j=c.window||{},g=[{label:"Total Orders",value:le(u.total_orders)},{label:"Total Riders",value:le(u.total_riders)},{label:"Avg Orders/Rider",value:null!==(e=u.orders_per_rider_avg)&&void 0!==e?e:"\u2014"},{label:"Fleet Start",value:u.fleet_start||"\u2014"},{label:"Fleet Done",value:u.fleet_done||"\u2014"},{label:"Duration",value:null!=u.total_duration_minutes?"".concat(u.total_duration_minutes," min"):"\u2014"}];return(0,_.jsxs)("div",{className:"da-detail",children:[(0,_.jsxs)("div",{className:"da-detail-head",style:{borderTopColor:r.color,background:r.bg},children:[(0,_.jsxs)("div",{children:[(0,_.jsxs)("div",{className:"da-detail-title",children:[r.label," Batch",(0,_.jsxs)("span",{className:"da-detail-sub-inline",children:[c.date?" \xb7 ".concat(c.date):"",j.from&&j.to?" \xb7 ".concat(j.from," \u2013 ").concat(j.to):""]})]}),(0,_.jsxs)("div",{className:"da-detail-sub",children:["Fetched at ",n.fetchedAt," \xb7 Input deliveries: ",null!==(s=c.input_delivery_count)&&void 0!==s?s:"\u2014"]})]}),(0,_.jsx)("button",{type:"button",className:"da-result-refresh",title:"Refresh",onClick:()=>{me((e=>{const s=(0,i.A)({},e);return delete s[xe],s})),je.mutate({batch:xe,tenantId:916})},disabled:l,style:{background:"".concat(r.color,"22"),color:r.color},children:(0,_.jsx)(S.joZ,{})})]}),(0,_.jsxs)("div",{className:"da-section",children:[(0,_.jsx)("div",{className:"da-section-label",children:"Fleet Summary"}),(0,_.jsx)("div",{className:"da-metric-grid da-metric-grid-3",children:g.map((e=>(0,_.jsxs)("div",{className:"da-metric",children:[(0,_.jsx)("div",{className:"da-metric-label",children:e.label}),(0,_.jsx)("div",{className:"da-metric-value",children:e.value})]},e.label)))})]}),v?(0,_.jsxs)("div",{className:"da-section",children:[(0,_.jsx)("div",{className:"da-section-label",children:"Top Recommendation"}),(0,_.jsxs)("div",{className:"da-rec",children:[(0,_.jsxs)("div",{className:"da-rec-head",children:[(0,_.jsxs)("div",{className:"da-rec-action",children:[(0,_.jsx)(S.DX0,{}),(0,_.jsx)("span",{children:(h.action||"recommendation").replaceAll("_"," ")})]}),null!=h.fleet_improvement_minutes&&(0,_.jsxs)("span",{className:"da-rec-improve",style:h.fleet_improvement_minutes>0?{background:"#dcfce7",color:"#166534"}:{background:"#f1f5f9",color:"#475569"},children:[h.fleet_improvement_minutes>0?"\u2191":"\u2022"," Fleet improves by ",h.fleet_improvement_minutes," min"]})]}),(0,_.jsxs)("div",{className:"da-rec-line",children:[(0,_.jsx)("strong",{children:h.idle_rider_name||"Rider ".concat(h.idle_rider_id)}),h.primary_kitchen&&(0,_.jsxs)(_.Fragment,{children:[" \xb7 primary kitchen ",(0,_.jsx)("strong",{children:h.primary_kitchen})]}),h.second_kitchen&&(0,_.jsxs)(_.Fragment,{children:[" \u2192 also serve ",(0,_.jsx)("strong",{children:h.second_kitchen})," after ",h.second_kitchen_dispatch_after||"\u2014"]})]}),h.description&&(0,_.jsx)("div",{className:"da-rec-desc",children:h.description}),(null===(a=h.activate_when)||void 0===a||null===(t=a.rules)||void 0===t?void 0:t.length)>0&&(0,_.jsxs)("div",{className:"da-rec-rules",children:[(0,_.jsxs)("div",{className:"da-rec-rules-head",children:["Activate when (",h.activate_when.condition||"AND","):"]}),h.activate_when.rules.map(((e,s)=>(0,_.jsxs)("div",{className:"da-rec-rule",children:[(0,_.jsxs)("code",{children:[e.field," ",e.operator," ",e.value]}),e.reason&&(0,_.jsxs)("span",{className:"da-rec-rule-why",children:[" \u2014 ",e.reason]})]},s)))]})]})]}):(0,_.jsxs)("div",{className:"da-section",children:[(0,_.jsx)("div",{className:"da-section-label",children:"Top Recommendation"}),(0,_.jsx)("div",{className:"da-rec da-rec-empty",children:(0,_.jsxs)("div",{className:"da-rec-action",children:[(0,_.jsx)(S.DX0,{}),(0,_.jsx)("span",{children:"Fleet is balanced, no reassignment needed right now."})]})})]}),m.length>0&&(0,_.jsxs)("div",{className:"da-section",children:[(0,_.jsxs)("div",{className:"da-section-label",children:["Rider Timelines ",(0,_.jsxs)("span",{className:"da-section-count",children:["(",m.length,")"]})]}),(0,_.jsx)("div",{className:"da-timeline-list",children:m.map((e=>{const s="active"===String(e.status||"").toLowerCase();return(0,_.jsxs)("div",{className:"da-timeline-card",children:[(0,_.jsxs)("div",{className:"da-timeline-top",children:[(0,_.jsxs)("div",{className:"da-timeline-name",children:[(0,_.jsx)(S.aVM,{style:{color:r.color}}),(0,_.jsx)("span",{children:e.name}),(0,_.jsxs)("span",{className:"da-timeline-id",children:["#",e.userid]})]}),(0,_.jsx)("span",{className:"da-pill ".concat(s?"is-active":"is-idle"),children:e.status})]}),(0,_.jsxs)("div",{className:"da-timeline-mid",children:[e.kitchen&&(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.NtI,{})," ",e.kitchen]}),(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.gsJ,{})," ",e.order_count," orders"]}),(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.VP9,{})," ",e.started_at," \u2192 ",e.finished_at]}),(0,_.jsxs)("span",{className:"da-chip",style:e.idle_minutes>30?{background:"#fef3c7",color:"#92400e"}:void 0,children:[(0,_.jsx)(S.pWE,{})," ",e.idle_minutes," min idle"]})]})]},e.userid)}))})]}),p.length>0&&(0,_.jsxs)("div",{className:"da-section",children:[(0,_.jsxs)("div",{className:"da-section-label",children:["Substitution Opportunities ",(0,_.jsxs)("span",{className:"da-section-count",children:["(",p.length,")"]})]}),(0,_.jsx)("div",{className:"da-sub-list",children:p.map(((e,s)=>{var a;const t=e.idle_rider||{},i=e.most_relieved_rider||{},r=null!==(a=e.fleet_improvement_minutes)&&void 0!==a?a:0;return(0,_.jsxs)("div",{className:"da-sub-card",children:[(0,_.jsxs)("div",{className:"da-sub-head",children:[(0,_.jsxs)("div",{className:"da-sub-title",children:[(0,_.jsx)("strong",{children:t.name||"Rider ".concat(t.userid)})," ","covers ",(0,_.jsx)("strong",{children:e.target_kitchen})]}),(0,_.jsxs)("span",{className:"da-sub-improve",style:r>0?{background:"#dcfce7",color:"#166534"}:{background:"#f1f5f9",color:"#475569"},children:["Fleet ",r>0?"\u2191":"\u2022"," ",r," min"]})]}),(0,_.jsxs)("div",{className:"da-sub-meta",children:[(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.xI$,{})," ",e.travel_to_kitchen_km," km"]}),(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.pWE,{})," ",e.travel_to_kitchen_minutes," min travel"]}),(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.VP9,{})," arrives ",e.arrive_at_kitchen]}),(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.gsJ,{})," ",e.total_orders_transferred," orders"]}),(0,_.jsxs)("span",{className:"da-chip",children:[(0,_.jsx)(S.xI$,{})," +",e.extra_km_for_idle_rider," km for idle rider"]})]}),i.name&&(0,_.jsxs)("div",{className:"da-sub-relieved",children:[(0,_.jsx)(S.imn,{}),"Most relieved: ",(0,_.jsx)("strong",{children: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,_.jsxs)("div",{className:"da-sub-transfers",children:[(0,_.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,_.jsxs)("div",{className:"da-transfer-row",children:[(0,_.jsxs)("span",{className:"da-transfer-id",children:["#",e.deliveryid]}),(0,_.jsxs)("span",{className:"da-transfer-from",children:["from ",e.from_rider_name]}),(0,_.jsxs)("span",{className:"da-transfer-time",children:[e.original_delivery_time," \u2192 ",e.estimated_delivery_time]}),(0,_.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)}))})]})]})})()]})]})}},84702:(e,s,a)=>{a.d(s,{Cx:()=>i,IE:()=>d,Ys:()=>r,Z3:()=>l,gM:()=>c,yP:()=>n});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"},r=new Set(["delivered"]),n=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])}}}]);