{"version":3,"sources":["webpack:///./src/templates/template-blog-page.js","webpack:///./src/components/container.js","webpack:///./node_modules/core-js/modules/es6.string.fixed.js","webpack:///./node_modules/gatsby-image/index.js","webpack:///./node_modules/gatsby-image/node_modules/prop-types/index.js","webpack:///./node_modules/gatsby-image/node_modules/prop-types/factoryWithThrowingShims.js","webpack:///./node_modules/gatsby-image/node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack:///./src/monogram.svg","webpack:///./src/components/blog-post-preview-item.js"],"names":["BlogPostsIndex","_ref","_ref2","_ref3","_ref4","_ref7","data","location","allMarkdownRemark","allCategoriesYaml","blogSidebar","items","title","link","concat","edges","map","edge","node","fields","name","slug","Glamor","createElement","_components_layout__WEBPACK_IMPORTED_MODULE_6__","css","flex","presets","Tablet","paddingBottom","rhythm","options","blockMarginBottom","react_helmet__WEBPACK_IMPORTED_MODULE_3___default","a","_components_container__WEBPACK_IMPORTED_MODULE_5__","background","logo","backgroundSize","backgroundRepeat","backgroundPosition","color","colors","zoomdataGreen","marginTop","position","width","height","padding","overflow","clip","whiteSpace","clipPath","textAlign","_ref5","_ref6","_components_blog_post_preview_item__WEBPACK_IMPORTED_MODULE_4__","post","key","marginBottom","borderRadius","radiusLg","boxShadow","paddingLeft","paddingRight","transition","animation","speedDefault","curveDefault","&:hover","transform","&:active","Desktop","marginLeft","marginRight","Hd","display","_components_sidebar_body__WEBPACK_IMPORTED_MODULE_7__","inline","yaml","propTypes","PropTypes","object","pageQuery","Container","_Object$assign","children","className","_ref$hasSideBar","hasSideBar","_ref$css","Object","assign","maxWidth","margin","maxWidthWithSidebar","isRequired","oneOfType","string","bool","__webpack_require__","createHTML","this","_interopRequireDefault","exports","__esModule","default","io","_inheritsLoose2","_assertThisInitialized2","_objectWithoutPropertiesLoose2","_extends2","_react","_propTypes","convertProps","props","convertedProps","resolutions","fixed","sizes","fluid","imageCache","inImageCache","src","listeners","listenToIntersections","el","cb","window","IntersectionObserver","entries","forEach","entry","l","target","isIntersecting","intersectionRatio","unobserve","rootMargin","observe","push","noscriptImg","srcSetWebp","srcSet","alt","opacity","transitionDelay","Img","forwardRef","ref","style","onLoad","onError","otherProps","top","left","objectFit","objectPosition","func","Image","_React$Component","_this","call","isVisible","IOSupported","fadeIn","seenBefore","critical","hasNoScript","state","imgLoaded","imageRef","createRef","handleImageLoaded","bind","handleRef","_proto","prototype","componentDidMount","onStartLoad","wasCached","img","current","complete","_this2","setState","render","_convertProps","_convertProps$style","_convertProps$imgStyl","imgStyle","_convertProps$placeho","placeholderStyle","placeholderClassName","backgroundColor","Tag","bgColor","imagePlaceholderStyle","imageStyle","placeholderImageProps","image","JSON","stringify","aspectRatio","base64","tracedSVG","bottom","right","type","dangerouslySetInnerHTML","__html","_image","divStyle","Component","defaultProps","fixedObject","shape","number","srcWebp","fluidObject","_default","module","ReactPropTypesSecret","emptyFunction","shim","propName","componentName","propFullName","secret","err","Error","getShim","ReactPropTypes","array","symbol","any","arrayOf","element","instanceOf","objectOf","oneOf","exact","checkPropTypes","BlogPostPreviewItem","avatar","frontmatter","author","childImageSharp","gatsby__WEBPACK_IMPORTED_MODULE_2__","to","fontWeight","excerpt","alignItems","gatsby_image__WEBPACK_IMPORTED_MODULE_3___default","id","verticalAlign","fontFamily","headerFontFamily","join","gray","calm","scale","Mobile","borderBottom","zIndex","&&",":hover","date","textIndent","border"],"mappings":"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","file":"component---src-templates-template-blog-page-js-0f6c61206eff4d8cf0d4.js","sourcesContent":["import { graphql } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport Helmet from 'react-helmet';\nimport BlogPostPreviewItem from '../components/blog-post-preview-item';\nimport Container from '../components/container';\nimport Layout from '../components/layout';\n\nimport SidebarBody from '../components/sidebar-body';\nimport logo from '../monogram.svg';\n\nimport presets from '../utils/presets';\nimport { options, rhythm } from '../utils/typography';\n\nconst BlogPostsIndex = ({ data, location }) => {\n const { allMarkdownRemark, allCategoriesYaml } = data;\n const blogSidebar = [\n {\n items: [{ title: `All`, link: `/blog/` }].concat(\n allCategoriesYaml.edges.map(edge => ({\n title: edge.node.fields.name,\n link: edge.node.fields.slug,\n })),\n ),\n title: `Categories`,\n },\n ];\n\n return (\n \n \n \n Developer Blog\n \n \n \n Developer Blog\n \n {!allMarkdownRemark && (\n \n No blog posts available for this category\n \n )}\n {allMarkdownRemark &&\n allMarkdownRemark.edges.map(({ node }) => (\n \n ))}\n \n \n \n \n \n \n );\n};\n\nBlogPostsIndex.propTypes = {\n data: PropTypes.object,\n location: PropTypes.object,\n};\n\nexport default BlogPostsIndex;\n\n// eslint-disable-next-line no-undef\nexport const pageQuery = graphql`\n query($name: String!) {\n allMarkdownRemark(\n sort: { order: DESC, fields: [frontmatter___date] }\n filter: {\n frontmatter: { tags: { in: [$name] }, draft: { ne: true } }\n fileAbsolutePath: { regex: \"/content.blog/\" }\n }\n ) {\n edges {\n node {\n ...BlogPostPreview_item\n }\n }\n }\n allCategoriesYaml {\n edges {\n node {\n fields {\n name\n slug\n }\n }\n }\n }\n }\n`;\n","import PropTypes from 'prop-types';\nimport React from 'react';\nimport presets from '../utils/presets';\n\nimport { options, rhythm } from '../utils/typography';\n\nconst Container = ({ children, className, hasSideBar = true, css = {} }) => (\n \n {children}\n \n);\n\nContainer.propTypes = {\n children: PropTypes.node.isRequired,\n className: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n hasSideBar: PropTypes.bool,\n css: PropTypes.object,\n};\n\nexport default Container;\n","'use strict';\n// B.2.3.6 String.prototype.fixed()\nrequire('./_string-html')('fixed', function (createHTML) {\n return function fixed() {\n return createHTML(this, 'tt', '', '');\n };\n});\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _objectWithoutPropertiesLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutPropertiesLoose\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\n// Handle legacy names for image queries.\nvar convertProps = function convertProps(props) {\n var convertedProps = (0, _extends2.default)({}, props);\n\n if (convertedProps.resolutions) {\n convertedProps.fixed = convertedProps.resolutions;\n delete convertedProps.resolutions;\n }\n\n if (convertedProps.sizes) {\n convertedProps.fluid = convertedProps.sizes;\n delete convertedProps.sizes;\n }\n\n return convertedProps;\n}; // Cache if we've seen an image before so we don't both with\n// lazy-loading & fading in on subsequent mounts.\n\n\nvar imageCache = {};\n\nvar inImageCache = function inImageCache(props) {\n var convertedProps = convertProps(props); // Find src\n\n var src = convertedProps.fluid ? convertedProps.fluid.src : convertedProps.fixed.src;\n return imageCache[src] || false;\n};\n\nvar activateCacheForImage = function activateCacheForImage(props) {\n var convertedProps = convertProps(props); // Find src\n\n var src = convertedProps.fluid ? convertedProps.fluid.src : convertedProps.fixed.src;\n imageCache[src] = true;\n};\n\nvar io;\nvar listeners = [];\n\nfunction getIO() {\n if (typeof io === \"undefined\" && typeof window !== \"undefined\" && window.IntersectionObserver) {\n io = new window.IntersectionObserver(function (entries) {\n entries.forEach(function (entry) {\n listeners.forEach(function (l) {\n if (l[0] === entry.target) {\n // Edge doesn't currently support isIntersecting, so also test for an intersectionRatio > 0\n if (entry.isIntersecting || entry.intersectionRatio > 0) {\n io.unobserve(l[0]);\n l[1]();\n }\n }\n });\n });\n }, {\n rootMargin: \"200px\"\n });\n }\n\n return io;\n}\n\nvar listenToIntersections = function listenToIntersections(el, cb) {\n getIO().observe(el);\n listeners.push([el, cb]);\n};\n\nvar noscriptImg = function noscriptImg(props) {\n // Check if prop exists before adding each attribute to the string output below to prevent\n // HTML validation issues caused by empty values like width=\"\" and height=\"\"\n var src = props.src ? \"src=\\\"\" + props.src + \"\\\" \" : \"src=\\\"\\\" \"; // required attribute\n\n var sizes = props.sizes ? \"sizes=\\\"\" + props.sizes + \"\\\" \" : \"\";\n var srcSetWebp = props.srcSetWebp ? \"\" : \"\";\n var srcSet = props.srcSet ? \"\" : \"\";\n var title = props.title ? \"title=\\\"\" + props.title + \"\\\" \" : \"\";\n var alt = props.alt ? \"alt=\\\"\" + props.alt + \"\\\" \" : \"alt=\\\"\\\" \"; // required attribute\n\n var width = props.width ? \"width=\\\"\" + props.width + \"\\\" \" : \"\";\n var height = props.height ? \"height=\\\"\" + props.height + \"\\\" \" : \"\";\n var opacity = props.opacity ? props.opacity : \"1\";\n var transitionDelay = props.transitionDelay ? props.transitionDelay : \"0.5s\";\n return \"\" + srcSetWebp + srcSet + \"\";\n};\n\nvar Img = _react.default.forwardRef(function (props, ref) {\n var style = props.style,\n onLoad = props.onLoad,\n onError = props.onError,\n otherProps = (0, _objectWithoutPropertiesLoose2.default)(props, [\"style\", \"onLoad\", \"onError\"]);\n return _react.default.createElement(\"img\", (0, _extends2.default)({}, otherProps, {\n onLoad: onLoad,\n onError: onError,\n ref: ref,\n style: (0, _extends2.default)({\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: \"100%\",\n objectFit: \"cover\",\n objectPosition: \"center\"\n }, style)\n }));\n});\n\nImg.propTypes = {\n style: _propTypes.default.object,\n onError: _propTypes.default.func,\n onLoad: _propTypes.default.func\n};\n\nvar Image =\n/*#__PURE__*/\nfunction (_React$Component) {\n (0, _inheritsLoose2.default)(Image, _React$Component);\n\n function Image(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this; // default settings for browser without Intersection Observer available\n\n var isVisible = true;\n var imgLoaded = false;\n var IOSupported = false;\n var fadeIn = props.fadeIn; // If this image has already been loaded before then we can assume it's\n // already in the browser cache so it's cheap to just show directly.\n\n var seenBefore = inImageCache(props); // browser with Intersection Observer available\n\n if (!seenBefore && typeof window !== \"undefined\" && window.IntersectionObserver) {\n isVisible = false;\n IOSupported = true;\n } // Never render image during SSR\n\n\n if (typeof window === \"undefined\") {\n isVisible = false;\n } // Force render for critical images\n\n\n if (props.critical) {\n isVisible = true;\n IOSupported = false;\n }\n\n var hasNoScript = !(_this.props.critical && !_this.props.fadeIn);\n _this.state = {\n isVisible: isVisible,\n imgLoaded: imgLoaded,\n IOSupported: IOSupported,\n fadeIn: fadeIn,\n hasNoScript: hasNoScript,\n seenBefore: seenBefore\n };\n _this.imageRef = _react.default.createRef();\n _this.handleImageLoaded = _this.handleImageLoaded.bind((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)));\n _this.handleRef = _this.handleRef.bind((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)));\n return _this;\n }\n\n var _proto = Image.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n if (this.state.isVisible && typeof this.props.onStartLoad === \"function\") {\n this.props.onStartLoad({\n wasCached: inImageCache(this.props)\n });\n }\n\n if (this.props.critical) {\n var img = this.imageRef.current;\n\n if (img && img.complete) {\n this.handleImageLoaded();\n }\n }\n };\n\n _proto.handleRef = function handleRef(ref) {\n var _this2 = this;\n\n if (this.state.IOSupported && ref) {\n listenToIntersections(ref, function () {\n if (!_this2.state.isVisible && typeof _this2.props.onStartLoad === \"function\") {\n _this2.props.onStartLoad({\n wasCached: inImageCache(_this2.props)\n });\n }\n\n _this2.setState({\n isVisible: true,\n imgLoaded: false\n });\n });\n }\n };\n\n _proto.handleImageLoaded = function handleImageLoaded() {\n activateCacheForImage(this.props);\n this.setState({\n imgLoaded: true\n });\n\n if (this.state.seenBefore) {\n this.setState({\n fadeIn: false\n });\n }\n\n if (this.props.onLoad) {\n this.props.onLoad();\n }\n };\n\n _proto.render = function render() {\n var _convertProps = convertProps(this.props),\n title = _convertProps.title,\n alt = _convertProps.alt,\n className = _convertProps.className,\n _convertProps$style = _convertProps.style,\n style = _convertProps$style === void 0 ? {} : _convertProps$style,\n _convertProps$imgStyl = _convertProps.imgStyle,\n imgStyle = _convertProps$imgStyl === void 0 ? {} : _convertProps$imgStyl,\n _convertProps$placeho = _convertProps.placeholderStyle,\n placeholderStyle = _convertProps$placeho === void 0 ? {} : _convertProps$placeho,\n placeholderClassName = _convertProps.placeholderClassName,\n fluid = _convertProps.fluid,\n fixed = _convertProps.fixed,\n backgroundColor = _convertProps.backgroundColor,\n Tag = _convertProps.Tag;\n\n var bgColor = typeof backgroundColor === \"boolean\" ? \"lightgray\" : backgroundColor;\n var imagePlaceholderStyle = (0, _extends2.default)({\n opacity: this.state.imgLoaded ? 0 : 1,\n transition: \"opacity 0.5s\",\n transitionDelay: this.state.imgLoaded ? \"0.5s\" : \"0.25s\"\n }, imgStyle, placeholderStyle);\n var imageStyle = (0, _extends2.default)({\n opacity: this.state.imgLoaded || this.state.fadeIn === false ? 1 : 0,\n transition: this.state.fadeIn === true ? \"opacity 0.5s\" : \"none\"\n }, imgStyle);\n var placeholderImageProps = {\n title: title,\n alt: !this.state.isVisible ? alt : \"\",\n style: imagePlaceholderStyle,\n className: placeholderClassName\n };\n\n if (fluid) {\n var image = fluid;\n return _react.default.createElement(Tag, {\n className: (className ? className : \"\") + \" gatsby-image-wrapper\",\n style: (0, _extends2.default)({\n position: \"relative\",\n overflow: \"hidden\"\n }, style),\n ref: this.handleRef,\n key: \"fluid-\" + JSON.stringify(image.srcSet)\n }, _react.default.createElement(Tag, {\n style: {\n width: \"100%\",\n paddingBottom: 100 / image.aspectRatio + \"%\"\n }\n }), image.base64 && _react.default.createElement(Img, (0, _extends2.default)({\n src: image.base64\n }, placeholderImageProps)), image.tracedSVG && _react.default.createElement(Img, (0, _extends2.default)({\n src: image.tracedSVG\n }, placeholderImageProps)), bgColor && _react.default.createElement(Tag, {\n title: title,\n style: {\n backgroundColor: bgColor,\n position: \"absolute\",\n top: 0,\n bottom: 0,\n opacity: !this.state.imgLoaded ? 1 : 0,\n transitionDelay: \"0.35s\",\n right: 0,\n left: 0\n }\n }), this.state.isVisible && _react.default.createElement(\"picture\", null, image.srcSetWebp && _react.default.createElement(\"source\", {\n type: \"image/webp\",\n srcSet: image.srcSetWebp,\n sizes: image.sizes\n }), _react.default.createElement(\"source\", {\n srcSet: image.srcSet,\n sizes: image.sizes\n }), _react.default.createElement(Img, {\n alt: alt,\n title: title,\n src: image.src,\n style: imageStyle,\n ref: this.imageRef,\n onLoad: this.handleImageLoaded,\n onError: this.props.onError\n })), this.state.hasNoScript && _react.default.createElement(\"noscript\", {\n dangerouslySetInnerHTML: {\n __html: noscriptImg((0, _extends2.default)({\n alt: alt,\n title: title\n }, image))\n }\n }));\n }\n\n if (fixed) {\n var _image = fixed;\n var divStyle = (0, _extends2.default)({\n position: \"relative\",\n overflow: \"hidden\",\n display: \"inline-block\",\n width: _image.width,\n height: _image.height\n }, style);\n\n if (style.display === \"inherit\") {\n delete divStyle.display;\n }\n\n return _react.default.createElement(Tag, {\n className: (className ? className : \"\") + \" gatsby-image-wrapper\",\n style: divStyle,\n ref: this.handleRef,\n key: \"fixed-\" + JSON.stringify(_image.srcSet)\n }, _image.base64 && _react.default.createElement(Img, (0, _extends2.default)({\n src: _image.base64\n }, placeholderImageProps)), _image.tracedSVG && _react.default.createElement(Img, (0, _extends2.default)({\n src: _image.tracedSVG\n }, placeholderImageProps)), bgColor && _react.default.createElement(Tag, {\n title: title,\n style: {\n backgroundColor: bgColor,\n width: _image.width,\n opacity: !this.state.imgLoaded ? 1 : 0,\n transitionDelay: \"0.25s\",\n height: _image.height\n }\n }), this.state.isVisible && _react.default.createElement(\"picture\", null, _image.srcSetWebp && _react.default.createElement(\"source\", {\n type: \"image/webp\",\n srcSet: _image.srcSetWebp,\n sizes: _image.sizes\n }), _react.default.createElement(\"source\", {\n srcSet: _image.srcSet,\n sizes: _image.sizes\n }), _react.default.createElement(Img, {\n alt: alt,\n title: title,\n width: _image.width,\n height: _image.height,\n src: _image.src,\n style: imageStyle,\n ref: this.imageRef,\n onLoad: this.handleImageLoaded,\n onError: this.props.onError\n })), this.state.hasNoScript && _react.default.createElement(\"noscript\", {\n dangerouslySetInnerHTML: {\n __html: noscriptImg((0, _extends2.default)({\n alt: alt,\n title: title,\n width: _image.width,\n height: _image.height\n }, _image))\n }\n }));\n }\n\n return null;\n };\n\n return Image;\n}(_react.default.Component);\n\nImage.defaultProps = {\n critical: false,\n fadeIn: true,\n alt: \"\",\n Tag: \"div\"\n};\n\nvar fixedObject = _propTypes.default.shape({\n width: _propTypes.default.number.isRequired,\n height: _propTypes.default.number.isRequired,\n src: _propTypes.default.string.isRequired,\n srcSet: _propTypes.default.string.isRequired,\n base64: _propTypes.default.string,\n tracedSVG: _propTypes.default.string,\n srcWebp: _propTypes.default.string,\n srcSetWebp: _propTypes.default.string\n});\n\nvar fluidObject = _propTypes.default.shape({\n aspectRatio: _propTypes.default.number.isRequired,\n src: _propTypes.default.string.isRequired,\n srcSet: _propTypes.default.string.isRequired,\n sizes: _propTypes.default.string.isRequired,\n base64: _propTypes.default.string,\n tracedSVG: _propTypes.default.string,\n srcWebp: _propTypes.default.string,\n srcSetWebp: _propTypes.default.string\n});\n\nImage.propTypes = {\n resolutions: fixedObject,\n sizes: fluidObject,\n fixed: fixedObject,\n fluid: fluidObject,\n fadeIn: _propTypes.default.bool,\n title: _propTypes.default.string,\n alt: _propTypes.default.string,\n className: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.object]),\n // Support Glamor's css prop.\n critical: _propTypes.default.bool,\n style: _propTypes.default.object,\n imgStyle: _propTypes.default.object,\n placeholderStyle: _propTypes.default.object,\n placeholderClassName: _propTypes.default.string,\n backgroundColor: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.bool]),\n onLoad: _propTypes.default.func,\n onError: _propTypes.default.func,\n onStartLoad: _propTypes.default.func,\n Tag: _propTypes.default.string\n};\nvar _default = Image;\nexports.default = _default;","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var REACT_ELEMENT_TYPE = (typeof Symbol === 'function' &&\n Symbol.for &&\n Symbol.for('react.element')) ||\n 0xeac7;\n\n var isValidElement = function(object) {\n return typeof object === 'object' &&\n object !== null &&\n object.$$typeof === REACT_ELEMENT_TYPE;\n };\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(isValidElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim\n };\n\n ReactPropTypes.checkPropTypes = emptyFunction;\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","module.exports = \"data:image/svg+xml;base64,<svg width="1200" height="1200" viewBox="0 0 1200 1200" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<title>monogram</title>
<desc>Created using Figma</desc>
<g id="Canvas" transform="translate(196 260)">
<clipPath id="clip-0" clip-rule="evenodd">
<path d="M -196 -260L 1004 -260L 1004 940L -196 940L -196 -260Z" fill="#FFFFFF"/>
</clipPath>
<g id="monogram" clip-path="url(#clip-0)">
<g id="Vector">
<use xlink:href="#path0_fill" transform="translate(-146 -260)" fill="#68AD45"/>
</g>
</g>
</g>
<defs>
<path id="path0_fill" d="M 1065.27 813.273L 1054.36 813.273C 1065.27 824.182 1082.18 830.182 1082.18 835.636C 1082.18 852.545 1048.36 847.091 1032 847.091L 1026 841.091L 1032 841.091C 1032 835.636 1048.36 835.636 1048.36 830.182C 1003.64 818.727 936.546 830.182 891.273 824.182C 852.546 824.182 818.727 847.091 784.909 841.091C 790.364 841.091 790.364 841.091 790.364 835.636C 774 835.636 734.727 835.636 728.727 847.091L 711.818 847.091L 711.818 841.091C 689.455 847.091 661.636 858 644.727 858C 616.909 858 594.545 858 571.636 869.455C 560.727 874.909 538.364 874.909 526.909 880.364C 504.546 897.273 453.818 886.364 448.364 908.727L 516 891.818C 510 897.273 493.091 897.273 487.636 908.727L 543.818 891.818C 538.364 902.727 521.455 897.273 510 902.727C 476.727 919.636 420.545 931.091 386.727 953.455C 381.273 958.909 375.273 970.364 369.818 970.364C 358.909 975.818 336.545 975.818 325.091 987.273C 319.636 992.727 313.636 1003.64 302.727 1009.64L 252 1042.91C 224.182 1071.27 235.091 1082.18 207.273 1105.09C 195.818 1116 173.455 1116 162.545 1132.91C 162.545 1132.91 128.727 1160.73 94.9091 1200L 78.5455 1183.64C 100.909 1138.36 111.818 1076.73 117.273 1093.64C 134.182 1127.45 123.273 1076.73 128.727 1054.36C 128.727 1042.91 140.182 1037.45 145.636 1032C 162.545 1015.09 168 975.818 184.909 953.455C 212.727 908.727 229.636 858 258 818.727C 274.364 784.909 297.273 757.091 313.636 729.273C 319.636 717.818 336.545 706.364 336.545 690C 330.545 690 336.545 695.455 325.091 690L 330.545 690C 330.545 684 336.545 678.545 342 673.091C 342 674.727 340.909 675.818 339.818 676.909C 345.273 672 354.545 669.818 358.909 661.636C 364.364 650.727 369.818 633.818 375.273 622.364C 381.273 616.909 386.727 616.909 392.182 611.455C 403.636 594.545 414.545 572.182 426 555.273C 431.455 549.818 437.455 549.818 442.909 543.818C 453.273 523.636 472.364 502.909 488.727 482.727C 478.909 491.455 468 496.364 459.818 504.545C 448.364 516 448.364 526.909 437.455 538.364C 431.455 543.818 420.545 538.364 420.545 543.818C 414.545 549.818 414.545 555.273 409.091 560.727C 381.273 589.091 352.909 622.364 330.545 656.182C 319.636 678.545 297.273 695.455 285.818 717.818C 246.545 779.455 212.727 841.091 179.455 902.727C 156.545 942 100.909 1032 78.5455 1071.27C 67.0909 1088.18 72.5455 1110.55 44.7273 1121.45C 44.7273 1093.64 78.5455 1071.27 89.4545 1048.91C 117.273 998.182 173.455 908.727 201.818 858C 280.364 717.818 369.818 577.636 487.636 448.364C 532.364 398.182 588.546 353.455 633.273 302.727L 605.455 308.182C 600 314.182 577.636 314.182 560.727 319.636C 543.818 325.091 526.909 331.091 516 336.545L 476.727 342C 448.364 358.909 414.545 370.364 392.182 381.273L 336.545 392.727C 336.545 386.727 319.636 392.727 308.182 392.727C 291.273 403.636 252 403.636 241.091 415.091C 258 487.636 241.091 549.818 246.545 616.909C 246.545 628.364 258 690 246.545 695.455C 229.636 717.818 123.273 628.364 100.909 600C 106.364 566.182 100.909 532.909 100.909 493.636C 100.909 459.818 111.818 437.455 106.364 403.636C 78.5455 403.636 61.6364 392.727 33.2727 381.273C 16.3636 370.364 10.9091 358.909 0 342C 10.9091 319.636 16.3636 302.727 44.7273 285.818L 111.818 258L 111.818 224.182C 128.727 174 117.273 106.364 140.182 50.1818C 145.636 33.8182 134.182 10.9091 156.545 0C 168 22.3636 179.455 78.5455 179.455 95.4545C 179.455 100.909 173.455 106.364 173.455 117.818C 173.455 128.727 184.909 134.727 184.909 145.636C 184.909 162.545 179.455 174 179.455 190.364C 184.909 218.727 190.364 235.636 201.818 263.455C 207.273 285.818 207.273 308.182 207.273 325.091C 241.091 325.091 291.273 314.182 313.636 297.273L 347.455 291.818C 375.273 280.364 414.545 268.909 437.455 258L 465.273 252.545C 499.091 235.636 555.273 229.636 588.545 207.273L 622.364 201.818C 650.182 184.909 700.909 179.455 728.727 162.545C 745.636 162.545 824.182 145.636 846.545 134.727C 874.909 123.273 908.182 112.364 942 106.364C 969.818 123.273 969.818 112.364 998.182 140.182C 998.182 151.636 1020.55 162.545 1026 174C 1048.36 218.727 1032 218.727 975.818 229.636C 969.818 235.636 936.545 252.545 919.636 252.545L 880.364 252.545C 846.546 274.909 807.273 291.818 779.455 319.636C 633.273 442.909 510 566.182 426 712.364C 403.636 745.636 375.273 774 352.909 801.818C 347.455 813.273 347.455 830.182 342 847.091C 336.545 863.455 313.636 874.909 313.636 897.273C 319.636 891.818 358.909 869.455 369.818 869.455C 375.273 869.455 381.273 874.909 381.273 874.909C 448.364 858 526.909 841.091 600 824.182C 622.364 818.727 656.182 818.727 672.545 813.273C 695.455 807.818 790.364 796.364 796.364 779.455C 784.909 779.455 774 779.455 762.546 774C 768 774 779.455 768.545 779.455 768.545C 757.091 774 723.273 762.545 700.909 762.545C 656.182 757.091 610.909 762.545 566.182 762.545C 538.364 762.545 510 768.545 482.182 762.545C 538.364 745.636 605.455 745.636 667.091 745.636C 689.455 745.636 711.818 740.182 740.182 740.182L 841.091 740.182C 885.818 740.182 947.455 734.727 986.727 745.636C 1009.09 751.636 1020.55 768.545 1042.91 784.909L 1054.36 784.909L 1059.82 790.909C 1059.82 796.364 1059.82 801.818 1065.27 813.273ZM 111.818 347.455C 106.364 331.091 111.818 314.182 111.818 291.818L 94.9091 291.818C 89.4546 302.727 72.5455 302.727 67.0909 314.182C 55.6364 319.636 50.1818 336.545 39.2727 347.455L 44.7273 353.455L 67.0909 353.455C 78.5455 358.909 94.9091 353.455 111.818 347.455ZM 555.273 403.636L 549.273 403.636C 549.273 409.636 543.818 415.091 543.818 420.545C 543.818 415.091 549.273 409.636 555.273 403.636ZM 521.455 442.909C 512.727 447.273 507.273 458.727 500.182 468.545C 504.545 458.182 505.636 448.364 521.455 442.909ZM 588.545 448.364L 605.455 442.909L 594.545 442.909L 588.545 448.364ZM 470.727 605.455C 473.455 608.182 474.545 608.182 475.636 608.727C 474 610.909 472.909 612.545 472.364 614.727C 468 614.727 465.273 616.909 465.273 616.909L 470.727 616.909L 472.364 614.727C 474.545 614.727 477.818 614.727 482.182 616.909C 478.909 610.364 477.273 609.273 475.636 608.727C 488.727 591.818 520.364 569.455 516 555.273L 510 555.273C 516 538.364 538.364 538.364 543.818 521.455L 538.364 521.455C 555.273 516 560.727 504.545 571.636 499.091C 566.182 499.091 560.727 504.545 555.273 504.545C 560.727 493.636 571.636 487.636 588.545 482.182C 583.091 476.727 583.091 476.727 583.091 471.273L 571.636 471.273C 566.182 499.091 538.364 516 521.455 532.909C 499.091 555.273 487.636 577.636 470.727 605.455ZM 431.455 616.909L 420.545 616.909C 420.545 622.364 414.545 628.364 409.091 628.364L 414.545 628.364C 420.545 622.364 426 622.364 431.455 616.909ZM 453.818 650.727C 442.909 650.727 448.364 656.182 442.909 650.727L 453.818 650.727ZM 437.455 661.636L 431.455 661.636C 426 667.636 414.545 673.091 409.091 684L 426 678.545C 426 673.091 431.455 667.636 437.455 661.636ZM 369.818 700.909L 358.909 700.909C 352.909 706.364 352.909 712.364 347.455 712.364L 352.909 712.364C 358.909 712.364 364.364 706.364 369.818 700.909ZM 409.091 717.818L 386.727 723.273C 386.727 733.636 380.182 742.909 371.455 751.636L 375.273 751.636C 375.273 745.636 386.727 751.636 392.182 745.636C 392.182 745.636 392.182 740.182 386.727 740.182C 392.182 729.273 403.636 723.273 409.091 717.818ZM 342 734.727C 336.545 740.182 336.545 740.182 342 740.182C 342 737.455 343.636 734.182 344.727 731.455C 346.909 728.727 347.455 727.091 347.455 723.273C 347.455 726 346.364 728.727 344.727 731.455C 344.182 732 343.636 733.091 342 734.727ZM 315.273 822C 314.182 819.818 313.636 820.909 313.636 824.182C 315.818 826.364 316.909 826.909 318 826.909C 318.545 828 318.545 828.545 319.636 830.182C 319.636 826.364 319.091 827.455 318 826.909C 317.455 826.364 316.909 825.273 316.364 824.182L 325.091 824.182C 325.091 813.273 336.545 818.727 342 813.273C 342 807.818 336.545 801.818 336.545 796.364C 342 790.909 352.909 790.909 358.909 784.909C 369.818 774 352.909 757.091 375.273 757.091C 372.545 754.364 370.909 752.727 371.455 752.182C 361.091 762 348 770.727 336.545 779.455C 325.636 790.364 324.545 810.545 315.273 822ZM 302.727 835.636C 308.182 841.091 308.182 841.091 319.636 835.636L 313.636 830.182L 302.727 835.636ZM 969.818 841.091L 998.182 835.636C 992.727 847.091 975.818 841.091 958.909 847.091L 969.818 841.091ZM 728.727 847.091L 745.636 847.091C 740.182 841.091 740.182 847.091 728.727 847.091ZM 297.273 858L 302.727 858C 297.273 847.091 297.273 847.091 302.727 847.091L 291.273 847.091C 297.273 852.545 291.273 852.545 297.273 858ZM 829.636 863.455C 829.636 869.455 824.182 869.455 818.727 869.455L 796.364 869.455L 796.364 863.455C 801.818 863.455 824.182 858 829.636 863.455ZM 610.909 886.364C 616.909 891.818 633.273 886.364 644.727 880.364C 639.273 880.364 622.364 886.364 610.909 886.364ZM 420.545 549.818L 426 549.818C 420.545 560.727 414.545 560.727 414.545 560.727C 414.545 555.273 420.545 555.273 420.545 549.818Z"/>
</defs>
</svg>
\"","import { graphql, Link } from 'gatsby';\nimport Img from 'gatsby-image';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport presets, { colors } from '../utils/presets';\n\nimport { options, rhythm, scale } from '../utils/typography';\n\nconst BlogPostPreviewItem = ({ post, className }) => {\n const avatar = post.frontmatter.author.avatar.childImageSharp.fixed;\n\n return (\n
\n \n

{post.frontmatter.title}

\n

\n {post.frontmatter.excerpt ? post.frontmatter.excerpt : post.excerpt}\n

\n \n \n \n \n
\n \n {post.frontmatter.author.id}\n \n {` `}\n on\n {` `}\n {post.frontmatter.date}\n
\n \n \n \n Read more\n \n
\n );\n};\n\nBlogPostPreviewItem.propTypes = {\n post: PropTypes.object.isRequired,\n className: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n};\n\nexport default BlogPostPreviewItem;\n\n// eslint-disable-next-line no-undef\nexport const blogPostPreviewFragment = graphql`\n fragment BlogPostPreview_item on MarkdownRemark {\n excerpt\n fields {\n slug\n }\n frontmatter {\n excerpt\n title\n date(formatString: \"MMMM Do YYYY\")\n tags {\n id\n }\n author {\n id\n fields {\n slug\n }\n avatar {\n childImageSharp {\n fixed(\n width: 30\n height: 30\n quality: 80\n traceSVG: {\n turdSize: 10\n background: \"#f6f2f8\"\n color: \"#e0d6eb\"\n }\n ) {\n ...GatsbyImageSharpFixed_tracedSVG\n }\n }\n }\n }\n }\n }\n`;\n"],"sourceRoot":""}