{"version":3,"file":"component---src-templates-post-js-3d6ebf0bc3fd32b44e17.js","mappings":"qaAgBO,MAAMA,EAAUC,EAAAA,QAAOC,IAAGC,WAAA,CAAAC,YAAA,mBAAAC,YAAA,eAAVJ,CAAU,2HAC3B,8WAkBCK,eAAeC,EAAeC,GACnC,MAAMC,EAASC,sFAAkEF,EACjF,IACE,MAAOG,SAAkBC,QAAQC,IAAI,CACnCC,MAAML,GACN,IAAIG,SAASG,GAAMC,WAAWD,EAAG,SAE7BE,QAAaN,EAASO,OAC5B,GAAID,EAAKE,gBAAiB,CAExB,OADaF,EAAKE,eAEpB,CACF,CAAE,MAAOC,GACP,OAAO,IACT,CACA,OAAO,IACT,CAEO,MAAMC,EAAgBC,IAAkB,IAAjB,QAAEC,GAASD,EACvC,MAAME,GAAOC,EAAAA,EAAAA,IAAe,eA0BpBC,MAAOC,GAAmBH,EAAKI,KAAKL,SACpCG,MAAOG,GAAmBL,EAAKI,KAAKE,QACtCC,EAAKP,EAAKI,KAAKI,cAAc,GAEnC,OACEC,EAAAA,cAACjC,EAAO,OACHuB,GACDU,EAAAA,cAAAA,EAAAA,SAAA,KACEA,EAAAA,cAAA,OAAKC,ICxFf,ynQDwF4BC,OAAQ,IAAKC,MAAO,IAAKC,IAAI,KAC/CJ,EAAAA,cAAA,MACEK,UAAU,eACVC,wBAAyB,CAAEC,QAAQC,EAAAA,EAAAA,GAAWd,QAIlDJ,GACAU,EAAAA,cAAAA,EAAAA,SAAA,KACEA,EAAAA,cAAA,MACEK,UAAU,UACVC,wBAAyB,CAAEC,QAAQC,EAAAA,EAAAA,GAAWZ,MAEhDI,EAAAA,cAACS,EAAAA,EAAQ,CAACJ,UAAU,kBAAkBK,GAAIZ,EAAGa,SAC3CX,EAAAA,cAAA,QACEM,wBAAyB,CAAEC,QAAQC,EAAAA,EAAAA,GAAWV,EAAGc,mBAKjD,EAId,WAAsB,IAADC,EAAAC,EAAAC,EACnB,MAAM,EAACzB,EAAQ,EAAC0B,IAAcC,EAAAA,EAAAA,WAAS,IACjC,EAACC,EAAK,EAACC,IAAWF,EAAAA,EAAAA,UAAS,MAmBjC,OAPAG,EAAAA,EAAAA,YAAU,KACR,GAAIC,EAAAA,GAAaC,OAAOC,SAASC,KAAM,EAXzCnD,eAAwBE,GACtB,MAAM2C,QAAa5C,EAAeC,GAClC2C,EAAKO,cAAeC,EAAAA,EAAAA,IAAaR,GACjCC,EAAQD,GACRF,GAAW,GACPK,EAAAA,GACFC,OAAOK,QAAQC,aAAa,CAAC,EAAGV,EAAKW,MAAOX,EAAKO,aAErD,CAKIK,CADcR,OAAOC,SAASC,KAAKO,UAAU,GAE/C,IACC,IAGD/B,EAAAA,cAACgC,EAAAA,EAAM,KACK,OAATd,GAAiBlB,EAAAA,cAACZ,EAAa,CAACE,QAASA,IAChC,OAAT4B,GACClB,EAAAA,cAAAA,EAAAA,SAAA,KACEA,EAAAA,cAACiC,EAAAA,EAAG,CACFJ,MAAOX,EAAKW,MACZK,YAAaC,IAAUjB,EAAKkB,UAAY,GACxCC,KAAM,CACJ,CACEC,SAAU,UACVC,QAAS,WAEX,CACED,SAAU,kBACVC,QAAgC,QAAvB1B,EAAAK,EAAKsB,0BAAkB,IAAA3B,GAAvBA,EAAyB4B,OAC9BvB,EAAKsB,mBAAmB,GAAGE,KAC3B,OAGRC,KAAMzB,EAAKyB,KACXC,iBAAkB,CACdC,OAA0B,QAApB/B,EAAEI,EAAK4B,qBAAa,IAAAhC,OAAA,EAAlBA,EAAoBtC,IAC5BuE,QAA2B,QAApBhC,EAAEG,EAAK4B,qBAAa,IAAA/B,OAAA,EAAlBA,EAAoBvC,OAGnCwB,EAAAA,cAACgD,EAAAA,EAAI,CAAC9B,KAAMA,EAAM+B,QAAQ,KAKnC,C,2LE7ID,UAAe5D,IAA4B,IAAD6D,EAAAC,EAAArC,EAAAD,EAAAuC,EAAA,IAA1B,KAAE7D,EAAI,YAAE8D,GAAahE,EACnC,MAAQH,gBAAiBoE,GAAY/D,EAAKI,KACpC4D,EAAWC,MAASC,SAAS,EAAG,UAEpCH,IACAA,aAAO,EAAPA,EAASI,gBAAiBH,EAASI,eACX,QAAxBL,SAAa,QAANJ,EAAPI,EAAStE,YAAI,IAAAkE,OAAN,EAAPA,EAAeU,OACgB,MAA/BN,SAAa,QAANH,EAAPG,EAAStE,YAAI,IAAAmE,OAAN,EAAPA,EAAeS,KAAKC,UAEpBP,EAAQQ,SAAU,GAGpB,MAAMvC,GAAWwC,EAAAA,EAAAA,eACXC,EAAc,IAAIC,gBAAgB1C,EAAS2C,SAC3C,EAAChD,EAAK,EAACC,IAAWF,EAAAA,EAAAA,UAASqC,IAG3B,EAACa,EAAM,EAACC,IAAYnD,EAAAA,EAAAA,UACJ,SAApBoC,aAAW,EAAXA,EAAagB,MAAiBf,EAAQQ,UAElC,EAACQ,EAAe,EAACC,IAAqBtD,EAAAA,EAAAA,WAAS,IAC/C,EAACgC,EAAO,EAACuB,IAAavD,EAAAA,EAAAA,WAAS,IAC/B,EAAC6C,EAAQ,EAACW,IAAcxD,EAAAA,EAAAA,WAAS,IACjC,EAACyD,EAAY,EAACC,IAAkB1D,EAAAA,EAAAA,UAAS,OAsC/CG,EAAAA,EAAAA,YAAU,KAgBH+C,GAfL9F,iBACE,MAAMuG,EAAWrD,EAASqD,UAAY,GAChCP,EAAKL,EAAYa,IAAI,OAAS,GAC9BC,EAASd,EAAYa,IAAI,YAAc,GACvCE,EAAef,EAAYa,IAAI,OAEjCE,QA3CR1G,eAA+BE,GAK7B,IAAIyG,EAJJP,GAAW,GACXF,GAAkB,GAClBH,GAAS,GAIT,IACEY,QAAmB1G,EAAAA,EAAAA,gBAAeC,EACpC,CAAE,MAAO0G,GACPC,QAAQC,IAAI,qBAAsBF,EACpC,CAEID,IACFR,GAAU,GACVQ,EAAWvD,cAAeC,EAAAA,EAAAA,IAAasD,GACvCL,EAAeK,GACf1D,OAAOK,QAAQC,aAAa,CAAC,EAAGoD,EAAWnD,MAAOmD,EAAWvD,eAG/D8C,GAAkB,EACpB,CAwBYa,CAAgBL,IACbH,GAAYP,UAvB3BhG,eAAwBsE,EAAM0B,EAAIS,GAChC,MAAMO,QAAcC,EAAAA,EAAAA,IAAQ3C,EAAM0B,EAAIS,GAC1B,IAADS,EAAAC,EAAPH,GACEA,EAAMvB,SAANuB,MAAiBA,GAAW,QAANE,EAALF,EAAOrG,YAAI,IAAAuG,GAAM,QAANC,EAAXD,EAAa3B,YAAI,IAAA4B,GAAjBA,EAAmB3B,SACtCwB,EAAMvB,SAAU,GAElB3C,EAAQkE,GACRjB,GAAS,KAETqB,EAAAA,EAAAA,IAAS,OAEb,CAcY3D,CAAS4D,mBAAmBd,GAAWP,EAAIS,EAErD,CAGEa,EACF,GACC,IAECzE,IACFA,EAAKO,cAAeC,EAAAA,EAAAA,IAAaR,GAC7BA,EAAK0E,YAAc1E,EAAK2E,cAC1B3E,EAAK2E,YAAc,mCAAqC3E,EAAK0E,YAGjE,MAAME,EAAW5E,SAAmB,QAAfJ,EAAJI,EAAM4B,qBAAa,IAAAhC,OAAf,EAAJA,EAAqBtC,IAChCuH,IAAW7E,SAAwB,QAApBL,EAAJK,EAAMsB,0BAAkB,IAAA3B,IAAxBA,EAA0B4B,SACvCvB,EAAKsB,mBAAmB,GAEtBG,EAAOzB,EACTA,EAAK8E,mBACHC,EAAAA,EAAAA,eAAc/E,IACdQ,EAAAA,EAAAA,IAAaR,GACf,KACEmB,EAAO,CACX,CACEC,SAAU,UACVC,QAAS,WAEX,CACED,SAAU,kBACVC,QAASwD,aAAQ,EAARA,EAAUrD,OAGjBE,EAAmB,CACvBC,OAAQiD,EACR/C,QAAS+C,GAGX,OACE9F,EAAAA,cAACgC,EAAAA,EAAM,KACLhC,EAAAA,cAACiC,EAAAA,EAAG,CACFJ,MAAOX,aAAI,EAAJA,EAAMW,MACbK,aACEhB,SAAa,QAATkC,EAAJlC,EAAMgF,eAAO,IAAA9C,OAAT,EAAJA,EAAeQ,OAAQzB,IAAUjB,aAAI,EAAJA,EAAMiF,gBAAkB,GAE3D9D,KAAMA,EACNM,KAAMA,EACNC,iBAAkBA,MAEjBuB,GACDnE,EAAAA,cAAAA,EAAAA,SAAA,OACK8D,IAAYY,GACb1E,EAAAA,cAACZ,EAAAA,cAAa,CAACE,QAASgF,MAEvBR,KAAaY,GACd1E,EAAAA,cAACgD,EAAAA,EAAI,CAAC9B,KAAMwD,EAAazB,OAAQA,KAEjCa,KAAa5C,GAAQlB,EAAAA,cAACgD,EAAAA,EAAI,CAAC9B,KAAMA,EAAM+B,OAAQA,MAGnDkB,GACAnE,EAAAA,cAAA,OAAKK,UAAU,wEAAuE,cAM7F,C,oBCpJD+F,EAAOC,QAAU,CAAEJ,cAhBnB,SAAuBK,GACrB,MAAM,KAAEC,EAAI,kBAAEC,GAAsBF,EAKpC,MAAM,aAAaE,GAAqBD,EAC1C,EASkCE,eAPlC,SAAwBH,GACtB,MAAM,MAAEzE,EAAK,mBAAE6E,GAAuBJ,EAGtC,OAAOI,GAAsB7E,CAC/B,E,mCCdA,MAAMR,EAA8B,oBAAXC,OAEzB,K","sources":["webpack://parrot-analytics-gatsby/./src/pages/insights/premium.js","webpack://parrot-analytics-gatsby/./src/images/icons/locked.png","webpack://parrot-analytics-gatsby/./src/templates/post.js","webpack://parrot-analytics-gatsby/./src/utils/demand-academy.js","webpack://parrot-analytics-gatsby/./src/utils/is-browser.js"],"sourcesContent":["import React, { useEffect, useState } from \"react\"\nimport { useStaticQuery, graphql } from \"gatsby\"\n// eslint-disable-next-line no-unused-vars\nimport { PageFragment } from \"components/fragments\"\nimport tw, { styled } from \"twin.macro\"\nimport striptags from \"striptags\"\n\nimport { brandRules } from \"utils/brand\"\nimport { insightsPath } from \"utils/insights\"\nimport Layout from \"components/layout\"\nimport SEO from \"components/seo\"\nimport Post from \"components/post\"\nimport Locked from \"images/icons/locked.png\"\nimport ButtonLE from \"components/button-le\"\nimport isBrowser from \"utils/is-browser\"\n\nexport const Loading = styled.div`\n ${tw`py-32 font-display font-bold text-white bg-black h-screen flex flex-col items-center justify-center text-center`}\n\n img {\n @media (max-width: 720px) {\n height: 50px;\n width: 50px;\n }\n }\n\n h1 {\n font-size: 24px;\n\n @media (min-width: 720px) {\n font-size: 36px;\n }\n }\n`\n\nexport async function getPremiumPost(token) {\n const url = `${process.env.GATSBY_DEMAND360_SIGNUP_API}/premium_insights?token=${token}`\n try {\n const [response] = await Promise.all([\n fetch(url),\n new Promise((r) => setTimeout(r, 3000)),\n ])\n const body = await response.json()\n if (body.insightsArticle) {\n const post = body.insightsArticle\n return post\n }\n } catch (e) {\n return null\n }\n return null\n}\n\nexport const LoadingScreen = ({ loading }) => {\n const data = useStaticQuery(graphql`\n {\n gcms {\n loading: websiteSetting(\n where: { name: \"Premium Insights loading message\" }\n ) {\n value\n }\n expired: websiteSetting(\n where: { name: \"Premium Insights invalid link\" }\n ) {\n value\n }\n sharedContent: contentBlocks(\n where: { identifier: \"shared-premium-insight-cta\" }\n ) {\n title\n mainContent {\n html\n }\n callToAction\n linkUrl\n }\n }\n }\n `)\n const { value: loadingMessage } = data.gcms.loading\n const { value: expiredMessage } = data.gcms.expired\n const cb = data.gcms.sharedContent[0]\n\n return (\n \n {!!loading && (\n <>\n
\n \n >\n )}\n {!loading && (\n <>\n \n \n \n \n >\n )}\n \n )\n}\n\nexport default () => {\n const [loading, setLoading] = useState(true)\n const [post, setPost] = useState(null)\n\n async function loadPost(token) {\n const post = await getPremiumPost(token)\n post.relativePath = insightsPath(post)\n setPost(post)\n setLoading(false)\n if (isBrowser) {\n window.history.replaceState({}, post.title, post.relativePath)\n }\n }\n\n useEffect(() => {\n if (isBrowser && window.location.hash) {\n const token = window.location.hash.substring(1)\n loadPost(token)\n }\n }, [])\n\n return (\n \n {post === null && }\n {post !== null && (\n <>\n \n \n >\n )}\n \n )\n}\n","export default \"\"","import React, { useEffect, useState } from \"react\"\nimport { graphql, navigate } from \"gatsby\"\nimport { useLocation } from \"@reach/router\"\nimport striptags from \"striptags\"\nimport moment from \"moment\"\n\nimport Post from \"components/post\"\nimport Layout from \"components/layout\"\nimport SEO from \"components/seo\"\nimport { getPost, insightsPath } from \"utils/insights\"\nimport { daArticlePath } from \"utils/demand-academy\"\nimport { LoadingScreen, getPremiumPost } from \"pages/insights/premium\"\n\n// Rules for loading posts dynamically\n// If context === 404 (loaded by catch all route)\n// => if id (CMS preview) => load regular with apiKey\n// => if pathname (not yet published post) => load regular\n// If context !== 404 (article exists)\n// => if more than 6 months since publication => mark post as non premium\n// (this loads the whole article during build without restrictions)\n// => if key query param (premium token) => load premium with token\n// => if no key query param (premium token) => load regular\n\nexport default ({ data, pageContext }) => {\n const { insightsArticle: cmsPost } = data.gcms\n const expireAt = moment().subtract(6, \"months\")\n if (\n cmsPost &&\n cmsPost?.publishingDate < expireAt.toISOString() &&\n cmsPost?.body?.text !== null &&\n cmsPost?.body?.text.trim() !== \"\"\n ) {\n cmsPost.premium = false\n }\n\n const location = useLocation()\n const queryParams = new URLSearchParams(location.search)\n const [post, setPost] = useState(cmsPost)\n // Post will be ready to use from the beginning if it's not\n // unknown (loaded by the catch all route) and not premium.\n const [ready, setReady] = useState(\n pageContext?.id !== \"404\" && !cmsPost.premium\n )\n const [premiumLoading, setPremiumLoading] = useState(false)\n const [shared, setShared] = useState(false)\n const [premium, setPremium] = useState(false)\n const [premiumPost, setPremiumPost] = useState(null)\n\n async function loadPremiumPost(token) {\n setPremium(true)\n setPremiumLoading(true)\n setReady(true)\n\n let loadedPost\n\n try {\n loadedPost = await getPremiumPost(token)\n } catch (error) {\n console.log(\"Error loading post\", error)\n }\n\n if (loadedPost) {\n setShared(true)\n loadedPost.relativePath = insightsPath(loadedPost)\n setPremiumPost(loadedPost)\n window.history.replaceState({}, loadedPost.title, loadedPost.relativePath)\n }\n\n setPremiumLoading(false)\n }\n\n async function loadPost(path, id, apiKey) {\n const dPost = await getPost(path, id, apiKey)\n if (dPost) {\n if (dPost.premium && dPost?.body?.text?.trim()) {\n dPost.premium = false\n }\n setPost(dPost)\n setReady(true)\n } else {\n navigate(\"/404\")\n }\n }\n\n useEffect(() => {\n async function load() {\n const pathname = location.pathname || \"\"\n const id = queryParams.get(\"id\") || \"\"\n const apiKey = queryParams.get(\"api-key\") || \"\"\n const premiumToken = queryParams.get(\"key\")\n\n if (premiumToken) {\n // Attempt to load premium content\n await loadPremiumPost(premiumToken)\n } else if (pathname || id) {\n // Attempt to load post by pathname or by id\n await loadPost(encodeURIComponent(pathname), id, apiKey)\n }\n }\n\n if (!ready) {\n load()\n }\n }, [])\n\n if (post) {\n post.relativePath = insightsPath(post)\n if (post.youtubeId && !post.externalUrl) {\n post.externalUrl = \"https://www.youtube.com/watch?v=\" + post.youtubeId\n }\n }\n const imageURL = post?.featuredImage?.url\n const category = post?.insightsCategories?.length\n ? post.insightsCategories[0]\n : false\n const path = post\n ? post.demandAcademyTier\n ? daArticlePath(post)\n : insightsPath(post)\n : null\n const meta = [\n {\n property: \"og:type\",\n content: \"article\",\n },\n {\n property: \"article:section\",\n content: category?.name,\n },\n ]\n const sharePreviewUrls = {\n social: imageURL,\n twitter: imageURL,\n }\n\n return (\n \n \n {!!ready && (\n <>\n {!!premium && !premiumPost && (\n \n )}\n {!!premium && !!premiumPost && (\n \n )}\n {!premium && !!post && }\n >\n )}\n {!ready && (\n \n Loading...\n
\n )}\n \n )\n}\n\nexport const query = graphql`\n query PostById($id: ID!) {\n gcms {\n insightsArticle(where: { id: $id }) {\n id\n title\n slug\n body {\n html\n text\n }\n legacyBody\n legacySummary\n summary {\n html\n text\n }\n insightsCategories {\n name\n slug\n }\n publishingDate\n featuredImage {\n url\n altText\n handle\n }\n premium\n wordpressId\n metadata\n articlePublisher {\n publisher\n }\n externalUrl\n youtubeId\n format\n markets {\n name\n isoCode\n }\n titlesJson\n moviesJson\n talentJson\n platforms {\n name\n slug\n }\n metrics {\n name\n }\n genres {\n name\n slug\n }\n industries {\n title\n slug\n }\n applications {\n title\n slug\n }\n demandAcademyTier {\n name\n }\n demandAcademySlug\n }\n }\n }\n`\n","function daArticlePath(article) {\n const { slug, demandAcademySlug } = article\n\n // TODO: This shouldn't be necessary if DA title is set\n // and the backend function is generating slugs for\n // it as expected\n return `/academy/${demandAcademySlug || slug}`\n}\n\nfunction daArticleTitle(article) {\n const { title, demandAcademyTitle } = article\n\n // TODO: This shouldn't be necessary if DA title is set\n return demandAcademyTitle || title\n}\n\nmodule.exports = { daArticlePath, daArticleTitle }\n","const isBrowser = typeof window !== \"undefined\"\n\nexport default isBrowser\n"],"names":["Loading","styled","div","withConfig","displayName","componentId","async","getPremiumPost","token","url","process","response","Promise","all","fetch","r","setTimeout","body","json","insightsArticle","e","LoadingScreen","_ref","loading","data","useStaticQuery","value","loadingMessage","gcms","expiredMessage","expired","cb","sharedContent","React","src","height","width","alt","className","dangerouslySetInnerHTML","__html","brandRules","ButtonLE","to","linkUrl","callToAction","_post$insightsCategor","_post$featuredImage","_post$featuredImage2","setLoading","useState","post","setPost","useEffect","isBrowser","window","location","hash","relativePath","insightsPath","history","replaceState","title","loadPost","substring","Layout","SEO","description","striptags","excerpt","meta","property","content","insightsCategories","length","name","path","sharePreviewUrls","social","featuredImage","twitter","Post","shared","_cmsPost$body","_cmsPost$body2","_post$summary","pageContext","cmsPost","expireAt","moment","subtract","publishingDate","toISOString","text","trim","premium","useLocation","queryParams","URLSearchParams","search","ready","setReady","id","premiumLoading","setPremiumLoading","setShared","setPremium","premiumPost","setPremiumPost","pathname","get","apiKey","premiumToken","loadedPost","error","console","log","loadPremiumPost","dPost","getPost","_dPost$body","_dPost$body$text","navigate","encodeURIComponent","load","youtubeId","externalUrl","imageURL","category","demandAcademyTier","daArticlePath","summary","legacySummary","module","exports","article","slug","demandAcademySlug","daArticleTitle","demandAcademyTitle"],"sourceRoot":""}