-
Notifications
You must be signed in to change notification settings - Fork 3
/
1-d5eb133895be9e7ac9f9.js.map
1 lines (1 loc) · 174 KB
/
1-d5eb133895be9e7ac9f9.js.map
1
{"version":3,"sources":["webpack:https:///./src/styles/A.js","webpack:https:///./src/styles/Img.js","webpack:https:///./src/styles/Button.js","webpack:https:///./src/styles/P.js","webpack:https:///./src/styles/Ul.js","webpack:https:///./src/styles/Input.js","webpack:https:///./src/styles/Svg.js","webpack:https:///./src/styles/Ol.js","webpack:https:///./src/styles/Nav.js","webpack:https:///./src/styles/Header.js","webpack:https:///./src/styles/Main.js","webpack:https:///./src/styles/Section.js","webpack:https:///./src/styles/Footer.js","webpack:https:///./src/styles/H3.js","webpack:https:///./src/styles/index.js","webpack:https:///./src/config/index.js","webpack:https:///./src/styles/theme.js","webpack:https:///./src/styles/media.js","webpack:https:///./src/components/icons/logo.js","webpack:https:///./src/components/icons/github.js","webpack:https:///./src/components/icons/linkedin.js","webpack:https:///./src/components/icons/codepen.js","webpack:https:///./src/components/icons/instagram.js","webpack:https:///./src/components/icons/twitter.js","webpack:https:///./src/components/icons/external.js","webpack:https:///./src/components/icons/folder.js","webpack:https:///./src/components/icons/index.js","webpack:https:///./.cache/gatsby-browser-entry.js","webpack:https:///./src/styles/mixins.js","webpack:https:///./src/styles/base.js","webpack:https:///./.cache/public-page-renderer.js","webpack:https:///./src/fonts/Calibre/Calibre-Light.ttf","webpack:https:///./src/fonts/Calibre/Calibre-Light.woff","webpack:https:///./src/fonts/Calibre/Calibre-Light.woff2","webpack:https:///./src/fonts/Calibre/Calibre-LightItalic.ttf","webpack:https:///./src/fonts/Calibre/Calibre-LightItalic.woff","webpack:https:///./src/fonts/Calibre/Calibre-LightItalic.woff2","webpack:https:///./src/fonts/Calibre/Calibre-Regular.ttf","webpack:https:///./src/fonts/Calibre/Calibre-Regular.woff","webpack:https:///./src/fonts/Calibre/Calibre-Regular.woff2","webpack:https:///./src/fonts/Calibre/Calibre-RegularItalic.ttf","webpack:https:///./src/fonts/Calibre/Calibre-RegularItalic.woff","webpack:https:///./src/fonts/Calibre/Calibre-RegularItalic.woff2","webpack:https:///./src/fonts/Calibre/Calibre-Medium.ttf","webpack:https:///./src/fonts/Calibre/Calibre-Medium.woff","webpack:https:///./src/fonts/Calibre/Calibre-Medium.woff2","webpack:https:///./src/fonts/Calibre/Calibre-MediumItalic.ttf","webpack:https:///./src/fonts/Calibre/Calibre-MediumItalic.woff","webpack:https:///./src/fonts/Calibre/Calibre-MediumItalic.woff2","webpack:https:///./src/fonts/Calibre/Calibre-Semibold.ttf","webpack:https:///./src/fonts/Calibre/Calibre-Semibold.woff","webpack:https:///./src/fonts/Calibre/Calibre-Semibold.woff2","webpack:https:///./src/fonts/Calibre/Calibre-SemiboldItalic.ttf","webpack:https:///./src/fonts/Calibre/Calibre-SemiboldItalic.woff","webpack:https:///./src/fonts/Calibre/Calibre-SemiboldItalic.woff2","webpack:https:///./src/fonts/SFMono/SFMono-Regular.ttf","webpack:https:///./src/fonts/SFMono/SFMono-Regular.woff","webpack:https:///./src/fonts/SFMono/SFMono-Regular.woff2","webpack:https:///./src/fonts/SFMono/SFMono-RegularItalic.ttf","webpack:https:///./src/fonts/SFMono/SFMono-RegularItalic.woff","webpack:https:///./src/fonts/SFMono/SFMono-RegularItalic.woff2","webpack:https:///./src/fonts/SFMono/SFMono-Medium.ttf","webpack:https:///./src/fonts/SFMono/SFMono-Medium.woff","webpack:https:///./src/fonts/SFMono/SFMono-Medium.woff2","webpack:https:///./src/fonts/SFMono/SFMono-MediumItalic.ttf","webpack:https:///./src/fonts/SFMono/SFMono-MediumItalic.woff","webpack:https:///./src/fonts/SFMono/SFMono-MediumItalic.woff2","webpack:https:///./src/fonts/SFMono/SFMono-Semibold.ttf","webpack:https:///./src/fonts/SFMono/SFMono-Semibold.woff","webpack:https:///./src/fonts/SFMono/SFMono-Semibold.woff2","webpack:https:///./src/fonts/SFMono/SFMono-SemiboldItalic.ttf","webpack:https:///./src/fonts/SFMono/SFMono-SemiboldItalic.woff","webpack:https:///./src/fonts/SFMono/SFMono-SemiboldItalic.woff2","webpack:https:///./src/images/resume.pdf","webpack:https:///./src/components/head.js","webpack:https:///./src/components/loader.js","webpack:https:///./src/utils/index.js","webpack:https:///./src/components/menu.js","webpack:https:///./src/components/header.js","webpack:https:///./src/components/social.js","webpack:https:///./src/components/email.js","webpack:https:///./src/components/footer.js","webpack:https:///./src/components/layout.js","webpack:https:///./.cache/public-page-renderer-prod.js","webpack:https:///./src/images/logo.png","webpack:https:///./src/images/favicons/apple-icon-57x57.png","webpack:https:///./src/images/favicons/apple-icon-60x60.png","webpack:https:///./src/images/favicons/apple-icon-72x72.png","webpack:https:///./src/images/favicons/apple-icon-76x76.png","webpack:https:///./src/images/favicons/apple-icon-114x114.png","webpack:https:///./src/images/favicons/apple-icon-120x120.png","webpack:https:///./src/images/favicons/apple-icon-144x144.png","webpack:https:///./src/images/favicons/apple-icon-152x152.png","webpack:https:///./src/images/favicons/apple-icon-180x180.png","webpack:https:///./src/images/favicons/android-icon-192x192.png","webpack:https:///./src/images/favicons/favicon-32x32.png","webpack:https:///./src/images/favicons/favicon-96x96.png","webpack:https:///./src/images/favicons/favicon-16x16.png","webpack:https:///./src/images/favicons/ms-icon-144x144.png"],"names":["A","styled","img","withConfig","displayName","componentId","a","theme","transition","colors","green","Button","button","blue","P","p","Ul","input","svg","ul","Ol","ol","Nav","header","nav","white","Main","main","Section","section","media","tablet","_templateObject","footer","margin","H3","h3","fontSizes","H3_templateObject","fonts","SFMono","xlarge","_templateObject2","large","mediumGrey","desktop","_templateObject3","_templateObject4","thone","_templateObject5","__webpack_require__","d","__webpack_exports__","mixins","styles_A","styles_Button","styles_P","styles_Ul","styles_Ol","styles_Nav","styles_Main","styles_Section","styles_H3","module","exports","siteTitle","siteDescription","siteKeywords","siteUrl","siteLanguage","siteImage","googleVerification","name","location","email","socialMedia","url","twitterHandle","googleAnalyticsID","headerHeight","greenColor","navyColor","srConfig","delay","origin","distance","duration","rotate","x","y","z","opacity","scale","easing","mobile","reset","useDelay","viewFactor","viewOffset","top","right","bottom","left","dark","darkestNavy","darkNavy","navy","lightNavy","darkGrey","blueGrey","grey","lightGrey","slate","lightSlate","lightestSlate","offWhite","pink","yellow","orange","darkBlue","highlight","transGreen","transNavy","shadowNavy","Calibre","xsmall","smallish","small","medium","xxlarge","borderRadius","headerScrollHeight","tabHeight","tabWidth","gradient","loaderDelay","hamburgerWidth","hamBefore","hamBeforeActive","hamAfter","hamAfterActive","sizes","giant","phablet","phone","tiny","Object","keys","reduce","accumulator","label","emSize","css","apply","arguments","IconLogo","react_default","createElement","xmlns","role","viewBox","id","transform","fill","stroke","strokeWidth","strokeLinecap","strokeLinejoin","points","IconGithub","IconLinkedin","IconCodepen","IconInstagram","cx","cy","r","IconTwitter","IconExternal","IconFolder","logo","github","linkedin","codepen","instagram","twitter","external","folder","graphql","StaticQueryContext","StaticQuery","react__WEBPACK_IMPORTED_MODULE_0__","react__WEBPACK_IMPORTED_MODULE_0___default","n","prop_types__WEBPACK_IMPORTED_MODULE_1__","prop_types__WEBPACK_IMPORTED_MODULE_1___default","gatsby_link__WEBPACK_IMPORTED_MODULE_2__","gatsby_link__WEBPACK_IMPORTED_MODULE_2___default","_public_page_renderer__WEBPACK_IMPORTED_MODULE_3__","_public_page_renderer__WEBPACK_IMPORTED_MODULE_3___default","_parse_path__WEBPACK_IMPORTED_MODULE_4__","React","createContext","props","Consumer","staticQueryData","data","query","render","children","Error","propTypes","PropTypes","object","string","isRequired","func","flexCenter","flexBetween","outline","link","inlineLink","smallButton","bigButton","sidePadding","injectGlobal","m","require","default","Head","_ref","metaData","Helmet_default","lang","prefix","itemProp","title","rel","type","href","content","description","config","property","appleIcon57x57","appleIcon60x60","appleIcon72x72","appleIcon76x76","appleIcon114x114","appleIcon120x120","appleIcon144x144","appleIcon152x152","appleIcon180x180","androidIcon192x192","favicon32x32","favicon96x96","favicon16x16","msIcon144x144","LoaderContainer","div","LogoWrapper","isMounted","Loader","state","componentDidMount","_this2","this","setState","animate","componentWillUnmount","_this3","anime","timeline","complete","finishLoading","add","targets","strokeDashoffset","setDashoffset","zIndex","className","Component","throttle","wait","timer","_this","_len","length","args","Array","_key","setTimeout","MenuContainer","menuOpen","Sidebar","NavLinks","NavList","NavListItem","li","_templateObject6","NavLink","AnchorLink","ResumeLink","Menu","_this$props","isHome","navLinks","handleMenuClick","onClick","aria-hidden","tabIndex","map","i","key","resume","target","bool","array","HeaderContainer","scrollDirection","header_templateObject","header_templateObject2","Navbar","Logo","LogoLink","Link","Hamburger","header_templateObject3","HamburgerBox","HamburgerInner","header_templateObject4","ResumeButton","DELTA","Header","lastScrollTop","handleScroll","_this$state","fromTop","window","scrollY","Math","abs","innerHeight","document","body","scrollHeight","handleResize","innerWidth","toggleMenu","handleKeydown","evt","e","isLink","hasAttribute","isContainer","classList","includes","addEventListener","removeEventListener","_this4","_this$state2","pathname","innerRef","el","react_transition_group","classNames","timeout","to","aria-label","icons","header_NavLinks","header_NavList","header_NavListItem","style","transitionDelay","header_NavLink","header_ResumeLink","menu","SocialContainer","social_templateObject","social_templateObject2","SocialItemList","SocialItem","SocialLink","Social","EmailContainer","email_templateObject","email_templateObject2","EmailLinkWrapper","EmailLink","Email","FooterContainer","footer_templateObject","Copy","GithubLink","Footer","footer_SocialContainer","footer_SocialItemList","footer_SocialItem","footer_SocialLink","SkipToContent","Layout","isLoading","gatsby_browser_entry","head","site","siteMetadata","components_loader","social","_2241923043","node","ProdPageRenderer","pageResources","loader","getResourcesForPathnameSync","InternalPageRenderer","assign","json","shape"],"mappings":"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","file":"1-d5eb133895be9e7ac9f9.js","sourcesContent":["import styled from 'styled-components';\r\nimport theme from './theme';\r\n\r\nconst A = styled.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: ${theme.transition};\r\n cursor: pointer;\r\n\r\n &:hover,\r\n &:focus {\r\n color: ${theme.colors.green};\r\n outline: 0;\r\n }\r\n`;\r\n\r\nexport default A;\r\n","import styled from 'styled-components';\r\n\r\nconst Img = styled.img`\r\n width: 100%;\r\n max-width: 100%;\r\n vertical-align: middle;\r\n`;\r\n\r\nexport default Img;\r\n","import styled from 'styled-components';\r\nimport theme from './theme';\r\n\r\nconst Button = styled.button`\r\n cursor: pointer;\r\n border: 0;\r\n border-radius: 0;\r\n\r\n &:focus,\r\n &:active {\r\n outline-color: ${theme.colors.blue};\r\n }\r\n`;\r\n\r\nexport default Button;\r\n","import styled from 'styled-components';\r\n\r\nconst P = styled.p`\r\n margin: 0 0 10px 0;\r\n`;\r\n\r\nexport default P;\r\n","import styled from 'styled-components';\r\n\r\nconst Ul = styled.ul`\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n`;\r\n\r\nexport default Ul;\r\n","import styled from 'styled-components';\r\n\r\nconst Input = styled.input`\r\n border-radius: 0;\r\n outline: 0;\r\n &:focus {\r\n outline: 0;\r\n }\r\n &::placeholder {\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\nexport default Input;\r\n","import styled from 'styled-components';\r\n\r\nconst Svg = styled.svg`\r\n width: 100%;\r\n height: 100%;\r\n fill: currentColor;\r\n vertical-align: middle;\r\n`;\r\n\r\nexport default Svg;\r\n","import styled from 'styled-components';\r\n\r\nconst Ol = styled.ol`\r\n padding: 0;\r\n margin: 0;\r\n list-style: none;\r\n`;\r\n\r\nexport default Ol;\r\n","import styled from 'styled-components';\r\nimport theme from './theme';\r\n\r\nconst Nav = styled.nav`\r\n width: 100%;\r\n color: ${theme.colors.white};\r\n`;\r\n\r\nexport default Nav;\r\n","import styled from 'styled-components';\r\n\r\nconst Header = styled.header`\r\n width: 100%;\r\n`;\r\n\r\nexport default Header;\r\n","import styled from 'styled-components';\r\n\r\nconst Main = styled.main`\r\n margin: 0 auto;\r\n width: 100%;\r\n`;\r\n\r\nexport default Main;\r\n","import styled from 'styled-components';\r\nimport media from './media';\r\n\r\nconst Section = styled.section`\r\n margin: 0 auto;\r\n padding: 150px 0;\r\n max-width: 1000px;\r\n\r\n ${media.tablet`padding: 100px 0;`};\r\n`;\r\n\r\nexport default Section;\r\n","import styled from 'styled-components';\r\nimport theme from './theme';\r\n\r\nconst Footer = styled.footer`\r\n margin: 0;\r\n padding: ${theme.margin};\r\n`;\r\n\r\nexport default Footer;\r\n","import styled from 'styled-components';\r\nimport theme from './theme';\r\nimport media from './media';\r\n\r\nconst H3 = styled.h3`\r\n position: relative;\r\n display: flex;\r\n align-items: center;\r\n margin: 10px 0 40px;\r\n width: 100%;\r\n white-space: nowrap;\r\n font-size: ${theme.fontSizes.h3};\r\n ${media.tablet`font-size: 24px;`};\r\n\r\n &:before {\r\n counter-increment: section;\r\n content: '0' counter(section) '.';\r\n margin-right: 10px;\r\n font-family: ${theme.fonts.SFMono};\r\n font-weight: normal;\r\n color: ${theme.colors.green};\r\n font-size: ${theme.fontSizes.xlarge};\r\n position: relative;\r\n bottom: 4px;\r\n ${media.tablet`font-size: ${theme.fontSizes.large};`};\r\n }\r\n\r\n &:after {\r\n content: '';\r\n display: block;\r\n height: 1px;\r\n width: 300px;\r\n background-color: ${theme.colors.mediumGrey};\r\n position: relative;\r\n top: -5px;\r\n margin-left: 20px;\r\n ${media.desktop`width: 200px`};\r\n ${media.tablet`width: 100%;`};\r\n ${media.thone`margin-left: 10px;`};\r\n }\r\n`;\r\n\r\nexport default H3;\r\n","import theme from './theme';\r\nimport base from './base';\r\nimport mixins from './mixins';\r\nimport media from './media';\r\nimport Img from './Img';\r\nimport A from './A';\r\nimport Button from './Button';\r\nimport P from './P';\r\nimport Input from './Input';\r\nimport Svg from './Svg';\r\nimport Ul from './Ul';\r\nimport Ol from './Ol';\r\nimport Header from './Header';\r\nimport Nav from './Nav';\r\nimport Main from './Main';\r\nimport Section from './Section';\r\nimport Footer from './Footer';\r\nimport H3 from './H3';\r\n\r\nexport {\r\n theme,\r\n base,\r\n mixins,\r\n media,\r\n Img,\r\n A,\r\n Button,\r\n P,\r\n Input,\r\n Svg,\r\n Ul,\r\n Ol,\r\n Header,\r\n Nav,\r\n Main,\r\n Section,\r\n Footer,\r\n H3,\r\n};\r\n","module.exports = {\r\n siteTitle:\r\n 'FeezyHendrix | FullStack Developer, Machine Learning Practitioner and a Hybrid Mobile Developer',\r\n siteDescription:\r\n 'Full stack software engineer based in Lagos, Nigeria who specializes in developing exceptional, high-quality web applications and we.',\r\n siteKeywords:\r\n 'Feezy Hendrix, Abdulhafeez Abdulraheem,feezyhendrix, fullstack engineer, software engineer, front-end engineer, web developer, javascript, lagos',\r\n siteUrl: 'https://feezyhendrix.github.io',\r\n siteLanguage: 'en_US',\r\n siteImage: 'https://brittanychiang.com/og.png',\r\n\r\n googleVerification: 'DCl7VAf9tcz6eD9gb67NfkNnJ1PKRNcg8qQiwpbx9Lk',\r\n\r\n name: 'AbdulHafeez AbdulRaheem',\r\n location: 'Lagos, NG',\r\n email: '[email protected]',\r\n socialMedia: [\r\n {\r\n name: 'Github',\r\n url: 'https://github.com/FeezyHendrix/',\r\n },\r\n {\r\n name: 'Linkedin',\r\n url: 'https://www.linkedin.com/in/feezyhendrix',\r\n },\r\n {\r\n name: 'Codepen',\r\n url: '',\r\n },\r\n {\r\n name: 'Instagram',\r\n url: 'https://www.instagram.com/feezyhendrix/',\r\n },\r\n {\r\n name: 'Twitter',\r\n url: 'https://twitter.com/feezyhendrix',\r\n },\r\n ],\r\n\r\n nav: [\r\n {\r\n name: 'About',\r\n url: '#about',\r\n },\r\n {\r\n name: 'Experience',\r\n url: '#jobs',\r\n },\r\n {\r\n name: 'Work',\r\n url: '#projects',\r\n },\r\n {\r\n name: 'Contact',\r\n url: '#contact',\r\n },\r\n ],\r\n\r\n twitterHandle: '@feezyhendrix',\r\n googleAnalyticsID: 'UA-45666519-2',\r\n\r\n headerHeight: 100,\r\n\r\n greenColor: '#64ffda',\r\n navyColor: '#116791',\r\n\r\n srConfig: (delay = 200) => {\r\n return {\r\n origin: 'bottom',\r\n distance: '20px',\r\n duration: 500,\r\n delay,\r\n rotate: { x: 0, y: 0, z: 0 },\r\n opacity: 0,\r\n scale: 1,\r\n easing: 'cubic-bezier(0.645, 0.045, 0.355, 1)',\r\n mobile: true,\r\n reset: false,\r\n useDelay: 'always',\r\n viewFactor: 0.25,\r\n viewOffset: { top: 0, right: 0, bottom: 0, left: 0 },\r\n };\r\n },\r\n};\r\n","const theme = {\r\n colors: {\r\n dark: '#000007',\r\n darkestNavy: '#01050b',\r\n darkNavy: '#020c1b',\r\n navy: '#0a192f',\r\n lightNavy: '#172a45',\r\n darkGrey: '#333f58',\r\n mediumGrey: '#2d3952',\r\n blueGrey: '#293d5a',\r\n grey: '#4c5772',\r\n lightGrey: '#606a86',\r\n slate: '#8892b0',\r\n lightSlate: '#a8b2d1',\r\n lightestSlate: '#ccd6f6',\r\n offWhite: '#dce7ff',\r\n white: '#e6f1ff',\r\n pink: '#FF647F',\r\n yellow: '#FFC464',\r\n orange: '#FF9E64',\r\n green: '#64ffda',\r\n blue: '#71AFFF',\r\n darkBlue: '#1D7FFC',\r\n highlight: 'rgba(41, 61, 90, 0.99)',\r\n transGreen: 'rgba(100, 255, 218, 0.07)',\r\n transNavy: 'rgba(10, 25, 47, 0.7)',\r\n shadowNavy: 'rgba(2, 12, 27, 0.9)',\r\n },\r\n\r\n fonts: {\r\n Calibre:\r\n 'Calibre, San Francisco, SF Pro Text, -apple-system, system-ui, BlinkMacSystemFont, Roboto, Helvetica Neue, Segoe UI, Arial, sans-serif',\r\n SFMono: 'SF Mono, Fira Code, Fira Mono, Roboto Mono, Lucida Console, Monaco, monospace',\r\n },\r\n\r\n fontSizes: {\r\n xsmall: '12px',\r\n smallish: '13px',\r\n small: '14px',\r\n medium: '16px',\r\n large: '18px',\r\n xlarge: '20px',\r\n xxlarge: '22px',\r\n h3: '30px',\r\n },\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 borderRadius: '2px',\r\n headerHeight: '100px',\r\n headerScrollHeight: '70px',\r\n margin: '20px',\r\n\r\n tabHeight: 42,\r\n tabWidth: 120,\r\n\r\n gradient: `linear-gradient(0.4turn, #64d6ff, #64ffda)`,\r\n\r\n loaderDelay: `6`,\r\n\r\n hamburgerWidth: 30,\r\n hamBefore: `top 0.1s ease-in 0.25s, opacity 0.1s ease-in`,\r\n hamBeforeActive: `top 0.1s ease-out, opacity 0.1s ease-out 0.12s`,\r\n hamAfter: `bottom 0.1s ease-in 0.25s, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19)`,\r\n hamAfterActive: `bottom 0.1s ease-out, transform 0.22s cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s`,\r\n};\r\n\r\nexport default theme;\r\n","import { css } from 'styled-components';\r\n\r\nconst sizes = {\r\n giant: 1440,\r\n desktop: 1000,\r\n tablet: 768,\r\n thone: 600,\r\n phablet: 480,\r\n phone: 376,\r\n tiny: 330,\r\n};\r\n\r\n// iterate through the sizes and create a media template\r\nexport const media = Object.keys(sizes).reduce((accumulator, label) => {\r\n // use em in breakpoints to work properly cross-browser and support users\r\n // changing their browsers font-size: https://zellwk.com/blog/media-query-units/\r\n const emSize = sizes[label] / 16;\r\n accumulator[label] = (...args) => css`\r\n @media (max-width: ${emSize}em) {\r\n ${css(...args)};\r\n }\r\n `;\r\n return accumulator;\r\n}, {});\r\n\r\nexport default media;\r\n","import React from 'react';\r\n\r\nconst IconLogo = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 84 96\">\r\n <title>Logo</title>\r\n <g id=\"Logo\" transform=\"translate(-8.000000, -2.000000)\">\r\n <g transform=\"translate(11.000000, 5.000000)\">\r\n <path\r\n d=\"M45.691667,45.15 C48.591667,46.1 50.691667,48.95 50.691667,52.2 C50.691667,57.95 46.691667,61 40.291667,61 L28.541667,61 L28.541667,30.3 L39.291667,30.3 C45.691667,30.3 49.691667,33.15 49.691667,38.65 C49.691667,41.95 47.941667,44.35 45.691667,45.15 Z M33.591667,43.2 L39.241667,43.2 C42.791667,43.2 44.691667,41.85 44.691667,38.95 C44.691667,36.05 42.791667,34.8 39.241667,34.8 L33.591667,34.8 L33.591667,43.2 Z M33.591667,47.5 L33.591667,56.5 L40.191667,56.5 C43.691667,56.5 45.591667,54.75 45.591667,52 C45.591667,49.2 43.691667,47.5 40.191667,47.5 L33.591667,47.5 Z\"\r\n fill=\"#64FFDA\"\r\n />\r\n <polygon\r\n id=\"Shape\"\r\n stroke=\"#64FFDA\"\r\n strokeWidth=\"5\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n points=\"39 0 0 22 0 67 39 90 78 68 78 23\"\r\n />\r\n </g>\r\n </g>\r\n </svg>\r\n);\r\n\r\nexport default IconLogo;\r\n","import React from 'react';\r\n\r\nconst IconGithub = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 438.549 438.549\">\r\n <title>Github</title>\r\n <path\r\n d=\"M409.132,114.573c-19.608-33.596-46.205-60.194-79.798-79.8C295.736,15.166,259.057,5.365,219.271,5.365\r\n c-39.781,0-76.472,9.804-110.063,29.408c-33.596,19.605-60.192,46.204-79.8,79.8C9.803,148.168,0,184.854,0,224.63 c0,47.78,13.94,90.745,41.827,128.906c27.884,38.164,63.906,64.572,108.063,79.227c5.14,0.954,8.945,0.283,11.419-1.996\r\n c2.475-2.282,3.711-5.14,3.711-8.562c0-0.571-0.049-5.708-0.144-15.417c-0.098-9.709-0.144-18.179-0.144-25.406l-6.567,1.136\r\n c-4.187,0.767-9.469,1.092-15.846,1c-6.374-0.089-12.991-0.757-19.842-1.999c-6.854-1.231-13.229-4.086-19.13-8.559\r\n c-5.898-4.473-10.085-10.328-12.56-17.556l-2.855-6.57c-1.903-4.374-4.899-9.233-8.992-14.559\r\n c-4.093-5.331-8.232-8.945-12.419-10.848l-1.999-1.431c-1.332-0.951-2.568-2.098-3.711-3.429c-1.142-1.331-1.997-2.663-2.568-3.997\r\n c-0.572-1.335-0.098-2.43,1.427-3.289c1.525-0.859,4.281-1.276,8.28-1.276l5.708,0.853c3.807,0.763,8.516,3.042,14.133,6.851\r\n c5.614,3.806,10.229,8.754,13.846,14.842c4.38,7.806,9.657,13.754,15.846,17.847c6.184,4.093,12.419,6.136,18.699,6.136\r\n c6.28,0,11.704-0.476,16.274-1.423c4.565-0.952,8.848-2.383,12.847-4.285c1.713-12.758,6.377-22.559,13.988-29.41\r\n c-10.848-1.14-20.601-2.857-29.264-5.14c-8.658-2.286-17.605-5.996-26.835-11.14c-9.235-5.137-16.896-11.516-22.985-19.126\r\n c-6.09-7.614-11.088-17.61-14.987-29.979c-3.901-12.374-5.852-26.648-5.852-42.826c0-23.035,7.52-42.637,22.557-58.817\r\n c-7.044-17.318-6.379-36.732,1.997-58.24c5.52-1.715,13.706-0.428,24.554,3.853c10.85,4.283,18.794,7.952,23.84,10.994\r\n c5.046,3.041,9.089,5.618,12.135,7.708c17.705-4.947,35.976-7.421,54.818-7.421s37.117,2.474,54.823,7.421l10.849-6.849\r\n c7.419-4.57,16.18-8.758,26.262-12.565c10.088-3.805,17.802-4.853,23.134-3.138c8.562,21.509,9.325,40.922,2.279,58.24\r\n c15.036,16.18,22.559,35.787,22.559,58.817c0,16.178-1.958,30.497-5.853,42.966c-3.9,12.471-8.941,22.457-15.125,29.979\r\n c-6.191,7.521-13.901,13.85-23.131,18.986c-9.232,5.14-18.182,8.85-26.84,11.136c-8.662,2.286-18.415,4.004-29.263,5.146\r\n c9.894,8.562,14.842,22.077,14.842,40.539v60.237c0,3.422,1.19,6.279,3.572,8.562c2.379,2.279,6.136,2.95,11.276,1.995\r\n c44.163-14.653,80.185-41.062,108.068-79.226c27.88-38.161,41.825-81.126,41.825-128.906\r\n C438.536,184.851,428.728,148.168,409.132,114.573z\"\r\n />\r\n </svg>\r\n);\r\n\r\nexport default IconGithub;\r\n","import React from 'react';\r\n\r\nconst IconLinkedin = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 430.117 430.117\">\r\n <title>LinkedIn</title>\r\n <path\r\n d=\"M430.117,261.543V420.56h-92.188V272.193c0-37.271-13.334-62.707-46.703-62.707\r\n c-25.473,0-40.632,17.142-47.301,33.724c-2.432,5.928-3.058,14.179-3.058,22.477V420.56h-92.219c0,0,1.242-251.285,0-277.32h92.21\r\n v39.309c-0.187,0.294-0.43,0.611-0.606,0.896h0.606v-0.896c12.251-18.869,34.13-45.824,83.102-45.824\r\n C384.633,136.724,430.117,176.361,430.117,261.543z M52.183,9.558C20.635,9.558,0,30.251,0,57.463\r\n c0,26.619,20.038,47.94,50.959,47.94h0.616c32.159,0,52.159-21.317,52.159-47.94C103.128,30.251,83.734,9.558,52.183,9.558z\r\n M5.477,420.56h92.184v-277.32H5.477V420.56z\"\r\n />\r\n </svg>\r\n);\r\n\r\nexport default IconLinkedin;\r\n","import React from 'react';\r\n\r\nconst IconCodepen = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 31.665 31.665\">\r\n <title>Codepen</title>\r\n <path\r\n d=\"M16.878,0.415c-0.854-0.565-1.968-0.552-2.809,0.034L1.485,9.214c-0.671,0.468-1.071,1.233-1.071,2.052v9.444\r\n c0,0.84,0.421,1.623,1.122,2.086l12.79,8.455c0.836,0.553,1.922,0.553,2.758,0l13.044-8.618c0.7-0.463,1.122-1.246,1.122-2.086\r\n v-9.279c0-0.839-0.421-1.622-1.121-2.085L16.878,0.415z M26.621,10.645l-4.821,3.237l-4.521-3.288L17.25,4.127L26.621,10.645z\r\n M13.979,4.133v6.329l-4.633,3.24l-4.621-3.099L13.979,4.133z M3.458,13.722l2.991,2.004l-2.991,2.093V13.722z M14.058,27.215\r\n l-9.331-6.258l4.661-3.258l4.67,3.133V27.215z M12.286,15.674l3.021-2.113l3.519,2.313l-3.119,2.095L12.286,15.674z M17.354,27.215\r\n V20.83l4.463-2.991l4.805,3.159L17.354,27.215z M27.954,17.927l-3.168-2.082l3.168-2.125V17.927z\"\r\n />\r\n </svg>\r\n);\r\n\r\nexport default IconCodepen;\r\n","import React from 'react';\r\n\r\nconst IconInstagram = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 512 512\">\r\n <title>Instagram</title>\r\n <g>\r\n <g>\r\n <path d=\"M352,0H160C71.648,0,0,71.648,0,160v192c0,88.352,71.648,160,160,160h192c88.352,0,160-71.648,160-160V160 C512,71.648,440.352,0,352,0z M464,352c0,61.76-50.24,112-112,112H160c-61.76,0-112-50.24-112-112V160C48,98.24,98.24,48,160,48 h192c61.76,0,112,50.24,112,112V352z\" />\r\n </g>\r\n </g>\r\n <g>\r\n <g>\r\n <path d=\"M256,128c-70.688,0-128,57.312-128,128s57.312,128,128,128s128-57.312,128-128S326.688,128,256,128z M256,336 c-44.096,0-80-35.904-80-80c0-44.128,35.904-80,80-80s80,35.872,80,80C336,300.096,300.096,336,256,336z\" />\r\n </g>\r\n </g>\r\n <g>\r\n <g>\r\n <circle cx=\"393.6\" cy=\"118.4\" r=\"17.056\" />\r\n </g>\r\n </g>\r\n </svg>\r\n);\r\n\r\nexport default IconInstagram;\r\n","import React from 'react';\r\n\r\nconst IconTwitter = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 612 612\">\r\n <title>Twitter</title>\r\n <path\r\n d=\"M612,116.258c-22.525,9.981-46.694,16.75-72.088,19.772c25.929-15.527,45.777-40.155,55.184-69.411\r\n c-24.322,14.379-51.169,24.82-79.775,30.48c-22.907-24.437-55.49-39.658-91.63-39.658c-69.334,0-125.551,56.217-125.551,125.513\r\n c0,9.828,1.109,19.427,3.251,28.606C197.065,206.32,104.556,156.337,42.641,80.386c-10.823,18.51-16.98,40.078-16.98,63.101\r\n c0,43.559,22.181,81.993,55.835,104.479c-20.575-0.688-39.926-6.348-56.867-15.756v1.568c0,60.806,43.291,111.554,100.693,123.104\r\n c-10.517,2.83-21.607,4.398-33.08,4.398c-8.107,0-15.947-0.803-23.634-2.333c15.985,49.907,62.336,86.199,117.253,87.194\r\n c-42.947,33.654-97.099,53.655-155.916,53.655c-10.134,0-20.116-0.612-29.944-1.721c55.567,35.681,121.536,56.485,192.438,56.485\r\n c230.948,0,357.188-191.291,357.188-357.188l-0.421-16.253C573.872,163.526,595.211,141.422,612,116.258z\"\r\n />\r\n </svg>\r\n);\r\n\r\nexport default IconTwitter;\r\n","import React from 'react';\r\n\r\nconst IconExternal = () => (\r\n <svg xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 194.818 194.818\">\r\n <title>External</title>\r\n <g>\r\n <path\r\n d=\"M185.818,2.161h-57.04c-4.971,0-9,4.029-9,9s4.029,9,9,9h35.312l-86.3,86.3c-3.515,3.515-3.515,9.213,0,12.728\r\n c1.758,1.757,4.061,2.636,6.364,2.636s4.606-0.879,6.364-2.636l86.3-86.3v35.313c0,4.971,4.029,9,9,9s9-4.029,9-9v-57.04\r\n C194.818,6.19,190.789,2.161,185.818,2.161z\"\r\n />\r\n <path\r\n d=\"M149,77.201c-4.971,0-9,4.029-9,9v88.456H18v-122h93.778c4.971,0,9-4.029,9-9s-4.029-9-9-9H9c-4.971,0-9,4.029-9,9v140\r\n c0,4.971,4.029,9,9,9h140c4.971,0,9-4.029,9-9V86.201C158,81.23,153.971,77.201,149,77.201z\"\r\n />\r\n </g>\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 xmlns=\"https://www.w3.org/2000/svg\" role=\"img\" viewBox=\"0 0 60 60\">\r\n <title>Folder</title>\r\n <path\r\n d=\"M57.49,21.5H54v-6.268c0-1.507-1.226-2.732-2.732-2.732H26.515l-5-7H2.732C1.226,5.5,0,6.726,0,8.232v43.687l0.006,0\r\n c-0.005,0.563,0.17,1.114,0.522,1.575C1.018,54.134,1.76,54.5,2.565,54.5h44.759c1.156,0,2.174-0.779,2.45-1.813L60,24.649v-0.177\r\n C60,22.75,58.944,21.5,57.49,21.5z M2,8.232C2,7.828,2.329,7.5,2.732,7.5h17.753l5,7h25.782c0.404,0,0.732,0.328,0.732,0.732V21.5\r\n H12.731c-0.144,0-0.287,0.012-0.426,0.036c-0.973,0.163-1.782,0.873-2.023,1.776L2,45.899V8.232z M47.869,52.083\r\n c-0.066,0.245-0.291,0.417-0.545,0.417H2.565c-0.243,0-0.385-0.139-0.448-0.222c-0.063-0.082-0.16-0.256-0.123-0.408l10.191-27.953\r\n c0.066-0.245,0.291-0.417,0.545-0.417H54h3.49c0.38,0,0.477,0.546,0.502,0.819L47.869,52.083z\"\r\n />\r\n </svg>\r\n);\r\n\r\nexport default IconFolder;\r\n","import IconLogo from './logo';\r\nimport IconGithub from './github';\r\nimport IconLinkedin from './linkedin';\r\nimport IconCodepen from './codepen';\r\nimport IconInstagram from './instagram';\r\nimport IconTwitter from './twitter';\r\nimport IconExternal from './external';\r\nimport IconFolder from './folder';\r\nimport IconLocation from './location';\r\n\r\nexport {\r\n IconLogo,\r\n IconGithub,\r\n IconLinkedin,\r\n IconCodepen,\r\n IconInstagram,\r\n IconTwitter,\r\n IconExternal,\r\n IconFolder,\r\n IconLocation,\r\n};\r\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\nimport Link, {\n withPrefix,\n navigate,\n push,\n replace,\n navigateTo,\n} from \"gatsby-link\"\nimport PageRenderer from \"./public-page-renderer\"\nimport parsePath from \"./parse-path\"\n\nconst StaticQueryContext = React.createContext({})\n\nconst StaticQuery = props => (\n <StaticQueryContext.Consumer>\n {staticQueryData => {\n if (\n props.data ||\n (staticQueryData[props.query] && staticQueryData[props.query].data)\n ) {\n return (props.render || props.children)(\n props.data ? props.data.data : staticQueryData[props.query].data\n )\n } else {\n return <div>Loading (StaticQuery)</div>\n }\n }}\n </StaticQueryContext.Consumer>\n)\n\nStaticQuery.propTypes = {\n data: PropTypes.object,\n query: PropTypes.string.isRequired,\n render: PropTypes.func,\n children: PropTypes.func,\n}\n\nfunction graphql() {\n throw new Error(\n `It appears like Gatsby is misconfigured. Gatsby related \\`graphql\\` calls ` +\n `are supposed to only be evaluated at compile time, and then compiled away,. ` +\n `Unfortunately, something went wrong and the query was left in the compiled code.\\n\\n.` +\n `Unless your site has a complex or custom babel/Gatsby configuration this is likely a bug in Gatsby.`\n )\n}\n\nexport {\n Link,\n withPrefix,\n graphql,\n parsePath,\n navigate,\n push, // TODO replace for v3\n replace, // TODO remove replace for v3\n navigateTo, // TODO: remove navigateTo for v3\n StaticQueryContext,\n StaticQuery,\n PageRenderer,\n}\n","import { css } from 'styled-components';\r\nimport theme from './theme';\r\nimport media from './media';\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 outline: css`\r\n outline: 1px solid red;\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: ${theme.transition};\r\n cursor: pointer;\r\n &:hover,\r\n &:active,\r\n &:focus {\r\n color: ${theme.colors.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: ${theme.transition};\r\n cursor: pointer;\r\n color: ${theme.colors.green};\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n color: ${theme.colors.green};\r\n outline: 0;\r\n &:after {\r\n width: 100%;\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: ${theme.colors.green};\r\n transition: ${theme.transition};\r\n }\r\n `,\r\n\r\n smallButton: css`\r\n color: ${theme.colors.green};\r\n background-color: transparent;\r\n border: 1px solid ${theme.colors.green};\r\n border-radius: ${theme.borderRadius};\r\n padding: 12px 17px;\r\n font-size: ${theme.fontSizes.smallish};\r\n font-family: ${theme.fonts.SFMono};\r\n line-height: 1;\r\n text-decoration: none;\r\n cursor: pointer;\r\n transition: ${theme.transition};\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n background-color: ${theme.colors.transGreen};\r\n }\r\n &:after {\r\n display: none !important;\r\n }\r\n `,\r\n\r\n bigButton: css`\r\n color: ${theme.colors.green};\r\n background-color: transparent;\r\n border: 1px solid ${theme.colors.green};\r\n border-radius: ${theme.borderRadius};\r\n padding: 18px 23px;\r\n font-size: ${theme.fontSizes.small};\r\n font-family: ${theme.fonts.SFMono};\r\n line-height: 1;\r\n text-decoration: none;\r\n cursor: pointer;\r\n transition: ${theme.transition};\r\n &:hover,\r\n &:focus,\r\n &:active {\r\n background-color: ${theme.colors.transGreen};\r\n }\r\n &:after {\r\n display: none !important;\r\n }\r\n `,\r\n\r\n sidePadding: css`\r\n padding: 0 150px;\r\n ${media.desktop`padding: 0 100px;`};\r\n ${media.tablet`padding: 0 50px;`};\r\n ${media.phablet`padding: 0 25px;`};\r\n `,\r\n};\r\n\r\nexport default mixins;\r\n","import { injectGlobal } from 'styled-components';\r\nimport theme from './theme';\r\nimport mixins from './mixins';\r\nimport media from './media';\r\nimport * as fonts from './fonts';\r\n\r\nconst base = injectGlobal`\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreLightWOFF2}) format('woff2'),\r\n url(${fonts.CalibreLightWOFF}) format('woff'),\r\n url(${fonts.CalibreLightTTF}) format('truetype');\r\n font-weight: 300;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreLightItalicWOFF2}) format('woff2'),\r\n url(${fonts.CalibreLightItalicWOFF}) format('woff'),\r\n url(${fonts.CalibreLightItalicTTF}) format('truetype');\r\n font-weight: 300;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreRegularWOFF2}) format('woff2'),\r\n url(${fonts.CalibreRegularWOFF}) format('woff'),\r\n url(${fonts.CalibreRegularTTF}) format('truetype');\r\n font-weight: normal;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreRegularItalicWOFF2}) format('woff2'),\r\n url(${fonts.CalibreRegularItalicWOFF}) format('woff'),\r\n url(${fonts.CalibreRegularItalicTTF}) format('truetype');\r\n font-weight: normal;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreMediumWOFF2}) format('woff2'),\r\n url(${fonts.CalibreMediumWOFF}) format('woff'),\r\n url(${fonts.CalibreMediumTTF}) format('truetype');\r\n font-weight: 500;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreMediumItalicWOFF2}) format('woff2'),\r\n url(${fonts.CalibreMediumItalicWOFF}) format('woff'),\r\n url(${fonts.CalibreMediumItalicTTF}) format('truetype');\r\n font-weight: 500;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreSemiboldWOFF2}) format('woff2'),\r\n url(${fonts.CalibreSemiboldWOFF}) format('woff'),\r\n url(${fonts.CalibreSemiboldTTF}) format('truetype');\r\n font-weight: 600;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'Calibre';\r\n src: url(${fonts.CalibreSemiboldItalicWOFF2}) format('woff2'),\r\n url(${fonts.CalibreSemiboldItalicWOFF}) format('woff'),\r\n url(${fonts.CalibreSemiboldItalicTTF}) format('truetype');\r\n font-weight: 600;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'SF Mono';\r\n src: url(${fonts.SFMonoRegularWOFF2}) format('woff2'),\r\n url(${fonts.SFMonoRegularWOFF}) format('woff'),\r\n url(${fonts.SFMonoRegularTTF}) format('truetype');\r\n font-weight: normal;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'SF Mono';\r\n src: url(${fonts.SFMonoRegularItalicWOFF2}) format('woff2'),\r\n url(${fonts.SFMonoRegularItalicWOFF}) format('woff'),\r\n url(${fonts.SFMonoRegularItalicTTF}) format('truetype');\r\n font-weight: normal;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'SF Mono';\r\n src: url(${fonts.SFMonoMediumWOFF2}) format('woff2'),\r\n url(${fonts.SFMonoMediumWOFF}) format('woff'),\r\n url(${fonts.SFMonoMediumTTF}) format('truetype');\r\n font-weight: 500;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'SF Mono';\r\n src: url(${fonts.SFMonoMediumItalicWOFF2}) format('woff2'),\r\n url(${fonts.SFMonoMediumItalicWOFF}) format('woff'),\r\n url(${fonts.SFMonoMediumItalicTTF}) format('truetype');\r\n font-weight: 500;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'SF Mono';\r\n src: url(${fonts.SFMonoSemiboldWOFF2}) format('woff2'),\r\n url(${fonts.SFMonoSemiboldWOFF}) format('woff'),\r\n url(${fonts.SFMonoSemiboldTTF}) format('truetype');\r\n font-weight: 600;\r\n font-style: normal;\r\n font-display: auto;\r\n }\r\n @font-face {\r\n font-family: 'SF Mono';\r\n src: url(${fonts.SFMonoSemiboldItalicWOFF2}) format('woff2'),\r\n url(${fonts.SFMonoSemiboldItalicWOFF}) format('woff'),\r\n url(${fonts.SFMonoSemiboldItalicTTF}) format('truetype');\r\n font-weight: 600;\r\n font-style: italic;\r\n font-display: auto;\r\n }\r\n\r\n html {\r\n box-sizing: border-box;\r\n width: 100%;\r\n }\r\n\r\n *,\r\n *:before,\r\n *:after {\r\n box-sizing: inherit;\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: ${theme.colors.navy};\r\n color: ${theme.colors.slate};\r\n line-height: 1.25;\r\n font-family: ${theme.fonts.Calibre};\r\n font-size: ${theme.fontSizes.xlarge};\r\n ${media.phablet`font-size: ${theme.fontSizes.large};`}\r\n\r\n &.hidden {\r\n overflow: hidden;\r\n }\r\n &.blur {\r\n overflow: hidden;\r\n #root > .container > * {\r\n filter: blur(5px) brightness(0.7);\r\n transition: ${theme.transition};\r\n pointer-events: none;\r\n user-select: none;\r\n }\r\n }\r\n }\r\n\r\n ::selection {\r\n background-color: ${theme.colors.highlight};\r\n }\r\n\r\n h1,\r\n h2,\r\n h3,\r\n h4,\r\n h5 {\r\n font-weight: 600;\r\n color: ${theme.colors.white};\r\n margin: 0 0 10px 0;\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 a {\r\n ${mixins.link};\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\r\n button {\r\n outline: 0;\r\n border: 0;\r\n }\r\n\r\n p {\r\n margin-top: 0;\r\n }\r\n\r\n .gatsby-image-outer-wrapper {\r\n height: 100%;\r\n }\r\n\r\n .fadeup-enter {\r\n opacity: 0.01;\r\n transform: translateY(20px);\r\n transition: opacity 300ms ${theme.easing}, transform 300ms ${theme.easing};\r\n }\r\n\r\n .fadeup-enter-active {\r\n opacity: 1;\r\n transform: translateY(0px);\r\n transition: opacity 300ms ${theme.easing}, transform 300ms ${theme.easing};\r\n }\r\n\r\n .fadedown-enter {\r\n opacity: 0.01;\r\n transform: translateY(-20px);\r\n transition: opacity 300ms ${theme.easing}, transform 300ms ${theme.easing};\r\n }\r\n\r\n .fadedown-enter-active {\r\n opacity: 1;\r\n transform: translateY(0px);\r\n transition: opacity 300ms ${theme.easing}, transform 300ms ${theme.easing};\r\n }\r\n\r\n .fade-enter {\r\n opacity: 0.01;\r\n transition: opacity 1000ms ${theme.easing};\r\n }\r\n\r\n .fade-enter-active {\r\n opacity: 1;\r\n transition: opacity 1000ms ${theme.easing};\r\n }\r\n\r\n`;\r\n\r\nexport default base;\r\n","const preferDefault = m => (m && m.default) || m\n\nif (process.env.BUILD_STAGE === `develop`) {\n module.exports = preferDefault(require(`./public-page-renderer-dev`))\n} else if (process.env.BUILD_STAGE === `build-javascript`) {\n module.exports = preferDefault(require(`./public-page-renderer-prod`))\n} else {\n module.exports = () => null\n}\n","module.exports = __webpack_public_path__ + \"static/Calibre-Light-73b7f4385ae2f8028e1b365a48038582.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-Light-62b8f0fd78f4d842b3a75c1d2512e449.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-Light-183de736efe789394f26ed013b0b5cdd.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-LightItalic-3ede1be73648125ed40cfd07e1292bf1.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-LightItalic-1222cf0d45062719e06c3d7d44937e8f.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-LightItalic-f34c1430353885b55d271d473235eb6a.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-Regular-96e0a7c47fdd7a8f05007837ead73b35.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-Regular-e08232148510aade507c2af9bb66acd0.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-Regular-b63c62e591d0c8fbe2c8f009883346d5.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-RegularItalic-c408807a3001d1f7773f5f7fe513c165.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-RegularItalic-3a445970c7bcd6b102ac6bd60178b0bc.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-RegularItalic-35657aa2d12ff78e3d8a8a5ba28c2c35.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-Medium-88178c3f2a309ad11520ee62765072d0.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-Medium-115d37180a9c07e2f480ca81b032babe.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-Medium-46b36969c7bb1d7ed4c8253e8f274788.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-MediumItalic-6eb2ac5a1d38f19c7085b131356b355e.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-MediumItalic-4afe8032c647b57de924543c052e0ee4.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-MediumItalic-3df14639dd2cb07c83bd39707d70910f.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-Semibold-8325d174436d55e995c7214faafcd47b.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-Semibold-347808401d7a6607ff9a86897aec0a39.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-Semibold-d8b856473a51d7eec2a9bccf2fbea54c.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-SemiboldItalic-71941c0c0420e703494d6e2a62bc12d4.ttf\";","module.exports = __webpack_public_path__ + \"static/Calibre-SemiboldItalic-6473be72d5216d0ec21d273af09b9fa3.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-SemiboldItalic-8f3e4b3eaed73e67bbc4fc81f308a35f.woff2\";","module.exports = __webpack_public_path__ + \"static/SFMono-Regular-d892da9f8895428033ec68a6c0426ba6.ttf\";","module.exports = __webpack_public_path__ + \"static/SFMono-Regular-d59c1702c527525e9939ba06166a3750.woff\";","module.exports = __webpack_public_path__ + \"static/SFMono-Regular-7faa66605357721067fe1b07d9103015.woff2\";","module.exports = __webpack_public_path__ + \"static/SFMono-RegularItalic-8eddf7adea62d66b9e4d031b58dfaaa6.ttf\";","module.exports = __webpack_public_path__ + \"static/SFMono-RegularItalic-502441ff6ee56a1df1558e8461050a46.woff\";","module.exports = __webpack_public_path__ + \"static/SFMono-RegularItalic-bb1fc3ab1772befac3587b30ca876a09.woff2\";","module.exports = __webpack_public_path__ + \"static/SFMono-Medium-02bbb63875ebdbf463e764bb3d8ff190.ttf\";","module.exports = __webpack_public_path__ + \"static/SFMono-Medium-7df7729fbc66c426b3500d72bc140f5c.woff\";","module.exports = __webpack_public_path__ + \"static/SFMono-Medium-99497ab65b5b8a7e5c18b7b3edde5c85.woff2\";","module.exports = __webpack_public_path__ + \"static/SFMono-MediumItalic-92f9fb02060aabf378f0639de5e033ef.ttf\";","module.exports = __webpack_public_path__ + \"static/SFMono-MediumItalic-9fbdbe4e2d56f80d6775b61f9b264df8.woff\";","module.exports = __webpack_public_path__ + \"static/SFMono-MediumItalic-ae7ea80fb472a7d27aa69b3cf00f487c.woff2\";","module.exports = __webpack_public_path__ + \"static/SFMono-Semibold-8282ed99a84b8e9c803baf3df5b76c01.ttf\";","module.exports = __webpack_public_path__ + \"static/SFMono-Semibold-2d4bff46a7a9ba9dc7701f75726a7815.woff\";","module.exports = __webpack_public_path__ + \"static/SFMono-Semibold-cebe2bfbe8a283427e3c5ad8a1b8ae2f.woff2\";","module.exports = __webpack_public_path__ + \"static/SFMono-SemiboldItalic-ca70ba8a9030ed9bb7e081f63fd3831b.ttf\";","module.exports = __webpack_public_path__ + \"static/SFMono-SemiboldItalic-41da0311eaa7077546785a822a6ba21a.woff\";","module.exports = __webpack_public_path__ + \"static/SFMono-SemiboldItalic-2fd68bed64aeaceadc6402efc4d82767.woff2\";","module.exports = __webpack_public_path__ + \"static/resume-cc1c5a6e6a30f7dd16434cd041fe65a0.pdf\";","import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport Helmet from 'react-helmet';\r\nimport config from '../config';\r\n\r\nimport logo from '../images/logo.png';\r\nimport appleIcon57x57 from '../images/favicons/apple-icon-57x57.png';\r\nimport appleIcon60x60 from '../images/favicons/apple-icon-60x60.png';\r\nimport appleIcon72x72 from '../images/favicons/apple-icon-72x72.png';\r\nimport appleIcon76x76 from '../images/favicons/apple-icon-76x76.png';\r\nimport appleIcon114x114 from '../images/favicons/apple-icon-114x114.png';\r\nimport appleIcon120x120 from '../images/favicons/apple-icon-120x120.png';\r\nimport appleIcon144x144 from '../images/favicons/apple-icon-144x144.png';\r\nimport appleIcon152x152 from '../images/favicons/apple-icon-152x152.png';\r\nimport appleIcon180x180 from '../images/favicons/apple-icon-180x180.png';\r\nimport androidIcon192x192 from '../images/favicons/android-icon-192x192.png';\r\nimport favicon32x32 from '../images/favicons/favicon-32x32.png';\r\nimport favicon96x96 from '../images/favicons/favicon-96x96.png';\r\nimport favicon16x16 from '../images/favicons/favicon-16x16.png';\r\nimport msIcon144x144 from '../images/favicons/ms-icon-144x144.png';\r\n\r\nconst Head = ({ metaData }) => (\r\n <Helmet>\r\n <html lang=\"en\" prefix=\"og: https://ogp.me/ns#\" />\r\n <title itemProp=\"name\" lang=\"en\">\r\n {metaData.title}\r\n </title>\r\n <link rel=\"icon\" type=\"image/png\" href={logo} />\r\n <meta name=\"description\" content={metaData.description} />\r\n <meta name=\"keywords\" content={config.siteKeywords} />\r\n <meta name=\"google-site-verification\" content={config.googleVerification} />\r\n <meta property=\"og:title\" content={metaData.title} />\r\n <meta property=\"og:description\" content={metaData.description} />\r\n <meta property=\"og:type\" content=\"website\" />\r\n <meta property=\"og:url\" content={metaData.siteUrl} />\r\n <meta property=\"og:site_name\" content={metaData.title} />\r\n <meta property=\"og:image\" content={config.siteImage} />\r\n <meta property=\"og:image:width\" content=\"1200\" />\r\n <meta property=\"og:image:height\" content=\"630\" />\r\n <meta property=\"og:image:type\" content=\"image/png\" />\r\n <meta property=\"og:locale\" content={config.siteLanguage} />\r\n <meta itemProp=\"name\" content={metaData.title} />\r\n <meta itemProp=\"description\" content={metaData.description} />\r\n <meta itemProp=\"image\" content={config.siteImage} />\r\n <meta name=\"twitter:card\" content=\"summary_large_image\" />\r\n <meta name=\"twitter:url\" content={metaData.siteUrl} />\r\n <meta name=\"twitter:site\" content={config.twitterHandle} />\r\n <meta name=\"twitter:creator\" content={config.twitterHandle} />\r\n <meta name=\"twitter:title\" content={metaData.title} />\r\n <meta name=\"twitter:description\" content={metaData.description} />\r\n <meta name=\"twitter:image:src\" content={config.siteImage} />\r\n <meta name=\"twitter:image:alt\" content={metaData.title} />\r\n\r\n <link rel=\"apple-touch-icon\" sizes=\"57x57\" href={appleIcon57x57} />\r\n <link rel=\"apple-touch-icon\" sizes=\"60x60\" href={appleIcon60x60} />\r\n <link rel=\"apple-touch-icon\" sizes=\"72x72\" href={appleIcon72x72} />\r\n <link rel=\"apple-touch-icon\" sizes=\"76x76\" href={appleIcon76x76} />\r\n <link rel=\"apple-touch-icon\" sizes=\"114x114\" href={appleIcon114x114} />\r\n <link rel=\"apple-touch-icon\" sizes=\"120x120\" href={appleIcon120x120} />\r\n <link rel=\"apple-touch-icon\" sizes=\"144x144\" href={appleIcon144x144} />\r\n <link rel=\"apple-touch-icon\" sizes=\"152x152\" href={appleIcon152x152} />\r\n <link rel=\"apple-touch-icon\" sizes=\"180x180\" href={appleIcon180x180} />\r\n <link rel=\"icon\" type=\"image/png\" sizes=\"192x192\" href={androidIcon192x192} />\r\n <link rel=\"icon\" type=\"image/png\" sizes=\"32x32\" href={favicon32x32} />\r\n <link rel=\"icon\" type=\"image/png\" sizes=\"96x96\" href={favicon96x96} />\r\n <link rel=\"icon\" type=\"image/png\" sizes=\"16x16\" href={favicon16x16} />\r\n <meta name=\"msapplication-TileColor\" content={config.navyColor} />\r\n <meta name=\"msapplication-TileImage\" content={msIcon144x144} />\r\n <meta name=\"theme-color\" content={config.navyColor} />\r\n </Helmet>\r\n);\r\n\r\nexport default Head;\r\n\r\nHead.propTypes = {\r\n metaData: PropTypes.object.isRequired,\r\n};\r\n","import React, { Component } from 'react';\r\nimport Helmet from 'react-helmet';\r\nimport PropTypes from 'prop-types';\r\n\r\nimport anime from 'animejs';\r\n\r\nimport styled from 'styled-components';\r\nimport { theme, mixins } from '../styles';\r\n\r\nconst LoaderContainer = styled.div`\r\n ${mixins.flexCenter};\r\n background-color: ${theme.colors.darkNavy};\r\n position: fixed;\r\n width: 100%;\r\n height: 100%;\r\n top: 0;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n z-index: 99;\r\n`;\r\nconst LogoWrapper = styled.div`\r\n width: max-content;\r\n max-width: 100px;\r\n transition: ${theme.transition};\r\n opacity: ${props => (props.isMounted ? 1 : 0)};\r\n svg {\r\n width: 100%;\r\n height: 100%;\r\n display: block;\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\nclass Loader extends Component {\r\n static propTypes = {\r\n finishLoading: PropTypes.func.isRequired,\r\n };\r\n\r\n state = {\r\n isMounted: false,\r\n };\r\n\r\n componentDidMount() {\r\n this.setState({ isMounted: true }, () => this.animate());\r\n }\r\n\r\n componentWillUnmount() {\r\n this.setState({ isMounted: false });\r\n }\r\n\r\n animate() {\r\n const loader = anime.timeline({\r\n complete: () => this.props.finishLoading(),\r\n });\r\n\r\n loader\r\n .add({\r\n targets: '#logo path',\r\n delay: 500,\r\n duration: 2000,\r\n easing: 'easeInOutQuart',\r\n strokeDashoffset: [anime.setDashoffset, 0],\r\n })\r\n .add({\r\n targets: '#logo #B',\r\n duration: 800,\r\n easing: 'easeInOutQuart',\r\n opacity: 1,\r\n })\r\n .add({\r\n targets: '#logo',\r\n delay: 700,\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 render() {\r\n const { isMounted } = this.state;\r\n\r\n return (\r\n <LoaderContainer className=\"loader\">\r\n <Helmet>\r\n <body className={isMounted ? 'hidden' : ''} />\r\n </Helmet>\r\n <LogoWrapper isMounted={isMounted}>\r\n <svg id=\"logo\" xmlns=\"https://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\">\r\n <title>Loader Logo</title>\r\n <g>\r\n <path\r\n stroke=\"#fff\"\r\n strokeWidth=\"4\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n d=\"M75,5\r\n l-60,0 0,90\r\n M15,45\r\n l50,0\"\r\n />\r\n </g>\r\n </svg>\r\n </LogoWrapper>\r\n </LoaderContainer>\r\n );\r\n }\r\n}\r\n\r\nexport default Loader;\r\n","export const throttle = (func, wait = 100) => {\r\n let timer = null;\r\n return function(...args) {\r\n if (timer === null) {\r\n timer = setTimeout(() => {\r\n func.apply(this, args);\r\n timer = null;\r\n }, wait);\r\n }\r\n };\r\n};\r\n","import React, { Component } from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport AnchorLink from 'react-anchor-link-smooth-scroll';\r\n\r\nimport resume from '../images/resume.pdf';\r\n\r\nimport styled from 'styled-components';\r\nimport { theme, mixins, media, Nav, Ol, A } from '../styles';\r\n\r\nconst MenuContainer = styled.div`\r\n position: fixed;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n width: 100%;\r\n height: 100vh;\r\n z-index: 10;\r\n outline: 0;\r\n transition: ${theme.transition};\r\n transform: translateX(${props => (props.menuOpen ? 0 : 100)}vw);\r\n visibility: ${props => (props.menuOpen ? 'visible' : 'hidden')};\r\n display: none;\r\n ${media.tablet`display: block;`};\r\n`;\r\nconst Sidebar = styled.div`\r\n ${mixins.flexCenter};\r\n flex-direction: column;\r\n background-color: ${theme.colors.lightNavy};\r\n padding: 50px;\r\n width: 50vw;\r\n height: 100%;\r\n position: relative;\r\n right: 0;\r\n margin-left: auto;\r\n font-family: ${theme.fonts.SFMono};\r\n box-shadow: -2px 0px 4px ${theme.colors.transNavy};\r\n ${media.thone`padding: 25px;`};\r\n ${media.phablet`width: 75vw;`};\r\n ${media.tiny`padding: 10px;`};\r\n`;\r\nconst NavLinks = styled(Nav)`\r\n ${mixins.flexBetween};\r\n flex-direction: column;\r\n text-align: center;\r\n`;\r\nconst NavList = styled(Ol)`\r\n width: 100%;\r\n`;\r\nconst NavListItem = styled.li`\r\n margin: 0 auto 20px;\r\n position: relative;\r\n font-size: ${theme.fontSizes.large};\r\n counter-increment: item 1;\r\n ${media.thone`\r\n margin: 0 auto 10px;\r\n font-size: ${theme.fontSizes.medium};\r\n `};\r\n ${media.tiny`\r\n font-size: ${theme.fontSizes.smallish};\r\n `};\r\n &:before {\r\n display: block;\r\n content: '0' counter(item) '.';\r\n color: ${theme.colors.green};\r\n font-size: ${theme.fontSizes.small};\r\n margin-bottom: 5px;\r\n }\r\n`;\r\nconst NavLink = styled(AnchorLink)`\r\n ${mixins.link};\r\n padding: 3px 20px 20px;\r\n width: 100%;\r\n`;\r\nconst ResumeLink = styled(A)`\r\n ${mixins.bigButton};\r\n padding: 18px 50px;\r\n margin: 10% auto 0;\r\n width: max-content;\r\n`;\r\n\r\nclass Menu extends Component {\r\n static propTypes = {\r\n isHome: PropTypes.bool,\r\n menuOpen: PropTypes.bool.isRequired,\r\n navLinks: PropTypes.array.isRequired,\r\n handleMenuClick: PropTypes.func.isRequired,\r\n };\r\n\r\n render() {\r\n const { isHome, menuOpen, navLinks, handleMenuClick } = this.props;\r\n\r\n return (\r\n <MenuContainer\r\n menuOpen={menuOpen}\r\n onClick={handleMenuClick}\r\n aria-hidden={!menuOpen}\r\n tabIndex={menuOpen ? 1 : -1}>\r\n <Sidebar>\r\n <NavLinks>\r\n {isHome && (\r\n <NavList>\r\n {navLinks &&\r\n navLinks.map(({ url, name }, i) => (\r\n <NavListItem key={i}>\r\n <NavLink href={url}>{name}</NavLink>\r\n </NavListItem>\r\n ))}\r\n </NavList>\r\n )}\r\n <ResumeLink href={resume} target=\"_blank\" rel=\" noopener noreferrer\">\r\n Resume\r\n </ResumeLink>\r\n </NavLinks>\r\n </Sidebar>\r\n </MenuContainer>\r\n );\r\n }\r\n}\r\n\r\nexport default Menu;\r\n","import React, { Component } from 'react';\r\nimport Helmet from 'react-helmet';\r\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\r\nimport PropTypes from 'prop-types';\r\nimport AnchorLink from 'react-anchor-link-smooth-scroll';\r\nimport { Link } from 'gatsby';\r\nimport { throttle } from '../utils';\r\n\r\nimport { headerHeight } from '../config';\r\nimport resume from '../images/resume.pdf';\r\n\r\nimport Menu from '../components/menu';\r\nimport { IconLogo } from './icons';\r\n\r\nimport styled from 'styled-components';\r\nimport { theme, mixins, media, Nav, Ol, A } from '../styles';\r\n\r\nconst HeaderContainer = styled.header`\r\n ${mixins.flexBetween};\r\n position: fixed;\r\n top: 0;\r\n padding: 0px 50px;\r\n background-color: ${theme.colors.navy};\r\n transition: ${theme.transition};\r\n z-index: 11;\r\n filter: none !important;\r\n pointer-events: auto !important;\r\n user-select: auto !important;\r\n width: 100%;\r\n height: ${props =>\r\n props.scrollDirection === 'none' ? theme.headerHeight : theme.headerScrollHeight};\r\n box-shadow: ${props =>\r\n props.scrollDirection === 'up' ? `0 2px 4px ${theme.colors.shadowNavy}` : 'none'};\r\n transform: translateY(\r\n ${props => (props.scrollDirection === 'down' ? `-${theme.headerScrollHeight}` : '0px')}\r\n );\r\n ${media.desktop`padding: 0 40px;`};\r\n ${media.tablet`padding: 0 25px;`};\r\n`;\r\nconst Navbar = styled(Nav)`\r\n ${mixins.flexBetween};\r\n font-family: ${theme.fonts.SFMono};\r\n width: 100%;\r\n color: ${theme.colors.lightestSlate};\r\n counter-reset: item 0;\r\n position: relative;\r\n z-index: 12;\r\n`;\r\nconst Logo = styled.div`\r\n ${mixins.flexCenter};\r\n`;\r\nconst LogoLink = styled(Link)`\r\n color: ${theme.colors.green};\r\n width: 42px;\r\n height: 42px;\r\n &:hover,\r\n &:focus {\r\n svg {\r\n fill: ${theme.colors.transGreen};\r\n }\r\n }\r\n svg {\r\n fill: none;\r\n transition: ${theme.transition};\r\n user-select: none;\r\n }\r\n`;\r\nconst Hamburger = styled.div`\r\n ${mixins.flexCenter};\r\n overflow: visible;\r\n margin: 0 -12px 0 0;\r\n padding: 15px;\r\n cursor: pointer;\r\n transition-timing-function: linear;\r\n transition-duration: 0.15s;\r\n transition-property: opacity, filter;\r\n text-transform: none;\r\n color: inherit;\r\n border: 0;\r\n background-color: transparent;\r\n display: none;\r\n ${media.tablet`display: flex;`};\r\n`;\r\nconst HamburgerBox = styled.div`\r\n position: relative;\r\n display: inline-block;\r\n width: ${theme.hamburgerWidth}px;\r\n height: 24px;\r\n`;\r\nconst HamburgerInner = styled.div`\r\n background-color: ${theme.colors.green};\r\n position: absolute;\r\n width: ${theme.hamburgerWidth}px;\r\n height: 2px;\r\n border-radius: ${theme.borderRadius};\r\n top: 50%;\r\n left: 0;\r\n right: 0;\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 background-color: ${theme.colors.green};\r\n position: absolute;\r\n left: auto;\r\n right: 0;\r\n width: ${theme.hamburgerWidth}px;\r\n height: 2px;\r\n transition-timing-function: ease;\r\n transition-duration: 0.15s;\r\n transition-property: transform;\r\n border-radius: 4px;\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: ${props => (props.menuOpen ? theme.hamBeforeActive : theme.hamBefore)};\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: ${props => (props.menuOpen ? theme.hamAfterActive : theme.hamAfter)};\r\n }\r\n`;\r\nconst NavLinks = styled.div`\r\n display: flex;\r\n align-items: center;\r\n ${media.tablet`display: none;`};\r\n`;\r\nconst NavList = styled(Ol)`\r\n div {\r\n ${mixins.flexBetween};\r\n }\r\n`;\r\nconst NavListItem = styled.li`\r\n margin: 0 10px;\r\n position: relative;\r\n font-size: ${theme.fontSizes.smallish};\r\n counter-increment: item 1;\r\n &:before {\r\n content: '0' counter(item) '.';\r\n text-align: right;\r\n color: ${theme.colors.green};\r\n font-size: ${theme.fontSizes.xsmall};\r\n }\r\n`;\r\nconst NavLink = styled(AnchorLink)`\r\n ${mixins.link};\r\n padding: 12px 10px;\r\n`;\r\nconst ResumeButton = styled.div``;\r\nconst ResumeLink = styled(A)`\r\n ${mixins.smallButton};\r\n margin-left: 10px;\r\n font-size: ${theme.fontSizes.smallish};\r\n`;\r\n\r\nconst DELTA = 5;\r\n\r\nclass Header extends Component {\r\n static propTypes = {\r\n location: PropTypes.object,\r\n navLinks: PropTypes.array.isRequired,\r\n };\r\n\r\n state = {\r\n lastScrollTop: 0,\r\n scrollDirection: 'none',\r\n menuOpen: false,\r\n isMounted: false,\r\n };\r\n\r\n componentDidMount() {\r\n setTimeout(() => this.setState({ isMounted: true }), 100);\r\n\r\n window.addEventListener('scroll', () => throttle(this.handleScroll()));\r\n window.addEventListener('resize', () => throttle(this.handleResize()));\r\n window.addEventListener('keydown', () => this.handleKeydown());\r\n }\r\n\r\n componentWillUnmount() {\r\n window.removeEventListener('scroll', () => this.handleScroll());\r\n window.removeEventListener('resize', () => this.handleResize());\r\n window.removeEventListener('keydown', () => this.handleKeydown());\r\n }\r\n\r\n handleScroll = () => {\r\n const { lastScrollTop, menuOpen, scrollDirection } = this.state;\r\n const fromTop = window.scrollY;\r\n\r\n // Make sure they scroll more than DELTA\r\n if (Math.abs(lastScrollTop - fromTop) <= DELTA || menuOpen) {\r\n return;\r\n }\r\n\r\n if (fromTop < DELTA) {\r\n this.setState({ scrollDirection: 'none' });\r\n } else if (fromTop > lastScrollTop && fromTop > headerHeight) {\r\n if (scrollDirection !== 'down') {\r\n this.setState({ scrollDirection: 'down' });\r\n }\r\n } else if (fromTop + window.innerHeight < document.body.scrollHeight) {\r\n if (scrollDirection !== 'up') {\r\n this.setState({ scrollDirection: 'up' });\r\n }\r\n }\r\n\r\n this.setState({ lastScrollTop: fromTop });\r\n };\r\n\r\n handleResize = () => {\r\n const { menuOpen } = this.state;\r\n\r\n if (window.innerWidth > 768 && menuOpen) {\r\n this.toggleMenu();\r\n }\r\n };\r\n\r\n handleKeydown = evt => {\r\n const { menuOpen } = this.state;\r\n\r\n if (!menuOpen) {\r\n return;\r\n }\r\n\r\n if (evt.key === 'Escape' || evt.key === 'Esc') {\r\n this.toggleMenu();\r\n }\r\n };\r\n\r\n toggleMenu = () => this.setState({ menuOpen: !this.state.menuOpen });\r\n\r\n handleMenuClick = e => {\r\n const target = e.target;\r\n const isLink = target.hasAttribute('href');\r\n const isContainer = target.classList && target.classList[0].includes('MenuContainer');\r\n\r\n if (isLink || isContainer) {\r\n this.toggleMenu();\r\n }\r\n };\r\n\r\n render() {\r\n const { scrollDirection, menuOpen, isMounted } = this.state;\r\n const { location, navLinks } = this.props;\r\n const isHome = location && location.pathname === '/';\r\n\r\n return (\r\n <HeaderContainer innerRef={el => (this.header = el)} scrollDirection={scrollDirection}>\r\n <Helmet>\r\n <body className={menuOpen ? 'blur' : ''} />\r\n </Helmet>\r\n <Navbar>\r\n <TransitionGroup>\r\n {isMounted && (\r\n <CSSTransition classNames=\"fade\" timeout={3000}>\r\n <Logo>\r\n <LogoLink to=\"/\" aria-label=\"Home\">\r\n <IconLogo />\r\n </LogoLink>\r\n </Logo>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n\r\n <TransitionGroup>\r\n {isMounted && (\r\n <CSSTransition classNames=\"fade\" timeout={3000}>\r\n <Hamburger onClick={this.toggleMenu}>\r\n <HamburgerBox>\r\n <HamburgerInner menuOpen={menuOpen} />\r\n </HamburgerBox>\r\n </Hamburger>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n\r\n <NavLinks>\r\n {isHome && (\r\n <NavList>\r\n <TransitionGroup>\r\n {isMounted &&\r\n navLinks &&\r\n navLinks.map(({ url, name }, i) => (\r\n <CSSTransition key={i} classNames=\"fadedown\" timeout={3000}>\r\n <NavListItem key={i} style={{ transitionDelay: `${i * 100}ms` }}>\r\n <NavLink href={url}>{name}</NavLink>\r\n </NavListItem>\r\n </CSSTransition>\r\n ))}\r\n </TransitionGroup>\r\n </NavList>\r\n )}\r\n <TransitionGroup>\r\n {isMounted && (\r\n <CSSTransition classNames=\"fadedown\" timeout={3000}>\r\n <ResumeButton style={{ transitionDelay: `600ms` }}>\r\n <ResumeLink href={resume} target=\"_blank\" rel=\" noopener noreferrer\">\r\n Resume\r\n </ResumeLink>\r\n </ResumeButton>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n </NavLinks>\r\n </Navbar>\r\n\r\n <Menu\r\n isHome={isHome}\r\n navLinks={navLinks}\r\n menuOpen={menuOpen}\r\n handleMenuClick={e => this.handleMenuClick(e)}\r\n />\r\n </HeaderContainer>\r\n );\r\n }\r\n}\r\n\r\nexport default Header;\r\n","import React, { Component } from 'react';\r\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\r\n\r\nimport { socialMedia } from '../config';\r\n\r\nimport { IconGithub, IconLinkedin, IconCodepen, IconInstagram, IconTwitter } from './icons';\r\n\r\nimport styled from 'styled-components';\r\nimport { theme, media, A, Ul } from '../styles';\r\n\r\nconst SocialContainer = styled.div`\r\n width: 40px;\r\n position: fixed;\r\n bottom: 0;\r\n left: 40px;\r\n color: ${theme.colors.lightSlate};\r\n ${media.desktop`left: 25px;`};\r\n ${media.tablet`display: none;`};\r\n`;\r\nconst SocialItemList = styled(Ul)`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\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: ${theme.colors.lightSlate};\r\n }\r\n`;\r\nconst SocialItem = styled.li`\r\n &:last-of-type {\r\n margin-bottom: 20px;\r\n }\r\n`;\r\nconst SocialLink = styled(A)`\r\n padding: 10px;\r\n svg {\r\n width: 18px;\r\n height: 18px;\r\n }\r\n`;\r\n\r\nclass Social extends Component {\r\n state = {\r\n isMounted: false,\r\n };\r\n\r\n componentDidMount() {\r\n setTimeout(() => this.setState({ isMounted: true }), 2000);\r\n }\r\n\r\n render() {\r\n const { isMounted } = this.state;\r\n\r\n return (\r\n <SocialContainer>\r\n <TransitionGroup>\r\n {isMounted && (\r\n <CSSTransition timeout={3000} classNames=\"fade\">\r\n <SocialItemList>\r\n {socialMedia &&\r\n socialMedia.map(({ url, name }, i) => (\r\n <SocialItem key={i}>\r\n <SocialLink\r\n href={url}\r\n target=\"_blank\"\r\n rel=\" noopener noreferrer\"\r\n aria-label={name}>\r\n {name === 'Github' ? (\r\n <IconGithub />\r\n ) : name === 'Linkedin' ? (\r\n <IconLinkedin />\r\n ) : name === 'Codepen' ? (\r\n <IconCodepen />\r\n ) : name === 'Instagram' ? (\r\n <IconInstagram />\r\n ) : name === 'Twitter' ? (\r\n <IconTwitter />\r\n ) : (\r\n <IconGithub />\r\n )}\r\n </SocialLink>\r\n </SocialItem>\r\n ))}\r\n </SocialItemList>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n </SocialContainer>\r\n );\r\n }\r\n}\r\n\r\nexport default Social;\r\n","import React, { Component } from 'react';\r\nimport { CSSTransition, TransitionGroup } from 'react-transition-group';\r\n\r\nimport { email } from '../config';\r\n\r\nimport styled from 'styled-components';\r\nimport { theme, media, A } from '../styles';\r\n\r\nconst EmailContainer = styled.div`\r\n width: 40px;\r\n position: fixed;\r\n bottom: 0;\r\n right: 40px;\r\n color: ${theme.colors.lightSlate};\r\n ${media.desktop`right: 25px;`};\r\n ${media.tablet`display: none;`};\r\n div {\r\n width: 100%;\r\n margin: 0 auto;\r\n }\r\n`;\r\nconst EmailLinkWrapper = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n position: relative;\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: ${theme.colors.lightSlate};\r\n }\r\n`;\r\nconst EmailLink = styled(A)`\r\n font-family: ${theme.fonts.SFMono};\r\n font-size: ${theme.fontSizes.xsmall};\r\n letter-spacing: 0.5px;\r\n writing-mode: vertical-rl;\r\n margin: 20px auto;\r\n padding: 10px;\r\n`;\r\n\r\nclass Email extends Component {\r\n state = {\r\n isMounted: false,\r\n };\r\n\r\n componentDidMount() {\r\n setTimeout(() => this.setState({ isMounted: true }), 2000);\r\n }\r\n\r\n render() {\r\n const { isMounted } = this.state;\r\n\r\n return (\r\n <EmailContainer>\r\n <TransitionGroup>\r\n {isMounted && (\r\n <CSSTransition timeout={3000} classNames=\"fade\">\r\n <EmailLinkWrapper>\r\n <EmailLink href={`mailto:${email}`}>{email}</EmailLink>\r\n </EmailLinkWrapper>\r\n </CSSTransition>\r\n )}\r\n </TransitionGroup>\r\n </EmailContainer>\r\n );\r\n }\r\n}\r\n\r\nexport default Email;\r\n","import React from 'react';\r\n\r\nimport { socialMedia } from '../config';\r\n\r\nimport { IconGithub, IconLinkedin, IconCodepen, IconInstagram, IconTwitter } from './icons';\r\n\r\nimport styled from 'styled-components';\r\nimport { theme, mixins, media, A, P, Ul } from '../styles';\r\n\r\nconst FooterContainer = styled.footer`\r\n ${mixins.flexCenter};\r\n flex-direction: column;\r\n padding: 15px;\r\n background-color: ${theme.colors.darkNavy};\r\n color: ${theme.colors.slate};\r\n text-align: center;\r\n height: auto;\r\n`;\r\nconst SocialContainer = styled.div`\r\n color: ${theme.colors.lightSlate};\r\n width: 100%;\r\n max-width: 270px;\r\n margin: 0 auto 10px;\r\n display: none;\r\n ${media.tablet`display: block;`};\r\n`;\r\nconst SocialItemList = styled(Ul)`\r\n ${mixins.flexBetween};\r\n`;\r\nconst SocialItem = styled.li``;\r\nconst SocialLink = styled(A)`\r\n padding: 10px;\r\n svg {\r\n width: 20px;\r\n height: 20px;\r\n }\r\n`;\r\nconst Copy = styled(P)`\r\n margin: 5px 0 3px;\r\n`;\r\nconst GithubLink = styled(A)`\r\n ${mixins.link};\r\n color: ${theme.colors.slate};\r\n font-family: ${theme.fonts.SFMono};\r\n font-size: ${theme.fontSizes.xsmall};\r\n`;\r\n\r\nconst Footer = () => (\r\n <FooterContainer>\r\n <SocialContainer>\r\n <SocialItemList>\r\n {socialMedia &&\r\n socialMedia.map(({ name, url }, i) => (\r\n <SocialItem key={i}>\r\n <SocialLink\r\n href={url}\r\n target=\"_blank\"\r\n rel=\" noopener noreferrer\"\r\n aria-label={name}>\r\n {name === 'Github' ? (\r\n <IconGithub />\r\n ) : name === 'Linkedin' ? (\r\n <IconLinkedin />\r\n ) : name === 'Codepen' ? (\r\n <IconCodepen />\r\n ) : name === 'Instagram' ? (\r\n <IconInstagram />\r\n ) : name === 'Twitter' ? (\r\n <IconTwitter />\r\n ) : (\r\n <IconGithub />\r\n )}\r\n </SocialLink>\r\n </SocialItem>\r\n ))}\r\n </SocialItemList>\r\n </SocialContainer>\r\n <Copy>\r\n <GithubLink\r\n href=\"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/bchiang7/v4\"\r\n target=\"_blank\"\r\n rel=\" noopener noreferrer\">\r\n Credit to Brittany Chiang\r\n </GithubLink>\r\n </Copy>\r\n </FooterContainer>\r\n);\r\n\r\nexport default Footer;\r\n","import React, { Component } from 'react';\r\nimport { StaticQuery, graphql } from 'gatsby';\r\nimport PropTypes from 'prop-types';\r\n\r\nimport { nav } from '../config';\r\n\r\nimport Head from '../components/head';\r\nimport Loader from '../components/loader';\r\nimport Header from '../components/header';\r\nimport Social from '../components/social';\r\nimport Email from '../components/email';\r\nimport Footer from '../components/footer';\r\n\r\nimport styled from 'styled-components';\r\nimport '../styles/base';\r\nimport { theme, A } from '../styles';\r\n\r\nconst SkipToContent = styled(A)`\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 &:hover {\r\n background-color: ${theme.colors.darkGrey};\r\n }\r\n &:focus,\r\n &:active {\r\n outline: 0;\r\n color: ${theme.colors.green};\r\n background-color: ${theme.colors.lightNavy};\r\n border-radius: ${theme.borderRadius};\r\n padding: 18px 23px;\r\n font-size: ${theme.fontSizes.small};\r\n font-family: ${theme.fonts.SFMono};\r\n line-height: 1;\r\n text-decoration: none;\r\n cursor: pointer;\r\n transition: ${theme.transition};\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\nclass Layout extends Component {\r\n static propTypes = {\r\n children: PropTypes.node.isRequired,\r\n location: PropTypes.object,\r\n };\r\n\r\n state = {\r\n isLoading: true,\r\n };\r\n\r\n finishLoading = () => this.setState({ isLoading: false });\r\n\r\n render() {\r\n const { children, location } = this.props;\r\n const { isLoading } = this.state;\r\n\r\n return (\r\n <StaticQuery\r\n query={graphql`\r\n query LayoutQuery {\r\n site {\r\n siteMetadata {\r\n title\r\n siteUrl\r\n description\r\n }\r\n }\r\n }\r\n `}\r\n render={data => (\r\n <div id=\"root\">\r\n <Head metaData={data.site.siteMetadata} />\r\n\r\n <SkipToContent href=\"#content\">Skip To Content</SkipToContent>\r\n\r\n {isLoading ? (\r\n <Loader finishLoading={this.finishLoading} />\r\n ) : (\r\n <div className=\"container\">\r\n <Header location={location} navLinks={nav} />\r\n <Social />\r\n <Email />\r\n {children}\r\n <Footer />\r\n </div>\r\n )}\r\n </div>\r\n )}\r\n />\r\n );\r\n }\r\n}\r\n\r\nexport default Layout;\r\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\n\nimport InternalPageRenderer from \"./page-renderer\"\nimport loader from \"./loader\"\n\nconst ProdPageRenderer = ({ location }) => {\n const pageResources = loader.getResourcesForPathnameSync(location.pathname)\n return React.createElement(InternalPageRenderer, {\n location,\n pageResources,\n ...pageResources.json,\n })\n}\n\nProdPageRenderer.propTypes = {\n location: PropTypes.shape({\n pathname: PropTypes.string.isRequired,\n }).isRequired,\n}\n\nexport default ProdPageRenderer\n","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\""],"sourceRoot":""}