{"version":3,"sources":["webpack:///./src/components/bio.js","webpack:///./node_modules/gatsby-image/index.js","webpack:///./src/templates/blog-index.module.css","webpack:///./content/assets/images/Steven McCord_circle.png","webpack:///./src/components/bio.module.css"],"names":["Bio","authorName","authorDescription","postDate","isFull","className","styles","bioWrapper","style","flexDirection","xs","sm","avatar","src","stevenAvatar","alt","borderRadius","maxWidth","objectFit","textAlign","description","lineHeight","date","_interopRequireDefault","require","exports","__esModule","default","io","_assertThisInitialized2","_inheritsLoose2","_objectWithoutPropertiesLoose2","_extends2","_react","_propTypes","convertProps","props","convertedProps","resolutions","sizes","critical","fixed","fluid","loading","groupByMedia","concat","matchesMedia","_ref","media","isBrowser","window","matchMedia","matches","getImageCacheKey","_ref2","srcData","getCurrentSrcData","currentData","Array","isArray","some","image","hasArtDirectionSupport","foundMedia","findIndex","noMedia","imageCache","Object","create","inImageCache","cacheKey","hasNativeLazyLoadSupport","HTMLImageElement","prototype","hasIOSupport","IntersectionObserver","listeners","WeakMap","generateImageSources","imageVariants","map","_ref3","srcSet","srcSetWebp","createElement","Fragment","key","type","withMedia","without","forEach","variant","push","generateTracedSVGSources","_ref4","tracedSVG","generateBase64Sources","_ref5","base64","generateNoscriptSource","_ref6","isWebp","listenToIntersections","el","cb","observer","entries","entry","has","target","get","isIntersecting","intersectionRatio","unobserve","delete","rootMargin","observe","set","noscriptImg","title","width","height","crossOrigin","draggable","join","Placeholder","forwardRef","ref","generateSources","spreadProps","ariaHidden","baseImage","Img","length","onLoad","onError","otherProps","position","top","left","objectPosition","propTypes","object","func","Image","_React$Component","_this","call","this","seenBefore","isCritical","addNoScript","fadeIn","useIOSupport","isVisible","state","imgLoaded","imgCached","isHydrated","imageRef","createRef","placeholderRef","handleImageLoaded","bind","handleRef","_proto","componentDidMount","setState","onStartLoad","wasCached","img","current","complete","componentWillUnmount","cleanUpListeners","_this2","imageInCache","currentSrc","render","_convertProps","_convertProps$style","_convertProps$imgStyl","imgStyle","_convertProps$placeho","placeholderStyle","placeholderClassName","backgroundColor","durationFadeIn","Tag","itemProp","shouldReveal","shouldFadeIn","imageStyle","opacity","transition","bgColor","delayHideStyle","transitionDelay","imagePlaceholderStyle","placeholderImageProps","overflow","maxHeight","JSON","stringify","paddingBottom","aspectRatio","bottom","right","dangerouslySetInnerHTML","__html","divStyle","display","Component","defaultProps","fixedObject","shape","number","isRequired","string","srcWebp","fluidObject","requireFixedOrFluid","originalPropTypes","propName","componentName","_PropTypes$checkPropT","Error","checkPropTypes","oneOfType","arrayOf","bool","oneOf","_default","module"],"mappings":"6FAAA,uGA4EeA,IAzDH,SAAC,GAAyD,IAAvDC,EAAsD,EAAtDA,WAAYC,EAA0C,EAA1CA,kBAAmBC,EAAuB,EAAvBA,SAAUC,EAAa,EAAbA,OA4BtD,OACE,kBAAC,IAAD,CAAWC,UAAWC,IAAOC,YAC3B,kBAAC,IAAD,CAAKF,UAAU,MAAMG,MAAO,CAACC,cAAeL,EAAS,MAAQ,WAC3D,kBAAC,IAAD,CAAKM,GAAI,GAAIC,GAAI,EAAGN,UAAWC,IAAOM,QACpC,yBACEP,UAAU,aACVQ,IAAKC,IACLC,IAAKd,GAAU,GACfO,MAAO,CACLQ,aAAc,EACdC,SAAUb,EAAS,IAAM,GACzBc,UAAW,cAIjB,kBAAC,IAAD,CAAKR,GAAI,GAAIC,GAAI,EAAGH,MAAO,CAACW,UAAWf,EAAS,OAAS,UAAWC,UAAWC,IAAOc,aACpF,uBAAGZ,MAAO,CAACa,WAAYjB,EAAS,IAAM,OAAtC,MACK,gCAASH,IAEd,uBAAGO,MAAO,CAACa,WAAYjB,EAAS,IAAM,OACnCA,EAASF,EAxBE,CACpB,gBAAiB,yEAuBmCD,IAAe,QAG7DG,GAAU,kBAAC,IAAD,CAAKC,UAAWC,IAAOgB,MAAOnB,O,oCCpElD,IAAIoB,EAAyBC,EAAQ,QAErCC,EAAQC,YAAa,EACrBD,EAAQE,aAAU,EAElB,IAsJIC,EAtJAC,EAA0BN,EAAuBC,EAAQ,SAEzDM,EAAkBP,EAAuBC,EAAQ,SAEjDO,EAAiCR,EAAuBC,EAAQ,SAEhEQ,EAAYT,EAAuBC,EAAQ,SAE3CS,EAASV,EAAuBC,EAAQ,SAExCU,EAAaX,EAAuBC,EAAQ,SAe5CW,EAAe,SAAsBC,GACvC,IAAIC,GAAiB,EAAIL,EAAUL,SAAS,GAAIS,GAC5CE,EAAcD,EAAeC,YAC7BC,EAAQF,EAAeE,MACvBC,EAAWH,EAAeG,SA4B9B,OA1BIF,IACFD,EAAeI,MAAQH,SAEhBD,EAAeC,aAGpBC,IACFF,EAAeK,MAAQH,SAEhBF,EAAeE,OAGpBC,IAEFH,EAAeM,QAAU,SAIvBN,EAAeK,QACjBL,EAAeK,MAAQE,EAAa,GAAGC,OAAOR,EAAeK,SAG3DL,EAAeI,QACjBJ,EAAeI,MAAQG,EAAa,GAAGC,OAAOR,EAAeI,SAGxDJ,GAsBLS,EAAe,SAAsBC,GACvC,IAAIC,EAAQD,EAAKC,MACjB,QAAOA,IAAQC,KAAeC,OAAOC,WAAWH,GAAOI,UAUrDC,EAAmB,SAA0BC,GAC/C,IAAIZ,EAAQY,EAAMZ,MACdD,EAAQa,EAAMb,MACdc,EAAUC,EAAkBd,GAASD,GAAS,IAClD,OAAOc,GAAWA,EAAQ1C,KASxB2C,EAAoB,SAA2BC,GACjD,GAAIR,GAtCuB,SAAgCQ,GAC3D,QAASA,GAAeC,MAAMC,QAAQF,IAAgBA,EAAYG,MAAK,SAAUC,GAC/E,YAA8B,IAAhBA,EAAMb,SAoCLc,CAAuBL,GAAc,CAEpD,IAAIM,EAAaN,EAAYO,UAAUlB,GAEvC,IAAoB,IAAhBiB,EACF,OAAON,EAAYM,GAIrB,IAAIE,EAAUR,EAAYO,WAAU,SAAUH,GAC5C,YAA8B,IAAhBA,EAAMb,SAGtB,IAAiB,IAAbiB,EACF,OAAOR,EAAYQ,GAKvB,OAAOR,EAAY,IAKjBS,EAAaC,OAAOC,OAAO,IAE3BC,EAAe,SAAsBjC,GACvC,IAAIC,EAAiBF,EAAaC,GAC9BkC,EAAWjB,EAAiBhB,GAChC,OAAO6B,EAAWI,KAAa,GAa7BC,EAAuD,oBAArBC,kBAAoC,YAAaA,iBAAiBC,UACpGxB,EAA8B,oBAAXC,OACnBwB,EAAezB,GAAaC,OAAOyB,qBAEnCC,EAAY,IAAIC,QAwBpB,SAASC,EAAqBC,GAC5B,OAAOA,EAAcC,KAAI,SAAUC,GACjC,IAAIpE,EAAMoE,EAAMpE,IACZqE,EAASD,EAAMC,OACfC,EAAaF,EAAME,WACnBnC,EAAQiC,EAAMjC,MACdT,EAAQ0C,EAAM1C,MAClB,OAAoBN,EAAON,QAAQyD,cAAcnD,EAAON,QAAQ0D,SAAU,CACxEC,IAAKzE,GACJsE,GAA2BlD,EAAON,QAAQyD,cAAc,SAAU,CACnEG,KAAM,aACNvC,MAAOA,EACPkC,OAAQC,EACR5C,MAAOA,IACL2C,GAAuBjD,EAAON,QAAQyD,cAAc,SAAU,CAChEpC,MAAOA,EACPkC,OAAQA,EACR3C,MAAOA,QAOb,SAASK,EAAamC,GACpB,IAAIS,EAAY,GACZC,EAAU,GASd,OARAV,EAAcW,SAAQ,SAAUC,GAC9B,OAAQA,EAAQ3C,MAAQwC,EAAYC,GAASG,KAAKD,MAO7C,GAAG9C,OAAO2C,EAAWC,GAG9B,SAASI,EAAyBd,GAChC,OAAOA,EAAcC,KAAI,SAAUc,GACjC,IAAIjF,EAAMiF,EAAMjF,IACZmC,EAAQ8C,EAAM9C,MACd+C,EAAYD,EAAMC,UACtB,OAAoB9D,EAAON,QAAQyD,cAAc,SAAU,CACzDE,IAAKzE,EACLmC,MAAOA,EACPkC,OAAQa,OAKd,SAASC,EAAsBjB,GAC7B,OAAOA,EAAcC,KAAI,SAAUiB,GACjC,IAAIpF,EAAMoF,EAAMpF,IACZmC,EAAQiD,EAAMjD,MACdkD,EAASD,EAAMC,OACnB,OAAoBjE,EAAON,QAAQyD,cAAc,SAAU,CACzDE,IAAKzE,EACLmC,MAAOA,EACPkC,OAAQgB,OAKd,SAASC,EAAuBC,EAAOC,GACrC,IAAInB,EAASkB,EAAMlB,OACfC,EAAaiB,EAAMjB,WACnBnC,EAAQoD,EAAMpD,MACdT,EAAQ6D,EAAM7D,MAKlB,MAAO,YAFQ8D,EAAS,qBAAuB,KAD/BrD,EAAQ,UAAaA,EAAQ,KAAQ,IAGV,YAJjCqD,EAASlB,EAAaD,GAI+B,MAD/C3C,EAAQ,UAAaA,EAAQ,KAAQ,IAC8B,KASrF,IAAI+D,EAAwB,SAA+BC,EAAIC,GAC7D,IAAIC,QAxGc,IAAP7E,GAAwC,oBAAXsB,QAA0BA,OAAOyB,uBACvE/C,EAAK,IAAIsB,OAAOyB,sBAAqB,SAAU+B,GAC7CA,EAAQhB,SAAQ,SAAUiB,GACxB,GAAI/B,EAAUgC,IAAID,EAAME,QAAS,CAC/B,IAAIL,EAAK5B,EAAUkC,IAAIH,EAAME,SAEzBF,EAAMI,gBAAkBJ,EAAMK,kBAAoB,KACpDpF,EAAGqF,UAAUN,EAAME,QACnBjC,EAAUsC,OAAOP,EAAME,QACvBL,WAIL,CACDW,WAAY,WAITvF,GA6FP,OALI6E,IACFA,EAASW,QAAQb,GACjB3B,EAAUyC,IAAId,EAAIC,IAGb,WACLC,EAASQ,UAAUV,GACnB3B,EAAUsC,OAAOX,KAIjBe,EAAc,SAAqBlF,GAGrC,IAAIvB,EAAMuB,EAAMvB,IAAM,QAAWuB,EAAMvB,IAAM,KAAQ,UAEjD0B,EAAQH,EAAMG,MAAQ,UAAaH,EAAMG,MAAQ,KAAQ,GACzD2C,EAAS9C,EAAM8C,OAAS,WAAc9C,EAAM8C,OAAS,KAAQ,GAC7DqC,EAAQnF,EAAMmF,MAAQ,UAAanF,EAAMmF,MAAQ,KAAQ,GACzDxG,EAAMqB,EAAMrB,IAAM,QAAWqB,EAAMrB,IAAM,KAAQ,UAEjDyG,EAAQpF,EAAMoF,MAAQ,UAAapF,EAAMoF,MAAQ,KAAQ,GACzDC,EAASrF,EAAMqF,OAAS,WAAcrF,EAAMqF,OAAS,KAAQ,GAC7DC,EAActF,EAAMsF,YAAc,gBAAmBtF,EAAMsF,YAAc,KAAQ,GACjF/E,EAAUP,EAAMO,QAAU,YAAeP,EAAMO,QAAU,KAAQ,GACjEgF,EAAYvF,EAAMuF,UAAY,cAAiBvF,EAAMuF,UAAY,KAAQ,GAE7E,MAAO,YAD+BvF,EAAM2C,cAlCvBC,KAAI,SAAUW,GACjC,OAAQA,EAAQR,WAAagB,EAAuBR,GAAS,GAAQ,IAAMQ,EAAuBR,MACjGiC,KAAK,IAiCuB,QAAUjF,EAAU6E,EAAQC,EAASlF,EAAQ2C,EAASrE,EAAME,EAAMwG,EAAQG,EAAcC,EAAY,+HAMjIE,EAA2B5F,EAAON,QAAQmG,YAAW,SAAU1F,EAAO2F,GACxE,IAAIlH,EAAMuB,EAAMvB,IACZkE,EAAgB3C,EAAM2C,cACtBiD,EAAkB5F,EAAM4F,gBACxBC,EAAc7F,EAAM6F,YACpBC,EAAa9F,EAAM8F,WAEnBC,EAAyBlG,EAAON,QAAQyD,cAAcgD,GAAK,EAAIpG,EAAUL,SAAS,CACpFoG,IAAKA,EACLlH,IAAKA,GACJoH,EAAa,CACdC,WAAYA,KAGd,OAAOnD,EAAcsD,OAAS,EAAiBpG,EAAON,QAAQyD,cAAc,UAAW,KAAM4C,EAAgBjD,GAAgBoD,GAAaA,KAGxIC,EAAmBnG,EAAON,QAAQmG,YAAW,SAAU1F,EAAO2F,GAChE,IAAIxF,EAAQH,EAAMG,MACd2C,EAAS9C,EAAM8C,OACfrE,EAAMuB,EAAMvB,IACZL,EAAQ4B,EAAM5B,MACd8H,EAASlG,EAAMkG,OACfC,EAAUnG,EAAMmG,QAChB5F,EAAUP,EAAMO,QAChBgF,EAAYvF,EAAMuF,UAClBO,EAAa9F,EAAM8F,WACnBM,GAAa,EAAIzG,EAA+BJ,SAASS,EAAO,CAAC,QAAS,SAAU,MAAO,QAAS,SAAU,UAAW,UAAW,YAAa,eACrJ,OAAoBH,EAAON,QAAQyD,cAAc,OAAO,EAAIpD,EAAUL,SAAS,CAC7E,cAAeuG,EACf3F,MAAOA,EACP2C,OAAQA,EACRrE,IAAKA,GACJ2H,EAAY,CACbF,OAAQA,EACRC,QAASA,EACTR,IAAKA,EACLpF,QAASA,EACTgF,UAAWA,EACXnH,OAAO,EAAIwB,EAAUL,SAAS,CAC5B8G,SAAU,WACVC,IAAK,EACLC,KAAM,EACNnB,MAAO,OACPC,OAAQ,OACRvG,UAAW,QACX0H,eAAgB,UACfpI,SAIP4H,EAAIS,UAAY,CACdrI,MAAO0B,EAAWP,QAAQmH,OAC1BP,QAASrG,EAAWP,QAAQoH,KAC5BT,OAAQpG,EAAWP,QAAQoH,MAG7B,IAAIC,EAAqB,SAAUC,GAGjC,SAASD,EAAM5G,GACb,IAAI8G,GAEJA,EAAQD,EAAiBE,KAAKC,KAAMhH,IAAUgH,MAGxCC,WAAapG,GAAaoB,EAAajC,GAC7C8G,EAAMI,WAA+B,UAAlBlH,EAAMO,SAAuBP,EAAMI,SACtD0G,EAAMK,cAAgBL,EAAMI,aAAelH,EAAMoH,QACjDN,EAAMO,cAAgBlF,GAA4BG,IAAiBwE,EAAMI,aAAeJ,EAAMG,WAC9F,IAAIK,EAAYR,EAAMI,YAAcrG,IAAcsB,IAA6B2E,EAAMO,cAYrF,OAXAP,EAAMS,MAAQ,CACZD,UAAWA,EACXE,WAAW,EACXC,WAAW,EACXL,QAASN,EAAMG,YAAcjH,EAAMoH,OACnCM,YAAY,GAEdZ,EAAMa,SAAwB9H,EAAON,QAAQqI,YAC7Cd,EAAMe,eAAiB7H,EAAM6H,gBAA+BhI,EAAON,QAAQqI,YAC3Ed,EAAMgB,kBAAoBhB,EAAMgB,kBAAkBC,MAAK,EAAItI,EAAwBF,SAASuH,IAC5FA,EAAMkB,UAAYlB,EAAMkB,UAAUD,MAAK,EAAItI,EAAwBF,SAASuH,IACrEA,GAxBT,EAAIpH,EAAgBH,SAASqH,EAAOC,GA2BpC,IAAIoB,EAASrB,EAAMvE,UA4QnB,OA1QA4F,EAAOC,kBAAoB,WAWzB,GAVAlB,KAAKmB,SAAS,CACZT,WAAY7G,IAGVmG,KAAKO,MAAMD,WAA+C,mBAA3BN,KAAKhH,MAAMoI,aAC5CpB,KAAKhH,MAAMoI,YAAY,CACrBC,UAAWpG,EAAa+E,KAAKhH,SAI7BgH,KAAKE,WAAY,CACnB,IAAIoB,EAAMtB,KAAKW,SAASY,QAEpBD,GAAOA,EAAIE,UACbxB,KAAKc,sBAKXG,EAAOQ,qBAAuB,WACxBzB,KAAK0B,kBACP1B,KAAK0B,oBAKTT,EAAOD,UAAY,SAAmBrC,GACpC,IAAIgD,EAAS3B,KAETA,KAAKK,cAAgB1B,IACvBqB,KAAK0B,iBAAmBxE,EAAsByB,GAAK,WACjD,IAAIiD,EAAe3G,EAAa0G,EAAO3I,OAElC2I,EAAOpB,MAAMD,WAAiD,mBAA7BqB,EAAO3I,MAAMoI,aACjDO,EAAO3I,MAAMoI,YAAY,CACvBC,UAAWO,IAQfD,EAAOR,SAAS,CACdb,WAAW,IACV,WACDqB,EAAOR,SAAS,CACdX,UAAWoB,EAKXnB,aAAckB,EAAOhB,SAASY,UAAWI,EAAOhB,SAASY,QAAQM,sBAO3EZ,EAAOH,kBAAoB,WA/SD,IAA+B9H,EACrDC,EACAiC,EAFqDlC,EAgTjCgH,KAAKhH,MA/SzBC,EAAiBF,EAAaC,IAC9BkC,EAAWjB,EAAiBhB,MAG9B6B,EAAWI,IAAY,GA4SvB8E,KAAKmB,SAAS,CACZX,WAAW,IAGTR,KAAKhH,MAAMkG,QACbc,KAAKhH,MAAMkG,UAIf+B,EAAOa,OAAS,WACd,IAAIC,EAAgBhJ,EAAaiH,KAAKhH,OAClCmF,EAAQ4D,EAAc5D,MACtBxG,EAAMoK,EAAcpK,IACpBV,EAAY8K,EAAc9K,UAC1B+K,EAAsBD,EAAc3K,MACpCA,OAAgC,IAAxB4K,EAAiC,GAAKA,EAC9CC,EAAwBF,EAAcG,SACtCA,OAAqC,IAA1BD,EAAmC,GAAKA,EACnDE,EAAwBJ,EAAcK,iBACtCA,OAA6C,IAA1BD,EAAmC,GAAKA,EAC3DE,EAAuBN,EAAcM,qBACrC/I,EAAQyI,EAAczI,MACtBD,EAAQ0I,EAAc1I,MACtBiJ,EAAkBP,EAAcO,gBAChCC,EAAiBR,EAAcQ,eAC/BC,EAAMT,EAAcS,IACpBC,EAAWV,EAAcU,SACzBlJ,EAAUwI,EAAcxI,QACxBgF,EAAYwD,EAAcxD,UAE1B5C,EAAgBrC,GAASD,EAE7B,IAAKsC,EACH,OAAO,KAGT,IAAI+G,GAAqC,IAAtB1C,KAAKO,MAAMH,QAAoBJ,KAAKO,MAAMC,UACzDmC,GAAqC,IAAtB3C,KAAKO,MAAMH,SAAoBJ,KAAKO,MAAME,UACzDmC,GAAa,EAAIhK,EAAUL,SAAS,CACtCsK,QAASH,EAAe,EAAI,EAC5BI,WAAYH,EAAe,WAAaJ,EAAiB,KAAO,QAC/DL,GACCa,EAAqC,kBAApBT,EAAgC,YAAcA,EAC/DU,EAAiB,CACnBC,gBAAiBV,EAAiB,MAEhCW,GAAwB,EAAItK,EAAUL,SAAS,CACjDsK,QAAS7C,KAAKO,MAAMC,UAAY,EAAI,GACnCmC,GAAgBK,EAAgBd,EAAUE,GACzCe,EAAwB,CAC1BhF,MAAOA,EACPxG,IAAMqI,KAAKO,MAAMD,UAAkB,GAAN3I,EAC7BP,MAAO8L,EACPjM,UAAWoL,EACXI,SAAUA,GAKRhI,EAASuF,KAAKO,MAAMG,WAAgCtG,EAAkBuB,GAArCA,EAAc,GAEnD,GAAIrC,EACF,OAAoBT,EAAON,QAAQyD,cAAcwG,EAAK,CACpDvL,WAAYA,GAAwB,IAAM,wBAC1CG,OAAO,EAAIwB,EAAUL,SAAS,CAC5B8G,SAAU,WACV+D,SAAU,SACVvL,SAAU4C,EAAM5C,SAAW4C,EAAM5C,SAAW,KAAO,KACnDwL,UAAW5I,EAAM4I,UAAY5I,EAAM4I,UAAY,KAAO,MACrDjM,GACHuH,IAAKqB,KAAKgB,UACV9E,IAAK,SAAWoH,KAAKC,UAAU9I,EAAMqB,SACvBjD,EAAON,QAAQyD,cAAcwG,EAAK,CAChD,eAAe,EACfpL,MAAO,CACLgH,MAAO,OACPoF,cAAe,IAAM/I,EAAMgJ,YAAc,OAEzCV,GAAwBlK,EAAON,QAAQyD,cAAcwG,EAAK,CAC5D,eAAe,EACfrE,MAAOA,EACP/G,OAAO,EAAIwB,EAAUL,SAAS,CAC5B+J,gBAAiBS,EACjB1D,SAAU,WACVC,IAAK,EACLoE,OAAQ,EACRb,QAAU7C,KAAKO,MAAMC,UAAgB,EAAJ,EACjCmD,MAAO,EACPpE,KAAM,GACLoD,GAAgBK,KACjBvI,EAAMqC,QAAuBjE,EAAON,QAAQyD,cAAcyC,EAAa,CACzEK,YAAY,EACZH,IAAKqB,KAAKa,eACVpJ,IAAKgD,EAAMqC,OACX+B,YAAasE,EACbxH,cAAeA,EACfiD,gBAAiBhC,IACfnC,EAAMkC,WAA0B9D,EAAON,QAAQyD,cAAcyC,EAAa,CAC5EK,YAAY,EACZH,IAAKqB,KAAKa,eACVpJ,IAAKgD,EAAMkC,UACXkC,YAAasE,EACbxH,cAAeA,EACfiD,gBAAiBnC,IACfuD,KAAKO,MAAMD,WAA0BzH,EAAON,QAAQyD,cAAc,UAAW,KAAMN,EAAqBC,GAA6B9C,EAAON,QAAQyD,cAAcgD,EAAK,CACzKrH,IAAKA,EACLwG,MAAOA,EACPhF,MAAOsB,EAAMtB,MACb1B,IAAKgD,EAAMhD,IACX6G,YAAa0B,KAAKhH,MAAMsF,YACxBxC,OAAQrB,EAAMqB,OACd1E,MAAOwL,EACPjE,IAAKqB,KAAKW,SACVzB,OAAQc,KAAKc,kBACb3B,QAASa,KAAKhH,MAAMmG,QACpBsD,SAAUA,EACVlJ,QAASA,EACTgF,UAAWA,KACRyB,KAAKG,aAA4BtH,EAAON,QAAQyD,cAAc,WAAY,CAC7E4H,wBAAyB,CACvBC,OAAQ3F,GAAY,EAAItF,EAAUL,SAAS,CACzCZ,IAAKA,EACLwG,MAAOA,EACP5E,QAASA,GACRkB,EAAO,CACRkB,cAAeA,SAMvB,GAAItC,EAAO,CACT,IAAIyK,GAAW,EAAIlL,EAAUL,SAAS,CACpC8G,SAAU,WACV+D,SAAU,SACVW,QAAS,eACT3F,MAAO3D,EAAM2D,MACbC,OAAQ5D,EAAM4D,QACbjH,GAMH,MAJsB,YAAlBA,EAAM2M,gBACDD,EAASC,QAGElL,EAAON,QAAQyD,cAAcwG,EAAK,CACpDvL,WAAYA,GAAwB,IAAM,wBAC1CG,MAAO0M,EACPnF,IAAKqB,KAAKgB,UACV9E,IAAK,SAAWoH,KAAKC,UAAU9I,EAAMqB,SACpCiH,GAAwBlK,EAAON,QAAQyD,cAAcwG,EAAK,CAC3D,eAAe,EACfrE,MAAOA,EACP/G,OAAO,EAAIwB,EAAUL,SAAS,CAC5B+J,gBAAiBS,EACjB3E,MAAO3D,EAAM2D,MACbyE,QAAU7C,KAAKO,MAAMC,UAAgB,EAAJ,EACjCnC,OAAQ5D,EAAM4D,QACbsE,GAAgBK,KACjBvI,EAAMqC,QAAuBjE,EAAON,QAAQyD,cAAcyC,EAAa,CACzEK,YAAY,EACZH,IAAKqB,KAAKa,eACVpJ,IAAKgD,EAAMqC,OACX+B,YAAasE,EACbxH,cAAeA,EACfiD,gBAAiBhC,IACfnC,EAAMkC,WAA0B9D,EAAON,QAAQyD,cAAcyC,EAAa,CAC5EK,YAAY,EACZH,IAAKqB,KAAKa,eACVpJ,IAAKgD,EAAMkC,UACXkC,YAAasE,EACbxH,cAAeA,EACfiD,gBAAiBnC,IACfuD,KAAKO,MAAMD,WAA0BzH,EAAON,QAAQyD,cAAc,UAAW,KAAMN,EAAqBC,GAA6B9C,EAAON,QAAQyD,cAAcgD,EAAK,CACzKrH,IAAKA,EACLwG,MAAOA,EACPC,MAAO3D,EAAM2D,MACbC,OAAQ5D,EAAM4D,OACdlF,MAAOsB,EAAMtB,MACb1B,IAAKgD,EAAMhD,IACX6G,YAAa0B,KAAKhH,MAAMsF,YACxBxC,OAAQrB,EAAMqB,OACd1E,MAAOwL,EACPjE,IAAKqB,KAAKW,SACVzB,OAAQc,KAAKc,kBACb3B,QAASa,KAAKhH,MAAMmG,QACpBsD,SAAUA,EACVlJ,QAASA,EACTgF,UAAWA,KACRyB,KAAKG,aAA4BtH,EAAON,QAAQyD,cAAc,WAAY,CAC7E4H,wBAAyB,CACvBC,OAAQ3F,GAAY,EAAItF,EAAUL,SAAS,CACzCZ,IAAKA,EACLwG,MAAOA,EACP5E,QAASA,GACRkB,EAAO,CACRkB,cAAeA,SAMvB,OAAO,MAGFiE,EAxSgB,CAySvB/G,EAAON,QAAQyL,WAEjBpE,EAAMqE,aAAe,CACnB7D,QAAQ,EACRmC,eAAgB,IAChB5K,IAAK,GACL6K,IAAK,MAGLjJ,QAAS,QAGX,IAAI2K,EAAcpL,EAAWP,QAAQ4L,MAAM,CACzC/F,MAAOtF,EAAWP,QAAQ6L,OAAOC,WACjChG,OAAQvF,EAAWP,QAAQ6L,OAAOC,WAClC5M,IAAKqB,EAAWP,QAAQ+L,OAAOD,WAC/BvI,OAAQhD,EAAWP,QAAQ+L,OAAOD,WAClCvH,OAAQhE,EAAWP,QAAQ+L,OAC3B3H,UAAW7D,EAAWP,QAAQ+L,OAC9BC,QAASzL,EAAWP,QAAQ+L,OAC5BvI,WAAYjD,EAAWP,QAAQ+L,OAC/B1K,MAAOd,EAAWP,QAAQ+L,SAGxBE,EAAc1L,EAAWP,QAAQ4L,MAAM,CACzCV,YAAa3K,EAAWP,QAAQ6L,OAAOC,WACvC5M,IAAKqB,EAAWP,QAAQ+L,OAAOD,WAC/BvI,OAAQhD,EAAWP,QAAQ+L,OAAOD,WAClClL,MAAOL,EAAWP,QAAQ+L,OAAOD,WACjCvH,OAAQhE,EAAWP,QAAQ+L,OAC3B3H,UAAW7D,EAAWP,QAAQ+L,OAC9BC,QAASzL,EAAWP,QAAQ+L,OAC5BvI,WAAYjD,EAAWP,QAAQ+L,OAC/B1K,MAAOd,EAAWP,QAAQ+L,OAC1BzM,SAAUiB,EAAWP,QAAQ6L,OAC7Bf,UAAWvK,EAAWP,QAAQ6L,SAGhC,SAASK,EAAoBC,GAC3B,OAAO,SAAU1L,EAAO2L,EAAUC,GAChC,IAAIC,EAEJ,IAAK7L,EAAMK,QAAUL,EAAMM,MACzB,MAAM,IAAIwL,MAAM,yDAA2DF,EAAgB,6CAG7F9L,EAAWP,QAAQwM,iBAAgBF,EAAwB,IAA0BF,GAAYD,EAAmBG,GAAwB7L,EAAO,OAAQ4L,IAQ/JhF,EAAMH,UAAY,CAChBvG,YAAagL,EACb/K,MAAOqL,EACPnL,MAAOoL,EAAoB3L,EAAWP,QAAQyM,UAAU,CAACd,EAAapL,EAAWP,QAAQ0M,QAAQf,MACjG5K,MAAOmL,EAAoB3L,EAAWP,QAAQyM,UAAU,CAACR,EAAa1L,EAAWP,QAAQ0M,QAAQT,MACjGpE,OAAQtH,EAAWP,QAAQ2M,KAC3B3C,eAAgBzJ,EAAWP,QAAQ6L,OACnCjG,MAAOrF,EAAWP,QAAQ+L,OAC1B3M,IAAKmB,EAAWP,QAAQ+L,OACxBrN,UAAW6B,EAAWP,QAAQyM,UAAU,CAAClM,EAAWP,QAAQ+L,OAAQxL,EAAWP,QAAQmH,SAEvFtG,SAAUN,EAAWP,QAAQ2M,KAC7B5G,YAAaxF,EAAWP,QAAQyM,UAAU,CAAClM,EAAWP,QAAQ+L,OAAQxL,EAAWP,QAAQ2M,OACzF9N,MAAO0B,EAAWP,QAAQmH,OAC1BwC,SAAUpJ,EAAWP,QAAQmH,OAC7B0C,iBAAkBtJ,EAAWP,QAAQmH,OACrC2C,qBAAsBvJ,EAAWP,QAAQ+L,OACzChC,gBAAiBxJ,EAAWP,QAAQyM,UAAU,CAAClM,EAAWP,QAAQ+L,OAAQxL,EAAWP,QAAQ2M,OAC7FhG,OAAQpG,EAAWP,QAAQoH,KAC3BR,QAASrG,EAAWP,QAAQoH,KAC5ByB,YAAatI,EAAWP,QAAQoH,KAChC6C,IAAK1J,EAAWP,QAAQ+L,OACxB7B,SAAU3J,EAAWP,QAAQ+L,OAC7B/K,QAAST,EAAWP,QAAQ4M,MAAM,CAAC,OAAQ,OAAQ,UACnD5G,UAAWzF,EAAWP,QAAQ2M,MAEhC,IAAIE,EAAWxF,EACfvH,EAAQE,QAAU6M,G,qBC9tBlBC,EAAOhN,QAAU,CAAC,mBAAqB,+CAA+C,eAAiB,2CAA2C,uBAAyB,mDAAmD,eAAiB,4FAA4F,cAAgB,0CAA0C,aAAe,yCAAyC,0BAA4B,sDAAsD,yBAA2B,qDAAqD,gBAAkB,4CAA4C,YAAc,wCAAwC,mBAAqB,qFAAqF,qBAAuB,iDAAiD,aAAe,yCAAyC,YAAc,wCAAwC,UAAY,sCAAsC,kBAAoB,kFAAkF,SAAW,qCAAqC,YAAc,wCAAwC,mBAAqB,+CAA+C,kBAAoB,8CAA8C,cAAgB,4C,qBCDv4CgN,EAAOhN,QAAU,IAA0B,oE,qBCC3CgN,EAAOhN,QAAU,CAAC,WAAa,gCAAgC,QAAU,6BAA6B,OAAS,uDAAuD,YAAc,4DAA4D,KAAO,qDAAqD,oBAAsB,yCAAyC,wBAA0B","file":"7d2f459ac1760bc6b74925afd167bf63573a0af9-d7b6bb65702f481c4db0.js","sourcesContent":["/**\n * Bio component that queries for data\n * with Gatsby's useStaticQuery component\n *\n * See: https://www.gatsbyjs.com/docs/use-static-query/\n */\n\nimport React from \"react\"\n// import { useStaticQuery, graphql } from \"gatsby\"\n// import Image from \"gatsby-image\"\n\nimport Container from 'react-bootstrap/Container'\nimport Row from 'react-bootstrap/Row'\nimport Col from 'react-bootstrap/Col'\n\nimport styles from './bio.module.css'\n\nimport stevenAvatar from '../../content/assets/images/Steven McCord_circle.png'\n\nconst Bio = ({ authorName, authorDescription, postDate, isFull }) => {\n // const avatarPath = \"images/\" + authorName + \".jpg\";\n // const { author, authorAvatar } = useStaticQuery(graphql`\n // query BioQuery (\n // $authorId: String\n // $avatarPath: String\n // ) {\n // # if there was more than one user, this would need to be filtered\n // author: wpUser(id: {eq: $authorId}) {\n // name\n // description\n // }\n // authorAvatar: file(relativePath: {eq: $avatarPath}) {\n // childImageSharp {\n // fluid {\n // ...GatsbyImageSharpFluid\n // }\n // }\n // }\n // }\n // `)\n\n // const avatarUrl = author?.avatar?.url\n\n const authorSummary = {\n 'Steven McCord': 'Co-founder and CEO of Spatial Laser, the company behind Locate Alpha.'\n }\n\n return (\n \n \n \n \n \n \n \n By {authorName}\n \n \n {isFull ? authorDescription : authorSummary[authorName] || null}\n \n \n {!isFull && {postDate}}\n \n \n )\n}\n\nexport default Bio\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\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\nvar logDeprecationNotice = function logDeprecationNotice(prop, replacement) {\n if (process.env.NODE_ENV === \"production\") {\n return;\n }\n\n console.log(\"\\n The \\\"\" + prop + \"\\\" prop is now deprecated and will be removed in the next major version\\n of \\\"gatsby-image\\\".\\n \");\n\n if (replacement) {\n console.log(\"Please use \" + replacement + \" instead of \\\"\" + prop + \"\\\".\");\n }\n}; // Handle legacy props during their deprecation phase\n\n\nvar convertProps = function convertProps(props) {\n var convertedProps = (0, _extends2.default)({}, props);\n var resolutions = convertedProps.resolutions,\n sizes = convertedProps.sizes,\n critical = convertedProps.critical;\n\n if (resolutions) {\n convertedProps.fixed = resolutions;\n logDeprecationNotice(\"resolutions\", \"the gatsby-image v2 prop \\\"fixed\\\"\");\n delete convertedProps.resolutions;\n }\n\n if (sizes) {\n convertedProps.fluid = sizes;\n logDeprecationNotice(\"sizes\", \"the gatsby-image v2 prop \\\"fluid\\\"\");\n delete convertedProps.sizes;\n }\n\n if (critical) {\n logDeprecationNotice(\"critical\", \"the native \\\"loading\\\" attribute\");\n convertedProps.loading = \"eager\";\n } // convert fluid & fixed to arrays so we only have to work with arrays\n\n\n if (convertedProps.fluid) {\n convertedProps.fluid = groupByMedia([].concat(convertedProps.fluid));\n }\n\n if (convertedProps.fixed) {\n convertedProps.fixed = groupByMedia([].concat(convertedProps.fixed));\n }\n\n return convertedProps;\n};\n/**\n * Checks if fluid or fixed are art-direction arrays.\n *\n * @param currentData {{media?: string}[]} The props to check for images.\n * @return {boolean}\n */\n\n\nvar hasArtDirectionSupport = function hasArtDirectionSupport(currentData) {\n return !!currentData && Array.isArray(currentData) && currentData.some(function (image) {\n return typeof image.media !== \"undefined\";\n });\n};\n/**\n * Tries to detect if a media query matches the current viewport.\n * @property media {{media?: string}} A media query string.\n * @return {boolean}\n */\n\n\nvar matchesMedia = function matchesMedia(_ref) {\n var media = _ref.media;\n return media ? isBrowser && !!window.matchMedia(media).matches : false;\n};\n/**\n * Find the source of an image to use as a key in the image cache.\n * Use `the first image in either `fixed` or `fluid`\n * @param {{fluid: {src: string, media?: string}[], fixed: {src: string, media?: string}[]}} args\n * @return {string?} Returns image src or undefined it not given.\n */\n\n\nvar getImageCacheKey = function getImageCacheKey(_ref2) {\n var fluid = _ref2.fluid,\n fixed = _ref2.fixed;\n var srcData = getCurrentSrcData(fluid || fixed || []);\n return srcData && srcData.src;\n};\n/**\n * Returns the current src - Preferably with art-direction support.\n * @param currentData {{media?: string}[], maxWidth?: Number, maxHeight?: Number} The fluid or fixed image array.\n * @return {{src: string, media?: string, maxWidth?: Number, maxHeight?: Number}}\n */\n\n\nvar getCurrentSrcData = function getCurrentSrcData(currentData) {\n if (isBrowser && hasArtDirectionSupport(currentData)) {\n // Do we have an image for the current Viewport?\n var foundMedia = currentData.findIndex(matchesMedia);\n\n if (foundMedia !== -1) {\n return currentData[foundMedia];\n } // No media matches, select first element without a media condition\n\n\n var noMedia = currentData.findIndex(function (image) {\n return typeof image.media === \"undefined\";\n });\n\n if (noMedia !== -1) {\n return currentData[noMedia];\n }\n } // Else return the first image.\n\n\n return currentData[0];\n}; // Cache if we've seen an image before so we don't bother with\n// lazy-loading & fading in on subsequent mounts.\n\n\nvar imageCache = Object.create({});\n\nvar inImageCache = function inImageCache(props) {\n var convertedProps = convertProps(props);\n var cacheKey = getImageCacheKey(convertedProps);\n return imageCache[cacheKey] || false;\n};\n\nvar activateCacheForImage = function activateCacheForImage(props) {\n var convertedProps = convertProps(props);\n var cacheKey = getImageCacheKey(convertedProps);\n\n if (cacheKey) {\n imageCache[cacheKey] = true;\n }\n}; // Native lazy-loading support: https://addyosmani.com/blog/lazy-loading/\n\n\nvar hasNativeLazyLoadSupport = typeof HTMLImageElement !== \"undefined\" && \"loading\" in HTMLImageElement.prototype;\nvar isBrowser = typeof window !== \"undefined\";\nvar hasIOSupport = isBrowser && window.IntersectionObserver;\nvar io;\nvar listeners = new WeakMap();\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 if (listeners.has(entry.target)) {\n var cb = listeners.get(entry.target); // Edge doesn't currently support isIntersecting, so also test for an intersectionRatio > 0\n\n if (entry.isIntersecting || entry.intersectionRatio > 0) {\n io.unobserve(entry.target);\n listeners.delete(entry.target);\n cb();\n }\n }\n });\n }, {\n rootMargin: \"200px\"\n });\n }\n\n return io;\n}\n\nfunction generateImageSources(imageVariants) {\n return imageVariants.map(function (_ref3) {\n var src = _ref3.src,\n srcSet = _ref3.srcSet,\n srcSetWebp = _ref3.srcSetWebp,\n media = _ref3.media,\n sizes = _ref3.sizes;\n return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, {\n key: src\n }, srcSetWebp && /*#__PURE__*/_react.default.createElement(\"source\", {\n type: \"image/webp\",\n media: media,\n srcSet: srcSetWebp,\n sizes: sizes\n }), srcSet && /*#__PURE__*/_react.default.createElement(\"source\", {\n media: media,\n srcSet: srcSet,\n sizes: sizes\n }));\n });\n} // Return an array ordered by elements having a media prop, does not use\n// native sort, as a stable sort is not guaranteed by all browsers/versions\n\n\nfunction groupByMedia(imageVariants) {\n var withMedia = [];\n var without = [];\n imageVariants.forEach(function (variant) {\n return (variant.media ? withMedia : without).push(variant);\n });\n\n if (without.length > 1 && process.env.NODE_ENV !== \"production\") {\n console.warn(\"We've found \" + without.length + \" sources without a media property. They might be ignored by the browser, see: https://www.gatsbyjs.org/packages/gatsby-image/#art-directing-multiple-images\");\n }\n\n return [].concat(withMedia, without);\n}\n\nfunction generateTracedSVGSources(imageVariants) {\n return imageVariants.map(function (_ref4) {\n var src = _ref4.src,\n media = _ref4.media,\n tracedSVG = _ref4.tracedSVG;\n return /*#__PURE__*/_react.default.createElement(\"source\", {\n key: src,\n media: media,\n srcSet: tracedSVG\n });\n });\n}\n\nfunction generateBase64Sources(imageVariants) {\n return imageVariants.map(function (_ref5) {\n var src = _ref5.src,\n media = _ref5.media,\n base64 = _ref5.base64;\n return /*#__PURE__*/_react.default.createElement(\"source\", {\n key: src,\n media: media,\n srcSet: base64\n });\n });\n}\n\nfunction generateNoscriptSource(_ref6, isWebp) {\n var srcSet = _ref6.srcSet,\n srcSetWebp = _ref6.srcSetWebp,\n media = _ref6.media,\n sizes = _ref6.sizes;\n var src = isWebp ? srcSetWebp : srcSet;\n var mediaAttr = media ? \"media=\\\"\" + media + \"\\\" \" : \"\";\n var typeAttr = isWebp ? \"type='image/webp' \" : \"\";\n var sizesAttr = sizes ? \"sizes=\\\"\" + sizes + \"\\\" \" : \"\";\n return \"\";\n}\n\nfunction generateNoscriptSources(imageVariants) {\n return imageVariants.map(function (variant) {\n return (variant.srcSetWebp ? generateNoscriptSource(variant, true) : \"\") + generateNoscriptSource(variant);\n }).join(\"\");\n}\n\nvar listenToIntersections = function listenToIntersections(el, cb) {\n var observer = getIO();\n\n if (observer) {\n observer.observe(el);\n listeners.set(el, cb);\n }\n\n return function () {\n observer.unobserve(el);\n listeners.delete(el);\n };\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 srcSet = props.srcSet ? \"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 crossOrigin = props.crossOrigin ? \"crossorigin=\\\"\" + props.crossOrigin + \"\\\" \" : \"\";\n var loading = props.loading ? \"loading=\\\"\" + props.loading + \"\\\" \" : \"\";\n var draggable = props.draggable ? \"draggable=\\\"\" + props.draggable + \"\\\" \" : \"\";\n var sources = generateNoscriptSources(props.imageVariants);\n return \"\" + sources + \"\";\n}; // Earlier versions of gatsby-image during the 2.x cycle did not wrap\n// the `Img` component in a `picture` element. This maintains compatibility\n// until a breaking change can be introduced in the next major release\n\n\nvar Placeholder = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {\n var src = props.src,\n imageVariants = props.imageVariants,\n generateSources = props.generateSources,\n spreadProps = props.spreadProps,\n ariaHidden = props.ariaHidden;\n\n var baseImage = /*#__PURE__*/_react.default.createElement(Img, (0, _extends2.default)({\n ref: ref,\n src: src\n }, spreadProps, {\n ariaHidden: ariaHidden\n }));\n\n return imageVariants.length > 1 ? /*#__PURE__*/_react.default.createElement(\"picture\", null, generateSources(imageVariants), baseImage) : baseImage;\n});\n\nvar Img = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {\n var sizes = props.sizes,\n srcSet = props.srcSet,\n src = props.src,\n style = props.style,\n onLoad = props.onLoad,\n onError = props.onError,\n loading = props.loading,\n draggable = props.draggable,\n ariaHidden = props.ariaHidden,\n otherProps = (0, _objectWithoutPropertiesLoose2.default)(props, [\"sizes\", \"srcSet\", \"src\", \"style\", \"onLoad\", \"onError\", \"loading\", \"draggable\", \"ariaHidden\"]);\n return /*#__PURE__*/_react.default.createElement(\"img\", (0, _extends2.default)({\n \"aria-hidden\": ariaHidden,\n sizes: sizes,\n srcSet: srcSet,\n src: src\n }, otherProps, {\n onLoad: onLoad,\n onError: onError,\n ref: ref,\n loading: loading,\n draggable: draggable,\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 = /*#__PURE__*/function (_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; // 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 _this.seenBefore = isBrowser && inImageCache(props);\n _this.isCritical = props.loading === \"eager\" || props.critical;\n _this.addNoScript = !(_this.isCritical && !props.fadeIn);\n _this.useIOSupport = !hasNativeLazyLoadSupport && hasIOSupport && !_this.isCritical && !_this.seenBefore;\n var isVisible = _this.isCritical || isBrowser && (hasNativeLazyLoadSupport || !_this.useIOSupport);\n _this.state = {\n isVisible: isVisible,\n imgLoaded: false,\n imgCached: false,\n fadeIn: !_this.seenBefore && props.fadeIn,\n isHydrated: false\n };\n _this.imageRef = /*#__PURE__*/_react.default.createRef();\n _this.placeholderRef = props.placeholderRef || /*#__PURE__*/_react.default.createRef();\n _this.handleImageLoaded = _this.handleImageLoaded.bind((0, _assertThisInitialized2.default)(_this));\n _this.handleRef = _this.handleRef.bind((0, _assertThisInitialized2.default)(_this));\n return _this;\n }\n\n var _proto = Image.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.setState({\n isHydrated: isBrowser\n });\n\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.isCritical) {\n var img = this.imageRef.current;\n\n if (img && img.complete) {\n this.handleImageLoaded();\n }\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this.cleanUpListeners) {\n this.cleanUpListeners();\n }\n } // Specific to IntersectionObserver based lazy-load support\n ;\n\n _proto.handleRef = function handleRef(ref) {\n var _this2 = this;\n\n if (this.useIOSupport && ref) {\n this.cleanUpListeners = listenToIntersections(ref, function () {\n var imageInCache = inImageCache(_this2.props);\n\n if (!_this2.state.isVisible && typeof _this2.props.onStartLoad === \"function\") {\n _this2.props.onStartLoad({\n wasCached: imageInCache\n });\n } // imgCached and imgLoaded must update after isVisible,\n // Once isVisible is true, imageRef becomes accessible, which imgCached needs access to.\n // imgLoaded and imgCached are in a 2nd setState call to be changed together,\n // avoiding initiating unnecessary animation frames from style changes.\n\n\n _this2.setState({\n isVisible: true\n }, function () {\n _this2.setState({\n imgLoaded: imageInCache,\n // `currentSrc` should be a string, but can be `undefined` in IE,\n // !! operator validates the value is not undefined/null/\"\"\n // for lazyloaded components this might be null\n // TODO fix imgCached behaviour as it's now false when it's lazyloaded\n imgCached: !!(_this2.imageRef.current && _this2.imageRef.current.currentSrc)\n });\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.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 durationFadeIn = _convertProps.durationFadeIn,\n Tag = _convertProps.Tag,\n itemProp = _convertProps.itemProp,\n loading = _convertProps.loading,\n draggable = _convertProps.draggable;\n\n var imageVariants = fluid || fixed; // Abort early if missing image data (#25371)\n\n if (!imageVariants) {\n return null;\n }\n\n var shouldReveal = this.state.fadeIn === false || this.state.imgLoaded;\n var shouldFadeIn = this.state.fadeIn === true && !this.state.imgCached;\n var imageStyle = (0, _extends2.default)({\n opacity: shouldReveal ? 1 : 0,\n transition: shouldFadeIn ? \"opacity \" + durationFadeIn + \"ms\" : \"none\"\n }, imgStyle);\n var bgColor = typeof backgroundColor === \"boolean\" ? \"lightgray\" : backgroundColor;\n var delayHideStyle = {\n transitionDelay: durationFadeIn + \"ms\"\n };\n var imagePlaceholderStyle = (0, _extends2.default)({\n opacity: this.state.imgLoaded ? 0 : 1\n }, shouldFadeIn && delayHideStyle, imgStyle, placeholderStyle);\n var placeholderImageProps = {\n title: title,\n alt: !this.state.isVisible ? alt : \"\",\n style: imagePlaceholderStyle,\n className: placeholderClassName,\n itemProp: itemProp\n }; // Initial client render state needs to match SSR until hydration finishes.\n // Once hydration completes, render again to update to the correct image.\n // `imageVariants` is always an Array type at this point due to `convertProps()`\n\n var image = !this.state.isHydrated ? imageVariants[0] : getCurrentSrcData(imageVariants);\n\n if (fluid) {\n return /*#__PURE__*/_react.default.createElement(Tag, {\n className: (className ? className : \"\") + \" gatsby-image-wrapper\",\n style: (0, _extends2.default)({\n position: \"relative\",\n overflow: \"hidden\",\n maxWidth: image.maxWidth ? image.maxWidth + \"px\" : null,\n maxHeight: image.maxHeight ? image.maxHeight + \"px\" : null\n }, style),\n ref: this.handleRef,\n key: \"fluid-\" + JSON.stringify(image.srcSet)\n }, /*#__PURE__*/_react.default.createElement(Tag, {\n \"aria-hidden\": true,\n style: {\n width: \"100%\",\n paddingBottom: 100 / image.aspectRatio + \"%\"\n }\n }), bgColor && /*#__PURE__*/_react.default.createElement(Tag, {\n \"aria-hidden\": true,\n title: title,\n style: (0, _extends2.default)({\n backgroundColor: bgColor,\n position: \"absolute\",\n top: 0,\n bottom: 0,\n opacity: !this.state.imgLoaded ? 1 : 0,\n right: 0,\n left: 0\n }, shouldFadeIn && delayHideStyle)\n }), image.base64 && /*#__PURE__*/_react.default.createElement(Placeholder, {\n ariaHidden: true,\n ref: this.placeholderRef,\n src: image.base64,\n spreadProps: placeholderImageProps,\n imageVariants: imageVariants,\n generateSources: generateBase64Sources\n }), image.tracedSVG && /*#__PURE__*/_react.default.createElement(Placeholder, {\n ariaHidden: true,\n ref: this.placeholderRef,\n src: image.tracedSVG,\n spreadProps: placeholderImageProps,\n imageVariants: imageVariants,\n generateSources: generateTracedSVGSources\n }), this.state.isVisible && /*#__PURE__*/_react.default.createElement(\"picture\", null, generateImageSources(imageVariants), /*#__PURE__*/_react.default.createElement(Img, {\n alt: alt,\n title: title,\n sizes: image.sizes,\n src: image.src,\n crossOrigin: this.props.crossOrigin,\n srcSet: image.srcSet,\n style: imageStyle,\n ref: this.imageRef,\n onLoad: this.handleImageLoaded,\n onError: this.props.onError,\n itemProp: itemProp,\n loading: loading,\n draggable: draggable\n })), this.addNoScript && /*#__PURE__*/_react.default.createElement(\"noscript\", {\n dangerouslySetInnerHTML: {\n __html: noscriptImg((0, _extends2.default)({\n alt: alt,\n title: title,\n loading: loading\n }, image, {\n imageVariants: imageVariants\n }))\n }\n }));\n }\n\n if (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 /*#__PURE__*/_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 }, bgColor && /*#__PURE__*/_react.default.createElement(Tag, {\n \"aria-hidden\": true,\n title: title,\n style: (0, _extends2.default)({\n backgroundColor: bgColor,\n width: image.width,\n opacity: !this.state.imgLoaded ? 1 : 0,\n height: image.height\n }, shouldFadeIn && delayHideStyle)\n }), image.base64 && /*#__PURE__*/_react.default.createElement(Placeholder, {\n ariaHidden: true,\n ref: this.placeholderRef,\n src: image.base64,\n spreadProps: placeholderImageProps,\n imageVariants: imageVariants,\n generateSources: generateBase64Sources\n }), image.tracedSVG && /*#__PURE__*/_react.default.createElement(Placeholder, {\n ariaHidden: true,\n ref: this.placeholderRef,\n src: image.tracedSVG,\n spreadProps: placeholderImageProps,\n imageVariants: imageVariants,\n generateSources: generateTracedSVGSources\n }), this.state.isVisible && /*#__PURE__*/_react.default.createElement(\"picture\", null, generateImageSources(imageVariants), /*#__PURE__*/_react.default.createElement(Img, {\n alt: alt,\n title: title,\n width: image.width,\n height: image.height,\n sizes: image.sizes,\n src: image.src,\n crossOrigin: this.props.crossOrigin,\n srcSet: image.srcSet,\n style: imageStyle,\n ref: this.imageRef,\n onLoad: this.handleImageLoaded,\n onError: this.props.onError,\n itemProp: itemProp,\n loading: loading,\n draggable: draggable\n })), this.addNoScript && /*#__PURE__*/_react.default.createElement(\"noscript\", {\n dangerouslySetInnerHTML: {\n __html: noscriptImg((0, _extends2.default)({\n alt: alt,\n title: title,\n loading: loading\n }, image, {\n imageVariants: imageVariants\n }))\n }\n }));\n }\n\n return null;\n };\n\n return Image;\n}(_react.default.Component);\n\nImage.defaultProps = {\n fadeIn: true,\n durationFadeIn: 500,\n alt: \"\",\n Tag: \"div\",\n // We set it to `lazy` by default because it's best to default to a performant\n // setting and let the user \"opt out\" to `eager`\n loading: \"lazy\"\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 media: _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 media: _propTypes.default.string,\n maxWidth: _propTypes.default.number,\n maxHeight: _propTypes.default.number\n});\n\nfunction requireFixedOrFluid(originalPropTypes) {\n return function (props, propName, componentName) {\n var _PropTypes$checkPropT;\n\n if (!props.fixed && !props.fluid) {\n throw new Error(\"The prop `fluid` or `fixed` is marked as required in `\" + componentName + \"`, but their values are both `undefined`.\");\n }\n\n _propTypes.default.checkPropTypes((_PropTypes$checkPropT = {}, _PropTypes$checkPropT[propName] = originalPropTypes, _PropTypes$checkPropT), props, \"prop\", componentName);\n };\n} // If you modify these propTypes, please don't forget to update following files as well:\n// https://github.com/gatsbyjs/gatsby/blob/master/packages/gatsby-image/index.d.ts\n// https://github.com/gatsbyjs/gatsby/blob/master/packages/gatsby-image/README.md#gatsby-image-props\n// https://github.com/gatsbyjs/gatsby/blob/master/docs/docs/gatsby-image.md#gatsby-image-props\n\n\nImage.propTypes = {\n resolutions: fixedObject,\n sizes: fluidObject,\n fixed: requireFixedOrFluid(_propTypes.default.oneOfType([fixedObject, _propTypes.default.arrayOf(fixedObject)])),\n fluid: requireFixedOrFluid(_propTypes.default.oneOfType([fluidObject, _propTypes.default.arrayOf(fluidObject)])),\n fadeIn: _propTypes.default.bool,\n durationFadeIn: _propTypes.default.number,\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 crossOrigin: _propTypes.default.oneOfType([_propTypes.default.string, _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 itemProp: _propTypes.default.string,\n loading: _propTypes.default.oneOf([\"auto\", \"lazy\", \"eager\"]),\n draggable: _propTypes.default.bool\n};\nvar _default = Image;\nexports.default = _default;","// extracted by mini-css-extract-plugin\nmodule.exports = {\"postArticleWrapper\":\"blog-index-module--postArticleWrapper--1wk4_\",\"contentWrapper\":\"blog-index-module--contentWrapper--DLcrs\",\"categoryHeaderFeatured\":\"blog-index-module--categoryHeaderFeatured--24qiV\",\"categoryHeader\":\"blog-index-module--categoryHeader--29JIt blog-index-module--categoryHeaderFeatured--24qiV\",\"categoryTitle\":\"blog-index-module--categoryTitle--3-9oG\",\"categoryLink\":\"blog-index-module--categoryLink--1XnN9\",\"categoryTitleForIndexPage\":\"blog-index-module--categoryTitleForIndexPage--2Bos0\",\"categoryLinkForIndexPage\":\"blog-index-module--categoryLinkForIndexPage--3tM9M\",\"postsRowWrapper\":\"blog-index-module--postsRowWrapper--HAot3\",\"postWrapper\":\"blog-index-module--postWrapper--2Bin2\",\"postWrapperFeature\":\"blog-index-module--postWrapperFeature--2Ujww blog-index-module--postWrapper--2Bin2\",\"featuredImageWrapper\":\"blog-index-module--featuredImageWrapper--10rQZ\",\"postFeatured\":\"blog-index-module--postFeatured--2Gseu\",\"postRegular\":\"blog-index-module--postRegular--3YXFD\",\"postTitle\":\"blog-index-module--postTitle--2Vnxa\",\"postTitleFeatured\":\"blog-index-module--postTitleFeatured--1WTMC blog-index-module--postTitle--2Vnxa\",\"postDate\":\"blog-index-module--postDate--3vmX-\",\"postExcerpt\":\"blog-index-module--postExcerpt--g1yzf\",\"socialShareWrapper\":\"blog-index-module--socialShareWrapper--2KWfy\",\"socialShareButton\":\"blog-index-module--socialShareButton--1z5J7\",\"blogPostTitle\":\"blog-index-module--blogPostTitle--2F_Gl\"};","module.exports = __webpack_public_path__ + \"static/Steven McCord_circle-1e8a3ac77d8c3ae7a3fc10841de2a2d6.png\";","// extracted by mini-css-extract-plugin\nmodule.exports = {\"bioWrapper\":\"bio-module--bioWrapper--7XxHv\",\"colBase\":\"bio-module--colBase--275CK\",\"avatar\":\"bio-module--avatar--3B4ef bio-module--colBase--275CK\",\"description\":\"bio-module--description--2vFcl bio-module--colBase--275CK\",\"date\":\"bio-module--date--33RAa bio-module--colBase--275CK\",\"aboutCompanyWrapper\":\"bio-module--aboutCompanyWrapper--3Mrli\",\"descriptionAboutCompany\":\"bio-module--descriptionAboutCompany--LyUBO bio-module--description--2vFcl bio-module--colBase--275CK\"};"],"sourceRoot":""}
\n By {authorName}\n
\n {isFull ? authorDescription : authorSummary[authorName] || null}\n