{"version":3,"sources":["webpack:///./src/components/seo.tsx","webpack:///./src/components/content.tsx","webpack:///./src/context/PromoContext.tsx","webpack:///./src/templates/appointment.tsx"],"names":["SEO","pagePath","metaInfo","env","schema","title","metaTitle","metaDescription","ogImage","openImage","asset","url","twitterImage","openTitle","openGraphDescription","twitterTitle","twitterDescription","dontIndex","noIndex","key","type","JSON","stringify","src","charset","data-domain-script","lang","http-equiv","content","property","name","siteRoute","queryClient","QueryClient","Content","modules","client","RenderModules","PromoContext","createContext","undefined","usePromo","context","useContext","Error","PromoProvider","children","useState","promos","setPromos","isLoading","error","useEffect","promoJson","value","Provider","Appointment","path","pageContext","main","shortDescription","image","appointmentType","showDefaultHero","meta","slug","showDefaultHeroModified","className","cls","imageId","_id","style","width","marginBottom","handleType","marginTop","appointmentLink","data","href","process","split"],"mappings":"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","file":"component---src-templates-appointment-tsx-85d6721a95883b808fe3.js","sourcesContent":["import React from 'react'\nimport { Helmet } from 'react-helmet'\n\nconst siteRoute = 'https://www.asktia.com'\n\nexport const SEO = ({\n pagePath,\n metaInfo,\n env,\n schema,\n}: {\n pagePath: string\n metaInfo: {\n metaTitle?: string\n metaDescription?: string\n openImageUrl?: string\n twitterImageUrl?: string\n twitterTitle?: string\n openTitle?: string\n openGraphDescription?: string\n twitterDescription?: string\n noIndex?: boolean\n }\n env: 'production' | 'development' | 'local' | 'staging'\n schema?: any\n}) => {\n const title = metaInfo\n ? metaInfo.metaTitle\n ? metaInfo.metaTitle\n : 'Ask Tia'\n : 'Ask Tia'\n const metaDescription = metaInfo\n ? metaInfo.metaDescription\n ? metaInfo.metaDescription\n : 'Ask Tia'\n : 'Ask Tia'\n const metaKeywords = 'ask tia, health, women, woman, wellness, clinic'\n const ogImage = metaInfo\n ? metaInfo.openImage\n ? metaInfo.openImage.asset.url\n : 'https://cdn.sanity.io/images/8qqycr4y/production/4eaae4b88cd6b4f41ebaa30a351d53ee2d6914ae-2400x1260.png'\n : 'https://cdn.sanity.io/images/8qqycr4y/production/4eaae4b88cd6b4f41ebaa30a351d53ee2d6914ae-2400x1260.png'\n const twitterImage = metaInfo\n ? metaInfo.twitterImage\n ? metaInfo.twitterImage.asset.url\n : 'https://cdn.sanity.io/images/8qqycr4y/production/4eaae4b88cd6b4f41ebaa30a351d53ee2d6914ae-2400x1260.png'\n : 'https://cdn.sanity.io/images/8qqycr4y/production/4eaae4b88cd6b4f41ebaa30a351d53ee2d6914ae-2400x1260.png'\n const openTitle = metaInfo\n ? metaInfo.openTitle\n ? metaInfo.openTitle\n : title\n : title\n const openGraphDescription = metaInfo\n ? metaInfo.openGraphDescription\n ? metaInfo.openGraphDescription\n : metaDescription\n : metaDescription\n const twitterTitle = metaInfo\n ? metaInfo.twitterTitle\n ? metaInfo.twitterTitle\n : title\n : title\n const twitterDescription = metaInfo\n ? metaInfo.twitterDescription\n ? metaInfo.twitterDescription\n : metaDescription\n : metaDescription\n\n const dontIndex = metaInfo?.noIndex || env !== 'production'\n\n // one trust integration at beginning of html head\n return (\n \n {schema && [\n ,\n ]}\n \n \n\n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n {dontIndex && }\n \n \n )\n}\n","// If you don't want to use TypeScript you can delete this file!\nimport React from 'react'\nimport { QueryClient, QueryClientProvider } from 'react-query'\nimport {\n AmplitudeExperimentProvider,\n AmplitudeExperimentContext,\n} from 'src/ampli/AmplitudeExperimentProvider'\nimport PromoProvider from 'src/context/PromoContext'\nimport { RenderModules } from 'src/utils/renderModules'\n\nconst queryClient = new QueryClient()\n\nexport const Content = ({ modules }: { modules: [] }) => {\n return (\n <>\n \n \n {RenderModules(modules)}\n \n \n \n )\n}\n\nexport default Content\n","import React, { createContext, useContext, useEffect, useState } from 'react'\nimport promoJson from '../../static/promoProps.json'\nimport { Promo, Promos } from 'src/interfaces/Promo'\n\ninterface PromoContextValue {\n promos: Promos | null\n isLoading: boolean\n error: Error | null\n}\n\nconst PromoContext = createContext(undefined)\n\ninterface PromoProviderProps {\n children: React.ReactNode\n}\n\nconst fetchActivePromo = async (): Promise => {\n const response = await fetch('/api/promos/active')\n\n if (!response.ok) {\n throw new Error('Failed to fetch active promotion')\n }\n\n const data = await response.json()\n\n return {\n ...data,\n validUntil: new Date(data.validUntil),\n }\n}\n\nexport const PromoProvider: React.FC = ({\n children,\n}: PromoProviderProps) => {\n const [promos, setPromos] = useState(null)\n const [isLoading, setIsLoading] = useState(false)\n const [error, setError] = useState(null)\n\n useEffect(() => {\n setPromos(promoJson)\n }, [])\n\n const value: PromoContextValue = {\n promos,\n isLoading,\n error,\n }\n\n return {children}\n}\n\nexport const usePromo = (): PromoContextValue => {\n const context = useContext(PromoContext)\n\n if (context === undefined) {\n throw new Error('usePromo must be used within a PromoProvider')\n }\n\n return context\n}\n\nexport default PromoProvider\n","// If you don't want to use TypeScript you can delete this file!\r\nimport React from 'react'\r\nimport { Link } from 'gatsby'\r\n\r\nimport { RenderModules } from 'src/utils/renderModules'\r\nimport { Image } from 'src/components/image'\r\n\r\nimport { Location, LocationClinic, LocationVirtual } from 'src/components/svgs'\r\nimport { SEO } from 'src/components/seo'\r\nimport { ButtonBlock } from 'src/components/inline/buttonBlock'\r\nimport Content from 'src/components/content'\r\n\r\nexport interface AppointmentProps {\r\n pageContext: {\r\n main: {\r\n modules: []\r\n slug: {\r\n current: string\r\n }\r\n appointmentLink: {\r\n _type: string\r\n content: { main: { slug: { current: string } } }\r\n }\r\n title: string\r\n showDefaultHero: boolean\r\n }\r\n meta: {}\r\n env: 'production' | 'development' | 'local' | 'staging'\r\n }\r\n path: string\r\n}\r\n\r\nconst Appointment = ({ path, pageContext }: AppointmentProps) => {\r\n const {\r\n main: {\r\n title,\r\n shortDescription,\r\n modules,\r\n image,\r\n appointmentType,\r\n showDefaultHero,\r\n slug,\r\n },\r\n meta,\r\n env,\r\n } = pageContext\r\n\r\n const handleType = (type: string) => {\r\n switch (type) {\r\n case 'in-clinic-only':\r\n return 'In-Clinic Only'\r\n case 'virtual-only':\r\n return 'Virtual Only'\r\n case 'in-clinic-and-virtual':\r\n return 'In-Clinic & Virtual'\r\n }\r\n }\r\n\r\n const handleIcon = (type: string) => {\r\n switch (type) {\r\n case 'in-clinic-only':\r\n return \r\n case 'virtual-only':\r\n return \r\n case 'in-clinic-and-virtual':\r\n return \r\n }\r\n }\r\n\r\n const url = path\r\n\r\n const showDefaultHeroModified =\r\n showDefaultHero === undefined ? true : showDefaultHero\r\n\r\n return (\r\n
\r\n \r\n {showDefaultHeroModified ? (\r\n
\r\n
\r\n \r\n
\r\n \r\n {handleType(appointmentType)}\r\n
\r\n

{title}

\r\n

{shortDescription}

\r\n
\r\n {pageContext.main.appointmentLink && (\r\n \r\n )}\r\n
\r\n \r\n Already a Tia member? Book here\r\n \r\n
\r\n
\r\n
\r\n ) : (\r\n <>\r\n )}\r\n \r\n \r\n )\r\n}\r\n\r\nexport default Appointment\r\n"],"sourceRoot":""}