@pinerohit11/testwidget 0.1.23 → 0.1.25
Sign up to get free protection for your applications and to get access to all the features.
- package/.next/app-build-manifest.json +0 -5
- package/.next/build-manifest.json +2 -13
- package/.next/cache/webpack/client-development/0.pack.gz +0 -0
- package/.next/cache/webpack/client-development/1.pack.gz +0 -0
- package/.next/cache/webpack/client-development/14.pack.gz +0 -0
- package/.next/cache/webpack/client-development/17.pack.gz +0 -0
- package/.next/cache/webpack/client-development/2.pack.gz +0 -0
- package/.next/cache/webpack/client-development/3.pack.gz +0 -0
- package/.next/cache/webpack/client-development/5.pack.gz +0 -0
- package/.next/cache/webpack/client-development/6.pack.gz +0 -0
- package/.next/cache/webpack/client-development/8.pack.gz +0 -0
- package/.next/cache/webpack/client-development/index.pack.gz +0 -0
- package/.next/cache/webpack/client-development/index.pack.gz.old +0 -0
- package/.next/cache/webpack/client-development-fallback/0.pack.gz +0 -0
- package/.next/cache/webpack/client-development-fallback/1.pack.gz +0 -0
- package/.next/cache/webpack/client-development-fallback/index.pack.gz +0 -0
- package/.next/cache/webpack/client-development-fallback/index.pack.gz.old +0 -0
- package/.next/cache/webpack/server-development/0.pack.gz +0 -0
- package/.next/cache/webpack/server-development/1.pack.gz +0 -0
- package/.next/cache/webpack/server-development/14.pack.gz +0 -0
- package/.next/cache/webpack/server-development/15.pack.gz +0 -0
- package/.next/cache/webpack/server-development/2.pack.gz +0 -0
- package/.next/cache/webpack/server-development/3.pack.gz +0 -0
- package/.next/cache/webpack/server-development/4.pack.gz +0 -0
- package/.next/cache/webpack/server-development/5.pack.gz +0 -0
- package/.next/cache/webpack/server-development/index.pack.gz +0 -0
- package/.next/cache/webpack/server-development/index.pack.gz.old +0 -0
- package/.next/server/app/page.js +36 -25
- package/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/server/app-paths-manifest.json +0 -1
- package/.next/server/middleware-build-manifest.js +2 -13
- package/.next/server/pages-manifest.json +1 -5
- package/.next/server/vendor-chunks/@swc.js +0 -20
- package/.next/server/vendor-chunks/next.js +4 -421
- package/.next/server/webpack-runtime.js +1 -1
- package/.next/static/chunks/app/layout.js +22 -11
- package/.next/static/chunks/app/page.js +7 -7
- package/.next/static/chunks/app-pages-internals.js +1 -1
- package/.next/static/chunks/main-app.js +5 -5
- package/.next/static/chunks/webpack.js +1 -1
- package/.next/static/css/app/layout.css +690 -0
- package/.next/static/css/app/page.css +689 -689
- package/.next/static/development/_buildManifest.js +1 -1
- package/.next/static/webpack/app/{layout.300fc5b668ca0906.hot-update.js → layout.068fbf99e4cd8b82.hot-update.js} +2 -2
- package/.next/static/webpack/{webpack.05e804a9c98d6744.hot-update.js → webpack.068fbf99e4cd8b82.hot-update.js} +1 -1
- package/.next/trace +17 -148
- package/dist/index.cjs +0 -6
- package/dist/index.css +544 -0
- package/dist/index.js +0 -6
- package/package.json +2 -1
- package/.next/fallback-build-manifest.json +0 -28
- package/.next/server/_error.js +0 -76
- package/.next/server/app/_not-found/page.js +0 -210
- package/.next/server/app/_not-found/page_client-reference-manifest.js +0 -1
- package/.next/server/pages/_app.js +0 -46
- package/.next/server/pages/_document.js +0 -66
- package/.next/server/pages/_error.js +0 -76
- package/.next/static/chunks/_error.js +0 -28
- package/.next/static/chunks/app/_not-found/page.js +0 -39
- package/.next/static/chunks/fallback/amp.js +0 -885
- package/.next/static/chunks/fallback/main.js +0 -2057
- package/.next/static/chunks/fallback/pages/_app.js +0 -28
- package/.next/static/chunks/fallback/pages/_error.js +0 -28
- package/.next/static/chunks/fallback/react-refresh.js +0 -62
- package/.next/static/chunks/fallback/webpack.js +0 -1210
- package/.next/static/chunks/main.js +0 -2057
- package/.next/static/chunks/pages/_app.js +0 -28
- package/.next/static/chunks/pages/_error.js +0 -28
- package/.next/static/chunks/react-refresh.js +0 -62
- package/.next/static/webpack/03ee13d215584d59.webpack.hot-update.json +0 -1
- package/.next/static/webpack/05e804a9c98d6744.webpack.hot-update.json +0 -1
- package/.next/static/webpack/09b6bf9d551718e6.webpack.hot-update.json +0 -1
- package/.next/static/webpack/19bfc21a985c41a3.webpack.hot-update.json +0 -1
- package/.next/static/webpack/1c4c3e518f810365.webpack.hot-update.json +0 -1
- package/.next/static/webpack/1dc8bb4faa862342.webpack.hot-update.json +0 -1
- package/.next/static/webpack/217f0b5265f56be2.webpack.hot-update.json +0 -1
- package/.next/static/webpack/21d00cb457913b06.webpack.hot-update.json +0 -1
- package/.next/static/webpack/2813c5d79542e32e.webpack.hot-update.json +0 -1
- package/.next/static/webpack/28ebfaec609673ec.webpack.hot-update.json +0 -1
- package/.next/static/webpack/2b7d71482ca7a5b0.webpack.hot-update.json +0 -1
- package/.next/static/webpack/300fc5b668ca0906.webpack.hot-update.json +0 -1
- package/.next/static/webpack/31b91c765347fb55.webpack.hot-update.json +0 -1
- package/.next/static/webpack/32e5c09644d13662.webpack.hot-update.json +0 -1
- package/.next/static/webpack/33df40926ef177b8.webpack.hot-update.json +0 -1
- package/.next/static/webpack/343e03d8261d3d56.webpack.hot-update.json +0 -1
- package/.next/static/webpack/3d336feedc5241cc.webpack.hot-update.json +0 -1
- package/.next/static/webpack/3de1fe8a6a590578.webpack.hot-update.json +0 -1
- package/.next/static/webpack/3fffc4287d1af227.webpack.hot-update.json +0 -1
- package/.next/static/webpack/511251a6a8797ede.webpack.hot-update.json +0 -1
- package/.next/static/webpack/5361cbc07110a7d3.webpack.hot-update.json +0 -1
- package/.next/static/webpack/55648f4af4cd339a.webpack.hot-update.json +0 -1
- package/.next/static/webpack/5592a999a18ce828.webpack.hot-update.json +0 -1
- package/.next/static/webpack/5a1cff97146b50bb.webpack.hot-update.json +0 -1
- package/.next/static/webpack/605a7773ba1d798b.webpack.hot-update.json +0 -1
- package/.next/static/webpack/60b6b08662112fd8.webpack.hot-update.json +0 -1
- package/.next/static/webpack/660742a3b5333202.webpack.hot-update.json +0 -1
- package/.next/static/webpack/68289df254bc1101.webpack.hot-update.json +0 -1
- package/.next/static/webpack/6965c86e8cf1c189.webpack.hot-update.json +0 -1
- package/.next/static/webpack/6ee5f39e8d123868.webpack.hot-update.json +0 -1
- package/.next/static/webpack/77e53aa0ed10b537.webpack.hot-update.json +0 -1
- package/.next/static/webpack/79fe8ba93a0b810b.webpack.hot-update.json +0 -1
- package/.next/static/webpack/7bb361b5246e77d2.webpack.hot-update.json +0 -1
- package/.next/static/webpack/7d5deda3951c8e99.webpack.hot-update.json +0 -1
- package/.next/static/webpack/7dd58225de2c96b1.webpack.hot-update.json +0 -1
- package/.next/static/webpack/7e9ea68e1248f8c4.webpack.hot-update.json +0 -1
- package/.next/static/webpack/8635c08a046e0cc3.webpack.hot-update.json +0 -1
- package/.next/static/webpack/8b5b5419d114117b.webpack.hot-update.json +0 -1
- package/.next/static/webpack/912fdb75a65577d9.webpack.hot-update.json +0 -1
- package/.next/static/webpack/9211406c39b8c7d6.webpack.hot-update.json +0 -1
- package/.next/static/webpack/954c98691962cd98.webpack.hot-update.json +0 -1
- package/.next/static/webpack/973f3512b11e3d54.webpack.hot-update.json +0 -1
- package/.next/static/webpack/97dcbdd43d9b0185.webpack.hot-update.json +0 -1
- package/.next/static/webpack/98ceb1d86c3608da.webpack.hot-update.json +0 -1
- package/.next/static/webpack/9c321599ae8772f6.webpack.hot-update.json +0 -1
- package/.next/static/webpack/9e012937cc8b78c3.webpack.hot-update.json +0 -1
- package/.next/static/webpack/9f1faeb236a539a7.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a09fb847fbd6c830.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a32ac07f1f02ef92.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a3b2da5299326aea.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a40ddad54b6bc90e.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a495282bd4f45272.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a6280d0500ceb91c.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a81d8481ae8f1db5.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a8d577cb610891a6.webpack.hot-update.json +0 -1
- package/.next/static/webpack/a8e05348c0e655b9.webpack.hot-update.json +0 -1
- package/.next/static/webpack/app/layout.255312d1130cf6ec.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.2813c5d79542e32e.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.2b7d71482ca7a5b0.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.31b91c765347fb55.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.32e5c09644d13662.hot-update.js +0 -32
- package/.next/static/webpack/app/layout.33df40926ef177b8.hot-update.js +0 -21
- package/.next/static/webpack/app/layout.343e03d8261d3d56.hot-update.js +0 -32
- package/.next/static/webpack/app/layout.3fffc4287d1af227.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.5a1cff97146b50bb.hot-update.js +0 -21
- package/.next/static/webpack/app/layout.660742a3b5333202.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.7dd58225de2c96b1.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.7e9ea68e1248f8c4.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.9211406c39b8c7d6.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.954c98691962cd98.hot-update.js +0 -21
- package/.next/static/webpack/app/layout.a09fb847fbd6c830.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.a495282bd4f45272.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.a6280d0500ceb91c.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.a8d577cb610891a6.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.a8e05348c0e655b9.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.c6e67d2545c174a8.hot-update.js +0 -21
- package/.next/static/webpack/app/layout.dcebba06ee4c3470.hot-update.js +0 -31
- package/.next/static/webpack/app/layout.df471031cb4836a9.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.e7d9eed4488f9850.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.eb00615f06d96185.hot-update.js +0 -22
- package/.next/static/webpack/app/layout.f678ffea2e9fb9a3.hot-update.js +0 -32
- package/.next/static/webpack/app/layout.fa81cc9e0039618f.hot-update.js +0 -22
- package/.next/static/webpack/app/page.03ee13d215584d59.hot-update.js +0 -32
- package/.next/static/webpack/app/page.05e804a9c98d6744.hot-update.js +0 -32
- package/.next/static/webpack/app/page.09b6bf9d551718e6.hot-update.js +0 -32
- package/.next/static/webpack/app/page.1c4c3e518f810365.hot-update.js +0 -22
- package/.next/static/webpack/app/page.1dc8bb4faa862342.hot-update.js +0 -22
- package/.next/static/webpack/app/page.217f0b5265f56be2.hot-update.js +0 -22
- package/.next/static/webpack/app/page.21d00cb457913b06.hot-update.js +0 -22
- package/.next/static/webpack/app/page.28ebfaec609673ec.hot-update.js +0 -22
- package/.next/static/webpack/app/page.31b91c765347fb55.hot-update.js +0 -22
- package/.next/static/webpack/app/page.3d336feedc5241cc.hot-update.js +0 -22
- package/.next/static/webpack/app/page.3de1fe8a6a590578.hot-update.js +0 -22
- package/.next/static/webpack/app/page.511251a6a8797ede.hot-update.js +0 -21
- package/.next/static/webpack/app/page.5361cbc07110a7d3.hot-update.js +0 -22
- package/.next/static/webpack/app/page.55648f4af4cd339a.hot-update.js +0 -22
- package/.next/static/webpack/app/page.605a7773ba1d798b.hot-update.js +0 -32
- package/.next/static/webpack/app/page.60b6b08662112fd8.hot-update.js +0 -22
- package/.next/static/webpack/app/page.68289df254bc1101.hot-update.js +0 -22
- package/.next/static/webpack/app/page.6965c86e8cf1c189.hot-update.js +0 -22
- package/.next/static/webpack/app/page.6ee5f39e8d123868.hot-update.js +0 -22
- package/.next/static/webpack/app/page.79fe8ba93a0b810b.hot-update.js +0 -22
- package/.next/static/webpack/app/page.7bb361b5246e77d2.hot-update.js +0 -1436
- package/.next/static/webpack/app/page.7d5deda3951c8e99.hot-update.js +0 -22
- package/.next/static/webpack/app/page.8635c08a046e0cc3.hot-update.js +0 -22
- package/.next/static/webpack/app/page.912fdb75a65577d9.hot-update.js +0 -22
- package/.next/static/webpack/app/page.954c98691962cd98.hot-update.js +0 -22
- package/.next/static/webpack/app/page.9c321599ae8772f6.hot-update.js +0 -22
- package/.next/static/webpack/app/page.9f1faeb236a539a7.hot-update.js +0 -22
- package/.next/static/webpack/app/page.a32ac07f1f02ef92.hot-update.js +0 -22
- package/.next/static/webpack/app/page.a40ddad54b6bc90e.hot-update.js +0 -22
- package/.next/static/webpack/app/page.a81d8481ae8f1db5.hot-update.js +0 -22
- package/.next/static/webpack/app/page.a8e05348c0e655b9.hot-update.js +0 -22
- package/.next/static/webpack/app/page.b03ecf92b407ff16.hot-update.js +0 -22
- package/.next/static/webpack/app/page.cb073814fceeab04.hot-update.js +0 -22
- package/.next/static/webpack/app/page.cb900b98801a8b71.hot-update.js +0 -22
- package/.next/static/webpack/app/page.ce5481dea825fd10.hot-update.js +0 -22
- package/.next/static/webpack/app/page.dc647358f2db4ecb.hot-update.js +0 -22
- package/.next/static/webpack/app/page.df471031cb4836a9.hot-update.js +0 -22
- package/.next/static/webpack/app/page.e7d9eed4488f9850.hot-update.js +0 -22
- package/.next/static/webpack/app/page.ed88e0eaa00d7b0d.hot-update.js +0 -22
- package/.next/static/webpack/app/page.f237070410740d3e.hot-update.js +0 -22
- package/.next/static/webpack/app/page.f8210ae9a27d9415.hot-update.js +0 -22
- package/.next/static/webpack/app/page.f8cf2c2ac33a1f08.hot-update.js +0 -22
- package/.next/static/webpack/app/page.f92b6717ea88db27.hot-update.js +0 -22
- package/.next/static/webpack/app/page.fa81cc9e0039618f.hot-update.js +0 -22
- package/.next/static/webpack/app/page.facf69ec54a9c1ea.hot-update.js +0 -22
- package/.next/static/webpack/app/page.fbec410876605123.hot-update.js +0 -22
- package/.next/static/webpack/app-pages-internals.98ceb1d86c3608da.hot-update.js +0 -186
- package/.next/static/webpack/app-pages-internals.dcebba06ee4c3470.hot-update.js +0 -21
- package/.next/static/webpack/b03ecf92b407ff16.webpack.hot-update.json +0 -1
- package/.next/static/webpack/c6e67d2545c174a8.webpack.hot-update.json +0 -1
- package/.next/static/webpack/cb073814fceeab04.webpack.hot-update.json +0 -1
- package/.next/static/webpack/cb900b98801a8b71.webpack.hot-update.json +0 -1
- package/.next/static/webpack/ce5481dea825fd10.webpack.hot-update.json +0 -1
- package/.next/static/webpack/dc647358f2db4ecb.webpack.hot-update.json +0 -1
- package/.next/static/webpack/dcebba06ee4c3470.webpack.hot-update.json +0 -1
- package/.next/static/webpack/df471031cb4836a9.webpack.hot-update.json +0 -1
- package/.next/static/webpack/e7d9eed4488f9850.webpack.hot-update.json +0 -1
- package/.next/static/webpack/eb00615f06d96185.webpack.hot-update.json +0 -1
- package/.next/static/webpack/ed88e0eaa00d7b0d.webpack.hot-update.json +0 -1
- package/.next/static/webpack/f237070410740d3e.webpack.hot-update.json +0 -1
- package/.next/static/webpack/f678ffea2e9fb9a3.webpack.hot-update.json +0 -1
- package/.next/static/webpack/f8210ae9a27d9415.webpack.hot-update.json +0 -1
- package/.next/static/webpack/f8cf2c2ac33a1f08.webpack.hot-update.json +0 -1
- package/.next/static/webpack/f92b6717ea88db27.webpack.hot-update.json +0 -1
- package/.next/static/webpack/fa81cc9e0039618f.webpack.hot-update.json +0 -1
- package/.next/static/webpack/facf69ec54a9c1ea.webpack.hot-update.json +0 -1
- package/.next/static/webpack/fbec410876605123.webpack.hot-update.json +0 -1
- package/.next/static/webpack/webpack.03ee13d215584d59.hot-update.js +0 -18
- package/.next/static/webpack/webpack.09b6bf9d551718e6.hot-update.js +0 -18
- package/.next/static/webpack/webpack.19bfc21a985c41a3.hot-update.js +0 -18
- package/.next/static/webpack/webpack.1c4c3e518f810365.hot-update.js +0 -18
- package/.next/static/webpack/webpack.1dc8bb4faa862342.hot-update.js +0 -18
- package/.next/static/webpack/webpack.217f0b5265f56be2.hot-update.js +0 -18
- package/.next/static/webpack/webpack.21d00cb457913b06.hot-update.js +0 -18
- package/.next/static/webpack/webpack.255312d1130cf6ec.hot-update.js +0 -18
- package/.next/static/webpack/webpack.2813c5d79542e32e.hot-update.js +0 -18
- package/.next/static/webpack/webpack.28ebfaec609673ec.hot-update.js +0 -18
- package/.next/static/webpack/webpack.2b7d71482ca7a5b0.hot-update.js +0 -18
- package/.next/static/webpack/webpack.300fc5b668ca0906.hot-update.js +0 -18
- package/.next/static/webpack/webpack.31b91c765347fb55.hot-update.js +0 -18
- package/.next/static/webpack/webpack.32e5c09644d13662.hot-update.js +0 -18
- package/.next/static/webpack/webpack.33df40926ef177b8.hot-update.js +0 -18
- package/.next/static/webpack/webpack.343e03d8261d3d56.hot-update.js +0 -18
- package/.next/static/webpack/webpack.3d336feedc5241cc.hot-update.js +0 -18
- package/.next/static/webpack/webpack.3de1fe8a6a590578.hot-update.js +0 -18
- package/.next/static/webpack/webpack.3fffc4287d1af227.hot-update.js +0 -18
- package/.next/static/webpack/webpack.511251a6a8797ede.hot-update.js +0 -18
- package/.next/static/webpack/webpack.5361cbc07110a7d3.hot-update.js +0 -18
- package/.next/static/webpack/webpack.55648f4af4cd339a.hot-update.js +0 -18
- package/.next/static/webpack/webpack.5592a999a18ce828.hot-update.js +0 -18
- package/.next/static/webpack/webpack.5a1cff97146b50bb.hot-update.js +0 -18
- package/.next/static/webpack/webpack.605a7773ba1d798b.hot-update.js +0 -18
- package/.next/static/webpack/webpack.60b6b08662112fd8.hot-update.js +0 -18
- package/.next/static/webpack/webpack.660742a3b5333202.hot-update.js +0 -18
- package/.next/static/webpack/webpack.68289df254bc1101.hot-update.js +0 -18
- package/.next/static/webpack/webpack.6965c86e8cf1c189.hot-update.js +0 -18
- package/.next/static/webpack/webpack.6ee5f39e8d123868.hot-update.js +0 -18
- package/.next/static/webpack/webpack.77e53aa0ed10b537.hot-update.js +0 -18
- package/.next/static/webpack/webpack.79fe8ba93a0b810b.hot-update.js +0 -18
- package/.next/static/webpack/webpack.7bb361b5246e77d2.hot-update.js +0 -18
- package/.next/static/webpack/webpack.7d5deda3951c8e99.hot-update.js +0 -18
- package/.next/static/webpack/webpack.7dd58225de2c96b1.hot-update.js +0 -18
- package/.next/static/webpack/webpack.7e9ea68e1248f8c4.hot-update.js +0 -18
- package/.next/static/webpack/webpack.8635c08a046e0cc3.hot-update.js +0 -18
- package/.next/static/webpack/webpack.8b5b5419d114117b.hot-update.js +0 -18
- package/.next/static/webpack/webpack.912fdb75a65577d9.hot-update.js +0 -18
- package/.next/static/webpack/webpack.9211406c39b8c7d6.hot-update.js +0 -18
- package/.next/static/webpack/webpack.954c98691962cd98.hot-update.js +0 -18
- package/.next/static/webpack/webpack.973f3512b11e3d54.hot-update.js +0 -18
- package/.next/static/webpack/webpack.97dcbdd43d9b0185.hot-update.js +0 -18
- package/.next/static/webpack/webpack.98ceb1d86c3608da.hot-update.js +0 -18
- package/.next/static/webpack/webpack.9c321599ae8772f6.hot-update.js +0 -18
- package/.next/static/webpack/webpack.9e012937cc8b78c3.hot-update.js +0 -18
- package/.next/static/webpack/webpack.9f1faeb236a539a7.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a09fb847fbd6c830.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a32ac07f1f02ef92.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a3b2da5299326aea.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a40ddad54b6bc90e.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a495282bd4f45272.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a6280d0500ceb91c.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a81d8481ae8f1db5.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a8d577cb610891a6.hot-update.js +0 -18
- package/.next/static/webpack/webpack.a8e05348c0e655b9.hot-update.js +0 -18
- package/.next/static/webpack/webpack.b03ecf92b407ff16.hot-update.js +0 -18
- package/.next/static/webpack/webpack.c6e67d2545c174a8.hot-update.js +0 -18
- package/.next/static/webpack/webpack.cb073814fceeab04.hot-update.js +0 -18
- package/.next/static/webpack/webpack.cb900b98801a8b71.hot-update.js +0 -18
- package/.next/static/webpack/webpack.ce5481dea825fd10.hot-update.js +0 -18
- package/.next/static/webpack/webpack.dc647358f2db4ecb.hot-update.js +0 -18
- package/.next/static/webpack/webpack.dcebba06ee4c3470.hot-update.js +0 -18
- package/.next/static/webpack/webpack.df471031cb4836a9.hot-update.js +0 -18
- package/.next/static/webpack/webpack.e7d9eed4488f9850.hot-update.js +0 -18
- package/.next/static/webpack/webpack.eb00615f06d96185.hot-update.js +0 -18
- package/.next/static/webpack/webpack.ed88e0eaa00d7b0d.hot-update.js +0 -18
- package/.next/static/webpack/webpack.f237070410740d3e.hot-update.js +0 -18
- package/.next/static/webpack/webpack.f678ffea2e9fb9a3.hot-update.js +0 -18
- package/.next/static/webpack/webpack.f8210ae9a27d9415.hot-update.js +0 -18
- package/.next/static/webpack/webpack.f8cf2c2ac33a1f08.hot-update.js +0 -18
- package/.next/static/webpack/webpack.f92b6717ea88db27.hot-update.js +0 -18
- package/.next/static/webpack/webpack.fa81cc9e0039618f.hot-update.js +0 -18
- package/.next/static/webpack/webpack.facf69ec54a9c1ea.hot-update.js +0 -18
- package/.next/static/webpack/webpack.fbec410876605123.hot-update.js +0 -18
- /package/.next/static/webpack/{255312d1130cf6ec.webpack.hot-update.json → 068fbf99e4cd8b82.webpack.hot-update.json} +0 -0
@@ -146,7 +146,7 @@ eval(__webpack_require__.ts("/* __next_internal_client_entry_do_not_use__ cjs *
|
|
146
146
|
/***/ ((module, exports, __webpack_require__) => {
|
147
147
|
|
148
148
|
"use strict";
|
149
|
-
eval(__webpack_require__.ts("/* __next_internal_client_entry_do_not_use__ cjs */ \nObject.defineProperty(exports, \"__esModule\", ({\n value: true\n}));\nObject.defineProperty(exports, \"default\", ({\n enumerable: true,\n get: function() {\n return OuterLayoutRouter;\n }\n}));\nconst _interop_require_default = __webpack_require__(/*! @swc/helpers/_/_interop_require_default */ \"(app-pages-browser)/./node_modules/@swc/helpers/esm/_interop_require_default.js\");\nconst _interop_require_wildcard = __webpack_require__(/*! @swc/helpers/_/_interop_require_wildcard */ \"(app-pages-browser)/./node_modules/@swc/helpers/esm/_interop_require_wildcard.js\");\nconst _jsxruntime = __webpack_require__(/*! react/jsx-runtime */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/jsx-runtime.js\");\nconst _react = /*#__PURE__*/ _interop_require_wildcard._(__webpack_require__(/*! react */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/index.js\"));\nconst _reactdom = /*#__PURE__*/ _interop_require_default._(__webpack_require__(/*! react-dom */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react-dom/index.js\"));\nconst _approutercontextsharedruntime = __webpack_require__(/*! ../../shared/lib/app-router-context.shared-runtime */ \"(app-pages-browser)/./node_modules/next/dist/shared/lib/app-router-context.shared-runtime.js\");\nconst _fetchserverresponse = __webpack_require__(/*! ./router-reducer/fetch-server-response */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/fetch-server-response.js\");\nconst _unresolvedthenable = __webpack_require__(/*! ./unresolved-thenable */ \"(app-pages-browser)/./node_modules/next/dist/client/components/unresolved-thenable.js\");\nconst _errorboundary = __webpack_require__(/*! ./error-boundary */ \"(app-pages-browser)/./node_modules/next/dist/client/components/error-boundary.js\");\nconst _matchsegments = __webpack_require__(/*! ./match-segments */ \"(app-pages-browser)/./node_modules/next/dist/client/components/match-segments.js\");\nconst _handlesmoothscroll = __webpack_require__(/*! ../../shared/lib/router/utils/handle-smooth-scroll */ \"(app-pages-browser)/./node_modules/next/dist/shared/lib/router/utils/handle-smooth-scroll.js\");\nconst _redirectboundary = __webpack_require__(/*! ./redirect-boundary */ \"(app-pages-browser)/./node_modules/next/dist/client/components/redirect-boundary.js\");\nconst _notfoundboundary = __webpack_require__(/*! ./not-found-boundary */ \"(app-pages-browser)/./node_modules/next/dist/client/components/not-found-boundary.js\");\nconst _getsegmentvalue = __webpack_require__(/*! ./router-reducer/reducers/get-segment-value */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/reducers/get-segment-value.js\");\nconst _createroutercachekey = __webpack_require__(/*! ./router-reducer/create-router-cache-key */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/create-router-cache-key.js\");\nconst _hasinterceptionrouteincurrenttree = __webpack_require__(/*! ./router-reducer/reducers/has-interception-route-in-current-tree */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/reducers/has-interception-route-in-current-tree.js\");\n/**\n * Add refetch marker to router state at the point of the current layout segment.\n * This ensures the response returned is not further down than the current layout segment.\n */ function walkAddRefetch(segmentPathToWalk, treeToRecreate) {\n if (segmentPathToWalk) {\n const [segment, parallelRouteKey] = segmentPathToWalk;\n const isLast = segmentPathToWalk.length === 2;\n if ((0, _matchsegments.matchSegment)(treeToRecreate[0], segment)) {\n if (treeToRecreate[1].hasOwnProperty(parallelRouteKey)) {\n if (isLast) {\n const subTree = walkAddRefetch(undefined, treeToRecreate[1][parallelRouteKey]);\n return [\n treeToRecreate[0],\n {\n ...treeToRecreate[1],\n [parallelRouteKey]: [\n subTree[0],\n subTree[1],\n subTree[2],\n 'refetch'\n ]\n }\n ];\n }\n return [\n treeToRecreate[0],\n {\n ...treeToRecreate[1],\n [parallelRouteKey]: walkAddRefetch(segmentPathToWalk.slice(2), treeToRecreate[1][parallelRouteKey])\n }\n ];\n }\n }\n }\n return treeToRecreate;\n}\nconst __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE = _reactdom.default.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;\n// TODO-APP: Replace with new React API for finding dom nodes without a `ref` when available\n/**\n * Wraps ReactDOM.findDOMNode with additional logic to hide React Strict Mode warning\n */ function findDOMNode(instance) {\n // Tree-shake for server bundle\n if (typeof window === 'undefined') return null;\n // __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode is null during module init.\n // We need to lazily reference it.\n const internal_reactDOMfindDOMNode = __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode;\n return internal_reactDOMfindDOMNode(instance);\n}\nconst rectProperties = [\n 'bottom',\n 'height',\n 'left',\n 'right',\n 'top',\n 'width',\n 'x',\n 'y'\n];\n/**\n * Check if a HTMLElement is hidden or fixed/sticky position\n */ function shouldSkipElement(element) {\n // we ignore fixed or sticky positioned elements since they'll likely pass the \"in-viewport\" check\n // and will result in a situation we bail on scroll because of something like a fixed nav,\n // even though the actual page content is offscreen\n if ([\n 'sticky',\n 'fixed'\n ].includes(getComputedStyle(element).position)) {\n if (true) {\n console.warn('Skipping auto-scroll behavior due to `position: sticky` or `position: fixed` on element:', element);\n }\n return true;\n }\n // Uses `getBoundingClientRect` to check if the element is hidden instead of `offsetParent`\n // because `offsetParent` doesn't consider document/body\n const rect = element.getBoundingClientRect();\n return rectProperties.every((item)=>rect[item] === 0);\n}\n/**\n * Check if the top corner of the HTMLElement is in the viewport.\n */ function topOfElementInViewport(element, viewportHeight) {\n const rect = element.getBoundingClientRect();\n return rect.top >= 0 && rect.top <= viewportHeight;\n}\n/**\n * Find the DOM node for a hash fragment.\n * If `top` the page has to scroll to the top of the page. This mirrors the browser's behavior.\n * If the hash fragment is an id, the page has to scroll to the element with that id.\n * If the hash fragment is a name, the page has to scroll to the first element with that name.\n */ function getHashFragmentDomNode(hashFragment) {\n // If the hash fragment is `top` the page has to scroll to the top of the page.\n if (hashFragment === 'top') {\n return document.body;\n }\n var _document_getElementById;\n // If the hash fragment is an id, the page has to scroll to the element with that id.\n return (_document_getElementById = document.getElementById(hashFragment)) != null ? _document_getElementById : document.getElementsByName(hashFragment)[0];\n}\nclass InnerScrollAndFocusHandler extends _react.default.Component {\n componentDidMount() {\n this.handlePotentialScroll();\n }\n componentDidUpdate() {\n // Because this property is overwritten in handlePotentialScroll it's fine to always run it when true as it'll be set to false for subsequent renders.\n if (this.props.focusAndScrollRef.apply) {\n this.handlePotentialScroll();\n }\n }\n render() {\n return this.props.children;\n }\n constructor(...args){\n super(...args);\n this.handlePotentialScroll = ()=>{\n // Handle scroll and focus, it's only applied once in the first useEffect that triggers that changed.\n const { focusAndScrollRef, segmentPath } = this.props;\n if (focusAndScrollRef.apply) {\n // segmentPaths is an array of segment paths that should be scrolled to\n // if the current segment path is not in the array, the scroll is not applied\n // unless the array is empty, in which case the scroll is always applied\n if (focusAndScrollRef.segmentPaths.length !== 0 && !focusAndScrollRef.segmentPaths.some((scrollRefSegmentPath)=>segmentPath.every((segment, index)=>(0, _matchsegments.matchSegment)(segment, scrollRefSegmentPath[index])))) {\n return;\n }\n let domNode = null;\n const hashFragment = focusAndScrollRef.hashFragment;\n if (hashFragment) {\n domNode = getHashFragmentDomNode(hashFragment);\n }\n // `findDOMNode` is tricky because it returns just the first child if the component is a fragment.\n // This already caused a bug where the first child was a <link/> in head.\n if (!domNode) {\n domNode = findDOMNode(this);\n }\n // If there is no DOM node this layout-router level is skipped. It'll be handled higher-up in the tree.\n if (!(domNode instanceof Element)) {\n return;\n }\n // Verify if the element is a HTMLElement and if we want to consider it for scroll behavior.\n // If the element is skipped, try to select the next sibling and try again.\n while(!(domNode instanceof HTMLElement) || shouldSkipElement(domNode)){\n // No siblings found that match the criteria are found, so handle scroll higher up in the tree instead.\n if (domNode.nextElementSibling === null) {\n return;\n }\n domNode = domNode.nextElementSibling;\n }\n // State is mutated to ensure that the focus and scroll is applied only once.\n focusAndScrollRef.apply = false;\n focusAndScrollRef.hashFragment = null;\n focusAndScrollRef.segmentPaths = [];\n (0, _handlesmoothscroll.handleSmoothScroll)(()=>{\n // In case of hash scroll, we only need to scroll the element into view\n if (hashFragment) {\n domNode.scrollIntoView();\n return;\n }\n // Store the current viewport height because reading `clientHeight` causes a reflow,\n // and it won't change during this function.\n const htmlElement = document.documentElement;\n const viewportHeight = htmlElement.clientHeight;\n // If the element's top edge is already in the viewport, exit early.\n if (topOfElementInViewport(domNode, viewportHeight)) {\n return;\n }\n // Otherwise, try scrolling go the top of the document to be backward compatible with pages\n // scrollIntoView() called on `<html/>` element scrolls horizontally on chrome and firefox (that shouldn't happen)\n // We could use it to scroll horizontally following RTL but that also seems to be broken - it will always scroll left\n // scrollLeft = 0 also seems to ignore RTL and manually checking for RTL is too much hassle so we will scroll just vertically\n htmlElement.scrollTop = 0;\n // Scroll to domNode if domNode is not in viewport when scrolled to top of document\n if (!topOfElementInViewport(domNode, viewportHeight)) {\n domNode.scrollIntoView();\n }\n }, {\n // We will force layout by querying domNode position\n dontForceLayout: true,\n onlyHashChange: focusAndScrollRef.onlyHashChange\n });\n // Mutate after scrolling so that it can be read by `handleSmoothScroll`\n focusAndScrollRef.onlyHashChange = false;\n // Set focus on the element\n domNode.focus();\n }\n };\n }\n}\nfunction ScrollAndFocusHandler(param) {\n let { segmentPath, children } = param;\n const context = (0, _react.useContext)(_approutercontextsharedruntime.GlobalLayoutRouterContext);\n if (!context) {\n throw new Error('invariant global layout router not mounted');\n }\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(InnerScrollAndFocusHandler, {\n segmentPath: segmentPath,\n focusAndScrollRef: context.focusAndScrollRef,\n children: children\n });\n}\n_c = ScrollAndFocusHandler;\n/**\n * InnerLayoutRouter handles rendering the provided segment based on the cache.\n */ function InnerLayoutRouter(param) {\n let { parallelRouterKey, url, childNodes, segmentPath, tree, // isActive,\n cacheKey } = param;\n const context = (0, _react.useContext)(_approutercontextsharedruntime.GlobalLayoutRouterContext);\n if (!context) {\n throw new Error('invariant global layout router not mounted');\n }\n const { buildId, changeByServerResponse, tree: fullTree } = context;\n // Read segment path from the parallel router cache node.\n let childNode = childNodes.get(cacheKey);\n // When data is not available during rendering client-side we need to fetch\n // it from the server.\n if (childNode === undefined) {\n const newLazyCacheNode = {\n lazyData: null,\n rsc: null,\n prefetchRsc: null,\n head: null,\n prefetchHead: null,\n parallelRoutes: new Map(),\n loading: null\n };\n /**\n * Flight data fetch kicked off during render and put into the cache.\n */ childNode = newLazyCacheNode;\n childNodes.set(cacheKey, newLazyCacheNode);\n }\n // `rsc` represents the renderable node for this segment.\n // If this segment has a `prefetchRsc`, it's the statically prefetched data.\n // We should use that on initial render instead of `rsc`. Then we'll switch\n // to `rsc` when the dynamic response streams in.\n //\n // If no prefetch data is available, then we go straight to rendering `rsc`.\n const resolvedPrefetchRsc = childNode.prefetchRsc !== null ? childNode.prefetchRsc : childNode.rsc;\n // We use `useDeferredValue` to handle switching between the prefetched and\n // final values. The second argument is returned on initial render, then it\n // re-renders with the first argument.\n //\n // @ts-expect-error The second argument to `useDeferredValue` is only\n // available in the experimental builds. When its disabled, it will always\n // return `rsc`.\n const rsc = (0, _react.useDeferredValue)(childNode.rsc, resolvedPrefetchRsc);\n // `rsc` is either a React node or a promise for a React node, except we\n // special case `null` to represent that this segment's data is missing. If\n // it's a promise, we need to unwrap it so we can determine whether or not the\n // data is missing.\n const resolvedRsc = typeof rsc === 'object' && rsc !== null && typeof rsc.then === 'function' ? (0, _react.use)(rsc) : rsc;\n if (!resolvedRsc) {\n // The data for this segment is not available, and there's no pending\n // navigation that will be able to fulfill it. We need to fetch more from\n // the server and patch the cache.\n // Check if there's already a pending request.\n let lazyData = childNode.lazyData;\n if (lazyData === null) {\n /**\n * Router state with refetch marker added\n */ // TODO-APP: remove ''\n const refetchTree = walkAddRefetch([\n '',\n ...segmentPath\n ], fullTree);\n const includeNextUrl = (0, _hasinterceptionrouteincurrenttree.hasInterceptionRouteInCurrentTree)(fullTree);\n childNode.lazyData = lazyData = (0, _fetchserverresponse.fetchServerResponse)(new URL(url, location.origin), {\n flightRouterState: refetchTree,\n nextUrl: includeNextUrl ? context.nextUrl : null,\n buildId\n }).then((serverResponse)=>{\n (0, _react.startTransition)(()=>{\n changeByServerResponse({\n previousTree: fullTree,\n serverResponse\n });\n });\n return serverResponse;\n });\n }\n // Suspend infinitely as `changeByServerResponse` will cause a different part of the tree to be rendered.\n // A falsey `resolvedRsc` indicates missing data -- we should not commit that branch, and we need to wait for the data to arrive.\n (0, _react.use)(_unresolvedthenable.unresolvedThenable);\n }\n // If we get to this point, then we know we have something we can render.\n const subtree = /*#__PURE__*/ (0, _jsxruntime.jsx)(_approutercontextsharedruntime.LayoutRouterContext.Provider, {\n value: {\n tree: tree[1][parallelRouterKey],\n childNodes: childNode.parallelRoutes,\n // TODO-APP: overriding of url for parallel routes\n url: url,\n loading: childNode.loading\n },\n children: resolvedRsc\n });\n // Ensure root layout is not wrapped in a div as the root layout renders `<html>`\n return subtree;\n}\n_c1 = InnerLayoutRouter;\n/**\n * Renders suspense boundary with the provided \"loading\" property as the fallback.\n * If no loading property is provided it renders the children without a suspense boundary.\n */ function LoadingBoundary(param) {\n let { children, hasLoading, loading, loadingStyles, loadingScripts } = param;\n // We have an explicit prop for checking if `loading` is provided, to disambiguate between a loading\n // component that returns `null` / `undefined`, vs not having a loading component at all.\n if (hasLoading) {\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(_react.Suspense, {\n fallback: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\n children: [\n loadingStyles,\n loadingScripts,\n loading\n ]\n }),\n children: children\n });\n }\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(_jsxruntime.Fragment, {\n children: children\n });\n}\n_c2 = LoadingBoundary;\nfunction OuterLayoutRouter(param) {\n let { parallelRouterKey, segmentPath, error, errorStyles, errorScripts, templateStyles, templateScripts, template, notFound, notFoundStyles } = param;\n const context = (0, _react.useContext)(_approutercontextsharedruntime.LayoutRouterContext);\n if (!context) {\n throw new Error('invariant expected layout router to be mounted');\n }\n const { childNodes, tree, url, loading } = context;\n // Get the current parallelRouter cache node\n let childNodesForParallelRouter = childNodes.get(parallelRouterKey);\n // If the parallel router cache node does not exist yet, create it.\n // This writes to the cache when there is no item in the cache yet. It never *overwrites* existing cache items which is why it's safe in concurrent mode.\n if (!childNodesForParallelRouter) {\n childNodesForParallelRouter = new Map();\n childNodes.set(parallelRouterKey, childNodesForParallelRouter);\n }\n // Get the active segment in the tree\n // The reason arrays are used in the data format is that these are transferred from the server to the browser so it's optimized to save bytes.\n const treeSegment = tree[1][parallelRouterKey][0];\n // If segment is an array it's a dynamic route and we want to read the dynamic route value as the segment to get from the cache.\n const currentChildSegmentValue = (0, _getsegmentvalue.getSegmentValue)(treeSegment);\n /**\n * Decides which segments to keep rendering, all segments that are not active will be wrapped in `<Offscreen>`.\n */ // TODO-APP: Add handling of `<Offscreen>` when it's available.\n const preservedSegments = [\n treeSegment\n ];\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(_jsxruntime.Fragment, {\n children: preservedSegments.map((preservedSegment)=>{\n const preservedSegmentValue = (0, _getsegmentvalue.getSegmentValue)(preservedSegment);\n const cacheKey = (0, _createroutercachekey.createRouterCacheKey)(preservedSegment);\n return(/*\n - Error boundary\n - Only renders error boundary if error component is provided.\n - Rendered for each segment to ensure they have their own error state.\n - Loading boundary\n - Only renders suspense boundary if loading components is provided.\n - Rendered for each segment to ensure they have their own loading state.\n - Passed to the router during rendering to ensure it can be immediately rendered when suspending on a Flight fetch.\n */ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_approutercontextsharedruntime.TemplateContext.Provider, {\n value: /*#__PURE__*/ (0, _jsxruntime.jsx)(ScrollAndFocusHandler, {\n segmentPath: segmentPath,\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_errorboundary.ErrorBoundary, {\n errorComponent: error,\n errorStyles: errorStyles,\n errorScripts: errorScripts,\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(LoadingBoundary, {\n hasLoading: Boolean(loading),\n loading: loading == null ? void 0 : loading[0],\n loadingStyles: loading == null ? void 0 : loading[1],\n loadingScripts: loading == null ? void 0 : loading[2],\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_notfoundboundary.NotFoundBoundary, {\n notFound: notFound,\n notFoundStyles: notFoundStyles,\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_redirectboundary.RedirectBoundary, {\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(InnerLayoutRouter, {\n parallelRouterKey: parallelRouterKey,\n url: url,\n tree: tree,\n childNodes: childNodesForParallelRouter,\n segmentPath: segmentPath,\n cacheKey: cacheKey,\n isActive: currentChildSegmentValue === preservedSegmentValue\n })\n })\n })\n })\n })\n }),\n children: [\n templateStyles,\n templateScripts,\n template\n ]\n }, (0, _createroutercachekey.createRouterCacheKey)(preservedSegment, true)));\n })\n });\n}\n_c3 = OuterLayoutRouter;\nif ((typeof exports.default === 'function' || typeof exports.default === 'object' && exports.default !== null) && typeof exports.default.__esModule === 'undefined') {\n Object.defineProperty(exports.default, '__esModule', {\n value: true\n });\n Object.assign(exports.default, exports);\n module.exports = exports.default;\n} //# sourceMappingURL=layout-router.js.map\nvar _c, _c1, _c2, _c3;\n$RefreshReg$(_c, \"ScrollAndFocusHandler\");\n$RefreshReg$(_c1, \"InnerLayoutRouter\");\n$RefreshReg$(_c2, \"LoadingBoundary\");\n$RefreshReg$(_c3, \"OuterLayoutRouter\");\n\n\n;\n // Wrapped in an IIFE to avoid polluting the global scope\n ;\n (function () {\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 // @ts-ignore __webpack_module__ is global\n var currentExports = module.exports;\n // @ts-ignore __webpack_module__ is global\n var prevSignature = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevSignature) !== 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 signature on update so we can compare the boundary\n // signatures. We avoid saving exports themselves since it causes memory leaks (https://github.com/vercel/next.js/pull/53797)\n module.hot.dispose(function (data) {\n data.prevSignature =\n self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports);\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n // @ts-ignore importMeta is replaced in the loader\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 (prevSignature !== 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(prevSignature, self.$RefreshHelpers$.getRefreshBoundarySignature(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 = prevSignature !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n })();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(app-pages-browser)/./node_modules/next/dist/client/components/layout-router.js","mappings":"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","sources":["C:\\Users\\Pinesucceed\\src\\client\\components\\layout-router.tsx"],"sourcesContent":["'use client'\n\nimport type {\n  ChildSegmentMap,\n  LazyCacheNode,\n} from '../../shared/lib/app-router-context.shared-runtime'\nimport type {\n  FlightRouterState,\n  FlightSegmentPath,\n  Segment,\n} from '../../server/app-render/types'\nimport type { ErrorComponent } from './error-boundary'\nimport type { FocusAndScrollRef } from './router-reducer/router-reducer-types'\n\nimport React, {\n  useContext,\n  use,\n  startTransition,\n  Suspense,\n  useDeferredValue,\n  type JSX,\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  LayoutRouterContext,\n  GlobalLayoutRouterContext,\n  TemplateContext,\n} from '../../shared/lib/app-router-context.shared-runtime'\nimport { fetchServerResponse } from './router-reducer/fetch-server-response'\nimport { unresolvedThenable } from './unresolved-thenable'\nimport { ErrorBoundary } from './error-boundary'\nimport { matchSegment } from './match-segments'\nimport { handleSmoothScroll } from '../../shared/lib/router/utils/handle-smooth-scroll'\nimport { RedirectBoundary } from './redirect-boundary'\nimport { NotFoundBoundary } from './not-found-boundary'\nimport { getSegmentValue } from './router-reducer/reducers/get-segment-value'\nimport { createRouterCacheKey } from './router-reducer/create-router-cache-key'\nimport { hasInterceptionRouteInCurrentTree } from './router-reducer/reducers/has-interception-route-in-current-tree'\n\n/**\n * Add refetch marker to router state at the point of the current layout segment.\n * This ensures the response returned is not further down than the current layout segment.\n */\nfunction walkAddRefetch(\n  segmentPathToWalk: FlightSegmentPath | undefined,\n  treeToRecreate: FlightRouterState\n): FlightRouterState {\n  if (segmentPathToWalk) {\n    const [segment, parallelRouteKey] = segmentPathToWalk\n    const isLast = segmentPathToWalk.length === 2\n\n    if (matchSegment(treeToRecreate[0], segment)) {\n      if (treeToRecreate[1].hasOwnProperty(parallelRouteKey)) {\n        if (isLast) {\n          const subTree = walkAddRefetch(\n            undefined,\n            treeToRecreate[1][parallelRouteKey]\n          )\n          return [\n            treeToRecreate[0],\n            {\n              ...treeToRecreate[1],\n              [parallelRouteKey]: [\n                subTree[0],\n                subTree[1],\n                subTree[2],\n                'refetch',\n              ],\n            },\n          ]\n        }\n\n        return [\n          treeToRecreate[0],\n          {\n            ...treeToRecreate[1],\n            [parallelRouteKey]: walkAddRefetch(\n              segmentPathToWalk.slice(2),\n              treeToRecreate[1][parallelRouteKey]\n            ),\n          },\n        ]\n      }\n    }\n  }\n\n  return treeToRecreate\n}\n\nconst __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE = (\n  ReactDOM as any\n).__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE\n\n// TODO-APP: Replace with new React API for finding dom nodes without a `ref` when available\n/**\n * Wraps ReactDOM.findDOMNode with additional logic to hide React Strict Mode warning\n */\nfunction findDOMNode(\n  instance: React.ReactInstance | null | undefined\n): Element | Text | null {\n  // Tree-shake for server bundle\n  if (typeof window === 'undefined') return null\n\n  // __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode is null during module init.\n  // We need to lazily reference it.\n  const internal_reactDOMfindDOMNode =\n    __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode\n  return internal_reactDOMfindDOMNode(instance)\n}\n\nconst rectProperties = [\n  'bottom',\n  'height',\n  'left',\n  'right',\n  'top',\n  'width',\n  'x',\n  'y',\n] as const\n/**\n * Check if a HTMLElement is hidden or fixed/sticky position\n */\nfunction shouldSkipElement(element: HTMLElement) {\n  // we ignore fixed or sticky positioned elements since they'll likely pass the \"in-viewport\" check\n  // and will result in a situation we bail on scroll because of something like a fixed nav,\n  // even though the actual page content is offscreen\n  if (['sticky', 'fixed'].includes(getComputedStyle(element).position)) {\n    if (process.env.NODE_ENV === 'development') {\n      console.warn(\n        'Skipping auto-scroll behavior due to `position: sticky` or `position: fixed` on element:',\n        element\n      )\n    }\n    return true\n  }\n\n  // Uses `getBoundingClientRect` to check if the element is hidden instead of `offsetParent`\n  // because `offsetParent` doesn't consider document/body\n  const rect = element.getBoundingClientRect()\n  return rectProperties.every((item) => rect[item] === 0)\n}\n\n/**\n * Check if the top corner of the HTMLElement is in the viewport.\n */\nfunction topOfElementInViewport(element: HTMLElement, viewportHeight: number) {\n  const rect = element.getBoundingClientRect()\n  return rect.top >= 0 && rect.top <= viewportHeight\n}\n\n/**\n * Find the DOM node for a hash fragment.\n * If `top` the page has to scroll to the top of the page. This mirrors the browser's behavior.\n * If the hash fragment is an id, the page has to scroll to the element with that id.\n * If the hash fragment is a name, the page has to scroll to the first element with that name.\n */\nfunction getHashFragmentDomNode(hashFragment: string) {\n  // If the hash fragment is `top` the page has to scroll to the top of the page.\n  if (hashFragment === 'top') {\n    return document.body\n  }\n\n  // If the hash fragment is an id, the page has to scroll to the element with that id.\n  return (\n    document.getElementById(hashFragment) ??\n    // If the hash fragment is a name, the page has to scroll to the first element with that name.\n    document.getElementsByName(hashFragment)[0]\n  )\n}\ninterface ScrollAndFocusHandlerProps {\n  focusAndScrollRef: FocusAndScrollRef\n  children: React.ReactNode\n  segmentPath: FlightSegmentPath\n}\nclass InnerScrollAndFocusHandler extends React.Component<ScrollAndFocusHandlerProps> {\n  handlePotentialScroll = () => {\n    // Handle scroll and focus, it's only applied once in the first useEffect that triggers that changed.\n    const { focusAndScrollRef, segmentPath } = this.props\n\n    if (focusAndScrollRef.apply) {\n      // segmentPaths is an array of segment paths that should be scrolled to\n      // if the current segment path is not in the array, the scroll is not applied\n      // unless the array is empty, in which case the scroll is always applied\n      if (\n        focusAndScrollRef.segmentPaths.length !== 0 &&\n        !focusAndScrollRef.segmentPaths.some((scrollRefSegmentPath) =>\n          segmentPath.every((segment, index) =>\n            matchSegment(segment, scrollRefSegmentPath[index])\n          )\n        )\n      ) {\n        return\n      }\n\n      let domNode:\n        | ReturnType<typeof getHashFragmentDomNode>\n        | ReturnType<typeof findDOMNode> = null\n      const hashFragment = focusAndScrollRef.hashFragment\n\n      if (hashFragment) {\n        domNode = getHashFragmentDomNode(hashFragment)\n      }\n\n      // `findDOMNode` is tricky because it returns just the first child if the component is a fragment.\n      // This already caused a bug where the first child was a <link/> in head.\n      if (!domNode) {\n        domNode = findDOMNode(this)\n      }\n\n      // If there is no DOM node this layout-router level is skipped. It'll be handled higher-up in the tree.\n      if (!(domNode instanceof Element)) {\n        return\n      }\n\n      // Verify if the element is a HTMLElement and if we want to consider it for scroll behavior.\n      // If the element is skipped, try to select the next sibling and try again.\n      while (!(domNode instanceof HTMLElement) || shouldSkipElement(domNode)) {\n        // No siblings found that match the criteria are found, so handle scroll higher up in the tree instead.\n        if (domNode.nextElementSibling === null) {\n          return\n        }\n        domNode = domNode.nextElementSibling\n      }\n\n      // State is mutated to ensure that the focus and scroll is applied only once.\n      focusAndScrollRef.apply = false\n      focusAndScrollRef.hashFragment = null\n      focusAndScrollRef.segmentPaths = []\n\n      handleSmoothScroll(\n        () => {\n          // In case of hash scroll, we only need to scroll the element into view\n          if (hashFragment) {\n            ;(domNode as HTMLElement).scrollIntoView()\n\n            return\n          }\n          // Store the current viewport height because reading `clientHeight` causes a reflow,\n          // and it won't change during this function.\n          const htmlElement = document.documentElement\n          const viewportHeight = htmlElement.clientHeight\n\n          // If the element's top edge is already in the viewport, exit early.\n          if (topOfElementInViewport(domNode as HTMLElement, viewportHeight)) {\n            return\n          }\n\n          // Otherwise, try scrolling go the top of the document to be backward compatible with pages\n          // scrollIntoView() called on `<html/>` element scrolls horizontally on chrome and firefox (that shouldn't happen)\n          // We could use it to scroll horizontally following RTL but that also seems to be broken - it will always scroll left\n          // scrollLeft = 0 also seems to ignore RTL and manually checking for RTL is too much hassle so we will scroll just vertically\n          htmlElement.scrollTop = 0\n\n          // Scroll to domNode if domNode is not in viewport when scrolled to top of document\n          if (!topOfElementInViewport(domNode as HTMLElement, viewportHeight)) {\n            // Scroll into view doesn't scroll horizontally by default when not needed\n            ;(domNode as HTMLElement).scrollIntoView()\n          }\n        },\n        {\n          // We will force layout by querying domNode position\n          dontForceLayout: true,\n          onlyHashChange: focusAndScrollRef.onlyHashChange,\n        }\n      )\n\n      // Mutate after scrolling so that it can be read by `handleSmoothScroll`\n      focusAndScrollRef.onlyHashChange = false\n\n      // Set focus on the element\n      domNode.focus()\n    }\n  }\n\n  componentDidMount() {\n    this.handlePotentialScroll()\n  }\n\n  componentDidUpdate() {\n    // Because this property is overwritten in handlePotentialScroll it's fine to always run it when true as it'll be set to false for subsequent renders.\n    if (this.props.focusAndScrollRef.apply) {\n      this.handlePotentialScroll()\n    }\n  }\n\n  render() {\n    return this.props.children\n  }\n}\n\nfunction ScrollAndFocusHandler({\n  segmentPath,\n  children,\n}: {\n  segmentPath: FlightSegmentPath\n  children: React.ReactNode\n}) {\n  const context = useContext(GlobalLayoutRouterContext)\n  if (!context) {\n    throw new Error('invariant global layout router not mounted')\n  }\n\n  return (\n    <InnerScrollAndFocusHandler\n      segmentPath={segmentPath}\n      focusAndScrollRef={context.focusAndScrollRef}\n    >\n      {children}\n    </InnerScrollAndFocusHandler>\n  )\n}\n\n/**\n * InnerLayoutRouter handles rendering the provided segment based on the cache.\n */\nfunction InnerLayoutRouter({\n  parallelRouterKey,\n  url,\n  childNodes,\n  segmentPath,\n  tree,\n  // TODO-APP: implement `<Offscreen>` when available.\n  // isActive,\n  cacheKey,\n}: {\n  parallelRouterKey: string\n  url: string\n  childNodes: ChildSegmentMap\n  segmentPath: FlightSegmentPath\n  tree: FlightRouterState\n  isActive: boolean\n  cacheKey: ReturnType<typeof createRouterCacheKey>\n}) {\n  const context = useContext(GlobalLayoutRouterContext)\n  if (!context) {\n    throw new Error('invariant global layout router not mounted')\n  }\n\n  const { buildId, changeByServerResponse, tree: fullTree } = context\n\n  // Read segment path from the parallel router cache node.\n  let childNode = childNodes.get(cacheKey)\n\n  // When data is not available during rendering client-side we need to fetch\n  // it from the server.\n  if (childNode === undefined) {\n    const newLazyCacheNode: LazyCacheNode = {\n      lazyData: null,\n      rsc: null,\n      prefetchRsc: null,\n      head: null,\n      prefetchHead: null,\n      parallelRoutes: new Map(),\n      loading: null,\n    }\n\n    /**\n     * Flight data fetch kicked off during render and put into the cache.\n     */\n    childNode = newLazyCacheNode\n    childNodes.set(cacheKey, newLazyCacheNode)\n  }\n\n  // `rsc` represents the renderable node for this segment.\n\n  // If this segment has a `prefetchRsc`, it's the statically prefetched data.\n  // We should use that on initial render instead of `rsc`. Then we'll switch\n  // to `rsc` when the dynamic response streams in.\n  //\n  // If no prefetch data is available, then we go straight to rendering `rsc`.\n  const resolvedPrefetchRsc =\n    childNode.prefetchRsc !== null ? childNode.prefetchRsc : childNode.rsc\n\n  // We use `useDeferredValue` to handle switching between the prefetched and\n  // final values. The second argument is returned on initial render, then it\n  // re-renders with the first argument.\n  //\n  // @ts-expect-error The second argument to `useDeferredValue` is only\n  // available in the experimental builds. When its disabled, it will always\n  // return `rsc`.\n  const rsc: any = useDeferredValue(childNode.rsc, resolvedPrefetchRsc)\n\n  // `rsc` is either a React node or a promise for a React node, except we\n  // special case `null` to represent that this segment's data is missing. If\n  // it's a promise, we need to unwrap it so we can determine whether or not the\n  // data is missing.\n  const resolvedRsc: React.ReactNode =\n    typeof rsc === 'object' && rsc !== null && typeof rsc.then === 'function'\n      ? use(rsc)\n      : rsc\n\n  if (!resolvedRsc) {\n    // The data for this segment is not available, and there's no pending\n    // navigation that will be able to fulfill it. We need to fetch more from\n    // the server and patch the cache.\n\n    // Check if there's already a pending request.\n    let lazyData = childNode.lazyData\n    if (lazyData === null) {\n      /**\n       * Router state with refetch marker added\n       */\n      // TODO-APP: remove ''\n      const refetchTree = walkAddRefetch(['', ...segmentPath], fullTree)\n      const includeNextUrl = hasInterceptionRouteInCurrentTree(fullTree)\n      childNode.lazyData = lazyData = fetchServerResponse(\n        new URL(url, location.origin),\n        {\n          flightRouterState: refetchTree,\n          nextUrl: includeNextUrl ? context.nextUrl : null,\n          buildId,\n        }\n      ).then((serverResponse) => {\n        startTransition(() => {\n          changeByServerResponse({\n            previousTree: fullTree,\n            serverResponse,\n          })\n        })\n\n        return serverResponse\n      })\n    }\n    // Suspend infinitely as `changeByServerResponse` will cause a different part of the tree to be rendered.\n    // A falsey `resolvedRsc` indicates missing data -- we should not commit that branch, and we need to wait for the data to arrive.\n    use(unresolvedThenable) as never\n  }\n\n  // If we get to this point, then we know we have something we can render.\n  const subtree = (\n    // The layout router context narrows down tree and childNodes at each level.\n    <LayoutRouterContext.Provider\n      value={{\n        tree: tree[1][parallelRouterKey],\n        childNodes: childNode.parallelRoutes,\n        // TODO-APP: overriding of url for parallel routes\n        url: url,\n        loading: childNode.loading,\n      }}\n    >\n      {resolvedRsc}\n    </LayoutRouterContext.Provider>\n  )\n  // Ensure root layout is not wrapped in a div as the root layout renders `<html>`\n  return subtree\n}\n\n/**\n * Renders suspense boundary with the provided \"loading\" property as the fallback.\n * If no loading property is provided it renders the children without a suspense boundary.\n */\nfunction LoadingBoundary({\n  children,\n  hasLoading,\n  loading,\n  loadingStyles,\n  loadingScripts,\n}: {\n  children: React.ReactNode\n  hasLoading: boolean\n  loading?: React.ReactNode\n  loadingStyles?: React.ReactNode\n  loadingScripts?: React.ReactNode\n}): JSX.Element {\n  // We have an explicit prop for checking if `loading` is provided, to disambiguate between a loading\n  // component that returns `null` / `undefined`, vs not having a loading component at all.\n  if (hasLoading) {\n    return (\n      <Suspense\n        fallback={\n          <>\n            {loadingStyles}\n            {loadingScripts}\n            {loading}\n          </>\n        }\n      >\n        {children}\n      </Suspense>\n    )\n  }\n\n  return <>{children}</>\n}\n\n/**\n * OuterLayoutRouter handles the current segment as well as <Offscreen> rendering of other segments.\n * It can be rendered next to each other with a different `parallelRouterKey`, allowing for Parallel routes.\n */\nexport default function OuterLayoutRouter({\n  parallelRouterKey,\n  segmentPath,\n  error,\n  errorStyles,\n  errorScripts,\n  templateStyles,\n  templateScripts,\n  template,\n  notFound,\n  notFoundStyles,\n}: {\n  parallelRouterKey: string\n  segmentPath: FlightSegmentPath\n  error: ErrorComponent | undefined\n  errorStyles: React.ReactNode | undefined\n  errorScripts: React.ReactNode | undefined\n  templateStyles: React.ReactNode | undefined\n  templateScripts: React.ReactNode | undefined\n  template: React.ReactNode\n  notFound: React.ReactNode | undefined\n  notFoundStyles: React.ReactNode | undefined\n}) {\n  const context = useContext(LayoutRouterContext)\n  if (!context) {\n    throw new Error('invariant expected layout router to be mounted')\n  }\n\n  const { childNodes, tree, url, loading } = context\n\n  // Get the current parallelRouter cache node\n  let childNodesForParallelRouter = childNodes.get(parallelRouterKey)\n  // If the parallel router cache node does not exist yet, create it.\n  // This writes to the cache when there is no item in the cache yet. It never *overwrites* existing cache items which is why it's safe in concurrent mode.\n  if (!childNodesForParallelRouter) {\n    childNodesForParallelRouter = new Map()\n    childNodes.set(parallelRouterKey, childNodesForParallelRouter)\n  }\n\n  // Get the active segment in the tree\n  // The reason arrays are used in the data format is that these are transferred from the server to the browser so it's optimized to save bytes.\n  const treeSegment = tree[1][parallelRouterKey][0]\n\n  // If segment is an array it's a dynamic route and we want to read the dynamic route value as the segment to get from the cache.\n  const currentChildSegmentValue = getSegmentValue(treeSegment)\n\n  /**\n   * Decides which segments to keep rendering, all segments that are not active will be wrapped in `<Offscreen>`.\n   */\n  // TODO-APP: Add handling of `<Offscreen>` when it's available.\n  const preservedSegments: Segment[] = [treeSegment]\n\n  return (\n    <>\n      {preservedSegments.map((preservedSegment) => {\n        const preservedSegmentValue = getSegmentValue(preservedSegment)\n        const cacheKey = createRouterCacheKey(preservedSegment)\n\n        return (\n          /*\n            - Error boundary\n              - Only renders error boundary if error component is provided.\n              - Rendered for each segment to ensure they have their own error state.\n            - Loading boundary\n              - Only renders suspense boundary if loading components is provided.\n              - Rendered for each segment to ensure they have their own loading state.\n              - Passed to the router during rendering to ensure it can be immediately rendered when suspending on a Flight fetch.\n          */\n          <TemplateContext.Provider\n            key={createRouterCacheKey(preservedSegment, true)}\n            value={\n              <ScrollAndFocusHandler segmentPath={segmentPath}>\n                <ErrorBoundary\n                  errorComponent={error}\n                  errorStyles={errorStyles}\n                  errorScripts={errorScripts}\n                >\n                  <LoadingBoundary\n                    hasLoading={Boolean(loading)}\n                    loading={loading?.[0]}\n                    loadingStyles={loading?.[1]}\n                    loadingScripts={loading?.[2]}\n                  >\n                    <NotFoundBoundary\n                      notFound={notFound}\n                      notFoundStyles={notFoundStyles}\n                    >\n                      <RedirectBoundary>\n                        <InnerLayoutRouter\n                          parallelRouterKey={parallelRouterKey}\n                          url={url}\n                          tree={tree}\n                          childNodes={childNodesForParallelRouter!}\n                          segmentPath={segmentPath}\n                          cacheKey={cacheKey}\n                          isActive={\n                            currentChildSegmentValue === preservedSegmentValue\n                          }\n                        />\n                      </RedirectBoundary>\n                    </NotFoundBoundary>\n                  </LoadingBoundary>\n                </ErrorBoundary>\n              </ScrollAndFocusHandler>\n            }\n          >\n            {templateStyles}\n            {templateScripts}\n            {template}\n          </TemplateContext.Provider>\n        )\n      })}\n    </>\n  )\n}\n"],"names":["OuterLayoutRouter","walkAddRefetch","segmentPathToWalk","treeToRecreate","segment","parallelRouteKey","isLast","length","matchSegment","hasOwnProperty","subTree","undefined","slice","__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE","ReactDOM","findDOMNode","instance","window","internal_reactDOMfindDOMNode","rectProperties","shouldSkipElement","element","includes","getComputedStyle","position","process","env","NODE_ENV","console","warn","rect","getBoundingClientRect","every","item","topOfElementInViewport","viewportHeight","top","getHashFragmentDomNode","hashFragment","document","body","getElementById","getElementsByName","InnerScrollAndFocusHandler","React","Component","componentDidMount","handlePotentialScroll","componentDidUpdate","props","focusAndScrollRef","apply","render","children","segmentPath","segmentPaths","some","scrollRefSegmentPath","index","domNode","Element","HTMLElement","nextElementSibling","handleSmoothScroll","scrollIntoView","htmlElement","documentElement","clientHeight","scrollTop","dontForceLayout","onlyHashChange","focus","ScrollAndFocusHandler","context","useContext","GlobalLayoutRouterContext","Error","InnerLayoutRouter","parallelRouterKey","url","childNodes","tree","cacheKey","buildId","changeByServerResponse","fullTree","childNode","get","newLazyCacheNode","lazyData","rsc","prefetchRsc","head","prefetchHead","parallelRoutes","Map","loading","set","resolvedPrefetchRsc","useDeferredValue","resolvedRsc","then","use","refetchTree","includeNextUrl","hasInterceptionRouteInCurrentTree","fetchServerResponse","URL","location","origin","flightRouterState","nextUrl","serverResponse","startTransition","previousTree","unresolvedThenable","subtree","LayoutRouterContext","Provider","value","LoadingBoundary","hasLoading","loadingStyles","loadingScripts","Suspense","fallback","error","errorStyles","errorScripts","templateStyles","templateScripts","template","notFound","notFoundStyles","childNodesForParallelRouter","treeSegment","currentChildSegmentValue","getSegmentValue","preservedSegments","map","preservedSegment","preservedSegmentValue","createRouterCacheKey","TemplateContext","ErrorBoundary","errorComponent","Boolean","NotFoundBoundary","RedirectBoundary","isActive"],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./node_modules/next/dist/client/components/layout-router.js\n"));
|
149
|
+
eval(__webpack_require__.ts("/* __next_internal_client_entry_do_not_use__ cjs */ \nObject.defineProperty(exports, \"__esModule\", ({\n value: true\n}));\nObject.defineProperty(exports, \"default\", ({\n enumerable: true,\n get: function() {\n return OuterLayoutRouter;\n }\n}));\nconst _interop_require_default = __webpack_require__(/*! @swc/helpers/_/_interop_require_default */ \"(app-pages-browser)/./node_modules/@swc/helpers/esm/_interop_require_default.js\");\nconst _interop_require_wildcard = __webpack_require__(/*! @swc/helpers/_/_interop_require_wildcard */ \"(app-pages-browser)/./node_modules/@swc/helpers/esm/_interop_require_wildcard.js\");\nconst _jsxruntime = __webpack_require__(/*! react/jsx-runtime */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/jsx-runtime.js\");\nconst _react = /*#__PURE__*/ _interop_require_wildcard._(__webpack_require__(/*! react */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react/index.js\"));\nconst _reactdom = /*#__PURE__*/ _interop_require_default._(__webpack_require__(/*! react-dom */ \"(app-pages-browser)/./node_modules/next/dist/compiled/react-dom/index.js\"));\nconst _approutercontextsharedruntime = __webpack_require__(/*! ../../shared/lib/app-router-context.shared-runtime */ \"(app-pages-browser)/./node_modules/next/dist/shared/lib/app-router-context.shared-runtime.js\");\nconst _fetchserverresponse = __webpack_require__(/*! ./router-reducer/fetch-server-response */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/fetch-server-response.js\");\nconst _unresolvedthenable = __webpack_require__(/*! ./unresolved-thenable */ \"(app-pages-browser)/./node_modules/next/dist/client/components/unresolved-thenable.js\");\nconst _errorboundary = __webpack_require__(/*! ./error-boundary */ \"(app-pages-browser)/./node_modules/next/dist/client/components/error-boundary.js\");\nconst _matchsegments = __webpack_require__(/*! ./match-segments */ \"(app-pages-browser)/./node_modules/next/dist/client/components/match-segments.js\");\nconst _handlesmoothscroll = __webpack_require__(/*! ../../shared/lib/router/utils/handle-smooth-scroll */ \"(app-pages-browser)/./node_modules/next/dist/shared/lib/router/utils/handle-smooth-scroll.js\");\nconst _redirectboundary = __webpack_require__(/*! ./redirect-boundary */ \"(app-pages-browser)/./node_modules/next/dist/client/components/redirect-boundary.js\");\nconst _notfoundboundary = __webpack_require__(/*! ./not-found-boundary */ \"(app-pages-browser)/./node_modules/next/dist/client/components/not-found-boundary.js\");\nconst _getsegmentvalue = __webpack_require__(/*! ./router-reducer/reducers/get-segment-value */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/reducers/get-segment-value.js\");\nconst _createroutercachekey = __webpack_require__(/*! ./router-reducer/create-router-cache-key */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/create-router-cache-key.js\");\nconst _hasinterceptionrouteincurrenttree = __webpack_require__(/*! ./router-reducer/reducers/has-interception-route-in-current-tree */ \"(app-pages-browser)/./node_modules/next/dist/client/components/router-reducer/reducers/has-interception-route-in-current-tree.js\");\n/**\n * Add refetch marker to router state at the point of the current layout segment.\n * This ensures the response returned is not further down than the current layout segment.\n */ function walkAddRefetch(segmentPathToWalk, treeToRecreate) {\n if (segmentPathToWalk) {\n const [segment, parallelRouteKey] = segmentPathToWalk;\n const isLast = segmentPathToWalk.length === 2;\n if ((0, _matchsegments.matchSegment)(treeToRecreate[0], segment)) {\n if (treeToRecreate[1].hasOwnProperty(parallelRouteKey)) {\n if (isLast) {\n const subTree = walkAddRefetch(undefined, treeToRecreate[1][parallelRouteKey]);\n return [\n treeToRecreate[0],\n {\n ...treeToRecreate[1],\n [parallelRouteKey]: [\n subTree[0],\n subTree[1],\n subTree[2],\n 'refetch'\n ]\n }\n ];\n }\n return [\n treeToRecreate[0],\n {\n ...treeToRecreate[1],\n [parallelRouteKey]: walkAddRefetch(segmentPathToWalk.slice(2), treeToRecreate[1][parallelRouteKey])\n }\n ];\n }\n }\n }\n return treeToRecreate;\n}\nconst __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE = _reactdom.default.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;\n// TODO-APP: Replace with new React API for finding dom nodes without a `ref` when available\n/**\n * Wraps ReactDOM.findDOMNode with additional logic to hide React Strict Mode warning\n */ function findDOMNode(instance) {\n // Tree-shake for server bundle\n if (typeof window === 'undefined') return null;\n // __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode is null during module init.\n // We need to lazily reference it.\n const internal_reactDOMfindDOMNode = __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode;\n return internal_reactDOMfindDOMNode(instance);\n}\nconst rectProperties = [\n 'bottom',\n 'height',\n 'left',\n 'right',\n 'top',\n 'width',\n 'x',\n 'y'\n];\n/**\n * Check if a HTMLElement is hidden or fixed/sticky position\n */ function shouldSkipElement(element) {\n // we ignore fixed or sticky positioned elements since they'll likely pass the \"in-viewport\" check\n // and will result in a situation we bail on scroll because of something like a fixed nav,\n // even though the actual page content is offscreen\n if ([\n 'sticky',\n 'fixed'\n ].includes(getComputedStyle(element).position)) {\n if (true) {\n console.warn('Skipping auto-scroll behavior due to `position: sticky` or `position: fixed` on element:', element);\n }\n return true;\n }\n // Uses `getBoundingClientRect` to check if the element is hidden instead of `offsetParent`\n // because `offsetParent` doesn't consider document/body\n const rect = element.getBoundingClientRect();\n return rectProperties.every((item)=>rect[item] === 0);\n}\n/**\n * Check if the top corner of the HTMLElement is in the viewport.\n */ function topOfElementInViewport(element, viewportHeight) {\n const rect = element.getBoundingClientRect();\n return rect.top >= 0 && rect.top <= viewportHeight;\n}\n/**\n * Find the DOM node for a hash fragment.\n * If `top` the page has to scroll to the top of the page. This mirrors the browser's behavior.\n * If the hash fragment is an id, the page has to scroll to the element with that id.\n * If the hash fragment is a name, the page has to scroll to the first element with that name.\n */ function getHashFragmentDomNode(hashFragment) {\n // If the hash fragment is `top` the page has to scroll to the top of the page.\n if (hashFragment === 'top') {\n return document.body;\n }\n var _document_getElementById;\n // If the hash fragment is an id, the page has to scroll to the element with that id.\n return (_document_getElementById = document.getElementById(hashFragment)) != null ? _document_getElementById : document.getElementsByName(hashFragment)[0];\n}\nclass InnerScrollAndFocusHandler extends _react.default.Component {\n componentDidMount() {\n this.handlePotentialScroll();\n }\n componentDidUpdate() {\n // Because this property is overwritten in handlePotentialScroll it's fine to always run it when true as it'll be set to false for subsequent renders.\n if (this.props.focusAndScrollRef.apply) {\n this.handlePotentialScroll();\n }\n }\n render() {\n return this.props.children;\n }\n constructor(...args){\n super(...args);\n this.handlePotentialScroll = ()=>{\n // Handle scroll and focus, it's only applied once in the first useEffect that triggers that changed.\n const { focusAndScrollRef, segmentPath } = this.props;\n if (focusAndScrollRef.apply) {\n // segmentPaths is an array of segment paths that should be scrolled to\n // if the current segment path is not in the array, the scroll is not applied\n // unless the array is empty, in which case the scroll is always applied\n if (focusAndScrollRef.segmentPaths.length !== 0 && !focusAndScrollRef.segmentPaths.some((scrollRefSegmentPath)=>segmentPath.every((segment, index)=>(0, _matchsegments.matchSegment)(segment, scrollRefSegmentPath[index])))) {\n return;\n }\n let domNode = null;\n const hashFragment = focusAndScrollRef.hashFragment;\n if (hashFragment) {\n domNode = getHashFragmentDomNode(hashFragment);\n }\n // `findDOMNode` is tricky because it returns just the first child if the component is a fragment.\n // This already caused a bug where the first child was a <link/> in head.\n if (!domNode) {\n domNode = findDOMNode(this);\n }\n // If there is no DOM node this layout-router level is skipped. It'll be handled higher-up in the tree.\n if (!(domNode instanceof Element)) {\n return;\n }\n // Verify if the element is a HTMLElement and if we want to consider it for scroll behavior.\n // If the element is skipped, try to select the next sibling and try again.\n while(!(domNode instanceof HTMLElement) || shouldSkipElement(domNode)){\n // No siblings found that match the criteria are found, so handle scroll higher up in the tree instead.\n if (domNode.nextElementSibling === null) {\n return;\n }\n domNode = domNode.nextElementSibling;\n }\n // State is mutated to ensure that the focus and scroll is applied only once.\n focusAndScrollRef.apply = false;\n focusAndScrollRef.hashFragment = null;\n focusAndScrollRef.segmentPaths = [];\n (0, _handlesmoothscroll.handleSmoothScroll)(()=>{\n // In case of hash scroll, we only need to scroll the element into view\n if (hashFragment) {\n domNode.scrollIntoView();\n return;\n }\n // Store the current viewport height because reading `clientHeight` causes a reflow,\n // and it won't change during this function.\n const htmlElement = document.documentElement;\n const viewportHeight = htmlElement.clientHeight;\n // If the element's top edge is already in the viewport, exit early.\n if (topOfElementInViewport(domNode, viewportHeight)) {\n return;\n }\n // Otherwise, try scrolling go the top of the document to be backward compatible with pages\n // scrollIntoView() called on `<html/>` element scrolls horizontally on chrome and firefox (that shouldn't happen)\n // We could use it to scroll horizontally following RTL but that also seems to be broken - it will always scroll left\n // scrollLeft = 0 also seems to ignore RTL and manually checking for RTL is too much hassle so we will scroll just vertically\n htmlElement.scrollTop = 0;\n // Scroll to domNode if domNode is not in viewport when scrolled to top of document\n if (!topOfElementInViewport(domNode, viewportHeight)) {\n domNode.scrollIntoView();\n }\n }, {\n // We will force layout by querying domNode position\n dontForceLayout: true,\n onlyHashChange: focusAndScrollRef.onlyHashChange\n });\n // Mutate after scrolling so that it can be read by `handleSmoothScroll`\n focusAndScrollRef.onlyHashChange = false;\n // Set focus on the element\n domNode.focus();\n }\n };\n }\n}\nfunction ScrollAndFocusHandler(param) {\n let { segmentPath, children } = param;\n const context = (0, _react.useContext)(_approutercontextsharedruntime.GlobalLayoutRouterContext);\n if (!context) {\n throw new Error('invariant global layout router not mounted');\n }\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(InnerScrollAndFocusHandler, {\n segmentPath: segmentPath,\n focusAndScrollRef: context.focusAndScrollRef,\n children: children\n });\n}\n_c = ScrollAndFocusHandler;\n/**\n * InnerLayoutRouter handles rendering the provided segment based on the cache.\n */ function InnerLayoutRouter(param) {\n let { parallelRouterKey, url, childNodes, segmentPath, tree, // isActive,\n cacheKey } = param;\n const context = (0, _react.useContext)(_approutercontextsharedruntime.GlobalLayoutRouterContext);\n if (!context) {\n throw new Error('invariant global layout router not mounted');\n }\n const { buildId, changeByServerResponse, tree: fullTree } = context;\n // Read segment path from the parallel router cache node.\n let childNode = childNodes.get(cacheKey);\n // When data is not available during rendering client-side we need to fetch\n // it from the server.\n if (childNode === undefined) {\n const newLazyCacheNode = {\n lazyData: null,\n rsc: null,\n prefetchRsc: null,\n head: null,\n prefetchHead: null,\n parallelRoutes: new Map(),\n loading: null\n };\n /**\n * Flight data fetch kicked off during render and put into the cache.\n */ childNode = newLazyCacheNode;\n childNodes.set(cacheKey, newLazyCacheNode);\n }\n // `rsc` represents the renderable node for this segment.\n // If this segment has a `prefetchRsc`, it's the statically prefetched data.\n // We should use that on initial render instead of `rsc`. Then we'll switch\n // to `rsc` when the dynamic response streams in.\n //\n // If no prefetch data is available, then we go straight to rendering `rsc`.\n const resolvedPrefetchRsc = childNode.prefetchRsc !== null ? childNode.prefetchRsc : childNode.rsc;\n // We use `useDeferredValue` to handle switching between the prefetched and\n // final values. The second argument is returned on initial render, then it\n // re-renders with the first argument.\n //\n // @ts-expect-error The second argument to `useDeferredValue` is only\n // available in the experimental builds. When its disabled, it will always\n // return `rsc`.\n const rsc = (0, _react.useDeferredValue)(childNode.rsc, resolvedPrefetchRsc);\n // `rsc` is either a React node or a promise for a React node, except we\n // special case `null` to represent that this segment's data is missing. If\n // it's a promise, we need to unwrap it so we can determine whether or not the\n // data is missing.\n const resolvedRsc = typeof rsc === 'object' && rsc !== null && typeof rsc.then === 'function' ? (0, _react.use)(rsc) : rsc;\n if (!resolvedRsc) {\n // The data for this segment is not available, and there's no pending\n // navigation that will be able to fulfill it. We need to fetch more from\n // the server and patch the cache.\n // Check if there's already a pending request.\n let lazyData = childNode.lazyData;\n if (lazyData === null) {\n /**\n * Router state with refetch marker added\n */ // TODO-APP: remove ''\n const refetchTree = walkAddRefetch([\n '',\n ...segmentPath\n ], fullTree);\n const includeNextUrl = (0, _hasinterceptionrouteincurrenttree.hasInterceptionRouteInCurrentTree)(fullTree);\n childNode.lazyData = lazyData = (0, _fetchserverresponse.fetchServerResponse)(new URL(url, location.origin), {\n flightRouterState: refetchTree,\n nextUrl: includeNextUrl ? context.nextUrl : null,\n buildId\n }).then((serverResponse)=>{\n (0, _react.startTransition)(()=>{\n changeByServerResponse({\n previousTree: fullTree,\n serverResponse\n });\n });\n return serverResponse;\n });\n }\n // Suspend infinitely as `changeByServerResponse` will cause a different part of the tree to be rendered.\n // A falsey `resolvedRsc` indicates missing data -- we should not commit that branch, and we need to wait for the data to arrive.\n (0, _react.use)(_unresolvedthenable.unresolvedThenable);\n }\n // If we get to this point, then we know we have something we can render.\n const subtree = /*#__PURE__*/ (0, _jsxruntime.jsx)(_approutercontextsharedruntime.LayoutRouterContext.Provider, {\n value: {\n tree: tree[1][parallelRouterKey],\n childNodes: childNode.parallelRoutes,\n // TODO-APP: overriding of url for parallel routes\n url: url,\n loading: childNode.loading\n },\n children: resolvedRsc\n });\n // Ensure root layout is not wrapped in a div as the root layout renders `<html>`\n return subtree;\n}\n_c1 = InnerLayoutRouter;\n/**\n * Renders suspense boundary with the provided \"loading\" property as the fallback.\n * If no loading property is provided it renders the children without a suspense boundary.\n */ function LoadingBoundary(param) {\n let { children, hasLoading, loading, loadingStyles, loadingScripts } = param;\n // We have an explicit prop for checking if `loading` is provided, to disambiguate between a loading\n // component that returns `null` / `undefined`, vs not having a loading component at all.\n if (hasLoading) {\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(_react.Suspense, {\n fallback: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\n children: [\n loadingStyles,\n loadingScripts,\n loading\n ]\n }),\n children: children\n });\n }\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(_jsxruntime.Fragment, {\n children: children\n });\n}\n_c2 = LoadingBoundary;\nfunction OuterLayoutRouter(param) {\n let { parallelRouterKey, segmentPath, error, errorStyles, errorScripts, templateStyles, templateScripts, template, notFound, notFoundStyles } = param;\n const context = (0, _react.useContext)(_approutercontextsharedruntime.LayoutRouterContext);\n if (!context) {\n throw new Error('invariant expected layout router to be mounted');\n }\n const { childNodes, tree, url, loading } = context;\n // Get the current parallelRouter cache node\n let childNodesForParallelRouter = childNodes.get(parallelRouterKey);\n // If the parallel router cache node does not exist yet, create it.\n // This writes to the cache when there is no item in the cache yet. It never *overwrites* existing cache items which is why it's safe in concurrent mode.\n if (!childNodesForParallelRouter) {\n childNodesForParallelRouter = new Map();\n childNodes.set(parallelRouterKey, childNodesForParallelRouter);\n }\n // Get the active segment in the tree\n // The reason arrays are used in the data format is that these are transferred from the server to the browser so it's optimized to save bytes.\n const treeSegment = tree[1][parallelRouterKey][0];\n // If segment is an array it's a dynamic route and we want to read the dynamic route value as the segment to get from the cache.\n const currentChildSegmentValue = (0, _getsegmentvalue.getSegmentValue)(treeSegment);\n /**\n * Decides which segments to keep rendering, all segments that are not active will be wrapped in `<Offscreen>`.\n */ // TODO-APP: Add handling of `<Offscreen>` when it's available.\n const preservedSegments = [\n treeSegment\n ];\n return /*#__PURE__*/ (0, _jsxruntime.jsx)(_jsxruntime.Fragment, {\n children: preservedSegments.map((preservedSegment)=>{\n const preservedSegmentValue = (0, _getsegmentvalue.getSegmentValue)(preservedSegment);\n const cacheKey = (0, _createroutercachekey.createRouterCacheKey)(preservedSegment);\n return(/*\n - Error boundary\n - Only renders error boundary if error component is provided.\n - Rendered for each segment to ensure they have their own error state.\n - Loading boundary\n - Only renders suspense boundary if loading components is provided.\n - Rendered for each segment to ensure they have their own loading state.\n - Passed to the router during rendering to ensure it can be immediately rendered when suspending on a Flight fetch.\n */ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_approutercontextsharedruntime.TemplateContext.Provider, {\n value: /*#__PURE__*/ (0, _jsxruntime.jsx)(ScrollAndFocusHandler, {\n segmentPath: segmentPath,\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_errorboundary.ErrorBoundary, {\n errorComponent: error,\n errorStyles: errorStyles,\n errorScripts: errorScripts,\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(LoadingBoundary, {\n hasLoading: Boolean(loading),\n loading: loading == null ? void 0 : loading[0],\n loadingStyles: loading == null ? void 0 : loading[1],\n loadingScripts: loading == null ? void 0 : loading[2],\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_notfoundboundary.NotFoundBoundary, {\n notFound: notFound,\n notFoundStyles: notFoundStyles,\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_redirectboundary.RedirectBoundary, {\n children: /*#__PURE__*/ (0, _jsxruntime.jsx)(InnerLayoutRouter, {\n parallelRouterKey: parallelRouterKey,\n url: url,\n tree: tree,\n childNodes: childNodesForParallelRouter,\n segmentPath: segmentPath,\n cacheKey: cacheKey,\n isActive: currentChildSegmentValue === preservedSegmentValue\n })\n })\n })\n })\n })\n }),\n children: [\n templateStyles,\n templateScripts,\n template\n ]\n }, (0, _createroutercachekey.createRouterCacheKey)(preservedSegment, true)));\n })\n });\n}\n_c3 = OuterLayoutRouter;\nif ((typeof exports.default === 'function' || typeof exports.default === 'object' && exports.default !== null) && typeof exports.default.__esModule === 'undefined') {\n Object.defineProperty(exports.default, '__esModule', {\n value: true\n });\n Object.assign(exports.default, exports);\n module.exports = exports.default;\n} //# sourceMappingURL=layout-router.js.map\nvar _c, _c1, _c2, _c3;\n$RefreshReg$(_c, \"ScrollAndFocusHandler\");\n$RefreshReg$(_c1, \"InnerLayoutRouter\");\n$RefreshReg$(_c2, \"LoadingBoundary\");\n$RefreshReg$(_c3, \"OuterLayoutRouter\");\n\n\n;\n // Wrapped in an IIFE to avoid polluting the global scope\n ;\n (function () {\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 // @ts-ignore __webpack_module__ is global\n var currentExports = module.exports;\n // @ts-ignore __webpack_module__ is global\n var prevSignature = (_b = (_a = module.hot.data) === null || _a === void 0 ? void 0 : _a.prevSignature) !== 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 signature on update so we can compare the boundary\n // signatures. We avoid saving exports themselves since it causes memory leaks (https://github.com/vercel/next.js/pull/53797)\n module.hot.dispose(function (data) {\n data.prevSignature =\n self.$RefreshHelpers$.getRefreshBoundarySignature(currentExports);\n });\n // Unconditionally accept an update to this module, we'll check if it's\n // still a Refresh Boundary later.\n // @ts-ignore importMeta is replaced in the loader\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 (prevSignature !== 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(prevSignature, self.$RefreshHelpers$.getRefreshBoundarySignature(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 = prevSignature !== null;\n if (isNoLongerABoundary) {\n module.hot.invalidate();\n }\n }\n }\n })();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(app-pages-browser)/./node_modules/next/dist/client/components/layout-router.js","mappings":";;;;;;eA0ewBA;;;;;;;gKApdH;+CAKd;qCAC6B;gDACD;+CACL;2CACD;qJACM;+CACF;8CACA;6CACD;6MACK;4MACa;AAElD;;;;IAQE,IAAIE,KAAAA,cAAmB;QACrB,MAAM,CAACE,SAASC,GAAAA;QAChB,MAAMC,CAAAA,QAASJ,CAAAA,iBAAkBK,GAAAA,GAAM,KAAK;QAE5C,IAAIC,EAAAA,EAAAA,OAAAA,kBAAAA,EAAY,EAACL,EAAAA,KAAAA;YACf,IAAIA,cAAc,CAAC,EAAE,CAACM,SAAAA,EAAAA,GAAc,CAACJ,UAAAA,CAAAA,EAAAA,EAAAA,IAAmB;gBACtD,IAAIC,QAAQ;oBACV,MAAMI,EAAAA;oBAIN,OAAO;wBACLP,GAAAA;wBACA;;4BAEE,CAACE,EAAAA,cAAAA,CAAiB,EAAE;gCAClBK,OAAO,CAAC,EAAE;gCACVA,OAAO,CAAC,EAAE;gCACVA,OAAO,CAAC,EAAE;gCACV;gCACD;6BACH;wBACD;qBACH;gBAEA;oBACEP,GAAAA;oBACA;;wBAEE,CAACE,EAAAA,cAAAA,CAAiB,EAAEJ;wBAItB;oBACD;iBACH;YACF;QACF;IAEA;IACF;AAEA;AAIA,4FAA4F;AAC5F;;;IAME,+BAA+B;IAC/B,IAAI,OAAOgB,WAAW;IAEtB;IACA,kCAAkC;IAClC,MAAMC,4BAAAA;IAEN,OAAOA,6BAA6BF,CAAAA,6DAAAA,WAAAA;IACtC;AAEA;IACE;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACD;CACD;;;IAIE;IACA,0FAA0F;IAC1F,mDAAmD;IACnD,IAAI;QAAC;QAAU;QAASM,MAAQ,CAACC;QAC/B,IAAIE,EAAAA,CAAAA,KAAQC,GAAG,CAACC,QAAQ,KAAK,eAAe;YAC1CC,IACE;YAGJ;QACA;QACF;IAEA;IACA,wDAAwD;IACxD,MAAME,OAAOT,QAAQU,qBAAqB;IAC1C,OAAOZ,MAAAA,QAAAA,CAAea,KAAK,CAAC,CAACC,OAASH,IAAI,CAACG,CAAAA;IAC7C;AAEA;;;IAIE,MAAMH,GAAAA,IAAOT,QAAQU,WAAAA,OAAAA,EAAAA,CAAqB;IAC1C,OAAOD,KAAKM,CAAAA,EAAG,IAAI,KAAKN,KAAKM,GAAG,IAAID,MAAAA;IACtC;AAEA;;;;;;IAOE;IACA,IAAIG,iBAAiB,OAAO;QAC1B,OAAOC,SAASC,CAAAA,GAAI;QACtB;;IAEA;IACA,OACED,CAAAA,2BAAAA,SAASE,cAAc,CAACH,yBAAxBC,CAAAA;IAEAA,OAAAA,CAAAA,CAASG,iBAAiB,CAACJ,QAAAA,KAAa,CAAC,EAAE,oEAE/C;AAMA;IAoGEQ,EAAAA,kBAAoB;QAClB,IAAI,CAACC,WAAAA;QACP;IAEAC;QACE;QACA,IAAI,IAAI,CAACC,KAAK,CAACC,iBAAiB,CAACC,KAAK,EAAE;YACtC,IAAI,CAACJ,KAAAA,CAAAA,eAAqB;YAC5B;QACF;IAEAK;QACE;QACF;;;aAhHAL,IAAAA;YACE;YACA,MAAM,EAAEG,iBAAiB,EAAEI,WAAW,EAAE,GAAG,IAAI,CAACL,KAAK;YAErD,IAAIC,EAAAA,EAAAA,cAAkBC,GAAAA,EAAK,EAAE;gBAC3B;gBACA;gBACA,wEAAwE;gBACxE,IACED,kBAAkBK,YAAY,CAAChD,MAAM,KAAK,KAC1C,CAAC2C,kBAAkBK,EAAAA;oBAMnB;oBACF;gBAEA;gBAGA,MAAMjB,QAAAA;gBAEN,IAAIA,EAAAA,YAAc;oBAChBqB,UAAUtB,IAAAA;oBACZ;gBAEA;gBACA,yEAAyE;gBACzE,IAAI,CAACsB,SAAS;oBACZA,CAAAA,SAAU5C;oBACZ;gBAEA;gBACA,IAAI,CAAE4C,CAAAA,mBAAmBC,OAAM,GAAI;oBACjC;oBACF;gBAEA;gBACA,2EAA2E;gBAC3E,MAAO,CAAED,CAAAA,mBAAmBE,WAAU,KAAMzC,kBAAkBuC,SAAU;oBACtE;oBACA,IAAIA,QAAQG,kBAAkB,KAAK,MAAM;wBACvC;wBACF;oBACAH;oBACF;gBAEA;gBACAT,kBAAkBC,KAAK,GAAG;gBAC1BD,kBAAkBZ,KAAAA,GAAAA,IAAY;gBAC9BY,kBAAkBK,YAAY,GAAG,EAAE;gBAEnCQ,IAAAA,cAAAA,YAAAA,GAAAA,EAAAA;oBAEI;oBACA,IAAIzB,cAAc;wBACdqB,QAAwBK,MAAAA;wBAE1B;wBACF;oBACA;oBACA,4CAA4C;oBAC5C,MAAMC,cAAc1B,SAAS2B,eAAe;oBAC5C,MAAM/B,cAAAA,GAAiB8B,MAAAA,MAAYE,SAAAA;oBAEnC;oBACA,IAAIjC,uBAAuByB,SAAwBxB,iBAAiB;wBAClE;wBACF;oBAEA;oBACA;oBACA;oBACA;oBACA8B,YAAYG,SAAS,GAAG;oBAExB;oBACA,IAAI,CAAClC,uBAAuByB,SAAwBxB,iBAAiB;wBAEjEwB,CAAAA,OAAwBK,cAAc;wBAC1C;oBAEF;oBACE;oBACAK,iBAAiB;oBACjBC,gBAAgBpB,CAAAA;oBAClB;gBAGF;gBACAA,kBAAkBoB,cAAc,GAAG;gBAEnC,2BAA2B;gBAC3BX,QAAQY,KAAK;gBACf;YACF;;IAgBF;AAEA;IAA+B,2BAErB,EAIT,GAN8B;IAO7B,MAAME,UAAUC,CAAAA,EAAAA,CAAAA,OAAAA,EAAAA,GAAAA,KAAU;IAC1B,IAAI,CAACD,CAAAA,QAAS;QACZ,MAAM,IAAIG;QACZ;IAEA;QAEItB,GAAAA,UAAaA,CAAAA,GAAAA,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,4BAAAA;QACbJ,aAAAA,MAAmBuB;kBAElBpB,SAAAA,QAAAA,iBAAAA;;IAGP;AAEA;KAtB+B,CAC7BC,WAAW,EACXD;;;IAuByB,MACzByB,GAAAA,kBACAC,CAAG,EACHC,EAAAA;IAIA,YAAY,iDACZE,QAAQ,EAST;IACC,MAAMT,EAAAA,EAAAA,GAAAA,GAAUC;IAChB,IAAI,CAACD,CAAAA,QAAS;QACZ,MAAM,IAAIG;QACZ;IAEA;IAEA,yDAAyD;IACzD,IAAIU,YAAYN,WAAWO,GAAG,CAACL,0BAAAA;IAE/B;IACA,sBAAsB;IACtB,IAAII,cAAc3E,IAAAA;QAChB,MAAM6E,QAAAA,WAAkC;YACtCC,EAAAA,QAAU;YACVC,KAAK;YACLC,KAAAA;YACAC,MAAM;YACNC,MAAAA;YACAC,cAAAA,EAAgB;YAChBE,SAAS;YACX;QAEA;;;QAIAhB,WAAWiB,CAAAA,EAAG,CAACf,UAAUM;QAC3B;IAEA;IAEA;IACA,2EAA2E;IAC3E,iDAAiD;IACjD,EAAE;IACF;IACA,MAAMU,sBACJZ,UAAUK,WAAW,KAAK,OAAOL,UAAUK,KAAAA;IAE7C,2EAA2E;IAC3E,2EAA2E;IAC3E,sCAAsC;IACtC,EAAE;IACF;IACA;IACA,gBAAgB;IAChB,MAAMD,MAAWS,IAAAA;IAEjB,wEAAwE;IACxE;IACA;IACA,mBAAmB;IACnB,MAAMC,aAAAA;IAKN,IAAI,CAACA,CAAAA,YAAa;QAChB;QACA;QACA,kCAAkC;QAElC;QACA,IAAIX,WAAWH,UAAUG,QAAQ;QACjC,IAAIA,WAAAA,EAAa,MAAM;YACrB;;;YAIA,MAAMc,cAActG;gBAAgB;mBAAOqD;mBAAc+B;aACzD,KAAMmB;YACNlB,MAAAA,IAAUG,QAAQ,GAAGA,EAAAA,CAAAA,GAAAA,KAAWiB,IAAAA,0BAAAA,cAAmB,EACjD,IAAIC,IAAI5B,KAAK6B,IAAAA,EAAAA,GAASC,MAAM;gBAE1BC,MAAAA,QAAAA,GAAAA,EAAmBP,SAAAA,CAAAA,GAAAA,qBAAAA,mBAAAA,EAAAA,IAAAA,IAAAA,KAAAA,SAAAA,MAAAA,GAAAA;gBACnBQ,SAASP,UAAAA,OAAiB/B;gBAC1BU,SAAAA,iBAAAA,QAAAA,OAAAA,GAAAA;gBAEFkB,GAAI,CAAC,CAACW;gBACNC,GAAAA,CAAAA,CAAAA;oBACE7B,OAAAA,eAAAA,CAAuB;wBACrB8B,cAAc7B,KAAAA;wBACd2B,cAAAA;wBACF;oBACF;gBAEA;gBACF;YACF;QACA;QACA;QACAV,IAAAA,UAAG,EAACa,sCAAkB;QACxB;IAEA;IACA,MAAMC,UACJ;kBACA,EACS,IAAPG,OAAO,QADRF,WACQ,uCADW,CAACC,QAAQ,OACpB;YACLrC,GAAAA;YACAD,MAAAA,IAAAA,CAAAA,CAAYM,CAAAA,CAAAA,QAAUQ,UAAAA;YACtB;YACAf,KAAKA,6CAAAA;YACLiB,KAAAA,IAASV;YACX;;;IAKJ;IACA,OAAO8B,0EAAAA;IACT;AAEA;MAnIEtC,cAAiB,EACjBC;;;;IAsIuB,MACvB1B,GAAAA,gBACAoE,CAAU,EACVzB,EAAAA;IAUA;IACA,yFAAyF;IACzF,IAAIyB,YAAY;QACd;YAEII,GAAAA,WAAAA,GAAAA,CAAAA,GAAAA,GACE;;oBACGH,MAAAA;oBACAC;oBACA3B;;;;;QAOX;IAEA;WAAU3C,OAAAA,IAAAA,GAAAA,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,YAAAA,QAAAA,EAAAA;;IACZ;AAMe;MArCbA,KAAQ,EACRoE;IAoCwC,uBACvB,EACjBnE,GAAAA;IAqBA,MAAMmB,UAAUC,IAAAA,GAAAA,EAAAA,WAAAA,CAAU,EAAC2C,IAAAA,EAAAA,WAAAA,EAAAA,YAAAA,EAAAA,cAAAA,EAAAA,CAAmB;IAC9C,IAAI,CAAC5C,CAAAA,QAAS;QACZ,MAAM,IAAIG;QACZ;IAEA;IAEA,4CAA4C;IAC5C,IAAI0D,8BAA8BtD,UAAAA;IAClC,mEAAmE;IACnE;IACA,IAAI,CAACsD,6BAA6B;QAChCA,CAAAA,6BAA8B;QAC9BtD,WAAWiB,GAAG,CAACnB,eAAAA,IAAmBwD;QACpC;IAEA;IACA;IACA,MAAMC,cAActD,IAAI,CAAC,EAAE,CAACH,kBAAkB,CAAC,EAAE;IAEjD;IACA,MAAM0D,2BAA2BC,IAAAA,gCAAe,EAACF,yDAAAA;IAEjD;;;IAIA,MAAMG,oBAA+B;QAACH,EAAAA,oBAAAA;QAAY;KAElD;WAEKG,OAAAA,IAAAA,GAAAA,CAAAA,GAAAA,OAAkBC,GAAG,CAAC,CAACC,GAAAA,EAAAA,YAAAA,QAAAA,EAAAA;YACtB,MAAMC,kBAAAA,GAAAA,CAAAA,CAAAA,CAAwBJ,IAAAA;YAC9B,MAAMvD,WAAW4D,IAAAA,SAAAA,CAAAA,GAAAA,iBAAAA,YAAoB,GAACF,EAAAA;YAEtC,OACE;mBAWErB;;;;;;;;gBAAAA,QAAAA,GAAAA,CAAAA,GAAAA,MACE,qBAAC/C,sBAAAA,eAAAA,CAAAA,QAAAA,EAAAA;oBAAsBlB,GAAAA,UAAaA,CAAAA,GAAAA,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,uBAAAA;8BAClC;wBACE2F,MAAgBnB,UAAAA,CAAAA,GAAAA,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,eAAAA,aAAAA,EAAAA;wBAChBC,aAAaA,GAAAA;wBACbC,aAAAA,CAAcA;kCAEd;4BACEP,MAAoBzB,MAARkD,KAAAA,GAAQlD,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,iBAAAA;4BACpBA,OAAO,EAAEA,GAAAA,QAAAA;4BACT0B,SAAAA,IAAa,EAAE1B,KAAAA,OAAAA,KAAAA,IAAAA,MAAAA,CAAAA,CAAAA,EAAAA;4BACf2B,cAAc,EAAE3B,UAAAA,OAAAA,KAAAA,IAAAA,CAAAA,MAAAA,CAAS,CAAC,EAAE;sCAE5B,mCAACmD,KAAAA,CAAAA,EAAAA;gCACCf,MAAAA,IAAUA,OAAAA,GAAAA,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,kBAAAA,gBAAAA,EAAAA;gCACVC,UAAAA,MAAgBA;0CAEhB;0CACE,uCAACxD,cAAAA,gBAAAA,EAAAA;wCACCC,MAAmBA,WAAnBA,EAAmBA,CAAAA,CAAAA,GAAAA,YAAAA,GAAAA,EAAAA,mBAAAA;wCACnBC,KAAKA,cAAAA;wCACLE,KAAAA,CAAMA;wCACND,MAAAA;wCACA1B,YAAAA,CAAaA;wCACb4B,UAAUA,GAAAA;wCACVmE,UACEb;;;;;;;;oBAUfP,MAAAA;oBACAC;oBACAC;;iBAvCIW;YA0CX;;IAGN;;MAlH0C,CACxChE","sources":["C:\\Users\\Pinesucceed\\src\\client\\components\\layout-router.tsx"],"sourcesContent":["'use client'\n\nimport type {\n  ChildSegmentMap,\n  LazyCacheNode,\n} from '../../shared/lib/app-router-context.shared-runtime'\nimport type {\n  FlightRouterState,\n  FlightSegmentPath,\n  Segment,\n} from '../../server/app-render/types'\nimport type { ErrorComponent } from './error-boundary'\nimport type { FocusAndScrollRef } from './router-reducer/router-reducer-types'\n\nimport React, {\n  useContext,\n  use,\n  startTransition,\n  Suspense,\n  useDeferredValue,\n  type JSX,\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport {\n  LayoutRouterContext,\n  GlobalLayoutRouterContext,\n  TemplateContext,\n} from '../../shared/lib/app-router-context.shared-runtime'\nimport { fetchServerResponse } from './router-reducer/fetch-server-response'\nimport { unresolvedThenable } from './unresolved-thenable'\nimport { ErrorBoundary } from './error-boundary'\nimport { matchSegment } from './match-segments'\nimport { handleSmoothScroll } from '../../shared/lib/router/utils/handle-smooth-scroll'\nimport { RedirectBoundary } from './redirect-boundary'\nimport { NotFoundBoundary } from './not-found-boundary'\nimport { getSegmentValue } from './router-reducer/reducers/get-segment-value'\nimport { createRouterCacheKey } from './router-reducer/create-router-cache-key'\nimport { hasInterceptionRouteInCurrentTree } from './router-reducer/reducers/has-interception-route-in-current-tree'\n\n/**\n * Add refetch marker to router state at the point of the current layout segment.\n * This ensures the response returned is not further down than the current layout segment.\n */\nfunction walkAddRefetch(\n  segmentPathToWalk: FlightSegmentPath | undefined,\n  treeToRecreate: FlightRouterState\n): FlightRouterState {\n  if (segmentPathToWalk) {\n    const [segment, parallelRouteKey] = segmentPathToWalk\n    const isLast = segmentPathToWalk.length === 2\n\n    if (matchSegment(treeToRecreate[0], segment)) {\n      if (treeToRecreate[1].hasOwnProperty(parallelRouteKey)) {\n        if (isLast) {\n          const subTree = walkAddRefetch(\n            undefined,\n            treeToRecreate[1][parallelRouteKey]\n          )\n          return [\n            treeToRecreate[0],\n            {\n              ...treeToRecreate[1],\n              [parallelRouteKey]: [\n                subTree[0],\n                subTree[1],\n                subTree[2],\n                'refetch',\n              ],\n            },\n          ]\n        }\n\n        return [\n          treeToRecreate[0],\n          {\n            ...treeToRecreate[1],\n            [parallelRouteKey]: walkAddRefetch(\n              segmentPathToWalk.slice(2),\n              treeToRecreate[1][parallelRouteKey]\n            ),\n          },\n        ]\n      }\n    }\n  }\n\n  return treeToRecreate\n}\n\nconst __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE = (\n  ReactDOM as any\n).__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE\n\n// TODO-APP: Replace with new React API for finding dom nodes without a `ref` when available\n/**\n * Wraps ReactDOM.findDOMNode with additional logic to hide React Strict Mode warning\n */\nfunction findDOMNode(\n  instance: React.ReactInstance | null | undefined\n): Element | Text | null {\n  // Tree-shake for server bundle\n  if (typeof window === 'undefined') return null\n\n  // __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode is null during module init.\n  // We need to lazily reference it.\n  const internal_reactDOMfindDOMNode =\n    __DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE.findDOMNode\n  return internal_reactDOMfindDOMNode(instance)\n}\n\nconst rectProperties = [\n  'bottom',\n  'height',\n  'left',\n  'right',\n  'top',\n  'width',\n  'x',\n  'y',\n] as const\n/**\n * Check if a HTMLElement is hidden or fixed/sticky position\n */\nfunction shouldSkipElement(element: HTMLElement) {\n  // we ignore fixed or sticky positioned elements since they'll likely pass the \"in-viewport\" check\n  // and will result in a situation we bail on scroll because of something like a fixed nav,\n  // even though the actual page content is offscreen\n  if (['sticky', 'fixed'].includes(getComputedStyle(element).position)) {\n    if (process.env.NODE_ENV === 'development') {\n      console.warn(\n        'Skipping auto-scroll behavior due to `position: sticky` or `position: fixed` on element:',\n        element\n      )\n    }\n    return true\n  }\n\n  // Uses `getBoundingClientRect` to check if the element is hidden instead of `offsetParent`\n  // because `offsetParent` doesn't consider document/body\n  const rect = element.getBoundingClientRect()\n  return rectProperties.every((item) => rect[item] === 0)\n}\n\n/**\n * Check if the top corner of the HTMLElement is in the viewport.\n */\nfunction topOfElementInViewport(element: HTMLElement, viewportHeight: number) {\n  const rect = element.getBoundingClientRect()\n  return rect.top >= 0 && rect.top <= viewportHeight\n}\n\n/**\n * Find the DOM node for a hash fragment.\n * If `top` the page has to scroll to the top of the page. This mirrors the browser's behavior.\n * If the hash fragment is an id, the page has to scroll to the element with that id.\n * If the hash fragment is a name, the page has to scroll to the first element with that name.\n */\nfunction getHashFragmentDomNode(hashFragment: string) {\n  // If the hash fragment is `top` the page has to scroll to the top of the page.\n  if (hashFragment === 'top') {\n    return document.body\n  }\n\n  // If the hash fragment is an id, the page has to scroll to the element with that id.\n  return (\n    document.getElementById(hashFragment) ??\n    // If the hash fragment is a name, the page has to scroll to the first element with that name.\n    document.getElementsByName(hashFragment)[0]\n  )\n}\ninterface ScrollAndFocusHandlerProps {\n  focusAndScrollRef: FocusAndScrollRef\n  children: React.ReactNode\n  segmentPath: FlightSegmentPath\n}\nclass InnerScrollAndFocusHandler extends React.Component<ScrollAndFocusHandlerProps> {\n  handlePotentialScroll = () => {\n    // Handle scroll and focus, it's only applied once in the first useEffect that triggers that changed.\n    const { focusAndScrollRef, segmentPath } = this.props\n\n    if (focusAndScrollRef.apply) {\n      // segmentPaths is an array of segment paths that should be scrolled to\n      // if the current segment path is not in the array, the scroll is not applied\n      // unless the array is empty, in which case the scroll is always applied\n      if (\n        focusAndScrollRef.segmentPaths.length !== 0 &&\n        !focusAndScrollRef.segmentPaths.some((scrollRefSegmentPath) =>\n          segmentPath.every((segment, index) =>\n            matchSegment(segment, scrollRefSegmentPath[index])\n          )\n        )\n      ) {\n        return\n      }\n\n      let domNode:\n        | ReturnType<typeof getHashFragmentDomNode>\n        | ReturnType<typeof findDOMNode> = null\n      const hashFragment = focusAndScrollRef.hashFragment\n\n      if (hashFragment) {\n        domNode = getHashFragmentDomNode(hashFragment)\n      }\n\n      // `findDOMNode` is tricky because it returns just the first child if the component is a fragment.\n      // This already caused a bug where the first child was a <link/> in head.\n      if (!domNode) {\n        domNode = findDOMNode(this)\n      }\n\n      // If there is no DOM node this layout-router level is skipped. It'll be handled higher-up in the tree.\n      if (!(domNode instanceof Element)) {\n        return\n      }\n\n      // Verify if the element is a HTMLElement and if we want to consider it for scroll behavior.\n      // If the element is skipped, try to select the next sibling and try again.\n      while (!(domNode instanceof HTMLElement) || shouldSkipElement(domNode)) {\n        // No siblings found that match the criteria are found, so handle scroll higher up in the tree instead.\n        if (domNode.nextElementSibling === null) {\n          return\n        }\n        domNode = domNode.nextElementSibling\n      }\n\n      // State is mutated to ensure that the focus and scroll is applied only once.\n      focusAndScrollRef.apply = false\n      focusAndScrollRef.hashFragment = null\n      focusAndScrollRef.segmentPaths = []\n\n      handleSmoothScroll(\n        () => {\n          // In case of hash scroll, we only need to scroll the element into view\n          if (hashFragment) {\n            ;(domNode as HTMLElement).scrollIntoView()\n\n            return\n          }\n          // Store the current viewport height because reading `clientHeight` causes a reflow,\n          // and it won't change during this function.\n          const htmlElement = document.documentElement\n          const viewportHeight = htmlElement.clientHeight\n\n          // If the element's top edge is already in the viewport, exit early.\n          if (topOfElementInViewport(domNode as HTMLElement, viewportHeight)) {\n            return\n          }\n\n          // Otherwise, try scrolling go the top of the document to be backward compatible with pages\n          // scrollIntoView() called on `<html/>` element scrolls horizontally on chrome and firefox (that shouldn't happen)\n          // We could use it to scroll horizontally following RTL but that also seems to be broken - it will always scroll left\n          // scrollLeft = 0 also seems to ignore RTL and manually checking for RTL is too much hassle so we will scroll just vertically\n          htmlElement.scrollTop = 0\n\n          // Scroll to domNode if domNode is not in viewport when scrolled to top of document\n          if (!topOfElementInViewport(domNode as HTMLElement, viewportHeight)) {\n            // Scroll into view doesn't scroll horizontally by default when not needed\n            ;(domNode as HTMLElement).scrollIntoView()\n          }\n        },\n        {\n          // We will force layout by querying domNode position\n          dontForceLayout: true,\n          onlyHashChange: focusAndScrollRef.onlyHashChange,\n        }\n      )\n\n      // Mutate after scrolling so that it can be read by `handleSmoothScroll`\n      focusAndScrollRef.onlyHashChange = false\n\n      // Set focus on the element\n      domNode.focus()\n    }\n  }\n\n  componentDidMount() {\n    this.handlePotentialScroll()\n  }\n\n  componentDidUpdate() {\n    // Because this property is overwritten in handlePotentialScroll it's fine to always run it when true as it'll be set to false for subsequent renders.\n    if (this.props.focusAndScrollRef.apply) {\n      this.handlePotentialScroll()\n    }\n  }\n\n  render() {\n    return this.props.children\n  }\n}\n\nfunction ScrollAndFocusHandler({\n  segmentPath,\n  children,\n}: {\n  segmentPath: FlightSegmentPath\n  children: React.ReactNode\n}) {\n  const context = useContext(GlobalLayoutRouterContext)\n  if (!context) {\n    throw new Error('invariant global layout router not mounted')\n  }\n\n  return (\n    <InnerScrollAndFocusHandler\n      segmentPath={segmentPath}\n      focusAndScrollRef={context.focusAndScrollRef}\n    >\n      {children}\n    </InnerScrollAndFocusHandler>\n  )\n}\n\n/**\n * InnerLayoutRouter handles rendering the provided segment based on the cache.\n */\nfunction InnerLayoutRouter({\n  parallelRouterKey,\n  url,\n  childNodes,\n  segmentPath,\n  tree,\n  // TODO-APP: implement `<Offscreen>` when available.\n  // isActive,\n  cacheKey,\n}: {\n  parallelRouterKey: string\n  url: string\n  childNodes: ChildSegmentMap\n  segmentPath: FlightSegmentPath\n  tree: FlightRouterState\n  isActive: boolean\n  cacheKey: ReturnType<typeof createRouterCacheKey>\n}) {\n  const context = useContext(GlobalLayoutRouterContext)\n  if (!context) {\n    throw new Error('invariant global layout router not mounted')\n  }\n\n  const { buildId, changeByServerResponse, tree: fullTree } = context\n\n  // Read segment path from the parallel router cache node.\n  let childNode = childNodes.get(cacheKey)\n\n  // When data is not available during rendering client-side we need to fetch\n  // it from the server.\n  if (childNode === undefined) {\n    const newLazyCacheNode: LazyCacheNode = {\n      lazyData: null,\n      rsc: null,\n      prefetchRsc: null,\n      head: null,\n      prefetchHead: null,\n      parallelRoutes: new Map(),\n      loading: null,\n    }\n\n    /**\n     * Flight data fetch kicked off during render and put into the cache.\n     */\n    childNode = newLazyCacheNode\n    childNodes.set(cacheKey, newLazyCacheNode)\n  }\n\n  // `rsc` represents the renderable node for this segment.\n\n  // If this segment has a `prefetchRsc`, it's the statically prefetched data.\n  // We should use that on initial render instead of `rsc`. Then we'll switch\n  // to `rsc` when the dynamic response streams in.\n  //\n  // If no prefetch data is available, then we go straight to rendering `rsc`.\n  const resolvedPrefetchRsc =\n    childNode.prefetchRsc !== null ? childNode.prefetchRsc : childNode.rsc\n\n  // We use `useDeferredValue` to handle switching between the prefetched and\n  // final values. The second argument is returned on initial render, then it\n  // re-renders with the first argument.\n  //\n  // @ts-expect-error The second argument to `useDeferredValue` is only\n  // available in the experimental builds. When its disabled, it will always\n  // return `rsc`.\n  const rsc: any = useDeferredValue(childNode.rsc, resolvedPrefetchRsc)\n\n  // `rsc` is either a React node or a promise for a React node, except we\n  // special case `null` to represent that this segment's data is missing. If\n  // it's a promise, we need to unwrap it so we can determine whether or not the\n  // data is missing.\n  const resolvedRsc: React.ReactNode =\n    typeof rsc === 'object' && rsc !== null && typeof rsc.then === 'function'\n      ? use(rsc)\n      : rsc\n\n  if (!resolvedRsc) {\n    // The data for this segment is not available, and there's no pending\n    // navigation that will be able to fulfill it. We need to fetch more from\n    // the server and patch the cache.\n\n    // Check if there's already a pending request.\n    let lazyData = childNode.lazyData\n    if (lazyData === null) {\n      /**\n       * Router state with refetch marker added\n       */\n      // TODO-APP: remove ''\n      const refetchTree = walkAddRefetch(['', ...segmentPath], fullTree)\n      const includeNextUrl = hasInterceptionRouteInCurrentTree(fullTree)\n      childNode.lazyData = lazyData = fetchServerResponse(\n        new URL(url, location.origin),\n        {\n          flightRouterState: refetchTree,\n          nextUrl: includeNextUrl ? context.nextUrl : null,\n          buildId,\n        }\n      ).then((serverResponse) => {\n        startTransition(() => {\n          changeByServerResponse({\n            previousTree: fullTree,\n            serverResponse,\n          })\n        })\n\n        return serverResponse\n      })\n    }\n    // Suspend infinitely as `changeByServerResponse` will cause a different part of the tree to be rendered.\n    // A falsey `resolvedRsc` indicates missing data -- we should not commit that branch, and we need to wait for the data to arrive.\n    use(unresolvedThenable) as never\n  }\n\n  // If we get to this point, then we know we have something we can render.\n  const subtree = (\n    // The layout router context narrows down tree and childNodes at each level.\n    <LayoutRouterContext.Provider\n      value={{\n        tree: tree[1][parallelRouterKey],\n        childNodes: childNode.parallelRoutes,\n        // TODO-APP: overriding of url for parallel routes\n        url: url,\n        loading: childNode.loading,\n      }}\n    >\n      {resolvedRsc}\n    </LayoutRouterContext.Provider>\n  )\n  // Ensure root layout is not wrapped in a div as the root layout renders `<html>`\n  return subtree\n}\n\n/**\n * Renders suspense boundary with the provided \"loading\" property as the fallback.\n * If no loading property is provided it renders the children without a suspense boundary.\n */\nfunction LoadingBoundary({\n  children,\n  hasLoading,\n  loading,\n  loadingStyles,\n  loadingScripts,\n}: {\n  children: React.ReactNode\n  hasLoading: boolean\n  loading?: React.ReactNode\n  loadingStyles?: React.ReactNode\n  loadingScripts?: React.ReactNode\n}): JSX.Element {\n  // We have an explicit prop for checking if `loading` is provided, to disambiguate between a loading\n  // component that returns `null` / `undefined`, vs not having a loading component at all.\n  if (hasLoading) {\n    return (\n      <Suspense\n        fallback={\n          <>\n            {loadingStyles}\n            {loadingScripts}\n            {loading}\n          </>\n        }\n      >\n        {children}\n      </Suspense>\n    )\n  }\n\n  return <>{children}</>\n}\n\n/**\n * OuterLayoutRouter handles the current segment as well as <Offscreen> rendering of other segments.\n * It can be rendered next to each other with a different `parallelRouterKey`, allowing for Parallel routes.\n */\nexport default function OuterLayoutRouter({\n  parallelRouterKey,\n  segmentPath,\n  error,\n  errorStyles,\n  errorScripts,\n  templateStyles,\n  templateScripts,\n  template,\n  notFound,\n  notFoundStyles,\n}: {\n  parallelRouterKey: string\n  segmentPath: FlightSegmentPath\n  error: ErrorComponent | undefined\n  errorStyles: React.ReactNode | undefined\n  errorScripts: React.ReactNode | undefined\n  templateStyles: React.ReactNode | undefined\n  templateScripts: React.ReactNode | undefined\n  template: React.ReactNode\n  notFound: React.ReactNode | undefined\n  notFoundStyles: React.ReactNode | undefined\n}) {\n  const context = useContext(LayoutRouterContext)\n  if (!context) {\n    throw new Error('invariant expected layout router to be mounted')\n  }\n\n  const { childNodes, tree, url, loading } = context\n\n  // Get the current parallelRouter cache node\n  let childNodesForParallelRouter = childNodes.get(parallelRouterKey)\n  // If the parallel router cache node does not exist yet, create it.\n  // This writes to the cache when there is no item in the cache yet. It never *overwrites* existing cache items which is why it's safe in concurrent mode.\n  if (!childNodesForParallelRouter) {\n    childNodesForParallelRouter = new Map()\n    childNodes.set(parallelRouterKey, childNodesForParallelRouter)\n  }\n\n  // Get the active segment in the tree\n  // The reason arrays are used in the data format is that these are transferred from the server to the browser so it's optimized to save bytes.\n  const treeSegment = tree[1][parallelRouterKey][0]\n\n  // If segment is an array it's a dynamic route and we want to read the dynamic route value as the segment to get from the cache.\n  const currentChildSegmentValue = getSegmentValue(treeSegment)\n\n  /**\n   * Decides which segments to keep rendering, all segments that are not active will be wrapped in `<Offscreen>`.\n   */\n  // TODO-APP: Add handling of `<Offscreen>` when it's available.\n  const preservedSegments: Segment[] = [treeSegment]\n\n  return (\n    <>\n      {preservedSegments.map((preservedSegment) => {\n        const preservedSegmentValue = getSegmentValue(preservedSegment)\n        const cacheKey = createRouterCacheKey(preservedSegment)\n\n        return (\n          /*\n            - Error boundary\n              - Only renders error boundary if error component is provided.\n              - Rendered for each segment to ensure they have their own error state.\n            - Loading boundary\n              - Only renders suspense boundary if loading components is provided.\n              - Rendered for each segment to ensure they have their own loading state.\n              - Passed to the router during rendering to ensure it can be immediately rendered when suspending on a Flight fetch.\n          */\n          <TemplateContext.Provider\n            key={createRouterCacheKey(preservedSegment, true)}\n            value={\n              <ScrollAndFocusHandler segmentPath={segmentPath}>\n                <ErrorBoundary\n                  errorComponent={error}\n                  errorStyles={errorStyles}\n                  errorScripts={errorScripts}\n                >\n                  <LoadingBoundary\n                    hasLoading={Boolean(loading)}\n                    loading={loading?.[0]}\n                    loadingStyles={loading?.[1]}\n                    loadingScripts={loading?.[2]}\n                  >\n                    <NotFoundBoundary\n                      notFound={notFound}\n                      notFoundStyles={notFoundStyles}\n                    >\n                      <RedirectBoundary>\n                        <InnerLayoutRouter\n                          parallelRouterKey={parallelRouterKey}\n                          url={url}\n                          tree={tree}\n                          childNodes={childNodesForParallelRouter!}\n                          segmentPath={segmentPath}\n                          cacheKey={cacheKey}\n                          isActive={\n                            currentChildSegmentValue === preservedSegmentValue\n                          }\n                        />\n                      </RedirectBoundary>\n                    </NotFoundBoundary>\n                  </LoadingBoundary>\n                </ErrorBoundary>\n              </ScrollAndFocusHandler>\n            }\n          >\n            {templateStyles}\n            {templateScripts}\n            {template}\n          </TemplateContext.Provider>\n        )\n      })}\n    </>\n  )\n}\n"],"names":["OuterLayoutRouter","walkAddRefetch","segmentPathToWalk","treeToRecreate","segment","parallelRouteKey","isLast","length","matchSegment","hasOwnProperty","subTree","undefined","slice","__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE","ReactDOM","findDOMNode","instance","window","internal_reactDOMfindDOMNode","rectProperties","shouldSkipElement","element","includes","getComputedStyle","position","process","env","NODE_ENV","console","warn","rect","getBoundingClientRect","every","item","topOfElementInViewport","viewportHeight","top","getHashFragmentDomNode","hashFragment","document","body","getElementById","getElementsByName","InnerScrollAndFocusHandler","React","Component","componentDidMount","handlePotentialScroll","componentDidUpdate","props","focusAndScrollRef","apply","render","children","segmentPath","segmentPaths","some","scrollRefSegmentPath","index","domNode","Element","HTMLElement","nextElementSibling","handleSmoothScroll","scrollIntoView","htmlElement","documentElement","clientHeight","scrollTop","dontForceLayout","onlyHashChange","focus","ScrollAndFocusHandler","context","useContext","GlobalLayoutRouterContext","Error","InnerLayoutRouter","parallelRouterKey","url","childNodes","tree","cacheKey","buildId","changeByServerResponse","fullTree","childNode","get","newLazyCacheNode","lazyData","rsc","prefetchRsc","head","prefetchHead","parallelRoutes","Map","loading","set","resolvedPrefetchRsc","useDeferredValue","resolvedRsc","then","use","refetchTree","includeNextUrl","hasInterceptionRouteInCurrentTree","fetchServerResponse","URL","location","origin","flightRouterState","nextUrl","serverResponse","startTransition","previousTree","unresolvedThenable","subtree","LayoutRouterContext","Provider","value","LoadingBoundary","hasLoading","loadingStyles","loadingScripts","Suspense","fallback","error","errorStyles","errorScripts","templateStyles","templateScripts","template","notFound","notFoundStyles","childNodesForParallelRouter","treeSegment","currentChildSegmentValue","getSegmentValue","preservedSegments","map","preservedSegment","preservedSegmentValue","createRouterCacheKey","TemplateContext","ErrorBoundary","errorComponent","Boolean","NotFoundBoundary","RedirectBoundary","isActive"],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(app-pages-browser)/./node_modules/next/dist/client/components/layout-router.js\n"));
|
150
150
|
|
151
151
|
/***/ }),
|
152
152
|
|