{"version":3,"sources":["webpack:///./node_modules/kdbush/src/sort.js","webpack:///./node_modules/kdbush/src/range.js","webpack:///./node_modules/kdbush/src/within.js","webpack:///./node_modules/kdbush/src/index.js","webpack:///./node_modules/supercluster/index.js","webpack:///./node_modules/@googlemaps/markerclusterer/dist/index.esm.js","webpack:///./src/assets/vehicle_1_green.png","webpack:///./node_modules/fast-deep-equal/index.js","webpack:///./src/assets/markers/darkstore-dark-marker.png"],"names":["sortKD","ids","coords","nodeSize","left","right","depth","m","k","inc","n","z","Math","log","s","exp","sd","sqrt","newLeft","max","floor","newRight","min","t","i","j","swapItem","swap","arr","tmp","range","minX","minY","maxX","maxY","stack","length","result","x","y","axis","pop","push","nextAxis","within","qx","qy","r","r2","sqDist","ax","ay","bx","by","dx","dy","defaultGetX","p","defaultGetY","points","getX","getY","ArrayType","Float64Array","this","IndexArrayType","Uint16Array","Uint32Array","defaultOptions","minZoom","maxZoom","minPoints","radius","extent","generateId","reduce","map","props","fround","Float32Array","options","extend","Object","create","trees","Array","console","time","timerId","clusters","geometry","createPointCluster","timeEnd","now","Date","_cluster","bbox","zoom","minLng","minLat","maxLng","maxLat","easternHem","getClusters","westernHem","concat","tree","_limitZoom","lngX","latY","id","c","numPoints","getClusterJSON","index","clusterId","originId","_getOriginId","originZoom","_getOriginZoom","errorMsg","Error","origin","pow","children","parentId","limit","offset","leaves","_appendLeaves","z2","top","bottom","tile","features","_addTileFeatures","expansionZoom","getChildren","properties","cluster_id","skipped","child","cluster","point_count","isCluster","tags","px","py","getClusterProperties","coordinates","f","type","round","undefined","neighborIds","numPointsOrigin","neighborId","b","wx","wy","clusterProperties","_map","numPoints2","createCluster","point","clone","original","Infinity","xLng","yLat","count","abbrev","point_count_abbreviated","lng","lat","sin","PI","y2","atan","dest","src","__rest","e","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","propertyIsEnumerable","Cluster","markers","position","google","maps","LatLng","_position","bounds","marker","getPosition","LatLngBounds","getCenter","filter","getVisible","setMap","AbstractAlgorithm","noop","_a","super","superCluster","assign","state","input","changed","load","getZoom","transformCluster","bind","getLeaves","leaf","ClusterStats","sum","clusterMarkerCounts","a","clusterMarkerSum","mean","DefaultRenderer","stats","color","svg","window","btoa","Marker","icon","url","scaledSize","Size","label","text","String","fontSize","title","zIndex","Number","MAX_ZINDEX","type1","type2","property","OverlayViewSafe","OverlayView","MarkerClustererEvents","defaultOnClusterClickHandler","_","fitBounds","MarkerClusterer","algorithm","renderer","onClusterClick","noDraw","includes","render","forEach","addMarker","splice","removed","removeMarker","getMap","Map","getProjection","event","trigger","CLUSTERING_BEGIN","calculate","mapCanvasProjection","reset","renderClusters","CLUSTERING_END","idleListener","addListener","removeListener","delete","CLUSTER_CLICK","module","exports","equal","constructor","keys","isArray","RegExp","source","flags","valueOf","toString","key"],"mappings":"kHACe,SAASA,EAAOC,EAAKC,EAAQC,EAAUC,EAAMC,EAAOC,GAC/D,GAAID,EAAQD,GAAQD,EAAU,OAE9B,MAAMI,EAAKH,EAAOC,GAAU,EAE5B,EAAOJ,EAAKC,EAAQK,EAAGH,EAAMC,EAAOC,EAAQ,GAE5CN,EAAOC,EAAKC,EAAQC,EAAUC,EAAMG,EAAI,EAAGD,EAAQ,GACnDN,EAAOC,EAAKC,EAAQC,EAAUI,EAAI,EAAGF,EAAOC,EAAQ,GAGxD,SAAS,EAAOL,EAAKC,EAAQM,EAAGJ,EAAMC,EAAOI,GAEzC,MAAOJ,EAAQD,EAAM,CACjB,GAAIC,EAAQD,EAAO,IAAK,CACpB,MAAMM,EAAIL,EAAQD,EAAO,EACnBG,EAAIC,EAAIJ,EAAO,EACfO,EAAIC,KAAKC,IAAIH,GACbI,EAAI,GAAMF,KAAKG,IAAI,EAAIJ,EAAI,GAC3BK,EAAK,GAAMJ,KAAKK,KAAKN,EAAIG,GAAKJ,EAAII,GAAKJ,IAAMH,EAAIG,EAAI,EAAI,GAAK,EAAI,GAClEQ,EAAUN,KAAKO,IAAIf,EAAMQ,KAAKQ,MAAMZ,EAAID,EAAIO,EAAIJ,EAAIM,IACpDK,EAAWT,KAAKU,IAAIjB,EAAOO,KAAKQ,MAAMZ,GAAKE,EAAIH,GAAKO,EAAIJ,EAAIM,IAClE,EAAOf,EAAKC,EAAQM,EAAGU,EAASG,EAAUZ,GAG9C,MAAMc,EAAIrB,EAAO,EAAIM,EAAIC,GACzB,IAAIe,EAAIpB,EACJqB,EAAIpB,EAERqB,EAASzB,EAAKC,EAAQE,EAAMI,GACxBN,EAAO,EAAIG,EAAQI,GAAOc,GAAGG,EAASzB,EAAKC,EAAQE,EAAMC,GAE7D,MAAOmB,EAAIC,EAAG,CACVC,EAASzB,EAAKC,EAAQsB,EAAGC,GACzBD,IACAC,IACA,MAAOvB,EAAO,EAAIsB,EAAIf,GAAOc,EAAGC,IAChC,MAAOtB,EAAO,EAAIuB,EAAIhB,GAAOc,EAAGE,IAGhCvB,EAAO,EAAIE,EAAOK,KAASc,EAAGG,EAASzB,EAAKC,EAAQE,EAAMqB,IAE1DA,IACAC,EAASzB,EAAKC,EAAQuB,EAAGpB,IAGzBoB,GAAKjB,IAAGJ,EAAOqB,EAAI,GACnBjB,GAAKiB,IAAGpB,EAAQoB,EAAI,IAIhC,SAASC,EAASzB,EAAKC,EAAQsB,EAAGC,GAC9BE,EAAK1B,EAAKuB,EAAGC,GACbE,EAAKzB,EAAQ,EAAIsB,EAAG,EAAIC,GACxBE,EAAKzB,EAAQ,EAAIsB,EAAI,EAAG,EAAIC,EAAI,GAGpC,SAASE,EAAKC,EAAKJ,EAAGC,GAClB,MAAMI,EAAMD,EAAIJ,GAChBI,EAAIJ,GAAKI,EAAIH,GACbG,EAAIH,GAAKI,EC5DE,SAASC,EAAM7B,EAAKC,EAAQ6B,EAAMC,EAAMC,EAAMC,EAAM/B,GAC/D,MAAMgC,EAAQ,CAAC,EAAGlC,EAAImC,OAAS,EAAG,GAC5BC,EAAS,GACf,IAAIC,EAAGC,EAEP,MAAOJ,EAAMC,OAAQ,CACjB,MAAMI,EAAOL,EAAMM,MACbpC,EAAQ8B,EAAMM,MACdrC,EAAO+B,EAAMM,MAEnB,GAAIpC,EAAQD,GAAQD,EAAU,CAC1B,IAAK,IAAIqB,EAAIpB,EAAMoB,GAAKnB,EAAOmB,IAC3Bc,EAAIpC,EAAO,EAAIsB,GACfe,EAAIrC,EAAO,EAAIsB,EAAI,GACfc,GAAKP,GAAQO,GAAKL,GAAQM,GAAKP,GAAQO,GAAKL,GAAMG,EAAOK,KAAKzC,EAAIuB,IAE1E,SAGJ,MAAMjB,EAAIK,KAAKQ,OAAOhB,EAAOC,GAAS,GAEtCiC,EAAIpC,EAAO,EAAIK,GACfgC,EAAIrC,EAAO,EAAIK,EAAI,GAEf+B,GAAKP,GAAQO,GAAKL,GAAQM,GAAKP,GAAQO,GAAKL,GAAMG,EAAOK,KAAKzC,EAAIM,IAEtE,MAAMoC,GAAYH,EAAO,GAAK,GAEjB,IAATA,EAAaT,GAAQO,EAAIN,GAAQO,KACjCJ,EAAMO,KAAKtC,GACX+B,EAAMO,KAAKnC,EAAI,GACf4B,EAAMO,KAAKC,KAEF,IAATH,EAAaP,GAAQK,EAAIJ,GAAQK,KACjCJ,EAAMO,KAAKnC,EAAI,GACf4B,EAAMO,KAAKrC,GACX8B,EAAMO,KAAKC,IAInB,OAAON,ECxCI,SAASO,EAAO3C,EAAKC,EAAQ2C,EAAIC,EAAIC,EAAG5C,GACnD,MAAMgC,EAAQ,CAAC,EAAGlC,EAAImC,OAAS,EAAG,GAC5BC,EAAS,GACTW,EAAKD,EAAIA,EAEf,MAAOZ,EAAMC,OAAQ,CACjB,MAAMI,EAAOL,EAAMM,MACbpC,EAAQ8B,EAAMM,MACdrC,EAAO+B,EAAMM,MAEnB,GAAIpC,EAAQD,GAAQD,EAAU,CAC1B,IAAK,IAAIqB,EAAIpB,EAAMoB,GAAKnB,EAAOmB,IACvByB,EAAO/C,EAAO,EAAIsB,GAAItB,EAAO,EAAIsB,EAAI,GAAIqB,EAAIC,IAAOE,GAAIX,EAAOK,KAAKzC,EAAIuB,IAEhF,SAGJ,MAAMjB,EAAIK,KAAKQ,OAAOhB,EAAOC,GAAS,GAEhCiC,EAAIpC,EAAO,EAAIK,GACfgC,EAAIrC,EAAO,EAAIK,EAAI,GAErB0C,EAAOX,EAAGC,EAAGM,EAAIC,IAAOE,GAAIX,EAAOK,KAAKzC,EAAIM,IAEhD,MAAMoC,GAAYH,EAAO,GAAK,GAEjB,IAATA,EAAaK,EAAKE,GAAKT,EAAIQ,EAAKC,GAAKR,KACrCJ,EAAMO,KAAKtC,GACX+B,EAAMO,KAAKnC,EAAI,GACf4B,EAAMO,KAAKC,KAEF,IAATH,EAAaK,EAAKE,GAAKT,EAAIQ,EAAKC,GAAKR,KACrCJ,EAAMO,KAAKnC,EAAI,GACf4B,EAAMO,KAAKrC,GACX8B,EAAMO,KAAKC,IAInB,OAAON,EAGX,SAASY,EAAOC,EAAIC,EAAIC,EAAIC,GACxB,MAAMC,EAAKJ,EAAKE,EACVG,EAAKJ,EAAKE,EAChB,OAAOC,EAAKA,EAAKC,EAAKA,E,kCCxC1B,MAAMC,EAAcC,GAAKA,EAAE,GACrBC,EAAcD,GAAKA,EAAE,GAEZ,MAAM,EACjB,YAAYE,EAAQC,EAAOJ,EAAaK,EAAOH,EAAavD,EAAW,GAAI2D,EAAYC,cACnFC,KAAK7D,SAAWA,EAChB6D,KAAKL,OAASA,EAEd,MAAMM,EAAiBN,EAAOvB,OAAS,MAAQ8B,YAAcC,YAEvDlE,EAAM+D,KAAK/D,IAAM,IAAIgE,EAAeN,EAAOvB,QAC3ClC,EAAS8D,KAAK9D,OAAS,IAAI4D,EAA0B,EAAhBH,EAAOvB,QAElD,IAAK,IAAIZ,EAAI,EAAGA,EAAImC,EAAOvB,OAAQZ,IAC/BvB,EAAIuB,GAAKA,EACTtB,EAAO,EAAIsB,GAAKoC,EAAKD,EAAOnC,IAC5BtB,EAAO,EAAIsB,EAAI,GAAKqC,EAAKF,EAAOnC,IAGpC,EAAKvB,EAAKC,EAAQC,EAAU,EAAGF,EAAImC,OAAS,EAAG,GAGnD,MAAML,EAAMC,EAAMC,EAAMC,GACpB,OAAOJ,EAAMkC,KAAK/D,IAAK+D,KAAK9D,OAAQ6B,EAAMC,EAAMC,EAAMC,EAAM8B,KAAK7D,UAGrE,OAAOmC,EAAGC,EAAGQ,GACT,OAAOH,EAAOoB,KAAK/D,IAAK+D,KAAK9D,OAAQoC,EAAGC,EAAGQ,EAAGiB,KAAK7D,WC7B3D,MAAMiE,EAAiB,CACnBC,QAAS,EACTC,QAAS,GACTC,UAAW,EACXC,OAAQ,GACRC,OAAQ,IACRtE,SAAU,GACVU,KAAK,EAGL6D,YAAY,EAGZC,OAAQ,KAGRC,IAAKC,GAASA,GAGZC,EAASlE,KAAKkE,QAAU,CAACjD,GAASS,IAAQT,EAAI,IAAMS,EAAUT,EAAI,IAA1C,CAAkD,IAAIkD,aAAa,IAElF,MAAM,EACjB,YAAYC,GACRhB,KAAKgB,QAAUC,EAAOC,OAAOC,OAAOf,GAAiBY,GACrDhB,KAAKoB,MAAQ,IAAIC,MAAMrB,KAAKgB,QAAQV,QAAU,GAGlD,KAAKX,GACD,MAAM,IAAC9C,EAAG,QAAEwD,EAAO,QAAEC,EAAO,SAAEnE,GAAY6D,KAAKgB,QAE3CnE,GAAKyE,QAAQC,KAAK,cAEtB,MAAMC,EAAU,WAAa7B,EAAOvB,gBAChCvB,GAAKyE,QAAQC,KAAKC,GAEtBxB,KAAKL,OAASA,EAGd,IAAI8B,EAAW,GACf,IAAK,IAAIjE,EAAI,EAAGA,EAAImC,EAAOvB,OAAQZ,IAC1BmC,EAAOnC,GAAGkE,UACfD,EAAS/C,KAAKiD,EAAmBhC,EAAOnC,GAAIA,IAEhDwC,KAAKoB,MAAMd,EAAU,GAAK,IAAI,EAAOmB,EAAU,EAAM,EAAMtF,EAAU4E,cAEjElE,GAAKyE,QAAQM,QAAQJ,GAIzB,IAAK,IAAI7E,EAAI2D,EAAS3D,GAAK0D,EAAS1D,IAAK,CACrC,MAAMkF,GAAOC,KAAKD,MAGlBJ,EAAWzB,KAAK+B,SAASN,EAAU9E,GACnCqD,KAAKoB,MAAMzE,GAAK,IAAI,EAAO8E,EAAU,EAAM,EAAMtF,EAAU4E,cAEvDlE,GAAKyE,QAAQzE,IAAI,2BAA4BF,EAAG8E,EAASrD,QAAS0D,KAAKD,MAAQA,GAKvF,OAFIhF,GAAKyE,QAAQM,QAAQ,cAElB5B,KAGX,YAAYgC,EAAMC,GACd,IAAIC,IAAWF,EAAK,GAAK,KAAO,IAAM,KAAO,IAAM,IACnD,MAAMG,EAASvF,KAAKO,KAAK,GAAIP,KAAKU,IAAI,GAAI0E,EAAK,KAC/C,IAAII,EAAqB,MAAZJ,EAAK,GAAa,MAAQA,EAAK,GAAK,KAAO,IAAM,KAAO,IAAM,IAC3E,MAAMK,EAASzF,KAAKO,KAAK,GAAIP,KAAKU,IAAI,GAAI0E,EAAK,KAE/C,GAAIA,EAAK,GAAKA,EAAK,IAAM,IACrBE,GAAU,IACVE,EAAS,SACN,GAAIF,EAASE,EAAQ,CACxB,MAAME,EAAatC,KAAKuC,YAAY,CAACL,EAAQC,EAAQ,IAAKE,GAASJ,GAC7DO,EAAaxC,KAAKuC,YAAY,EAAE,IAAKJ,EAAQC,EAAQC,GAASJ,GACpE,OAAOK,EAAWG,OAAOD,GAG7B,MAAME,EAAO1C,KAAKoB,MAAMpB,KAAK2C,WAAWV,IAClChG,EAAMyG,EAAK5E,MAAM8E,EAAKV,GAASW,EAAKR,GAASO,EAAKR,GAASS,EAAKV,IAChEV,EAAW,GACjB,IAAK,MAAMqB,KAAM7G,EAAK,CAClB,MAAM8G,EAAIL,EAAK/C,OAAOmD,GACtBrB,EAAS/C,KAAKqE,EAAEC,UAAYC,EAAeF,GAAK/C,KAAKL,OAAOoD,EAAEG,QAElE,OAAOzB,EAGX,YAAY0B,GACR,MAAMC,EAAWpD,KAAKqD,aAAaF,GAC7BG,EAAatD,KAAKuD,eAAeJ,GACjCK,EAAW,oCAEXN,EAAQlD,KAAKoB,MAAMkC,GACzB,IAAKJ,EAAO,MAAM,IAAIO,MAAMD,GAE5B,MAAME,EAASR,EAAMvD,OAAOyD,GAC5B,IAAKM,EAAQ,MAAM,IAAID,MAAMD,GAE7B,MAAMzE,EAAIiB,KAAKgB,QAAQR,QAAUR,KAAKgB,QAAQP,OAAS7D,KAAK+G,IAAI,EAAGL,EAAa,IAC1ErH,EAAMiH,EAAMtE,OAAO8E,EAAOpF,EAAGoF,EAAOnF,EAAGQ,GACvC6E,EAAW,GACjB,IAAK,MAAMd,KAAM7G,EAAK,CAClB,MAAM8G,EAAIG,EAAMvD,OAAOmD,GACnBC,EAAEc,WAAaV,GACfS,EAASlF,KAAKqE,EAAEC,UAAYC,EAAeF,GAAK/C,KAAKL,OAAOoD,EAAEG,QAItE,GAAwB,IAApBU,EAASxF,OAAc,MAAM,IAAIqF,MAAMD,GAE3C,OAAOI,EAGX,UAAUT,EAAWW,EAAOC,GACxBD,EAAQA,GAAS,GACjBC,EAASA,GAAU,EAEnB,MAAMC,EAAS,GAGf,OAFAhE,KAAKiE,cAAcD,EAAQb,EAAWW,EAAOC,EAAQ,GAE9CC,EAGX,QAAQrH,EAAG2B,EAAGC,GACV,MAAMmE,EAAO1C,KAAKoB,MAAMpB,KAAK2C,WAAWhG,IAClCuH,EAAKtH,KAAK+G,IAAI,EAAGhH,IACjB,OAAC8D,EAAM,OAAED,GAAUR,KAAKgB,QACxBvB,EAAIe,EAASC,EACb0D,GAAO5F,EAAIkB,GAAKyE,EAChBE,GAAU7F,EAAI,EAAIkB,GAAKyE,EAEvBG,EAAO,CACTC,SAAU,IAkBd,OAfAtE,KAAKuE,iBACD7B,EAAK5E,OAAOQ,EAAImB,GAAKyE,EAAIC,GAAM7F,EAAI,EAAImB,GAAKyE,EAAIE,GAChD1B,EAAK/C,OAAQrB,EAAGC,EAAG2F,EAAIG,GAEjB,IAAN/F,GACA0B,KAAKuE,iBACD7B,EAAK5E,MAAM,EAAI2B,EAAIyE,EAAIC,EAAK,EAAGC,GAC/B1B,EAAK/C,OAAQuE,EAAI3F,EAAG2F,EAAIG,GAE5B/F,IAAM4F,EAAK,GACXlE,KAAKuE,iBACD7B,EAAK5E,MAAM,EAAGqG,EAAK1E,EAAIyE,EAAIE,GAC3B1B,EAAK/C,QAAS,EAAGpB,EAAG2F,EAAIG,GAGzBA,EAAKC,SAASlG,OAASiG,EAAO,KAGzC,wBAAwBlB,GACpB,IAAIqB,EAAgBxE,KAAKuD,eAAeJ,GAAa,EACrD,MAAOqB,GAAiBxE,KAAKgB,QAAQV,QAAS,CAC1C,MAAMsD,EAAW5D,KAAKyE,YAAYtB,GAElC,GADAqB,IACwB,IAApBZ,EAASxF,OAAc,MAC3B+E,EAAYS,EAAS,GAAGc,WAAWC,WAEvC,OAAOH,EAGX,cAAcnG,EAAQ8E,EAAWW,EAAOC,EAAQa,GAC5C,MAAMhB,EAAW5D,KAAKyE,YAAYtB,GAElC,IAAK,MAAM0B,KAASjB,EAAU,CAC1B,MAAM/C,EAAQgE,EAAMH,WAkBpB,GAhBI7D,GAASA,EAAMiE,QACXF,EAAU/D,EAAMkE,aAAehB,EAE/Ba,GAAW/D,EAAMkE,YAGjBH,EAAU5E,KAAKiE,cAAc5F,EAAQwC,EAAM8D,WAAYb,EAAOC,EAAQa,GAGnEA,EAAUb,EAEjBa,IAGAvG,EAAOK,KAAKmG,GAEZxG,EAAOD,SAAW0F,EAAO,MAGjC,OAAOc,EAGX,iBAAiB3I,EAAK0D,EAAQrB,EAAGC,EAAG2F,EAAIG,GACpC,IAAK,MAAM7G,KAAKvB,EAAK,CACjB,MAAM8G,EAAIpD,EAAOnC,GACXwH,EAAYjC,EAAEC,UAEpB,IAAIiC,EAAMC,EAAIC,EACd,GAAIH,EACAC,EAAOG,EAAqBrC,GAC5BmC,EAAKnC,EAAEzE,EACP6G,EAAKpC,EAAExE,MACJ,CACH,MAAMkB,EAAIO,KAAKL,OAAOoD,EAAEG,OACxB+B,EAAOxF,EAAEiF,WACTQ,EAAKtC,EAAKnD,EAAEiC,SAAS2D,YAAY,IACjCF,EAAKtC,EAAKpD,EAAEiC,SAAS2D,YAAY,IAGrC,MAAMC,EAAI,CACNC,KAAM,EACN7D,SAAU,CAAC,CACP9E,KAAK4I,MAAMxF,KAAKgB,QAAQP,QAAUyE,EAAKhB,EAAK5F,IAC5C1B,KAAK4I,MAAMxF,KAAKgB,QAAQP,QAAU0E,EAAKjB,EAAK3F,MAEhD0G,QAIJ,IAAInC,EACAkC,EACAlC,EAAKC,EAAED,GACA9C,KAAKgB,QAAQN,WAEpBoC,EAAKC,EAAEG,MACAlD,KAAKL,OAAOoD,EAAEG,OAAOJ,KAE5BA,EAAK9C,KAAKL,OAAOoD,EAAEG,OAAOJ,SAGnB2C,IAAP3C,IAAkBwC,EAAExC,GAAKA,GAE7BuB,EAAKC,SAAS5F,KAAK4G,IAI3B,WAAW3I,GACP,OAAOC,KAAKO,IAAI6C,KAAKgB,QAAQX,QAASzD,KAAKU,IAAIV,KAAKQ,OAAOT,GAAIqD,KAAKgB,QAAQV,QAAU,IAG1F,SAASX,EAAQsC,GACb,MAAMR,EAAW,IACX,OAACjB,EAAM,OAAEC,EAAM,OAAEE,EAAM,UAAEJ,GAAaP,KAAKgB,QAC3CjC,EAAIyB,GAAUC,EAAS7D,KAAK+G,IAAI,EAAG1B,IAGzC,IAAK,IAAIzE,EAAI,EAAGA,EAAImC,EAAOvB,OAAQZ,IAAK,CACpC,MAAMiC,EAAIE,EAAOnC,GAEjB,GAAIiC,EAAEwC,MAAQA,EAAM,SACpBxC,EAAEwC,KAAOA,EAGT,MAAMS,EAAO1C,KAAKoB,MAAMa,EAAO,GACzByD,EAAchD,EAAK9D,OAAOa,EAAEnB,EAAGmB,EAAElB,EAAGQ,GAEpC4G,EAAkBlG,EAAEuD,WAAa,EACvC,IAAIA,EAAY2C,EAGhB,IAAK,MAAMC,KAAcF,EAAa,CAClC,MAAMG,EAAInD,EAAK/C,OAAOiG,GAElBC,EAAE5D,KAAOA,IAAMe,GAAa6C,EAAE7C,WAAa,GAInD,GAAIA,EAAY2C,GAAmB3C,GAAazC,EAAW,CACvD,IAAIuF,EAAKrG,EAAEnB,EAAIqH,EACXI,EAAKtG,EAAElB,EAAIoH,EAEXK,EAAoBrF,GAAUgF,EAAkB,EAAI3F,KAAKiG,KAAKxG,GAAG,GAAQ,KAG7E,MAAMqD,GAAMtF,GAAK,IAAMyE,EAAO,GAAKjC,KAAKL,OAAOvB,OAE/C,IAAK,MAAMwH,KAAcF,EAAa,CAClC,MAAMG,EAAInD,EAAK/C,OAAOiG,GAEtB,GAAIC,EAAE5D,MAAQA,EAAM,SACpB4D,EAAE5D,KAAOA,EAET,MAAMiE,EAAaL,EAAE7C,WAAa,EAClC8C,GAAMD,EAAEvH,EAAI4H,EACZH,GAAMF,EAAEtH,EAAI2H,EAEZL,EAAEhC,SAAWf,EAETnC,IACKqF,IAAmBA,EAAoBhG,KAAKiG,KAAKxG,GAAG,IACzDkB,EAAOqF,EAAmBhG,KAAKiG,KAAKJ,KAI5CpG,EAAEoE,SAAWf,EACbrB,EAAS/C,KAAKyH,EAAcL,EAAK9C,EAAW+C,EAAK/C,EAAWF,EAAIE,EAAWgD,SAK3E,GAFAvE,EAAS/C,KAAKe,GAEVuD,EAAY,EACZ,IAAK,MAAM4C,KAAcF,EAAa,CAClC,MAAMG,EAAInD,EAAK/C,OAAOiG,GAClBC,EAAE5D,MAAQA,IACd4D,EAAE5D,KAAOA,EACTR,EAAS/C,KAAKmH,KAM9B,OAAOpE,EAIX,aAAa0B,GACT,OAAQA,EAAYnD,KAAKL,OAAOvB,QAAW,EAI/C,eAAe+E,GACX,OAAQA,EAAYnD,KAAKL,OAAOvB,QAAU,GAG9C,KAAKgI,EAAOC,GACR,GAAID,EAAMpD,UACN,OAAOqD,EAAQpF,EAAO,GAAImF,EAAM1B,YAAc0B,EAAM1B,WAExD,MAAM4B,EAAWtG,KAAKL,OAAOyG,EAAMlD,OAAOwB,WACpCrG,EAAS2B,KAAKgB,QAAQJ,IAAI0F,GAChC,OAAOD,GAAShI,IAAWiI,EAAWrF,EAAO,GAAI5C,GAAUA,GAInE,SAAS8H,EAAc7H,EAAGC,EAAGuE,EAAIE,EAAW0B,GACxC,MAAO,CACHpG,EAAGwC,EAAOxC,GACVC,EAAGuC,EAAOvC,GACV0D,KAAMsE,IACNzD,KACAe,UAAW,EACXb,YACA0B,cAIR,SAAS/C,EAAmBlC,EAAGqD,GAC3B,MAAOxE,EAAGC,GAAKkB,EAAEiC,SAAS2D,YAC1B,MAAO,CACH/G,EAAGwC,EAAO8B,EAAKtE,IACfC,EAAGuC,EAAO+B,EAAKtE,IACf0D,KAAMsE,IACNrD,MAAOJ,EACPe,UAAW,GAInB,SAASZ,EAAe6B,GACpB,MAAO,CACHS,KAAM,UACNzC,GAAIgC,EAAQhC,GACZ4B,WAAYU,EAAqBN,GACjCpD,SAAU,CACN6D,KAAM,QACNF,YAAa,CAACmB,EAAK1B,EAAQxG,GAAImI,EAAK3B,EAAQvG,MAKxD,SAAS6G,EAAqBN,GAC1B,MAAM4B,EAAQ5B,EAAQ9B,UAChB2D,EACFD,GAAS,IAAW9J,KAAK4I,MAAMkB,EAAQ,KAAtB,IACjBA,GAAS,IAAU9J,KAAK4I,MAAMkB,EAAQ,KAAO,GAA7B,IAAuCA,EAC3D,OAAOzF,EAAOA,EAAO,GAAI6D,EAAQJ,YAAa,CAC1CI,SAAS,EACTH,WAAYG,EAAQhC,GACpBiC,YAAa2B,EACbE,wBAAyBD,IAKjC,SAAS/D,EAAKiE,GACV,OAAOA,EAAM,IAAM,GAEvB,SAAShE,EAAKiE,GACV,MAAMC,EAAMnK,KAAKmK,IAAID,EAAMlK,KAAKoK,GAAK,KAC/BzI,EAAK,GAAM,IAAO3B,KAAKC,KAAK,EAAIkK,IAAQ,EAAIA,IAAQnK,KAAKoK,GAC/D,OAAOzI,EAAI,EAAI,EAAIA,EAAI,EAAI,EAAIA,EAInC,SAASiI,EAAKlI,GACV,OAAmB,KAAXA,EAAI,IAEhB,SAASmI,EAAKlI,GACV,MAAM0I,GAAM,IAAU,IAAJ1I,GAAW3B,KAAKoK,GAAK,IACvC,OAAO,IAAMpK,KAAKsK,KAAKtK,KAAKG,IAAIkK,IAAOrK,KAAKoK,GAAK,GAGrD,SAAS/F,EAAOkG,EAAMC,GAClB,IAAK,MAAMtE,KAAMsE,EAAKD,EAAKrE,GAAMsE,EAAItE,GACrC,OAAOqE,EAGX,SAAS,EAAK1H,GACV,OAAOA,EAAEnB,EAEb,SAAS,EAAKmB,GACV,OAAOA,EAAElB,E;;;;;;;;;;;;;;;AC7Yb,SAAS8I,EAAOvK,EAAGwK,GACf,IAAI/J,EAAI,GACR,IAAK,IAAIkC,KAAK3C,EAAOoE,OAAOqG,UAAUC,eAAeC,KAAK3K,EAAG2C,IAAM6H,EAAEI,QAAQjI,GAAK,IAC9ElC,EAAEkC,GAAK3C,EAAE2C,IACb,GAAS,MAAL3C,GAAqD,oBAAjCoE,OAAOyG,sBACtB,KAAInK,EAAI,EAAb,IAAgBiC,EAAIyB,OAAOyG,sBAAsB7K,GAAIU,EAAIiC,EAAErB,OAAQZ,IAC3D8J,EAAEI,QAAQjI,EAAEjC,IAAM,GAAK0D,OAAOqG,UAAUK,qBAAqBH,KAAK3K,EAAG2C,EAAEjC,MACvED,EAAEkC,EAAEjC,IAAMV,EAAE2C,EAAEjC,KAE1B,OAAOD,EAkBX,MAAMsK,EACF,aAAY,QAAEC,EAAO,SAAEC,IACnB/H,KAAK8H,QAAUA,EACXC,IACIA,aAAoBC,OAAOC,KAAKC,OAChClI,KAAKmI,UAAYJ,EAGjB/H,KAAKmI,UAAY,IAAIH,OAAOC,KAAKC,OAAOH,IAIpD,aACI,GAA4B,IAAxB/H,KAAK8H,QAAQ1J,QAAiB4B,KAAKmI,UAGvC,OAAOnI,KAAK8H,QAAQnH,OAAO,CAACyH,EAAQC,IACzBD,EAAOnH,OAAOoH,EAAOC,eAC7B,IAAIN,OAAOC,KAAKM,aAAavI,KAAKmI,UAAWnI,KAAKmI,YAEzD,eACI,OAAOnI,KAAKmI,WAAanI,KAAKoI,OAAOI,YAKzC,YACI,OAAOxI,KAAK8H,QAAQW,OAAQlM,GAAMA,EAAEmM,cAC/BtK,OAKT,KAAKiK,GACDrI,KAAK8H,QAAQpJ,KAAK2J,GAKtB,SACQrI,KAAKqI,SACLrI,KAAKqI,OAAOM,OAAO,aACZ3I,KAAKqI,QAEhBrI,KAAK8H,QAAQ1J,OAAS,GA6F9B,MAAMwK,EACF,aAAY,QAAEtI,EAAU,KACpBN,KAAKM,QAAUA,EAcnB,MAAK,QAAEwH,IACH,OAAOe,EAAKf,IAuCpB,MAAMe,EAAQf,IACV,MAAMrG,EAAWqG,EAAQlH,IAAKyH,GAAW,IAAIR,EAAQ,CACjDE,SAAUM,EAAOC,cACjBR,QAAS,CAACO,MAEd,OAAO5G,GAoHX,MAAM,UAA8BmH,EAChC,YAAYE,GACR,IAAI,QAAExI,EAAO,OAAEE,EAAS,IAAOsI,EAAI9H,EAAUqG,EAAOyB,EAAI,CAAC,UAAW,WACpEC,MAAM,CAAEzI,YACRN,KAAKgJ,aAAe,IAAI,EAAa9H,OAAO+H,OAAO,CAAE3I,QAASN,KAAKM,QAASE,UAAUQ,IACtFhB,KAAKkJ,MAAQ,CAAEjH,KAAM,MAEzB,UAAUkH,GACN,IAAIC,GAAU,EACd,IAAK,IAAMD,EAAMrB,QAAS9H,KAAK8H,SAAU,CACrCsB,GAAU,EAEVpJ,KAAK8H,QAAU,IAAIqB,EAAMrB,SACzB,MAAMnI,EAASK,KAAK8H,QAAQlH,IAAKyH,IACtB,CACH9C,KAAM,UACN7D,SAAU,CACN6D,KAAM,QACNF,YAAa,CACTgD,EAAOC,cAAczB,MACrBwB,EAAOC,cAAcxB,QAG7BpC,WAAY,CAAE2D,aAGtBrI,KAAKgJ,aAAaK,KAAK1J,GAE3B,MAAMuJ,EAAQ,CAAEjH,KAAMkH,EAAMvI,IAAI0I,WAWhC,OAVKF,GACGpJ,KAAKkJ,MAAMjH,KAAOjC,KAAKM,SAAW4I,EAAMjH,KAAOjC,KAAKM,UAEpD8I,EAAUA,IAAY,IAAMpJ,KAAKkJ,MAAOA,IAGhDlJ,KAAKkJ,MAAQA,EACTE,IACApJ,KAAKyB,SAAWzB,KAAK8E,QAAQqE,IAE1B,CAAE1H,SAAUzB,KAAKyB,SAAU2H,WAEtC,SAAQ,IAAExI,IACN,OAAOZ,KAAKgJ,aACPzG,YAAY,EAAE,KAAM,GAAI,IAAK,IAAK3F,KAAK4I,MAAM5E,EAAI0I,YACjD1I,IAAIZ,KAAKuJ,iBAAiBC,KAAKxJ,OAExC,kBAAmB0B,UAAY2D,aAAcwB,EAAKC,IAAO,WAAEpC,IACvD,GAAIA,EAAWI,QACX,OAAO,IAAI+C,EAAQ,CACfC,QAAS9H,KAAKgJ,aACTS,UAAU/E,EAAWC,WAAY4B,KACjC3F,IAAK8I,GAASA,EAAKhF,WAAW2D,QACnCN,SAAU,IAAIC,OAAOC,KAAKC,OAAO,CAAEpB,MAAKD,UAG3C,CACD,MAAMwB,EAAS3D,EAAW2D,OAC1B,OAAO,IAAIR,EAAQ,CACfC,QAAS,CAACO,GACVN,SAAUM,EAAOC,kBAwBjC,MAAMqB,EACF,YAAY7B,EAASrG,GACjBzB,KAAK8H,QAAU,CAAE8B,IAAK9B,EAAQ1J,QAC9B,MAAMyL,EAAsBpI,EAASb,IAAKkJ,GAAMA,EAAEpD,OAC5CqD,EAAmBF,EAAoBlJ,OAAO,CAACmJ,EAAGjE,IAAMiE,EAAIjE,EAAG,GACrE7F,KAAKyB,SAAW,CACZiF,MAAOjF,EAASrD,OAChB0J,QAAS,CACLkC,KAAMD,EAAmBtI,EAASrD,OAClCwL,IAAKG,EACLzM,IAAKV,KAAKU,OAAOuM,GACjB1M,IAAKP,KAAKO,OAAO0M,MAKjC,MAAMI,EAuCF,QAAO,MAAEvD,EAAK,SAAEqB,GAAYmC,GAExB,MAAMC,EAAQzD,EAAQ9J,KAAKO,IAAI,GAAI+M,EAAMzI,SAASqG,QAAQkC,MAAQ,UAAY,UAExEI,EAAMC,OAAOC,KAAK,kBACjBH,6OAMP,OAAO,IAAInC,OAAOC,KAAKsC,OAAO,CAC1BxC,WACAyC,KAAM,CACFC,IAAK,6BAA6BL,EAClCM,WAAY,IAAI1C,OAAOC,KAAK0C,KAAK,GAAI,KAEzCC,MAAO,CACHC,KAAMC,OAAOpE,GACbyD,MAAO,wBACPY,SAAU,QAEdC,MAAO,cAActE,YAErBuE,OAAQC,OAAOlD,OAAOC,KAAKsC,OAAOY,YAAczE,KA4B5D,SAAS,EAAO0E,EAAOC,GAGnB,IAAK,IAAIC,KAAYD,EAAM9D,UACvB6D,EAAM7D,UAAU+D,GAAYD,EAAM9D,UAAU+D,GAMpD,MAAMC,EACF,cAMI,EAAOA,EAAiBvD,OAAOC,KAAKuD,cAmB5C,IAAIC,GACJ,SAAWA,GACPA,EAAsB,oBAAsB,kBAC5CA,EAAsB,kBAAoB,gBAC1CA,EAAsB,iBAAmB,SAH7C,CAIGA,IAA0BA,EAAwB,KACrD,MAAMC,EAA+B,CAACC,EAAG7G,EAASlE,KAC9CA,EAAIgL,UAAU9G,EAAQsD,SAO1B,MAAMyD,UAAwBN,EAC1B,aAAY,IAAE3K,EAAG,QAAEkH,EAAU,GAAE,UAAEgE,EAAY,IAAI,EAAsB,IAAG,SAAEC,EAAW,IAAI9B,EAAiB,eAAE+B,EAAiBN,IAC3H3C,QACA/I,KAAK8H,QAAU,IAAIA,GACnB9H,KAAKyB,SAAW,GAChBzB,KAAK8L,UAAYA,EACjB9L,KAAK+L,SAAWA,EAChB/L,KAAKgM,eAAiBA,EAClBpL,GACAZ,KAAK2I,OAAO/H,GAGpB,UAAUyH,EAAQ4D,GACVjM,KAAK8H,QAAQoE,SAAS7D,KAG1BrI,KAAK8H,QAAQpJ,KAAK2J,GACb4D,GACDjM,KAAKmM,UAGb,WAAWrE,EAASmE,GAChBnE,EAAQsE,QAAS/D,IACbrI,KAAKqM,UAAUhE,GAAQ,KAEtB4D,GACDjM,KAAKmM,SAGb,aAAa9D,EAAQ4D,GACjB,MAAM/I,EAAQlD,KAAK8H,QAAQJ,QAAQW,GACnC,OAAe,IAAXnF,IAIJmF,EAAOM,OAAO,MACd3I,KAAK8H,QAAQwE,OAAOpJ,EAAO,GACtB+I,GACDjM,KAAKmM,UAEF,GAEX,cAAcrE,EAASmE,GACnB,IAAIM,GAAU,EAOd,OANAzE,EAAQsE,QAAS/D,IACbkE,EAAUvM,KAAKwM,aAAanE,GAAQ,IAASkE,IAE7CA,IAAYN,GACZjM,KAAKmM,SAEFI,EAEX,aAAaN,GACTjM,KAAK8H,QAAQ1J,OAAS,EACjB6N,GACDjM,KAAKmM,SAMb,SACI,MAAMvL,EAAMZ,KAAKyM,SACjB,GAAI7L,aAAeoH,OAAOC,KAAKyE,KAAO1M,KAAK2M,gBAAiB,CACxD3E,OAAOC,KAAK2E,MAAMC,QAAQ7M,KAAMyL,EAAsBqB,iBAAkB9M,MACxE,MAAM,SAAEyB,EAAQ,QAAE2H,GAAYpJ,KAAK8L,UAAUiB,UAAU,CACnDjF,QAAS9H,KAAK8H,QACdlH,MACAoM,oBAAqBhN,KAAK2M,mBAG1BvD,QAAsB3D,GAAX2D,KAEXpJ,KAAKiN,QAELjN,KAAKyB,SAAWA,EAChBzB,KAAKkN,kBAETlF,OAAOC,KAAK2E,MAAMC,QAAQ7M,KAAMyL,EAAsB0B,eAAgBnN,OAG9E,QACIA,KAAKoN,aAAepN,KAAKyM,SAASY,YAAY,OAAQrN,KAAKmM,OAAO3C,KAAKxJ,OACvEA,KAAKmM,SAET,WACInE,OAAOC,KAAK2E,MAAMU,eAAetN,KAAKoN,cACtCpN,KAAKiN,QAET,QACIjN,KAAK8H,QAAQsE,QAAS/D,GAAWA,EAAOM,OAAO,OAC/C3I,KAAKyB,SAAS2K,QAAStH,GAAYA,EAAQyI,UAC3CvN,KAAKyB,SAAW,GAEpB,iBAEI,MAAMyI,EAAQ,IAAIP,EAAa3J,KAAK8H,QAAS9H,KAAKyB,UAC5Cb,EAAMZ,KAAKyM,SACjBzM,KAAKyB,SAAS2K,QAAStH,IACY,IAA3BA,EAAQgD,QAAQ1J,OAChB0G,EAAQuD,OAASvD,EAAQgD,QAAQ,IAGjChD,EAAQuD,OAASrI,KAAK+L,SAASI,OAAOrH,EAASoF,GAC3ClK,KAAKgM,gBACLlH,EAAQuD,OAAOgF,YAAY,QAE1BT,IACG5E,OAAOC,KAAK2E,MAAMC,QAAQ7M,KAAMyL,EAAsB+B,cAAe1I,GACrE9E,KAAKgM,eAAeY,EAAO9H,EAASlE,MAIhDkE,EAAQuD,OAAOM,OAAO/H,Q,qBCxsBlC6M,EAAOC,QAAU,k0I,oCCMjBD,EAAOC,QAAU,SAASC,EAAM7D,EAAGjE,GACjC,GAAIiE,IAAMjE,EAAG,OAAO,EAEpB,GAAIiE,GAAKjE,GAAiB,iBAALiE,GAA6B,iBAALjE,EAAe,CAC1D,GAAIiE,EAAE8D,cAAgB/H,EAAE+H,YAAa,OAAO,EAE5C,IAAIxP,EAAQZ,EAAGqQ,EACf,GAAIxM,MAAMyM,QAAQhE,GAAI,CAEpB,GADA1L,EAAS0L,EAAE1L,OACPA,GAAUyH,EAAEzH,OAAQ,OAAO,EAC/B,IAAKZ,EAAIY,EAAgB,IAARZ,KACf,IAAKmQ,EAAM7D,EAAEtM,GAAIqI,EAAErI,IAAK,OAAO,EACjC,OAAO,EAKT,GAAIsM,EAAE8D,cAAgBG,OAAQ,OAAOjE,EAAEkE,SAAWnI,EAAEmI,QAAUlE,EAAEmE,QAAUpI,EAAEoI,MAC5E,GAAInE,EAAEoE,UAAYhN,OAAOqG,UAAU2G,QAAS,OAAOpE,EAAEoE,YAAcrI,EAAEqI,UACrE,GAAIpE,EAAEqE,WAAajN,OAAOqG,UAAU4G,SAAU,OAAOrE,EAAEqE,aAAetI,EAAEsI,WAIxE,GAFAN,EAAO3M,OAAO2M,KAAK/D,GACnB1L,EAASyP,EAAKzP,OACVA,IAAW8C,OAAO2M,KAAKhI,GAAGzH,OAAQ,OAAO,EAE7C,IAAKZ,EAAIY,EAAgB,IAARZ,KACf,IAAK0D,OAAOqG,UAAUC,eAAeC,KAAK5B,EAAGgI,EAAKrQ,IAAK,OAAO,EAEhE,IAAKA,EAAIY,EAAgB,IAARZ,KAAY,CAC3B,IAAI4Q,EAAMP,EAAKrQ,GAEf,IAAKmQ,EAAM7D,EAAEsE,GAAMvI,EAAEuI,IAAO,OAAO,EAGrC,OAAO,EAIT,OAAOtE,IAAIA,GAAKjE,IAAIA,I,mBC5CtB4H,EAAOC,QAAU","file":"js/chunk-45eadf48.7f5392dc.js","sourcesContent":["\nexport default function sortKD(ids, coords, nodeSize, left, right, depth) {\n if (right - left <= nodeSize) return;\n\n const m = (left + right) >> 1;\n\n select(ids, coords, m, left, right, depth % 2);\n\n sortKD(ids, coords, nodeSize, left, m - 1, depth + 1);\n sortKD(ids, coords, nodeSize, m + 1, right, depth + 1);\n}\n\nfunction select(ids, coords, k, left, right, inc) {\n\n while (right > left) {\n if (right - left > 600) {\n const n = right - left + 1;\n const m = k - left + 1;\n const z = Math.log(n);\n const s = 0.5 * Math.exp(2 * z / 3);\n const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n select(ids, coords, k, newLeft, newRight, inc);\n }\n\n const t = coords[2 * k + inc];\n let i = left;\n let j = right;\n\n swapItem(ids, coords, left, k);\n if (coords[2 * right + inc] > t) swapItem(ids, coords, left, right);\n\n while (i < j) {\n swapItem(ids, coords, i, j);\n i++;\n j--;\n while (coords[2 * i + inc] < t) i++;\n while (coords[2 * j + inc] > t) j--;\n }\n\n if (coords[2 * left + inc] === t) swapItem(ids, coords, left, j);\n else {\n j++;\n swapItem(ids, coords, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\nfunction swapItem(ids, coords, i, j) {\n swap(ids, i, j);\n swap(coords, 2 * i, 2 * j);\n swap(coords, 2 * i + 1, 2 * j + 1);\n}\n\nfunction swap(arr, i, j) {\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n","\nexport default function range(ids, coords, minX, minY, maxX, maxY, nodeSize) {\n const stack = [0, ids.length - 1, 0];\n const result = [];\n let x, y;\n\n while (stack.length) {\n const axis = stack.pop();\n const right = stack.pop();\n const left = stack.pop();\n\n if (right - left <= nodeSize) {\n for (let i = left; i <= right; i++) {\n x = coords[2 * i];\n y = coords[2 * i + 1];\n if (x >= minX && x <= maxX && y >= minY && y <= maxY) result.push(ids[i]);\n }\n continue;\n }\n\n const m = Math.floor((left + right) / 2);\n\n x = coords[2 * m];\n y = coords[2 * m + 1];\n\n if (x >= minX && x <= maxX && y >= minY && y <= maxY) result.push(ids[m]);\n\n const nextAxis = (axis + 1) % 2;\n\n if (axis === 0 ? minX <= x : minY <= y) {\n stack.push(left);\n stack.push(m - 1);\n stack.push(nextAxis);\n }\n if (axis === 0 ? maxX >= x : maxY >= y) {\n stack.push(m + 1);\n stack.push(right);\n stack.push(nextAxis);\n }\n }\n\n return result;\n}\n","\nexport default function within(ids, coords, qx, qy, r, nodeSize) {\n const stack = [0, ids.length - 1, 0];\n const result = [];\n const r2 = r * r;\n\n while (stack.length) {\n const axis = stack.pop();\n const right = stack.pop();\n const left = stack.pop();\n\n if (right - left <= nodeSize) {\n for (let i = left; i <= right; i++) {\n if (sqDist(coords[2 * i], coords[2 * i + 1], qx, qy) <= r2) result.push(ids[i]);\n }\n continue;\n }\n\n const m = Math.floor((left + right) / 2);\n\n const x = coords[2 * m];\n const y = coords[2 * m + 1];\n\n if (sqDist(x, y, qx, qy) <= r2) result.push(ids[m]);\n\n const nextAxis = (axis + 1) % 2;\n\n if (axis === 0 ? qx - r <= x : qy - r <= y) {\n stack.push(left);\n stack.push(m - 1);\n stack.push(nextAxis);\n }\n if (axis === 0 ? qx + r >= x : qy + r >= y) {\n stack.push(m + 1);\n stack.push(right);\n stack.push(nextAxis);\n }\n }\n\n return result;\n}\n\nfunction sqDist(ax, ay, bx, by) {\n const dx = ax - bx;\n const dy = ay - by;\n return dx * dx + dy * dy;\n}\n","\nimport sort from './sort';\nimport range from './range';\nimport within from './within';\n\nconst defaultGetX = p => p[0];\nconst defaultGetY = p => p[1];\n\nexport default class KDBush {\n constructor(points, getX = defaultGetX, getY = defaultGetY, nodeSize = 64, ArrayType = Float64Array) {\n this.nodeSize = nodeSize;\n this.points = points;\n\n const IndexArrayType = points.length < 65536 ? Uint16Array : Uint32Array;\n\n const ids = this.ids = new IndexArrayType(points.length);\n const coords = this.coords = new ArrayType(points.length * 2);\n\n for (let i = 0; i < points.length; i++) {\n ids[i] = i;\n coords[2 * i] = getX(points[i]);\n coords[2 * i + 1] = getY(points[i]);\n }\n\n sort(ids, coords, nodeSize, 0, ids.length - 1, 0);\n }\n\n range(minX, minY, maxX, maxY) {\n return range(this.ids, this.coords, minX, minY, maxX, maxY, this.nodeSize);\n }\n\n within(x, y, r) {\n return within(this.ids, this.coords, x, y, r, this.nodeSize);\n }\n}\n","\nimport KDBush from 'kdbush';\n\nconst defaultOptions = {\n minZoom: 0, // min zoom to generate clusters on\n maxZoom: 16, // max zoom level to cluster the points on\n minPoints: 2, // minimum points to form a cluster\n radius: 40, // cluster radius in pixels\n extent: 512, // tile extent (radius is calculated relative to it)\n nodeSize: 64, // size of the KD-tree leaf node, affects performance\n log: false, // whether to log timing info\n\n // whether to generate numeric ids for input features (in vector tiles)\n generateId: false,\n\n // a reduce function for calculating custom cluster properties\n reduce: null, // (accumulated, props) => { accumulated.sum += props.sum; }\n\n // properties to use for individual points when running the reducer\n map: props => props // props => ({sum: props.my_value})\n};\n\nconst fround = Math.fround || (tmp => ((x) => { tmp[0] = +x; return tmp[0]; }))(new Float32Array(1));\n\nexport default class Supercluster {\n constructor(options) {\n this.options = extend(Object.create(defaultOptions), options);\n this.trees = new Array(this.options.maxZoom + 1);\n }\n\n load(points) {\n const {log, minZoom, maxZoom, nodeSize} = this.options;\n\n if (log) console.time('total time');\n\n const timerId = `prepare ${ points.length } points`;\n if (log) console.time(timerId);\n\n this.points = points;\n\n // generate a cluster object for each point and index input points into a KD-tree\n let clusters = [];\n for (let i = 0; i < points.length; i++) {\n if (!points[i].geometry) continue;\n clusters.push(createPointCluster(points[i], i));\n }\n this.trees[maxZoom + 1] = new KDBush(clusters, getX, getY, nodeSize, Float32Array);\n\n if (log) console.timeEnd(timerId);\n\n // cluster points on max zoom, then cluster the results on previous zoom, etc.;\n // results in a cluster hierarchy across zoom levels\n for (let z = maxZoom; z >= minZoom; z--) {\n const now = +Date.now();\n\n // create a new set of clusters for the zoom and index them with a KD-tree\n clusters = this._cluster(clusters, z);\n this.trees[z] = new KDBush(clusters, getX, getY, nodeSize, Float32Array);\n\n if (log) console.log('z%d: %d clusters in %dms', z, clusters.length, +Date.now() - now);\n }\n\n if (log) console.timeEnd('total time');\n\n return this;\n }\n\n getClusters(bbox, zoom) {\n let minLng = ((bbox[0] + 180) % 360 + 360) % 360 - 180;\n const minLat = Math.max(-90, Math.min(90, bbox[1]));\n let maxLng = bbox[2] === 180 ? 180 : ((bbox[2] + 180) % 360 + 360) % 360 - 180;\n const maxLat = Math.max(-90, Math.min(90, bbox[3]));\n\n if (bbox[2] - bbox[0] >= 360) {\n minLng = -180;\n maxLng = 180;\n } else if (minLng > maxLng) {\n const easternHem = this.getClusters([minLng, minLat, 180, maxLat], zoom);\n const westernHem = this.getClusters([-180, minLat, maxLng, maxLat], zoom);\n return easternHem.concat(westernHem);\n }\n\n const tree = this.trees[this._limitZoom(zoom)];\n const ids = tree.range(lngX(minLng), latY(maxLat), lngX(maxLng), latY(minLat));\n const clusters = [];\n for (const id of ids) {\n const c = tree.points[id];\n clusters.push(c.numPoints ? getClusterJSON(c) : this.points[c.index]);\n }\n return clusters;\n }\n\n getChildren(clusterId) {\n const originId = this._getOriginId(clusterId);\n const originZoom = this._getOriginZoom(clusterId);\n const errorMsg = 'No cluster with the specified id.';\n\n const index = this.trees[originZoom];\n if (!index) throw new Error(errorMsg);\n\n const origin = index.points[originId];\n if (!origin) throw new Error(errorMsg);\n\n const r = this.options.radius / (this.options.extent * Math.pow(2, originZoom - 1));\n const ids = index.within(origin.x, origin.y, r);\n const children = [];\n for (const id of ids) {\n const c = index.points[id];\n if (c.parentId === clusterId) {\n children.push(c.numPoints ? getClusterJSON(c) : this.points[c.index]);\n }\n }\n\n if (children.length === 0) throw new Error(errorMsg);\n\n return children;\n }\n\n getLeaves(clusterId, limit, offset) {\n limit = limit || 10;\n offset = offset || 0;\n\n const leaves = [];\n this._appendLeaves(leaves, clusterId, limit, offset, 0);\n\n return leaves;\n }\n\n getTile(z, x, y) {\n const tree = this.trees[this._limitZoom(z)];\n const z2 = Math.pow(2, z);\n const {extent, radius} = this.options;\n const p = radius / extent;\n const top = (y - p) / z2;\n const bottom = (y + 1 + p) / z2;\n\n const tile = {\n features: []\n };\n\n this._addTileFeatures(\n tree.range((x - p) / z2, top, (x + 1 + p) / z2, bottom),\n tree.points, x, y, z2, tile);\n\n if (x === 0) {\n this._addTileFeatures(\n tree.range(1 - p / z2, top, 1, bottom),\n tree.points, z2, y, z2, tile);\n }\n if (x === z2 - 1) {\n this._addTileFeatures(\n tree.range(0, top, p / z2, bottom),\n tree.points, -1, y, z2, tile);\n }\n\n return tile.features.length ? tile : null;\n }\n\n getClusterExpansionZoom(clusterId) {\n let expansionZoom = this._getOriginZoom(clusterId) - 1;\n while (expansionZoom <= this.options.maxZoom) {\n const children = this.getChildren(clusterId);\n expansionZoom++;\n if (children.length !== 1) break;\n clusterId = children[0].properties.cluster_id;\n }\n return expansionZoom;\n }\n\n _appendLeaves(result, clusterId, limit, offset, skipped) {\n const children = this.getChildren(clusterId);\n\n for (const child of children) {\n const props = child.properties;\n\n if (props && props.cluster) {\n if (skipped + props.point_count <= offset) {\n // skip the whole cluster\n skipped += props.point_count;\n } else {\n // enter the cluster\n skipped = this._appendLeaves(result, props.cluster_id, limit, offset, skipped);\n // exit the cluster\n }\n } else if (skipped < offset) {\n // skip a single point\n skipped++;\n } else {\n // add a single point\n result.push(child);\n }\n if (result.length === limit) break;\n }\n\n return skipped;\n }\n\n _addTileFeatures(ids, points, x, y, z2, tile) {\n for (const i of ids) {\n const c = points[i];\n const isCluster = c.numPoints;\n\n let tags, px, py;\n if (isCluster) {\n tags = getClusterProperties(c);\n px = c.x;\n py = c.y;\n } else {\n const p = this.points[c.index];\n tags = p.properties;\n px = lngX(p.geometry.coordinates[0]);\n py = latY(p.geometry.coordinates[1]);\n }\n\n const f = {\n type: 1,\n geometry: [[\n Math.round(this.options.extent * (px * z2 - x)),\n Math.round(this.options.extent * (py * z2 - y))\n ]],\n tags\n };\n\n // assign id\n let id;\n if (isCluster) {\n id = c.id;\n } else if (this.options.generateId) {\n // optionally generate id\n id = c.index;\n } else if (this.points[c.index].id) {\n // keep id if already assigned\n id = this.points[c.index].id;\n }\n\n if (id !== undefined) f.id = id;\n\n tile.features.push(f);\n }\n }\n\n _limitZoom(z) {\n return Math.max(this.options.minZoom, Math.min(Math.floor(+z), this.options.maxZoom + 1));\n }\n\n _cluster(points, zoom) {\n const clusters = [];\n const {radius, extent, reduce, minPoints} = this.options;\n const r = radius / (extent * Math.pow(2, zoom));\n\n // loop through each point\n for (let i = 0; i < points.length; i++) {\n const p = points[i];\n // if we've already visited the point at this zoom level, skip it\n if (p.zoom <= zoom) continue;\n p.zoom = zoom;\n\n // find all nearby points\n const tree = this.trees[zoom + 1];\n const neighborIds = tree.within(p.x, p.y, r);\n\n const numPointsOrigin = p.numPoints || 1;\n let numPoints = numPointsOrigin;\n\n // count the number of points in a potential cluster\n for (const neighborId of neighborIds) {\n const b = tree.points[neighborId];\n // filter out neighbors that are already processed\n if (b.zoom > zoom) numPoints += b.numPoints || 1;\n }\n\n // if there were neighbors to merge, and there are enough points to form a cluster\n if (numPoints > numPointsOrigin && numPoints >= minPoints) {\n let wx = p.x * numPointsOrigin;\n let wy = p.y * numPointsOrigin;\n\n let clusterProperties = reduce && numPointsOrigin > 1 ? this._map(p, true) : null;\n\n // encode both zoom and point index on which the cluster originated -- offset by total length of features\n const id = (i << 5) + (zoom + 1) + this.points.length;\n\n for (const neighborId of neighborIds) {\n const b = tree.points[neighborId];\n\n if (b.zoom <= zoom) continue;\n b.zoom = zoom; // save the zoom (so it doesn't get processed twice)\n\n const numPoints2 = b.numPoints || 1;\n wx += b.x * numPoints2; // accumulate coordinates for calculating weighted center\n wy += b.y * numPoints2;\n\n b.parentId = id;\n\n if (reduce) {\n if (!clusterProperties) clusterProperties = this._map(p, true);\n reduce(clusterProperties, this._map(b));\n }\n }\n\n p.parentId = id;\n clusters.push(createCluster(wx / numPoints, wy / numPoints, id, numPoints, clusterProperties));\n\n } else { // left points as unclustered\n clusters.push(p);\n\n if (numPoints > 1) {\n for (const neighborId of neighborIds) {\n const b = tree.points[neighborId];\n if (b.zoom <= zoom) continue;\n b.zoom = zoom;\n clusters.push(b);\n }\n }\n }\n }\n\n return clusters;\n }\n\n // get index of the point from which the cluster originated\n _getOriginId(clusterId) {\n return (clusterId - this.points.length) >> 5;\n }\n\n // get zoom of the point from which the cluster originated\n _getOriginZoom(clusterId) {\n return (clusterId - this.points.length) % 32;\n }\n\n _map(point, clone) {\n if (point.numPoints) {\n return clone ? extend({}, point.properties) : point.properties;\n }\n const original = this.points[point.index].properties;\n const result = this.options.map(original);\n return clone && result === original ? extend({}, result) : result;\n }\n}\n\nfunction createCluster(x, y, id, numPoints, properties) {\n return {\n x: fround(x), // weighted cluster center; round for consistency with Float32Array index\n y: fround(y),\n zoom: Infinity, // the last zoom the cluster was processed at\n id, // encodes index of the first child of the cluster and its zoom level\n parentId: -1, // parent cluster id\n numPoints,\n properties\n };\n}\n\nfunction createPointCluster(p, id) {\n const [x, y] = p.geometry.coordinates;\n return {\n x: fround(lngX(x)), // projected point coordinates\n y: fround(latY(y)),\n zoom: Infinity, // the last zoom the point was processed at\n index: id, // index of the source feature in the original input array,\n parentId: -1 // parent cluster id\n };\n}\n\nfunction getClusterJSON(cluster) {\n return {\n type: 'Feature',\n id: cluster.id,\n properties: getClusterProperties(cluster),\n geometry: {\n type: 'Point',\n coordinates: [xLng(cluster.x), yLat(cluster.y)]\n }\n };\n}\n\nfunction getClusterProperties(cluster) {\n const count = cluster.numPoints;\n const abbrev =\n count >= 10000 ? `${Math.round(count / 1000) }k` :\n count >= 1000 ? `${Math.round(count / 100) / 10 }k` : count;\n return extend(extend({}, cluster.properties), {\n cluster: true,\n cluster_id: cluster.id,\n point_count: count,\n point_count_abbreviated: abbrev\n });\n}\n\n// longitude/latitude to spherical mercator in [0..1] range\nfunction lngX(lng) {\n return lng / 360 + 0.5;\n}\nfunction latY(lat) {\n const sin = Math.sin(lat * Math.PI / 180);\n const y = (0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI);\n return y < 0 ? 0 : y > 1 ? 1 : y;\n}\n\n// spherical mercator to longitude/latitude\nfunction xLng(x) {\n return (x - 0.5) * 360;\n}\nfunction yLat(y) {\n const y2 = (180 - y * 360) * Math.PI / 180;\n return 360 * Math.atan(Math.exp(y2)) / Math.PI - 90;\n}\n\nfunction extend(dest, src) {\n for (const id in src) dest[id] = src[id];\n return dest;\n}\n\nfunction getX(p) {\n return p.x;\n}\nfunction getY(p) {\n return p.y;\n}\n","import SuperCluster from 'supercluster';\nimport equal from 'fast-deep-equal';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nclass Cluster {\n constructor({ markers, position }) {\n this.markers = markers;\n if (position) {\n if (position instanceof google.maps.LatLng) {\n this._position = position;\n }\n else {\n this._position = new google.maps.LatLng(position);\n }\n }\n }\n get bounds() {\n if (this.markers.length === 0 && !this._position) {\n return undefined;\n }\n return this.markers.reduce((bounds, marker) => {\n return bounds.extend(marker.getPosition());\n }, new google.maps.LatLngBounds(this._position, this._position));\n }\n get position() {\n return this._position || this.bounds.getCenter();\n }\n /**\n * Get the count of **visible** markers.\n */\n get count() {\n return this.markers.filter((m) => m.getVisible())\n .length;\n }\n /**\n * Add a marker to the cluster.\n */\n push(marker) {\n this.markers.push(marker);\n }\n /**\n * Cleanup references and remove marker from map.\n */\n delete() {\n if (this.marker) {\n this.marker.setMap(null);\n delete this.marker;\n }\n this.markers.length = 0;\n }\n}\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nconst filterMarkersToPaddedViewport = (map, mapCanvasProjection, markers, viewportPadding) => {\n const extendedMapBounds = extendBoundsToPaddedViewport(map.getBounds(), mapCanvasProjection, viewportPadding);\n return markers.filter((marker) => extendedMapBounds.contains(marker.getPosition()));\n};\n/**\n * Extends a bounds by a number of pixels in each direction.\n */\nconst extendBoundsToPaddedViewport = (bounds, projection, pixels) => {\n const { northEast, southWest } = latLngBoundsToPixelBounds(bounds, projection);\n const extendedPixelBounds = extendPixelBounds({ northEast, southWest }, pixels);\n return pixelBoundsToLatLngBounds(extendedPixelBounds, projection);\n};\n/**\n * @hidden\n */\nconst distanceBetweenPoints = (p1, p2) => {\n const R = 6371; // Radius of the Earth in km\n const dLat = ((p2.lat - p1.lat) * Math.PI) / 180;\n const dLon = ((p2.lng - p1.lng) * Math.PI) / 180;\n const a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +\n Math.cos((p1.lat * Math.PI) / 180) *\n Math.cos((p2.lat * Math.PI) / 180) *\n Math.sin(dLon / 2) *\n Math.sin(dLon / 2);\n const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));\n return R * c;\n};\n/**\n * @hidden\n */\nconst latLngBoundsToPixelBounds = (bounds, projection) => {\n return {\n northEast: projection.fromLatLngToDivPixel(bounds.getNorthEast()),\n southWest: projection.fromLatLngToDivPixel(bounds.getSouthWest()),\n };\n};\n/**\n * @hidden\n */\nconst extendPixelBounds = ({ northEast, southWest }, pixels) => {\n northEast.x += pixels;\n northEast.y -= pixels;\n southWest.x -= pixels;\n southWest.y += pixels;\n return { northEast, southWest };\n};\n/**\n * @hidden\n */\nconst pixelBoundsToLatLngBounds = ({ northEast, southWest }, projection) => {\n const bounds = new google.maps.LatLngBounds();\n bounds.extend(projection.fromDivPixelToLatLng(northEast));\n bounds.extend(projection.fromDivPixelToLatLng(southWest));\n return bounds;\n};\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @hidden\n */\nclass AbstractAlgorithm {\n constructor({ maxZoom = 16 }) {\n this.maxZoom = maxZoom;\n }\n /**\n * Helper function to bypass clustering based upon some map state such as\n * zoom, number of markers, etc.\n *\n * ```typescript\n * cluster({markers, map}: AlgorithmInput): Cluster[] {\n * if (shouldBypassClustering(map)) {\n * return this.noop({markers, map})\n * }\n * }\n * ```\n */\n noop({ markers }) {\n return noop(markers);\n }\n}\n/**\n * Abstract viewport algorithm proves a class to filter markers by a padded\n * viewport. This is a common optimization.\n *\n * @hidden\n */\nclass AbstractViewportAlgorithm extends AbstractAlgorithm {\n constructor(_a) {\n var { viewportPadding = 60 } = _a, options = __rest(_a, [\"viewportPadding\"]);\n super(options);\n this.viewportPadding = 60;\n this.viewportPadding = viewportPadding;\n }\n calculate({ markers, map, mapCanvasProjection, }) {\n if (map.getZoom() >= this.maxZoom) {\n return {\n clusters: this.noop({\n markers,\n map,\n mapCanvasProjection,\n }),\n changed: false,\n };\n }\n return {\n clusters: this.cluster({\n markers: filterMarkersToPaddedViewport(map, mapCanvasProjection, markers, this.viewportPadding),\n map,\n mapCanvasProjection,\n }),\n };\n }\n}\n/**\n * @hidden\n */\nconst noop = (markers) => {\n const clusters = markers.map((marker) => new Cluster({\n position: marker.getPosition(),\n markers: [marker],\n }));\n return clusters;\n};\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * The default Grid algorithm historically used in Google Maps marker\n * clustering.\n *\n * The Grid algorithm does not implement caching and markers may flash as the\n * viewport changes. Instead use {@link SuperClusterAlgorithm}.\n */\nclass GridAlgorithm extends AbstractViewportAlgorithm {\n constructor(_a) {\n var { maxDistance = 40000, gridSize = 40 } = _a, options = __rest(_a, [\"maxDistance\", \"gridSize\"]);\n super(options);\n this.clusters = [];\n this.maxDistance = maxDistance;\n this.gridSize = gridSize;\n }\n cluster({ markers, map, mapCanvasProjection, }) {\n this.clusters = [];\n markers.forEach((marker) => {\n this.addToClosestCluster(marker, map, mapCanvasProjection);\n });\n return this.clusters;\n }\n addToClosestCluster(marker, map, projection) {\n let maxDistance = this.maxDistance; // Some large number\n let cluster = null;\n for (let i = 0; i < this.clusters.length; i++) {\n const candidate = this.clusters[i];\n const distance = distanceBetweenPoints(candidate.bounds.getCenter().toJSON(), marker.getPosition().toJSON());\n if (distance < maxDistance) {\n maxDistance = distance;\n cluster = candidate;\n }\n }\n if (cluster &&\n extendBoundsToPaddedViewport(cluster.bounds, projection, this.gridSize).contains(marker.getPosition())) {\n cluster.push(marker);\n }\n else {\n const cluster = new Cluster({ markers: [marker] });\n this.clusters.push(cluster);\n }\n }\n}\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Noop algorithm does not generate any clusters or filter markers by the an extended viewport.\n */\nclass NoopAlgorithm extends AbstractAlgorithm {\n constructor(_a) {\n var options = __rest(_a, []);\n super(options);\n }\n calculate({ markers, map, mapCanvasProjection, }) {\n return {\n clusters: this.cluster({ markers, map, mapCanvasProjection }),\n changed: false,\n };\n }\n cluster(input) {\n return this.noop(input);\n }\n}\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A very fast JavaScript algorithm for geospatial point clustering using KD trees.\n *\n * @see https://www.npmjs.com/package/supercluster for more information on options.\n */\nclass SuperClusterAlgorithm extends AbstractAlgorithm {\n constructor(_a) {\n var { maxZoom, radius = 60 } = _a, options = __rest(_a, [\"maxZoom\", \"radius\"]);\n super({ maxZoom });\n this.superCluster = new SuperCluster(Object.assign({ maxZoom: this.maxZoom, radius }, options));\n this.state = { zoom: null };\n }\n calculate(input) {\n let changed = false;\n if (!equal(input.markers, this.markers)) {\n changed = true;\n // TODO use proxy to avoid copy?\n this.markers = [...input.markers];\n const points = this.markers.map((marker) => {\n return {\n type: \"Feature\",\n geometry: {\n type: \"Point\",\n coordinates: [\n marker.getPosition().lng(),\n marker.getPosition().lat(),\n ],\n },\n properties: { marker },\n };\n });\n this.superCluster.load(points);\n }\n const state = { zoom: input.map.getZoom() };\n if (!changed) {\n if (this.state.zoom > this.maxZoom && state.zoom > this.maxZoom) ;\n else {\n changed = changed || !equal(this.state, state);\n }\n }\n this.state = state;\n if (changed) {\n this.clusters = this.cluster(input);\n }\n return { clusters: this.clusters, changed };\n }\n cluster({ map }) {\n return this.superCluster\n .getClusters([-180, -90, 180, 90], Math.round(map.getZoom()))\n .map(this.transformCluster.bind(this));\n }\n transformCluster({ geometry: { coordinates: [lng, lat], }, properties, }) {\n if (properties.cluster) {\n return new Cluster({\n markers: this.superCluster\n .getLeaves(properties.cluster_id, Infinity)\n .map((leaf) => leaf.properties.marker),\n position: new google.maps.LatLng({ lat, lng }),\n });\n }\n else {\n const marker = properties.marker;\n return new Cluster({\n markers: [marker],\n position: marker.getPosition(),\n });\n }\n }\n}\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Provides statistics on all clusters in the current render cycle for use in {@link Renderer.render}.\n */\nclass ClusterStats {\n constructor(markers, clusters) {\n this.markers = { sum: markers.length };\n const clusterMarkerCounts = clusters.map((a) => a.count);\n const clusterMarkerSum = clusterMarkerCounts.reduce((a, b) => a + b, 0);\n this.clusters = {\n count: clusters.length,\n markers: {\n mean: clusterMarkerSum / clusters.length,\n sum: clusterMarkerSum,\n min: Math.min(...clusterMarkerCounts),\n max: Math.max(...clusterMarkerCounts),\n },\n };\n }\n}\nclass DefaultRenderer {\n /**\n * The default render function for the library used by {@link MarkerClusterer}.\n *\n * Currently set to use the following:\n *\n * ```typescript\n * // change color if this cluster has more markers than the mean cluster\n * const color =\n * count > Math.max(10, stats.clusters.markers.mean)\n * ? \"#ff0000\"\n * : \"#0000ff\";\n *\n * // create svg url with fill color\n * const svg = window.btoa(`\n * \n * \n * \n * \n * \n * `);\n *\n * // create marker using svg icon\n * return new google.maps.Marker({\n * position,\n * icon: {\n * url: `data:image/svg+xml;base64,${svg}`,\n * scaledSize: new google.maps.Size(45, 45),\n * },\n * label: {\n * text: String(count),\n * color: \"rgba(255,255,255,0.9)\",\n * fontSize: \"12px\",\n * },\n * // adjust zIndex to be above other markers\n * zIndex: 1000 + count,\n * });\n * ```\n */\n render({ count, position }, stats) {\n // change color if this cluster has more markers than the mean cluster\n const color = count > Math.max(10, stats.clusters.markers.mean) ? \"#ff0000\" : \"#0000ff\";\n // create svg url with fill color\n const svg = window.btoa(`\n \n \n \n \n `);\n // create marker using svg icon\n return new google.maps.Marker({\n position,\n icon: {\n url: `data:image/svg+xml;base64,${svg}`,\n scaledSize: new google.maps.Size(45, 45),\n },\n label: {\n text: String(count),\n color: \"rgba(255,255,255,0.9)\",\n fontSize: \"12px\",\n },\n title: `Cluster of ${count} markers`,\n // adjust zIndex to be above other markers\n zIndex: Number(google.maps.Marker.MAX_ZINDEX) + count,\n });\n }\n}\n\n/**\n * Copyright 2019 Google LLC. All Rights Reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Extends an object's prototype by another's.\n *\n * @param type1 The Type to be extended.\n * @param type2 The Type to extend with.\n * @ignore\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction extend(type1, type2) {\n /* istanbul ignore next */\n // eslint-disable-next-line prefer-const\n for (let property in type2.prototype) {\n type1.prototype[property] = type2.prototype[property];\n }\n}\n/**\n * @ignore\n */\nclass OverlayViewSafe {\n constructor() {\n // MarkerClusterer implements google.maps.OverlayView interface. We use the\n // extend function to extend MarkerClusterer with google.maps.OverlayView\n // because it might not always be available when the code is defined so we\n // look for it at the last possible moment. If it doesn't exist now then\n // there is no point going ahead :)\n extend(OverlayViewSafe, google.maps.OverlayView);\n }\n}\n\n/**\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar MarkerClustererEvents;\n(function (MarkerClustererEvents) {\n MarkerClustererEvents[\"CLUSTERING_BEGIN\"] = \"clusteringbegin\";\n MarkerClustererEvents[\"CLUSTERING_END\"] = \"clusteringend\";\n MarkerClustererEvents[\"CLUSTER_CLICK\"] = \"click\";\n})(MarkerClustererEvents || (MarkerClustererEvents = {}));\nconst defaultOnClusterClickHandler = (_, cluster, map) => {\n map.fitBounds(cluster.bounds);\n};\n/**\n * MarkerClusterer creates and manages per-zoom-level clusters for large amounts\n * of markers. See {@link MarkerClustererOptions} for more details.\n *\n */\nclass MarkerClusterer extends OverlayViewSafe {\n constructor({ map, markers = [], algorithm = new SuperClusterAlgorithm({}), renderer = new DefaultRenderer(), onClusterClick = defaultOnClusterClickHandler, }) {\n super();\n this.markers = [...markers];\n this.clusters = [];\n this.algorithm = algorithm;\n this.renderer = renderer;\n this.onClusterClick = onClusterClick;\n if (map) {\n this.setMap(map);\n }\n }\n addMarker(marker, noDraw) {\n if (this.markers.includes(marker)) {\n return;\n }\n this.markers.push(marker);\n if (!noDraw) {\n this.render();\n }\n }\n addMarkers(markers, noDraw) {\n markers.forEach((marker) => {\n this.addMarker(marker, true);\n });\n if (!noDraw) {\n this.render();\n }\n }\n removeMarker(marker, noDraw) {\n const index = this.markers.indexOf(marker);\n if (index === -1) {\n // Marker is not in our list of markers, so do nothing:\n return false;\n }\n marker.setMap(null);\n this.markers.splice(index, 1); // Remove the marker from the list of managed markers\n if (!noDraw) {\n this.render();\n }\n return true;\n }\n removeMarkers(markers, noDraw) {\n let removed = false;\n markers.forEach((marker) => {\n removed = this.removeMarker(marker, true) || removed;\n });\n if (removed && !noDraw) {\n this.render();\n }\n return removed;\n }\n clearMarkers(noDraw) {\n this.markers.length = 0;\n if (!noDraw) {\n this.render();\n }\n }\n /**\n * Recalculates and draws all the marker clusters.\n */\n render() {\n const map = this.getMap();\n if (map instanceof google.maps.Map && this.getProjection()) {\n google.maps.event.trigger(this, MarkerClustererEvents.CLUSTERING_BEGIN, this);\n const { clusters, changed } = this.algorithm.calculate({\n markers: this.markers,\n map,\n mapCanvasProjection: this.getProjection(),\n });\n // allow algorithms to return flag on whether the clusters/markers have changed\n if (changed || changed == undefined) {\n // reset visibility of markers and clusters\n this.reset();\n // store new clusters\n this.clusters = clusters;\n this.renderClusters();\n }\n google.maps.event.trigger(this, MarkerClustererEvents.CLUSTERING_END, this);\n }\n }\n onAdd() {\n this.idleListener = this.getMap().addListener(\"idle\", this.render.bind(this));\n this.render();\n }\n onRemove() {\n google.maps.event.removeListener(this.idleListener);\n this.reset();\n }\n reset() {\n this.markers.forEach((marker) => marker.setMap(null));\n this.clusters.forEach((cluster) => cluster.delete());\n this.clusters = [];\n }\n renderClusters() {\n // generate stats to pass to renderers\n const stats = new ClusterStats(this.markers, this.clusters);\n const map = this.getMap();\n this.clusters.forEach((cluster) => {\n if (cluster.markers.length === 1) {\n cluster.marker = cluster.markers[0];\n }\n else {\n cluster.marker = this.renderer.render(cluster, stats);\n if (this.onClusterClick) {\n cluster.marker.addListener(\"click\", \n /* istanbul ignore next */\n (event) => {\n google.maps.event.trigger(this, MarkerClustererEvents.CLUSTER_CLICK, cluster);\n this.onClusterClick(event, cluster, map);\n });\n }\n }\n cluster.marker.setMap(map);\n });\n }\n}\n\nexport { AbstractAlgorithm, AbstractViewportAlgorithm, Cluster, ClusterStats, DefaultRenderer, GridAlgorithm, MarkerClusterer, MarkerClustererEvents, NoopAlgorithm, SuperClusterAlgorithm, defaultOnClusterClickHandler, distanceBetweenPoints, extendBoundsToPaddedViewport, extendPixelBounds, filterMarkersToPaddedViewport, noop, pixelBoundsToLatLngBounds };\n//# sourceMappingURL=index.esm.js.map\n","module.exports = \"\"","'use strict';\n\n// do not edit .js files directly - edit src/index.jst\n\n\n\nmodule.exports = function equal(a, b) {\n if (a === b) return true;\n\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n if (a.constructor !== b.constructor) return false;\n\n var length, i, keys;\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;)\n if (!equal(a[i], b[i])) return false;\n return true;\n }\n\n\n\n if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;\n if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();\n if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();\n\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) return false;\n\n for (i = length; i-- !== 0;)\n if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;\n\n for (i = length; i-- !== 0;) {\n var key = keys[i];\n\n if (!equal(a[key], b[key])) return false;\n }\n\n return true;\n }\n\n // true if both NaN, false otherwise\n return a!==a && b!==b;\n};\n","module.exports = \"\""],"sourceRoot":""}