@react-google-maps/api
Version:
React.js Google Maps API integration
1 lines • 160 kB
JavaScript
"use strict";var e=require("react/jsx-runtime"),t=require("react"),n=require("react-dom");function s(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var s=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,s.get?s:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var o,r,i=s(n);function a(e){return a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},a(e)}function l(e){var t=function(e,t){if("object"!=a(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var s=n.call(e,t||"default");if("object"!=a(s))return s;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==a(t)?t:t+""}function u(e,t,n){return(t=l(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function p(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var c=p(function(){if(r)return o;r=1;var e=process.env.NODE_ENV;return o=function(t,n,s,o,r,i,a,l){if("production"!==e&&void 0===n)throw new Error("invariant requires an error message argument");if(!t){var u;if(void 0===n)u=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var p=[s,o,r,i,a,l],c=0;(u=new Error(n.replace(/%s/g,(function(){return p[c++]})))).name="Invariant Violation"}throw u.framesToPop=1,u}}}()),h=t.createContext(null);function d(){c(!!t.useContext,"useGoogleMap is React hook and requires React version 16.8+");var e=t.useContext(h);return c(!!e,"useGoogleMap needs a GoogleMap available up in the tree"),e}function g(e,t,n,s){var o,r,i={};return o=e,r=(e,o)=>{var r=n[o];r!==t[o]&&(i[o]=r,e(s,r))},Object.keys(o).forEach((e=>r(o[e],e))),i}function m(e,t,n){var s,o,r,i=(s=n,o=function(n,s,o){return"function"==typeof e[o]&&n.push(google.maps.event.addListener(t,s,e[o])),n},r=[],Object.keys(s).reduce((function(e,t){return o(e,s[t],t)}),r));return i}function v(e){google.maps.event.removeListener(e)}function f(){(arguments.length>0&&void 0!==arguments[0]?arguments[0]:[]).forEach(v)}function y(e){var{updaterMap:t,eventMap:n,prevProps:s,nextProps:o,instance:r}=e,i=m(o,r,n);return g(t,s,o,r),i}var L={onDblClick:"dblclick",onDragEnd:"dragend",onDragStart:"dragstart",onMapTypeIdChanged:"maptypeid_changed",onMouseMove:"mousemove",onMouseOut:"mouseout",onMouseOver:"mouseover",onMouseDown:"mousedown",onMouseUp:"mouseup",onRightClick:"rightclick",onTilesLoaded:"tilesloaded",onBoundsChanged:"bounds_changed",onCenterChanged:"center_changed",onClick:"click",onDrag:"drag",onHeadingChanged:"heading_changed",onIdle:"idle",onProjectionChanged:"projection_changed",onResize:"resize",onTiltChanged:"tilt_changed",onZoomChanged:"zoom_changed"},b={extraMapTypes(e,t){t.forEach((function(t,n){e.mapTypes.set(String(n),t)}))},center(e,t){e.setCenter(t)},clickableIcons(e,t){e.setClickableIcons(t)},heading(e,t){e.setHeading(t)},mapTypeId(e,t){e.setMapTypeId(t)},options(e,t){e.setOptions(t)},streetView(e,t){e.setStreetView(t)},tilt(e,t){e.setTilt(t)},zoom(e,t){e.setZoom(t)}};t.memo((function(n){var{children:s,options:o,id:r,mapContainerStyle:i,mapContainerClassName:a,center:l,onClick:u,onDblClick:p,onDrag:c,onDragEnd:d,onDragStart:g,onMouseMove:m,onMouseOut:v,onMouseOver:f,onMouseDown:y,onMouseUp:L,onRightClick:b,onCenterChanged:x,onLoad:C,onUnmount:E}=n,[M,w]=t.useState(null),k=t.useRef(null),[P,S]=t.useState(null),[O,D]=t.useState(null),[j,I]=t.useState(null),[B,T]=t.useState(null),[_,R]=t.useState(null),[U,z]=t.useState(null),[A,Z]=t.useState(null),[V,W]=t.useState(null),[N,H]=t.useState(null),[F,G]=t.useState(null),[K,Y]=t.useState(null),[q,J]=t.useState(null);return t.useEffect((()=>{o&&null!==M&&M.setOptions(o)}),[M,o]),t.useEffect((()=>{null!==M&&void 0!==l&&M.setCenter(l)}),[M,l]),t.useEffect((()=>{M&&p&&(null!==O&&google.maps.event.removeListener(O),D(google.maps.event.addListener(M,"dblclick",p)))}),[p]),t.useEffect((()=>{M&&d&&(null!==j&&google.maps.event.removeListener(j),I(google.maps.event.addListener(M,"dragend",d)))}),[d]),t.useEffect((()=>{M&&g&&(null!==B&&google.maps.event.removeListener(B),T(google.maps.event.addListener(M,"dragstart",g)))}),[g]),t.useEffect((()=>{M&&y&&(null!==_&&google.maps.event.removeListener(_),R(google.maps.event.addListener(M,"mousedown",y)))}),[y]),t.useEffect((()=>{M&&m&&(null!==U&&google.maps.event.removeListener(U),z(google.maps.event.addListener(M,"mousemove",m)))}),[m]),t.useEffect((()=>{M&&v&&(null!==A&&google.maps.event.removeListener(A),Z(google.maps.event.addListener(M,"mouseout",v)))}),[v]),t.useEffect((()=>{M&&f&&(null!==V&&google.maps.event.removeListener(V),W(google.maps.event.addListener(M,"mouseover",f)))}),[f]),t.useEffect((()=>{M&&L&&(null!==N&&google.maps.event.removeListener(N),H(google.maps.event.addListener(M,"mouseup",L)))}),[L]),t.useEffect((()=>{M&&b&&(null!==F&&google.maps.event.removeListener(F),G(google.maps.event.addListener(M,"rightclick",b)))}),[b]),t.useEffect((()=>{M&&u&&(null!==K&&google.maps.event.removeListener(K),Y(google.maps.event.addListener(M,"click",u)))}),[u]),t.useEffect((()=>{M&&c&&(null!==q&&google.maps.event.removeListener(q),J(google.maps.event.addListener(M,"drag",c)))}),[c]),t.useEffect((()=>{M&&x&&(null!==P&&google.maps.event.removeListener(P),S(google.maps.event.addListener(M,"center_changed",x)))}),[u]),t.useEffect((()=>{var e=null===k.current?null:new google.maps.Map(k.current,o);return w(e),null!==e&&C&&C(e),()=>{null!==e&&E&&E(e)}}),[]),e.jsx("div",{id:r,ref:k,style:i,className:a,children:e.jsx(h.Provider,{value:M,children:null!==M?s:null})})}));class x extends t.PureComponent{constructor(){super(...arguments),u(this,"state",{map:null}),u(this,"registeredEvents",[]),u(this,"mapRef",null),u(this,"getInstance",(()=>null===this.mapRef?null:new google.maps.Map(this.mapRef,this.props.options))),u(this,"panTo",(e=>{var t=this.getInstance();t&&t.panTo(e)})),u(this,"setMapCallback",(()=>{null!==this.state.map&&this.props.onLoad&&this.props.onLoad(this.state.map)})),u(this,"getRef",(e=>{this.mapRef=e}))}componentDidMount(){var e=this.getInstance();this.registeredEvents=y({updaterMap:b,eventMap:L,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{map:e}}),this.setMapCallback)}componentDidUpdate(e){null!==this.state.map&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:b,eventMap:L,prevProps:e,nextProps:this.props,instance:this.state.map}))}componentWillUnmount(){null!==this.state.map&&(this.props.onUnmount&&this.props.onUnmount(this.state.map),f(this.registeredEvents))}render(){return e.jsx("div",{id:this.props.id,ref:this.getRef,style:this.props.mapContainerStyle,className:this.props.mapContainerClassName,children:e.jsx(h.Provider,{value:this.state.map,children:null!==this.state.map?this.props.children:null})})}}function C(e,t,n,s,o,r,i){try{var a=e[r](i),l=a.value}catch(e){return void n(e)}a.done?t(l):Promise.resolve(l).then(s,o)}function E(e){return function(){var t=this,n=arguments;return new Promise((function(s,o){var r=e.apply(t,n);function i(e){C(r,s,o,i,a,"next",e)}function a(e){C(r,s,o,i,a,"throw",e)}i(void 0)}))}}function M(e){var{googleMapsApiKey:t,googleMapsClientId:n,version:s="weekly",language:o,region:r,libraries:i,channel:a,mapIds:l,authReferrerPolicy:u}=e,p=[];return c(t&&n||!(t&&n),"You need to specify either googleMapsApiKey or googleMapsClientId for @react-google-maps/api load script to work. You cannot use both at the same time."),t?p.push("key=".concat(t)):n&&p.push("client=".concat(n)),s&&p.push("v=".concat(s)),o&&p.push("language=".concat(o)),r&&p.push("region=".concat(r)),i&&i.length&&p.push("libraries=".concat(i.sort().join(","))),a&&p.push("channel=".concat(a)),l&&l.length&&p.push("map_ids=".concat(l.join(","))),u&&p.push("auth_referrer_policy=".concat(u)),p.push("loading=async"),p.push("callback=initMap"),"https://maps.googleapis.com/maps/api/js?".concat(p.join("&"))}var w="undefined"!=typeof document;function k(e){var{url:t,id:n,nonce:s}=e;return w?new Promise((function(e,o){var r=document.getElementById(n),i=window;if(r){var a=r.getAttribute("data-state");if(r.src===t&&"error"!==a){if("ready"===a)return e(n);var l=i.initMap,u=r.onerror;return i.initMap=function(){l&&l(),e(n)},void(r.onerror=function(e){u&&u(e),o(e)})}r.remove()}var p=document.createElement("script");p.type="text/javascript",p.src=t,p.id=n,p.async=!0,p.nonce=s||"",p.onerror=function(e){p.setAttribute("data-state","error"),o(e)},i.initMap=function(){p.setAttribute("data-state","ready"),e(n)},document.head.appendChild(p)})).catch((e=>{throw console.error("injectScript error: ",e),e})):Promise.reject(new Error("document is undefined"))}function P(e){var t=e.href;return!(!t||0!==t.indexOf("https://fonts.googleapis.com/css?family=Roboto")&&0!==t.indexOf("https://fonts.googleapis.com/css?family=Google+Sans+Text"))||("style"===e.tagName.toLowerCase()&&e.styleSheet&&e.styleSheet.cssText&&0===e.styleSheet.cssText.replace("\r\n","").indexOf(".gm-style")?(e.styleSheet.cssText="",!0):"style"===e.tagName.toLowerCase()&&e.innerHTML&&0===e.innerHTML.replace("\r\n","").indexOf(".gm-style")?(e.innerHTML="",!0):"style"===e.tagName.toLowerCase()&&!e.styleSheet&&!e.innerHTML)}function S(){var e=document.getElementsByTagName("head")[0];if(e){var t=e.insertBefore.bind(e);e.insertBefore=function(n,s){return P(n)||Reflect.apply(t,e,[n,s]),n};var n=e.appendChild.bind(e);e.appendChild=function(t){return P(t)||Reflect.apply(n,e,[t]),t}}}var O=!1;function D(){return e.jsx("div",{children:"Loading..."})}var j,I={id:"script-loader",version:"weekly"};class B extends t.PureComponent{constructor(){super(...arguments),u(this,"check",null),u(this,"state",{loaded:!1}),u(this,"cleanupCallback",(()=>{delete window.google.maps,this.injectScript()})),u(this,"isCleaningUp",E((function*(){return new Promise((function(e){if(O){if(w)var t=window.setInterval((function(){O||(window.clearInterval(t),e())}),1)}else e()}))}))),u(this,"cleanup",(()=>{O=!0;var e=document.getElementById(this.props.id);e&&e.parentNode&&e.parentNode.removeChild(e),Array.prototype.slice.call(document.getElementsByTagName("script")).filter((function(e){return"string"==typeof e.src&&e.src.includes("maps.googleapis")})).forEach((function(e){e.parentNode&&e.parentNode.removeChild(e)})),Array.prototype.slice.call(document.getElementsByTagName("link")).filter((function(e){return"https://fonts.googleapis.com/css?family=Roboto:300,400,500,700|Google+Sans"===e.href})).forEach((function(e){e.parentNode&&e.parentNode.removeChild(e)})),Array.prototype.slice.call(document.getElementsByTagName("style")).filter((function(e){return void 0!==e.innerText&&e.innerText.length>0&&e.innerText.includes(".gm-")})).forEach((function(e){e.parentNode&&e.parentNode.removeChild(e)}))})),u(this,"injectScript",(()=>{this.props.preventGoogleFontsLoading&&S(),c(!!this.props.id,'LoadScript requires "id" prop to be a string: %s',this.props.id),k({id:this.props.id,nonce:this.props.nonce,url:M(this.props)}).then((()=>{this.props.onLoad&&this.props.onLoad(),this.setState((function(){return{loaded:!0}}))})).catch((e=>{this.props.onError&&this.props.onError(e),console.error("\n There has been an Error with loading Google Maps API script, please check that you provided correct google API key (".concat(this.props.googleMapsApiKey||"-",") or Client ID (").concat(this.props.googleMapsClientId||"-",") to <LoadScript />\n Otherwise it is a Network issue.\n "))}))})),u(this,"getRef",(e=>{this.check=e}))}componentDidMount(){if(w){if(window.google&&window.google.maps&&!O)return void console.error("google api is already presented");this.isCleaningUp().then(this.injectScript).catch((function(e){console.error("Error at injecting script after cleaning up: ",e)}))}}componentDidUpdate(e){this.props.libraries!==e.libraries&&console.warn("Performance warning! LoadScript has been reloaded unintentionally! You should not pass `libraries` prop as new array. Please keep an array of libraries as static class property for Components and PureComponents, or just a const variable outside of component, or somewhere in config files or ENV variables"),w&&e.language!==this.props.language&&(this.cleanup(),this.setState((function(){return{loaded:!1}}),this.cleanupCallback))}componentWillUnmount(){if(w){this.cleanup();window.setTimeout((()=>{this.check||(delete window.google,O=!1)}),1),this.props.onUnmount&&this.props.onUnmount()}}render(){return e.jsxs(e.Fragment,{children:[e.jsx("div",{ref:this.getRef}),this.state.loaded?this.props.children:this.props.loadingElement||e.jsx(D,{})]})}}function T(e,t){if(null==e)return{};var n,s,o=function(e,t){if(null==e)return{};var n={};for(var s in e)if({}.hasOwnProperty.call(e,s)){if(t.includes(s))continue;n[s]=e[s]}return n}(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(s=0;s<r.length;s++)n=r[s],t.includes(n)||{}.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}function _(e){var{id:n=I.id,version:s=I.version,nonce:o,googleMapsApiKey:r,googleMapsClientId:i,language:a,region:l,libraries:u,preventGoogleFontsLoading:p,channel:h,mapIds:d,authReferrerPolicy:g}=e,m=t.useRef(!1),[v,f]=t.useState(!1),[y,L]=t.useState(void 0);t.useEffect((function(){return m.current=!0,()=>{m.current=!1}}),[]),t.useEffect((function(){w&&p&&S()}),[p]),t.useEffect((function(){v&&c(!!window.google,"useLoadScript was marked as loaded, but window.google is not present. Something went wrong.")}),[v]);var b=M({version:s,googleMapsApiKey:r,googleMapsClientId:i,language:a,region:l,libraries:u,channel:h,mapIds:d,authReferrerPolicy:g});t.useEffect((function(){function e(){m.current&&(f(!0),j=b)}w&&(window.google&&window.google.maps&&j===b?e():k({id:n,url:b,nonce:o}).then(e).catch((function(e){m.current&&L(e),console.warn("\n There has been an Error with loading Google Maps API script, please check that you provided correct google API key (".concat(r||"-",") or Client ID (").concat(i||"-",")\n Otherwise it is a Network issue.\n ")),console.error(e)})))}),[n,b,o]);var x=t.useRef(void 0);return t.useEffect((function(){x.current&&u!==x.current&&console.warn("Performance warning! LoadScript has been reloaded unintentionally! You should not pass `libraries` prop as new array. Please keep an array of libraries as static class property for Components and PureComponents, or just a const variable outside of component, or somewhere in config files or ENV variables"),x.current=u}),[u]),{isLoaded:v,loadError:y,url:b}}u(B,"defaultProps",I);var R=["loadingElement","onLoad","onError","onUnmount","children"],U=e.jsx(D,{});var z=t.memo((function(e){var{loadingElement:n,onLoad:s,onError:o,onUnmount:r,children:i}=e,a=T(e,R),{isLoaded:l,loadError:u}=_(a);return t.useEffect((function(){l&&"function"==typeof s&&s()}),[l,s]),t.useEffect((function(){u&&"function"==typeof o&&o(u)}),[u,o]),t.useEffect((function(){return()=>{r&&r()}}),[r]),l?i:n||U}));function A(e,t,n,s){return new(n||(n=Promise))((function(t,o){function r(e){try{a(s.next(e))}catch(e){o(e)}}function i(e){try{a(s.throw(e))}catch(e){o(e)}}function a(e){var s;e.done?t(e.value):(s=e.value,s instanceof n?s:new n((function(e){e(s)}))).then(r,i)}a((s=s.apply(e,[])).next())}))}function Z(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}"function"==typeof SuppressedError&&SuppressedError;var V,W=function e(t,n){if(t===n)return!0;if(t&&n&&"object"==typeof t&&"object"==typeof n){if(t.constructor!==n.constructor)return!1;var s,o,r;if(Array.isArray(t)){if((s=t.length)!=n.length)return!1;for(o=s;0!=o--;)if(!e(t[o],n[o]))return!1;return!0}if(t.constructor===RegExp)return t.source===n.source&&t.flags===n.flags;if(t.valueOf!==Object.prototype.valueOf)return t.valueOf()===n.valueOf();if(t.toString!==Object.prototype.toString)return t.toString()===n.toString();if((s=(r=Object.keys(t)).length)!==Object.keys(n).length)return!1;for(o=s;0!=o--;)if(!Object.prototype.hasOwnProperty.call(n,r[o]))return!1;for(o=s;0!=o--;){var i=r[o];if(!e(t[i],n[i]))return!1}return!0}return t!=t&&n!=n},N=Z(W),H="__googleMapsScriptId";!function(e){e[e.INITIALIZED=0]="INITIALIZED",e[e.LOADING=1]="LOADING",e[e.SUCCESS=2]="SUCCESS",e[e.FAILURE=3]="FAILURE"}(V||(V={}));class F{constructor(e){var{apiKey:t,authReferrerPolicy:n,channel:s,client:o,id:r=H,language:i,libraries:a=[],mapIds:l,nonce:u,region:p,retries:c=3,url:h="https://maps.googleapis.com/maps/api/js",version:d}=e;if(this.callbacks=[],this.done=!1,this.loading=!1,this.errors=[],this.apiKey=t,this.authReferrerPolicy=n,this.channel=s,this.client=o,this.id=r||H,this.language=i,this.libraries=a,this.mapIds=l,this.nonce=u,this.region=p,this.retries=c,this.url=h,this.version=d,F.instance){if(!N(this.options,F.instance.options))throw new Error("Loader must not be called again with different options. ".concat(JSON.stringify(this.options)," !== ").concat(JSON.stringify(F.instance.options)));return F.instance}F.instance=this}get options(){return{version:this.version,apiKey:this.apiKey,channel:this.channel,client:this.client,id:this.id,libraries:this.libraries,language:this.language,region:this.region,mapIds:this.mapIds,nonce:this.nonce,url:this.url,authReferrerPolicy:this.authReferrerPolicy}}get status(){return this.errors.length?V.FAILURE:this.done?V.SUCCESS:this.loading?V.LOADING:V.INITIALIZED}get failed(){return this.done&&!this.loading&&this.errors.length>=this.retries+1}createUrl(){var e=this.url;return e+="?callback=__googleMapsCallback&loading=async",this.apiKey&&(e+="&key=".concat(this.apiKey)),this.channel&&(e+="&channel=".concat(this.channel)),this.client&&(e+="&client=".concat(this.client)),this.libraries.length>0&&(e+="&libraries=".concat(this.libraries.join(","))),this.language&&(e+="&language=".concat(this.language)),this.region&&(e+="®ion=".concat(this.region)),this.version&&(e+="&v=".concat(this.version)),this.mapIds&&(e+="&map_ids=".concat(this.mapIds.join(","))),this.authReferrerPolicy&&(e+="&auth_referrer_policy=".concat(this.authReferrerPolicy)),e}deleteScript(){var e=document.getElementById(this.id);e&&e.remove()}load(){return this.loadPromise()}loadPromise(){return new Promise(((e,t)=>{this.loadCallback((n=>{n?t(n.error):e(window.google)}))}))}importLibrary(e){return this.execute(),google.maps.importLibrary(e)}loadCallback(e){this.callbacks.push(e),this.execute()}setScript(){var e,t;if(document.getElementById(this.id))this.callback();else{var n={key:this.apiKey,channel:this.channel,client:this.client,libraries:this.libraries.length&&this.libraries,v:this.version,mapIds:this.mapIds,language:this.language,region:this.region,authReferrerPolicy:this.authReferrerPolicy};Object.keys(n).forEach((e=>!n[e]&&delete n[e])),(null===(t=null===(e=null===window||void 0===window?void 0:window.google)||void 0===e?void 0:e.maps)||void 0===t?void 0:t.importLibrary)||(e=>{var t,n,s,o="The Google Maps JavaScript API",r="google",i="importLibrary",a="__ib__",l=document,u=window,p=(u=u[r]||(u[r]={})).maps||(u.maps={}),c=new Set,h=new URLSearchParams,d=()=>t||(t=new Promise(((i,u)=>A(this,0,void 0,(function*(){var d;for(s in yield n=l.createElement("script"),n.id=this.id,h.set("libraries",[...c]+""),e)h.set(s.replace(/[A-Z]/g,(e=>"_"+e[0].toLowerCase())),e[s]);h.set("callback",r+".maps."+a),n.src=this.url+"?"+h,p[a]=i,n.onerror=()=>t=u(Error(o+" could not load.")),n.nonce=this.nonce||(null===(d=l.querySelector("script[nonce]"))||void 0===d?void 0:d.nonce)||"",l.head.append(n)})))));p[i]?console.warn(o+" only loads once. Ignoring:",e):p[i]=function(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),s=1;s<t;s++)n[s-1]=arguments[s];return c.add(e)&&d().then((()=>p[i](e,...n)))}})(n);var s=this.libraries.map((e=>this.importLibrary(e)));s.length||s.push(this.importLibrary("core")),Promise.all(s).then((()=>this.callback()),(e=>{var t=new ErrorEvent("error",{error:e});this.loadErrorCallback(t)}))}}reset(){this.deleteScript(),this.done=!1,this.loading=!1,this.errors=[],this.onerrorEvent=null}resetIfRetryingFailed(){this.failed&&this.reset()}loadErrorCallback(e){if(this.errors.push(e),this.errors.length<=this.retries){var t=this.errors.length*Math.pow(2,this.errors.length);console.error("Failed to load Google Maps script, retrying in ".concat(t," ms.")),setTimeout((()=>{this.deleteScript(),this.setScript()}),t)}else this.onerrorEvent=e,this.callback()}callback(){this.done=!0,this.loading=!1,this.callbacks.forEach((e=>{e(this.onerrorEvent)})),this.callbacks=[]}execute(){if(this.resetIfRetryingFailed(),!this.loading)if(this.done)this.callback();else{if(window.google&&window.google.maps&&window.google.maps.version)return console.warn("Google Maps already loaded outside @googlemaps/js-api-loader. This may result in undesirable behavior as options and script parameters may not match."),void this.callback();this.loading=!0,this.setScript()}}}var G=["maps"];function K(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var s=Object.getOwnPropertySymbols(e);t&&(s=s.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,s)}return n}function Y(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?K(Object(n),!0).forEach((function(t){u(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):K(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var q={},J={options(e,t){e.setOptions(t)}};var X=t.memo((function(e){var{options:n,onLoad:s,onUnmount:o}=e,r=t.useContext(h),[i,a]=t.useState(null);return t.useEffect((()=>{null!==i&&i.setMap(r)}),[r]),t.useEffect((()=>{n&&null!==i&&i.setOptions(n)}),[i,n]),t.useEffect((()=>{var e=new google.maps.TrafficLayer(Y(Y({},n),{},{map:r}));return a(e),s&&s(e),()=>{null!==i&&(o&&o(i),i.setMap(null))}}),[]),null}));class $ extends t.PureComponent{constructor(){super(...arguments),u(this,"state",{trafficLayer:null}),u(this,"setTrafficLayerCallback",(()=>{null!==this.state.trafficLayer&&this.props.onLoad&&this.props.onLoad(this.state.trafficLayer)})),u(this,"registeredEvents",[])}componentDidMount(){var e=new google.maps.TrafficLayer(Y(Y({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:J,eventMap:q,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{trafficLayer:e}}),this.setTrafficLayerCallback)}componentDidUpdate(e){null!==this.state.trafficLayer&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:J,eventMap:q,prevProps:e,nextProps:this.props,instance:this.state.trafficLayer}))}componentWillUnmount(){null!==this.state.trafficLayer&&(this.props.onUnmount&&this.props.onUnmount(this.state.trafficLayer),f(this.registeredEvents),this.state.trafficLayer.setMap(null))}render(){return null}}u($,"contextType",h);var Q=t.memo((function(e){var{onLoad:n,onUnmount:s}=e,o=t.useContext(h),[r,i]=t.useState(null);return t.useEffect((()=>{null!==r&&r.setMap(o)}),[o]),t.useEffect((()=>{var e=new google.maps.BicyclingLayer;return i(e),e.setMap(o),n&&n(e),()=>{null!==e&&(s&&s(e),e.setMap(null))}}),[]),null}));class ee extends t.PureComponent{constructor(){super(...arguments),u(this,"state",{bicyclingLayer:null}),u(this,"setBicyclingLayerCallback",(()=>{null!==this.state.bicyclingLayer&&(this.state.bicyclingLayer.setMap(this.context),this.props.onLoad&&this.props.onLoad(this.state.bicyclingLayer))}))}componentDidMount(){var e=new google.maps.BicyclingLayer;this.setState((()=>({bicyclingLayer:e})),this.setBicyclingLayerCallback)}componentWillUnmount(){null!==this.state.bicyclingLayer&&(this.props.onUnmount&&this.props.onUnmount(this.state.bicyclingLayer),this.state.bicyclingLayer.setMap(null))}render(){return null}}u(ee,"contextType",h);var te=t.memo((function(e){var{onLoad:n,onUnmount:s}=e,o=t.useContext(h),[r,i]=t.useState(null);return t.useEffect((()=>{null!==r&&r.setMap(o)}),[o]),t.useEffect((()=>{var e=new google.maps.TransitLayer;return i(e),e.setMap(o),n&&n(e),()=>{null!==r&&(s&&s(r),r.setMap(null))}}),[]),null}));class ne extends t.PureComponent{constructor(){super(...arguments),u(this,"state",{transitLayer:null}),u(this,"setTransitLayerCallback",(()=>{null!==this.state.transitLayer&&(this.state.transitLayer.setMap(this.context),this.props.onLoad&&this.props.onLoad(this.state.transitLayer))}))}componentDidMount(){var e=new google.maps.TransitLayer;this.setState((function(){return{transitLayer:e}}),this.setTransitLayerCallback)}componentWillUnmount(){null!==this.state.transitLayer&&(this.props.onUnmount&&this.props.onUnmount(this.state.transitLayer),this.state.transitLayer.setMap(null))}render(){return null}}function se(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var s=Object.getOwnPropertySymbols(e);t&&(s=s.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,s)}return n}function oe(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?se(Object(n),!0).forEach((function(t){u(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):se(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}u(ne,"contextType",h);var re={onCircleComplete:"circlecomplete",onMarkerComplete:"markercomplete",onOverlayComplete:"overlaycomplete",onPolygonComplete:"polygoncomplete",onPolylineComplete:"polylinecomplete",onRectangleComplete:"rectanglecomplete"},ie={drawingMode(e,t){e.setDrawingMode(t)},options(e,t){e.setOptions(t)}};var ae=t.memo((function(e){var{options:n,drawingMode:s,onCircleComplete:o,onMarkerComplete:r,onOverlayComplete:i,onPolygonComplete:a,onPolylineComplete:l,onRectangleComplete:u,onLoad:p,onUnmount:d}=e,g=t.useContext(h),[m,v]=t.useState(null),[f,y]=t.useState(null),[L,b]=t.useState(null),[x,C]=t.useState(null),[E,M]=t.useState(null),[w,k]=t.useState(null),[P,S]=t.useState(null);return t.useEffect((()=>{null!==m&&m.setMap(g)}),[g]),t.useEffect((()=>{n&&null!==m&&m.setOptions(n)}),[m,n]),t.useEffect((()=>{null!==m&&m.setDrawingMode(null!=s?s:null)}),[m,s]),t.useEffect((()=>{m&&o&&(null!==f&&google.maps.event.removeListener(f),y(google.maps.event.addListener(m,"circlecomplete",o)))}),[m,o]),t.useEffect((()=>{m&&r&&(null!==L&&google.maps.event.removeListener(L),b(google.maps.event.addListener(m,"markercomplete",r)))}),[m,r]),t.useEffect((()=>{m&&i&&(null!==x&&google.maps.event.removeListener(x),C(google.maps.event.addListener(m,"overlaycomplete",i)))}),[m,i]),t.useEffect((()=>{m&&a&&(null!==E&&google.maps.event.removeListener(E),M(google.maps.event.addListener(m,"polygoncomplete",a)))}),[m,a]),t.useEffect((()=>{m&&l&&(null!==w&&google.maps.event.removeListener(w),k(google.maps.event.addListener(m,"polylinecomplete",l)))}),[m,l]),t.useEffect((()=>{m&&u&&(null!==P&&google.maps.event.removeListener(P),S(google.maps.event.addListener(m,"rectanglecomplete",u)))}),[m,u]),t.useEffect((()=>{c(!!google.maps.drawing,"Did you include prop libraries={['drawing']} in the URL? %s",google.maps.drawing);var e=new google.maps.drawing.DrawingManager(oe(oe({},n),{},{map:g}));return s&&e.setDrawingMode(s),o&&y(google.maps.event.addListener(e,"circlecomplete",o)),r&&b(google.maps.event.addListener(e,"markercomplete",r)),i&&C(google.maps.event.addListener(e,"overlaycomplete",i)),a&&M(google.maps.event.addListener(e,"polygoncomplete",a)),l&&k(google.maps.event.addListener(e,"polylinecomplete",l)),u&&S(google.maps.event.addListener(e,"rectanglecomplete",u)),v(e),p&&p(e),()=>{null!==m&&(f&&google.maps.event.removeListener(f),L&&google.maps.event.removeListener(L),x&&google.maps.event.removeListener(x),E&&google.maps.event.removeListener(E),w&&google.maps.event.removeListener(w),P&&google.maps.event.removeListener(P),d&&d(m),m.setMap(null))}}),[]),null}));class le extends t.PureComponent{constructor(e){super(e),u(this,"registeredEvents",[]),u(this,"state",{drawingManager:null}),u(this,"setDrawingManagerCallback",(()=>{null!==this.state.drawingManager&&this.props.onLoad&&this.props.onLoad(this.state.drawingManager)})),c(!!google.maps.drawing,"Did you include prop libraries={['drawing']} in the URL? %s",google.maps.drawing)}componentDidMount(){var e=new google.maps.drawing.DrawingManager(oe(oe({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:ie,eventMap:re,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{drawingManager:e}}),this.setDrawingManagerCallback)}componentDidUpdate(e){null!==this.state.drawingManager&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:ie,eventMap:re,prevProps:e,nextProps:this.props,instance:this.state.drawingManager}))}componentWillUnmount(){null!==this.state.drawingManager&&(this.props.onUnmount&&this.props.onUnmount(this.state.drawingManager),f(this.registeredEvents),this.state.drawingManager.setMap(null))}render(){return null}}function ue(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var s=Object.getOwnPropertySymbols(e);t&&(s=s.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,s)}return n}function pe(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?ue(Object(n),!0).forEach((function(t){u(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):ue(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}u(le,"contextType",h);var ce={onAnimationChanged:"animation_changed",onClick:"click",onClickableChanged:"clickable_changed",onCursorChanged:"cursor_changed",onDblClick:"dblclick",onDrag:"drag",onDragEnd:"dragend",onDraggableChanged:"draggable_changed",onDragStart:"dragstart",onFlatChanged:"flat_changed",onIconChanged:"icon_changed",onMouseDown:"mousedown",onMouseOut:"mouseout",onMouseOver:"mouseover",onMouseUp:"mouseup",onPositionChanged:"position_changed",onRightClick:"rightclick",onShapeChanged:"shape_changed",onTitleChanged:"title_changed",onVisibleChanged:"visible_changed",onZindexChanged:"zindex_changed"},he={animation(e,t){e.setAnimation(t)},clickable(e,t){e.setClickable(t)},cursor(e,t){e.setCursor(t)},draggable(e,t){e.setDraggable(t)},icon(e,t){e.setIcon(t)},label(e,t){e.setLabel(t)},map(e,t){e.setMap(t)},opacity(e,t){e.setOpacity(t)},options(e,t){e.setOptions(t)},position(e,t){e.setPosition(t)},shape(e,t){e.setShape(t)},title(e,t){e.setTitle(t)},visible(e,t){e.setVisible(t)},zIndex(e,t){e.setZIndex(t)}},de={};var ge=t.memo((function(n){var{position:s,options:o,clusterer:r,noClustererRedraw:i,children:a,draggable:l,visible:u,animation:p,clickable:c,cursor:d,icon:g,label:m,opacity:v,shape:f,title:y,zIndex:L,onClick:b,onDblClick:x,onDrag:C,onDragEnd:E,onDragStart:M,onMouseOut:w,onMouseOver:k,onMouseUp:P,onMouseDown:S,onRightClick:O,onClickableChanged:D,onCursorChanged:j,onAnimationChanged:I,onDraggableChanged:B,onFlatChanged:T,onIconChanged:_,onPositionChanged:R,onShapeChanged:U,onTitleChanged:z,onVisibleChanged:A,onZindexChanged:Z,onLoad:V,onUnmount:W}=n,N=t.useContext(h),[H,F]=t.useState(null),[G,K]=t.useState(null),[Y,q]=t.useState(null),[J,X]=t.useState(null),[$,Q]=t.useState(null),[ee,te]=t.useState(null),[ne,se]=t.useState(null),[oe,re]=t.useState(null),[ie,ae]=t.useState(null),[le,ue]=t.useState(null),[ce,he]=t.useState(null),[ge,me]=t.useState(null),[ve,fe]=t.useState(null),[ye,Le]=t.useState(null),[be,xe]=t.useState(null),[Ce,Ee]=t.useState(null),[Me,we]=t.useState(null),[ke,Pe]=t.useState(null),[Se,Oe]=t.useState(null),[De,je]=t.useState(null),[Ie,Be]=t.useState(null),[Te,_e]=t.useState(null);t.useEffect((()=>{null!==H&&H.setMap(N)}),[N]),t.useEffect((()=>{void 0!==o&&null!==H&&H.setOptions(o)}),[H,o]),t.useEffect((()=>{void 0!==l&&null!==H&&H.setDraggable(l)}),[H,l]),t.useEffect((()=>{s&&null!==H&&H.setPosition(s)}),[H,s]),t.useEffect((()=>{void 0!==u&&null!==H&&H.setVisible(u)}),[H,u]),t.useEffect((()=>{null==H||H.setAnimation(p)}),[H,p]),t.useEffect((()=>{H&&void 0!==c&&H.setClickable(c)}),[H,c]),t.useEffect((()=>{H&&void 0!==d&&H.setCursor(d)}),[H,d]),t.useEffect((()=>{H&&void 0!==g&&H.setIcon(g)}),[H,g]),t.useEffect((()=>{H&&void 0!==m&&H.setLabel(m)}),[H,m]),t.useEffect((()=>{H&&void 0!==v&&H.setOpacity(v)}),[H,v]),t.useEffect((()=>{H&&void 0!==f&&H.setShape(f)}),[H,f]),t.useEffect((()=>{H&&void 0!==y&&H.setTitle(y)}),[H,y]),t.useEffect((()=>{H&&void 0!==L&&H.setZIndex(L)}),[H,L]),t.useEffect((()=>{H&&x&&(null!==G&&google.maps.event.removeListener(G),K(google.maps.event.addListener(H,"dblclick",x)))}),[x]),t.useEffect((()=>{H&&E&&(null!==Y&&google.maps.event.removeListener(Y),q(google.maps.event.addListener(H,"dragend",E)))}),[E]),t.useEffect((()=>{H&&M&&(null!==J&&google.maps.event.removeListener(J),X(google.maps.event.addListener(H,"dragstart",M)))}),[M]),t.useEffect((()=>{H&&S&&(null!==$&&google.maps.event.removeListener($),Q(google.maps.event.addListener(H,"mousedown",S)))}),[S]),t.useEffect((()=>{H&&w&&(null!==ee&&google.maps.event.removeListener(ee),te(google.maps.event.addListener(H,"mouseout",w)))}),[w]),t.useEffect((()=>{H&&k&&(null!==ne&&google.maps.event.removeListener(ne),se(google.maps.event.addListener(H,"mouseover",k)))}),[k]),t.useEffect((()=>{H&&P&&(null!==oe&&google.maps.event.removeListener(oe),re(google.maps.event.addListener(H,"mouseup",P)))}),[P]),t.useEffect((()=>{H&&O&&(null!==ie&&google.maps.event.removeListener(ie),ae(google.maps.event.addListener(H,"rightclick",O)))}),[O]),t.useEffect((()=>{H&&b&&(null!==le&&google.maps.event.removeListener(le),ue(google.maps.event.addListener(H,"click",b)))}),[b]),t.useEffect((()=>{H&&C&&(null!==ce&&google.maps.event.removeListener(ce),he(google.maps.event.addListener(H,"drag",C)))}),[C]),t.useEffect((()=>{H&&D&&(null!==ge&&google.maps.event.removeListener(ge),me(google.maps.event.addListener(H,"clickable_changed",D)))}),[D]),t.useEffect((()=>{H&&j&&(null!==ve&&google.maps.event.removeListener(ve),fe(google.maps.event.addListener(H,"cursor_changed",j)))}),[j]),t.useEffect((()=>{H&&I&&(null!==ye&&google.maps.event.removeListener(ye),Le(google.maps.event.addListener(H,"animation_changed",I)))}),[I]),t.useEffect((()=>{H&&B&&(null!==be&&google.maps.event.removeListener(be),xe(google.maps.event.addListener(H,"draggable_changed",B)))}),[B]),t.useEffect((()=>{H&&T&&(null!==Ce&&google.maps.event.removeListener(Ce),Ee(google.maps.event.addListener(H,"flat_changed",T)))}),[T]),t.useEffect((()=>{H&&_&&(null!==Me&&google.maps.event.removeListener(Me),we(google.maps.event.addListener(H,"icon_changed",_)))}),[_]),t.useEffect((()=>{H&&R&&(null!==ke&&google.maps.event.removeListener(ke),Pe(google.maps.event.addListener(H,"position_changed",R)))}),[R]),t.useEffect((()=>{H&&U&&(null!==Se&&google.maps.event.removeListener(Se),Oe(google.maps.event.addListener(H,"shape_changed",U)))}),[U]),t.useEffect((()=>{H&&z&&(null!==De&&google.maps.event.removeListener(De),je(google.maps.event.addListener(H,"title_changed",z)))}),[z]),t.useEffect((()=>{H&&A&&(null!==Ie&&google.maps.event.removeListener(Ie),Be(google.maps.event.addListener(H,"visible_changed",A)))}),[A]),t.useEffect((()=>{H&&Z&&(null!==Te&&google.maps.event.removeListener(Te),_e(google.maps.event.addListener(H,"zindex_changed",Z)))}),[Z]),t.useEffect((()=>{var e=pe(pe(pe({},o||de),r?de:{map:N}),{},{position:s}),t=new google.maps.Marker(e);return r?r.addMarker(t,!!i):t.setMap(N),s&&t.setPosition(s),void 0!==u&&t.setVisible(u),void 0!==l&&t.setDraggable(l),void 0!==c&&t.setClickable(c),"string"==typeof d&&t.setCursor(d),g&&t.setIcon(g),void 0!==m&&t.setLabel(m),void 0!==v&&t.setOpacity(v),f&&t.setShape(f),"string"==typeof y&&t.setTitle(y),"number"==typeof L&&t.setZIndex(L),x&&K(google.maps.event.addListener(t,"dblclick",x)),E&&q(google.maps.event.addListener(t,"dragend",E)),M&&X(google.maps.event.addListener(t,"dragstart",M)),S&&Q(google.maps.event.addListener(t,"mousedown",S)),w&&te(google.maps.event.addListener(t,"mouseout",w)),k&&se(google.maps.event.addListener(t,"mouseover",k)),P&&re(google.maps.event.addListener(t,"mouseup",P)),O&&ae(google.maps.event.addListener(t,"rightclick",O)),b&&ue(google.maps.event.addListener(t,"click",b)),C&&he(google.maps.event.addListener(t,"drag",C)),D&&me(google.maps.event.addListener(t,"clickable_changed",D)),j&&fe(google.maps.event.addListener(t,"cursor_changed",j)),I&&Le(google.maps.event.addListener(t,"animation_changed",I)),B&&xe(google.maps.event.addListener(t,"draggable_changed",B)),T&&Ee(google.maps.event.addListener(t,"flat_changed",T)),_&&we(google.maps.event.addListener(t,"icon_changed",_)),R&&Pe(google.maps.event.addListener(t,"position_changed",R)),U&&Oe(google.maps.event.addListener(t,"shape_changed",U)),z&&je(google.maps.event.addListener(t,"title_changed",z)),A&&Be(google.maps.event.addListener(t,"visible_changed",A)),Z&&_e(google.maps.event.addListener(t,"zindex_changed",Z)),F(t),V&&V(t),()=>{null!==G&&google.maps.event.removeListener(G),null!==Y&&google.maps.event.removeListener(Y),null!==J&&google.maps.event.removeListener(J),null!==$&&google.maps.event.removeListener($),null!==ee&&google.maps.event.removeListener(ee),null!==ne&&google.maps.event.removeListener(ne),null!==oe&&google.maps.event.removeListener(oe),null!==ie&&google.maps.event.removeListener(ie),null!==le&&google.maps.event.removeListener(le),null!==ge&&google.maps.event.removeListener(ge),null!==ve&&google.maps.event.removeListener(ve),null!==ye&&google.maps.event.removeListener(ye),null!==be&&google.maps.event.removeListener(be),null!==Ce&&google.maps.event.removeListener(Ce),null!==Me&&google.maps.event.removeListener(Me),null!==ke&&google.maps.event.removeListener(ke),null!==De&&google.maps.event.removeListener(De),null!==Ie&&google.maps.event.removeListener(Ie),null!==Te&&google.maps.event.removeListener(Te),W&&W(t),r?r.removeMarker(t,!!i):t&&t.setMap(null)}}),[]);var Re=t.useMemo((()=>a?t.Children.map(a,(e=>{if(!t.isValidElement(e))return e;var n=e;return t.cloneElement(n,{anchor:H})})):null),[a,H]);return e.jsx(e.Fragment,{children:Re})||null}));class me extends t.PureComponent{constructor(){super(...arguments),u(this,"registeredEvents",[])}componentDidMount(){var e=this;return E((function*(){var t=pe(pe(pe({},e.props.options||de),e.props.clusterer?de:{map:e.context}),{},{position:e.props.position});e.marker=new google.maps.Marker(t),e.props.clusterer?e.props.clusterer.addMarker(e.marker,!!e.props.noClustererRedraw):e.marker.setMap(e.context),e.registeredEvents=y({updaterMap:he,eventMap:ce,prevProps:{},nextProps:e.props,instance:e.marker}),e.props.onLoad&&e.props.onLoad(e.marker)}))()}componentDidUpdate(e){this.marker&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:he,eventMap:ce,prevProps:e,nextProps:this.props,instance:this.marker}))}componentWillUnmount(){this.marker&&(this.props.onUnmount&&this.props.onUnmount(this.marker),f(this.registeredEvents),this.props.clusterer?this.props.clusterer.removeMarker(this.marker,!!this.props.noClustererRedraw):this.marker&&this.marker.setMap(null))}render(){return(this.props.children?t.Children.map(this.props.children,(e=>{if(!t.isValidElement(e))return e;var n=e;return t.cloneElement(n,{anchor:this.marker})})):null)||null}}u(me,"contextType",h);var ve=function(){function e(t,n){t.getClusterer().extend(e,google.maps.OverlayView),this.cluster=t,this.clusterClassName=this.cluster.getClusterer().getClusterClass(),this.className=this.clusterClassName,this.styles=n,this.center=void 0,this.div=null,this.sums=null,this.visible=!1,this.boundsChangedListener=null,this.url="",this.height=0,this.width=0,this.anchorText=[0,0],this.anchorIcon=[0,0],this.textColor="black",this.textSize=11,this.textDecoration="none",this.fontWeight="bold",this.fontStyle="normal",this.fontFamily="Arial,sans-serif",this.backgroundPosition="0 0",this.cMouseDownInCluster=null,this.cDraggingMapByCluster=null,this.timeOut=null,this.setMap(t.getMap()),this.onBoundsChanged=this.onBoundsChanged.bind(this),this.onMouseDown=this.onMouseDown.bind(this),this.onClick=this.onClick.bind(this),this.onMouseOver=this.onMouseOver.bind(this),this.onMouseOut=this.onMouseOut.bind(this),this.onAdd=this.onAdd.bind(this),this.onRemove=this.onRemove.bind(this),this.draw=this.draw.bind(this),this.hide=this.hide.bind(this),this.show=this.show.bind(this),this.useStyle=this.useStyle.bind(this),this.setCenter=this.setCenter.bind(this),this.getPosFromLatLng=this.getPosFromLatLng.bind(this)}return e.prototype.onBoundsChanged=function(){this.cDraggingMapByCluster=this.cMouseDownInCluster},e.prototype.onMouseDown=function(){this.cMouseDownInCluster=!0,this.cDraggingMapByCluster=!1},e.prototype.onClick=function(e){if(this.cMouseDownInCluster=!1,!this.cDraggingMapByCluster){var t=this.cluster.getClusterer();if(google.maps.event.trigger(t,"click",this.cluster),google.maps.event.trigger(t,"clusterclick",this.cluster),t.getZoomOnClick()){var n=t.getMaxZoom(),s=this.cluster.getBounds(),o=t.getMap();null!==o&&"fitBounds"in o&&o.fitBounds(s),this.timeOut=window.setTimeout((function(){var e=t.getMap();if(null!==e){"fitBounds"in e&&e.fitBounds(s);var o=e.getZoom()||0;null!==n&&o>n&&e.setZoom(n+1)}}),100)}e.cancelBubble=!0,e.stopPropagation&&e.stopPropagation()}},e.prototype.onMouseOver=function(){google.maps.event.trigger(this.cluster.getClusterer(),"mouseover",this.cluster)},e.prototype.onMouseOut=function(){google.maps.event.trigger(this.cluster.getClusterer(),"mouseout",this.cluster)},e.prototype.onAdd=function(){var e;this.div=document.createElement("div"),this.div.className=this.className,this.visible&&this.show(),null===(e=this.getPanes())||void 0===e||e.overlayMouseTarget.appendChild(this.div);var t=this.getMap();null!==t&&(this.boundsChangedListener=google.maps.event.addListener(t,"bounds_changed",this.onBoundsChanged),this.div.addEventListener("mousedown",this.onMouseDown),this.div.addEventListener("click",this.onClick),this.div.addEventListener("mouseover",this.onMouseOver),this.div.addEventListener("mouseout",this.onMouseOut))},e.prototype.onRemove=function(){this.div&&this.div.parentNode&&(this.hide(),null!==this.boundsChangedListener&&google.maps.event.removeListener(this.boundsChangedListener),this.div.removeEventListener("mousedown",this.onMouseDown),this.div.removeEventListener("click",this.onClick),this.div.removeEventListener("mouseover",this.onMouseOver),this.div.removeEventListener("mouseout",this.onMouseOut),this.div.parentNode.removeChild(this.div),null!==this.timeOut&&(window.clearTimeout(this.timeOut),this.timeOut=null),this.div=null)},e.prototype.draw=function(){if(this.visible&&null!==this.div&&this.center){var e=this.getPosFromLatLng(this.center);this.div.style.top=null!==e?"".concat(e.y,"px"):"0",this.div.style.left=null!==e?"".concat(e.x,"px"):"0"}},e.prototype.hide=function(){this.div&&(this.div.style.display="none"),this.visible=!1},e.prototype.show=function(){var e,t,n,s,o,r;if(this.div&&this.center){var i=null===this.sums||void 0===this.sums.title||""===this.sums.title?this.cluster.getClusterer().getTitle():this.sums.title,a=this.backgroundPosition.split(" "),l=parseInt((null===(e=a[0])||void 0===e?void 0:e.replace(/^\s+|\s+$/g,""))||"0",10),u=parseInt((null===(t=a[1])||void 0===t?void 0:t.replace(/^\s+|\s+$/g,""))||"0",10),p=this.getPosFromLatLng(this.center);this.div.className=this.className,this.div.setAttribute("style","cursor: pointer; position: absolute; top: ".concat(null!==p?"".concat(p.y,"px"):"0","; left: ").concat(null!==p?"".concat(p.x,"px"):"0","; width: ").concat(this.width,"px; height: ").concat(this.height,"px; "));var c=document.createElement("img");c.alt=i,c.src=this.url,c.width=this.width,c.height=this.height,c.setAttribute("style","position: absolute; top: ".concat(u,"px; left: ").concat(l,"px")),this.cluster.getClusterer().enableRetinaIcons||(c.style.clip="rect(-".concat(u,"px, -").concat(l+this.width,"px, -").concat(u+this.height,", -").concat(l,")"));var h=document.createElement("div");h.setAttribute("style","position: absolute; top: ".concat(this.anchorText[0],"px; left: ").concat(this.anchorText[1],"px; color: ").concat(this.textColor,"; font-size: ").concat(this.textSize,"px; font-family: ").concat(this.fontFamily,"; font-weight: ").concat(this.fontWeight,"; fontStyle: ").concat(this.fontStyle,"; text-decoration: ").concat(this.textDecoration,"; text-align: center; width: ").concat(this.width,"px; line-height: ").concat(this.height,"px")),(null===(n=this.sums)||void 0===n?void 0:n.text)&&(h.innerText="".concat(null===(s=this.sums)||void 0===s?void 0:s.text)),(null===(o=this.sums)||void 0===o?void 0:o.html)&&(h.innerHTML="".concat(null===(r=this.sums)||void 0===r?void 0:r.html)),this.div.innerHTML="",this.div.appendChild(c),this.div.appendChild(h),this.div.title=i,this.div.style.display=""}this.visible=!0},e.prototype.useStyle=function(e){this.sums=e;var t=this.cluster.getClusterer().getStyles(),n=t[Math.min(t.length-1,Math.max(0,e.index-1))];n&&(this.url=n.url,this.height=n.height,this.width=n.width,n.className&&(this.className="".concat(this.clusterClassName," ").concat(n.className)),this.anchorText=n.anchorText||[0,0],this.anchorIcon=n.anchorIcon||[this.height/2,this.width/2],this.textColor=n.textColor||"black",this.textSize=n.textSize||11,this.textDecoration=n.textDecoration||"none",this.fontWeight=n.fontWeight||"bold",this.fontStyle=n.fontStyle||"normal",this.fontFamily=n.fontFamily||"Arial,sans-serif",this.backgroundPosition=n.backgroundPosition||"0 0")},e.prototype.setCenter=function(e){this.center=e},e.prototype.getPosFromLatLng=function(e){var t=this.getProjection().fromLatLngToDivPixel(e);return null!==t&&(t.x-=this.anchorIcon[1],t.y-=this.anchorIcon[0]),t},e}(),fe=function(){function e(e){this.markerClusterer=e,this.map=this.markerClusterer.getMap(),this.gridSize=this.markerClusterer.getGridSize(),this.minClusterSize=this.markerClusterer.getMinimumClusterSize(),this.averageCenter=this.markerClusterer.getAverageCenter(),this.markers=[],this.center=void 0,this.bounds=null,this.clusterIcon=new ve(this,this.markerClusterer.getStyles()),this.getSize=this.getSize.bind(this),this.getMarkers=this.getMarkers.bind(this),this.getCenter=this.getCenter.bind(this),this.getMap=this.getMap.bind(this),this.getClusterer=this.getClusterer.bind(this),this.getBounds=this.getBounds.bind(this),this.remove=this.remove.bind(this),this.addMarker=this.addMarker.bind(this),this.isMarkerInClusterBounds=this.isMarkerInClusterBounds.bind(this),this.calculateBounds=this.calculateBounds.bind(this),this.updateIcon=this.updateIcon.bind(this),this.isMarkerAlreadyAdded=this.isMarkerAlreadyAdded.bind(this)}return e.prototype.getSize=function(){return this.markers.length},e.prototype.getMarkers=function(){return this.markers},e.prototype.getCenter=function(){return this.center},e.prototype.getMap=function(){return this.map},e.prototype.getClusterer=function(){return this.markerClusterer},e.prototype.getBounds=function(){for(var e=new google.maps.LatLngBounds(this.center,this.center),t=0,n=this.getMarkers();t<n.length;t++){var s=n[t].getPosition();s&&e.extend(s)}return e},e.prototype.remove=function(){this.clusterIcon.setMap(null),this.markers=[],delete this.markers},e.prototype.addMarker=function(e){var t,n;if(this.isMarkerAlreadyAdded(e))return!1;if(this.center){if(this.averageCenter&&(n=e.getPosition())){var s=this.markers.length+1;this.center=new google.maps.LatLng((this.center.lat()*(s-1)+n.lat())/s,(this.center.lng()*(s-1)+n.lng())/s),this.calculateBounds()}}else(n=e.getPosition())&&(this.center=n,this.calculateBounds());e.isAdded=!0,this.markers.push(e);var o=this.markers.length,r=this.markerClusterer.getMaxZoom(),i=null===(t=this.map)||void 0===t?void 0:t.getZoom();if(null!==r&&void 0!==i&&i>r)e.getMap()!==this.map&&e.setMap(this.map);else if(o<this.minClusterSize)e.getMap()!==this.map&&e.setMap(this.map);else if(o===this.minClusterSize)for(var a=0,l=this.markers;a<l.length;a++){l[a].setMap(null)}else e.setMap(null);return!0},e.prototype.isMarkerInClusterBounds=function(e){if(null!==this.bounds){var t=e.getPosition();if(t)return this.bounds.contains(t)}return!1},e.prototype.calculateBounds=function(){this.bounds=this.markerClusterer.getExtendedBounds(new google.maps.LatLngBounds(this.center,this.center))},e.prototype.updateIcon=function(){var e,t=this.markers.length,n=this.markerClusterer.getMaxZoom(),s=null===(e=this.map)||void 0===e?void 0:e.getZoom();null!==n&&void 0!==s&&s>n||t<this.minClusterSize?this.clusterIcon.hide():(this.center&&this.clusterIcon.setCenter(this.center),this.clusterIcon.useStyle(this.markerClusterer.getCalculator()(this.markers,this.markerClusterer.getStyles().length)),this.clusterIcon.show())},e.prototype.isMarkerAlreadyAdded=function(e){if(this.markers.includes)return this.markers.includes(e);for(var t=0;t<this.markers.length;t++)if(e===this.markers[t])return!0;return!1},e}();function ye(e,t){var n=e.length,s=n.toString().length,o=Math.min(s,t);return{text:n.toString(),index:o,title:""}}var Le=[53,56,66,78,90],be=function(){function e(t,n,s){void 0===n&&(n=[]),void 0===s&&(s={}),this.getMinimumClusterSize=this.getMinimumClusterSize.bind(this),this.setMinimumClusterSize=this.setMinimumClusterSize.bind(this),this.getEnableRetinaIcons=this.getEnableRetinaIcons.bind(this),this.setEnableRetinaIcons=this.setEnableRetinaIcons.bind(this),this.addToClosestCluster=this.addToClosestCluster.bind(this),this.getImageExtension=this.getImageExtension.bind(this),this.setImageExtension=this.setImageExtension.bind(this),this.getExtendedBounds=this.getExtendedBounds.bind(this),this.getAverageCenter=this.getAverageCenter.bind(this),this.setAverageCenter=this.setAverageCenter.bind(this),this.getTotalClusters=this.getTotalClusters.bind(this),this.fitMapToMarkers=this.fitMapToMarkers.bind(this),this.getIgnoreHidden=this.getIgnoreHidden.bind(this),this.set