/*! For license information please see 523.8639a532.chunk.js.LICENSE.txt */
"use strict";(self.webpackChunkmantis_material_react=self.webpackChunkmantis_material_react||[]).push([[523],{10523:(e,t,n)=>{n.d(t,{BH:()=>U,Fu:()=>gt,KD:()=>G,Ro:()=>Lt,i3:()=>nn,pH:()=>pe,u6:()=>C});var s,o,i=n(44414),r=n(9950),a=n(17119);function l(e){return l="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},l(e)}function u(e){var t=function(e,t){if("object"!=l(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var s=n.call(e,t||"default");if("object"!=l(s))return s;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==l(t)?t:t+""}function p(e,t,n){return(t=u(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function c(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var d=c(o?s:(o=1,s=function(e,t,n,s,o,i,r,a){if(!e){var l;if(void 0===t)l=new Error("Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.");else{var u=[n,s,o,i,r,a],p=0;(l=new Error(t.replace(/%s/g,(function(){return u[p++]})))).name="Invariant Violation"}throw l.framesToPop=1,l}})),h=(0,r.createContext)(null);function g(e,t,n,s){var o,i,r={};return o=e,i=(e,o)=>{var i=n[o];i!==t[o]&&(r[o]=i,e(s,i))},Object.keys(o).forEach((e=>i(o[e],e))),r}function m(e,t,n){var s,o,i,r=(s=n,o=function(n,s,o){return"function"===typeof e[o]&&n.push(google.maps.event.addListener(t,s,e[o])),n},i=[],Object.keys(s).reduce((function(e,t){return o(e,s[t],t)}),i));return r}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:i}=e,r=m(o,i,n);return g(t,s,o,i),r}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"},L={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)}};(0,r.memo)((function(e){var{children:t,options:n,id:s,mapContainerStyle:o,mapContainerClassName:a,center:l,onClick:u,onDblClick:p,onDrag:c,onDragEnd:d,onDragStart:g,onMouseMove:m,onMouseOut:v,onMouseOver:f,onMouseDown:y,onMouseUp:b,onRightClick:L,onCenterChanged:C,onLoad:E,onUnmount:w}=e,[M,x]=(0,r.useState)(null),k=(0,r.useRef)(null),[P,O]=(0,r.useState)(null),[S,D]=(0,r.useState)(null),[I,j]=(0,r.useState)(null),[B,_]=(0,r.useState)(null),[R,T]=(0,r.useState)(null),[U,z]=(0,r.useState)(null),[A,Z]=(0,r.useState)(null),[V,W]=(0,r.useState)(null),[N,H]=(0,r.useState)(null),[F,G]=(0,r.useState)(null),[K,Y]=(0,r.useState)(null),[q,J]=(0,r.useState)(null);return(0,r.useEffect)((()=>{n&&null!==M&&M.setOptions(n)}),[M,n]),(0,r.useEffect)((()=>{null!==M&&"undefined"!==typeof l&&M.setCenter(l)}),[M,l]),(0,r.useEffect)((()=>{M&&p&&(null!==S&&google.maps.event.removeListener(S),D(google.maps.event.addListener(M,"dblclick",p)))}),[p]),(0,r.useEffect)((()=>{M&&d&&(null!==I&&google.maps.event.removeListener(I),j(google.maps.event.addListener(M,"dragend",d)))}),[d]),(0,r.useEffect)((()=>{M&&g&&(null!==B&&google.maps.event.removeListener(B),_(google.maps.event.addListener(M,"dragstart",g)))}),[g]),(0,r.useEffect)((()=>{M&&y&&(null!==R&&google.maps.event.removeListener(R),T(google.maps.event.addListener(M,"mousedown",y)))}),[y]),(0,r.useEffect)((()=>{M&&m&&(null!==U&&google.maps.event.removeListener(U),z(google.maps.event.addListener(M,"mousemove",m)))}),[m]),(0,r.useEffect)((()=>{M&&v&&(null!==A&&google.maps.event.removeListener(A),Z(google.maps.event.addListener(M,"mouseout",v)))}),[v]),(0,r.useEffect)((()=>{M&&f&&(null!==V&&google.maps.event.removeListener(V),W(google.maps.event.addListener(M,"mouseover",f)))}),[f]),(0,r.useEffect)((()=>{M&&b&&(null!==N&&google.maps.event.removeListener(N),H(google.maps.event.addListener(M,"mouseup",b)))}),[b]),(0,r.useEffect)((()=>{M&&L&&(null!==F&&google.maps.event.removeListener(F),G(google.maps.event.addListener(M,"rightclick",L)))}),[L]),(0,r.useEffect)((()=>{M&&u&&(null!==K&&google.maps.event.removeListener(K),Y(google.maps.event.addListener(M,"click",u)))}),[u]),(0,r.useEffect)((()=>{M&&c&&(null!==q&&google.maps.event.removeListener(q),J(google.maps.event.addListener(M,"drag",c)))}),[c]),(0,r.useEffect)((()=>{M&&C&&(null!==P&&google.maps.event.removeListener(P),O(google.maps.event.addListener(M,"center_changed",C)))}),[u]),(0,r.useEffect)((()=>{var e=null===k.current?null:new google.maps.Map(k.current,n);return x(e),null!==e&&E&&E(e),()=>{null!==e&&w&&w(e)}}),[]),(0,i.jsx)("div",{id:s,ref:k,style:o,className:a,children:(0,i.jsx)(h.Provider,{value:M,children:null!==M?t:null})})}));class C extends r.PureComponent{constructor(){super(...arguments),p(this,"state",{map:null}),p(this,"registeredEvents",[]),p(this,"mapRef",null),p(this,"getInstance",(()=>null===this.mapRef?null:new google.maps.Map(this.mapRef,this.props.options))),p(this,"panTo",(e=>{var t=this.getInstance();t&&t.panTo(e)})),p(this,"setMapCallback",(()=>{null!==this.state.map&&this.props.onLoad&&this.props.onLoad(this.state.map)})),p(this,"getRef",(e=>{this.mapRef=e}))}componentDidMount(){var e=this.getInstance();this.registeredEvents=y({updaterMap:L,eventMap:b,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:L,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),f(this.registeredEvents))}render(){return(0,i.jsx)("div",{id:this.props.id,ref:this.getRef,style:this.props.mapContainerStyle,className:this.props.mapContainerClassName,children:(0,i.jsx)(h.Provider,{value:this.state.map,children:null!==this.state.map?this.props.children:null})})}}function E(e,t,n,s,o,i,r){try{var a=e[i](r),l=a.value}catch(e){return void n(e)}a.done?t(l):Promise.resolve(l).then(s,o)}function w(e){return function(){var t=this,n=arguments;return new Promise((function(s,o){var i=e.apply(t,n);function r(e){E(i,s,o,r,a,"next",e)}function a(e){E(i,s,o,r,a,"throw",e)}r(void 0)}))}}function M(e){var{googleMapsApiKey:t,googleMapsClientId:n,version:s="weekly",language:o,region:i,libraries:r,channel:a,mapIds:l,authReferrerPolicy:u,apiUrl:p="https://maps.googleapis.com"}=e,c=[];return d(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?c.push("key=".concat(t)):n&&c.push("client=".concat(n)),s&&c.push("v=".concat(s)),o&&c.push("language=".concat(o)),i&&c.push("region=".concat(i)),r&&r.length&&c.push("libraries=".concat(r.sort().join(","))),a&&c.push("channel=".concat(a)),l&&l.length&&c.push("map_ids=".concat(l.join(","))),u&&c.push("auth_referrer_policy=".concat(u)),c.push("loading=async"),c.push("callback=initMap"),"".concat(p,"/maps/api/js?").concat(c.join("&"))}var x="undefined"!==typeof document;function k(e){var{url:t,id:n,nonce:s}=e;return x?new Promise((function(e,o){var i=document.getElementById(n),r=window;if(i){var a=i.getAttribute("data-state");if(i.src===t&&"error"!==a){if("ready"===a)return e(n);var l=r.initMap,u=i.onerror;return r.initMap=function(){l&&l(),e(n)},void(i.onerror=function(e){u&&u(e),o(e)})}i.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)},r.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 O(){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 S=!1;function D(){return(0,i.jsx)("div",{children:"Loading..."})}var I,j={id:"script-loader",version:"weekly"};class B extends r.PureComponent{constructor(){super(...arguments),p(this,"check",null),p(this,"state",{loaded:!1}),p(this,"cleanupCallback",(()=>{delete window.google.maps,this.injectScript()})),p(this,"isCleaningUp",w((function*(){return new Promise((function(e){if(S){if(x)var t=window.setInterval((function(){S||(window.clearInterval(t),e())}),1)}else e()}))}))),p(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)}))})),p(this,"injectScript",(()=>{this.props.preventGoogleFontsLoading&&O(),d(!!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 \n Otherwise it is a Network issue.\n "))}))})),p(this,"getRef",(e=>{this.check=e}))}componentDidMount(){if(x){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"),x&&e.language!==this.props.language&&(this.cleanup(),this.setState((function(){return{loaded:!1}}),this.cleanupCallback))}componentWillUnmount(){if(x){this.cleanup();window.setTimeout((()=>{this.check||(delete window.google,S=!1)}),1),this.props.onUnmount&&this.props.onUnmount()}}render(){return(0,i.jsxs)(i.Fragment,{children:[(0,i.jsx)("div",{ref:this.getRef}),this.state.loaded?this.props.children:this.props.loadingElement||(0,i.jsx)(D,{})]})}}function _(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 i=Object.getOwnPropertySymbols(e);for(s=0;s{v.current=!1}}),[]),(0,r.useEffect)((function(){x&&p&&O()}),[p]),(0,r.useEffect)((function(){f&&d(!!window.google,"useLoadScript was marked as loaded, but window.google is not present. Something went wrong.")}),[f]);var C=M({version:n,googleMapsApiKey:o,googleMapsClientId:i,language:a,region:l,libraries:u,channel:c,mapIds:h,authReferrerPolicy:g,apiUrl:m});(0,r.useEffect)((function(){function e(){v.current&&(y(!0),I=C)}x&&(window.google&&window.google.maps&&I===C?e():k({id:t,url:C,nonce:s}).then(e).catch((function(e){v.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(o||"-",") or Client ID (").concat(i||"-",")\n Otherwise it is a Network issue.\n ")),console.error(e)})))}),[t,C,s]);var E=(0,r.useRef)(void 0);return(0,r.useEffect)((function(){E.current&&u!==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=u}),[u]),{isLoaded:f,loadError:b,url:C}}(a);return(0,r.useEffect)((function(){l&&"function"===typeof n&&n()}),[l,n]),(0,r.useEffect)((function(){u&&"function"===typeof s&&s(u)}),[u,s]),(0,r.useEffect)((function(){return()=>{o&&o()}}),[o]),l?i:t||T}));function z(e,t,n,s){return new(n||(n=Promise))((function(t,o){function i(e){try{a(s.next(e))}catch(t){o(t)}}function r(e){try{a(s.throw(e))}catch(t){o(t)}}function a(e){var s;e.done?t(e.value):(s=e.value,s instanceof n?s:new n((function(e){e(s)}))).then(i,r)}a((s=s.apply(e,[])).next())}))}function A(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}"function"===typeof SuppressedError&&SuppressedError;var Z,V=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,i;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=(i=Object.keys(t)).length)!==Object.keys(n).length)return!1;for(o=s;0!==o--;)if(!Object.prototype.hasOwnProperty.call(n,i[o]))return!1;for(o=s;0!==o--;){var r=i[o];if(!e(t[r],n[r]))return!1}return!0}return t!==t&&n!==n},W=A(V),N="__googleMapsScriptId";!function(e){e[e.INITIALIZED=0]="INITIALIZED",e[e.LOADING=1]="LOADING",e[e.SUCCESS=2]="SUCCESS",e[e.FAILURE=3]="FAILURE"}(Z||(Z={}));class H{constructor(e){var{apiKey:t,authReferrerPolicy:n,channel:s,client:o,id:i=N,language:r,libraries:a=[],mapIds:l,nonce:u,region:p,retries:c=3,url:d="https://maps.googleapis.com/maps/api/js",version:h}=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=i||N,this.language=r,this.libraries=a,this.mapIds=l,this.nonce=u,this.region=p,this.retries=c,this.url=d,this.version=h,H.instance){if(!W(this.options,H.instance.options))throw new Error("Loader must not be called again with different options. ".concat(JSON.stringify(this.options)," !== ").concat(JSON.stringify(H.instance.options)));return H.instance}H.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?Z.FAILURE:this.done?Z.SUCCESS:this.loading?Z.LOADING:Z.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",i="google",r="importLibrary",a="__ib__",l=document,u=window,p=(u=u[i]||(u[i]={})).maps||(u.maps={}),c=new Set,d=new URLSearchParams,h=()=>t||(t=new Promise(((r,u)=>z(this,0,void 0,(function*(){var h;for(s in yield n=l.createElement("script"),n.id=this.id,d.set("libraries",[...c]+""),e)d.set(s.replace(/[A-Z]/g,(e=>"_"+e[0].toLowerCase())),e[s]);d.set("callback",i+".maps."+a),n.src=this.url+"?"+d,p[a]=r,n.onerror=()=>t=u(Error(o+" could not load.")),n.nonce=this.nonce||(null===(h=l.querySelector("script[nonce]"))||void 0===h?void 0:h.nonce)||"",l.head.append(n)})))));p[r]?console.warn(o+" only loads once. Ignoring:",e):p[r]=function(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),s=1;sp[r](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 F=["maps"];function G(e){var{id:t=j.id,version:n=j.version,nonce:s,googleMapsApiKey:o,language:i,region:a,libraries:l=F,preventGoogleFontsLoading:u,mapIds:p,authReferrerPolicy:c}=e,d=(0,r.useRef)(!1),[h,g]=(0,r.useState)(!1),[m,v]=(0,r.useState)(void 0);(0,r.useEffect)((function(){return d.current=!0,()=>{d.current=!1}}),[]);var f=(0,r.useMemo)((()=>new H({id:t,apiKey:o,version:n,libraries:l,language:i||"en",region:a||"US",mapIds:p||[],nonce:s||"",authReferrerPolicy:c||"origin"})),[t,o,n,l,i,a,p,s,c]);(0,r.useEffect)((function(){h||f.load().then((()=>{d.current&&g(!0)})).catch((e=>{v(e)}))}),[]),(0,r.useEffect)((()=>{x&&u&&O()}),[u]);var y=(0,r.useRef)();return(0,r.useEffect)((()=>{y.current&&l!==y.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"),y.current=l}),[l]),{isLoaded:h,loadError:m}}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{null!==i&&i.setMap(o)}),[o]),(0,r.useEffect)((()=>{t&&null!==i&&i.setOptions(t)}),[i,t]),(0,r.useEffect)((()=>{var e=new google.maps.TrafficLayer(Y(Y({},t),{},{map:o}));return a(e),n&&n(e),()=>{null!==i&&(s&&s(i),i.setMap(null))}}),[]),null}));class X extends r.PureComponent{constructor(){super(...arguments),p(this,"state",{trafficLayer:null}),p(this,"setTrafficLayerCallback",(()=>{null!==this.state.trafficLayer&&this.props.onLoad&&this.props.onLoad(this.state.trafficLayer)})),p(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}}p(X,"contextType",h);(0,r.memo)((function(e){var{onLoad:t,onUnmount:n}=e,s=(0,r.useContext)(h),[o,i]=(0,r.useState)(null);return(0,r.useEffect)((()=>{null!==o&&o.setMap(s)}),[s]),(0,r.useEffect)((()=>{var e=new google.maps.BicyclingLayer;return i(e),e.setMap(s),t&&t(e),()=>{null!==e&&(n&&n(e),e.setMap(null))}}),[]),null}));class $ extends r.PureComponent{constructor(){super(...arguments),p(this,"state",{bicyclingLayer:null}),p(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}}p($,"contextType",h);(0,r.memo)((function(e){var{onLoad:t,onUnmount:n}=e,s=(0,r.useContext)(h),[o,i]=(0,r.useState)(null);return(0,r.useEffect)((()=>{null!==o&&o.setMap(s)}),[s]),(0,r.useEffect)((()=>{var e=new google.maps.TransitLayer;return i(e),e.setMap(s),t&&t(e),()=>{null!==o&&(n&&n(o),o.setMap(null))}}),[]),null}));class Q extends r.PureComponent{constructor(){super(...arguments),p(this,"state",{transitLayer:null}),p(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 ee(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 te(e){for(var t=1;t{null!==m&&m.setMap(g)}),[g]),(0,r.useEffect)((()=>{t&&null!==m&&m.setOptions(t)}),[m,t]),(0,r.useEffect)((()=>{null!==m&&m.setDrawingMode(null!==n&&void 0!==n?n:null)}),[m,n]),(0,r.useEffect)((()=>{m&&s&&(null!==f&&google.maps.event.removeListener(f),y(google.maps.event.addListener(m,"circlecomplete",s)))}),[m,s]),(0,r.useEffect)((()=>{m&&o&&(null!==b&&google.maps.event.removeListener(b),L(google.maps.event.addListener(m,"markercomplete",o)))}),[m,o]),(0,r.useEffect)((()=>{m&&i&&(null!==C&&google.maps.event.removeListener(C),E(google.maps.event.addListener(m,"overlaycomplete",i)))}),[m,i]),(0,r.useEffect)((()=>{m&&a&&(null!==w&&google.maps.event.removeListener(w),M(google.maps.event.addListener(m,"polygoncomplete",a)))}),[m,a]),(0,r.useEffect)((()=>{m&&l&&(null!==x&&google.maps.event.removeListener(x),k(google.maps.event.addListener(m,"polylinecomplete",l)))}),[m,l]),(0,r.useEffect)((()=>{m&&u&&(null!==P&&google.maps.event.removeListener(P),O(google.maps.event.addListener(m,"rectanglecomplete",u)))}),[m,u]),(0,r.useEffect)((()=>{d(!!google.maps.drawing,"Did you include prop libraries={['drawing']} in the URL? %s",google.maps.drawing);var e=new google.maps.drawing.DrawingManager(te(te({},t),{},{map:g}));return n&&e.setDrawingMode(n),s&&y(google.maps.event.addListener(e,"circlecomplete",s)),o&&L(google.maps.event.addListener(e,"markercomplete",o)),i&&E(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&&O(google.maps.event.addListener(e,"rectanglecomplete",u)),v(e),p&&p(e),()=>{null!==m&&(f&&google.maps.event.removeListener(f),b&&google.maps.event.removeListener(b),C&&google.maps.event.removeListener(C),w&&google.maps.event.removeListener(w),x&&google.maps.event.removeListener(x),P&&google.maps.event.removeListener(P),c&&c(m),m.setMap(null))}}),[]),null}));class oe extends r.PureComponent{constructor(e){super(e),p(this,"registeredEvents",[]),p(this,"state",{drawingManager:null}),p(this,"setDrawingManagerCallback",(()=>{null!==this.state.drawingManager&&this.props.onLoad&&this.props.onLoad(this.state.drawingManager)})),d(!!google.maps.drawing,"Did you include prop libraries={['drawing']} in the URL? %s",google.maps.drawing)}componentDidMount(){var e=new google.maps.drawing.DrawingManager(te(te({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:se,eventMap:ne,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:se,eventMap:ne,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 ie(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 re(e){for(var t=1;t{null!==H&&H.setMap(N)}),[N]),(0,r.useEffect)((()=>{"undefined"!==typeof n&&null!==H&&H.setOptions(n)}),[H,n]),(0,r.useEffect)((()=>{"undefined"!==typeof l&&null!==H&&H.setDraggable(l)}),[H,l]),(0,r.useEffect)((()=>{t&&null!==H&&H.setPosition(t)}),[H,t]),(0,r.useEffect)((()=>{"undefined"!==typeof u&&null!==H&&H.setVisible(u)}),[H,u]),(0,r.useEffect)((()=>{null===H||void 0===H||H.setAnimation(p)}),[H,p]),(0,r.useEffect)((()=>{H&&void 0!==c&&H.setClickable(c)}),[H,c]),(0,r.useEffect)((()=>{H&&void 0!==d&&H.setCursor(d)}),[H,d]),(0,r.useEffect)((()=>{H&&void 0!==g&&H.setIcon(g)}),[H,g]),(0,r.useEffect)((()=>{H&&void 0!==m&&H.setLabel(m)}),[H,m]),(0,r.useEffect)((()=>{H&&void 0!==v&&H.setOpacity(v)}),[H,v]),(0,r.useEffect)((()=>{H&&void 0!==f&&H.setShape(f)}),[H,f]),(0,r.useEffect)((()=>{H&&void 0!==y&&H.setTitle(y)}),[H,y]),(0,r.useEffect)((()=>{H&&void 0!==b&&H.setZIndex(b)}),[H,b]),(0,r.useEffect)((()=>{H&&C&&(null!==G&&google.maps.event.removeListener(G),K(google.maps.event.addListener(H,"dblclick",C)))}),[C]),(0,r.useEffect)((()=>{H&&w&&(null!==Y&&google.maps.event.removeListener(Y),q(google.maps.event.addListener(H,"dragend",w)))}),[w]),(0,r.useEffect)((()=>{H&&M&&(null!==J&&google.maps.event.removeListener(J),X(google.maps.event.addListener(H,"dragstart",M)))}),[M]),(0,r.useEffect)((()=>{H&&O&&(null!==$&&google.maps.event.removeListener($),Q(google.maps.event.addListener(H,"mousedown",O)))}),[O]),(0,r.useEffect)((()=>{H&&x&&(null!==ee&&google.maps.event.removeListener(ee),te(google.maps.event.addListener(H,"mouseout",x)))}),[x]),(0,r.useEffect)((()=>{H&&k&&(null!==ne&&google.maps.event.removeListener(ne),se(google.maps.event.addListener(H,"mouseover",k)))}),[k]),(0,r.useEffect)((()=>{H&&P&&(null!==oe&&google.maps.event.removeListener(oe),ie(google.maps.event.addListener(H,"mouseup",P)))}),[P]),(0,r.useEffect)((()=>{H&&S&&(null!==ae&&google.maps.event.removeListener(ae),le(google.maps.event.addListener(H,"rightclick",S)))}),[S]),(0,r.useEffect)((()=>{H&&L&&(null!==pe&&google.maps.event.removeListener(pe),ce(google.maps.event.addListener(H,"click",L)))}),[L]),(0,r.useEffect)((()=>{H&&E&&(null!==de&&google.maps.event.removeListener(de),he(google.maps.event.addListener(H,"drag",E)))}),[E]),(0,r.useEffect)((()=>{H&&D&&(null!==ge&&google.maps.event.removeListener(ge),me(google.maps.event.addListener(H,"clickable_changed",D)))}),[D]),(0,r.useEffect)((()=>{H&&I&&(null!==ve&&google.maps.event.removeListener(ve),fe(google.maps.event.addListener(H,"cursor_changed",I)))}),[I]),(0,r.useEffect)((()=>{H&&j&&(null!==ye&&google.maps.event.removeListener(ye),be(google.maps.event.addListener(H,"animation_changed",j)))}),[j]),(0,r.useEffect)((()=>{H&&B&&(null!==Le&&google.maps.event.removeListener(Le),Ce(google.maps.event.addListener(H,"draggable_changed",B)))}),[B]),(0,r.useEffect)((()=>{H&&_&&(null!==Ee&&google.maps.event.removeListener(Ee),we(google.maps.event.addListener(H,"flat_changed",_)))}),[_]),(0,r.useEffect)((()=>{H&&R&&(null!==Me&&google.maps.event.removeListener(Me),xe(google.maps.event.addListener(H,"icon_changed",R)))}),[R]),(0,r.useEffect)((()=>{H&&T&&(null!==ke&&google.maps.event.removeListener(ke),Pe(google.maps.event.addListener(H,"position_changed",T)))}),[T]),(0,r.useEffect)((()=>{H&&U&&(null!==Oe&&google.maps.event.removeListener(Oe),Se(google.maps.event.addListener(H,"shape_changed",U)))}),[U]),(0,r.useEffect)((()=>{H&&z&&(null!==De&&google.maps.event.removeListener(De),Ie(google.maps.event.addListener(H,"title_changed",z)))}),[z]),(0,r.useEffect)((()=>{H&&A&&(null!==je&&google.maps.event.removeListener(je),Be(google.maps.event.addListener(H,"visible_changed",A)))}),[A]),(0,r.useEffect)((()=>{H&&Z&&(null!==_e&&google.maps.event.removeListener(_e),Re(google.maps.event.addListener(H,"zindex_changed",Z)))}),[Z]),(0,r.useEffect)((()=>{var e=re(re(re({},n||ue),s?ue:{map:N}),{},{position:t}),i=new google.maps.Marker(e);return s?s.addMarker(i,!!o):i.setMap(N),t&&i.setPosition(t),"undefined"!==typeof u&&i.setVisible(u),"undefined"!==typeof l&&i.setDraggable(l),"undefined"!==typeof c&&i.setClickable(c),"string"===typeof d&&i.setCursor(d),g&&i.setIcon(g),"undefined"!==typeof m&&i.setLabel(m),"undefined"!==typeof v&&i.setOpacity(v),f&&i.setShape(f),"string"===typeof y&&i.setTitle(y),"number"===typeof b&&i.setZIndex(b),C&&K(google.maps.event.addListener(i,"dblclick",C)),w&&q(google.maps.event.addListener(i,"dragend",w)),M&&X(google.maps.event.addListener(i,"dragstart",M)),O&&Q(google.maps.event.addListener(i,"mousedown",O)),x&&te(google.maps.event.addListener(i,"mouseout",x)),k&&se(google.maps.event.addListener(i,"mouseover",k)),P&&ie(google.maps.event.addListener(i,"mouseup",P)),S&&le(google.maps.event.addListener(i,"rightclick",S)),L&&ce(google.maps.event.addListener(i,"click",L)),E&&he(google.maps.event.addListener(i,"drag",E)),D&&me(google.maps.event.addListener(i,"clickable_changed",D)),I&&fe(google.maps.event.addListener(i,"cursor_changed",I)),j&&be(google.maps.event.addListener(i,"animation_changed",j)),B&&Ce(google.maps.event.addListener(i,"draggable_changed",B)),_&&we(google.maps.event.addListener(i,"flat_changed",_)),R&&xe(google.maps.event.addListener(i,"icon_changed",R)),T&&Pe(google.maps.event.addListener(i,"position_changed",T)),U&&Se(google.maps.event.addListener(i,"shape_changed",U)),z&&Ie(google.maps.event.addListener(i,"title_changed",z)),A&&Be(google.maps.event.addListener(i,"visible_changed",A)),Z&&Re(google.maps.event.addListener(i,"zindex_changed",Z)),F(i),V&&V(i),()=>{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!==ae&&google.maps.event.removeListener(ae),null!==pe&&google.maps.event.removeListener(pe),null!==ge&&google.maps.event.removeListener(ge),null!==ve&&google.maps.event.removeListener(ve),null!==ye&&google.maps.event.removeListener(ye),null!==Le&&google.maps.event.removeListener(Le),null!==Ee&&google.maps.event.removeListener(Ee),null!==Me&&google.maps.event.removeListener(Me),null!==ke&&google.maps.event.removeListener(ke),null!==De&&google.maps.event.removeListener(De),null!==je&&google.maps.event.removeListener(je),null!==_e&&google.maps.event.removeListener(_e),W&&W(i),s?s.removeMarker(i,!!o):i&&i.setMap(null)}}),[]);var Te=(0,r.useMemo)((()=>a?r.Children.map(a,(e=>{if(!(0,r.isValidElement)(e))return e;var t=e;return(0,r.cloneElement)(t,{anchor:H})})):null),[a,H]);return(0,i.jsx)(i.Fragment,{children:Te})||null}));class pe extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[])}componentDidMount(){var e=this;return w((function*(){var t=re(re(re({},e.props.options||ue),e.props.clusterer?ue:{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:le,eventMap:ae,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:le,eventMap:ae,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?r.Children.map(this.props.children,(e=>{if(!(0,r.isValidElement)(e))return e;var t=e;return(0,r.cloneElement)(t,{anchor:this.marker})})):null)||null}}p(pe,"contextType",h);var ce=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,i;if(this.div&&this.center){var r=null===this.sums||"undefined"===typeof 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=r,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 d=document.createElement("div");d.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)&&(d.innerText="".concat(null===(s=this.sums)||void 0===s?void 0:s.text)),(null===(o=this.sums)||void 0===o?void 0:o.html)&&(d.innerHTML="".concat(null===(i=this.sums)||void 0===i?void 0:i.html)),this.div.innerHTML="",this.div.appendChild(c),this.div.appendChild(d),this.div.title=r,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}(),de=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 ce(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();ti)e.getMap()!==this.map&&e.setMap(this.map);else if(on||t0))for(var e=0;e3?new google.maps.LatLngBounds(null===s||void 0===s?void 0:s.getSouthWest(),null===s||void 0===s?void 0:s.getNorthEast()):new google.maps.LatLngBounds(new google.maps.LatLng(85.02070771743472,-178.48388434375),new google.maps.LatLng(-85.08136444384544,178.00048865625)),i=this.getExtendedBounds(o),r=Math.min(e+this.batchSize,this.markers.length),a=e;a{O&&x&&(null!==U&&google.maps.event.removeListener(U),z(google.maps.event.addListener(O,fe.onMouseOut,x)))}),[x]),(0,r.useEffect)((()=>{O&&M&&(null!==A&&google.maps.event.removeListener(A),Z(google.maps.event.addListener(O,fe.onMouseOver,M)))}),[M]),(0,r.useEffect)((()=>{O&&C&&(null!==I&&google.maps.event.removeListener(I),j(google.maps.event.addListener(O,fe.onClick,C)))}),[C]),(0,r.useEffect)((()=>{O&&E&&(null!==B&&google.maps.event.removeListener(B),_(google.maps.event.addListener(O,fe.onClusteringBegin,E)))}),[E]),(0,r.useEffect)((()=>{O&&w&&(null!==R&&google.maps.event.removeListener(R),_(google.maps.event.addListener(O,fe.onClusteringEnd,w)))}),[w]),(0,r.useEffect)((()=>{"undefined"!==typeof s&&null!==O&&ye.averageCenter(O,s)}),[O,s]),(0,r.useEffect)((()=>{"undefined"!==typeof o&&null!==O&&ye.batchSizeIE(O,o)}),[O,o]),(0,r.useEffect)((()=>{"undefined"!==typeof i&&null!==O&&ye.calculator(O,i)}),[O,i]),(0,r.useEffect)((()=>{"undefined"!==typeof a&&null!==O&&ye.clusterClass(O,a)}),[O,a]),(0,r.useEffect)((()=>{"undefined"!==typeof l&&null!==O&&ye.enableRetinaIcons(O,l)}),[O,l]),(0,r.useEffect)((()=>{"undefined"!==typeof u&&null!==O&&ye.gridSize(O,u)}),[O,u]),(0,r.useEffect)((()=>{"undefined"!==typeof c&&null!==O&&ye.ignoreHidden(O,c)}),[O,c]),(0,r.useEffect)((()=>{"undefined"!==typeof d&&null!==O&&ye.imageExtension(O,d)}),[O,d]),(0,r.useEffect)((()=>{"undefined"!==typeof g&&null!==O&&ye.imagePath(O,g)}),[O,g]),(0,r.useEffect)((()=>{"undefined"!==typeof m&&null!==O&&ye.imageSizes(O,m)}),[O,m]),(0,r.useEffect)((()=>{"undefined"!==typeof v&&null!==O&&ye.maxZoom(O,v)}),[O,v]),(0,r.useEffect)((()=>{"undefined"!==typeof f&&null!==O&&ye.minimumClusterSize(O,f)}),[O,f]),(0,r.useEffect)((()=>{"undefined"!==typeof y&&null!==O&&ye.styles(O,y)}),[O,y]),(0,r.useEffect)((()=>{"undefined"!==typeof b&&null!==O&&ye.title(O,b)}),[O,b]),(0,r.useEffect)((()=>{"undefined"!==typeof L&&null!==O&&ye.zoomOnClick(O,L)}),[O,L]),(0,r.useEffect)((()=>{if(D){var e=function(e){for(var t=1;t{null!==U&&google.maps.event.removeListener(U),null!==A&&google.maps.event.removeListener(A),null!==I&&google.maps.event.removeListener(I),null!==B&&google.maps.event.removeListener(B),null!==R&&google.maps.event.removeListener(R),P&&P(t)}}}),[]),null!==O&&t(O)||null}));class Le extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{markerClusterer:null}),p(this,"setClustererCallback",(()=>{null!==this.state.markerClusterer&&this.props.onLoad&&this.props.onLoad(this.state.markerClusterer)}))}componentDidMount(){if(this.context){var e=new me(this.context,[],this.props.options);this.registeredEvents=y({updaterMap:ye,eventMap:fe,prevProps:{},nextProps:this.props,instance:e}),this.setState((()=>({markerClusterer:e})),this.setClustererCallback)}}componentDidUpdate(e){this.state.markerClusterer&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:ye,eventMap:fe,prevProps:e,nextProps:this.props,instance:this.state.markerClusterer}))}componentWillUnmount(){null!==this.state.markerClusterer&&(this.props.onUnmount&&this.props.onUnmount(this.state.markerClusterer),f(this.registeredEvents),this.state.markerClusterer.setMap(null))}render(){return null!==this.state.markerClusterer?this.props.children(this.state.markerClusterer):null}}function Ce(e){e.cancelBubble=!0,e.stopPropagation&&e.stopPropagation()}p(Le,"contextType",h);var Ee=function(){function e(t){void 0===t&&(t={}),this.getCloseClickHandler=this.getCloseClickHandler.bind(this),this.closeClickHandler=this.closeClickHandler.bind(this),this.createInfoBoxDiv=this.createInfoBoxDiv.bind(this),this.addClickHandler=this.addClickHandler.bind(this),this.getCloseBoxImg=this.getCloseBoxImg.bind(this),this.getBoxWidths=this.getBoxWidths.bind(this),this.setBoxStyle=this.setBoxStyle.bind(this),this.setPosition=this.setPosition.bind(this),this.getPosition=this.getPosition.bind(this),this.setOptions=this.setOptions.bind(this),this.setContent=this.setContent.bind(this),this.setVisible=this.setVisible.bind(this),this.getContent=this.getContent.bind(this),this.getVisible=this.getVisible.bind(this),this.setZIndex=this.setZIndex.bind(this),this.getZIndex=this.getZIndex.bind(this),this.onRemove=this.onRemove.bind(this),this.panBox=this.panBox.bind(this),this.extend=this.extend.bind(this),this.close=this.close.bind(this),this.draw=this.draw.bind(this),this.show=this.show.bind(this),this.hide=this.hide.bind(this),this.open=this.open.bind(this),this.extend(e,google.maps.OverlayView),this.content=t.content||"",this.disableAutoPan=t.disableAutoPan||!1,this.maxWidth=t.maxWidth||0,this.pixelOffset=t.pixelOffset||new google.maps.Size(0,0),this.position=t.position||new google.maps.LatLng(0,0),this.zIndex=t.zIndex||null,this.boxClass=t.boxClass||"infoBox",this.boxStyle=t.boxStyle||{},this.closeBoxMargin=t.closeBoxMargin||"2px",this.closeBoxURL=t.closeBoxURL||"http://www.google.com/intl/en_us/mapfiles/close.gif",""===t.closeBoxURL&&(this.closeBoxURL=""),this.infoBoxClearance=t.infoBoxClearance||new google.maps.Size(1,1),"undefined"===typeof t.visible&&("undefined"===typeof t.isHidden?t.visible=!0:t.visible=!t.isHidden),this.isHidden=!t.visible,this.alignBottom=t.alignBottom||!1,this.pane=t.pane||"floatPane",this.enableEventPropagation=t.enableEventPropagation||!1,this.div=null,this.closeListener=null,this.moveListener=null,this.mapListener=null,this.contextListener=null,this.eventListeners=null,this.fixedWidthSet=null}return e.prototype.createInfoBoxDiv=function(){var e=this;if(!this.div){this.div=document.createElement("div"),this.setBoxStyle(),"string"===typeof this.content?this.div.innerHTML=this.getCloseBoxImg()+this.content:(this.div.innerHTML=this.getCloseBoxImg(),this.div.appendChild(this.content));var t=this.getPanes();if(null!==t&&t[this.pane].appendChild(this.div),this.addClickHandler(),this.div.style.width)this.fixedWidthSet=!0;else if(0!==this.maxWidth&&this.div.offsetWidth>this.maxWidth)this.div.style.width=this.maxWidth+"px",this.fixedWidthSet=!0;else{var n=this.getBoxWidths();this.div.style.width=this.div.offsetWidth-n.left-n.right+"px",this.fixedWidthSet=!1}if(this.panBox(this.disableAutoPan),!this.enableEventPropagation){this.eventListeners=[];for(var s=0,o=["mousedown","mouseover","mouseout","mouseup","click","dblclick","touchstart","touchend","touchmove"];s"),e},e.prototype.addClickHandler=function(){this.closeListener=this.div&&this.div.firstChild&&""!==this.closeBoxURL?google.maps.event.addListener(this.div.firstChild,"click",this.getCloseClickHandler()):null},e.prototype.closeClickHandler=function(e){e.cancelBubble=!0,e.stopPropagation&&e.stopPropagation(),google.maps.event.trigger(this,"closeclick"),this.close()},e.prototype.getCloseClickHandler=function(){return this.closeClickHandler},e.prototype.panBox=function(e){if(this.div&&!e){var t=this.getMap();if(t instanceof google.maps.Map){var n=0,s=0,o=t.getBounds();o&&!o.contains(this.position)&&t.setCenter(this.position);var i=t.getDiv(),r=i.offsetWidth,a=i.offsetHeight,l=this.pixelOffset.width,u=this.pixelOffset.height,p=this.div.offsetWidth,c=this.div.offsetHeight,d=this.infoBoxClearance.width,h=this.infoBoxClearance.height,g=this.getProjection().fromLatLngToContainerPixel(this.position);null!==g&&(g.x<-l+d?n=g.x+l-d:g.x+p+l+d>r&&(n=g.x+p+l+d-r),this.alignBottom?g.y<-u+h+c?s=g.y+u-h-c:g.y+u+h>a&&(s=g.y+u+h-a):g.y<-u+h?s=g.y+u-h:g.y+c+u+h>a&&(s=g.y+c+u+h-a)),0===n&&0===s||t.panBy(n,s)}}},e.prototype.setBoxStyle=function(){if(this.div){this.div.className=this.boxClass,this.div.style.cssText="";var e=this.boxStyle;for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&(this.div.style[t]=e[t]);if(this.div.style.webkitTransform="translateZ(0)","undefined"!==typeof this.div.style.opacity&&""!==this.div.style.opacity){var n=parseFloat(this.div.style.opacity||"");this.div.style.msFilter='"progid:DXImageTransform.Microsoft.Alpha(Opacity='+100*n+')"',this.div.style.filter="alpha(opacity="+100*n+")"}this.div.style.position="absolute",this.div.style.visibility="hidden",null!==this.zIndex&&(this.div.style.zIndex=this.zIndex+""),this.div.style.overflow||(this.div.style.overflow="auto")}},e.prototype.getBoxWidths=function(){var e={top:0,bottom:0,left:0,right:0};if(!this.div)return e;if(document.defaultView){var t=this.div.ownerDocument,n=t&&t.defaultView?t.defaultView.getComputedStyle(this.div,""):null;n&&(e.top=parseInt(n.borderTopWidth||"",10)||0,e.bottom=parseInt(n.borderBottomWidth||"",10)||0,e.left=parseInt(n.borderLeftWidth||"",10)||0,e.right=parseInt(n.borderRightWidth||"",10)||0)}else if(document.documentElement.currentStyle){var s=this.div.currentStyle;s&&(e.top=parseInt(s.borderTopWidth||"",10)||0,e.bottom=parseInt(s.borderBottomWidth||"",10)||0,e.left=parseInt(s.borderLeftWidth||"",10)||0,e.right=parseInt(s.borderRightWidth||"",10)||0)}return e},e.prototype.onRemove=function(){this.div&&this.div.parentNode&&(this.div.parentNode.removeChild(this.div),this.div=null)},e.prototype.draw=function(){if(this.createInfoBoxDiv(),this.div){var e=this.getProjection().fromLatLngToDivPixel(this.position);null!==e&&(this.div.style.left=e.x+this.pixelOffset.width+"px",this.alignBottom?this.div.style.bottom=-(e.y+this.pixelOffset.height)+"px":this.div.style.top=e.y+this.pixelOffset.height+"px"),this.isHidden?this.div.style.visibility="hidden":this.div.style.visibility="visible"}},e.prototype.setOptions=function(e){void 0===e&&(e={}),"undefined"!==typeof e.boxClass&&(this.boxClass=e.boxClass,this.setBoxStyle()),"undefined"!==typeof e.boxStyle&&(this.boxStyle=e.boxStyle,this.setBoxStyle()),"undefined"!==typeof e.content&&this.setContent(e.content),"undefined"!==typeof e.disableAutoPan&&(this.disableAutoPan=e.disableAutoPan),"undefined"!==typeof e.maxWidth&&(this.maxWidth=e.maxWidth),"undefined"!==typeof e.pixelOffset&&(this.pixelOffset=e.pixelOffset),"undefined"!==typeof e.alignBottom&&(this.alignBottom=e.alignBottom),"undefined"!==typeof e.position&&this.setPosition(e.position),"undefined"!==typeof e.zIndex&&this.setZIndex(e.zIndex),"undefined"!==typeof e.closeBoxMargin&&(this.closeBoxMargin=e.closeBoxMargin),"undefined"!==typeof e.closeBoxURL&&(this.closeBoxURL=e.closeBoxURL),"undefined"!==typeof e.infoBoxClearance&&(this.infoBoxClearance=e.infoBoxClearance),"undefined"!==typeof e.isHidden&&(this.isHidden=e.isHidden),"undefined"!==typeof e.visible&&(this.isHidden=!e.visible),"undefined"!==typeof e.enableEventPropagation&&(this.enableEventPropagation=e.enableEventPropagation),this.div&&this.draw()},e.prototype.setContent=function(e){this.content=e,this.div&&(this.closeListener&&(google.maps.event.removeListener(this.closeListener),this.closeListener=null),this.fixedWidthSet||(this.div.style.width=""),"string"===typeof e?this.div.innerHTML=this.getCloseBoxImg()+e:(this.div.innerHTML=this.getCloseBoxImg(),this.div.appendChild(e)),this.fixedWidthSet||(this.div.style.width=this.div.offsetWidth+"px","string"===typeof e?this.div.innerHTML=this.getCloseBoxImg()+e:(this.div.innerHTML=this.getCloseBoxImg(),this.div.appendChild(e))),this.addClickHandler()),google.maps.event.trigger(this,"content_changed")},e.prototype.setPosition=function(e){this.position=e,this.div&&this.draw(),google.maps.event.trigger(this,"position_changed")},e.prototype.setVisible=function(e){this.isHidden=!e,this.div&&(this.div.style.visibility=this.isHidden?"hidden":"visible")},e.prototype.setZIndex=function(e){this.zIndex=e,this.div&&(this.div.style.zIndex=e+""),google.maps.event.trigger(this,"zindex_changed")},e.prototype.getContent=function(){return this.content},e.prototype.getPosition=function(){return this.position},e.prototype.getZIndex=function(){return this.zIndex},e.prototype.getVisible=function(){var e=this.getMap();return"undefined"!==typeof e&&null!==e&&!this.isHidden},e.prototype.show=function(){this.isHidden=!1,this.div&&(this.div.style.visibility="visible")},e.prototype.hide=function(){this.isHidden=!0,this.div&&(this.div.style.visibility="hidden")},e.prototype.open=function(e,t){var n=this;t&&(this.position=t.getPosition(),this.moveListener=google.maps.event.addListener(t,"position_changed",(function(){var e=t.getPosition();n.setPosition(e)})),this.mapListener=google.maps.event.addListener(t,"map_changed",(function(){n.setMap(t.map)}))),this.setMap(e),this.div&&this.panBox()},e.prototype.close=function(){if(this.closeListener&&(google.maps.event.removeListener(this.closeListener),this.closeListener=null),this.eventListeners){for(var e=0,t=this.eventListeners;e{f&&null!==y&&(y.close(),n?y.open(f,n):y.getPosition()&&y.open(f))}),[f,y,n]),(0,r.useEffect)((()=>{s&&null!==y&&y.setOptions(s)}),[y,s]),(0,r.useEffect)((()=>{if(o&&null!==y){var e=o instanceof google.maps.LatLng?o:new google.maps.LatLng(o.lat,o.lng);y.setPosition(e)}}),[o]),(0,r.useEffect)((()=>{"number"===typeof i&&null!==y&&y.setZIndex(i)}),[i]),(0,r.useEffect)((()=>{y&&l&&(null!==L&&google.maps.event.removeListener(L),C(google.maps.event.addListener(y,"closeclick",l)))}),[l]),(0,r.useEffect)((()=>{y&&u&&(null!==E&&google.maps.event.removeListener(E),w(google.maps.event.addListener(y,"domready",u)))}),[u]),(0,r.useEffect)((()=>{y&&p&&(null!==M&&google.maps.event.removeListener(M),x(google.maps.event.addListener(y,"content_changed",p)))}),[p]),(0,r.useEffect)((()=>{y&&c&&(null!==k&&google.maps.event.removeListener(k),P(google.maps.event.addListener(y,"position_changed",c)))}),[c]),(0,r.useEffect)((()=>{y&&g&&(null!==O&&google.maps.event.removeListener(O),S(google.maps.event.addListener(y,"zindex_changed",g)))}),[g]),(0,r.useEffect)((()=>{if(f){var e,t=s||Se,{position:o}=t,i=_(t,we);!o||o instanceof google.maps.LatLng||(e=new google.maps.LatLng(o.lat,o.lng));var r=new Ee(ke(ke({},i),e?{position:e}:{}));D.current=document.createElement("div"),b(r),l&&C(google.maps.event.addListener(r,"closeclick",l)),u&&w(google.maps.event.addListener(r,"domready",u)),p&&x(google.maps.event.addListener(r,"content_changed",p)),c&&P(google.maps.event.addListener(r,"position_changed",c)),g&&S(google.maps.event.addListener(r,"zindex_changed",g)),r.setContent(D.current),n?r.open(f,n):r.getPosition()?r.open(f):d(!1,"You must provide either an anchor or a position prop for ."),m&&m(r)}return()=>{null!==y&&(L&&google.maps.event.removeListener(L),M&&google.maps.event.removeListener(M),E&&google.maps.event.removeListener(E),k&&google.maps.event.removeListener(k),O&&google.maps.event.removeListener(O),v&&v(y),y.close())}}),[]),D.current?(0,a.createPortal)(r.Children.only(t),D.current):null}));class je extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"containerElement",null),p(this,"state",{infoBox:null}),p(this,"open",((e,t)=>{t?null!==this.context&&e.open(this.context,t):e.getPosition()?null!==this.context&&e.open(this.context):d(!1,"You must provide either an anchor or a position prop for .")})),p(this,"setInfoBoxCallback",(()=>{null!==this.state.infoBox&&null!==this.containerElement&&(this.state.infoBox.setContent(this.containerElement),this.open(this.state.infoBox,this.props.anchor),this.props.onLoad&&this.props.onLoad(this.state.infoBox))}))}componentDidMount(){var e,t=this.props.options||{},{position:n}=t,s=_(t,Me);!n||n instanceof google.maps.LatLng||(e=new google.maps.LatLng(n.lat,n.lng));var o=new Ee(ke(ke({},s),e?{position:e}:{}));this.containerElement=document.createElement("div"),this.registeredEvents=y({updaterMap:Oe,eventMap:Pe,prevProps:{},nextProps:this.props,instance:o}),this.setState({infoBox:o},this.setInfoBoxCallback)}componentDidUpdate(e){var{infoBox:t}=this.state;null!==t&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:Oe,eventMap:Pe,prevProps:e,nextProps:this.props,instance:t}))}componentWillUnmount(){var{onUnmount:e}=this.props,{infoBox:t}=this.state;null!==t&&(e&&e(t),f(this.registeredEvents),t.close())}render(){return this.containerElement?(0,a.createPortal)(r.Children.only(this.props.children),this.containerElement):null}}p(je,"contextType",h);var Be=(Ie||(Ie=1,De=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,i;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=(i=Object.keys(t)).length)!==Object.keys(n).length)return!1;for(o=s;0!==o--;)if(!Object.prototype.hasOwnProperty.call(n,i[o]))return!1;for(o=s;0!==o--;){var r=i[o];if(!e(t[r],n[r]))return!1}return!0}return t!==t&&n!==n}),De),_e=c(Be),Re=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array];class Te{static from(e){if(!(e instanceof ArrayBuffer))throw new Error("Data must be an instance of ArrayBuffer.");var[t,n]=new Uint8Array(e,0,2);if(219!==t)throw new Error("Data does not appear to be in a KDBush format.");var s=n>>4;if(1!==s)throw new Error("Got v".concat(s," data when expected v").concat(1,"."));var o=Re[15&n];if(!o)throw new Error("Unrecognized array type.");var[i]=new Uint16Array(e,2,1),[r]=new Uint32Array(e,4,1);return new Te(r,i,o,e)}constructor(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:64,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:Float64Array,s=arguments.length>3?arguments[3]:void 0;if(isNaN(e)||e<0)throw new Error("Unpexpected numItems value: ".concat(e,"."));this.numItems=+e,this.nodeSize=Math.min(Math.max(+t,2),65535),this.ArrayType=n,this.IndexArrayType=e<65536?Uint16Array:Uint32Array;var o=Re.indexOf(this.ArrayType),i=2*e*this.ArrayType.BYTES_PER_ELEMENT,r=e*this.IndexArrayType.BYTES_PER_ELEMENT,a=(8-r%8)%8;if(o<0)throw new Error("Unexpected typed array class: ".concat(n,"."));s&&s instanceof ArrayBuffer?(this.data=s,this.ids=new this.IndexArrayType(this.data,8,e),this.coords=new this.ArrayType(this.data,8+r+a,2*e),this._pos=2*e,this._finished=!0):(this.data=new ArrayBuffer(8+i+r+a),this.ids=new this.IndexArrayType(this.data,8,e),this.coords=new this.ArrayType(this.data,8+r+a,2*e),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,16+o]),new Uint16Array(this.data,2,1)[0]=t,new Uint32Array(this.data,4,1)[0]=e)}add(e,t){var n=this._pos>>1;return this.ids[n]=n,this.coords[this._pos++]=e,this.coords[this._pos++]=t,n}finish(){var e=this._pos>>1;if(e!==this.numItems)throw new Error("Added ".concat(e," items when expected ").concat(this.numItems,"."));return Ue(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(e,t,n,s){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");for(var{ids:o,coords:i,nodeSize:r}=this,a=[0,o.length-1,0],l=[];a.length;){var u=a.pop()||0,p=a.pop()||0,c=a.pop()||0;if(p-c<=r)for(var d=c;d<=p;d++){var h=i[2*d],g=i[2*d+1];h>=e&&h<=n&&g>=t&&g<=s&&l.push(o[d])}else{var m=c+p>>1,v=i[2*m],f=i[2*m+1];v>=e&&v<=n&&f>=t&&f<=s&&l.push(o[m]),(0===u?e<=v:t<=f)&&(a.push(c),a.push(m-1),a.push(1-u)),(0===u?n>=v:s>=f)&&(a.push(m+1),a.push(p),a.push(1-u))}}return l}within(e,t,n){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");for(var{ids:s,coords:o,nodeSize:i}=this,r=[0,s.length-1,0],a=[],l=n*n;r.length;){var u=r.pop()||0,p=r.pop()||0,c=r.pop()||0;if(p-c<=i)for(var d=c;d<=p;d++)Ve(o[2*d],o[2*d+1],e,t)<=l&&a.push(s[d]);else{var h=c+p>>1,g=o[2*h],m=o[2*h+1];Ve(g,m,e,t)<=l&&a.push(s[h]),(0===u?e-n<=g:t-n<=m)&&(r.push(c),r.push(h-1),r.push(1-u)),(0===u?e+n>=g:t+n>=m)&&(r.push(h+1),r.push(p),r.push(1-u))}}return a}}function Ue(e,t,n,s,o,i){if(!(o-s<=n)){var r=s+o>>1;ze(e,t,r,s,o,i),Ue(e,t,n,s,r-1,1-i),Ue(e,t,n,r+1,o,1-i)}}function ze(e,t,n,s,o,i){for(;o>s;){if(o-s>600){var r=o-s+1,a=n-s+1,l=Math.log(r),u=.5*Math.exp(2*l/3),p=.5*Math.sqrt(l*u*(r-u)/r)*(a-r/2<0?-1:1);ze(e,t,n,Math.max(s,Math.floor(n-a*u/r+p)),Math.min(o,Math.floor(n+(r-a)*u/r+p)),i)}var c=t[2*n+i],d=s,h=o;for(Ae(e,t,s,n),t[2*o+i]>c&&Ae(e,t,s,o);dc;)h--}t[2*s+i]===c?Ae(e,t,s,h):Ae(e,t,++h,o),h<=n&&(s=h+1),n<=h&&(o=h-1)}}function Ae(e,t,n,s){Ze(e,n,s),Ze(t,2*n,2*s),Ze(t,2*n+1,2*s+1)}function Ze(e,t,n){var s=e[t];e[t]=e[n],e[n]=s}function Ve(e,t,n,s){var o=e-n,i=t-s;return o*o+i*i}var We,Ne={minZoom:0,maxZoom:16,minPoints:2,radius:40,extent:512,nodeSize:64,log:!1,generateId:!1,reduce:null,map:e=>e},He=Math.fround||(We=new Float32Array(1),e=>(We[0]=+e,We[0]));class Fe{constructor(e){this.options=Object.assign(Object.create(Ne),e),this.trees=new Array(this.options.maxZoom+1),this.stride=this.options.reduce?7:6,this.clusterProps=[]}load(e){var{log:t,minZoom:n,maxZoom:s}=this.options;t&&console.time("total time");var o="prepare ".concat(e.length," points");t&&console.time(o),this.points=e;for(var i=[],r=0;r=n;h--){var g=+Date.now();d=this.trees[h]=this._createTree(this._cluster(d,h)),t&&console.log("z%d: %d clusters in %dms",h,d.numItems,+Date.now()-g)}return t&&console.timeEnd("total time"),this}getClusters(e,t){var n=((e[0]+180)%360+360)%360-180,s=Math.max(-90,Math.min(90,e[1])),o=180===e[2]?180:((e[2]+180)%360+360)%360-180,i=Math.max(-90,Math.min(90,e[3]));if(e[2]-e[0]>=360)n=-180,o=180;else if(n>o){var r=this.getClusters([n,s,180,i],t),a=this.getClusters([-180,s,o,i],t);return r.concat(a)}var l=this.trees[this._limitZoom(t)],u=l.range(Ye(n),qe(i),Ye(o),qe(s)),p=l.data,c=[];for(var d of u){var h=this.stride*d;c.push(p[h+5]>1?Ge(p,h,this.clusterProps):this.points[p[h+3]])}return c}getChildren(e){var t=this._getOriginId(e),n=this._getOriginZoom(e),s="No cluster with the specified id.",o=this.trees[n];if(!o)throw new Error(s);var i=o.data;if(t*this.stride>=i.length)throw new Error(s);var r=this.options.radius/(this.options.extent*Math.pow(2,n-1)),a=i[t*this.stride],l=i[t*this.stride+1],u=o.within(a,l,r),p=[];for(var c of u){var d=c*this.stride;i[d+4]===e&&p.push(i[d+5]>1?Ge(i,d,this.clusterProps):this.points[i[d+3]])}if(0===p.length)throw new Error(s);return p}getLeaves(e,t,n){t=t||10,n=n||0;var s=[];return this._appendLeaves(s,e,t,n,0),s}getTile(e,t,n){var s=this.trees[this._limitZoom(e)],o=Math.pow(2,e),{extent:i,radius:r}=this.options,a=r/i,l=(n-a)/o,u=(n+1+a)/o,p={features:[]};return this._addTileFeatures(s.range((t-a)/o,l,(t+1+a)/o,u),s.data,t,n,o,p),0===t&&this._addTileFeatures(s.range(1-a/o,l,1,u),s.data,o,n,o,p),t===o-1&&this._addTileFeatures(s.range(0,l,a/o,u),s.data,-1,n,o,p),p.features.length?p:null}getClusterExpansionZoom(e){for(var t=this._getOriginZoom(e)-1;t<=this.options.maxZoom;){var n=this.getChildren(e);if(t++,1!==n.length)break;e=n[0].properties.cluster_id}return t}_appendLeaves(e,t,n,s,o){var i=this.getChildren(t);for(var r of i){var a=r.properties;if(a&&a.cluster?o+a.point_count<=s?o+=a.point_count:o=this._appendLeaves(e,a.cluster_id,n,s,o):o1,u=void 0,p=void 0,c=void 0;if(l)u=Ke(t,a,this.clusterProps),p=t[a],c=t[a+1];else{var d=this.points[t[a+3]];u=d.properties;var[h,g]=d.geometry.coordinates;p=Ye(h),c=qe(g)}var m={type:1,geometry:[[Math.round(this.options.extent*(p*o-n)),Math.round(this.options.extent*(c*o-s))]],tags:u},v=void 0;void 0!==(v=l||this.options.generateId?t[a+3]:this.points[t[a+3]].id)&&(m.id=v),i.features.push(m)}}_limitZoom(e){return Math.max(this.options.minZoom,Math.min(Math.floor(+e),this.options.maxZoom+1))}_cluster(e,t){for(var{radius:n,extent:s,reduce:o,minPoints:i}=this.options,r=n/(s*Math.pow(2,t)),a=e.data,l=[],u=this.stride,p=0;pt&&(m+=a[f+5])}if(m>g&&m>=i){var y=c*g,b=d*g,L=void 0,C=-1,E=(p/u<<5)+(t+1)+this.points.length;for(var w of h){var M=w*u;if(!(a[M+2]<=t)){a[M+2]=t;var x=a[M+5];y+=a[M]*x,b+=a[M+1]*x,a[M+4]=E,o&&(L||(L=this._map(a,p,!0),C=this.clusterProps.length,this.clusterProps.push(L)),o(L,this._map(a,M)))}}a[p+4]=E,l.push(y/m,b/m,1/0,E,-1,m),o&&l.push(C)}else{for(var k=0;k1)for(var P of h){var O=P*u;if(!(a[O+2]<=t)){a[O+2]=t;for(var S=0;S>5}_getOriginZoom(e){return(e-this.points.length)%32}_map(e,t,n){if(e[t+5]>1){var s=this.clusterProps[e[t+6]];return n?Object.assign({},s):s}var o=this.points[e[t+3]].properties,i=this.options.map(o);return n&&i===o?Object.assign({},i):i}}function Ge(e,t,n){return{type:"Feature",id:e[t+3],properties:Ke(e,t,n),geometry:{type:"Point",coordinates:[(s=e[t],360*(s-.5)),Je(e[t+1])]}};var s}function Ke(e,t,n){var s=e[t+5],o=s>=1e4?"".concat(Math.round(s/1e3),"k"):s>=1e3?"".concat(Math.round(s/100)/10,"k"):s,i=e[t+6],r=-1===i?{}:Object.assign({},n[i]);return Object.assign(r,{cluster:!0,cluster_id:e[t+3],point_count:s,point_count_abbreviated:o})}function Ye(e){return e/360+.5}function qe(e){var t=Math.sin(e*Math.PI/180),n=.5-.25*Math.log((1+t)/(1-t))/Math.PI;return n<0?0:n>1?1:n}function Je(e){var t=(180-360*e)*Math.PI/180;return 360*Math.atan(Math.exp(t))/Math.PI-90}function Xe(e,t){var n={};for(var s in e)Object.prototype.hasOwnProperty.call(e,s)&&t.indexOf(s)<0&&(n[s]=e[s]);if(null!=e&&"function"===typeof Object.getOwnPropertySymbols){var o=0;for(s=Object.getOwnPropertySymbols(e);o$e.getVisible(e))).length}push(e){this.markers.push(e)}delete(){this.marker&&($e.setMap(this.marker,null),this.marker=void 0),this.markers.length=0}}class et{constructor(e){var{maxZoom:t=16}=e;this.maxZoom=t}noop(e){var{markers:t}=e;return nt(t)}}var tt,nt=e=>e.map((e=>new Qe({position:$e.getPosition(e),markers:[e]})));class st extends et{constructor(e){var{maxZoom:t,radius:n=60}=e,s=Xe(e,["maxZoom","radius"]);super({maxZoom:t}),this.state={zoom:-1},this.superCluster=new Fe(Object.assign({maxZoom:this.maxZoom,radius:n},s))}calculate(e){var t=!1,n={zoom:e.map.getZoom()};if(!_e(e.markers,this.markers)){t=!0,this.markers=[...e.markers];var s=this.markers.map((e=>{var t=$e.getPosition(e);return{type:"Feature",geometry:{type:"Point",coordinates:[t.lng(),t.lat()]},properties:{marker:e}}}));this.superCluster.load(s)}return t||(this.state.zoom<=this.maxZoom||n.zoom<=this.maxZoom)&&(t=!_e(this.state,n)),this.state=n,t&&(this.clusters=this.cluster(e)),{clusters:this.clusters,changed:t}}cluster(e){var{map:t}=e;return this.superCluster.getClusters([-180,-90,180,90],Math.round(t.getZoom())).map((e=>this.transformCluster(e)))}transformCluster(e){var{geometry:{coordinates:[t,n]},properties:s}=e;if(s.cluster)return new Qe({markers:this.superCluster.getLeaves(s.cluster_id,1/0).map((e=>e.properties.marker)),position:{lat:n,lng:t}});var o=s.marker;return new Qe({markers:[o],position:$e.getPosition(o)})}}class ot{constructor(e,t){this.markers={sum:e.length};var n=t.map((e=>e.count)),s=n.reduce(((e,t)=>e+t),0);this.clusters={count:t.length,markers:{mean:s/t.length,sum:s,min:Math.min(...n),max:Math.max(...n)}}}}class it{render(e,t,n){var{count:s,position:o}=e,i=s>Math.max(10,t.clusters.markers.mean)?"#ff0000":"#0000ff",r='"),a="Cluster of ".concat(s," markers"),l=Number(google.maps.Marker.MAX_ZINDEX)+s;if($e.isAdvancedMarkerAvailable(n)){var u=(new DOMParser).parseFromString(r,"image/svg+xml").documentElement;u.setAttribute("transform","translate(0 25)");var p={map:n,position:o,zIndex:l,title:a,content:u};return new google.maps.marker.AdvancedMarkerElement(p)}var c={position:o,zIndex:l,title:a,icon:{url:"data:image/svg+xml;base64,".concat(btoa(r)),anchor:new google.maps.Point(25,25)}};return new google.maps.Marker(c)}}class rt{constructor(){!function(e,t){for(var n in t.prototype)e.prototype[n]=t.prototype[n]}(rt,google.maps.OverlayView)}}!function(e){e.CLUSTERING_BEGIN="clusteringbegin",e.CLUSTERING_END="clusteringend",e.CLUSTER_CLICK="click"}(tt||(tt={}));var at=(e,t,n)=>{n.fitBounds(t.bounds)};class lt extends rt{constructor(e){var{map:t,markers:n=[],algorithmOptions:s={},algorithm:o=new st(s),renderer:i=new it,onClusterClick:r=at}=e;super(),this.markers=[...n],this.clusters=[],this.algorithm=o,this.renderer=i,this.onClusterClick=r,t&&this.setMap(t)}addMarker(e,t){this.markers.includes(e)||(this.markers.push(e),t||this.render())}addMarkers(e,t){e.forEach((e=>{this.addMarker(e,!0)})),t||this.render()}removeMarker(e,t){var n=this.markers.indexOf(e);return-1!==n&&($e.setMap(e,null),this.markers.splice(n,1),t||this.render(),!0)}removeMarkers(e,t){var n=!1;return e.forEach((e=>{n=this.removeMarker(e,!0)||n})),n&&!t&&this.render(),n}clearMarkers(e){this.markers.length=0,e||this.render()}render(){var e=this.getMap();if(e instanceof google.maps.Map&&e.getProjection()){google.maps.event.trigger(this,tt.CLUSTERING_BEGIN,this);var{clusters:t,changed:n}=this.algorithm.calculate({markers:this.markers,map:e,mapCanvasProjection:this.getProjection()});if(n||void 0==n){var s=new Set;for(var o of t)1==o.markers.length&&s.add(o.markers[0]);var i=[];for(var r of this.clusters)null!=r.marker&&(1==r.markers.length?s.has(r.marker)||$e.setMap(r.marker,null):i.push(r.marker));this.clusters=t,this.renderClusters(),requestAnimationFrame((()=>i.forEach((e=>$e.setMap(e,null)))))}google.maps.event.trigger(this,tt.CLUSTERING_END,this)}}onAdd(){this.idleListener=this.getMap().addListener("idle",this.render.bind(this)),this.render()}onRemove(){google.maps.event.removeListener(this.idleListener),this.reset()}reset(){this.markers.forEach((e=>$e.setMap(e,null))),this.clusters.forEach((e=>e.delete())),this.clusters=[]}renderClusters(){var e=new ot(this.markers,this.clusters),t=this.getMap();this.clusters.forEach((n=>{1===n.markers.length?n.marker=n.markers[0]:(n.marker=this.renderer.render(n,e,t),n.markers.forEach((e=>$e.setMap(e,null))),this.onClusterClick&&n.marker.addListener("click",(e=>{google.maps.event.trigger(this,tt.CLUSTER_CLICK,n),this.onClusterClick(e,n,t)}))),$e.setMap(n.marker,t)}))}}function ut(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 pt(e){for(var t=1;t{if(t&&null===n){var o=new lt(pt(pt({},e),{},{map:t}));s(o)}}),[t]),n}(0,r.memo)((function(e){var{children:t,options:n}=e,s=ct(n);return null!==s?t(s):null}));var dt={onCloseClick:"closeclick",onContentChanged:"content_changed",onDomReady:"domready",onPositionChanged:"position_changed",onZindexChanged:"zindex_changed"},ht={options(e,t){e.setOptions(t)},position(e,t){e.setPosition(t)},zIndex(e,t){e.setZIndex(t)}};(0,r.memo)((function(e){var{children:t,anchor:n,options:s,position:o,zIndex:i,onCloseClick:l,onDomReady:u,onContentChanged:p,onPositionChanged:c,onZindexChanged:g,onLoad:m,onUnmount:v}=e,f=(0,r.useContext)(h),[y,b]=(0,r.useState)(null),[L,C]=(0,r.useState)(null),[E,w]=(0,r.useState)(null),[M,x]=(0,r.useState)(null),[k,P]=(0,r.useState)(null),[O,S]=(0,r.useState)(null),D=(0,r.useRef)(null);return(0,r.useEffect)((()=>{null!==y&&(y.close(),n?y.open(f,n):y.getPosition()&&y.open(f))}),[f,y,n]),(0,r.useEffect)((()=>{s&&null!==y&&y.setOptions(s)}),[y,s]),(0,r.useEffect)((()=>{o&&null!==y&&y.setPosition(o)}),[o]),(0,r.useEffect)((()=>{"number"===typeof i&&null!==y&&y.setZIndex(i)}),[i]),(0,r.useEffect)((()=>{y&&l&&(null!==L&&google.maps.event.removeListener(L),C(google.maps.event.addListener(y,"closeclick",l)))}),[l]),(0,r.useEffect)((()=>{y&&u&&(null!==E&&google.maps.event.removeListener(E),w(google.maps.event.addListener(y,"domready",u)))}),[u]),(0,r.useEffect)((()=>{y&&p&&(null!==M&&google.maps.event.removeListener(M),x(google.maps.event.addListener(y,"content_changed",p)))}),[p]),(0,r.useEffect)((()=>{y&&c&&(null!==k&&google.maps.event.removeListener(k),P(google.maps.event.addListener(y,"position_changed",c)))}),[c]),(0,r.useEffect)((()=>{y&&g&&(null!==O&&google.maps.event.removeListener(O),S(google.maps.event.addListener(y,"zindex_changed",g)))}),[g]),(0,r.useEffect)((()=>{var e=new google.maps.InfoWindow(s);return b(e),D.current=document.createElement("div"),l&&C(google.maps.event.addListener(e,"closeclick",l)),u&&w(google.maps.event.addListener(e,"domready",u)),p&&x(google.maps.event.addListener(e,"content_changed",p)),c&&P(google.maps.event.addListener(e,"position_changed",c)),g&&S(google.maps.event.addListener(e,"zindex_changed",g)),e.setContent(D.current),o&&e.setPosition(o),i&&e.setZIndex(i),n?e.open(f,n):e.getPosition()?e.open(f):d(!1,"You must provide either an anchor (typically render it inside a ) or a position props for ."),m&&m(e),()=>{L&&google.maps.event.removeListener(L),M&&google.maps.event.removeListener(M),E&&google.maps.event.removeListener(E),k&&google.maps.event.removeListener(k),O&&google.maps.event.removeListener(O),v&&v(e),e.close()}}),[]),D.current?(0,a.createPortal)(r.Children.only(t),D.current):null}));class gt extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"containerElement",null),p(this,"state",{infoWindow:null}),p(this,"open",((e,t)=>{t?e.open(this.context,t):e.getPosition()?e.open(this.context):d(!1,"You must provide either an anchor (typically render it inside a ) or a position props for .")})),p(this,"setInfoWindowCallback",(()=>{null!==this.state.infoWindow&&null!==this.containerElement&&(this.state.infoWindow.setContent(this.containerElement),this.open(this.state.infoWindow,this.props.anchor),this.props.onLoad&&this.props.onLoad(this.state.infoWindow))}))}componentDidMount(){var e=new google.maps.InfoWindow(this.props.options);this.containerElement=document.createElement("div"),this.registeredEvents=y({updaterMap:ht,eventMap:dt,prevProps:{},nextProps:this.props,instance:e}),this.setState((()=>({infoWindow:e})),this.setInfoWindowCallback)}componentDidUpdate(e){null!==this.state.infoWindow&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:ht,eventMap:dt,prevProps:e,nextProps:this.props,instance:this.state.infoWindow}))}componentWillUnmount(){null!==this.state.infoWindow&&(f(this.registeredEvents),this.props.onUnmount&&this.props.onUnmount(this.state.infoWindow),this.state.infoWindow.close())}render(){return this.containerElement?(0,a.createPortal)(r.Children.only(this.props.children),this.containerElement):null}}function mt(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 vt(e){for(var t=1;t{null!==E&&E.setMap(C)}),[C]),(0,r.useEffect)((()=>{"undefined"!==typeof t&&null!==E&&E.setOptions(t)}),[E,t]),(0,r.useEffect)((()=>{"undefined"!==typeof n&&null!==E&&E.setDraggable(n)}),[E,n]),(0,r.useEffect)((()=>{"undefined"!==typeof s&&null!==E&&E.setEditable(s)}),[E,s]),(0,r.useEffect)((()=>{"undefined"!==typeof o&&null!==E&&E.setVisible(o)}),[E,o]),(0,r.useEffect)((()=>{"undefined"!==typeof i&&null!==E&&E.setPath(i)}),[E,i]),(0,r.useEffect)((()=>{E&&a&&(null!==M&&google.maps.event.removeListener(M),x(google.maps.event.addListener(E,"dblclick",a)))}),[a]),(0,r.useEffect)((()=>{E&&l&&(null!==k&&google.maps.event.removeListener(k),P(google.maps.event.addListener(E,"dragend",l)))}),[l]),(0,r.useEffect)((()=>{E&&u&&(null!==O&&google.maps.event.removeListener(O),S(google.maps.event.addListener(E,"dragstart",u)))}),[u]),(0,r.useEffect)((()=>{E&&p&&(null!==D&&google.maps.event.removeListener(D),I(google.maps.event.addListener(E,"mousedown",p)))}),[p]),(0,r.useEffect)((()=>{E&&c&&(null!==j&&google.maps.event.removeListener(j),B(google.maps.event.addListener(E,"mousemove",c)))}),[c]),(0,r.useEffect)((()=>{E&&d&&(null!==_&&google.maps.event.removeListener(_),R(google.maps.event.addListener(E,"mouseout",d)))}),[d]),(0,r.useEffect)((()=>{E&&g&&(null!==T&&google.maps.event.removeListener(T),U(google.maps.event.addListener(E,"mouseover",g)))}),[g]),(0,r.useEffect)((()=>{E&&m&&(null!==z&&google.maps.event.removeListener(z),A(google.maps.event.addListener(E,"mouseup",m)))}),[m]),(0,r.useEffect)((()=>{E&&v&&(null!==Z&&google.maps.event.removeListener(Z),V(google.maps.event.addListener(E,"rightclick",v)))}),[v]),(0,r.useEffect)((()=>{E&&f&&(null!==W&&google.maps.event.removeListener(W),N(google.maps.event.addListener(E,"click",f)))}),[f]),(0,r.useEffect)((()=>{E&&y&&(null!==H&&google.maps.event.removeListener(H),F(google.maps.event.addListener(E,"drag",y)))}),[y]),(0,r.useEffect)((()=>{var e=new google.maps.Polyline(vt(vt({},t||bt),{},{map:C}));return i&&e.setPath(i),"undefined"!==typeof o&&e.setVisible(o),"undefined"!==typeof s&&e.setEditable(s),"undefined"!==typeof n&&e.setDraggable(n),a&&x(google.maps.event.addListener(e,"dblclick",a)),l&&P(google.maps.event.addListener(e,"dragend",l)),u&&S(google.maps.event.addListener(e,"dragstart",u)),p&&I(google.maps.event.addListener(e,"mousedown",p)),c&&B(google.maps.event.addListener(e,"mousemove",c)),d&&R(google.maps.event.addListener(e,"mouseout",d)),g&&U(google.maps.event.addListener(e,"mouseover",g)),m&&A(google.maps.event.addListener(e,"mouseup",m)),v&&V(google.maps.event.addListener(e,"rightclick",v)),f&&N(google.maps.event.addListener(e,"click",f)),y&&F(google.maps.event.addListener(e,"drag",y)),w(e),b&&b(e),()=>{null!==M&&google.maps.event.removeListener(M),null!==k&&google.maps.event.removeListener(k),null!==O&&google.maps.event.removeListener(O),null!==D&&google.maps.event.removeListener(D),null!==j&&google.maps.event.removeListener(j),null!==_&&google.maps.event.removeListener(_),null!==T&&google.maps.event.removeListener(T),null!==z&&google.maps.event.removeListener(z),null!==Z&&google.maps.event.removeListener(Z),null!==W&&google.maps.event.removeListener(W),L&&L(e),e.setMap(null)}}),[]),null}));class Lt extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{polyline:null}),p(this,"setPolylineCallback",(()=>{null!==this.state.polyline&&this.props.onLoad&&this.props.onLoad(this.state.polyline)}))}componentDidMount(){var e=new google.maps.Polyline(vt(vt({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:yt,eventMap:ft,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{polyline:e}}),this.setPolylineCallback)}componentDidUpdate(e){null!==this.state.polyline&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:yt,eventMap:ft,prevProps:e,nextProps:this.props,instance:this.state.polyline}))}componentWillUnmount(){null!==this.state.polyline&&(this.props.onUnmount&&this.props.onUnmount(this.state.polyline),f(this.registeredEvents),this.state.polyline.setMap(null))}render(){return null}}function Ct(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 Et(e){for(var t=1;t{null!==M&&M.setMap(w)}),[w]),(0,r.useEffect)((()=>{"undefined"!==typeof t&&null!==M&&M.setOptions(t)}),[M,t]),(0,r.useEffect)((()=>{"undefined"!==typeof n&&null!==M&&M.setDraggable(n)}),[M,n]),(0,r.useEffect)((()=>{"undefined"!==typeof s&&null!==M&&M.setEditable(s)}),[M,s]),(0,r.useEffect)((()=>{"undefined"!==typeof o&&null!==M&&M.setVisible(o)}),[M,o]),(0,r.useEffect)((()=>{"undefined"!==typeof i&&null!==M&&M.setPath(i)}),[M,i]),(0,r.useEffect)((()=>{"undefined"!==typeof a&&null!==M&&M.setPaths(a)}),[M,a]),(0,r.useEffect)((()=>{M&&"function"===typeof l&&(null!==k&&google.maps.event.removeListener(k),P(google.maps.event.addListener(M,"dblclick",l)))}),[l]),(0,r.useEffect)((()=>{M&&(google.maps.event.addListener(M.getPath(),"insert_at",(()=>{null===E||void 0===E||E(M)})),google.maps.event.addListener(M.getPath(),"set_at",(()=>{null===E||void 0===E||E(M)})),google.maps.event.addListener(M.getPath(),"remove_at",(()=>{null===E||void 0===E||E(M)})))}),[M,E]),(0,r.useEffect)((()=>{M&&"function"===typeof u&&(null!==O&&google.maps.event.removeListener(O),S(google.maps.event.addListener(M,"dragend",u)))}),[u]),(0,r.useEffect)((()=>{M&&"function"===typeof p&&(null!==D&&google.maps.event.removeListener(D),I(google.maps.event.addListener(M,"dragstart",p)))}),[p]),(0,r.useEffect)((()=>{M&&"function"===typeof c&&(null!==j&&google.maps.event.removeListener(j),B(google.maps.event.addListener(M,"mousedown",c)))}),[c]),(0,r.useEffect)((()=>{M&&"function"===typeof d&&(null!==_&&google.maps.event.removeListener(_),R(google.maps.event.addListener(M,"mousemove",d)))}),[d]),(0,r.useEffect)((()=>{M&&"function"===typeof g&&(null!==T&&google.maps.event.removeListener(T),U(google.maps.event.addListener(M,"mouseout",g)))}),[g]),(0,r.useEffect)((()=>{M&&"function"===typeof m&&(null!==z&&google.maps.event.removeListener(z),A(google.maps.event.addListener(M,"mouseover",m)))}),[m]),(0,r.useEffect)((()=>{M&&"function"===typeof v&&(null!==Z&&google.maps.event.removeListener(Z),V(google.maps.event.addListener(M,"mouseup",v)))}),[v]),(0,r.useEffect)((()=>{M&&"function"===typeof f&&(null!==W&&google.maps.event.removeListener(W),N(google.maps.event.addListener(M,"rightclick",f)))}),[f]),(0,r.useEffect)((()=>{M&&"function"===typeof y&&(null!==H&&google.maps.event.removeListener(H),F(google.maps.event.addListener(M,"click",y)))}),[y]),(0,r.useEffect)((()=>{M&&"function"===typeof b&&(null!==G&&google.maps.event.removeListener(G),K(google.maps.event.addListener(M,"drag",b)))}),[b]),(0,r.useEffect)((()=>{var e=new google.maps.Polygon(Et(Et({},t),{},{map:w}));return i&&e.setPath(i),a&&e.setPaths(a),"undefined"!==typeof o&&e.setVisible(o),"undefined"!==typeof s&&e.setEditable(s),"undefined"!==typeof n&&e.setDraggable(n),l&&P(google.maps.event.addListener(e,"dblclick",l)),u&&S(google.maps.event.addListener(e,"dragend",u)),p&&I(google.maps.event.addListener(e,"dragstart",p)),c&&B(google.maps.event.addListener(e,"mousedown",c)),d&&R(google.maps.event.addListener(e,"mousemove",d)),g&&U(google.maps.event.addListener(e,"mouseout",g)),m&&A(google.maps.event.addListener(e,"mouseover",m)),v&&V(google.maps.event.addListener(e,"mouseup",v)),f&&N(google.maps.event.addListener(e,"rightclick",f)),y&&F(google.maps.event.addListener(e,"click",y)),b&&K(google.maps.event.addListener(e,"drag",b)),x(e),L&&L(e),()=>{null!==k&&google.maps.event.removeListener(k),null!==O&&google.maps.event.removeListener(O),null!==D&&google.maps.event.removeListener(D),null!==j&&google.maps.event.removeListener(j),null!==_&&google.maps.event.removeListener(_),null!==T&&google.maps.event.removeListener(T),null!==z&&google.maps.event.removeListener(z),null!==Z&&google.maps.event.removeListener(Z),null!==W&&google.maps.event.removeListener(W),null!==H&&google.maps.event.removeListener(H),C&&C(e),e.setMap(null)}}),[]),null}));class xt extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[])}componentDidMount(){var e=this.props.options||{};this.polygon=new google.maps.Polygon(e),this.polygon.setMap(this.context),this.registeredEvents=y({updaterMap:Mt,eventMap:wt,prevProps:{},nextProps:this.props,instance:this.polygon}),this.props.onLoad&&this.props.onLoad(this.polygon)}componentDidUpdate(e){this.polygon&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:Mt,eventMap:wt,prevProps:e,nextProps:this.props,instance:this.polygon}))}componentWillUnmount(){this.polygon&&(this.props.onUnmount&&this.props.onUnmount(this.polygon),f(this.registeredEvents),this.polygon&&this.polygon.setMap(null))}render(){return null}}function kt(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 Pt(e){for(var t=1;t{null!==w&&w.setMap(E)}),[E]),(0,r.useEffect)((()=>{"undefined"!==typeof t&&null!==w&&w.setOptions(t)}),[w,t]),(0,r.useEffect)((()=>{"undefined"!==typeof s&&null!==w&&w.setDraggable(s)}),[w,s]),(0,r.useEffect)((()=>{"undefined"!==typeof o&&null!==w&&w.setEditable(o)}),[w,o]),(0,r.useEffect)((()=>{"undefined"!==typeof i&&null!==w&&w.setVisible(i)}),[w,i]),(0,r.useEffect)((()=>{"undefined"!==typeof n&&null!==w&&w.setBounds(n)}),[w,n]),(0,r.useEffect)((()=>{w&&a&&(null!==x&&google.maps.event.removeListener(x),k(google.maps.event.addListener(w,"dblclick",a)))}),[a]),(0,r.useEffect)((()=>{w&&l&&(null!==P&&google.maps.event.removeListener(P),O(google.maps.event.addListener(w,"dragend",l)))}),[l]),(0,r.useEffect)((()=>{w&&u&&(null!==S&&google.maps.event.removeListener(S),D(google.maps.event.addListener(w,"dragstart",u)))}),[u]),(0,r.useEffect)((()=>{w&&p&&(null!==I&&google.maps.event.removeListener(I),j(google.maps.event.addListener(w,"mousedown",p)))}),[p]),(0,r.useEffect)((()=>{w&&c&&(null!==B&&google.maps.event.removeListener(B),_(google.maps.event.addListener(w,"mousemove",c)))}),[c]),(0,r.useEffect)((()=>{w&&d&&(null!==R&&google.maps.event.removeListener(R),T(google.maps.event.addListener(w,"mouseout",d)))}),[d]),(0,r.useEffect)((()=>{w&&g&&(null!==U&&google.maps.event.removeListener(U),z(google.maps.event.addListener(w,"mouseover",g)))}),[g]),(0,r.useEffect)((()=>{w&&m&&(null!==A&&google.maps.event.removeListener(A),Z(google.maps.event.addListener(w,"mouseup",m)))}),[m]),(0,r.useEffect)((()=>{w&&v&&(null!==V&&google.maps.event.removeListener(V),W(google.maps.event.addListener(w,"rightclick",v)))}),[v]),(0,r.useEffect)((()=>{w&&f&&(null!==N&&google.maps.event.removeListener(N),H(google.maps.event.addListener(w,"click",f)))}),[f]),(0,r.useEffect)((()=>{w&&y&&(null!==F&&google.maps.event.removeListener(F),G(google.maps.event.addListener(w,"drag",y)))}),[y]),(0,r.useEffect)((()=>{w&&b&&(null!==K&&google.maps.event.removeListener(K),Y(google.maps.event.addListener(w,"bounds_changed",b)))}),[b]),(0,r.useEffect)((()=>{var e=new google.maps.Rectangle(Pt(Pt({},t),{},{map:E}));return"undefined"!==typeof i&&e.setVisible(i),"undefined"!==typeof o&&e.setEditable(o),"undefined"!==typeof s&&e.setDraggable(s),"undefined"!==typeof n&&e.setBounds(n),a&&k(google.maps.event.addListener(e,"dblclick",a)),l&&O(google.maps.event.addListener(e,"dragend",l)),u&&D(google.maps.event.addListener(e,"dragstart",u)),p&&j(google.maps.event.addListener(e,"mousedown",p)),c&&_(google.maps.event.addListener(e,"mousemove",c)),d&&T(google.maps.event.addListener(e,"mouseout",d)),g&&z(google.maps.event.addListener(e,"mouseover",g)),m&&Z(google.maps.event.addListener(e,"mouseup",m)),v&&W(google.maps.event.addListener(e,"rightclick",v)),f&&H(google.maps.event.addListener(e,"click",f)),y&&G(google.maps.event.addListener(e,"drag",y)),b&&Y(google.maps.event.addListener(e,"bounds_changed",b)),M(e),L&&L(e),()=>{null!==x&&google.maps.event.removeListener(x),null!==P&&google.maps.event.removeListener(P),null!==S&&google.maps.event.removeListener(S),null!==I&&google.maps.event.removeListener(I),null!==B&&google.maps.event.removeListener(B),null!==R&&google.maps.event.removeListener(R),null!==U&&google.maps.event.removeListener(U),null!==A&&google.maps.event.removeListener(A),null!==V&&google.maps.event.removeListener(V),null!==N&&google.maps.event.removeListener(N),null!==F&&google.maps.event.removeListener(F),null!==K&&google.maps.event.removeListener(K),C&&C(e),e.setMap(null)}}),[]),null}));class Dt extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{rectangle:null}),p(this,"setRectangleCallback",(()=>{null!==this.state.rectangle&&this.props.onLoad&&this.props.onLoad(this.state.rectangle)}))}componentDidMount(){var e=new google.maps.Rectangle(Pt(Pt({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:St,eventMap:Ot,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{rectangle:e}}),this.setRectangleCallback)}componentDidUpdate(e){null!==this.state.rectangle&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:St,eventMap:Ot,prevProps:e,nextProps:this.props,instance:this.state.rectangle}))}componentWillUnmount(){null!==this.state.rectangle&&(this.props.onUnmount&&this.props.onUnmount(this.state.rectangle),f(this.registeredEvents),this.state.rectangle.setMap(null))}render(){return null}}function It(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 jt(e){for(var t=1;t{null!==x&&x.setMap(M)}),[M]),(0,r.useEffect)((()=>{"undefined"!==typeof t&&null!==x&&x.setOptions(t)}),[x,t]),(0,r.useEffect)((()=>{"undefined"!==typeof o&&null!==x&&x.setDraggable(o)}),[x,o]),(0,r.useEffect)((()=>{"undefined"!==typeof i&&null!==x&&x.setEditable(i)}),[x,i]),(0,r.useEffect)((()=>{"undefined"!==typeof a&&null!==x&&x.setVisible(a)}),[x,a]),(0,r.useEffect)((()=>{"number"===typeof s&&null!==x&&x.setRadius(s)}),[x,s]),(0,r.useEffect)((()=>{"undefined"!==typeof n&&null!==x&&x.setCenter(n)}),[x,n]),(0,r.useEffect)((()=>{x&&l&&(null!==P&&google.maps.event.removeListener(P),O(google.maps.event.addListener(x,"dblclick",l)))}),[l]),(0,r.useEffect)((()=>{x&&u&&(null!==S&&google.maps.event.removeListener(S),D(google.maps.event.addListener(x,"dragend",u)))}),[u]),(0,r.useEffect)((()=>{x&&p&&(null!==I&&google.maps.event.removeListener(I),j(google.maps.event.addListener(x,"dragstart",p)))}),[p]),(0,r.useEffect)((()=>{x&&c&&(null!==B&&google.maps.event.removeListener(B),_(google.maps.event.addListener(x,"mousedown",c)))}),[c]),(0,r.useEffect)((()=>{x&&d&&(null!==R&&google.maps.event.removeListener(R),T(google.maps.event.addListener(x,"mousemove",d)))}),[d]),(0,r.useEffect)((()=>{x&&g&&(null!==U&&google.maps.event.removeListener(U),z(google.maps.event.addListener(x,"mouseout",g)))}),[g]),(0,r.useEffect)((()=>{x&&m&&(null!==A&&google.maps.event.removeListener(A),Z(google.maps.event.addListener(x,"mouseover",m)))}),[m]),(0,r.useEffect)((()=>{x&&v&&(null!==V&&google.maps.event.removeListener(V),W(google.maps.event.addListener(x,"mouseup",v)))}),[v]),(0,r.useEffect)((()=>{x&&f&&(null!==N&&google.maps.event.removeListener(N),H(google.maps.event.addListener(x,"rightclick",f)))}),[f]),(0,r.useEffect)((()=>{x&&y&&(null!==F&&google.maps.event.removeListener(F),G(google.maps.event.addListener(x,"click",y)))}),[y]),(0,r.useEffect)((()=>{x&&b&&(null!==K&&google.maps.event.removeListener(K),Y(google.maps.event.addListener(x,"drag",b)))}),[b]),(0,r.useEffect)((()=>{x&&L&&(null!==q&&google.maps.event.removeListener(q),J(google.maps.event.addListener(x,"center_changed",L)))}),[y]),(0,r.useEffect)((()=>{x&&C&&(null!==X&&google.maps.event.removeListener(X),$(google.maps.event.addListener(x,"radius_changed",C)))}),[C]),(0,r.useEffect)((()=>{var e=new google.maps.Circle(jt(jt({},t||Rt),{},{map:M}));return"number"===typeof s&&e.setRadius(s),"undefined"!==typeof n&&e.setCenter(n),"number"===typeof s&&e.setRadius(s),"undefined"!==typeof a&&e.setVisible(a),"undefined"!==typeof i&&e.setEditable(i),"undefined"!==typeof o&&e.setDraggable(o),l&&O(google.maps.event.addListener(e,"dblclick",l)),u&&D(google.maps.event.addListener(e,"dragend",u)),p&&j(google.maps.event.addListener(e,"dragstart",p)),c&&_(google.maps.event.addListener(e,"mousedown",c)),d&&T(google.maps.event.addListener(e,"mousemove",d)),g&&z(google.maps.event.addListener(e,"mouseout",g)),m&&Z(google.maps.event.addListener(e,"mouseover",m)),v&&W(google.maps.event.addListener(e,"mouseup",v)),f&&H(google.maps.event.addListener(e,"rightclick",f)),y&&G(google.maps.event.addListener(e,"click",y)),b&&Y(google.maps.event.addListener(e,"drag",b)),L&&J(google.maps.event.addListener(e,"center_changed",L)),C&&$(google.maps.event.addListener(e,"radius_changed",C)),k(e),E&&E(e),()=>{null!==P&&google.maps.event.removeListener(P),null!==S&&google.maps.event.removeListener(S),null!==I&&google.maps.event.removeListener(I),null!==B&&google.maps.event.removeListener(B),null!==R&&google.maps.event.removeListener(R),null!==U&&google.maps.event.removeListener(U),null!==A&&google.maps.event.removeListener(A),null!==V&&google.maps.event.removeListener(V),null!==N&&google.maps.event.removeListener(N),null!==F&&google.maps.event.removeListener(F),null!==q&&google.maps.event.removeListener(q),null!==X&&google.maps.event.removeListener(X),w&&w(e),e.setMap(null)}}),[]),null}));class Tt extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{circle:null}),p(this,"setCircleCallback",(()=>{null!==this.state.circle&&this.props.onLoad&&this.props.onLoad(this.state.circle)}))}componentDidMount(){var e=new google.maps.Circle(jt(jt({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:_t,eventMap:Bt,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{circle:e}}),this.setCircleCallback)}componentDidUpdate(e){null!==this.state.circle&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:_t,eventMap:Bt,prevProps:e,nextProps:this.props,instance:this.state.circle}))}componentWillUnmount(){var e;null!==this.state.circle&&(this.props.onUnmount&&this.props.onUnmount(this.state.circle),f(this.registeredEvents),null===(e=this.state.circle)||void 0===e||e.setMap(null))}render(){return null}}function Ut(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 zt(e){for(var t=1;t{null!==L&&L.setMap(b)}),[b]),(0,r.useEffect)((()=>{L&&s&&(null!==E&&google.maps.event.removeListener(E),w(google.maps.event.addListener(L,"dblclick",s)))}),[s]),(0,r.useEffect)((()=>{L&&o&&(null!==M&&google.maps.event.removeListener(M),x(google.maps.event.addListener(L,"mousedown",o)))}),[o]),(0,r.useEffect)((()=>{L&&i&&(null!==k&&google.maps.event.removeListener(k),P(google.maps.event.addListener(L,"mousemove",i)))}),[i]),(0,r.useEffect)((()=>{L&&a&&(null!==O&&google.maps.event.removeListener(O),S(google.maps.event.addListener(L,"mouseout",a)))}),[a]),(0,r.useEffect)((()=>{L&&l&&(null!==D&&google.maps.event.removeListener(D),I(google.maps.event.addListener(L,"mouseover",l)))}),[l]),(0,r.useEffect)((()=>{L&&u&&(null!==j&&google.maps.event.removeListener(j),B(google.maps.event.addListener(L,"mouseup",u)))}),[u]),(0,r.useEffect)((()=>{L&&p&&(null!==_&&google.maps.event.removeListener(_),R(google.maps.event.addListener(L,"rightclick",p)))}),[p]),(0,r.useEffect)((()=>{L&&n&&(null!==T&&google.maps.event.removeListener(T),U(google.maps.event.addListener(L,"click",n)))}),[n]),(0,r.useEffect)((()=>{L&&c&&(null!==z&&google.maps.event.removeListener(z),A(google.maps.event.addListener(L,"addfeature",c)))}),[c]),(0,r.useEffect)((()=>{L&&d&&(null!==Z&&google.maps.event.removeListener(Z),V(google.maps.event.addListener(L,"removefeature",d)))}),[d]),(0,r.useEffect)((()=>{L&&g&&(null!==W&&google.maps.event.removeListener(W),N(google.maps.event.addListener(L,"removeproperty",g)))}),[g]),(0,r.useEffect)((()=>{L&&m&&(null!==H&&google.maps.event.removeListener(H),F(google.maps.event.addListener(L,"setgeometry",m)))}),[m]),(0,r.useEffect)((()=>{L&&v&&(null!==G&&google.maps.event.removeListener(G),K(google.maps.event.addListener(L,"setproperty",v)))}),[v]),(0,r.useEffect)((()=>{if(null!==b){var e=new google.maps.Data(zt(zt({},t),{},{map:b}));s&&w(google.maps.event.addListener(e,"dblclick",s)),o&&x(google.maps.event.addListener(e,"mousedown",o)),i&&P(google.maps.event.addListener(e,"mousemove",i)),a&&S(google.maps.event.addListener(e,"mouseout",a)),l&&I(google.maps.event.addListener(e,"mouseover",l)),u&&B(google.maps.event.addListener(e,"mouseup",u)),p&&R(google.maps.event.addListener(e,"rightclick",p)),n&&U(google.maps.event.addListener(e,"click",n)),c&&A(google.maps.event.addListener(e,"addfeature",c)),d&&V(google.maps.event.addListener(e,"removefeature",d)),g&&N(google.maps.event.addListener(e,"removeproperty",g)),m&&F(google.maps.event.addListener(e,"setgeometry",m)),v&&K(google.maps.event.addListener(e,"setproperty",v)),C(e),f&&f(e)}return()=>{L&&(null!==E&&google.maps.event.removeListener(E),null!==M&&google.maps.event.removeListener(M),null!==k&&google.maps.event.removeListener(k),null!==O&&google.maps.event.removeListener(O),null!==D&&google.maps.event.removeListener(D),null!==j&&google.maps.event.removeListener(j),null!==_&&google.maps.event.removeListener(_),null!==T&&google.maps.event.removeListener(T),null!==z&&google.maps.event.removeListener(z),null!==Z&&google.maps.event.removeListener(Z),null!==W&&google.maps.event.removeListener(W),null!==H&&google.maps.event.removeListener(H),null!==G&&google.maps.event.removeListener(G),y&&y(L),L.setMap(null))}}),[]),null}));class Vt extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{data:null}),p(this,"setDataCallback",(()=>{null!==this.state.data&&this.props.onLoad&&this.props.onLoad(this.state.data)}))}componentDidMount(){if(null!==this.context){var e=new google.maps.Data(zt(zt({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:Zt,eventMap:At,prevProps:{},nextProps:this.props,instance:e}),this.setState((()=>({data:e})),this.setDataCallback)}}componentDidUpdate(e){null!==this.state.data&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:Zt,eventMap:At,prevProps:e,nextProps:this.props,instance:this.state.data}))}componentWillUnmount(){null!==this.state.data&&(this.props.onUnmount&&this.props.onUnmount(this.state.data),f(this.registeredEvents),this.state.data&&this.state.data.setMap(null))}render(){return null}}function Wt(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 Nt(e){for(var t=1;t{null!==this.state.kmlLayer&&this.props.onLoad&&this.props.onLoad(this.state.kmlLayer)}))}componentDidMount(){var e=new google.maps.KmlLayer(Nt(Nt({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:Ft,eventMap:Ht,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{kmlLayer:e}}),this.setKmlLayerCallback)}componentDidUpdate(e){null!==this.state.kmlLayer&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:Ft,eventMap:Ht,prevProps:e,nextProps:this.props,instance:this.state.kmlLayer}))}componentWillUnmount(){null!==this.state.kmlLayer&&(this.props.onUnmount&&this.props.onUnmount(this.state.kmlLayer),f(this.registeredEvents),this.state.kmlLayer.setMap(null))}render(){return null}}function Kt(e,t){return"function"===typeof t?t(e.offsetWidth,e.offsetHeight):{x:0,y:0}}function Yt(e,t){return new t(e.lat,e.lng)}function qt(e,t){return new t(new google.maps.LatLng(e.ne.lat,e.ne.lng),new google.maps.LatLng(e.sw.lat,e.sw.lng))}function Jt(e,t,n,s){return void 0!==n?function(e,t,n){var s=e&&e.fromLatLngToDivPixel(n.getNorthEast()),o=e&&e.fromLatLngToDivPixel(n.getSouthWest());return s&&o?{left:"".concat(o.x+t.x,"px"),top:"".concat(s.y+t.y,"px"),width:"".concat(s.x-o.x-t.x,"px"),height:"".concat(o.y-s.y-t.y,"px")}:{left:"-9999px",top:"-9999px"}}(e,t,(o=n,i=google.maps.LatLngBounds,r=qt,o instanceof i?o:r(o,i))):function(e,t,n){var s=e&&e.fromLatLngToDivPixel(n);if(s){var{x:o,y:i}=s;return{left:"".concat(o+t.x,"px"),top:"".concat(i+t.y,"px")}}return{left:"-9999px",top:"-9999px"}}(e,t,function(e,t,n){return e instanceof t?e:n(e,t)}(s,google.maps.LatLng,Yt));var o,i,r}function Xt(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 $t(e,t,n,s,o){class i extends google.maps.OverlayView{constructor(e,t,n,s){super(),this.container=e,this.pane=t,this.position=n,this.bounds=s}onAdd(){var e,t=null===(e=this.getPanes())||void 0===e?void 0:e[this.pane];null===t||void 0===t||t.appendChild(this.container)}draw(){var e=this.getProjection(),t=function(e){for(var t=1;t{var e=document.createElement("div");return e.style.position="absolute",e}),[]),g=(0,r.useMemo)((()=>$t(d,s,t,n,u)),[d,s,t,n]);return(0,r.useEffect)((()=>(null===i||void 0===i||i(g),null===g||void 0===g||g.setMap(c),()=>{null===l||void 0===l||l(g),null===g||void 0===g||g.setMap(null)})),[c,g]),(0,r.useEffect)((()=>{d.style.zIndex="".concat(o)}),[o,d]),a.createPortal(p,d)}));class nn extends r.PureComponent{constructor(e){super(e),p(this,"state",{paneEl:null,containerStyle:{position:"absolute"}}),p(this,"updatePane",(()=>{var e=this.props.mapPaneName,t=this.overlayView.getPanes();d(!!e,"OverlayView requires props.mapPaneName but got %s",e),t?this.setState({paneEl:t[e]}):this.setState({paneEl:null})})),p(this,"onAdd",(()=>{var e,t;this.updatePane(),null===(e=(t=this.props).onLoad)||void 0===e||e.call(t,this.overlayView)})),p(this,"onPositionElement",(()=>{var e,t,n,s,o,i,r=this.overlayView.getProjection(),a=function(e){for(var t=1;t{this.onPositionElement()})),p(this,"onRemove",(()=>{var e,t;this.setState((()=>({paneEl:null}))),null===(e=(t=this.props).onUnmount)||void 0===e||e.call(t,this.overlayView)})),this.containerRef=(0,r.createRef)();var t=new google.maps.OverlayView;t.onAdd=this.onAdd,t.draw=this.draw,t.onRemove=this.onRemove,this.overlayView=t}componentDidMount(){this.overlayView.setMap(this.context)}componentDidUpdate(e){var t=en(e.position),n=en(this.props.position),s=tn(e.bounds),o=tn(this.props.bounds);t===n&&s===o||this.overlayView.draw(),e.mapPaneName!==this.props.mapPaneName&&this.updatePane()}componentWillUnmount(){this.overlayView.setMap(null)}render(){var e=this.state.paneEl;return e?a.createPortal((0,i.jsx)("div",{ref:this.containerRef,style:this.state.containerStyle,children:r.Children.only(this.props.children)}),e):null}}function sn(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 on(e){for(var t=1;tnew google.maps.GroundOverlay(t,a,s)),[]);return(0,r.useEffect)((()=>{null!==l&&l.setMap(i)}),[i]),(0,r.useEffect)((()=>{"undefined"!==typeof t&&null!==l&&(l.set("url",t),l.setMap(i))}),[l,t]),(0,r.useEffect)((()=>{"undefined"!==typeof o&&null!==l&&l.setOpacity(o?1:0)}),[l,o]),(0,r.useEffect)((()=>{var e=new google.maps.LatLngBounds(new google.maps.LatLng(n.south,n.west),new google.maps.LatLng(n.north,n.east));"undefined"!==typeof n&&null!==l&&(l.set("bounds",e),l.setMap(i))}),[l,n]),null}));class ln extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{groundOverlay:null}),p(this,"setGroundOverlayCallback",(()=>{null!==this.state.groundOverlay&&this.props.onLoad&&this.props.onLoad(this.state.groundOverlay)}))}componentDidMount(){d(!!this.props.url||!!this.props.bounds,"For GroundOverlay, url and bounds are passed in to constructor and are immutable after instantiated. This is the behavior of Google Maps JavaScript API v3 ( See https://developers.google.com/maps/documentation/javascript/reference#GroundOverlay) Hence, use the corresponding two props provided by `react-google-maps-api`, url and bounds. In some cases, you'll need the GroundOverlay component to reflect the changes of url and bounds. You can leverage the React's key property to remount the component. Typically, just `key={url}` would serve your need. See https://github.com/tomchentw/react-google-maps/issues/655");var e=new google.maps.GroundOverlay(this.props.url,this.props.bounds,on(on({},this.props.options),{},{map:this.context}));this.registeredEvents=y({updaterMap:an,eventMap:rn,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{groundOverlay:e}}),this.setGroundOverlayCallback)}componentDidUpdate(e){null!==this.state.groundOverlay&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:an,eventMap:rn,prevProps:e,nextProps:this.props,instance:this.state.groundOverlay}))}componentWillUnmount(){this.state.groundOverlay&&(this.props.onUnmount&&this.props.onUnmount(this.state.groundOverlay),this.state.groundOverlay.setMap(null))}render(){return null}}function un(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 pn(e){for(var t=1;t{google.maps.visualization||d(!!google.maps.visualization,'Did you include prop libraries={["visualization"]} in useJsApiScript? %s',google.maps.visualization)}),[]),(0,r.useEffect)((()=>{d(!!t,"data property is required in HeatmapLayer %s",t)}),[t]),(0,r.useEffect)((()=>{null!==a&&a.setMap(i)}),[i]),(0,r.useEffect)((()=>{o&&null!==a&&a.setOptions(o)}),[a,o]),(0,r.useEffect)((()=>{var e=new google.maps.visualization.HeatmapLayer(pn(pn({},o),{},{data:t,map:i}));return l(e),n&&n(e),()=>{null!==a&&(s&&s(a),a.setMap(null))}}),[]),null}));class hn extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{heatmapLayer:null}),p(this,"setHeatmapLayerCallback",(()=>{null!==this.state.heatmapLayer&&this.props.onLoad&&this.props.onLoad(this.state.heatmapLayer)}))}componentDidMount(){d(!!google.maps.visualization,'Did you include prop libraries={["visualization"]} to ? %s',google.maps.visualization),d(!!this.props.data,"data property is required in HeatmapLayer %s",this.props.data);var e=new google.maps.visualization.HeatmapLayer(pn(pn({},this.props.options),{},{data:this.props.data,map:this.context}));this.registeredEvents=y({updaterMap:dn,eventMap:cn,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{heatmapLayer:e}}),this.setHeatmapLayerCallback)}componentDidUpdate(e){f(this.registeredEvents),this.registeredEvents=y({updaterMap:dn,eventMap:cn,prevProps:e,nextProps:this.props,instance:this.state.heatmapLayer})}componentWillUnmount(){null!==this.state.heatmapLayer&&(this.props.onUnmount&&this.props.onUnmount(this.state.heatmapLayer),f(this.registeredEvents),this.state.heatmapLayer.setMap(null))}render(){return null}}p(hn,"contextType",h);var gn={onCloseClick:"closeclick",onPanoChanged:"pano_changed",onPositionChanged:"position_changed",onPovChanged:"pov_changed",onResize:"resize",onStatusChanged:"status_changed",onVisibleChanged:"visible_changed",onZoomChanged:"zoom_changed"},mn={register(e,t,n){e.registerPanoProvider(t,n)},links(e,t){e.setLinks(t)},motionTracking(e,t){e.setMotionTracking(t)},options(e,t){e.setOptions(t)},pano(e,t){e.setPano(t)},position(e,t){e.setPosition(t)},pov(e,t){e.setPov(t)},visible(e,t){e.setVisible(t)},zoom(e,t){e.setZoom(t)}};class vn extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{streetViewPanorama:null}),p(this,"setStreetViewPanoramaCallback",(()=>{null!==this.state.streetViewPanorama&&this.props.onLoad&&this.props.onLoad(this.state.streetViewPanorama)}))}componentDidMount(){var e,t,n=null!==(e=null===(t=this.context)||void 0===t?void 0:t.getStreetView())&&void 0!==e?e:null;this.registeredEvents=y({updaterMap:mn,eventMap:gn,prevProps:{},nextProps:this.props,instance:n}),this.setState((()=>({streetViewPanorama:n})),this.setStreetViewPanoramaCallback)}componentDidUpdate(e){null!==this.state.streetViewPanorama&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:mn,eventMap:gn,prevProps:e,nextProps:this.props,instance:this.state.streetViewPanorama}))}componentWillUnmount(){null!==this.state.streetViewPanorama&&(this.props.onUnmount&&this.props.onUnmount(this.state.streetViewPanorama),f(this.registeredEvents),this.state.streetViewPanorama.setVisible(!1))}render(){return null}}p(vn,"contextType",h);class fn extends r.PureComponent{constructor(){super(...arguments),p(this,"state",{streetViewService:null}),p(this,"setStreetViewServiceCallback",(()=>{null!==this.state.streetViewService&&this.props.onLoad&&this.props.onLoad(this.state.streetViewService)}))}componentDidMount(){var e=new google.maps.StreetViewService;this.setState((function(){return{streetViewService:e}}),this.setStreetViewServiceCallback)}componentWillUnmount(){null!==this.state.streetViewService&&this.props.onUnmount&&this.props.onUnmount(this.state.streetViewService)}render(){return null}}p(fn,"contextType",h);r.PureComponent;var yn={onDirectionsChanged:"directions_changed"},bn={directions(e,t){e.setDirections(t)},map(e,t){e.setMap(t)},options(e,t){e.setOptions(t)},panel(e,t){e.setPanel(t)},routeIndex(e,t){e.setRouteIndex(t)}};class Ln extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"state",{directionsRenderer:null}),p(this,"setDirectionsRendererCallback",(()=>{null!==this.state.directionsRenderer&&(this.state.directionsRenderer.setMap(this.context),this.props.onLoad&&this.props.onLoad(this.state.directionsRenderer))}))}componentDidMount(){var e=new google.maps.DirectionsRenderer(this.props.options);this.registeredEvents=y({updaterMap:bn,eventMap:yn,prevProps:{},nextProps:this.props,instance:e}),this.setState((function(){return{directionsRenderer:e}}),this.setDirectionsRendererCallback)}componentDidUpdate(e){null!==this.state.directionsRenderer&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:bn,eventMap:yn,prevProps:e,nextProps:this.props,instance:this.state.directionsRenderer}))}componentWillUnmount(){null!==this.state.directionsRenderer&&(this.props.onUnmount&&this.props.onUnmount(this.state.directionsRenderer),f(this.registeredEvents),this.state.directionsRenderer&&this.state.directionsRenderer.setMap(null))}render(){return null}}p(Ln,"contextType",h);r.PureComponent;var Cn={onPlacesChanged:"places_changed"},En={bounds(e,t){e.setBounds(t)}};class wn extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"containerElement",(0,r.createRef)()),p(this,"state",{searchBox:null}),p(this,"setSearchBoxCallback",(()=>{null!==this.state.searchBox&&this.props.onLoad&&this.props.onLoad(this.state.searchBox)}))}componentDidMount(){if(d(!!google.maps.places,'You need to provide libraries={["places"]} prop to component %s',google.maps.places),null!==this.containerElement&&null!==this.containerElement.current){var e=this.containerElement.current.querySelector("input");if(null!==e){var t=new google.maps.places.SearchBox(e,this.props.options);this.registeredEvents=y({updaterMap:En,eventMap:Cn,prevProps:{},nextProps:this.props,instance:t}),this.setState((function(){return{searchBox:t}}),this.setSearchBoxCallback)}}}componentDidUpdate(e){null!==this.state.searchBox&&(f(this.registeredEvents),this.registeredEvents=y({updaterMap:En,eventMap:Cn,prevProps:e,nextProps:this.props,instance:this.state.searchBox}))}componentWillUnmount(){null!==this.state.searchBox&&(this.props.onUnmount&&this.props.onUnmount(this.state.searchBox),f(this.registeredEvents))}render(){return(0,i.jsx)("div",{ref:this.containerElement,children:r.Children.only(this.props.children)})}}p(wn,"contextType",h);var Mn={onPlaceChanged:"place_changed"},xn={bounds(e,t){e.setBounds(t)},restrictions(e,t){e.setComponentRestrictions(t)},fields(e,t){e.setFields(t)},options(e,t){e.setOptions(t)},types(e,t){e.setTypes(t)}};class kn extends r.PureComponent{constructor(){super(...arguments),p(this,"registeredEvents",[]),p(this,"containerElement",(0,r.createRef)()),p(this,"state",{autocomplete:null}),p(this,"setAutocompleteCallback",(()=>{null!==this.state.autocomplete&&this.props.onLoad&&this.props.onLoad(this.state.autocomplete)}))}componentDidMount(){var e;d(!!google.maps.places,'You need to provide libraries={["places"]} prop to component %s',google.maps.places);var t=null===(e=this.containerElement.current)||void 0===e?void 0:e.querySelector("input");if(t){var n=new google.maps.places.Autocomplete(t,this.props.options);this.registeredEvents=y({updaterMap:xn,eventMap:Mn,prevProps:{},nextProps:this.props,instance:n}),this.setState((()=>({autocomplete:n})),this.setAutocompleteCallback)}}componentDidUpdate(e){f(this.registeredEvents),this.registeredEvents=y({updaterMap:xn,eventMap:Mn,prevProps:e,nextProps:this.props,instance:this.state.autocomplete})}componentWillUnmount(){null!==this.state.autocomplete&&f(this.registeredEvents)}render(){return(0,i.jsx)("div",{ref:this.containerElement,className:this.props.className,children:r.Children.only(this.props.children)})}}p(kn,"defaultProps",{className:""}),p(kn,"contextType",h)}}]);