{"version":3,"sources":["webpack:///./src/components/bio.js","webpack:///./node_modules/gatsby-image/index.js"],"names":["Bio","data","useStaticQuery","site","siteMetadata","author","social","style","display","marginBottom","rhythm","fixed","avatar","childImageSharp","alt","name","marginRight","minWidth","borderRadius","imgStyle","summary","href","twitter","target","rel","_interopRequireDefault","require","exports","__esModule","default","io","_assertThisInitialized2","_inheritsLoose2","_objectWithoutPropertiesLoose2","_extends2","_react","_propTypes","convertProps","props","convertedProps","resolutions","sizes","critical","fluid","loading","groupByMedia","concat","matchesMedia","_ref","media","isBrowser","window","matchMedia","matches","getImageCacheKey","_ref2","srcData","getCurrentSrcData","src","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","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","objectFit","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","className","_convertProps$style","_convertProps$imgStyl","_convertProps$placeho","placeholderStyle","placeholderClassName","backgroundColor","durationFadeIn","Tag","itemProp","shouldReveal","shouldFadeIn","imageStyle","opacity","transition","bgColor","delayHideStyle","transitionDelay","imagePlaceholderStyle","placeholderImageProps","overflow","maxWidth","maxHeight","JSON","stringify","paddingBottom","aspectRatio","bottom","right","dangerouslySetInnerHTML","__html","divStyle","Component","defaultProps","fixedObject","shape","number","isRequired","string","srcWebp","fluidObject","requireFixedOrFluid","originalPropTypes","propName","componentName","_PropTypes$checkPropT","Error","checkPropTypes","oneOfType","arrayOf","bool","oneOf","_default"],"mappings":"6FAAA,sEAqEeA,IAxDH,WACV,IAAMC,EAAOC,yBAAe,cADZ,EAwBWD,EAAKE,KAAKC,aAA7BC,EAxBQ,EAwBRA,OAAQC,EAxBA,EAwBAA,OAChB,OACE,yBACEC,MAAO,CACLC,QAAQ,OACRC,aAAcC,YAAO,OAGvB,kBAAC,IAAD,CACEC,MAAOV,EAAKW,OAAOC,gBAAgBF,MACnCG,IAAKT,EAAOU,KACZR,MAAO,CACLS,YAAaN,YAAO,IACpBD,aAAc,EACdQ,SAAU,GACVC,aAAa,QAEfC,SAAU,CACRD,aAAa,SAGjB,yCACa,gCAASb,EAAOU,MAD7B,IAC6CV,EAAOe,QAClD,6BACA,uBAAGC,KAAI,uBAAyBf,EAAOgB,QAAWC,OAAO,SAASC,IAAI,cAAtE,yC,oCC3DR,IAAIC,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,EAAe5B,MAAQ6B,SAEhBD,EAAeC,aAGpBC,IACFF,EAAeI,MAAQF,SAEhBF,EAAeE,OAGpBC,IAEFH,EAAeK,QAAU,SAIvBL,EAAeI,QACjBJ,EAAeI,MAAQE,EAAa,GAAGC,OAAOP,EAAeI,SAG3DJ,EAAe5B,QACjB4B,EAAe5B,MAAQkC,EAAa,GAAGC,OAAOP,EAAe5B,SAGxD4B,GAsBLQ,EAAe,SAAsBC,GACvC,IAAIC,EAAQD,EAAKC,MACjB,QAAOA,IAAQC,KAAeC,OAAOC,WAAWH,GAAOI,UAUrDC,EAAmB,SAA0BC,GAC/C,IAAIZ,EAAQY,EAAMZ,MACdhC,EAAQ4C,EAAM5C,MACd6C,EAAUC,EAAkBd,GAAShC,GAAS,IAClD,OAAO6C,GAAWA,EAAQE,KASxBD,EAAoB,SAA2BE,GACjD,GAAIT,GAtCuB,SAAgCS,GAC3D,QAASA,GAAeC,MAAMC,QAAQF,IAAgBA,EAAYG,MAAK,SAAUC,GAC/E,YAA8B,IAAhBA,EAAMd,SAoCLe,CAAuBL,GAAc,CAEpD,IAAIM,EAAaN,EAAYO,UAAUnB,GAEvC,IAAoB,IAAhBkB,EACF,OAAON,EAAYM,GAIrB,IAAIE,EAAUR,EAAYO,WAAU,SAAUH,GAC5C,YAA8B,IAAhBA,EAAMd,SAGtB,IAAiB,IAAbkB,EACF,OAAOR,EAAYQ,GAKvB,OAAOR,EAAY,IAKjBS,EAAaC,OAAOC,OAAO,IAE3BC,EAAe,SAAsBjC,GACvC,IAAIC,EAAiBF,EAAaC,GAC9BkC,EAAWlB,EAAiBf,GAChC,OAAO6B,EAAWI,KAAa,GAa7BC,EAAuD,oBAArBC,kBAAoC,YAAaA,iBAAiBC,UACpGzB,EAA8B,oBAAXC,OACnByB,EAAe1B,GAAaC,OAAO0B,qBAEnCC,EAAY,IAAIC,QAwBpB,SAASC,EAAqBC,GAC5B,OAAOA,EAAcC,KAAI,SAAUC,GACjC,IAAIzB,EAAMyB,EAAMzB,IACZ0B,EAASD,EAAMC,OACfC,EAAaF,EAAME,WACnBpC,EAAQkC,EAAMlC,MACdR,EAAQ0C,EAAM1C,MAClB,OAAoBN,EAAON,QAAQyD,cAAcnD,EAAON,QAAQ0D,SAAU,CACxEC,IAAK9B,GACJ2B,GAA2BlD,EAAON,QAAQyD,cAAc,SAAU,CACnEG,KAAM,aACNxC,MAAOA,EACPmC,OAAQC,EACR5C,MAAOA,IACL2C,GAAuBjD,EAAON,QAAQyD,cAAc,SAAU,CAChErC,MAAOA,EACPmC,OAAQA,EACR3C,MAAOA,QAOb,SAASI,EAAaoC,GACpB,IAAIS,EAAY,GACZC,EAAU,GASd,OARAV,EAAcW,SAAQ,SAAUC,GAC9B,OAAQA,EAAQ5C,MAAQyC,EAAYC,GAASG,KAAKD,MAO7C,GAAG/C,OAAO4C,EAAWC,GAG9B,SAASI,EAAyBd,GAChC,OAAOA,EAAcC,KAAI,SAAUc,GACjC,IAAItC,EAAMsC,EAAMtC,IACZT,EAAQ+C,EAAM/C,MACdgD,EAAYD,EAAMC,UACtB,OAAoB9D,EAAON,QAAQyD,cAAc,SAAU,CACzDE,IAAK9B,EACLT,MAAOA,EACPmC,OAAQa,OAKd,SAASC,EAAsBjB,GAC7B,OAAOA,EAAcC,KAAI,SAAUiB,GACjC,IAAIzC,EAAMyC,EAAMzC,IACZT,EAAQkD,EAAMlD,MACdmD,EAASD,EAAMC,OACnB,OAAoBjE,EAAON,QAAQyD,cAAc,SAAU,CACzDE,IAAK9B,EACLT,MAAOA,EACPmC,OAAQgB,OAKd,SAASC,EAAuBC,EAAOC,GACrC,IAAInB,EAASkB,EAAMlB,OACfC,EAAaiB,EAAMjB,WACnBpC,EAAQqD,EAAMrD,MACdR,EAAQ6D,EAAM7D,MAKlB,MAAO,YAFQ8D,EAAS,qBAAuB,KAD/BtD,EAAQ,UAAaA,EAAQ,KAAQ,IAGV,YAJjCsD,EAASlB,EAAaD,GAI+B,MAD/C3C,EAAQ,UAAaA,EAAQ,KAAQ,IAC8B,KASrF,IAAI+D,EAAwB,SAA+BC,EAAIC,GAC7D,IAAIC,QAxGc,IAAP7E,GAAwC,oBAAXqB,QAA0BA,OAAO0B,uBACvE/C,EAAK,IAAIqB,OAAO0B,sBAAqB,SAAU+B,GAC7CA,EAAQhB,SAAQ,SAAUiB,GACxB,GAAI/B,EAAUgC,IAAID,EAAMtF,QAAS,CAC/B,IAAImF,EAAK5B,EAAUiC,IAAIF,EAAMtF,SAEzBsF,EAAMG,gBAAkBH,EAAMI,kBAAoB,KACpDnF,EAAGoF,UAAUL,EAAMtF,QACnBuD,EAAUqC,OAAON,EAAMtF,QACvBmF,WAIL,CACDU,WAAY,WAITtF,GA6FP,OALI6E,IACFA,EAASU,QAAQZ,GACjB3B,EAAUwC,IAAIb,EAAIC,IAGb,WACLC,EAASO,UAAUT,GACnB3B,EAAUqC,OAAOV,KAIjBc,EAAc,SAAqBjF,GAGrC,IAAIoB,EAAMpB,EAAMoB,IAAM,QAAWpB,EAAMoB,IAAM,KAAQ,UAEjDjB,EAAQH,EAAMG,MAAQ,UAAaH,EAAMG,MAAQ,KAAQ,GACzD2C,EAAS9C,EAAM8C,OAAS,WAAc9C,EAAM8C,OAAS,KAAQ,GAC7DoC,EAAQlF,EAAMkF,MAAQ,UAAalF,EAAMkF,MAAQ,KAAQ,GACzD1G,EAAMwB,EAAMxB,IAAM,QAAWwB,EAAMxB,IAAM,KAAQ,UAEjD2G,EAAQnF,EAAMmF,MAAQ,UAAanF,EAAMmF,MAAQ,KAAQ,GACzDC,EAASpF,EAAMoF,OAAS,WAAcpF,EAAMoF,OAAS,KAAQ,GAC7DC,EAAcrF,EAAMqF,YAAc,gBAAmBrF,EAAMqF,YAAc,KAAQ,GACjF/E,EAAUN,EAAMM,QAAU,YAAeN,EAAMM,QAAU,KAAQ,GACjEgF,EAAYtF,EAAMsF,UAAY,cAAiBtF,EAAMsF,UAAY,KAAQ,GAE7E,MAAO,YAD+BtF,EAAM2C,cAlCvBC,KAAI,SAAUW,GACjC,OAAQA,EAAQR,WAAagB,EAAuBR,GAAS,GAAQ,IAAMQ,EAAuBR,MACjGgC,KAAK,IAiCuB,QAAUjF,EAAU6E,EAAQC,EAASjF,EAAQ2C,EAAS1B,EAAM5C,EAAM0G,EAAQG,EAAcC,EAAY,+HAMjIE,EAA2B3F,EAAON,QAAQkG,YAAW,SAAUzF,EAAO0F,GACxE,IAAItE,EAAMpB,EAAMoB,IACZuB,EAAgB3C,EAAM2C,cACtBgD,EAAkB3F,EAAM2F,gBACxBC,EAAc5F,EAAM4F,YACpBC,EAAa7F,EAAM6F,WAEnBC,EAAyBjG,EAAON,QAAQyD,cAAc+C,GAAK,EAAInG,EAAUL,SAAS,CACpFmG,IAAKA,EACLtE,IAAKA,GACJwE,EAAa,CACdC,WAAYA,KAGd,OAAOlD,EAAcqD,OAAS,EAAiBnG,EAAON,QAAQyD,cAAc,UAAW,KAAM2C,EAAgBhD,GAAgBmD,GAAaA,KAGxIC,EAAmBlG,EAAON,QAAQkG,YAAW,SAAUzF,EAAO0F,GAChE,IAAIvF,EAAQH,EAAMG,MACd2C,EAAS9C,EAAM8C,OACf1B,EAAMpB,EAAMoB,IACZnD,EAAQ+B,EAAM/B,MACdgI,EAASjG,EAAMiG,OACfC,EAAUlG,EAAMkG,QAChB5F,EAAUN,EAAMM,QAChBgF,EAAYtF,EAAMsF,UAClBO,EAAa7F,EAAM6F,WACnBM,GAAa,EAAIxG,EAA+BJ,SAASS,EAAO,CAAC,QAAS,SAAU,MAAO,QAAS,SAAU,UAAW,UAAW,YAAa,eACrJ,OAAoBH,EAAON,QAAQyD,cAAc,OAAO,EAAIpD,EAAUL,SAAS,CAC7E,cAAesG,EACf1F,MAAOA,EACP2C,OAAQA,EACR1B,IAAKA,GACJ+E,EAAY,CACbF,OAAQA,EACRC,QAASA,EACTR,IAAKA,EACLpF,QAASA,EACTgF,UAAWA,EACXrH,OAAO,EAAI2B,EAAUL,SAAS,CAC5B6G,SAAU,WACVC,IAAK,EACLC,KAAM,EACNnB,MAAO,OACPC,OAAQ,OACRmB,UAAW,QACXC,eAAgB,UACfvI,SAIP8H,EAAIU,UAAY,CACdxI,MAAO6B,EAAWP,QAAQmH,OAC1BR,QAASpG,EAAWP,QAAQoH,KAC5BV,OAAQnG,EAAWP,QAAQoH,MAG7B,IAAIC,EAAqB,SAAUC,GAGjC,SAASD,EAAM5G,GACb,IAAI8G,GAEJA,EAAQD,EAAiBE,KAAKC,KAAMhH,IAAUgH,MAGxCC,WAAarG,GAAaqB,EAAajC,GAC7C8G,EAAMI,WAA+B,UAAlBlH,EAAMM,SAAuBN,EAAMI,SACtD0G,EAAMK,cAAgBL,EAAMI,aAAelH,EAAMoH,QACjDN,EAAMO,cAAgBlF,GAA4BG,IAAiBwE,EAAMI,aAAeJ,EAAMG,WAC9F,IAAIK,EAAYR,EAAMI,YAActG,IAAcuB,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,WAAY9G,IAGVoG,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,SAAmBtC,GACpC,IAAIiD,EAAS3B,KAETA,KAAKK,cAAgB3B,IACvBsB,KAAK0B,iBAAmBxE,EAAsBwB,GAAK,WACjD,IAAIkD,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,EAAWlB,EAAiBf,MAG9B6B,EAAWI,IAAY,GA4SvB8E,KAAKmB,SAAS,CACZX,WAAW,IAGTR,KAAKhH,MAAMiG,QACbe,KAAKhH,MAAMiG,UAIfgC,EAAOa,OAAS,WACd,IAAIC,EAAgBhJ,EAAaiH,KAAKhH,OAClCkF,EAAQ6D,EAAc7D,MACtB1G,EAAMuK,EAAcvK,IACpBwK,EAAYD,EAAcC,UAC1BC,EAAsBF,EAAc9K,MACpCA,OAAgC,IAAxBgL,EAAiC,GAAKA,EAC9CC,EAAwBH,EAAclK,SACtCA,OAAqC,IAA1BqK,EAAmC,GAAKA,EACnDC,EAAwBJ,EAAcK,iBACtCA,OAA6C,IAA1BD,EAAmC,GAAKA,EAC3DE,EAAuBN,EAAcM,qBACrChJ,EAAQ0I,EAAc1I,MACtBhC,EAAQ0K,EAAc1K,MACtBiL,EAAkBP,EAAcO,gBAChCC,EAAiBR,EAAcQ,eAC/BC,EAAMT,EAAcS,IACpBC,EAAWV,EAAcU,SACzBnJ,EAAUyI,EAAczI,QACxBgF,EAAYyD,EAAczD,UAE1B3C,EAAgBtC,GAAShC,EAE7B,IAAKsE,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/D1K,GACCkL,EAAqC,kBAApBT,EAAgC,YAAcA,EAC/DU,EAAiB,CACnBC,gBAAiBV,EAAiB,MAEhCW,GAAwB,EAAItK,EAAUL,SAAS,CACjDsK,QAAS7C,KAAKO,MAAMC,UAAY,EAAI,GACnCmC,GAAgBK,EAAgBnL,EAAUuK,GACzCe,EAAwB,CAC1BjF,MAAOA,EACP1G,IAAMwI,KAAKO,MAAMD,UAAkB,GAAN9I,EAC7BP,MAAOiM,EACPlB,UAAWK,EACXI,SAAUA,GAKRhI,EAASuF,KAAKO,MAAMG,WAAgCvG,EAAkBwB,GAArCA,EAAc,GAEnD,GAAItC,EACF,OAAoBR,EAAON,QAAQyD,cAAcwG,EAAK,CACpDR,WAAYA,GAAwB,IAAM,wBAC1C/K,OAAO,EAAI2B,EAAUL,SAAS,CAC5B6G,SAAU,WACVgE,SAAU,SACVC,SAAU5I,EAAM4I,SAAW5I,EAAM4I,SAAW,KAAO,KACnDC,UAAW7I,EAAM6I,UAAY7I,EAAM6I,UAAY,KAAO,MACrDrM,GACHyH,IAAKsB,KAAKgB,UACV9E,IAAK,SAAWqH,KAAKC,UAAU/I,EAAMqB,SACvBjD,EAAON,QAAQyD,cAAcwG,EAAK,CAChD,eAAe,EACfvL,MAAO,CACLkH,MAAO,OACPsF,cAAe,IAAMhJ,EAAMiJ,YAAc,OAEzCX,GAAwBlK,EAAON,QAAQyD,cAAcwG,EAAK,CAC5D,eAAe,EACftE,MAAOA,EACPjH,OAAO,EAAI2B,EAAUL,SAAS,CAC5B+J,gBAAiBS,EACjB3D,SAAU,WACVC,IAAK,EACLsE,OAAQ,EACRd,QAAU7C,KAAKO,MAAMC,UAAgB,EAAJ,EACjCoD,MAAO,EACPtE,KAAM,GACLqD,GAAgBK,KACjBvI,EAAMqC,QAAuBjE,EAAON,QAAQyD,cAAcwC,EAAa,CACzEK,YAAY,EACZH,IAAKsB,KAAKa,eACVzG,IAAKK,EAAMqC,OACX8B,YAAauE,EACbxH,cAAeA,EACfgD,gBAAiB/B,IACfnC,EAAMkC,WAA0B9D,EAAON,QAAQyD,cAAcwC,EAAa,CAC5EK,YAAY,EACZH,IAAKsB,KAAKa,eACVzG,IAAKK,EAAMkC,UACXiC,YAAauE,EACbxH,cAAeA,EACfgD,gBAAiBlC,IACfuD,KAAKO,MAAMD,WAA0BzH,EAAON,QAAQyD,cAAc,UAAW,KAAMN,EAAqBC,GAA6B9C,EAAON,QAAQyD,cAAc+C,EAAK,CACzKvH,IAAKA,EACL0G,MAAOA,EACP/E,MAAOsB,EAAMtB,MACbiB,IAAKK,EAAML,IACXiE,YAAa2B,KAAKhH,MAAMqF,YACxBvC,OAAQrB,EAAMqB,OACd7E,MAAO2L,EACPlE,IAAKsB,KAAKW,SACV1B,OAAQe,KAAKc,kBACb5B,QAASc,KAAKhH,MAAMkG,QACpBuD,SAAUA,EACVnJ,QAASA,EACTgF,UAAWA,KACR0B,KAAKG,aAA4BtH,EAAON,QAAQyD,cAAc,WAAY,CAC7E6H,wBAAyB,CACvBC,OAAQ7F,GAAY,EAAIrF,EAAUL,SAAS,CACzCf,IAAKA,EACL0G,MAAOA,EACP5E,QAASA,GACRmB,EAAO,CACRkB,cAAeA,SAMvB,GAAItE,EAAO,CACT,IAAI0M,GAAW,EAAInL,EAAUL,SAAS,CACpC6G,SAAU,WACVgE,SAAU,SACVlM,QAAS,eACTiH,MAAO1D,EAAM0D,MACbC,OAAQ3D,EAAM2D,QACbnH,GAMH,MAJsB,YAAlBA,EAAMC,gBACD6M,EAAS7M,QAGE2B,EAAON,QAAQyD,cAAcwG,EAAK,CACpDR,WAAYA,GAAwB,IAAM,wBAC1C/K,MAAO8M,EACPrF,IAAKsB,KAAKgB,UACV9E,IAAK,SAAWqH,KAAKC,UAAU/I,EAAMqB,SACpCiH,GAAwBlK,EAAON,QAAQyD,cAAcwG,EAAK,CAC3D,eAAe,EACftE,MAAOA,EACPjH,OAAO,EAAI2B,EAAUL,SAAS,CAC5B+J,gBAAiBS,EACjB5E,MAAO1D,EAAM0D,MACb0E,QAAU7C,KAAKO,MAAMC,UAAgB,EAAJ,EACjCpC,OAAQ3D,EAAM2D,QACbuE,GAAgBK,KACjBvI,EAAMqC,QAAuBjE,EAAON,QAAQyD,cAAcwC,EAAa,CACzEK,YAAY,EACZH,IAAKsB,KAAKa,eACVzG,IAAKK,EAAMqC,OACX8B,YAAauE,EACbxH,cAAeA,EACfgD,gBAAiB/B,IACfnC,EAAMkC,WAA0B9D,EAAON,QAAQyD,cAAcwC,EAAa,CAC5EK,YAAY,EACZH,IAAKsB,KAAKa,eACVzG,IAAKK,EAAMkC,UACXiC,YAAauE,EACbxH,cAAeA,EACfgD,gBAAiBlC,IACfuD,KAAKO,MAAMD,WAA0BzH,EAAON,QAAQyD,cAAc,UAAW,KAAMN,EAAqBC,GAA6B9C,EAAON,QAAQyD,cAAc+C,EAAK,CACzKvH,IAAKA,EACL0G,MAAOA,EACPC,MAAO1D,EAAM0D,MACbC,OAAQ3D,EAAM2D,OACdjF,MAAOsB,EAAMtB,MACbiB,IAAKK,EAAML,IACXiE,YAAa2B,KAAKhH,MAAMqF,YACxBvC,OAAQrB,EAAMqB,OACd7E,MAAO2L,EACPlE,IAAKsB,KAAKW,SACV1B,OAAQe,KAAKc,kBACb5B,QAASc,KAAKhH,MAAMkG,QACpBuD,SAAUA,EACVnJ,QAASA,EACTgF,UAAWA,KACR0B,KAAKG,aAA4BtH,EAAON,QAAQyD,cAAc,WAAY,CAC7E6H,wBAAyB,CACvBC,OAAQ7F,GAAY,EAAIrF,EAAUL,SAAS,CACzCf,IAAKA,EACL0G,MAAOA,EACP5E,QAASA,GACRmB,EAAO,CACRkB,cAAeA,SAMvB,OAAO,MAGFiE,EAxSgB,CAySvB/G,EAAON,QAAQyL,WAEjBpE,EAAMqE,aAAe,CACnB7D,QAAQ,EACRmC,eAAgB,IAChB/K,IAAK,GACLgL,IAAK,MAGLlJ,QAAS,QAGX,IAAI4K,EAAcpL,EAAWP,QAAQ4L,MAAM,CACzChG,MAAOrF,EAAWP,QAAQ6L,OAAOC,WACjCjG,OAAQtF,EAAWP,QAAQ6L,OAAOC,WAClCjK,IAAKtB,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/B3K,MAAOb,EAAWP,QAAQ+L,SAGxBE,EAAc1L,EAAWP,QAAQ4L,MAAM,CACzCT,YAAa5K,EAAWP,QAAQ6L,OAAOC,WACvCjK,IAAKtB,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/B3K,MAAOb,EAAWP,QAAQ+L,OAC1BjB,SAAUvK,EAAWP,QAAQ6L,OAC7Bd,UAAWxK,EAAWP,QAAQ6L,SAGhC,SAASK,EAAoBC,GAC3B,OAAO,SAAU1L,EAAO2L,EAAUC,GAChC,IAAIC,EAEJ,IAAK7L,EAAM3B,QAAU2B,EAAMK,MACzB,MAAM,IAAIyL,MAAM,yDAA2DF,EAAgB,6CAG7F9L,EAAWP,QAAQwM,iBAAgBF,EAAwB,IAA0BF,GAAYD,EAAmBG,GAAwB7L,EAAO,OAAQ4L,IAQ/JhF,EAAMH,UAAY,CAChBvG,YAAagL,EACb/K,MAAOqL,EACPnN,MAAOoN,EAAoB3L,EAAWP,QAAQyM,UAAU,CAACd,EAAapL,EAAWP,QAAQ0M,QAAQf,MACjG7K,MAAOoL,EAAoB3L,EAAWP,QAAQyM,UAAU,CAACR,EAAa1L,EAAWP,QAAQ0M,QAAQT,MACjGpE,OAAQtH,EAAWP,QAAQ2M,KAC3B3C,eAAgBzJ,EAAWP,QAAQ6L,OACnClG,MAAOpF,EAAWP,QAAQ+L,OAC1B9M,IAAKsB,EAAWP,QAAQ+L,OACxBtC,UAAWlJ,EAAWP,QAAQyM,UAAU,CAAClM,EAAWP,QAAQ+L,OAAQxL,EAAWP,QAAQmH,SAEvFtG,SAAUN,EAAWP,QAAQ2M,KAC7B7G,YAAavF,EAAWP,QAAQyM,UAAU,CAAClM,EAAWP,QAAQ+L,OAAQxL,EAAWP,QAAQ2M,OACzFjO,MAAO6B,EAAWP,QAAQmH,OAC1B7H,SAAUiB,EAAWP,QAAQmH,OAC7B0C,iBAAkBtJ,EAAWP,QAAQmH,OACrC2C,qBAAsBvJ,EAAWP,QAAQ+L,OACzChC,gBAAiBxJ,EAAWP,QAAQyM,UAAU,CAAClM,EAAWP,QAAQ+L,OAAQxL,EAAWP,QAAQ2M,OAC7FjG,OAAQnG,EAAWP,QAAQoH,KAC3BT,QAASpG,EAAWP,QAAQoH,KAC5ByB,YAAatI,EAAWP,QAAQoH,KAChC6C,IAAK1J,EAAWP,QAAQ+L,OACxB7B,SAAU3J,EAAWP,QAAQ+L,OAC7BhL,QAASR,EAAWP,QAAQ4M,MAAM,CAAC,OAAQ,OAAQ,UACnD7G,UAAWxF,EAAWP,QAAQ2M,MAEhC,IAAIE,EAAWxF,EACfvH,EAAQE,QAAU6M","file":"cd7d5f864fc9e15ed8adef086269b0aeff617554-cda897c39fec669efbda.js","sourcesContent":["/**\n * Bio component that queries for data\n * with Gatsby's useStaticQuery component\n *\n * See: https://www.gatsbyjs.org/docs/use-static-query/\n */\n\nimport React from \"react\"\nimport { useStaticQuery, graphql } from \"gatsby\"\nimport Image from \"gatsby-image\"\n\nimport { rhythm } from \"../utils/typography\"\n\nconst Bio = () => {\n const data = useStaticQuery(graphql`\n query BioQuery {\n avatar: file(absolutePath: { regex: \"/profile-pic.jpg/\" }) {\n childImageSharp {\n fixed(width: 50, height: 50) {\n ...GatsbyImageSharpFixed\n }\n }\n }\n site {\n siteMetadata {\n author {\n name\n summary\n }\n social {\n twitter\n }\n }\n }\n }\n `)\n\n const { author, social } = data.site.siteMetadata\n return (\n \n \n

\n Written by {author.name} {author.summary}\n

\n \n You should follow him on Twitter.\n \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;"],"sourceRoot":""}