@graphcommerce/image 2.105.8 → 2.105.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (338) hide show
  1. package/example/.next/build-manifest.json +34 -0
  2. package/example/.next/cache/images/-HVj9kxSkhJbEZEzJL5NAtVW-u8TJ523pV0gOjw1--U=/1656761718343.g+b6VAyYfz-VIgqhPopw+-RX62-WCBq5CTxdVPJ75Vk=.webp +0 -0
  3. package/example/.next/cache/images/0AxIIzYSO-2GyMgpS4xIF3BFoscLS34mhauz5mXVqJI=/1656759656442.NBBV5492hL3QVNkmiFNlwRcY6wuplArFk0uPSkVzZ58=.webp +0 -0
  4. package/example/.next/cache/images/1uj6MCqnWAg9G4AXu+RJEh7K5QHy8VI4Y8ObOpU5IWQ=/1656757031249.VBybHurr5aiEFOzpuVXHhwBOCF1G+Hnp8-GFzxjCNKg=.webp +0 -0
  5. package/example/.next/cache/images/2CMowrXl2P7YIz49CHi5gPtsp-gXV9ZDKqoWiS5hkgg=/1625470305766.rUaLjCqfuLKwkvaizd3g3TjzYGo3W8ANpZIUgzZh00Y=.webp +0 -0
  6. package/example/.next/cache/images/2prvJygajL4oBYGVG5HGNf-JaL-XmFDIpbahHqRCWEg=/1625298564969.7tWao0CKoVY673JEnP1IP-G6bNjQvDP5sxvUAq1X3KM=.webp +0 -0
  7. package/example/.next/cache/images/3NxY-MLy0nY73yQFX-qsDAkXMgiMq8iWud4VVdU8I0o=/1625299547154.rpuCm5pugpQ6IK28LsWKUGLk+P2ZtehuBgJTOX-6zlA=.webp +0 -0
  8. package/example/.next/cache/images/3UPUXn6t--gJO9HNBHFJulrS3paVQoKP5-Wu41KkrR8=/1656758598282.BZMn4WYPgB+gq-BR3w1-5MwG1AdBRAVpYWGWxNVW-KE=.webp +0 -0
  9. package/example/.next/cache/images/3ucItT2KUqDcjKA+4Dl8YhPsb3qbPW8shQeD5JogEp0=/1656749533975.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  10. package/example/.next/cache/images/4aSxJpLrV7SgzFGFQe1JbHJTiVGRNl4YdKl2iZqTz6c=/1625299570724.mruw0gK2J1y6VIaCvayFrs7ltIasseRnQjCS1Rx7zNI=.webp +0 -0
  11. package/example/.next/cache/images/4u0SwKJhO4a+ZARfOmnUAY+bQvzdjsw8AOIk6sRiVTM=/1625469705760.rueREa67ebDmXGY+W3G-eopQp5EK-SQHOa4KHFuqVNo=.webp +0 -0
  12. package/example/.next/cache/images/5H41dGaHwg71zktiD3Ks9K8yaZ1e9lsBag4NHyoIUdo=/1625219570987.zIxZGRHl91NEtnV4nbyU0rB3EtEyR9Lxnri-+voKAvs=.webp +0 -0
  13. package/example/.next/cache/images/64IULfOR-D0oVW4sHrfc5WtPLdjLPbkoNKHdCwWGSuQ=/1625219570994.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  14. package/example/.next/cache/images/6Dgu5A6GajPsgDQ66k-pbq0Iyr0Byrn7+mivxE4fvVU=/1656758443091.KL97JxovJgisoPc5EXEfrrnnqyRymWEBTSqLA8Uy5lE=.webp +0 -0
  15. package/example/.next/cache/images/6Zcso+WcU0OlZ-atPSh40Gljk74hWpvqMF88bf-3Qys=/1656749578452.zIxZGRHl91NEtnV4nbyU0rB3EtEyR9Lxnri-+voKAvs=.webp +0 -0
  16. package/example/.next/cache/images/7Xkon9LFmZ6wE0IgEIsfUN0bOr0oCSOXaDnnrVjSoXo=/1625300548289.8yJB9XC45AIM6XoUsu8htXCK2wYvqnWCKbnxO3MmpsU=.webp +0 -0
  17. package/example/.next/cache/images/7vvZbnWp2pvmwNgUNIKXmCk9XhfIOYqyBy1xwOMmxZE=/1625470260322.onl4+lYWryHL62flX4FJdXEMQ1UVnyT5sBYF1DggMaQ=.webp +0 -0
  18. package/example/.next/cache/images/83VK7ld0YcmgdOG+R2h+ckiGWOVKzIn42CnTelSeAD0=/1657107410585.OC5j-AyaLksS78WoFh2ZPpURObFKvSCnpt9rqzn7tNY=.webp +0 -0
  19. package/example/.next/cache/images/8qtv2hTcdwZiVYN5j5XNVw4eDlHblWR91R1ilGPHF4g=/1625300457906.pVKudFsHslINh1TOUoOPSHb8op8iqiQ3IVE78QQH0qU=.webp +0 -0
  20. package/example/.next/cache/images/B8i6U4dvhS5QlonuTChvnVeIfVNcMFP5Ze9dGHpLu0A=/1625213911796.zMx5v1d6EgYxzhH5u9vceuQAZdrlkrwNiW-EzuaYMnw=.webp +0 -0
  21. package/example/.next/cache/images/BW0ysRJMh9oulzEYbELupyRAI1rZZ5be0xuxnDLc-bw=/1656761231260.zspGYR3AWdcc816W2F6Ne1-JNgSDBH1h6KEFeVLnWok=.webp +0 -0
  22. package/example/.next/cache/images/BY6YpwPh82mp5JiBEti5gmwC-9O4ohRUPluASqROc10=/1625498155146.EJMSOifv8id0Peguf7ikEne7xMi9Ac9iDe9kTIAAXvY=.webp +0 -0
  23. package/example/.next/cache/images/CUGp4g70zl+vsFGT41IZkj-Y2votkqh3Eezzs9H3H5w=/1625299521288.EnYAcm4cT6T5yKVAQDTY6cZti0zsxnVbImrF7LfgF1Y=.webp +0 -0
  24. package/example/.next/cache/images/DJ3B5hLxX-+UMbqed+x58+rl9juscSn+Ra7YA8CNkkY=/1625484120800.SAng7YQ8PDlPQNubgLkMMsiFwaPCuTeDBsfUyvmttG4=.webp +0 -0
  25. package/example/.next/cache/images/DW4yKnn+mYRfs8-2Ko5oE3DrZbJMhFNEmGp90CyT7O0=/1625300236026.VFNPRZf-z9qFOV2S5AbunCkRGCcPXzlwiTKrNjmNGi8=.webp +0 -0
  26. package/example/.next/cache/images/Dh5jFfTTZHXju+2VMueg1Lo7sM3GkEWBlgWZ37h29ME=/1625474260306.gkzHU98m9zIqApL3d93FWcZqGULcRirOdpOxzJgPTK8=.webp +0 -0
  27. package/example/.next/cache/images/Du4jaIoZ-PXvqN2avgQOOGlaQg-Vt4QUVcukv77Hm7w=/1656756770777.kZnEJ9pDGRP7pgjpXGDPuV-HLcq5hWt9eWAFm6G84OI=.webp +0 -0
  28. package/example/.next/cache/images/EqW5whXX7fgu5+SPdxyBZ4fE0fOWCLMo9b5W7hd28iY=/1625571324722.txUxO6DkO8veTJ1oLkXvvNgVuTbvHdj4MVBwHIu-eus=.webp +0 -0
  29. package/example/.next/cache/images/GKXPXPApDNp1ZIjYBtQk7dd3rnbKh7NElD+WIyHa8js=/1656756098400.lgHCIyknPFqSgPVSBuQffgINRpboZCYlBKftrwpBLkA=.webp +0 -0
  30. package/example/.next/cache/images/GTOHdx8sLxs79IJinD+Nk80LrOg0DaC9h3d8TAby3bs=/1657107680617.OC5j-AyaLksS78WoFh2ZPpURObFKvSCnpt9rqzn7tNY=.webp +0 -0
  31. package/example/.next/cache/images/GnqqaGL66JFx1j+fCokxnnujneezplnVU7gYhckh9+A=/1625299583173.dgcaCltbHvvFCi1sPMucuHCL9UCtWiFSyOAYH-v2LtU=.webp +0 -0
  32. package/example/.next/cache/images/HTqsLdQpcguBI7BE1SfU-i2MwHyN3krlryhF1BEPj3M=/1657107680404.c8k-vRV2T9vq1REo-K4LzVwKVUP5lQuho4ubYzHj544=.webp +0 -0
  33. package/example/.next/cache/images/HroIIPKGVQ42ycMx-gSdWVFfchcgf8J-XU3FJOZhpmk=/1625570328298.IUpe91jGi-RlVgrjYmX7wkMcXIIYvodu5j4BqaKZcss=.webp +0 -0
  34. package/example/.next/cache/images/HsTN95OGw5aJGpWWSep-H7pXMN32ZSfW86FEPFe02K8=/1625299498281.1gBokMmVVuor1gnCAbJvXKp1sytwxY0A-VcmYIwXm7g=.webp +0 -0
  35. package/example/.next/cache/images/JRIhYbicTTQFjjKlC-aW9QRo+2KiSk80+wi0T+FeWQ4=/1656756648992.kZnEJ9pDGRP7pgjpXGDPuV-HLcq5hWt9eWAFm6G84OI=.webp +0 -0
  36. package/example/.next/cache/images/KtPkhGYwacFij4NA7Z4VNrRLb21KQUty7jAgxxv7tAE=/1625565460203.83IxQdLmWiSE2uISXx1KtUWFzH+wlQzRq3azOBbUtnQ=.webp +0 -0
  37. package/example/.next/cache/images/MPZjiVEFZqHRi2TtFwyHot9phvfEIcDLWmmyrYFIHAQ=/1625299521601.0uwV84UCn-oB-gRLRxi8DD2sl7zK5emgxfblkV3Dvhc=.webp +0 -0
  38. package/example/.next/cache/images/MT6MCs8Nc+PJ2byqQCa1HW8Xp4OTRNnb6kLgLwDGLZo=/1656762484828.heenQ4-yt4r55ULQ0ofqHJ1j8eTKD8ksx640PPhaqP8=.webp +0 -0
  39. package/example/.next/cache/images/MiOwljI0QJwKEuOg3n2Gp3J0qyXXNOXE8ttWHB7CHa0=/1625567166356.KCzRRP4Cub2rpOYKetN+L9dCJTAsFVW-GkP0NRsQbcM=.webp +0 -0
  40. package/example/.next/cache/images/OcFEP0e8eNeBt9ck16eoMwSpfJleEwCMpm1ZbdqT4uo=/1656749533901.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  41. package/example/.next/cache/images/PPUtJ0W6DfemefElrKITkTNq7MVnHyMS38XuEtsy89U=/1656761403704.zlagepWT8AKDwOh4aJODpXTOFN+FobGMo1L6WuOVNwY=.webp +0 -0
  42. package/example/.next/cache/images/PaxNiuRifROBs1R1uM75REC6kUAfiYOLrtQAiK1P2nU=/1625213904646.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  43. package/example/.next/cache/images/PqLR89B4R1+qzyEVqVw9OQhSmFy5JuXLa64i3LYpJxE=/1625299444323.ThlpSva2rHbbbp958zCj1tdrgMqjFcGYnaDRo2wQQLU=.webp +0 -0
  44. package/example/.next/cache/images/Q8f9uZJBks2H-YkwdWd2QMgMX5mL5FBMo0VsHO-ctdo=/1656760649959.qh3caBPe-Th-zaMPDt-ZdhSBl91dRP8N9s3EJ6UMQCs=.webp +0 -0
  45. package/example/.next/cache/images/RP6k9Bj4-jsHEycAYxFHZhLqKTmbLMjucvDSvlyLLZs=/1657107680610.Yg+3ChC1edO6kEAwbaim2hCjb8Wyh4toEpEOzcilUL0=.webp +0 -0
  46. package/example/.next/cache/images/SHd0AXJTfPXkImZMKmp27MvqUvYI111zyzIOkLgtCb0=/1625299593567.TvdLtgnmAXbrBjg8nRUCWyBuQNstKWJTmF-wV4728B8=.webp +0 -0
  47. package/example/.next/cache/images/SHhlhVL9L57O78uM0iSaBgxVR9J7EKRa67Ito-z2rr4=/1625300308618.po7Imjgw32SuMQKt1-Oty+v5w-l64kmnJHzwul9giqo=.webp +0 -0
  48. package/example/.next/cache/images/SKUjqmwgFQbQ2Q6MjsEPStCv9Q-+CeDEv66+YXRb2wY=/1625299577727.ZqADH5sK9bpHXGGKzDBkLCjPfDO+oTBSZlFZyEAOo9w=.webp +0 -0
  49. package/example/.next/cache/images/ShHgXRk5XG5XLtxR20jbimMMzYyCjZYWCyrSOBcRyoU=/1625299553057.Tg2j6WSVMgii8RrZgrt4twY3IKhtmUMHplwYzi-hh70=.webp +0 -0
  50. package/example/.next/cache/images/TZiyZjIDqFs6d60EaSVU3oX2L1bCkImChBpIWqOREeg=/1625299514280.rC+4Pdzi1RPfIvqsEFdtuGJL9sPG4+sel+0v3cfnJpk=.webp +0 -0
  51. package/example/.next/cache/images/YKC4gyKqaL5abLjWnWAv+OgECV0oK00TZ1P5130s4ig=/1625300636674.q2+QpCTCb2zgc0H3rXxU17I4lALn3BLpChG0i7WZMew=.webp +0 -0
  52. package/example/.next/cache/images/Z0Y8VikQqHdIyl12mjEQKArSNnKgqb5MgUYp+RJ5EO4=/1656761463364.kZnEJ9pDGRP7pgjpXGDPuV-HLcq5hWt9eWAFm6G84OI=.webp +0 -0
  53. package/example/.next/cache/images/aoSFeHouZT4mEYTInYHZHTBtgeKvEELQADTBcRV6hkw=/1625298476457.T0UaZPCESw+8pja9oQlbUDVINYgmacs0lCsbFS5R7vc=.webp +0 -0
  54. package/example/.next/cache/images/c9dcuiQ8O5e6pwHRxJtUCx3tFTD5fk0GH07hStsE6Q0=/1657107680401.jwYrFWs2M9PlA3K2ZZaR7tQk1BCwIU3EyAw9b-RBJGc=.webp +0 -0
  55. package/example/.next/cache/images/cTF2A44FXn8nLM91wKUoIEqhphWsnHQeM19UXTYuCjU=/1625566943586.FsHRv9b2D1Qu0XuUCIC0AB2goFSO+maM7H+SE4GSn1U=.webp +0 -0
  56. package/example/.next/cache/images/cVH7moJ73vvxuB1En1mtSjyjCAn7ZedMLuWgvI8YD9U=/1656759920737.rpQVMyg-AaUmlLQcsNkRBcHwqIhhb5bVfXmej8NL3Ls=.webp +0 -0
  57. package/example/.next/cache/images/dSxPG4mvFB-hsFa2WNNKGVH+EM8F73q59MOz+d84wt0=/1625470290291.9SaCLJMI8CiS-JzFL7TaZTfWXnpzp2E6eTe+RFZYv-c=.webp +0 -0
  58. package/example/.next/cache/images/dw-FglYBg89Atjb1B0R85+AwxeHSPUjuO8Kh1CV0-m4=/1625497900295.xFYayjV9nBGOKUTVq5XxlGEIWR5B5NOtP2X6N9gcAUo=.webp +0 -0
  59. package/example/.next/cache/images/f0TzeTFnAY-0ltYUi9v76DWDq3xCt2-9uBbQx4xeK3E=/1625299582181.v4L5Aguf03P1aXwUUG2yzWa4jsIkRvG35rv7Xk2e3Yg=.webp +0 -0
  60. package/example/.next/cache/images/fy3he+3cRQ9wtXvPOgCMpbECVEZpx-cdDDs+J0bnCl0=/1625219592716.zIxZGRHl91NEtnV4nbyU0rB3EtEyR9Lxnri-+voKAvs=.webp +0 -0
  61. package/example/.next/cache/images/g9PwkkYlS8p6OZa5PbvEmIxLFhwMULmPZ4JXWpN+m9E=/1625299465140.loc887GnjFgThYkCZOwQOxrUnC1XK+hbFpOxLOZV2YE=.webp +0 -0
  62. package/example/.next/cache/images/gEWhGfMHCTTgqNTJGXoavWIjsPe5-XHrTCOZoM0K3A0=/1625299501484.jzxT8QO8RG7s8Kz3g63dSfVxZEFiu6uGPLFz3e2W7cU=.webp +0 -0
  63. package/example/.next/cache/images/iHANQk+34mFntRtrtUkKrthnmdjp6ruWLqwvBnj0shA=/1625219571001.+yVlIMc84gsVdgGr6dfpa+NKaYqXQLJb4rxP95iokjo=.webp +0 -0
  64. package/example/.next/cache/images/iTGjNMCKRRKWT6Se1ypy6B8G7VG3aE81NoYZWWuFkRM=/1625299505650.WGHxeAxX5Th696JjcRa8sgeI+xCA-D31-rJYa1TfqYc=.webp +0 -0
  65. package/example/.next/cache/images/iUy4uGqOpV5cYkmJQ6H1OenGKhlJKn8YXFjNrlAcoJM=/1625474121167.YG1FPtrJnhaldgLFyM0PYUrKRS4YzNPynIHRBAsZJpI=.webp +0 -0
  66. package/example/.next/cache/images/jiDD0qNI10KXQQAUzeRuRNNktq5a6AhagAaeeFC-TAQ=/1656761403766.MdJnQq7SbBrJRtJEjPRng-ovqekSsQAPxEoERZwU0AY=.webp +0 -0
  67. package/example/.next/cache/images/k6CGZJxOx65S31BJg2vWXcUUTInuc28HlY+vruC5p08=/1625300551403.vqRL7Mz7oVbXyhRHwxk5vtqXEHKbcR-xYitHMim2KoM=.webp +0 -0
  68. package/example/.next/cache/images/lUg+tPaN1bFXtqfifZGZF3zOXqUiJsVHbrj7P0CI9eE=/1656749479842.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  69. package/example/.next/cache/images/m2NzDIE4Ft53TdiwYp3ymfmxd-MB8H+NCDL9HP2heoQ=/1625570988005.GgcoTYV3RHmRWw83xvhRld3iVysMAhdfGrX91Zl0skk=.webp +0 -0
  70. package/example/.next/cache/images/n6WUQmM45C8h6AyLZQVtPJihzo+YXCGPZPoSLlieaeg=/1656749479842.+yVlIMc84gsVdgGr6dfpa+NKaYqXQLJb4rxP95iokjo=.webp +0 -0
  71. package/example/.next/cache/images/nRr2Uwi8fvy6WIpGEwEQdqIUrjmlZc6rJPhxxJa82Es=/1625213880032.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  72. package/example/.next/cache/images/o0N432kChXWOqK5UVRtqLsLDWb5+dYe2JvYO6d24vc0=/1625482549426.CaPu+NWbHtURILwAbvjOMW3vT0776ONf0tXGWzsaDnA=.webp +0 -0
  73. package/example/.next/cache/images/oCrD0LhpE+c2Igt0JD1Yw0kC7aOo62HQ-5wedgqBbzc=/1656761398353.f9SVRkSQOaIIA6GikQ8gIzTuFdteePWKPeSdEPKiVZ4=.webp +0 -0
  74. package/example/.next/cache/images/oQ6ibo6F3ySy2ESJgLZIdmbcWTiOP3Q0KhY2fpikQ5k=/1625299093245.wohGDcrAnckq4RxHw2+ScWJWe1Dk5fIwjyVoVBt5cEE=.webp +0 -0
  75. package/example/.next/cache/images/p7XzvB8oyN5nfu11eCA42SeEp7sL+LPQQoRU64YT1cc=/1625299322699.eYKIZha0lC4+LSV+ZINxWGGOfgqw30+9w2erMlPbFTA=.webp +0 -0
  76. package/example/.next/cache/images/pnG318NZ2UvU2k21miucoxLsd8wGC5T6lVtcIzbPgd0=/1625299443084.RDAllNEC0jZGUcFFZqqZrEKfEVth-wpANCdkO+jAVvE=.webp +0 -0
  77. package/example/.next/cache/images/sDmCscY0vQ6Ce3yhoIzfNRxh-aSDxq+RTOoq0cUN4cI=/1656756694154.vDQunPJtcqmDa5Dw3GNOsYnbPoyIC9zEHXjUgRX+5VI=.webp +0 -0
  78. package/example/.next/cache/images/tv5navWlSovKHHXAA+lKFltBgdnGNbCL3KnX761Ycus=/1625566936879.641rNXHFuO1fzs0BSgp5C+Sw+zWBQp6CJs4+utqZU1c=.webp +0 -0
  79. package/example/.next/cache/images/utC1kNaPpZdZepwnTfNu9cW-3ICXwUkEoLi+pTgGKO8=/1656749851790.zMx5v1d6EgYxzhH5u9vceuQAZdrlkrwNiW-EzuaYMnw=.webp +0 -0
  80. package/example/.next/cache/images/v156Um7QIAhI-jW4GZuohhI1SVZ3A-C5W7stSH6+Ex8=/1625571324722.GGkUlkTqDjM2yzNmjFvUx-dBg-dCLrVvQNFj1xYp+L4=.webp +0 -0
  81. package/example/.next/cache/images/ve17AGz6UzylkfjhegWUnZ4SUXdLbpBWd-M+DAbqhVo=/1625213911797.zMx5v1d6EgYxzhH5u9vceuQAZdrlkrwNiW-EzuaYMnw=.webp +0 -0
  82. package/example/.next/cache/images/w+++27-2ebMrzNGxoKhSr9vf0VqhIlpV3xO8-nmznSM=/1625219570994.+yVlIMc84gsVdgGr6dfpa+NKaYqXQLJb4rxP95iokjo=.webp +0 -0
  83. package/example/.next/cache/images/wEVHpFSN5nWkDzJM1zD9IzkT-5+9aLCjtzZlx7FnChA=/1625300569493.rBN4UJXzzvwnwMc6lkdFNiOodKZnuw9BElwqky7XTJ0=.webp +0 -0
  84. package/example/.next/cache/images/wOSsRjxgCIRti4Y51UNQVHeNw92Sg-OV6tSME5c2+RU=/1657107410586.c+9x+gNEkQckj5C8j9I5aZJiJf35+8bi-q7MlbQBOlk=.webp +0 -0
  85. package/example/.next/cache/images/wciNuT5QUpxVMjbdEd5KWYQAkxr4pu0mSsO8CrnNuRo=/1625300606596.WAxNBjGkgmTuieJ8l+3FtINuMozp8NMBQx9OfMbxvLY=.webp +0 -0
  86. package/example/.next/cache/images/xQ--vjMXdpyez6gYJhx5c22xjy6UfzN8shB+AT-WnQw=/1625213880032.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  87. package/example/.next/cache/images/xfzsIzvsjdsLHqIoLrdTT1AjZi9+RIje5JHlDlzw+LQ=/1625299556299.c43pjJ8oT5uj6rWCkZRR+sYJ2unczuZsJsvTPoYMCNg=.webp +0 -0
  88. package/example/.next/cache/images/xvjW0MVJv7OygHiGuo5gvdejePhehBB84DWWy0RobDg=/1625571376478.kZnEJ9pDGRP7pgjpXGDPuV-HLcq5hWt9eWAFm6G84OI=.webp +0 -0
  89. package/example/.next/cache/images/yEcVQvBB4mvzdzhAgu6yUci93hNSew5goqdazysmcaw=/1625299488426.1uAYRUalqmHfx5q0dqBXjl-shnwNiMuPt3-D6D6kgHw=.webp +0 -0
  90. package/example/.next/cache/images/yX0fhb7SMjwEomDwIq68YQHaZlZCZl7B8XxgNuNT2Ds=/1625219571007.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  91. package/example/.next/cache/images/zh5j6vOXiawy6rDIG3BLBs4itvIs0VVtnkvSFIKa5g4=/1625213904647.i+PvewsVBTnrxKjImamNkgl0fCG8DPKrY-1y1ZQKR3c=.webp +0 -0
  92. package/example/.next/cache/images/zmAZ9S2RPA8WIuVoev9YQINu8aQgcsNtDGNiLjNAYlU=/1656756588278.ifTqMK-gjLzo3qsY-0kwQOYgfnZzrDlPk0kqF90U9p8=.webp +0 -0
  93. package/example/.next/cache/webpack/client-development/0.pack +0 -0
  94. package/example/.next/cache/webpack/client-development/1.pack +0 -0
  95. package/example/.next/cache/webpack/client-development/2.pack +0 -0
  96. package/example/.next/cache/webpack/client-development/3.pack +0 -0
  97. package/example/.next/cache/webpack/client-development/4.pack +0 -0
  98. package/example/.next/cache/webpack/client-development/5.pack +0 -0
  99. package/example/.next/cache/webpack/client-development/6.pack +0 -0
  100. package/example/.next/cache/webpack/client-development/7.pack +0 -0
  101. package/example/.next/cache/webpack/client-development/8.pack +0 -0
  102. package/example/.next/cache/webpack/client-development/9.pack +0 -0
  103. package/example/.next/cache/webpack/client-development/index.pack +0 -0
  104. package/example/.next/cache/webpack/client-development/index.pack.old +0 -0
  105. package/example/.next/cache/webpack/server-development/0.pack +0 -0
  106. package/example/.next/cache/webpack/server-development/1.pack +0 -0
  107. package/example/.next/cache/webpack/server-development/2.pack +0 -0
  108. package/example/.next/cache/webpack/server-development/3.pack +0 -0
  109. package/example/.next/cache/webpack/server-development/4.pack +0 -0
  110. package/example/.next/cache/webpack/server-development/5.pack +0 -0
  111. package/example/.next/cache/webpack/server-development/6.pack +0 -0
  112. package/example/.next/cache/webpack/server-development/7.pack +0 -0
  113. package/example/.next/cache/webpack/server-development/8.pack +0 -0
  114. package/example/.next/cache/webpack/server-development/index.pack +0 -0
  115. package/example/.next/cache/webpack/server-development/index.pack.old +0 -0
  116. package/example/.next/cache/withYarn1Workspaces.3d60d45801.json +1 -0
  117. package/example/.next/cache/withYarn1Workspaces.d8e240ca09.json +1 -0
  118. package/example/.next/react-loadable-manifest.json +8 -0
  119. package/example/.next/server/pages/_app.js +47 -0
  120. package/example/.next/server/pages/_document.js +209 -0
  121. package/example/.next/server/pages/_error.js +68 -0
  122. package/example/.next/server/pages/index.js +135 -0
  123. package/example/.next/server/pages/next/dist/pages/_error.js +68 -0
  124. package/example/.next/server/pages-manifest.json +6 -0
  125. package/example/.next/server/static/image/components/image.66235d2f01fd4fba70eb3938db05810e.jpg +0 -0
  126. package/example/.next/server/webpack-runtime.js +168 -0
  127. package/example/.next/static/chunks/amp.js +84 -0
  128. package/example/.next/static/chunks/main.js +1140 -0
  129. package/example/.next/static/chunks/node_modules_next_dist_client_dev_noop_js.js +22 -0
  130. package/example/.next/static/chunks/pages/_app.js +74 -0
  131. package/example/.next/static/chunks/pages/_error.js +95 -0
  132. package/example/.next/static/chunks/pages/index.js +280 -0
  133. package/example/.next/static/chunks/pages/next/dist/pages/_error.js +148 -0
  134. package/example/.next/static/chunks/polyfills.js +40 -0
  135. package/example/.next/static/chunks/react-refresh.js +63 -0
  136. package/example/.next/static/chunks/webpack.js +1277 -0
  137. package/example/.next/static/development/_buildManifest.js +1 -0
  138. package/example/.next/static/development/_ssgManifest.js +1 -0
  139. package/example/.next/static/image/components/image.66235d2f01fd4fba70eb3938db05810e.jpg +0 -0
  140. package/example/.next/static/webpack/0588aaab49febd8cfe1c.webpack.hot-update.json +1 -0
  141. package/example/.next/static/webpack/072a7d130e228881d052.webpack.hot-update.json +1 -0
  142. package/example/.next/static/webpack/0762084187c63da9472d.webpack.hot-update.json +1 -0
  143. package/example/.next/static/webpack/0cea8b02db9004a9010b.webpack.hot-update.json +1 -0
  144. package/example/.next/static/webpack/0e5144f94622b3a25db6.webpack.hot-update.json +1 -0
  145. package/example/.next/static/webpack/1252cfc380272b4fe2e6.webpack.hot-update.json +1 -0
  146. package/example/.next/static/webpack/1402ac884dae19bf86c6.webpack.hot-update.json +1 -0
  147. package/example/.next/static/webpack/147aac9d3d7030a41f7f.webpack.hot-update.json +1 -0
  148. package/example/.next/static/webpack/1bda8bbbca0e0f13f045.webpack.hot-update.json +1 -0
  149. package/example/.next/static/webpack/234d4ce3b70ffd983ba8.webpack.hot-update.json +1 -0
  150. package/example/.next/static/webpack/26b79f15961d39636a40.webpack.hot-update.json +1 -0
  151. package/example/.next/static/webpack/2826318bc6ba4bd9d644.webpack.hot-update.json +1 -0
  152. package/example/.next/static/webpack/2a955e2b9072adb73190.webpack.hot-update.json +1 -0
  153. package/example/.next/static/webpack/2c2aaee83efae1379187.webpack.hot-update.json +1 -0
  154. package/example/.next/static/webpack/3555adce6517c2f7e42e.webpack.hot-update.json +1 -0
  155. package/example/.next/static/webpack/3588af142e46a835343c.webpack.hot-update.json +1 -0
  156. package/example/.next/static/webpack/37f12cbe9b48a34c52c2.webpack.hot-update.json +1 -0
  157. package/example/.next/static/webpack/3ac52037129af449eb72.webpack.hot-update.json +1 -0
  158. package/example/.next/static/webpack/3b42c94e63de900303b9.webpack.hot-update.json +1 -0
  159. package/example/.next/static/webpack/3c79280973f09aaa87fe.webpack.hot-update.json +1 -0
  160. package/example/.next/static/webpack/3c87c0ea5ce694e8d1c5.webpack.hot-update.json +1 -0
  161. package/example/.next/static/webpack/3de319507c766ee73bea.webpack.hot-update.json +1 -0
  162. package/example/.next/static/webpack/43b43eb8c73ce45f78f3.webpack.hot-update.json +1 -0
  163. package/example/.next/static/webpack/43c79a23f821cd622aee.webpack.hot-update.json +1 -0
  164. package/example/.next/static/webpack/4e0a0f884a956cbb5abe.webpack.hot-update.json +1 -0
  165. package/example/.next/static/webpack/50a19b6d8c63681a6f59.webpack.hot-update.json +1 -0
  166. package/example/.next/static/webpack/51822142283bf3a4fb5a.webpack.hot-update.json +1 -0
  167. package/example/.next/static/webpack/55ee69f8d85488769153.webpack.hot-update.json +1 -0
  168. package/example/.next/static/webpack/57d0775bfd690a4598a7.webpack.hot-update.json +1 -0
  169. package/example/.next/static/webpack/585753f40a2ba758aaeb.webpack.hot-update.json +1 -0
  170. package/example/.next/static/webpack/58da75bd3cf67c71206b.webpack.hot-update.json +1 -0
  171. package/example/.next/static/webpack/5d0aa62f686882951598.webpack.hot-update.json +1 -0
  172. package/example/.next/static/webpack/5de110501cdd600f11d7.webpack.hot-update.json +1 -0
  173. package/example/.next/static/webpack/63775ccd9a7849e5764c.webpack.hot-update.json +1 -0
  174. package/example/.next/static/webpack/6b4663280b1db8f5e905.webpack.hot-update.json +1 -0
  175. package/example/.next/static/webpack/6d11705f01219ee2fa3d.webpack.hot-update.json +1 -0
  176. package/example/.next/static/webpack/6d4eca6985c3546f0f71.webpack.hot-update.json +1 -0
  177. package/example/.next/static/webpack/6e6063845501820278cd.webpack.hot-update.json +1 -0
  178. package/example/.next/static/webpack/74a36e7ef8e1ce4fdf4a.webpack.hot-update.json +1 -0
  179. package/example/.next/static/webpack/796fe50a2b9d66aec2d7.webpack.hot-update.json +1 -0
  180. package/example/.next/static/webpack/878b2eb56dd102f8d1de.webpack.hot-update.json +1 -0
  181. package/example/.next/static/webpack/8d58abc5879781fbdb2f.webpack.hot-update.json +1 -0
  182. package/example/.next/static/webpack/8f405c984e4934b20605.webpack.hot-update.json +1 -0
  183. package/example/.next/static/webpack/90295054405377c77f5b.webpack.hot-update.json +1 -0
  184. package/example/.next/static/webpack/9310bbbf11c1977e9d98.webpack.hot-update.json +1 -0
  185. package/example/.next/static/webpack/9a0237d669946cc844e6.webpack.hot-update.json +1 -0
  186. package/example/.next/static/webpack/9aeee506244bc34b7b4b.webpack.hot-update.json +1 -0
  187. package/example/.next/static/webpack/9f473ce1942e5fdb3632.webpack.hot-update.json +1 -0
  188. package/example/.next/static/webpack/a1185fb9adfe5b70bc2f.webpack.hot-update.json +1 -0
  189. package/example/.next/static/webpack/a11eb25c0fca8e105e00.webpack.hot-update.json +1 -0
  190. package/example/.next/static/webpack/a48bbb1152e41e6a3cf2.webpack.hot-update.json +1 -0
  191. package/example/.next/static/webpack/aa3b500d2bc6950dbadd.webpack.hot-update.json +1 -0
  192. package/example/.next/static/webpack/ab0b9af23ef3fd93299c.webpack.hot-update.json +1 -0
  193. package/example/.next/static/webpack/aea6a75d56441fbbdaff.webpack.hot-update.json +1 -0
  194. package/example/.next/static/webpack/af81bfc5f0a8c32c3b51.webpack.hot-update.json +1 -0
  195. package/example/.next/static/webpack/b370b882a7b8cbf89abd.webpack.hot-update.json +1 -0
  196. package/example/.next/static/webpack/b3e2c4a7565fcfca527f.webpack.hot-update.json +1 -0
  197. package/example/.next/static/webpack/c6068e16d94c09cfd6b6.webpack.hot-update.json +1 -0
  198. package/example/.next/static/webpack/c73596b5b037cb23ec6b.webpack.hot-update.json +1 -0
  199. package/example/.next/static/webpack/c7dab37225cb7bc65af3.webpack.hot-update.json +1 -0
  200. package/example/.next/static/webpack/d2f930e23e921b06ed5c.webpack.hot-update.json +1 -0
  201. package/example/.next/static/webpack/d371d7c066578693521e.webpack.hot-update.json +1 -0
  202. package/example/.next/static/webpack/d965a3cf3815af872d29.webpack.hot-update.json +1 -0
  203. package/example/.next/static/webpack/da33d321cff0dda32eb0.webpack.hot-update.json +1 -0
  204. package/example/.next/static/webpack/dba31d980c30d691d16b.webpack.hot-update.json +1 -0
  205. package/example/.next/static/webpack/dd8aa6ef77cd74d84ec3.webpack.hot-update.json +1 -0
  206. package/example/.next/static/webpack/e15c892c8dbe9bc25020.webpack.hot-update.json +1 -0
  207. package/example/.next/static/webpack/e8bf5676cc19a6345ad3.webpack.hot-update.json +1 -0
  208. package/example/.next/static/webpack/eddd97db36cfbd0a1e7c.webpack.hot-update.json +1 -0
  209. package/example/.next/static/webpack/f031b79058783bc1558e.webpack.hot-update.json +1 -0
  210. package/example/.next/static/webpack/f3fa39ef803627283382.webpack.hot-update.json +1 -0
  211. package/example/.next/static/webpack/f48796a76815229d67ab.webpack.hot-update.json +1 -0
  212. package/example/.next/static/webpack/feb45f4041e620b79d86.webpack.hot-update.json +1 -0
  213. package/example/.next/static/webpack/ff24e5856387293df7e5.webpack.hot-update.json +1 -0
  214. package/example/.next/static/webpack/pages/index.072a7d130e228881d052.hot-update.js +22 -0
  215. package/example/.next/static/webpack/pages/index.0762084187c63da9472d.hot-update.js +22 -0
  216. package/example/.next/static/webpack/pages/index.0cea8b02db9004a9010b.hot-update.js +22 -0
  217. package/example/.next/static/webpack/pages/index.0e5144f94622b3a25db6.hot-update.js +22 -0
  218. package/example/.next/static/webpack/pages/index.1402ac884dae19bf86c6.hot-update.js +22 -0
  219. package/example/.next/static/webpack/pages/index.147aac9d3d7030a41f7f.hot-update.js +22 -0
  220. package/example/.next/static/webpack/pages/index.26b79f15961d39636a40.hot-update.js +22 -0
  221. package/example/.next/static/webpack/pages/index.2a955e2b9072adb73190.hot-update.js +22 -0
  222. package/example/.next/static/webpack/pages/index.3555adce6517c2f7e42e.hot-update.js +22 -0
  223. package/example/.next/static/webpack/pages/index.37f12cbe9b48a34c52c2.hot-update.js +22 -0
  224. package/example/.next/static/webpack/pages/index.3ac52037129af449eb72.hot-update.js +22 -0
  225. package/example/.next/static/webpack/pages/index.3c79280973f09aaa87fe.hot-update.js +22 -0
  226. package/example/.next/static/webpack/pages/index.43b43eb8c73ce45f78f3.hot-update.js +22 -0
  227. package/example/.next/static/webpack/pages/index.43c79a23f821cd622aee.hot-update.js +22 -0
  228. package/example/.next/static/webpack/pages/index.4e0a0f884a956cbb5abe.hot-update.js +22 -0
  229. package/example/.next/static/webpack/pages/index.50a19b6d8c63681a6f59.hot-update.js +22 -0
  230. package/example/.next/static/webpack/pages/index.51822142283bf3a4fb5a.hot-update.js +22 -0
  231. package/example/.next/static/webpack/pages/index.58da75bd3cf67c71206b.hot-update.js +22 -0
  232. package/example/.next/static/webpack/pages/index.5d0aa62f686882951598.hot-update.js +22 -0
  233. package/example/.next/static/webpack/pages/index.5de110501cdd600f11d7.hot-update.js +22 -0
  234. package/example/.next/static/webpack/pages/index.63775ccd9a7849e5764c.hot-update.js +22 -0
  235. package/example/.next/static/webpack/pages/index.6d11705f01219ee2fa3d.hot-update.js +22 -0
  236. package/example/.next/static/webpack/pages/index.6d4eca6985c3546f0f71.hot-update.js +22 -0
  237. package/example/.next/static/webpack/pages/index.6e6063845501820278cd.hot-update.js +22 -0
  238. package/example/.next/static/webpack/pages/index.74a36e7ef8e1ce4fdf4a.hot-update.js +22 -0
  239. package/example/.next/static/webpack/pages/index.796fe50a2b9d66aec2d7.hot-update.js +22 -0
  240. package/example/.next/static/webpack/pages/index.8d58abc5879781fbdb2f.hot-update.js +22 -0
  241. package/example/.next/static/webpack/pages/index.90295054405377c77f5b.hot-update.js +22 -0
  242. package/example/.next/static/webpack/pages/index.9310bbbf11c1977e9d98.hot-update.js +22 -0
  243. package/example/.next/static/webpack/pages/index.9a0237d669946cc844e6.hot-update.js +22 -0
  244. package/example/.next/static/webpack/pages/index.9aeee506244bc34b7b4b.hot-update.js +22 -0
  245. package/example/.next/static/webpack/pages/index.9f473ce1942e5fdb3632.hot-update.js +22 -0
  246. package/example/.next/static/webpack/pages/index.a48bbb1152e41e6a3cf2.hot-update.js +22 -0
  247. package/example/.next/static/webpack/pages/index.aa3b500d2bc6950dbadd.hot-update.js +22 -0
  248. package/example/.next/static/webpack/pages/index.aea6a75d56441fbbdaff.hot-update.js +22 -0
  249. package/example/.next/static/webpack/pages/index.b3e2c4a7565fcfca527f.hot-update.js +22 -0
  250. package/example/.next/static/webpack/pages/index.c6068e16d94c09cfd6b6.hot-update.js +22 -0
  251. package/example/.next/static/webpack/pages/index.c7dab37225cb7bc65af3.hot-update.js +22 -0
  252. package/example/.next/static/webpack/pages/index.d2f930e23e921b06ed5c.hot-update.js +22 -0
  253. package/example/.next/static/webpack/pages/index.d371d7c066578693521e.hot-update.js +22 -0
  254. package/example/.next/static/webpack/pages/index.d965a3cf3815af872d29.hot-update.js +22 -0
  255. package/example/.next/static/webpack/pages/index.dba31d980c30d691d16b.hot-update.js +22 -0
  256. package/example/.next/static/webpack/pages/index.dd8aa6ef77cd74d84ec3.hot-update.js +22 -0
  257. package/example/.next/static/webpack/pages/index.e15c892c8dbe9bc25020.hot-update.js +22 -0
  258. package/example/.next/static/webpack/pages/index.e8bf5676cc19a6345ad3.hot-update.js +22 -0
  259. package/example/.next/static/webpack/pages/index.eddd97db36cfbd0a1e7c.hot-update.js +22 -0
  260. package/example/.next/static/webpack/pages/index.f3fa39ef803627283382.hot-update.js +22 -0
  261. package/example/.next/static/webpack/pages/index.f48796a76815229d67ab.hot-update.js +22 -0
  262. package/example/.next/static/webpack/pages/index.feb45f4041e620b79d86.hot-update.js +22 -0
  263. package/example/.next/static/webpack/webpack.0588aaab49febd8cfe1c.hot-update.js +19 -0
  264. package/example/.next/static/webpack/webpack.072a7d130e228881d052.hot-update.js +19 -0
  265. package/example/.next/static/webpack/webpack.0762084187c63da9472d.hot-update.js +19 -0
  266. package/example/.next/static/webpack/webpack.0cea8b02db9004a9010b.hot-update.js +19 -0
  267. package/example/.next/static/webpack/webpack.0e5144f94622b3a25db6.hot-update.js +19 -0
  268. package/example/.next/static/webpack/webpack.1252cfc380272b4fe2e6.hot-update.js +19 -0
  269. package/example/.next/static/webpack/webpack.1402ac884dae19bf86c6.hot-update.js +19 -0
  270. package/example/.next/static/webpack/webpack.147aac9d3d7030a41f7f.hot-update.js +19 -0
  271. package/example/.next/static/webpack/webpack.1bda8bbbca0e0f13f045.hot-update.js +19 -0
  272. package/example/.next/static/webpack/webpack.234d4ce3b70ffd983ba8.hot-update.js +19 -0
  273. package/example/.next/static/webpack/webpack.26b79f15961d39636a40.hot-update.js +19 -0
  274. package/example/.next/static/webpack/webpack.2826318bc6ba4bd9d644.hot-update.js +19 -0
  275. package/example/.next/static/webpack/webpack.2a955e2b9072adb73190.hot-update.js +19 -0
  276. package/example/.next/static/webpack/webpack.2c2aaee83efae1379187.hot-update.js +19 -0
  277. package/example/.next/static/webpack/webpack.3555adce6517c2f7e42e.hot-update.js +19 -0
  278. package/example/.next/static/webpack/webpack.3588af142e46a835343c.hot-update.js +19 -0
  279. package/example/.next/static/webpack/webpack.37f12cbe9b48a34c52c2.hot-update.js +19 -0
  280. package/example/.next/static/webpack/webpack.3ac52037129af449eb72.hot-update.js +19 -0
  281. package/example/.next/static/webpack/webpack.3b42c94e63de900303b9.hot-update.js +19 -0
  282. package/example/.next/static/webpack/webpack.3c79280973f09aaa87fe.hot-update.js +19 -0
  283. package/example/.next/static/webpack/webpack.3c87c0ea5ce694e8d1c5.hot-update.js +19 -0
  284. package/example/.next/static/webpack/webpack.3de319507c766ee73bea.hot-update.js +19 -0
  285. package/example/.next/static/webpack/webpack.43b43eb8c73ce45f78f3.hot-update.js +19 -0
  286. package/example/.next/static/webpack/webpack.43c79a23f821cd622aee.hot-update.js +19 -0
  287. package/example/.next/static/webpack/webpack.4e0a0f884a956cbb5abe.hot-update.js +19 -0
  288. package/example/.next/static/webpack/webpack.50a19b6d8c63681a6f59.hot-update.js +19 -0
  289. package/example/.next/static/webpack/webpack.51822142283bf3a4fb5a.hot-update.js +19 -0
  290. package/example/.next/static/webpack/webpack.55ee69f8d85488769153.hot-update.js +19 -0
  291. package/example/.next/static/webpack/webpack.57d0775bfd690a4598a7.hot-update.js +19 -0
  292. package/example/.next/static/webpack/webpack.585753f40a2ba758aaeb.hot-update.js +19 -0
  293. package/example/.next/static/webpack/webpack.58da75bd3cf67c71206b.hot-update.js +19 -0
  294. package/example/.next/static/webpack/webpack.5d0aa62f686882951598.hot-update.js +19 -0
  295. package/example/.next/static/webpack/webpack.5de110501cdd600f11d7.hot-update.js +19 -0
  296. package/example/.next/static/webpack/webpack.63775ccd9a7849e5764c.hot-update.js +19 -0
  297. package/example/.next/static/webpack/webpack.6b4663280b1db8f5e905.hot-update.js +19 -0
  298. package/example/.next/static/webpack/webpack.6d11705f01219ee2fa3d.hot-update.js +19 -0
  299. package/example/.next/static/webpack/webpack.6d4eca6985c3546f0f71.hot-update.js +19 -0
  300. package/example/.next/static/webpack/webpack.6e6063845501820278cd.hot-update.js +19 -0
  301. package/example/.next/static/webpack/webpack.74a36e7ef8e1ce4fdf4a.hot-update.js +19 -0
  302. package/example/.next/static/webpack/webpack.796fe50a2b9d66aec2d7.hot-update.js +19 -0
  303. package/example/.next/static/webpack/webpack.878b2eb56dd102f8d1de.hot-update.js +19 -0
  304. package/example/.next/static/webpack/webpack.8d58abc5879781fbdb2f.hot-update.js +19 -0
  305. package/example/.next/static/webpack/webpack.8f405c984e4934b20605.hot-update.js +30 -0
  306. package/example/.next/static/webpack/webpack.90295054405377c77f5b.hot-update.js +19 -0
  307. package/example/.next/static/webpack/webpack.9310bbbf11c1977e9d98.hot-update.js +19 -0
  308. package/example/.next/static/webpack/webpack.9a0237d669946cc844e6.hot-update.js +19 -0
  309. package/example/.next/static/webpack/webpack.9aeee506244bc34b7b4b.hot-update.js +19 -0
  310. package/example/.next/static/webpack/webpack.9f473ce1942e5fdb3632.hot-update.js +19 -0
  311. package/example/.next/static/webpack/webpack.a1185fb9adfe5b70bc2f.hot-update.js +19 -0
  312. package/example/.next/static/webpack/webpack.a11eb25c0fca8e105e00.hot-update.js +19 -0
  313. package/example/.next/static/webpack/webpack.a48bbb1152e41e6a3cf2.hot-update.js +19 -0
  314. package/example/.next/static/webpack/webpack.aa3b500d2bc6950dbadd.hot-update.js +19 -0
  315. package/example/.next/static/webpack/webpack.ab0b9af23ef3fd93299c.hot-update.js +19 -0
  316. package/example/.next/static/webpack/webpack.aea6a75d56441fbbdaff.hot-update.js +19 -0
  317. package/example/.next/static/webpack/webpack.af81bfc5f0a8c32c3b51.hot-update.js +19 -0
  318. package/example/.next/static/webpack/webpack.b370b882a7b8cbf89abd.hot-update.js +19 -0
  319. package/example/.next/static/webpack/webpack.b3e2c4a7565fcfca527f.hot-update.js +19 -0
  320. package/example/.next/static/webpack/webpack.c6068e16d94c09cfd6b6.hot-update.js +19 -0
  321. package/example/.next/static/webpack/webpack.c73596b5b037cb23ec6b.hot-update.js +19 -0
  322. package/example/.next/static/webpack/webpack.c7dab37225cb7bc65af3.hot-update.js +19 -0
  323. package/example/.next/static/webpack/webpack.d2f930e23e921b06ed5c.hot-update.js +19 -0
  324. package/example/.next/static/webpack/webpack.d371d7c066578693521e.hot-update.js +19 -0
  325. package/example/.next/static/webpack/webpack.d965a3cf3815af872d29.hot-update.js +19 -0
  326. package/example/.next/static/webpack/webpack.da33d321cff0dda32eb0.hot-update.js +19 -0
  327. package/example/.next/static/webpack/webpack.dba31d980c30d691d16b.hot-update.js +19 -0
  328. package/example/.next/static/webpack/webpack.dd8aa6ef77cd74d84ec3.hot-update.js +19 -0
  329. package/example/.next/static/webpack/webpack.e15c892c8dbe9bc25020.hot-update.js +19 -0
  330. package/example/.next/static/webpack/webpack.e8bf5676cc19a6345ad3.hot-update.js +19 -0
  331. package/example/.next/static/webpack/webpack.eddd97db36cfbd0a1e7c.hot-update.js +19 -0
  332. package/example/.next/static/webpack/webpack.f031b79058783bc1558e.hot-update.js +19 -0
  333. package/example/.next/static/webpack/webpack.f3fa39ef803627283382.hot-update.js +19 -0
  334. package/example/.next/static/webpack/webpack.f48796a76815229d67ab.hot-update.js +19 -0
  335. package/example/.next/static/webpack/webpack.feb45f4041e620b79d86.hot-update.js +19 -0
  336. package/example/.next/static/webpack/webpack.ff24e5856387293df7e5.hot-update.js +19 -0
  337. package/example/package.json +4 -4
  338. package/package.json +7 -7
@@ -0,0 +1,22 @@
1
+ /*
2
+ * ATTENTION: An "eval-source-map" devtool has been used.
3
+ * This devtool is neither made for production nor for readable output files.
4
+ * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
5
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
6
+ * or disable the default devtool with "devtool: false".
7
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
8
+ */
9
+ self["webpackHotUpdate_N_E"]("pages/index",{
10
+
11
+ /***/ "../components/Image.tsx":
12
+ /*!*******************************!*\
13
+ !*** ../components/Image.tsx ***!
14
+ \*******************************/
15
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
16
+
17
+ "use strict";
18
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"isStaticRequire\": function() { return /* binding */ isStaticRequire; },\n/* harmony export */ \"isStaticImageData\": function() { return /* binding */ isStaticImageData; },\n/* harmony export */ \"isStaticImport\": function() { return /* binding */ isStaticImport; },\n/* harmony export */ \"getInt\": function() { return /* binding */ getInt; },\n/* harmony export */ \"Image\": function() { return /* binding */ Image; }\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"../../../node_modules/react/jsx-dev-runtime.js\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties */ \"../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js\");\n/* harmony import */ var _Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/defineProperty */ \"../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/defineProperty.js\");\n/* harmony import */ var _bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @bedrock-layout/use-forwarded-ref */ \"../../../node_modules/@bedrock-layout/use-forwarded-ref/lib/index.m.js\");\n/* harmony import */ var next_dist_next_server_server_image_config__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! next/dist/next-server/server/image-config */ \"../../../node_modules/next/dist/next-server/server/image-config.js\");\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! next/head */ \"../../../node_modules/next/head.js\");\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(next_head__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! react */ \"../../../node_modules/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../config/config */ \"../config/config.ts\");\n/* module decorator */ module = __webpack_require__.hmd(module);\n\n\n\n\n\nvar _jsxFileName = \"/Users/paulhachmang/Sites/reachdigital-next/packages/image/components/Image.tsx\",\n _s = $RefreshSig$();\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_2__.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\n/* eslint-disable prefer-const */\n\n/* eslint-disable no-param-reassign */\n\n/* eslint-disable @next/next/no-img-element */\n\n/* eslint-disable jsx-a11y/alt-text */\n\n\n\n\n\n\nif (false) {}\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined];\nconst loaders = new Map([['imgix', _config_config__WEBPACK_IMPORTED_MODULE_6__.imgixLoader], ['cloudinary', _config_config__WEBPACK_IMPORTED_MODULE_6__.cloudinaryLoader], ['akamai', _config_config__WEBPACK_IMPORTED_MODULE_6__.akamaiLoader], ['default', _config_config__WEBPACK_IMPORTED_MODULE_6__.defaultLoader]]);\nconst VALID_LAYOUT_VALUES = ['fill', 'responsive', 'intrinsic', 'fixed'];\nfunction isStaticRequire(src) {\n return src.default !== undefined;\n}\nfunction isStaticImageData(src) {\n return src.src !== undefined;\n}\nfunction isStaticImport(src) {\n return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src));\n} // sort smallest to largest\n\nconst allSizes = [..._config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes, ..._config_config__WEBPACK_IMPORTED_MODULE_6__.configImageSizes];\n_config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes.sort((a, b) => a - b);\nallSizes.sort((a, b) => a - b);\n\nfunction getWidths(width, layout, sizes = '', scale) {\n if (sizes && layout === 'fill' || layout === 'responsive') {\n // Find all the \"vw\" percent sizes used in the sizes prop\n const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g;\n const percentSizes = []; // eslint-disable-next-line no-cond-assign\n\n for (let match; match = viewportWidthRe.exec(sizes); match) {\n var _match;\n\n percentSizes.push(parseInt((_match = match) === null || _match === void 0 ? void 0 : _match[2], 10));\n }\n\n if (percentSizes.length) {\n const smallestRatio = Math.min(...percentSizes) * 0.01;\n return {\n widths: allSizes.filter(s => s >= _config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes[0] * smallestRatio),\n kind: 'w'\n };\n } // Find all the \"px\" sizes used in the sizes prop\n\n\n const pxWidthRe = /(^|\\s)(1?\\d+)px/g;\n const pxSizes = []; // eslint-disable-next-line no-cond-assign\n\n for (let match; match = pxWidthRe.exec(sizes); match) {\n var _match2;\n\n pxSizes.push(parseInt((_match2 = match) === null || _match2 === void 0 ? void 0 : _match2[2], 10));\n }\n\n if (pxSizes.length) {\n return {\n widths: pxSizes.map(pxSize => {\n var _allSizes$filter, _allSizes$filter2;\n\n const scaled = (_allSizes$filter = allSizes.filter(s => s * scale > pxSize)) === null || _allSizes$filter === void 0 ? void 0 : _allSizes$filter[0];\n const dpr2 = (_allSizes$filter2 = allSizes.filter(s => s > pxSize)) === null || _allSizes$filter2 === void 0 ? void 0 : _allSizes$filter2[0];\n return scale > 1 ? Math.max(scaled, dpr2) : Math.min(scaled, dpr2);\n }),\n kind: 'w'\n };\n }\n\n return {\n widths: allSizes,\n kind: 'w'\n };\n }\n\n if (typeof width !== 'number' || layout === 'fill') {\n return {\n widths: _config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes,\n kind: 'w'\n };\n }\n\n const widths = [...new Set( // > This means that most OLED screens that say they are 3x resolution,\n // > are actually 3x in the green color, but only 1.5x in the red and\n // > blue colors. Showing a 3x resolution image in the app vs a 2x\n // > resolution image will be visually the same, though the 3x image\n // > takes significantly more data. Even true 3x resolution screens are\n // > wasteful as the human eye cannot see that level of detail without\n // > something like a magnifying glass.\n // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n [width, width * 2\n /* , width * 3*/\n ].map(w => allSizes.find(p => p >= w) || allSizes[allSizes.length - 1]))];\n return {\n widths,\n kind: 'x'\n };\n}\n\nfunction generateSourceAttrs({\n src,\n layout,\n width,\n quality = 44,\n sizes,\n loader,\n scale\n}) {\n const {\n widths,\n kind\n } = getWidths(width, layout, sizes, scale);\n return {\n sizes: !sizes && kind === 'w' ? `50vw` : sizes,\n srcSet: widths.map((w, i) => `${loader({\n src,\n quality,\n width: w\n })} ${kind === 'w' ? Math.round(w * scale) : i + 1}${kind}`).join(', ')\n };\n}\n\nfunction getInt(x) {\n if (typeof x === 'number') {\n return x;\n }\n\n if (typeof x === 'string') {\n return parseInt(x, 10);\n }\n\n return undefined;\n}\n\nfunction defaultImageLoader(loaderProps) {\n const load = loaders.get(_config_config__WEBPACK_IMPORTED_MODULE_6__.configLoader);\n\n if (load) {\n return load(_objectSpread({\n root: _config_config__WEBPACK_IMPORTED_MODULE_6__.configPath\n }, loaderProps));\n }\n\n throw new Error(`[@reachdigital/image]: Unknown \"loader\" found in \"next.config.js\". Expected: ${next_dist_next_server_server_image_config__WEBPACK_IMPORTED_MODULE_3__.VALID_LOADERS.join(', ')}. Received: ${_config_config__WEBPACK_IMPORTED_MODULE_6__.configLoader}`);\n} // See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\n\n\nfunction removePlaceholder(img, placeholder) {\n if (placeholder === 'blur' && img) {\n const handleLoad = () => {\n if (!img.src.startsWith('data:')) {\n const p = 'decode' in img ? img.decode() : Promise.resolve(); // eslint-disable-next-line @typescript-eslint/no-floating-promises\n\n p.catch(() => {}).then(() => {\n img.style.filter = 'none';\n img.style.backgroundSize = 'none';\n img.style.backgroundImage = 'none';\n });\n }\n };\n\n if (img.complete) {\n // If the real image fails to load, this will still remove the placeholder.\n // This is the desired behavior for now, and will be revisited when error\n // handling is worked on for the image component itself.\n handleLoad();\n } else {\n img.onload = handleLoad;\n }\n }\n}\n/** Checks whether an image is currently in the viewport */\n\n\nfunction isInViewport(elem) {\n const {\n top,\n right,\n bottom,\n left\n } = elem.getBoundingClientRect();\n return bottom >= 0 && right >= 0 && top <= window.innerHeight && left <= window.innerWidth;\n}\n\nfunction isSizesRecord(sizes) {\n return typeof sizes === 'object';\n}\n\nfunction sizesEntries(sizes) {\n if (isSizesRecord(sizes)) {\n return Object.entries(sizes).map(([breakpoint, size]) => [Number(breakpoint), size]).sort(([sizeA], [sizeB]) => sizeB - sizeA);\n }\n\n return [[0, sizes]];\n}\n\nfunction generateSizesString(sizes) {\n return sizesEntries(sizes).map(([breakpoint, size]) => {\n if (breakpoint === 0) return size;\n return `(min-width: ${breakpoint}px) ${size}`;\n }).join(', ');\n}\n/** Since we're handling stuff ourselves we omit some stuff */\n\n\nconst Image = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_5___default().forwardRef(_c = _s((_ref, forwardedRef) => {\n var _generateSizesString, _loading;\n\n _s();\n\n let {\n src,\n sizes: sizesIncomming,\n unoptimized = false,\n loading,\n layout = 'responsive',\n quality,\n width,\n height,\n style,\n loader = defaultImageLoader,\n placeholder = 'empty',\n blurDataURL\n } = _ref,\n imgProps = (0,_Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__.default)(_ref, [\"src\", \"sizes\", \"unoptimized\", \"loading\", \"layout\", \"quality\", \"width\", \"height\", \"style\", \"loader\", \"placeholder\", \"blurDataURL\"]);\n\n const ref = (0,_bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__.default)(forwardedRef);\n const sizesOrig = layout === 'fixed' && width && !sizesIncomming ? `${width}px` : sizesIncomming;\n const sizes = (_generateSizesString = generateSizesString(sizesOrig)) !== null && _generateSizesString !== void 0 ? _generateSizesString : '50vw'; // If no responsive sizes are given, we're defaulting to 50vw on mobile\n // const [sizes, setSizes] = useState(toSizesString(sizesOrig) ?? `50vw`)\n\n (0,react__WEBPACK_IMPORTED_MODULE_5__.useEffect)(() => {\n if (false) {}\n if (!ref.current) return () => {};\n\n function reportSizes(img) {\n var _sizesEntries$find;\n\n let ratio;\n let msg = '';\n const [breakpoint, size] = (_sizesEntries$find = sizesEntries(sizesOrig).find(([s]) => s === 0 ? true : window.matchMedia(`(min-width: ${s})`))) !== null && _sizesEntries$find !== void 0 ? _sizesEntries$find : [0, '100vw'];\n\n if (size) {\n const el = document.createElement('div');\n el.setAttribute('style', `width: ${size}`);\n document.body.appendChild(el);\n const measuredWidth = el.getBoundingClientRect().width; // el.remove()\n\n ratio = measuredWidth ** 2 / img.naturalWidth ** 2;\n msg += `Image has \"sizes\" property set, but size 'min-width(${breakpoint}px) ${size}' is incorrect.`;\n } else {\n msg += `Image has no \"sizes\" property set.`;\n ratio = (window.innerWidth * 0.5) ** 2 / img.naturalWidth ** 2;\n }\n\n const round = nr => Math.round(nr * 100) / 100;\n\n if (ratio > 1.2) {\n console.warn(`[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(ratio)}x too many pixels`, img);\n } else if (ratio < 0.8) {\n console.warn(`[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(1 / ratio)}x too few pixels`, img);\n }\n } // Warn the user when he isn't providing sizes and how to proceed\n\n\n const ro = new ResizeObserver(([entry]) => {\n const img = entry.target;\n if (img.naturalWidth) reportSizes(img);\n\n img.onload = () => reportSizes(img);\n });\n ro.observe(ref.current);\n return () => ro.disconnect();\n }, [layout, ref, sizesOrig, src, width]);\n let staticSrc = '';\n\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src;\n\n if (!staticImageData.src) {\n throw new Error(`[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(staticImageData)}`);\n }\n\n blurDataURL = blurDataURL || staticImageData.blurDataURL;\n staticSrc = staticImageData.src;\n\n if (!layout || layout !== 'fill') {\n height = height || staticImageData.height;\n width = width || staticImageData.width;\n\n if (!staticImageData.height || !staticImageData.width) {\n throw new Error(`[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(staticImageData)}`);\n }\n }\n }\n\n src = typeof src === 'string' ? src : staticSrc;\n const widthInt = getInt(width);\n const heightInt = getInt(height);\n const qualityInt = getInt(quality);\n\n if (true) {\n if (!src) {\n throw new Error(`[@reachdigital/image]: Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`@reachdigital/image\\` component. Received: ${JSON.stringify({\n width,\n height,\n quality\n })}`);\n }\n\n if (!VALID_LAYOUT_VALUES.includes(layout)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(String).join(',')}.`);\n }\n\n if (typeof widthInt !== 'undefined' && Number.isNaN(widthInt) || typeof heightInt !== 'undefined' && Number.isNaN(heightInt)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`);\n }\n\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(String).join(',')}.`);\n }\n\n if (placeholder === 'blur') {\n if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n console.warn(`[@reachdigital/image]: Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`);\n }\n\n if (!blurDataURL) {\n const VALID_BLUR_EXT = ['jpeg', 'png', 'webp']; // should match next-image-loader\n\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n Possible solutions:\n - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(',')}\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`);\n }\n }\n }\n\n if (typeof widthInt === 'undefined' && typeof heightInt === 'undefined') {\n if (layout === 'fill') {// handle fill\n } else if (true) {\n // <Image src=\"i.png\" />\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`);\n }\n }\n\n (_loading = loading) !== null && _loading !== void 0 ? _loading : loading = 'lazy';\n\n if (src && src.startsWith('data:')) {\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n unoptimized = true;\n }\n\n const attributes3x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 1.5\n });\n const attributes2x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 1\n });\n const attributes1x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 0.5\n });\n if (layout !== 'fixed' && !style) style = {};\n if (layout === 'responsive') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: 'auto'\n });\n if (layout === 'intrinsic') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: 'auto',\n maxWidth: width\n });\n if (layout === 'fill') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: '100%'\n });\n return /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.Fragment, {\n children: [unoptimized ? /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"img\", _objectSpread(_objectSpread({\n ref: ref\n }, imgProps), {}, {\n src: src,\n width: width,\n height: height,\n style: style\n }), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 617,\n columnNumber: 11\n }, undefined) : /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"picture\", {\n children: [/*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"source\", _objectSpread({\n media: \"(-webkit-min-device-pixel-ratio: 2.5)\"\n }, attributes3x), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 620,\n columnNumber: 13\n }, undefined), /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"source\", _objectSpread({\n media: \"(-webkit-min-device-pixel-ratio: 1.5)\"\n }, attributes2x), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 621,\n columnNumber: 13\n }, undefined), /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"img\", _objectSpread(_objectSpread(_objectSpread({\n ref: ref\n }, imgProps), attributes1x), {}, {\n loading: loading,\n width: width,\n height: height,\n style: style\n }), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 622,\n columnNumber: 13\n }, undefined)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 619,\n columnNumber: 11\n }, undefined), loading === 'eager' && /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)((next_head__WEBPACK_IMPORTED_MODULE_4___default()), {\n children: /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"link\", {\n rel: \"preload\",\n as: \"image\",\n media: \"(-webkit-min-device-pixel-ratio: 2.5)\" // @ts-expect-error imagesrcset is not yet in the link element type\n ,\n imagesrcset: attributes1x.srcSet,\n imagesizes: sizes\n }, `__nimg-2x-${attributes1x.srcSet}${attributes1x.sizes}`, false, {\n fileName: _jsxFileName,\n lineNumber: 635,\n columnNumber: 13\n }, undefined)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 634,\n columnNumber: 11\n }, undefined)]\n }, void 0, true);\n}, \"uc1ywpQv+s/tGng4xj/L6VVOIq8=\", false, function () {\n return [_bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__.default];\n}));\n_c2 = Image;\nImage.displayName = 'NextPicture';\n\n\nvar _c, _c2;\n\n$RefreshReg$(_c, \"Image$React.forwardRef\");\n$RefreshReg$(_c2, \"Image\");\n\n;\n var _a, _b;\n // Legacy CSS implementations will `eval` browser code in a Node.js context\n // to extract CSS. For backwards compatibility, we need to check we're in a\n // browser context before continuing.\n if (typeof self !== 'undefined' &&\n // AMP / No-JS mode does not inject these helpers:\n '$RefreshHelpers$' in self) {\n var currentExports = module.__proto__.exports;\n var prevExports = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevExports) !== null && _b !== void 0 ? _b : null;\n // This cannot happen in MainTemplate because the exports mismatch between\n // templating and execution.\n self.$RefreshHelpers$.registerExportsForReactRefresh(currentExports, module.id);\n // A module can be accepted automatically based on its exports, e.g. when\n // it is a Refresh Boundary.\n if (self.$RefreshHelpers$.isReactRefreshBoundary(currentExports)) {\n // Save the previous exports on update so we can compare the boundary\n // signatures.\n module.hot.dispose(function (data) {\n data.prevExports = currentExports;\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n module.hot.accept();\n // This field is set when the previous version of this module was a\n // Refresh Boundary, letting us know we need to check for invalidation or\n // enqueue an update.\n if (prevExports !== null) {\n // A boundary can become ineligible if its exports are incompatible\n // with the previous exports.\n //\n // For example, if you add/remove/change exports, we'll want to\n // re-execute the importing modules, and force those components to\n // re-render. Similarly, if you convert a class component to a\n // function, we want to invalidate the boundary.\n if (self.$RefreshHelpers$.shouldInvalidateReactRefreshBoundary(prevExports, currentExports)) {\n module.hot.invalidate();\n }\n else {\n self.$RefreshHelpers$.scheduleUpdate();\n }\n }\n }\n else {\n // Since we just executed the code for the module, it's possible that the\n // new exports made it ineligible for being a boundary.\n // We only care about the case when we were _previously_ a boundary,\n // because we already accepted this update (accidental side effect).\n var isNoLongerABoundary = prevExports !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://_N_E/../components/Image.tsx?2b6d"],"names":["VALID_LOADING_VALUES","undefined","loaders","Map","imgixLoader","cloudinaryLoader","akamaiLoader","defaultLoader","VALID_LAYOUT_VALUES","isStaticRequire","src","default","isStaticImageData","isStaticImport","allSizes","configDeviceSizes","configImageSizes","a","b","sort","getWidths","width","layout","sizes","scale","viewportWidthRe","percentSizes","match","exec","push","parseInt","length","smallestRatio","Math","min","widths","filter","s","kind","pxWidthRe","pxSizes","map","pxSize","scaled","dpr2","max","Set","w","find","p","generateSourceAttrs","quality","loader","srcSet","i","round","join","getInt","x","defaultImageLoader","loaderProps","load","get","configLoader","root","configPath","Error","VALID_LOADERS","removePlaceholder","img","placeholder","handleLoad","startsWith","decode","Promise","resolve","catch","then","style","backgroundSize","backgroundImage","complete","onload","isInViewport","elem","top","right","bottom","left","getBoundingClientRect","window","innerHeight","innerWidth","isSizesRecord","sizesEntries","Object","entries","breakpoint","size","Number","sizeA","sizeB","generateSizesString","Image","React","forwardedRef","sizesIncomming","unoptimized","loading","height","blurDataURL","imgProps","ref","useForwardedRef","sizesOrig","useEffect","current","reportSizes","ratio","msg","matchMedia","el","document","createElement","setAttribute","body","appendChild","measuredWidth","naturalWidth","nr","console","warn","ro","ResizeObserver","entry","target","observe","disconnect","staticSrc","staticImageData","JSON","stringify","widthInt","heightInt","qualityInt","includes","String","isNaN","VALID_BLUR_EXT","attributes3x","attributes2x","attributes1x","maxWidth","displayName"],"mappings":"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","file":"../components/Image.tsx.js","sourcesContent":["/* eslint-disable prefer-const */\n/* eslint-disable no-param-reassign */\n/* eslint-disable @next/next/no-img-element */\n/* eslint-disable jsx-a11y/alt-text */\nimport useForwardedRef from '@bedrock-layout/use-forwarded-ref'\nimport { LoaderValue, VALID_LOADERS } from 'next/dist/next-server/server/image-config'\nimport Head from 'next/head'\nimport type { ImageLoaderProps, ImageLoader } from 'next/image'\nimport React, { useEffect, useState } from 'react'\nimport useResizeObserver from 'use-resize-observer'\nimport {\n  akamaiLoader,\n  cloudinaryLoader,\n  configDeviceSizes,\n  configImageSizes,\n  configLoader,\n  configPath,\n  DefaultImageLoaderProps,\n  defaultLoader,\n  imgixLoader,\n} from '../config/config'\nimport useConnectionType from '../hooks/useConnectionType'\n\nif (typeof window === 'undefined') {\n  // eslint-disable-next-line no-underscore-dangle\n  global.__NEXT_IMAGE_IMPORTED = true\n}\n\nexport type { ImageLoaderProps, ImageLoader }\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined] as const\ntype LoadingValue = typeof VALID_LOADING_VALUES[number]\n\nconst loaders = new Map<LoaderValue, (props: DefaultImageLoaderProps) => string>([\n  ['imgix', imgixLoader],\n  ['cloudinary', cloudinaryLoader],\n  ['akamai', akamaiLoader],\n  ['default', defaultLoader],\n])\n\nconst VALID_LAYOUT_VALUES = ['fill', 'responsive', 'intrinsic', 'fixed'] as const\ntype LayoutValue = 'fill' | 'fixed' | 'intrinsic' | 'responsive' | undefined\n\ntype PlaceholderValue = 'blur' | 'empty'\n\ntype ImgElementStyle = NonNullable<JSX.IntrinsicElements['img']['style']>\n\ninterface StaticImageData {\n  src: string\n  height: number\n  width: number\n  blurDataURL?: string\n}\n\ninterface StaticRequire {\n  default: StaticImageData\n}\n\ntype StaticImport = StaticRequire | StaticImageData\n\nexport function isStaticRequire(src: StaticRequire | StaticImageData): src is StaticRequire {\n  return (src as StaticRequire).default !== undefined\n}\n\nexport function isStaticImageData(src: StaticRequire | StaticImageData): src is StaticImageData {\n  return (src as StaticImageData).src !== undefined\n}\n\nexport function isStaticImport(src: string | StaticImport): src is StaticImport {\n  return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src))\n}\n\n// sort smallest to largest\nconst allSizes = [...configDeviceSizes, ...configImageSizes]\nconfigDeviceSizes.sort((a, b) => a - b)\nallSizes.sort((a, b) => a - b)\n\nfunction getWidths(\n  width: number | undefined,\n  layout: LayoutValue,\n  sizes = '',\n  scale: number,\n): { widths: number[]; kind: 'w' | 'x' } {\n  if ((sizes && layout === 'fill') || layout === 'responsive') {\n    // Find all the \"vw\" percent sizes used in the sizes prop\n    const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g\n    const percentSizes: number[] = []\n    // eslint-disable-next-line no-cond-assign\n    for (let match: string[] | null; (match = viewportWidthRe.exec(sizes)); match) {\n      percentSizes.push(parseInt(match?.[2], 10))\n    }\n    if (percentSizes.length) {\n      const smallestRatio = Math.min(...percentSizes) * 0.01\n\n      return {\n        widths: allSizes.filter((s) => s >= configDeviceSizes[0] * smallestRatio),\n        kind: 'w',\n      }\n    }\n\n    // Find all the \"px\" sizes used in the sizes prop\n    const pxWidthRe = /(^|\\s)(1?\\d+)px/g\n    const pxSizes: number[] = []\n    // eslint-disable-next-line no-cond-assign\n    for (let match: string[] | null; (match = pxWidthRe.exec(sizes)); match) {\n      pxSizes.push(parseInt(match?.[2], 10))\n    }\n\n    if (pxSizes.length) {\n      return {\n        widths: pxSizes.map((pxSize) => {\n          const scaled = allSizes.filter((s) => s * scale > pxSize)?.[0]\n          const dpr2 = allSizes.filter((s) => s > pxSize)?.[0]\n          return scale > 1 ? Math.max(scaled, dpr2) : Math.min(scaled, dpr2)\n        }),\n        kind: 'w',\n      }\n    }\n\n    return { widths: allSizes, kind: 'w' }\n  }\n  if (typeof width !== 'number' || layout === 'fill') {\n    return { widths: configDeviceSizes, kind: 'w' }\n  }\n\n  const widths = [\n    ...new Set(\n      // > This means that most OLED screens that say they are 3x resolution,\n      // > are actually 3x in the green color, but only 1.5x in the red and\n      // > blue colors. Showing a 3x resolution image in the app vs a 2x\n      // > resolution image will be visually the same, though the 3x image\n      // > takes significantly more data. Even true 3x resolution screens are\n      // > wasteful as the human eye cannot see that level of detail without\n      // > something like a magnifying glass.\n      // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n      [width, width * 2 /* , width * 3*/].map(\n        (w) => allSizes.find((p) => p >= w) || allSizes[allSizes.length - 1],\n      ),\n    ),\n  ]\n  return { widths, kind: 'x' }\n}\n\ntype GenImgAttrsData = {\n  src: string\n  layout: LayoutValue\n  loader: ImageLoader\n  width?: number\n  quality?: number\n  sizes?: string\n  scale: number\n}\n\ntype GenImgAttrsResult = {\n  srcSet: string | undefined\n  sizes: string | undefined\n}\n\nfunction generateSourceAttrs({\n  src,\n  layout,\n  width,\n  quality = 44,\n  sizes,\n  loader,\n  scale,\n}: GenImgAttrsData): GenImgAttrsResult {\n  const { widths, kind } = getWidths(width, layout, sizes, scale)\n\n  return {\n    sizes: !sizes && kind === 'w' ? `50vw` : sizes,\n    srcSet: widths\n      .map(\n        (w, i) =>\n          `${loader({ src, quality, width: w })} ${\n            kind === 'w' ? Math.round(w * scale) : i + 1\n          }${kind}`,\n      )\n      .join(', '),\n  }\n}\n\nexport function getInt(x: unknown): number | undefined {\n  if (typeof x === 'number') {\n    return x\n  }\n  if (typeof x === 'string') {\n    return parseInt(x, 10)\n  }\n  return undefined\n}\n\nfunction defaultImageLoader(loaderProps: ImageLoaderProps) {\n  const load = loaders.get(configLoader)\n  if (load) {\n    return load({ root: configPath, ...loaderProps })\n  }\n  throw new Error(\n    `[@reachdigital/image]: Unknown \"loader\" found in \"next.config.js\". Expected: ${VALID_LOADERS.join(\n      ', ',\n    )}. Received: ${configLoader}`,\n  )\n}\n\n// See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\nfunction removePlaceholder(img: HTMLImageElement | null, placeholder: PlaceholderValue) {\n  if (placeholder === 'blur' && img) {\n    const handleLoad = () => {\n      if (!img.src.startsWith('data:')) {\n        const p = 'decode' in img ? img.decode() : Promise.resolve()\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        p.catch(() => {}).then(() => {\n          img.style.filter = 'none'\n          img.style.backgroundSize = 'none'\n          img.style.backgroundImage = 'none'\n        })\n      }\n    }\n    if (img.complete) {\n      // If the real image fails to load, this will still remove the placeholder.\n      // This is the desired behavior for now, and will be revisited when error\n      // handling is worked on for the image component itself.\n      handleLoad()\n    } else {\n      img.onload = handleLoad\n    }\n  }\n}\n\n/** Checks whether an image is currently in the viewport */\nfunction isInViewport(elem: HTMLImageElement): boolean {\n  const { top, right, bottom, left } = elem.getBoundingClientRect()\n  return bottom >= 0 && right >= 0 && top <= window.innerHeight && left <= window.innerWidth\n}\n\ntype SizesString = `${number}vw` | `${number}px`\ntype SizesRecord = Record<number, SizesString>\ntype Sizes = SizesString | SizesRecord | undefined\n\nfunction isSizesRecord(sizes?: Sizes): sizes is SizesRecord {\n  return typeof sizes === 'object'\n}\n\nfunction sizesEntries(sizes: Sizes): (readonly [number, SizesString | undefined])[] {\n  if (isSizesRecord(sizes)) {\n    return Object.entries(sizes)\n      .map(([breakpoint, size]) => [Number(breakpoint), size] as const)\n      .sort(([sizeA], [sizeB]) => sizeB - sizeA)\n  }\n  return [[0, sizes] as const]\n}\n\nfunction generateSizesString(sizes?: Sizes) {\n  return sizesEntries(sizes)\n    .map(([breakpoint, size]) => {\n      if (breakpoint === 0) return size\n      return `(min-width: ${breakpoint}px) ${size}`\n    })\n    .join(', ')\n}\n\n/** Since we're handling stuff ourselves we omit some stuff */\ntype IntrisincImage = Omit<\n  JSX.IntrinsicElements['img'],\n  'src' | 'srcSet' | 'ref' | 'width' | 'height' | 'loading' | 'sizes' | 'width' | 'height'\n> & { loading?: LoadingValue }\n\nexport type BaseImageProps = IntrisincImage & {\n  loader?: ImageLoader\n  quality?: number | string\n  unoptimized?: boolean\n\n  /**\n   * Possible values:\n   *\n   * - `fixed`: the image dimensions will not change as the viewport changes (no responsiveness)\n   *   similar to the native img element.\n   * - `intrinsic`: the image will scale the dimensions down for smaller viewports but maintain the\n   *   original dimensions (the width and height given) for larger viewports.\n   * - `responsive`: the image will scale the dimensions down for smaller viewports and scale up for\n   *   larger viewports.\n   */\n  layout?: LayoutValue\n\n  /** Size the image is rendered on mobile */\n  sizes?: SizesString | SizesRecord\n}\n\n/**\n * When `fixed`, the image dimensions will not change as the viewport changes (no responsiveness)\n * similar to the native img element.\n *\n * ```tsx\n * <img width={width} height={height} />\n * ```\n *\n * Use case: When you want to render the image at the given width/height and not change based on browser size.\n */\ntype LayoutTypeNative = {\n  layout?: 'fixed'\n  /**\n   * The width and the height values are the values used to calculate the aspect ratio om the image\n   * and reserve space in the browser.\n   *\n   * With layout=fixed and no styling the image is rendered at the width and height given.\n   */\n  width: number\n  height: number\n}\n\n/**\n * When `intrinsic`, the image will scale the dimensions down for smaller viewports but maintain the\n * original dimensions (the width and height given) for larger viewports.\n *\n * ```tsx\n * <img style={{ width: '100%', height: 'auto' maxWidth: `${width}px` }}\n * ```\n *\n * Use case: When you want to render an image but don't scale it up.\n */\ntype LayoutTypeIntrinsic = {\n  layout?: 'intrinsic'\n\n  width: number\n  height: number\n\n  style?: Omit<ImgElementStyle, 'width' | 'height' | 'maxWidth'>\n}\n\n/**\n * When `responsive`, the image will scale the dimensions down for smaller viewports and scale up\n * for larger viewports.\n *\n * ```tsx\n * <img style={{ width: '100%', height: 'auto' maxWidth: ${width} }}\n * ```\n *\n * Use case: When you want the image to fill it's parent container in width\n */\ntype LayoutTypeResponsive = {\n  layout?: 'responsive'\n\n  width: number\n  height: number\n\n  style?: Omit<ImgElementStyle, 'width' | 'height'>\n}\n\n/**\n * When `fill`, the image will stretch both width and height to the dimensions of the parent\n * element, paired with the objectFit property.\n *\n * Since the width/height isn't required to render the page we can omit it.\n *\n * ```tsx\n * <img width={width} height={height} style={{ width: '100%', height: '100%' }}\n * ```\n *\n * Use case: When you have a predefined area set to render an image\n */\ntype LayoutTypeFill = {\n  layout?: 'fill'\n\n  width?: never\n  height?: never\n\n  // objectFit: ImgElementStyle['objectFit']\n  style?: Omit<ImgElementStyle, 'width' | 'height'>\n}\n\nexport type StringImageProps = {\n  src: string\n} & (LayoutTypeFill | LayoutTypeResponsive | LayoutTypeNative | LayoutTypeIntrinsic) &\n  (\n    | { placeholder?: Exclude<PlaceholderValue, 'blur'>; blurDataURL?: never }\n    | { placeholder: 'blur'; blurDataURL: string }\n  )\n\nexport type ObjectImageProps = {\n  src: StaticImport\n  width?: number\n  height?: number | string\n  layout?: LayoutValue\n  placeholder?: PlaceholderValue\n  blurDataURL?: never\n}\n\nexport type ImageProps = BaseImageProps & (StringImageProps | ObjectImageProps)\n\nexport type StringImage = BaseImageProps & StringImageProps\nexport type ObjectImage = BaseImageProps & ObjectImageProps\n\nconst Image = React.forwardRef<HTMLImageElement, ImageProps>(\n  (\n    {\n      src,\n      sizes: sizesIncomming,\n      unoptimized = false,\n      loading,\n      layout = 'responsive',\n      quality,\n      width,\n      height,\n      style,\n      loader = defaultImageLoader,\n      placeholder = 'empty',\n      blurDataURL,\n      ...imgProps\n    },\n    forwardedRef,\n  ) => {\n    const ref = useForwardedRef(forwardedRef)\n\n    const sizesOrig =\n      layout === 'fixed' && width && !sizesIncomming\n        ? (`${width}px` as SizesString)\n        : sizesIncomming\n\n    const sizes = generateSizesString(sizesOrig) ?? '50vw'\n\n    // If no responsive sizes are given, we're defaulting to 50vw on mobile\n    // const [sizes, setSizes] = useState(toSizesString(sizesOrig) ?? `50vw`)\n\n    useEffect(() => {\n      if (process.env.NODE_ENV === 'production') return () => {}\n      if (!ref.current) return () => {}\n\n      function reportSizes(img: HTMLImageElement) {\n        let ratio: number\n\n        let msg = ''\n        const [breakpoint, size] = sizesEntries(sizesOrig).find(([s]) =>\n          s === 0 ? true : window.matchMedia(`(min-width: ${s})`),\n        ) ?? [0, '100vw']\n        if (size) {\n          const el = document.createElement('div')\n          el.setAttribute('style', `width: ${size}`)\n          document.body.appendChild(el)\n          const measuredWidth = el.getBoundingClientRect().width\n          // el.remove()\n          ratio = measuredWidth ** 2 / img.naturalWidth ** 2\n          msg += `Image has \"sizes\" property set, but size 'min-width(${breakpoint}px) ${size}' is incorrect.`\n        } else {\n          msg += `Image has no \"sizes\" property set.`\n          ratio = (window.innerWidth * 0.5) ** 2 / img.naturalWidth ** 2\n        }\n\n        const round = (nr: number) => Math.round(nr * 100) / 100\n        if (ratio > 1.2) {\n          console.warn(\n            `[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(\n              ratio,\n            )}x too many pixels`,\n            img,\n          )\n        } else if (ratio < 0.8) {\n          console.warn(\n            `[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(\n              1 / ratio,\n            )}x too few pixels`,\n            img,\n          )\n        }\n      }\n\n      // Warn the user when he isn't providing sizes and how to proceed\n      const ro = new ResizeObserver(([entry]) => {\n        const img = entry.target as HTMLImageElement\n        if (img.naturalWidth) reportSizes(img)\n\n        img.onload = () => reportSizes(img)\n      })\n      ro.observe(ref.current)\n\n      return () => ro.disconnect()\n    }, [layout, ref, sizesOrig, src, width])\n\n    let staticSrc = ''\n    if (isStaticImport(src)) {\n      const staticImageData = isStaticRequire(src) ? src.default : src\n      if (!staticImageData.src) {\n        throw new Error(\n          `[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(\n            staticImageData,\n          )}`,\n        )\n      }\n      blurDataURL = blurDataURL || staticImageData.blurDataURL\n      staticSrc = staticImageData.src\n      if (!layout || layout !== 'fill') {\n        height = height || staticImageData.height\n        width = width || staticImageData.width\n        if (!staticImageData.height || !staticImageData.width) {\n          throw new Error(\n            `[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(\n              staticImageData,\n            )}`,\n          )\n        }\n      }\n    }\n    src = typeof src === 'string' ? src : staticSrc\n\n    const widthInt = getInt(width)\n    const heightInt = getInt(height)\n    const qualityInt = getInt(quality)\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (!src) {\n        throw new Error(\n          `[@reachdigital/image]: Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`@reachdigital/image\\` component. Received: ${JSON.stringify(\n            { width, height, quality },\n          )}`,\n        )\n      }\n      if (!VALID_LAYOUT_VALUES.includes(layout)) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(\n            String,\n          ).join(',')}.`,\n        )\n      }\n      if (\n        (typeof widthInt !== 'undefined' && Number.isNaN(widthInt)) ||\n        (typeof heightInt !== 'undefined' && Number.isNaN(heightInt))\n      ) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`,\n        )\n      }\n      if (!VALID_LOADING_VALUES.includes(loading)) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(\n            String,\n          ).join(',')}.`,\n        )\n      }\n      if (placeholder === 'blur') {\n        if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n          console.warn(\n            `[@reachdigital/image]: Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`,\n          )\n        }\n        if (!blurDataURL) {\n          const VALID_BLUR_EXT = ['jpeg', 'png', 'webp'] // should match next-image-loader\n\n          throw new Error(\n            `[@reachdigital/image]: Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n          Possible solutions:\n            - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n            - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(\n              ',',\n            )}\n            - Remove the \"placeholder\" property, effectively no blur effect\n          Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`,\n          )\n        }\n      }\n    }\n\n    if (typeof widthInt === 'undefined' && typeof heightInt === 'undefined') {\n      if (layout === 'fill') {\n        // handle fill\n      } else if (process.env.NODE_ENV !== 'production') {\n        // <Image src=\"i.png\" />\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`,\n        )\n      }\n    }\n\n    loading ??= 'lazy'\n    if (src && src.startsWith('data:')) {\n      // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n      unoptimized = true\n    }\n\n    const attributes3x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 1.5,\n    })\n\n    const attributes2x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 1,\n    })\n\n    const attributes1x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 0.5,\n    })\n\n    if (layout !== 'fixed' && !style) style = {}\n    if (layout === 'responsive') style = { ...style, width: '100%', height: 'auto' }\n    if (layout === 'intrinsic') style = { ...style, width: '100%', height: 'auto', maxWidth: width }\n    if (layout === 'fill') style = { ...style, width: '100%', height: '100%' }\n\n    return (\n      <>\n        {unoptimized ? (\n          <img ref={ref} {...imgProps} src={src} width={width} height={height} style={style} />\n        ) : (\n          <picture>\n            <source media='(-webkit-min-device-pixel-ratio: 2.5)' {...attributes3x} />\n            <source media='(-webkit-min-device-pixel-ratio: 1.5)' {...attributes2x} />\n            <img\n              ref={ref}\n              {...imgProps}\n              {...attributes1x}\n              loading={loading}\n              width={width}\n              height={height}\n              style={style}\n            />\n          </picture>\n        )}\n        {loading === 'eager' && (\n          <Head>\n            <link\n              key={`__nimg-2x-${attributes1x.srcSet}${attributes1x.sizes}`}\n              rel='preload'\n              as='image'\n              media='(-webkit-min-device-pixel-ratio: 2.5)'\n              // @ts-expect-error imagesrcset is not yet in the link element type\n              imagesrcset={attributes1x.srcSet}\n              imagesizes={sizes}\n            />\n          </Head>\n        )}\n      </>\n    )\n  },\n)\nImage.displayName = 'NextPicture'\n\nexport { Image }\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../components/Image.tsx\n");
19
+
20
+ /***/ })
21
+
22
+ });
@@ -0,0 +1,22 @@
1
+ /*
2
+ * ATTENTION: An "eval-source-map" devtool has been used.
3
+ * This devtool is neither made for production nor for readable output files.
4
+ * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
5
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
6
+ * or disable the default devtool with "devtool: false".
7
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
8
+ */
9
+ self["webpackHotUpdate_N_E"]("pages/index",{
10
+
11
+ /***/ "../components/Image.tsx":
12
+ /*!*******************************!*\
13
+ !*** ../components/Image.tsx ***!
14
+ \*******************************/
15
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
16
+
17
+ "use strict";
18
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"isStaticRequire\": function() { return /* binding */ isStaticRequire; },\n/* harmony export */ \"isStaticImageData\": function() { return /* binding */ isStaticImageData; },\n/* harmony export */ \"isStaticImport\": function() { return /* binding */ isStaticImport; },\n/* harmony export */ \"getInt\": function() { return /* binding */ getInt; },\n/* harmony export */ \"Image\": function() { return /* binding */ Image; }\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"../../../node_modules/react/jsx-dev-runtime.js\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties */ \"../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js\");\n/* harmony import */ var _Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/defineProperty */ \"../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/defineProperty.js\");\n/* harmony import */ var _bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @bedrock-layout/use-forwarded-ref */ \"../../../node_modules/@bedrock-layout/use-forwarded-ref/lib/index.m.js\");\n/* harmony import */ var next_dist_next_server_server_image_config__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! next/dist/next-server/server/image-config */ \"../../../node_modules/next/dist/next-server/server/image-config.js\");\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! next/head */ \"../../../node_modules/next/head.js\");\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(next_head__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! react */ \"../../../node_modules/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../config/config */ \"../config/config.ts\");\n/* module decorator */ module = __webpack_require__.hmd(module);\n\n\n\n\n\nvar _jsxFileName = \"/Users/paulhachmang/Sites/reachdigital-next/packages/image/components/Image.tsx\",\n _s = $RefreshSig$();\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_2__.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\n/* eslint-disable prefer-const */\n\n/* eslint-disable no-param-reassign */\n\n/* eslint-disable @next/next/no-img-element */\n\n/* eslint-disable jsx-a11y/alt-text */\n\n\n\n\n\n\nif (false) {}\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined];\nconst loaders = new Map([['imgix', _config_config__WEBPACK_IMPORTED_MODULE_6__.imgixLoader], ['cloudinary', _config_config__WEBPACK_IMPORTED_MODULE_6__.cloudinaryLoader], ['akamai', _config_config__WEBPACK_IMPORTED_MODULE_6__.akamaiLoader], ['default', _config_config__WEBPACK_IMPORTED_MODULE_6__.defaultLoader]]);\nconst VALID_LAYOUT_VALUES = ['fill', 'responsive', 'intrinsic', 'fixed'];\nfunction isStaticRequire(src) {\n return src.default !== undefined;\n}\nfunction isStaticImageData(src) {\n return src.src !== undefined;\n}\nfunction isStaticImport(src) {\n return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src));\n} // sort smallest to largest\n\nconst allSizes = [..._config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes, ..._config_config__WEBPACK_IMPORTED_MODULE_6__.configImageSizes];\n_config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes.sort((a, b) => a - b);\nallSizes.sort((a, b) => a - b);\n\nfunction getWidths(width, layout, sizes = '', scale) {\n if (sizes && layout === 'fill' || layout === 'responsive') {\n // Find all the \"vw\" percent sizes used in the sizes prop\n const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g;\n const percentSizes = []; // eslint-disable-next-line no-cond-assign\n\n for (let match; match = viewportWidthRe.exec(sizes); match) {\n var _match;\n\n percentSizes.push(parseInt((_match = match) === null || _match === void 0 ? void 0 : _match[2], 10));\n }\n\n if (percentSizes.length) {\n const smallestRatio = Math.min(...percentSizes) * 0.01;\n return {\n widths: allSizes.filter(s => s >= _config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes[0] * smallestRatio),\n kind: 'w'\n };\n } // Find all the \"px\" sizes used in the sizes prop\n\n\n const pxWidthRe = /(^|\\s)(1?\\d+)px/g;\n const pxSizes = []; // eslint-disable-next-line no-cond-assign\n\n for (let match; match = pxWidthRe.exec(sizes); match) {\n var _match2;\n\n pxSizes.push(parseInt((_match2 = match) === null || _match2 === void 0 ? void 0 : _match2[2], 10));\n }\n\n if (pxSizes.length) {\n return {\n widths: pxSizes.map(pxSize => {\n var _allSizes$filter, _allSizes$filter2;\n\n const scaled = (_allSizes$filter = allSizes.filter(s => s * scale > pxSize)) === null || _allSizes$filter === void 0 ? void 0 : _allSizes$filter[0];\n const dpr2 = (_allSizes$filter2 = allSizes.filter(s => s > pxSize)) === null || _allSizes$filter2 === void 0 ? void 0 : _allSizes$filter2[0];\n return scale > 1 ? Math.max(scaled, dpr2) : Math.min(scaled, dpr2);\n }),\n kind: 'w'\n };\n }\n\n return {\n widths: allSizes,\n kind: 'w'\n };\n }\n\n if (typeof width !== 'number' || layout === 'fill') {\n return {\n widths: _config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes,\n kind: 'w'\n };\n }\n\n const widths = [...new Set( // > This means that most OLED screens that say they are 3x resolution,\n // > are actually 3x in the green color, but only 1.5x in the red and\n // > blue colors. Showing a 3x resolution image in the app vs a 2x\n // > resolution image will be visually the same, though the 3x image\n // > takes significantly more data. Even true 3x resolution screens are\n // > wasteful as the human eye cannot see that level of detail without\n // > something like a magnifying glass.\n // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n [width, width * 2\n /* , width * 3*/\n ].map(w => allSizes.find(p => p >= w) || allSizes[allSizes.length - 1]))];\n return {\n widths,\n kind: 'x'\n };\n}\n\nfunction generateSourceAttrs({\n src,\n layout,\n width,\n quality = 44,\n sizes,\n loader,\n scale\n}) {\n const {\n widths,\n kind\n } = getWidths(width, layout, sizes, scale);\n return {\n sizes: !sizes && kind === 'w' ? `50vw` : sizes,\n srcSet: widths.map((w, i) => `${loader({\n src,\n quality,\n width: w\n })} ${kind === 'w' ? Math.round(w * scale) : i + 1}${kind}`).join(', ')\n };\n}\n\nfunction getInt(x) {\n if (typeof x === 'number') {\n return x;\n }\n\n if (typeof x === 'string') {\n return parseInt(x, 10);\n }\n\n return undefined;\n}\n\nfunction defaultImageLoader(loaderProps) {\n const load = loaders.get(_config_config__WEBPACK_IMPORTED_MODULE_6__.configLoader);\n\n if (load) {\n return load(_objectSpread({\n root: _config_config__WEBPACK_IMPORTED_MODULE_6__.configPath\n }, loaderProps));\n }\n\n throw new Error(`[@reachdigital/image]: Unknown \"loader\" found in \"next.config.js\". Expected: ${next_dist_next_server_server_image_config__WEBPACK_IMPORTED_MODULE_3__.VALID_LOADERS.join(', ')}. Received: ${_config_config__WEBPACK_IMPORTED_MODULE_6__.configLoader}`);\n} // See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\n\n\nfunction removePlaceholder(img, placeholder) {\n if (placeholder === 'blur' && img) {\n const handleLoad = () => {\n if (!img.src.startsWith('data:')) {\n const p = 'decode' in img ? img.decode() : Promise.resolve(); // eslint-disable-next-line @typescript-eslint/no-floating-promises\n\n p.catch(() => {}).then(() => {\n img.style.filter = 'none';\n img.style.backgroundSize = 'none';\n img.style.backgroundImage = 'none';\n });\n }\n };\n\n if (img.complete) {\n // If the real image fails to load, this will still remove the placeholder.\n // This is the desired behavior for now, and will be revisited when error\n // handling is worked on for the image component itself.\n handleLoad();\n } else {\n img.onload = handleLoad;\n }\n }\n}\n/** Checks whether an image is currently in the viewport */\n\n\nfunction isInViewport(elem) {\n const {\n top,\n right,\n bottom,\n left\n } = elem.getBoundingClientRect();\n return bottom >= 0 && right >= 0 && top <= window.innerHeight && left <= window.innerWidth;\n}\n\nfunction isSizesRecord(sizes) {\n return typeof sizes === 'object';\n}\n\nfunction sizesEntries(sizes) {\n if (isSizesRecord(sizes)) {\n return Object.entries(sizes).map(([breakpoint, size]) => [Number(breakpoint), size]).sort(([sizeA], [sizeB]) => sizeB - sizeA);\n }\n\n return [[0, sizes]];\n}\n\nfunction generateSizesString(sizes) {\n return sizesEntries(sizes).map(([breakpoint, size]) => {\n if (breakpoint === 0) return size;\n return `(min-width: ${breakpoint}px) ${size}`;\n }).join(', ');\n}\n/** Since we're handling stuff ourselves we omit some stuff */\n\n\nconst Image = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_5___default().forwardRef(_c = _s((_ref, forwardedRef) => {\n var _generateSizesString, _loading;\n\n _s();\n\n let {\n src,\n sizes: sizesOrig,\n unoptimized = false,\n loading,\n layout = 'responsive',\n quality,\n width,\n height,\n style,\n loader = defaultImageLoader,\n placeholder = 'empty',\n blurDataURL\n } = _ref,\n imgProps = (0,_Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__.default)(_ref, [\"src\", \"sizes\", \"unoptimized\", \"loading\", \"layout\", \"quality\", \"width\", \"height\", \"style\", \"loader\", \"placeholder\", \"blurDataURL\"]);\n\n const ref = (0,_bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__.default)(forwardedRef);\n const sizes = (_generateSizesString = generateSizesString(layout === 'fixed' && width && !sizesOrig ? `${width}px` : sizesOrig)) !== null && _generateSizesString !== void 0 ? _generateSizesString : '50vw'; // If no responsive sizes are given, we're defaulting to 50vw on mobile\n // const [sizes, setSizes] = useState(toSizesString(sizesOrig) ?? `50vw`)\n\n (0,react__WEBPACK_IMPORTED_MODULE_5__.useEffect)(() => {\n if (!ref.current || false || layout === 'fixed' && width) return () => {}; // Warn the user when he isn't providing sizes and how to proceed\n\n const ro = new ResizeObserver(([entry]) => {\n var _sizesEntries$find;\n\n const currentvw = entry.contentRect.width;\n let ratio;\n let msg = '';\n const [breakpoint, size] = (_sizesEntries$find = sizesEntries(sizesOrig).find(([s]) => s === 0 ? true : window.matchMedia(`(min-width: ${s})`))) !== null && _sizesEntries$find !== void 0 ? _sizesEntries$find : [0, '100vw'];\n\n if (size) {\n const el = document.createElement('div');\n el.setAttribute('style', `width: ${size}`);\n document.body.appendChild(el);\n const measuredWidth = el.getBoundingClientRect().width; // el.remove()\n\n ratio = measuredWidth ** 2 / currentvw ** 2;\n msg += `Image has \"sizes\" property set, but size 'min-width(${breakpoint}px) ${size}' is incorrect.`;\n } else {\n msg += `Image has no \"sizes\" property set.`;\n ratio = (window.innerWidth * 0.5) ** 2 / currentvw ** 2;\n }\n\n const round = nr => Math.round(nr * 100) / 100;\n\n if (ratio > 1.2) {\n console.warn(`[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(ratio)}x too many pixels`, entry.target);\n } else if (ratio < 0.8) {\n console.warn(`[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(1 / ratio)}x too few pixels`, entry.target);\n }\n });\n ro.observe(ref.current);\n return () => ro.disconnect();\n }, [layout, ref, sizesOrig, src, width]);\n let staticSrc = '';\n\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src;\n\n if (!staticImageData.src) {\n throw new Error(`[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(staticImageData)}`);\n }\n\n blurDataURL = blurDataURL || staticImageData.blurDataURL;\n staticSrc = staticImageData.src;\n\n if (!layout || layout !== 'fill') {\n height = height || staticImageData.height;\n width = width || staticImageData.width;\n\n if (!staticImageData.height || !staticImageData.width) {\n throw new Error(`[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(staticImageData)}`);\n }\n }\n }\n\n src = typeof src === 'string' ? src : staticSrc;\n const widthInt = getInt(width);\n const heightInt = getInt(height);\n const qualityInt = getInt(quality);\n\n if (true) {\n if (!src) {\n throw new Error(`[@reachdigital/image]: Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`@reachdigital/image\\` component. Received: ${JSON.stringify({\n width,\n height,\n quality\n })}`);\n }\n\n if (!VALID_LAYOUT_VALUES.includes(layout)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(String).join(',')}.`);\n }\n\n if (typeof widthInt !== 'undefined' && Number.isNaN(widthInt) || typeof heightInt !== 'undefined' && Number.isNaN(heightInt)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`);\n }\n\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(String).join(',')}.`);\n }\n\n if (placeholder === 'blur') {\n if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n console.warn(`[@reachdigital/image]: Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`);\n }\n\n if (!blurDataURL) {\n const VALID_BLUR_EXT = ['jpeg', 'png', 'webp']; // should match next-image-loader\n\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n Possible solutions:\n - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(',')}\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`);\n }\n }\n }\n\n if (typeof widthInt === 'undefined' && typeof heightInt === 'undefined') {\n if (layout === 'fill') {// handle fill\n } else if (true) {\n // <Image src=\"i.png\" />\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`);\n }\n }\n\n (_loading = loading) !== null && _loading !== void 0 ? _loading : loading = 'lazy';\n\n if (src && src.startsWith('data:')) {\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n unoptimized = true;\n }\n\n const attributes3x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 1.5\n });\n const attributes2x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 1\n });\n const attributes1x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 0.5\n });\n if (layout !== 'fixed' && !style) style = {};\n if (layout === 'responsive') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: 'auto'\n });\n if (layout === 'intrinsic') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: 'auto',\n maxWidth: width\n });\n if (layout === 'fill') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: '100%'\n });\n return /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.Fragment, {\n children: [unoptimized ? /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"img\", _objectSpread(_objectSpread({\n ref: ref\n }, imgProps), {}, {\n src: src,\n width: width,\n height: height,\n style: style\n }), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 609,\n columnNumber: 11\n }, undefined) : /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"picture\", {\n children: [/*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"source\", _objectSpread({\n media: \"(-webkit-min-device-pixel-ratio: 2.5)\"\n }, attributes3x), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 612,\n columnNumber: 13\n }, undefined), /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"source\", _objectSpread({\n media: \"(-webkit-min-device-pixel-ratio: 1.5)\"\n }, attributes2x), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 613,\n columnNumber: 13\n }, undefined), /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"img\", _objectSpread(_objectSpread(_objectSpread({\n ref: ref\n }, imgProps), attributes1x), {}, {\n loading: loading,\n width: width,\n height: height,\n style: style\n }), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 614,\n columnNumber: 13\n }, undefined)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 611,\n columnNumber: 11\n }, undefined), loading === 'eager' && /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)((next_head__WEBPACK_IMPORTED_MODULE_4___default()), {\n children: /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"link\", {\n rel: \"preload\",\n as: \"image\",\n media: \"(-webkit-min-device-pixel-ratio: 2.5)\" // @ts-expect-error imagesrcset is not yet in the link element type\n ,\n imagesrcset: attributes1x.srcSet,\n imagesizes: sizes\n }, `__nimg-2x-${attributes1x.srcSet}${attributes1x.sizes}`, false, {\n fileName: _jsxFileName,\n lineNumber: 627,\n columnNumber: 13\n }, undefined)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 626,\n columnNumber: 11\n }, undefined)]\n }, void 0, true);\n}, \"uc1ywpQv+s/tGng4xj/L6VVOIq8=\", false, function () {\n return [_bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__.default];\n}));\n_c2 = Image;\nImage.displayName = 'NextPicture';\n\n\nvar _c, _c2;\n\n$RefreshReg$(_c, \"Image$React.forwardRef\");\n$RefreshReg$(_c2, \"Image\");\n\n;\n var _a, _b;\n // Legacy CSS implementations will `eval` browser code in a Node.js context\n // to extract CSS. For backwards compatibility, we need to check we're in a\n // browser context before continuing.\n if (typeof self !== 'undefined' &&\n // AMP / No-JS mode does not inject these helpers:\n '$RefreshHelpers$' in self) {\n var currentExports = module.__proto__.exports;\n var prevExports = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevExports) !== null && _b !== void 0 ? _b : null;\n // This cannot happen in MainTemplate because the exports mismatch between\n // templating and execution.\n self.$RefreshHelpers$.registerExportsForReactRefresh(currentExports, module.id);\n // A module can be accepted automatically based on its exports, e.g. when\n // it is a Refresh Boundary.\n if (self.$RefreshHelpers$.isReactRefreshBoundary(currentExports)) {\n // Save the previous exports on update so we can compare the boundary\n // signatures.\n module.hot.dispose(function (data) {\n data.prevExports = currentExports;\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n module.hot.accept();\n // This field is set when the previous version of this module was a\n // Refresh Boundary, letting us know we need to check for invalidation or\n // enqueue an update.\n if (prevExports !== null) {\n // A boundary can become ineligible if its exports are incompatible\n // with the previous exports.\n //\n // For example, if you add/remove/change exports, we'll want to\n // re-execute the importing modules, and force those components to\n // re-render. Similarly, if you convert a class component to a\n // function, we want to invalidate the boundary.\n if (self.$RefreshHelpers$.shouldInvalidateReactRefreshBoundary(prevExports, currentExports)) {\n module.hot.invalidate();\n }\n else {\n self.$RefreshHelpers$.scheduleUpdate();\n }\n }\n }\n else {\n // Since we just executed the code for the module, it's possible that the\n // new exports made it ineligible for being a boundary.\n // We only care about the case when we were _previously_ a boundary,\n // because we already accepted this update (accidental side effect).\n var isNoLongerABoundary = prevExports !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://_N_E/../components/Image.tsx?2b6d"],"names":["VALID_LOADING_VALUES","undefined","loaders","Map","imgixLoader","cloudinaryLoader","akamaiLoader","defaultLoader","VALID_LAYOUT_VALUES","isStaticRequire","src","default","isStaticImageData","isStaticImport","allSizes","configDeviceSizes","configImageSizes","a","b","sort","getWidths","width","layout","sizes","scale","viewportWidthRe","percentSizes","match","exec","push","parseInt","length","smallestRatio","Math","min","widths","filter","s","kind","pxWidthRe","pxSizes","map","pxSize","scaled","dpr2","max","Set","w","find","p","generateSourceAttrs","quality","loader","srcSet","i","round","join","getInt","x","defaultImageLoader","loaderProps","load","get","configLoader","root","configPath","Error","VALID_LOADERS","removePlaceholder","img","placeholder","handleLoad","startsWith","decode","Promise","resolve","catch","then","style","backgroundSize","backgroundImage","complete","onload","isInViewport","elem","top","right","bottom","left","getBoundingClientRect","window","innerHeight","innerWidth","isSizesRecord","sizesEntries","Object","entries","breakpoint","size","Number","sizeA","sizeB","generateSizesString","Image","React","forwardedRef","sizesOrig","unoptimized","loading","height","blurDataURL","imgProps","ref","useForwardedRef","useEffect","current","ro","ResizeObserver","entry","currentvw","contentRect","ratio","msg","matchMedia","el","document","createElement","setAttribute","body","appendChild","measuredWidth","nr","console","warn","target","observe","disconnect","staticSrc","staticImageData","JSON","stringify","widthInt","heightInt","qualityInt","includes","String","isNaN","VALID_BLUR_EXT","attributes3x","attributes2x","attributes1x","maxWidth","displayName"],"mappings":"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","file":"../components/Image.tsx.js","sourcesContent":["/* eslint-disable prefer-const */\n/* eslint-disable no-param-reassign */\n/* eslint-disable @next/next/no-img-element */\n/* eslint-disable jsx-a11y/alt-text */\nimport useForwardedRef from '@bedrock-layout/use-forwarded-ref'\nimport { LoaderValue, VALID_LOADERS } from 'next/dist/next-server/server/image-config'\nimport Head from 'next/head'\nimport type { ImageLoaderProps, ImageLoader } from 'next/image'\nimport React, { useEffect, useState } from 'react'\nimport useResizeObserver from 'use-resize-observer'\nimport {\n  akamaiLoader,\n  cloudinaryLoader,\n  configDeviceSizes,\n  configImageSizes,\n  configLoader,\n  configPath,\n  DefaultImageLoaderProps,\n  defaultLoader,\n  imgixLoader,\n} from '../config/config'\nimport useConnectionType from '../hooks/useConnectionType'\n\nif (typeof window === 'undefined') {\n  // eslint-disable-next-line no-underscore-dangle\n  global.__NEXT_IMAGE_IMPORTED = true\n}\n\nexport type { ImageLoaderProps, ImageLoader }\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined] as const\ntype LoadingValue = typeof VALID_LOADING_VALUES[number]\n\nconst loaders = new Map<LoaderValue, (props: DefaultImageLoaderProps) => string>([\n  ['imgix', imgixLoader],\n  ['cloudinary', cloudinaryLoader],\n  ['akamai', akamaiLoader],\n  ['default', defaultLoader],\n])\n\nconst VALID_LAYOUT_VALUES = ['fill', 'responsive', 'intrinsic', 'fixed'] as const\ntype LayoutValue = 'fill' | 'fixed' | 'intrinsic' | 'responsive' | undefined\n\ntype PlaceholderValue = 'blur' | 'empty'\n\ntype ImgElementStyle = NonNullable<JSX.IntrinsicElements['img']['style']>\n\ninterface StaticImageData {\n  src: string\n  height: number\n  width: number\n  blurDataURL?: string\n}\n\ninterface StaticRequire {\n  default: StaticImageData\n}\n\ntype StaticImport = StaticRequire | StaticImageData\n\nexport function isStaticRequire(src: StaticRequire | StaticImageData): src is StaticRequire {\n  return (src as StaticRequire).default !== undefined\n}\n\nexport function isStaticImageData(src: StaticRequire | StaticImageData): src is StaticImageData {\n  return (src as StaticImageData).src !== undefined\n}\n\nexport function isStaticImport(src: string | StaticImport): src is StaticImport {\n  return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src))\n}\n\n// sort smallest to largest\nconst allSizes = [...configDeviceSizes, ...configImageSizes]\nconfigDeviceSizes.sort((a, b) => a - b)\nallSizes.sort((a, b) => a - b)\n\nfunction getWidths(\n  width: number | undefined,\n  layout: LayoutValue,\n  sizes = '',\n  scale: number,\n): { widths: number[]; kind: 'w' | 'x' } {\n  if ((sizes && layout === 'fill') || layout === 'responsive') {\n    // Find all the \"vw\" percent sizes used in the sizes prop\n    const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g\n    const percentSizes: number[] = []\n    // eslint-disable-next-line no-cond-assign\n    for (let match: string[] | null; (match = viewportWidthRe.exec(sizes)); match) {\n      percentSizes.push(parseInt(match?.[2], 10))\n    }\n    if (percentSizes.length) {\n      const smallestRatio = Math.min(...percentSizes) * 0.01\n\n      return {\n        widths: allSizes.filter((s) => s >= configDeviceSizes[0] * smallestRatio),\n        kind: 'w',\n      }\n    }\n\n    // Find all the \"px\" sizes used in the sizes prop\n    const pxWidthRe = /(^|\\s)(1?\\d+)px/g\n    const pxSizes: number[] = []\n    // eslint-disable-next-line no-cond-assign\n    for (let match: string[] | null; (match = pxWidthRe.exec(sizes)); match) {\n      pxSizes.push(parseInt(match?.[2], 10))\n    }\n\n    if (pxSizes.length) {\n      return {\n        widths: pxSizes.map((pxSize) => {\n          const scaled = allSizes.filter((s) => s * scale > pxSize)?.[0]\n          const dpr2 = allSizes.filter((s) => s > pxSize)?.[0]\n          return scale > 1 ? Math.max(scaled, dpr2) : Math.min(scaled, dpr2)\n        }),\n        kind: 'w',\n      }\n    }\n\n    return { widths: allSizes, kind: 'w' }\n  }\n  if (typeof width !== 'number' || layout === 'fill') {\n    return { widths: configDeviceSizes, kind: 'w' }\n  }\n\n  const widths = [\n    ...new Set(\n      // > This means that most OLED screens that say they are 3x resolution,\n      // > are actually 3x in the green color, but only 1.5x in the red and\n      // > blue colors. Showing a 3x resolution image in the app vs a 2x\n      // > resolution image will be visually the same, though the 3x image\n      // > takes significantly more data. Even true 3x resolution screens are\n      // > wasteful as the human eye cannot see that level of detail without\n      // > something like a magnifying glass.\n      // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n      [width, width * 2 /* , width * 3*/].map(\n        (w) => allSizes.find((p) => p >= w) || allSizes[allSizes.length - 1],\n      ),\n    ),\n  ]\n  return { widths, kind: 'x' }\n}\n\ntype GenImgAttrsData = {\n  src: string\n  layout: LayoutValue\n  loader: ImageLoader\n  width?: number\n  quality?: number\n  sizes?: string\n  scale: number\n}\n\ntype GenImgAttrsResult = {\n  srcSet: string | undefined\n  sizes: string | undefined\n}\n\nfunction generateSourceAttrs({\n  src,\n  layout,\n  width,\n  quality = 44,\n  sizes,\n  loader,\n  scale,\n}: GenImgAttrsData): GenImgAttrsResult {\n  const { widths, kind } = getWidths(width, layout, sizes, scale)\n\n  return {\n    sizes: !sizes && kind === 'w' ? `50vw` : sizes,\n    srcSet: widths\n      .map(\n        (w, i) =>\n          `${loader({ src, quality, width: w })} ${\n            kind === 'w' ? Math.round(w * scale) : i + 1\n          }${kind}`,\n      )\n      .join(', '),\n  }\n}\n\nexport function getInt(x: unknown): number | undefined {\n  if (typeof x === 'number') {\n    return x\n  }\n  if (typeof x === 'string') {\n    return parseInt(x, 10)\n  }\n  return undefined\n}\n\nfunction defaultImageLoader(loaderProps: ImageLoaderProps) {\n  const load = loaders.get(configLoader)\n  if (load) {\n    return load({ root: configPath, ...loaderProps })\n  }\n  throw new Error(\n    `[@reachdigital/image]: Unknown \"loader\" found in \"next.config.js\". Expected: ${VALID_LOADERS.join(\n      ', ',\n    )}. Received: ${configLoader}`,\n  )\n}\n\n// See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\nfunction removePlaceholder(img: HTMLImageElement | null, placeholder: PlaceholderValue) {\n  if (placeholder === 'blur' && img) {\n    const handleLoad = () => {\n      if (!img.src.startsWith('data:')) {\n        const p = 'decode' in img ? img.decode() : Promise.resolve()\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        p.catch(() => {}).then(() => {\n          img.style.filter = 'none'\n          img.style.backgroundSize = 'none'\n          img.style.backgroundImage = 'none'\n        })\n      }\n    }\n    if (img.complete) {\n      // If the real image fails to load, this will still remove the placeholder.\n      // This is the desired behavior for now, and will be revisited when error\n      // handling is worked on for the image component itself.\n      handleLoad()\n    } else {\n      img.onload = handleLoad\n    }\n  }\n}\n\n/** Checks whether an image is currently in the viewport */\nfunction isInViewport(elem: HTMLImageElement): boolean {\n  const { top, right, bottom, left } = elem.getBoundingClientRect()\n  return bottom >= 0 && right >= 0 && top <= window.innerHeight && left <= window.innerWidth\n}\n\ntype SizesString = `${number}vw` | `${number}px`\ntype SizesRecord = Record<number, SizesString>\ntype Sizes = SizesString | SizesRecord | undefined\n\nfunction isSizesRecord(sizes?: Sizes): sizes is SizesRecord {\n  return typeof sizes === 'object'\n}\n\nfunction sizesEntries(sizes: Sizes): (readonly [number, SizesString | undefined])[] {\n  if (isSizesRecord(sizes)) {\n    return Object.entries(sizes)\n      .map(([breakpoint, size]) => [Number(breakpoint), size] as const)\n      .sort(([sizeA], [sizeB]) => sizeB - sizeA)\n  }\n  return [[0, sizes] as const]\n}\n\nfunction generateSizesString(sizes?: Sizes) {\n  return sizesEntries(sizes)\n    .map(([breakpoint, size]) => {\n      if (breakpoint === 0) return size\n      return `(min-width: ${breakpoint}px) ${size}`\n    })\n    .join(', ')\n}\n\n/** Since we're handling stuff ourselves we omit some stuff */\ntype IntrisincImage = Omit<\n  JSX.IntrinsicElements['img'],\n  'src' | 'srcSet' | 'ref' | 'width' | 'height' | 'loading' | 'sizes' | 'width' | 'height'\n> & { loading?: LoadingValue }\n\nexport type BaseImageProps = IntrisincImage & {\n  loader?: ImageLoader\n  quality?: number | string\n  unoptimized?: boolean\n\n  /**\n   * Possible values:\n   *\n   * - `fixed`: the image dimensions will not change as the viewport changes (no responsiveness)\n   *   similar to the native img element.\n   * - `intrinsic`: the image will scale the dimensions down for smaller viewports but maintain the\n   *   original dimensions (the width and height given) for larger viewports.\n   * - `responsive`: the image will scale the dimensions down for smaller viewports and scale up for\n   *   larger viewports.\n   */\n  layout?: LayoutValue\n\n  /** Size the image is rendered on mobile */\n  sizes?: SizesString | SizesRecord\n}\n\n/**\n * When `fixed`, the image dimensions will not change as the viewport changes (no responsiveness)\n * similar to the native img element.\n *\n * ```tsx\n * <img width={width} height={height} />\n * ```\n *\n * Use case: When you want to render the image at the given width/height and not change based on browser size.\n */\ntype LayoutTypeNative = {\n  layout?: 'fixed'\n  /**\n   * The width and the height values are the values used to calculate the aspect ratio om the image\n   * and reserve space in the browser.\n   *\n   * With layout=fixed and no styling the image is rendered at the width and height given.\n   */\n  width: number\n  height: number\n}\n\n/**\n * When `intrinsic`, the image will scale the dimensions down for smaller viewports but maintain the\n * original dimensions (the width and height given) for larger viewports.\n *\n * ```tsx\n * <img style={{ width: '100%', height: 'auto' maxWidth: `${width}px` }}\n * ```\n *\n * Use case: When you want to render an image but don't scale it up.\n */\ntype LayoutTypeIntrinsic = {\n  layout?: 'intrinsic'\n\n  width: number\n  height: number\n\n  style?: Omit<ImgElementStyle, 'width' | 'height' | 'maxWidth'>\n}\n\n/**\n * When `responsive`, the image will scale the dimensions down for smaller viewports and scale up\n * for larger viewports.\n *\n * ```tsx\n * <img style={{ width: '100%', height: 'auto' maxWidth: ${width} }}\n * ```\n *\n * Use case: When you want the image to fill it's parent container in width\n */\ntype LayoutTypeResponsive = {\n  layout?: 'responsive'\n\n  width: number\n  height: number\n\n  style?: Omit<ImgElementStyle, 'width' | 'height'>\n}\n\n/**\n * When `fill`, the image will stretch both width and height to the dimensions of the parent\n * element, paired with the objectFit property.\n *\n * Since the width/height isn't required to render the page we can omit it.\n *\n * ```tsx\n * <img width={width} height={height} style={{ width: '100%', height: '100%' }}\n * ```\n *\n * Use case: When you have a predefined area set to render an image\n */\ntype LayoutTypeFill = {\n  layout?: 'fill'\n\n  width?: never\n  height?: never\n\n  // objectFit: ImgElementStyle['objectFit']\n  style?: Omit<ImgElementStyle, 'width' | 'height'>\n}\n\nexport type StringImageProps = {\n  src: string\n} & (LayoutTypeFill | LayoutTypeResponsive | LayoutTypeNative | LayoutTypeIntrinsic) &\n  (\n    | { placeholder?: Exclude<PlaceholderValue, 'blur'>; blurDataURL?: never }\n    | { placeholder: 'blur'; blurDataURL: string }\n  )\n\nexport type ObjectImageProps = {\n  src: StaticImport\n  width?: number\n  height?: number | string\n  layout?: LayoutValue\n  placeholder?: PlaceholderValue\n  blurDataURL?: never\n}\n\nexport type ImageProps = BaseImageProps & (StringImageProps | ObjectImageProps)\n\nexport type StringImage = BaseImageProps & StringImageProps\nexport type ObjectImage = BaseImageProps & ObjectImageProps\n\nconst Image = React.forwardRef<HTMLImageElement, ImageProps>(\n  (\n    {\n      src,\n      sizes: sizesOrig,\n      unoptimized = false,\n      loading,\n      layout = 'responsive',\n      quality,\n      width,\n      height,\n      style,\n      loader = defaultImageLoader,\n      placeholder = 'empty',\n      blurDataURL,\n      ...imgProps\n    },\n    forwardedRef,\n  ) => {\n    const ref = useForwardedRef(forwardedRef)\n\n    const sizes =\n      generateSizesString(layout === 'fixed' && width && !sizesOrig ? `${width}px` : sizesOrig) ??\n      '50vw'\n\n    // If no responsive sizes are given, we're defaulting to 50vw on mobile\n    // const [sizes, setSizes] = useState(toSizesString(sizesOrig) ?? `50vw`)\n\n    useEffect(() => {\n      if (!ref.current || process.env.NODE_ENV === 'production' || (layout === 'fixed' && width))\n        return () => {}\n\n      // Warn the user when he isn't providing sizes and how to proceed\n      const ro = new ResizeObserver(([entry]) => {\n        const currentvw = entry.contentRect.width\n\n        let ratio: number\n\n        let msg = ''\n        const [breakpoint, size] = sizesEntries(sizesOrig).find(([s]) =>\n          s === 0 ? true : window.matchMedia(`(min-width: ${s})`),\n        ) ?? [0, '100vw']\n        if (size) {\n          const el = document.createElement('div')\n          el.setAttribute('style', `width: ${size}`)\n          document.body.appendChild(el)\n          const measuredWidth = el.getBoundingClientRect().width\n          // el.remove()\n          ratio = measuredWidth ** 2 / currentvw ** 2\n          msg += `Image has \"sizes\" property set, but size 'min-width(${breakpoint}px) ${size}' is incorrect.`\n        } else {\n          msg += `Image has no \"sizes\" property set.`\n          ratio = (window.innerWidth * 0.5) ** 2 / currentvw ** 2\n        }\n\n        const round = (nr: number) => Math.round(nr * 100) / 100\n        if (ratio > 1.2) {\n          console.warn(\n            `[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(\n              ratio,\n            )}x too many pixels`,\n            entry.target,\n          )\n        } else if (ratio < 0.8) {\n          console.warn(\n            `[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(\n              1 / ratio,\n            )}x too few pixels`,\n            entry.target,\n          )\n        }\n      })\n      ro.observe(ref.current)\n\n      return () => ro.disconnect()\n    }, [layout, ref, sizesOrig, src, width])\n\n    let staticSrc = ''\n    if (isStaticImport(src)) {\n      const staticImageData = isStaticRequire(src) ? src.default : src\n      if (!staticImageData.src) {\n        throw new Error(\n          `[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(\n            staticImageData,\n          )}`,\n        )\n      }\n      blurDataURL = blurDataURL || staticImageData.blurDataURL\n      staticSrc = staticImageData.src\n      if (!layout || layout !== 'fill') {\n        height = height || staticImageData.height\n        width = width || staticImageData.width\n        if (!staticImageData.height || !staticImageData.width) {\n          throw new Error(\n            `[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(\n              staticImageData,\n            )}`,\n          )\n        }\n      }\n    }\n    src = typeof src === 'string' ? src : staticSrc\n\n    const widthInt = getInt(width)\n    const heightInt = getInt(height)\n    const qualityInt = getInt(quality)\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (!src) {\n        throw new Error(\n          `[@reachdigital/image]: Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`@reachdigital/image\\` component. Received: ${JSON.stringify(\n            { width, height, quality },\n          )}`,\n        )\n      }\n      if (!VALID_LAYOUT_VALUES.includes(layout)) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(\n            String,\n          ).join(',')}.`,\n        )\n      }\n      if (\n        (typeof widthInt !== 'undefined' && Number.isNaN(widthInt)) ||\n        (typeof heightInt !== 'undefined' && Number.isNaN(heightInt))\n      ) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`,\n        )\n      }\n      if (!VALID_LOADING_VALUES.includes(loading)) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(\n            String,\n          ).join(',')}.`,\n        )\n      }\n      if (placeholder === 'blur') {\n        if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n          console.warn(\n            `[@reachdigital/image]: Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`,\n          )\n        }\n        if (!blurDataURL) {\n          const VALID_BLUR_EXT = ['jpeg', 'png', 'webp'] // should match next-image-loader\n\n          throw new Error(\n            `[@reachdigital/image]: Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n          Possible solutions:\n            - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n            - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(\n              ',',\n            )}\n            - Remove the \"placeholder\" property, effectively no blur effect\n          Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`,\n          )\n        }\n      }\n    }\n\n    if (typeof widthInt === 'undefined' && typeof heightInt === 'undefined') {\n      if (layout === 'fill') {\n        // handle fill\n      } else if (process.env.NODE_ENV !== 'production') {\n        // <Image src=\"i.png\" />\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`,\n        )\n      }\n    }\n\n    loading ??= 'lazy'\n    if (src && src.startsWith('data:')) {\n      // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n      unoptimized = true\n    }\n\n    const attributes3x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 1.5,\n    })\n\n    const attributes2x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 1,\n    })\n\n    const attributes1x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 0.5,\n    })\n\n    if (layout !== 'fixed' && !style) style = {}\n    if (layout === 'responsive') style = { ...style, width: '100%', height: 'auto' }\n    if (layout === 'intrinsic') style = { ...style, width: '100%', height: 'auto', maxWidth: width }\n    if (layout === 'fill') style = { ...style, width: '100%', height: '100%' }\n\n    return (\n      <>\n        {unoptimized ? (\n          <img ref={ref} {...imgProps} src={src} width={width} height={height} style={style} />\n        ) : (\n          <picture>\n            <source media='(-webkit-min-device-pixel-ratio: 2.5)' {...attributes3x} />\n            <source media='(-webkit-min-device-pixel-ratio: 1.5)' {...attributes2x} />\n            <img\n              ref={ref}\n              {...imgProps}\n              {...attributes1x}\n              loading={loading}\n              width={width}\n              height={height}\n              style={style}\n            />\n          </picture>\n        )}\n        {loading === 'eager' && (\n          <Head>\n            <link\n              key={`__nimg-2x-${attributes1x.srcSet}${attributes1x.sizes}`}\n              rel='preload'\n              as='image'\n              media='(-webkit-min-device-pixel-ratio: 2.5)'\n              // @ts-expect-error imagesrcset is not yet in the link element type\n              imagesrcset={attributes1x.srcSet}\n              imagesizes={sizes}\n            />\n          </Head>\n        )}\n      </>\n    )\n  },\n)\nImage.displayName = 'NextPicture'\n\nexport { Image }\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../components/Image.tsx\n");
19
+
20
+ /***/ })
21
+
22
+ });
@@ -0,0 +1,22 @@
1
+ /*
2
+ * ATTENTION: An "eval-source-map" devtool has been used.
3
+ * This devtool is neither made for production nor for readable output files.
4
+ * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
5
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
6
+ * or disable the default devtool with "devtool: false".
7
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
8
+ */
9
+ self["webpackHotUpdate_N_E"]("pages/index",{
10
+
11
+ /***/ "../components/Image.tsx":
12
+ /*!*******************************!*\
13
+ !*** ../components/Image.tsx ***!
14
+ \*******************************/
15
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
16
+
17
+ "use strict";
18
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"isStaticRequire\": function() { return /* binding */ isStaticRequire; },\n/* harmony export */ \"isStaticImageData\": function() { return /* binding */ isStaticImageData; },\n/* harmony export */ \"isStaticImport\": function() { return /* binding */ isStaticImport; },\n/* harmony export */ \"getInt\": function() { return /* binding */ getInt; },\n/* harmony export */ \"Image\": function() { return /* binding */ Image; }\n/* harmony export */ });\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react/jsx-dev-runtime */ \"../../../node_modules/react/jsx-dev-runtime.js\");\n/* harmony import */ var react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties */ \"../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js\");\n/* harmony import */ var _Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/defineProperty */ \"../../../node_modules/next/node_modules/@babel/runtime/helpers/esm/defineProperty.js\");\n/* harmony import */ var _bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @bedrock-layout/use-forwarded-ref */ \"../../../node_modules/@bedrock-layout/use-forwarded-ref/lib/index.m.js\");\n/* harmony import */ var next_dist_next_server_server_image_config__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! next/dist/next-server/server/image-config */ \"../../../node_modules/next/dist/next-server/server/image-config.js\");\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! next/head */ \"../../../node_modules/next/head.js\");\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(next_head__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! react */ \"../../../node_modules/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../config/config */ \"../config/config.ts\");\n/* module decorator */ module = __webpack_require__.hmd(module);\n\n\n\n\n\nvar _jsxFileName = \"/Users/paulhachmang/Sites/reachdigital-next/packages/image/components/Image.tsx\",\n _s = $RefreshSig$();\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_2__.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\n/* eslint-disable prefer-const */\n\n/* eslint-disable no-param-reassign */\n\n/* eslint-disable @next/next/no-img-element */\n\n/* eslint-disable jsx-a11y/alt-text */\n\n\n\n\n\n\nif (false) {}\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined];\nconst loaders = new Map([['imgix', _config_config__WEBPACK_IMPORTED_MODULE_6__.imgixLoader], ['cloudinary', _config_config__WEBPACK_IMPORTED_MODULE_6__.cloudinaryLoader], ['akamai', _config_config__WEBPACK_IMPORTED_MODULE_6__.akamaiLoader], ['default', _config_config__WEBPACK_IMPORTED_MODULE_6__.defaultLoader]]);\nconst VALID_LAYOUT_VALUES = ['fill', 'responsive', 'intrinsic', 'fixed'];\nfunction isStaticRequire(src) {\n return src.default !== undefined;\n}\nfunction isStaticImageData(src) {\n return src.src !== undefined;\n}\nfunction isStaticImport(src) {\n return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src));\n} // sort smallest to largest\n\nconst allSizes = [..._config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes, ..._config_config__WEBPACK_IMPORTED_MODULE_6__.configImageSizes];\n_config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes.sort((a, b) => a - b);\nallSizes.sort((a, b) => a - b);\n\nfunction getWidths(width, layout, sizes = '', scale) {\n if (sizes && layout === 'fill' || layout === 'responsive') {\n // Find all the \"vw\" percent sizes used in the sizes prop\n const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g;\n const percentSizes = []; // eslint-disable-next-line no-cond-assign\n\n for (let match; match = viewportWidthRe.exec(sizes); match) {\n var _match;\n\n percentSizes.push(parseInt((_match = match) === null || _match === void 0 ? void 0 : _match[2], 10));\n }\n\n if (percentSizes.length) {\n const smallestRatio = Math.min(...percentSizes) * 0.01;\n return {\n widths: allSizes.filter(s => s >= _config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes[0] * smallestRatio),\n kind: 'w'\n };\n } // Find all the \"px\" sizes used in the sizes prop\n\n\n const pxWidthRe = /(^|\\s)(1?\\d+)px/g;\n const pxSizes = []; // eslint-disable-next-line no-cond-assign\n\n for (let match; match = pxWidthRe.exec(sizes); match) {\n var _match2;\n\n pxSizes.push(parseInt((_match2 = match) === null || _match2 === void 0 ? void 0 : _match2[2], 10));\n }\n\n if (pxSizes.length) {\n return {\n widths: pxSizes.map(pxSize => {\n var _allSizes$filter, _allSizes$filter2;\n\n const scaled = (_allSizes$filter = allSizes.filter(s => s * scale > pxSize)) === null || _allSizes$filter === void 0 ? void 0 : _allSizes$filter[0];\n const dpr2 = (_allSizes$filter2 = allSizes.filter(s => s > pxSize)) === null || _allSizes$filter2 === void 0 ? void 0 : _allSizes$filter2[0];\n return scale > 1 ? Math.max(scaled, dpr2) : Math.min(scaled, dpr2);\n }),\n kind: 'w'\n };\n }\n\n return {\n widths: allSizes,\n kind: 'w'\n };\n }\n\n if (typeof width !== 'number' || layout === 'fill') {\n return {\n widths: _config_config__WEBPACK_IMPORTED_MODULE_6__.configDeviceSizes,\n kind: 'w'\n };\n }\n\n const widths = [...new Set( // > This means that most OLED screens that say they are 3x resolution,\n // > are actually 3x in the green color, but only 1.5x in the red and\n // > blue colors. Showing a 3x resolution image in the app vs a 2x\n // > resolution image will be visually the same, though the 3x image\n // > takes significantly more data. Even true 3x resolution screens are\n // > wasteful as the human eye cannot see that level of detail without\n // > something like a magnifying glass.\n // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n [width, width * 2\n /* , width * 3*/\n ].map(w => allSizes.find(p => p >= w) || allSizes[allSizes.length - 1]))];\n return {\n widths,\n kind: 'x'\n };\n}\n\nfunction generateSourceAttrs({\n src,\n layout,\n width,\n quality = 44,\n sizes,\n loader,\n scale\n}) {\n const {\n widths,\n kind\n } = getWidths(width, layout, sizes, scale);\n return {\n sizes: !sizes && kind === 'w' ? `50vw` : sizes,\n srcSet: widths.map((w, i) => `${loader({\n src,\n quality,\n width: w\n })} ${kind === 'w' ? Math.round(w * scale) : i + 1}${kind}`).join(', ')\n };\n}\n\nfunction getInt(x) {\n if (typeof x === 'number') {\n return x;\n }\n\n if (typeof x === 'string') {\n return parseInt(x, 10);\n }\n\n return undefined;\n}\n\nfunction defaultImageLoader(loaderProps) {\n const load = loaders.get(_config_config__WEBPACK_IMPORTED_MODULE_6__.configLoader);\n\n if (load) {\n return load(_objectSpread({\n root: _config_config__WEBPACK_IMPORTED_MODULE_6__.configPath\n }, loaderProps));\n }\n\n throw new Error(`[@reachdigital/image]: Unknown \"loader\" found in \"next.config.js\". Expected: ${next_dist_next_server_server_image_config__WEBPACK_IMPORTED_MODULE_3__.VALID_LOADERS.join(', ')}. Received: ${_config_config__WEBPACK_IMPORTED_MODULE_6__.configLoader}`);\n} // See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\n\n\nfunction removePlaceholder(img, placeholder) {\n if (placeholder === 'blur' && img) {\n const handleLoad = () => {\n if (!img.src.startsWith('data:')) {\n const p = 'decode' in img ? img.decode() : Promise.resolve(); // eslint-disable-next-line @typescript-eslint/no-floating-promises\n\n p.catch(() => {}).then(() => {\n img.style.filter = 'none';\n img.style.backgroundSize = 'none';\n img.style.backgroundImage = 'none';\n });\n }\n };\n\n if (img.complete) {\n // If the real image fails to load, this will still remove the placeholder.\n // This is the desired behavior for now, and will be revisited when error\n // handling is worked on for the image component itself.\n handleLoad();\n } else {\n img.onload = handleLoad;\n }\n }\n}\n/** Checks whether an image is currently in the viewport */\n\n\nfunction isInViewport(elem) {\n const {\n top,\n right,\n bottom,\n left\n } = elem.getBoundingClientRect();\n return bottom >= 0 && right >= 0 && top <= window.innerHeight && left <= window.innerWidth;\n}\n\nfunction isSizesRecord(sizes) {\n return typeof sizes === 'object';\n}\n\nfunction sizesEntries(sizes) {\n if (isSizesRecord(sizes)) {\n return Object.entries(sizes).map(([breakpoint, size]) => [Number(breakpoint), size]).sort(([sizeA], [sizeB]) => sizeB - sizeA);\n }\n\n return [[0, sizes]];\n}\n\nfunction generateSizesString(sizes) {\n return sizesEntries(sizes).map(([breakpoint, size]) => {\n if (breakpoint === 0) return size;\n return `(min-width: ${breakpoint}px) ${size}`;\n }).join(', ');\n}\n/** Since we're handling stuff ourselves we omit some stuff */\n\n\nconst Image = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_5___default().forwardRef(_c = _s((_ref, forwardedRef) => {\n var _generateSizesString, _loading;\n\n _s();\n\n let {\n src,\n sizes: sizesOrig,\n unoptimized = false,\n loading,\n layout = 'responsive',\n quality,\n width,\n height,\n style,\n loader = defaultImageLoader,\n placeholder = 'empty',\n blurDataURL\n } = _ref,\n imgProps = (0,_Users_paulhachmang_Sites_reachdigital_next_node_modules_next_node_modules_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__.default)(_ref, [\"src\", \"sizes\", \"unoptimized\", \"loading\", \"layout\", \"quality\", \"width\", \"height\", \"style\", \"loader\", \"placeholder\", \"blurDataURL\"]);\n\n const ref = (0,_bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__.default)(forwardedRef);\n const sizes = (_generateSizesString = generateSizesString(layout === 'fixed' && width && !sizesOrig ? `${width}px` : sizesOrig)) !== null && _generateSizesString !== void 0 ? _generateSizesString : '50vw'; // If no responsive sizes are given, we're defaulting to 50vw on mobile\n // const [sizes, setSizes] = useState(toSizesString(sizesOrig) ?? `50vw`)\n\n (0,react__WEBPACK_IMPORTED_MODULE_5__.useEffect)(() => {\n if (!ref.current || false) return () => {}; // Warn the user when he isn't providing sizes and how to proceed\n\n const ro = new ResizeObserver(([entry]) => {\n var _sizesEntries$find;\n\n const currentvw = entry.contentRect.width;\n let ratio;\n let msg = '';\n const [breakpoint, size] = (_sizesEntries$find = sizesEntries(sizesOrig).find(([s]) => s === 0 ? true : window.matchMedia(`(min-width: ${s})`))) !== null && _sizesEntries$find !== void 0 ? _sizesEntries$find : [0, '100vw'];\n\n if (size) {\n const el = document.createElement('div');\n el.setAttribute('style', `width: ${size}`);\n document.body.appendChild(el);\n const measuredWidth = el.getBoundingClientRect().width; // el.remove()\n\n ratio = measuredWidth ** 2 / currentvw ** 2;\n msg += `Image has \"sizes\" property set, but size 'min-width(${breakpoint}px) ${size}' is incorrect.`;\n } else {\n msg += `Image has no \"sizes\" property set.`;\n ratio = (window.innerWidth * 0.5) ** 2 / currentvw ** 2;\n }\n\n const round = nr => Math.round(nr * 100) / 100;\n\n if (ratio > 1.2) {\n console.warn(`[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(ratio)}x too many pixels`, entry.target);\n } else if (ratio < 0.8) {\n console.warn(`[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(1 / ratio)}x too few pixels`, entry.target);\n }\n });\n ro.observe(ref.current);\n return () => ro.disconnect();\n }, [ref, sizesOrig, src]);\n let staticSrc = '';\n\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src;\n\n if (!staticImageData.src) {\n throw new Error(`[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(staticImageData)}`);\n }\n\n blurDataURL = blurDataURL || staticImageData.blurDataURL;\n staticSrc = staticImageData.src;\n\n if (!layout || layout !== 'fill') {\n height = height || staticImageData.height;\n width = width || staticImageData.width;\n\n if (!staticImageData.height || !staticImageData.width) {\n throw new Error(`[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(staticImageData)}`);\n }\n }\n }\n\n src = typeof src === 'string' ? src : staticSrc;\n const widthInt = getInt(width);\n const heightInt = getInt(height);\n const qualityInt = getInt(quality);\n\n if (true) {\n if (!src) {\n throw new Error(`[@reachdigital/image]: Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`@reachdigital/image\\` component. Received: ${JSON.stringify({\n width,\n height,\n quality\n })}`);\n }\n\n if (!VALID_LAYOUT_VALUES.includes(layout)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(String).join(',')}.`);\n }\n\n if (typeof widthInt !== 'undefined' && Number.isNaN(widthInt) || typeof heightInt !== 'undefined' && Number.isNaN(heightInt)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`);\n }\n\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(String).join(',')}.`);\n }\n\n if (placeholder === 'blur') {\n if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n console.warn(`[@reachdigital/image]: Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`);\n }\n\n if (!blurDataURL) {\n const VALID_BLUR_EXT = ['jpeg', 'png', 'webp']; // should match next-image-loader\n\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n Possible solutions:\n - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(',')}\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`);\n }\n }\n }\n\n if (typeof widthInt === 'undefined' && typeof heightInt === 'undefined') {\n if (layout === 'fill') {// handle fill\n } else if (true) {\n // <Image src=\"i.png\" />\n throw new Error(`[@reachdigital/image]: Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`);\n }\n }\n\n (_loading = loading) !== null && _loading !== void 0 ? _loading : loading = 'lazy';\n\n if (src && src.startsWith('data:')) {\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n unoptimized = true;\n }\n\n const attributes3x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 1.5\n });\n const attributes2x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 1\n });\n const attributes1x = generateSourceAttrs({\n src,\n layout: layout,\n loader,\n quality: qualityInt,\n sizes,\n width: widthInt,\n scale: 0.5\n });\n if (layout !== 'fixed' && !style) style = {};\n if (layout === 'responsive') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: 'auto'\n });\n if (layout === 'intrinsic') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: 'auto',\n maxWidth: width\n });\n if (layout === 'fill') style = _objectSpread(_objectSpread({}, style), {}, {\n width: '100%',\n height: '100%'\n });\n return /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.Fragment, {\n children: [unoptimized ? /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"img\", _objectSpread(_objectSpread({\n ref: ref\n }, imgProps), {}, {\n src: src,\n width: width,\n height: height,\n style: style\n }), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 608,\n columnNumber: 11\n }, undefined) : /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"picture\", {\n children: [/*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"source\", _objectSpread({\n media: \"(-webkit-min-device-pixel-ratio: 2.5)\"\n }, attributes3x), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 611,\n columnNumber: 13\n }, undefined), /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"source\", _objectSpread({\n media: \"(-webkit-min-device-pixel-ratio: 1.5)\"\n }, attributes2x), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 612,\n columnNumber: 13\n }, undefined), /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"img\", _objectSpread(_objectSpread(_objectSpread({\n ref: ref\n }, imgProps), attributes1x), {}, {\n loading: loading,\n width: width,\n height: height,\n style: style\n }), void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 613,\n columnNumber: 13\n }, undefined)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 610,\n columnNumber: 11\n }, undefined), loading === 'eager' && /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)((next_head__WEBPACK_IMPORTED_MODULE_4___default()), {\n children: /*#__PURE__*/(0,react_jsx_dev_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxDEV)(\"link\", {\n rel: \"preload\",\n as: \"image\",\n media: \"(-webkit-min-device-pixel-ratio: 2.5)\" // @ts-expect-error imagesrcset is not yet in the link element type\n ,\n imagesrcset: attributes1x.srcSet,\n imagesizes: sizes\n }, `__nimg-2x-${attributes1x.srcSet}${attributes1x.sizes}`, false, {\n fileName: _jsxFileName,\n lineNumber: 626,\n columnNumber: 13\n }, undefined)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 625,\n columnNumber: 11\n }, undefined)]\n }, void 0, true);\n}, \"uc1ywpQv+s/tGng4xj/L6VVOIq8=\", false, function () {\n return [_bedrock_layout_use_forwarded_ref__WEBPACK_IMPORTED_MODULE_7__.default];\n}));\n_c2 = Image;\nImage.displayName = 'NextPicture';\n\n\nvar _c, _c2;\n\n$RefreshReg$(_c, \"Image$React.forwardRef\");\n$RefreshReg$(_c2, \"Image\");\n\n;\n var _a, _b;\n // Legacy CSS implementations will `eval` browser code in a Node.js context\n // to extract CSS. For backwards compatibility, we need to check we're in a\n // browser context before continuing.\n if (typeof self !== 'undefined' &&\n // AMP / No-JS mode does not inject these helpers:\n '$RefreshHelpers$' in self) {\n var currentExports = module.__proto__.exports;\n var prevExports = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevExports) !== null && _b !== void 0 ? _b : null;\n // This cannot happen in MainTemplate because the exports mismatch between\n // templating and execution.\n self.$RefreshHelpers$.registerExportsForReactRefresh(currentExports, module.id);\n // A module can be accepted automatically based on its exports, e.g. when\n // it is a Refresh Boundary.\n if (self.$RefreshHelpers$.isReactRefreshBoundary(currentExports)) {\n // Save the previous exports on update so we can compare the boundary\n // signatures.\n module.hot.dispose(function (data) {\n data.prevExports = currentExports;\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n module.hot.accept();\n // This field is set when the previous version of this module was a\n // Refresh Boundary, letting us know we need to check for invalidation or\n // enqueue an update.\n if (prevExports !== null) {\n // A boundary can become ineligible if its exports are incompatible\n // with the previous exports.\n //\n // For example, if you add/remove/change exports, we'll want to\n // re-execute the importing modules, and force those components to\n // re-render. Similarly, if you convert a class component to a\n // function, we want to invalidate the boundary.\n if (self.$RefreshHelpers$.shouldInvalidateReactRefreshBoundary(prevExports, currentExports)) {\n module.hot.invalidate();\n }\n else {\n self.$RefreshHelpers$.scheduleUpdate();\n }\n }\n }\n else {\n // Since we just executed the code for the module, it's possible that the\n // new exports made it ineligible for being a boundary.\n // We only care about the case when we were _previously_ a boundary,\n // because we already accepted this update (accidental side effect).\n var isNoLongerABoundary = prevExports !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://_N_E/../components/Image.tsx?2b6d"],"names":["VALID_LOADING_VALUES","undefined","loaders","Map","imgixLoader","cloudinaryLoader","akamaiLoader","defaultLoader","VALID_LAYOUT_VALUES","isStaticRequire","src","default","isStaticImageData","isStaticImport","allSizes","configDeviceSizes","configImageSizes","a","b","sort","getWidths","width","layout","sizes","scale","viewportWidthRe","percentSizes","match","exec","push","parseInt","length","smallestRatio","Math","min","widths","filter","s","kind","pxWidthRe","pxSizes","map","pxSize","scaled","dpr2","max","Set","w","find","p","generateSourceAttrs","quality","loader","srcSet","i","round","join","getInt","x","defaultImageLoader","loaderProps","load","get","configLoader","root","configPath","Error","VALID_LOADERS","removePlaceholder","img","placeholder","handleLoad","startsWith","decode","Promise","resolve","catch","then","style","backgroundSize","backgroundImage","complete","onload","isInViewport","elem","top","right","bottom","left","getBoundingClientRect","window","innerHeight","innerWidth","isSizesRecord","sizesEntries","Object","entries","breakpoint","size","Number","sizeA","sizeB","generateSizesString","Image","React","forwardedRef","sizesOrig","unoptimized","loading","height","blurDataURL","imgProps","ref","useForwardedRef","useEffect","current","ro","ResizeObserver","entry","currentvw","contentRect","ratio","msg","matchMedia","el","document","createElement","setAttribute","body","appendChild","measuredWidth","nr","console","warn","target","observe","disconnect","staticSrc","staticImageData","JSON","stringify","widthInt","heightInt","qualityInt","includes","String","isNaN","VALID_BLUR_EXT","attributes3x","attributes2x","attributes1x","maxWidth","displayName"],"mappings":"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","file":"../components/Image.tsx.js","sourcesContent":["/* eslint-disable prefer-const */\n/* eslint-disable no-param-reassign */\n/* eslint-disable @next/next/no-img-element */\n/* eslint-disable jsx-a11y/alt-text */\nimport useForwardedRef from '@bedrock-layout/use-forwarded-ref'\nimport { LoaderValue, VALID_LOADERS } from 'next/dist/next-server/server/image-config'\nimport Head from 'next/head'\nimport type { ImageLoaderProps, ImageLoader } from 'next/image'\nimport React, { useEffect, useState } from 'react'\nimport useResizeObserver from 'use-resize-observer'\nimport {\n  akamaiLoader,\n  cloudinaryLoader,\n  configDeviceSizes,\n  configImageSizes,\n  configLoader,\n  configPath,\n  DefaultImageLoaderProps,\n  defaultLoader,\n  imgixLoader,\n} from '../config/config'\nimport useConnectionType from '../hooks/useConnectionType'\n\nif (typeof window === 'undefined') {\n  // eslint-disable-next-line no-underscore-dangle\n  global.__NEXT_IMAGE_IMPORTED = true\n}\n\nexport type { ImageLoaderProps, ImageLoader }\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined] as const\ntype LoadingValue = typeof VALID_LOADING_VALUES[number]\n\nconst loaders = new Map<LoaderValue, (props: DefaultImageLoaderProps) => string>([\n  ['imgix', imgixLoader],\n  ['cloudinary', cloudinaryLoader],\n  ['akamai', akamaiLoader],\n  ['default', defaultLoader],\n])\n\nconst VALID_LAYOUT_VALUES = ['fill', 'responsive', 'intrinsic', 'fixed'] as const\ntype LayoutValue = 'fill' | 'fixed' | 'intrinsic' | 'responsive' | undefined\n\ntype PlaceholderValue = 'blur' | 'empty'\n\ntype ImgElementStyle = NonNullable<JSX.IntrinsicElements['img']['style']>\n\ninterface StaticImageData {\n  src: string\n  height: number\n  width: number\n  blurDataURL?: string\n}\n\ninterface StaticRequire {\n  default: StaticImageData\n}\n\ntype StaticImport = StaticRequire | StaticImageData\n\nexport function isStaticRequire(src: StaticRequire | StaticImageData): src is StaticRequire {\n  return (src as StaticRequire).default !== undefined\n}\n\nexport function isStaticImageData(src: StaticRequire | StaticImageData): src is StaticImageData {\n  return (src as StaticImageData).src !== undefined\n}\n\nexport function isStaticImport(src: string | StaticImport): src is StaticImport {\n  return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src))\n}\n\n// sort smallest to largest\nconst allSizes = [...configDeviceSizes, ...configImageSizes]\nconfigDeviceSizes.sort((a, b) => a - b)\nallSizes.sort((a, b) => a - b)\n\nfunction getWidths(\n  width: number | undefined,\n  layout: LayoutValue,\n  sizes = '',\n  scale: number,\n): { widths: number[]; kind: 'w' | 'x' } {\n  if ((sizes && layout === 'fill') || layout === 'responsive') {\n    // Find all the \"vw\" percent sizes used in the sizes prop\n    const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g\n    const percentSizes: number[] = []\n    // eslint-disable-next-line no-cond-assign\n    for (let match: string[] | null; (match = viewportWidthRe.exec(sizes)); match) {\n      percentSizes.push(parseInt(match?.[2], 10))\n    }\n    if (percentSizes.length) {\n      const smallestRatio = Math.min(...percentSizes) * 0.01\n\n      return {\n        widths: allSizes.filter((s) => s >= configDeviceSizes[0] * smallestRatio),\n        kind: 'w',\n      }\n    }\n\n    // Find all the \"px\" sizes used in the sizes prop\n    const pxWidthRe = /(^|\\s)(1?\\d+)px/g\n    const pxSizes: number[] = []\n    // eslint-disable-next-line no-cond-assign\n    for (let match: string[] | null; (match = pxWidthRe.exec(sizes)); match) {\n      pxSizes.push(parseInt(match?.[2], 10))\n    }\n\n    if (pxSizes.length) {\n      return {\n        widths: pxSizes.map((pxSize) => {\n          const scaled = allSizes.filter((s) => s * scale > pxSize)?.[0]\n          const dpr2 = allSizes.filter((s) => s > pxSize)?.[0]\n          return scale > 1 ? Math.max(scaled, dpr2) : Math.min(scaled, dpr2)\n        }),\n        kind: 'w',\n      }\n    }\n\n    return { widths: allSizes, kind: 'w' }\n  }\n  if (typeof width !== 'number' || layout === 'fill') {\n    return { widths: configDeviceSizes, kind: 'w' }\n  }\n\n  const widths = [\n    ...new Set(\n      // > This means that most OLED screens that say they are 3x resolution,\n      // > are actually 3x in the green color, but only 1.5x in the red and\n      // > blue colors. Showing a 3x resolution image in the app vs a 2x\n      // > resolution image will be visually the same, though the 3x image\n      // > takes significantly more data. Even true 3x resolution screens are\n      // > wasteful as the human eye cannot see that level of detail without\n      // > something like a magnifying glass.\n      // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n      [width, width * 2 /* , width * 3*/].map(\n        (w) => allSizes.find((p) => p >= w) || allSizes[allSizes.length - 1],\n      ),\n    ),\n  ]\n  return { widths, kind: 'x' }\n}\n\ntype GenImgAttrsData = {\n  src: string\n  layout: LayoutValue\n  loader: ImageLoader\n  width?: number\n  quality?: number\n  sizes?: string\n  scale: number\n}\n\ntype GenImgAttrsResult = {\n  srcSet: string | undefined\n  sizes: string | undefined\n}\n\nfunction generateSourceAttrs({\n  src,\n  layout,\n  width,\n  quality = 44,\n  sizes,\n  loader,\n  scale,\n}: GenImgAttrsData): GenImgAttrsResult {\n  const { widths, kind } = getWidths(width, layout, sizes, scale)\n\n  return {\n    sizes: !sizes && kind === 'w' ? `50vw` : sizes,\n    srcSet: widths\n      .map(\n        (w, i) =>\n          `${loader({ src, quality, width: w })} ${\n            kind === 'w' ? Math.round(w * scale) : i + 1\n          }${kind}`,\n      )\n      .join(', '),\n  }\n}\n\nexport function getInt(x: unknown): number | undefined {\n  if (typeof x === 'number') {\n    return x\n  }\n  if (typeof x === 'string') {\n    return parseInt(x, 10)\n  }\n  return undefined\n}\n\nfunction defaultImageLoader(loaderProps: ImageLoaderProps) {\n  const load = loaders.get(configLoader)\n  if (load) {\n    return load({ root: configPath, ...loaderProps })\n  }\n  throw new Error(\n    `[@reachdigital/image]: Unknown \"loader\" found in \"next.config.js\". Expected: ${VALID_LOADERS.join(\n      ', ',\n    )}. Received: ${configLoader}`,\n  )\n}\n\n// See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\nfunction removePlaceholder(img: HTMLImageElement | null, placeholder: PlaceholderValue) {\n  if (placeholder === 'blur' && img) {\n    const handleLoad = () => {\n      if (!img.src.startsWith('data:')) {\n        const p = 'decode' in img ? img.decode() : Promise.resolve()\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        p.catch(() => {}).then(() => {\n          img.style.filter = 'none'\n          img.style.backgroundSize = 'none'\n          img.style.backgroundImage = 'none'\n        })\n      }\n    }\n    if (img.complete) {\n      // If the real image fails to load, this will still remove the placeholder.\n      // This is the desired behavior for now, and will be revisited when error\n      // handling is worked on for the image component itself.\n      handleLoad()\n    } else {\n      img.onload = handleLoad\n    }\n  }\n}\n\n/** Checks whether an image is currently in the viewport */\nfunction isInViewport(elem: HTMLImageElement): boolean {\n  const { top, right, bottom, left } = elem.getBoundingClientRect()\n  return bottom >= 0 && right >= 0 && top <= window.innerHeight && left <= window.innerWidth\n}\n\ntype SizesString = `${number}vw` | `${number}px`\ntype SizesRecord = Record<number, SizesString>\ntype Sizes = SizesString | SizesRecord | undefined\n\nfunction isSizesRecord(sizes?: Sizes): sizes is SizesRecord {\n  return typeof sizes === 'object'\n}\n\nfunction sizesEntries(sizes: Sizes): (readonly [number, SizesString | undefined])[] {\n  if (isSizesRecord(sizes)) {\n    return Object.entries(sizes)\n      .map(([breakpoint, size]) => [Number(breakpoint), size] as const)\n      .sort(([sizeA], [sizeB]) => sizeB - sizeA)\n  }\n  return [[0, sizes] as const]\n}\n\nfunction generateSizesString(sizes?: Sizes) {\n  return sizesEntries(sizes)\n    .map(([breakpoint, size]) => {\n      if (breakpoint === 0) return size\n      return `(min-width: ${breakpoint}px) ${size}`\n    })\n    .join(', ')\n}\n\n/** Since we're handling stuff ourselves we omit some stuff */\ntype IntrisincImage = Omit<\n  JSX.IntrinsicElements['img'],\n  'src' | 'srcSet' | 'ref' | 'width' | 'height' | 'loading' | 'sizes' | 'width' | 'height'\n> & { loading?: LoadingValue }\n\nexport type BaseImageProps = IntrisincImage & {\n  loader?: ImageLoader\n  quality?: number | string\n  unoptimized?: boolean\n\n  /**\n   * Possible values:\n   *\n   * - `fixed`: the image dimensions will not change as the viewport changes (no responsiveness)\n   *   similar to the native img element.\n   * - `intrinsic`: the image will scale the dimensions down for smaller viewports but maintain the\n   *   original dimensions (the width and height given) for larger viewports.\n   * - `responsive`: the image will scale the dimensions down for smaller viewports and scale up for\n   *   larger viewports.\n   */\n  layout?: LayoutValue\n\n  /** Size the image is rendered on mobile */\n  sizes?: SizesString | SizesRecord\n}\n\n/**\n * When `fixed`, the image dimensions will not change as the viewport changes (no responsiveness)\n * similar to the native img element.\n *\n * ```tsx\n * <img width={width} height={height} />\n * ```\n *\n * Use case: When you want to render the image at the given width/height and not change based on browser size.\n */\ntype LayoutTypeNative = {\n  layout?: 'fixed'\n  /**\n   * The width and the height values are the values used to calculate the aspect ratio om the image\n   * and reserve space in the browser.\n   *\n   * With layout=fixed and no styling the image is rendered at the width and height given.\n   */\n  width: number\n  height: number\n}\n\n/**\n * When `intrinsic`, the image will scale the dimensions down for smaller viewports but maintain the\n * original dimensions (the width and height given) for larger viewports.\n *\n * ```tsx\n * <img style={{ width: '100%', height: 'auto' maxWidth: `${width}px` }}\n * ```\n *\n * Use case: When you want to render an image but don't scale it up.\n */\ntype LayoutTypeIntrinsic = {\n  layout?: 'intrinsic'\n\n  width: number\n  height: number\n\n  style?: Omit<ImgElementStyle, 'width' | 'height' | 'maxWidth'>\n}\n\n/**\n * When `responsive`, the image will scale the dimensions down for smaller viewports and scale up\n * for larger viewports.\n *\n * ```tsx\n * <img style={{ width: '100%', height: 'auto' maxWidth: ${width} }}\n * ```\n *\n * Use case: When you want the image to fill it's parent container in width\n */\ntype LayoutTypeResponsive = {\n  layout?: 'responsive'\n\n  width: number\n  height: number\n\n  style?: Omit<ImgElementStyle, 'width' | 'height'>\n}\n\n/**\n * When `fill`, the image will stretch both width and height to the dimensions of the parent\n * element, paired with the objectFit property.\n *\n * Since the width/height isn't required to render the page we can omit it.\n *\n * ```tsx\n * <img width={width} height={height} style={{ width: '100%', height: '100%' }}\n * ```\n *\n * Use case: When you have a predefined area set to render an image\n */\ntype LayoutTypeFill = {\n  layout?: 'fill'\n\n  width?: never\n  height?: never\n\n  // objectFit: ImgElementStyle['objectFit']\n  style?: Omit<ImgElementStyle, 'width' | 'height'>\n}\n\nexport type StringImageProps = {\n  src: string\n} & (LayoutTypeFill | LayoutTypeResponsive | LayoutTypeNative | LayoutTypeIntrinsic) &\n  (\n    | { placeholder?: Exclude<PlaceholderValue, 'blur'>; blurDataURL?: never }\n    | { placeholder: 'blur'; blurDataURL: string }\n  )\n\nexport type ObjectImageProps = {\n  src: StaticImport\n  width?: number\n  height?: number | string\n  layout?: LayoutValue\n  placeholder?: PlaceholderValue\n  blurDataURL?: never\n}\n\nexport type ImageProps = BaseImageProps & (StringImageProps | ObjectImageProps)\n\nexport type StringImage = BaseImageProps & StringImageProps\nexport type ObjectImage = BaseImageProps & ObjectImageProps\n\nconst Image = React.forwardRef<HTMLImageElement, ImageProps>(\n  (\n    {\n      src,\n      sizes: sizesOrig,\n      unoptimized = false,\n      loading,\n      layout = 'responsive',\n      quality,\n      width,\n      height,\n      style,\n      loader = defaultImageLoader,\n      placeholder = 'empty',\n      blurDataURL,\n      ...imgProps\n    },\n    forwardedRef,\n  ) => {\n    const ref = useForwardedRef(forwardedRef)\n\n    const sizes =\n      generateSizesString(layout === 'fixed' && width && !sizesOrig ? `${width}px` : sizesOrig) ??\n      '50vw'\n\n    // If no responsive sizes are given, we're defaulting to 50vw on mobile\n    // const [sizes, setSizes] = useState(toSizesString(sizesOrig) ?? `50vw`)\n\n    useEffect(() => {\n      if (!ref.current || process.env.NODE_ENV === 'production') return () => {}\n\n      // Warn the user when he isn't providing sizes and how to proceed\n      const ro = new ResizeObserver(([entry]) => {\n        const currentvw = entry.contentRect.width\n\n        let ratio: number\n\n        let msg = ''\n        const [breakpoint, size] = sizesEntries(sizesOrig).find(([s]) =>\n          s === 0 ? true : window.matchMedia(`(min-width: ${s})`),\n        ) ?? [0, '100vw']\n        if (size) {\n          const el = document.createElement('div')\n          el.setAttribute('style', `width: ${size}`)\n          document.body.appendChild(el)\n          const measuredWidth = el.getBoundingClientRect().width\n          // el.remove()\n          ratio = measuredWidth ** 2 / currentvw ** 2\n          msg += `Image has \"sizes\" property set, but size 'min-width(${breakpoint}px) ${size}' is incorrect.`\n        } else {\n          msg += `Image has no \"sizes\" property set.`\n          ratio = (window.innerWidth * 0.5) ** 2 / currentvw ** 2\n        }\n\n        const round = (nr: number) => Math.round(nr * 100) / 100\n        if (ratio > 1.2) {\n          console.warn(\n            `[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(\n              ratio,\n            )}x too many pixels`,\n            entry.target,\n          )\n        } else if (ratio < 0.8) {\n          console.warn(\n            `[@reachdigital/image]: ${msg} Currently downloading an image that has ${round(\n              1 / ratio,\n            )}x too few pixels`,\n            entry.target,\n          )\n        }\n      })\n      ro.observe(ref.current)\n\n      return () => ro.disconnect()\n    }, [ref, sizesOrig, src])\n\n    let staticSrc = ''\n    if (isStaticImport(src)) {\n      const staticImageData = isStaticRequire(src) ? src.default : src\n      if (!staticImageData.src) {\n        throw new Error(\n          `[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(\n            staticImageData,\n          )}`,\n        )\n      }\n      blurDataURL = blurDataURL || staticImageData.blurDataURL\n      staticSrc = staticImageData.src\n      if (!layout || layout !== 'fill') {\n        height = height || staticImageData.height\n        width = width || staticImageData.width\n        if (!staticImageData.height || !staticImageData.width) {\n          throw new Error(\n            `[@reachdigital/image]: An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(\n              staticImageData,\n            )}`,\n          )\n        }\n      }\n    }\n    src = typeof src === 'string' ? src : staticSrc\n\n    const widthInt = getInt(width)\n    const heightInt = getInt(height)\n    const qualityInt = getInt(quality)\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (!src) {\n        throw new Error(\n          `[@reachdigital/image]: Image is missing required \"src\" property. Make sure you pass \"src\" in props to the \\`@reachdigital/image\\` component. Received: ${JSON.stringify(\n            { width, height, quality },\n          )}`,\n        )\n      }\n      if (!VALID_LAYOUT_VALUES.includes(layout)) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"layout\" property. Provided \"${layout}\" should be one of ${VALID_LAYOUT_VALUES.map(\n            String,\n          ).join(',')}.`,\n        )\n      }\n      if (\n        (typeof widthInt !== 'undefined' && Number.isNaN(widthInt)) ||\n        (typeof heightInt !== 'undefined' && Number.isNaN(heightInt))\n      ) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"width\" or \"height\" property. These should be numeric values.`,\n        )\n      }\n      if (!VALID_LOADING_VALUES.includes(loading)) {\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(\n            String,\n          ).join(',')}.`,\n        )\n      }\n      if (placeholder === 'blur') {\n        if (layout !== 'fill' && (widthInt || 0) * (heightInt || 0) < 1600) {\n          console.warn(\n            `[@reachdigital/image]: Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`,\n          )\n        }\n        if (!blurDataURL) {\n          const VALID_BLUR_EXT = ['jpeg', 'png', 'webp'] // should match next-image-loader\n\n          throw new Error(\n            `[@reachdigital/image]: Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n          Possible solutions:\n            - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n            - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(\n              ',',\n            )}\n            - Remove the \"placeholder\" property, effectively no blur effect\n          Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`,\n          )\n        }\n      }\n    }\n\n    if (typeof widthInt === 'undefined' && typeof heightInt === 'undefined') {\n      if (layout === 'fill') {\n        // handle fill\n      } else if (process.env.NODE_ENV !== 'production') {\n        // <Image src=\"i.png\" />\n        throw new Error(\n          `[@reachdigital/image]: Image with src \"${src}\" must use \"width\" and \"height\" properties or \"layout='fill'\" property.`,\n        )\n      }\n    }\n\n    loading ??= 'lazy'\n    if (src && src.startsWith('data:')) {\n      // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n      unoptimized = true\n    }\n\n    const attributes3x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 1.5,\n    })\n\n    const attributes2x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 1,\n    })\n\n    const attributes1x = generateSourceAttrs({\n      src,\n      layout: layout as LayoutValue,\n      loader,\n      quality: qualityInt,\n      sizes,\n      width: widthInt,\n      scale: 0.5,\n    })\n\n    if (layout !== 'fixed' && !style) style = {}\n    if (layout === 'responsive') style = { ...style, width: '100%', height: 'auto' }\n    if (layout === 'intrinsic') style = { ...style, width: '100%', height: 'auto', maxWidth: width }\n    if (layout === 'fill') style = { ...style, width: '100%', height: '100%' }\n\n    return (\n      <>\n        {unoptimized ? (\n          <img ref={ref} {...imgProps} src={src} width={width} height={height} style={style} />\n        ) : (\n          <picture>\n            <source media='(-webkit-min-device-pixel-ratio: 2.5)' {...attributes3x} />\n            <source media='(-webkit-min-device-pixel-ratio: 1.5)' {...attributes2x} />\n            <img\n              ref={ref}\n              {...imgProps}\n              {...attributes1x}\n              loading={loading}\n              width={width}\n              height={height}\n              style={style}\n            />\n          </picture>\n        )}\n        {loading === 'eager' && (\n          <Head>\n            <link\n              key={`__nimg-2x-${attributes1x.srcSet}${attributes1x.sizes}`}\n              rel='preload'\n              as='image'\n              media='(-webkit-min-device-pixel-ratio: 2.5)'\n              // @ts-expect-error imagesrcset is not yet in the link element type\n              imagesrcset={attributes1x.srcSet}\n              imagesizes={sizes}\n            />\n          </Head>\n        )}\n      </>\n    )\n  },\n)\nImage.displayName = 'NextPicture'\n\nexport { Image }\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../components/Image.tsx\n");
19
+
20
+ /***/ })
21
+
22
+ });