{"version":3,"file":"component---src-templates-page-contact-js-ccb155d288e84daa762e.js","mappings":"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","sources":["webpack://landbay/./src/hooks/useScript.js","webpack://landbay/./src/templates/page-contact.js","webpack://landbay/./src/assets/img/map-marker.png","webpack://landbay/./src/utils/formatPhoneNumber.js"],"sourcesContent":["/**\n * Allows a component to load a third party script\n * See: https://usehooks.com/useScript/\n */\nimport { useState, useEffect } from \"react\";\n\nexport default function useScript(src) {\n // Keep track of script status (\"idle\", \"loading\", \"ready\", \"error\")\n const [status, setStatus] = useState(src ? \"loading\" : \"idle\");\n useEffect(\n () => {\n // Allow falsy src value if waiting on other data needed for\n // constructing the script URL passed to this hook.\n if (!src) {\n setStatus(\"idle\");\n return;\n }\n // Fetch existing script element by src\n // It may have been added by another intance of this hook\n let script = document.querySelector(`script[src=\"${src}\"]`);\n if (!script) {\n // Create script\n script = document.createElement(\"script\");\n script.src = src;\n script.async = true;\n script.setAttribute(\"data-status\", \"loading\");\n // Add script to document body\n document.body.appendChild(script);\n // Store status in attribute on script\n // This can be read by other instances of this hook\n const setAttributeFromEvent = (event) => {\n script.setAttribute(\n \"data-status\",\n event.type === \"load\" ? \"ready\" : \"error\"\n );\n };\n script.addEventListener(\"load\", setAttributeFromEvent);\n script.addEventListener(\"error\", setAttributeFromEvent);\n } else {\n // Grab existing script status from attribute and set to state.\n setStatus(script.getAttribute(\"data-status\"));\n }\n // Script event handler to update status in state\n // Note: Even if the script already exists we still need to add\n // event handlers to update the state for *this* hook instance.\n const setStateFromEvent = (event) => {\n setStatus(event.type === \"load\" ? \"ready\" : \"error\");\n };\n // Add event listeners\n script.addEventListener(\"load\", setStateFromEvent);\n script.addEventListener(\"error\", setStateFromEvent);\n // Remove event listeners on cleanup\n return () => {\n if (script) {\n script.removeEventListener(\"load\", setStateFromEvent);\n script.removeEventListener(\"error\", setStateFromEvent);\n }\n };\n },\n [src] // Only re-run effect if script src changes\n );\n return status;\n}","import React, { useState, useEffect } from \"react\"\nimport { graphql, Link } from \"gatsby\"\nimport Layout from '../components/Layout' \nimport Hero from '../components/widgets/Hero' \nimport formatPhoneNumber from '../utils/formatPhoneNumber' \nimport Seo from 'gatsby-plugin-wpgraphql-seo';\nimport useScript from \"../hooks/useScript\";\nimport mapMarker from \"../assets/img/map-marker.png\"\n\nexport default function Careers({ data }) {\n const page = data.allWpPage.nodes[0];\n const [scriptLoaded, setScriptLoaded] = useState(false);\n\n //load in the google maps script via our useScript hook\n useScript(\n \"https://maps.googleapis.com/maps/api/js?key=AIzaSyBRD-ysASOP5Ki-ogoQB4KHd8_m2vbQfDs&callback=initMap\"\n );\n\n if (typeof window !== 'undefined') {\n\t\n window.initMap = function() {\n\t setScriptLoaded(true);\n\t //console.log('in initMap');\n }\n }\n\n useEffect(() => {\n //console.log('in contact use effect')\n\tif (scriptLoaded || (window && window.google?.maps) ) {\n //console.log('script is loaded, adding map')\n\t\t\n\t const coord = {\n\t lat: 51.495520,\n lng: -0.145830\n\t };\n\t\n\t const map = new window.google.maps.Map(document.getElementById('map'), {\n center: coord,\n zoom: 16,\n styles: [{\"featureType\": \"administrative\",\"elementType\": \"all\",\"stylers\": [{\"saturation\": \"-100\"}]},{\"featureType\": \"administrative.province\",\"elementType\": \"all\",\"stylers\": [{\"visibility\": \"off\"}]},{\"featureType\": \"landscape\",\"elementType\": \"all\",\"stylers\": [{\"saturation\": -100},{\"lightness\": 65},{\"visibility\": \"on\"}]},{\"featureType\": \"poi\",\"elementType\": \"all\",\"stylers\": [{\"saturation\": -100},{\"lightness\": \"50\"},{\"visibility\": \"simplified\"}]},{\"featureType\": \"road\",\"elementType\": \"all\",\"stylers\": [{\"saturation\": \"-100\"}]},{\"featureType\": \"road.highway\",\"elementType\": \"all\",\"stylers\": [{\"visibility\": \"simplified\"}]},{\"featureType\": \"road.arterial\",\"elementType\": \"all\",\"stylers\": [{\"lightness\": \"30\"}]},{\"featureType\": \"road.local\",\"elementType\": \"all\",\"stylers\": [{\"lightness\": \"40\"}]},{\"featureType\": \"transit\",\"elementType\": \"all\",\"stylers\": [{\"saturation\": -100},{\"visibility\": \"simplified\"}]},{\"featureType\": \"water\",\"elementType\": \"geometry\",\"stylers\": [{\"hue\": \"#ffff00\"},{\"lightness\": -25},{\"saturation\": -97}]},{\"featureType\": \"water\",\"elementType\": \"labels\",\"stylers\": [{\"lightness\": -25},{\"saturation\": -100}]}]\n })\n\n\t const image = {\n\t url: mapMarker,\n\t size: new window.google.maps.Size(75, 100),\n \t scaledSize: new window.google.maps.Size(75, 100),\n\t origin: new window.google.maps.Point(0, 0),\n\t anchor: new window.google.maps.Point(37.5, 100),\n\t };\n\n new window.google.maps.Marker({\n position: coord,\n icon: image,\n animation: window.google.maps.Animation.DROP,\n map\n });\n\t}\n }, [scriptLoaded]);\n\n return (\n \t\n \n\t
\n\t \n\t
\n\t
\n\t\t
\n\t\t\t

{page.title}

\n\t\t
\n\t\t
\n\t\t\t
\n\t\t\t\t{page.contact?.contactBlocks?.length && page.contact.contactBlocks.map((block, i) => (\n\t\t\t\t
\n\t\t\t\t\t\t

{block.title}

\n\t\t\t\t\t\t

{block.subtitle}

\n\t\t\t\t\t\t{block.phone && (\n\t\t\t\t\t\t

Call {block.phone}

\n\t\t\t\t\t )}\n\t\t\t\t\t\t{block.email && (\n\t\t\t\t\t\t

Email {block.email}

\n\t\t\t\t\t )}\n\t\t\t\t\t\t{block.text && (\n\t\t\t\t\t\t

{block.text}

\n\t\t\t\t\t )}\n\t\t\t\t\t\t{block.links?.length && (\n\t\t\t\t\t\t\t

\n\t\t\t\t\t\t\t\t{block.links.map(({link}, j) => (\n\t\t\t\t\t\t\t\t\t{link.title}\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t\t

\n\t\t\t\t\t\t)}\n\t\t\t\t
\n\t\t\t ))}\n\t\t\t
\n\t\t
\n\t\t
\n\t\t\t
\n\t\t\t\t

{page.contact?.contactMap?.title}

\n\t\t\t\t
\n\t\t\t\t\t

{page.contact?.contactMap?.companyName}

\n\t\t\t\t\t

\n\t\t\t\t

\n\t\t\t
\n\t\t\t
\n\t\t
\n\t
\n
\n )\n}\nexport const query = graphql`\n query($id: String!) {\n allWpPage(filter: { id: { eq: $id } }) {\n nodes {\n title\n ...PageSEOFragment\n\t\tcontact {\n\t contactBlocks {\n\t title\n\t subtitle\n\t phone\n\t email\n\t text\n\t links {\n\t link {\n\t target\n\t title\n\t url\n\t }\n\t }\n\t }\n\t contactMap {\n\t title\n\t companyName\n\t address\n\t }\n\t }\n }\n }\n }\n`","export default \"\"","\nexport default function formatPhoneNumber(phoneNumber) {\n\t//return 'tel:'+phoneNumber.replace(/\\s+/g, '').replace(/(.)(\\d{4})(\\d)/, '+44 ($1)$2 $3');\n return 'tel:'+phoneNumber.replace(/\\s+/g, '').replace(/(.)(\\d{4})(\\d)/, '+44$2$3');\n}\n"],"names":["useScript","src","useState","status","setStatus","useEffect","script","document","querySelector","getAttribute","createElement","async","setAttribute","body","appendChild","setAttributeFromEvent","event","type","addEventListener","setStateFromEvent","removeEventListener","Careers","page","data","allWpPage","nodes","scriptLoaded","setScriptLoaded","window","initMap","google","maps","coord","lat","lng","map","Map","getElementById","center","zoom","styles","image","url","size","Size","scaledSize","origin","Point","anchor","Marker","position","icon","animation","Animation","DROP","Layout","className","post","Hero","widget","layout","title","contact","contactBlocks","length","block","i","key","subtitle","phone","href","formatPhoneNumber","email","text","links","j","link","Link","to","contactMap","companyName","dangerouslySetInnerHTML","__html","address","id","phoneNumber","replace"],"sourceRoot":""}