{"version":3,"sources":["webpack:///./src/app/pages/WeatherPage.js","webpack:///./src/templates/ThreeArticleDeck.js","webpack:///./src/app/components/FollowConcept.js","webpack:///./src/app/components/Articles.js","webpack:///./src/templates/ArticleDeck.js","webpack:///./src/templates/ArticleFourRow.js","webpack:///./src/app/pages/DefaultTrendPage.js","webpack:///./src/app/pages/TagPage.js","webpack:///./src/templates/SixArticleDeck.js","webpack:///./src/app/pages/NotFound.js","webpack:///./src/app/components/WingBanners.js","webpack:///./src/templates/Default.js"],"names":["Leaderboard","HP","Wing","mpuRHS","WeatherPage","props","adPath","location","pathname","setPageType","useEffect","section","sectionPageView","visitorId","sessionId","app","firstRender","titleTemplate","title","property","content","itemProp","name","description","url","keywords","twitterName","main","px","sm","wAdD","wallpaperActive","mt","lg","w","maxWidth","mx","isConnected","slotId","targeting","interstitial","collapseEmptyDiv","className","anchor","mapping","MAPPINGS","Interstitial","FORMATS","mappingLeft","mappingRight","onSlotRenderEndedLeft","onSlotRenderEndedRight","noDiv","loading","Skeleton","count","pageSize","withMore","moreButtonColour","noImage","NoImage","notFound","NotFound","component","articles","moreButton","withReadCount","div","my","textAlign","display","justifyContent","alignItems","flexDirection","leaderboard","slice","mb","defaultProps","BasicTemplate","withRouter","connect","state","getVisitorId","getSessionId","dispatch","bindActionCreators","fetchArticles","fetchMoreArticles","OpinionArticles","article","hoverColor","clickSource","color","to","getCanonical","spaceX","source","position","image","getImage","width","getImageSize","alt","getTeaser","shape","visibility","h5","text","p","author","formatAgo","published","Template","authorName","sectionLabel","relatedSections","isOpinion","gridTemplateColumns","gap","map","index","key","uuid","lastType","borderWidth","borderStyle","borderColor","last","MPU","mpu","ThreeArticleDeck","DefaultTemplate","componentText","subscribeConcept","button","bg","_","hover","borderRadius","textTransform","py","onClick","FollowConcept","topic","followText","unFollowText","template","useState","isSubscribed","setIsSubscribed","helpPopupVisible","setHelpPopupVisible","subscription","setSubscription","registration","setRegistration","isSubscribedToConcept","console","log","Promise","resolve","data","qs","stringify","titleKey","process","endpoint","axios","post","headers","then","res","subscribed","filter","status","length","error","message","JSON","navigator","serviceWorker","getRegistration","reg","pushManager","getSubscription","sub","setSubscribed","canPush","window","isFollowing","visible","img","src","iolBlocks","fontWeight","mr","ml","subscribe","userVisibleOnly","applicationServerKey","urlB64ToUint8Array","err","MoreFromButton","styled","Articles","React","scrollY","setScrollY","hasFetchedMore","timer","setTimeout","scrollTo","clearTimeout","id","gridColumn","pageView","canonical","replace","pageYOffset","sectionProps","sectionsLabels","label","rel","itemprop","href","nextHref","prevHref","memo","deepCompare","Pos","ArticleDeck","spaceY","headline","ArticleFourRow","banner","h","backgroundImage","backgroundRepeat","backgroundPosition","backgroundSize","overflow","top","left","right","bottom","backgroundColor","transform","h1","fontFamily","type","h2","contentKey","pb","flex","h6","aside","mpu600","DefaultTrendPage","hasMounted","useHasMounted","downMd","useDown","TagPage","staticContext","this","is404","Component","wallpaperMapping","setWallPaperActive","handleWallpaperLoaded","useCallback","e","isEmpty","useLocation","zIndex","startsWith","Wallpaper","wallpaper","onSlotRenderEnded","wAdM","Wingbanner","wingbanner","Default"],"mappings":"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","file":"static/js/pages-TagPage.d1bc0a61.chunk.js","sourcesContent":["import React, { useEffect } from 'react'\nimport { connect } from 'react-redux'\nimport Helmet from 'react-helmet'\nimport { bindActionCreators } from 'redux'\nimport { withRouter } from 'react-router'\nimport { x } from '@xstyled/styled-components'\n\nimport Articles from '../components/Articles'\nimport { fetchArticles, fetchMoreArticles } from '../../store/articles'\nimport { sectionPageView, setPageType } from '../../store/app'\nimport { getVisitorId, getSessionId } from '../../store/article'\nimport WingBanners from '../components/WingBanners'\nimport Ad from '../components/Ad'\nimport {FORMATS, MAPPINGS} from '../components/AdFormats'\nimport NoImage from '../../../assets/images/general/no-image.png'\n\nimport WeatherWidget from '../components/WeatherWidget'\nimport ArticleDeck from '../../templates/ArticleDeck'\nimport ThreeArticleDeck from '../../templates/ThreeArticleDeck'\nimport SixArticleDeck from '../../templates/SixArticleDeck'\n\nimport { WeatherPageSkeleton as Skeleton } from '../components/Skeletons'\nimport BasicTemplate from '../../templates/Default'\nimport NotFound from './NotFound'\nimport { getTeaser } from '../../lib/articleUtils'\n\nconst Leaderboard = [\n  [[1024, 0], [[728, 90], [970, 90], [970, 250], 'fluid']],\n  [[640, 0], [[460, 60], 'fluid']],\n  [[0, 0], [[300, 600], [336, 280], [320, 100], [320, 50], [300, 250], [300, 100], [300, 50], 'fluid']]\n]\n\nconst HP = [\n  [[1024, 0], [[300, 600], 'fluid']],\n  [[640, 0], [[300, 600], 'fluid']],\n  [[0, 0], [[300, 600], [336, 280], [320, 100], [320, 50], [300, 250], [300, 100], [300, 50], 'fluid']]\n]\n\nconst Wing = [\n  [[1024, 0], [[160, 600], [120, 600]]],\n  [[640, 0], []],\n  [[0, 0], []]\n]\n\nconst mpuRHS = [\n  [[1024, 0], [[300, 250], 'fluid']],\n  [[640, 0], [[300, 250], [336, 280], 'fluid']],\n  [[0, 0], [[300, 600], [336, 280], [320, 100], [320, 50], [300, 250], [300, 100], [300, 50], 'fluid']]\n]\n\nconst DefaultTemplate = ({ articles, authorName, section, noImage, isConnected, sectionLabel, moreButton, relatedSections, withReadCount, adPath }) => (\n  <ul>\n    {articles.map(article => (\n      <li key={article.uuid}>{getTeaser(article)}</li>\n    ))}\n  </ul>\n)\n\nconst WeatherPage = (props) => {\n  const adPath = `${props.adPath || (props.location.pathname + '/homepage')}`\n  setPageType('section')\n  useEffect(\n    () => {\n      if (('/' + props.section) === props.location.pathname) {\n         props.sectionPageView(props.location.pathname, props.section, props.visitorId, props.sessionId, props.app.firstRender)\n      }\n    },\n    [props.section]\n  )\n  return (\n    <>\n      <Helmet titleTemplate={'%s'}\n        title={props.title} >\n        <meta property='og:title' content={props.title} />\n        <meta itemProp='headline' content={props.title} />\n        <meta name='description' content={props.description} />\n        <meta itemProp='description' content={props.description} />\n        <meta property='og:description' content={props.description} />\n        <meta property='og:url' content={props.url} />\n        <meta property='keywords' content={props.keywords} />\n        <meta name='twitter:site' content={props.twitterName} />\n        <meta name='twitter:creator' content={props.twitterName} />\n        <meta name='twitter:title' content={props.title} />\n        <meta name='twitter:description' content={props.description} />\n      </Helmet>\n      <x.main px={{ sm: '20px', wAdD: props.app.wallpaperActive ? '0px' : '200px' }} mt={{ sm: '96px', lg: props.app.wallpaperActive ? '0px' : '173px' }} w='100%' maxWidth={{ sm: '1260px', wAdD: props.app.wallpaperActive ? '1220px' : '1660px' }} mx='auto'>\n        <Ad isConnected={props.isConnected} adPath={props.adPath} slotId='interstitial' targeting={{ interstitial: 'interstitial' }} collapseEmptyDiv className='advert' anchor='interstitial' mapping={MAPPINGS.Interstitial} {...FORMATS.interstitial} />\n        <WingBanners isConnected={props.isConnected} adPath={adPath} location={props.location} mappingLeft={Wing} mappingRight={Wing} onSlotRenderEndedLeft={props.onSlotRenderEndedLeft} onSlotRenderEndedRight={props.onSlotRenderEndedRight} />\n        <Articles\n          {...props} noDiv isConnected={true} loading={Skeleton} section={props.section} count={17} pageSize={16} withMore moreButtonColour='btn-red' noImage={NoImage} notFound={NotFound} component={({ articles, section, noImage, moreButton, isConnected, withReadCount }) => (\n            <>\n              <x.div my={20} mx={-20} textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column'>\n                <Ad isConnected={props.isConnected} adPath={adPath} collapseEmptyDiv slotId='leaderboard-top' targeting={{ leaderboard: 'top' }} className='advert' mapping={MAPPINGS['Leaderboard']} {...FORMATS.leaderboard} />\n              </x.div>\n              <WeatherWidget />\n              <x.div maxWidth={1220} w='100%' mx='auto' mt={50}>\n                <SixArticleDeck articles={articles.slice(0, 6)} section={props.section} noImage={noImage} isConnected={isConnected} withReadCount={withReadCount} adPath={adPath} mapping={HP} visitorId={props.visitorId} sessionId={props.sessionId} />\n                <ArticleDeck articles={articles.slice(6, 10)} section={props.section} noImage={noImage} isConnected={isConnected} withReadCount={withReadCount} adPath={adPath} mapping={mpuRHS} visitorId={props.visitorId} sessionId={props.sessionId} />\n                <ThreeArticleDeck articles={articles.slice(10, 13)} section={props.section} noImage={noImage} isConnected={isConnected} withReadCount={withReadCount} adPath={adPath} mapping={mpuRHS} visitorId={props.visitorId} sessionId={props.sessionId} />\n                <ArticleDeck articles={articles.slice(13)} section={props.section} noImage={noImage} moreButton={moreButton} isConnected={isConnected} withReadCount={withReadCount} adPath={adPath} mapping={mpuRHS} visitorId={props.visitorId} sessionId={props.sessionId} />\n              </x.div>\n            </>\n          )}\n        />\n        <x.div mt={20} mb={50} mx={-20} textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column'>\n          <Ad isConnected={props.isConnected} adPath={adPath} collapseEmptyDiv slotId='Leaderboard-bot' targeting={{ Leaderboard: 'bot' }} className='advert' mapping={Leaderboard} {...FORMATS.leaderboard} />\n        </x.div>\n      </x.main>\n    </>\n    )\n  }\n\nWeatherPage.defaultProps = {\n  component: BasicTemplate,\n  section: 'news'\n}\nconst mapDispatchToProps = (dispatch) => bindActionCreators({ fetchArticles, fetchMoreArticles, sectionPageView }, dispatch)\n\nexport default withRouter(connect((state) => ({ app: state.app, articles: state.articles, visitorId: getVisitorId(state), sessionId: getSessionId(state) }), mapDispatchToProps)(WeatherPage))\n","import React from 'react'\nimport { getCanonical, getImageSize, getImage, getTeaser } from '../lib/articleUtils'\nimport { x } from '@xstyled/styled-components'\nimport { formatAgo } from '../lib/dateUtils'\nimport ImageOrNoImage from '../app/components/ui/Image'\nimport NoImage from '../../assets/images/general/no-image.png'\nimport StyledLink from '../app/components/ui/Link'\nimport Ad from '../app/components/Ad'\nimport { FORMATS } from '../app/components/AdFormats'\n\nconst OpinionArticles = ({ article, hoverColor, visitorId, sessionId, section, clickSource, color }) => {\n  return (\n    <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' alignItems='flex-start' spaceX={{ sm: '10px', lg: 'unset' }} flexDirection={{ sm: 'row', lg: 'column' }} justifyContent={{ sm: 'space-between', lg: 'unset' }} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource} color={color} hoverColor={hoverColor}>\n      <x.div position='relative' display='flex' justifyContent='center' alignItems='center'>\n        <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={getTeaser(article)} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n        <ImageOrNoImage image={getImage(article)} maxWidth={100} width={getImageSize('slider')} alt={getTeaser(article)} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n      </x.div>\n      <x.div mt={{ lg: '10px' }}>\n        <x.h5 text={{ sm: 'h6', lg: 'h5' }} mb={8}>{getTeaser(article)}</x.h5>\n        <x.p text='meta' color='meta' my={8}>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n      </x.div>\n    </StyledLink>\n  )\n}\n\nconst Template = ({ articles, authorName, section, noImage, isConnected, sectionLabel, relatedSections, withReadCount, adPath, mapping, visitorId, sessionId, color, hoverColor, isOpinion }) => {\n  const clickSource = 'Three Article Deck'\n  return (\n    <x.div display={{ sm: '', lg: 'grid' }} gridTemplateColumns={{ sm: '', lg: 'calc(100% - 340px) 300px' }} gap={{ lg: '40' }} w='100%' mb={40} mt={40}>\n      <x.div display={{ sm: '', lg: 'grid' }} gridTemplateColumns={{ sm: '', lg: 'repeat(3, calc((100% - 80px) / 3))' }} gap={{ lg: '40' }}>\n        {articles.map((article, index) => (\n          <x.article key={article.uuid} position='relative' className='divider-right-six' p={{ sm: '0 0 20px 0', lg: '0', lastType: '0' }} borderWidth={{ sm: '0 0 1px 0', lg: '0', lastType: '0' }} borderStyle='solid' borderColor='divider' mb={{ sm: '20px', lg: '0', last: '0' }}>\n            {!isOpinion &&\n              <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' alignItems='flex-start' spaceX={{ sm: '10px', lg: 'unset' }} flexDirection={{ sm: 'row', lg: 'column-reverse' }} justifyContent={{ sm: 'space-between', lg: 'unset' }} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource} color={color} hoverColor={hoverColor}>\n                <x.div mt={{ lg: '10px' }}>\n                  <x.h5 text={{ sm: 'h6', lg: 'h5' }} mb={8}>{getTeaser(article)}</x.h5>\n                  <x.p text='meta' color='meta' my={8}>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n                </x.div>\n                <x.div position='relative' display='flex' justifyContent='center' alignItems='center'>\n                  <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={getTeaser(article)} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n                  <ImageOrNoImage image={getImage(article)} maxWidth={50} width={getImageSize('slider')} alt={getTeaser(article)} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n                </x.div>\n              </StyledLink>}\n            {isOpinion &&\n              <OpinionArticles\n                article={article} hoverColor={hoverColor} visitorId={visitorId} sessionId={sessionId} section={section} clickSource={clickSource} color={color}\n              />}\n          </x.article>\n        ))}\n      </x.div>\n      <x.div textAlign='center' display='flex' justifyContent='flex-start' alignItems='center' flexDirection='column' p={{ sm: '20px', lg: '0' }} mt={{ sm: '40px', lg: '0' }}>\n        <Ad isConnected={isConnected} adPath={adPath} slotId='MPU-botright' targeting={{ MPU: 'botright' }} collapseEmptyDiv className='advert' mapping={mapping} {...FORMATS.mpu} />\n      </x.div>\n    </x.div>\n\n  )\n}\n\nconst ThreeArticleDeck = (props) => {\n  return (\n    <Template {...props} />\n  )\n}\n\nexport default ThreeArticleDeck\n","import React, { useEffect, useState } from 'react'\nimport { x } from '@xstyled/styled-components'\nimport axios from 'axios'\nimport qs from 'qs'\nimport { urlB64ToUint8Array } from '../ServiceWorker'\nimport StyledLink from './ui/Link'\nimport Popup from 'ion-popup'\nimport iolBlocks from '../../../assets/images/general/push-notifications.svg'\n\nconst DefaultTemplate = ({ componentText, subscribeConcept }) => (\n  <x.button text='small' bg={{ _: 'white', hover: 'red' }} color={{ _: 'red', hover: 'white' }} borderWidth='1px' borderStyle='solid' borderColor='red' textAlign='center'  borderRadius='100px' textTransform='uppercase' mb={20} px={20} py={8} onClick={() => subscribeConcept()}>{componentText}</x.button>\n)\n\nconst FollowConcept = ({ topic, followText, unFollowText, template, sessionId, visitorId, section }) => {\n  const Template = template || DefaultTemplate\n  const [isSubscribed, setIsSubscribed] = useState(false)\n  const [helpPopupVisible, setHelpPopupVisible] = useState(false)\n  const [subscription, setSubscription] = useState(false)\n  const [registration, setRegistration] = useState(false)\n  const clickSource = 'Follow Concept'\n\n  useEffect(() => {\n    if (navigator.serviceWorker) {\n      navigator.serviceWorker.getRegistration()\n        .then(reg => {\n          console.log('*** FollowConcept: registration', reg)\n          setRegistration(reg)\n        })\n    }\n  }, [])\n\n  useEffect(() => {\n    console.log('*** FollowConcept: registration', registration)\n    if (registration && registration.pushManager) {\n      registration.pushManager.getSubscription()\n        .then(sub => {\n          console.log('*** FollowConcept: subscription', sub)\n          setSubscription(sub)\n        })\n    }\n  }, [registration])\n\n  useEffect(() => {\n    console.log('FollowConcept setIsSubscribed', topic.name, subscription, topic.topic)\n    async function setSubscribed () {\n      const isSubscribed = await isSubscribedToConcept(topic.topic, subscription)\n      setIsSubscribed(isSubscribed)\n    }\n    setSubscribed()\n  }, [subscription, topic.topic])\n\n  function isSubscribedToConcept (uuid, subscription) {\n    if (!subscription) {\n      console.log('*** isSubscribedToConcept: User is not subscribed to any push notifications')\n      return Promise.resolve(false)\n    }\n    const data = qs.stringify({\n      titleKey: process.env.RAZZLE_TITLE_KEY,\n      endpoint: (subscription && subscription.endpoint) || '' \n    })\n    return axios.post(process.env.RAZZLE_PUSH_SERVICE + '/topics', data, {\n        headers: {\n          'Content-Type': 'application/x-www-form-urlencoded'\n        }\n      })\n      .then(res => {\n        const subscribed = res.data.filter(topic => topic.topic === uuid)\n        console.log('*** subscriptions response', res.status, res.data, 'subscribed:', (subscribed.length > 0))\n        return (subscribed.length > 0)\n      })\n      .catch(error => {\n        console.log('*** isSubscribedToConcept error:', error.message)\n        return false\n      })\n  }\n\n  function subscribeConcept (uuid, subscription) {\n    const data = {\n      topic: uuid,\n      titleKey: process.env.RAZZLE_TITLE_KEY,\n      subscription: JSON.stringify(subscription)\n    }\n    console.log('*** FollowConcept:', 'Subscribing', data)\n    console.log('Calling', isSubscribed ? 'unsubscribe' : 'subscribe', topic.name)\n    axios.post(process.env.RAZZLE_PUSH_SERVICE + (isSubscribed ? '/unsubscribe' : '/subscribe'), qs.stringify(data), {\n      headers: {\n        'Content-Type': 'application/x-www-form-urlencoded'\n      }\n    })\n    .then(res => setIsSubscribed(!isSubscribed))\n    .catch(error => {\n      console.log(isSubscribed ? 'Unsubscribe' : 'Subscribe', 'Error:', error.message)\n      return false\n    })\n  }\n\n  function registerAndSubscribeConcept (uuid) {\n    console.log('*** FollowConcept:', 'Registering and subscribing')\n    if (registration && registration.pushManager) {\n      registration.pushManager.subscribe({\n        userVisibleOnly: true,\n        applicationServerKey: urlB64ToUint8Array(process.env.RAZZLE_SERVERKEY)\n      })\n        .then(function (subscription) {\n          console.log('User IS now subscribed.')\n          setSubscription(subscription)\n          return subscribeConcept(uuid, subscription)\n        })\n        .catch(function (err) {\n          console.log('Failed to subscribe the user: ', err)\n          setHelpPopupVisible(true)\n          setSubscription(false)\n        })\n    }\n  }\n\n  const canPush = !!(process.env.RAZZLE_ENABLE_PUSHNOTIFICATIONS && typeof window !== 'undefined' && typeof window.navigator !== 'undefined' && subscription)\n  const isFollowing = canPush && isSubscribed\n  console.log('*** FollowConcept:', {canPush, isFollowing, subscription})\n\n  if (canPush) {\n    return <Template componentText={isFollowing ? unFollowText : followText} subscribeConcept={() => subscribeConcept(topic.topic, subscription)} />\n  } else {\n    if (registration && registration.pushManager) {\n      return (\n        <>\n          {helpPopupVisible &&\n            <Popup visible>\n              <x.div display='grid' gridTemplateColumns='56px auto' gap={20}>\n                <x.div>\n                  <x.img src={iolBlocks} alt='IOL' w={56} />\n                </x.div>\n                <x.div color='grey'>\n                  <x.p text='xlarge' fontWeight='medium'>Small problem..</x.p>\n                  <x.p mt={5}>You have previously chosen to block notifications.</x.p>\n                  <x.p mb={15}>To follow stories requires you to enable notifications in your browser settings.</x.p>\n                  <x.div display='flex' justifyContent='flex-end'>\n                    <StyledLink onClick={() => setHelpPopupVisible(false)} to={'/help'} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource}><x.p mt={3} mr={15}>Help</x.p></StyledLink>\n                    <x.button onClick={() => setHelpPopupVisible(false)} bg='#2E5FDC' color='white' p='6px 20px' borderRadius={4} ml={5}>OK</x.button>\n                  </x.div>\n                </x.div>\n              </x.div>\n            </Popup>}\n          <Template componentText={followText} subscribeConcept={() => registerAndSubscribeConcept(topic.topic)} />\n        </>\n      )\n    } else {\n      return null\n    }\n  }\n}\n\nexport default FollowConcept\n","import { memo } from 'react'\nimport styled, { x } from '@xstyled/styled-components'\nimport { Articles as IONArticles } from 'ion-article-cmp'\nimport Helmet from 'react-helmet'\nimport { pageView } from '../../store/app'\nimport deepCompare from '../../lib/deepCompare'\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\n\nconst MoreFromButton = styled.button`\n  text-transform: uppercase;\n  padding: 10px 20px;\n  color: #FFF;\n  background-color: grey;\n  transition: all linear .3s;\n  &:hover {\n    background-color: black;\n  }\n`\n\nexport const Articles = (props) => {\n  const [scrollY, setScrollY] = React.useState(-1)\n  const hasFetchedMore = props.articles[props.section] ? props.articles[props.section].hasFetchedMore : false\n\n  React.useEffect(() => {\n    if (hasFetchedMore && scrollY >= 0) {\n      const timer = setTimeout(() => {\n        window.scrollTo(0, scrollY)\n        setScrollY(-1)\n      }, 0)\n      return () => clearTimeout(timer)\n    }\n  }, [hasFetchedMore])\n\n  return (\n    <IONArticles\n      moreButton={(p) => (\n        <x.div id='buttonContainer' className='more-from-btn noScript' display='flex' justifyContent='center' alignItems='center' w='100%' gridColumn='span 4' my='20'>\n          {typeof window !== 'undefined' && (\n            <MoreFromButton\n              className={'btn' + p.moreButtonColour} id='viewMoreButton'\n              onClick={() => {\n                props.pageView(p.canonical.replace(process.env.RAZZLE_SITE_URL, ''))\n                setScrollY(window.pageYOffset)\n                return p.onClick()\n              }}\n            >More From {p.sectionProps.sectionsLabels && p.sectionProps.sectionsLabels[0] && p.sectionProps.sectionsLabels[0].label}\n            </MoreFromButton>\n          )}\n          {typeof window === 'undefined' && (\n            <a id='viewMoreButtonNoScript' href={p.nextHref}><MoreFromButton>More From {p.sectionProps.sectionsLabels && p.sectionProps.sectionsLabels[0] && p.sectionProps.sectionsLabels[0].label}</MoreFromButton></a>\n          )}\n          <Helmet>\n            <link rel='canonical' itemprop='url' href={p.canonical} />\n            <link rel='next' href={p.nextHref} />\n            {p.prevHref && (\n              <link rel='prev' href={p.prevHref} />\n            )}\n          </Helmet>\n        </x.div>\n      )} {...props}\n    />\n  )\n}\n\nconst mapDispatchToProps = (dispatch) => bindActionCreators({ pageView }, dispatch)\nexport default memo(connect(state => state.app, mapDispatchToProps)(Articles), deepCompare)\n","import React, { Fragment } from 'react'\nimport { getCanonical, getImageSize, getImage, getTeaser } from '../lib/articleUtils'\nimport { x } from '@xstyled/styled-components'\nimport { formatAgo } from '../lib/dateUtils'\nimport ImageOrNoImage from '../app/components/ui/Image'\nimport NoImage from '../../assets/images/general/no-image.png'\nimport StyledLink from '../app/components/ui/Link'\nimport Ad from '../app/components/Ad'\nimport { FORMATS } from '../app/components/AdFormats'\n\nconst OpinionArticles = ({ article, hoverColor, visitorId, sessionId, section, clickSource, color }) => {\n  return (\n    <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' alignItems='flex-start' spaceX={{ sm: '10px', lg: 'unset' }} flexDirection={{ sm: 'row', lg: 'column' }} justifyContent={{ sm: 'space-between', lg: 'unset' }} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource} color={color} hoverColor={hoverColor}>\n      <x.div position='relative' display='flex' justifyContent='center' alignItems='center'>\n        <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={getTeaser(article)} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n        <ImageOrNoImage image={getImage(article)} maxWidth={100} width={getImageSize('slider')} alt={getTeaser(article)} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n      </x.div>\n      <x.div mt={{ lg: '10px' }}>\n        <x.h5 text={{ sm: 'h6', lg: 'h5' }} mb={8}>{getTeaser(article)}</x.h5>\n        <x.p text='meta' color='meta' my={8}>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n      </x.div>\n    </StyledLink>\n  )\n}\n\nconst Template = ({ articles, authorName, section, noImage, isConnected, sectionLabel, moreButton, relatedSections, withReadCount, adPath, mapping, visitorId, sessionId, color, hoverColor, isOpinion }) => {\n  const clickSource = 'Article Deck'\n  return (\n    <x.div display={{ sm: '', lg: 'grid' }} gridTemplateColumns={{ sm: '', lg: 'repeat(3, calc((100% - 420px) / 3)) 300px' }} gap={{ lg: '40' }}>\n      {articles.map((article, index) => (\n        <Fragment key={index}>\n          {index > 0 && index % 16 === 0 &&\n            <x.div key={index} maxWidth={1220} mx='auto' my={50} textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column' w='100%' gridColumn='span 4'>\n              <Ad isConnected={isConnected} adPath={adPath} collapseEmptyDiv slotId='leaderboard-middle' targeting={{ Pos: 'Leaderboard-middle' }} className='advert' mapping={mapping} {...FORMATS.leaderboard} />\n            </x.div>}\n          <x.article key={article.uuid} position='relative' className='divider-right' p={{ sm: '0 0 20px 0', lg: '0', lastType: '0' }} borderWidth={{ sm: '0 0 1px 0', lg: '0', lastType: '0' }} borderStyle='solid' borderColor='divider' mb={{ sm: '20px', lg: '0', last: '0' }}>\n            {!isOpinion &&\n              <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' alignItems='flex-start' spaceX={{ sm: '10px', lg: 'unset' }} flexDirection={{ sm: 'row', lg: 'column-reverse' }} justifyContent={{ sm: 'space-between', lg: 'unset' }} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource} color={color} hoverColor={hoverColor}>\n                <x.div mt={{ lg: '10px' }}>\n                  <x.h5 text={{ sm: 'h6', lg: 'h5' }} mb={8}>{getTeaser(article)}</x.h5>\n                  <x.p text='meta' color='meta' my={8}>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n                </x.div>\n                <x.div position='relative' display='flex' justifyContent='center' alignItems='center'>\n                  <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={getTeaser(article)} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n                  <ImageOrNoImage image={getImage(article)} maxWidth={50} width={getImageSize('slider')} alt={getTeaser(article)} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n                </x.div>\n              </StyledLink>}\n            {isOpinion &&\n              <OpinionArticles\n                article={article} hoverColor={hoverColor} visitorId={visitorId} sessionId={sessionId} section={section} clickSource={clickSource} color={color}\n              />}\n          </x.article>\n        </Fragment>\n      ))}\n      {moreButton}\n    </x.div>\n  )\n}\nconst ArticleDeck = (props) => {\n  return (\n    <Template {...props} />\n  )\n}\n\nexport default ArticleDeck\n","import React, { Fragment } from 'react'\nimport { getCanonical, getImageSize, getImage, getTeaser } from '../lib/articleUtils'\nimport { x } from '@xstyled/styled-components'\nimport { formatAgo } from '../lib/dateUtils'\nimport ImageOrNoImage from '../app/components/ui/Image'\nimport NoImage from '../../assets/images/general/no-image.png'\nimport StyledLink from '../app/components/ui/Link'\nimport Ad from '../app/components/Ad'\nimport { FORMATS } from '../app/components/AdFormats'\n\nconst Template = ({ articles, authorName, section, noImage, isConnected, sectionLabel, moreButton, relatedSections, withReadCount, adPath, mapping, visitorId, sessionId }) => {\n  const clickSource = 'Article Four Row'\n  return (\n    <x.div display={{ sm: '', lg: 'grid' }} gridTemplateColumns={{ sm: '', lg: 'repeat(4, calc((100% - 120px) / 4))' }} gap={{ lg: '40' }}>\n      {articles.map((article, index) => (\n        <Fragment key={index}>\n          {index > 0 && index % 16 === 0 &&\n            <x.div key={index} maxWidth={1220} mx='auto' my={50} textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column' w='100%' gridColumn='span 4'>\n              <Ad isConnected={isConnected} adPath={adPath} collapseEmptyDiv slotId='Leaderboard-middle' targeting={{ Leaderboard: 'middle' }} className='advert' mapping={mapping} {...FORMATS.leaderboard} />\n            </x.div>}\n          <x.article key={article.uuid} position='relative' className='divider-right' p={{ sm: '0 0 20px 0', lg: '0', lastType: '0' }} borderWidth={{ sm: '0 0 1px 0', lg: '0', lastType: '0' }} borderStyle='solid' borderColor='divider' mb={{ sm: '20px', lg: '0', last: '0' }}>\n            <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' spaceY={{ sm: '0', lg: '10px' }} spaceX={{ sm: '10px', lg: '0' }} flexDirection={{ sm: 'row', lg: 'column-reverse' }} section={section} sessionId={sessionId} visitorId={visitorId} source={clickSource}>\n              <x.div>\n                <x.h5 text='h5' mt={0} mb={8}>{getTeaser(article)}</x.h5>\n                <x.p text='meta' color='meta'>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n              </x.div>\n              <x.div position='relative' display='flex' justifyContent='center' alignItems={{ sm: 'flex-start', lg: 'unset' }}>\n                <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={article.headline} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n                <ImageOrNoImage image={getImage(article)} maxWidth={50} width={getImageSize('slider')} alt={article.headline} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n              </x.div>\n            </StyledLink>\n          </x.article>\n        </Fragment>\n      ))}\n      {moreButton}\n    </x.div>\n  )\n}\n\nconst ArticleFourRow = (props) => {\n  return (\n    <Template {...props} />\n  )\n}\n\nexport default ArticleFourRow\n","import React, { useEffect } from 'react'\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport { withRouter } from 'react-router'\nimport { x, useDown } from '@xstyled/styled-components'\nimport useHasMounted from '../../lib/useHasMounted'\nimport Helmet from 'react-helmet'\n\nimport Articles from '../components/Articles'\nimport { fetchArticles, fetchMoreArticles } from '../../store/articles'\nimport { sectionPageView, setPageType } from '../../store/app'\nimport { getVisitorId, getSessionId } from '../../store/article'\nimport WingBanners from '../components/WingBanners'\nimport Ad from '../components/Ad'\nimport { FORMATS, MAPPINGS } from '../components/AdFormats'\nimport ArticleFourRow from '../../templates/ArticleFourRow'\nimport NotFound from './NotFound'\nimport NoImage from '../../../assets/images/general/no-image.png'\nimport StyledLink from '../components/ui/Link'\nimport ImageOrNoImage from '../components/ui/Image'\nimport { formatAgo } from '../../lib/dateUtils'\nimport { getCanonical, getImageSize, getImage, getTeaser } from '../../lib/articleUtils'\nimport FollowConcept from '../components/FollowConcept'\nimport { BasicPageSkeleton as Skeleton } from '../components/Skeletons'\n\nconst Leaderboard = [\n  [[1024, 0], [[728, 90], [970, 90], [970, 250], 'fluid']],\n  [[640, 0], [[460, 60], 'fluid']],\n  [[0, 0], [[300, 600], [336, 280], [320, 100], [320, 50], [300, 250], [300, 100], [300, 50], 'fluid']]\n]\n\nconst Wing = [\n  [[1024, 0], [[160, 600], [120, 600]]],\n  [[640, 0], []],\n  [[0, 0], []]\n]\n\nconst HP = [\n  [[1024, 0], [[300, 600], 'fluid']],\n  [[640, 0], [[300, 600], 'fluid']],\n  [[0, 0], [[300, 600], [336, 280], [320, 100], [320, 50], [300, 250], [300, 100], [300, 50], 'fluid']]\n]\n\nconst DefaultTemplate = ({ articles, section, sectionLabel, banner, noImage, isConnected, moreButton, withReadCount, adPath, sectionsLabels, visitorId, sessionId }) => {\n  const clickSource = 'Trend Page'\n  return (\n    <>\n      <x.div w='100%' maxWidth={1220} mx='auto' my={50} h={165} backgroundImage={banner ? `url(${banner})` : 'url(/images/standard.jpg)'} backgroundRepeat='no-repeat' backgroundPosition='50%' backgroundSize='cover' overflow='hidden' display='flex' justifyContent='center' alignItems='center' position='relative'>\n        <x.div position='absolute' top='0' left='0' right='0' bottom='0' backgroundColor='rgba(0, 0, 0, 0.35);'>\n        <x.div position='absolute' top='50%' left='50%' transform='translate(-50%, -50%)' display='flex' flexDirection='column' alignItems='center' justifyContent='center'>\n          {sectionLabel && sectionLabel !== 'none' && <x.h1 text={{ sm: 'xlarge', lg: 'xxlarge' }} textTransform='uppercase' fontFamily='\"PT Serif\", serif' color='white' w='auto'>{sectionLabel}</x.h1>}\n          <x.div mt={20}>\n            {sectionsLabels && sectionsLabels[0] && sectionsLabels[0].uuid &&\n              <FollowConcept\n                topic={{ topic: sectionsLabels[0].uuid, type: 'trend', name: sectionsLabels[0].label }}\n                followText='Follow Trend'\n                unFollowText='Unfollow Trend'\n                template={({ componentText, subscribeConcept }) => (\n                  <x.button text='small' bg={{ _: 'transparent', hover: 'white' }} color={{ _: 'white', hover: 'red' }} borderWidth='1px' borderStyle='solid' borderColor='white' textAlign='center' borderRadius='100px' textTransform='uppercase' mb={20} px={20} py={8} onClick={() => subscribeConcept()}>{componentText}</x.button>\n                )}\n                visitorId={visitorId}\n                sessionId={sessionId}\n                section={section}\n              />}\n          </x.div>\n        </x.div>\n      </x.div>\n      </x.div>\n      <x.div w='100%' maxWidth={1220} mx='auto' display='grid' gridTemplateColumns={{ sm: '100%', lg: 'minmax(min-content, 560px) minmax(min-content, 282px) 300px' }} gap={{ lg: '40' }} mt={50} mb={30}>\n        <x.div display='flex' flexDirection='column' position='relative' className='divider-right' p={{ sm: '0 0 20px 0', lg: '0' }} borderWidth={{ sm: '0 0 1px 0', lg: '0' }} borderStyle='solid' borderColor='divider'>\n        <x.article>\n          <StyledLink article={articles[0]} to={'/' + getCanonical(articles[0])} text='secondary' section={section} visitorId={visitorId} sessionId={sessionId} source={clickSource}>\n            <ImageOrNoImage image={getImage(articles[0])} w='100%' mb={10} width={getImageSize('hero')} alt={getTeaser(articles[0])} shape='16x9' noImage={NoImage} />\n            <x.h2 text='h1'>{getTeaser(articles[0])}</x.h2>\n            <x.p text='meta' color='meta' my={8}>By {articles[0].author} | Published {formatAgo(articles[0].published, true)}</x.p>\n            <x.p text='large'>{articles[0].abstract}</x.p>\n          </StyledLink>\n        </x.article>\n      </x.div>\n        <x.div position='relative' p={{ sm: '20px 0', lg: '0' }} className='divider-right' borderWidth='0'>\n        {articles.slice(1, 3).map(article => (\n          <x.article key={article.contentKey} pb={20} borderWidth='0 0 1px 0' borderStyle='solid' borderColor='divider'>\n            <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' spaceX={10} section={section} visitorId={visitorId} sessionId={sessionId} source={clickSource}>\n              <x.div flex='1 1 0'>\n                <x.h6 text='h6'>{getTeaser(article)}</x.h6>\n                <x.p text='meta' color='meta' mt={8}>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n              </x.div>\n              <x.div>\n                <ImageOrNoImage image={getImage(article)} w={{ sm: '50px', lg: '100%' }} mb={10} width={getImageSize('normal')} alt={getTeaser(article)} shape=\"square\" noImage={NoImage} />\n              </x.div>\n            </StyledLink>\n          </x.article>\n        ))}\n        {articles.slice(3, 6).map(article => (\n          <x.article key={article.contentKey} py={20} borderWidth='0 0 1px 0' borderStyle='solid' borderColor='divider'>\n            <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' spaceX={10} section={section} visitorId={visitorId} sessionId={sessionId} source={clickSource}>\n              <x.div flex='1 1 0'>\n                <x.h6 text='h6'>{getTeaser(article)}</x.h6>\n                <x.p text='meta' color='meta' mt={8}>By {article.author} | Published {formatAgo(article.published, true)}</x.p>\n              </x.div>\n              <x.div display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }}>\n                <ImageOrNoImage image={getImage(article)} w={{ sm: '50px', lg: '100%' }} mb={10} width={getImageSize('normal')} alt={getTeaser(article)} shape=\"square\" noImage={NoImage} />\n              </x.div>\n            </StyledLink>\n          </x.article>\n        ))}\n      </x.div>\n        <x.aside>\n        <x.div textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column' p={{ sm: '20px', lg: '0' }}>\n          <Ad isConnected={isConnected} adPath={adPath} slotId='MPU600-right' targeting={{ mpu600: 'right' }} mapping={HP} collapseEmptyDiv {...FORMATS.mpu600} />\n        </x.div>\n      </x.aside>\n      </x.div>\n      <x.div maxWidth={1220} w='100%' mx='auto' mt={50}>\n        <ArticleFourRow articles={articles.slice(5)} section={section} noImage={noImage} moreButton={moreButton} isConnected={isConnected} withReadCount={withReadCount} adPath={adPath} visitorId={visitorId} sessionId={sessionId} />\n      </x.div>\n    </>\n  )\n}\n\nconst DefaultTrendPage = (props) => {\n  const Template = props.template || DefaultTemplate\n  const hasMounted = useHasMounted()\n  const downMd = useDown('md')\n  setPageType('section')\n  useEffect(\n    () => {\n      if (('/' + props.section) === props.location.pathname) {\n        props.sectionPageView(props.location.pathname, props.section, props.visitorId, props.sessionId, props.app.firstRender)\n      }\n    },\n    [props.section]\n  )\n  return (\n    <>\n      <Helmet\ntitleTemplate=\"%s\"\n        title={props.title}>\n        <meta property='og:title' content={props.title} />\n        <meta itemProp='headline' content={props.title} />\n        <meta name='description' content={props.description} />\n        <meta itemProp='description' content={props.description} />\n        <meta property='og:description' content={props.description} />\n        <meta property='og:url' content={props.url} />\n        <meta property='keywords' content={props.keywords} />\n        <meta name='twitter:site' content={props.twitterName} />\n        <meta name='twitter:creator' content={props.twitterName} />\n        <meta name='twitter:title' content={props.title} />\n        <meta name='twitter:description' content={props.description} />\n      </Helmet>\n      <x.main px={{ sm: '20px', wAdD: props.app.wallpaperActive ? '0px' : '200px' }} mt={{ sm: '96px', lg: props.app.wallpaperActive ? '0px' : '173px' }} w='100%' maxWidth={{ sm: '1260px', wAdD: props.app.wallpaperActive ? '1220px' : '1660px' }} mx='auto'>\n        <Ad isConnected={props.isConnected} adPath={props.adPath} slotId='interstitial' targeting={{ interstitial: 'interstitial' }} collapseEmptyDiv className='advert' anchor='interstitial' mapping={MAPPINGS.Interstitial} {...FORMATS.interstitial} />\n        <WingBanners isConnected={props.isConnected} adPath={props.adPath} location={props.location} mappingLeft={Wing} mappingRight={Wing} onSlotRenderEndedLeft={props.onSlotRenderEndedLeft} onSlotRenderEndedRight={props.onSlotRenderEndedRight} />\n        <Articles\n          {...props} noDiv isConnected loading={Skeleton} section={props.section} sectionLabel={props.sectionLabel} sectionsLabels={props.sectionsLabels} count={25} pageSize={16} withMore moreButtonColour='btn-red' noImage={NoImage} notFound={NotFound} component={Template}\n        />\n        {hasMounted && !downMd &&\n          <x.div my={50} mx={-20} textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column'>\n            <Ad isConnected={props.isConnected} adPath={props.adPath} collapseEmptyDiv slotId='Leaderboard-bot' targeting={{ Leaderboard: 'bot' }} className='advert' mapping={Leaderboard} {...FORMATS.leaderboard} />\n          </x.div>}\n      </x.main>\n    </>\n  )\n}\n\nDefaultTrendPage.defaultProps = {\n  component: DefaultTemplate,\n  section: 'trends/plantbasedcooking'\n}\nconst mapDispatchToProps = (dispatch) => bindActionCreators({ fetchArticles, fetchMoreArticles, sectionPageView }, dispatch)\n\nexport default withRouter(connect((state) => ({ app: state.app, articles: state.articles, visitorId: getVisitorId(state), sessionId: getSessionId(state) }), mapDispatchToProps)(DefaultTrendPage))\n","import React, { useEffect } from 'react'\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport { withRouter } from 'react-router'\nimport Helmet from 'react-helmet'\nimport { x, useDown } from '@xstyled/styled-components'\nimport useHasMounted from '../../lib/useHasMounted'\n\nimport Articles from '../components/Articles'\nimport { fetchArticles, fetchMoreArticles } from '../../store/articles'\nimport { sectionPageView, setPageType } from '../../store/app'\nimport { getVisitorId, getSessionId } from '../../store/article'\nimport WingBanners from '../components/WingBanners'\nimport Ad from '../components/Ad'\nimport { FORMATS, MAPPINGS } from '../components/AdFormats'\nimport ArticleFourRow from '../../templates/ArticleFourRow'\nimport { BasicPageSkeleton as Skeleton } from '../components/Skeletons'\nimport FollowConcept from '../components/FollowConcept'\nimport NotFound from './NotFound'\nimport NoImage from '../../../assets/images/general/no-image.png'\n\nconst Leaderboard = [\n  [[1024, 0], [[728, 90], [970, 90], [970, 250], 'fluid']],\n  [[640, 0], [[460, 60], 'fluid']],\n  [[0, 0], [[300, 600], [336, 280], [320, 100], [320, 50], [300, 250], [300, 100], [300, 50], 'fluid']]\n]\n\nconst Wing = [\n  [[1024, 0], [[160, 600], [120, 600]]],\n  [[640, 0], []],\n  [[0, 0], []]\n]\n\nconst DefaultTemplate = ({ articles, section, noImage, isConnected, sectionLabel, sectionsLabels, moreButton, withReadCount, adPath, visitorId, sessionId }) => (\n  <>\n    <Helmet titleTemplate=\"%s\" title={(sectionLabel + ' | Latest News & Developments | IOL')}>\n      <meta property='og:title' content={(sectionLabel + ' | Latest News & Developments | IOL')} />\n      <meta itemProp='headline' content={(sectionLabel + ' | Latest News & Developments | IOL')} />\n    </Helmet>\n    <x.div w='100%' maxWidth={1220} mx='auto' my={50} borderWidth='0 0 1px 0' borderStyle='solid' borderColor='divider' display='flex' justifyContent='space-between'>\n      <x.h1 text='h4' fontFamily='\"PT Serif\", serif' pb={20}>{sectionLabel}</x.h1>\n      {sectionsLabels && sectionsLabels[0] && sectionsLabels[0].uuid &&\n        <FollowConcept\ntopic={{ topic: sectionsLabels[0].uuid, type: 'tag', name: sectionsLabels[0].label }}\n          followText=\"Follow Tag\"\n          unFollowText=\"Unfollow Tag\"\n          sessionId={sessionId}\n          visitorId={visitorId}\n          section={section}\n        />}\n    </x.div>\n    <x.div maxWidth={1220} w='100%' mx='auto' mt={50}>\n      <ArticleFourRow articles={articles} section={section} noImage={noImage} moreButton={moreButton} isConnected={isConnected} withReadCount={withReadCount} adPath={adPath} mapping={Leaderboard} visitorId={visitorId} sessionId={sessionId} />\n    </x.div>\n  </>\n)\n\nconst TagPage = (props) => {\n  const Template = props.template || DefaultTemplate\n  const hasMounted = useHasMounted()\n  const downMd = useDown('md')\n  setPageType('section')\n  useEffect(\n    () => {\n      if (('/' + props.section) === props.location.pathname) {\n        props.sectionPageView(props.location.pathname, props.section, props.visitorId, props.sessionId, props.app.firstRender)\n      }\n    },\n    [props.section]\n  )\n  return (\n    <>\n      <x.main px={{ sm: '20px', wAdD: props.app.wallpaperActive ? '0px' : '200px' }} mt={{ sm: '96px', lg: props.app.wallpaperActive ? '0px' : '173px' }} w='100%' maxWidth={{ sm: '1260px', wAdD: props.app.wallpaperActive ? '1220px' : '1660px' }} mx='auto'>\n        <Ad isConnected={props.isConnected} adPath={props.adPath} slotId='interstitial' targeting={{ interstitial: 'interstitial' }} collapseEmptyDiv className='advert' anchor='interstitial' mapping={MAPPINGS.Interstitial} {...FORMATS.interstitial} />\n        <WingBanners isConnected={props.isConnected} adPath={props.adPath} location={props.location} mappingLeft={Wing} mappingRight={Wing} onSlotRenderEndedLeft={props.onSlotRenderEndedLeft} onSlotRenderEndedRight={props.onSlotRenderEndedRight} />\n        <Articles\n          {...props} noDiv isConnected loading={Skeleton} section={props.section} count={24} pageSize={16} withMore moreButtonColour='btn-red' noImage={NoImage} notFound={NotFound} component={Template}\n        />\n        {hasMounted && !downMd &&\n          <x.div mt={20} mb={50} mx={-20} textAlign='center' display='flex' justifyContent='center' alignItems='center' flexDirection='column'>\n            <Ad isConnected={props.isConnected} adPath={props.adPath} collapseEmptyDiv slotId='Leaderboard-bot' targeting={{ Leaderboard: 'bot' }} className='advert' mapping={Leaderboard} {...FORMATS.leaderboard} />\n          </x.div>}\n      </x.main>\n    </>\n  )\n}\n\nTagPage.defaultProps = {\n  component: DefaultTemplate,\n  section: 'tags/local-government-elections'\n}\nconst mapDispatchToProps = (dispatch) => bindActionCreators({ fetchArticles, fetchMoreArticles, sectionPageView }, dispatch)\n\nexport default withRouter(connect((state) => ({ app: state.app, articles: state.articles, visitorId: getVisitorId(state), sessionId: getSessionId(state) }), mapDispatchToProps)(TagPage))\n","import React from 'react'\nimport { getCanonical, getImageSize, getImage, getTeaser } from '../lib/articleUtils'\nimport { x, useDown } from '@xstyled/styled-components'\nimport { formatAgo } from '../lib/dateUtils'\nimport ImageOrNoImage from '../app/components/ui/Image'\nimport NoImage from '../../assets/images/general/no-image.png'\nimport StyledLink from '../app/components/ui/Link'\nimport Ad from '../app/components/Ad'\nimport { FORMATS } from '../app/components/AdFormats'\n\nconst OpinionArticles = ({ article, hoverColor, visitorId, sessionId, section, clickSource, color }) => {\n  return (\n    <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' alignItems='flex-start' spaceX={{ sm: '10px', lg: 'unset' }} flexDirection={{ sm: 'row', lg: 'column' }} justifyContent={{ sm: 'space-between', lg: 'unset' }} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource} color={color} hoverColor={hoverColor}>\n      <x.div position='relative' display='flex' justifyContent='center' alignItems='center'>\n        <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={getTeaser(article)} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n        <ImageOrNoImage image={getImage(article)} maxWidth={100} width={getImageSize('slider')} alt={getTeaser(article)} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n      </x.div>\n      <x.div mt={{ lg: '10px' }}>\n        <x.h5 text={{ sm: 'h6', lg: 'h5' }} mb={8}>{getTeaser(article)}</x.h5>\n        <x.p text='meta' color='meta' my={8}>By {article?.author} | Published {formatAgo(article.published, true)}</x.p>\n      </x.div>\n    </StyledLink>\n  )\n}\n\nconst Template = ({ articles, authorName, section, noImage, isConnected, sectionLabel, relatedSections, withReadCount, adPath, mapping, visitorId, sessionId, color, hoverColor, isOpinion }) => {\n  const clickSource = 'Six Article Deck'\n  return (\n    <x.div display={{ sm: '', lg: 'grid' }} gridTemplateColumns={{ sm: '', lg: 'calc(100% - 340px) 300px' }} gap={{ lg: '40' }} w='100%' mb={40}>\n      <x.div display={{ sm: '', lg: 'grid' }} gridTemplateColumns={{ sm: '', lg: 'repeat(3, calc((100% - 80px) / 3))' }} gap={{ lg: '40' }}>\n        {articles.map((article, index) => (\n          <x.article key={article.uuid} position='relative' className='divider-right-six' p={{ sm: '0 0 20px 0', lg: '0', lastType: '0' }} borderWidth={{ sm: '0 0 1px 0', lg: '0', lastType: '0' }} borderStyle='solid' borderColor='divider' mb={{ sm: '20px', lg: '0', last: '0' }}>\n            {!isOpinion &&\n              <StyledLink article={article} to={'/' + getCanonical(article)} display='flex' alignItems='flex-start' spaceX={{ sm: '10px', lg: 'unset' }} flexDirection={{ sm: 'row', lg: 'column-reverse' }} justifyContent={{ sm: 'space-between', lg: 'unset' }} visitorId={visitorId} sessionId={sessionId} section={section} source={clickSource} color={color} hoverColor={hoverColor}>\n                <x.div mt={{ lg: '10px' }}>\n                  <x.h5 text={{ sm: 'h6', lg: 'h5' }} mb={8}>{getTeaser(article)}</x.h5>\n                  <x.p text='meta' color='meta' my={8}>By {article?.author} | Published {formatAgo(article.published, true)}</x.p>\n                </x.div>\n                <x.div position='relative' display='flex' justifyContent='center' alignItems='center'>\n                  <ImageOrNoImage image={getImage(article)} w='auto' width={getImageSize('slider')} alt={getTeaser(article)} shape='16x9' display={{ sm: 'none', lg: 'block' }} visibility={{ sm: 'hidden', lg: 'visible' }} noImage={NoImage} />\n                  <ImageOrNoImage image={getImage(article)} maxWidth={50} width={getImageSize('slider')} alt={getTeaser(article)} shape='square' display={{ sm: 'block', lg: 'none' }} visibility={{ sm: 'visible', lg: 'hidden' }} noImage={NoImage} />\n                </x.div>\n              </StyledLink>}\n            {isOpinion &&\n              <OpinionArticles\n                article={article} hoverColor={hoverColor} visitorId={visitorId} sessionId={sessionId} section={section} clickSource={clickSource} color={color}\n              />}\n          </x.article>\n        ))}\n      </x.div>\n      <x.div textAlign='center' display='flex' justifyContent='flex-start' alignItems='center' flexDirection='column' p={{ sm: '20px', lg: '0' }} mt={{ sm: '40px', lg: '0' }}>\n        <Ad isConnected={isConnected} adPath={adPath} slotId='mpu600-bot' targeting={{ mpu600: 'bot' }} collapseEmptyDiv className='advert' mapping={mapping} {...FORMATS.mpu600} />\n      </x.div>\n    </x.div>\n  )\n}\n\nexport default Template\n","import React, { Component } from 'react'\nimport { x } from '@xstyled/styled-components'\n\nclass NotFound extends Component {\n  UNSAFE_componentWillMount () {\n    const { staticContext } = this.props\n    if (staticContext) {\n      staticContext.is404 = true\n    }\n  }\n\n  render () {\n    const props = this.props\n    return (\n      <>\n        <x.div w='100%' maxWidth={1220} mx='auto' my={50} borderWidth='0 0 1px 0' borderStyle='solid' borderColor='divider'>\n          <x.h1 text='h1' pb={20}>404 Page not found</x.h1>\n        </x.div>\n      </>\n    )\n  }\n}\n\nexport default NotFound\n","import React, { useCallback } from 'react'\nimport { x } from '@xstyled/styled-components'\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport { setWallPaperActive } from '../../store/app'\nimport Ad from '../components/Ad'\nimport {FORMATS, MAPPINGS} from './AdFormats'\nimport { useLocation } from 'react-router-dom'\n\nconst wallpaperMapping = [\n  [[1500, 0], [1, 1]],\n  [[1400, 0], [1, 1]],\n  [[1024, 0], []],\n  [[640, 0], []],\n  [[0, 0], []]\n]\n\nconst WingBanners = ({ isConnected, adPath, mappingLeft, mappingRight, onSlotRenderEndedLeft, onSlotRenderEndedRight, wallpaperActive, setWallPaperActive }) => {\n  const handleWallpaperLoaded = useCallback((e) => {\n    setWallPaperActive(!e.isEmpty)\n  })\n  const { pathname } = useLocation()\n  return (\n    <>\n      <x.section w='100vw' h='100%' position='absolute' left='50%' mt={20} top='0' transform='translateX(-50%)' zIndex='1' display={wallpaperActive ? 'none' : 'block'} visibility={wallpaperActive ? 'hidden' : 'visible'}>\n        {/* Only request Wallpapers on the home page */}\n        {(pathname === '/' || pathname === '/business' || pathname.startsWith('/business-report')) && process.env.RAZZLE_ENABLE_WALLPAPER &&\n          <Ad isConnected={isConnected} adPath={adPath} collapseEmptyDiv slotId='wallpaper' targeting={{ Wallpaper: '1' }} mapping={wallpaperMapping} className='wallpaper-advert' {...FORMATS.wallpaper} onSlotRenderEnded={handleWallpaperLoaded} />}\n        <x.div position='absolute' left={20} top={0} display={{ wAdM: 'none', wAdD: 'block' }} h='100%'>\n          <x.div position='sticky' top={20}>\n            <Ad isConnected={isConnected} adPath={adPath} slotId='Wingbanner-Left' targeting={{ Wingbanner: 'Left' }} onSlotRenderEnded={onSlotRenderEndedLeft} collapseEmptyDiv mapping={mappingLeft} {...FORMATS.wingbanner} />\n          </x.div>\n        </x.div>\n        <x.div position='absolute' right={20} top={0} display={{ wAdM: 'none', wAdD: 'block' }} h='100%'>\n          <x.div position='sticky' top={20}>\n            <Ad isConnected={isConnected} adPath={adPath} slotId='Wingbanner-Right' targeting={{ Wingbanner: 'Right' }} onSlotRenderEnded={onSlotRenderEndedRight} collapseEmptyDiv mapping={mappingRight} {...FORMATS.wingbanner} />\n          </x.div>\n        </x.div>\n      </x.section>\n    </>\n  )\n}\n\nconst mapStateToProps = (state) => (state.app)\nconst mapDispatchToProps = (dispatch) => bindActionCreators({ setWallPaperActive }, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(WingBanners)\n","import React from 'react'\n// import React, { Fragment } from 'react'\n// import ArticleCard from '../../app/components/ArticleCard'\n// import SectionPageHighlight from './SectionPageHighlight'\n// import Ad from '../components/Ad'\n// import FORMATS from '../../app/components/AdFormats'\n// import TrendsBar from '../../app/components/TrendsBar'\n\nconst Default = ({ articles, authorName, section, noImage, isConnected, sectionLabel, moreButton, relatedSections, withReadCount, adPath }) => {\n  return (\n    <div>Section Page Highlight goes here....</div>)\n}\n\nexport default Default\n"],"sourceRoot":""}