{"version":3,"file":"component---src-pages-index-js-38ff2fc8f9078836cd15.js","mappings":"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","sources":["webpack://gatsby-london/./src/components/signup.js","webpack://gatsby-london/./src/components/signup.module.css","webpack://gatsby-london/./src/components/postCard.js","webpack://gatsby-london/./src/pages/index.js"],"sourcesContent":["import React, {useState} from 'react';\r\nimport * as signupStyles from \"./signup.module.css\"\r\nimport { useGoogleReCaptcha } from 'react-google-recaptcha-v3'\r\nimport Helmet from \"react-helmet\"\r\n\r\nfunction validateEmail(email) {\r\n const re = /^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\r\n return re.test(String(email).toLowerCase());\r\n}\r\n \r\nexport default function Signup() {\r\n const { executeRecaptcha } = useGoogleReCaptcha()\r\n console.log('executeRecaptcha', executeRecaptcha)\r\n\r\n const [email, setEmail] = useState('');\r\n const [valid, setValid] = useState(true);\r\n const [mode, setMode] = useState(0);\r\n\r\n const handleEmailChange = (e) => setEmail(e.target.value);\r\n\r\n const handleSubmit = async (e) => {\r\n e.preventDefault();\r\n\r\n setMode(1)\r\n\r\n try {\r\n console.log(\"handleSubmit\", e)\r\n\r\n if (!executeRecaptcha) {\r\n console.log(\"!executeRecaptcha\")\r\n throw \"Not Ready\"\r\n }\r\n\r\n // VALIDATE\r\n if (!validateEmail(email)) {\r\n console.log(\"not valid\")\r\n setValid(false)\r\n setMode(0)\r\n return\r\n }\r\n\r\n const token = await executeRecaptcha('signup')\r\n console.log('token', token)\r\n\r\n const data = JSON.stringify({email, token})\r\n\r\n console.log('data', data)\r\n\r\n const submitResult = await fetch('https://cwzrokjccj.execute-api.us-east-1.amazonaws.com/001/signup', {\r\n method: 'POST',\r\n headers: {\r\n 'Accept': 'application/json, text/plain, */*',\r\n 'Content-type': 'application/json'\r\n },\r\n body: data \r\n })\r\n\r\n const finalResult = await submitResult.json()\r\n\r\n console.log('finalResult', finalResult);\r\n\r\n if(finalResult.result == \"OK\") {\r\n setMode(2)\r\n return\r\n } \r\n\r\n throw \"Unexpected Result\"\r\n \r\n } catch(e) {\r\n console.log(e)\r\n setMode(3)\r\n }\r\n };\r\n\r\n return (\r\n
\r\n \r\n \r\n \r\n {\r\n {\r\n 0:
\r\n {/*
Join my inner circle,
*/}\r\n
Join my inner circle, for rare glimpses into new creations!
\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n\r\n {!valid && Please enter a valid email address.}\r\n
\r\n {/*
*/}\r\n
,\r\n 1:
\r\n
Working...
\r\n
,\r\n 2:
\r\n
Done. Thank you for joining!
\r\n
,\r\n 3:
\r\n
Oops, unable not join, refresh and try agian.
\r\n
\r\n }[mode]\r\n }\r\n
\r\n )\r\n \r\n}\r\n","// extracted by mini-css-extract-plugin\nexport var container = \"signup-module--container--TNhyb\";\nexport var descripton = \"signup-module--descripton--lt+sc\";\nexport var done = \"signup-module--done--Jkq8n\";\nexport var emailInput = \"signup-module--emailInput--NzfMi\";\nexport var inputContainer = \"signup-module--inputContainer--MBIa7\";\nexport var inputRow = \"signup-module--inputRow--+rASG\";\nexport var oops = \"signup-module--oops--sAcT9\";\nexport var privacy = \"signup-module--privacy--qLyzf\";\nexport var submitButton = \"signup-module--submitButton--0UC4F\";\nexport var title = \"signup-module--title--gwaEE\";\nexport var validation = \"signup-module--validation--Kt9tx\";\nexport var working = \"signup-module--working--tEWS8\";","import React from \"react\"\r\nimport { Link } from \"gatsby\"\r\nimport { GatsbyImage } from \"gatsby-plugin-image\"\r\n\r\nexport default props => (\r\n \r\n\r\n
\r\n {/* You can use a GatsbyImage component if the image is dynamic */}\r\n\r\n {props.node.frontmatter.thumbnail &&\r\n \r\n }\r\n\r\n \r\n {/* Any content here will be centered in the component */}\r\n \r\n
\r\n

\r\n {props.node.frontmatter.title || props.node.fields.slug}\r\n

\r\n
\r\n \r\n
\r\n \r\n\r\n\r\n\r\n \r\n)\r\n\r\n// ${props.count % 3 === 0 && `post-card-large`}\r\n","import React from \"react\"\r\nimport { graphql, StaticQuery } from \"gatsby\"\r\nimport { GatsbyImage } from 'gatsby-plugin-image';\r\n\r\nimport Layout from \"../components/layout\"\r\nimport SEO from \"../components/seo\"\r\nimport PostCard from \"../components/postCard\"\r\nimport Signup from \"../components/signup\"\r\n\r\nimport \"../utils/styles.css\"\r\nimport \"../utils/normalize.css\"\r\nimport \"../utils/css/screen.css\"\r\n\r\nconst BlogIndex = ({ data }, location) => {\r\n const siteTitle = data.site.siteMetadata.title\r\n const posts = data.allMarkdownRemark.edges\r\n let postCounter = 0\r\n\r\n\r\n return (\r\n \r\n \r\n \r\n
\r\n \r\n
\r\n\r\n
\r\n

\r\n Mesmerizing sculptures that blend digital precision with organic beauty.\r\n

\r\n
\r\n\r\n {/*
*/}\r\n\r\n
\r\n {posts.map(({ node }) => {\r\n postCounter++\r\n return (\r\n \r\n )\r\n })}\r\n
\r\n
\r\n )\r\n}\r\n\r\n\r\n\r\nconst indexQuery = graphql`\r\n query {\r\n site {\r\n siteMetadata {\r\n title\r\n description\r\n }\r\n }\r\n bannerImage: file(relativePath: { eq: \"header1.jpg\" }) {\r\n childImageSharp {\r\n gatsbyImageData(layout: CONSTRAINED, width: 1360)\r\n }\r\n }\r\n allMarkdownRemark(\r\n filter: {fileAbsolutePath: {regex: \"/content/blog/\"}}\r\n sort: { fields: [frontmatter___date], order: DESC }\r\n ) {\r\n edges {\r\n node {\r\n excerpt\r\n fields {\r\n slug\r\n }\r\n frontmatter {\r\n date(formatString: \"MMMM DD, YYYY\")\r\n title\r\n description\r\n thumbnail {\r\n childImageSharp {\r\n gatsbyImageData(layout: CONSTRAINED, width: 640)\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n`\r\n\r\nexport default props => (\r\n (\r\n \r\n )}\r\n />\r\n)\r\n"],"names":["validateEmail","email","test","String","toLowerCase","Signup","executeRecaptcha","useGoogleReCaptcha","console","log","useState","setEmail","valid","setValid","mode","setMode","handleSubmit","e","preventDefault","token","data","JSON","stringify","fetch","method","headers","body","submitResult","json","finalResult","result","className","Helmet","href","crossorigin","rel","type","onSubmit","style","marginBottom","name","id","value","onChange","target","placeholder","required","class","props","postClass","node","frontmatter","thumbnail","display","G","gridArea","alt","image","childImageSharp","gatsbyImageData","position","placeItems","Link","to","fields","slug","title","BlogIndex","location","siteTitle","site","siteMetadata","posts","allMarkdownRemark","edges","postCounter","keywords","bannerImage","objectPosition","padding","maxWidth","fontSize","map","key","count","StaticQuery","query","render"],"sourceRoot":""}