-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path546641dfde76ed00139ea2c3eae09499c5f2164a-d1bbded0aabcfd4cf393.js.map
1 lines (1 loc) · 427 KB
/
546641dfde76ed00139ea2c3eae09499c5f2164a-d1bbded0aabcfd4cf393.js.map
1
{"version":3,"file":"546641dfde76ed00139ea2c3eae09499c5f2164a-d1bbded0aabcfd4cf393.js","mappings":"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","sources":["webpack://v4/./node_modules/react-fast-compare/index.js","webpack://v4/./node_modules/react-helmet/es/Helmet.js","webpack://v4/./node_modules/react-side-effect/lib/index.js","webpack://v4/./node_modules/dom-helpers/esm/removeClass.js","webpack://v4/./node_modules/react-transition-group/esm/config.js","webpack://v4/./node_modules/react-transition-group/esm/utils/reflow.js","webpack://v4/./node_modules/react-transition-group/esm/Transition.js","webpack://v4/./node_modules/react-transition-group/esm/CSSTransition.js","webpack://v4/./node_modules/dom-helpers/esm/addClass.js","webpack://v4/./node_modules/dom-helpers/esm/hasClass.js","webpack://v4/./node_modules/react-transition-group/esm/utils/ChildMapping.js","webpack://v4/./node_modules/react-transition-group/esm/TransitionGroup.js","webpack://v4/./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","webpack://v4/./node_modules/react-transition-group/esm/TransitionGroupContext.js","webpack://v4/./src/components/icons/appstore.js","webpack://v4/./src/components/icons/bookmark.js","webpack://v4/./src/components/icons/codepen.js","webpack://v4/./src/components/icons/external.js","webpack://v4/./src/components/icons/folder.js","webpack://v4/./src/components/icons/fork.js","webpack://v4/./src/components/icons/icon.js","webpack://v4/./src/components/icons/github.js","webpack://v4/./src/components/icons/instagram.js","webpack://v4/./src/components/icons/linkedin.js","webpack://v4/./src/components/icons/loader.js","webpack://v4/./src/components/icons/logo.js","webpack://v4/./src/components/icons/playstore.js","webpack://v4/./src/components/icons/star.js","webpack://v4/./src/components/icons/twitter.js","webpack://v4/./src/components/icons/facebook.js","webpack://v4/./src/components/icons/kaggle.js","webpack://v4/./src/components/icons/stackoverflow.js","webpack://v4/./src/components/head.js","webpack://v4/./src/styles/mixins.js","webpack://v4/./src/styles/theme.js","webpack://v4/./src/styles/fonts.js","webpack://v4/./src/fonts/Calibre/Calibre-Regular.woff","webpack://v4/./src/fonts/Calibre/Calibre-Regular.woff2","webpack://v4/./src/fonts/Calibre/Calibre-Medium.woff","webpack://v4/./src/fonts/Calibre/Calibre-Medium.woff2","webpack://v4/./src/fonts/Calibre/Calibre-Semibold.woff","webpack://v4/./src/fonts/Calibre/Calibre-Semibold.woff2","webpack://v4/./src/fonts/Calibre/Calibre-RegularItalic.woff","webpack://v4/./src/fonts/Calibre/Calibre-RegularItalic.woff2","webpack://v4/./src/fonts/Calibre/Calibre-MediumItalic.woff","webpack://v4/./src/fonts/Calibre/Calibre-MediumItalic.woff2","webpack://v4/./src/fonts/Calibre/Calibre-SemiboldItalic.woff","webpack://v4/./src/fonts/Calibre/Calibre-SemiboldItalic.woff2","webpack://v4/./src/fonts/SFMono/SFMono-Regular.woff","webpack://v4/./src/fonts/SFMono/SFMono-Regular.woff2","webpack://v4/./src/fonts/SFMono/SFMono-Semibold.woff","webpack://v4/./src/fonts/SFMono/SFMono-Semibold.woff2","webpack://v4/./src/fonts/SFMono/SFMono-RegularItalic.woff","webpack://v4/./src/fonts/SFMono/SFMono-RegularItalic.woff2","webpack://v4/./src/fonts/SFMono/SFMono-SemiboldItalic.woff","webpack://v4/./src/fonts/SFMono/SFMono-SemiboldItalic.woff2","webpack://v4/./src/styles/variables.js","webpack://v4/./src/styles/TransitionStyles.js","webpack://v4/./src/styles/PrismStyles.js","webpack://v4/./src/styles/GlobalStyle.js","webpack://v4/./src/components/layout.js","webpack://v4/./node_modules/animejs/lib/anime.es.js","webpack://v4/./src/components/loader.js","webpack://v4/./src/components/nav.js","webpack://v4/./src/components/menu.js","webpack://v4/./src/components/side.js","webpack://v4/./src/components/social.js","webpack://v4/./src/components/email.js","webpack://v4/./src/components/footer.js","webpack://v4/./src/components/sections/hero.js","webpack://v4/./src/components/sections/about.js","webpack://v4/./src/components/sections/jobs.js","webpack://v4/./src/components/sections/contact.js","webpack://v4/./src/components/sections/featured.js","webpack://v4/./src/components/sections/projects.js","webpack://v4/./src/components/sections/education.js","webpack://v4/./src/components/sections/competitions.js","webpack://v4/./src/config.js","webpack://v4/./src/hooks/useOnClickOutside.js","webpack://v4/./src/hooks/usePrefersReducedMotion.js","webpack://v4/./src/hooks/useScrollDirection.js","webpack://v4/./src/utils/index.js","webpack://v4/./node_modules/is-dom-node/dist/is-dom-node.es.js","webpack://v4/./node_modules/is-dom-node-list/dist/is-dom-node-list.es.js","webpack://v4/./node_modules/tealight/dist/tealight.es.js","webpack://v4/./node_modules/rematrix/dist/rematrix.es.js","webpack://v4/./node_modules/miniraf/dist/miniraf.es.js","webpack://v4/./node_modules/scrollreveal/dist/scrollreveal.es.js","webpack://v4/./src/utils/sr.js","webpack://v4/./node_modules/@babel/runtime/helpers/esm/extends.js","webpack://v4/./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js"],"sourcesContent":["/* global Map:readonly, Set:readonly, ArrayBuffer:readonly */\n\nvar hasElementType = typeof Element !== 'undefined';\nvar hasMap = typeof Map === 'function';\nvar hasSet = typeof Set === 'function';\nvar hasArrayBuffer = typeof ArrayBuffer === 'function' && !!ArrayBuffer.isView;\n\n// Note: We **don't** need `envHasBigInt64Array` in fde es6/index.js\n\nfunction equal(a, b) {\n // START: fast-deep-equal es6/index.js 3.1.1\n if (a === b) return true;\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n if (a.constructor !== b.constructor) return false;\n var length, i, keys;\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;) if (!equal(a[i], b[i])) return false;\n return true;\n }\n\n // START: Modifications:\n // 1. Extra `has<Type> &&` helpers in initial condition allow es6 code\n // to co-exist with es5.\n // 2. Replace `for of` with es5 compliant iteration using `for`.\n // Basically, take:\n //\n // ```js\n // for (i of a.entries())\n // if (!b.has(i[0])) return false;\n // ```\n //\n // ... and convert to:\n //\n // ```js\n // it = a.entries();\n // while (!(i = it.next()).done)\n // if (!b.has(i.value[0])) return false;\n // ```\n //\n // **Note**: `i` access switches to `i.value`.\n var it;\n if (hasMap && a instanceof Map && b instanceof Map) {\n if (a.size !== b.size) return false;\n it = a.entries();\n while (!(i = it.next()).done) if (!b.has(i.value[0])) return false;\n it = a.entries();\n while (!(i = it.next()).done) if (!equal(i.value[1], b.get(i.value[0]))) return false;\n return true;\n }\n if (hasSet && a instanceof Set && b instanceof Set) {\n if (a.size !== b.size) return false;\n it = a.entries();\n while (!(i = it.next()).done) if (!b.has(i.value[0])) return false;\n return true;\n }\n // END: Modifications\n\n if (hasArrayBuffer && ArrayBuffer.isView(a) && ArrayBuffer.isView(b)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;) if (a[i] !== b[i]) return false;\n return true;\n }\n if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;\n if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();\n if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) return false;\n for (i = length; i-- !== 0;) if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;\n // END: fast-deep-equal\n\n // START: react-fast-compare\n // custom handling for DOM elements\n if (hasElementType && a instanceof Element) return false;\n\n // custom handling for React/Preact\n for (i = length; i-- !== 0;) {\n if ((keys[i] === '_owner' || keys[i] === '__v' || keys[i] === '__o') && a.$$typeof) {\n // React-specific: avoid traversing React elements' _owner\n // Preact-specific: avoid traversing Preact elements' __v and __o\n // __v = $_original / $_vnode\n // __o = $_owner\n // These properties contain circular references and are not needed when\n // comparing the actual elements (and not their owners)\n // .$$typeof and ._store on just reasonable markers of elements\n\n continue;\n }\n\n // all other properties should be traversed as usual\n if (!equal(a[keys[i]], b[keys[i]])) return false;\n }\n // END: react-fast-compare\n\n // START: fast-deep-equal\n return true;\n }\n return a !== a && b !== b;\n}\n// end fast-deep-equal\n\nmodule.exports = function isEqual(a, b) {\n try {\n return equal(a, b);\n } catch (error) {\n if ((error.message || '').match(/stack|recursion/i)) {\n // warn on circular references, don't crash\n // browsers give this different errors name and messages:\n // chrome/safari: \"RangeError\", \"Maximum call stack size exceeded\"\n // firefox: \"InternalError\", too much recursion\"\n // edge: \"Error\", \"Out of stack space\"\n console.warn('react-fast-compare cannot handle circular refs');\n return false;\n }\n // some other error. we should definitely know about these\n throw error;\n }\n};","import PropTypes from 'prop-types';\nimport withSideEffect from 'react-side-effect';\nimport isEqual from 'react-fast-compare';\nimport React from 'react';\nimport objectAssign from 'object-assign';\nvar ATTRIBUTE_NAMES = {\n BODY: \"bodyAttributes\",\n HTML: \"htmlAttributes\",\n TITLE: \"titleAttributes\"\n};\nvar TAG_NAMES = {\n BASE: \"base\",\n BODY: \"body\",\n HEAD: \"head\",\n HTML: \"html\",\n LINK: \"link\",\n META: \"meta\",\n NOSCRIPT: \"noscript\",\n SCRIPT: \"script\",\n STYLE: \"style\",\n TITLE: \"title\"\n};\nvar VALID_TAG_NAMES = Object.keys(TAG_NAMES).map(function (name) {\n return TAG_NAMES[name];\n});\nvar TAG_PROPERTIES = {\n CHARSET: \"charset\",\n CSS_TEXT: \"cssText\",\n HREF: \"href\",\n HTTPEQUIV: \"http-equiv\",\n INNER_HTML: \"innerHTML\",\n ITEM_PROP: \"itemprop\",\n NAME: \"name\",\n PROPERTY: \"property\",\n REL: \"rel\",\n SRC: \"src\",\n TARGET: \"target\"\n};\nvar REACT_TAG_MAP = {\n accesskey: \"accessKey\",\n charset: \"charSet\",\n class: \"className\",\n contenteditable: \"contentEditable\",\n contextmenu: \"contextMenu\",\n \"http-equiv\": \"httpEquiv\",\n itemprop: \"itemProp\",\n tabindex: \"tabIndex\"\n};\nvar HELMET_PROPS = {\n DEFAULT_TITLE: \"defaultTitle\",\n DEFER: \"defer\",\n ENCODE_SPECIAL_CHARACTERS: \"encodeSpecialCharacters\",\n ON_CHANGE_CLIENT_STATE: \"onChangeClientState\",\n TITLE_TEMPLATE: \"titleTemplate\"\n};\nvar HTML_TAG_MAP = Object.keys(REACT_TAG_MAP).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key]] = key;\n return obj;\n}, {});\nvar SELF_CLOSING_TAGS = [TAG_NAMES.NOSCRIPT, TAG_NAMES.SCRIPT, TAG_NAMES.STYLE];\nvar HELMET_ATTRIBUTE = \"data-react-helmet\";\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\nvar classCallCheck = function classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n};\nvar inherits = function inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\nvar objectWithoutProperties = function objectWithoutProperties(obj, keys) {\n var target = {};\n for (var i in obj) {\n if (keys.indexOf(i) >= 0) continue;\n if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;\n target[i] = obj[i];\n }\n return target;\n};\nvar possibleConstructorReturn = function possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\nvar encodeSpecialCharacters = function encodeSpecialCharacters(str) {\n var encode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n if (encode === false) {\n return String(str);\n }\n return String(str).replace(/&/g, \"&\").replace(/</g, \"<\").replace(/>/g, \">\").replace(/\"/g, \""\").replace(/'/g, \"'\");\n};\nvar getTitleFromPropsList = function getTitleFromPropsList(propsList) {\n var innermostTitle = getInnermostProperty(propsList, TAG_NAMES.TITLE);\n var innermostTemplate = getInnermostProperty(propsList, HELMET_PROPS.TITLE_TEMPLATE);\n if (innermostTemplate && innermostTitle) {\n // use function arg to avoid need to escape $ characters\n return innermostTemplate.replace(/%s/g, function () {\n return Array.isArray(innermostTitle) ? innermostTitle.join(\"\") : innermostTitle;\n });\n }\n var innermostDefaultTitle = getInnermostProperty(propsList, HELMET_PROPS.DEFAULT_TITLE);\n return innermostTitle || innermostDefaultTitle || undefined;\n};\nvar getOnChangeClientState = function getOnChangeClientState(propsList) {\n return getInnermostProperty(propsList, HELMET_PROPS.ON_CHANGE_CLIENT_STATE) || function () {};\n};\nvar getAttributesFromPropsList = function getAttributesFromPropsList(tagType, propsList) {\n return propsList.filter(function (props) {\n return typeof props[tagType] !== \"undefined\";\n }).map(function (props) {\n return props[tagType];\n }).reduce(function (tagAttrs, current) {\n return _extends({}, tagAttrs, current);\n }, {});\n};\nvar getBaseTagFromPropsList = function getBaseTagFromPropsList(primaryAttributes, propsList) {\n return propsList.filter(function (props) {\n return typeof props[TAG_NAMES.BASE] !== \"undefined\";\n }).map(function (props) {\n return props[TAG_NAMES.BASE];\n }).reverse().reduce(function (innermostBaseTag, tag) {\n if (!innermostBaseTag.length) {\n var keys = Object.keys(tag);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && tag[lowerCaseAttributeKey]) {\n return innermostBaseTag.concat(tag);\n }\n }\n }\n return innermostBaseTag;\n }, []);\n};\nvar getTagsFromPropsList = function getTagsFromPropsList(tagName, primaryAttributes, propsList) {\n // Calculate list of tags, giving priority innermost component (end of the propslist)\n var approvedSeenTags = {};\n return propsList.filter(function (props) {\n if (Array.isArray(props[tagName])) {\n return true;\n }\n if (typeof props[tagName] !== \"undefined\") {\n warn(\"Helmet: \" + tagName + \" should be of type \\\"Array\\\". Instead found type \\\"\" + _typeof(props[tagName]) + \"\\\"\");\n }\n return false;\n }).map(function (props) {\n return props[tagName];\n }).reverse().reduce(function (approvedTags, instanceTags) {\n var instanceSeenTags = {};\n instanceTags.filter(function (tag) {\n var primaryAttributeKey = void 0;\n var keys = Object.keys(tag);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n\n // Special rule with link tags, since rel and href are both primary tags, rel takes priority\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && !(primaryAttributeKey === TAG_PROPERTIES.REL && tag[primaryAttributeKey].toLowerCase() === \"canonical\") && !(lowerCaseAttributeKey === TAG_PROPERTIES.REL && tag[lowerCaseAttributeKey].toLowerCase() === \"stylesheet\")) {\n primaryAttributeKey = lowerCaseAttributeKey;\n }\n // Special case for innerHTML which doesn't work lowercased\n if (primaryAttributes.indexOf(attributeKey) !== -1 && (attributeKey === TAG_PROPERTIES.INNER_HTML || attributeKey === TAG_PROPERTIES.CSS_TEXT || attributeKey === TAG_PROPERTIES.ITEM_PROP)) {\n primaryAttributeKey = attributeKey;\n }\n }\n if (!primaryAttributeKey || !tag[primaryAttributeKey]) {\n return false;\n }\n var value = tag[primaryAttributeKey].toLowerCase();\n if (!approvedSeenTags[primaryAttributeKey]) {\n approvedSeenTags[primaryAttributeKey] = {};\n }\n if (!instanceSeenTags[primaryAttributeKey]) {\n instanceSeenTags[primaryAttributeKey] = {};\n }\n if (!approvedSeenTags[primaryAttributeKey][value]) {\n instanceSeenTags[primaryAttributeKey][value] = true;\n return true;\n }\n return false;\n }).reverse().forEach(function (tag) {\n return approvedTags.push(tag);\n });\n\n // Update seen tags with tags from this instance\n var keys = Object.keys(instanceSeenTags);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var tagUnion = objectAssign({}, approvedSeenTags[attributeKey], instanceSeenTags[attributeKey]);\n approvedSeenTags[attributeKey] = tagUnion;\n }\n return approvedTags;\n }, []).reverse();\n};\nvar getInnermostProperty = function getInnermostProperty(propsList, property) {\n for (var i = propsList.length - 1; i >= 0; i--) {\n var props = propsList[i];\n if (props.hasOwnProperty(property)) {\n return props[property];\n }\n }\n return null;\n};\nvar reducePropsToState = function reducePropsToState(propsList) {\n return {\n baseTag: getBaseTagFromPropsList([TAG_PROPERTIES.HREF, TAG_PROPERTIES.TARGET], propsList),\n bodyAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.BODY, propsList),\n defer: getInnermostProperty(propsList, HELMET_PROPS.DEFER),\n encode: getInnermostProperty(propsList, HELMET_PROPS.ENCODE_SPECIAL_CHARACTERS),\n htmlAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.HTML, propsList),\n linkTags: getTagsFromPropsList(TAG_NAMES.LINK, [TAG_PROPERTIES.REL, TAG_PROPERTIES.HREF], propsList),\n metaTags: getTagsFromPropsList(TAG_NAMES.META, [TAG_PROPERTIES.NAME, TAG_PROPERTIES.CHARSET, TAG_PROPERTIES.HTTPEQUIV, TAG_PROPERTIES.PROPERTY, TAG_PROPERTIES.ITEM_PROP], propsList),\n noscriptTags: getTagsFromPropsList(TAG_NAMES.NOSCRIPT, [TAG_PROPERTIES.INNER_HTML], propsList),\n onChangeClientState: getOnChangeClientState(propsList),\n scriptTags: getTagsFromPropsList(TAG_NAMES.SCRIPT, [TAG_PROPERTIES.SRC, TAG_PROPERTIES.INNER_HTML], propsList),\n styleTags: getTagsFromPropsList(TAG_NAMES.STYLE, [TAG_PROPERTIES.CSS_TEXT], propsList),\n title: getTitleFromPropsList(propsList),\n titleAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.TITLE, propsList)\n };\n};\nvar rafPolyfill = function () {\n var clock = Date.now();\n return function (callback) {\n var currentTime = Date.now();\n if (currentTime - clock > 16) {\n clock = currentTime;\n callback(currentTime);\n } else {\n setTimeout(function () {\n rafPolyfill(callback);\n }, 0);\n }\n };\n}();\nvar cafPolyfill = function cafPolyfill(id) {\n return clearTimeout(id);\n};\nvar requestAnimationFrame = typeof window !== \"undefined\" ? window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || rafPolyfill : global.requestAnimationFrame || rafPolyfill;\nvar cancelAnimationFrame = typeof window !== \"undefined\" ? window.cancelAnimationFrame || window.webkitCancelAnimationFrame || window.mozCancelAnimationFrame || cafPolyfill : global.cancelAnimationFrame || cafPolyfill;\nvar warn = function warn(msg) {\n return console && typeof console.warn === \"function\" && console.warn(msg);\n};\nvar _helmetCallback = null;\nvar handleClientStateChange = function handleClientStateChange(newState) {\n if (_helmetCallback) {\n cancelAnimationFrame(_helmetCallback);\n }\n if (newState.defer) {\n _helmetCallback = requestAnimationFrame(function () {\n commitTagChanges(newState, function () {\n _helmetCallback = null;\n });\n });\n } else {\n commitTagChanges(newState);\n _helmetCallback = null;\n }\n};\nvar commitTagChanges = function commitTagChanges(newState, cb) {\n var baseTag = newState.baseTag,\n bodyAttributes = newState.bodyAttributes,\n htmlAttributes = newState.htmlAttributes,\n linkTags = newState.linkTags,\n metaTags = newState.metaTags,\n noscriptTags = newState.noscriptTags,\n onChangeClientState = newState.onChangeClientState,\n scriptTags = newState.scriptTags,\n styleTags = newState.styleTags,\n title = newState.title,\n titleAttributes = newState.titleAttributes;\n updateAttributes(TAG_NAMES.BODY, bodyAttributes);\n updateAttributes(TAG_NAMES.HTML, htmlAttributes);\n updateTitle(title, titleAttributes);\n var tagUpdates = {\n baseTag: updateTags(TAG_NAMES.BASE, baseTag),\n linkTags: updateTags(TAG_NAMES.LINK, linkTags),\n metaTags: updateTags(TAG_NAMES.META, metaTags),\n noscriptTags: updateTags(TAG_NAMES.NOSCRIPT, noscriptTags),\n scriptTags: updateTags(TAG_NAMES.SCRIPT, scriptTags),\n styleTags: updateTags(TAG_NAMES.STYLE, styleTags)\n };\n var addedTags = {};\n var removedTags = {};\n Object.keys(tagUpdates).forEach(function (tagType) {\n var _tagUpdates$tagType = tagUpdates[tagType],\n newTags = _tagUpdates$tagType.newTags,\n oldTags = _tagUpdates$tagType.oldTags;\n if (newTags.length) {\n addedTags[tagType] = newTags;\n }\n if (oldTags.length) {\n removedTags[tagType] = tagUpdates[tagType].oldTags;\n }\n });\n cb && cb();\n onChangeClientState(newState, addedTags, removedTags);\n};\nvar flattenArray = function flattenArray(possibleArray) {\n return Array.isArray(possibleArray) ? possibleArray.join(\"\") : possibleArray;\n};\nvar updateTitle = function updateTitle(title, attributes) {\n if (typeof title !== \"undefined\" && document.title !== title) {\n document.title = flattenArray(title);\n }\n updateAttributes(TAG_NAMES.TITLE, attributes);\n};\nvar updateAttributes = function updateAttributes(tagName, attributes) {\n var elementTag = document.getElementsByTagName(tagName)[0];\n if (!elementTag) {\n return;\n }\n var helmetAttributeString = elementTag.getAttribute(HELMET_ATTRIBUTE);\n var helmetAttributes = helmetAttributeString ? helmetAttributeString.split(\",\") : [];\n var attributesToRemove = [].concat(helmetAttributes);\n var attributeKeys = Object.keys(attributes);\n for (var i = 0; i < attributeKeys.length; i++) {\n var attribute = attributeKeys[i];\n var value = attributes[attribute] || \"\";\n if (elementTag.getAttribute(attribute) !== value) {\n elementTag.setAttribute(attribute, value);\n }\n if (helmetAttributes.indexOf(attribute) === -1) {\n helmetAttributes.push(attribute);\n }\n var indexToSave = attributesToRemove.indexOf(attribute);\n if (indexToSave !== -1) {\n attributesToRemove.splice(indexToSave, 1);\n }\n }\n for (var _i = attributesToRemove.length - 1; _i >= 0; _i--) {\n elementTag.removeAttribute(attributesToRemove[_i]);\n }\n if (helmetAttributes.length === attributesToRemove.length) {\n elementTag.removeAttribute(HELMET_ATTRIBUTE);\n } else if (elementTag.getAttribute(HELMET_ATTRIBUTE) !== attributeKeys.join(\",\")) {\n elementTag.setAttribute(HELMET_ATTRIBUTE, attributeKeys.join(\",\"));\n }\n};\nvar updateTags = function updateTags(type, tags) {\n var headElement = document.head || document.querySelector(TAG_NAMES.HEAD);\n var tagNodes = headElement.querySelectorAll(type + \"[\" + HELMET_ATTRIBUTE + \"]\");\n var oldTags = Array.prototype.slice.call(tagNodes);\n var newTags = [];\n var indexToDelete = void 0;\n if (tags && tags.length) {\n tags.forEach(function (tag) {\n var newElement = document.createElement(type);\n for (var attribute in tag) {\n if (tag.hasOwnProperty(attribute)) {\n if (attribute === TAG_PROPERTIES.INNER_HTML) {\n newElement.innerHTML = tag.innerHTML;\n } else if (attribute === TAG_PROPERTIES.CSS_TEXT) {\n if (newElement.styleSheet) {\n newElement.styleSheet.cssText = tag.cssText;\n } else {\n newElement.appendChild(document.createTextNode(tag.cssText));\n }\n } else {\n var value = typeof tag[attribute] === \"undefined\" ? \"\" : tag[attribute];\n newElement.setAttribute(attribute, value);\n }\n }\n }\n newElement.setAttribute(HELMET_ATTRIBUTE, \"true\");\n\n // Remove a duplicate tag from domTagstoRemove, so it isn't cleared.\n if (oldTags.some(function (existingTag, index) {\n indexToDelete = index;\n return newElement.isEqualNode(existingTag);\n })) {\n oldTags.splice(indexToDelete, 1);\n } else {\n newTags.push(newElement);\n }\n });\n }\n oldTags.forEach(function (tag) {\n return tag.parentNode.removeChild(tag);\n });\n newTags.forEach(function (tag) {\n return headElement.appendChild(tag);\n });\n return {\n oldTags: oldTags,\n newTags: newTags\n };\n};\nvar generateElementAttributesAsString = function generateElementAttributesAsString(attributes) {\n return Object.keys(attributes).reduce(function (str, key) {\n var attr = typeof attributes[key] !== \"undefined\" ? key + \"=\\\"\" + attributes[key] + \"\\\"\" : \"\" + key;\n return str ? str + \" \" + attr : attr;\n }, \"\");\n};\nvar generateTitleAsString = function generateTitleAsString(type, title, attributes, encode) {\n var attributeString = generateElementAttributesAsString(attributes);\n var flattenedTitle = flattenArray(title);\n return attributeString ? \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeString + \">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"</\" + type + \">\" : \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"</\" + type + \">\";\n};\nvar generateTagsAsString = function generateTagsAsString(type, tags, encode) {\n return tags.reduce(function (str, tag) {\n var attributeHtml = Object.keys(tag).filter(function (attribute) {\n return !(attribute === TAG_PROPERTIES.INNER_HTML || attribute === TAG_PROPERTIES.CSS_TEXT);\n }).reduce(function (string, attribute) {\n var attr = typeof tag[attribute] === \"undefined\" ? attribute : attribute + \"=\\\"\" + encodeSpecialCharacters(tag[attribute], encode) + \"\\\"\";\n return string ? string + \" \" + attr : attr;\n }, \"\");\n var tagContent = tag.innerHTML || tag.cssText || \"\";\n var isSelfClosing = SELF_CLOSING_TAGS.indexOf(type) === -1;\n return str + \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeHtml + (isSelfClosing ? \"/>\" : \">\" + tagContent + \"</\" + type + \">\");\n }, \"\");\n};\nvar convertElementAttributestoReactProps = function convertElementAttributestoReactProps(attributes) {\n var initProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return Object.keys(attributes).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key] || key] = attributes[key];\n return obj;\n }, initProps);\n};\nvar convertReactPropstoHtmlAttributes = function convertReactPropstoHtmlAttributes(props) {\n var initAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return Object.keys(props).reduce(function (obj, key) {\n obj[HTML_TAG_MAP[key] || key] = props[key];\n return obj;\n }, initAttributes);\n};\nvar generateTitleAsReactComponent = function generateTitleAsReactComponent(type, title, attributes) {\n var _initProps;\n\n // assigning into an array to define toString function on it\n var initProps = (_initProps = {\n key: title\n }, _initProps[HELMET_ATTRIBUTE] = true, _initProps);\n var props = convertElementAttributestoReactProps(attributes, initProps);\n return [React.createElement(TAG_NAMES.TITLE, props, title)];\n};\nvar generateTagsAsReactComponent = function generateTagsAsReactComponent(type, tags) {\n return tags.map(function (tag, i) {\n var _mappedTag;\n var mappedTag = (_mappedTag = {\n key: i\n }, _mappedTag[HELMET_ATTRIBUTE] = true, _mappedTag);\n Object.keys(tag).forEach(function (attribute) {\n var mappedAttribute = REACT_TAG_MAP[attribute] || attribute;\n if (mappedAttribute === TAG_PROPERTIES.INNER_HTML || mappedAttribute === TAG_PROPERTIES.CSS_TEXT) {\n var content = tag.innerHTML || tag.cssText;\n mappedTag.dangerouslySetInnerHTML = {\n __html: content\n };\n } else {\n mappedTag[mappedAttribute] = tag[attribute];\n }\n });\n return React.createElement(type, mappedTag);\n });\n};\nvar getMethodsForTag = function getMethodsForTag(type, tags, encode) {\n switch (type) {\n case TAG_NAMES.TITLE:\n return {\n toComponent: function toComponent() {\n return generateTitleAsReactComponent(type, tags.title, tags.titleAttributes, encode);\n },\n toString: function toString() {\n return generateTitleAsString(type, tags.title, tags.titleAttributes, encode);\n }\n };\n case ATTRIBUTE_NAMES.BODY:\n case ATTRIBUTE_NAMES.HTML:\n return {\n toComponent: function toComponent() {\n return convertElementAttributestoReactProps(tags);\n },\n toString: function toString() {\n return generateElementAttributesAsString(tags);\n }\n };\n default:\n return {\n toComponent: function toComponent() {\n return generateTagsAsReactComponent(type, tags);\n },\n toString: function toString() {\n return generateTagsAsString(type, tags, encode);\n }\n };\n }\n};\nvar mapStateOnServer = function mapStateOnServer(_ref) {\n var baseTag = _ref.baseTag,\n bodyAttributes = _ref.bodyAttributes,\n encode = _ref.encode,\n htmlAttributes = _ref.htmlAttributes,\n linkTags = _ref.linkTags,\n metaTags = _ref.metaTags,\n noscriptTags = _ref.noscriptTags,\n scriptTags = _ref.scriptTags,\n styleTags = _ref.styleTags,\n _ref$title = _ref.title,\n title = _ref$title === undefined ? \"\" : _ref$title,\n titleAttributes = _ref.titleAttributes;\n return {\n base: getMethodsForTag(TAG_NAMES.BASE, baseTag, encode),\n bodyAttributes: getMethodsForTag(ATTRIBUTE_NAMES.BODY, bodyAttributes, encode),\n htmlAttributes: getMethodsForTag(ATTRIBUTE_NAMES.HTML, htmlAttributes, encode),\n link: getMethodsForTag(TAG_NAMES.LINK, linkTags, encode),\n meta: getMethodsForTag(TAG_NAMES.META, metaTags, encode),\n noscript: getMethodsForTag(TAG_NAMES.NOSCRIPT, noscriptTags, encode),\n script: getMethodsForTag(TAG_NAMES.SCRIPT, scriptTags, encode),\n style: getMethodsForTag(TAG_NAMES.STYLE, styleTags, encode),\n title: getMethodsForTag(TAG_NAMES.TITLE, {\n title: title,\n titleAttributes: titleAttributes\n }, encode)\n };\n};\nvar Helmet = function Helmet(Component) {\n var _class, _temp;\n return _temp = _class = function (_React$Component) {\n inherits(HelmetWrapper, _React$Component);\n function HelmetWrapper() {\n classCallCheck(this, HelmetWrapper);\n return possibleConstructorReturn(this, _React$Component.apply(this, arguments));\n }\n HelmetWrapper.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps) {\n return !isEqual(this.props, nextProps);\n };\n HelmetWrapper.prototype.mapNestedChildrenToProps = function mapNestedChildrenToProps(child, nestedChildren) {\n if (!nestedChildren) {\n return null;\n }\n switch (child.type) {\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.NOSCRIPT:\n return {\n innerHTML: nestedChildren\n };\n case TAG_NAMES.STYLE:\n return {\n cssText: nestedChildren\n };\n }\n throw new Error(\"<\" + child.type + \" /> elements are self-closing and can not contain children. Refer to our API for more information.\");\n };\n HelmetWrapper.prototype.flattenArrayTypeChildren = function flattenArrayTypeChildren(_ref) {\n var _babelHelpers$extends;\n var child = _ref.child,\n arrayTypeChildren = _ref.arrayTypeChildren,\n newChildProps = _ref.newChildProps,\n nestedChildren = _ref.nestedChildren;\n return _extends({}, arrayTypeChildren, (_babelHelpers$extends = {}, _babelHelpers$extends[child.type] = [].concat(arrayTypeChildren[child.type] || [], [_extends({}, newChildProps, this.mapNestedChildrenToProps(child, nestedChildren))]), _babelHelpers$extends));\n };\n HelmetWrapper.prototype.mapObjectTypeChildren = function mapObjectTypeChildren(_ref2) {\n var _babelHelpers$extends2, _babelHelpers$extends3;\n var child = _ref2.child,\n newProps = _ref2.newProps,\n newChildProps = _ref2.newChildProps,\n nestedChildren = _ref2.nestedChildren;\n switch (child.type) {\n case TAG_NAMES.TITLE:\n return _extends({}, newProps, (_babelHelpers$extends2 = {}, _babelHelpers$extends2[child.type] = nestedChildren, _babelHelpers$extends2.titleAttributes = _extends({}, newChildProps), _babelHelpers$extends2));\n case TAG_NAMES.BODY:\n return _extends({}, newProps, {\n bodyAttributes: _extends({}, newChildProps)\n });\n case TAG_NAMES.HTML:\n return _extends({}, newProps, {\n htmlAttributes: _extends({}, newChildProps)\n });\n }\n return _extends({}, newProps, (_babelHelpers$extends3 = {}, _babelHelpers$extends3[child.type] = _extends({}, newChildProps), _babelHelpers$extends3));\n };\n HelmetWrapper.prototype.mapArrayTypeChildrenToProps = function mapArrayTypeChildrenToProps(arrayTypeChildren, newProps) {\n var newFlattenedProps = _extends({}, newProps);\n Object.keys(arrayTypeChildren).forEach(function (arrayChildName) {\n var _babelHelpers$extends4;\n newFlattenedProps = _extends({}, newFlattenedProps, (_babelHelpers$extends4 = {}, _babelHelpers$extends4[arrayChildName] = arrayTypeChildren[arrayChildName], _babelHelpers$extends4));\n });\n return newFlattenedProps;\n };\n HelmetWrapper.prototype.warnOnInvalidChildren = function warnOnInvalidChildren(child, nestedChildren) {\n if (process.env.NODE_ENV !== \"production\") {\n if (!VALID_TAG_NAMES.some(function (name) {\n return child.type === name;\n })) {\n if (typeof child.type === \"function\") {\n return warn(\"You may be attempting to nest <Helmet> components within each other, which is not allowed. Refer to our API for more information.\");\n }\n return warn(\"Only elements types \" + VALID_TAG_NAMES.join(\", \") + \" are allowed. Helmet does not support rendering <\" + child.type + \"> elements. Refer to our API for more information.\");\n }\n if (nestedChildren && typeof nestedChildren !== \"string\" && (!Array.isArray(nestedChildren) || nestedChildren.some(function (nestedChild) {\n return typeof nestedChild !== \"string\";\n }))) {\n throw new Error(\"Helmet expects a string as a child of <\" + child.type + \">. Did you forget to wrap your children in braces? ( <\" + child.type + \">{``}</\" + child.type + \"> ) Refer to our API for more information.\");\n }\n }\n return true;\n };\n HelmetWrapper.prototype.mapChildrenToProps = function mapChildrenToProps(children, newProps) {\n var _this2 = this;\n var arrayTypeChildren = {};\n React.Children.forEach(children, function (child) {\n if (!child || !child.props) {\n return;\n }\n var _child$props = child.props,\n nestedChildren = _child$props.children,\n childProps = objectWithoutProperties(_child$props, [\"children\"]);\n var newChildProps = convertReactPropstoHtmlAttributes(childProps);\n _this2.warnOnInvalidChildren(child, nestedChildren);\n switch (child.type) {\n case TAG_NAMES.LINK:\n case TAG_NAMES.META:\n case TAG_NAMES.NOSCRIPT:\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.STYLE:\n arrayTypeChildren = _this2.flattenArrayTypeChildren({\n child: child,\n arrayTypeChildren: arrayTypeChildren,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n default:\n newProps = _this2.mapObjectTypeChildren({\n child: child,\n newProps: newProps,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n }\n });\n newProps = this.mapArrayTypeChildrenToProps(arrayTypeChildren, newProps);\n return newProps;\n };\n HelmetWrapper.prototype.render = function render() {\n var _props = this.props,\n children = _props.children,\n props = objectWithoutProperties(_props, [\"children\"]);\n var newProps = _extends({}, props);\n if (children) {\n newProps = this.mapChildrenToProps(children, newProps);\n }\n return React.createElement(Component, newProps);\n };\n createClass(HelmetWrapper, null, [{\n key: \"canUseDOM\",\n // Component.peek comes from react-side-effect:\n // For testing, you may use a static peek() method available on the returned component.\n // It lets you get the current state without resetting the mounted instance stack.\n // Don’t use it for anything other than testing.\n\n /**\n * @param {Object} base: {\"target\": \"_blank\", \"href\": \"http://mysite.com/\"}\n * @param {Object} bodyAttributes: {\"className\": \"root\"}\n * @param {String} defaultTitle: \"Default Title\"\n * @param {Boolean} defer: true\n * @param {Boolean} encodeSpecialCharacters: true\n * @param {Object} htmlAttributes: {\"lang\": \"en\", \"amp\": undefined}\n * @param {Array} link: [{\"rel\": \"canonical\", \"href\": \"http://mysite.com/example\"}]\n * @param {Array} meta: [{\"name\": \"description\", \"content\": \"Test description\"}]\n * @param {Array} noscript: [{\"innerHTML\": \"<img src='http://mysite.com/js/test.js'\"}]\n * @param {Function} onChangeClientState: \"(newState) => console.log(newState)\"\n * @param {Array} script: [{\"type\": \"text/javascript\", \"src\": \"http://mysite.com/js/test.js\"}]\n * @param {Array} style: [{\"type\": \"text/css\", \"cssText\": \"div { display: block; color: blue; }\"}]\n * @param {String} title: \"Title\"\n * @param {Object} titleAttributes: {\"itemprop\": \"name\"}\n * @param {String} titleTemplate: \"MySite.com - %s\"\n */\n set: function set$$1(canUseDOM) {\n Component.canUseDOM = canUseDOM;\n }\n }]);\n return HelmetWrapper;\n }(React.Component), _class.propTypes = {\n base: PropTypes.object,\n bodyAttributes: PropTypes.object,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n defaultTitle: PropTypes.string,\n defer: PropTypes.bool,\n encodeSpecialCharacters: PropTypes.bool,\n htmlAttributes: PropTypes.object,\n link: PropTypes.arrayOf(PropTypes.object),\n meta: PropTypes.arrayOf(PropTypes.object),\n noscript: PropTypes.arrayOf(PropTypes.object),\n onChangeClientState: PropTypes.func,\n script: PropTypes.arrayOf(PropTypes.object),\n style: PropTypes.arrayOf(PropTypes.object),\n title: PropTypes.string,\n titleAttributes: PropTypes.object,\n titleTemplate: PropTypes.string\n }, _class.defaultProps = {\n defer: true,\n encodeSpecialCharacters: true\n }, _class.peek = Component.peek, _class.rewind = function () {\n var mappedState = Component.rewind();\n if (!mappedState) {\n // provide fallback if mappedState is undefined\n mappedState = mapStateOnServer({\n baseTag: [],\n bodyAttributes: {},\n encodeSpecialCharacters: true,\n htmlAttributes: {},\n linkTags: [],\n metaTags: [],\n noscriptTags: [],\n scriptTags: [],\n styleTags: [],\n title: \"\",\n titleAttributes: {}\n });\n }\n return mappedState;\n }, _temp;\n};\nvar NullComponent = function NullComponent() {\n return null;\n};\nvar HelmetSideEffects = withSideEffect(reducePropsToState, handleClientStateChange, mapStateOnServer)(NullComponent);\nvar HelmetExport = Helmet(HelmetSideEffects);\nHelmetExport.renderStatic = HelmetExport.rewind;\nexport default HelmetExport;\nexport { HelmetExport as Helmet };","'use strict';\n\nfunction _interopDefault(ex) {\n return ex && typeof ex === 'object' && 'default' in ex ? ex['default'] : ex;\n}\nvar React = require('react');\nvar React__default = _interopDefault(React);\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction withSideEffect(reducePropsToState, handleStateChangeOnClient, mapStateOnServer) {\n if (typeof reducePropsToState !== 'function') {\n throw new Error('Expected reducePropsToState to be a function.');\n }\n if (typeof handleStateChangeOnClient !== 'function') {\n throw new Error('Expected handleStateChangeOnClient to be a function.');\n }\n if (typeof mapStateOnServer !== 'undefined' && typeof mapStateOnServer !== 'function') {\n throw new Error('Expected mapStateOnServer to either be undefined or a function.');\n }\n function getDisplayName(WrappedComponent) {\n return WrappedComponent.displayName || WrappedComponent.name || 'Component';\n }\n return function wrap(WrappedComponent) {\n if (typeof WrappedComponent !== 'function') {\n throw new Error('Expected WrappedComponent to be a React component.');\n }\n var mountedInstances = [];\n var state;\n function emitChange() {\n state = reducePropsToState(mountedInstances.map(function (instance) {\n return instance.props;\n }));\n if (SideEffect.canUseDOM) {\n handleStateChangeOnClient(state);\n } else if (mapStateOnServer) {\n state = mapStateOnServer(state);\n }\n }\n var SideEffect = /*#__PURE__*/\n function (_PureComponent) {\n _inheritsLoose(SideEffect, _PureComponent);\n function SideEffect() {\n return _PureComponent.apply(this, arguments) || this;\n }\n\n // Try to use displayName of wrapped component\n // Expose canUseDOM so tests can monkeypatch it\n SideEffect.peek = function peek() {\n return state;\n };\n SideEffect.rewind = function rewind() {\n if (SideEffect.canUseDOM) {\n throw new Error('You may only call rewind() on the server. Call peek() to read the current state.');\n }\n var recordedState = state;\n state = undefined;\n mountedInstances = [];\n return recordedState;\n };\n var _proto = SideEffect.prototype;\n _proto.UNSAFE_componentWillMount = function UNSAFE_componentWillMount() {\n mountedInstances.push(this);\n emitChange();\n };\n _proto.componentDidUpdate = function componentDidUpdate() {\n emitChange();\n };\n _proto.componentWillUnmount = function componentWillUnmount() {\n var index = mountedInstances.indexOf(this);\n mountedInstances.splice(index, 1);\n emitChange();\n };\n _proto.render = function render() {\n return React__default.createElement(WrappedComponent, this.props);\n };\n return SideEffect;\n }(React.PureComponent);\n _defineProperty(SideEffect, \"displayName\", \"SideEffect(\" + getDisplayName(WrappedComponent) + \")\");\n _defineProperty(SideEffect, \"canUseDOM\", canUseDOM);\n return SideEffect;\n };\n}\nmodule.exports = withSideEffect;","function replaceClassName(origClass, classToRemove) {\n return origClass.replace(new RegExp(\"(^|\\\\s)\" + classToRemove + \"(?:\\\\s|$)\", 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n/**\n * Removes a CSS class from a given element.\n * \n * @param element the element\n * @param className the CSS class name\n */\n\n\nexport default function removeClass(element, className) {\n if (element.classList) {\n element.classList.remove(className);\n } else if (typeof element.className === 'string') {\n element.className = replaceClassName(element.className, className);\n } else {\n element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n }\n}","export default {\n disabled: false\n};","export var forceReflow = function forceReflow(node) {\n return node.scrollTop;\n};","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { forceReflow } from './utils/reflow';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * <Transition in={inProp} timeout={duration}>\n * {state => (\n * <div style={{\n * ...defaultStyle,\n * ...transitionStyles[state]\n * }}>\n * I'm a fade Transition!\n * </div>\n * )}\n * </Transition>\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n * <div>\n * <Transition in={inProp} timeout={500}>\n * {state => (\n * // ...\n * )}\n * </Transition>\n * <button onClick={() => setInProp(true)}>\n * Click to Enter\n * </button>\n * </div>\n * );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nvar Transition = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Transition, _React$Component);\n function Transition(props, context) {\n var _this;\n _this = _React$Component.call(this, props, context) || this;\n var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n var initialStatus;\n _this.appearStatus = null;\n if (props.in) {\n if (appear) {\n initialStatus = EXITED;\n _this.appearStatus = ENTERING;\n } else {\n initialStatus = ENTERED;\n }\n } else {\n if (props.unmountOnExit || props.mountOnEnter) {\n initialStatus = UNMOUNTED;\n } else {\n initialStatus = EXITED;\n }\n }\n _this.state = {\n status: initialStatus\n };\n _this.nextCallback = null;\n return _this;\n }\n Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n var nextIn = _ref.in;\n if (nextIn && prevState.status === UNMOUNTED) {\n return {\n status: EXITED\n };\n }\n return null;\n } // getSnapshotBeforeUpdate(prevProps) {\n // let nextStatus = null\n // if (prevProps !== this.props) {\n // const { status } = this.state\n // if (this.props.in) {\n // if (status !== ENTERING && status !== ENTERED) {\n // nextStatus = ENTERING\n // }\n // } else {\n // if (status === ENTERING || status === ENTERED) {\n // nextStatus = EXITING\n // }\n // }\n // }\n // return { nextStatus }\n // }\n ;\n\n var _proto = Transition.prototype;\n _proto.componentDidMount = function componentDidMount() {\n this.updateStatus(true, this.appearStatus);\n };\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var nextStatus = null;\n if (prevProps !== this.props) {\n var status = this.state.status;\n if (this.props.in) {\n if (status !== ENTERING && status !== ENTERED) {\n nextStatus = ENTERING;\n }\n } else {\n if (status === ENTERING || status === ENTERED) {\n nextStatus = EXITING;\n }\n }\n }\n this.updateStatus(false, nextStatus);\n };\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cancelNextCallback();\n };\n _proto.getTimeouts = function getTimeouts() {\n var timeout = this.props.timeout;\n var exit, enter, appear;\n exit = enter = appear = timeout;\n if (timeout != null && typeof timeout !== 'number') {\n exit = timeout.exit;\n enter = timeout.enter; // TODO: remove fallback for next major\n\n appear = timeout.appear !== undefined ? timeout.appear : enter;\n }\n return {\n exit: exit,\n enter: enter,\n appear: appear\n };\n };\n _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n if (mounting === void 0) {\n mounting = false;\n }\n if (nextStatus !== null) {\n // nextStatus will always be ENTERING or EXITING.\n this.cancelNextCallback();\n if (nextStatus === ENTERING) {\n if (this.props.unmountOnExit || this.props.mountOnEnter) {\n var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this); // https://github.com/reactjs/react-transition-group/pull/749\n // With unmountOnExit or mountOnEnter, the enter animation should happen at the transition between `exited` and `entering`.\n // To make the animation happen, we have to separate each rendering and avoid being processed as batched.\n\n if (node) forceReflow(node);\n }\n this.performEnter(mounting);\n } else {\n this.performExit();\n }\n } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n this.setState({\n status: UNMOUNTED\n });\n }\n };\n _proto.performEnter = function performEnter(mounting) {\n var _this2 = this;\n var enter = this.props.enter;\n var appearing = this.context ? this.context.isMounting : mounting;\n var _ref2 = this.props.nodeRef ? [appearing] : [ReactDOM.findDOMNode(this), appearing],\n maybeNode = _ref2[0],\n maybeAppearing = _ref2[1];\n var timeouts = this.getTimeouts();\n var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n // if we are mounting and running this it means appear _must_ be set\n\n if (!mounting && !enter || config.disabled) {\n this.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(maybeNode);\n });\n return;\n }\n this.props.onEnter(maybeNode, maybeAppearing);\n this.safeSetState({\n status: ENTERING\n }, function () {\n _this2.props.onEntering(maybeNode, maybeAppearing);\n _this2.onTransitionEnd(enterTimeout, function () {\n _this2.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(maybeNode, maybeAppearing);\n });\n });\n });\n };\n _proto.performExit = function performExit() {\n var _this3 = this;\n var exit = this.props.exit;\n var timeouts = this.getTimeouts();\n var maybeNode = this.props.nodeRef ? undefined : ReactDOM.findDOMNode(this); // no exit animation skip right to EXITED\n\n if (!exit || config.disabled) {\n this.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(maybeNode);\n });\n return;\n }\n this.props.onExit(maybeNode);\n this.safeSetState({\n status: EXITING\n }, function () {\n _this3.props.onExiting(maybeNode);\n _this3.onTransitionEnd(timeouts.exit, function () {\n _this3.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(maybeNode);\n });\n });\n });\n };\n _proto.cancelNextCallback = function cancelNextCallback() {\n if (this.nextCallback !== null) {\n this.nextCallback.cancel();\n this.nextCallback = null;\n }\n };\n _proto.safeSetState = function safeSetState(nextState, callback) {\n // This shouldn't be necessary, but there are weird race conditions with\n // setState callbacks and unmounting in testing, so always make sure that\n // we can cancel any pending setState callbacks after we unmount.\n callback = this.setNextCallback(callback);\n this.setState(nextState, callback);\n };\n _proto.setNextCallback = function setNextCallback(callback) {\n var _this4 = this;\n var active = true;\n this.nextCallback = function (event) {\n if (active) {\n active = false;\n _this4.nextCallback = null;\n callback(event);\n }\n };\n this.nextCallback.cancel = function () {\n active = false;\n };\n return this.nextCallback;\n };\n _proto.onTransitionEnd = function onTransitionEnd(timeout, handler) {\n this.setNextCallback(handler);\n var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this);\n var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n if (!node || doesNotHaveTimeoutOrListener) {\n setTimeout(this.nextCallback, 0);\n return;\n }\n if (this.props.addEndListener) {\n var _ref3 = this.props.nodeRef ? [this.nextCallback] : [node, this.nextCallback],\n maybeNode = _ref3[0],\n maybeNextCallback = _ref3[1];\n this.props.addEndListener(maybeNode, maybeNextCallback);\n }\n if (timeout != null) {\n setTimeout(this.nextCallback, timeout);\n }\n };\n _proto.render = function render() {\n var status = this.state.status;\n if (status === UNMOUNTED) {\n return null;\n }\n var _this$props = this.props,\n children = _this$props.children,\n _in = _this$props.in,\n _mountOnEnter = _this$props.mountOnEnter,\n _unmountOnExit = _this$props.unmountOnExit,\n _appear = _this$props.appear,\n _enter = _this$props.enter,\n _exit = _this$props.exit,\n _timeout = _this$props.timeout,\n _addEndListener = _this$props.addEndListener,\n _onEnter = _this$props.onEnter,\n _onEntering = _this$props.onEntering,\n _onEntered = _this$props.onEntered,\n _onExit = _this$props.onExit,\n _onExiting = _this$props.onExiting,\n _onExited = _this$props.onExited,\n _nodeRef = _this$props.nodeRef,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\", \"mountOnEnter\", \"unmountOnExit\", \"appear\", \"enter\", \"exit\", \"timeout\", \"addEndListener\", \"onEnter\", \"onEntering\", \"onEntered\", \"onExit\", \"onExiting\", \"onExited\", \"nodeRef\"]);\n return /*#__PURE__*/(\n // allows for nested Transitions\n React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, typeof children === 'function' ? children(status, childProps) : React.cloneElement(React.Children.only(children), childProps))\n );\n };\n return Transition;\n}(React.Component);\nTransition.contextType = TransitionGroupContext;\n// Name the function so it is clearer in the documentation\n\nfunction noop() {}\nTransition.defaultProps = {\n in: false,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n enter: true,\n exit: true,\n onEnter: noop,\n onEntering: noop,\n onEntered: noop,\n onExit: noop,\n onExiting: noop,\n onExited: noop\n};\nTransition.UNMOUNTED = UNMOUNTED;\nTransition.EXITED = EXITED;\nTransition.ENTERING = ENTERING;\nTransition.ENTERED = ENTERED;\nTransition.EXITING = EXITING;\nexport default Transition;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport addOneClass from 'dom-helpers/addClass';\nimport removeOneClass from 'dom-helpers/removeClass';\nimport React from 'react';\nimport Transition from './Transition';\nimport { classNamesShape } from './utils/PropTypes';\nimport { forceReflow } from './utils/reflow';\nvar _addClass = function addClass(node, classes) {\n return node && classes && classes.split(' ').forEach(function (c) {\n return addOneClass(node, c);\n });\n};\nvar removeClass = function removeClass(node, classes) {\n return node && classes && classes.split(' ').forEach(function (c) {\n return removeOneClass(node, c);\n });\n};\n/**\n * A transition component inspired by the excellent\n * [ng-animate](https://docs.angularjs.org/api/ngAnimate) library, you should\n * use it if you're using CSS transitions or animations. It's built upon the\n * [`Transition`](https://reactcommunity.org/react-transition-group/transition)\n * component, so it inherits all of its props.\n *\n * `CSSTransition` applies a pair of class names during the `appear`, `enter`,\n * and `exit` states of the transition. The first class is applied and then a\n * second `*-active` class in order to activate the CSS transition. After the\n * transition, matching `*-done` class names are applied to persist the\n * transition state.\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n * <div>\n * <CSSTransition in={inProp} timeout={200} classNames=\"my-node\">\n * <div>\n * {\"I'll receive my-node-* classes\"}\n * </div>\n * </CSSTransition>\n * <button type=\"button\" onClick={() => setInProp(true)}>\n * Click to Enter\n * </button>\n * </div>\n * );\n * }\n * ```\n *\n * When the `in` prop is set to `true`, the child component will first receive\n * the class `example-enter`, then the `example-enter-active` will be added in\n * the next tick. `CSSTransition` [forces a\n * reflow](https://github.com/reactjs/react-transition-group/blob/5007303e729a74be66a21c3e2205e4916821524b/src/CSSTransition.js#L208-L215)\n * between before adding the `example-enter-active`. This is an important trick\n * because it allows us to transition between `example-enter` and\n * `example-enter-active` even though they were added immediately one after\n * another. Most notably, this is what makes it possible for us to animate\n * _appearance_.\n *\n * ```css\n * .my-node-enter {\n * opacity: 0;\n * }\n * .my-node-enter-active {\n * opacity: 1;\n * transition: opacity 200ms;\n * }\n * .my-node-exit {\n * opacity: 1;\n * }\n * .my-node-exit-active {\n * opacity: 0;\n * transition: opacity 200ms;\n * }\n * ```\n *\n * `*-active` classes represent which styles you want to animate **to**, so it's\n * important to add `transition` declaration only to them, otherwise transitions\n * might not behave as intended! This might not be obvious when the transitions\n * are symmetrical, i.e. when `*-enter-active` is the same as `*-exit`, like in\n * the example above (minus `transition`), but it becomes apparent in more\n * complex transitions.\n *\n * **Note**: If you're using the\n * [`appear`](http://reactcommunity.org/react-transition-group/transition#Transition-prop-appear)\n * prop, make sure to define styles for `.appear-*` classes as well.\n */\n\nvar CSSTransition = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(CSSTransition, _React$Component);\n function CSSTransition() {\n var _this;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n _this.appliedClasses = {\n appear: {},\n enter: {},\n exit: {}\n };\n _this.onEnter = function (maybeNode, maybeAppearing) {\n var _this$resolveArgument = _this.resolveArguments(maybeNode, maybeAppearing),\n node = _this$resolveArgument[0],\n appearing = _this$resolveArgument[1];\n _this.removeClasses(node, 'exit');\n _this.addClass(node, appearing ? 'appear' : 'enter', 'base');\n if (_this.props.onEnter) {\n _this.props.onEnter(maybeNode, maybeAppearing);\n }\n };\n _this.onEntering = function (maybeNode, maybeAppearing) {\n var _this$resolveArgument2 = _this.resolveArguments(maybeNode, maybeAppearing),\n node = _this$resolveArgument2[0],\n appearing = _this$resolveArgument2[1];\n var type = appearing ? 'appear' : 'enter';\n _this.addClass(node, type, 'active');\n if (_this.props.onEntering) {\n _this.props.onEntering(maybeNode, maybeAppearing);\n }\n };\n _this.onEntered = function (maybeNode, maybeAppearing) {\n var _this$resolveArgument3 = _this.resolveArguments(maybeNode, maybeAppearing),\n node = _this$resolveArgument3[0],\n appearing = _this$resolveArgument3[1];\n var type = appearing ? 'appear' : 'enter';\n _this.removeClasses(node, type);\n _this.addClass(node, type, 'done');\n if (_this.props.onEntered) {\n _this.props.onEntered(maybeNode, maybeAppearing);\n }\n };\n _this.onExit = function (maybeNode) {\n var _this$resolveArgument4 = _this.resolveArguments(maybeNode),\n node = _this$resolveArgument4[0];\n _this.removeClasses(node, 'appear');\n _this.removeClasses(node, 'enter');\n _this.addClass(node, 'exit', 'base');\n if (_this.props.onExit) {\n _this.props.onExit(maybeNode);\n }\n };\n _this.onExiting = function (maybeNode) {\n var _this$resolveArgument5 = _this.resolveArguments(maybeNode),\n node = _this$resolveArgument5[0];\n _this.addClass(node, 'exit', 'active');\n if (_this.props.onExiting) {\n _this.props.onExiting(maybeNode);\n }\n };\n _this.onExited = function (maybeNode) {\n var _this$resolveArgument6 = _this.resolveArguments(maybeNode),\n node = _this$resolveArgument6[0];\n _this.removeClasses(node, 'exit');\n _this.addClass(node, 'exit', 'done');\n if (_this.props.onExited) {\n _this.props.onExited(maybeNode);\n }\n };\n _this.resolveArguments = function (maybeNode, maybeAppearing) {\n return _this.props.nodeRef ? [_this.props.nodeRef.current, maybeNode] // here `maybeNode` is actually `appearing`\n : [maybeNode, maybeAppearing];\n };\n _this.getClassNames = function (type) {\n var classNames = _this.props.classNames;\n var isStringClassNames = typeof classNames === 'string';\n var prefix = isStringClassNames && classNames ? classNames + \"-\" : '';\n var baseClassName = isStringClassNames ? \"\" + prefix + type : classNames[type];\n var activeClassName = isStringClassNames ? baseClassName + \"-active\" : classNames[type + \"Active\"];\n var doneClassName = isStringClassNames ? baseClassName + \"-done\" : classNames[type + \"Done\"];\n return {\n baseClassName: baseClassName,\n activeClassName: activeClassName,\n doneClassName: doneClassName\n };\n };\n return _this;\n }\n var _proto = CSSTransition.prototype;\n _proto.addClass = function addClass(node, type, phase) {\n var className = this.getClassNames(type)[phase + \"ClassName\"];\n var _this$getClassNames = this.getClassNames('enter'),\n doneClassName = _this$getClassNames.doneClassName;\n if (type === 'appear' && phase === 'done' && doneClassName) {\n className += \" \" + doneClassName;\n } // This is to force a repaint,\n // which is necessary in order to transition styles when adding a class name.\n\n if (phase === 'active') {\n if (node) forceReflow(node);\n }\n if (className) {\n this.appliedClasses[type][phase] = className;\n _addClass(node, className);\n }\n };\n _proto.removeClasses = function removeClasses(node, type) {\n var _this$appliedClasses$ = this.appliedClasses[type],\n baseClassName = _this$appliedClasses$.base,\n activeClassName = _this$appliedClasses$.active,\n doneClassName = _this$appliedClasses$.done;\n this.appliedClasses[type] = {};\n if (baseClassName) {\n removeClass(node, baseClassName);\n }\n if (activeClassName) {\n removeClass(node, activeClassName);\n }\n if (doneClassName) {\n removeClass(node, doneClassName);\n }\n };\n _proto.render = function render() {\n var _this$props = this.props,\n _ = _this$props.classNames,\n props = _objectWithoutPropertiesLoose(_this$props, [\"classNames\"]);\n return /*#__PURE__*/React.createElement(Transition, _extends({}, props, {\n onEnter: this.onEnter,\n onEntered: this.onEntered,\n onEntering: this.onEntering,\n onExit: this.onExit,\n onExiting: this.onExiting,\n onExited: this.onExited\n }));\n };\n return CSSTransition;\n}(React.Component);\nCSSTransition.defaultProps = {\n classNames: ''\n};\nexport default CSSTransition;","import hasClass from './hasClass';\n/**\n * Adds a CSS class to a given element.\n * \n * @param element the element\n * @param className the CSS class name\n */\n\nexport default function addClass(element, className) {\n if (element.classList) element.classList.add(className);else if (!hasClass(element, className)) if (typeof element.className === 'string') element.className = element.className + \" \" + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + \" \" + className);\n}","/**\n * Checks if a given element has a CSS class.\n * \n * @param element the element\n * @param className the CSS class name\n */\nexport default function hasClass(element, className) {\n if (element.classList) return !!className && element.classList.contains(className);\n return (\" \" + (element.className.baseVal || element.className) + \" \").indexOf(\" \" + className + \" \") !== -1;\n}","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && isValidElement(child) ? mapFn(child) : child;\n };\n var result = Object.create(null);\n if (children) Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n var i;\n var childMapping = {};\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n return childMapping;\n}\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\nexport function getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!isValidElement(child)) return;\n var hasPrev = (key in prevChildMapping);\n var hasNext = (key in nextChildMapping);\n var prevChild = prevChildMapping[key];\n var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = cloneElement(child, {\n in: false\n });\n } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n};\n/**\n * The `<TransitionGroup>` component manages a set of transition components\n * (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition\n * components, `<TransitionGroup>` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the `<TransitionGroup>`.\n *\n * Note that `<TransitionGroup>` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\nvar TransitionGroup = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n function TransitionGroup(props, context) {\n var _this;\n _this = _React$Component.call(this, props, context) || this;\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_this)); // Initial children should all be entering, dependent on appear\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n var _proto = TransitionGroup.prototype;\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n } // node is `undefined` when user provided `nodeRef` prop\n ;\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = getChildMapping(this.props.children);\n if (child.key in currentChildMapping) return;\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n if (Component === null) {\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, children);\n }\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, /*#__PURE__*/React.createElement(Component, props, children));\n };\n return TransitionGroup;\n}(React.Component);\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","import React from 'react';\nexport default React.createContext(null);","import React from 'react';\r\n\r\nconst IconAppStore = () => (\r\n <svg\r\n version=\"1.1\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n x=\"0px\"\r\n y=\"0px\"\r\n viewBox=\"0 0 512 512\"\r\n xmlSpace=\"preserve\">\r\n <title>Apple App Store</title>\r\n <g>\r\n <g>\r\n <path\r\n d=\"M407,0H105C47.103,0,0,47.103,0,105v302c0,57.897,47.103,105,105,105h302c57.897,0,105-47.103,105-105V105\r\n C512,47.103,464.897,0,407,0z M482,407c0,41.355-33.645,75-75,75H105c-41.355,0-75-33.645-75-75V105c0-41.355,33.645-75,75-75h302\r\n c41.355,0,75,33.645,75,75V407z\"\r\n />\r\n </g>\r\n </g>\r\n <g>\r\n <g>\r\n <path\r\n d=\"M305.646,123.531c-1.729-6.45-5.865-11.842-11.648-15.18c-11.936-6.892-27.256-2.789-34.15,9.151L256,124.166\r\n l-3.848-6.665c-6.893-11.937-22.212-16.042-34.15-9.151h-0.001c-11.938,6.893-16.042,22.212-9.15,34.151l18.281,31.664\r\n L159.678,291H110.5c-13.785,0-25,11.215-25,25c0,13.785,11.215,25,25,25h189.86l-28.868-50h-54.079l85.735-148.498\r\n C306.487,136.719,307.375,129.981,305.646,123.531z\"\r\n />\r\n </g>\r\n </g>\r\n <g>\r\n <g>\r\n <path\r\n d=\"M401.5,291h-49.178l-55.907-96.834l-28.867,50l86.804,150.348c3.339,5.784,8.729,9.921,15.181,11.65\r\n c2.154,0.577,4.339,0.863,6.511,0.863c4.332,0,8.608-1.136,12.461-3.361c11.938-6.893,16.042-22.213,9.149-34.15L381.189,341\r\n H401.5c13.785,0,25-11.215,25-25C426.5,302.215,415.285,291,401.5,291z\"\r\n />\r\n </g>\r\n </g>\r\n <g>\r\n <g>\r\n <path\r\n d=\"M119.264,361l-4.917,8.516c-6.892,11.938-2.787,27.258,9.151,34.15c3.927,2.267,8.219,3.345,12.458,3.344\r\n c8.646,0,17.067-4.484,21.693-12.495L176.999,361H119.264z\"\r\n />\r\n </g>\r\n </g>\r\n </svg>\r\n);\r\n\r\nexport default IconAppStore;\r\n","import React from 'react';\r\n\r\nconst IconBookmark = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"1\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-bookmark\">\r\n <title>Bookmark</title>\r\n <path d=\"M19 21l-7-5-7 5V5a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2z\"></path>\r\n </svg>\r\n);\r\n\r\nexport default IconBookmark;\r\n","import React from 'react';\r\n\r\nconst IconCodepen = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n role=\"img\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-codepen\">\r\n <title>CodePen</title>\r\n <polygon points=\"12 2 22 8.5 22 15.5 12 22 2 15.5 2 8.5 12 2\"></polygon>\r\n <line x1=\"12\" y1=\"22\" x2=\"12\" y2=\"15.5\"></line>\r\n <polyline points=\"22 8.5 12 15.5 2 8.5\"></polyline>\r\n <polyline points=\"2 15.5 12 8.5 22 15.5\"></polyline>\r\n <line x1=\"12\" y1=\"2\" x2=\"12\" y2=\"8.5\"></line>\r\n </svg>\r\n);\r\n\r\nexport default IconCodepen;\r\n","import React from 'react';\r\n\r\nconst IconExternal = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n role=\"img\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-external-link\">\r\n <title>External Link</title>\r\n <path d=\"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6\"></path>\r\n <polyline points=\"15 3 21 3 21 9\"></polyline>\r\n <line x1=\"10\" y1=\"14\" x2=\"21\" y2=\"3\"></line>\r\n </svg>\r\n);\r\n\r\nexport default IconExternal;\r\n","import React from 'react';\r\n\r\nconst IconFolder = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n role=\"img\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"1\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-folder\">\r\n <title>Folder</title>\r\n <path d=\"M22 19a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h5l2 3h9a2 2 0 0 1 2 2z\"></path>\r\n </svg>\r\n);\r\n\r\nexport default IconFolder;\r\n","import React from 'react';\r\n\r\nconst IconFork = () => (\r\n <svg\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-git-branch\">\r\n <title>Git Fork</title>\r\n <line x1=\"6\" y1=\"3\" x2=\"6\" y2=\"15\"></line>\r\n <circle cx=\"18\" cy=\"6\" r=\"3\"></circle>\r\n <circle cx=\"6\" cy=\"18\" r=\"3\"></circle>\r\n <path d=\"M18 9a9 9 0 0 1-9 9\"></path>\r\n </svg>\r\n);\r\n\r\nexport default IconFork;\r\n","import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport {\r\n IconAppStore,\r\n IconBookmark,\r\n IconCodepen,\r\n IconExternal,\r\n IconFolder,\r\n IconFork,\r\n IconGitHub,\r\n IconInstagram,\r\n IconLinkedin,\r\n IconLoader,\r\n IconLogo,\r\n IconPlayStore,\r\n IconStar,\r\n IconTwitter,\r\n IconFacebook,\r\n IconKaggle,\r\n IconStackoverflow,\r\n} from '@components/icons';\r\n\r\nconst Icon = ({ name }) => {\r\n switch (name) {\r\n case 'AppStore':\r\n return <IconAppStore />;\r\n case 'Bookmark':\r\n return <IconBookmark />;\r\n case 'Codepen':\r\n return <IconCodepen />;\r\n case 'External':\r\n return <IconExternal />;\r\n case 'Folder':\r\n return <IconFolder />;\r\n case 'Fork':\r\n return <IconFork />;\r\n case 'GitHub':\r\n return <IconGitHub />;\r\n case 'Instagram':\r\n return <IconInstagram />;\r\n case 'Linkedin':\r\n return <IconLinkedin />;\r\n case 'Loader':\r\n return <IconLoader />;\r\n case 'Logo':\r\n return <IconLogo />;\r\n case 'PlayStore':\r\n return <IconPlayStore />;\r\n case 'Star':\r\n return <IconStar />;\r\n case 'Twitter':\r\n return <IconTwitter />; \r\n case 'Facebook':\r\n return <IconFacebook />; \r\n case 'Kaggle':\r\n return <IconKaggle />; \r\n case 'StackOverflow':\r\n return <IconStackoverflow />;\r\n default:\r\n return <IconExternal />;\r\n }\r\n};\r\n\r\nIcon.propTypes = {\r\n name: PropTypes.string.isRequired,\r\n};\r\n\r\nexport default Icon;\r\n","import React from 'react';\r\n\r\nconst IconGitHub = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n role=\"img\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-github\">\r\n <title>GitHub</title>\r\n <path d=\"M9 19c-5 1.5-5-2.5-7-3m14 6v-3.87a3.37 3.37 0 0 0-.94-2.61c3.14-.35 6.44-1.54 6.44-7A5.44 5.44 0 0 0 20 4.77 5.07 5.07 0 0 0 19.91 1S18.73.65 16 2.48a13.38 13.38 0 0 0-7 0C6.27.65 5.09 1 5.09 1A5.07 5.07 0 0 0 5 4.77a5.44 5.44 0 0 0-1.5 3.78c0 5.42 3.3 6.61 6.44 7A3.37 3.37 0 0 0 9 18.13V22\"></path>\r\n </svg>\r\n);\r\n\r\nexport default IconGitHub;\r\n","import React from 'react';\r\n\r\nconst IconInstagram = () => (\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\r\n <title>Instagram</title>\r\n <path d=\"M17.992 24h-2.868c-.226 0-.554-.073-.838-.42l-4.403-5.872-.767.764v4.689c0 .501-.331.837-.822.837H6.072c-.492 0-.822-.336-.822-.837V.837c0-.501.33-.837.822-.837h2.223c.492 0 .822.336.822.837v12.487l4.806-5.096c.252-.262.525-.393.814-.393h2.964c.317 0 .592.178.715.465.125.29.073.64-.126.851l-5.693 5.776 5.984 7.794c.047.062.08.134.095.21l.065.338a.505.505 0 0 1-.005.212c-.061.252-.288.519-.744.519zM6.25 22.999h1.867v-4.734a.5.5 0 0 1 .147-.354l1.321-1.317a.5.5 0 0 1 .753.054l4.735 6.315 2.456.031-5.991-7.803a.5.5 0 0 1 .041-.656l5.618-5.7H14.74c.003.002-.032.019-.094.083L8.98 14.926a.5.5 0 0 1-.863-.343V1H6.25v21.999zM8.295 1h.004L8.295.5V1z\"/></svg>\r\n);\r\n\r\nexport default IconInstagram;\r\n","import React from 'react';\r\n\r\nconst IconLinkedin = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n role=\"img\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-linkedin\">\r\n <title>LinkedIn</title>\r\n <path d=\"M16 8a6 6 0 0 1 6 6v7h-4v-7a2 2 0 0 0-2-2 2 2 0 0 0-2 2v7h-4v-7a6 6 0 0 1 6-6z\"></path>\r\n <rect x=\"2\" y=\"9\" width=\"4\" height=\"12\"></rect>\r\n <circle cx=\"4\" cy=\"4\" r=\"2\"></circle>\r\n </svg>\r\n);\r\n\r\nexport default IconLinkedin;\r\n","import React from 'react';\n\nconst IconLoader = () => (\n <svg id=\"logo\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\">\n <title>Loader Logo</title>\n <g>\n {/* <g id=\"S\" transform=\"translate(11.000000, 5.000000)\"> */}\n <g id=\"S\">\n <path\n d=\"m 35 59 m 26 -15 c 0 -5 -4 -9 -10 -9 c -6 0 -10 4 -10 9 c 0 10 16 8 16 15 c 0 3 -3 5 -6 5 c -3 0 -6 -2 -6 -5 l -4 0 c 0 5 5 9 10 9 c 6 0 10 -4 10 -9 c 0 -9 -16 -10 -16 -15 c 0 -3 3 -5 6 -5 c 3 0 6 2 6 5 l 4 0\"\n fill=\"currentColor\"\n />\n </g>\n <path\n stroke=\"currentColor\"\n strokeWidth=\"5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M 50, 5\n L 11, 27\n L 11, 72\n L 50, 95\n L 89, 73\n L 89, 28 z\"\n />\n </g>\n </svg>\n);\n\nexport default IconLoader;\n","import React from 'react';\n\nconst IconLogo = () => (\n <svg id=\"logo\" xmlns=\"http://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 84 96\">\n <title>Logo</title>\n <g transform=\"translate(-8.000000, -2.000000)\">\n <g transform=\"translate(11.000000, 5.000000)\">\n <path\n d=\"m 23 54 m 26 -15 c 0 -5 -4 -9 -10 -9 c -6 0 -10 4 -10 9 c 0 10 16 8 16 15 c 0 3 -3 5 -6 5 c -3 0 -6 -2 -6 -5 l -4 0 c 0 5 5 9 10 9 c 6 0 10 -4 10 -9 c 0 -9 -16 -10 -16 -15 c 0 -3 3 -5 6 -5 c 3 0 6 2 6 5 l 4 0\"\n fill=\"currentColor\"\n />\n <polygon\n id=\"Shape\"\n stroke=\"currentColor\"\n strokeWidth=\"5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n points=\"39 0 0 22 0 67 39 90 78 68 78 23\"\n />\n </g>\n </g>\n </svg>\n);\n\nexport default IconLogo;\n","import React from 'react';\r\n\r\nconst IconPlayStore = () => (\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" role=\"img\" x=\"0px\" y=\"0px\" viewBox=\"0 0 512.001 512.001\">\r\n <title>Google Play Store</title>\r\n <path\r\n d=\"M464.252,212.09L99.624,8.07C84.247-1.873,64.754-2.691,48.574,5.967C32.183,14.74,22,31.737,22,50.329v411.342\r\n c0,18.592,10.183,35.59,26.573,44.361c16.097,8.617,35.593,7.891,51.052-2.101l364.628-204.022\r\n c16.121-9.02,25.747-25.435,25.747-43.908C490,237.527,480.374,221.111,464.252,212.09z M341.677,181.943l-50.339,50.339\r\n L113.108,54.051L341.677,181.943z M55.544,467.323V44.676L267.621,256L55.544,467.323z M113.108,457.949l178.232-178.231\r\n l50.339,50.339L113.108,457.949z M447.874,270.637l-75.779,42.401l-57.038-57.037l57.037-57.037l75.778,42.4\r\n c7.746,4.335,8.583,11.68,8.583,14.637C456.455,258.958,455.62,266.302,447.874,270.637z\"\r\n />\r\n </svg>\r\n);\r\n\r\nexport default IconPlayStore;\r\n","import React from 'react';\r\n\r\nconst IconStar = () => (\r\n <svg\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-star\">\r\n <title>Star</title>\r\n <polygon points=\"12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2\" />\r\n </svg>\r\n);\r\n\r\nexport default IconStar;\r\n","import React from 'react';\r\n\r\nconst IconTwitter = () => (\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n role=\"img\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n className=\"feather feather-twitter\">\r\n <title>Twitter</title>\r\n <path d=\"M23 3a10.9 10.9 0 0 1-3.14 1.53 4.48 4.48 0 0 0-7.86 3v1A10.66 10.66 0 0 1 3 4s-4 9 5 13a11.64 11.64 0 0 1-7 2c9 5 20 0 20-11.5a4.5 4.5 0 0 0-.08-.83A7.72 7.72 0 0 0 23 3z\"></path>\r\n </svg>\r\n);\r\n\r\nexport default IconTwitter;\r\n","import React from 'react';\r\n\r\nconst IconFacebook = () => (\r\n <svg xmlns=\"http://www.w3.org/2000/svg\"\r\n version=\"1.1\" x=\"0px\" y=\"0px\" \r\n viewBox=\"0 0 1000 1000\" >\r\n <title>Facebook</title>\r\n <g>\r\n <path d=\"M425,355.4v95.1h-76.1v114H425v266.2H539V564.6h114.1v-114H539.1v-76.1c0-22.8,15.2-38,38-38h76.1V222.4H558C485.8,222.4,425,283.2,425,355.4L425,355.4z\"/>\r\n <path d=\"M500,10C230.5,10,10,230.5,10,500c0,269.4,220.5,490,490,490c269.5,0,490-220.5,490-490C990,230.5,769.5,10,500,10z M500,949.2C252.9,949.2,50.8,747,50.8,500C50.8,253,252.9,50.8,500,50.8S949.2,253,949.2,500C949.2,747,747.1,949.2,500,949.2z\"/>\r\n </g>\r\n </svg>\r\n);\r\n\r\nexport default IconFacebook;\r\n","import React from 'react';\r\n\r\nconst IconKaggle = () => (\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\">\r\n <title>Kaggle</title>\r\n <path d=\"M17.992 24h-2.868c-.226 0-.554-.073-.838-.42l-4.403-5.872-.767.764v4.689c0 .501-.331.837-.822.837H6.072c-.492 0-.822-.336-.822-.837V.837c0-.501.33-.837.822-.837h2.223c.492 0 .822.336.822.837v12.487l4.806-5.096c.252-.262.525-.393.814-.393h2.964c.317 0 .592.178.715.465.125.29.073.64-.126.851l-5.693 5.776 5.984 7.794c.047.062.08.134.095.21l.065.338a.505.505 0 0 1-.005.212c-.061.252-.288.519-.744.519zM6.25 22.999h1.867v-4.734a.5.5 0 0 1 .147-.354l1.321-1.317a.5.5 0 0 1 .753.054l4.735 6.315 2.456.031-5.991-7.803a.5.5 0 0 1 .041-.656l5.618-5.7H14.74c.003.002-.032.019-.094.083L8.98 14.926a.5.5 0 0 1-.863-.343V1H6.25v21.999zM8.295 1h.004L8.295.5V1z\"/></svg>\r\n);\r\n\r\nexport default IconKaggle;\r\n","import React from 'react';\r\n\r\nconst IconStackoverflow = () => (\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" x=\"0px\" y=\"0px\" viewBox=\"0 0 1000 1000\" >\r\n <title>StackOverflow</title>\r\n <path d=\"M284.146,943.869v97.896h472.857v-97.896H284.146z M292.149,767.778 l-6.773,97.896l471.627,32.018l6.156-97.281L292.149,767.778L292.149,767.778z M146.845,727.143V1200h78.193h619.394h49.872V727.143 h-78.192v394.049H225.038V727.143H146.845L146.845,727.143z M327.859,559.672l-23.396,94.817L763.16,768.393l23.396-95.433 L327.859,559.672z M429.45,322.627l-49.872,84.352l407.594,239.508l49.872-84.967L429.45,322.627z M678.192,97.896l-81.271,54.797 l262.903,392.201l81.271-54.182L678.192,97.896L678.192,97.896z M995.896,0l-97.281,11.698l57.261,469.164l97.28-11.698L995.896,0z\"/>\r\n </svg>\r\n);\r\n\r\nexport default IconStackoverflow;\r\n","import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport { Helmet } from 'react-helmet';\r\nimport { useLocation } from '@reach/router';\r\nimport { useStaticQuery, graphql } from 'gatsby';\r\n\r\n// https://www.gatsbyjs.com/docs/add-seo-component/\r\n\r\nconst Head = ({ title, description, image }) => {\r\n const { pathname } = useLocation();\r\n\r\n const { site } = useStaticQuery(\r\n graphql`\r\n query {\r\n site {\r\n siteMetadata {\r\n defaultTitle: title\r\n defaultDescription: description\r\n siteUrl\r\n defaultImage: image\r\n twitterUsername\r\n }\r\n }\r\n }\r\n `,\r\n );\r\n\r\n const {\r\n defaultTitle,\r\n defaultDescription,\r\n siteUrl,\r\n defaultImage,\r\n twitterUsername,\r\n } = site.siteMetadata;\r\n\r\n const seo = {\r\n title: title || defaultTitle,\r\n description: description || defaultDescription,\r\n image: `${siteUrl}${image || defaultImage}`,\r\n url: `${siteUrl}${pathname}`,\r\n };\r\n\r\n return (\r\n <Helmet title={title} defaultTitle={seo.title} titleTemplate={`%s | ${defaultTitle}`}>\r\n <html lang=\"en\" />\r\n\r\n <meta name=\"description\" content={seo.description} />\r\n <meta name=\"image\" content={seo.image} />\r\n\r\n <meta property=\"og:title\" content={seo.title} />\r\n <meta property=\"og:description\" content={seo.description} />\r\n <meta property=\"og:image\" content={seo.image} />\r\n <meta property=\"og:url\" content={seo.url} />\r\n <meta property=\"og:type\" content=\"website\" />\r\n\r\n <meta name=\"twitter:card\" content=\"summary_large_image\" />\r\n <meta name=\"twitter:creator\" content={twitterUsername} />\r\n <meta name=\"twitter:title\" content={seo.title} />\r\n <meta name=\"twitter:description\" content={seo.description} />\r\n <meta name=\"twitter:image\" content={seo.image} />\r\n\r\n <meta name=\"google-site-verification\" content=\"DCl7VAf9tcz6eD9gb67NfkNnJ1PKRNcg8qQiwpbx9Lk\" />\r\n </Helmet>\r\n );\r\n};\r\n\r\nexport default Head;\r\n\r\nHead.propTypes = {\r\n title: PropTypes.string,\r\n description: PropTypes.string,\r\n image: PropTypes.string,\r\n};\r\n\r\nHead.defaultProps = {\r\n title: null,\r\n description: null,\r\n image: null,\r\n};\r\n","import { css } from 'styled-components';\r\n\r\nconst button = css`\r\n color: var(--green);\r\n background-color: transparent;\r\n border: 1px solid var(--green);\r\n border-radius: var(--border-radius);\r\n font-size: var(--fz-xs);\r\n font-family: var(--font-mono);\r\n line-height: 1;\r\n text-decoration: none;\r\n cursor: pointer;\r\n transition: var(--transition);\r\n padding: 1.25rem 1.75rem;\r\n\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n background-color: var(--green-tint);\r\n outline: none;\r\n }\r\n &:after {\r\n display: none !important;\r\n }\r\n`;\r\n\r\nconst mixins = {\r\n flexCenter: css`\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n `,\r\n\r\n flexBetween: css`\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n `,\r\n\r\n link: css`\r\n display: inline-block;\r\n text-decoration: none;\r\n text-decoration-skip-ink: auto;\r\n color: inherit;\r\n position: relative;\r\n transition: var(--transition);\r\n &:hover,\r\n &:active,\r\n &:focus {\r\n color: var(--green);\r\n outline: 0;\r\n }\r\n `,\r\n\r\n inlineLink: css`\r\n display: inline-block;\r\n text-decoration: none;\r\n text-decoration-skip-ink: auto;\r\n position: relative;\r\n transition: var(--transition);\r\n color: var(--green);\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n color: var(--green);\r\n outline: 0;\r\n &:after {\r\n width: 100%;\r\n }\r\n & > * {\r\n color: var(--green) !important;\r\n transition: var(--transition);\r\n }\r\n }\r\n &:after {\r\n content: '';\r\n display: block;\r\n width: 0;\r\n height: 1px;\r\n position: relative;\r\n bottom: 0.37em;\r\n background-color: var(--green);\r\n transition: var(--transition);\r\n opacity: 0.5;\r\n }\r\n `,\r\n\r\n button,\r\n\r\n smallButton: css`\r\n color: var(--green);\r\n background-color: transparent;\r\n border: 1px solid var(--green);\r\n border-radius: var(--border-radius);\r\n padding: 0.75rem 1rem;\r\n font-size: var(--fz-xs);\r\n font-family: var(--font-mono);\r\n line-height: 1;\r\n text-decoration: none;\r\n cursor: pointer;\r\n transition: var(--transition);\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n background-color: var(--green-tint);\r\n outline: none;\r\n }\r\n &:after {\r\n display: none !important;\r\n }\r\n `,\r\n\r\n bigButton: css`\r\n color: var(--green);\r\n background-color: transparent;\r\n border: 1px solid var(--green);\r\n border-radius: var(--border-radius);\r\n padding: 1.25rem 1.75rem;\r\n font-size: var(--fz-sm);\r\n font-family: var(--font-mono);\r\n line-height: 1;\r\n text-decoration: none;\r\n cursor: pointer;\r\n transition: var(--transition);\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n background-color: var(--green-tint);\r\n outline: none;\r\n }\r\n &:after {\r\n display: none !important;\r\n }\r\n `,\r\n\r\n boxShadow: css`\r\n box-shadow: 0 10px 30px -15px var(--navy-shadow);\r\n transition: var(--transition);\r\n\r\n &:hover,\r\n &:focus {\r\n box-shadow: 0 20px 30px -15px var(--navy-shadow);\r\n }\r\n `,\r\n\r\n fancyList: css`\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n font-size: var(--fz-lg);\r\n li {\r\n position: relative;\r\n padding-left: 30px;\r\n margin-bottom: 10px;\r\n &:before {\r\n content: '▹';\r\n position: absolute;\r\n left: 0;\r\n color: var(--green);\r\n }\r\n }\r\n `,\r\n\r\n resetList: css`\r\n list-style: none;\r\n padding: 0;\r\n margin: 0;\r\n `,\r\n};\r\n\r\nexport default mixins;\r\n","import mixins from './mixins';\r\n\r\nconst theme = {\r\n bp: {\r\n mobileS: `max-width: 330px`,\r\n mobileM: `max-width: 400px`,\r\n mobileL: `max-width: 480px`,\r\n tabletS: `max-width: 600px`,\r\n tabletL: `max-width: 768px`,\r\n desktopXS: `max-width: 900px`,\r\n desktopS: `max-width: 1080px`,\r\n desktopM: `max-width: 1200px`,\r\n desktopL: `max-width: 1400px`,\r\n },\r\n\r\n mixins,\r\n};\r\n\r\nexport default theme;\r\n","import { css } from 'styled-components';\r\n\r\nimport CalibreRegularWoff from '@fonts/Calibre/Calibre-Regular.woff';\r\nimport CalibreRegularWoff2 from '@fonts/Calibre/Calibre-Regular.woff2';\r\nimport CalibreMediumWoff from '@fonts/Calibre/Calibre-Medium.woff';\r\nimport CalibreMediumWoff2 from '@fonts/Calibre/Calibre-Medium.woff2';\r\nimport CalibreSemiboldWoff from '@fonts/Calibre/Calibre-Semibold.woff';\r\nimport CalibreSemiboldWoff2 from '@fonts/Calibre/Calibre-Semibold.woff2';\r\n\r\nimport CalibreRegularItalicWoff from '@fonts/Calibre/Calibre-RegularItalic.woff';\r\nimport CalibreRegularItalicWoff2 from '@fonts/Calibre/Calibre-RegularItalic.woff2';\r\nimport CalibreMediumItalicWoff from '@fonts/Calibre/Calibre-MediumItalic.woff';\r\nimport CalibreMediumItalicWoff2 from '@fonts/Calibre/Calibre-MediumItalic.woff2';\r\nimport CalibreSemiboldItalicWoff from '@fonts/Calibre/Calibre-SemiboldItalic.woff';\r\nimport CalibreSemiboldItalicWoff2 from '@fonts/Calibre/Calibre-SemiboldItalic.woff2';\r\n\r\nimport SFMonoRegularWoff from '@fonts/SFMono/SFMono-Regular.woff';\r\nimport SFMonoRegularWoff2 from '@fonts/SFMono/SFMono-Regular.woff2';\r\nimport SFMonoSemiboldWoff from '@fonts/SFMono/SFMono-Semibold.woff';\r\nimport SFMonoSemiboldWoff2 from '@fonts/SFMono/SFMono-Semibold.woff2';\r\n\r\nimport SFMonoRegularItalicWoff from '@fonts/SFMono/SFMono-RegularItalic.woff';\r\nimport SFMonoRegularItalicWoff2 from '@fonts/SFMono/SFMono-RegularItalic.woff2';\r\nimport SFMonoSemiboldItalicWoff from '@fonts/SFMono/SFMono-SemiboldItalic.woff';\r\nimport SFMonoSemiboldItalicWoff2 from '@fonts/SFMono/SFMono-SemiboldItalic.woff2';\r\n\r\nconst calibreNormalWeights = {\r\n 400: [CalibreRegularWoff, CalibreRegularWoff2],\r\n 500: [CalibreMediumWoff, CalibreMediumWoff2],\r\n 600: [CalibreSemiboldWoff, CalibreSemiboldWoff2],\r\n};\r\n\r\nconst calibreItalicWeights = {\r\n 400: [CalibreRegularItalicWoff, CalibreRegularItalicWoff2],\r\n 500: [CalibreMediumItalicWoff, CalibreMediumItalicWoff2],\r\n 600: [CalibreSemiboldItalicWoff, CalibreSemiboldItalicWoff2],\r\n};\r\n\r\nconst sfMonoNormalWeights = {\r\n 400: [SFMonoRegularWoff, SFMonoRegularWoff2],\r\n 600: [SFMonoSemiboldWoff, SFMonoSemiboldWoff2],\r\n};\r\n\r\nconst sfMonoItalicWeights = {\r\n 400: [SFMonoRegularItalicWoff, SFMonoRegularItalicWoff2],\r\n 600: [SFMonoSemiboldItalicWoff, SFMonoSemiboldItalicWoff2],\r\n};\r\n\r\nconst calibre = {\r\n name: 'Calibre',\r\n normal: calibreNormalWeights,\r\n italic: calibreItalicWeights,\r\n};\r\n\r\nconst sfMono = {\r\n name: 'SF Mono',\r\n normal: sfMonoNormalWeights,\r\n italic: sfMonoItalicWeights,\r\n};\r\n\r\nconst createFontFaces = (family, style = 'normal') => {\r\n let styles = '';\r\n\r\n for (const [weight, formats] of Object.entries(family[style])) {\r\n const woff = formats[0];\r\n const woff2 = formats[1];\r\n\r\n styles += `\r\n @font-face {\r\n font-family: '${family.name}';\r\n src: url(${woff2}) format('woff2'),\r\n url(${woff}) format('woff');\r\n font-weight: ${weight};\r\n font-style: ${style};\r\n font-display: auto;\r\n }\r\n `;\r\n }\r\n\r\n return styles;\r\n};\r\n\r\nconst calibreNormal = createFontFaces(calibre);\r\nconst calibreItalic = createFontFaces(calibre, 'italic');\r\n\r\nconst sfMonoNormal = createFontFaces(sfMono);\r\nconst sfMonoItalic = createFontFaces(sfMono, 'italic');\r\n\r\nconst Fonts = css`\r\n ${calibreNormal + calibreItalic + sfMonoNormal + sfMonoItalic}\r\n`;\r\n\r\nexport default Fonts;\r\n","export default __webpack_public_path__ + \"static/Calibre-Regular-98526589fa32315c552129869e08427e.woff\";","export default __webpack_public_path__ + \"static/Calibre-Regular-b0d4cbb1201155ddccc21d1b8059a670.woff2\";","export default __webpack_public_path__ + \"static/Calibre-Medium-46693d9b57a6b8a657b5393258f6e899.woff\";","export default __webpack_public_path__ + \"static/Calibre-Medium-568dce56f869a519a015d3b69443b067.woff2\";","export default __webpack_public_path__ + \"static/Calibre-Semibold-6972688a249bd53a6c7e69a89e50cdd6.woff\";","export default __webpack_public_path__ + \"static/Calibre-Semibold-94fc73852539d6733dc0d80252c5e3fb.woff2\";","export default __webpack_public_path__ + \"static/Calibre-RegularItalic-57371b9e514dbbe9da31dad1a298de2d.woff\";","export default __webpack_public_path__ + \"static/Calibre-RegularItalic-5f875bd7b669f1e11b622d4d6d71b5b0.woff2\";","export default __webpack_public_path__ + \"static/Calibre-MediumItalic-aa285f95879aa2c2d26b228d5e422da6.woff\";","export default __webpack_public_path__ + \"static/Calibre-MediumItalic-7aa140573fd9ed30ae01e117c418b12b.woff2\";","export default __webpack_public_path__ + \"static/Calibre-SemiboldItalic-ad4bd95abee7bca1bdd6a93398f84a04.woff\";","export default __webpack_public_path__ + \"static/Calibre-SemiboldItalic-5f04bffe7ce988169806d66e417a966a.woff2\";","export default __webpack_public_path__ + \"static/SFMono-Regular-e36fa5257c93fc7711eae342068f9eda.woff\";","export default __webpack_public_path__ + \"static/SFMono-Regular-8799e6387338d58f2f137df821c86eb4.woff2\";","export default __webpack_public_path__ + \"static/SFMono-Semibold-ee054046915420413d0068fb1e7105c3.woff\";","export default __webpack_public_path__ + \"static/SFMono-Semibold-6e6f6c93f4bdf9cbd090c60e97a017e2.woff2\";","export default __webpack_public_path__ + \"static/SFMono-RegularItalic-3a20a00dfdeb4ba538473fa7bf625cbd.woff\";","export default __webpack_public_path__ + \"static/SFMono-RegularItalic-a596917f86217b40000ff1b894cd0e52.woff2\";","export default __webpack_public_path__ + \"static/SFMono-SemiboldItalic-10eb596e904940cd1aebb2cc6286015c.woff\";","export default __webpack_public_path__ + \"static/SFMono-SemiboldItalic-9a0ae6382e12c5e28a7342ffb41cf4da.woff2\";","import { css } from 'styled-components';\r\n\r\nconst variables = css`\r\n :root {\r\n --dark-navy: #020c1b;\r\n --navy: #0a192f;\r\n --light-navy: #112240;\r\n --lightest-navy: #233554;\r\n --navy-shadow: rgba(2, 12, 27, 0.7);\r\n --dark-slate: #495670;\r\n --slate: #8892b0;\r\n --light-slate: #a8b2d1;\r\n --lightest-slate: #ccd6f6;\r\n --white: #e6f1ff;\r\n --green: #64ffda;\r\n --green-tint: rgba(100, 255, 218, 0.1);\r\n --pink: #f57dff;\r\n --blue: #57cbff;\r\n\r\n --font-sans: 'Calibre', 'Inter', 'San Francisco', 'SF Pro Text', -apple-system, system-ui,\r\n sans-serif;\r\n --font-mono: 'SF Mono', 'Fira Code', 'Fira Mono', 'Roboto Mono', monospace;\r\n\r\n --fz-xxs: 12px;\r\n --fz-xs: 13px;\r\n --fz-sm: 14px;\r\n --fz-md: 16px;\r\n --fz-lg: 18px;\r\n --fz-xl: 20px;\r\n --fz-xxl: 22px;\r\n --fz-heading: 32px;\r\n\r\n --border-radius: 4px;\r\n --nav-height: 100px;\r\n --nav-scroll-height: 70px;\r\n\r\n --tab-height: 42px;\r\n --tab-width: 120px;\r\n\r\n --easing: cubic-bezier(0.645, 0.045, 0.355, 1);\r\n --transition: all 0.25s cubic-bezier(0.645, 0.045, 0.355, 1);\r\n\r\n --hamburger-width: 30px;\r\n\r\n --ham-before: top 0.1s ease-in 0.25s, opacity 0.1s ease-in;\r\n --ham-before-active: top 0.1s ease-out, opacity 0.1s ease-out 0.12s;\r\n --ham-after: bottom 0.1s ease-in 0.25s, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19);\r\n --ham-after-active: bottom 0.1s ease-out,\r\n transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;\r\n }\r\n`;\r\n\r\nexport default variables;\r\n","import { css } from 'styled-components';\r\n\r\n// https://reactcommunity.org/react-transition-group/css-transition\r\n\r\nconst TransitionStyles = css`\r\n /* Fade up */\r\n .fadeup-enter {\r\n opacity: 0.01;\r\n transform: translateY(20px);\r\n transition: opacity 300ms var(--easing), transform 300ms var(--easing);\r\n }\r\n\r\n .fadeup-enter-active {\r\n opacity: 1;\r\n transform: translateY(0px);\r\n transition: opacity 300ms var(--easing), transform 300ms var(--easing);\r\n }\r\n\r\n /* Fade down */\r\n .fadedown-enter {\r\n opacity: 0.01;\r\n transform: translateY(-20px);\r\n transition: opacity 300ms var(--easing), transform 300ms var(--easing);\r\n }\r\n\r\n .fadedown-enter-active {\r\n opacity: 1;\r\n transform: translateY(0px);\r\n transition: opacity 300ms var(--easing), transform 300ms var(--easing);\r\n }\r\n\r\n /* Fade */\r\n .fade-enter {\r\n opacity: 0;\r\n }\r\n .fade-enter-active {\r\n opacity: 1;\r\n transition: opacity 300ms var(--easing);\r\n }\r\n .fade-exit {\r\n opacity: 1;\r\n }\r\n .fade-exit-active {\r\n opacity: 0;\r\n transition: opacity 300ms var(--easing);\r\n }\r\n`;\r\n\r\nexport default TransitionStyles;\r\n","import { css } from 'styled-components';\r\n\r\nconst prismColors = {\r\n bg: `#112340`,\r\n lineHighlight: `#1d2d50`,\r\n blue: `#5ccfe6`,\r\n purple: `#c3a6ff`,\r\n green: `#bae67e`,\r\n yellow: `#ffd580`,\r\n orange: `#ffae57`,\r\n red: `#ef6b73`,\r\n grey: `#a2aabc`,\r\n comment: `#8695b799`,\r\n};\r\n\r\n// https://www.gatsbyjs.org/packages/gatsby-remark-prismjs\r\n\r\nconst PrismStyles = css`\r\n /**\r\n * Add back the container background-color, border-radius, padding, margin\r\n * and overflow that we removed from <pre>.\r\n */\r\n .gatsby-highlight {\r\n background-color: ${prismColors.bg};\r\n color: ${prismColors.grey};\r\n border-radius: var(--border-radius);\r\n margin: 2em 0;\r\n padding: 1.25em;\r\n overflow: auto;\r\n position: relative;\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-md);\r\n }\r\n\r\n .gatsby-highlight code[class*='language-'],\r\n .gatsby-highlight pre[class*='language-'] {\r\n height: auto !important;\r\n font-size: var(--fz-sm);\r\n line-height: 1.5;\r\n white-space: pre;\r\n word-spacing: normal;\r\n word-break: normal;\r\n word-wrap: normal;\r\n tab-size: 2;\r\n hyphens: none;\r\n }\r\n\r\n /**\r\n * Remove the default PrismJS theme background-color, border-radius, margin,\r\n * padding and overflow.\r\n * 1. Make the element just wide enough to fit its content.\r\n * 2. Always fill the visible space in .gatsby-highlight.\r\n * 3. Adjust the position of the line numbers\r\n */\r\n .gatsby-highlight pre[class*='language-'] {\r\n background-color: transparent;\r\n margin: 0;\r\n padding: 0;\r\n overflow: initial;\r\n float: left; /* 1 */\r\n min-width: 100%; /* 2 */\r\n padding-top: 2em;\r\n }\r\n\r\n /* File names */\r\n .gatsby-code-title {\r\n padding: 1em 1.5em;\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-xs);\r\n background-color: ${prismColors.bg};\r\n color: ${prismColors.grey};\r\n border-top-left-radius: var(--border-radius);\r\n border-top-right-radius: var(--border-radius);\r\n border-bottom: 1px solid ${prismColors.lineHighlight};\r\n\r\n & + .gatsby-highlight {\r\n margin-top: 0;\r\n border-top-left-radius: 0;\r\n border-top-right-radius: 0;\r\n }\r\n }\r\n\r\n /* Line highlighting */\r\n .gatsby-highlight-code-line {\r\n display: block;\r\n background-color: ${prismColors.lineHighlight};\r\n border-left: 2px solid var(--green);\r\n padding-left: calc(1em + 2px);\r\n padding-right: 1em;\r\n margin-right: -1.35em;\r\n margin-left: -1.35em;\r\n }\r\n\r\n /* Language badges */\r\n .gatsby-highlight pre[class*='language-']::before {\r\n background: var(--lightest-navy);\r\n color: var(--white);\r\n font-size: var(--fz-xxs);\r\n font-family: var(--font-mono);\r\n line-height: 1.5;\r\n letter-spacing: 0.1em;\r\n text-transform: uppercase;\r\n border-radius: 0 0 3px 3px;\r\n position: absolute;\r\n top: 0;\r\n left: 1.25rem;\r\n padding: 0.25rem 0.5rem;\r\n }\r\n .gatsby-highlight pre[class='language-javascript']::before {\r\n content: 'js';\r\n }\r\n .gatsby-highlight pre[class='language-js']::before {\r\n content: 'js';\r\n }\r\n .gatsby-highlight pre[class='language-jsx']::before {\r\n content: 'jsx';\r\n }\r\n .gatsby-highlight pre[class='language-graphql']::before {\r\n content: 'GraphQL';\r\n }\r\n .gatsby-highlight pre[class='language-html']::before {\r\n content: 'html';\r\n }\r\n .gatsby-highlight pre[class='language-css']::before {\r\n content: 'css';\r\n }\r\n .gatsby-highlight pre[class='language-mdx']::before {\r\n content: 'mdx';\r\n }\r\n .gatsby-highlight pre[class='language-shell']::before {\r\n content: 'shell';\r\n }\r\n .gatsby-highlight pre[class='language-sh']::before {\r\n content: 'sh';\r\n }\r\n .gatsby-highlight pre[class='language-bash']::before {\r\n content: 'bash';\r\n }\r\n .gatsby-highlight pre[class='language-yaml']::before {\r\n content: 'yaml';\r\n }\r\n .gatsby-highlight pre[class='language-markdown']::before {\r\n content: 'md';\r\n }\r\n .gatsby-highlight pre[class='language-json']::before,\r\n .gatsby-highlight pre[class='language-json5']::before {\r\n content: 'json';\r\n }\r\n .gatsby-highlight pre[class='language-diff']::before {\r\n content: 'diff';\r\n }\r\n .gatsby-highlight pre[class='language-text']::before {\r\n content: 'text';\r\n }\r\n .gatsby-highlight pre[class='language-flow']::before {\r\n content: 'flow';\r\n }\r\n\r\n /* Prism Styles */\r\n .token {\r\n display: inline;\r\n }\r\n .token.comment,\r\n .token.block-comment,\r\n .token.prolog,\r\n .token.doctype,\r\n .token.cdata {\r\n color: ${prismColors.comment};\r\n }\r\n .token.punctuation {\r\n color: ${prismColors.grey};\r\n }\r\n .token.namespace,\r\n .token.deleted {\r\n color: ${prismColors.red};\r\n }\r\n .token.function-name,\r\n .token.function,\r\n .token.class-name,\r\n .token.constant,\r\n .token.symbol {\r\n color: ${prismColors.yellow};\r\n }\r\n .token.attr-name,\r\n .token.operator,\r\n .token.rule {\r\n color: ${prismColors.orange};\r\n }\r\n .token.keyword,\r\n .token.boolean,\r\n .token.number,\r\n .token.property {\r\n color: ${prismColors.purple};\r\n }\r\n .token.tag,\r\n .token.selector,\r\n .token.important,\r\n .token.atrule,\r\n .token.builtin,\r\n .token.entity,\r\n .token.url {\r\n color: ${prismColors.blue};\r\n }\r\n .token.string,\r\n .token.char,\r\n .token.attr-value,\r\n .token.regex,\r\n .token.variable,\r\n .token.inserted {\r\n color: ${prismColors.green};\r\n }\r\n .token.important,\r\n .token.bold {\r\n font-weight: 600;\r\n }\r\n .token.italic {\r\n font-style: italic;\r\n }\r\n .token.entity {\r\n cursor: help;\r\n }\r\n .namespace {\r\n opacity: 0.7;\r\n }\r\n`;\r\n\r\nexport default PrismStyles;\r\n","import { createGlobalStyle } from 'styled-components';\r\nimport fonts from './fonts';\r\nimport variables from './variables';\r\nimport TransitionStyles from './TransitionStyles';\r\nimport PrismStyles from './PrismStyles';\r\n\r\nconst GlobalStyle = createGlobalStyle`\r\n ${fonts};\r\n ${variables};\r\n\r\n html {\r\n box-sizing: border-box;\r\n width: 100%;\r\n scroll-behavior: smooth;\r\n }\r\n\r\n *,\r\n *:before,\r\n *:after {\r\n box-sizing: inherit;\r\n }\r\n\r\n ::selection {\r\n background-color: var(--lightest-navy);\r\n color: var(--lightest-slate);\r\n }\r\n\r\n /* Provide basic, default focus styles.*/\r\n :focus {\r\n outline: 2px dashed var(--green);\r\n outline-offset: 3px;\r\n }\r\n\r\n /*\r\n Remove default focus styles for mouse users ONLY if\r\n :focus-visible is supported on this platform.\r\n */\r\n :focus:not(:focus-visible) {\r\n outline: none;\r\n outline-offset: 0px;\r\n }\r\n\r\n /*\r\n Optionally: If :focus-visible is supported on this\r\n platform, provide enhanced focus styles for keyboard\r\n focus.\r\n */\r\n :focus-visible {\r\n outline: 2px dashed var(--green);\r\n outline-offset: 3px;\r\n }\r\n\r\n /* Scrollbar Styles */\r\n html {\r\n scrollbar-width: thin;\r\n scrollbar-color: var(--dark-slate) var(--navy);\r\n }\r\n ::-webkit-scrollbar {\r\n width: 12px;\r\n }\r\n ::-webkit-scrollbar-track {\r\n background: var(--navy);\r\n }\r\n ::-webkit-scrollbar-thumb {\r\n background-color: var(--dark-slate);\r\n border: 3px solid var(--navy);\r\n border-radius: 10px;\r\n }\r\n\r\n body {\r\n margin: 0;\r\n width: 100%;\r\n min-height: 100%;\r\n overflow-x: hidden;\r\n -moz-osx-font-smoothing: grayscale;\r\n -webkit-font-smoothing: antialiased;\r\n background-color: var(--navy);\r\n color: var(--slate);\r\n font-family: var(--font-sans);\r\n font-size: var(--fz-xl);\r\n line-height: 1.3;\r\n\r\n @media (max-width: 480px) {\r\n font-size: var(--fz-lg);\r\n }\r\n\r\n &.hidden {\r\n overflow: hidden;\r\n }\r\n\r\n &.blur {\r\n overflow: hidden;\r\n\r\n header {\r\n background-color: transparent;\r\n }\r\n\r\n #content > * {\r\n filter: blur(5px) brightness(0.7);\r\n transition: var(--transition);\r\n pointer-events: none;\r\n user-select: none;\r\n }\r\n }\r\n }\r\n\r\n #root {\r\n min-height: 100vh;\r\n display: grid;\r\n grid-template-rows: 1fr auto;\r\n grid-template-columns: 100%;\r\n }\r\n\r\n main {\r\n margin: 0 auto;\r\n width: 100%;\r\n max-width: 1600px;\r\n min-height: 100vh;\r\n padding: 200px 150px;\r\n\r\n @media (max-width: 1080px) {\r\n padding: 200px 100px;\r\n }\r\n @media (max-width: 768px) {\r\n padding: 150px 50px;\r\n }\r\n @media (max-width: 480px) {\r\n padding: 125px 25px;\r\n }\r\n\r\n &.fillHeight {\r\n padding: 0 150px;\r\n\r\n @media (max-width: 1080px) {\r\n padding: 0 100px;\r\n }\r\n @media (max-width: 768px) {\r\n padding: 0 50px;\r\n }\r\n @media (max-width: 480px) {\r\n padding: 0 25px;\r\n }\r\n }\r\n }\r\n\r\n section {\r\n margin: 0 auto;\r\n padding: 100px 0;\r\n max-width: 1000px;\r\n\r\n @media (max-width: 768px) {\r\n padding: 80px 0;\r\n }\r\n\r\n @media (max-width: 480px) {\r\n padding: 60px 0;\r\n }\r\n }\r\n\r\n h1,\r\n h2,\r\n h3,\r\n h4,\r\n h5,\r\n h6 {\r\n margin: 0 0 10px 0;\r\n font-weight: 600;\r\n color: var(--lightest-slate);\r\n line-height: 1.1;\r\n }\r\n\r\n .big-heading {\r\n margin: 0;\r\n font-size: clamp(40px, 8vw, 80px);\r\n }\r\n\r\n .medium-heading {\r\n margin: 0;\r\n font-size: clamp(40px, 8vw, 60px);\r\n }\r\n\r\n .numbered-heading {\r\n display: flex;\r\n align-items: center;\r\n position: relative;\r\n margin: 10px 0 40px;\r\n width: 100%;\r\n font-size: clamp(26px, 5vw, var(--fz-heading));\r\n white-space: nowrap;\r\n\r\n &:before {\r\n position: relative;\r\n bottom: 4px;\r\n counter-increment: section;\r\n content: '0' counter(section) '.';\r\n margin-right: 10px;\r\n color: var(--green);\r\n font-family: var(--font-mono);\r\n font-size: clamp(var(--fz-md), 3vw, var(--fz-xl));\r\n font-weight: 400;\r\n\r\n @media (max-width: 480px) {\r\n margin-bottom: -3px;\r\n margin-right: 5px;\r\n }\r\n }\r\n\r\n &:after {\r\n content: '';\r\n display: block;\r\n position: relative;\r\n top: -5px;\r\n width: 300px;\r\n height: 1px;\r\n margin-left: 20px;\r\n background-color: var(--lightest-navy);\r\n\r\n @media (max-width: 1080px) {\r\n width: 200px;\r\n }\r\n @media (max-width: 768px) {\r\n width: 100%;\r\n }\r\n @media (max-width: 600px) {\r\n margin-left: 10px;\r\n }\r\n }\r\n }\r\n\r\n img,\r\n svg,\r\n .gatsby-image-wrapper {\r\n width: 100%;\r\n max-width: 100%;\r\n vertical-align: middle;\r\n }\r\n\r\n img[alt=\"\"],\r\n img:not([alt]) {\r\n filter: blur(5px);\r\n }\r\n\r\n svg {\r\n width: 100%;\r\n height: 100%;\r\n fill: currentColor;\r\n vertical-align: middle;\r\n\r\n &.feather {\r\n fill: none;\r\n }\r\n }\r\n\r\n a {\r\n display: inline-block;\r\n text-decoration: none;\r\n text-decoration-skip-ink: auto;\r\n color: inherit;\r\n position: relative;\r\n transition: var(--transition);\r\n\r\n &:hover,\r\n &:focus {\r\n color: var(--green);\r\n }\r\n\r\n &.inline-link {\r\n ${({ theme }) => theme.mixins.inlineLink};\r\n }\r\n }\r\n\r\n button {\r\n cursor: pointer;\r\n border: 0;\r\n border-radius: 0;\r\n }\r\n\r\n input, textarea {\r\n border-radius: 0;\r\n outline: 0;\r\n\r\n &:focus {\r\n outline: 0;\r\n }\r\n &:focus,\r\n &:active {\r\n &::placeholder {\r\n opacity: 0.5;\r\n }\r\n }\r\n }\r\n\r\n p {\r\n margin: 0 0 15px 0;\r\n\r\n &:last-child,\r\n &:last-of-type {\r\n margin: 0;\r\n }\r\n\r\n & > a {\r\n ${({ theme }) => theme.mixins.inlineLink};\r\n }\r\n\r\n & > code {\r\n background-color: var(--light-navy);\r\n color: var(--white);\r\n font-size: var(--fz-sm);\r\n border-radius: var(--border-radius);\r\n padding: 0.3em 0.5em;\r\n }\r\n }\r\n\r\n ul {\r\n &.fancy-list {\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n font-size: var(--fz-lg);\r\n li {\r\n position: relative;\r\n padding-left: 30px;\r\n margin-bottom: 10px;\r\n &:before {\r\n content: '▹';\r\n position: absolute;\r\n left: 0;\r\n color: var(--green);\r\n }\r\n }\r\n }\r\n }\r\n\r\n blockquote {\r\n border-left-color: var(--green);\r\n border-left-style: solid;\r\n border-left-width: 1px;\r\n margin-left: 0px;\r\n margin-right: 0px;\r\n padding-left: 1.5rem;\r\n\r\n p {\r\n font-style: italic;\r\n font-size: 24px;\r\n }\r\n }\r\n\r\n hr {\r\n background-color: var(--lightest-navy);\r\n height: 1px;\r\n border-width: 0px;\r\n border-style: initial;\r\n border-color: initial;\r\n border-image: initial;\r\n margin: 1rem;\r\n }\r\n\r\n code {\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-md);\r\n }\r\n\r\n .skip-to-content {\r\n ${({ theme }) => theme.mixins.button};\r\n position: absolute;\r\n top: auto;\r\n left: -999px;\r\n width: 1px;\r\n height: 1px;\r\n overflow: hidden;\r\n z-index: -99;\r\n\r\n &:focus,\r\n &:active {\r\n background-color: var(--green);\r\n color: var(--navy);\r\n top: 0;\r\n left: 0;\r\n width: auto;\r\n height: auto;\r\n overflow: auto;\r\n z-index: 99;\r\n }\r\n }\r\n\r\n #logo {\r\n color: var(--green);\r\n }\r\n\r\n .overline {\r\n color: var(--green);\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-md);\r\n font-weight: 400;\r\n }\r\n\r\n .subtitle {\r\n color: var(--green);\r\n margin: 0 0 20px 0;\r\n font-size: var(--fz-md);\r\n font-family: var(--font-mono);\r\n font-weight: 400;\r\n line-height: 1.5;\r\n @media (max-width: 1080px) {\r\n font-size: var(--fz-sm);\r\n }\r\n @media (max-width: 768px) {\r\n font-size: var(--fz-xs);\r\n }\r\n\r\n a {\r\n ${({ theme }) => theme.mixins.inlineLink};\r\n line-height: 1.5;\r\n }\r\n }\r\n\r\n .breadcrumb {\r\n display: flex;\r\n align-items: center;\r\n margin-bottom: 50px;\r\n color: var(--green);\r\n\r\n .arrow {\r\n display: block;\r\n margin-right: 10px;\r\n padding-top: 4px;\r\n }\r\n\r\n a {\r\n ${({ theme }) => theme.mixins.inlineLink};\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-sm);\r\n font-weight: 600;\r\n line-height: 1.5;\r\n text-transform: uppercase;\r\n letter-spacing: 0.1em;\r\n }\r\n }\r\n\r\n .gatsby-image-outer-wrapper {\r\n height: 100%;\r\n }\r\n\r\n ${TransitionStyles};\r\n\r\n ${PrismStyles};\r\n`;\r\n\r\nexport default GlobalStyle;\r\n","import React, { useState, useEffect } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport styled, { ThemeProvider } from 'styled-components';\r\nimport { Head, Loader, Nav, Social, Email, Footer } from '@components';\r\nimport { GlobalStyle, theme } from '@styles';\r\n\r\nconst StyledContent = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n min-height: 100vh;\r\n`;\r\n\r\nconst Layout = ({ children, location }) => {\r\n const isHome = location.pathname === '/';\r\n const [isLoading, setIsLoading] = useState(isHome);\r\n\r\n // Sets target=\"_blank\" rel=\"noopener noreferrer\" on external links\r\n const handleExternalLinks = () => {\r\n const allLinks = Array.from(document.querySelectorAll('a'));\r\n if (allLinks.length > 0) {\r\n allLinks.forEach(link => {\r\n if (link.host !== window.location.host) {\r\n link.setAttribute('rel', 'noopener noreferrer');\r\n link.setAttribute('target', '_blank');\r\n }\r\n });\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (isLoading) {\r\n return;\r\n }\r\n\r\n if (location.hash) {\r\n const id = location.hash.substring(1); // location.hash without the '#'\r\n setTimeout(() => {\r\n const el = document.getElementById(id);\r\n if (el) {\r\n el.scrollIntoView();\r\n el.focus();\r\n }\r\n }, 0);\r\n }\r\n\r\n handleExternalLinks();\r\n }, [isLoading]);\r\n\r\n return (\r\n <>\r\n <Head />\r\n\r\n <div id=\"root\">\r\n <ThemeProvider theme={theme}>\r\n <GlobalStyle />\r\n\r\n <a className=\"skip-to-content\" href=\"#content\">\r\n Skip to Content\r\n </a>\r\n\r\n {isLoading && isHome ? (\r\n <Loader finishLoading={() => setIsLoading(false)} />\r\n ) : (\r\n <StyledContent>\r\n <Nav isHome={isHome} />\r\n <Social isHome={isHome} />\r\n <Email isHome={isHome} />\r\n\r\n <div id=\"content\">\r\n {children}\r\n <Footer />\r\n </div>\r\n </StyledContent>\r\n )}\r\n </ThemeProvider>\r\n </div>\r\n </>\r\n );\r\n};\r\n\r\nLayout.propTypes = {\r\n children: PropTypes.node.isRequired,\r\n location: PropTypes.object.isRequired,\r\n};\r\n\r\nexport default Layout;\r\n","/*\n * anime.js v3.2.1\n * (c) 2020 Julian Garnier\n * Released under the MIT license\n * animejs.com\n */\n\n// Defaults\n\nvar defaultInstanceSettings = {\n update: null,\n begin: null,\n loopBegin: null,\n changeBegin: null,\n change: null,\n changeComplete: null,\n loopComplete: null,\n complete: null,\n loop: 1,\n direction: 'normal',\n autoplay: true,\n timelineOffset: 0\n};\nvar defaultTweenSettings = {\n duration: 1000,\n delay: 0,\n endDelay: 0,\n easing: 'easeOutElastic(1, .5)',\n round: 0\n};\nvar validTransforms = ['translateX', 'translateY', 'translateZ', 'rotate', 'rotateX', 'rotateY', 'rotateZ', 'scale', 'scaleX', 'scaleY', 'scaleZ', 'skew', 'skewX', 'skewY', 'perspective', 'matrix', 'matrix3d'];\n\n// Caching\n\nvar cache = {\n CSS: {},\n springs: {}\n};\n\n// Utils\n\nfunction minMax(val, min, max) {\n return Math.min(Math.max(val, min), max);\n}\nfunction stringContains(str, text) {\n return str.indexOf(text) > -1;\n}\nfunction applyArguments(func, args) {\n return func.apply(null, args);\n}\nvar is = {\n arr: function arr(a) {\n return Array.isArray(a);\n },\n obj: function obj(a) {\n return stringContains(Object.prototype.toString.call(a), 'Object');\n },\n pth: function pth(a) {\n return is.obj(a) && a.hasOwnProperty('totalLength');\n },\n svg: function svg(a) {\n return a instanceof SVGElement;\n },\n inp: function inp(a) {\n return a instanceof HTMLInputElement;\n },\n dom: function dom(a) {\n return a.nodeType || is.svg(a);\n },\n str: function str(a) {\n return typeof a === 'string';\n },\n fnc: function fnc(a) {\n return typeof a === 'function';\n },\n und: function und(a) {\n return typeof a === 'undefined';\n },\n nil: function nil(a) {\n return is.und(a) || a === null;\n },\n hex: function hex(a) {\n return /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(a);\n },\n rgb: function rgb(a) {\n return /^rgb/.test(a);\n },\n hsl: function hsl(a) {\n return /^hsl/.test(a);\n },\n col: function col(a) {\n return is.hex(a) || is.rgb(a) || is.hsl(a);\n },\n key: function key(a) {\n return !defaultInstanceSettings.hasOwnProperty(a) && !defaultTweenSettings.hasOwnProperty(a) && a !== 'targets' && a !== 'keyframes';\n }\n};\n\n// Easings\n\nfunction parseEasingParameters(string) {\n var match = /\\(([^)]+)\\)/.exec(string);\n return match ? match[1].split(',').map(function (p) {\n return parseFloat(p);\n }) : [];\n}\n\n// Spring solver inspired by Webkit Copyright © 2016 Apple Inc. All rights reserved. https://webkit.org/demos/spring/spring.js\n\nfunction spring(string, duration) {\n var params = parseEasingParameters(string);\n var mass = minMax(is.und(params[0]) ? 1 : params[0], .1, 100);\n var stiffness = minMax(is.und(params[1]) ? 100 : params[1], .1, 100);\n var damping = minMax(is.und(params[2]) ? 10 : params[2], .1, 100);\n var velocity = minMax(is.und(params[3]) ? 0 : params[3], .1, 100);\n var w0 = Math.sqrt(stiffness / mass);\n var zeta = damping / (2 * Math.sqrt(stiffness * mass));\n var wd = zeta < 1 ? w0 * Math.sqrt(1 - zeta * zeta) : 0;\n var a = 1;\n var b = zeta < 1 ? (zeta * w0 + -velocity) / wd : -velocity + w0;\n function solver(t) {\n var progress = duration ? duration * t / 1000 : t;\n if (zeta < 1) {\n progress = Math.exp(-progress * zeta * w0) * (a * Math.cos(wd * progress) + b * Math.sin(wd * progress));\n } else {\n progress = (a + b * progress) * Math.exp(-progress * w0);\n }\n if (t === 0 || t === 1) {\n return t;\n }\n return 1 - progress;\n }\n function getDuration() {\n var cached = cache.springs[string];\n if (cached) {\n return cached;\n }\n var frame = 1 / 6;\n var elapsed = 0;\n var rest = 0;\n while (true) {\n elapsed += frame;\n if (solver(elapsed) === 1) {\n rest++;\n if (rest >= 16) {\n break;\n }\n } else {\n rest = 0;\n }\n }\n var duration = elapsed * frame * 1000;\n cache.springs[string] = duration;\n return duration;\n }\n return duration ? solver : getDuration;\n}\n\n// Basic steps easing implementation https://developer.mozilla.org/fr/docs/Web/CSS/transition-timing-function\n\nfunction steps(steps) {\n if (steps === void 0) steps = 10;\n return function (t) {\n return Math.ceil(minMax(t, 0.000001, 1) * steps) * (1 / steps);\n };\n}\n\n// BezierEasing https://github.com/gre/bezier-easing\n\nvar bezier = function () {\n var kSplineTableSize = 11;\n var kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\n function A(aA1, aA2) {\n return 1.0 - 3.0 * aA2 + 3.0 * aA1;\n }\n function B(aA1, aA2) {\n return 3.0 * aA2 - 6.0 * aA1;\n }\n function C(aA1) {\n return 3.0 * aA1;\n }\n function calcBezier(aT, aA1, aA2) {\n return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT;\n }\n function getSlope(aT, aA1, aA2) {\n return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1);\n }\n function binarySubdivide(aX, aA, aB, mX1, mX2) {\n var currentX,\n currentT,\n i = 0;\n do {\n currentT = aA + (aB - aA) / 2.0;\n currentX = calcBezier(currentT, mX1, mX2) - aX;\n if (currentX > 0.0) {\n aB = currentT;\n } else {\n aA = currentT;\n }\n } while (Math.abs(currentX) > 0.0000001 && ++i < 10);\n return currentT;\n }\n function newtonRaphsonIterate(aX, aGuessT, mX1, mX2) {\n for (var i = 0; i < 4; ++i) {\n var currentSlope = getSlope(aGuessT, mX1, mX2);\n if (currentSlope === 0.0) {\n return aGuessT;\n }\n var currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n }\n function bezier(mX1, mY1, mX2, mY2) {\n if (!(0 <= mX1 && mX1 <= 1 && 0 <= mX2 && mX2 <= 1)) {\n return;\n }\n var sampleValues = new Float32Array(kSplineTableSize);\n if (mX1 !== mY1 || mX2 !== mY2) {\n for (var i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n }\n function getTForX(aX) {\n var intervalStart = 0;\n var currentSample = 1;\n var lastSample = kSplineTableSize - 1;\n for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n var dist = (aX - sampleValues[currentSample]) / (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n var guessForT = intervalStart + dist * kSampleStepSize;\n var initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= 0.001) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n } else if (initialSlope === 0.0) {\n return guessForT;\n } else {\n return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n }\n }\n return function (x) {\n if (mX1 === mY1 && mX2 === mY2) {\n return x;\n }\n if (x === 0 || x === 1) {\n return x;\n }\n return calcBezier(getTForX(x), mY1, mY2);\n };\n }\n return bezier;\n}();\nvar penner = function () {\n // Based on jQuery UI's implemenation of easing equations from Robert Penner (http://www.robertpenner.com/easing)\n\n var eases = {\n linear: function linear() {\n return function (t) {\n return t;\n };\n }\n };\n var functionEasings = {\n Sine: function Sine() {\n return function (t) {\n return 1 - Math.cos(t * Math.PI / 2);\n };\n },\n Circ: function Circ() {\n return function (t) {\n return 1 - Math.sqrt(1 - t * t);\n };\n },\n Back: function Back() {\n return function (t) {\n return t * t * (3 * t - 2);\n };\n },\n Bounce: function Bounce() {\n return function (t) {\n var pow2,\n b = 4;\n while (t < ((pow2 = Math.pow(2, --b)) - 1) / 11) {}\n return 1 / Math.pow(4, 3 - b) - 7.5625 * Math.pow((pow2 * 3 - 2) / 22 - t, 2);\n };\n },\n Elastic: function Elastic(amplitude, period) {\n if (amplitude === void 0) amplitude = 1;\n if (period === void 0) period = .5;\n var a = minMax(amplitude, 1, 10);\n var p = minMax(period, .1, 2);\n return function (t) {\n return t === 0 || t === 1 ? t : -a * Math.pow(2, 10 * (t - 1)) * Math.sin((t - 1 - p / (Math.PI * 2) * Math.asin(1 / a)) * (Math.PI * 2) / p);\n };\n }\n };\n var baseEasings = ['Quad', 'Cubic', 'Quart', 'Quint', 'Expo'];\n baseEasings.forEach(function (name, i) {\n functionEasings[name] = function () {\n return function (t) {\n return Math.pow(t, i + 2);\n };\n };\n });\n Object.keys(functionEasings).forEach(function (name) {\n var easeIn = functionEasings[name];\n eases['easeIn' + name] = easeIn;\n eases['easeOut' + name] = function (a, b) {\n return function (t) {\n return 1 - easeIn(a, b)(1 - t);\n };\n };\n eases['easeInOut' + name] = function (a, b) {\n return function (t) {\n return t < 0.5 ? easeIn(a, b)(t * 2) / 2 : 1 - easeIn(a, b)(t * -2 + 2) / 2;\n };\n };\n eases['easeOutIn' + name] = function (a, b) {\n return function (t) {\n return t < 0.5 ? (1 - easeIn(a, b)(1 - t * 2)) / 2 : (easeIn(a, b)(t * 2 - 1) + 1) / 2;\n };\n };\n });\n return eases;\n}();\nfunction parseEasings(easing, duration) {\n if (is.fnc(easing)) {\n return easing;\n }\n var name = easing.split('(')[0];\n var ease = penner[name];\n var args = parseEasingParameters(easing);\n switch (name) {\n case 'spring':\n return spring(easing, duration);\n case 'cubicBezier':\n return applyArguments(bezier, args);\n case 'steps':\n return applyArguments(steps, args);\n default:\n return applyArguments(ease, args);\n }\n}\n\n// Strings\n\nfunction selectString(str) {\n try {\n var nodes = document.querySelectorAll(str);\n return nodes;\n } catch (e) {\n return;\n }\n}\n\n// Arrays\n\nfunction filterArray(arr, callback) {\n var len = arr.length;\n var thisArg = arguments.length >= 2 ? arguments[1] : void 0;\n var result = [];\n for (var i = 0; i < len; i++) {\n if (i in arr) {\n var val = arr[i];\n if (callback.call(thisArg, val, i, arr)) {\n result.push(val);\n }\n }\n }\n return result;\n}\nfunction flattenArray(arr) {\n return arr.reduce(function (a, b) {\n return a.concat(is.arr(b) ? flattenArray(b) : b);\n }, []);\n}\nfunction toArray(o) {\n if (is.arr(o)) {\n return o;\n }\n if (is.str(o)) {\n o = selectString(o) || o;\n }\n if (o instanceof NodeList || o instanceof HTMLCollection) {\n return [].slice.call(o);\n }\n return [o];\n}\nfunction arrayContains(arr, val) {\n return arr.some(function (a) {\n return a === val;\n });\n}\n\n// Objects\n\nfunction cloneObject(o) {\n var clone = {};\n for (var p in o) {\n clone[p] = o[p];\n }\n return clone;\n}\nfunction replaceObjectProps(o1, o2) {\n var o = cloneObject(o1);\n for (var p in o1) {\n o[p] = o2.hasOwnProperty(p) ? o2[p] : o1[p];\n }\n return o;\n}\nfunction mergeObjects(o1, o2) {\n var o = cloneObject(o1);\n for (var p in o2) {\n o[p] = is.und(o1[p]) ? o2[p] : o1[p];\n }\n return o;\n}\n\n// Colors\n\nfunction rgbToRgba(rgbValue) {\n var rgb = /rgb\\((\\d+,\\s*[\\d]+,\\s*[\\d]+)\\)/g.exec(rgbValue);\n return rgb ? \"rgba(\" + rgb[1] + \",1)\" : rgbValue;\n}\nfunction hexToRgba(hexValue) {\n var rgx = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n var hex = hexValue.replace(rgx, function (m, r, g, b) {\n return r + r + g + g + b + b;\n });\n var rgb = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n var r = parseInt(rgb[1], 16);\n var g = parseInt(rgb[2], 16);\n var b = parseInt(rgb[3], 16);\n return \"rgba(\" + r + \",\" + g + \",\" + b + \",1)\";\n}\nfunction hslToRgba(hslValue) {\n var hsl = /hsl\\((\\d+),\\s*([\\d.]+)%,\\s*([\\d.]+)%\\)/g.exec(hslValue) || /hsla\\((\\d+),\\s*([\\d.]+)%,\\s*([\\d.]+)%,\\s*([\\d.]+)\\)/g.exec(hslValue);\n var h = parseInt(hsl[1], 10) / 360;\n var s = parseInt(hsl[2], 10) / 100;\n var l = parseInt(hsl[3], 10) / 100;\n var a = hsl[4] || 1;\n function hue2rgb(p, q, t) {\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * 6 * t;\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n }\n var r, g, b;\n if (s == 0) {\n r = g = b = l;\n } else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n return \"rgba(\" + r * 255 + \",\" + g * 255 + \",\" + b * 255 + \",\" + a + \")\";\n}\nfunction colorToRgb(val) {\n if (is.rgb(val)) {\n return rgbToRgba(val);\n }\n if (is.hex(val)) {\n return hexToRgba(val);\n }\n if (is.hsl(val)) {\n return hslToRgba(val);\n }\n}\n\n// Units\n\nfunction getUnit(val) {\n var split = /[+-]?\\d*\\.?\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(val);\n if (split) {\n return split[1];\n }\n}\nfunction getTransformUnit(propName) {\n if (stringContains(propName, 'translate') || propName === 'perspective') {\n return 'px';\n }\n if (stringContains(propName, 'rotate') || stringContains(propName, 'skew')) {\n return 'deg';\n }\n}\n\n// Values\n\nfunction getFunctionValue(val, animatable) {\n if (!is.fnc(val)) {\n return val;\n }\n return val(animatable.target, animatable.id, animatable.total);\n}\nfunction getAttribute(el, prop) {\n return el.getAttribute(prop);\n}\nfunction convertPxToUnit(el, value, unit) {\n var valueUnit = getUnit(value);\n if (arrayContains([unit, 'deg', 'rad', 'turn'], valueUnit)) {\n return value;\n }\n var cached = cache.CSS[value + unit];\n if (!is.und(cached)) {\n return cached;\n }\n var baseline = 100;\n var tempEl = document.createElement(el.tagName);\n var parentEl = el.parentNode && el.parentNode !== document ? el.parentNode : document.body;\n parentEl.appendChild(tempEl);\n tempEl.style.position = 'absolute';\n tempEl.style.width = baseline + unit;\n var factor = baseline / tempEl.offsetWidth;\n parentEl.removeChild(tempEl);\n var convertedUnit = factor * parseFloat(value);\n cache.CSS[value + unit] = convertedUnit;\n return convertedUnit;\n}\nfunction getCSSValue(el, prop, unit) {\n if (prop in el.style) {\n var uppercasePropName = prop.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n var value = el.style[prop] || getComputedStyle(el).getPropertyValue(uppercasePropName) || '0';\n return unit ? convertPxToUnit(el, value, unit) : value;\n }\n}\nfunction getAnimationType(el, prop) {\n if (is.dom(el) && !is.inp(el) && (!is.nil(getAttribute(el, prop)) || is.svg(el) && el[prop])) {\n return 'attribute';\n }\n if (is.dom(el) && arrayContains(validTransforms, prop)) {\n return 'transform';\n }\n if (is.dom(el) && prop !== 'transform' && getCSSValue(el, prop)) {\n return 'css';\n }\n if (el[prop] != null) {\n return 'object';\n }\n}\nfunction getElementTransforms(el) {\n if (!is.dom(el)) {\n return;\n }\n var str = el.style.transform || '';\n var reg = /(\\w+)\\(([^)]*)\\)/g;\n var transforms = new Map();\n var m;\n while (m = reg.exec(str)) {\n transforms.set(m[1], m[2]);\n }\n return transforms;\n}\nfunction getTransformValue(el, propName, animatable, unit) {\n var defaultVal = stringContains(propName, 'scale') ? 1 : 0 + getTransformUnit(propName);\n var value = getElementTransforms(el).get(propName) || defaultVal;\n if (animatable) {\n animatable.transforms.list.set(propName, value);\n animatable.transforms['last'] = propName;\n }\n return unit ? convertPxToUnit(el, value, unit) : value;\n}\nfunction getOriginalTargetValue(target, propName, unit, animatable) {\n switch (getAnimationType(target, propName)) {\n case 'transform':\n return getTransformValue(target, propName, animatable, unit);\n case 'css':\n return getCSSValue(target, propName, unit);\n case 'attribute':\n return getAttribute(target, propName);\n default:\n return target[propName] || 0;\n }\n}\nfunction getRelativeValue(to, from) {\n var operator = /^(\\*=|\\+=|-=)/.exec(to);\n if (!operator) {\n return to;\n }\n var u = getUnit(to) || 0;\n var x = parseFloat(from);\n var y = parseFloat(to.replace(operator[0], ''));\n switch (operator[0][0]) {\n case '+':\n return x + y + u;\n case '-':\n return x - y + u;\n case '*':\n return x * y + u;\n }\n}\nfunction validateValue(val, unit) {\n if (is.col(val)) {\n return colorToRgb(val);\n }\n if (/\\s/g.test(val)) {\n return val;\n }\n var originalUnit = getUnit(val);\n var unitLess = originalUnit ? val.substr(0, val.length - originalUnit.length) : val;\n if (unit) {\n return unitLess + unit;\n }\n return unitLess;\n}\n\n// getTotalLength() equivalent for circle, rect, polyline, polygon and line shapes\n// adapted from https://gist.github.com/SebLambla/3e0550c496c236709744\n\nfunction getDistance(p1, p2) {\n return Math.sqrt(Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2));\n}\nfunction getCircleLength(el) {\n return Math.PI * 2 * getAttribute(el, 'r');\n}\nfunction getRectLength(el) {\n return getAttribute(el, 'width') * 2 + getAttribute(el, 'height') * 2;\n}\nfunction getLineLength(el) {\n return getDistance({\n x: getAttribute(el, 'x1'),\n y: getAttribute(el, 'y1')\n }, {\n x: getAttribute(el, 'x2'),\n y: getAttribute(el, 'y2')\n });\n}\nfunction getPolylineLength(el) {\n var points = el.points;\n var totalLength = 0;\n var previousPos;\n for (var i = 0; i < points.numberOfItems; i++) {\n var currentPos = points.getItem(i);\n if (i > 0) {\n totalLength += getDistance(previousPos, currentPos);\n }\n previousPos = currentPos;\n }\n return totalLength;\n}\nfunction getPolygonLength(el) {\n var points = el.points;\n return getPolylineLength(el) + getDistance(points.getItem(points.numberOfItems - 1), points.getItem(0));\n}\n\n// Path animation\n\nfunction getTotalLength(el) {\n if (el.getTotalLength) {\n return el.getTotalLength();\n }\n switch (el.tagName.toLowerCase()) {\n case 'circle':\n return getCircleLength(el);\n case 'rect':\n return getRectLength(el);\n case 'line':\n return getLineLength(el);\n case 'polyline':\n return getPolylineLength(el);\n case 'polygon':\n return getPolygonLength(el);\n }\n}\nfunction setDashoffset(el) {\n var pathLength = getTotalLength(el);\n el.setAttribute('stroke-dasharray', pathLength);\n return pathLength;\n}\n\n// Motion path\n\nfunction getParentSvgEl(el) {\n var parentEl = el.parentNode;\n while (is.svg(parentEl)) {\n if (!is.svg(parentEl.parentNode)) {\n break;\n }\n parentEl = parentEl.parentNode;\n }\n return parentEl;\n}\nfunction getParentSvg(pathEl, svgData) {\n var svg = svgData || {};\n var parentSvgEl = svg.el || getParentSvgEl(pathEl);\n var rect = parentSvgEl.getBoundingClientRect();\n var viewBoxAttr = getAttribute(parentSvgEl, 'viewBox');\n var width = rect.width;\n var height = rect.height;\n var viewBox = svg.viewBox || (viewBoxAttr ? viewBoxAttr.split(' ') : [0, 0, width, height]);\n return {\n el: parentSvgEl,\n viewBox: viewBox,\n x: viewBox[0] / 1,\n y: viewBox[1] / 1,\n w: width,\n h: height,\n vW: viewBox[2],\n vH: viewBox[3]\n };\n}\nfunction getPath(path, percent) {\n var pathEl = is.str(path) ? selectString(path)[0] : path;\n var p = percent || 100;\n return function (property) {\n return {\n property: property,\n el: pathEl,\n svg: getParentSvg(pathEl),\n totalLength: getTotalLength(pathEl) * (p / 100)\n };\n };\n}\nfunction getPathProgress(path, progress, isPathTargetInsideSVG) {\n function point(offset) {\n if (offset === void 0) offset = 0;\n var l = progress + offset >= 1 ? progress + offset : 0;\n return path.el.getPointAtLength(l);\n }\n var svg = getParentSvg(path.el, path.svg);\n var p = point();\n var p0 = point(-1);\n var p1 = point(+1);\n var scaleX = isPathTargetInsideSVG ? 1 : svg.w / svg.vW;\n var scaleY = isPathTargetInsideSVG ? 1 : svg.h / svg.vH;\n switch (path.property) {\n case 'x':\n return (p.x - svg.x) * scaleX;\n case 'y':\n return (p.y - svg.y) * scaleY;\n case 'angle':\n return Math.atan2(p1.y - p0.y, p1.x - p0.x) * 180 / Math.PI;\n }\n}\n\n// Decompose value\n\nfunction decomposeValue(val, unit) {\n // const rgx = /-?\\d*\\.?\\d+/g; // handles basic numbers\n // const rgx = /[+-]?\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?/g; // handles exponents notation\n var rgx = /[+-]?\\d*\\.?\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?/g; // handles exponents notation\n var value = validateValue(is.pth(val) ? val.totalLength : val, unit) + '';\n return {\n original: value,\n numbers: value.match(rgx) ? value.match(rgx).map(Number) : [0],\n strings: is.str(val) || unit ? value.split(rgx) : []\n };\n}\n\n// Animatables\n\nfunction parseTargets(targets) {\n var targetsArray = targets ? flattenArray(is.arr(targets) ? targets.map(toArray) : toArray(targets)) : [];\n return filterArray(targetsArray, function (item, pos, self) {\n return self.indexOf(item) === pos;\n });\n}\nfunction getAnimatables(targets) {\n var parsed = parseTargets(targets);\n return parsed.map(function (t, i) {\n return {\n target: t,\n id: i,\n total: parsed.length,\n transforms: {\n list: getElementTransforms(t)\n }\n };\n });\n}\n\n// Properties\n\nfunction normalizePropertyTweens(prop, tweenSettings) {\n var settings = cloneObject(tweenSettings);\n // Override duration if easing is a spring\n if (/^spring/.test(settings.easing)) {\n settings.duration = spring(settings.easing);\n }\n if (is.arr(prop)) {\n var l = prop.length;\n var isFromTo = l === 2 && !is.obj(prop[0]);\n if (!isFromTo) {\n // Duration divided by the number of tweens\n if (!is.fnc(tweenSettings.duration)) {\n settings.duration = tweenSettings.duration / l;\n }\n } else {\n // Transform [from, to] values shorthand to a valid tween value\n prop = {\n value: prop\n };\n }\n }\n var propArray = is.arr(prop) ? prop : [prop];\n return propArray.map(function (v, i) {\n var obj = is.obj(v) && !is.pth(v) ? v : {\n value: v\n };\n // Default delay value should only be applied to the first tween\n if (is.und(obj.delay)) {\n obj.delay = !i ? tweenSettings.delay : 0;\n }\n // Default endDelay value should only be applied to the last tween\n if (is.und(obj.endDelay)) {\n obj.endDelay = i === propArray.length - 1 ? tweenSettings.endDelay : 0;\n }\n return obj;\n }).map(function (k) {\n return mergeObjects(k, settings);\n });\n}\nfunction flattenKeyframes(keyframes) {\n var propertyNames = filterArray(flattenArray(keyframes.map(function (key) {\n return Object.keys(key);\n })), function (p) {\n return is.key(p);\n }).reduce(function (a, b) {\n if (a.indexOf(b) < 0) {\n a.push(b);\n }\n return a;\n }, []);\n var properties = {};\n var loop = function loop(i) {\n var propName = propertyNames[i];\n properties[propName] = keyframes.map(function (key) {\n var newKey = {};\n for (var p in key) {\n if (is.key(p)) {\n if (p == propName) {\n newKey.value = key[p];\n }\n } else {\n newKey[p] = key[p];\n }\n }\n return newKey;\n });\n };\n for (var i = 0; i < propertyNames.length; i++) loop(i);\n return properties;\n}\nfunction getProperties(tweenSettings, params) {\n var properties = [];\n var keyframes = params.keyframes;\n if (keyframes) {\n params = mergeObjects(flattenKeyframes(keyframes), params);\n }\n for (var p in params) {\n if (is.key(p)) {\n properties.push({\n name: p,\n tweens: normalizePropertyTweens(params[p], tweenSettings)\n });\n }\n }\n return properties;\n}\n\n// Tweens\n\nfunction normalizeTweenValues(tween, animatable) {\n var t = {};\n for (var p in tween) {\n var value = getFunctionValue(tween[p], animatable);\n if (is.arr(value)) {\n value = value.map(function (v) {\n return getFunctionValue(v, animatable);\n });\n if (value.length === 1) {\n value = value[0];\n }\n }\n t[p] = value;\n }\n t.duration = parseFloat(t.duration);\n t.delay = parseFloat(t.delay);\n return t;\n}\nfunction normalizeTweens(prop, animatable) {\n var previousTween;\n return prop.tweens.map(function (t) {\n var tween = normalizeTweenValues(t, animatable);\n var tweenValue = tween.value;\n var to = is.arr(tweenValue) ? tweenValue[1] : tweenValue;\n var toUnit = getUnit(to);\n var originalValue = getOriginalTargetValue(animatable.target, prop.name, toUnit, animatable);\n var previousValue = previousTween ? previousTween.to.original : originalValue;\n var from = is.arr(tweenValue) ? tweenValue[0] : previousValue;\n var fromUnit = getUnit(from) || getUnit(originalValue);\n var unit = toUnit || fromUnit;\n if (is.und(to)) {\n to = previousValue;\n }\n tween.from = decomposeValue(from, unit);\n tween.to = decomposeValue(getRelativeValue(to, from), unit);\n tween.start = previousTween ? previousTween.end : 0;\n tween.end = tween.start + tween.delay + tween.duration + tween.endDelay;\n tween.easing = parseEasings(tween.easing, tween.duration);\n tween.isPath = is.pth(tweenValue);\n tween.isPathTargetInsideSVG = tween.isPath && is.svg(animatable.target);\n tween.isColor = is.col(tween.from.original);\n if (tween.isColor) {\n tween.round = 1;\n }\n previousTween = tween;\n return tween;\n });\n}\n\n// Tween progress\n\nvar setProgressValue = {\n css: function css(t, p, v) {\n return t.style[p] = v;\n },\n attribute: function attribute(t, p, v) {\n return t.setAttribute(p, v);\n },\n object: function object(t, p, v) {\n return t[p] = v;\n },\n transform: function transform(t, p, v, transforms, manual) {\n transforms.list.set(p, v);\n if (p === transforms.last || manual) {\n var str = '';\n transforms.list.forEach(function (value, prop) {\n str += prop + \"(\" + value + \") \";\n });\n t.style.transform = str;\n }\n }\n};\n\n// Set Value helper\n\nfunction setTargetsValue(targets, properties) {\n var animatables = getAnimatables(targets);\n animatables.forEach(function (animatable) {\n for (var property in properties) {\n var value = getFunctionValue(properties[property], animatable);\n var target = animatable.target;\n var valueUnit = getUnit(value);\n var originalValue = getOriginalTargetValue(target, property, valueUnit, animatable);\n var unit = valueUnit || getUnit(originalValue);\n var to = getRelativeValue(validateValue(value, unit), originalValue);\n var animType = getAnimationType(target, property);\n setProgressValue[animType](target, property, to, animatable.transforms, true);\n }\n });\n}\n\n// Animations\n\nfunction createAnimation(animatable, prop) {\n var animType = getAnimationType(animatable.target, prop.name);\n if (animType) {\n var tweens = normalizeTweens(prop, animatable);\n var lastTween = tweens[tweens.length - 1];\n return {\n type: animType,\n property: prop.name,\n animatable: animatable,\n tweens: tweens,\n duration: lastTween.end,\n delay: tweens[0].delay,\n endDelay: lastTween.endDelay\n };\n }\n}\nfunction getAnimations(animatables, properties) {\n return filterArray(flattenArray(animatables.map(function (animatable) {\n return properties.map(function (prop) {\n return createAnimation(animatable, prop);\n });\n })), function (a) {\n return !is.und(a);\n });\n}\n\n// Create Instance\n\nfunction getInstanceTimings(animations, tweenSettings) {\n var animLength = animations.length;\n var getTlOffset = function getTlOffset(anim) {\n return anim.timelineOffset ? anim.timelineOffset : 0;\n };\n var timings = {};\n timings.duration = animLength ? Math.max.apply(Math, animations.map(function (anim) {\n return getTlOffset(anim) + anim.duration;\n })) : tweenSettings.duration;\n timings.delay = animLength ? Math.min.apply(Math, animations.map(function (anim) {\n return getTlOffset(anim) + anim.delay;\n })) : tweenSettings.delay;\n timings.endDelay = animLength ? timings.duration - Math.max.apply(Math, animations.map(function (anim) {\n return getTlOffset(anim) + anim.duration - anim.endDelay;\n })) : tweenSettings.endDelay;\n return timings;\n}\nvar instanceID = 0;\nfunction createNewInstance(params) {\n var instanceSettings = replaceObjectProps(defaultInstanceSettings, params);\n var tweenSettings = replaceObjectProps(defaultTweenSettings, params);\n var properties = getProperties(tweenSettings, params);\n var animatables = getAnimatables(params.targets);\n var animations = getAnimations(animatables, properties);\n var timings = getInstanceTimings(animations, tweenSettings);\n var id = instanceID;\n instanceID++;\n return mergeObjects(instanceSettings, {\n id: id,\n children: [],\n animatables: animatables,\n animations: animations,\n duration: timings.duration,\n delay: timings.delay,\n endDelay: timings.endDelay\n });\n}\n\n// Core\n\nvar activeInstances = [];\nvar engine = function () {\n var raf;\n function play() {\n if (!raf && (!isDocumentHidden() || !anime.suspendWhenDocumentHidden) && activeInstances.length > 0) {\n raf = requestAnimationFrame(step);\n }\n }\n function step(t) {\n // memo on algorithm issue:\n // dangerous iteration over mutable `activeInstances`\n // (that collection may be updated from within callbacks of `tick`-ed animation instances)\n var activeInstancesLength = activeInstances.length;\n var i = 0;\n while (i < activeInstancesLength) {\n var activeInstance = activeInstances[i];\n if (!activeInstance.paused) {\n activeInstance.tick(t);\n i++;\n } else {\n activeInstances.splice(i, 1);\n activeInstancesLength--;\n }\n }\n raf = i > 0 ? requestAnimationFrame(step) : undefined;\n }\n function handleVisibilityChange() {\n if (!anime.suspendWhenDocumentHidden) {\n return;\n }\n if (isDocumentHidden()) {\n // suspend ticks\n raf = cancelAnimationFrame(raf);\n } else {\n // is back to active tab\n // first adjust animations to consider the time that ticks were suspended\n activeInstances.forEach(function (instance) {\n return instance._onDocumentVisibility();\n });\n engine();\n }\n }\n if (typeof document !== 'undefined') {\n document.addEventListener('visibilitychange', handleVisibilityChange);\n }\n return play;\n}();\nfunction isDocumentHidden() {\n return !!document && document.hidden;\n}\n\n// Public Instance\n\nfunction anime(params) {\n if (params === void 0) params = {};\n var startTime = 0,\n lastTime = 0,\n now = 0;\n var children,\n childrenLength = 0;\n var resolve = null;\n function makePromise(instance) {\n var promise = window.Promise && new Promise(function (_resolve) {\n return resolve = _resolve;\n });\n instance.finished = promise;\n return promise;\n }\n var instance = createNewInstance(params);\n var promise = makePromise(instance);\n function toggleInstanceDirection() {\n var direction = instance.direction;\n if (direction !== 'alternate') {\n instance.direction = direction !== 'normal' ? 'normal' : 'reverse';\n }\n instance.reversed = !instance.reversed;\n children.forEach(function (child) {\n return child.reversed = instance.reversed;\n });\n }\n function adjustTime(time) {\n return instance.reversed ? instance.duration - time : time;\n }\n function resetTime() {\n startTime = 0;\n lastTime = adjustTime(instance.currentTime) * (1 / anime.speed);\n }\n function seekChild(time, child) {\n if (child) {\n child.seek(time - child.timelineOffset);\n }\n }\n function syncInstanceChildren(time) {\n if (!instance.reversePlayback) {\n for (var i = 0; i < childrenLength; i++) {\n seekChild(time, children[i]);\n }\n } else {\n for (var i$1 = childrenLength; i$1--;) {\n seekChild(time, children[i$1]);\n }\n }\n }\n function setAnimationsProgress(insTime) {\n var i = 0;\n var animations = instance.animations;\n var animationsLength = animations.length;\n while (i < animationsLength) {\n var anim = animations[i];\n var animatable = anim.animatable;\n var tweens = anim.tweens;\n var tweenLength = tweens.length - 1;\n var tween = tweens[tweenLength];\n // Only check for keyframes if there is more than one tween\n if (tweenLength) {\n tween = filterArray(tweens, function (t) {\n return insTime < t.end;\n })[0] || tween;\n }\n var elapsed = minMax(insTime - tween.start - tween.delay, 0, tween.duration) / tween.duration;\n var eased = isNaN(elapsed) ? 1 : tween.easing(elapsed);\n var strings = tween.to.strings;\n var round = tween.round;\n var numbers = [];\n var toNumbersLength = tween.to.numbers.length;\n var progress = void 0;\n for (var n = 0; n < toNumbersLength; n++) {\n var value = void 0;\n var toNumber = tween.to.numbers[n];\n var fromNumber = tween.from.numbers[n] || 0;\n if (!tween.isPath) {\n value = fromNumber + eased * (toNumber - fromNumber);\n } else {\n value = getPathProgress(tween.value, eased * toNumber, tween.isPathTargetInsideSVG);\n }\n if (round) {\n if (!(tween.isColor && n > 2)) {\n value = Math.round(value * round) / round;\n }\n }\n numbers.push(value);\n }\n // Manual Array.reduce for better performances\n var stringsLength = strings.length;\n if (!stringsLength) {\n progress = numbers[0];\n } else {\n progress = strings[0];\n for (var s = 0; s < stringsLength; s++) {\n var a = strings[s];\n var b = strings[s + 1];\n var n$1 = numbers[s];\n if (!isNaN(n$1)) {\n if (!b) {\n progress += n$1 + ' ';\n } else {\n progress += n$1 + b;\n }\n }\n }\n }\n setProgressValue[anim.type](animatable.target, anim.property, progress, animatable.transforms);\n anim.currentValue = progress;\n i++;\n }\n }\n function setCallback(cb) {\n if (instance[cb] && !instance.passThrough) {\n instance[cb](instance);\n }\n }\n function countIteration() {\n if (instance.remaining && instance.remaining !== true) {\n instance.remaining--;\n }\n }\n function setInstanceProgress(engineTime) {\n var insDuration = instance.duration;\n var insDelay = instance.delay;\n var insEndDelay = insDuration - instance.endDelay;\n var insTime = adjustTime(engineTime);\n instance.progress = minMax(insTime / insDuration * 100, 0, 100);\n instance.reversePlayback = insTime < instance.currentTime;\n if (children) {\n syncInstanceChildren(insTime);\n }\n if (!instance.began && instance.currentTime > 0) {\n instance.began = true;\n setCallback('begin');\n }\n if (!instance.loopBegan && instance.currentTime > 0) {\n instance.loopBegan = true;\n setCallback('loopBegin');\n }\n if (insTime <= insDelay && instance.currentTime !== 0) {\n setAnimationsProgress(0);\n }\n if (insTime >= insEndDelay && instance.currentTime !== insDuration || !insDuration) {\n setAnimationsProgress(insDuration);\n }\n if (insTime > insDelay && insTime < insEndDelay) {\n if (!instance.changeBegan) {\n instance.changeBegan = true;\n instance.changeCompleted = false;\n setCallback('changeBegin');\n }\n setCallback('change');\n setAnimationsProgress(insTime);\n } else {\n if (instance.changeBegan) {\n instance.changeCompleted = true;\n instance.changeBegan = false;\n setCallback('changeComplete');\n }\n }\n instance.currentTime = minMax(insTime, 0, insDuration);\n if (instance.began) {\n setCallback('update');\n }\n if (engineTime >= insDuration) {\n lastTime = 0;\n countIteration();\n if (!instance.remaining) {\n instance.paused = true;\n if (!instance.completed) {\n instance.completed = true;\n setCallback('loopComplete');\n setCallback('complete');\n if (!instance.passThrough && 'Promise' in window) {\n resolve();\n promise = makePromise(instance);\n }\n }\n } else {\n startTime = now;\n setCallback('loopComplete');\n instance.loopBegan = false;\n if (instance.direction === 'alternate') {\n toggleInstanceDirection();\n }\n }\n }\n }\n instance.reset = function () {\n var direction = instance.direction;\n instance.passThrough = false;\n instance.currentTime = 0;\n instance.progress = 0;\n instance.paused = true;\n instance.began = false;\n instance.loopBegan = false;\n instance.changeBegan = false;\n instance.completed = false;\n instance.changeCompleted = false;\n instance.reversePlayback = false;\n instance.reversed = direction === 'reverse';\n instance.remaining = instance.loop;\n children = instance.children;\n childrenLength = children.length;\n for (var i = childrenLength; i--;) {\n instance.children[i].reset();\n }\n if (instance.reversed && instance.loop !== true || direction === 'alternate' && instance.loop === 1) {\n instance.remaining++;\n }\n setAnimationsProgress(instance.reversed ? instance.duration : 0);\n };\n\n // internal method (for engine) to adjust animation timings before restoring engine ticks (rAF)\n instance._onDocumentVisibility = resetTime;\n\n // Set Value helper\n\n instance.set = function (targets, properties) {\n setTargetsValue(targets, properties);\n return instance;\n };\n instance.tick = function (t) {\n now = t;\n if (!startTime) {\n startTime = now;\n }\n setInstanceProgress((now + (lastTime - startTime)) * anime.speed);\n };\n instance.seek = function (time) {\n setInstanceProgress(adjustTime(time));\n };\n instance.pause = function () {\n instance.paused = true;\n resetTime();\n };\n instance.play = function () {\n if (!instance.paused) {\n return;\n }\n if (instance.completed) {\n instance.reset();\n }\n instance.paused = false;\n activeInstances.push(instance);\n resetTime();\n engine();\n };\n instance.reverse = function () {\n toggleInstanceDirection();\n instance.completed = instance.reversed ? false : true;\n resetTime();\n };\n instance.restart = function () {\n instance.reset();\n instance.play();\n };\n instance.remove = function (targets) {\n var targetsArray = parseTargets(targets);\n removeTargetsFromInstance(targetsArray, instance);\n };\n instance.reset();\n if (instance.autoplay) {\n instance.play();\n }\n return instance;\n}\n\n// Remove targets from animation\n\nfunction removeTargetsFromAnimations(targetsArray, animations) {\n for (var a = animations.length; a--;) {\n if (arrayContains(targetsArray, animations[a].animatable.target)) {\n animations.splice(a, 1);\n }\n }\n}\nfunction removeTargetsFromInstance(targetsArray, instance) {\n var animations = instance.animations;\n var children = instance.children;\n removeTargetsFromAnimations(targetsArray, animations);\n for (var c = children.length; c--;) {\n var child = children[c];\n var childAnimations = child.animations;\n removeTargetsFromAnimations(targetsArray, childAnimations);\n if (!childAnimations.length && !child.children.length) {\n children.splice(c, 1);\n }\n }\n if (!animations.length && !children.length) {\n instance.pause();\n }\n}\nfunction removeTargetsFromActiveInstances(targets) {\n var targetsArray = parseTargets(targets);\n for (var i = activeInstances.length; i--;) {\n var instance = activeInstances[i];\n removeTargetsFromInstance(targetsArray, instance);\n }\n}\n\n// Stagger helpers\n\nfunction stagger(val, params) {\n if (params === void 0) params = {};\n var direction = params.direction || 'normal';\n var easing = params.easing ? parseEasings(params.easing) : null;\n var grid = params.grid;\n var axis = params.axis;\n var fromIndex = params.from || 0;\n var fromFirst = fromIndex === 'first';\n var fromCenter = fromIndex === 'center';\n var fromLast = fromIndex === 'last';\n var isRange = is.arr(val);\n var val1 = isRange ? parseFloat(val[0]) : parseFloat(val);\n var val2 = isRange ? parseFloat(val[1]) : 0;\n var unit = getUnit(isRange ? val[1] : val) || 0;\n var start = params.start || 0 + (isRange ? val1 : 0);\n var values = [];\n var maxValue = 0;\n return function (el, i, t) {\n if (fromFirst) {\n fromIndex = 0;\n }\n if (fromCenter) {\n fromIndex = (t - 1) / 2;\n }\n if (fromLast) {\n fromIndex = t - 1;\n }\n if (!values.length) {\n for (var index = 0; index < t; index++) {\n if (!grid) {\n values.push(Math.abs(fromIndex - index));\n } else {\n var fromX = !fromCenter ? fromIndex % grid[0] : (grid[0] - 1) / 2;\n var fromY = !fromCenter ? Math.floor(fromIndex / grid[0]) : (grid[1] - 1) / 2;\n var toX = index % grid[0];\n var toY = Math.floor(index / grid[0]);\n var distanceX = fromX - toX;\n var distanceY = fromY - toY;\n var value = Math.sqrt(distanceX * distanceX + distanceY * distanceY);\n if (axis === 'x') {\n value = -distanceX;\n }\n if (axis === 'y') {\n value = -distanceY;\n }\n values.push(value);\n }\n maxValue = Math.max.apply(Math, values);\n }\n if (easing) {\n values = values.map(function (val) {\n return easing(val / maxValue) * maxValue;\n });\n }\n if (direction === 'reverse') {\n values = values.map(function (val) {\n return axis ? val < 0 ? val * -1 : -val : Math.abs(maxValue - val);\n });\n }\n }\n var spacing = isRange ? (val2 - val1) / maxValue : val1;\n return start + spacing * (Math.round(values[i] * 100) / 100) + unit;\n };\n}\n\n// Timeline\n\nfunction timeline(params) {\n if (params === void 0) params = {};\n var tl = anime(params);\n tl.duration = 0;\n tl.add = function (instanceParams, timelineOffset) {\n var tlIndex = activeInstances.indexOf(tl);\n var children = tl.children;\n if (tlIndex > -1) {\n activeInstances.splice(tlIndex, 1);\n }\n function passThrough(ins) {\n ins.passThrough = true;\n }\n for (var i = 0; i < children.length; i++) {\n passThrough(children[i]);\n }\n var insParams = mergeObjects(instanceParams, replaceObjectProps(defaultTweenSettings, params));\n insParams.targets = insParams.targets || params.targets;\n var tlDuration = tl.duration;\n insParams.autoplay = false;\n insParams.direction = tl.direction;\n insParams.timelineOffset = is.und(timelineOffset) ? tlDuration : getRelativeValue(timelineOffset, tlDuration);\n passThrough(tl);\n tl.seek(insParams.timelineOffset);\n var ins = anime(insParams);\n passThrough(ins);\n children.push(ins);\n var timings = getInstanceTimings(children, params);\n tl.delay = timings.delay;\n tl.endDelay = timings.endDelay;\n tl.duration = timings.duration;\n tl.seek(0);\n tl.reset();\n if (tl.autoplay) {\n tl.play();\n }\n return tl;\n };\n return tl;\n}\nanime.version = '3.2.1';\nanime.speed = 1;\n// TODO:#review: naming, documentation\nanime.suspendWhenDocumentHidden = true;\nanime.running = activeInstances;\nanime.remove = removeTargetsFromActiveInstances;\nanime.get = getOriginalTargetValue;\nanime.set = setTargetsValue;\nanime.convertPx = convertPxToUnit;\nanime.path = getPath;\nanime.setDashoffset = setDashoffset;\nanime.stagger = stagger;\nanime.timeline = timeline;\nanime.easing = parseEasings;\nanime.penner = penner;\nanime.random = function (min, max) {\n return Math.floor(Math.random() * (max - min + 1)) + min;\n};\nexport default anime;","import React, { useState, useEffect } from 'react';\r\nimport { Helmet } from 'react-helmet';\r\nimport PropTypes from 'prop-types';\r\nimport anime from 'animejs';\r\nimport styled from 'styled-components';\r\nimport { IconLoader } from '@components/icons';\r\n\r\nconst StyledLoader = styled.div`\r\n ${({ theme }) => theme.mixins.flexCenter};\r\n position: fixed;\r\n top: 0;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: var(--dark-navy);\r\n z-index: 99;\r\n\r\n .logo-wrapper {\r\n width: max-content;\r\n max-width: 100px;\r\n transition: var(--transition);\r\n opacity: ${props => (props.isMounted ? 1 : 0)};\r\n svg {\r\n display: block;\r\n width: 100%;\r\n height: 100%;\r\n margin: 0 auto;\r\n fill: none;\r\n user-select: none;\r\n #B {\r\n opacity: 0;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst Loader = ({ finishLoading }) => {\r\n const [isMounted, setIsMounted] = useState(false);\r\n\r\n const animate = () => {\r\n const loader = anime.timeline({\r\n complete: () => finishLoading(),\r\n });\r\n\r\n loader\r\n .add({\r\n targets: '#logo path',\r\n delay: 300,\r\n duration: 1500,\r\n easing: 'easeInOutQuart',\r\n strokeDashoffset: [anime.setDashoffset, 0],\r\n })\r\n .add({\r\n targets: '#logo #B',\r\n duration: 700,\r\n easing: 'easeInOutQuart',\r\n opacity: 1,\r\n })\r\n .add({\r\n targets: '#logo',\r\n delay: 500,\r\n duration: 300,\r\n easing: 'easeInOutQuart',\r\n opacity: 0,\r\n scale: 0.1,\r\n })\r\n .add({\r\n targets: '.loader',\r\n duration: 200,\r\n easing: 'easeInOutQuart',\r\n opacity: 0,\r\n zIndex: -1,\r\n });\r\n };\r\n\r\n useEffect(() => {\r\n const timeout = setTimeout(() => setIsMounted(true), 10);\r\n animate();\r\n return () => clearTimeout(timeout);\r\n }, []);\r\n\r\n return (\r\n <StyledLoader className=\"loader\" isMounted={isMounted}>\r\n <Helmet bodyAttributes={{ class: `hidden` }} />\r\n\r\n <div className=\"logo-wrapper\">\r\n <IconLoader />\r\n </div>\r\n </StyledLoader>\r\n );\r\n};\r\n\r\nLoader.propTypes = {\r\n finishLoading: PropTypes.func.isRequired,\r\n};\r\n\r\nexport default Loader;\r\n","import React, { useState, useEffect } from 'react';\r\nimport { Link } from 'gatsby';\r\nimport PropTypes from 'prop-types';\r\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\r\nimport styled, { css } from 'styled-components';\r\nimport { navLinks } from '@config';\r\nimport { loaderDelay } from '@utils';\r\nimport { useScrollDirection, usePrefersReducedMotion } from '@hooks';\r\nimport { Menu } from '@components';\r\nimport { IconLogo } from '@components/icons';\r\n\r\nconst StyledHeader = styled.header`\r\n ${({ theme }) => theme.mixins.flexBetween};\r\n position: fixed;\r\n top: 0;\r\n z-index: 11;\r\n padding: 0px 50px;\r\n width: 100%;\r\n height: var(--nav-height);\r\n background-color: rgba(10, 25, 47, 0.85);\r\n filter: none !important;\r\n pointer-events: auto !important;\r\n user-select: auto !important;\r\n backdrop-filter: blur(10px);\r\n transition: var(--transition);\r\n\r\n @media (max-width: 1080px) {\r\n padding: 0 40px;\r\n }\r\n @media (max-width: 768px) {\r\n padding: 0 25px;\r\n }\r\n\r\n @media (prefers-reduced-motion: no-preference) {\r\n ${props =>\r\n props.scrollDirection === 'up' &&\r\n !props.scrolledToTop &&\r\n css`\r\n height: var(--nav-scroll-height);\r\n transform: translateY(0px);\r\n background-color: rgba(10, 25, 47, 0.85);\r\n box-shadow: 0 10px 30px -10px var(--navy-shadow);\r\n `};\r\n\r\n ${props =>\r\n props.scrollDirection === 'down' &&\r\n !props.scrolledToTop &&\r\n css`\r\n height: var(--nav-scroll-height);\r\n transform: translateY(calc(var(--nav-scroll-height) * -1));\r\n box-shadow: 0 10px 30px -10px var(--navy-shadow);\r\n `};\r\n }\r\n`;\r\n\r\nconst StyledNav = styled.nav`\r\n ${({ theme }) => theme.mixins.flexBetween};\r\n position: relative;\r\n width: 100%;\r\n color: var(--lightest-slate);\r\n font-family: var(--font-mono);\r\n counter-reset: item 0;\r\n z-index: 12;\r\n\r\n .logo {\r\n ${({ theme }) => theme.mixins.flexCenter};\r\n\r\n a {\r\n color: var(--green);\r\n width: 42px;\r\n height: 42px;\r\n\r\n &:hover,\r\n &:focus {\r\n svg {\r\n fill: var(--green-tint);\r\n }\r\n }\r\n\r\n svg {\r\n fill: none;\r\n transition: var(--transition);\r\n user-select: none;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst StyledLinks = styled.div`\r\n display: flex;\r\n align-items: center;\r\n\r\n @media (max-width: 768px) {\r\n display: none;\r\n }\r\n\r\n ol {\r\n ${({ theme }) => theme.mixins.flexBetween};\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n\r\n li {\r\n margin: 0 5px;\r\n position: relative;\r\n counter-increment: item 1;\r\n font-size: var(--fz-xs);\r\n\r\n a {\r\n padding: 10px;\r\n\r\n &:before {\r\n content: '0' counter(item) '.';\r\n margin-right: 5px;\r\n color: var(--green);\r\n font-size: var(--fz-xxs);\r\n text-align: right;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .resume-button {\r\n ${({ theme }) => theme.mixins.smallButton};\r\n margin-left: 15px;\r\n font-size: var(--fz-xs);\r\n }\r\n`;\r\n\r\nconst Nav = ({ isHome }) => {\r\n const [isMounted, setIsMounted] = useState(!isHome);\r\n const scrollDirection = useScrollDirection('down');\r\n const [scrolledToTop, setScrolledToTop] = useState(true);\r\n const prefersReducedMotion = usePrefersReducedMotion();\r\n\r\n const handleScroll = () => {\r\n setScrolledToTop(window.pageYOffset < 50);\r\n };\r\n\r\n useEffect(() => {\r\n if (prefersReducedMotion) {\r\n return;\r\n }\r\n\r\n const timeout = setTimeout(() => {\r\n setIsMounted(true);\r\n }, 100);\r\n\r\n window.addEventListener('scroll', handleScroll);\r\n\r\n return () => {\r\n clearTimeout(timeout);\r\n window.removeEventListener('scroll', handleScroll);\r\n };\r\n }, []);\r\n\r\n const timeout = isHome ? loaderDelay : 0;\r\n const fadeClass = isHome ? 'fade' : '';\r\n const fadeDownClass = isHome ? 'fadedown' : '';\r\n\r\n const Logo = (\r\n <div className=\"logo\" tabIndex=\"-1\">\r\n {isHome ? (\r\n <a href=\"/\" aria-label=\"home\">\r\n <IconLogo />\r\n </a>\r\n ) : (\r\n <Link to=\"/\" aria-label=\"home\">\r\n <IconLogo />\r\n </Link>\r\n )}\r\n </div>\r\n );\r\n\r\n const ResumeLink = (\r\n <a className=\"resume-button\" href=\"/resume.pdf\" target=\"_blank\" rel=\"noopener noreferrer\">\r\n Resume\r\n </a>\r\n );\r\n\r\n return (\r\n <StyledHeader scrollDirection={scrollDirection} scrolledToTop={scrolledToTop}>\r\n <StyledNav>\r\n {prefersReducedMotion ? (\r\n <>\r\n {Logo}\r\n\r\n <StyledLinks>\r\n <ol>\r\n {navLinks &&\r\n navLinks.map(({ url, name }, i) => (\r\n <li key={i}>\r\n <Link to={url}>{name}</Link>\r\n </li>\r\n ))}\r\n </ol>\r\n <div>{ResumeLink}</div>\r\n </StyledLinks>\r\n\r\n <Menu />\r\n </>\r\n ) : (\r\n <>\r\n <TransitionGroup component={null}>\r\n {isMounted && (\r\n <CSSTransition classNames={fadeClass} timeout={timeout}>\r\n <>{Logo}</>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n\r\n <StyledLinks>\r\n <ol>\r\n <TransitionGroup component={null}>\r\n {isMounted &&\r\n navLinks &&\r\n navLinks.map(({ url, name }, i) => (\r\n <CSSTransition key={i} classNames={fadeDownClass} timeout={timeout}>\r\n <li key={i} style={{ transitionDelay: `${isHome ? i * 100 : 0}ms` }}>\r\n <Link to={url}>{name}</Link>\r\n </li>\r\n </CSSTransition>\r\n ))}\r\n </TransitionGroup>\r\n </ol>\r\n\r\n <TransitionGroup component={null}>\r\n {isMounted && (\r\n <CSSTransition classNames={fadeDownClass} timeout={timeout}>\r\n <div style={{ transitionDelay: `${isHome ? navLinks.length * 100 : 0}ms` }}>\r\n {ResumeLink}\r\n </div>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n </StyledLinks>\r\n\r\n <TransitionGroup component={null}>\r\n {isMounted && (\r\n <CSSTransition classNames={fadeClass} timeout={timeout}>\r\n <Menu />\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n </>\r\n )}\r\n </StyledNav>\r\n </StyledHeader>\r\n );\r\n};\r\n\r\nNav.propTypes = {\r\n isHome: PropTypes.bool,\r\n};\r\n\r\nexport default Nav;\r\n","import React, { useState, useEffect, useRef } from 'react';\r\nimport { Helmet } from 'react-helmet';\r\nimport { Link } from 'gatsby';\r\nimport styled from 'styled-components';\r\nimport { navLinks } from '@config';\r\nimport { KEY_CODES } from '@utils';\r\nimport { useOnClickOutside } from '@hooks';\r\n\r\nconst StyledMenu = styled.div`\r\n display: none;\r\n\r\n @media (max-width: 768px) {\r\n display: block;\r\n }\r\n`;\r\n\r\nconst StyledHamburgerButton = styled.button`\r\n display: none;\r\n\r\n @media (max-width: 768px) {\r\n ${({ theme }) => theme.mixins.flexCenter};\r\n position: relative;\r\n z-index: 10;\r\n margin-right: -15px;\r\n padding: 15px;\r\n border: 0;\r\n background-color: transparent;\r\n color: inherit;\r\n text-transform: none;\r\n transition-timing-function: linear;\r\n transition-duration: 0.15s;\r\n transition-property: opacity, filter;\r\n }\r\n\r\n .ham-box {\r\n display: inline-block;\r\n position: relative;\r\n width: var(--hamburger-width);\r\n height: 24px;\r\n }\r\n\r\n .ham-box-inner {\r\n position: absolute;\r\n top: 50%;\r\n right: 0;\r\n width: var(--hamburger-width);\r\n height: 2px;\r\n border-radius: var(--border-radius);\r\n background-color: var(--green);\r\n transition-duration: 0.22s;\r\n transition-property: transform;\r\n transition-delay: ${props => (props.menuOpen ? `0.12s` : `0s`)};\r\n transform: rotate(${props => (props.menuOpen ? `225deg` : `0deg`)});\r\n transition-timing-function: cubic-bezier(\r\n ${props => (props.menuOpen ? `0.215, 0.61, 0.355, 1` : `0.55, 0.055, 0.675, 0.19`)}\r\n );\r\n &:before,\r\n &:after {\r\n content: '';\r\n display: block;\r\n position: absolute;\r\n left: auto;\r\n right: 0;\r\n width: var(--hamburger-width);\r\n height: 2px;\r\n border-radius: 4px;\r\n background-color: var(--green);\r\n transition-timing-function: ease;\r\n transition-duration: 0.15s;\r\n transition-property: transform;\r\n }\r\n &:before {\r\n width: ${props => (props.menuOpen ? `100%` : `120%`)};\r\n top: ${props => (props.menuOpen ? `0` : `-10px`)};\r\n opacity: ${props => (props.menuOpen ? 0 : 1)};\r\n transition: ${({ menuOpen }) =>\r\n menuOpen ? 'var(--ham-before-active)' : 'var(--ham-before)'};\r\n }\r\n &:after {\r\n width: ${props => (props.menuOpen ? `100%` : `80%`)};\r\n bottom: ${props => (props.menuOpen ? `0` : `-10px`)};\r\n transform: rotate(${props => (props.menuOpen ? `-90deg` : `0`)});\r\n transition: ${({ menuOpen }) => (menuOpen ? 'var(--ham-after-active)' : 'var(--ham-after)')};\r\n }\r\n }\r\n`;\r\n\r\nconst StyledSidebar = styled.aside`\r\n display: none;\r\n\r\n @media (max-width: 768px) {\r\n ${({ theme }) => theme.mixins.flexCenter};\r\n position: fixed;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n padding: 50px 10px;\r\n width: min(75vw, 400px);\r\n height: 100vh;\r\n outline: 0;\r\n background-color: var(--light-navy);\r\n box-shadow: -10px 0px 30px -15px var(--navy-shadow);\r\n z-index: 9;\r\n transform: translateX(${props => (props.menuOpen ? 0 : 100)}vw);\r\n visibility: ${props => (props.menuOpen ? 'visible' : 'hidden')};\r\n transition: var(--transition);\r\n }\r\n\r\n nav {\r\n ${({ theme }) => theme.mixins.flexBetween};\r\n width: 100%;\r\n flex-direction: column;\r\n color: var(--lightest-slate);\r\n font-family: var(--font-mono);\r\n text-align: center;\r\n }\r\n\r\n ol {\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n width: 100%;\r\n\r\n li {\r\n position: relative;\r\n margin: 0 auto 20px;\r\n counter-increment: item 1;\r\n font-size: clamp(var(--fz-sm), 4vw, var(--fz-lg));\r\n\r\n @media (max-width: 600px) {\r\n margin: 0 auto 10px;\r\n }\r\n\r\n &:before {\r\n content: '0' counter(item) '.';\r\n display: block;\r\n margin-bottom: 5px;\r\n color: var(--green);\r\n font-size: var(--fz-sm);\r\n }\r\n }\r\n\r\n a {\r\n ${({ theme }) => theme.mixins.link};\r\n width: 100%;\r\n padding: 3px 20px 20px;\r\n }\r\n }\r\n\r\n .resume-link {\r\n ${({ theme }) => theme.mixins.bigButton};\r\n padding: 18px 50px;\r\n margin: 10% auto 0;\r\n width: max-content;\r\n }\r\n`;\r\n\r\nconst Menu = () => {\r\n const [menuOpen, setMenuOpen] = useState(false);\r\n\r\n const toggleMenu = () => setMenuOpen(!menuOpen);\r\n\r\n const buttonRef = useRef(null);\r\n const navRef = useRef(null);\r\n\r\n let menuFocusables;\r\n let firstFocusableEl;\r\n let lastFocusableEl;\r\n\r\n const setFocusables = () => {\r\n menuFocusables = [buttonRef.current, ...Array.from(navRef.current.querySelectorAll('a'))];\r\n firstFocusableEl = menuFocusables[0];\r\n lastFocusableEl = menuFocusables[menuFocusables.length - 1];\r\n };\r\n\r\n const handleBackwardTab = e => {\r\n if (document.activeElement === firstFocusableEl) {\r\n e.preventDefault();\r\n lastFocusableEl.focus();\r\n }\r\n };\r\n\r\n const handleForwardTab = e => {\r\n if (document.activeElement === lastFocusableEl) {\r\n e.preventDefault();\r\n firstFocusableEl.focus();\r\n }\r\n };\r\n\r\n const onKeyDown = e => {\r\n switch (e.key) {\r\n case KEY_CODES.ESCAPE:\r\n case KEY_CODES.ESCAPE_IE11: {\r\n setMenuOpen(false);\r\n break;\r\n }\r\n\r\n case KEY_CODES.TAB: {\r\n if (menuFocusables && menuFocusables.length === 1) {\r\n e.preventDefault();\r\n break;\r\n }\r\n if (e.shiftKey) {\r\n handleBackwardTab(e);\r\n } else {\r\n handleForwardTab(e);\r\n }\r\n break;\r\n }\r\n\r\n default: {\r\n break;\r\n }\r\n }\r\n };\r\n\r\n const onResize = e => {\r\n if (e.currentTarget.innerWidth > 768) {\r\n setMenuOpen(false);\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n document.addEventListener('keydown', onKeyDown);\r\n window.addEventListener('resize', onResize);\r\n\r\n setFocusables();\r\n\r\n return () => {\r\n document.removeEventListener('keydown', onKeyDown);\r\n window.removeEventListener('resize', onResize);\r\n };\r\n }, []);\r\n\r\n const wrapperRef = useRef();\r\n useOnClickOutside(wrapperRef, () => setMenuOpen(false));\r\n\r\n return (\r\n <StyledMenu>\r\n <Helmet>\r\n <body className={menuOpen ? 'blur' : ''} />\r\n </Helmet>\r\n\r\n <div ref={wrapperRef}>\r\n <StyledHamburgerButton\r\n onClick={toggleMenu}\r\n menuOpen={menuOpen}\r\n ref={buttonRef}\r\n aria-label=\"Menu\">\r\n <div className=\"ham-box\">\r\n <div className=\"ham-box-inner\" />\r\n </div>\r\n </StyledHamburgerButton>\r\n\r\n <StyledSidebar menuOpen={menuOpen} aria-hidden={!menuOpen} tabIndex={menuOpen ? 1 : -1}>\r\n <nav ref={navRef}>\r\n {navLinks && (\r\n <ol>\r\n {navLinks.map(({ url, name }, i) => (\r\n <li key={i}>\r\n <Link to={url} onClick={() => setMenuOpen(false)}>\r\n {name}\r\n </Link>\r\n </li>\r\n ))}\r\n </ol>\r\n )}\r\n\r\n <a href=\"/resume.pdf\" className=\"resume-link\">\r\n Resume\r\n </a>\r\n </nav>\r\n </StyledSidebar>\r\n </div>\r\n </StyledMenu>\r\n );\r\n};\r\n\r\nexport default Menu;\r\n","import React, { useState, useEffect } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\r\nimport styled from 'styled-components';\r\nimport { loaderDelay } from '@utils';\r\nimport { usePrefersReducedMotion } from '@hooks';\r\n\r\nconst StyledSideElement = styled.div`\r\n width: 40px;\r\n position: fixed;\r\n bottom: 0;\r\n left: ${props => (props.orientation === 'left' ? '40px' : 'auto')};\r\n right: ${props => (props.orientation === 'left' ? 'auto' : '40px')};\r\n z-index: 10;\r\n color: var(--light-slate);\r\n\r\n @media (max-width: 1080px) {\r\n left: ${props => (props.orientation === 'left' ? '20px' : 'auto')};\r\n right: ${props => (props.orientation === 'left' ? 'auto' : '20px')};\r\n }\r\n\r\n @media (max-width: 768px) {\r\n display: none;\r\n }\r\n`;\r\n\r\nconst Side = ({ children, isHome, orientation }) => {\r\n const [isMounted, setIsMounted] = useState(!isHome);\r\n const prefersReducedMotion = usePrefersReducedMotion();\r\n\r\n useEffect(() => {\r\n if (!isHome || prefersReducedMotion) {\r\n return;\r\n }\r\n const timeout = setTimeout(() => setIsMounted(true), loaderDelay);\r\n return () => clearTimeout(timeout);\r\n }, []);\r\n\r\n return (\r\n <StyledSideElement orientation={orientation}>\r\n {prefersReducedMotion ? (\r\n <>{children}</>\r\n ) : (\r\n <TransitionGroup component={null}>\r\n {isMounted && (\r\n <CSSTransition classNames={isHome ? 'fade' : ''} timeout={isHome ? loaderDelay : 0}>\r\n {children}\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n )}\r\n </StyledSideElement>\r\n );\r\n};\r\n\r\nSide.propTypes = {\r\n children: PropTypes.node.isRequired,\r\n isHome: PropTypes.bool,\r\n orientation: PropTypes.string,\r\n};\r\n\r\nexport default Side;\r\n","import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport styled from 'styled-components';\r\nimport { socialMedia } from '@config';\r\nimport { Side } from '@components';\r\nimport { Icon } from '@components/icons';\r\n\r\nconst StyledSocialList = styled.ul`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n margin: 0;\r\n padding: 0;\r\n list-style: none;\r\n\r\n &:after {\r\n content: '';\r\n display: block;\r\n width: 1px;\r\n height: 90px;\r\n margin: 0 auto;\r\n background-color: var(--light-slate);\r\n }\r\n\r\n li {\r\n &:last-of-type {\r\n margin-bottom: 20px;\r\n }\r\n\r\n a {\r\n padding: 10px;\r\n\r\n &:hover,\r\n &:focus {\r\n transform: translateY(-3px);\r\n }\r\n\r\n svg {\r\n width: 20px;\r\n height: 20px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst Social = ({ isHome }) => (\r\n <Side isHome={isHome} orientation=\"left\">\r\n <StyledSocialList>\r\n {socialMedia &&\r\n socialMedia.map(({ url, name }, i) => (\r\n <li key={i}>\r\n <a href={url} aria-label={name} target=\"_blank\" rel=\"noreferrer\">\r\n <Icon name={name} />\r\n </a>\r\n </li>\r\n ))}\r\n </StyledSocialList>\r\n </Side>\r\n);\r\n\r\nSocial.propTypes = {\r\n isHome: PropTypes.bool,\r\n};\r\n\r\nexport default Social;\r\n","import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport styled from 'styled-components';\r\nimport { email } from '@config';\r\nimport { Side } from '@components';\r\n\r\nconst StyledLinkWrapper = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n position: relative;\r\n\r\n &:after {\r\n content: '';\r\n display: block;\r\n width: 1px;\r\n height: 90px;\r\n margin: 0 auto;\r\n background-color: var(--light-slate);\r\n }\r\n\r\n a {\r\n margin: 20px auto;\r\n padding: 10px;\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-xxs);\r\n line-height: var(--fz-lg);\r\n letter-spacing: 0.1em;\r\n writing-mode: vertical-rl;\r\n\r\n &:hover,\r\n &:focus {\r\n transform: translateY(-3px);\r\n }\r\n }\r\n`;\r\n\r\nconst Email = ({ isHome }) => (\r\n <Side isHome={isHome} orientation=\"right\">\r\n <StyledLinkWrapper>\r\n <a href={`mailto:${email}`}>{email}</a>\r\n </StyledLinkWrapper>\r\n </Side>\r\n);\r\n\r\nEmail.propTypes = {\r\n isHome: PropTypes.bool,\r\n};\r\n\r\nexport default Email;\r\n","import React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport { Icon } from '@components/icons';\nimport { socialMedia } from '@config';\n\nconst StyledFooter = styled.footer`\n ${({ theme }) => theme.mixins.flexCenter};\n flex-direction: column;\n height: auto;\n min-height: 70px;\n padding: 15px;\n text-align: center;\n`;\n\nconst StyledSocialLinks = styled.div`\n display: none;\n\n @media (max-width: 768px) {\n display: block;\n width: 100%;\n max-width: 270px;\n margin: 0 auto 10px;\n color: var(--light-slate);\n }\n\n ul {\n ${({ theme }) => theme.mixins.flexBetween};\n padding: 0;\n margin: 0;\n list-style: none;\n\n a {\n padding: 10px;\n svg {\n width: 20px;\n height: 20px;\n }\n }\n }\n`;\n\nconst StyledCredit = styled.div`\n color: var(--light-slate);\n font-family: var(--font-mono);\n font-size: var(--fz-xxs);\n line-height: 1;\n\n a {\n padding: 10px;\n }\n\n .github-stats {\n margin-top: 10px;\n\n & > span {\n display: inline-flex;\n align-items: center;\n margin: 0 7px;\n }\n svg {\n display: inline-block;\n margin-right: 5px;\n width: 14px;\n height: 14px;\n }\n }\n`;\n\nconst Footer = () => {\n const [githubInfo, setGitHubInfo] = useState({\n stars: null,\n forks: null,\n });\n\n useEffect(() => {\n if (process.env.NODE_ENV !== 'production') {\n return;\n }\n fetch('https://api.github.com/repos/sawradip/v4')\n .then(response => response.json())\n .then(json => {\n const { stargazers_count, forks_count } = json;\n setGitHubInfo({\n stars: stargazers_count,\n forks: forks_count,\n });\n })\n .catch(e => console.error(e));\n }, []);\n\n return (\n <StyledFooter>\n <StyledSocialLinks>\n <ul>\n {socialMedia &&\n socialMedia.map(({ name, url }, i) => (\n <li key={i}>\n <a href={url} aria-label={name}>\n <Icon name={name} />\n </a>\n </li>\n ))}\n </ul>\n </StyledSocialLinks>\n\n <StyledCredit tabindex=\"-1\">\n <a href=\"https://github.com/sawradip/v4\">\n <div> Built by Sawradip Saha ( Designed by Brittany Chiang )</div>\n\n {githubInfo.stars && githubInfo.forks && (\n <div className=\"github-stats\">\n <span>\n <Icon name=\"Star\" />\n <span>{githubInfo.stars.toLocaleString()}</span>\n </span>\n <span>\n <Icon name=\"Fork\" />\n <span>{githubInfo.forks.toLocaleString()}</span>\n </span>\n </div>\n )}\n </a>\n </StyledCredit>\n </StyledFooter>\n );\n};\n\nFooter.propTypes = {\n githubInfo: PropTypes.object,\n};\n\nexport default Footer;\n","import React, { useState, useEffect } from 'react';\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\nimport styled from 'styled-components';\nimport { navDelay, loaderDelay } from '@utils';\nimport { usePrefersReducedMotion } from '@hooks';\n\nconst StyledHeroSection = styled.section`\n ${({ theme }) => theme.mixins.flexCenter};\n flex-direction: column;\n align-items: flex-start;\n min-height: 100vh;\n height: 100vh;\n padding: 0;\n\n @media (max-height: 700px) and (min-width: 700px), (max-width: 360px) {\n height: auto;\n padding-top: var(--nav-height);\n }\n\n h1 {\n margin: 0 0 30px 4px;\n color: var(--green);\n font-family: var(--font-mono);\n font-size: clamp(var(--fz-sm), 5vw, var(--fz-md));\n font-weight: 400;\n\n @media (max-width: 480px) {\n margin: 0 0 20px 2px;\n }\n }\n\n h3 {\n margin-top: 5px;\n color: var(--slate);\n line-height: 0.9;\n }\n\n p {\n margin: 20px 0 0;\n max-width: 540px;\n }\n\n .email-link {\n ${({ theme }) => theme.mixins.bigButton};\n margin-top: 50px;\n }\n`;\n\nconst Hero = () => {\n const [isMounted, setIsMounted] = useState(false);\n const prefersReducedMotion = usePrefersReducedMotion();\n\n useEffect(() => {\n if (prefersReducedMotion) {\n return;\n }\n\n const timeout = setTimeout(() => setIsMounted(true), navDelay);\n return () => clearTimeout(timeout);\n }, []);\n\n const one = <h1>Hi, my name is</h1>;\n const two = <h2 className=\"big-heading\">Sawradip Saha.</h2>;\n const three = <h3 className=\"big-heading\">I create intelligence.</h3>;\n const four = (\n <>\n <p>\n I’m a machine learning engineer specializing in building complex data processing and model\n training pipelines. Currently, I’m focused on contributing to open-source projects , in\n addition to my role at{' '}\n <a href=\"https://magicmind.me/\" target=\"_blank\" rel=\"noreferrer\">\n MagicMind\n </a>\n .\n </p>\n </>\n );\n const five = (\n <a\n className=\"email-link\"\n href=\"/resume.pdf\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Check out my CV!\n </a>\n );\n\n const items = [one, two, three, four, five];\n\n return (\n <StyledHeroSection>\n {prefersReducedMotion ? (\n <>\n {items.map((item, i) => (\n <div key={i}>{item}</div>\n ))}\n </>\n ) : (\n <TransitionGroup component={null}>\n {isMounted &&\n items.map((item, i) => (\n <CSSTransition key={i} classNames=\"fadeup\" timeout={loaderDelay}>\n <div style={{ transitionDelay: `${i + 1}00ms` }}>{item}</div>\n </CSSTransition>\n ))}\n </TransitionGroup>\n )}\n </StyledHeroSection>\n );\n};\n\nexport default Hero;\n","import React, { useEffect, useRef } from 'react';\nimport { StaticImage } from 'gatsby-plugin-image';\nimport styled from 'styled-components';\nimport { srConfig } from '@config';\nimport sr from '@utils/sr';\nimport { usePrefersReducedMotion } from '@hooks';\n\nconst StyledAboutSection = styled.section`\n max-width: 900px;\n\n .inner {\n display: grid;\n grid-template-columns: 3fr 2fr;\n grid-gap: 50px;\n\n @media (max-width: 768px) {\n display: block;\n }\n }\n`;\nconst StyledText = styled.div`\n ul.skills-list {\n display: grid;\n grid-template-columns: repeat(2, minmax(140px, 200px));\n grid-gap: 0 10px;\n padding: 0;\n margin: 20px 0 0 0;\n overflow: hidden;\n list-style: none;\n\n li {\n position: relative;\n margin-bottom: 10px;\n padding-left: 20px;\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n\n &:before {\n content: '▹';\n position: absolute;\n left: 0;\n color: var(--green);\n font-size: var(--fz-sm);\n line-height: 12px;\n }\n }\n }\n`;\nconst StyledPic = styled.div`\n position: relative;\n max-width: 300px;\n\n @media (max-width: 768px) {\n margin: 50px auto 0;\n width: 70%;\n }\n\n .wrapper {\n ${({ theme }) => theme.mixins.boxShadow};\n display: block;\n position: relative;\n width: 100%;\n border-radius: var(--border-radius);\n background-color: var(--green);\n\n &:hover,\n &:focus {\n outline: 0;\n\n &:after {\n top: 15px;\n left: 15px;\n }\n\n .img {\n filter: none;\n mix-blend-mode: normal;\n }\n }\n\n .img {\n position: relative;\n border-radius: var(--border-radius);\n mix-blend-mode: multiply;\n filter: grayscale(100%) contrast(1);\n transition: var(--transition);\n }\n\n &:before,\n &:after {\n content: '';\n display: block;\n position: absolute;\n width: 100%;\n height: 100%;\n border-radius: var(--border-radius);\n transition: var(--transition);\n }\n\n &:before {\n top: 0;\n left: 0;\n background-color: var(--navy);\n mix-blend-mode: screen;\n }\n\n &:after {\n border: 2px solid var(--green);\n top: 20px;\n left: 20px;\n z-index: -1;\n }\n }\n`;\n\nconst About = () => {\n const revealContainer = useRef(null);\n const prefersReducedMotion = usePrefersReducedMotion();\n\n useEffect(() => {\n if (prefersReducedMotion) {\n return;\n }\n\n sr.reveal(revealContainer.current, srConfig());\n }, []);\n\n const skills = ['PyTorch', 'chatGPT', 'Cuda', 'GPT3', 'C#', 'Dall-E2'];\n\n return (\n <StyledAboutSection id=\"about\" ref={revealContainer}>\n <h2 className=\"numbered-heading\">About Me</h2>\n\n <div className=\"inner\">\n <StyledText>\n <div>\n <p>\n Hi! I am <b>Sawradip</b>. I am deeply passionate about using my expertise in machine\n learning and computer vision to tackle real-world problems. With a strong foundation\n in deep learning and Python programming, I have consistently demonstrated my ability\n to successfully design and implement complex data processing and model training\n pipelines.\n </p>\n\n <p>\n Fast-forward to today, and I’ve had participated in several international and regional\n Deep Learning competitions, including{' '}\n <a href=\"https://signalprocessingsociety.org/community-involvement/vip-cup-2021-icip-2021/\">\n IEEE VIP CUP 2021\n </a>{' '}\n (1st Place),{' '}\n <a href=\"https://www.kaggle.com/competitions/dlsprint/discussion/349991/\">\n Deep Learning Sprint 2022\n </a>{' '}\n (2nd Place),{' '}\n <a href=\"https://2022.ieeeicip.org/video-and-image-processing-cup//\">\n IEEE VIP CUP 2022\n </a>{' '}\n (3rd Place), and <a href=\"https://www.robi.com.bd/en/datathon/\">Robi Datathon 2.0 </a>{' '}\n (Top 10). My main focus these days is core deep learning, GPU Programming and making a\n larger contribution at open-source projects including{' '}\n <a href=\"https://github.com/pytorch/pytorch/\">PyTorch</a>.\n </p>\n\n <p>\n I recently joined <a href=\"https://magicmind.me\">MagicMind,</a> a Next-generation\n wellness platform & Spiritual experiences as a Machine Learning Intern.\n </p>\n\n <p>Here are a few technologies I’ve been working with recently:</p>\n </div>\n\n <ul className=\"skills-list\">\n {skills && skills.map((skill, i) => <li key={i}>{skill}</li>)}\n </ul>\n </StyledText>\n\n <StyledPic>\n <div className=\"wrapper\">\n <StaticImage\n className=\"img\"\n src=\"../../images/sawra.jpeg\"\n width={500}\n quality={95}\n formats={['AUTO', 'WEBP', 'AVIF']}\n alt=\"Headshot\"\n />\n </div>\n </StyledPic>\n </div>\n </StyledAboutSection>\n );\n};\n\nexport default About;\n","import React, { useState, useEffect, useRef } from 'react';\r\nimport { useStaticQuery, graphql } from 'gatsby';\r\nimport { CSSTransition } from 'react-transition-group';\r\nimport styled from 'styled-components';\r\nimport { srConfig } from '@config';\r\nimport { KEY_CODES } from '@utils';\r\nimport sr from '@utils/sr';\r\nimport { usePrefersReducedMotion } from '@hooks';\r\n\r\nconst StyledJobsSection = styled.section`\r\n max-width: 700px;\r\n\r\n .inner {\r\n display: flex;\r\n\r\n @media (max-width: 600px) {\r\n display: block;\r\n }\r\n\r\n // Prevent container from jumping\r\n @media (min-width: 700px) {\r\n min-height: 340px;\r\n }\r\n }\r\n`;\r\n\r\nconst StyledTabList = styled.div`\r\n position: relative;\r\n z-index: 3;\r\n width: max-content;\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n\r\n @media (max-width: 600px) {\r\n display: flex;\r\n overflow-x: auto;\r\n width: calc(100% + 100px);\r\n padding-left: 50px;\r\n margin-left: -50px;\r\n margin-bottom: 30px;\r\n }\r\n @media (max-width: 480px) {\r\n width: calc(100% + 50px);\r\n padding-left: 25px;\r\n margin-left: -25px;\r\n }\r\n\r\n li {\r\n &:first-of-type {\r\n @media (max-width: 600px) {\r\n margin-left: 50px;\r\n }\r\n @media (max-width: 480px) {\r\n margin-left: 25px;\r\n }\r\n }\r\n &:last-of-type {\r\n @media (max-width: 600px) {\r\n padding-right: 50px;\r\n }\r\n @media (max-width: 480px) {\r\n padding-right: 25px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst StyledTabButton = styled.button`\r\n ${({ theme }) => theme.mixins.link};\r\n display: flex;\r\n align-items: center;\r\n width: 100%;\r\n height: var(--tab-height);\r\n padding: 0 20px 2px;\r\n border-left: 2px solid var(--lightest-navy);\r\n background-color: transparent;\r\n color: ${({ isActive }) => (isActive ? 'var(--green)' : 'var(--slate)')};\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-xs);\r\n text-align: left;\r\n white-space: nowrap;\r\n\r\n @media (max-width: 768px) {\r\n padding: 0 15px 2px;\r\n }\r\n @media (max-width: 600px) {\r\n ${({ theme }) => theme.mixins.flexCenter};\r\n min-width: 120px;\r\n padding: 0 15px;\r\n border-left: 0;\r\n border-bottom: 2px solid var(--lightest-navy);\r\n text-align: center;\r\n }\r\n\r\n &:hover,\r\n &:focus {\r\n background-color: var(--light-navy);\r\n }\r\n`;\r\n\r\nconst StyledHighlight = styled.div`\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n z-index: 10;\r\n width: 2px;\r\n height: var(--tab-height);\r\n border-radius: var(--border-radius);\r\n background: var(--green);\r\n transform: translateY(calc(${({ activeTabId }) => activeTabId} * var(--tab-height)));\r\n transition: transform 0.25s cubic-bezier(0.645, 0.045, 0.355, 1);\r\n transition-delay: 0.1s;\r\n\r\n @media (max-width: 600px) {\r\n top: auto;\r\n bottom: 0;\r\n width: 100%;\r\n max-width: var(--tab-width);\r\n height: 2px;\r\n margin-left: 50px;\r\n transform: translateX(calc(${({ activeTabId }) => activeTabId} * var(--tab-width)));\r\n }\r\n @media (max-width: 480px) {\r\n margin-left: 25px;\r\n }\r\n`;\r\n\r\nconst StyledTabPanels = styled.div`\r\n position: relative;\r\n width: 100%;\r\n margin-left: 20px;\r\n\r\n @media (max-width: 600px) {\r\n margin-left: 0;\r\n }\r\n`;\r\n\r\nconst StyledTabPanel = styled.div`\r\n width: 100%;\r\n height: auto;\r\n padding: 10px 5px;\r\n\r\n ul {\r\n ${({ theme }) => theme.mixins.fancyList};\r\n }\r\n\r\n h3 {\r\n margin-bottom: 2px;\r\n font-size: var(--fz-xxl);\r\n font-weight: 500;\r\n line-height: 1.3;\r\n\r\n .company {\r\n color: var(--green);\r\n }\r\n }\r\n\r\n .range {\r\n margin-bottom: 25px;\r\n color: var(--light-slate);\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-xs);\r\n }\r\n`;\r\n\r\nconst Jobs = () => {\r\n const data = useStaticQuery(graphql`\r\n query {\r\n jobs: allMarkdownRemark(\r\n filter: { fileAbsolutePath: { regex: \"/content/jobs/\" } }\r\n sort: { fields: [frontmatter___date], order: DESC }\r\n ) {\r\n edges {\r\n node {\r\n frontmatter {\r\n title\r\n company\r\n location\r\n range\r\n url\r\n }\r\n html\r\n }\r\n }\r\n }\r\n }\r\n `);\r\n\r\n const jobsData = data.jobs.edges;\r\n\r\n const [activeTabId, setActiveTabId] = useState(0);\r\n const [tabFocus, setTabFocus] = useState(null);\r\n const tabs = useRef([]);\r\n const revealContainer = useRef(null);\r\n const prefersReducedMotion = usePrefersReducedMotion();\r\n\r\n useEffect(() => {\r\n if (prefersReducedMotion) {\r\n return;\r\n }\r\n\r\n sr.reveal(revealContainer.current, srConfig());\r\n }, []);\r\n\r\n const focusTab = () => {\r\n if (tabs.current[tabFocus]) {\r\n tabs.current[tabFocus].focus();\r\n return;\r\n }\r\n // If we're at the end, go to the start\r\n if (tabFocus >= tabs.current.length) {\r\n setTabFocus(0);\r\n }\r\n // If we're at the start, move to the end\r\n if (tabFocus < 0) {\r\n setTabFocus(tabs.current.length - 1);\r\n }\r\n };\r\n\r\n // Only re-run the effect if tabFocus changes\r\n useEffect(() => focusTab(), [tabFocus]);\r\n\r\n // Focus on tabs when using up & down arrow keys\r\n const onKeyDown = e => {\r\n switch (e.key) {\r\n case KEY_CODES.ARROW_UP: {\r\n e.preventDefault();\r\n setTabFocus(tabFocus - 1);\r\n break;\r\n }\r\n\r\n case KEY_CODES.ARROW_DOWN: {\r\n e.preventDefault();\r\n setTabFocus(tabFocus + 1);\r\n break;\r\n }\r\n\r\n default: {\r\n break;\r\n }\r\n }\r\n };\r\n\r\n return (\r\n <StyledJobsSection id=\"jobs\" ref={revealContainer}>\r\n <h2 className=\"numbered-heading\">Where I’ve Worked</h2>\r\n\r\n <div className=\"inner\">\r\n <StyledTabList role=\"tablist\" aria-label=\"Job tabs\" onKeyDown={e => onKeyDown(e)}>\r\n {jobsData &&\r\n jobsData.map(({ node }, i) => {\r\n const { company } = node.frontmatter;\r\n return (\r\n <StyledTabButton\r\n key={i}\r\n isActive={activeTabId === i}\r\n onClick={() => setActiveTabId(i)}\r\n ref={el => (tabs.current[i] = el)}\r\n id={`tab-${i}`}\r\n role=\"tab\"\r\n tabIndex={activeTabId === i ? '0' : '-1'}\r\n aria-selected={activeTabId === i ? true : false}\r\n aria-controls={`panel-${i}`}>\r\n <span>{company}</span>\r\n </StyledTabButton>\r\n );\r\n })}\r\n <StyledHighlight activeTabId={activeTabId} />\r\n </StyledTabList>\r\n\r\n <StyledTabPanels>\r\n {jobsData &&\r\n jobsData.map(({ node }, i) => {\r\n const { frontmatter, html } = node;\r\n const { title, url, company, range } = frontmatter;\r\n\r\n return (\r\n <CSSTransition key={i} in={activeTabId === i} timeout={250} classNames=\"fade\">\r\n <StyledTabPanel\r\n id={`panel-${i}`}\r\n role=\"tabpanel\"\r\n tabIndex={activeTabId === i ? '0' : '-1'}\r\n aria-labelledby={`tab-${i}`}\r\n aria-hidden={activeTabId !== i}\r\n hidden={activeTabId !== i}>\r\n <h3>\r\n <span>{title}</span>\r\n <span className=\"company\">\r\n @ \r\n <a href={url} className=\"inline-link\">\r\n {company}\r\n </a>\r\n </span>\r\n </h3>\r\n\r\n <p className=\"range\">{range}</p>\r\n\r\n <div dangerouslySetInnerHTML={{ __html: html }} />\r\n </StyledTabPanel>\r\n </CSSTransition>\r\n );\r\n })}\r\n </StyledTabPanels>\r\n </div>\r\n </StyledJobsSection>\r\n );\r\n};\r\n\r\nexport default Jobs;\r\n","import React, { useEffect, useRef } from 'react';\nimport styled from 'styled-components';\nimport { srConfig, email } from '@config';\nimport sr from '@utils/sr';\nimport { usePrefersReducedMotion } from '@hooks';\n\nconst StyledContactSection = styled.section`\n max-width: 600px;\n margin: 0 auto 100px;\n text-align: center;\n\n @media (max-width: 768px) {\n margin: 0 auto 50px;\n }\n\n .overline {\n display: block;\n margin-bottom: 20px;\n color: var(--green);\n font-family: var(--font-mono);\n font-size: var(--fz-md);\n font-weight: 400;\n\n &:before {\n bottom: 0;\n font-size: var(--fz-sm);\n }\n\n &:after {\n display: none;\n }\n }\n\n .title {\n font-size: clamp(40px, 5vw, 60px);\n }\n\n .email-link {\n ${({ theme }) => theme.mixins.bigButton};\n margin-top: 50px;\n }\n`;\n\nconst Contact = () => {\n const revealContainer = useRef(null);\n const prefersReducedMotion = usePrefersReducedMotion();\n\n useEffect(() => {\n if (prefersReducedMotion) {\n return;\n }\n\n sr.reveal(revealContainer.current, srConfig());\n }, []);\n\n return (\n <StyledContactSection id=\"contact\" ref={revealContainer}>\n <h2 className=\"numbered-heading overline\">What’s Next?</h2>\n\n <h2 className=\"title\">Get In Touch</h2>\n\n <p>\n I am passionate about continuing to grow and develop my skills in the field of machine\n learning and am open to discussing any potential projects, including open-source projects,\n or opportunities.\n </p>\n\n <a className=\"email-link\" href={`mailto:${email}`}>\n Say Hello\n </a>\n </StyledContactSection>\n );\n};\n\nexport default Contact;\n","import React, { useEffect, useRef } from 'react';\nimport { useStaticQuery, graphql } from 'gatsby';\nimport { GatsbyImage, getImage } from 'gatsby-plugin-image';\nimport styled from 'styled-components';\nimport sr from '@utils/sr';\nimport { srConfig } from '@config';\nimport { Icon } from '@components/icons';\nimport { usePrefersReducedMotion } from '@hooks';\n\nconst StyledProjectsGrid = styled.ul`\n ${({ theme }) => theme.mixins.resetList};\n\n a {\n position: relative;\n z-index: 1;\n }\n`;\n\nconst StyledProject = styled.li`\n position: relative;\n display: grid;\n grid-gap: 10px;\n grid-template-columns: repeat(12, 1fr);\n align-items: center;\n\n @media (max-width: 768px) {\n ${({ theme }) => theme.mixins.boxShadow};\n }\n\n &:not(:last-of-type) {\n margin-bottom: 100px;\n\n @media (max-width: 768px) {\n margin-bottom: 70px;\n }\n\n @media (max-width: 480px) {\n margin-bottom: 30px;\n }\n }\n\n &:nth-of-type(odd) {\n .project-content {\n grid-column: 7 / -1;\n text-align: right;\n\n @media (max-width: 1080px) {\n grid-column: 5 / -1;\n }\n @media (max-width: 768px) {\n grid-column: 1 / -1;\n padding: 40px 40px 30px;\n text-align: left;\n }\n @media (max-width: 480px) {\n padding: 25px 25px 20px;\n }\n }\n .project-tech-list {\n justify-content: flex-end;\n\n @media (max-width: 768px) {\n justify-content: flex-start;\n }\n\n li {\n margin: 0 0 5px 20px;\n\n @media (max-width: 768px) {\n margin: 0 10px 5px 0;\n }\n }\n }\n .project-links {\n justify-content: flex-end;\n margin-left: 0;\n margin-right: -10px;\n\n @media (max-width: 768px) {\n justify-content: flex-start;\n margin-left: -10px;\n margin-right: 0;\n }\n }\n .project-image {\n grid-column: 1 / 8;\n\n @media (max-width: 768px) {\n grid-column: 1 / -1;\n }\n }\n }\n\n .project-content {\n position: relative;\n grid-column: 1 / 7;\n grid-row: 1 / -1;\n\n @media (max-width: 1080px) {\n grid-column: 1 / 9;\n }\n\n @media (max-width: 768px) {\n display: flex;\n flex-direction: column;\n justify-content: center;\n height: 100%;\n grid-column: 1 / -1;\n padding: 40px 40px 30px;\n z-index: 5;\n }\n\n @media (max-width: 480px) {\n padding: 30px 25px 20px;\n }\n }\n\n .project-overline {\n margin: 10px 0;\n color: var(--green);\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n font-weight: 400;\n }\n\n .project-title {\n color: var(--lightest-slate);\n font-size: clamp(24px, 5vw, 28px);\n\n @media (min-width: 768px) {\n margin: 0 0 20px;\n }\n\n @media (max-width: 768px) {\n color: var(--white);\n\n a {\n position: static;\n\n &:before {\n content: '';\n display: block;\n position: absolute;\n z-index: 0;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n }\n }\n }\n }\n\n .project-description {\n ${({ theme }) => theme.mixins.boxShadow};\n position: relative;\n z-index: 2;\n padding: 25px;\n border-radius: var(--border-radius);\n background-color: var(--light-navy);\n color: var(--light-slate);\n font-size: var(--fz-lg);\n\n @media (max-width: 768px) {\n padding: 20px 0;\n background-color: transparent;\n box-shadow: none;\n\n &:hover {\n box-shadow: none;\n }\n }\n\n a {\n ${({ theme }) => theme.mixins.inlineLink};\n }\n\n strong {\n color: var(--white);\n font-weight: normal;\n }\n }\n\n .project-tech-list {\n display: flex;\n flex-wrap: wrap;\n position: relative;\n z-index: 2;\n margin: 25px 0 10px;\n padding: 0;\n list-style: none;\n\n li {\n margin: 0 20px 5px 0;\n color: var(--light-slate);\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n white-space: nowrap;\n }\n\n @media (max-width: 768px) {\n margin: 10px 0;\n\n li {\n margin: 0 10px 5px 0;\n color: var(--lightest-slate);\n }\n }\n }\n\n .project-links {\n display: flex;\n align-items: center;\n position: relative;\n margin-top: 10px;\n margin-left: -10px;\n color: var(--lightest-slate);\n\n a {\n ${({ theme }) => theme.mixins.flexCenter};\n padding: 10px;\n\n &.external {\n svg {\n width: 22px;\n height: 22px;\n margin-top: -4px;\n }\n }\n\n svg {\n width: 20px;\n height: 20px;\n }\n }\n\n .cta {\n ${({ theme }) => theme.mixins.smallButton};\n margin: 10px;\n }\n }\n\n .project-image {\n ${({ theme }) => theme.mixins.boxShadow};\n grid-column: 6 / -1;\n grid-row: 1 / -1;\n position: relative;\n z-index: 1;\n\n @media (max-width: 768px) {\n grid-column: 1 / -1;\n height: 100%;\n opacity: 0.25;\n }\n\n a {\n width: 100%;\n height: 100%;\n background-color: var(--green);\n border-radius: var(--border-radius);\n vertical-align: middle;\n\n &:hover,\n &:focus {\n background: transparent;\n outline: 0;\n\n &:before,\n .img {\n background: transparent;\n filter: none;\n }\n }\n\n &:before {\n content: '';\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n z-index: 3;\n transition: var(--transition);\n background-color: var(--navy);\n mix-blend-mode: screen;\n }\n }\n\n .img {\n border-radius: var(--border-radius);\n mix-blend-mode: multiply;\n filter: grayscale(100%) contrast(1) brightness(90%);\n\n @media (max-width: 768px) {\n object-fit: cover;\n width: auto;\n height: 100%;\n filter: grayscale(100%) contrast(1) brightness(50%);\n }\n }\n }\n`;\n\nconst Featured = () => {\n const data = useStaticQuery(graphql`\n {\n featured: allMarkdownRemark(\n filter: { fileAbsolutePath: { regex: \"/content/featured/\" } }\n sort: { fields: [frontmatter___date], order: ASC }\n ) {\n edges {\n node {\n frontmatter {\n title\n cover {\n childImageSharp {\n gatsbyImageData(width: 700, placeholder: BLURRED, formats: [AUTO, WEBP, AVIF])\n }\n }\n tech\n github\n external\n }\n html\n }\n }\n }\n }\n `);\n\n const featuredProjects = data.featured.edges.filter(({ node }) => node);\n const revealTitle = useRef(null);\n const revealProjects = useRef([]);\n const prefersReducedMotion = usePrefersReducedMotion();\n\n useEffect(() => {\n if (prefersReducedMotion) {\n return;\n }\n\n sr.reveal(revealTitle.current, srConfig());\n revealProjects.current.forEach((ref, i) => sr.reveal(ref, srConfig(i * 100)));\n }, []);\n\n return (\n <section id=\"projects\">\n <h2 className=\"numbered-heading\" ref={revealTitle}>\n Some Projects I’ve Built\n </h2>\n\n <StyledProjectsGrid>\n {featuredProjects &&\n featuredProjects.map(({ node }, i) => {\n const { frontmatter, html } = node;\n const { external, title, tech, github, cover } = frontmatter;\n const image = getImage(cover);\n\n return (\n <StyledProject key={i} ref={el => (revealProjects.current[i] = el)}>\n <div className=\"project-content\">\n <div>\n <p className=\"project-overline\">Featured Project</p>\n\n <h3 className=\"project-title\">\n <a href={external}>{title}</a>\n </h3>\n\n <div\n className=\"project-description\"\n dangerouslySetInnerHTML={{ __html: html }}\n />\n\n {tech.length && (\n <ul className=\"project-tech-list\">\n {tech.map((tech, i) => (\n <li key={i}>{tech}</li>\n ))}\n </ul>\n )}\n\n <div className=\"project-links\">\n {github && (\n <a href={github} aria-label=\"GitHub Link\">\n <Icon name=\"GitHub\" />\n </a>\n )}\n {external && (\n <a href={external} aria-label=\"External Link\" className=\"external\">\n <Icon name=\"External\" />\n </a>\n )}\n </div>\n </div>\n </div>\n\n <div className=\"project-image\">\n <a href={external ? external : github ? github : '#'}>\n <GatsbyImage image={image} alt={title} className=\"img\" />\n </a>\n </div>\n </StyledProject>\n );\n })}\n </StyledProjectsGrid>\n </section>\n );\n};\n\nexport default Featured;\n","import React, { useState, useEffect, useRef } from 'react';\r\nimport { Link, useStaticQuery, graphql } from 'gatsby';\r\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\r\nimport styled from 'styled-components';\r\nimport { srConfig } from '@config';\r\nimport sr from '@utils/sr';\r\nimport { Icon } from '@components/icons';\r\nimport { usePrefersReducedMotion } from '@hooks';\r\n\r\nconst StyledProjectsSection = styled.section`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n\r\n h2 {\r\n font-size: clamp(24px, 5vw, var(--fz-heading));\r\n }\r\n\r\n .archive-link {\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-sm);\r\n &:after {\r\n bottom: 0.1em;\r\n }\r\n }\r\n\r\n .projects-grid {\r\n ${({ theme }) => theme.mixins.resetList};\r\n display: grid;\r\n grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));\r\n grid-gap: 15px;\r\n position: relative;\r\n margin-top: 50px;\r\n\r\n @media (max-width: 1080px) {\r\n grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));\r\n }\r\n }\r\n\r\n .more-button {\r\n ${({ theme }) => theme.mixins.button};\r\n margin: 80px auto 0;\r\n }\r\n`;\r\n\r\nconst StyledProject = styled.li`\r\n position: relative;\r\n cursor: default;\r\n transition: var(--transition);\r\n\r\n @media (prefers-reduced-motion: no-preference) {\r\n &:hover,\r\n &:focus-within {\r\n .project-inner {\r\n transform: translateY(-7px);\r\n }\r\n }\r\n }\r\n\r\n a {\r\n position: relative;\r\n z-index: 1;\r\n }\r\n\r\n .project-inner {\r\n ${({ theme }) => theme.mixins.boxShadow};\r\n ${({ theme }) => theme.mixins.flexBetween};\r\n flex-direction: column;\r\n align-items: flex-start;\r\n position: relative;\r\n height: 100%;\r\n padding: 2rem 1.75rem;\r\n border-radius: var(--border-radius);\r\n background-color: var(--light-navy);\r\n transition: var(--transition);\r\n overflow: auto;\r\n }\r\n\r\n .project-top {\r\n ${({ theme }) => theme.mixins.flexBetween};\r\n margin-bottom: 35px;\r\n\r\n .folder {\r\n color: var(--green);\r\n svg {\r\n width: 40px;\r\n height: 40px;\r\n }\r\n }\r\n\r\n .project-links {\r\n display: flex;\r\n align-items: center;\r\n margin-right: -10px;\r\n color: var(--light-slate);\r\n\r\n a {\r\n ${({ theme }) => theme.mixins.flexCenter};\r\n padding: 5px 7px;\r\n\r\n &.external {\r\n svg {\r\n width: 22px;\r\n height: 22px;\r\n margin-top: -4px;\r\n }\r\n }\r\n\r\n svg {\r\n width: 20px;\r\n height: 20px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .project-title {\r\n margin: 0 0 10px;\r\n color: var(--lightest-slate);\r\n font-size: var(--fz-xxl);\r\n\r\n a {\r\n position: static;\r\n\r\n &:before {\r\n content: '';\r\n display: block;\r\n position: absolute;\r\n z-index: 0;\r\n width: 100%;\r\n height: 100%;\r\n top: 0;\r\n left: 0;\r\n }\r\n }\r\n }\r\n\r\n .project-description {\r\n color: var(--light-slate);\r\n font-size: 17px;\r\n\r\n a {\r\n ${({ theme }) => theme.mixins.inlineLink};\r\n }\r\n }\r\n\r\n .project-tech-list {\r\n display: flex;\r\n align-items: flex-end;\r\n flex-grow: 1;\r\n flex-wrap: wrap;\r\n padding: 0;\r\n margin: 20px 0 0 0;\r\n list-style: none;\r\n\r\n li {\r\n font-family: var(--font-mono);\r\n font-size: var(--fz-xxs);\r\n line-height: 1.75;\r\n\r\n &:not(:last-of-type) {\r\n margin-right: 15px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst Projects = () => {\r\n const data = useStaticQuery(graphql`\r\n query {\r\n projects: allMarkdownRemark(\r\n filter: {\r\n fileAbsolutePath: { regex: \"/content/projects/\" }\r\n frontmatter: { showInProjects: { ne: false } }\r\n }\r\n sort: { fields: [frontmatter___date], order: DESC }\r\n ) {\r\n edges {\r\n node {\r\n frontmatter {\r\n title\r\n tech\r\n github\r\n external\r\n }\r\n html\r\n }\r\n }\r\n }\r\n }\r\n `);\r\n\r\n const [showMore, setShowMore] = useState(false);\r\n const revealTitle = useRef(null);\r\n const revealArchiveLink = useRef(null);\r\n const revealProjects = useRef([]);\r\n const prefersReducedMotion = usePrefersReducedMotion();\r\n\r\n useEffect(() => {\r\n if (prefersReducedMotion) {\r\n return;\r\n }\r\n\r\n sr.reveal(revealTitle.current, srConfig());\r\n sr.reveal(revealArchiveLink.current, srConfig());\r\n revealProjects.current.forEach((ref, i) => sr.reveal(ref, srConfig(i * 100)));\r\n }, []);\r\n\r\n const GRID_LIMIT = 6;\r\n const projects = data.projects.edges.filter(({ node }) => node);\r\n const firstSix = projects.slice(0, GRID_LIMIT);\r\n const projectsToShow = showMore ? projects : firstSix;\r\n\r\n const projectInner = node => {\r\n const { frontmatter, html } = node;\r\n const { github, external, title, tech } = frontmatter;\r\n\r\n return (\r\n <div className=\"project-inner\">\r\n <header>\r\n <div className=\"project-top\">\r\n <div className=\"folder\">\r\n <Icon name=\"Folder\" />\r\n </div>\r\n <div className=\"project-links\">\r\n {github && (\r\n <a href={github} aria-label=\"GitHub Link\" target=\"_blank\" rel=\"noreferrer\">\r\n <Icon name=\"GitHub\" />\r\n </a>\r\n )}\r\n {external && (\r\n <a\r\n href={external}\r\n aria-label=\"External Link\"\r\n className=\"external\"\r\n target=\"_blank\"\r\n rel=\"noreferrer\">\r\n <Icon name=\"External\" />\r\n </a>\r\n )}\r\n </div>\r\n </div>\r\n\r\n <h3 className=\"project-title\">\r\n <a href={external} target=\"_blank\" rel=\"noreferrer\">\r\n {title}\r\n </a>\r\n </h3>\r\n\r\n <div className=\"project-description\" dangerouslySetInnerHTML={{ __html: html }} />\r\n </header>\r\n\r\n <footer>\r\n {tech && (\r\n <ul className=\"project-tech-list\">\r\n {tech.map((tech, i) => (\r\n <li key={i}>{tech}</li>\r\n ))}\r\n </ul>\r\n )}\r\n </footer>\r\n </div>\r\n );\r\n };\r\n\r\n return (\r\n <StyledProjectsSection>\r\n <h2 ref={revealTitle}>Other Noteworthy Projects</h2>\r\n\r\n <Link className=\"inline-link archive-link\" to=\"/archive\" ref={revealArchiveLink}>\r\n view the archive\r\n </Link>\r\n\r\n <ul className=\"projects-grid\">\r\n {prefersReducedMotion ? (\r\n <>\r\n {projectsToShow &&\r\n projectsToShow.map(({ node }, i) => (\r\n <StyledProject key={i}>{projectInner(node)}</StyledProject>\r\n ))}\r\n </>\r\n ) : (\r\n <TransitionGroup component={null}>\r\n {projectsToShow &&\r\n projectsToShow.map(({ node }, i) => (\r\n <CSSTransition\r\n key={i}\r\n classNames=\"fadeup\"\r\n timeout={i >= GRID_LIMIT ? (i - GRID_LIMIT) * 300 : 300}\r\n exit={false}>\r\n <StyledProject\r\n key={i}\r\n ref={el => (revealProjects.current[i] = el)}\r\n style={{\r\n transitionDelay: `${i >= GRID_LIMIT ? (i - GRID_LIMIT) * 100 : 0}ms`,\r\n }}>\r\n {projectInner(node)}\r\n </StyledProject>\r\n </CSSTransition>\r\n ))}\r\n </TransitionGroup>\r\n )}\r\n </ul>\r\n\r\n <button className=\"more-button\" onClick={() => setShowMore(!showMore)}>\r\n Show {showMore ? 'Less' : 'More'}\r\n </button>\r\n </StyledProjectsSection>\r\n );\r\n};\r\n\r\nexport default Projects;\r\n","import React, { useState, useEffect, useRef } from 'react';\nimport { useStaticQuery, graphql } from 'gatsby';\nimport { CSSTransition } from 'react-transition-group';\nimport styled from 'styled-components';\nimport { srConfig } from '@config';\nimport { KEY_CODES } from '@utils';\nimport sr from '@utils/sr';\nimport { usePrefersReducedMotion } from '@hooks';\n\nconst StyledJobsSection = styled.section`\n max-width: 700px;\n\n .inner {\n display: flex;\n\n @media (max-width: 600px) {\n display: block;\n }\n\n // Prevent container from jumping\n @media (min-width: 700px) {\n min-height: 340px;\n }\n }\n`;\n\nconst StyledTabList = styled.div`\n position: relative;\n z-index: 3;\n width: max-content;\n padding: 0;\n margin: 0;\n list-style: none;\n\n @media (max-width: 600px) {\n display: flex;\n overflow-x: auto;\n width: calc(100% + 100px);\n padding-left: 50px;\n margin-left: -50px;\n margin-bottom: 30px;\n }\n @media (max-width: 480px) {\n width: calc(100% + 50px);\n padding-left: 25px;\n margin-left: -25px;\n }\n\n li {\n &:first-of-type {\n @media (max-width: 600px) {\n margin-left: 50px;\n }\n @media (max-width: 480px) {\n margin-left: 25px;\n }\n }\n &:last-of-type {\n @media (max-width: 600px) {\n padding-right: 50px;\n }\n @media (max-width: 480px) {\n padding-right: 25px;\n }\n }\n }\n`;\n\nconst StyledTabButton = styled.button`\n ${({ theme }) => theme.mixins.link};\n display: flex;\n align-items: center;\n width: 100%;\n height: var(--tab-height);\n padding: 0 20px 2px;\n border-left: 2px solid var(--lightest-navy);\n background-color: transparent;\n color: ${({ isActive }) => (isActive ? 'var(--green)' : 'var(--slate)')};\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n text-align: left;\n white-space: nowrap;\n\n @media (max-width: 768px) {\n padding: 0 15px 2px;\n }\n @media (max-width: 600px) {\n ${({ theme }) => theme.mixins.flexCenter};\n min-width: 120px;\n padding: 0 15px;\n border-left: 0;\n border-bottom: 2px solid var(--lightest-navy);\n text-align: center;\n }\n\n &:hover,\n &:focus {\n background-color: var(--light-navy);\n }\n`;\n\nconst StyledHighlight = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n z-index: 10;\n width: 2px;\n height: var(--tab-height);\n border-radius: var(--border-radius);\n background: var(--green);\n transform: translateY(calc(${({ activeTabId }) => activeTabId} * var(--tab-height)));\n transition: transform 0.25s cubic-bezier(0.645, 0.045, 0.355, 1);\n transition-delay: 0.1s;\n\n @media (max-width: 600px) {\n top: auto;\n bottom: 0;\n width: 100%;\n max-width: var(--tab-width);\n height: 2px;\n margin-left: 50px;\n transform: translateX(calc(${({ activeTabId }) => activeTabId} * var(--tab-width)));\n }\n @media (max-width: 480px) {\n margin-left: 25px;\n }\n`;\n\nconst StyledTabPanels = styled.div`\n position: relative;\n width: 100%;\n margin-left: 20px;\n\n @media (max-width: 600px) {\n margin-left: 0;\n }\n`;\n\nconst StyledTabPanel = styled.div`\n width: 100%;\n height: auto;\n padding: 10px 5px;\n\n ul {\n ${({ theme }) => theme.mixins.fancyList};\n }\n\n h3 {\n margin-bottom: 2px;\n font-size: var(--fz-xxl);\n font-weight: 500;\n line-height: 1.3;\n\n .company {\n color: var(--green);\n }\n }\n\n .range {\n margin-bottom: 25px;\n color: var(--light-slate);\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n }\n`;\n\nconst Education = () => {\n const data = useStaticQuery(graphql`\n query {\n jobs: allMarkdownRemark(\n filter: { fileAbsolutePath: { regex: \"/content/education/\" } }\n sort: { fields: [frontmatter___date], order: DESC }\n ) {\n edges {\n node {\n frontmatter {\n title\n company\n institution\n location\n range\n url\n }\n html\n }\n }\n }\n }\n `);\n\n const jobsData = data.jobs.edges;\n\n const [activeTabId, setActiveTabId] = useState(0);\n const [tabFocus, setTabFocus] = useState(null);\n const tabs = useRef([]);\n const revealContainer = useRef(null);\n const prefersReducedMotion = usePrefersReducedMotion();\n\n useEffect(() => {\n if (prefersReducedMotion) {\n return;\n }\n\n sr.reveal(revealContainer.current, srConfig());\n }, []);\n\n const focusTab = () => {\n if (tabs.current[tabFocus]) {\n tabs.current[tabFocus].focus();\n return;\n }\n // If we're at the end, go to the start\n if (tabFocus >= tabs.current.length) {\n setTabFocus(0);\n }\n // If we're at the start, move to the end\n if (tabFocus < 0) {\n setTabFocus(tabs.current.length - 1);\n }\n };\n\n // Only re-run the effect if tabFocus changes\n useEffect(() => focusTab(), [tabFocus]);\n\n // Focus on tabs when using up & down arrow keys\n const onKeyDown = e => {\n switch (e.key) {\n case KEY_CODES.ARROW_UP: {\n e.preventDefault();\n setTabFocus(tabFocus - 1);\n break;\n }\n\n case KEY_CODES.ARROW_DOWN: {\n e.preventDefault();\n setTabFocus(tabFocus + 1);\n break;\n }\n\n default: {\n break;\n }\n }\n };\n\n return (\n <StyledJobsSection id=\"education\" ref={revealContainer}>\n <h2 className=\"numbered-heading\">Where I’ve Learned</h2>\n\n <div className=\"inner\">\n <StyledTabList role=\"tablist\" aria-label=\"Job tabs\" onKeyDown={e => onKeyDown(e)}>\n {jobsData &&\n jobsData.map(({ node }, i) => {\n const { company } = node.frontmatter;\n return (\n <StyledTabButton\n key={i}\n isActive={activeTabId === i}\n onClick={() => setActiveTabId(i)}\n ref={el => (tabs.current[i] = el)}\n id={`tab-${i}`}\n role=\"tab\"\n tabIndex={activeTabId === i ? '0' : '-1'}\n aria-selected={activeTabId === i ? true : false}\n aria-controls={`panel-${i}`}\n >\n <span>{company}</span>\n </StyledTabButton>\n );\n })}\n <StyledHighlight activeTabId={activeTabId} />\n </StyledTabList>\n\n <StyledTabPanels>\n {jobsData &&\n jobsData.map(({ node }, i) => {\n const { frontmatter, html } = node;\n const { title, url, range, location, institution } = frontmatter;\n\n return (\n <CSSTransition key={i} in={activeTabId === i} timeout={250} classNames=\"fade\">\n <StyledTabPanel\n id={`panel-${i}`}\n role=\"tabpanel\"\n tabIndex={activeTabId === i ? '0' : '-1'}\n aria-labelledby={`tab-${i}`}\n aria-hidden={activeTabId !== i}\n hidden={activeTabId !== i}\n >\n <h3>\n <span>{title}</span>\n <span className=\"company\">\n @ \n <a href={url} className=\"inline-link\">\n {institution}\n </a>\n </span>\n </h3>\n <p className=\"range\">{location}</p>\n <p className=\"range\">{range}</p>\n\n <div dangerouslySetInnerHTML={{ __html: html }} />\n </StyledTabPanel>\n </CSSTransition>\n );\n })}\n </StyledTabPanels>\n </div>\n </StyledJobsSection>\n );\n};\n\nexport default Education;\n","import React, { useEffect, useRef } from 'react';\nimport { useStaticQuery, graphql } from 'gatsby';\nimport { GatsbyImage, getImage } from 'gatsby-plugin-image';\nimport styled from 'styled-components';\nimport sr from '@utils/sr';\nimport { srConfig } from '@config';\nimport { Icon } from '@components/icons';\nimport { usePrefersReducedMotion } from '@hooks';\n\nconst StyledProjectsGrid = styled.ul`\n ${({ theme }) => theme.mixins.resetList};\n\n a {\n position: relative;\n z-index: 1;\n }\n`;\n\nconst StyledProject = styled.li`\n position: relative;\n display: grid;\n grid-gap: 10px;\n grid-template-columns: repeat(12, 1fr);\n align-items: center;\n\n @media (max-width: 768px) {\n ${({ theme }) => theme.mixins.boxShadow};\n }\n\n &:not(:last-of-type) {\n margin-bottom: 100px;\n\n @media (max-width: 768px) {\n margin-bottom: 70px;\n }\n\n @media (max-width: 480px) {\n margin-bottom: 30px;\n }\n }\n\n &:nth-of-type(odd) {\n .project-content {\n grid-column: 7 / -1;\n text-align: right;\n\n @media (max-width: 1080px) {\n grid-column: 5 / -1;\n }\n @media (max-width: 768px) {\n grid-column: 1 / -1;\n padding: 40px 40px 30px;\n text-align: left;\n }\n @media (max-width: 480px) {\n padding: 25px 25px 20px;\n }\n }\n .project-tech-list {\n justify-content: flex-end;\n\n @media (max-width: 768px) {\n justify-content: flex-start;\n }\n\n li {\n margin: 0 0 5px 20px;\n\n @media (max-width: 768px) {\n margin: 0 10px 5px 0;\n }\n }\n }\n .project-links {\n justify-content: flex-end;\n margin-left: 0;\n margin-right: -10px;\n\n @media (max-width: 768px) {\n justify-content: flex-start;\n margin-left: -10px;\n margin-right: 0;\n }\n }\n .project-image {\n grid-column: 1 / 8;\n\n @media (max-width: 768px) {\n grid-column: 1 / -1;\n }\n }\n }\n\n .project-content {\n position: relative;\n grid-column: 1 / 7;\n grid-row: 1 / -1;\n\n @media (max-width: 1080px) {\n grid-column: 1 / 9;\n }\n\n @media (max-width: 768px) {\n display: flex;\n flex-direction: column;\n justify-content: center;\n height: 100%;\n grid-column: 1 / -1;\n padding: 40px 40px 30px;\n z-index: 5;\n }\n\n @media (max-width: 480px) {\n padding: 30px 25px 20px;\n }\n }\n\n .project-overline {\n margin: 10px 0;\n color: var(--green);\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n font-weight: 400;\n }\n\n .project-title {\n color: var(--lightest-slate);\n font-size: clamp(24px, 5vw, 28px);\n\n @media (min-width: 768px) {\n margin: 0 0 20px;\n }\n\n @media (max-width: 768px) {\n color: var(--white);\n\n a {\n position: static;\n\n &:before {\n content: '';\n display: block;\n position: absolute;\n z-index: 0;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n }\n }\n }\n }\n\n .project-description {\n ${({ theme }) => theme.mixins.boxShadow};\n position: relative;\n z-index: 2;\n padding: 25px;\n border-radius: var(--border-radius);\n background-color: var(--light-navy);\n color: var(--light-slate);\n font-size: var(--fz-lg);\n\n @media (max-width: 768px) {\n padding: 20px 0;\n background-color: transparent;\n box-shadow: none;\n\n &:hover {\n box-shadow: none;\n }\n }\n\n a {\n ${({ theme }) => theme.mixins.inlineLink};\n }\n\n strong {\n color: var(--white);\n font-weight: normal;\n }\n }\n\n .project-tech-list {\n display: flex;\n flex-wrap: wrap;\n position: relative;\n z-index: 2;\n margin: 25px 0 10px;\n padding: 0;\n list-style: none;\n\n li {\n margin: 0 20px 5px 0;\n color: var(--light-slate);\n font-family: var(--font-mono);\n font-size: var(--fz-xs);\n white-space: nowrap;\n }\n\n @media (max-width: 768px) {\n margin: 10px 0;\n\n li {\n margin: 0 10px 5px 0;\n color: var(--lightest-slate);\n }\n }\n }\n\n .project-links {\n display: flex;\n align-items: center;\n position: relative;\n margin-top: 10px;\n margin-left: -10px;\n color: var(--lightest-slate);\n\n a {\n ${({ theme }) => theme.mixins.flexCenter};\n padding: 10px;\n\n &.external {\n svg {\n width: 22px;\n height: 22px;\n margin-top: -4px;\n }\n }\n\n svg {\n width: 20px;\n height: 20px;\n }\n }\n\n .cta {\n ${({ theme }) => theme.mixins.smallButton};\n margin: 10px;\n }\n }\n\n .project-image {\n ${({ theme }) => theme.mixins.boxShadow};\n grid-column: 6 / -1;\n grid-row: 1 / -1;\n position: relative;\n z-index: 1;\n\n @media (max-width: 768px) {\n grid-column: 1 / -1;\n height: 100%;\n opacity: 0.25;\n }\n\n a {\n width: 100%;\n height: 100%;\n background-color: var(--green);\n border-radius: var(--border-radius);\n vertical-align: middle;\n\n &:hover,\n &:focus {\n background: transparent;\n outline: 0;\n\n &:before,\n .img {\n background: transparent;\n filter: none;\n }\n }\n\n &:before {\n content: '';\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n z-index: 3;\n transition: var(--transition);\n background-color: var(--navy);\n mix-blend-mode: screen;\n }\n }\n\n .img {\n border-radius: var(--border-radius);\n mix-blend-mode: multiply;\n filter: grayscale(100%) contrast(1) brightness(90%);\n\n @media (max-width: 768px) {\n object-fit: cover;\n width: auto;\n height: 100%;\n filter: grayscale(100%) contrast(1) brightness(50%);\n }\n }\n }\n`;\n\nconst Competitions = () => {\n const data = useStaticQuery(graphql`\n {\n featured: allMarkdownRemark(\n filter: { fileAbsolutePath: { regex: \"/content/competitions/\" } }\n sort: { fields: [frontmatter___date], order: ASC }\n ) {\n edges {\n node {\n frontmatter {\n title\n cover {\n childImageSharp {\n gatsbyImageData(width: 700, placeholder: BLURRED, formats: [AUTO, WEBP, AVIF])\n }\n }\n tech\n github\n external\n position\n }\n html\n }\n }\n }\n }\n `);\n\n const featuredProjects = data.featured.edges.filter(({ node }) => node);\n const revealTitle = useRef(null);\n const revealProjects = useRef([]);\n const prefersReducedMotion = usePrefersReducedMotion();\n\n useEffect(() => {\n if (prefersReducedMotion) {\n return;\n }\n\n sr.reveal(revealTitle.current, srConfig());\n revealProjects.current.forEach((ref, i) => sr.reveal(ref, srConfig(i * 100)));\n }, []);\n\n return (\n <section id=\"competitions\">\n <h2 className=\"numbered-heading\" ref={revealTitle}>\n Some Competitions I've Cracked\n </h2>\n\n <StyledProjectsGrid>\n {featuredProjects &&\n featuredProjects.map(({ node }, i) => {\n const { frontmatter, html } = node;\n const { external, title, tech, github, cover, position } = frontmatter;\n const image = getImage(cover);\n\n return (\n <StyledProject key={i} ref={el => (revealProjects.current[i] = el)}>\n <div className=\"project-content\">\n <div>\n <p className=\"project-overline\">{position}</p>\n\n <h3 className=\"project-title\">\n <a href={external}>{title}</a>\n </h3>\n\n <div\n className=\"project-description\"\n dangerouslySetInnerHTML={{ __html: html }}\n />\n\n {tech.length && (\n <ul className=\"project-tech-list\">\n {tech.map((tech, i) => (\n <li key={i}>{tech}</li>\n ))}\n </ul>\n )}\n\n <div className=\"project-links\">\n {github && (\n <a href={github} aria-label=\"GitHub Link\">\n <Icon name=\"GitHub\" />\n </a>\n )}\n {external && (\n <a href={external} aria-label=\"External Link\" className=\"external\">\n <Icon name=\"External\" />\n </a>\n )}\n </div>\n </div>\n </div>\n\n <div className=\"project-image\">\n <a href={external ? external : github ? github : '#'}>\n <GatsbyImage image={image} alt={title} className=\"img\" />\n </a>\n </div>\n </StyledProject>\n );\n })}\n </StyledProjectsGrid>\n </section>\n );\n};\n\nexport default Competitions;\n","module.exports = {\n email: 'sawradip0@gmail.com',\n\n socialMedia: [\n {\n name: 'GitHub',\n url: 'https://github.com/sawradip',\n },\n {\n name: 'Linkedin',\n url: 'https://www.linkedin.com/in/sawradip',\n },\n {\n name: 'Facebook',\n url: 'https://facebook.com/sawradip',\n },\n {\n name: 'Twitter',\n url: 'https://twitter.com/sawradip',\n },\n {\n name: 'StackOverflow',\n url: 'https://stackoverflow.com/users/13945920/sawradip-saha',\n },\n {\n name: 'Kaggle',\n url: 'https://www.kaggle.com/sawradipsaha',\n },\n ],\n\n navLinks: [\n {\n name: 'About',\n url: '/#about',\n },\n {\n name: 'Education',\n url: '/#education',\n },\n {\n name: 'Experience',\n url: '/#jobs',\n },\n {\n name: 'Competitions',\n url: '/#competitions',\n },\n // {\n // name: 'Project',\n // url: '/#projects',\n // },\n {\n name: 'Contact',\n url: '/#contact',\n },\n ],\n\n colors: {\n green: '#64ffda',\n navy: '#0a192f',\n darkNavy: '#020c1b',\n },\n\n srConfig: (delay = 200, viewFactor = 0.25) => ({\n origin: 'bottom',\n distance: '20px',\n duration: 500,\n delay,\n rotate: { x: 0, y: 0, z: 0 },\n opacity: 0,\n scale: 1,\n easing: 'cubic-bezier(0.645, 0.045, 0.355, 1)',\n mobile: true,\n reset: false,\n useDelay: 'always',\n viewFactor,\n viewOffset: { top: 0, right: 0, bottom: 0, left: 0 },\n }),\n};\n","import { useEffect } from 'react';\r\n\r\n// https://usehooks.com/useOnClickOutside/\r\n\r\nconst useOnClickOutside = (ref, handler) => {\r\n useEffect(\r\n () => {\r\n const listener = event => {\r\n // Do nothing if clicking ref's element or descendent elements\r\n if (!ref.current || ref.current.contains(event.target)) {\r\n return;\r\n }\r\n\r\n handler(event);\r\n };\r\n\r\n document.addEventListener('mousedown', listener);\r\n document.addEventListener('touchstart', listener);\r\n\r\n return () => {\r\n document.removeEventListener('mousedown', listener);\r\n document.removeEventListener('touchstart', listener);\r\n };\r\n },\r\n // Add ref and handler to effect dependencies\r\n // It's worth noting that because passed in handler is a new ...\r\n // ... function on every render that will cause this effect ...\r\n // ... callback/cleanup to run every render. It's not a big deal ...\r\n // ... but to optimize you can wrap handler in useCallback before ...\r\n // ... passing it into this hook.\r\n [ref, handler],\r\n );\r\n};\r\n\r\nexport default useOnClickOutside;\r\n","/**\r\n * https://www.joshwcomeau.com/snippets/react-hooks/use-prefers-reduced-motion/\r\n */\r\n\r\nimport { useState, useEffect } from 'react';\r\nconst QUERY = '(prefers-reduced-motion: no-preference)';\r\nconst isRenderingOnServer = typeof window === 'undefined';\r\n\r\nconst getInitialState = () =>\r\n // For our initial server render, we won't know if the user\r\n // prefers reduced motion, but it doesn't matter. This value\r\n // will be overwritten on the client, before any animations\r\n // occur.\r\n isRenderingOnServer ? true : !window.matchMedia(QUERY).matches;\r\nfunction usePrefersReducedMotion() {\r\n const [prefersReducedMotion, setPrefersReducedMotion] = useState(getInitialState);\r\n useEffect(() => {\r\n const mediaQueryList = window.matchMedia(QUERY);\r\n const listener = event => {\r\n setPrefersReducedMotion(!event.matches);\r\n };\r\n mediaQueryList.addListener(listener);\r\n return () => {\r\n mediaQueryList.removeListener(listener);\r\n };\r\n }, []);\r\n return prefersReducedMotion;\r\n}\r\n\r\nexport default usePrefersReducedMotion;\r\n","const SCROLL_UP = 'up';\r\nconst SCROLL_DOWN = 'down';\r\n\r\nimport { useState, useEffect } from 'react';\r\n\r\nconst useScrollDirection = ({ initialDirection, thresholdPixels, off } = {}) => {\r\n const [scrollDir, setScrollDir] = useState(initialDirection);\r\n\r\n useEffect(() => {\r\n const threshold = thresholdPixels || 0;\r\n let lastScrollY = window.pageYOffset;\r\n let ticking = false;\r\n\r\n const updateScrollDir = () => {\r\n const scrollY = window.pageYOffset;\r\n\r\n if (Math.abs(scrollY - lastScrollY) < threshold) {\r\n // We haven't exceeded the threshold\r\n ticking = false;\r\n return;\r\n }\r\n\r\n setScrollDir(scrollY > lastScrollY ? SCROLL_DOWN : SCROLL_UP);\r\n lastScrollY = scrollY > 0 ? scrollY : 0;\r\n ticking = false;\r\n };\r\n\r\n const onScroll = () => {\r\n if (!ticking) {\r\n window.requestAnimationFrame(updateScrollDir);\r\n ticking = true;\r\n }\r\n };\r\n\r\n /**\r\n * Bind the scroll handler if `off` is set to false.\r\n * If `off` is set to true reset the scroll direction.\r\n */\r\n !off ? window.addEventListener('scroll', onScroll) : setScrollDir(initialDirection);\r\n\r\n return () => window.removeEventListener('scroll', onScroll);\r\n }, [initialDirection, thresholdPixels, off]);\r\n\r\n return scrollDir;\r\n};\r\n\r\nexport default useScrollDirection;\r\n","export const hex2rgba = (hex, alpha = 1) => {\r\n const [r, g, b] = hex.match(/\\w\\w/g).map(x => parseInt(x, 16));\r\n return `rgba(${r},${g},${b},${alpha})`;\r\n};\r\n\r\nexport const navDelay = 1000;\r\nexport const loaderDelay = 2000;\r\n\r\nexport const KEY_CODES = {\r\n ARROW_LEFT: 'ArrowLeft',\r\n ARROW_LEFT_IE11: 'Left',\r\n ARROW_RIGHT: 'ArrowRight',\r\n ARROW_RIGHT_IE11: 'Right',\r\n ARROW_UP: 'ArrowUp',\r\n ARROW_UP_IE11: 'Up',\r\n ARROW_DOWN: 'ArrowDown',\r\n ARROW_DOWN_IE11: 'Down',\r\n ESCAPE: 'Escape',\r\n ESCAPE_IE11: 'Esc',\r\n TAB: 'Tab',\r\n SPACE: ' ',\r\n SPACE_IE11: 'Spacebar',\r\n ENTER: 'Enter',\r\n};\r\n","/*! @license is-dom-node v1.0.4\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nfunction isDomNode(x) {\n return typeof window.Node === 'object' ? x instanceof window.Node : x !== null && typeof x === 'object' && typeof x.nodeType === 'number' && typeof x.nodeName === 'string';\n}\nexport default isDomNode;","/*! @license is-dom-node-list v1.2.1\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nimport isDomNode from 'is-dom-node';\nfunction isDomNodeList(x) {\n var prototypeToString = Object.prototype.toString.call(x);\n var regex = /^\\[object (HTMLCollection|NodeList|Object)\\]$/;\n return typeof window.NodeList === 'object' ? x instanceof window.NodeList : x !== null && typeof x === 'object' && typeof x.length === 'number' && regex.test(prototypeToString) && (x.length === 0 || isDomNode(x[0]));\n}\nexport default isDomNodeList;","/*! @license Tealight v0.3.6\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nimport isDomNode from 'is-dom-node';\nimport isDomNodeList from 'is-dom-node-list';\nfunction tealight(target, context) {\n if (context === void 0) context = document;\n if (target instanceof Array) {\n return target.filter(isDomNode);\n }\n if (isDomNode(target)) {\n return [target];\n }\n if (isDomNodeList(target)) {\n return Array.prototype.slice.call(target);\n }\n if (typeof target === \"string\") {\n try {\n var query = context.querySelectorAll(target);\n return Array.prototype.slice.call(query);\n } catch (err) {\n return [];\n }\n }\n return [];\n}\nexport default tealight;","/*! @license Rematrix v0.3.0\n\n\tCopyright 2018 Julian Lloyd.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in\n\tall copies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n\tTHE SOFTWARE.\n*/\n/**\n * @module Rematrix\n */\n\n/**\n * Transformation matrices in the browser come in two flavors:\n *\n * - `matrix` using 6 values (short)\n * - `matrix3d` using 16 values (long)\n *\n * This utility follows this [conversion guide](https://goo.gl/EJlUQ1)\n * to expand short form matrices to their equivalent long form.\n *\n * @param {array} source - Accepts both short and long form matrices.\n * @return {array}\n */\nfunction format(source) {\n if (source.constructor !== Array) {\n throw new TypeError('Expected array.');\n }\n if (source.length === 16) {\n return source;\n }\n if (source.length === 6) {\n var matrix = identity();\n matrix[0] = source[0];\n matrix[1] = source[1];\n matrix[4] = source[2];\n matrix[5] = source[3];\n matrix[12] = source[4];\n matrix[13] = source[5];\n return matrix;\n }\n throw new RangeError('Expected array with either 6 or 16 values.');\n}\n\n/**\n * Returns a matrix representing no transformation. The product of any matrix\n * multiplied by the identity matrix will be the original matrix.\n *\n * > **Tip:** Similar to how `5 * 1 === 5`, where `1` is the identity.\n *\n * @return {array}\n */\nfunction identity() {\n var matrix = [];\n for (var i = 0; i < 16; i++) {\n i % 5 == 0 ? matrix.push(1) : matrix.push(0);\n }\n return matrix;\n}\n\n/**\n * Returns a matrix describing the inverse transformation of the source\n * matrix. The product of any matrix multiplied by its inverse will be the\n * identity matrix.\n *\n * > **Tip:** Similar to how `5 * (1/5) === 1`, where `1/5` is the inverse.\n *\n * @param {array} source - Accepts both short and long form matrices.\n * @return {array}\n */\nfunction inverse(source) {\n var m = format(source);\n var s0 = m[0] * m[5] - m[4] * m[1];\n var s1 = m[0] * m[6] - m[4] * m[2];\n var s2 = m[0] * m[7] - m[4] * m[3];\n var s3 = m[1] * m[6] - m[5] * m[2];\n var s4 = m[1] * m[7] - m[5] * m[3];\n var s5 = m[2] * m[7] - m[6] * m[3];\n var c5 = m[10] * m[15] - m[14] * m[11];\n var c4 = m[9] * m[15] - m[13] * m[11];\n var c3 = m[9] * m[14] - m[13] * m[10];\n var c2 = m[8] * m[15] - m[12] * m[11];\n var c1 = m[8] * m[14] - m[12] * m[10];\n var c0 = m[8] * m[13] - m[12] * m[9];\n var determinant = 1 / (s0 * c5 - s1 * c4 + s2 * c3 + s3 * c2 - s4 * c1 + s5 * c0);\n if (isNaN(determinant) || determinant === Infinity) {\n throw new Error('Inverse determinant attempted to divide by zero.');\n }\n return [(m[5] * c5 - m[6] * c4 + m[7] * c3) * determinant, (-m[1] * c5 + m[2] * c4 - m[3] * c3) * determinant, (m[13] * s5 - m[14] * s4 + m[15] * s3) * determinant, (-m[9] * s5 + m[10] * s4 - m[11] * s3) * determinant, (-m[4] * c5 + m[6] * c2 - m[7] * c1) * determinant, (m[0] * c5 - m[2] * c2 + m[3] * c1) * determinant, (-m[12] * s5 + m[14] * s2 - m[15] * s1) * determinant, (m[8] * s5 - m[10] * s2 + m[11] * s1) * determinant, (m[4] * c4 - m[5] * c2 + m[7] * c0) * determinant, (-m[0] * c4 + m[1] * c2 - m[3] * c0) * determinant, (m[12] * s4 - m[13] * s2 + m[15] * s0) * determinant, (-m[8] * s4 + m[9] * s2 - m[11] * s0) * determinant, (-m[4] * c3 + m[5] * c1 - m[6] * c0) * determinant, (m[0] * c3 - m[1] * c1 + m[2] * c0) * determinant, (-m[12] * s3 + m[13] * s1 - m[14] * s0) * determinant, (m[8] * s3 - m[9] * s1 + m[10] * s0) * determinant];\n}\n\n/**\n * Returns a 4x4 matrix describing the combined transformations\n * of both arguments.\n *\n * > **Note:** Order is very important. For example, rotating 45°\n * along the Z-axis, followed by translating 500 pixels along the\n * Y-axis... is not the same as translating 500 pixels along the\n * Y-axis, followed by rotating 45° along on the Z-axis.\n *\n * @param {array} m - Accepts both short and long form matrices.\n * @param {array} x - Accepts both short and long form matrices.\n * @return {array}\n */\nfunction multiply(m, x) {\n var fm = format(m);\n var fx = format(x);\n var product = [];\n for (var i = 0; i < 4; i++) {\n var row = [fm[i], fm[i + 4], fm[i + 8], fm[i + 12]];\n for (var j = 0; j < 4; j++) {\n var k = j * 4;\n var col = [fx[k], fx[k + 1], fx[k + 2], fx[k + 3]];\n var result = row[0] * col[0] + row[1] * col[1] + row[2] * col[2] + row[3] * col[3];\n product[i + k] = result;\n }\n }\n return product;\n}\n\n/**\n * Attempts to return a 4x4 matrix describing the CSS transform\n * matrix passed in, but will return the identity matrix as a\n * fallback.\n *\n * > **Tip:** This method is used to convert a CSS matrix (retrieved as a\n * `string` from computed styles) to its equivalent array format.\n *\n * @param {string} source - `matrix` or `matrix3d` CSS Transform value.\n * @return {array}\n */\nfunction parse(source) {\n if (typeof source === 'string') {\n var match = source.match(/matrix(3d)?\\(([^)]+)\\)/);\n if (match) {\n var raw = match[2].split(', ').map(parseFloat);\n return format(raw);\n }\n }\n return identity();\n}\n\n/**\n * Returns a 4x4 matrix describing Z-axis rotation.\n *\n * > **Tip:** This is just an alias for `Rematrix.rotateZ` for parity with CSS\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\nfunction rotate(angle) {\n return rotateZ(angle);\n}\n\n/**\n * Returns a 4x4 matrix describing X-axis rotation.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\nfunction rotateX(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[5] = matrix[10] = Math.cos(theta);\n matrix[6] = matrix[9] = Math.sin(theta);\n matrix[9] *= -1;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Y-axis rotation.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\nfunction rotateY(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[0] = matrix[10] = Math.cos(theta);\n matrix[2] = matrix[8] = Math.sin(theta);\n matrix[2] *= -1;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Z-axis rotation.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\nfunction rotateZ(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[0] = matrix[5] = Math.cos(theta);\n matrix[1] = matrix[4] = Math.sin(theta);\n matrix[4] *= -1;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing 2D scaling. The first argument\n * is used for both X and Y-axis scaling, unless an optional\n * second argument is provided to explicitly define Y-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @param {number} [scalarY] - Decimal multiplier.\n * @return {array}\n */\nfunction scale(scalar, scalarY) {\n var matrix = identity();\n matrix[0] = scalar;\n matrix[5] = typeof scalarY === 'number' ? scalarY : scalar;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing X-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @return {array}\n */\nfunction scaleX(scalar) {\n var matrix = identity();\n matrix[0] = scalar;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Y-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @return {array}\n */\nfunction scaleY(scalar) {\n var matrix = identity();\n matrix[5] = scalar;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Z-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @return {array}\n */\nfunction scaleZ(scalar) {\n var matrix = identity();\n matrix[10] = scalar;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing shear. The first argument\n * defines X-axis shearing, and an optional second argument\n * defines Y-axis shearing.\n *\n * @param {number} angleX - Measured in degrees.\n * @param {number} [angleY] - Measured in degrees.\n * @return {array}\n */\nfunction skew(angleX, angleY) {\n var thetaX = Math.PI / 180 * angleX;\n var matrix = identity();\n matrix[4] = Math.tan(thetaX);\n if (angleY) {\n var thetaY = Math.PI / 180 * angleY;\n matrix[1] = Math.tan(thetaY);\n }\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing X-axis shear.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\nfunction skewX(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[4] = Math.tan(theta);\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Y-axis shear.\n *\n * @param {number} angle - Measured in degrees\n * @return {array}\n */\nfunction skewY(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[1] = Math.tan(theta);\n return matrix;\n}\n\n/**\n * Returns a CSS Transform property value equivalent to the source matrix.\n *\n * @param {array} source - Accepts both short and long form matrices.\n * @return {string}\n */\nfunction toString(source) {\n return \"matrix3d(\" + format(source).join(', ') + \")\";\n}\n\n/**\n * Returns a 4x4 matrix describing 2D translation. The first\n * argument defines X-axis translation, and an optional second\n * argument defines Y-axis translation.\n *\n * @param {number} distanceX - Measured in pixels.\n * @param {number} [distanceY] - Measured in pixels.\n * @return {array}\n */\nfunction translate(distanceX, distanceY) {\n var matrix = identity();\n matrix[12] = distanceX;\n if (distanceY) {\n matrix[13] = distanceY;\n }\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing X-axis translation.\n *\n * @param {number} distance - Measured in pixels.\n * @return {array}\n */\nfunction translateX(distance) {\n var matrix = identity();\n matrix[12] = distance;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Y-axis translation.\n *\n * @param {number} distance - Measured in pixels.\n * @return {array}\n */\nfunction translateY(distance) {\n var matrix = identity();\n matrix[13] = distance;\n return matrix;\n}\n\n/**\n * Returns a 4x4 matrix describing Z-axis translation.\n *\n * @param {number} distance - Measured in pixels.\n * @return {array}\n */\nfunction translateZ(distance) {\n var matrix = identity();\n matrix[14] = distance;\n return matrix;\n}\nexport { format, identity, inverse, multiply, parse, rotate, rotateX, rotateY, rotateZ, scale, scaleX, scaleY, scaleZ, skew, skewX, skewY, toString, translate, translateX, translateY, translateZ };","/*! @license miniraf v1.0.0\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nvar polyfill = function () {\n var clock = Date.now();\n return function (callback) {\n var currentTime = Date.now();\n if (currentTime - clock > 16) {\n clock = currentTime;\n callback(currentTime);\n } else {\n setTimeout(function () {\n return polyfill(callback);\n }, 0);\n }\n };\n}();\nvar index = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || polyfill;\nexport default index;","/*! @license ScrollReveal v4.0.9\n\n\tCopyright 2021 Fisssion LLC.\n\n\tLicensed under the GNU General Public License 3.0 for\n\tcompatible open source projects and non-commercial use.\n\n\tFor commercial sites, themes, projects, and applications,\n\tkeep your source code private/proprietary by purchasing\n\ta commercial license from https://scrollrevealjs.org/\n*/\nimport $ from 'tealight';\nimport { translateY, translateX, rotateX, rotateY, rotateZ, scale, parse, multiply } from 'rematrix';\nimport raf from 'miniraf';\nvar defaults = {\n delay: 0,\n distance: '0',\n duration: 600,\n easing: 'cubic-bezier(0.5, 0, 0, 1)',\n interval: 0,\n opacity: 0,\n origin: 'bottom',\n rotate: {\n x: 0,\n y: 0,\n z: 0\n },\n scale: 1,\n cleanup: false,\n container: document.documentElement,\n desktop: true,\n mobile: true,\n reset: false,\n useDelay: 'always',\n viewFactor: 0.0,\n viewOffset: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n },\n afterReset: function afterReset() {},\n afterReveal: function afterReveal() {},\n beforeReset: function beforeReset() {},\n beforeReveal: function beforeReveal() {}\n};\nfunction failure() {\n document.documentElement.classList.remove('sr');\n return {\n clean: function clean() {},\n destroy: function destroy() {},\n reveal: function reveal() {},\n sync: function sync() {},\n get noop() {\n return true;\n }\n };\n}\nfunction success() {\n document.documentElement.classList.add('sr');\n if (document.body) {\n document.body.style.height = '100%';\n } else {\n document.addEventListener('DOMContentLoaded', function () {\n document.body.style.height = '100%';\n });\n }\n}\nvar mount = {\n success: success,\n failure: failure\n};\nfunction isObject(x) {\n return x !== null && x instanceof Object && (x.constructor === Object || Object.prototype.toString.call(x) === '[object Object]');\n}\nfunction each(collection, callback) {\n if (isObject(collection)) {\n var keys = Object.keys(collection);\n return keys.forEach(function (key) {\n return callback(collection[key], key, collection);\n });\n }\n if (collection instanceof Array) {\n return collection.forEach(function (item, i) {\n return callback(item, i, collection);\n });\n }\n throw new TypeError('Expected either an array or object literal.');\n}\nfunction logger(message) {\n var details = [],\n len = arguments.length - 1;\n while (len-- > 0) details[len] = arguments[len + 1];\n if (this.constructor.debug && console) {\n var report = \"%cScrollReveal: \" + message;\n details.forEach(function (detail) {\n return report += \"\\n — \" + detail;\n });\n console.log(report, 'color: #ea654b;'); // eslint-disable-line no-console\n }\n}\n\nfunction rinse() {\n var this$1 = this;\n var struct = function struct() {\n return {\n active: [],\n stale: []\n };\n };\n var elementIds = struct();\n var sequenceIds = struct();\n var containerIds = struct();\n\n /**\n * Take stock of active element IDs.\n */\n try {\n each($('[data-sr-id]'), function (node) {\n var id = parseInt(node.getAttribute('data-sr-id'));\n elementIds.active.push(id);\n });\n } catch (e) {\n throw e;\n }\n /**\n * Destroy stale elements.\n */\n each(this.store.elements, function (element) {\n if (elementIds.active.indexOf(element.id) === -1) {\n elementIds.stale.push(element.id);\n }\n });\n each(elementIds.stale, function (staleId) {\n return delete this$1.store.elements[staleId];\n });\n\n /**\n * Take stock of active container and sequence IDs.\n */\n each(this.store.elements, function (element) {\n if (containerIds.active.indexOf(element.containerId) === -1) {\n containerIds.active.push(element.containerId);\n }\n if (element.hasOwnProperty('sequence')) {\n if (sequenceIds.active.indexOf(element.sequence.id) === -1) {\n sequenceIds.active.push(element.sequence.id);\n }\n }\n });\n\n /**\n * Destroy stale containers.\n */\n each(this.store.containers, function (container) {\n if (containerIds.active.indexOf(container.id) === -1) {\n containerIds.stale.push(container.id);\n }\n });\n each(containerIds.stale, function (staleId) {\n var stale = this$1.store.containers[staleId].node;\n stale.removeEventListener('scroll', this$1.delegate);\n stale.removeEventListener('resize', this$1.delegate);\n delete this$1.store.containers[staleId];\n });\n\n /**\n * Destroy stale sequences.\n */\n each(this.store.sequences, function (sequence) {\n if (sequenceIds.active.indexOf(sequence.id) === -1) {\n sequenceIds.stale.push(sequence.id);\n }\n });\n each(sequenceIds.stale, function (staleId) {\n return delete this$1.store.sequences[staleId];\n });\n}\nvar getPrefixedCssProp = function () {\n var properties = {};\n var style = document.documentElement.style;\n function getPrefixedCssProperty(name, source) {\n if (source === void 0) source = style;\n if (name && typeof name === 'string') {\n if (properties[name]) {\n return properties[name];\n }\n if (typeof source[name] === 'string') {\n return properties[name] = name;\n }\n if (typeof source[\"-webkit-\" + name] === 'string') {\n return properties[name] = \"-webkit-\" + name;\n }\n throw new RangeError(\"Unable to find \\\"\" + name + \"\\\" style property.\");\n }\n throw new TypeError('Expected a string.');\n }\n getPrefixedCssProperty.clearCache = function () {\n return properties = {};\n };\n return getPrefixedCssProperty;\n}();\nfunction style(element) {\n var computed = window.getComputedStyle(element.node);\n var position = computed.position;\n var config = element.config;\n\n /**\n * Generate inline styles\n */\n var inline = {};\n var inlineStyle = element.node.getAttribute('style') || '';\n var inlineMatch = inlineStyle.match(/[\\w-]+\\s*:\\s*[^;]+\\s*/gi) || [];\n inline.computed = inlineMatch ? inlineMatch.map(function (m) {\n return m.trim();\n }).join('; ') + ';' : '';\n inline.generated = inlineMatch.some(function (m) {\n return m.match(/visibility\\s?:\\s?visible/i);\n }) ? inline.computed : inlineMatch.concat(['visibility: visible']).map(function (m) {\n return m.trim();\n }).join('; ') + ';';\n\n /**\n * Generate opacity styles\n */\n var computedOpacity = parseFloat(computed.opacity);\n var configOpacity = !isNaN(parseFloat(config.opacity)) ? parseFloat(config.opacity) : parseFloat(computed.opacity);\n var opacity = {\n computed: computedOpacity !== configOpacity ? \"opacity: \" + computedOpacity + \";\" : '',\n generated: computedOpacity !== configOpacity ? \"opacity: \" + configOpacity + \";\" : ''\n };\n\n /**\n * Generate transformation styles\n */\n var transformations = [];\n if (parseFloat(config.distance)) {\n var axis = config.origin === 'top' || config.origin === 'bottom' ? 'Y' : 'X';\n\n /**\n * Let’s make sure our our pixel distances are negative for top and left.\n * e.g. { origin: 'top', distance: '25px' } starts at `top: -25px` in CSS.\n */\n var distance = config.distance;\n if (config.origin === 'top' || config.origin === 'left') {\n distance = /^-/.test(distance) ? distance.substr(1) : \"-\" + distance;\n }\n var ref = distance.match(/(^-?\\d+\\.?\\d?)|(em$|px$|%$)/g);\n var value = ref[0];\n var unit = ref[1];\n switch (unit) {\n case 'em':\n distance = parseInt(computed.fontSize) * value;\n break;\n case 'px':\n distance = value;\n break;\n case '%':\n /**\n * Here we use `getBoundingClientRect` instead of\n * the existing data attached to `element.geometry`\n * because only the former includes any transformations\n * current applied to the element.\n *\n * If that behavior ends up being unintuitive, this\n * logic could instead utilize `element.geometry.height`\n * and `element.geoemetry.width` for the distance calculation\n */\n distance = axis === 'Y' ? element.node.getBoundingClientRect().height * value / 100 : element.node.getBoundingClientRect().width * value / 100;\n break;\n default:\n throw new RangeError('Unrecognized or missing distance unit.');\n }\n if (axis === 'Y') {\n transformations.push(translateY(distance));\n } else {\n transformations.push(translateX(distance));\n }\n }\n if (config.rotate.x) {\n transformations.push(rotateX(config.rotate.x));\n }\n if (config.rotate.y) {\n transformations.push(rotateY(config.rotate.y));\n }\n if (config.rotate.z) {\n transformations.push(rotateZ(config.rotate.z));\n }\n if (config.scale !== 1) {\n if (config.scale === 0) {\n /**\n * The CSS Transforms matrix interpolation specification\n * basically disallows transitions of non-invertible\n * matrixes, which means browsers won't transition\n * elements with zero scale.\n *\n * That’s inconvenient for the API and developer\n * experience, so we simply nudge their value\n * slightly above zero; this allows browsers\n * to transition our element as expected.\n *\n * `0.0002` was the smallest number\n * that performed across browsers.\n */\n transformations.push(scale(0.0002));\n } else {\n transformations.push(scale(config.scale));\n }\n }\n var transform = {};\n if (transformations.length) {\n transform.property = getPrefixedCssProp('transform');\n /**\n * The default computed transform value should be one of:\n * undefined || 'none' || 'matrix()' || 'matrix3d()'\n */\n transform.computed = {\n raw: computed[transform.property],\n matrix: parse(computed[transform.property])\n };\n transformations.unshift(transform.computed.matrix);\n var product = transformations.reduce(multiply);\n transform.generated = {\n initial: transform.property + \": matrix3d(\" + product.join(', ') + \");\",\n final: transform.property + \": matrix3d(\" + transform.computed.matrix.join(', ') + \");\"\n };\n } else {\n transform.generated = {\n initial: '',\n final: ''\n };\n }\n\n /**\n * Generate transition styles\n */\n var transition = {};\n if (opacity.generated || transform.generated.initial) {\n transition.property = getPrefixedCssProp('transition');\n transition.computed = computed[transition.property];\n transition.fragments = [];\n var delay = config.delay;\n var duration = config.duration;\n var easing = config.easing;\n if (opacity.generated) {\n transition.fragments.push({\n delayed: \"opacity \" + duration / 1000 + \"s \" + easing + \" \" + delay / 1000 + \"s\",\n instant: \"opacity \" + duration / 1000 + \"s \" + easing + \" 0s\"\n });\n }\n if (transform.generated.initial) {\n transition.fragments.push({\n delayed: transform.property + \" \" + duration / 1000 + \"s \" + easing + \" \" + delay / 1000 + \"s\",\n instant: transform.property + \" \" + duration / 1000 + \"s \" + easing + \" 0s\"\n });\n }\n\n /**\n * The default computed transition property should be undefined, or one of:\n * '' || 'none 0s ease 0s' || 'all 0s ease 0s' || 'all 0s 0s cubic-bezier()'\n */\n var hasCustomTransition = transition.computed && !transition.computed.match(/all 0s|none 0s/);\n if (hasCustomTransition) {\n transition.fragments.unshift({\n delayed: transition.computed,\n instant: transition.computed\n });\n }\n var composed = transition.fragments.reduce(function (composition, fragment, i) {\n composition.delayed += i === 0 ? fragment.delayed : \", \" + fragment.delayed;\n composition.instant += i === 0 ? fragment.instant : \", \" + fragment.instant;\n return composition;\n }, {\n delayed: '',\n instant: ''\n });\n transition.generated = {\n delayed: transition.property + \": \" + composed.delayed + \";\",\n instant: transition.property + \": \" + composed.instant + \";\"\n };\n } else {\n transition.generated = {\n delayed: '',\n instant: ''\n };\n }\n return {\n inline: inline,\n opacity: opacity,\n position: position,\n transform: transform,\n transition: transition\n };\n}\n\n/**\n * apply a CSS string to an element using the CSSOM (element.style) rather\n * than setAttribute, which may violate the content security policy.\n *\n * @param {Node} [el] Element to receive styles.\n * @param {string} [declaration] Styles to apply.\n */\nfunction applyStyle(el, declaration) {\n declaration.split(';').forEach(function (pair) {\n var ref = pair.split(':');\n var property = ref[0];\n var value = ref.slice(1);\n if (property && value) {\n el.style[property.trim()] = value.join(':');\n }\n });\n}\nfunction clean(target) {\n var this$1 = this;\n var dirty;\n try {\n each($(target), function (node) {\n var id = node.getAttribute('data-sr-id');\n if (id !== null) {\n dirty = true;\n var element = this$1.store.elements[id];\n if (element.callbackTimer) {\n window.clearTimeout(element.callbackTimer.clock);\n }\n applyStyle(element.node, element.styles.inline.generated);\n node.removeAttribute('data-sr-id');\n delete this$1.store.elements[id];\n }\n });\n } catch (e) {\n return logger.call(this, 'Clean failed.', e.message);\n }\n if (dirty) {\n try {\n rinse.call(this);\n } catch (e) {\n return logger.call(this, 'Clean failed.', e.message);\n }\n }\n}\nfunction destroy() {\n var this$1 = this;\n\n /**\n * Remove all generated styles and element ids\n */\n each(this.store.elements, function (element) {\n applyStyle(element.node, element.styles.inline.generated);\n element.node.removeAttribute('data-sr-id');\n });\n\n /**\n * Remove all event listeners.\n */\n each(this.store.containers, function (container) {\n var target = container.node === document.documentElement ? window : container.node;\n target.removeEventListener('scroll', this$1.delegate);\n target.removeEventListener('resize', this$1.delegate);\n });\n\n /**\n * Clear all data from the store\n */\n this.store = {\n containers: {},\n elements: {},\n history: [],\n sequences: {}\n };\n}\nfunction deepAssign(target) {\n var sources = [],\n len = arguments.length - 1;\n while (len-- > 0) sources[len] = arguments[len + 1];\n if (isObject(target)) {\n each(sources, function (source) {\n each(source, function (data, key) {\n if (isObject(data)) {\n if (!target[key] || !isObject(target[key])) {\n target[key] = {};\n }\n deepAssign(target[key], data);\n } else {\n target[key] = data;\n }\n });\n });\n return target;\n } else {\n throw new TypeError('Target must be an object literal.');\n }\n}\nfunction isMobile(agent) {\n if (agent === void 0) agent = navigator.userAgent;\n return /Android|iPhone|iPad|iPod/i.test(agent);\n}\nvar nextUniqueId = function () {\n var uid = 0;\n return function () {\n return uid++;\n };\n}();\nfunction initialize() {\n var this$1 = this;\n rinse.call(this);\n each(this.store.elements, function (element) {\n var styles = [element.styles.inline.generated];\n if (element.visible) {\n styles.push(element.styles.opacity.computed);\n styles.push(element.styles.transform.generated.final);\n element.revealed = true;\n } else {\n styles.push(element.styles.opacity.generated);\n styles.push(element.styles.transform.generated.initial);\n element.revealed = false;\n }\n applyStyle(element.node, styles.filter(function (s) {\n return s !== '';\n }).join(' '));\n });\n each(this.store.containers, function (container) {\n var target = container.node === document.documentElement ? window : container.node;\n target.addEventListener('scroll', this$1.delegate);\n target.addEventListener('resize', this$1.delegate);\n });\n\n /**\n * Manually invoke delegate once to capture\n * element and container dimensions, container\n * scroll position, and trigger any valid reveals\n */\n this.delegate();\n\n /**\n * Wipe any existing `setTimeout` now\n * that initialization has completed.\n */\n this.initTimeout = null;\n}\nfunction animate(element, force) {\n if (force === void 0) force = {};\n var pristine = force.pristine || this.pristine;\n var delayed = element.config.useDelay === 'always' || element.config.useDelay === 'onload' && pristine || element.config.useDelay === 'once' && !element.seen;\n var shouldReveal = element.visible && !element.revealed;\n var shouldReset = !element.visible && element.revealed && element.config.reset;\n if (force.reveal || shouldReveal) {\n return triggerReveal.call(this, element, delayed);\n }\n if (force.reset || shouldReset) {\n return triggerReset.call(this, element);\n }\n}\nfunction triggerReveal(element, delayed) {\n var styles = [element.styles.inline.generated, element.styles.opacity.computed, element.styles.transform.generated.final];\n if (delayed) {\n styles.push(element.styles.transition.generated.delayed);\n } else {\n styles.push(element.styles.transition.generated.instant);\n }\n element.revealed = element.seen = true;\n applyStyle(element.node, styles.filter(function (s) {\n return s !== '';\n }).join(' '));\n registerCallbacks.call(this, element, delayed);\n}\nfunction triggerReset(element) {\n var styles = [element.styles.inline.generated, element.styles.opacity.generated, element.styles.transform.generated.initial, element.styles.transition.generated.instant];\n element.revealed = false;\n applyStyle(element.node, styles.filter(function (s) {\n return s !== '';\n }).join(' '));\n registerCallbacks.call(this, element);\n}\nfunction registerCallbacks(element, isDelayed) {\n var this$1 = this;\n var duration = isDelayed ? element.config.duration + element.config.delay : element.config.duration;\n var beforeCallback = element.revealed ? element.config.beforeReveal : element.config.beforeReset;\n var afterCallback = element.revealed ? element.config.afterReveal : element.config.afterReset;\n var elapsed = 0;\n if (element.callbackTimer) {\n elapsed = Date.now() - element.callbackTimer.start;\n window.clearTimeout(element.callbackTimer.clock);\n }\n beforeCallback(element.node);\n element.callbackTimer = {\n start: Date.now(),\n clock: window.setTimeout(function () {\n afterCallback(element.node);\n element.callbackTimer = null;\n if (element.revealed && !element.config.reset && element.config.cleanup) {\n clean.call(this$1, element.node);\n }\n }, duration - elapsed)\n };\n}\nfunction sequence(element, pristine) {\n if (pristine === void 0) pristine = this.pristine;\n\n /**\n * We first check if the element should reset.\n */\n if (!element.visible && element.revealed && element.config.reset) {\n return animate.call(this, element, {\n reset: true\n });\n }\n var seq = this.store.sequences[element.sequence.id];\n var i = element.sequence.index;\n if (seq) {\n var visible = new SequenceModel(seq, 'visible', this.store);\n var revealed = new SequenceModel(seq, 'revealed', this.store);\n seq.models = {\n visible: visible,\n revealed: revealed\n };\n\n /**\n * If the sequence has no revealed members,\n * then we reveal the first visible element\n * within that sequence.\n *\n * The sequence then cues a recursive call\n * in both directions.\n */\n if (!revealed.body.length) {\n var nextId = seq.members[visible.body[0]];\n var nextElement = this.store.elements[nextId];\n if (nextElement) {\n cue.call(this, seq, visible.body[0], -1, pristine);\n cue.call(this, seq, visible.body[0], +1, pristine);\n return animate.call(this, nextElement, {\n reveal: true,\n pristine: pristine\n });\n }\n }\n\n /**\n * If our element isn’t resetting, we check the\n * element sequence index against the head, and\n * then the foot of the sequence.\n */\n if (!seq.blocked.head && i === [].concat(revealed.head).pop() && i >= [].concat(visible.body).shift()) {\n cue.call(this, seq, i, -1, pristine);\n return animate.call(this, element, {\n reveal: true,\n pristine: pristine\n });\n }\n if (!seq.blocked.foot && i === [].concat(revealed.foot).shift() && i <= [].concat(visible.body).pop()) {\n cue.call(this, seq, i, +1, pristine);\n return animate.call(this, element, {\n reveal: true,\n pristine: pristine\n });\n }\n }\n}\nfunction Sequence(interval) {\n var i = Math.abs(interval);\n if (!isNaN(i)) {\n this.id = nextUniqueId();\n this.interval = Math.max(i, 16);\n this.members = [];\n this.models = {};\n this.blocked = {\n head: false,\n foot: false\n };\n } else {\n throw new RangeError('Invalid sequence interval.');\n }\n}\nfunction SequenceModel(seq, prop, store) {\n var this$1 = this;\n this.head = [];\n this.body = [];\n this.foot = [];\n each(seq.members, function (id, index) {\n var element = store.elements[id];\n if (element && element[prop]) {\n this$1.body.push(index);\n }\n });\n if (this.body.length) {\n each(seq.members, function (id, index) {\n var element = store.elements[id];\n if (element && !element[prop]) {\n if (index < this$1.body[0]) {\n this$1.head.push(index);\n } else {\n this$1.foot.push(index);\n }\n }\n });\n }\n}\nfunction cue(seq, i, direction, pristine) {\n var this$1 = this;\n var blocked = ['head', null, 'foot'][1 + direction];\n var nextId = seq.members[i + direction];\n var nextElement = this.store.elements[nextId];\n seq.blocked[blocked] = true;\n setTimeout(function () {\n seq.blocked[blocked] = false;\n if (nextElement) {\n sequence.call(this$1, nextElement, pristine);\n }\n }, seq.interval);\n}\nfunction reveal(target, options, syncing) {\n var this$1 = this;\n if (options === void 0) options = {};\n if (syncing === void 0) syncing = false;\n var containerBuffer = [];\n var sequence$$1;\n var interval = options.interval || defaults.interval;\n try {\n if (interval) {\n sequence$$1 = new Sequence(interval);\n }\n var nodes = $(target);\n if (!nodes.length) {\n throw new Error('Invalid reveal target.');\n }\n var elements = nodes.reduce(function (elementBuffer, elementNode) {\n var element = {};\n var existingId = elementNode.getAttribute('data-sr-id');\n if (existingId) {\n deepAssign(element, this$1.store.elements[existingId]);\n\n /**\n * In order to prevent previously generated styles\n * from throwing off the new styles, the style tag\n * has to be reverted to its pre-reveal state.\n */\n applyStyle(element.node, element.styles.inline.computed);\n } else {\n element.id = nextUniqueId();\n element.node = elementNode;\n element.seen = false;\n element.revealed = false;\n element.visible = false;\n }\n var config = deepAssign({}, element.config || this$1.defaults, options);\n if (!config.mobile && isMobile() || !config.desktop && !isMobile()) {\n if (existingId) {\n clean.call(this$1, element);\n }\n return elementBuffer; // skip elements that are disabled\n }\n\n var containerNode = $(config.container)[0];\n if (!containerNode) {\n throw new Error('Invalid container.');\n }\n if (!containerNode.contains(elementNode)) {\n return elementBuffer; // skip elements found outside the container\n }\n\n var containerId;\n {\n containerId = getContainerId(containerNode, containerBuffer, this$1.store.containers);\n if (containerId === null) {\n containerId = nextUniqueId();\n containerBuffer.push({\n id: containerId,\n node: containerNode\n });\n }\n }\n element.config = config;\n element.containerId = containerId;\n element.styles = style(element);\n if (sequence$$1) {\n element.sequence = {\n id: sequence$$1.id,\n index: sequence$$1.members.length\n };\n sequence$$1.members.push(element.id);\n }\n elementBuffer.push(element);\n return elementBuffer;\n }, []);\n\n /**\n * Modifying the DOM via setAttribute needs to be handled\n * separately from reading computed styles in the map above\n * for the browser to batch DOM changes (limiting reflows)\n */\n each(elements, function (element) {\n this$1.store.elements[element.id] = element;\n element.node.setAttribute('data-sr-id', element.id);\n });\n } catch (e) {\n return logger.call(this, 'Reveal failed.', e.message);\n }\n\n /**\n * Now that element set-up is complete...\n * Let’s commit any container and sequence data we have to the store.\n */\n each(containerBuffer, function (container) {\n this$1.store.containers[container.id] = {\n id: container.id,\n node: container.node\n };\n });\n if (sequence$$1) {\n this.store.sequences[sequence$$1.id] = sequence$$1;\n }\n\n /**\n * If reveal wasn't invoked by sync, we want to\n * make sure to add this call to the history.\n */\n if (syncing !== true) {\n this.store.history.push({\n target: target,\n options: options\n });\n\n /**\n * Push initialization to the event queue, giving\n * multiple reveal calls time to be interpreted.\n */\n if (this.initTimeout) {\n window.clearTimeout(this.initTimeout);\n }\n this.initTimeout = window.setTimeout(initialize.bind(this), 0);\n }\n}\nfunction getContainerId(node) {\n var collections = [],\n len = arguments.length - 1;\n while (len-- > 0) collections[len] = arguments[len + 1];\n var id = null;\n each(collections, function (collection) {\n each(collection, function (container) {\n if (id === null && container.node === node) {\n id = container.id;\n }\n });\n });\n return id;\n}\n\n/**\n * Re-runs the reveal method for each record stored in history,\n * for capturing new content asynchronously loaded into the DOM.\n */\nfunction sync() {\n var this$1 = this;\n each(this.store.history, function (record) {\n reveal.call(this$1, record.target, record.options, true);\n });\n initialize.call(this);\n}\nvar polyfill = function polyfill(x) {\n return (x > 0) - (x < 0) || +x;\n};\nvar mathSign = Math.sign || polyfill;\nfunction getGeometry(target, isContainer) {\n /**\n * We want to ignore padding and scrollbars for container elements.\n * More information here: https://goo.gl/vOZpbz\n */\n var height = isContainer ? target.node.clientHeight : target.node.offsetHeight;\n var width = isContainer ? target.node.clientWidth : target.node.offsetWidth;\n var offsetTop = 0;\n var offsetLeft = 0;\n var node = target.node;\n do {\n if (!isNaN(node.offsetTop)) {\n offsetTop += node.offsetTop;\n }\n if (!isNaN(node.offsetLeft)) {\n offsetLeft += node.offsetLeft;\n }\n node = node.offsetParent;\n } while (node);\n return {\n bounds: {\n top: offsetTop,\n right: offsetLeft + width,\n bottom: offsetTop + height,\n left: offsetLeft\n },\n height: height,\n width: width\n };\n}\nfunction getScrolled(container) {\n var top, left;\n if (container.node === document.documentElement) {\n top = window.pageYOffset;\n left = window.pageXOffset;\n } else {\n top = container.node.scrollTop;\n left = container.node.scrollLeft;\n }\n return {\n top: top,\n left: left\n };\n}\nfunction isElementVisible(element) {\n if (element === void 0) element = {};\n var container = this.store.containers[element.containerId];\n if (!container) {\n return;\n }\n var viewFactor = Math.max(0, Math.min(1, element.config.viewFactor));\n var viewOffset = element.config.viewOffset;\n var elementBounds = {\n top: element.geometry.bounds.top + element.geometry.height * viewFactor,\n right: element.geometry.bounds.right - element.geometry.width * viewFactor,\n bottom: element.geometry.bounds.bottom - element.geometry.height * viewFactor,\n left: element.geometry.bounds.left + element.geometry.width * viewFactor\n };\n var containerBounds = {\n top: container.geometry.bounds.top + container.scroll.top + viewOffset.top,\n right: container.geometry.bounds.right + container.scroll.left - viewOffset.right,\n bottom: container.geometry.bounds.bottom + container.scroll.top - viewOffset.bottom,\n left: container.geometry.bounds.left + container.scroll.left + viewOffset.left\n };\n return elementBounds.top < containerBounds.bottom && elementBounds.right > containerBounds.left && elementBounds.bottom > containerBounds.top && elementBounds.left < containerBounds.right || element.styles.position === 'fixed';\n}\nfunction delegate(event, elements) {\n var this$1 = this;\n if (event === void 0) event = {\n type: 'init'\n };\n if (elements === void 0) elements = this.store.elements;\n raf(function () {\n var stale = event.type === 'init' || event.type === 'resize';\n each(this$1.store.containers, function (container) {\n if (stale) {\n container.geometry = getGeometry.call(this$1, container, true);\n }\n var scroll = getScrolled.call(this$1, container);\n if (container.scroll) {\n container.direction = {\n x: mathSign(scroll.left - container.scroll.left),\n y: mathSign(scroll.top - container.scroll.top)\n };\n }\n container.scroll = scroll;\n });\n\n /**\n * Due to how the sequencer is implemented, it’s\n * important that we update the state of all\n * elements, before any animation logic is\n * evaluated (in the second loop below).\n */\n each(elements, function (element) {\n if (stale || element.geometry === undefined) {\n element.geometry = getGeometry.call(this$1, element);\n }\n element.visible = isElementVisible.call(this$1, element);\n });\n each(elements, function (element) {\n if (element.sequence) {\n sequence.call(this$1, element);\n } else {\n animate.call(this$1, element);\n }\n });\n this$1.pristine = false;\n });\n}\nfunction isTransformSupported() {\n var style = document.documentElement.style;\n return 'transform' in style || 'WebkitTransform' in style;\n}\nfunction isTransitionSupported() {\n var style = document.documentElement.style;\n return 'transition' in style || 'WebkitTransition' in style;\n}\nvar version = \"4.0.9\";\nvar boundDelegate;\nvar boundDestroy;\nvar boundReveal;\nvar boundClean;\nvar boundSync;\nvar config;\nvar debug;\nvar instance;\nfunction ScrollReveal(options) {\n if (options === void 0) options = {};\n var invokedWithoutNew = typeof this === 'undefined' || Object.getPrototypeOf(this) !== ScrollReveal.prototype;\n if (invokedWithoutNew) {\n return new ScrollReveal(options);\n }\n if (!ScrollReveal.isSupported()) {\n logger.call(this, 'Instantiation failed.', 'This browser is not supported.');\n return mount.failure();\n }\n var buffer;\n try {\n buffer = config ? deepAssign({}, config, options) : deepAssign({}, defaults, options);\n } catch (e) {\n logger.call(this, 'Invalid configuration.', e.message);\n return mount.failure();\n }\n try {\n var container = $(buffer.container)[0];\n if (!container) {\n throw new Error('Invalid container.');\n }\n } catch (e) {\n logger.call(this, e.message);\n return mount.failure();\n }\n config = buffer;\n if (!config.mobile && isMobile() || !config.desktop && !isMobile()) {\n logger.call(this, 'This device is disabled.', \"desktop: \" + config.desktop, \"mobile: \" + config.mobile);\n return mount.failure();\n }\n mount.success();\n this.store = {\n containers: {},\n elements: {},\n history: [],\n sequences: {}\n };\n this.pristine = true;\n boundDelegate = boundDelegate || delegate.bind(this);\n boundDestroy = boundDestroy || destroy.bind(this);\n boundReveal = boundReveal || reveal.bind(this);\n boundClean = boundClean || clean.bind(this);\n boundSync = boundSync || sync.bind(this);\n Object.defineProperty(this, 'delegate', {\n get: function get() {\n return boundDelegate;\n }\n });\n Object.defineProperty(this, 'destroy', {\n get: function get() {\n return boundDestroy;\n }\n });\n Object.defineProperty(this, 'reveal', {\n get: function get() {\n return boundReveal;\n }\n });\n Object.defineProperty(this, 'clean', {\n get: function get() {\n return boundClean;\n }\n });\n Object.defineProperty(this, 'sync', {\n get: function get() {\n return boundSync;\n }\n });\n Object.defineProperty(this, 'defaults', {\n get: function get() {\n return config;\n }\n });\n Object.defineProperty(this, 'version', {\n get: function get() {\n return version;\n }\n });\n Object.defineProperty(this, 'noop', {\n get: function get() {\n return false;\n }\n });\n return instance ? instance : instance = this;\n}\nScrollReveal.isSupported = function () {\n return isTransformSupported() && isTransitionSupported();\n};\nObject.defineProperty(ScrollReveal, 'debug', {\n get: function get() {\n return debug || false;\n },\n set: function set(value) {\n return debug = typeof value === 'boolean' ? value : debug;\n }\n});\nScrollReveal();\nexport default ScrollReveal;","import ScrollReveal from 'scrollreveal';\r\n\r\nconst isSSR = typeof window === 'undefined';\r\nconst sr = isSSR ? null : ScrollReveal();\r\n\r\nexport default sr;\r\n","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}"],"names":["hasElementType","Element","hasMap","Map","hasSet","Set","hasArrayBuffer","ArrayBuffer","isView","equal","a","b","constructor","length","i","keys","it","Array","isArray","size","entries","next","done","has","value","get","RegExp","source","flags","valueOf","Object","prototype","toString","hasOwnProperty","call","$$typeof","module","exports","error","message","match","console","warn","clock","Component","_class","_temp","ATTRIBUTE_NAMES","TAG_NAMES","BASE","BODY","HEAD","HTML","LINK","META","NOSCRIPT","SCRIPT","STYLE","TITLE","TAG_PROPERTIES","map","name","REACT_TAG_MAP","accesskey","charset","class","contenteditable","contextmenu","itemprop","tabindex","HELMET_PROPS","HTML_TAG_MAP","reduce","obj","key","SELF_CLOSING_TAGS","HELMET_ATTRIBUTE","_typeof","Symbol","iterator","classCallCheck","instance","Constructor","TypeError","createClass","defineProperties","target","props","descriptor","enumerable","configurable","writable","defineProperty","protoProps","staticProps","_extends","assign","arguments","objectWithoutProperties","indexOf","possibleConstructorReturn","self","ReferenceError","encodeSpecialCharacters","str","encode","undefined","String","replace","getTitleFromPropsList","propsList","innermostTitle","getInnermostProperty","innermostTemplate","join","innermostDefaultTitle","getOnChangeClientState","getAttributesFromPropsList","tagType","filter","tagAttrs","current","getBaseTagFromPropsList","primaryAttributes","reverse","innermostBaseTag","tag","lowerCaseAttributeKey","toLowerCase","concat","getTagsFromPropsList","tagName","approvedSeenTags","approvedTags","instanceTags","instanceSeenTags","primaryAttributeKey","attributeKey","forEach","push","tagUnion","property","rafPolyfill","Date","now","callback","currentTime","setTimeout","cafPolyfill","id","clearTimeout","requestAnimationFrame","window","bind","webkitRequestAnimationFrame","mozRequestAnimationFrame","g","cancelAnimationFrame","webkitCancelAnimationFrame","mozCancelAnimationFrame","msg","_helmetCallback","commitTagChanges","newState","cb","baseTag","bodyAttributes","htmlAttributes","linkTags","metaTags","noscriptTags","onChangeClientState","scriptTags","styleTags","title","titleAttributes","updateAttributes","updateTitle","tagUpdates","updateTags","addedTags","removedTags","_tagUpdates$tagType","newTags","oldTags","flattenArray","possibleArray","attributes","document","elementTag","getElementsByTagName","helmetAttributeString","getAttribute","helmetAttributes","split","attributesToRemove","attributeKeys","attribute","setAttribute","indexToSave","splice","_i","removeAttribute","type","tags","headElement","head","querySelector","tagNodes","querySelectorAll","slice","indexToDelete","newElement","createElement","innerHTML","styleSheet","cssText","appendChild","createTextNode","some","existingTag","index","isEqualNode","parentNode","removeChild","generateElementAttributesAsString","attr","convertElementAttributestoReactProps","initProps","getMethodsForTag","toComponent","_initProps","attributeString","flattenedTitle","generateTitleAsString","_mappedTag","mappedTag","mappedAttribute","content","dangerouslySetInnerHTML","__html","generateTagsAsReactComponent","attributeHtml","string","tagContent","isSelfClosing","generateTagsAsString","mapStateOnServer","_ref","_ref$title","base","link","meta","noscript","script","style","HelmetSideEffects","defer","HelmetExport","_React$Component","HelmetWrapper","this","apply","subClass","superClass","create","setPrototypeOf","__proto__","inherits","shouldComponentUpdate","nextProps","mapNestedChildrenToProps","child","nestedChildren","Error","flattenArrayTypeChildren","_babelHelpers$extends","arrayTypeChildren","newChildProps","mapObjectTypeChildren","_ref2","_babelHelpers$extends2","_babelHelpers$extends3","newProps","mapArrayTypeChildrenToProps","newFlattenedProps","arrayChildName","_babelHelpers$extends4","warnOnInvalidChildren","mapChildrenToProps","children","_this2","_child$props","initAttributes","convertReactPropstoHtmlAttributes","render","_props","set","canUseDOM","propTypes","defaultTitle","titleTemplate","defaultProps","peek","rewind","mappedState","renderStatic","ex","React","React__default","_defineProperty","reducePropsToState","handleStateChangeOnClient","WrappedComponent","state","mountedInstances","emitChange","SideEffect","_PureComponent","recordedState","_proto","UNSAFE_componentWillMount","componentDidUpdate","componentWillUnmount","PureComponent","displayName","getDisplayName","replaceClassName","origClass","classToRemove","forceReflow","node","scrollTop","UNMOUNTED","EXITED","ENTERING","ENTERED","EXITING","Transition","context","_this","initialStatus","appear","isMounting","enter","appearStatus","in","unmountOnExit","mountOnEnter","status","nextCallback","getDerivedStateFromProps","prevState","componentDidMount","updateStatus","prevProps","nextStatus","cancelNextCallback","getTimeouts","exit","timeout","mounting","nodeRef","performEnter","performExit","setState","appearing","maybeNode","maybeAppearing","timeouts","enterTimeout","config","safeSetState","onEntered","onEnter","onEntering","onTransitionEnd","_this3","onExit","onExiting","onExited","cancel","nextState","setNextCallback","_this4","active","event","handler","doesNotHaveTimeoutOrListener","addEndListener","_ref3","maybeNextCallback","_this$props","childProps","TransitionGroupContext","noop","contextType","removeClass","classes","c","className","element","classList","remove","baseVal","CSSTransition","_len","args","_key","appliedClasses","_this$resolveArgument","resolveArguments","removeClasses","addClass","_this$resolveArgument2","_this$resolveArgument3","getClassNames","classNames","isStringClassNames","baseClassName","activeClassName","doneClassName","phase","add","contains","hasClass","_addClass","_this$appliedClasses$","getChildMapping","mapFn","result","Children","isValidElement","mapper","getProp","prop","getNextChildMapping","prevChildMapping","nextChildMapping","prev","getValueForKey","nextKeysPending","pendingKeys","prevKey","childMapping","nextKey","pendingNextKey","mergeChildMappings","hasPrev","hasNext","prevChild","isLeaving","cloneElement","values","k","TransitionGroup","handleExited","_assertThisInitialized","contextValue","firstRender","mounted","currentChildMapping","component","childFactory","version","xmlns","x","y","viewBox","xmlSpace","d","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin","role","points","x1","y1","x2","y2","cx","cy","r","width","height","transform","Head","description","image","pathname","useLocation","useStaticQuery","site","siteMetadata","defaultDescription","siteUrl","defaultImage","twitterUsername","seo","url","Helmet","lang","button","css","bp","mobileS","mobileM","mobileL","tabletS","tabletL","desktopXS","desktopS","desktopM","desktopL","mixins","flexCenter","flexBetween","inlineLink","smallButton","bigButton","boxShadow","fancyList","resetList","calibre","normal","italic","sfMono","createFontFaces","family","styles","weight","formats","woff","woff2","calibreNormal","calibreItalic","sfMonoNormal","sfMonoItalic","prismColors","createGlobalStyle","fonts","variables","theme","TransitionStyles","PrismStyles","StyledContent","styled","location","isHome","useState","isLoading","setIsLoading","useEffect","hash","substring","el","getElementById","scrollIntoView","focus","allLinks","from","host","ThemeProvider","href","finishLoading","defaultInstanceSettings","update","begin","loopBegin","changeBegin","change","changeComplete","loopComplete","complete","loop","direction","autoplay","timelineOffset","defaultTweenSettings","duration","delay","endDelay","easing","round","validTransforms","cache","CSS","springs","minMax","val","min","max","Math","stringContains","text","applyArguments","func","is","arr","pth","svg","SVGElement","inp","HTMLInputElement","dom","nodeType","fnc","und","nil","hex","test","rgb","hsl","col","parseEasingParameters","exec","p","parseFloat","spring","params","mass","stiffness","damping","velocity","w0","sqrt","zeta","wd","solver","t","progress","exp","cos","sin","cached","frame","elapsed","rest","steps","ceil","eases","functionEasings","bezier","kSampleStepSize","A","aA1","aA2","B","C","calcBezier","aT","getSlope","mX1","mY1","mX2","mY2","sampleValues","Float32Array","getTForX","aX","intervalStart","currentSample","kSplineTableSize","guessForT","initialSlope","aGuessT","currentSlope","newtonRaphsonIterate","aA","aB","currentX","currentT","abs","binarySubdivide","penner","linear","Sine","PI","Circ","Back","Bounce","pow2","pow","Elastic","amplitude","period","asin","easeIn","parseEasings","ease","selectString","e","filterArray","len","thisArg","toArray","o","NodeList","HTMLCollection","arrayContains","cloneObject","clone","replaceObjectProps","o1","o2","mergeObjects","colorToRgb","rgbValue","hexValue","m","parseInt","hexToRgba","hslValue","h","s","l","hue2rgb","q","hslToRgba","getUnit","getFunctionValue","animatable","total","convertPxToUnit","unit","tempEl","parentEl","body","position","factor","offsetWidth","convertedUnit","getCSSValue","uppercasePropName","getComputedStyle","getPropertyValue","getAnimationType","getElementTransforms","reg","transforms","getTransformValue","propName","defaultVal","getTransformUnit","list","getOriginalTargetValue","getRelativeValue","to","operator","u","validateValue","originalUnit","unitLess","substr","getDistance","p1","p2","getPolylineLength","previousPos","totalLength","numberOfItems","currentPos","getItem","getTotalLength","getCircleLength","getRectLength","getLineLength","getPolygonLength","getParentSvg","pathEl","svgData","parentSvgEl","getParentSvgEl","rect","getBoundingClientRect","viewBoxAttr","w","vW","vH","getPathProgress","path","isPathTargetInsideSVG","point","offset","getPointAtLength","p0","scaleX","scaleY","atan2","decomposeValue","rgx","original","numbers","Number","strings","parseTargets","targets","item","pos","getAnimatables","parsed","normalizePropertyTweens","tweenSettings","settings","propArray","v","getProperties","properties","keyframes","propertyNames","newKey","flattenKeyframes","tweens","normalizeTweens","previousTween","tween","normalizeTweenValues","tweenValue","toUnit","originalValue","previousValue","fromUnit","start","end","isPath","isColor","setProgressValue","object","manual","last","setTargetsValue","valueUnit","animType","getAnimations","animatables","lastTween","createAnimation","getInstanceTimings","animations","animLength","getTlOffset","anim","timings","instanceID","activeInstances","engine","raf","step","activeInstancesLength","activeInstance","paused","tick","addEventListener","anime","suspendWhenDocumentHidden","isDocumentHidden","_onDocumentVisibility","hidden","startTime","lastTime","childrenLength","resolve","makePromise","promise","Promise","_resolve","finished","instanceSettings","createNewInstance","toggleInstanceDirection","reversed","adjustTime","time","resetTime","speed","seekChild","seek","setAnimationsProgress","insTime","animationsLength","tweenLength","eased","isNaN","toNumbersLength","n","toNumber","fromNumber","stringsLength","n$1","currentValue","setCallback","passThrough","setInstanceProgress","engineTime","insDuration","insDelay","insEndDelay","reversePlayback","i$1","syncInstanceChildren","began","loopBegan","changeBegan","changeCompleted","remaining","completed","reset","pause","play","restart","removeTargetsFromInstance","removeTargetsFromAnimations","targetsArray","childAnimations","running","convertPx","percent","setDashoffset","pathLength","stagger","grid","axis","fromIndex","fromFirst","fromCenter","fromLast","isRange","val1","val2","maxValue","fromX","fromY","floor","distanceX","distanceY","timeline","tl","instanceParams","tlIndex","ins","insParams","tlDuration","random","StyledLoader","isMounted","setIsMounted","strokeDashoffset","opacity","scale","zIndex","StyledHeader","scrollDirection","scrolledToTop","StyledNav","StyledLinks","useScrollDirection","setScrolledToTop","prefersReducedMotion","usePrefersReducedMotion","handleScroll","pageYOffset","removeEventListener","loaderDelay","fadeClass","fadeDownClass","Logo","tabIndex","Link","ResumeLink","rel","navLinks","transitionDelay","StyledMenu","StyledHamburgerButton","menuOpen","StyledSidebar","menuFocusables","firstFocusableEl","lastFocusableEl","setMenuOpen","buttonRef","useRef","navRef","onKeyDown","KEY_CODES","preventDefault","shiftKey","activeElement","handleBackwardTab","handleForwardTab","onResize","currentTarget","innerWidth","wrapperRef","useOnClickOutside","ref","onClick","StyledSideElement","orientation","StyledSocialList","socialMedia","StyledLinkWrapper","email","StyledFooter","StyledSocialLinks","StyledCredit","stars","forks","githubInfo","setGitHubInfo","fetch","then","response","json","stargazers_count","forks_count","catch","toLocaleString","StyledHeroSection","navDelay","items","StyledAboutSection","StyledText","StyledPic","revealContainer","sr","srConfig","skills","skill","S","src","quality","alt","StyledJobsSection","StyledTabList","StyledTabButton","isActive","StyledHighlight","activeTabId","StyledTabPanels","StyledTabPanel","jobsData","jobs","edges","setActiveTabId","tabFocus","setTabFocus","tabs","company","frontmatter","html","range","StyledContactSection","institution","StyledProjectsGrid","StyledProject","featuredProjects","featured","revealTitle","revealProjects","external","tech","github","cover","getImage","G","colors","green","navy","darkNavy","viewFactor","origin","distance","rotate","z","mobile","useDelay","viewOffset","top","right","bottom","left","listener","QUERY","isRenderingOnServer","getInitialState","matchMedia","matches","setPrefersReducedMotion","mediaQueryList","addListener","removeListener","initialDirection","thresholdPixels","off","scrollDir","setScrollDir","threshold","lastScrollY","ticking","updateScrollDir","scrollY","onScroll","ARROW_LEFT","ARROW_LEFT_IE11","ARROW_RIGHT","ARROW_RIGHT_IE11","ARROW_UP","ARROW_UP_IE11","ARROW_DOWN","ARROW_DOWN_IE11","ESCAPE","ESCAPE_IE11","TAB","SPACE","SPACE_IE11","ENTER","Node","nodeName","prototypeToString","query","err","format","matrix","identity","RangeError","multiply","fm","fx","product","row","j","parse","rotateZ","angle","theta","scalar","scalarY","polyfill","defaults","interval","cleanup","container","documentElement","desktop","afterReset","afterReveal","beforeReset","beforeReveal","mount","success","failure","clean","destroy","reveal","sync","isObject","each","collection","logger","details","debug","report","detail","log","rinse","this$1","elementIds","stale","sequenceIds","containerIds","store","elements","staleId","containerId","sequence","containers","delegate","sequences","getPrefixedCssProp","getPrefixedCssProperty","clearCache","computed","inline","inlineMatch","trim","generated","computedOpacity","configOpacity","transformations","fontSize","translateY","translateX","rotateY","raw","unshift","initial","final","transition","fragments","delayed","instant","composed","composition","fragment","applyStyle","declaration","pair","dirty","callbackTimer","history","deepAssign","sources","data","isMobile","agent","navigator","userAgent","uid","nextUniqueId","initialize","visible","revealed","initTimeout","animate","force","pristine","seen","shouldReveal","shouldReset","triggerReveal","triggerReset","registerCallbacks","isDelayed","beforeCallback","afterCallback","seq","SequenceModel","models","nextId","members","nextElement","cue","blocked","pop","shift","foot","Sequence","options","syncing","sequence$$1","containerBuffer","nodes","elementBuffer","elementNode","existingId","containerNode","collections","getContainerId","record","mathSign","sign","getGeometry","isContainer","clientHeight","offsetHeight","clientWidth","offsetTop","offsetLeft","offsetParent","bounds","getScrolled","pageXOffset","scrollLeft","isElementVisible","elementBounds","geometry","containerBounds","scroll","boundDelegate","boundDestroy","boundReveal","boundClean","boundSync","ScrollReveal","buffer","getPrototypeOf","isSupported","isTransformSupported","isTransitionSupported","_objectWithoutPropertiesLoose","excluded","sourceKeys"],"sourceRoot":""}