@deatog/react-google-maps-api
Version:
React.js Google Maps API integration
1 lines • 144 kB
JavaScript
"use strict";var e=require("react/jsx-runtime"),t=require("react"),s=require("react-dom");function r(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(s){if("default"!==s){var r=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(t,s,r.get?r:{enumerable:!0,get:function(){return e[s]}})}})),t.default=e,Object.freeze(t)}var n,o,i=r(s);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 s=e[Symbol.toPrimitive];if(void 0!==s){var r=s.call(e,t||"default");if("object"!=a(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==a(t)?t:t+""}function c(e,t,s){return(t=l(t))in e?Object.defineProperty(e,t,{value:s,enumerable:!0,configurable:!0,writable:!0}):e[t]=s,e}function p(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var u=p(function(){if(o)return n;o=1;var e=process.env.NODE_ENV;return n=function(t,s,r,n,o,i,a,l){if("production"!==e&&void 0===s)throw new Error("invariant requires an error message argument");if(!t){var c;if(void 0===s)c=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var p=[r,n,o,i,a,l],u=0;(c=new Error(s.replace(/%s/g,(function(){return p[u++]})))).name="Invariant Violation"}throw c.framesToPop=1,c}}}()),h=t.createContext(null);function d(){u(!!t.useContext,"useGoogleMap is React hook and requires React version 16.8+");var e=t.useContext(h);return u(!!e,"useGoogleMap needs a GoogleMap available up in the tree"),e}function g(e,t,s,r){var n,o,i={};return n=e,o=(e,n)=>{var o=s[n];o!==t[n]&&(i[n]=o,e(r,o))},Object.keys(n).forEach((e=>o(n[e],e))),i}function m(e,t,s){var r,n,o,i=(r=s,n=function(s,r,n){return"function"==typeof e[n]&&s.push(google.maps.event.addListener(t,r,e[n])),s},o=[],Object.keys(r).reduce((function(e,t){return n(e,r[t],t)}),o));return i}function f(e){google.maps.event.removeListener(e)}function v(){(arguments.length>0&&void 0!==arguments[0]?arguments[0]:[]).forEach(f)}function y(e){var{updaterMap:t,eventMap:s,prevProps:r,nextProps:n,instance:o}=e,i=m(n,o,s);return g(t,r,n,o),i}var b={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"},x={extraMapTypes(e,t){t.forEach((function(t,s){e.mapTypes.set(String(s),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(s){var{children:r,options:n,id:o,mapContainerStyle:i,mapContainerClassName:a,center:l,onClick:c,onDblClick:p,onDrag:u,onDragEnd:d,onDragStart:g,onMouseMove:m,onMouseOut:f,onMouseOver:v,onMouseDown:y,onMouseUp:b,onRightClick:x,onCenterChanged:C,onLoad:E,onUnmount:M}=s,[w,L]=t.useState(null),P=t.useRef(null);return t.useEffect((()=>{n&&null!==w&&w.setOptions(n)}),[w,n]),t.useEffect((()=>{null!==w&&void 0!==l&&w.setCenter(l)}),[w,l]),t.useEffect((()=>{if(w&&p){var e=google.maps.event.addListener(w,"dblclick",p);return()=>{e.remove()}}}),[w,p]),t.useEffect((()=>{if(w&&d){var e=google.maps.event.addListener(w,"dragend",d);return()=>{e.remove()}}}),[w,d]),t.useEffect((()=>{if(w&&g){var e=google.maps.event.addListener(w,"dragstart",g);return()=>{e.remove()}}}),[w,g]),t.useEffect((()=>{if(w&&y){var e=google.maps.event.addListener(w,"mousedown",y);return()=>{e.remove()}}}),[w,y]),t.useEffect((()=>{if(w&&m){var e=google.maps.event.addListener(w,"mousemove",m);return()=>{e.remove()}}}),[w,m]),t.useEffect((()=>{if(w&&f){var e=google.maps.event.addListener(w,"mouseout",f);return()=>{e.remove()}}}),[w,f]),t.useEffect((()=>{if(w&&v){var e=google.maps.event.addListener(w,"mouseover",v);return()=>{e.remove()}}}),[w,v]),t.useEffect((()=>{if(w&&b){var e=google.maps.event.addListener(w,"mouseup",b);return()=>{e.remove()}}}),[w,b]),t.useEffect((()=>{if(w&&x){var e=google.maps.event.addListener(w,"rightclick",x);return()=>{e.remove()}}}),[w,x]),t.useEffect((()=>{if(w&&c){var e=google.maps.event.addListener(w,"click",c);return()=>{e.remove()}}}),[w,c]),t.useEffect((()=>{if(w&&u){var e=google.maps.event.addListener(w,"drag",u);return()=>{e.remove()}}}),[w,u]),t.useEffect((()=>{if(w&&C){var e=google.maps.event.addListener(w,"center_changed",C);return()=>{e.remove()}}}),[c]),t.useEffect((()=>{w&&E&&E(w)}),[w,E]),t.useEffect((()=>{if(w&&M)return()=>{M(w)}}),[w,M]),t.useEffect((()=>{var e=null===P.current?null:new google.maps.Map(P.current,n);L(e)}),[]),e.jsx("div",{id:o,ref:P,style:i,className:a,children:e.jsx(h.Provider,{value:w,children:null!==w?r:null})})}));class C extends t.PureComponent{constructor(){super(...arguments),c(this,"state",{map:null}),c(this,"registeredEvents",[]),c(this,"mapRef",null),c(this,"getInstance",(()=>null===this.mapRef?null:new google.maps.Map(this.mapRef,this.props.options))),c(this,"panTo",(e=>{var t=this.getInstance();t&&t.panTo(e)})),c(this,"setMapCallback",(()=>{null!==this.state.map&&this.props.onLoad&&this.props.onLoad(this.state.map)})),c(this,"getRef",(e=>{this.mapRef=e}))}componentDidMount(){var e=this.getInstance();this.registeredEvents=y({updaterMap:x,eventMap:b,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{map:e}}),this.setMapCallback)}componentDidUpdate(e){null!==this.state.map&&(v(this.registeredEvents),this.registeredEvents=y({updaterMap:x,eventMap:b,prevProps:e,nextProps:this.props,instance:this.state.map}))}componentWillUnmount(){null!==this.state.map&&(this.props.onUnmount&&this.props.onUnmount(this.state.map),v(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 E(e,t,s,r,n,o,i){try{var a=e[o](i),l=a.value}catch(e){return void s(e)}a.done?t(l):Promise.resolve(l).then(r,n)}function M(e){return function(){var t=this,s=arguments;return new Promise((function(r,n){var o=e.apply(t,s);function i(e){E(o,r,n,i,a,"next",e)}function a(e){E(o,r,n,i,a,"throw",e)}i(void 0)}))}}function w(e){var{googleMapsApiKey:t,googleMapsClientId:s,version:r="weekly",language:n,region:o,libraries:i,channel:a,mapIds:l,authReferrerPolicy:c,apiUrl:p="https://maps.googleapis.com"}=e,h=[];return u(t&&s||!(t&&s),"You need to specify either googleMapsApiKey or googleMapsClientId for @deatog/react-google-maps-api load script to work. You cannot use both at the same time."),t?h.push("key=".concat(t)):s&&h.push("client=".concat(s)),r&&h.push("v=".concat(r)),n&&h.push("language=".concat(n)),o&&h.push("region=".concat(o)),i&&i.length&&h.push("libraries=".concat(i.sort().join(","))),a&&h.push("channel=".concat(a)),l&&l.length&&h.push("map_ids=".concat(l.join(","))),c&&h.push("auth_referrer_policy=".concat(c)),h.push("loading=async"),h.push("callback=initMap"),"".concat(p,"/maps/api/js?").concat(h.join("&"))}var L="undefined"!=typeof document;function P(e){var{url:t,id:s,nonce:r}=e;return L?new Promise((function(e,n){var o=document.getElementById(s),i=window;if(o){var a=o.getAttribute("data-state");if(o.src===t&&"error"!==a){if("ready"===a)return e(s);var l=i.initMap,c=o.onerror;return i.initMap=function(){l&&l(),e(s)},void(o.onerror=function(e){c&&c(e),n(e)})}o.remove()}var p=document.createElement("script");p.type="text/javascript",p.src=t,p.id=s,p.async=!0,p.nonce=r||"",p.onerror=function(e){p.setAttribute("data-state","error"),n(e)},i.initMap=function(){p.setAttribute("data-state","ready"),e(s)},document.head.appendChild(p)})).catch((e=>{throw console.error("injectScript error: ",e),e})):Promise.reject(new Error("document is undefined"))}function k(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 O(){var e=document.getElementsByTagName("head")[0];if(e){var t=e.insertBefore.bind(e);e.insertBefore=function(s,r){return k(s)||Reflect.apply(t,e,[s,r]),s};var s=e.appendChild.bind(e);e.appendChild=function(t){return k(t)||Reflect.apply(s,e,[t]),t}}}var S=!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),c(this,"check",null),c(this,"state",{loaded:!1}),c(this,"cleanupCallback",(()=>{delete window.google.maps,this.injectScript()})),c(this,"isCleaningUp",M((function*(){return new Promise((function(e){if(S){if(L)var t=window.setInterval((function(){S||(window.clearInterval(t),e())}),1)}else e()}))}))),c(this,"cleanup",(()=>{S=!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)}))})),c(this,"injectScript",(()=>{this.props.preventGoogleFontsLoading&&O(),u(!!this.props.id,'LoadScript requires "id" prop to be a string: %s',this.props.id),P({id:this.props.id,nonce:this.props.nonce,url:w(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 "))}))})),c(this,"getRef",(e=>{this.check=e}))}componentDidMount(){if(L){if(window.google&&window.google.maps&&!S)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"),L&&e.language!==this.props.language&&(this.cleanup(),this.setState((function(){return{loaded:!1}}),this.cleanupCallback))}componentWillUnmount(){if(L){this.cleanup();window.setTimeout((()=>{this.check||(delete window.google,S=!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 s,r,n=function(e,t){if(null==e)return{};var s={};for(var r in e)if({}.hasOwnProperty.call(e,r)){if(-1!==t.indexOf(r))continue;s[r]=e[r]}return s}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(r=0;r<o.length;r++)s=o[r],-1===t.indexOf(s)&&{}.propertyIsEnumerable.call(e,s)&&(n[s]=e[s])}return n}function R(e){var{id:s=I.id,version:r=I.version,nonce:n,googleMapsApiKey:o,googleMapsClientId:i,language:a,region:l,libraries:c,preventGoogleFontsLoading:p,channel:h,mapIds:d,authReferrerPolicy:g,apiUrl:m="https://maps.googleapis.com"}=e,f=t.useRef(!1),[v,y]=t.useState(!1),[b,x]=t.useState(void 0);t.useEffect((function(){return f.current=!0,()=>{f.current=!1}}),[]),t.useEffect((function(){L&&p&&O()}),[p]),t.useEffect((function(){v&&u(!!window.google,"useLoadScript was marked as loaded, but window.google is not present. Something went wrong.")}),[v]);var C=w({version:r,googleMapsApiKey:o,googleMapsClientId:i,language:a,region:l,libraries:c,channel:h,mapIds:d,authReferrerPolicy:g,apiUrl:m});t.useEffect((function(){function e(){f.current&&(y(!0),j=C)}L&&(window.google&&window.google.maps&&j===C?e():P({id:s,url:C,nonce:n}).then(e).catch((function(e){f.current&&x(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(o||"-",") or Client ID (").concat(i||"-",")\n Otherwise it is a Network issue.\n ")),console.error(e)})))}),[s,C,n]);var E=t.useRef(void 0);return t.useEffect((function(){E.current&&c!==E.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"),E.current=c}),[c]),{isLoaded:v,loadError:b,url:C}}c(B,"defaultProps",I);var U=["loadingElement","onLoad","onError","onUnmount","children"],_=e.jsx(D,{});var A=t.memo((function(e){var{loadingElement:s,onLoad:r,onError:n,onUnmount:o,children:i}=e,a=T(e,U),{isLoaded:l,loadError:c}=R(a);return t.useEffect((function(){l&&"function"==typeof r&&r()}),[l,r]),t.useEffect((function(){c&&"function"==typeof n&&n(c)}),[c,n]),t.useEffect((function(){return()=>{o&&o()}}),[o]),l?i:s||_}));function z(e,t,s,r){return new(s||(s=Promise))((function(t,n){function o(e){try{a(r.next(e))}catch(e){n(e)}}function i(e){try{a(r.throw(e))}catch(e){n(e)}}function a(e){var r;e.done?t(e.value):(r=e.value,r instanceof s?r:new s((function(e){e(r)}))).then(o,i)}a((r=r.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,s){if(t===s)return!0;if(t&&s&&"object"==typeof t&&"object"==typeof s){if(t.constructor!==s.constructor)return!1;var r,n,o;if(Array.isArray(t)){if((r=t.length)!=s.length)return!1;for(n=r;0!=n--;)if(!e(t[n],s[n]))return!1;return!0}if(t.constructor===RegExp)return t.source===s.source&&t.flags===s.flags;if(t.valueOf!==Object.prototype.valueOf)return t.valueOf()===s.valueOf();if(t.toString!==Object.prototype.toString)return t.toString()===s.toString();if((r=(o=Object.keys(t)).length)!==Object.keys(s).length)return!1;for(n=r;0!=n--;)if(!Object.prototype.hasOwnProperty.call(s,o[n]))return!1;for(n=r;0!=n--;){var i=o[n];if(!e(t[i],s[i]))return!1}return!0}return t!=t&&s!=s},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:s,channel:r,client:n,id:o=H,language:i,libraries:a=[],mapIds:l,nonce:c,region:p,retries:u=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=s,this.channel=r,this.client=n,this.id=o||H,this.language=i,this.libraries=a,this.mapIds=l,this.nonce=c,this.region=p,this.retries=u,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((s=>{s?t(s.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 s={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(s).forEach((e=>!s[e]&&delete s[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,s,r,n="The Google Maps JavaScript API",o="google",i="importLibrary",a="__ib__",l=document,c=window,p=(c=c[o]||(c[o]={})).maps||(c.maps={}),u=new Set,h=new URLSearchParams,d=()=>t||(t=new Promise(((i,c)=>z(this,0,void 0,(function*(){var d;for(r in yield s=l.createElement("script"),s.id=this.id,h.set("libraries",[...u]+""),e)h.set(r.replace(/[A-Z]/g,(e=>"_"+e[0].toLowerCase())),e[r]);h.set("callback",o+".maps."+a),s.src=this.url+"?"+h,p[a]=i,s.onerror=()=>t=c(Error(n+" could not load.")),s.nonce=this.nonce||(null===(d=l.querySelector("script[nonce]"))||void 0===d?void 0:d.nonce)||"",l.head.append(s)})))));p[i]?console.warn(n+" only loads once. Ignoring:",e):p[i]=function(e){for(var t=arguments.length,s=new Array(t>1?t-1:0),r=1;r<t;r++)s[r-1]=arguments[r];return u.add(e)&&d().then((()=>p[i](e,...s)))}})(s);var r=this.libraries.map((e=>this.importLibrary(e)));r.length||r.push(this.importLibrary("core")),Promise.all(r).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 s=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),s.push.apply(s,r)}return s}function Y(e){for(var t=1;t<arguments.length;t++){var s=null!=arguments[t]?arguments[t]:{};t%2?K(Object(s),!0).forEach((function(t){c(e,t,s[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(s)):K(Object(s)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(s,t))}))}return e}var q={},J={options(e,t){e.setOptions(t)}};var X=t.memo((function(e){var{options:s,onLoad:r,onUnmount:n}=e,o=t.useContext(h),[i,a]=t.useState(null);return t.useEffect((()=>{null!==i&&i.setMap(o)}),[o]),t.useEffect((()=>{s&&null!==i&&i.setOptions(s)}),[i,s]),t.useEffect((()=>{var e=new google.maps.TrafficLayer(Y(Y({},s),{},{map:o}));return a(e),r&&r(e),()=>{null!==i&&(n&&n(i),i.setMap(null))}}),[]),null}));class $ extends t.PureComponent{constructor(){super(...arguments),c(this,"state",{trafficLayer:null}),c(this,"setTrafficLayerCallback",(()=>{null!==this.state.trafficLayer&&this.props.onLoad&&this.props.onLoad(this.state.trafficLayer)})),c(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&&(v(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),v(this.registeredEvents),this.state.trafficLayer.setMap(null))}render(){return null}}c($,"contextType",h);var Q=t.memo((function(e){var{onLoad:s,onUnmount:r}=e,n=t.useContext(h),[o,i]=t.useState(null);return t.useEffect((()=>{null!==o&&o.setMap(n)}),[n]),t.useEffect((()=>{var e=new google.maps.BicyclingLayer;return i(e),e.setMap(n),s&&s(e),()=>{null!==e&&(r&&r(e),e.setMap(null))}}),[]),null}));class ee extends t.PureComponent{constructor(){super(...arguments),c(this,"state",{bicyclingLayer:null}),c(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}}c(ee,"contextType",h);var te=t.memo((function(e){var{onLoad:s,onUnmount:r}=e,n=t.useContext(h),[o,i]=t.useState(null);return t.useEffect((()=>{null!==o&&o.setMap(n)}),[n]),t.useEffect((()=>{var e=new google.maps.TransitLayer;return i(e),e.setMap(n),s&&s(e),()=>{null!==o&&(r&&r(o),o.setMap(null))}}),[]),null}));class se extends t.PureComponent{constructor(){super(...arguments),c(this,"state",{transitLayer:null}),c(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 re(e,t){var s=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),s.push.apply(s,r)}return s}function ne(e){for(var t=1;t<arguments.length;t++){var s=null!=arguments[t]?arguments[t]:{};t%2?re(Object(s),!0).forEach((function(t){c(e,t,s[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(s)):re(Object(s)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(s,t))}))}return e}c(se,"contextType",h);var oe={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:s,drawingMode:r,onCircleComplete:n,onMarkerComplete:o,onOverlayComplete:i,onPolygonComplete:a,onPolylineComplete:l,onRectangleComplete:c,onLoad:p,onUnmount:d}=e,g=t.useContext(h),m=t.useMemo((()=>(u(!!google.maps.drawing,"Did you include prop libraries={['drawing']} in the URL? %s",google.maps.drawing),new google.maps.drawing.DrawingManager(ne(ne({},s),{},{map:g})))),[]);return t.useEffect((()=>{if(g)return m.setMap(g),()=>{m.setMap(null)}}),[m,g]),t.useEffect((()=>{s&&m.setOptions(s)}),[m,s]),t.useEffect((()=>{m.setDrawingMode(null!=r?r:null)}),[m,r]),t.useEffect((()=>{if(n){var e=google.maps.event.addListener(m,"circlecomplete",n);return()=>{e.remove()}}}),[m,n]),t.useEffect((()=>{if(o){var e=google.maps.event.addListener(m,"markercomplete",o);return()=>{e.remove()}}}),[m,o]),t.useEffect((()=>{if(i){var e=google.maps.event.addListener(m,"overlaycomplete",i);return()=>{e.remove()}}}),[m,i]),t.useEffect((()=>{if(a){var e=google.maps.event.addListener(m,"polygoncomplete",a);return()=>{e.remove()}}}),[m,a]),t.useEffect((()=>{if(l){var e=google.maps.event.addListener(m,"polylinecomplete",l);return()=>{e.remove()}}}),[m,l]),t.useEffect((()=>{if(c){var e=google.maps.event.addListener(m,"rectanglecomplete",c);return()=>{e.remove()}}}),[m,c]),t.useEffect((()=>{p&&p(m)}),[m,p]),t.useEffect((()=>{if(d)return()=>{d(m)}}),[m,d]),null}));class le extends t.PureComponent{constructor(e){super(e),c(this,"registeredEvents",[]),c(this,"state",{drawingManager:null}),c(this,"setDrawingManagerCallback",(()=>{null!==this.state.drawingManager&&this.props.onLoad&&this.props.onLoad(this.state.drawingManager)})),u(!!google.maps.drawing,"Did you include prop libraries={['drawing']} in the URL? %s",google.maps.drawing)}componentDidMount(){var e=new google.maps.drawing.DrawingManager(ne(ne({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:ie,eventMap:oe,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{drawingManager:e}}),this.setDrawingManagerCallback)}componentDidUpdate(e){null!==this.state.drawingManager&&(v(this.registeredEvents),this.registeredEvents=y({updaterMap:ie,eventMap:oe,prevProps:e,nextProps:this.props,instance:this.state.drawingManager}))}componentWillUnmount(){null!==this.state.drawingManager&&(this.props.onUnmount&&this.props.onUnmount(this.state.drawingManager),v(this.registeredEvents),this.state.drawingManager.setMap(null))}render(){return null}}function ce(e,t){var s=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),s.push.apply(s,r)}return s}function pe(e){for(var t=1;t<arguments.length;t++){var s=null!=arguments[t]?arguments[t]:{};t%2?ce(Object(s),!0).forEach((function(t){c(e,t,s[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(s)):ce(Object(s)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(s,t))}))}return e}c(le,"contextType",h);var ue={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(s){var{position:r,options:n,clusterer:o,noClustererRedraw:i,children:a,draggable:l,visible:c,animation:p,clickable:u,cursor:d,icon:g,label:m,opacity:f,shape:v,title:y,zIndex:b,onClick:x,onDblClick:C,onDrag:E,onDragEnd:M,onDragStart:w,onMouseOut:L,onMouseOver:P,onMouseUp:k,onMouseDown:O,onRightClick:S,onClickableChanged:D,onCursorChanged:j,onAnimationChanged:I,onDraggableChanged:B,onFlatChanged:T,onIconChanged:R,onPositionChanged:U,onShapeChanged:_,onTitleChanged:A,onVisibleChanged:z,onZindexChanged:Z,onLoad:V,onUnmount:W}=s,N=t.useContext(h),H=t.useMemo((()=>{var e=pe(pe(pe({},n||de),o?de:{map:N}),{},{position:r});return new google.maps.Marker(e)}),[]);t.useEffect((()=>{n&&H.setOptions(n)}),[H,n]),t.useEffect((()=>{void 0!==l&&H.setDraggable(l)}),[H,l]),t.useEffect((()=>{r&&H.setPosition(r)}),[H,r]),t.useEffect((()=>{void 0!==c&&H.setVisible(c)}),[H,c]),t.useEffect((()=>{H.setAnimation(p)}),[H,p]),t.useEffect((()=>{void 0!==u&&H.setClickable(u)}),[H,u]),t.useEffect((()=>{void 0!==d&&H.setCursor(d)}),[H,d]),t.useEffect((()=>{void 0!==g&&H.setIcon(g)}),[H,g]),t.useEffect((()=>{void 0!==m&&H.setLabel(m)}),[H,m]),t.useEffect((()=>{void 0!==f&&H.setOpacity(f)}),[H,f]),t.useEffect((()=>{void 0!==v&&H.setShape(v)}),[H,v]),t.useEffect((()=>{void 0!==y&&H.setTitle(y)}),[H,y]),t.useEffect((()=>{void 0!==b&&H.setZIndex(b)}),[H,b]),t.useEffect((()=>{if(C){var e=google.maps.event.addListener(H,"dblclick",C);return()=>{e.remove()}}}),[H,C]),t.useEffect((()=>{if(M){var e=google.maps.event.addListener(H,"dragend",M);return()=>{e.remove()}}}),[H,M]),t.useEffect((()=>{if(w){var e=google.maps.event.addListener(H,"dragstart",w);return()=>{e.remove()}}}),[H,w]),t.useEffect((()=>{if(O){var e=google.maps.event.addListener(H,"mousedown",O);return()=>{e.remove()}}}),[H,O]),t.useEffect((()=>{if(L){var e=google.maps.event.addListener(H,"mouseout",L);return()=>{e.remove()}}}),[H,L]),t.useEffect((()=>{if(P){var e=google.maps.event.addListener(H,"mouseover",P);return()=>{e.remove()}}}),[H,P]),t.useEffect((()=>{if(k){var e=google.maps.event.addListener(H,"mouseup",k);return()=>{e.remove()}}}),[H,k]),t.useEffect((()=>{if(S){var e=google.maps.event.addListener(H,"rightclick",S);return()=>{e.remove()}}}),[H,S]),t.useEffect((()=>{if(x){var e=google.maps.event.addListener(H,"click",x);return()=>{e.remove()}}}),[H,x]),t.useEffect((()=>{if(E){var e=google.maps.event.addListener(H,"drag",E);return()=>{e.remove()}}}),[H,E]),t.useEffect((()=>{if(D){var e=google.maps.event.addListener(H,"clickable_changed",D);return()=>{e.remove()}}}),[H,D]),t.useEffect((()=>{if(j){var e=google.maps.event.addListener(H,"cursor_changed",j);return()=>{e.remove()}}}),[H,j]),t.useEffect((()=>{if(I){var e=google.maps.event.addListener(H,"animation_changed",I);return()=>{e.remove()}}}),[H,I]),t.useEffect((()=>{if(B){var e=google.maps.event.addListener(H,"draggable_changed",B);return()=>{e.remove()}}}),[H,B]),t.useEffect((()=>{if(T){var e=google.maps.event.addListener(H,"flat_changed",T);return()=>{e.remove()}}}),[H,T]),t.useEffect((()=>{if(R){var e=google.maps.event.addListener(H,"icon_changed",R);return()=>{e.remove()}}}),[H,R]),t.useEffect((()=>{if(U){var e=google.maps.event.addListener(H,"position_changed",U);return()=>{e.remove()}}}),[H,U]),t.useEffect((()=>{if(_){var e=google.maps.event.addListener(H,"shape_changed",_);return()=>{e.remove()}}}),[H,_]),t.useEffect((()=>{if(A){var e=google.maps.event.addListener(H,"title_changed",A);return()=>{e.remove()}}}),[H,A]),t.useEffect((()=>{if(z){var e=google.maps.event.addListener(H,"visible_changed",z);return()=>{e.remove()}}}),[H,z]),t.useEffect((()=>{if(Z){var e=google.maps.event.addListener(H,"zindex_changed",Z);return()=>{e.remove()}}}),[H,Z]),t.useEffect((()=>(o?o.addMarker(H,!!i):H.setMap(N),()=>{o?o.removeMarker(H,!!i):H.setMap(null)})),[H,N,o,i]),t.useEffect((()=>{V&&V(H)}),[H,V]),t.useEffect((()=>{W&&W(H)}),[H,W]);var F=t.useMemo((()=>a?t.Children.map(a,(e=>{if(!t.isValidElement(e))return e;var s=e;return t.cloneElement(s,{anchor:H})})):null),[a,H]);return e.jsx(e.Fragment,{children:F})||null}));class me extends t.PureComponent{constructor(){super(...arguments),c(this,"registeredEvents",[])}componentDidMount(){var e=this;return M((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:ue,prevProps:{},nextProps:e.props,instance:e.marker}),e.props.onLoad&&e.props.onLoad(e.marker)}))()}componentDidUpdate(e){this.marker&&(v(this.registeredEvents),this.registeredEvents=y({updaterMap:he,eventMap:ue,prevProps:e,nextProps:this.props,instance:this.marker}))}componentWillUnmount(){this.marker&&(this.props.onUnmount&&this.props.onUnmount(this.marker),v(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 s=e;return t.cloneElement(s,{anchor:this.marker})})):null)||null}}c(me,"contextType",h);var fe=function(){function e(t,s){t.getClusterer().extend(e,google.maps.OverlayView),this.cluster=t,this.clusterClassName=this.cluster.getClusterer().getClusterClass(),this.className=this.clusterClassName,this.styles=s,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 s=t.getMaxZoom(),r=this.cluster.getBounds(),n=t.getMap();null!==n&&"fitBounds"in n&&n.fitBounds(r),this.timeOut=window.setTimeout((function(){var e=t.getMap();if(null!==e){"fitBounds"in e&&e.fitBounds(r);var n=e.getZoom()||0;null!==s&&n>s&&e.setZoom(s+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,s,r,n,o;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),c=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 u=document.createElement("img");u.alt=i,u.src=this.url,u.width=this.width,u.height=this.height,u.setAttribute("style","position: absolute; top: ".concat(c,"px; left: ").concat(l,"px")),this.cluster.getClusterer().enableRetinaIcons||(u.style.clip="rect(-".concat(c,"px, -").concat(l+this.width,"px, -").concat(c+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===(s=this.sums)||void 0===s?void 0:s.text)&&(h.innerText="".concat(null===(r=this.sums)||void 0===r?void 0:r.text)),(null===(n=this.sums)||void 0===n?void 0:n.html)&&(h.innerHTML="".concat(null===(o=this.sums)||void 0===o?void 0:o.html)),this.div.innerHTML="",this.div.appendChild(u),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(),s=t[Math.min(t.length-1,Math.max(0,e.index-1))];s&&(this.url=s.url,this.height=s.height,this.width=s.width,s.className&&(this.className="".concat(this.clusterClassName," ").concat(s.className)),this.anchorText=s.anchorText||[0,0],this.anchorIcon=s.anchorIcon||[this.height/2,this.width/2],this.textColor=s.textColor||"black",this.textSize=s.textSize||11,this.textDecoration=s.textDecoration||"none",this.fontWeight=s.fontWeight||"bold",this.fontStyle=s.fontStyle||"normal",this.fontFamily=s.fontFamily||"Arial,sans-serif",this.backgroundPosition=s.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}(),ve=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 fe(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,s=this.getMarkers();t<s.length;t++){var r=s[t].getPosition();r&&e.extend(r)}return e},e.prototype.remove=function(){this.clusterIcon.setMap(null),this.markers=[],delete this.markers},e.prototype.addMarker=function(e){var t,s;if(this.isMarkerAlreadyAdded(e))return!1;if(this.center){if(this.averageCenter&&(s=e.getPosition())){var r=this.markers.length+1;this.center=new google.maps.LatLng((this.center.lat()*(r-1)+s.lat())/r,(this.center.lng()*(r-1)+s.lng())/r),this.calculateBounds()}}else(s=e.getPosition())&&(this.center=s,this.calculateBounds());e.isAdded=!0,this.markers.push(e);var n=this.markers.length,o=this.markerClusterer.getMaxZoom(),i=null===(t=this.map)||void 0===t?void 0:t.getZoom();if(null!==o&&void 0!==i&&i>o)e.getMap()!==this.map&&e.setMap(this.map);else if(n<this.minClusterSize)e.getMap()!==this.map&&e.setMap(this.map);else if(n===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,s=this.markerClusterer.getMaxZoom(),r=null===(e=this.map)||void 0===e?void 0:e.getZoom();null!==s&&void 0!==r&&r>s||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 s=e.length,r=s.toString().length,n=Math.min(r,t);return{text:s.toString(),index:n,title:""}}var be=[53,56,66,78,90],xe=function(){function e(t,s,r){void 0===s&&(s=[]),void 0===r&&(r={}),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.setIgnoreHidden=this.setIgnoreHidden.bind(this),this.getClusterClass=this.getClusterClass.bind(this),this.setClusterClass=this.setClusterClass.bind(this),this.getTotalMarkers=this.getTotalMarkers.bind(this),this.getZoomOnClick=this.getZoomOnClick.bind(this),this.setZoomOnClick=this.setZoomOnClick.bind(this),this.getBatchSizeIE=this.getBatchSizeIE.bind(this),this.setBatchSizeIE=this.setBatchSizeIE.bind(this),this.createClusters=this.createClusters.bind(this),this.onZoomChanged=this.onZoomChanged.bind(this),this.getImageSizes=this.getImageSizes.bind(this),this.setImageSizes=this.setImageSizes.bind(this),this.getCalculator=this.getCalculator.bind(this),this.setCalculator=this.setCalculator.bind(this),this.removeMarkers=this.removeMarkers.bind(this),this.resetViewport=this.resetViewport.bind(this),this.getImagePath=this.getImagePath.bind(this),this.setImagePath=this.setImagePath.bind(this),this.pushMarkerTo=this.pushMarkerTo.bind(this),this.removeMarker=this.removeMarker.bind(this),this.clearMarkers=this.clearMarkers.bind(this),this.setupStyles=this.setupStyles.bind(this),this.getGridSize=this.getGridSize.bind(this),this.setGridSize=this.setGridSize.bind(this),this.getClusters=this.getClusters.bind(this),this.getMaxZoom=this.getMaxZoom.bind(this),this.setMaxZoom=this.setMaxZoom.bind(this),this.getMarkers=this.getMarkers.bind(this),this.addMarkers=this.addMarkers.bind(this),this.getStyles=this.getStyles.bind(this),this.setStyles=this.setStyles.bind(this),this.addMarker=this.addMarker.bind(this),this.onRemove=this.onRemove.bind(this),this.getTitle=this.getTitle.bind(this),this.setTitle=this.setTitle.bind(this),this.repaint=this.repaint.bind(this),this.onIdle=this.onIdle.bind(this),this.redraw=this.redraw.bind(this),this.onAdd=this.onAdd.bind(this),this.draw=this.draw.bind(this),this.extend=this.extend.bind(this),this.extend(e,google.maps.OverlayView),this.markers=new Set,this.clusters=[],this.listeners=[],this.activeMap=null,this.ready=!1,this.gridSize=r.gridSize||60,this.minClusterSize=r.minimumClusterSize||2,this.maxZoom=r.maxZoom||null,this.styles=r.styles||[],this.title=r.title||"",this.zoomOnClick=!0,void 0!==r.zoomOnClick&&(this.zoomOnClick=r.zoomOnClick),this.averageCenter=!1,void 0!==r.averageCenter&&(this.averageCenter=r.averageCenter),this.ignoreHidden=!1,void 0!==r.ignoreHidden&&(this.ignoreHidden=r.ignoreHidden),this.enableRetinaIcons=!1,void 0!==r.enableRetinaIcons&&(this.enableRetinaIcons=r.enableRetinaIcons),this.imagePath=r.imagePath||"https://developers.google.com/maps/documentation/javascript/examples/markerclusterer/m",this.imageExtension=r.imageExtension||"png",this.imageSizes=r.imageSizes||be,this.calculator=r.calculator||ye,this.batchSize=r.batchSize||2e3,this.batchSizeIE=r.batchSizeIE||500,this.clusterClass=r.clusterClass||"cluster",-1!==navigator.userAgent.toLowerCase().indexOf("msie")&&(this.batchSize=this.batchSizeIE),this.timerRefStatic=null,this.setupStyles(),this.addMarkers(s,!0),this.setMap(t)}return e.prototype.onZoomChanged=function(){var e,t;this.resetViewport(!1),(null===(e=this.getMap())||void 0===e?void 0:e.getZoom())!==(this.get("minZoom")||0)&&(null===(t=this.getMap())||void 0===t?void 0:t.getZoom())!==this.get("maxZoom")||google.maps.event.trigger(this,"idle")},e.prototype.onIdle=function(){this.redraw()},e.prototype.onAdd=function(){var e=this.getMap();this.activeMap=e,this.ready=!0,this.repaint(),null!==e&&(this.listeners=[google.maps.event.addListener(e,"zoom_changed",this.onZoomChanged),google.maps.event.addListener(e,"idle",this.onIdle)])},e.prototype.onRemove=function(){for(var e=this.markers.values(),t=e.next();!t.done;){var s=t.value;s.getMap()!==this.activeMap&&s.setMap(this.activeMap),t=e.next()}for(var r=0,n=this.clusters;r<n.length;r++){n[r].remove()}this.clusters=[];for(var o=0,i=this.listeners;o<i.length;o++){var a=i[o];google.maps.event.removeListener(a)}this.listeners=[],this.activeMap=null,this.ready=!1},e.prototype.draw=function(){},e.prototype.getMap=function(){return null},e.prototype.getPanes=function(){return null},e.prototype.getProjection=function(){return{fromContainerPixelToLatLng:function(){return null},fromDivPixelToLatLng:function(){return null},fromLatLngToContainerPixel:function(){return null},fromLatLngToDivPixel:function(){return null},getVisibleRegion:function(){return null},getWorldWidth:function(){return 0}}},e.prototype.setMap=function(){},e.prototype.addListener=function(){return{remove:function(){}}},e.prototype.bindTo=function(){},e.prototype.get=function(){},e.prototype.notify=function(){},e.prototype.set=function(){},e.prototype.setValues=function(){},e.prototype.unbind=function(){},e.pr