{"version":3,"sources":["webpack:///./src/helpers/media.ts","webpack:///./node_modules/cookie/index.js","webpack:///./src/stories/Components/Buttons/LinkButton/LinkButton.tsx","webpack:///./src/helpers/brand.ts","webpack:///./src/helpers/cssVar.ts","webpack:///./src/img/icons/clover-green.svg","webpack:///./src/stories/Widgets/NotificationBanner/NotificationBanner.styles.ts","webpack:///./src/stories/Widgets/NotificationBanner/NotificationBanner.tsx","webpack:///./src/helpers/fonts.ts","webpack:///./node_modules/universal-cookie/es6/utils.js","webpack:///./node_modules/universal-cookie/es6/Cookies.js","webpack:///./node_modules/react-cookie/es6/Cookies.js","webpack:///./node_modules/react-cookie/es6/CookiesContext.js","webpack:///./node_modules/react-cookie/es6/useCookies.js","webpack:///./node_modules/react-cookie/es6/utils.js","webpack:///./src/img/icons/close.svg","webpack:///./src/stories/Components/Buttons/LinkButton/LinkButton.styles.ts","webpack:///./src/helpers/animation.ts","webpack:///./src/stories/Components/Buttons/ButtonShared.styles.ts"],"names":["Device","from","size","until","between","start","end","exports","parse","str","options","TypeError","obj","opt","pairs","split","pairSplitRegExp","dec","decode","i","length","pair","eq_idx","indexOf","key","substr","trim","val","slice","undefined","tryDecode","serialize","name","enc","encode","fieldContentRegExp","test","value","maxAge","isNaN","isFinite","Math","floor","domain","path","expires","toUTCString","httpOnly","secure","sameSite","toLowerCase","decodeURIComponent","encodeURIComponent","e","LinkButton","className","icon","themeOption","title","otherProps","iconComponent","React","createElement","SBS","as","href","S","Button","black","white","grey","greyLight","greyVeryLight","pending","hta","green","greenAlt","greenDark","greenLight","purple","tableBg","htaRebrand","greenLightAlt","greenBright","apl","hortHouse","greyMid","orange","rss","validation","error","warning","success","cssVar","setCssVar","Container","styled","section","transition","brand","LinkButtonStyles","buttonTheme","bgColor","borderColor","fgColor","NotificationBar","div","TabletLarge","NotificationInner","NotificationGrid","NotificationTextArea","Tablet","NotificationIcon","NotificationText","p","NotificationCtaArea","NotificationClose","button","Clover","img","NotificationBannerStyles","Close","SvgClose","NotificationBanner","id","HTASvgClover","notification","cookies","setCookie","useCookies","text","cta","src","role","url","type","ctaTheme","target","onClick","sourceSansPro","light","css","lightItalic","regular","regularItalic","medium","mediumItalic","semiBold","semiBoldItalic","bold","boldItalic","readCookie","cleanValue","cleanupCookieValue","doNotParse","isParsingCookie","JSON","__assign","Object","assign","t","s","n","arguments","prototype","hasOwnProperty","call","apply","this","Cookies","_this","changeListeners","HAS_DOCUMENT_COOKIE","cookie","parseCookies","Promise","document","catch","_updateBrowserValues","parseOptions","_emitChange","params","get","getAll","result","name_1","set","_a","stringify","remove","finalOptions","Date","addChangeListener","callback","push","removeChangeListener","idx","splice","CookiesContext","Provider","Consumer","dependencies","Error","initialCookies","allCookies","setCookies","previousCookiesRef","window","onChange","newCookies","oldCookies","_i","dependencies_1","dependency","shouldUpdate","current","bind","_g","_extends","source","props","xmlns","viewBox","fill","stroke","strokeLinecap","strokeWidth","d","a","sharedButtonStyles","rgba","inView","threshold","rootMargin","earlyRootMargin","globalThreshold","easeInOutCubic","fadeIn","animate","duration","delay","easingFunc","properties","timing","theme","Icon","MobileLarge","span","Text","fonts"],"mappings":"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","file":"NotificationBanner-4342cf38b08c2ec0ff36.js","sourcesContent":["export var Device;\r\n(function (Device) {\r\n Device[Device[\"MobileSmall\"] = 320] = \"MobileSmall\";\r\n Device[Device[\"Mobile\"] = 375] = \"Mobile\";\r\n Device[Device[\"MobileLarge\"] = 480] = \"MobileLarge\";\r\n Device[Device[\"TabletSmall\"] = 568] = \"TabletSmall\";\r\n Device[Device[\"Tablet\"] = 768] = \"Tablet\";\r\n Device[Device[\"TabletLarge\"] = 1024] = \"TabletLarge\";\r\n Device[Device[\"DesktopSmall\"] = 1280] = \"DesktopSmall\";\r\n Device[Device[\"Desktop\"] = 1366] = \"Desktop\";\r\n Device[Device[\"DesktopMedium\"] = 1440] = \"DesktopMedium\";\r\n Device[Device[\"DesktopLarge\"] = 1600] = \"DesktopLarge\";\r\n Device[Device[\"ActualDesktop\"] = 1920] = \"ActualDesktop\";\r\n Device[Device[\"DesktopXL\"] = 2560] = \"DesktopXL\";\r\n})(Device || (Device = {}));\r\nexport function from(size) {\r\n return `(min-width: ${size}px)`;\r\n}\r\nexport function until(size) {\r\n return `(max-width: ${size - 1}px)`;\r\n}\r\nexport function between(start, end) {\r\n return `${from(start)} and ${until(end)}`;\r\n}\r\n","/*!\n * cookie\n * Copyright(c) 2012-2014 Roman Shtylman\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module exports.\n * @public\n */\n\nexports.parse = parse;\nexports.serialize = serialize;\n\n/**\n * Module variables.\n * @private\n */\n\nvar decode = decodeURIComponent;\nvar encode = encodeURIComponent;\nvar pairSplitRegExp = /; */;\n\n/**\n * RegExp to match field-content in RFC 7230 sec 3.2\n *\n * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]\n * field-vchar = VCHAR / obs-text\n * obs-text = %x80-FF\n */\n\nvar fieldContentRegExp = /^[\\u0009\\u0020-\\u007e\\u0080-\\u00ff]+$/;\n\n/**\n * Parse a cookie header.\n *\n * Parse the given cookie header string into an object\n * The object has the various cookies as keys(names) => values\n *\n * @param {string} str\n * @param {object} [options]\n * @return {object}\n * @public\n */\n\nfunction parse(str, options) {\n if (typeof str !== 'string') {\n throw new TypeError('argument str must be a string');\n }\n\n var obj = {}\n var opt = options || {};\n var pairs = str.split(pairSplitRegExp);\n var dec = opt.decode || decode;\n\n for (var i = 0; i < pairs.length; i++) {\n var pair = pairs[i];\n var eq_idx = pair.indexOf('=');\n\n // skip things that don't look like key=value\n if (eq_idx < 0) {\n continue;\n }\n\n var key = pair.substr(0, eq_idx).trim()\n var val = pair.substr(++eq_idx, pair.length).trim();\n\n // quoted values\n if ('\"' == val[0]) {\n val = val.slice(1, -1);\n }\n\n // only assign once\n if (undefined == obj[key]) {\n obj[key] = tryDecode(val, dec);\n }\n }\n\n return obj;\n}\n\n/**\n * Serialize data into a cookie header.\n *\n * Serialize the a name value pair into a cookie string suitable for\n * http headers. An optional options object specified cookie parameters.\n *\n * serialize('foo', 'bar', { httpOnly: true })\n * => \"foo=bar; httpOnly\"\n *\n * @param {string} name\n * @param {string} val\n * @param {object} [options]\n * @return {string}\n * @public\n */\n\nfunction serialize(name, val, options) {\n var opt = options || {};\n var enc = opt.encode || encode;\n\n if (typeof enc !== 'function') {\n throw new TypeError('option encode is invalid');\n }\n\n if (!fieldContentRegExp.test(name)) {\n throw new TypeError('argument name is invalid');\n }\n\n var value = enc(val);\n\n if (value && !fieldContentRegExp.test(value)) {\n throw new TypeError('argument val is invalid');\n }\n\n var str = name + '=' + value;\n\n if (null != opt.maxAge) {\n var maxAge = opt.maxAge - 0;\n\n if (isNaN(maxAge) || !isFinite(maxAge)) {\n throw new TypeError('option maxAge is invalid')\n }\n\n str += '; Max-Age=' + Math.floor(maxAge);\n }\n\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError('option domain is invalid');\n }\n\n str += '; Domain=' + opt.domain;\n }\n\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError('option path is invalid');\n }\n\n str += '; Path=' + opt.path;\n }\n\n if (opt.expires) {\n if (typeof opt.expires.toUTCString !== 'function') {\n throw new TypeError('option expires is invalid');\n }\n\n str += '; Expires=' + opt.expires.toUTCString();\n }\n\n if (opt.httpOnly) {\n str += '; HttpOnly';\n }\n\n if (opt.secure) {\n str += '; Secure';\n }\n\n if (opt.sameSite) {\n var sameSite = typeof opt.sameSite === 'string'\n ? opt.sameSite.toLowerCase() : opt.sameSite;\n\n switch (sameSite) {\n case true:\n str += '; SameSite=Strict';\n break;\n case 'lax':\n str += '; SameSite=Lax';\n break;\n case 'strict':\n str += '; SameSite=Strict';\n break;\n case 'none':\n str += '; SameSite=None';\n break;\n default:\n throw new TypeError('option sameSite is invalid');\n }\n }\n\n return str;\n}\n\n/**\n * Try decoding a string using a decoding function.\n *\n * @param {string} str\n * @param {function} decode\n * @private\n */\n\nfunction tryDecode(str, decode) {\n try {\n return decode(str);\n } catch (e) {\n return str;\n }\n}\n","import React from 'react';\r\nimport * as SBS from '../ButtonShared.styles';\r\nimport S from './LinkButton.styles';\r\nconst LinkButton = ({ className, icon, themeOption = 'green', title, ...otherProps }) => {\r\n let iconComponent;\r\n if (typeof icon === 'string') {\r\n iconComponent = (React.createElement(SBS.Icon, { as: \"svg\", \"aria-label\": title },\r\n React.createElement(\"use\", { href: icon })));\r\n }\r\n else if (typeof icon !== 'undefined') {\r\n iconComponent = React.createElement(SBS.Icon, { as: icon, \"aria-label\": title });\r\n }\r\n else {\r\n iconComponent = undefined;\r\n }\r\n return (React.createElement(S.Button, { className: className, themeOption: themeOption, ...otherProps },\r\n React.createElement(SBS.Text, null, title),\r\n iconComponent));\r\n};\r\nexport default LinkButton;\r\n","export default {\r\n // SHARED\r\n black: '#121212',\r\n white: '#FFFFFF',\r\n grey: '#555658',\r\n greyLight: '#93958F',\r\n greyVeryLight: '#F2F2F2',\r\n pending: '#FCE1C0',\r\n // HTA\r\n hta: {\r\n green: '#8FB433',\r\n greenAlt: '#6F8B27',\r\n greenDark: '#206142',\r\n greenLight: '#DCE8BF',\r\n purple: '#602366',\r\n tableBg: '#EEF1E9',\r\n },\r\n // HTA rebrand\r\n htaRebrand: {\r\n green: '#206142',\r\n greenAlt: '#8FB433',\r\n greenDark: '#14432C',\r\n greenLight: '#559677',\r\n greenLightAlt: '#628D78',\r\n greenBright: '#66B429',\r\n purple: '#602366',\r\n },\r\n // APL\r\n apl: {\r\n green: '#66BC29',\r\n greenAlt: '#56A022',\r\n greenLight: '#BAE19F',\r\n },\r\n // HORT HOUSE\r\n hortHouse: {\r\n green: '#8FB433',\r\n greenAlt: '#6F8B27',\r\n greenDark: '#4D7F42',\r\n greenLight: '#DCE8BF',\r\n greyMid: '#747474',\r\n orange: '#EB7820',\r\n },\r\n // RSS\r\n rss: {\r\n green: '#95C11F',\r\n greenDark: '#688816',\r\n greenLight: '#D1EA8D',\r\n grey: '#333333',\r\n greyLight: '#464646',\r\n },\r\n validation: {\r\n error: '#d90000',\r\n warning: '#e06e1b',\r\n success: '#56a022',\r\n },\r\n};\r\n","const variables = [\r\n 'fgColor',\r\n 'fgColorAlt',\r\n 'bgColor',\r\n 'bgColorAlt',\r\n 'accentColor',\r\n 'accentColorAlt',\r\n 'accentColor2',\r\n 'siteWidth',\r\n 'sitePadding',\r\n 'sectionMargin',\r\n 'buttonBgColor',\r\n 'buttonBorderColor',\r\n 'buttonColor',\r\n];\r\nfunction cssVar(name) {\r\n return `var(--${name})`;\r\n}\r\nfunction setCssVar(name, value) {\r\n return `--${name}: ${value}`;\r\n}\r\nexport { cssVar, setCssVar };\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgCloverGreen(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 348.25 280.779\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 822\",\n d: \"M211.832 280.779c-15.676-18.351-28.317-68.157-28.844-76.726-.3-4.823-2.22-16.41 2.212-23.957 27.059 21.3 23.949 54.11 48.78 77.173 12.421 10.645 38.662 10.888 48.784 8.864 11.643-2.328 32.154-9.527 34.37-43.154 2.26-34.37 40.123-46.592 29.112-87.5-3.877-14.414-11.088-29.383-42.184-32.981-37.368-4.336-55.436 21.725-82.052 38.135-9.75 5.322-19.948 13.747-30.593 11.531 16.842-38.135 63.25-42.148 75.831-71.846 7.383-17.444 9.982-35.185-3.993-55.871S228.49-6.379 195.462 4.3c-9.691 3.134-11.367 5.267-21.337 4.712S162.481 7.436 152.779 4.3c-33.025-10.679-53.823-.541-67.79 20.15s-11.387 38.427-4 55.871c12.585 29.7 58.986 33.711 75.827 71.846-10.633 2.216-20.834-6.209-30.585-11.531-26.604-16.41-44.672-42.471-82.044-38.136-31.1 3.6-38.3 18.567-42.184 32.981-11.008 40.906 26.843 53.128 29.107 87.5 2.212 33.627 22.727 40.826 34.362 43.154 10.126 2.024 36.366 1.781 48.788-8.864 24.831-23.063 21.725-55.875 48.78-77.173 4.432 7.547 2.519 19.134 2.216 23.957-.527 8.569-13.168 58.375-28.844 76.726z\",\n fill: \"#8FB433\"\n })));\n}\n\nexport default __webpack_public_path__ + \"ce0d41400e71b231263db52be457602e.svg\";\nexport { SvgCloverGreen as ReactComponent };","import { transition } from '@helpers/animation';\r\nimport brand from '@helpers/brand';\r\nimport { cssVar, setCssVar } from '@helpers/cssVar';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { ReactComponent as SvgClose } from '@img/icons/close.svg';\r\nimport { buttonTheme } from '@stories/Components/Buttons/ButtonShared.styles';\r\nimport LinkButtonStyles from '@stories/Components/Buttons/LinkButton/LinkButton.styles';\r\nimport styled from 'styled-components';\r\nconst Container = styled.section `\r\n ${transition('max-height', 1)};\r\n\r\n max-height: 100vh;\r\n background-color: ${brand.white};\r\n position: relative;\r\n\r\n .theme-hh & {\r\n background-color: ${brand.grey};\r\n }\r\n\r\n .theme-rss & {\r\n background-color: ${brand.black};\r\n }\r\n\r\n &[data-cookie='true'] {\r\n max-height: 0;\r\n }\r\n\r\n .theme-hta & {\r\n ${() => LinkButtonStyles.Button} {\r\n ${buttonTheme({\r\n bgColor: brand.hta.green,\r\n borderColor: brand.hta.green,\r\n fgColor: brand.black,\r\n})}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.hta.greenLight,\r\n borderColor: brand.hta.greenLight,\r\n fgColor: brand.black,\r\n})}\r\n }\r\n\r\n &:active {\r\n ${buttonTheme({\r\n bgColor: brand.hta.green,\r\n borderColor: brand.hta.green,\r\n fgColor: brand.black,\r\n})}\r\n }\r\n }\r\n }\r\n`;\r\nconst NotificationBar = styled.div `\r\n ${transition('opacity')};\r\n\r\n width: 100%;\r\n padding: 1px 0;\r\n\r\n ${Container}[data-cookie='true'] & {\r\n opacity: 0;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n margin: 5px;\r\n width: calc(100% - 10px);\r\n }\r\n\r\n .theme-hh & {\r\n background-color: ${brand.grey};\r\n }\r\n`;\r\nconst NotificationInner = styled.div `\r\n background-color: ${cssVar('bgColor')};\r\n color: ${cssVar('fgColor')};\r\n margin: 12px auto;\r\n max-width: 1100px;\r\n min-height: 68px;\r\n padding: 10px;\r\n border-radius: 10px;\r\n box-shadow: 0px 5px 20px 4px rgba(0, 0, 0, 0.2);\r\n pointer-events: all;\r\n display: flex;\r\n align-content: center;\r\n align-items: center;\r\n justify-content: space-evenly;\r\n\r\n ${setCssVar('bgColor', brand.hta.greenDark)};\r\n ${setCssVar('fgColor', brand.white)};\r\n\r\n .theme-apl & {\r\n ${setCssVar('bgColor', brand.apl.green)};\r\n ${setCssVar('fgColor', brand.black)};\r\n\r\n ${LinkButtonStyles.Button} {\r\n background: ${brand.white};\r\n color: ${brand.black};\r\n }\r\n }\r\n\r\n .theme-hh & {\r\n ${setCssVar('bgColor', brand.hortHouse.green)};\r\n ${setCssVar('fgColor', brand.white)};\r\n\r\n ${LinkButtonStyles.Button} {\r\n background: ${brand.white};\r\n color: ${brand.grey};\r\n }\r\n }\r\n\r\n .theme-rss & {\r\n ${setCssVar('bgColor', brand.rss.greyLight)};\r\n ${setCssVar('fgColor', brand.white)};\r\n }\r\n`;\r\nconst NotificationGrid = styled.div `\r\n width: 100%;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n flex-direction: column;\r\n\r\n ${LinkButtonStyles.Button} {\r\n height: auto;\r\n padding-top: 5px;\r\n padding-bottom: 5px;\r\n }\r\n }\r\n`;\r\nconst NotificationTextArea = styled.div `\r\n display: flex;\r\n gap: 20px;\r\n justify-content: center;\r\n align-items: center;\r\n padding: 0 20px;\r\n margin: auto;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding-bottom: 10px;\r\n padding-right: 35px;\r\n }\r\n\r\n span {\r\n @media ${until(Device.TabletLarge)} {\r\n display: block;\r\n margin: 0 auto;\r\n }\r\n }\r\n\r\n a {\r\n min-width: 160px;\r\n }\r\n\r\n @media ${until(Device.Tablet)} {\r\n flex-direction: column;\r\n }\r\n`;\r\nconst NotificationIcon = styled.div ``;\r\nconst NotificationText = styled.p `\r\n text-align: left;\r\n font-size: 16px;\r\n line-height: 22px;\r\n font-weight: 600;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 18px;\r\n line-height: 24px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n }\r\n\r\n @media ${until(Device.Tablet)} {\r\n text-align: center;\r\n }\r\n`;\r\nconst NotificationCtaArea = styled.div `\r\n @media ${from(Device.TabletLarge)} {\r\n display: flex;\r\n align-items: center;\r\n }\r\n`;\r\nconst NotificationClose = styled.button `\r\n background-color: transparent;\r\n border: none;\r\n color: ${brand.white};\r\n margin: 0 30px 0 40px;\r\n line-height: 0;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n position: absolute;\r\n right: 10px;\r\n top: 20px;\r\n margin: 0;\r\n }\r\n`;\r\nconst Clover = styled.img `\r\n width: 100%;\r\n max-width: 30px;\r\n height: 25px;\r\n\r\n svg {\r\n width: 100%;\r\n height: 100%;\r\n }\r\n\r\n .theme-hh & {\r\n color: ${brand.grey};\r\n }\r\n`;\r\nconst Close = styled(SvgClose) `\r\n height: 25px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n height: 15px;\r\n }\r\n .theme-apl & {\r\n color: ${brand.black};\r\n }\r\n`;\r\nconst NotificationBannerStyles = {\r\n Container,\r\n NotificationBar,\r\n NotificationClose,\r\n NotificationCtaArea,\r\n NotificationGrid,\r\n NotificationInner,\r\n NotificationIcon,\r\n NotificationText,\r\n NotificationTextArea,\r\n Close,\r\n Clover,\r\n};\r\nexport default NotificationBannerStyles;\r\n","import HTASvgClover from '@img/icons/clover-green.svg?url';\r\nimport LinkButton from '@stories/Components/Buttons/LinkButton/LinkButton';\r\nimport * as React from 'react';\r\nimport { useCookies } from 'react-cookie';\r\nimport S from './NotificationBanner.styles';\r\nconst NotificationBanner = ({ id, icon = HTASvgClover, notification, }) => {\r\n const [cookies, setCookie] = useCookies();\r\n if (!notification) {\r\n return null;\r\n }\r\n const { text, cta } = notification;\r\n return (React.createElement(S.Container, { \"data-cookie\": cookies[`cookieNotificationSet-${id}`] ? true : false },\r\n React.createElement(S.NotificationBar, null,\r\n React.createElement(S.NotificationInner, null,\r\n React.createElement(S.NotificationGrid, null,\r\n React.createElement(S.NotificationTextArea, null,\r\n React.createElement(S.NotificationIcon, null,\r\n ' ',\r\n React.createElement(S.Clover, { src: icon, role: \"presentation\" })),\r\n React.createElement(S.NotificationText, null,\r\n React.createElement(\"span\", null, text)),\r\n cta?.text && cta?.url && (React.createElement(LinkButton, { type: \"button\", themeOption: notification.ctaTheme, title: cta.text, href: cta.url, target: cta.target }))),\r\n React.createElement(S.NotificationCtaArea, null,\r\n React.createElement(S.NotificationClose, { type: \"button\", onClick: () => setCookie(`cookieNotificationSet-${id}`, true, { path: '/' }) },\r\n React.createElement(S.Close, null))))))));\r\n};\r\nexport default NotificationBanner;\r\n","import { css } from 'styled-components';\r\nexport default {\r\n sourceSansPro: {\r\n light: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-style: normal;\r\n font-weight: 300;\r\n `,\r\n lightItalic: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-weight: 300;\r\n font-style: italic;\r\n `,\r\n regular: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-style: normal;\r\n font-weight: 400;\r\n `,\r\n regularItalic: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-weight: 400;\r\n font-style: italic;\r\n `,\r\n medium: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-style: normal;\r\n font-weight: 500;\r\n `,\r\n mediumItalic: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-weight: 500;\r\n font-style: italic;\r\n `,\r\n semiBold: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-style: normal;\r\n font-weight: 600;\r\n `,\r\n semiBoldItalic: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-weight: 600;\r\n font-style: italic;\r\n `,\r\n bold: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-style: normal;\r\n font-weight: 700;\r\n `,\r\n boldItalic: css `\r\n font-family: 'Source Sans Pro', sans-serif;\r\n font-weight: 700;\r\n font-style: italic;\r\n `,\r\n },\r\n};\r\n","import * as cookie from 'cookie';\r\nexport function hasDocumentCookie() {\r\n // Can we get/set cookies on document.cookie?\r\n return typeof document === 'object' && typeof document.cookie === 'string';\r\n}\r\nexport function cleanCookies() {\r\n document.cookie.split(';').forEach(function (c) {\r\n document.cookie = c\r\n .replace(/^ +/, '')\r\n .replace(/=.*/, '=;expires=' + new Date().toUTCString() + ';path=/');\r\n });\r\n}\r\nexport function parseCookies(cookies, options) {\r\n if (typeof cookies === 'string') {\r\n return cookie.parse(cookies, options);\r\n }\r\n else if (typeof cookies === 'object' && cookies !== null) {\r\n return cookies;\r\n }\r\n else {\r\n return {};\r\n }\r\n}\r\nexport function isParsingCookie(value, doNotParse) {\r\n if (typeof doNotParse === 'undefined') {\r\n // We guess if the cookie start with { or [, it has been serialized\r\n doNotParse =\r\n !value || (value[0] !== '{' && value[0] !== '[' && value[0] !== '\"');\r\n }\r\n return !doNotParse;\r\n}\r\nexport function readCookie(value, options) {\r\n if (options === void 0) { options = {}; }\r\n var cleanValue = cleanupCookieValue(value);\r\n if (isParsingCookie(cleanValue, options.doNotParse)) {\r\n try {\r\n return JSON.parse(cleanValue);\r\n }\r\n catch (e) {\r\n // At least we tried\r\n }\r\n }\r\n // Ignore clean value if we failed the deserialization\r\n // It is not relevant anymore to trim those values\r\n return value;\r\n}\r\nfunction cleanupCookieValue(value) {\r\n // express prepend j: before serializing a cookie\r\n if (value && value[0] === 'j' && value[1] === ':') {\r\n return value.substr(2);\r\n }\r\n return value;\r\n}\r\n","var __assign = (this && this.__assign) || function () {\r\n __assign = Object.assign || function(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\r\n t[p] = s[p];\r\n }\r\n return t;\r\n };\r\n return __assign.apply(this, arguments);\r\n};\r\nimport * as cookie from 'cookie';\r\nimport { hasDocumentCookie, parseCookies, readCookie } from './utils';\r\nvar Cookies = /** @class */ (function () {\r\n function Cookies(cookies, options) {\r\n var _this = this;\r\n this.changeListeners = [];\r\n this.HAS_DOCUMENT_COOKIE = false;\r\n this.cookies = parseCookies(cookies, options);\r\n new Promise(function () {\r\n _this.HAS_DOCUMENT_COOKIE = hasDocumentCookie();\r\n }).catch(function () { });\r\n }\r\n Cookies.prototype._updateBrowserValues = function (parseOptions) {\r\n if (!this.HAS_DOCUMENT_COOKIE) {\r\n return;\r\n }\r\n this.cookies = cookie.parse(document.cookie, parseOptions);\r\n };\r\n Cookies.prototype._emitChange = function (params) {\r\n for (var i = 0; i < this.changeListeners.length; ++i) {\r\n this.changeListeners[i](params);\r\n }\r\n };\r\n Cookies.prototype.get = function (name, options, parseOptions) {\r\n if (options === void 0) { options = {}; }\r\n this._updateBrowserValues(parseOptions);\r\n return readCookie(this.cookies[name], options);\r\n };\r\n Cookies.prototype.getAll = function (options, parseOptions) {\r\n if (options === void 0) { options = {}; }\r\n this._updateBrowserValues(parseOptions);\r\n var result = {};\r\n for (var name_1 in this.cookies) {\r\n result[name_1] = readCookie(this.cookies[name_1], options);\r\n }\r\n return result;\r\n };\r\n Cookies.prototype.set = function (name, value, options) {\r\n var _a;\r\n if (typeof value === 'object') {\r\n value = JSON.stringify(value);\r\n }\r\n this.cookies = __assign(__assign({}, this.cookies), (_a = {}, _a[name] = value, _a));\r\n if (this.HAS_DOCUMENT_COOKIE) {\r\n document.cookie = cookie.serialize(name, value, options);\r\n }\r\n this._emitChange({ name: name, value: value, options: options });\r\n };\r\n Cookies.prototype.remove = function (name, options) {\r\n var finalOptions = (options = __assign(__assign({}, options), { expires: new Date(1970, 1, 1, 0, 0, 1), maxAge: 0 }));\r\n this.cookies = __assign({}, this.cookies);\r\n delete this.cookies[name];\r\n if (this.HAS_DOCUMENT_COOKIE) {\r\n document.cookie = cookie.serialize(name, '', finalOptions);\r\n }\r\n this._emitChange({ name: name, value: undefined, options: options });\r\n };\r\n Cookies.prototype.addChangeListener = function (callback) {\r\n this.changeListeners.push(callback);\r\n };\r\n Cookies.prototype.removeChangeListener = function (callback) {\r\n var idx = this.changeListeners.indexOf(callback);\r\n if (idx >= 0) {\r\n this.changeListeners.splice(idx, 1);\r\n }\r\n };\r\n return Cookies;\r\n}());\r\nexport default Cookies;\r\n","import Cookies from 'universal-cookie';\r\nexport default Cookies;\r\n","import * as React from 'react';\r\nimport Cookies from './Cookies';\r\nvar CookiesContext = React.createContext(new Cookies());\r\nexport var Provider = CookiesContext.Provider, Consumer = CookiesContext.Consumer;\r\nexport default CookiesContext;\r\n","import { useContext, useLayoutEffect, useState, useRef, useMemo } from 'react';\r\nimport CookiesContext from './CookiesContext';\r\nimport { isInBrowser } from './utils';\r\nexport default function useCookies(dependencies) {\r\n var cookies = useContext(CookiesContext);\r\n if (!cookies) {\r\n throw new Error('Missing ');\r\n }\r\n var initialCookies = cookies.getAll();\r\n var _a = useState(initialCookies), allCookies = _a[0], setCookies = _a[1];\r\n var previousCookiesRef = useRef(allCookies);\r\n if (isInBrowser()) {\r\n useLayoutEffect(function () {\r\n function onChange() {\r\n var newCookies = cookies.getAll();\r\n if (shouldUpdate(dependencies || null, newCookies, previousCookiesRef.current)) {\r\n setCookies(newCookies);\r\n }\r\n previousCookiesRef.current = newCookies;\r\n }\r\n cookies.addChangeListener(onChange);\r\n return function () {\r\n cookies.removeChangeListener(onChange);\r\n };\r\n }, [cookies]);\r\n }\r\n var setCookie = useMemo(function () { return cookies.set.bind(cookies); }, [cookies]);\r\n var removeCookie = useMemo(function () { return cookies.remove.bind(cookies); }, [cookies]);\r\n return [allCookies, setCookie, removeCookie];\r\n}\r\nfunction shouldUpdate(dependencies, newCookies, oldCookies) {\r\n if (!dependencies) {\r\n return true;\r\n }\r\n for (var _i = 0, dependencies_1 = dependencies; _i < dependencies_1.length; _i++) {\r\n var dependency = dependencies_1[_i];\r\n if (newCookies[dependency] !== oldCookies[dependency]) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n}\r\n","export function isInBrowser() {\r\n return (typeof window !== 'undefined' &&\r\n typeof window.document !== 'undefined' &&\r\n typeof window.document.createElement !== 'undefined');\r\n}\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgClose(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 26.828 26.828\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 32870\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeLinecap: \"round\",\n strokeWidth: 2\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 7\",\n d: \"M1.414 1.414l24 24\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 8\",\n d: \"M1.414 25.414l24-24\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"71d1993e1ce744719ca5bb5626276056.svg\";\nexport { SvgClose as ReactComponent };","import brand from '@helpers/brand';\r\nimport { rgba } from 'polished';\r\nimport styled, { css } from 'styled-components';\r\nimport { buttonTheme, sharedButtonStyles } from '../ButtonShared.styles';\r\nconst Button = styled.a `\r\n ${sharedButtonStyles};\r\n\r\n ${({ themeOption }) => themeOption === 'green' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.green,\r\n borderColor: brand.htaRebrand.green,\r\n fgColor: brand.white,\r\n })}\r\n\r\n .theme-hh & {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenAlt,\r\n borderColor: brand.htaRebrand.greenAlt,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenLight,\r\n borderColor: brand.htaRebrand.greenLight,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n\r\n &:active {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenDark,\r\n borderColor: brand.htaRebrand.greenDark,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'greenOriginal' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: brand.hta.green,\r\n borderColor: brand.hta.green,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.hta.greenLight,\r\n borderColor: brand.hta.greenLight,\r\n fgColor: brand.black,\r\n })}\r\n }\r\n\r\n &:active {\r\n ${buttonTheme({\r\n bgColor: brand.hta.greenDark,\r\n borderColor: brand.hta.greenDark,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'greenOutline' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: rgba(brand.hta.green, 0),\r\n borderColor: brand.htaRebrand.green,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenLightAlt,\r\n borderColor: brand.htaRebrand.green,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n\r\n &:active {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenDark,\r\n borderColor: brand.htaRebrand.greenAlt,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'greenLightOutline' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: brand.white,\r\n borderColor: brand.htaRebrand.greenBright,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenLightAlt,\r\n borderColor: brand.htaRebrand.greenBright,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n\r\n &:active {\r\n ${buttonTheme({\r\n bgColor: brand.htaRebrand.greenDark,\r\n borderColor: brand.htaRebrand.greenBright,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'aplGreen' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: brand.apl.green,\r\n borderColor: brand.apl.green,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.apl.greenLight,\r\n borderColor: brand.apl.greenLight,\r\n fgColor: brand.black,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'aplGreenOutline' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: rgba(brand.apl.green, 0),\r\n borderColor: brand.apl.green,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: brand.apl.greenLight,\r\n borderColor: brand.apl.green,\r\n fgColor: brand.black,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'white' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: brand.white,\r\n borderColor: brand.white,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: '#383838',\r\n borderColor: brand.white,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'whiteOutline' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: rgba('#383838', 0),\r\n borderColor: brand.white,\r\n fgColor: brand.white,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: '#383838',\r\n borderColor: brand.white,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n\r\n ${({ themeOption }) => themeOption === 'blackOutline' &&\r\n css `\r\n ${buttonTheme({\r\n bgColor: rgba('#383838', 0),\r\n borderColor: brand.black,\r\n fgColor: brand.black,\r\n })}\r\n\r\n &:focus,\r\n &:hover {\r\n ${buttonTheme({\r\n bgColor: '#383838',\r\n borderColor: brand.black,\r\n fgColor: brand.white,\r\n })}\r\n }\r\n `}\r\n`;\r\nexport default {\r\n Button,\r\n};\r\n","import { css } from 'styled-components';\r\nexport default {\r\n inView: {\r\n threshold: 0.25,\r\n rootMargin: '0px 0px -25% 0px',\r\n earlyRootMargin: '0px 0px -10% 0px',\r\n },\r\n globalThreshold: 0.25,\r\n easeInOutCubic: 'cubic-bezier(0.645, 0.045, 0.355, 1)',\r\n};\r\nexport const slideInUpInitial = css `\r\n > span {\r\n opacity: 0;\r\n transform: translateY(100%);\r\n }\r\n`;\r\nexport function slideInUp(animate, duration, delay, easingFunc) {\r\n return css `\r\n overflow: hidden;\r\n\r\n > span {\r\n display: inline-block;\r\n transition: transform ${duration}ms ${delay}ms ${easingFunc},\r\n opacity ${duration}ms ${delay}ms ${easingFunc};\r\n }\r\n\r\n ${animate\r\n ? css `\r\n > span {\r\n opacity: 1;\r\n transform: translateY(0px);\r\n }\r\n `\r\n : css `\r\n ${slideInUpInitial};\r\n `}\r\n `;\r\n}\r\nexport function fadeInUp(animate, amount, duration, delay, easingFunc) {\r\n return css `\r\n transition: transform ${duration}ms ${delay}ms ${easingFunc},\r\n opacity ${duration}ms ${delay}ms ${easingFunc};\r\n\r\n ${animate\r\n ? css `\r\n opacity: 1;\r\n transform: translateY(0px);\r\n `\r\n : css `\r\n opacity: 0;\r\n transform: translateY(${amount}px);\r\n `}\r\n `;\r\n}\r\nexport function fadeIn(animate, duration, delay, easingFunc) {\r\n return css `\r\n transition: opacity ${duration}ms ${delay}ms ${easingFunc};\r\n\r\n ${animate\r\n ? css `\r\n opacity: 1;\r\n `\r\n : css `\r\n opacity: 0;\r\n `}\r\n `;\r\n}\r\nexport const cubicEaseOut = `cubic-bezier(0.215, 0.61, 0.355, 1)`;\r\nexport const transition = (properties, duration = 0.35, timing = cubicEaseOut) => css `\r\n transition-duration: ${typeof duration === 'string' ? duration : `${duration}s`};\r\n transition-property: ${properties};\r\n transition-timing-function: ${timing};\r\n will-change: ${properties};\r\n `;\r\n","import fonts from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nexport function buttonTheme(theme) {\r\n const value = css `\r\n ${theme.bgColor &&\r\n css `\r\n --buttonBgColor: ${theme.bgColor};\r\n `}\r\n\r\n ${theme.borderColor &&\r\n css `\r\n --buttonBorderColor: ${theme.borderColor};\r\n `}\r\n\r\n ${theme.fgColor &&\r\n css `\r\n --buttonColor: ${theme.fgColor};\r\n `}\r\n `;\r\n return value;\r\n}\r\nexport const sharedButtonStyles = css `\r\n display: inline-flex;\r\n align-items: center;\r\n border: 0;\r\n background-color: var(--buttonBgColor);\r\n border: 1px solid var(--buttonBorderColor);\r\n border-radius: 8px;\r\n color: var(--buttonColor);\r\n height: 48px;\r\n justify-content: flex-start;\r\n margin: 0;\r\n outline: none;\r\n padding: 0 14px;\r\n place-content: center;\r\n place-items: center;\r\n text-decoration: none;\r\n transition: background-color 0.15s ease-out, background-size 0.15s ease-out,\r\n border-color 0.15s ease-out, color 0.15s ease-out, opacity 0.15s ease-out,\r\n transform 0.15s ease-out;\r\n user-select: none;\r\n width: auto;\r\n\r\n &:disabled {\r\n opacity: 0.5;\r\n }\r\n\r\n &:focus {\r\n outline: none;\r\n }\r\n\r\n ${() => Icon} {\r\n margin-left: 12px;\r\n }\r\n\r\n @media ${from(Device.MobileLarge)} {\r\n min-width: 150px;\r\n padding: 0 24px;\r\n }\r\n`;\r\nexport const Icon = styled.span `\r\n display: block;\r\n height: 20px;\r\n width: 20px;\r\n\r\n @media ${from(Device.Tablet)} {\r\n height: 24px;\r\n width: 24px;\r\n }\r\n`;\r\nexport const Text = styled.span `\r\n color: currentColor;\r\n ${fonts.sourceSansPro.semiBold};\r\n font-size: 18px;\r\n line-height: 25px;\r\n`;\r\n"],"sourceRoot":""}