Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(next/image): add images.localPatterns config #70529

Merged

Conversation

styfle
Copy link
Member

@styfle styfle commented Sep 26, 2024

This PR adds support for images.localPatterns configuration to allow specific local images to be optimized and (more importantly) return 400 Bad Request for anything that doesn't match the configured patterns.

module.exports = {
  images: {
    localPatterns: [
      {
        pathname: '/assets/images/**',
        search: '',
      },
    ],
  },
}

This feature is similar to the existing images.remotePatterns configuration but instead of filtering remote image, it filters local images.

Local images could be images in the public directory, API handlers, even rewrites. In the case of a static import, import img from './img.png, the allow list is configured automatically so you don't need to manually allow /_next/static/media/**.

@ijjk ijjk added created-by: Next.js team PRs by the Next.js team. Documentation Related to Next.js' official documentation. tests type: next labels Sep 26, 2024
@ijjk
Copy link
Member

ijjk commented Sep 26, 2024

Tests Passed

@ijjk
Copy link
Member

ijjk commented Sep 26, 2024

Stats from current PR

Default Build (Increase detected ⚠️)
General
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
buildDuration 19.6s 19.9s ⚠️ +279ms
buildDurationCached 16.1s 8s N/A
nodeModulesSize 371 MB 359 MB N/A
nextStartRea..uration (ms) 434ms 445ms N/A
Client Bundles (main, webpack) Overall increase ⚠️
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
2120-HASH.js gzip 5.25 kB 5.27 kB N/A
2893-HASH.js gzip 41.8 kB 43.1 kB ⚠️ +1.26 kB
4799ad3f-HASH.js gzip 52.8 kB 52.8 kB N/A
6087.HASH.js gzip 170 B 169 B N/A
framework-HASH.js gzip 57.6 kB 57.6 kB N/A
main-app-HASH.js gzip 227 B 230 B N/A
main-HASH.js gzip 32.7 kB 32.7 kB N/A
webpack-HASH.js gzip 1.71 kB 1.71 kB N/A
Overall change 41.8 kB 43.1 kB ⚠️ +1.26 kB
Legacy Client Bundles (polyfills)
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
polyfills-HASH.js gzip 39.4 kB 39.4 kB
Overall change 39.4 kB 39.4 kB
Client Pages
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
_app-HASH.js gzip 193 B 193 B
_error-HASH.js gzip 192 B 192 B
amp-HASH.js gzip 511 B 510 B N/A
css-HASH.js gzip 343 B 343 B
dynamic-HASH.js gzip 1.84 kB 1.84 kB N/A
edge-ssr-HASH.js gzip 264 B 264 B
head-HASH.js gzip 364 B 363 B N/A
hooks-HASH.js gzip 392 B 392 B
image-HASH.js gzip 4.41 kB 4.4 kB N/A
index-HASH.js gzip 269 B 268 B N/A
link-HASH.js gzip 2.78 kB 2.78 kB N/A
routerDirect..HASH.js gzip 327 B 329 B N/A
script-HASH.js gzip 397 B 392 B N/A
withRouter-HASH.js gzip 325 B 325 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Overall change 1.81 kB 1.81 kB
Client Build Manifests
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
_buildManifest.js gzip 751 B 748 B N/A
Overall change 0 B 0 B
Rendered Page Sizes
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
index.html gzip 522 B 523 B N/A
link.html gzip 536 B 538 B N/A
withRouter.html gzip 517 B 520 B N/A
Overall change 0 B 0 B
Edge SSR bundle Size
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
edge-ssr.js gzip 129 kB 128 kB N/A
page.js gzip 182 kB 179 kB N/A
Overall change 0 B 0 B
Middleware size
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
middleware-b..fest.js gzip 670 B 669 B N/A
middleware-r..fest.js gzip 156 B 154 B N/A
middleware.js gzip 30 kB 29.8 kB N/A
edge-runtime..pack.js gzip 844 B 844 B
Overall change 844 B 844 B
Next Runtimes Overall increase ⚠️
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
973-experime...dev.js gzip 322 B 322 B
973.runtime.dev.js gzip 314 B 314 B
app-page-exp...dev.js gzip 319 kB 318 kB N/A
app-page-exp..prod.js gzip 126 kB 126 kB N/A
app-page-tur..prod.js gzip 140 kB 139 kB N/A
app-page-tur..prod.js gzip 134 kB 134 kB N/A
app-page.run...dev.js gzip 309 kB 308 kB N/A
app-page.run..prod.js gzip 122 kB 121 kB N/A
app-route-ex...dev.js gzip 34.1 kB 32.1 kB N/A
app-route-ex..prod.js gzip 22.7 kB 21.7 kB N/A
app-route-tu..prod.js gzip 22.7 kB 21.7 kB N/A
app-route-tu..prod.js gzip 22.4 kB 21.5 kB N/A
app-route.ru...dev.js gzip 35.8 kB 33.7 kB N/A
app-route.ru..prod.js gzip 22.4 kB 21.5 kB N/A
pages-api-tu..prod.js gzip 9.62 kB 9.62 kB
pages-api.ru...dev.js gzip 11.5 kB 11.5 kB
pages-api.ru..prod.js gzip 9.61 kB 9.61 kB
pages-turbo...prod.js gzip 20.9 kB 20.8 kB N/A
pages.runtim...dev.js gzip 26.5 kB 26.4 kB N/A
pages.runtim..prod.js gzip 20.9 kB 20.8 kB N/A
server.runti..prod.js gzip 57.5 kB 57.9 kB ⚠️ +430 B
Overall change 88.8 kB 89.2 kB ⚠️ +430 B
build cache Overall increase ⚠️
vercel/next.js canary vercel/next.js styfle/next-3771-add-support-for-imageslocalpatterns-allow-list Change
0.pack gzip 1.67 MB 1.66 MB N/A
index.pack gzip 132 kB 133 kB ⚠️ +1.36 kB
Overall change 132 kB 133 kB ⚠️ +1.36 kB
Diff details
Diff for page.js
@@ -15,7 +15,7 @@
       /***/
     },
 
-    /***/ 9022: /***/ (
+    /***/ 6442: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -30,7 +30,7 @@
         default: () => /* binding */ nHandler,
       });
 
-      // NAMESPACE OBJECT: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statsACEYSe%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
+      // NAMESPACE OBJECT: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statsACEYSe%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
       var page_next_edge_ssr_entry_namespaceObject = {};
       __webpack_require__.r(page_next_edge_ssr_entry_namespaceObject);
       __webpack_require__.d(page_next_edge_ssr_entry_namespaceObject, {
@@ -44,23 +44,17 @@
           entry_base /* RenderFromTemplateContext */.b5,
         __next_app__: () => __next_app__,
         actionAsyncStorage: () => entry_base /* actionAsyncStorage */.Wz,
-        createPrerenderParamsForClientSegment: () =>
-          entry_base /* createPrerenderParamsForClientSegment */.XH,
-        createPrerenderSearchParamsForClientPage: () =>
-          entry_base /* createPrerenderSearchParamsForClientPage */.$h,
-        createServerParamsForMetadata: () =>
-          entry_base /* createServerParamsForMetadata */.qj,
-        createServerParamsForServerSegment: () =>
-          entry_base /* createServerParamsForServerSegment */.p5,
-        createServerSearchParamsForMetadata: () =>
-          entry_base /* createServerSearchParamsForMetadata */.Kn,
-        createServerSearchParamsForServerPage: () =>
-          entry_base /* createServerSearchParamsForServerPage */.Bt,
+        createDynamicallyTrackedParams: () =>
+          entry_base /* createDynamicallyTrackedParams */.eV,
+        createDynamicallyTrackedSearchParams: () =>
+          entry_base /* createDynamicallyTrackedSearchParams */.rL,
+        createUntrackedSearchParams: () =>
+          entry_base /* createUntrackedSearchParams */.S5,
         decodeAction: () => entry_base /* decodeAction */.Hs,
         decodeFormState: () => entry_base /* decodeFormState */.dH,
         decodeReply: () => entry_base /* decodeReply */.kf,
         pages: () => pages,
-        patchFetch: () => entry_base /* patchFetch */.eH,
+        patchFetch: () => entry_base /* patchFetch */.XH,
         preconnect: () => entry_base /* preconnect */.$P,
         preloadFont: () => entry_base /* preloadFont */.C5,
         preloadStyle: () => entry_base /* preloadStyle */.oH,
@@ -76,35 +70,35 @@
         tree: () => tree,
       });
 
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/web/globals.js
-      var globals = __webpack_require__(3663);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/web/adapter.js + 3 modules
-      var adapter = __webpack_require__(302);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/build/webpack/loaders/next-edge-ssr-loader/render.js + 88 modules
-      var render = __webpack_require__(9447);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/lib/incremental-cache/index.js + 3 modules
-      var incremental_cache = __webpack_require__(7458);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/app-render/app-render.js + 77 modules
-      var app_render = __webpack_require__(6752);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/route-modules/app-page/module.compiled.js
-      var module_compiled = __webpack_require__(7537);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/route-kind.js
-      var route_kind = __webpack_require__(4905);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/client/components/error-boundary.js
-      var error_boundary = __webpack_require__(4740);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/app-render/entry-base.js + 9 modules
-      var entry_base = __webpack_require__(406); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statsACEYSe%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/web/globals.js
+      var globals = __webpack_require__(4950);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/web/adapter.js + 3 modules
+      var adapter = __webpack_require__(2858);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/build/webpack/loaders/next-edge-ssr-loader/render.js + 85 modules
+      var render = __webpack_require__(3208);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/lib/incremental-cache/index.js + 3 modules
+      var incremental_cache = __webpack_require__(7539);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/app-render/app-render.js + 74 modules
+      var app_render = __webpack_require__(8471);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/route-modules/app-page/module.compiled.js
+      var module_compiled = __webpack_require__(5259);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/route-kind.js
+      var route_kind = __webpack_require__(8281);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/client/components/error-boundary.js
+      var error_boundary = __webpack_require__(790);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/app-render/entry-base.js + 10 modules
+      var entry_base = __webpack_require__(3206); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statsACEYSe%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
       const module0 = () =>
         Promise.resolve(/* import() eager */).then(
-          __webpack_require__.bind(__webpack_require__, 5931)
+          __webpack_require__.bind(__webpack_require__, 3867)
         );
       const module1 = () =>
         Promise.resolve(/* import() eager */).then(
-          __webpack_require__.bind(__webpack_require__, 3697)
+          __webpack_require__.bind(__webpack_require__, 4592)
         );
       const page2 = () =>
         Promise.resolve(/* import() eager */).then(
-          __webpack_require__.bind(__webpack_require__, 2928)
+          __webpack_require__.bind(__webpack_require__, 4242)
         );
 
       // We inject the tree and pages here so that we can use them in the route
@@ -167,12 +161,12 @@
       });
 
       //# sourceMappingURL=app-page.js.map
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/lib/page-types.js
-      var page_types = __webpack_require__(203);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/app-render/encryption-utils.js
-      var encryption_utils = __webpack_require__(8791);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/esm/server/app-render/action-utils.js
-      var action_utils = __webpack_require__(5338); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/dist/build/webpack/loaders/next-edge-ssr-loader/index.js?{"absolute500Path":"","absoluteAppPath":"next/dist/pages/_app","absoluteDocumentPath":"next/dist/pages/_document","absoluteErrorPath":"next/dist/pages/_error","absolutePagePath":"private-next-app-dir/app-edge-ssr/page.js","dev":false,"isServerComponent":true,"page":"/app-edge-ssr/page","stringifiedConfig":"eyJlbnYiOnt9LCJlc2xpbnQiOnsiaWdub3JlRHVyaW5nQnVpbGRzIjpmYWxzZX0sInR5cGVzY3JpcHQiOnsiaWdub3JlQnVpbGRFcnJvcnMiOmZhbHNlLCJ0c2NvbmZpZ1BhdGgiOiJ0c2NvbmZpZy5qc29uIn0sImRpc3REaXIiOiIubmV4dCIsImNsZWFuRGlzdERpciI6dHJ1ZSwiYXNzZXRQcmVmaXgiOiIiLCJjYWNoZU1heE1lbW9yeVNpemUiOjUyNDI4ODAwLCJjb25maWdPcmlnaW4iOiJuZXh0LmNvbmZpZy5qcyIsInVzZUZpbGVTeXN0ZW1QdWJsaWNSb3V0ZXMiOnRydWUsImdlbmVyYXRlRXRhZ3MiOnRydWUsInBhZ2VFeHRlbnNpb25zIjpbInRzeCIsInRzIiwianN4IiwianMiXSwicG93ZXJlZEJ5SGVhZGVyIjp0cnVlLCJjb21wcmVzcyI6dHJ1ZSwiaW1hZ2VzIjp7ImRldmljZVNpemVzIjpbNjQwLDc1MCw4MjgsMTA4MCwxMjAwLDE5MjAsMjA0OCwzODQwXSwiaW1hZ2VTaXplcyI6WzE2LDMyLDQ4LDY0LDk2LDEyOCwyNTYsMzg0XSwicGF0aCI6Ii9fbmV4dC9pbWFnZSIsImxvYWRlciI6ImRlZmF1bHQiLCJsb2FkZXJGaWxlIjoiIiwiZG9tYWlucyI6W10sImRpc2FibGVTdGF0aWNJbWFnZXMiOmZhbHNlLCJtaW5pbXVtQ2FjaGVUVEwiOjYwLCJmb3JtYXRzIjpbImltYWdlL3dlYnAiXSwiZGFuZ2Vyb3VzbHlBbGxvd1NWRyI6ZmFsc2UsImNvbnRlbnRTZWN1cml0eVBvbGljeSI6InNjcmlwdC1zcmMgJ25vbmUnOyBmcmFtZS1zcmMgJ25vbmUnOyBzYW5kYm94OyIsImNvbnRlbnREaXNwb3NpdGlvblR5cGUiOiJhdHRhY2htZW50IiwicmVtb3RlUGF0dGVybnMiOltdLCJ1bm9wdGltaXplZCI6ZmFsc2V9LCJkZXZJbmRpY2F0b3JzIjp7ImFwcElzclN0YXR1cyI6dHJ1ZSwiYnVpbGRBY3Rpdml0eSI6dHJ1ZSwiYnVpbGRBY3Rpdml0eVBvc2l0aW9uIjoiYm90dG9tLXJpZ2h0In0sIm9uRGVtYW5kRW50cmllcyI6eyJtYXhJbmFjdGl2ZUFnZSI6NjAwMDAsInBhZ2VzQnVmZmVyTGVuZ3RoIjo1fSwiYW1wIjp7ImNhbm9uaWNhbEJhc2UiOiIifSwiYmFzZVBhdGgiOiIiLCJzYXNzT3B0aW9ucyI6e30sInRyYWlsaW5nU2xhc2giOmZhbHNlLCJpMThuIjpudWxsLCJwcm9kdWN0aW9uQnJvd3NlclNvdXJjZU1hcHMiOmZhbHNlLCJleGNsdWRlRGVmYXVsdE1vbWVudExvY2FsZXMiOnRydWUsInNlcnZlclJ1bnRpbWVDb25maWciOnt9LCJwdWJsaWNSdW50aW1lQ29uZmlnIjp7fSwicmVhY3RQcm9kdWN0aW9uUHJvZmlsaW5nIjpmYWxzZSwicmVhY3RTdHJpY3RNb2RlIjpudWxsLCJyZWFjdE1heEhlYWRlcnNMZW5ndGgiOjYwMDAsImh0dHBBZ2VudE9wdGlvbnMiOnsia2VlcEFsaXZlIjp0cnVlfSwibG9nZ2luZyI6e30sInN0YXRpY1BhZ2VHZW5lcmF0aW9uVGltZW91dCI6NjAsIm1vZHVsYXJpemVJbXBvcnRzIjp7IkBtdWkvaWNvbnMtbWF0ZXJpYWwiOnsidHJhbnNmb3JtIjoiQG11aS9pY29ucy1tYXRlcmlhbC97e21lbWJlcn19In0sImxvZGFzaCI6eyJ0cmFuc2Zvcm0iOiJsb2Rhc2gve3ttZW1iZXJ9fSJ9fSwib3V0cHV0RmlsZVRyYWNpbmdSb290IjoiL3RtcC9uZXh0LXN0YXRzQUNFWVNlL3N0YXRzLWFwcCIsImV4cGVyaW1lbnRhbCI6eyJtdWx0aVpvbmVEcmFmdE1vZGUiOmZhbHNlLCJhcHBOYXZGYWlsSGFuZGxpbmciOmZhbHNlLCJwcmVyZW5kZXJFYXJseUV4aXQiOnRydWUsInNlcnZlck1pbmlmaWNhdGlvbiI6dHJ1ZSwic2VydmVyU291cmNlTWFwcyI6ZmFsc2UsImxpbmtOb1RvdWNoU3RhcnQiOmZhbHNlLCJjYXNlU2Vuc2l0aXZlUm91dGVzIjpmYWxzZSwicHJlbG9hZEVudHJpZXNPblN0YXJ0Ijp0cnVlLCJjbGllbnRSb3V0ZXJGaWx0ZXIiOnRydWUsImNsaWVudFJvdXRlckZpbHRlclJlZGlyZWN0cyI6ZmFsc2UsImZldGNoQ2FjaGVLZXlQcmVmaXgiOiIiLCJtaWRkbGV3YXJlUHJlZmV0Y2giOiJmbGV4aWJsZSIsIm9wdGltaXN0aWNDbGllbnRDYWNoZSI6dHJ1ZSwibWFudWFsQ2xpZW50QmFzZVBhdGgiOmZhbHNlLCJjcHVzIjoxOSwibWVtb3J5QmFzZWRXb3JrZXJzQ291bnQiOmZhbHNlLCJpc3JGbHVzaFRvRGlzayI6dHJ1ZSwid29ya2VyVGhyZWFkcyI6ZmFsc2UsIm9wdGltaXplQ3NzIjpmYWxzZSwibmV4dFNjcmlwdFdvcmtlcnMiOmZhbHNlLCJzY3JvbGxSZXN0b3JhdGlvbiI6ZmFsc2UsImV4dGVybmFsRGlyIjpmYWxzZSwiZGlzYWJsZU9wdGltaXplZExvYWRpbmciOmZhbHNlLCJnemlwU2l6ZSI6dHJ1ZSwiY3JhQ29tcGF0IjpmYWxzZSwiZXNtRXh0ZXJuYWxzIjp0cnVlLCJmdWxseVNwZWNpZmllZCI6ZmFsc2UsInN3Y1RyYWNlUHJvZmlsaW5nIjpmYWxzZSwiZm9yY2VTd2NUcmFuc2Zvcm1zIjpmYWxzZSwibGFyZ2VQYWdlRGF0YUJ5dGVzIjoxMjgwMDAsInR1cmJvIjp7InJvb3QiOiIvdG1wL25leHQtc3RhdHNBQ0VZU2Uvc3RhdHMtYXBwIn0sInR5cGVkUm91dGVzIjpmYWxzZSwidHlwZWRFbnYiOmZhbHNlLCJwYXJhbGxlbFNlcnZlckNvbXBpbGVzIjpmYWxzZSwicGFyYWxsZWxTZXJ2ZXJCdWlsZFRyYWNlcyI6ZmFsc2UsInBwciI6ZmFsc2UsInBwckZhbGxiYWNrcyI6ZmFsc2UsIndlYnBhY2tNZW1vcnlPcHRpbWl6YXRpb25zIjpmYWxzZSwib3B0aW1pemVTZXJ2ZXJSZWFjdCI6dHJ1ZSwidXNlRWFybHlJbXBvcnQiOmZhbHNlLCJzdGFsZVRpbWVzIjp7ImR5bmFtaWMiOjAsInN0YXRpYyI6MzAwfSwiYWZ0ZXIiOmZhbHNlLCJzZXJ2ZXJDb21wb25lbnRzSG1yQ2FjaGUiOnRydWUsInN0YXRpY0dlbmVyYXRpb25NYXhDb25jdXJyZW5jeSI6OCwic3RhdGljR2VuZXJhdGlvbk1pblBhZ2VzUGVyV29ya2VyIjoyNSwiZHluYW1pY0lPIjpmYWxzZSwib3B0aW1pemVQYWNrYWdlSW1wb3J0cyI6WyJsdWNpZGUtcmVhY3QiLCJkYXRlLWZucyIsImxvZGFzaC1lcyIsInJhbWRhIiwiYW50ZCIsInJlYWN0LWJvb3RzdHJhcCIsImFob29rcyIsIkBhbnQtZGVzaWduL2ljb25zIiwiQGhlYWRsZXNzdWkvcmVhY3QiLCJAaGVhZGxlc3N1aS1mbG9hdC9yZWFjdCIsIkBoZXJvaWNvbnMvcmVhY3QvMjAvc29saWQiLCJAaGVyb2ljb25zL3JlYWN0LzI0L3NvbGlkIiwiQGhlcm9pY29ucy9yZWFjdC8yNC9vdXRsaW5lIiwiQHZpc3gvdmlzeCIsIkB0cmVtb3IvcmVhY3QiLCJyeGpzIiwiQG11aS9tYXRlcmlhbCIsIkBtdWkvaWNvbnMtbWF0ZXJpYWwiLCJyZWNoYXJ0cyIsInJlYWN0LXVzZSIsImVmZmVjdCIsIkBlZmZlY3Qvc2NoZW1hIiwiQGVmZmVjdC9wbGF0Zm9ybSIsIkBlZmZlY3QvcGxhdGZvcm0tbm9kZSIsIkBlZmZlY3QvcGxhdGZvcm0tYnJvd3NlciIsIkBlZmZlY3QvcGxhdGZvcm0tYnVuIiwiQGVmZmVjdC9zcWwiLCJAZWZmZWN0L3NxbC1tc3NxbCIsIkBlZmZlY3Qvc3FsLW15c3FsMiIsIkBlZmZlY3Qvc3FsLXBnIiwiQGVmZmVjdC9zcWwtc3F1bGl0ZS1ub2RlIiwiQGVmZmVjdC9zcWwtc3F1bGl0ZS1idW4iLCJAZWZmZWN0L3NxbC1zcXVsaXRlLXdhc20iLCJAZWZmZWN0L3NxbC1zcXVsaXRlLXJlYWN0LW5hdGl2ZSIsIkBlZmZlY3QvcnBjIiwiQGVmZmVjdC9ycGMtaHR0cCIsIkBlZmZlY3QvdHlwZWNsYXNzIiwiQGVmZmVjdC9leHBlcmltZW50YWwiLCJAZWZmZWN0L29wZW50ZWxlbWV0cnkiLCJAbWF0ZXJpYWwtdWkvY29yZSIsIkBtYXRlcmlhbC11aS9pY29ucyIsIkB0YWJsZXIvaWNvbnMtcmVhY3QiLCJtdWktY29yZSIsInJlYWN0LWljb25zL2FpIiwicmVhY3QtaWNvbnMvYmkiLCJyZWFjdC1pY29ucy9icyIsInJlYWN0LWljb25zL2NnIiwicmVhY3QtaWNvbnMvY2kiLCJyZWFjdC1pY29ucy9kaSIsInJlYWN0LWljb25zL2ZhIiwicmVhY3QtaWNvbnMvZmE2IiwicmVhY3QtaWNvbnMvZmMiLCJyZWFjdC1pY29ucy9maSIsInJlYWN0LWljb25zL2dpIiwicmVhY3QtaWNvbnMvZ28iLCJyZWFjdC1pY29ucy9nciIsInJlYWN0LWljb25zL2hpIiwicmVhY3QtaWNvbnMvaGkyIiwicmVhY3QtaWNvbnMvaW0iLCJyZWFjdC1pY29ucy9pbyIsInJlYWN0LWljb25zL2lvNSIsInJlYWN0LWljb25zL2xpYSIsInJlYWN0LWljb25zL2xpYiIsInJlYWN0LWljb25zL2x1IiwicmVhY3QtaWNvbnMvbWQiLCJyZWFjdC1pY29ucy9waSIsInJlYWN0LWljb25zL3JpIiwicmVhY3QtaWNvbnMvcngiLCJyZWFjdC1pY29ucy9zaSIsInJlYWN0LWljb25zL3NsIiwicmVhY3QtaWNvbnMvdGIiLCJyZWFjdC1pY29ucy90ZmkiLCJyZWFjdC1pY29ucy90aSIsInJlYWN0LWljb25zL3ZzYyIsInJlYWN0LWljb25zL3dpIl19LCJidW5kbGVQYWdlc1JvdXRlckRlcGVuZGVuY2llcyI6ZmFsc2UsImNvbmZpZ0ZpbGUiOiIvdG1wL25leHQtc3RhdHNBQ0VZU2Uvc3RhdHMtYXBwL25leHQuY29uZmlnLmpzIiwiY29uZmlnRmlsZU5hbWUiOiJuZXh0LmNvbmZpZy5qcyJ9","pagesType":"app","appDirLoader":"bmV4dC1hcHAtbG9hZGVyP25hbWU9YXBwJTJGYXBwLWVkZ2Utc3NyJTJGcGFnZSZwYWdlPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZVBhdGg9cHJpdmF0ZS1uZXh0LWFwcC1kaXIlMkZhcHAtZWRnZS1zc3IlMkZwYWdlLmpzJmFwcERpcj0lMkZ0bXAlMkZuZXh0LXN0YXRzQUNFWVNlJTJGc3RhdHMtYXBwJTJGYXBwJmFwcFBhdGhzPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZUV4dGVuc2lvbnM9dHN4JnBhZ2VFeHRlbnNpb25zPXRzJnBhZ2VFeHRlbnNpb25zPWpzeCZwYWdlRXh0ZW5zaW9ucz1qcyZiYXNlUGF0aD0mYXNzZXRQcmVmaXg9Jm5leHRDb25maWdPdXRwdXQ9JmZseWluZ1NodXR0bGU9ZmFsc2UmcHJlZmVycmVkUmVnaW9uPSZtaWRkbGV3YXJlQ29uZmlnPWUzMCUzRCE=","sriEnabled":false,"middlewareConfig":"e30="}!
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/lib/page-types.js
+      var page_types = __webpack_require__(8438);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/app-render/encryption-utils.js
+      var encryption_utils = __webpack_require__(4011);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/esm/server/app-render/action-utils.js
+      var action_utils = __webpack_require__(9470); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/dist/build/webpack/loaders/next-edge-ssr-loader/index.js?{"absolute500Path":"","absoluteAppPath":"next/dist/pages/_app","absoluteDocumentPath":"next/dist/pages/_document","absoluteErrorPath":"next/dist/pages/_error","absolutePagePath":"private-next-app-dir/app-edge-ssr/page.js","dev":false,"isServerComponent":true,"page":"/app-edge-ssr/page","stringifiedConfig":"eyJlbnYiOnt9LCJlc2xpbnQiOnsiaWdub3JlRHVyaW5nQnVpbGRzIjpmYWxzZX0sInR5cGVzY3JpcHQiOnsiaWdub3JlQnVpbGRFcnJvcnMiOmZhbHNlLCJ0c2NvbmZpZ1BhdGgiOiJ0c2NvbmZpZy5qc29uIn0sImRpc3REaXIiOiIubmV4dCIsImNsZWFuRGlzdERpciI6dHJ1ZSwiYXNzZXRQcmVmaXgiOiIiLCJjYWNoZU1heE1lbW9yeVNpemUiOjUyNDI4ODAwLCJjb25maWdPcmlnaW4iOiJuZXh0LmNvbmZpZy5qcyIsInVzZUZpbGVTeXN0ZW1QdWJsaWNSb3V0ZXMiOnRydWUsImdlbmVyYXRlRXRhZ3MiOnRydWUsInBhZ2VFeHRlbnNpb25zIjpbInRzeCIsInRzIiwianN4IiwianMiXSwicG93ZXJlZEJ5SGVhZGVyIjp0cnVlLCJjb21wcmVzcyI6dHJ1ZSwiaW1hZ2VzIjp7ImRldmljZVNpemVzIjpbNjQwLDc1MCw4MjgsMTA4MCwxMjAwLDE5MjAsMjA0OCwzODQwXSwiaW1hZ2VTaXplcyI6WzE2LDMyLDQ4LDY0LDk2LDEyOCwyNTYsMzg0XSwicGF0aCI6Ii9fbmV4dC9pbWFnZSIsImxvYWRlciI6ImRlZmF1bHQiLCJsb2FkZXJGaWxlIjoiIiwiZG9tYWlucyI6W10sImRpc2FibGVTdGF0aWNJbWFnZXMiOmZhbHNlLCJtaW5pbXVtQ2FjaGVUVEwiOjYwLCJmb3JtYXRzIjpbImltYWdlL3dlYnAiXSwiZGFuZ2Vyb3VzbHlBbGxvd1NWRyI6ZmFsc2UsImNvbnRlbnRTZWN1cml0eVBvbGljeSI6InNjcmlwdC1zcmMgJ25vbmUnOyBmcmFtZS1zcmMgJ25vbmUnOyBzYW5kYm94OyIsImNvbnRlbnREaXNwb3NpdGlvblR5cGUiOiJhdHRhY2htZW50IiwicmVtb3RlUGF0dGVybnMiOltdLCJ1bm9wdGltaXplZCI6ZmFsc2V9LCJkZXZJbmRpY2F0b3JzIjp7ImFwcElzclN0YXR1cyI6dHJ1ZSwiYnVpbGRBY3Rpdml0eSI6dHJ1ZSwiYnVpbGRBY3Rpdml0eVBvc2l0aW9uIjoiYm90dG9tLXJpZ2h0In0sIm9uRGVtYW5kRW50cmllcyI6eyJtYXhJbmFjdGl2ZUFnZSI6NjAwMDAsInBhZ2VzQnVmZmVyTGVuZ3RoIjo1fSwiYW1wIjp7ImNhbm9uaWNhbEJhc2UiOiIifSwiYmFzZVBhdGgiOiIiLCJzYXNzT3B0aW9ucyI6e30sInRyYWlsaW5nU2xhc2giOmZhbHNlLCJpMThuIjpudWxsLCJwcm9kdWN0aW9uQnJvd3NlclNvdXJjZU1hcHMiOmZhbHNlLCJleGNsdWRlRGVmYXVsdE1vbWVudExvY2FsZXMiOnRydWUsInNlcnZlclJ1bnRpbWVDb25maWciOnt9LCJwdWJsaWNSdW50aW1lQ29uZmlnIjp7fSwicmVhY3RQcm9kdWN0aW9uUHJvZmlsaW5nIjpmYWxzZSwicmVhY3RTdHJpY3RNb2RlIjpudWxsLCJyZWFjdE1heEhlYWRlcnNMZW5ndGgiOjYwMDAsImh0dHBBZ2VudE9wdGlvbnMiOnsia2VlcEFsaXZlIjp0cnVlfSwibG9nZ2luZyI6e30sInN0YXRpY1BhZ2VHZW5lcmF0aW9uVGltZW91dCI6NjAsIm1vZHVsYXJpemVJbXBvcnRzIjp7IkBtdWkvaWNvbnMtbWF0ZXJpYWwiOnsidHJhbnNmb3JtIjoiQG11aS9pY29ucy1tYXRlcmlhbC97e21lbWJlcn19In0sImxvZGFzaCI6eyJ0cmFuc2Zvcm0iOiJsb2Rhc2gve3ttZW1iZXJ9fSJ9fSwib3V0cHV0RmlsZVRyYWNpbmdSb290IjoiL3RtcC9uZXh0LXN0YXRzQUNFWVNlL3N0YXRzLWFwcCIsImV4cGVyaW1lbnRhbCI6eyJtdWx0aVpvbmVEcmFmdE1vZGUiOmZhbHNlLCJhcHBOYXZGYWlsSGFuZGxpbmciOmZhbHNlLCJwcmVyZW5kZXJFYXJseUV4aXQiOnRydWUsInNlcnZlck1pbmlmaWNhdGlvbiI6dHJ1ZSwic2VydmVyU291cmNlTWFwcyI6ZmFsc2UsImxpbmtOb1RvdWNoU3RhcnQiOmZhbHNlLCJjYXNlU2Vuc2l0aXZlUm91dGVzIjpmYWxzZSwicHJlbG9hZEVudHJpZXNPblN0YXJ0Ijp0cnVlLCJjbGllbnRSb3V0ZXJGaWx0ZXIiOnRydWUsImNsaWVudFJvdXRlckZpbHRlclJlZGlyZWN0cyI6ZmFsc2UsImZldGNoQ2FjaGVLZXlQcmVmaXgiOiIiLCJtaWRkbGV3YXJlUHJlZmV0Y2giOiJmbGV4aWJsZSIsIm9wdGltaXN0aWNDbGllbnRDYWNoZSI6dHJ1ZSwibWFudWFsQ2xpZW50QmFzZVBhdGgiOmZhbHNlLCJjcHVzIjoxOSwibWVtb3J5QmFzZWRXb3JrZXJzQ291bnQiOmZhbHNlLCJpc3JGbHVzaFRvRGlzayI6dHJ1ZSwid29ya2VyVGhyZWFkcyI6ZmFsc2UsIm9wdGltaXplQ3NzIjpmYWxzZSwibmV4dFNjcmlwdFdvcmtlcnMiOmZhbHNlLCJzY3JvbGxSZXN0b3JhdGlvbiI6ZmFsc2UsImV4dGVybmFsRGlyIjpmYWxzZSwiZGlzYWJsZU9wdGltaXplZExvYWRpbmciOmZhbHNlLCJnemlwU2l6ZSI6dHJ1ZSwiY3JhQ29tcGF0IjpmYWxzZSwiZXNtRXh0ZXJuYWxzIjp0cnVlLCJmdWxseVNwZWNpZmllZCI6ZmFsc2UsInN3Y1RyYWNlUHJvZmlsaW5nIjpmYWxzZSwiZm9yY2VTd2NUcmFuc2Zvcm1zIjpmYWxzZSwibGFyZ2VQYWdlRGF0YUJ5dGVzIjoxMjgwMDAsInR1cmJvIjp7InJvb3QiOiIvdG1wL25leHQtc3RhdHNBQ0VZU2Uvc3RhdHMtYXBwIn0sInR5cGVkUm91dGVzIjpmYWxzZSwidHlwZWRFbnYiOmZhbHNlLCJwYXJhbGxlbFNlcnZlckNvbXBpbGVzIjpmYWxzZSwicGFyYWxsZWxTZXJ2ZXJCdWlsZFRyYWNlcyI6ZmFsc2UsInBwciI6ZmFsc2UsInBwckZhbGxiYWNrcyI6ZmFsc2UsIndlYnBhY2tNZW1vcnlPcHRpbWl6YXRpb25zIjpmYWxzZSwib3B0aW1pemVTZXJ2ZXJSZWFjdCI6dHJ1ZSwidXNlRWFybHlJbXBvcnQiOmZhbHNlLCJzdGFsZVRpbWVzIjp7ImR5bmFtaWMiOjAsInN0YXRpYyI6MzAwfSwiYWZ0ZXIiOmZhbHNlLCJzZXJ2ZXJDb21wb25lbnRzSG1yQ2FjaGUiOnRydWUsInN0YXRpY0dlbmVyYXRpb25NYXhDb25jdXJyZW5jeSI6OCwic3RhdGljR2VuZXJhdGlvbk1pblBhZ2VzUGVyV29ya2VyIjoyNSwiZHluYW1pY0lPIjpmYWxzZSwib3B0aW1pemVQYWNrYWdlSW1wb3J0cyI6WyJsdWNpZGUtcmVhY3QiLCJkYXRlLWZucyIsImxvZGFzaC1lcyIsInJhbWRhIiwiYW50ZCIsInJlYWN0LWJvb3RzdHJhcCIsImFob29rcyIsIkBhbnQtZGVzaWduL2ljb25zIiwiQGhlYWRsZXNzdWkvcmVhY3QiLCJAaGVhZGxlc3N1aS1mbG9hdC9yZWFjdCIsIkBoZXJvaWNvbnMvcmVhY3QvMjAvc29saWQiLCJAaGVyb2ljb25zL3JlYWN0LzI0L3NvbGlkIiwiQGhlcm9pY29ucy9yZWFjdC8yNC9vdXRsaW5lIiwiQHZpc3gvdmlzeCIsIkB0cmVtb3IvcmVhY3QiLCJyeGpzIiwiQG11aS9tYXRlcmlhbCIsIkBtdWkvaWNvbnMtbWF0ZXJpYWwiLCJyZWNoYXJ0cyIsInJlYWN0LXVzZSIsImVmZmVjdCIsIkBlZmZlY3Qvc2NoZW1hIiwiQGVmZmVjdC9wbGF0Zm9ybSIsIkBlZmZlY3QvcGxhdGZvcm0tbm9kZSIsIkBlZmZlY3QvcGxhdGZvcm0tYnJvd3NlciIsIkBlZmZlY3QvcGxhdGZvcm0tYnVuIiwiQGVmZmVjdC9zcWwiLCJAZWZmZWN0L3NxbC1tc3NxbCIsIkBlZmZlY3Qvc3FsLW15c3FsMiIsIkBlZmZlY3Qvc3FsLXBnIiwiQGVmZmVjdC9zcWwtc3F1bGl0ZS1ub2RlIiwiQGVmZmVjdC9zcWwtc3F1bGl0ZS1idW4iLCJAZWZmZWN0L3NxbC1zcXVsaXRlLXdhc20iLCJAZWZmZWN0L3NxbC1zcXVsaXRlLXJlYWN0LW5hdGl2ZSIsIkBlZmZlY3QvcnBjIiwiQGVmZmVjdC9ycGMtaHR0cCIsIkBlZmZlY3QvdHlwZWNsYXNzIiwiQGVmZmVjdC9leHBlcmltZW50YWwiLCJAZWZmZWN0L29wZW50ZWxlbWV0cnkiLCJAbWF0ZXJpYWwtdWkvY29yZSIsIkBtYXRlcmlhbC11aS9pY29ucyIsIkB0YWJsZXIvaWNvbnMtcmVhY3QiLCJtdWktY29yZSIsInJlYWN0LWljb25zL2FpIiwicmVhY3QtaWNvbnMvYmkiLCJyZWFjdC1pY29ucy9icyIsInJlYWN0LWljb25zL2NnIiwicmVhY3QtaWNvbnMvY2kiLCJyZWFjdC1pY29ucy9kaSIsInJlYWN0LWljb25zL2ZhIiwicmVhY3QtaWNvbnMvZmE2IiwicmVhY3QtaWNvbnMvZmMiLCJyZWFjdC1pY29ucy9maSIsInJlYWN0LWljb25zL2dpIiwicmVhY3QtaWNvbnMvZ28iLCJyZWFjdC1pY29ucy9nciIsInJlYWN0LWljb25zL2hpIiwicmVhY3QtaWNvbnMvaGkyIiwicmVhY3QtaWNvbnMvaW0iLCJyZWFjdC1pY29ucy9pbyIsInJlYWN0LWljb25zL2lvNSIsInJlYWN0LWljb25zL2xpYSIsInJlYWN0LWljb25zL2xpYiIsInJlYWN0LWljb25zL2x1IiwicmVhY3QtaWNvbnMvbWQiLCJyZWFjdC1pY29ucy9waSIsInJlYWN0LWljb25zL3JpIiwicmVhY3QtaWNvbnMvcngiLCJyZWFjdC1pY29ucy9zaSIsInJlYWN0LWljb25zL3NsIiwicmVhY3QtaWNvbnMvdGIiLCJyZWFjdC1pY29ucy90ZmkiLCJyZWFjdC1pY29ucy90aSIsInJlYWN0LWljb25zL3ZzYyIsInJlYWN0LWljb25zL3dpIl19LCJidW5kbGVQYWdlc1JvdXRlckRlcGVuZGVuY2llcyI6ZmFsc2UsImNvbmZpZ0ZpbGUiOiIvdG1wL25leHQtc3RhdHNBQ0VZU2Uvc3RhdHMtYXBwL25leHQuY29uZmlnLmpzIiwiY29uZmlnRmlsZU5hbWUiOiJuZXh0LmNvbmZpZy5qcyJ9","pagesType":"app","appDirLoader":"bmV4dC1hcHAtbG9hZGVyP25hbWU9YXBwJTJGYXBwLWVkZ2Utc3NyJTJGcGFnZSZwYWdlPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZVBhdGg9cHJpdmF0ZS1uZXh0LWFwcC1kaXIlMkZhcHAtZWRnZS1zc3IlMkZwYWdlLmpzJmFwcERpcj0lMkZ0bXAlMkZuZXh0LXN0YXRzQUNFWVNlJTJGc3RhdHMtYXBwJTJGYXBwJmFwcFBhdGhzPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZUV4dGVuc2lvbnM9dHN4JnBhZ2VFeHRlbnNpb25zPXRzJnBhZ2VFeHRlbnNpb25zPWpzeCZwYWdlRXh0ZW5zaW9ucz1qcyZiYXNlUGF0aD0mYXNzZXRQcmVmaXg9Jm5leHRDb25maWdPdXRwdXQ9JmZseWluZ1NodXR0bGU9ZmFsc2UmcHJlZmVycmVkUmVnaW9uPSZtaWRkbGV3YXJlQ29uZmlnPWUzMCUzRCE=","sriEnabled":false,"middlewareConfig":"e30="}!
       var _self___RSC_MANIFEST;
 
       const incrementalCacheHandler = null;
@@ -436,53 +430,53 @@
       /***/
     },
 
-    /***/ 7820: /***/ (
+    /***/ 1784: /***/ (
       __unused_webpack_module,
       __unused_webpack_exports,
       __webpack_require__
     ) => {
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 9653)
+        __webpack_require__.bind(__webpack_require__, 263)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 1323)
+        __webpack_require__.bind(__webpack_require__, 239)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 933)
+        __webpack_require__.bind(__webpack_require__, 6808)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 7131)
+        __webpack_require__.bind(__webpack_require__, 9543)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 3048)
+        __webpack_require__.bind(__webpack_require__, 4145)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 8281)
+        __webpack_require__.bind(__webpack_require__, 6196)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 3129)
+        __webpack_require__.bind(__webpack_require__, 754)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 9429)
+        __webpack_require__.bind(__webpack_require__, 3482)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 1985)
+        __webpack_require__.bind(__webpack_require__, 9294)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 1815)
+        __webpack_require__.bind(__webpack_require__, 8049)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 566)
+        __webpack_require__.bind(__webpack_require__, 2408)
       );
 
       /***/
     },
 
-    /***/ 5415: /***/ () => {
+    /***/ 8977: /***/ () => {
       /***/
     },
 
-    /***/ 2928: /***/ (
+    /***/ 4242: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -502,7 +496,7 @@
       /***/
     },
 
-    /***/ 5931: /***/ (
+    /***/ 3867: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -514,7 +508,7 @@
         /* harmony export */
       });
       /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ =
-        __webpack_require__(7887);
+        __webpack_require__(9851);
 
       function RootLayout({ children }) {
         return /*#__PURE__*/ (0,
@@ -533,7 +527,7 @@
     // webpackRuntimeModules
     /******/ var __webpack_exec__ = (moduleId) =>
       __webpack_require__((__webpack_require__.s = moduleId));
-    /******/ __webpack_require__.O(0, [425, 404], () => __webpack_exec__(9022));
+    /******/ __webpack_require__.O(0, [219, 473], () => __webpack_exec__(6442));
     /******/ var __webpack_exports__ = __webpack_require__.O();
     /******/ (_ENTRIES = typeof _ENTRIES === "undefined" ? {} : _ENTRIES)[
       "middleware_app/app-edge-ssr/page"
Diff for middleware.js

Diff too large to display

Diff for edge-ssr.js

Diff too large to display

Diff for image-HASH.js
@@ -1,7 +1,7 @@
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
   [8358],
   {
-    /***/ 9553: /***/ (
+    /***/ 2542: /***/ (
       __unused_webpack_module,
       __unused_webpack_exports,
       __webpack_require__
@@ -9,7 +9,7 @@
       (window.__NEXT_P = window.__NEXT_P || []).push([
         "/image",
         function () {
-          return __webpack_require__(4973);
+          return __webpack_require__(5220);
         },
       ]);
       if (false) {
@@ -18,7 +18,7 @@
       /***/
     },
 
-    /***/ 4492: /***/ (module, exports, __webpack_require__) => {
+    /***/ 39: /***/ (module, exports, __webpack_require__) => {
       "use strict";
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
@@ -40,17 +40,17 @@
         __webpack_require__(5096)
       );
       const _head = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(1900)
+        __webpack_require__(4927)
       );
-      const _getimgprops = __webpack_require__(7298);
-      const _imageconfig = __webpack_require__(364);
-      const _imageconfigcontextsharedruntime = __webpack_require__(607);
-      const _warnonce = __webpack_require__(3417);
-      const _routercontextsharedruntime = __webpack_require__(8249);
+      const _getimgprops = __webpack_require__(9121);
+      const _imageconfig = __webpack_require__(5657);
+      const _imageconfigcontextsharedruntime = __webpack_require__(4517);
+      const _warnonce = __webpack_require__(1512);
+      const _routercontextsharedruntime = __webpack_require__(499);
       const _imageloader = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(6186)
+        __webpack_require__(6699)
       );
-      const _usemergedref = __webpack_require__(1927);
+      const _usemergedref = __webpack_require__(5395);
       // This is replaced by webpack define plugin
       const configEnv = {
         deviceSizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840],
@@ -371,36 +371,44 @@
       /***/
     },
 
-    /***/ 1927: /***/ (module, exports, __webpack_require__) => {
+    /***/ 5395: /***/ (module, exports, __webpack_require__) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
-      Object.defineProperty(exports, "useMergedRef", {
-        enumerable: true,
-        get: function () {
+      0 && 0;
+      function _export(target, all) {
+        for (var name in all)
+          Object.defineProperty(target, name, {
+            enumerable: true,
+            get: all[name],
+          });
+      }
+      _export(exports, {
+        mergeRefs: function () {
+          return mergeRefs;
+        },
+        useMergedRef: function () {
           return useMergedRef;
         },
       });
       const _react = __webpack_require__(3839);
       function useMergedRef(refA, refB) {
-        const cleanupA = (0, _react.useRef)(() => {});
-        const cleanupB = (0, _react.useRef)(() => {});
-        return (0, _react.useMemo)(() => {
-          if (!refA || !refB) {
-            return refA || refB;
-          }
-          return (current) => {
-            if (current === null) {
-              cleanupA.current();
-              cleanupB.current();
-            } else {
-              cleanupA.current = applyRef(refA, current);
-              cleanupB.current = applyRef(refB, current);
-            }
+        return (0, _react.useMemo)(() => mergeRefs(refA, refB), [refA, refB]);
+      }
+      function mergeRefs(refA, refB) {
+        if (!refA || !refB) {
+          return refA || refB;
+        }
+        return (current) => {
+          const cleanupA = applyRef(refA, current);
+          const cleanupB = applyRef(refB, current);
+          return () => {
+            cleanupA();
+            cleanupB();
           };
-        }, [refA, refB]);
+        };
       }
       function applyRef(refA, current) {
         if (typeof refA === "function") {
@@ -432,7 +440,7 @@
       /***/
     },
 
-    /***/ 7298: /***/ (
+    /***/ 9121: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -448,9 +456,9 @@
           return getImgProps;
         },
       });
-      const _warnonce = __webpack_require__(3417);
-      const _imageblursvg = __webpack_require__(3844);
-      const _imageconfig = __webpack_require__(364);
+      const _warnonce = __webpack_require__(1512);
+      const _imageblursvg = __webpack_require__(94);
+      const _imageconfig = __webpack_require__(5657);
       const VALID_LOADING_VALUES =
         /* unused pure expression or super */ null && [
           "lazy",
@@ -823,7 +831,7 @@
       /***/
     },
 
-    /***/ 3844: /***/ (__unused_webpack_module, exports) => {
+    /***/ 94: /***/ (__unused_webpack_module, exports) => {
       "use strict";
       /**
        * A shared function, used on both client and server, to generate a SVG blur placeholder.
@@ -878,7 +886,7 @@
       /***/
     },
 
-    /***/ 2464: /***/ (
+    /***/ 7268: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -905,10 +913,10 @@
         },
       });
       const _interop_require_default = __webpack_require__(9608);
-      const _getimgprops = __webpack_require__(7298);
-      const _imagecomponent = __webpack_require__(4492);
+      const _getimgprops = __webpack_require__(9121);
+      const _imagecomponent = __webpack_require__(39);
       const _imageloader = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(6186)
+        __webpack_require__(6699)
       );
       function getImageProps(imgProps) {
         const { props } = (0, _getimgprops.getImgProps)(imgProps, {
@@ -940,7 +948,7 @@
       /***/
     },
 
-    /***/ 6186: /***/ (__unused_webpack_module, exports) => {
+    /***/ 6699: /***/ (__unused_webpack_module, exports) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -975,7 +983,7 @@
       /***/
     },
 
-    /***/ 4973: /***/ (
+    /***/ 5220: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -992,8 +1000,8 @@
 
       // EXTERNAL MODULE: ./node_modules/.pnpm/react@19.0.0-rc-5d19e1c8-20240923/node_modules/react/jsx-runtime.js
       var jsx_runtime = __webpack_require__(4129);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_exh3korby52talgbfgrfijbiwa/node_modules/next/image.js
-      var next_image = __webpack_require__(487);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-5d19e1c8-20240923_re_l4vv5whrqalbzw3o4esxkwi2ju/node_modules/next/image.js
+      var next_image = __webpack_require__(6147);
       var image_default = /*#__PURE__*/ __webpack_require__.n(next_image); // CONCATENATED MODULE: ./pages/nextjs.png
       /* harmony default export */ const nextjs = {
         src: "/_next/static/media/nextjs.cae0b805.png",
@@ -1023,12 +1031,12 @@
       /***/
     },
 
-    /***/ 487: /***/ (
+    /***/ 6147: /***/ (
       module,
       __unused_webpack_exports,
       __webpack_require__
     ) => {
-      module.exports = __webpack_require__(2464);
+      module.exports = __webpack_require__(7268);
 
       /***/
     },
@@ -1038,7 +1046,7 @@
     /******/ var __webpack_exec__ = (moduleId) =>
       __webpack_require__((__webpack_require__.s = moduleId));
     /******/ __webpack_require__.O(0, [2888, 9774, 179], () =>
-      __webpack_exec__(9553)
+      __webpack_exec__(2542)
     );
     /******/ var __webpack_exports__ = __webpack_require__.O();
     /******/ _N_E = __webpack_exports__;
Diff for link-HASH.js
@@ -1,7 +1,7 @@
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
   [4644],
   {
-    /***/ 9200: /***/ (
+    /***/ 8015: /***/ (
       __unused_webpack_module,
       __unused_webpack_exports,
       __webpack_require__
@@ -9,7 +9,7 @@
       (window.__NEXT_P = window.__NEXT_P || []).push([
         "/link",
         function () {
-          return __webpack_require__(4203);
+          return __webpack_require__(4680);
         },
       ]);
       if (false) {
@@ -18,7 +18,7 @@
       /***/
     },
 
-    /***/ 1835: /***/ (module, exports) => {
+    /***/ 1196: /***/ (module, exports) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -96,7 +96,7 @@
       /***/
     },
 
-    /***/ 767: /***/ (module, exports, __webpack_require__) => {
+    /***/ 6621: /***/ (module, exports, __webpack_require__) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -108,7 +108,7 @@
           return getDomainLocale;
         },
       });
-      const _normalizetrailingslash = __webpack_require__(1995);
+      const _normalizetrailingslash = __webpack_require__(2134);
       const basePath =
         /* unused pure expression or super */ null && (false || "");
       function getDomainLocale(path, locale, locales, domainLocales) {
@@ -132,7 +132,7 @@
       /***/
     },
 
-    /***/ 2282: /***/ (module, exports, __webpack_require__) => {
+    /***/ 1372: /***/ (module, exports, __webpack_require__) => {
       "use strict";
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
@@ -149,18 +149,18 @@
       const _react = /*#__PURE__*/ _interop_require_default._(
         __webpack_require__(3839)
       );
-      const _resolvehref = __webpack_require__(3707);
-      const _islocalurl = __webpack_require__(4077);
-      const _formaturl = __webpack_require__(1894);
-      const _utils = __webpack_require__(2477);
-      const _addlocale = __webpack_require__(1608);
-      const _routercontextsharedruntime = __webpack_require__(8249);
-      const _approutercontextsharedruntime = __webpack_require__(4257);
-      const _useintersection = __webpack_require__(1147);
-      const _getdomainlocale = __webpack_require__(767);
-      const _addbasepath = __webpack_require__(8486);
-      const _routerreducertypes = __webpack_require__(1835);
-      const _usemergedref = __webpack_require__(1927);
+      const _resolvehref = __webpack_require__(474);
+      const _islocalurl = __webpack_require__(4503);
+      const _formaturl = __webpack_require__(8734);
+      const _utils = __webpack_require__(4432);
+      const _addlocale = __webpack_require__(6728);
+      const _routercontextsharedruntime = __webpack_require__(499);
+      const _approutercontextsharedruntime = __webpack_require__(3294);
+      const _useintersection = __webpack_require__(2146);
+      const _getdomainlocale = __webpack_require__(6621);
+      const _addbasepath = __webpack_require__(6324);
+      const _routerreducertypes = __webpack_require__(1196);
+      const _usemergedref = __webpack_require__(5395);
       const prefetched = new Set();
       function prefetch(router, href, as, options, appOptions, isAppRouter) {
         if (false) {
@@ -588,7 +588,7 @@
       /***/
     },
 
-    /***/ 1147: /***/ (module, exports, __webpack_require__) => {
+    /***/ 2146: /***/ (module, exports, __webpack_require__) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -601,7 +601,7 @@
         },
       });
       const _react = __webpack_require__(3839);
-      const _requestidlecallback = __webpack_require__(5488);
+      const _requestidlecallback = __webpack_require__(4677);
       const hasIntersectionObserver =
         typeof IntersectionObserver === "function";
       const observers = new Map();
@@ -714,36 +714,44 @@
       /***/
     },
 
-    /***/ 1927: /***/ (module, exports, __webpack_require__) => {
+    /***/ 5395: /***/ (module, exports, __webpack_require__) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
-      Object.defineProperty(exports, "useMergedRef", {
-        enumerable: true,
-        get: function () {
+      0 && 0;
+      function _export(target, all) {
+        for (var name in all)
+          Object.defineProperty(target, name, {
+            enumerable: true,
+            get: all[name],
+          });
+      }
+      _export(exports, {
+        mergeRefs: function () {
+          return mergeRefs;
+        },
+        useMergedRef: function () {
           return useMergedRef;
         },
       });
       const _react = __webpack_require__(3839);
       function useMergedRef(refA, refB) {
-        const cleanupA = (0, _react.useRef)(() => {});
-        const cleanupB = (0, _react.useRef)(() => {});
-        return (0, _react.useMemo)(() => {
-          if (!refA || !refB) {
-            return refA || refB;
-          }
-          return (current) => {
-            if (current === null) {
-              cleanupA.current();
-              cleanupB.current();
-            } else {
-              cleanupA.current = applyRef(refA, current);
-              cleanupB.current = applyRef(refB, current);
-            }
+        return (0, _react.useMemo)(() => mergeRefs(refA, refB), [refA, refB]);
+      }
+      function mergeRefs(refA, refB) {
+        if (!refA || !refB) {
+          return refA || refB;
+        }
+        return (current) => {
+          const cleanupA = applyRef(refA, current);
+          const cleanupB = applyRef(refB, current);
+          return () => {
+            cleanupA();
+            cleanupB();
           };
-        }, [refA, refB]);
+        };
       }
       function applyRef(refA, current) {
         if (typeof refA === "function") {
@@ -775,7 +783,7 @@
       /***/
     },
 
-    /***/ 4203: /***/ (
+    /***/ 4680: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -790,7 +798,7 @@
       /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ =
         __webpack_require__(4129);
       /* harmony import */ var next_link__WEBPACK_IMPORTED_MODULE_1__ =
-        __webpack_require__(8655);
+        __webpack_require__(4397);
       /* harmony import */ var next_link__WEBPACK_IMPORTED_MODULE_1___default =
         /*#__PURE__*/ __webpack_require__.n(
           next_link__WEBPACK_IMPORTED_MODULE_1__
@@ -821,12 +829,12 @@
       /***/
     },
 
-    /***/ 8655: /***/ (
+    /***/ 4397: /***/ (
       module,
       __unused_webpack_exports,
       __webpack_require__
     ) => {
-      module.exports = __webpack_require__(2282);
+      module.exports = __webpack_require__(1372);
 
       /***/
     },
@@ -836,7 +844,7 @@
     /******/ var __webpack_exec__ = (moduleId) =>
       __webpack_require__((__webpack_require__.s = moduleId));
     /******/ __webpack_require__.O(0, [2888, 9774, 179], () =>
-      __webpack_exec__(9200)
+      __webpack_exec__(8015)
     );
     /******/ var __webpack_exports__ = __webpack_require__.O();
     /******/ _N_E = __webpack_exports__;
Diff for 2120-HASH.js
@@ -1,8 +1,8 @@
 "use strict";
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
-  [2120],
+  [7468],
   {
-    /***/ 2120: /***/ (module, exports, __webpack_require__) => {
+    /***/ 7468: /***/ (module, exports, __webpack_require__) => {
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
         value: true,
@@ -13,27 +13,27 @@
           return Image;
         },
       });
-      const _interop_require_default = __webpack_require__(7544);
-      const _interop_require_wildcard = __webpack_require__(7671);
-      const _jsxruntime = __webpack_require__(9377);
+      const _interop_require_default = __webpack_require__(6899);
+      const _interop_require_wildcard = __webpack_require__(1399);
+      const _jsxruntime = __webpack_require__(8683);
       const _react = /*#__PURE__*/ _interop_require_wildcard._(
-        __webpack_require__(9795)
+        __webpack_require__(333)
       );
       const _reactdom = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(995)
+        __webpack_require__(3241)
       );
       const _head = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(7253)
+        __webpack_require__(5259)
       );
-      const _getimgprops = __webpack_require__(4949);
-      const _imageconfig = __webpack_require__(7337);
-      const _imageconfigcontextsharedruntime = __webpack_require__(7656);
-      const _warnonce = __webpack_require__(9875);
-      const _routercontextsharedruntime = __webpack_require__(8675);
+      const _getimgprops = __webpack_require__(3234);
+      const _imageconfig = __webpack_require__(5976);
+      const _imageconfigcontextsharedruntime = __webpack_require__(8784);
+      const _warnonce = __webpack_require__(9221);
+      const _routercontextsharedruntime = __webpack_require__(619);
       const _imageloader = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(5827)
+        __webpack_require__(2811)
       );
-      const _usemergedref = __webpack_require__(9026);
+      const _usemergedref = __webpack_require__(7297);
       // This is replaced by webpack define plugin
       const configEnv = {
         deviceSizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840],
@@ -355,34 +355,42 @@
       /***/
     },
 
-    /***/ 9026: /***/ (module, exports, __webpack_require__) => {
+    /***/ 7297: /***/ (module, exports, __webpack_require__) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
-      Object.defineProperty(exports, "useMergedRef", {
-        enumerable: true,
-        get: function () {
+      0 && 0;
+      function _export(target, all) {
+        for (var name in all)
+          Object.defineProperty(target, name, {
+            enumerable: true,
+            get: all[name],
+          });
+      }
+      _export(exports, {
+        mergeRefs: function () {
+          return mergeRefs;
+        },
+        useMergedRef: function () {
           return useMergedRef;
         },
       });
-      const _react = __webpack_require__(9795);
+      const _react = __webpack_require__(333);
       function useMergedRef(refA, refB) {
-        const cleanupA = (0, _react.useRef)(() => {});
-        const cleanupB = (0, _react.useRef)(() => {});
-        return (0, _react.useMemo)(() => {
-          if (!refA || !refB) {
-            return refA || refB;
-          }
-          return (current) => {
-            if (current === null) {
-              cleanupA.current();
-              cleanupB.current();
-            } else {
-              cleanupA.current = applyRef(refA, current);
-              cleanupB.current = applyRef(refB, current);
-            }
+        return (0, _react.useMemo)(() => mergeRefs(refA, refB), [refA, refB]);
+      }
+      function mergeRefs(refA, refB) {
+        if (!refA || !refB) {
+          return refA || refB;
+        }
+        return (current) => {
+          const cleanupA = applyRef(refA, current);
+          const cleanupB = applyRef(refB, current);
+          return () => {
+            cleanupA();
+            cleanupB();
           };
-        }, [refA, refB]);
+        };
       }
       function applyRef(refA, current) {
         if (typeof refA === "function") {
@@ -414,7 +422,7 @@
       /***/
     },
 
-    /***/ 6606: /***/ (
+    /***/ 6300: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -428,9 +436,9 @@
           return AmpStateContext;
         },
       });
-      const _interop_require_default = __webpack_require__(7544);
+      const _interop_require_default = __webpack_require__(6899);
       const _react = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(9795)
+        __webpack_require__(333)
       );
       const AmpStateContext = _react.default.createContext({});
       if (false) {
@@ -439,7 +447,7 @@
       /***/
     },
 
-    /***/ 1910: /***/ (__unused_webpack_module, exports) => {
+    /***/ 1503: /***/ (__unused_webpack_module, exports) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -461,7 +469,7 @@
       /***/
     },
 
-    /***/ 4949: /***/ (
+    /***/ 3234: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -475,9 +483,9 @@
           return getImgProps;
         },
       });
-      const _warnonce = __webpack_require__(9875);
-      const _imageblursvg = __webpack_require__(4567);
-      const _imageconfig = __webpack_require__(7337);
+      const _warnonce = __webpack_require__(9221);
+      const _imageblursvg = __webpack_require__(9188);
+      const _imageconfig = __webpack_require__(5976);
       const VALID_LOADING_VALUES =
         /* unused pure expression or super */ null && [
           "lazy",
@@ -850,8 +858,8 @@
       /***/
     },
 
-    /***/ 7253: /***/ (module, exports, __webpack_require__) => {
-      /* provided dependency */ var process = __webpack_require__(3335);
+    /***/ 5259: /***/ (module, exports, __webpack_require__) => {
+      /* provided dependency */ var process = __webpack_require__(6843);
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
         value: true,
@@ -872,19 +880,19 @@
           return defaultHead;
         },
       });
-      const _interop_require_default = __webpack_require__(7544);
-      const _interop_require_wildcard = __webpack_require__(7671);
-      const _jsxruntime = __webpack_require__(9377);
+      const _interop_require_default = __webpack_require__(6899);
+      const _interop_require_wildcard = __webpack_require__(1399);
+      const _jsxruntime = __webpack_require__(8683);
       const _react = /*#__PURE__*/ _interop_require_wildcard._(
-        __webpack_require__(9795)
+        __webpack_require__(333)
       );
       const _sideeffect = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(533)
+        __webpack_require__(848)
       );
-      const _ampcontextsharedruntime = __webpack_require__(6606);
-      const _headmanagercontextsharedruntime = __webpack_require__(338);
-      const _ampmode = __webpack_require__(1910);
-      const _warnonce = __webpack_require__(9875);
+      const _ampcontextsharedruntime = __webpack_require__(6300);
+      const _headmanagercontextsharedruntime = __webpack_require__(2324);
+      const _ampmode = __webpack_require__(1503);
+      const _warnonce = __webpack_require__(9221);
       function defaultHead(inAmpMode) {
         if (inAmpMode === void 0) inAmpMode = false;
         const head = [
@@ -1068,7 +1076,7 @@
       /***/
     },
 
-    /***/ 4567: /***/ (__unused_webpack_module, exports) => {
+    /***/ 9188: /***/ (__unused_webpack_module, exports) => {
       /**
        * A shared function, used on both client and server, to generate a SVG blur placeholder.
        */
@@ -1122,7 +1130,7 @@
       /***/
     },
 
-    /***/ 7656: /***/ (
+    /***/ 8784: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -1136,11 +1144,11 @@
           return ImageConfigContext;
         },
       });
-      const _interop_require_default = __webpack_require__(7544);
+      const _interop_require_default = __webpack_require__(6899);
       const _react = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(9795)
+        __webpack_require__(333)
       );
-      const _imageconfig = __webpack_require__(7337);
+      const _imageconfig = __webpack_require__(5976);
       const ImageConfigContext = _react.default.createContext(
         _imageconfig.imageConfigDefault
       );
@@ -1150,7 +1158,7 @@
       /***/
     },
 
-    /***/ 7337: /***/ (__unused_webpack_module, exports) => {
+    /***/ 5976: /***/ (__unused_webpack_module, exports) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -1190,6 +1198,7 @@
         dangerouslyAllowSVG: false,
         contentSecurityPolicy: "script-src 'none'; frame-src 'none'; sandbox;",
         contentDispositionType: "attachment",
+        localPatterns: undefined,
         remotePatterns: [],
         unoptimized: false,
       }; //# sourceMappingURL=image-config.js.map
@@ -1197,7 +1206,7 @@
       /***/
     },
 
-    /***/ 5827: /***/ (__unused_webpack_module, exports) => {
+    /***/ 2811: /***/ (__unused_webpack_module, exports) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -1230,7 +1239,7 @@
       /***/
     },
 
-    /***/ 8675: /***/ (
+    /***/ 619: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -1244,9 +1253,9 @@
           return RouterContext;
         },
       });
-      const _interop_require_default = __webpack_require__(7544);
+      const _interop_require_default = __webpack_require__(6899);
       const _react = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(9795)
+        __webpack_require__(333)
       );
       const RouterContext = _react.default.createContext(null);
       if (false) {
@@ -1255,7 +1264,7 @@
       /***/
     },
 
-    /***/ 533: /***/ (
+    /***/ 848: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -1269,7 +1278,7 @@
           return SideEffect;
         },
       });
-      const _react = __webpack_require__(9795);
+      const _react = __webpack_require__(333);
       const isServer = typeof window === "undefined";
       const useClientOnlyLayoutEffect = isServer
         ? () => {}
Diff for 2893-HASH.js

Diff too large to display

Diff for 4799ad3f-HASH.js
@@ -1,13 +1,13 @@
 "use strict";
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
-  [8740],
+  [8897],
   {
-    /***/ 7946: /***/ (
+    /***/ 3183: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
     ) => {
-      /* provided dependency */ var process = __webpack_require__(3335);
+      /* provided dependency */ var process = __webpack_require__(6843);
       /**
        * @license React
        * react-dom-client.production.js
@@ -22,9 +22,9 @@
  Modernizr 3.0.0pre (Custom Build) | MIT
 */
 
-      var Scheduler = __webpack_require__(2093),
-        React = __webpack_require__(9795),
-        ReactDOM = __webpack_require__(995);
+      var Scheduler = __webpack_require__(5766),
+        React = __webpack_require__(333),
+        ReactDOM = __webpack_require__(3241);
       function formatProdErrorMessage(code) {
         var url = "https://react.dev/errors/" + code;
         if (1 < arguments.length) {
@@ -715,6 +715,15 @@
             return -1;
         }
       }
+      function getLanesToRetrySynchronouslyOnError(
+        root,
+        originallyAttemptedLanes
+      ) {
+        if (root.errorRecoveryDisabledLanes & originallyAttemptedLanes)
+          return 0;
+        root = root.pendingLanes & -536870913;
+        return 0 !== root ? root : root & 536870912 ? 536870912 : 0;
+      }
       function claimNextTransitionLane() {
         var lane = nextTransitionLane;
         nextTransitionLane <<= 1;
@@ -2055,14 +2064,14 @@
       if (canUseDOM) {
         var JSCompiler_inline_result$jscomp$278;
         if (canUseDOM) {
-          var isSupported$jscomp$inline_413 = "oninput" in document;
-          if (!isSupported$jscomp$inline_413) {
-            var element$jscomp$inline_414 = document.createElement("div");
-            element$jscomp$inline_414.setAttribute("oninput", "return;");
-            isSupported$jscomp$inline_413 =
-              "function" === typeof element$jscomp$inline_414.oninput;
+          var isSupported$jscomp$inline_414 = "oninput" in document;
+          if (!isSupported$jscomp$inline_414) {
+            var element$jscomp$inline_415 = document.createElement("div");
+            element$jscomp$inline_415.setAttribute("oninput", "return;");
+            isSupported$jscomp$inline_414 =
+              "function" === typeof element$jscomp$inline_415.oninput;
           }
-          JSCompiler_inline_result$jscomp$278 = isSupported$jscomp$inline_413;
+          JSCompiler_inline_result$jscomp$278 = isSupported$jscomp$inline_414;
         } else JSCompiler_inline_result$jscomp$278 = !1;
         isInputEventSupported =
           JSCompiler_inline_result$jscomp$278 &&
@@ -10909,92 +10918,67 @@
               )),
             ensureRootIsScheduled(root);
       }
-      function performWorkOnRoot(root$jscomp$0, lanes, forceSync) {
+      function performConcurrentWorkOnRoot(root, didTimeout) {
         if (0 !== (executionContext & 6))
           throw Error(formatProdErrorMessage(327));
-        var exitStatus = (forceSync =
-          !forceSync &&
+        var originalCallbackNode = root.callbackNode;
+        if (flushPassiveEffects() && root.callbackNode !== originalCallbackNode)
+          return null;
+        var lanes = getNextLanes(
+          root,
+          root === workInProgressRoot ? workInProgressRootRenderLanes : 0
+        );
+        if (0 === lanes) return null;
+        var shouldTimeSlice =
           0 === (lanes & 60) &&
-          0 === (lanes & root$jscomp$0.expiredLanes))
-          ? renderRootConcurrent(root$jscomp$0, lanes)
-          : renderRootSync(root$jscomp$0, lanes);
-        if (0 !== exitStatus) {
-          var renderWasConcurrent = forceSync;
+          0 === (lanes & root.expiredLanes) &&
+          !didTimeout;
+        didTimeout = shouldTimeSlice
+          ? renderRootConcurrent(root, lanes)
+          : renderRootSync(root, lanes);
+        if (0 !== didTimeout) {
+          var renderWasConcurrent = shouldTimeSlice;
           do {
-            if (6 === exitStatus)
+            if (6 === didTimeout)
               markRootSuspended(
-                root$jscomp$0,
+                root,
                 lanes,
                 0,
                 workInProgressRootDidSkipSuspendedSiblings
               );
             else {
-              forceSync = root$jscomp$0.current.alternate;
+              shouldTimeSlice = root.current.alternate;
               if (
                 renderWasConcurrent &&
-                !isRenderConsistentWithExternalStores(forceSync)
+                !isRenderConsistentWithExternalStores(shouldTimeSlice)
               ) {
-                exitStatus = renderRootSync(root$jscomp$0, lanes);
+                didTimeout = renderRootSync(root, lanes);
                 renderWasConcurrent = !1;
                 continue;
               }
-              if (2 === exitStatus) {
+              if (2 === didTimeout) {
                 renderWasConcurrent = lanes;
+                var errorRetryLanes = getLanesToRetrySynchronouslyOnError(
+                  root,
+                  renderWasConcurrent
+                );
                 if (
-                  root$jscomp$0.errorRecoveryDisabledLanes & renderWasConcurrent
+                  0 !== errorRetryLanes &&
+                  ((lanes = errorRetryLanes),
+                  (didTimeout = recoverFromConcurrentError(
+                    root,
+                    renderWasConcurrent,
+                    errorRetryLanes
+                  )),
+                  (renderWasConcurrent = !1),
+                  2 !== didTimeout)
                 )
-                  var JSCompiler_inline_result = 0;
-                else
-                  (JSCompiler_inline_result =
-                    root$jscomp$0.pendingLanes & -536870913),
-                    (JSCompiler_inline_result =
-                      0 !== JSCompiler_inline_result
-                        ? JSCompiler_inline_result
-                        : JSCompiler_inline_result & 536870912
-                        ? 536870912
-                        : 0);
-                if (0 !== JSCompiler_inline_result) {
-                  lanes = JSCompiler_inline_result;
-                  a: {
-                    var root = root$jscomp$0;
-                    exitStatus = workInProgressRootConcurrentErrors;
-                    var wasRootDehydrated =
-                      root.current.memoizedState.isDehydrated;
-                    wasRootDehydrated &&
-                      (prepareFreshStack(
-                        root,
-                        JSCompiler_inline_result
-                      ).flags |= 256);
-                    JSCompiler_inline_result = renderRootSync(
-                      root,
-                      JSCompiler_inline_result
-                    );
-                    if (2 !== JSCompiler_inline_result) {
-                      if (
-                        workInProgressRootDidAttachPingListener &&
-                        !wasRootDehydrated
-                      ) {
-                        root.errorRecoveryDisabledLanes |= renderWasConcurrent;
-                        workInProgressRootInterleavedUpdatedLanes |=
-                          renderWasConcurrent;
-                        exitStatus = 4;
-                        break a;
-                      }
-                      renderWasConcurrent = workInProgressRootRecoverableErrors;
-                      workInProgressRootRecoverableErrors = exitStatus;
-                      null !== renderWasConcurrent &&
-                        queueRecoverableErrors(renderWasConcurrent);
-                    }
-                    exitStatus = JSCompiler_inline_result;
-                  }
-                  renderWasConcurrent = !1;
-                  if (2 !== exitStatus) continue;
-                }
+                  continue;
               }
-              if (1 === exitStatus) {
-                prepareFreshStack(root$jscomp$0, 0);
+              if (1 === didTimeout) {
+                prepareFreshStack(root, 0);
                 markRootSuspended(
-                  root$jscomp$0,
+                  root,
                   lanes,
                   0,
                   workInProgressRootDidSkipSuspendedSiblings
@@ -11002,8 +10986,8 @@
                 break;
               }
               a: {
-                renderWasConcurrent = root$jscomp$0;
-                switch (exitStatus) {
+                renderWasConcurrent = root;
+                switch (didTimeout) {
                   case 0:
                   case 1:
                     throw Error(formatProdErrorMessage(345));
@@ -11027,12 +11011,12 @@
                   default:
                     throw Error(formatProdErrorMessage(329));
                 }
-                renderWasConcurrent.finishedWork = forceSync;
+                renderWasConcurrent.finishedWork = shouldTimeSlice;
                 renderWasConcurrent.finishedLanes = lanes;
                 if (
                   (lanes & 62914560) === lanes &&
-                  ((exitStatus = globalMostRecentFallbackTime + 300 - now()),
-                  10 < exitStatus)
+                  ((didTimeout = globalMostRecentFallbackTime + 300 - now()),
+                  10 < didTimeout)
                 ) {
                   markRootSuspended(
                     renderWasConcurrent,
@@ -11045,7 +11029,7 @@
                     commitRootWhenReady.bind(
                       null,
                       renderWasConcurrent,
-                      forceSync,
+                      shouldTimeSlice,
                       workInProgressRootRecoverableErrors,
                       workInProgressTransitions,
                       workInProgressRootDidIncludeRecursiveRenderUpdate,
@@ -11053,18 +11037,15 @@
                       workInProgressDeferredLane,
                       workInProgressRootInterleavedUpdatedLanes,
                       workInProgressSuspendedRetryLanes,
-                      workInProgressRootDidSkipSuspendedSiblings,
-                      2,
-                      -0,
-                      0
+                      workInProgressRootDidSkipSuspendedSiblings
                     ),
-                    exitStatus
+                    didTimeout
                   );
                   break a;
                 }
                 commitRootWhenReady(
                   renderWasConcurrent,
-                  forceSync,
+                  shouldTimeSlice,
                   workInProgressRootRecoverableErrors,
                   workInProgressTransitions,
                   workInProgressRootDidIncludeRecursiveRenderUpdate,
@@ -11072,17 +11053,44 @@
                   workInProgressDeferredLane,
                   workInProgressRootInterleavedUpdatedLanes,
                   workInProgressSuspendedRetryLanes,
-                  workInProgressRootDidSkipSuspendedSiblings,
-                  0,
-                  -0,
-                  0
+                  workInProgressRootDidSkipSuspendedSiblings
                 );
               }
             }
             break;
           } while (1);
         }
-        ensureRootIsScheduled(root$jscomp$0);
+        ensureRootIsScheduled(root);
+        scheduleTaskForRootDuringMicrotask(root, now());
+        root =
+          root.callbackNode === originalCallbackNode
+            ? performConcurrentWorkOnRoot.bind(null, root)
+            : null;
+        return root;
+      }
+      function recoverFromConcurrentError(
+        root,
+        originallyAttemptedLanes,
+        errorRetryLanes
+      ) {
+        var errorsFromFirstAttempt = workInProgressRootConcurrentErrors,
+          wasRootDehydrated = root.current.memoizedState.isDehydrated;
+        wasRootDehydrated &&
+          (prepareFreshStack(root, errorRetryLanes).flags |= 256);
+        errorRetryLanes = renderRootSync(root, errorRetryLanes);
+        if (2 !== errorRetryLanes) {
+          if (workInProgressRootDidAttachPingListener && !wasRootDehydrated)
+            return (
+              (root.errorRecoveryDisabledLanes |= originallyAttemptedLanes),
+              (workInProgressRootInterleavedUpdatedLanes |=
+                originallyAttemptedLanes),
+              4
+            );
+          root = workInProgressRootRecoverableErrors;
+          workInProgressRootRecoverableErrors = errorsFromFirstAttempt;
+          null !== root && queueRecoverableErrors(root);
+        }
+        return errorRetryLanes;
       }
       function queueRecoverableErrors(errors) {
         null === workInProgressRootRecoverableErrors
@@ -11102,10 +11110,7 @@
         spawnedLane,
         updatedLanes,
         suspendedRetryLanes,
-        didSkipSuspendedSiblings,
-        suspendedCommitReason,
-        completedRenderStartTime,
-        completedRenderEndTime
+        didSkipSuspendedSiblings
       ) {
         var subtreeFlags = finishedWork.subtreeFlags;
         if (subtreeFlags & 8192 || 16785408 === (subtreeFlags & 16785408))
@@ -11128,10 +11133,7 @@
                 didIncludeRenderPhaseUpdate,
                 spawnedLane,
                 updatedLanes,
-                suspendedRetryLanes,
-                1,
-                completedRenderStartTime,
-                completedRenderEndTime
+                suspendedRetryLanes
               )
             );
             markRootSuspended(
@@ -11149,10 +11151,7 @@
           didIncludeRenderPhaseUpdate,
           spawnedLane,
           updatedLanes,
-          suspendedRetryLanes,
-          suspendedCommitReason,
-          completedRenderStartTime,
-          completedRenderEndTime
+          suspendedRetryLanes
         );
       }
       function isRenderConsistentWithExternalStores(finishedWork) {
@@ -11222,6 +11221,57 @@
         0 !== spawnedLane &&
           markSpawnedDeferredLane(root, spawnedLane, suspendedLanes);
       }
+      function performSyncWorkOnRoot(root, lanes) {
+        if (0 !== (executionContext & 6))
+          throw Error(formatProdErrorMessage(327));
+        if (flushPassiveEffects()) return ensureRootIsScheduled(root), null;
+        var exitStatus = renderRootSync(root, lanes);
+        if (2 === exitStatus) {
+          var originallyAttemptedLanes = lanes,
+            errorRetryLanes = getLanesToRetrySynchronouslyOnError(
+              root,
+              originallyAttemptedLanes
+            );
+          0 !== errorRetryLanes &&
+            ((lanes = errorRetryLanes),
+            (exitStatus = recoverFromConcurrentError(
+              root,
+              originallyAttemptedLanes,
+              errorRetryLanes
+            )));
+        }
+        if (1 === exitStatus)
+          return (
+            prepareFreshStack(root, 0),
+            markRootSuspended(root, lanes, 0, !1),
+            ensureRootIsScheduled(root),
+            null
+          );
+        if (6 === exitStatus)
+          return (
+            markRootSuspended(
+              root,
+              lanes,
+              workInProgressDeferredLane,
+              workInProgressRootDidSkipSuspendedSiblings
+            ),
+            ensureRootIsScheduled(root),
+            null
+          );
+        root.finishedWork = root.current.alternate;
+        root.finishedLanes = lanes;
+        commitRoot(
+          root,
+          workInProgressRootRecoverableErrors,
+          workInProgressTransitions,
+          workInProgressRootDidIncludeRecursiveRenderUpdate,
+          workInProgressDeferredLane,
+          workInProgressRootInterleavedUpdatedLanes,
+          workInProgressSuspendedRetryLanes
+        );
+        ensureRootIsScheduled(root);
+        return null;
+      }
       function flushSyncWork$1() {
         return 0 === (executionContext & 6)
           ? (flushSyncWorkAcrossRoots_impl(0, !1), !1)
@@ -11680,10 +11730,7 @@
         didIncludeRenderPhaseUpdate,
         spawnedLane,
         updatedLanes,
-        suspendedRetryLanes,
-        suspendedCommitReason,
-        completedRenderStartTime,
-        completedRenderEndTime
+        suspendedRetryLanes
       ) {
         var prevTransition = ReactSharedInternals.T,
           previousUpdateLanePriority = ReactDOMSharedInternals.p;
@@ -11698,15 +11745,13 @@
               previousUpdateLanePriority,
               spawnedLane,
               updatedLanes,
-              suspendedRetryLanes,
-              suspendedCommitReason,
-              completedRenderStartTime,
-              completedRenderEndTime
+              suspendedRetryLanes
             );
         } finally {
           (ReactSharedInternals.T = prevTransition),
             (ReactDOMSharedInternals.p = previousUpdateLanePriority);
         }
+        return null;
       }
       function commitRootImpl(
         root,
@@ -11753,7 +11798,7 @@
           (pendingPassiveEffectsRemainingLanes = remainingLanes),
           (pendingPassiveTransitions = transitions),
           scheduleCallback$1(NormalPriority$1, function () {
-            flushPassiveEffects(!0);
+            flushPassiveEffects();
             return null;
           }));
         transitions = 0 !== (finishedWork.flags & 15990);
@@ -11998,7 +12043,7 @@
         retryTimedOutBoundary(boundaryFiber, retryLane);
       }
       function throwIfInfiniteUpdateLoopDetected() {
-        if (100 < nestedUpdateCount)
+        if (50 < nestedUpdateCount)
           throw (
             ((nestedUpdateCount = 0),
             (rootWithNestedUpdates = null),
@@ -12170,39 +12215,12 @@
           default:
             suspendedLanes = NormalPriority$1;
         }
-        pingedLanes = performWorkOnRootViaSchedulerTask.bind(null, root);
+        pingedLanes = performConcurrentWorkOnRoot.bind(null, root);
         suspendedLanes = scheduleCallback$3(suspendedLanes, pingedLanes);
         root.callbackPriority = currentTime;
         root.callbackNode = suspendedLanes;
         return currentTime;
       }
-      function performWorkOnRootViaSchedulerTask(root, didTimeout) {
-        var originalCallbackNode = root.callbackNode;
-        if (flushPassiveEffects() && root.callbackNode !== originalCallbackNode)
-          return null;
-        var workInProgressRootRenderLanes$jscomp$0 =
-          workInProgressRootRenderLanes;
-        workInProgressRootRenderLanes$jscomp$0 = getNextLanes(
-          root,
-          root === workInProgressRoot
-            ? workInProgressRootRenderLanes$jscomp$0
-            : 0
-        );
-        if (0 === workInProgressRootRenderLanes$jscomp$0) return null;
-        performWorkOnRoot(
-          root,
-          workInProgressRootRenderLanes$jscomp$0,
-          didTimeout
-        );
-        scheduleTaskForRootDuringMicrotask(root, now());
-        return root.callbackNode === originalCallbackNode
-          ? performWorkOnRootViaSchedulerTask.bind(null, root)
-          : null;
-      }
-      function performSyncWorkOnRoot(root, lanes) {
-        if (flushPassiveEffects()) return null;
-        performWorkOnRoot(root, lanes, !0);
-      }
       function scheduleImmediateTask(cb) {
         scheduleMicrotask(function () {
           0 !== (executionContext & 6)
@@ -12318,20 +12336,20 @@
         }
       }
       for (
-        var i$jscomp$inline_1419 = 0;
-        i$jscomp$inline_1419 < simpleEventPluginEvents.length;
-        i$jscomp$inline_1419++
+        var i$jscomp$inline_1411 = 0;
+        i$jscomp$inline_1411 < simpleEventPluginEvents.length;
+        i$jscomp$inline_1411++
       ) {
-        var eventName$jscomp$inline_1420 =
-            simpleEventPluginEvents[i$jscomp$inline_1419],
-          domEventName$jscomp$inline_1421 =
-            eventName$jscomp$inline_1420.toLowerCase(),
-          capitalizedEvent$jscomp$inline_1422 =
-            eventName$jscomp$inline_1420[0].toUpperCase() +
-            eventName$jscomp$inline_1420.slice(1);
+        var eventName$jscomp$inline_1412 =
+            simpleEventPluginEvents[i$jscomp$inline_1411],
+          domEventName$jscomp$inline_1413 =
+            eventName$jscomp$inline_1412.toLowerCase(),
+          capitalizedEvent$jscomp$inline_1414 =
+            eventName$jscomp$inline_1412[0].toUpperCase() +
+            eventName$jscomp$inline_1412.slice(1);
         registerSimpleEvent(
-          domEventName$jscomp$inline_1421,
-          "on" + capitalizedEvent$jscomp$inline_1422
+          domEventName$jscomp$inline_1413,
+          "on" + capitalizedEvent$jscomp$inline_1414
         );
       }
       registerSimpleEvent(ANIMATION_END, "onAnimationEnd");
@@ -16000,16 +16018,16 @@
           0 === i && attemptExplicitHydrationTarget(target);
         }
       };
-      var isomorphicReactPackageVersion$jscomp$inline_1666 = React.version;
+      var isomorphicReactPackageVersion$jscomp$inline_1658 = React.version;
       if (
-        "19.0.0-rc-2d16326d-20240930" !==
-        isomorphicReactPackageVersion$jscomp$inline_1666
+        "19.0.0-rc-5d19e1c8-20240923" !==
+        isomorphicReactPackageVersion$jscomp$inline_1658
       )
         throw Error(
           formatProdErrorMessage(
             527,
-            isomorphicReactPackageVersion$jscomp$inline_1666,
-            "19.0.0-rc-2d16326d-20240930"
+            isomorphicReactPackageVersion$jscomp$inline_1658,
+            "19.0.0-rc-5d19e1c8-20240923"
           )
         );
       ReactDOMSharedInternals.findDOMNode = function (componentOrElement) {
@@ -16029,25 +16047,25 @@
           null === componentOrElement ? null : componentOrElement.stateNode;
         return componentOrElement;
       };
-      var internals$jscomp$inline_2137 = {
+      var internals$jscomp$inline_2124 = {
         bundleType: 0,
-        version: "19.0.0-rc-2d16326d-20240930",
+        version: "19.0.0-rc-5d19e1c8-20240923",
         rendererPackageName: "react-dom",
         currentDispatcherRef: ReactSharedInternals,
         findFiberByHostInstance: getClosestInstanceFromNode,
-        reconcilerVersion: "19.0.0-rc-2d16326d-20240930",
+        reconcilerVersion: "19.0.0-rc-5d19e1c8-20240923",
       };
       if ("undefined" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__) {
-        var hook$jscomp$inline_2138 = __REACT_DEVTOOLS_GLOBAL_HOOK__;
+        var hook$jscomp$inline_2125 = __REACT_DEVTOOLS_GLOBAL_HOOK__;
         if (
-          !hook$jscomp$inline_2138.isDisabled &&
-          hook$jscomp$inline_2138.supportsFiber
+          !hook$jscomp$inline_2125.isDisabled &&
+          hook$jscomp$inline_2125.supportsFiber
         )
           try {
-            (rendererID = hook$jscomp$inline_2138.inject(
-              internals$jscomp$inline_2137
+            (rendererID = hook$jscomp$inline_2125.inject(
+              internals$jscomp$inline_2124
             )),
-              (injectedHook = hook$jscomp$inline_2138);
+              (injectedHook = hook$jscomp$inline_2125);
           } catch (err) {}
       }
       exports.createRoot = function (container, options) {
@@ -16143,7 +16161,7 @@
         listenToAllSupportedEvents(container);
         return new ReactDOMHydrationRoot(initialChildren);
       };
-      exports.version = "19.0.0-rc-2d16326d-20240930";
+      exports.version = "19.0.0-rc-5d19e1c8-20240923";
 
       /***/
     },
Diff for main-HASH.js

Diff too large to display

Diff for app-page-exp..ntime.dev.js
failed to diff
Diff for app-page-exp..time.prod.js

Diff too large to display

Diff for app-page-tur..time.prod.js

Diff too large to display

Diff for app-page-tur..time.prod.js

Diff too large to display

Diff for app-page.runtime.dev.js
failed to diff
Diff for app-page.runtime.prod.js

Diff too large to display

Diff for app-route-ex..ntime.dev.js

Diff too large to display

Diff for app-route-ex..time.prod.js

Diff too large to display

Diff for app-route-tu..time.prod.js

Diff too large to display

Diff for app-route-tu..time.prod.js

Diff too large to display

Diff for app-route.runtime.dev.js

Diff too large to display

Diff for app-route.ru..time.prod.js

Diff too large to display

Diff for pages-turbo...time.prod.js

Diff too large to display

Diff for pages.runtime.dev.js

Diff too large to display

Diff for pages.runtime.prod.js

Diff too large to display

Diff for server.runtime.prod.js

Diff too large to display

Commit: 246d0c2

@styfle styfle requested a review from a team September 30, 2024 21:16
@styfle styfle marked this pull request as ready for review October 1, 2024 19:08
Copy link

vercel bot commented Oct 1, 2024

Notifying the following users due to files changed in this PR based on this repo's notify modifiers:

@timneutkens, @ijjk, @shuding, @huozhi:

packages/next/src/server/config.ts

@styfle styfle enabled auto-merge (squash) October 1, 2024 20:25
const {
hasRemoteMatch,
} = require('../../shared/lib/match-remote-pattern')
if (!hasRemoteMatch(config.domains, config.remotePatterns, parsedSrc)) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should this check be present for localPatterns as well?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good catch! I had it on the new image component but not the legacy image component.

Added in 246d0c2

@styfle styfle requested a review from ijjk October 1, 2024 20:48
// Modifying this function should also modify writeImagesManifest()
export function matchLocalPattern(pattern: LocalPattern, url: URL): boolean {
if (pattern.search !== undefined) {
if (pattern.search !== url.search) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does ordering on the search value here matter since the user prop can't control intermediaries like CDNs changing it?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes the order matters because search is a string literal.

I don't think CDN's changing it will be very common since this is going to be the value passed to the src prop on the image component.

In the future, we could add support for any order using an an object or array.

@styfle styfle merged commit a9c045d into canary Oct 1, 2024
107 of 111 checks passed
@styfle styfle deleted the styfle/next-3771-add-support-for-imageslocalpatterns-allow-list branch October 1, 2024 21:45
kodiakhq bot pushed a commit to vercel/vercel that referenced this pull request Oct 3, 2024
styfle added a commit that referenced this pull request Oct 4, 2024
This adds support for `images.localPatterns` config to allow specific
local images to be optimized and (more importantly) block anything that
doesn't match a pattern.
styfle added a commit that referenced this pull request Oct 4, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
created-by: Next.js team PRs by the Next.js team. Documentation Related to Next.js' official documentation. tests type: next
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants