@ahmedrowaihi/pdf-forge-preview 1.0.0-canary.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.next/BUILD_ID +1 -0
- package/.next/app-path-routes-manifest.json +7 -0
- package/.next/build/chunks/[root-of-the-server]__12fb5caf._.js +233 -0
- package/.next/build/chunks/[root-of-the-server]__12fb5caf._.js.map +8 -0
- package/.next/build/chunks/[root-of-the-server]__242deb00._.js +500 -0
- package/.next/build/chunks/[root-of-the-server]__242deb00._.js.map +11 -0
- package/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_ad9a1eec._.js +13 -0
- package/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_ad9a1eec._.js.map +5 -0
- package/.next/build/chunks/[turbopack]_runtime.js +795 -0
- package/.next/build/chunks/[turbopack]_runtime.js.map +10 -0
- package/.next/build/chunks/node_modules__pnpm_806d01c0._.js +6758 -0
- package/.next/build/chunks/node_modules__pnpm_806d01c0._.js.map +47 -0
- package/.next/build/package.json +1 -0
- package/.next/build/postcss.js +6 -0
- package/.next/build/postcss.js.map +5 -0
- package/.next/build-manifest.json +20 -0
- package/.next/diagnostics/build-diagnostics.json +6 -0
- package/.next/diagnostics/framework.json +1 -0
- package/.next/export-marker.json +6 -0
- package/.next/fallback-build-manifest.json +12 -0
- package/.next/images-manifest.json +66 -0
- package/.next/next-minimal-server.js.nft.json +1 -0
- package/.next/next-server.js.nft.json +1 -0
- package/.next/package.json +1 -0
- package/.next/prerender-manifest.json +65 -0
- package/.next/required-server-files.js +163 -0
- package/.next/required-server-files.json +163 -0
- package/.next/routes-manifest.json +77 -0
- package/.next/server/app/_global-error/page/app-paths-manifest.json +3 -0
- package/.next/server/app/_global-error/page/build-manifest.json +17 -0
- package/.next/server/app/_global-error/page/next-font-manifest.json +6 -0
- package/.next/server/app/_global-error/page/react-loadable-manifest.json +1 -0
- package/.next/server/app/_global-error/page/server-reference-manifest.json +4 -0
- package/.next/server/app/_global-error/page.js +11 -0
- package/.next/server/app/_global-error/page.js.map +5 -0
- package/.next/server/app/_global-error/page.js.nft.json +1 -0
- package/.next/server/app/_global-error/page_client-reference-manifest.js +2 -0
- package/.next/server/app/_global-error.html +2 -0
- package/.next/server/app/_global-error.meta +15 -0
- package/.next/server/app/_global-error.rsc +13 -0
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +5 -0
- package/.next/server/app/_global-error.segments/_full.segment.rsc +13 -0
- package/.next/server/app/_global-error.segments/_head.segment.rsc +6 -0
- package/.next/server/app/_global-error.segments/_index.segment.rsc +4 -0
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -0
- package/.next/server/app/_not-found/page/app-paths-manifest.json +3 -0
- package/.next/server/app/_not-found/page/build-manifest.json +17 -0
- package/.next/server/app/_not-found/page/next-font-manifest.json +16 -0
- package/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -0
- package/.next/server/app/_not-found/page/server-reference-manifest.json +20 -0
- package/.next/server/app/_not-found/page.js +14 -0
- package/.next/server/app/_not-found/page.js.map +5 -0
- package/.next/server/app/_not-found/page.js.nft.json +1 -0
- package/.next/server/app/_not-found/page_client-reference-manifest.js +2 -0
- package/.next/server/app/favicon.ico/route/app-paths-manifest.json +3 -0
- package/.next/server/app/favicon.ico/route/build-manifest.json +11 -0
- package/.next/server/app/favicon.ico/route.js +6 -0
- package/.next/server/app/favicon.ico/route.js.map +5 -0
- package/.next/server/app/favicon.ico/route.js.nft.json +1 -0
- package/.next/server/app/favicon.ico.body +0 -0
- package/.next/server/app/favicon.ico.meta +1 -0
- package/.next/server/app/page/app-paths-manifest.json +3 -0
- package/.next/server/app/page/build-manifest.json +17 -0
- package/.next/server/app/page/next-font-manifest.json +16 -0
- package/.next/server/app/page/react-loadable-manifest.json +1 -0
- package/.next/server/app/page/server-reference-manifest.json +20 -0
- package/.next/server/app/page.js +17 -0
- package/.next/server/app/page.js.map +5 -0
- package/.next/server/app/page.js.nft.json +1 -0
- package/.next/server/app/page_client-reference-manifest.js +2 -0
- package/.next/server/app/preview/[...slug]/page/app-paths-manifest.json +3 -0
- package/.next/server/app/preview/[...slug]/page/build-manifest.json +17 -0
- package/.next/server/app/preview/[...slug]/page/next-font-manifest.json +16 -0
- package/.next/server/app/preview/[...slug]/page/react-loadable-manifest.json +1 -0
- package/.next/server/app/preview/[...slug]/page/server-reference-manifest.json +65 -0
- package/.next/server/app/preview/[...slug]/page.js +19 -0
- package/.next/server/app/preview/[...slug]/page.js.map +5 -0
- package/.next/server/app/preview/[...slug]/page.js.nft.json +1 -0
- package/.next/server/app/preview/[...slug]/page_client-reference-manifest.js +2 -0
- package/.next/server/app-paths-manifest.json +7 -0
- package/.next/server/chunks/730ea_preview-server__next-internal_server_app_favicon_ico_route_actions_a71a8ae7.js +3 -0
- package/.next/server/chunks/730ea_preview-server__next-internal_server_app_favicon_ico_route_actions_a71a8ae7.js.map +1 -0
- package/.next/server/chunks/[externals]_next_dist_a6d89067._.js +3 -0
- package/.next/server/chunks/[externals]_next_dist_a6d89067._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__a62cd78d._.js +21 -0
- package/.next/server/chunks/[root-of-the-server]__a62cd78d._.js.map +1 -0
- package/.next/server/chunks/[turbopack]_runtime.js +795 -0
- package/.next/server/chunks/[turbopack]_runtime.js.map +10 -0
- package/.next/server/chunks/ssr/730ea_preview-server__next-internal_server_app__global-error_page_actions_986e2de5.js +3 -0
- package/.next/server/chunks/ssr/730ea_preview-server__next-internal_server_app__global-error_page_actions_986e2de5.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__025eaae9._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__025eaae9._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__1536282c._.js +4 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__1536282c._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__15cf9d36._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__15cf9d36._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__450f653e._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__450f653e._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__4874d0d7._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__4874d0d7._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__49771cdc._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__49771cdc._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__9ff74047._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__9ff74047._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__a9be37b1._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__a9be37b1._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__aeefe74e._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__aeefe74e._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__b13738d2._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__b13738d2._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__bb428c83._.js +4 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__bb428c83._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__c61333e3._.js +10 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__c61333e3._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__cb0c7b1a._.js +4 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__cb0c7b1a._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__dafcae4c._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__dafcae4c._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__e47d0c07._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__e47d0c07._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__ecac8617._.js +31 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__ecac8617._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__fd4bda25._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__fd4bda25._.js.map +1 -0
- package/.next/server/chunks/ssr/[turbopack]_runtime.js +795 -0
- package/.next/server/chunks/ssr/[turbopack]_runtime.js.map +10 -0
- package/.next/server/chunks/ssr/_19494208._.js +19 -0
- package/.next/server/chunks/ssr/_19494208._.js.map +1 -0
- package/.next/server/chunks/ssr/_810f54e9._.js +4 -0
- package/.next/server/chunks/ssr/_810f54e9._.js.map +1 -0
- package/.next/server/chunks/ssr/_aa01e67e._.js +4 -0
- package/.next/server/chunks/ssr/_aa01e67e._.js.map +1 -0
- package/.next/server/chunks/ssr/_bf10718b._.js +4 -0
- package/.next/server/chunks/ssr/_bf10718b._.js.map +1 -0
- package/.next/server/chunks/ssr/_c57c12df._.js +4 -0
- package/.next/server/chunks/ssr/_c57c12df._.js.map +1 -0
- package/.next/server/chunks/ssr/_d9b57cb8._.js +5 -0
- package/.next/server/chunks/ssr/_d9b57cb8._.js.map +1 -0
- package/.next/server/chunks/ssr/_e2a766a8._.js +3 -0
- package/.next/server/chunks/ssr/_e2a766a8._.js.map +1 -0
- package/.next/server/chunks/ssr/_e2b86512._.js +8 -0
- package/.next/server/chunks/ssr/_e2b86512._.js.map +1 -0
- package/.next/server/chunks/ssr/_ee8ea3aa._.js +19 -0
- package/.next/server/chunks/ssr/_ee8ea3aa._.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_5870db32._.js +3 -0
- package/.next/server/chunks/ssr/e8449_next_dist_5870db32._.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_builtin_forbidden_5542069c.js +3 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_builtin_forbidden_5542069c.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_builtin_global-error_d0870f3a.js +3 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_builtin_global-error_d0870f3a.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_builtin_unauthorized_4c01c8d5.js +3 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_builtin_unauthorized_4c01c8d5.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_d90ace34._.js +3 -0
- package/.next/server/chunks/ssr/e8449_next_dist_client_components_d90ace34._.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_esm_af7aafb8._.js +6 -0
- package/.next/server/chunks/ssr/e8449_next_dist_esm_af7aafb8._.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_esm_build_templates_app-page_f16f0848.js +4 -0
- package/.next/server/chunks/ssr/e8449_next_dist_esm_build_templates_app-page_f16f0848.js.map +1 -0
- package/.next/server/chunks/ssr/e8449_next_dist_f0d8a2cc._.js +4 -0
- package/.next/server/chunks/ssr/e8449_next_dist_f0d8a2cc._.js.map +1 -0
- package/.next/server/chunks/ssr/node_modules__pnpm_37510d96._.js +5 -0
- package/.next/server/chunks/ssr/node_modules__pnpm_37510d96._.js.map +1 -0
- package/.next/server/chunks/ssr/packages_preview-server_src_app_897ecf1c._.js +3 -0
- package/.next/server/chunks/ssr/packages_preview-server_src_app_897ecf1c._.js.map +1 -0
- package/.next/server/chunks/ssr/packages_preview-server_src_e17a2a9b._.js +3 -0
- package/.next/server/chunks/ssr/packages_preview-server_src_e17a2a9b._.js.map +1 -0
- package/.next/server/functions-config-manifest.json +4 -0
- package/.next/server/interception-route-rewrite-manifest.js +1 -0
- package/.next/server/middleware-build-manifest.js +21 -0
- package/.next/server/middleware-manifest.json +6 -0
- package/.next/server/next-font-manifest.js +1 -0
- package/.next/server/next-font-manifest.json +34 -0
- package/.next/server/pages/500.html +2 -0
- package/.next/server/pages-manifest.json +3 -0
- package/.next/server/server-reference-manifest.js +1 -0
- package/.next/server/server-reference-manifest.json +80 -0
- package/.next/static/cdYIhKFtJ0GB-yJK5ywz_/_buildManifest.js +11 -0
- package/.next/static/cdYIhKFtJ0GB-yJK5ywz_/_clientMiddlewareManifest.json +1 -0
- package/.next/static/cdYIhKFtJ0GB-yJK5ywz_/_ssgManifest.js +1 -0
- package/.next/static/chunks/0464c7ff175ee6ff.js +1 -0
- package/.next/static/chunks/10468413db24762a.js +14 -0
- package/.next/static/chunks/2de338262e51ef94.js +3 -0
- package/.next/static/chunks/37adc260f85da877.js +1 -0
- package/.next/static/chunks/521eee9903bc4d1f.js +5 -0
- package/.next/static/chunks/6051bd38272cb442.js +14 -0
- package/.next/static/chunks/8d433d4b9d701456.js +1 -0
- package/.next/static/chunks/92ba72595aad9df6.js +1 -0
- package/.next/static/chunks/959ed978a6e89a66.js +1 -0
- package/.next/static/chunks/a6dad97d9634a72d.js +1 -0
- package/.next/static/chunks/a6dad97d9634a72d.js.map +1 -0
- package/.next/static/chunks/a6db6456c5b75734.js +1 -0
- package/.next/static/chunks/c3ece0a7e3e07076.js +1 -0
- package/.next/static/chunks/d1b29a74f6814a03.css +3 -0
- package/.next/static/chunks/f7ec22614fe1c1fe.js +1 -0
- package/.next/static/chunks/turbopack-e062a8e6d6034eb0.js +4 -0
- package/.next/static/media/1bffadaabf893a1e-s.7cd81963.woff2 +0 -0
- package/.next/static/media/2bbe8d2671613f1f-s.76dcb0b2.woff2 +0 -0
- package/.next/static/media/2c55a0e60120577a-s.2a48534a.woff2 +0 -0
- package/.next/static/media/5476f68d60460930-s.c995e352.woff2 +0 -0
- package/.next/static/media/83afe278b6a6bb3c-s.p.3a6ba036.woff2 +0 -0
- package/.next/static/media/9c72aa0f40e4eef8-s.18a48cbc.woff2 +0 -0
- package/.next/static/media/SFMonoBold-s.p.b90ec775.otf +0 -0
- package/.next/static/media/SFMonoHeavy-s.p.545fe93b.otf +0 -0
- package/.next/static/media/SFMonoLight-s.p.7c5363a6.otf +0 -0
- package/.next/static/media/SFMonoMedium-s.p.a4fc9904.otf +0 -0
- package/.next/static/media/SFMonoRegular-s.p.04ea7bf3.otf +0 -0
- package/.next/static/media/SFMonoSemibold-s.p.2d2ddb43.otf +0 -0
- package/.next/static/media/ad66f9afd8947f86-s.7a40eb73.woff2 +0 -0
- package/.next/static/media/favicon.678eb597.ico +0 -0
- package/.next/static/media/logo.22a370b0.png +0 -0
- package/.next/trace +1 -0
- package/.next/trace-build +1 -0
- package/.next/turbopack +0 -0
- package/.next/types/routes.d.ts +58 -0
- package/.next/types/validator.ts +70 -0
- package/CHANGELOG.md +12 -0
- package/LICENSE.md +8 -0
- package/index.mjs +17 -0
- package/jsx-runtime/jsx-dev-runtime.js +26 -0
- package/module-punycode.d.ts +3 -0
- package/next-env.d.ts +6 -0
- package/next.config.mjs +15 -0
- package/package.json +78 -0
- package/postcss.config.js +5 -0
- package/readme.md +33 -0
- package/scripts/build-preview-server.mts +25 -0
- package/scripts/dev.mts +57 -0
- package/scripts/seed.mts +36 -0
- package/src/actions/export-single-template.ts +74 -0
- package/src/actions/get-template-path-from-slug.ts +32 -0
- package/src/actions/get-templates-directory-metadata-action.ts +19 -0
- package/src/actions/render-template-by-path.tsx +313 -0
- package/src/actions/safe-action.ts +15 -0
- package/src/animated-icons-data/help.json +1082 -0
- package/src/animated-icons-data/link.json +1309 -0
- package/src/animated-icons-data/load.json +443 -0
- package/src/animated-icons-data/mail.json +1320 -0
- package/src/app/env.ts +14 -0
- package/src/app/favicon.ico +0 -0
- package/src/app/fonts/SFMono/SFMonoBold.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoBoldItalic.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoHeavy.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoHeavyItalic.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoLight.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoLightItalic.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoMedium.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoMediumItalic.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoRegular.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoRegularItalic.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoSemibold.otf +0 -0
- package/src/app/fonts/SFMono/SFMonoSemiboldItalic.otf +0 -0
- package/src/app/fonts.ts +39 -0
- package/src/app/globals.css +136 -0
- package/src/app/layout.tsx +46 -0
- package/src/app/logo.png +0 -0
- package/src/app/page.tsx +52 -0
- package/src/app/preview/[...slug]/download-button.tsx +138 -0
- package/src/app/preview/[...slug]/error-overlay.tsx +58 -0
- package/src/app/preview/[...slug]/page.tsx +90 -0
- package/src/app/preview/[...slug]/preview.tsx +249 -0
- package/src/app/preview/[...slug]/template-frame.tsx +68 -0
- package/src/components/button.tsx +101 -0
- package/src/components/code-container.tsx +169 -0
- package/src/components/code-snippet.tsx +9 -0
- package/src/components/code.tsx +185 -0
- package/src/components/heading.tsx +113 -0
- package/src/components/icons/icon-arrow-down.tsx +16 -0
- package/src/components/icons/icon-base.tsx +26 -0
- package/src/components/icons/icon-bug.tsx +19 -0
- package/src/components/icons/icon-button.tsx +23 -0
- package/src/components/icons/icon-check.tsx +19 -0
- package/src/components/icons/icon-clipboard.tsx +40 -0
- package/src/components/icons/icon-cloud-alert.tsx +18 -0
- package/src/components/icons/icon-cloud-check.tsx +17 -0
- package/src/components/icons/icon-download.tsx +19 -0
- package/src/components/icons/icon-file.tsx +19 -0
- package/src/components/icons/icon-folder-open.tsx +19 -0
- package/src/components/icons/icon-folder.tsx +18 -0
- package/src/components/icons/icon-hide-sidebar.tsx +23 -0
- package/src/components/icons/icon-image.tsx +19 -0
- package/src/components/icons/icon-info.tsx +18 -0
- package/src/components/icons/icon-link.tsx +14 -0
- package/src/components/icons/icon-loader.tsx +16 -0
- package/src/components/icons/icon-monitor.tsx +19 -0
- package/src/components/icons/icon-moon.tsx +16 -0
- package/src/components/icons/icon-phone.tsx +26 -0
- package/src/components/icons/icon-reload.tsx +18 -0
- package/src/components/icons/icon-source.tsx +19 -0
- package/src/components/icons/icon-stamp.tsx +14 -0
- package/src/components/icons/icon-sun.tsx +74 -0
- package/src/components/icons/icon-warning.tsx +31 -0
- package/src/components/index.ts +7 -0
- package/src/components/logo.tsx +41 -0
- package/src/components/resizable-wrapper.tsx +269 -0
- package/src/components/shell.tsx +95 -0
- package/src/components/sidebar/file-tree-directory-children.tsx +142 -0
- package/src/components/sidebar/file-tree-directory.tsx +92 -0
- package/src/components/sidebar/file-tree.tsx +31 -0
- package/src/components/sidebar/index.ts +1 -0
- package/src/components/sidebar/sidebar.tsx +46 -0
- package/src/components/text.tsx +99 -0
- package/src/components/toolbar/checking-results.tsx +150 -0
- package/src/components/toolbar/code-preview-line-link.tsx +39 -0
- package/src/components/toolbar/results-table.tsx +0 -0
- package/src/components/toolbar/results.tsx +52 -0
- package/src/components/toolbar/toolbar-button.tsx +52 -0
- package/src/components/toolbar/use-cached-state.ts +36 -0
- package/src/components/toolbar.tsx +182 -0
- package/src/components/tooltip-content.tsx +31 -0
- package/src/components/tooltip.tsx +19 -0
- package/src/components/topbar/active-view-toggle-group.tsx +86 -0
- package/src/components/topbar/emulated-dark-mode-toggle.tsx +58 -0
- package/src/components/topbar/view-size-controls.tsx +173 -0
- package/src/components/topbar.tsx +59 -0
- package/src/contexts/preview.tsx +91 -0
- package/src/contexts/templates.tsx +57 -0
- package/src/contexts/toolbar.tsx +22 -0
- package/src/hooks/use-clamped-state.ts +24 -0
- package/src/hooks/use-fragment-identifier.ts +14 -0
- package/src/hooks/use-hot-reload.ts +31 -0
- package/src/hooks/use-rendering-metadata.ts +37 -0
- package/src/hooks/use-template-rendering-result.ts +58 -0
- package/src/utils/cn.ts +6 -0
- package/src/utils/constants.ts +8 -0
- package/src/utils/contains-template.ts +52 -0
- package/src/utils/convert-stack-with-sourcemap.ts +79 -0
- package/src/utils/copy-text-to-clipboard.ts +7 -0
- package/src/utils/create-jsx-runtime.ts +47 -0
- package/src/utils/esbuild/escape-string-for-regex.ts +3 -0
- package/src/utils/esbuild/renderring-utilities-exporter.ts +64 -0
- package/src/utils/get-line-and-column-from-offset.ts +11 -0
- package/src/utils/get-template-component.ts +158 -0
- package/src/utils/get-templates-directory-metadata.ts +195 -0
- package/src/utils/index.ts +6 -0
- package/src/utils/language-map.ts +7 -0
- package/src/utils/load-stream.ts +15 -0
- package/src/utils/register-spinner-autostopping.ts +28 -0
- package/src/utils/result.ts +49 -0
- package/src/utils/run-bundled-code.ts +86 -0
- package/src/utils/sanitize.ts +6 -0
- package/src/utils/sleep.ts +3 -0
- package/src/utils/snake-to-camel.ts +5 -0
- package/src/utils/static-node-modules-for-vm.ts +93 -0
- package/src/utils/style-text.ts +11 -0
- package/src/utils/types/as.ts +26 -0
- package/src/utils/types/error-object.ts +11 -0
- package/src/utils/types/hot-reload-change.ts +13 -0
- package/src/utils/types/template.ts +8 -0
- package/src/utils/unreachable.ts +8 -0
- package/templates/.gitkeep +0 -0
- package/tsconfig.json +47 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/utils/warn-once.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/deployment-id.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/image-blur-svg.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/image-config.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/get-img-props.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/dist/client/image-component.js/__nextjs-internal-proxy.cjs","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/client/image-component.tsx","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/find-closest-quality.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/image-loader.ts","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/shared/lib/image-external.tsx","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/image.js","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/dist/client/app-dir/link.js/__nextjs-internal-proxy.cjs","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/client/app-dir/link.tsx","../../../../../../node_modules/.pnpm/next%4016.1.1_%40babel%2Bcore%407.26.10_react-dom%4019.2.3_react%4019.2.3__react%4019.2.3/node_modules/next/src/client/app-dir/link.react-server.tsx","../../../../../../packages/preview-server/src/components/button.tsx/__nextjs-internal-proxy.mjs","../../../../../../packages/preview-server/src/components/code.tsx/__nextjs-internal-proxy.mjs","../../../../../../packages/preview-server/src/components/sidebar/sidebar.tsx/__nextjs-internal-proxy.mjs","../../../../../../packages/preview-server/src/components/topbar.tsx/__nextjs-internal-proxy.mjs","../../../../../../packages/preview-server/src/components/index.ts","../../../../../../node_modules/.pnpm/clsx%402.1.1/node_modules/clsx/dist/clsx.mjs","../../../../../../node_modules/.pnpm/%40radix-ui%2Breact-slot%401.2.3_%40types%2Breact%4019.2.7_react%4019.2.3/node_modules/%40radix-ui/react-slot/dist/index.mjs","../../../../../../packages/preview-server/src/utils/language-map.ts","../../../../../../packages/preview-server/src/app/page.tsx","../../../../../../packages/preview-server/src/components/sidebar/index.ts","../../../../../../packages/preview-server/src/components/code-snippet.tsx","../../../../../../packages/preview-server/src/app/logo.png.mjs%20%28structured%20image%20object%20with%20data%20url%29","../../../../../../packages/preview-server/src/utils/copy-text-to-clipboard.ts","../../../../../../packages/preview-server/src/utils/unreachable.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/class-group-utils.ts","../../../../../../node_modules/.pnpm/%40radix-ui%2Breact-compose-refs%401.1.2_%40types%2Breact%4019.2.7_react%4019.2.3/node_modules/%40radix-ui/react-compose-refs/dist/index.mjs","../../../../../../packages/preview-server/src/components/logo.tsx","../../../../../../packages/preview-server/src/utils/cn.ts","../../../../../../packages/preview-server/src/utils/sanitize.ts","../../../../../../node_modules/.pnpm/%40radix-ui%2Breact-slot%401.2.3_%40types%2Breact%4019.2.7_react%4019.2.3/node_modules/%40radix-ui/react-slot/src/slot.tsx","../../../../../../packages/preview-server/src/components/text.tsx","../../../../../../packages/preview-server/src/components/heading.tsx","../../../../../../node_modules/.pnpm/%40radix-ui%2Breact-compose-refs%401.1.2_%40types%2Breact%4019.2.7_react%4019.2.3/node_modules/%40radix-ui/react-compose-refs/src/compose-refs.tsx","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/lru-cache.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/parse-class-name.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/sort-modifiers.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/config-utils.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/merge-classlist.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/tw-join.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/create-tailwind-merge.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/from-theme.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/validators.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/default-config.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/merge-configs.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/extend-tailwind-merge.ts","../../../../../../node_modules/.pnpm/tailwind-merge%403.2.0/node_modules/tailwind-merge/src/lib/tw-merge.ts"],"sourcesContent":["let warnOnce = (_: string) => {}\nif (process.env.NODE_ENV !== 'production') {\n const warnings = new Set<string>()\n warnOnce = (msg: string) => {\n if (!warnings.has(msg)) {\n console.warn(msg)\n }\n warnings.add(msg)\n }\n}\n\nexport { warnOnce }\n","// This could also be a variable instead of a function, but some unit tests want to change the ID at\n// runtime. Even though that would never happen in a real deployment.\nexport function getDeploymentId(): string | undefined {\n return process.env.NEXT_DEPLOYMENT_ID\n}\n\nexport function getDeploymentIdQueryOrEmptyString(): string {\n let deploymentId = getDeploymentId()\n if (deploymentId) {\n return `?dpl=${deploymentId}`\n }\n return ''\n}\n","/**\n * A shared function, used on both client and server, to generate a SVG blur placeholder.\n */\nexport function getImageBlurSvg({\n widthInt,\n heightInt,\n blurWidth,\n blurHeight,\n blurDataURL,\n objectFit,\n}: {\n widthInt?: number\n heightInt?: number\n blurWidth?: number\n blurHeight?: number\n blurDataURL: string\n objectFit?: string\n}): string {\n const std = 20\n const svgWidth = blurWidth ? blurWidth * 40 : widthInt\n const svgHeight = blurHeight ? blurHeight * 40 : heightInt\n\n const viewBox =\n svgWidth && svgHeight ? `viewBox='0 0 ${svgWidth} ${svgHeight}'` : ''\n const preserveAspectRatio = viewBox\n ? 'none'\n : objectFit === 'contain'\n ? 'xMidYMid'\n : objectFit === 'cover'\n ? 'xMidYMid slice'\n : 'none'\n\n return `%3Csvg xmlns='http://www.w3.org/2000/svg' ${viewBox}%3E%3Cfilter id='b' color-interpolation-filters='sRGB'%3E%3CfeGaussianBlur stdDeviation='${std}'/%3E%3CfeColorMatrix values='1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 100 -1' result='s'/%3E%3CfeFlood x='0' y='0' width='100%25' height='100%25'/%3E%3CfeComposite operator='out' in='s'/%3E%3CfeComposite in2='SourceGraphic'/%3E%3CfeGaussianBlur stdDeviation='${std}'/%3E%3C/filter%3E%3Cimage width='100%25' height='100%25' x='0' y='0' preserveAspectRatio='${preserveAspectRatio}' style='filter: url(%23b);' href='${blurDataURL}'/%3E%3C/svg%3E`\n}\n","export const VALID_LOADERS = [\n 'default',\n 'imgix',\n 'cloudinary',\n 'akamai',\n 'custom',\n] as const\n\nexport type LoaderValue = (typeof VALID_LOADERS)[number]\n\nexport type ImageLoaderProps = {\n src: string\n width: number\n quality?: number\n}\n\nexport type ImageLoaderPropsWithConfig = ImageLoaderProps & {\n config: Readonly<ImageConfig>\n}\n\nexport type LocalPattern = {\n /**\n * Can be literal or wildcard.\n * Single `*` matches a single path segment.\n * Double `**` matches any number of path segments.\n */\n pathname?: string\n\n /**\n * Can be literal query string such as `?v=1` or\n * empty string meaning no query string.\n */\n search?: string\n}\n\nexport type RemotePattern = {\n /**\n * Must be `http` or `https`.\n */\n protocol?: 'http' | 'https'\n\n /**\n * Can be literal or wildcard.\n * Single `*` matches a single subdomain.\n * Double `**` matches any number of subdomains.\n */\n hostname: string\n\n /**\n * Can be literal port such as `8080` or empty string\n * meaning no port.\n */\n port?: string\n\n /**\n * Can be literal or wildcard.\n * Single `*` matches a single path segment.\n * Double `**` matches any number of path segments.\n */\n pathname?: string\n\n /**\n * Can be literal query string such as `?v=1` or\n * empty string meaning no query string.\n */\n search?: string\n}\n\ntype ImageFormat = 'image/avif' | 'image/webp'\n\n/**\n * Image configurations\n *\n * @see [Image configuration options](https://nextjs.org/docs/api-reference/next/image#configuration-options)\n */\nexport type ImageConfigComplete = {\n /** @see [Device sizes documentation](https://nextjs.org/docs/api-reference/next/image#device-sizes) */\n deviceSizes: number[]\n\n /** @see [Image sizing documentation](https://nextjs.org/docs/app/building-your-application/optimizing/images#image-sizing) */\n imageSizes: number[]\n\n /** @see [Image loaders configuration](https://nextjs.org/docs/api-reference/next/legacy/image#loader) */\n loader: LoaderValue\n\n /** @see [Image loader configuration](https://nextjs.org/docs/app/api-reference/components/image#path) */\n path: string\n\n /** @see [Image loader configuration](https://nextjs.org/docs/api-reference/next/image#loader-configuration) */\n loaderFile: string\n\n /**\n * @deprecated Use `remotePatterns` instead.\n */\n domains: string[]\n\n /** @see [Disable static image import configuration](https://nextjs.org/docs/api-reference/next/image#disable-static-imports) */\n disableStaticImages: boolean\n\n /** @see [Cache behavior](https://nextjs.org/docs/api-reference/next/image#caching-behavior) */\n minimumCacheTTL: number\n\n /** @see [Acceptable formats](https://nextjs.org/docs/api-reference/next/image#acceptable-formats) */\n formats: ImageFormat[]\n\n /** @see [Maximum Redirects](https://nextjs.org/docs/api-reference/next/image#maximumredirects) */\n maximumRedirects: number\n\n /** @see [Dangerously Allow Local IP](https://nextjs.org/docs/api-reference/next/image#dangerously-allow-local-ip) */\n dangerouslyAllowLocalIP: boolean\n\n /** @see [Dangerously Allow SVG](https://nextjs.org/docs/api-reference/next/image#dangerously-allow-svg) */\n dangerouslyAllowSVG: boolean\n\n /** @see [Content Security Policy](https://nextjs.org/docs/api-reference/next/image#contentsecuritypolicy) */\n contentSecurityPolicy: string\n\n /** @see [Content Disposition Type](https://nextjs.org/docs/api-reference/next/image#contentdispositiontype) */\n contentDispositionType: 'inline' | 'attachment'\n\n /** @see [Remote Patterns](https://nextjs.org/docs/api-reference/next/image#remotepatterns) */\n remotePatterns: Array<URL | RemotePattern>\n\n /** @see [Local Patterns](https://nextjs.org/docs/api-reference/next/image#localPatterns) */\n localPatterns: LocalPattern[] | undefined\n\n /** @see [Qualities](https://nextjs.org/docs/api-reference/next/image#qualities) */\n qualities: number[] | undefined\n\n /** @see [Unoptimized](https://nextjs.org/docs/api-reference/next/image#unoptimized) */\n unoptimized: boolean\n}\n\nexport type ImageConfig = Partial<ImageConfigComplete>\n\nexport const imageConfigDefault: ImageConfigComplete = {\n deviceSizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840],\n imageSizes: [32, 48, 64, 96, 128, 256, 384],\n path: '/_next/image',\n loader: 'default',\n loaderFile: '',\n /**\n * @deprecated Use `remotePatterns` instead to protect your application from malicious users.\n */\n domains: [],\n disableStaticImages: false,\n minimumCacheTTL: 14400, // 4 hours\n formats: ['image/webp'],\n maximumRedirects: 3,\n dangerouslyAllowLocalIP: false,\n dangerouslyAllowSVG: false,\n contentSecurityPolicy: `script-src 'none'; frame-src 'none'; sandbox;`,\n contentDispositionType: 'attachment',\n localPatterns: undefined, // default: allow all local images\n remotePatterns: [], // default: allow no remote images\n qualities: [75],\n unoptimized: false,\n}\n","import { warnOnce } from './utils/warn-once'\nimport { getDeploymentId } from './deployment-id'\nimport { getImageBlurSvg } from './image-blur-svg'\nimport { imageConfigDefault } from './image-config'\nimport type {\n ImageConfigComplete,\n ImageLoaderProps,\n ImageLoaderPropsWithConfig,\n} from './image-config'\n\nimport type { CSSProperties, JSX } from 'react'\n\nexport interface StaticImageData {\n src: string\n height: number\n width: number\n blurDataURL?: string\n blurWidth?: number\n blurHeight?: number\n}\n\nexport interface StaticRequire {\n default: StaticImageData\n}\n\nexport type StaticImport = StaticRequire | StaticImageData\n\nexport type ImageProps = Omit<\n JSX.IntrinsicElements['img'],\n 'src' | 'srcSet' | 'ref' | 'alt' | 'width' | 'height' | 'loading'\n> & {\n src: string | StaticImport\n alt: string\n width?: number | `${number}`\n height?: number | `${number}`\n fill?: boolean\n loader?: ImageLoader\n quality?: number | `${number}`\n preload?: boolean\n /**\n * @deprecated Use `preload` prop instead.\n * See https://nextjs.org/docs/app/api-reference/components/image#preload\n */\n priority?: boolean\n loading?: LoadingValue\n placeholder?: PlaceholderValue\n blurDataURL?: string\n unoptimized?: boolean\n overrideSrc?: string\n /**\n * @deprecated Use `onLoad` instead.\n * @see https://nextjs.org/docs/app/api-reference/components/image#onload\n */\n onLoadingComplete?: OnLoadingComplete\n /**\n * @deprecated Use `fill` prop instead of `layout=\"fill\"` or change import to `next/legacy/image`.\n * @see https://nextjs.org/docs/api-reference/next/legacy/image\n */\n layout?: string\n /**\n * @deprecated Use `style` prop instead.\n */\n objectFit?: string\n /**\n * @deprecated Use `style` prop instead.\n */\n objectPosition?: string\n /**\n * @deprecated This prop does not do anything.\n */\n lazyBoundary?: string\n /**\n * @deprecated This prop does not do anything.\n */\n lazyRoot?: string\n}\n\nexport type ImgProps = Omit<ImageProps, 'src' | 'loader'> & {\n loading: LoadingValue\n width: number | undefined\n height: number | undefined\n style: NonNullable<JSX.IntrinsicElements['img']['style']>\n sizes: string | undefined\n srcSet: string | undefined\n src: string\n}\n\nconst VALID_LOADING_VALUES = ['lazy', 'eager', undefined] as const\n\n// Object-fit values that are not valid background-size values\nconst INVALID_BACKGROUND_SIZE_VALUES = [\n '-moz-initial',\n 'fill',\n 'none',\n 'scale-down',\n undefined,\n]\ntype LoadingValue = (typeof VALID_LOADING_VALUES)[number]\ntype ImageConfig = ImageConfigComplete & {\n allSizes: number[]\n output?: 'standalone' | 'export'\n}\n\nexport type ImageLoader = (p: ImageLoaderProps) => string\n\n// Do not export - this is an internal type only\n// because `next.config.js` is only meant for the\n// built-in loaders, not for a custom loader() prop.\ntype ImageLoaderWithConfig = (p: ImageLoaderPropsWithConfig) => string\n\nexport type PlaceholderValue = 'blur' | 'empty' | `data:image/${string}`\nexport type OnLoad = React.ReactEventHandler<HTMLImageElement> | undefined\nexport type OnLoadingComplete = (img: HTMLImageElement) => void\n\nexport type PlaceholderStyle = Partial<\n Pick<\n CSSProperties,\n | 'backgroundSize'\n | 'backgroundPosition'\n | 'backgroundRepeat'\n | 'backgroundImage'\n >\n>\n\nfunction isStaticRequire(\n src: StaticRequire | StaticImageData\n): src is StaticRequire {\n return (src as StaticRequire).default !== undefined\n}\n\nfunction isStaticImageData(\n src: StaticRequire | StaticImageData\n): src is StaticImageData {\n return (src as StaticImageData).src !== undefined\n}\n\nfunction isStaticImport(src: string | StaticImport): src is StaticImport {\n return (\n !!src &&\n typeof src === 'object' &&\n (isStaticRequire(src as StaticImport) ||\n isStaticImageData(src as StaticImport))\n )\n}\n\nconst allImgs = new Map<\n string,\n { src: string; loading: LoadingValue; placeholder: PlaceholderValue }\n>()\nlet perfObserver: PerformanceObserver | undefined\n\nfunction getInt(x: unknown): number | undefined {\n if (typeof x === 'undefined') {\n return x\n }\n if (typeof x === 'number') {\n return Number.isFinite(x) ? x : NaN\n }\n if (typeof x === 'string' && /^[0-9]+$/.test(x)) {\n return parseInt(x, 10)\n }\n return NaN\n}\n\nfunction getWidths(\n { deviceSizes, allSizes }: ImageConfig,\n width: number | undefined,\n sizes: string | undefined\n): { widths: number[]; kind: 'w' | 'x' } {\n if (sizes) {\n // Find all the \"vw\" percent sizes used in the sizes prop\n const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g\n const percentSizes = []\n for (let match; (match = viewportWidthRe.exec(sizes)); match) {\n percentSizes.push(parseInt(match[2]))\n }\n if (percentSizes.length) {\n const smallestRatio = Math.min(...percentSizes) * 0.01\n return {\n widths: allSizes.filter((s) => s >= deviceSizes[0] * smallestRatio),\n kind: 'w',\n }\n }\n return { widths: allSizes, kind: 'w' }\n }\n if (typeof width !== 'number') {\n return { widths: deviceSizes, kind: 'w' }\n }\n\n const widths = [\n ...new Set(\n // > This means that most OLED screens that say they are 3x resolution,\n // > are actually 3x in the green color, but only 1.5x in the red and\n // > blue colors. Showing a 3x resolution image in the app vs a 2x\n // > resolution image will be visually the same, though the 3x image\n // > takes significantly more data. Even true 3x resolution screens are\n // > wasteful as the human eye cannot see that level of detail without\n // > something like a magnifying glass.\n // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n [width, width * 2 /*, width * 3*/].map(\n (w) => allSizes.find((p) => p >= w) || allSizes[allSizes.length - 1]\n )\n ),\n ]\n return { widths, kind: 'x' }\n}\n\ntype GenImgAttrsData = {\n config: ImageConfig\n src: string\n unoptimized: boolean\n loader: ImageLoaderWithConfig\n width?: number\n quality?: number\n sizes?: string\n}\n\ntype GenImgAttrsResult = {\n src: string\n srcSet: string | undefined\n sizes: string | undefined\n}\n\nfunction generateImgAttrs({\n config,\n src,\n unoptimized,\n width,\n quality,\n sizes,\n loader,\n}: GenImgAttrsData): GenImgAttrsResult {\n if (unoptimized) {\n const deploymentId = getDeploymentId()\n if (src.startsWith('/') && !src.startsWith('//') && deploymentId) {\n const sep = src.includes('?') ? '&' : '?'\n src = `${src}${sep}dpl=${deploymentId}`\n }\n return { src, srcSet: undefined, sizes: undefined }\n }\n\n const { widths, kind } = getWidths(config, width, sizes)\n const last = widths.length - 1\n\n return {\n sizes: !sizes && kind === 'w' ? '100vw' : sizes,\n srcSet: widths\n .map(\n (w, i) =>\n `${loader({ config, src, quality, width: w })} ${\n kind === 'w' ? w : i + 1\n }${kind}`\n )\n .join(', '),\n\n // It's intended to keep `src` the last attribute because React updates\n // attributes in order. If we keep `src` the first one, Safari will\n // immediately start to fetch `src`, before `sizes` and `srcSet` are even\n // updated by React. That causes multiple unnecessary requests if `srcSet`\n // and `sizes` are defined.\n // This bug cannot be reproduced in Chrome or Firefox.\n src: loader({ config, src, quality, width: widths[last] }),\n }\n}\n\n/**\n * A shared function, used on both client and server, to generate the props for <img>.\n */\nexport function getImgProps(\n {\n src,\n sizes,\n unoptimized = false,\n priority = false,\n preload = false,\n loading,\n className,\n quality,\n width,\n height,\n fill = false,\n style,\n overrideSrc,\n onLoad,\n onLoadingComplete,\n placeholder = 'empty',\n blurDataURL,\n fetchPriority,\n decoding = 'async',\n layout,\n objectFit,\n objectPosition,\n lazyBoundary,\n lazyRoot,\n ...rest\n }: ImageProps,\n _state: {\n defaultLoader: ImageLoaderWithConfig\n imgConf: ImageConfigComplete\n showAltText?: boolean\n blurComplete?: boolean\n }\n): {\n props: ImgProps\n meta: {\n unoptimized: boolean\n preload: boolean\n placeholder: NonNullable<ImageProps['placeholder']>\n fill: boolean\n }\n} {\n const { imgConf, showAltText, blurComplete, defaultLoader } = _state\n let config: ImageConfig\n let c = imgConf || imageConfigDefault\n if ('allSizes' in c) {\n config = c as ImageConfig\n } else {\n const allSizes = [...c.deviceSizes, ...c.imageSizes].sort((a, b) => a - b)\n const deviceSizes = c.deviceSizes.sort((a, b) => a - b)\n const qualities = c.qualities?.sort((a, b) => a - b)\n config = { ...c, allSizes, deviceSizes, qualities }\n }\n\n if (typeof defaultLoader === 'undefined') {\n throw new Error(\n 'images.loaderFile detected but the file is missing default export.\\nRead more: https://nextjs.org/docs/messages/invalid-images-config'\n )\n }\n let loader: ImageLoaderWithConfig = rest.loader || defaultLoader\n\n // Remove property so it's not spread on <img> element\n delete rest.loader\n delete (rest as any).srcSet\n\n // This special value indicates that the user\n // didn't define a \"loader\" prop or \"loader\" config.\n const isDefaultLoader = '__next_img_default' in loader\n\n if (isDefaultLoader) {\n if (config.loader === 'custom') {\n throw new Error(\n `Image with src \"${src}\" is missing \"loader\" prop.` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader`\n )\n }\n } else {\n // The user defined a \"loader\" prop or config.\n // Since the config object is internal only, we\n // must not pass it to the user-defined \"loader\".\n const customImageLoader = loader as ImageLoader\n loader = (obj) => {\n const { config: _, ...opts } = obj\n return customImageLoader(opts)\n }\n }\n\n if (layout) {\n if (layout === 'fill') {\n fill = true\n }\n const layoutToStyle: Record<string, Record<string, string> | undefined> = {\n intrinsic: { maxWidth: '100%', height: 'auto' },\n responsive: { width: '100%', height: 'auto' },\n }\n const layoutToSizes: Record<string, string | undefined> = {\n responsive: '100vw',\n fill: '100vw',\n }\n const layoutStyle = layoutToStyle[layout]\n if (layoutStyle) {\n style = { ...style, ...layoutStyle }\n }\n const layoutSizes = layoutToSizes[layout]\n if (layoutSizes && !sizes) {\n sizes = layoutSizes\n }\n }\n\n let staticSrc = ''\n let widthInt = getInt(width)\n let heightInt = getInt(height)\n let blurWidth: number | undefined\n let blurHeight: number | undefined\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src\n\n if (!staticImageData.src) {\n throw new Error(\n `An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(\n staticImageData\n )}`\n )\n }\n if (!staticImageData.height || !staticImageData.width) {\n throw new Error(\n `An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(\n staticImageData\n )}`\n )\n }\n\n blurWidth = staticImageData.blurWidth\n blurHeight = staticImageData.blurHeight\n blurDataURL = blurDataURL || staticImageData.blurDataURL\n staticSrc = staticImageData.src\n\n if (!fill) {\n if (!widthInt && !heightInt) {\n widthInt = staticImageData.width\n heightInt = staticImageData.height\n } else if (widthInt && !heightInt) {\n const ratio = widthInt / staticImageData.width\n heightInt = Math.round(staticImageData.height * ratio)\n } else if (!widthInt && heightInt) {\n const ratio = heightInt / staticImageData.height\n widthInt = Math.round(staticImageData.width * ratio)\n }\n }\n }\n src = typeof src === 'string' ? src : staticSrc\n\n let isLazy =\n !priority &&\n !preload &&\n (loading === 'lazy' || typeof loading === 'undefined')\n if (!src || src.startsWith('data:') || src.startsWith('blob:')) {\n // https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n unoptimized = true\n isLazy = false\n }\n if (config.unoptimized) {\n unoptimized = true\n }\n if (\n isDefaultLoader &&\n !config.dangerouslyAllowSVG &&\n src.split('?', 1)[0].endsWith('.svg')\n ) {\n // Special case to make svg serve as-is to avoid proxying\n // through the built-in Image Optimization API.\n unoptimized = true\n }\n\n const qualityInt = getInt(quality)\n\n if (process.env.NODE_ENV !== 'production') {\n if (config.output === 'export' && isDefaultLoader && !unoptimized) {\n throw new Error(\n `Image Optimization using the default loader is not compatible with \\`{ output: 'export' }\\`.\n Possible solutions:\n - Remove \\`{ output: 'export' }\\` and run \"next start\" to run server mode including the Image Optimization API.\n - Configure \\`{ images: { unoptimized: true } }\\` in \\`next.config.js\\` to disable the Image Optimization API.\n Read more: https://nextjs.org/docs/messages/export-image-api`\n )\n }\n if (!src) {\n // React doesn't show the stack trace and there's\n // no `src` to help identify which image, so we\n // instead console.error(ref) during mount.\n unoptimized = true\n } else {\n if (fill) {\n if (width) {\n throw new Error(\n `Image with src \"${src}\" has both \"width\" and \"fill\" properties. Only one should be used.`\n )\n }\n if (height) {\n throw new Error(\n `Image with src \"${src}\" has both \"height\" and \"fill\" properties. Only one should be used.`\n )\n }\n if (style?.position && style.position !== 'absolute') {\n throw new Error(\n `Image with src \"${src}\" has both \"fill\" and \"style.position\" properties. Images with \"fill\" always use position absolute - it cannot be modified.`\n )\n }\n if (style?.width && style.width !== '100%') {\n throw new Error(\n `Image with src \"${src}\" has both \"fill\" and \"style.width\" properties. Images with \"fill\" always use width 100% - it cannot be modified.`\n )\n }\n if (style?.height && style.height !== '100%') {\n throw new Error(\n `Image with src \"${src}\" has both \"fill\" and \"style.height\" properties. Images with \"fill\" always use height 100% - it cannot be modified.`\n )\n }\n } else {\n if (typeof widthInt === 'undefined') {\n throw new Error(\n `Image with src \"${src}\" is missing required \"width\" property.`\n )\n } else if (isNaN(widthInt)) {\n throw new Error(\n `Image with src \"${src}\" has invalid \"width\" property. Expected a numeric value in pixels but received \"${width}\".`\n )\n }\n if (typeof heightInt === 'undefined') {\n throw new Error(\n `Image with src \"${src}\" is missing required \"height\" property.`\n )\n } else if (isNaN(heightInt)) {\n throw new Error(\n `Image with src \"${src}\" has invalid \"height\" property. Expected a numeric value in pixels but received \"${height}\".`\n )\n }\n // eslint-disable-next-line no-control-regex\n if (/^[\\x00-\\x20]/.test(src)) {\n throw new Error(\n `Image with src \"${src}\" cannot start with a space or control character. Use src.trimStart() to remove it or encodeURIComponent(src) to keep it.`\n )\n }\n // eslint-disable-next-line no-control-regex\n if (/[\\x00-\\x20]$/.test(src)) {\n throw new Error(\n `Image with src \"${src}\" cannot end with a space or control character. Use src.trimEnd() to remove it or encodeURIComponent(src) to keep it.`\n )\n }\n }\n }\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(\n `Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(\n String\n ).join(',')}.`\n )\n }\n if (priority && loading === 'lazy') {\n throw new Error(\n `Image with src \"${src}\" has both \"priority\" and \"loading='lazy'\" properties. Only one should be used.`\n )\n }\n if (preload && loading === 'lazy') {\n throw new Error(\n `Image with src \"${src}\" has both \"preload\" and \"loading='lazy'\" properties. Only one should be used.`\n )\n }\n if (preload && priority) {\n throw new Error(\n `Image with src \"${src}\" has both \"preload\" and \"priority\" properties. Only \"preload\" should be used.`\n )\n }\n if (\n placeholder !== 'empty' &&\n placeholder !== 'blur' &&\n !placeholder.startsWith('data:image/')\n ) {\n throw new Error(\n `Image with src \"${src}\" has invalid \"placeholder\" property \"${placeholder}\".`\n )\n }\n if (placeholder !== 'empty') {\n if (widthInt && heightInt && widthInt * heightInt < 1600) {\n warnOnce(\n `Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder\" property to improve performance.`\n )\n }\n }\n if (\n qualityInt &&\n config.qualities &&\n !config.qualities.includes(qualityInt)\n ) {\n warnOnce(\n `Image with src \"${src}\" is using quality \"${qualityInt}\" which is not configured in images.qualities [${config.qualities.join(', ')}]. Please update your config to [${[...config.qualities, qualityInt].sort().join(', ')}].` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-unconfigured-qualities`\n )\n }\n if (placeholder === 'blur' && !blurDataURL) {\n const VALID_BLUR_EXT = ['jpeg', 'png', 'webp', 'avif'] // should match next-image-loader\n\n throw new Error(\n `Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n Possible solutions:\n - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(\n ','\n )} (animated images not supported)\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`\n )\n }\n if ('ref' in rest) {\n warnOnce(\n `Image with src \"${src}\" is using unsupported \"ref\" property. Consider using the \"onLoad\" property instead.`\n )\n }\n\n if (!unoptimized && !isDefaultLoader) {\n const urlStr = loader({\n config,\n src,\n width: widthInt || 400,\n quality: qualityInt || 75,\n })\n let url: URL | undefined\n try {\n url = new URL(urlStr)\n } catch (err) {}\n if (urlStr === src || (url && url.pathname === src && !url.search)) {\n warnOnce(\n `Image with src \"${src}\" has a \"loader\" property that does not implement width. Please implement it or use the \"unoptimized\" property instead.` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader-width`\n )\n }\n }\n\n if (onLoadingComplete) {\n warnOnce(\n `Image with src \"${src}\" is using deprecated \"onLoadingComplete\" property. Please use the \"onLoad\" property instead.`\n )\n }\n\n for (const [legacyKey, legacyValue] of Object.entries({\n layout,\n objectFit,\n objectPosition,\n lazyBoundary,\n lazyRoot,\n })) {\n if (legacyValue) {\n warnOnce(\n `Image with src \"${src}\" has legacy prop \"${legacyKey}\". Did you forget to run the codemod?` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-upgrade-to-13`\n )\n }\n }\n\n if (\n typeof window !== 'undefined' &&\n !perfObserver &&\n window.PerformanceObserver\n ) {\n perfObserver = new PerformanceObserver((entryList) => {\n for (const entry of entryList.getEntries()) {\n // @ts-ignore - missing \"LargestContentfulPaint\" class with \"element\" prop\n const imgSrc = entry?.element?.src || ''\n const lcpImage = allImgs.get(imgSrc)\n if (\n lcpImage &&\n lcpImage.loading === 'lazy' &&\n lcpImage.placeholder === 'empty' &&\n !lcpImage.src.startsWith('data:') &&\n !lcpImage.src.startsWith('blob:')\n ) {\n // https://web.dev/lcp/#measure-lcp-in-javascript\n warnOnce(\n `Image with src \"${lcpImage.src}\" was detected as the Largest Contentful Paint (LCP). Please add the \\`loading=\"eager\"\\` property if this image is above the fold.` +\n `\\nRead more: https://nextjs.org/docs/app/api-reference/components/image#loading`\n )\n }\n }\n })\n try {\n perfObserver.observe({\n type: 'largest-contentful-paint',\n buffered: true,\n })\n } catch (err) {\n // Log error but don't crash the app\n console.error(err)\n }\n }\n }\n const imgStyle = Object.assign(\n fill\n ? {\n position: 'absolute',\n height: '100%',\n width: '100%',\n left: 0,\n top: 0,\n right: 0,\n bottom: 0,\n objectFit,\n objectPosition,\n }\n : {},\n showAltText ? {} : { color: 'transparent' },\n style\n )\n\n const backgroundImage =\n !blurComplete && placeholder !== 'empty'\n ? placeholder === 'blur'\n ? `url(\"data:image/svg+xml;charset=utf-8,${getImageBlurSvg({\n widthInt,\n heightInt,\n blurWidth,\n blurHeight,\n blurDataURL: blurDataURL || '', // assume not undefined\n objectFit: imgStyle.objectFit,\n })}\")`\n : `url(\"${placeholder}\")` // assume `data:image/`\n : null\n\n const backgroundSize = !INVALID_BACKGROUND_SIZE_VALUES.includes(\n imgStyle.objectFit\n )\n ? imgStyle.objectFit\n : imgStyle.objectFit === 'fill'\n ? '100% 100%' // the background-size equivalent of `fill`\n : 'cover'\n\n let placeholderStyle: PlaceholderStyle = backgroundImage\n ? {\n backgroundSize,\n backgroundPosition: imgStyle.objectPosition || '50% 50%',\n backgroundRepeat: 'no-repeat',\n backgroundImage,\n }\n : {}\n\n if (process.env.NODE_ENV === 'development') {\n if (\n placeholderStyle.backgroundImage &&\n placeholder === 'blur' &&\n blurDataURL?.startsWith('/')\n ) {\n // During `next dev`, we don't want to generate blur placeholders with webpack\n // because it can delay starting the dev server. Instead, `next-image-loader.js`\n // will inline a special url to lazily generate the blur placeholder at request time.\n placeholderStyle.backgroundImage = `url(\"${blurDataURL}\")`\n }\n }\n\n const imgAttributes = generateImgAttrs({\n config,\n src,\n unoptimized,\n width: widthInt,\n quality: qualityInt,\n sizes,\n loader,\n })\n\n const loadingFinal = isLazy ? 'lazy' : loading\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof window !== 'undefined') {\n let fullUrl: URL\n try {\n fullUrl = new URL(imgAttributes.src)\n } catch (e) {\n fullUrl = new URL(imgAttributes.src, window.location.href)\n }\n allImgs.set(fullUrl.href, { src, loading: loadingFinal, placeholder })\n }\n }\n\n const props: ImgProps = {\n ...rest,\n loading: loadingFinal,\n fetchPriority,\n width: widthInt,\n height: heightInt,\n decoding,\n className,\n style: { ...imgStyle, ...placeholderStyle },\n sizes: imgAttributes.sizes,\n srcSet: imgAttributes.srcSet,\n src: overrideSrc || imgAttributes.src,\n }\n const meta = { unoptimized, preload: preload || priority, placeholder, fill }\n return { props, meta }\n}\n","// This file is generated by next-core EcmascriptClientReferenceModule.\nconst { createClientModuleProxy } = require(\"react-server-dom-turbopack/server\");\n\n__turbopack_context__.n(createClientModuleProxy(\"[project]/node_modules/.pnpm/next@16.1.1_@babel+core@7.26.10_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/next/dist/client/image-component.js\"));\n","'use client'\n\nimport React, {\n useRef,\n useEffect,\n useCallback,\n useContext,\n useMemo,\n useState,\n forwardRef,\n use,\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport Head from '../shared/lib/head'\nimport { getImgProps } from '../shared/lib/get-img-props'\nimport type {\n ImageProps,\n ImgProps,\n OnLoad,\n OnLoadingComplete,\n PlaceholderValue,\n} from '../shared/lib/get-img-props'\nimport type {\n ImageConfigComplete,\n ImageLoaderProps,\n} from '../shared/lib/image-config'\nimport { imageConfigDefault } from '../shared/lib/image-config'\nimport { ImageConfigContext } from '../shared/lib/image-config-context.shared-runtime'\nimport { warnOnce } from '../shared/lib/utils/warn-once'\nimport { RouterContext } from '../shared/lib/router-context.shared-runtime'\n\n// This is replaced by webpack alias\nimport defaultLoader from 'next/dist/shared/lib/image-loader'\nimport { useMergedRef } from './use-merged-ref'\n\n// This is replaced by webpack define plugin\nconst configEnv = process.env.__NEXT_IMAGE_OPTS as any as ImageConfigComplete\n\nif (typeof window === 'undefined') {\n ;(globalThis as any).__NEXT_IMAGE_IMPORTED = true\n}\n\nexport type { ImageLoaderProps }\nexport type ImageLoader = (p: ImageLoaderProps) => string\n\ntype ImgElementWithDataProp = HTMLImageElement & {\n 'data-loaded-src': string | undefined\n}\n\ntype ImageElementProps = ImgProps & {\n unoptimized: boolean\n placeholder: PlaceholderValue\n onLoadRef: React.MutableRefObject<OnLoad | undefined>\n onLoadingCompleteRef: React.MutableRefObject<OnLoadingComplete | undefined>\n setBlurComplete: (b: boolean) => void\n setShowAltText: (b: boolean) => void\n sizesInput: string | undefined\n}\n\n// See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\nfunction handleLoading(\n img: ImgElementWithDataProp,\n placeholder: PlaceholderValue,\n onLoadRef: React.MutableRefObject<OnLoad | undefined>,\n onLoadingCompleteRef: React.MutableRefObject<OnLoadingComplete | undefined>,\n setBlurComplete: (b: boolean) => void,\n unoptimized: boolean,\n sizesInput: string | undefined\n) {\n const src = img?.src\n if (!img || img['data-loaded-src'] === src) {\n return\n }\n img['data-loaded-src'] = src\n const p = 'decode' in img ? img.decode() : Promise.resolve()\n p.catch(() => {}).then(() => {\n if (!img.parentElement || !img.isConnected) {\n // Exit early in case of race condition:\n // - onload() is called\n // - decode() is called but incomplete\n // - unmount is called\n // - decode() completes\n return\n }\n if (placeholder !== 'empty') {\n setBlurComplete(true)\n }\n if (onLoadRef?.current) {\n // Since we don't have the SyntheticEvent here,\n // we must create one with the same shape.\n // See https://reactjs.org/docs/events.html\n const event = new Event('load')\n Object.defineProperty(event, 'target', { writable: false, value: img })\n let prevented = false\n let stopped = false\n onLoadRef.current({\n ...event,\n nativeEvent: event,\n currentTarget: img,\n target: img,\n isDefaultPrevented: () => prevented,\n isPropagationStopped: () => stopped,\n persist: () => {},\n preventDefault: () => {\n prevented = true\n event.preventDefault()\n },\n stopPropagation: () => {\n stopped = true\n event.stopPropagation()\n },\n })\n }\n if (onLoadingCompleteRef?.current) {\n onLoadingCompleteRef.current(img)\n }\n if (process.env.NODE_ENV !== 'production') {\n const origSrc = new URL(src, 'http://n').searchParams.get('url') || src\n if (img.getAttribute('data-nimg') === 'fill') {\n if (!unoptimized && (!sizesInput || sizesInput === '100vw')) {\n let widthViewportRatio =\n img.getBoundingClientRect().width / window.innerWidth\n if (widthViewportRatio < 0.6) {\n if (sizesInput === '100vw') {\n warnOnce(\n `Image with src \"${origSrc}\" has \"fill\" prop and \"sizes\" prop of \"100vw\", but image is not rendered at full viewport width. Please adjust \"sizes\" to improve page performance. Read more: https://nextjs.org/docs/api-reference/next/image#sizes`\n )\n } else {\n warnOnce(\n `Image with src \"${origSrc}\" has \"fill\" but is missing \"sizes\" prop. Please add it to improve page performance. Read more: https://nextjs.org/docs/api-reference/next/image#sizes`\n )\n }\n }\n }\n if (img.parentElement) {\n const { position } = window.getComputedStyle(img.parentElement)\n const valid = ['absolute', 'fixed', 'relative']\n if (!valid.includes(position)) {\n warnOnce(\n `Image with src \"${origSrc}\" has \"fill\" and parent element with invalid \"position\". Provided \"${position}\" should be one of ${valid\n .map(String)\n .join(',')}.`\n )\n }\n }\n if (img.height === 0) {\n warnOnce(\n `Image with src \"${origSrc}\" has \"fill\" and a height value of 0. This is likely because the parent element of the image has not been styled to have a set height.`\n )\n }\n }\n\n const heightModified =\n img.height.toString() !== img.getAttribute('height')\n const widthModified = img.width.toString() !== img.getAttribute('width')\n if (\n (heightModified && !widthModified) ||\n (!heightModified && widthModified)\n ) {\n warnOnce(\n `Image with src \"${origSrc}\" has either width or height modified, but not the other. If you use CSS to change the size of your image, also include the styles 'width: \"auto\"' or 'height: \"auto\"' to maintain the aspect ratio.`\n )\n }\n }\n })\n}\n\nfunction getDynamicProps(\n fetchPriority?: string\n): Record<string, string | undefined> {\n if (Boolean(use)) {\n // In React 19.0.0 or newer, we must use camelCase\n // prop to avoid \"Warning: Invalid DOM property\".\n // See https://github.com/facebook/react/pull/25927\n return { fetchPriority }\n }\n // In React 18.2.0 or older, we must use lowercase prop\n // to avoid \"Warning: Invalid DOM property\".\n return { fetchpriority: fetchPriority }\n}\n\nconst ImageElement = forwardRef<HTMLImageElement | null, ImageElementProps>(\n (\n {\n src,\n srcSet,\n sizes,\n height,\n width,\n decoding,\n className,\n style,\n fetchPriority,\n placeholder,\n loading,\n unoptimized,\n fill,\n onLoadRef,\n onLoadingCompleteRef,\n setBlurComplete,\n setShowAltText,\n sizesInput,\n onLoad,\n onError,\n ...rest\n },\n forwardedRef\n ) => {\n const ownRef = useCallback(\n (img: ImgElementWithDataProp | null) => {\n if (!img) {\n return\n }\n if (onError) {\n // If the image has an error before react hydrates, then the error is lost.\n // The workaround is to wait until the image is mounted which is after hydration,\n // then we set the src again to trigger the error handler (if there was an error).\n // eslint-disable-next-line no-self-assign\n img.src = img.src\n }\n if (process.env.NODE_ENV !== 'production') {\n if (!src) {\n console.error(`Image is missing required \"src\" property:`, img)\n }\n if (img.getAttribute('alt') === null) {\n console.error(\n `Image is missing required \"alt\" property. Please add Alternative Text to describe the image for screen readers and search engines.`\n )\n }\n }\n if (img.complete) {\n handleLoading(\n img,\n placeholder,\n onLoadRef,\n onLoadingCompleteRef,\n setBlurComplete,\n unoptimized,\n sizesInput\n )\n }\n },\n [\n src,\n placeholder,\n onLoadRef,\n onLoadingCompleteRef,\n setBlurComplete,\n onError,\n unoptimized,\n sizesInput,\n ]\n )\n\n const ref = useMergedRef(forwardedRef, ownRef)\n\n return (\n <img\n {...rest}\n {...getDynamicProps(fetchPriority)}\n // It's intended to keep `loading` before `src` because React updates\n // props in order which causes Safari/Firefox to not lazy load properly.\n // See https://github.com/facebook/react/issues/25883\n loading={loading}\n width={width}\n height={height}\n decoding={decoding}\n data-nimg={fill ? 'fill' : '1'}\n className={className}\n style={style}\n // It's intended to keep `src` the last attribute because React updates\n // attributes in order. If we keep `src` the first one, Safari will\n // immediately start to fetch `src`, before `sizes` and `srcSet` are even\n // updated by React. That causes multiple unnecessary requests if `srcSet`\n // and `sizes` are defined.\n // This bug cannot be reproduced in Chrome or Firefox.\n sizes={sizes}\n srcSet={srcSet}\n src={src}\n ref={ref}\n onLoad={(event) => {\n const img = event.currentTarget as ImgElementWithDataProp\n handleLoading(\n img,\n placeholder,\n onLoadRef,\n onLoadingCompleteRef,\n setBlurComplete,\n unoptimized,\n sizesInput\n )\n }}\n onError={(event) => {\n // if the real image fails to load, this will ensure \"alt\" is visible\n setShowAltText(true)\n if (placeholder !== 'empty') {\n // If the real image fails to load, this will still remove the placeholder.\n setBlurComplete(true)\n }\n if (onError) {\n onError(event)\n }\n }}\n />\n )\n }\n)\n\nfunction ImagePreload({\n isAppRouter,\n imgAttributes,\n}: {\n isAppRouter: boolean\n imgAttributes: ImgProps\n}) {\n const opts: ReactDOM.PreloadOptions = {\n as: 'image',\n imageSrcSet: imgAttributes.srcSet,\n imageSizes: imgAttributes.sizes,\n crossOrigin: imgAttributes.crossOrigin,\n referrerPolicy: imgAttributes.referrerPolicy,\n ...getDynamicProps(imgAttributes.fetchPriority),\n }\n\n if (isAppRouter && ReactDOM.preload) {\n ReactDOM.preload(imgAttributes.src, opts)\n return null\n }\n\n return (\n <Head>\n <link\n key={\n '__nimg-' +\n imgAttributes.src +\n imgAttributes.srcSet +\n imgAttributes.sizes\n }\n rel=\"preload\"\n // Note how we omit the `href` attribute, as it would only be relevant\n // for browsers that do not support `imagesrcset`, and in those cases\n // it would cause the incorrect image to be preloaded.\n //\n // https://html.spec.whatwg.org/multipage/semantics.html#attr-link-imagesrcset\n href={imgAttributes.srcSet ? undefined : imgAttributes.src}\n {...opts}\n />\n </Head>\n )\n}\n\n/**\n * The `Image` component is used to optimize images.\n *\n * Read more: [Next.js docs: `Image`](https://nextjs.org/docs/app/api-reference/components/image)\n */\nexport const Image = forwardRef<HTMLImageElement | null, ImageProps>(\n (props, forwardedRef) => {\n const pagesRouter = useContext(RouterContext)\n // We're in the app directory if there is no pages router.\n const isAppRouter = !pagesRouter\n\n const configContext = useContext(ImageConfigContext)\n const config = useMemo(() => {\n const c = configEnv || configContext || imageConfigDefault\n\n const allSizes = [...c.deviceSizes, ...c.imageSizes].sort((a, b) => a - b)\n const deviceSizes = c.deviceSizes.sort((a, b) => a - b)\n const qualities = c.qualities?.sort((a, b) => a - b)\n return {\n ...c,\n allSizes,\n deviceSizes,\n qualities,\n // During the SSR, configEnv (__NEXT_IMAGE_OPTS) does not include\n // security sensitive configs like `localPatterns`, which is needed\n // during the server render to ensure it's validated. Therefore use\n // configContext, which holds the config from the server for validation.\n localPatterns:\n typeof window === 'undefined'\n ? configContext?.localPatterns\n : c.localPatterns,\n }\n }, [configContext])\n\n const { onLoad, onLoadingComplete } = props\n const onLoadRef = useRef(onLoad)\n\n useEffect(() => {\n onLoadRef.current = onLoad\n }, [onLoad])\n\n const onLoadingCompleteRef = useRef(onLoadingComplete)\n\n useEffect(() => {\n onLoadingCompleteRef.current = onLoadingComplete\n }, [onLoadingComplete])\n\n const [blurComplete, setBlurComplete] = useState(false)\n const [showAltText, setShowAltText] = useState(false)\n const { props: imgAttributes, meta: imgMeta } = getImgProps(props, {\n defaultLoader,\n imgConf: config,\n blurComplete,\n showAltText,\n })\n\n return (\n <>\n {\n <ImageElement\n {...imgAttributes}\n unoptimized={imgMeta.unoptimized}\n placeholder={imgMeta.placeholder}\n fill={imgMeta.fill}\n onLoadRef={onLoadRef}\n onLoadingCompleteRef={onLoadingCompleteRef}\n setBlurComplete={setBlurComplete}\n setShowAltText={setShowAltText}\n sizesInput={props.sizes}\n ref={forwardedRef}\n />\n }\n {imgMeta.preload ? (\n <ImagePreload\n isAppRouter={isAppRouter}\n imgAttributes={imgAttributes}\n />\n ) : null}\n </>\n )\n }\n)\n","import type { NextConfig } from '../../server/config-shared'\n\n/**\n * Find the closest matching `quality` in the list of `config.qualities`\n * @param quality the quality prop passed to the image component\n * @param config the \"images\" configuration from next.config.js\n * @returns the closest matching quality value\n */\nexport function findClosestQuality(\n quality: number | undefined,\n config: NextConfig['images'] | undefined\n): number {\n const q = quality || 75\n if (!config?.qualities?.length) {\n return q\n }\n return config.qualities.reduce(\n (prev, cur) => (Math.abs(cur - q) < Math.abs(prev - q) ? cur : prev),\n 0\n )\n}\n","import type { ImageLoaderPropsWithConfig } from './image-config'\nimport { findClosestQuality } from './find-closest-quality'\nimport { getDeploymentId } from './deployment-id'\n\nfunction defaultLoader({\n config,\n src,\n width,\n quality,\n}: ImageLoaderPropsWithConfig): string {\n if (\n src.startsWith('/') &&\n src.includes('?') &&\n config.localPatterns?.length === 1 &&\n config.localPatterns[0].pathname === '**' &&\n config.localPatterns[0].search === ''\n ) {\n throw new Error(\n `Image with src \"${src}\" is using a query string which is not configured in images.localPatterns.` +\n `\\nRead more: https://nextjs.org/docs/messages/next-image-unconfigured-localpatterns`\n )\n }\n\n if (process.env.NODE_ENV !== 'production') {\n const missingValues = []\n\n // these should always be provided but make sure they are\n if (!src) missingValues.push('src')\n if (!width) missingValues.push('width')\n\n if (missingValues.length > 0) {\n throw new Error(\n `Next Image Optimization requires ${missingValues.join(\n ', '\n )} to be provided. Make sure you pass them as props to the \\`next/image\\` component. Received: ${JSON.stringify(\n { src, width, quality }\n )}`\n )\n }\n\n if (src.startsWith('//')) {\n throw new Error(\n `Failed to parse src \"${src}\" on \\`next/image\\`, protocol-relative URL (//) must be changed to an absolute URL (http:// or https://)`\n )\n }\n\n if (src.startsWith('/') && config.localPatterns) {\n if (\n process.env.NODE_ENV !== 'test' &&\n // micromatch isn't compatible with edge runtime\n process.env.NEXT_RUNTIME !== 'edge'\n ) {\n // We use dynamic require because this should only error in development\n const { hasLocalMatch } =\n require('./match-local-pattern') as typeof import('./match-local-pattern')\n if (!hasLocalMatch(config.localPatterns, src)) {\n throw new Error(\n `Invalid src prop (${src}) on \\`next/image\\` does not match \\`images.localPatterns\\` configured in your \\`next.config.js\\`\\n` +\n `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-localpatterns`\n )\n }\n }\n }\n\n if (!src.startsWith('/') && (config.domains || config.remotePatterns)) {\n let parsedSrc: URL\n try {\n parsedSrc = new URL(src)\n } catch (err) {\n console.error(err)\n throw new Error(\n `Failed to parse src \"${src}\" on \\`next/image\\`, if using relative image it must start with a leading slash \"/\" or be an absolute URL (http:// or https://)`\n )\n }\n\n if (\n process.env.NODE_ENV !== 'test' &&\n // micromatch isn't compatible with edge runtime\n process.env.NEXT_RUNTIME !== 'edge'\n ) {\n // We use dynamic require because this should only error in development\n const { hasRemoteMatch } =\n require('./match-remote-pattern') as typeof import('./match-remote-pattern')\n if (\n !hasRemoteMatch(config.domains!, config.remotePatterns!, parsedSrc)\n ) {\n throw new Error(\n `Invalid src prop (${src}) on \\`next/image\\`, hostname \"${parsedSrc.hostname}\" is not configured under images in your \\`next.config.js\\`\\n` +\n `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-host`\n )\n }\n }\n }\n }\n\n const q = findClosestQuality(quality, config)\n\n let deploymentId = getDeploymentId()\n return `${config.path}?url=${encodeURIComponent(src)}&w=${width}&q=${q}${\n src.startsWith('/') && deploymentId ? `&dpl=${deploymentId}` : ''\n }`\n}\n\n// We use this to determine if the import is the default loader\n// or a custom loader defined by the user in next.config.js\ndefaultLoader.__next_img_default = true\n\nexport default defaultLoader\n","import type { ImageConfigComplete, ImageLoaderProps } from './image-config'\nimport type { ImageProps, ImageLoader, StaticImageData } from './get-img-props'\n\nimport { getImgProps } from './get-img-props'\nimport { Image } from '../../client/image-component'\n\n// This is replaced by webpack alias\nimport defaultLoader from 'next/dist/shared/lib/image-loader'\n\n/**\n * For more advanced use cases, you can call `getImageProps()`\n * to get the props that would be passed to the underlying `<img>` element,\n * and instead pass to them to another component, style, canvas, etc.\n *\n * Read more: [Next.js docs: `getImageProps`](https://nextjs.org/docs/app/api-reference/components/image#getimageprops)\n */\nexport function getImageProps(imgProps: ImageProps) {\n const { props } = getImgProps(imgProps, {\n defaultLoader,\n // This is replaced by webpack define plugin\n imgConf: process.env.__NEXT_IMAGE_OPTS as any as ImageConfigComplete,\n })\n // Normally we don't care about undefined props because we pass to JSX,\n // but this exported function could be used by the end user for anything\n // so we delete undefined props to clean it up a little.\n for (const [key, value] of Object.entries(props)) {\n if (value === undefined) {\n delete props[key as keyof typeof props]\n }\n }\n return { props }\n}\n\nexport default Image\n\nexport type { ImageProps, ImageLoaderProps, ImageLoader, StaticImageData }\n","module.exports = require('./dist/shared/lib/image-external')\n","// This file is generated by next-core EcmascriptClientReferenceModule.\nconst { createClientModuleProxy } = require(\"react-server-dom-turbopack/server\");\n\n__turbopack_context__.n(createClientModuleProxy(\"[project]/node_modules/.pnpm/next@16.1.1_@babel+core@7.26.10_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/next/dist/client/app-dir/link.js\"));\n","'use client'\n\nimport React, { createContext, useContext, useOptimistic, useRef } from 'react'\nimport type { UrlObject } from 'url'\nimport { formatUrl } from '../../shared/lib/router/utils/format-url'\nimport { AppRouterContext } from '../../shared/lib/app-router-context.shared-runtime'\nimport { useMergedRef } from '../use-merged-ref'\nimport { isAbsoluteUrl } from '../../shared/lib/utils'\nimport { addBasePath } from '../add-base-path'\nimport { warnOnce } from '../../shared/lib/utils/warn-once'\nimport type { PENDING_LINK_STATUS } from '../components/links'\nimport {\n IDLE_LINK_STATUS,\n mountLinkInstance,\n onNavigationIntent,\n unmountLinkForCurrentNavigation,\n unmountPrefetchableInstance,\n type LinkInstance,\n} from '../components/links'\nimport { isLocalURL } from '../../shared/lib/router/utils/is-local-url'\nimport {\n FetchStrategy,\n type PrefetchTaskFetchStrategy,\n} from '../components/segment-cache/types'\nimport { errorOnce } from '../../shared/lib/utils/error-once'\n\ntype Url = string | UrlObject\ntype RequiredKeys<T> = {\n [K in keyof T]-?: {} extends Pick<T, K> ? never : K\n}[keyof T]\ntype OptionalKeys<T> = {\n [K in keyof T]-?: {} extends Pick<T, K> ? K : never\n}[keyof T]\n\ntype OnNavigateEventHandler = (event: { preventDefault: () => void }) => void\n\ntype InternalLinkProps = {\n /**\n * **Required**. The path or URL to navigate to. It can also be an object (similar to `URL`).\n *\n * @example\n * ```tsx\n * // Navigate to /dashboard:\n * <Link href=\"/dashboard\">Dashboard</Link>\n *\n * // Navigate to /about?name=test:\n * <Link href={{ pathname: '/about', query: { name: 'test' } }}>\n * About\n * </Link>\n * ```\n *\n * @remarks\n * - For external URLs, use a fully qualified URL such as `https://...`.\n * - In the App Router, dynamic routes must not include bracketed segments in `href`.\n */\n href: Url\n\n /**\n * @deprecated v10.0.0: `href` props pointing to a dynamic route are\n * automatically resolved and no longer require the `as` prop.\n */\n as?: Url\n\n /**\n * Replace the current `history` state instead of adding a new URL into the stack.\n *\n * @defaultValue `false`\n *\n * @example\n * ```tsx\n * <Link href=\"/about\" replace>\n * About (replaces the history state)\n * </Link>\n * ```\n */\n replace?: boolean\n\n /**\n * Whether to override the default scroll behavior. If `true`, Next.js attempts to maintain\n * the scroll position if the newly navigated page is still visible. If not, it scrolls to the top.\n *\n * If `false`, Next.js will not modify the scroll behavior at all.\n *\n * @defaultValue `true`\n *\n * @example\n * ```tsx\n * <Link href=\"/dashboard\" scroll={false}>\n * No auto scroll\n * </Link>\n * ```\n */\n scroll?: boolean\n\n /**\n * Update the path of the current page without rerunning data fetching methods\n * like `getStaticProps`, `getServerSideProps`, or `getInitialProps`.\n *\n * @remarks\n * `shallow` only applies to the Pages Router. For the App Router, see the\n * [following documentation](https://nextjs.org/docs/app/building-your-application/routing/linking-and-navigating#using-the-native-history-api).\n *\n * @defaultValue `false`\n *\n * @example\n * ```tsx\n * <Link href=\"/blog\" shallow>\n * Shallow navigation\n * </Link>\n * ```\n */\n shallow?: boolean\n\n /**\n * Forces `Link` to pass its `href` to the child component. Useful if the child is a custom\n * component that wraps an `<a>` tag, or if you're using certain styling libraries.\n *\n * @defaultValue `false`\n *\n * @example\n * ```tsx\n * <Link href=\"/dashboard\" passHref legacyBehavior>\n * <MyStyledAnchor>Dashboard</MyStyledAnchor>\n * </Link>\n * ```\n */\n passHref?: boolean\n\n /**\n * Prefetch the page in the background.\n * Any `<Link />` that is in the viewport (initially or through scroll) will be prefetched.\n * Prefetch can be disabled by passing `prefetch={false}`.\n *\n * @remarks\n * Prefetching is only enabled in production.\n *\n * - In the **App Router**:\n * - `\"auto\"`, `null`, `undefined` (default): Prefetch behavior depends on static vs dynamic routes:\n * - Static routes: fully prefetched\n * - Dynamic routes: partial prefetch to the nearest segment with a `loading.js`\n * - `true`: Always prefetch the full route and data.\n * - `false`: Disable prefetching on both viewport and hover.\n * - In the **Pages Router**:\n * - `true` (default): Prefetches the route and data in the background on viewport or hover.\n * - `false`: Prefetch only on hover, not on viewport.\n *\n * @defaultValue `true` (Pages Router) or `null` (App Router)\n *\n * @example\n * ```tsx\n * <Link href=\"/dashboard\" prefetch={false}>\n * Dashboard\n * </Link>\n * ```\n */\n prefetch?: boolean | 'auto' | null\n\n /**\n * (unstable) Switch to a full prefetch on hover. Effectively the same as\n * updating the prefetch prop to `true` in a mouse event.\n */\n unstable_dynamicOnHover?: boolean\n\n /**\n * The active locale is automatically prepended in the Pages Router. `locale` allows for providing\n * a different locale, or can be set to `false` to opt out of automatic locale behavior.\n *\n * @remarks\n * Note: locale only applies in the Pages Router and is ignored in the App Router.\n *\n * @example\n * ```tsx\n * // Use the 'fr' locale:\n * <Link href=\"/about\" locale=\"fr\">\n * About (French)\n * </Link>\n *\n * // Disable locale prefix:\n * <Link href=\"/about\" locale={false}>\n * About (no locale prefix)\n * </Link>\n * ```\n */\n locale?: string | false\n\n /**\n * Enable legacy link behavior.\n *\n * @deprecated This will be removed in a future version\n * @defaultValue `false`\n * @see https://github.com/vercel/next.js/commit/489e65ed98544e69b0afd7e0cfc3f9f6c2b803b7\n */\n legacyBehavior?: boolean\n\n /**\n * Optional event handler for when the mouse pointer is moved onto the `<Link>`.\n */\n onMouseEnter?: React.MouseEventHandler<HTMLAnchorElement>\n\n /**\n * Optional event handler for when the `<Link>` is touched.\n */\n onTouchStart?: React.TouchEventHandler<HTMLAnchorElement>\n\n /**\n * Optional event handler for when the `<Link>` is clicked.\n */\n onClick?: React.MouseEventHandler<HTMLAnchorElement>\n\n /**\n * Optional event handler for when the `<Link>` is navigated.\n */\n onNavigate?: OnNavigateEventHandler\n}\n\n// TODO-APP: Include the full set of Anchor props\n// adding this to the publicly exported type currently breaks existing apps\n\n// `RouteInferType` is a stub here to avoid breaking `typedRoutes` when the type\n// isn't generated yet. It will be replaced when type generation runs.\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport type LinkProps<RouteInferType = any> = InternalLinkProps\ntype LinkPropsRequired = RequiredKeys<LinkProps>\ntype LinkPropsOptional = OptionalKeys<Omit<InternalLinkProps, 'locale'>>\n\nfunction isModifiedEvent(event: React.MouseEvent): boolean {\n const eventTarget = event.currentTarget as HTMLAnchorElement | SVGAElement\n const target = eventTarget.getAttribute('target')\n return (\n (target && target !== '_self') ||\n event.metaKey ||\n event.ctrlKey ||\n event.shiftKey ||\n event.altKey || // triggers resource download\n (event.nativeEvent && event.nativeEvent.which === 2)\n )\n}\n\nfunction linkClicked(\n e: React.MouseEvent,\n href: string,\n as: string,\n linkInstanceRef: React.RefObject<LinkInstance | null>,\n replace?: boolean,\n scroll?: boolean,\n onNavigate?: OnNavigateEventHandler\n): void {\n if (typeof window !== 'undefined') {\n const { nodeName } = e.currentTarget\n\n // anchors inside an svg have a lowercase nodeName\n const isAnchorNodeName = nodeName.toUpperCase() === 'A'\n if (\n (isAnchorNodeName && isModifiedEvent(e)) ||\n e.currentTarget.hasAttribute('download')\n ) {\n // ignore click for browser’s default behavior\n return\n }\n\n if (!isLocalURL(href)) {\n if (replace) {\n // browser default behavior does not replace the history state\n // so we need to do it manually\n e.preventDefault()\n location.replace(href)\n }\n\n // ignore click for browser’s default behavior\n return\n }\n\n e.preventDefault()\n\n if (onNavigate) {\n let isDefaultPrevented = false\n\n onNavigate({\n preventDefault: () => {\n isDefaultPrevented = true\n },\n })\n\n if (isDefaultPrevented) {\n return\n }\n }\n\n const { dispatchNavigateAction } =\n require('../components/app-router-instance') as typeof import('../components/app-router-instance')\n\n React.startTransition(() => {\n dispatchNavigateAction(\n as || href,\n replace ? 'replace' : 'push',\n scroll ?? true,\n linkInstanceRef.current\n )\n })\n }\n}\n\nfunction formatStringOrUrl(urlObjOrString: UrlObject | string): string {\n if (typeof urlObjOrString === 'string') {\n return urlObjOrString\n }\n\n return formatUrl(urlObjOrString)\n}\n\n/**\n * A React component that extends the HTML `<a>` element to provide\n * [prefetching](https://nextjs.org/docs/app/building-your-application/routing/linking-and-navigating#2-prefetching)\n * and client-side navigation. This is the primary way to navigate between routes in Next.js.\n *\n * @remarks\n * - Prefetching is only enabled in production.\n *\n * @see https://nextjs.org/docs/app/api-reference/components/link\n */\nexport default function LinkComponent(\n props: LinkProps & {\n children: React.ReactNode\n ref: React.Ref<HTMLAnchorElement>\n }\n) {\n const [linkStatus, setOptimisticLinkStatus] = useOptimistic(IDLE_LINK_STATUS)\n\n let children: React.ReactNode\n\n const linkInstanceRef = useRef<LinkInstance | null>(null)\n\n const {\n href: hrefProp,\n as: asProp,\n children: childrenProp,\n prefetch: prefetchProp = null,\n passHref,\n replace,\n shallow,\n scroll,\n onClick,\n onMouseEnter: onMouseEnterProp,\n onTouchStart: onTouchStartProp,\n legacyBehavior = false,\n onNavigate,\n ref: forwardedRef,\n unstable_dynamicOnHover,\n ...restProps\n } = props\n\n children = childrenProp\n\n if (\n legacyBehavior &&\n (typeof children === 'string' || typeof children === 'number')\n ) {\n children = <a>{children}</a>\n }\n\n const router = React.useContext(AppRouterContext)\n\n const prefetchEnabled = prefetchProp !== false\n\n const fetchStrategy =\n prefetchProp !== false\n ? getFetchStrategyFromPrefetchProp(prefetchProp)\n : // TODO: it makes no sense to assign a fetchStrategy when prefetching is disabled.\n FetchStrategy.PPR\n\n if (process.env.NODE_ENV !== 'production') {\n function createPropError(args: {\n key: string\n expected: string\n actual: string\n }) {\n return new Error(\n `Failed prop type: The prop \\`${args.key}\\` expects a ${args.expected} in \\`<Link>\\`, but got \\`${args.actual}\\` instead.` +\n (typeof window !== 'undefined'\n ? \"\\nOpen your browser's console to view the Component stack trace.\"\n : '')\n )\n }\n\n // TypeScript trick for type-guarding:\n const requiredPropsGuard: Record<LinkPropsRequired, true> = {\n href: true,\n } as const\n const requiredProps: LinkPropsRequired[] = Object.keys(\n requiredPropsGuard\n ) as LinkPropsRequired[]\n requiredProps.forEach((key: LinkPropsRequired) => {\n if (key === 'href') {\n if (\n props[key] == null ||\n (typeof props[key] !== 'string' && typeof props[key] !== 'object')\n ) {\n throw createPropError({\n key,\n expected: '`string` or `object`',\n actual: props[key] === null ? 'null' : typeof props[key],\n })\n }\n } else {\n // TypeScript trick for type-guarding:\n const _: never = key\n }\n })\n\n // TypeScript trick for type-guarding:\n const optionalPropsGuard: Record<LinkPropsOptional, true> = {\n as: true,\n replace: true,\n scroll: true,\n shallow: true,\n passHref: true,\n prefetch: true,\n unstable_dynamicOnHover: true,\n onClick: true,\n onMouseEnter: true,\n onTouchStart: true,\n legacyBehavior: true,\n onNavigate: true,\n } as const\n const optionalProps: LinkPropsOptional[] = Object.keys(\n optionalPropsGuard\n ) as LinkPropsOptional[]\n optionalProps.forEach((key: LinkPropsOptional) => {\n const valType = typeof props[key]\n\n if (key === 'as') {\n if (props[key] && valType !== 'string' && valType !== 'object') {\n throw createPropError({\n key,\n expected: '`string` or `object`',\n actual: valType,\n })\n }\n } else if (\n key === 'onClick' ||\n key === 'onMouseEnter' ||\n key === 'onTouchStart' ||\n key === 'onNavigate'\n ) {\n if (props[key] && valType !== 'function') {\n throw createPropError({\n key,\n expected: '`function`',\n actual: valType,\n })\n }\n } else if (\n key === 'replace' ||\n key === 'scroll' ||\n key === 'shallow' ||\n key === 'passHref' ||\n key === 'legacyBehavior' ||\n key === 'unstable_dynamicOnHover'\n ) {\n if (props[key] != null && valType !== 'boolean') {\n throw createPropError({\n key,\n expected: '`boolean`',\n actual: valType,\n })\n }\n } else if (key === 'prefetch') {\n if (\n props[key] != null &&\n valType !== 'boolean' &&\n props[key] !== 'auto'\n ) {\n throw createPropError({\n key,\n expected: '`boolean | \"auto\"`',\n actual: valType,\n })\n }\n } else {\n // TypeScript trick for type-guarding:\n const _: never = key\n }\n })\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (props.locale) {\n warnOnce(\n 'The `locale` prop is not supported in `next/link` while using the `app` router. Read more about app router internalization: https://nextjs.org/docs/app/building-your-application/routing/internationalization'\n )\n }\n if (!asProp) {\n let href: string | undefined\n if (typeof hrefProp === 'string') {\n href = hrefProp\n } else if (\n typeof hrefProp === 'object' &&\n typeof hrefProp.pathname === 'string'\n ) {\n href = hrefProp.pathname\n }\n\n if (href) {\n const hasDynamicSegment = href\n .split('/')\n .some((segment) => segment.startsWith('[') && segment.endsWith(']'))\n\n if (hasDynamicSegment) {\n throw new Error(\n `Dynamic href \\`${href}\\` found in <Link> while using the \\`/app\\` router, this is not supported. Read more: https://nextjs.org/docs/messages/app-dir-dynamic-href`\n )\n }\n }\n }\n }\n\n const { href, as } = React.useMemo(() => {\n const resolvedHref = formatStringOrUrl(hrefProp)\n return {\n href: resolvedHref,\n as: asProp ? formatStringOrUrl(asProp) : resolvedHref,\n }\n }, [hrefProp, asProp])\n\n // This will return the first child, if multiple are provided it will throw an error\n let child: any\n if (legacyBehavior) {\n if ((children as any)?.$$typeof === Symbol.for('react.lazy')) {\n throw new Error(\n `\\`<Link legacyBehavior>\\` received a direct child that is either a Server Component, or JSX that was loaded with React.lazy(). This is not supported. Either remove legacyBehavior, or make the direct child a Client Component that renders the Link's \\`<a>\\` tag.`\n )\n }\n\n if (process.env.NODE_ENV === 'development') {\n if (onClick) {\n console.warn(\n `\"onClick\" was passed to <Link> with \\`href\\` of \\`${hrefProp}\\` but \"legacyBehavior\" was set. The legacy behavior requires onClick be set on the child of next/link`\n )\n }\n if (onMouseEnterProp) {\n console.warn(\n `\"onMouseEnter\" was passed to <Link> with \\`href\\` of \\`${hrefProp}\\` but \"legacyBehavior\" was set. The legacy behavior requires onMouseEnter be set on the child of next/link`\n )\n }\n try {\n child = React.Children.only(children)\n } catch (err) {\n if (!children) {\n throw new Error(\n `No children were passed to <Link> with \\`href\\` of \\`${hrefProp}\\` but one child is required https://nextjs.org/docs/messages/link-no-children`\n )\n }\n throw new Error(\n `Multiple children were passed to <Link> with \\`href\\` of \\`${hrefProp}\\` but only one child is supported https://nextjs.org/docs/messages/link-multiple-children` +\n (typeof window !== 'undefined'\n ? \" \\nOpen your browser's console to view the Component stack trace.\"\n : '')\n )\n }\n } else {\n child = React.Children.only(children)\n }\n } else {\n if (process.env.NODE_ENV === 'development') {\n if ((children as any)?.type === 'a') {\n throw new Error(\n 'Invalid <Link> with <a> child. Please remove <a> or use <Link legacyBehavior>.\\nLearn more: https://nextjs.org/docs/messages/invalid-new-link-with-extra-anchor'\n )\n }\n }\n }\n\n const childRef: any = legacyBehavior\n ? child && typeof child === 'object' && child.ref\n : forwardedRef\n\n // Use a callback ref to attach an IntersectionObserver to the anchor tag on\n // mount. In the future we will also use this to keep track of all the\n // currently mounted <Link> instances, e.g. so we can re-prefetch them after\n // a revalidation or refresh.\n const observeLinkVisibilityOnMount = React.useCallback(\n (element: HTMLAnchorElement | SVGAElement) => {\n if (router !== null) {\n linkInstanceRef.current = mountLinkInstance(\n element,\n href,\n router,\n fetchStrategy,\n prefetchEnabled,\n setOptimisticLinkStatus\n )\n }\n\n return () => {\n if (linkInstanceRef.current) {\n unmountLinkForCurrentNavigation(linkInstanceRef.current)\n linkInstanceRef.current = null\n }\n unmountPrefetchableInstance(element)\n }\n },\n [prefetchEnabled, href, router, fetchStrategy, setOptimisticLinkStatus]\n )\n\n const mergedRef = useMergedRef(observeLinkVisibilityOnMount, childRef)\n\n const childProps: {\n onTouchStart?: React.TouchEventHandler<HTMLAnchorElement>\n onMouseEnter: React.MouseEventHandler<HTMLAnchorElement>\n onClick: React.MouseEventHandler<HTMLAnchorElement>\n href?: string\n ref?: any\n } = {\n ref: mergedRef,\n onClick(e) {\n if (process.env.NODE_ENV !== 'production') {\n if (!e) {\n throw new Error(\n `Component rendered inside next/link has to pass click event to \"onClick\" prop.`\n )\n }\n }\n\n if (!legacyBehavior && typeof onClick === 'function') {\n onClick(e)\n }\n\n if (\n legacyBehavior &&\n child.props &&\n typeof child.props.onClick === 'function'\n ) {\n child.props.onClick(e)\n }\n\n if (!router) {\n return\n }\n if (e.defaultPrevented) {\n return\n }\n linkClicked(e, href, as, linkInstanceRef, replace, scroll, onNavigate)\n },\n onMouseEnter(e) {\n if (!legacyBehavior && typeof onMouseEnterProp === 'function') {\n onMouseEnterProp(e)\n }\n\n if (\n legacyBehavior &&\n child.props &&\n typeof child.props.onMouseEnter === 'function'\n ) {\n child.props.onMouseEnter(e)\n }\n\n if (!router) {\n return\n }\n if (!prefetchEnabled || process.env.NODE_ENV === 'development') {\n return\n }\n\n const upgradeToDynamicPrefetch = unstable_dynamicOnHover === true\n onNavigationIntent(\n e.currentTarget as HTMLAnchorElement | SVGAElement,\n upgradeToDynamicPrefetch\n )\n },\n onTouchStart: process.env.__NEXT_LINK_NO_TOUCH_START\n ? undefined\n : function onTouchStart(e) {\n if (!legacyBehavior && typeof onTouchStartProp === 'function') {\n onTouchStartProp(e)\n }\n\n if (\n legacyBehavior &&\n child.props &&\n typeof child.props.onTouchStart === 'function'\n ) {\n child.props.onTouchStart(e)\n }\n\n if (!router) {\n return\n }\n if (!prefetchEnabled) {\n return\n }\n\n const upgradeToDynamicPrefetch = unstable_dynamicOnHover === true\n onNavigationIntent(\n e.currentTarget as HTMLAnchorElement | SVGAElement,\n upgradeToDynamicPrefetch\n )\n },\n }\n\n // If the url is absolute, we can bypass the logic to prepend the basePath.\n if (isAbsoluteUrl(as)) {\n childProps.href = as\n } else if (\n !legacyBehavior ||\n passHref ||\n (child.type === 'a' && !('href' in child.props))\n ) {\n childProps.href = addBasePath(as)\n }\n\n let link: React.ReactNode\n\n if (legacyBehavior) {\n if (process.env.NODE_ENV === 'development') {\n errorOnce(\n '`legacyBehavior` is deprecated and will be removed in a future ' +\n 'release. A codemod is available to upgrade your components:\\n\\n' +\n 'npx @next/codemod@latest new-link .\\n\\n' +\n 'Learn more: https://nextjs.org/docs/app/building-your-application/upgrading/codemods#remove-a-tags-from-link-components'\n )\n }\n link = React.cloneElement(child, childProps)\n } else {\n link = (\n <a {...restProps} {...childProps}>\n {children}\n </a>\n )\n }\n\n return (\n <LinkStatusContext.Provider value={linkStatus}>\n {link}\n </LinkStatusContext.Provider>\n )\n}\n\nconst LinkStatusContext = createContext<\n typeof PENDING_LINK_STATUS | typeof IDLE_LINK_STATUS\n>(IDLE_LINK_STATUS)\n\nexport const useLinkStatus = () => {\n return useContext(LinkStatusContext)\n}\n\nfunction getFetchStrategyFromPrefetchProp(\n prefetchProp: Exclude<LinkProps['prefetch'], undefined | false>\n): PrefetchTaskFetchStrategy {\n if (process.env.__NEXT_CACHE_COMPONENTS) {\n if (prefetchProp === true) {\n return FetchStrategy.Full\n }\n\n // `null` or `\"auto\"`: this is the default \"auto\" mode, where we will prefetch partially if the link is in the viewport.\n // This will also include invalid prop values that don't match the types specified here.\n // (although those should've been filtered out by prop validation in dev)\n prefetchProp satisfies null | 'auto'\n return FetchStrategy.PPR\n } else {\n return prefetchProp === null || prefetchProp === 'auto'\n ? // We default to PPR, and we'll discover whether or not the route supports it with the initial prefetch.\n FetchStrategy.PPR\n : // In the old implementation without runtime prefetches, `prefetch={true}` forces all dynamic data to be prefetched.\n // To preserve backwards-compatibility, anything other than `false`, `null`, or `\"auto\"` results in a full prefetch.\n // (although invalid values should've been filtered out by prop validation in dev)\n FetchStrategy.Full\n }\n}\n","import type { ComponentProps } from 'react'\nimport ClientLinkComponent, { type LinkProps, useLinkStatus } from './link'\n\nexport default function LinkComponent(\n props: ComponentProps<typeof ClientLinkComponent>\n) {\n const isLegacyBehavior = props.legacyBehavior\n const childIsHostComponent =\n typeof props.children === 'string' ||\n typeof props.children === 'number' ||\n typeof (props.children as any)?.type === 'string'\n const childIsClientComponent =\n (props.children as any)?.type?.$$typeof ===\n Symbol.for('react.client.reference')\n\n if (isLegacyBehavior && !childIsHostComponent && !childIsClientComponent) {\n if ((props.children as any)?.type?.$$typeof === Symbol.for('react.lazy')) {\n console.error(\n `Using a Lazy Component as a direct child of \\`<Link legacyBehavior>\\` from a Server Component is not supported. If you need legacyBehavior, wrap your Lazy Component in a Client Component that renders the Link's \\`<a>\\` tag.`\n )\n } else {\n console.error(\n `Using a Server Component as a direct child of \\`<Link legacyBehavior>\\` is not supported. If you need legacyBehavior, wrap your Server Component in a Client Component that renders the Link's \\`<a>\\` tag.`\n )\n }\n }\n\n return <ClientLinkComponent {...props} />\n}\n\nexport { type LinkProps, useLinkStatus }\n","// This file is generated by next-core EcmascriptClientReferenceModule.\nimport { registerClientReference } from \"react-server-dom-turbopack/server\";\nexport const Button = registerClientReference(\n function() { throw new Error(\"Attempted to call Button() from the server but Button is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.\"); },\n \"[project]/packages/preview-server/src/components/button.tsx\",\n \"Button\",\n);\n","// This file is generated by next-core EcmascriptClientReferenceModule.\nimport { registerClientReference } from \"react-server-dom-turbopack/server\";\nexport const Code = registerClientReference(\n function() { throw new Error(\"Attempted to call Code() from the server but Code is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.\"); },\n \"[project]/packages/preview-server/src/components/code.tsx\",\n \"Code\",\n);\n","// This file is generated by next-core EcmascriptClientReferenceModule.\nimport { registerClientReference } from \"react-server-dom-turbopack/server\";\nexport const Sidebar = registerClientReference(\n function() { throw new Error(\"Attempted to call Sidebar() from the server but Sidebar is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.\"); },\n \"[project]/packages/preview-server/src/components/sidebar/sidebar.tsx\",\n \"Sidebar\",\n);\n","// This file is generated by next-core EcmascriptClientReferenceModule.\nimport { registerClientReference } from \"react-server-dom-turbopack/server\";\nexport const Topbar = registerClientReference(\n function() { throw new Error(\"Attempted to call Topbar() from the server but Topbar is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.\"); },\n \"[project]/packages/preview-server/src/components/topbar.tsx\",\n \"Topbar\",\n);\n","export * from './button';\nexport * from './code';\nexport * from './heading';\nexport * from './logo';\nexport * from './sidebar';\nexport * from './text';\nexport * from './topbar';\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","const languageMap = {\n tsx: 'React',\n html: 'HTML',\n markdown: 'Plain Text',\n};\n\nexport default languageMap;\n","import path from 'node:path';\nimport Image from 'next/image';\nimport Link from 'next/link';\nimport { Button, Heading, Text } from '../components';\nimport CodeSnippet from '../components/code-snippet';\nimport { Shell } from '../components/shell';\nimport { templatesDirectoryAbsolutePath } from './env';\nimport logo from './logo.png';\n\nexport default function Home() {\n const baseTemplatesDirectoryName = path.basename(\n templatesDirectoryAbsolutePath,\n );\n\n return (\n <Shell>\n <div className=\"w-full h-full flex items-center justify-center p-8\">\n <div className=\"-mt-10 relative max-w-lg flex flex-col items-center gap-3 text-center\">\n <Image\n alt=\"React PDF Forge Icon\"\n className=\"mb-8\"\n height={144}\n src={logo}\n style={{\n borderRadius: 34,\n boxShadow: '0 .625rem 12.5rem 1.25rem #2B7CA080',\n }}\n width={141}\n />\n <Heading as=\"h2\" size=\"6\" weight=\"medium\">\n Welcome to React PDF Forge\n </Heading>\n <Text as=\"p\">\n To start developing your PDF templates, you can create a<br />\n <CodeSnippet>.jsx</CodeSnippet> or <CodeSnippet>.tsx</CodeSnippet>{' '}\n file under your{' '}\n <CodeSnippet>{baseTemplatesDirectoryName}</CodeSnippet> folder.\n </Text>\n <Button asChild className=\"mt-3\" size=\"3\">\n <Link\n href=\"https://github.com/ahmedrowaihi/react-pdf-forge\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Check the docs\n </Link>\n </Button>\n </div>\n </div>\n </Shell>\n );\n}\n","export * from './sidebar';\n","const CodeSnippet = ({ children }) => {\n return (\n <code className=\"m-0.5 inline-block rounded-md bg-white/10 p-1 font-mono leading-none text-slate-12\">\n {children}\n </code>\n );\n};\n\nexport default CodeSnippet;\n","import src from \"IMAGE\";\nexport default { src, width: 1024, height: 1024, blurWidth: 8, blurHeight: 8, blurDataURL: \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAYAAADED76LAAABE0lEQVR42gEIAff+ABYyQHkgTGPrJ1lz/ilfe/8nXHj/IVBq/h9JX+kWMD11ABxEWe0qT2L/dae9/2qmwP9fmbT/QGuA/xg8Tv8cQ1fpABg9Uf8oVGn/XqPB/2afuv9kmbP/VYSf/yBHW/8ZP1P+ABY4S/8gTWT/RYOh/05/mP9Ke5T/PXKR/x9JYP8YO07/ABY1Rv8cRVv/L2iJ/0R/nf9Cepj/K1p4/xxCV/8XOEn/ABUyQf8YO0//Iklk/092jv9McIj/Hj9Y/xg6Tf8WNET+ABY0Q+0UMED/HUFY/y5UbP8tU2r/Gz5T/xQwP/8WNEPpABEoM3sXOEntGT9T/xtDWf8bQlj/GT1R/xc3SOsQJjF2rYF2q4NU9j8AAAAASUVORK5CYII=\"};\n","export const copyTextToClipboard = async (text: string) => {\n try {\n await navigator.clipboard.writeText(text);\n } catch {\n throw new Error('Not able to copy');\n }\n};\n","export const unreachable = (\n condition: string | Record<string, unknown>,\n message = `Entered unreachable code. Received '${\n typeof condition === 'string' ? condition : JSON.stringify(condition)\n }'.`,\n): never => {\n throw new TypeError(message);\n};\n","import {\n AnyClassGroupIds,\n AnyConfig,\n AnyThemeGroupIds,\n ClassGroup,\n ClassValidator,\n Config,\n ThemeGetter,\n ThemeObject,\n} from './types'\n\nexport interface ClassPartObject {\n nextPart: Map<string, ClassPartObject>\n validators: ClassValidatorObject[]\n classGroupId?: AnyClassGroupIds\n}\n\ninterface ClassValidatorObject {\n classGroupId: AnyClassGroupIds\n validator: ClassValidator\n}\n\nconst CLASS_PART_SEPARATOR = '-'\n\nexport const createClassGroupUtils = (config: AnyConfig) => {\n const classMap = createClassMap(config)\n const { conflictingClassGroups, conflictingClassGroupModifiers } = config\n\n const getClassGroupId = (className: string) => {\n const classParts = className.split(CLASS_PART_SEPARATOR)\n\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and remove it from classParts.\n if (classParts[0] === '' && classParts.length !== 1) {\n classParts.shift()\n }\n\n return getGroupRecursive(classParts, classMap) || getGroupIdForArbitraryProperty(className)\n }\n\n const getConflictingClassGroupIds = (\n classGroupId: AnyClassGroupIds,\n hasPostfixModifier: boolean,\n ) => {\n const conflicts = conflictingClassGroups[classGroupId] || []\n\n if (hasPostfixModifier && conflictingClassGroupModifiers[classGroupId]) {\n return [...conflicts, ...conflictingClassGroupModifiers[classGroupId]!]\n }\n\n return conflicts\n }\n\n return {\n getClassGroupId,\n getConflictingClassGroupIds,\n }\n}\n\nconst getGroupRecursive = (\n classParts: string[],\n classPartObject: ClassPartObject,\n): AnyClassGroupIds | undefined => {\n if (classParts.length === 0) {\n return classPartObject.classGroupId\n }\n\n const currentClassPart = classParts[0]!\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart)\n const classGroupFromNextClassPart = nextClassPartObject\n ? getGroupRecursive(classParts.slice(1), nextClassPartObject)\n : undefined\n\n if (classGroupFromNextClassPart) {\n return classGroupFromNextClassPart\n }\n\n if (classPartObject.validators.length === 0) {\n return undefined\n }\n\n const classRest = classParts.join(CLASS_PART_SEPARATOR)\n\n return classPartObject.validators.find(({ validator }) => validator(classRest))?.classGroupId\n}\n\nconst arbitraryPropertyRegex = /^\\[(.+)\\]$/\n\nconst getGroupIdForArbitraryProperty = (className: string) => {\n if (arbitraryPropertyRegex.test(className)) {\n const arbitraryPropertyClassName = arbitraryPropertyRegex.exec(className)![1]\n const property = arbitraryPropertyClassName?.substring(\n 0,\n arbitraryPropertyClassName.indexOf(':'),\n )\n\n if (property) {\n // I use two dots here because one dot is used as prefix for class groups in plugins\n return 'arbitrary..' + property\n }\n }\n}\n\n/**\n * Exported for testing only\n */\nexport const createClassMap = (config: Config<AnyClassGroupIds, AnyThemeGroupIds>) => {\n const { theme, classGroups } = config\n const classMap: ClassPartObject = {\n nextPart: new Map<string, ClassPartObject>(),\n validators: [],\n }\n\n for (const classGroupId in classGroups) {\n processClassesRecursively(classGroups[classGroupId]!, classMap, classGroupId, theme)\n }\n\n return classMap\n}\n\nconst processClassesRecursively = (\n classGroup: ClassGroup<AnyThemeGroupIds>,\n classPartObject: ClassPartObject,\n classGroupId: AnyClassGroupIds,\n theme: ThemeObject<AnyThemeGroupIds>,\n) => {\n classGroup.forEach((classDefinition) => {\n if (typeof classDefinition === 'string') {\n const classPartObjectToEdit =\n classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition)\n classPartObjectToEdit.classGroupId = classGroupId\n return\n }\n\n if (typeof classDefinition === 'function') {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(\n classDefinition(theme),\n classPartObject,\n classGroupId,\n theme,\n )\n return\n }\n\n classPartObject.validators.push({\n validator: classDefinition,\n classGroupId,\n })\n\n return\n }\n\n Object.entries(classDefinition).forEach(([key, classGroup]) => {\n processClassesRecursively(\n classGroup,\n getPart(classPartObject, key),\n classGroupId,\n theme,\n )\n })\n })\n}\n\nconst getPart = (classPartObject: ClassPartObject, path: string) => {\n let currentClassPartObject = classPartObject\n\n path.split(CLASS_PART_SEPARATOR).forEach((pathPart) => {\n if (!currentClassPartObject.nextPart.has(pathPart)) {\n currentClassPartObject.nextPart.set(pathPart, {\n nextPart: new Map(),\n validators: [],\n })\n }\n\n currentClassPartObject = currentClassPartObject.nextPart.get(pathPart)!\n })\n\n return currentClassPartObject\n}\n\nconst isThemeGetter = (func: ClassValidator | ThemeGetter): func is ThemeGetter =>\n (func as ThemeGetter).isThemeGetter\n","// packages/react/compose-refs/src/compose-refs.tsx\nimport * as React from \"react\";\nfunction setRef(ref, value) {\n if (typeof ref === \"function\") {\n return ref(value);\n } else if (ref !== null && ref !== void 0) {\n ref.current = value;\n }\n}\nfunction composeRefs(...refs) {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == \"function\") {\n hasCleanup = true;\n }\n return cleanup;\n });\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == \"function\") {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\nfunction useComposedRefs(...refs) {\n return React.useCallback(composeRefs(...refs), refs);\n}\nexport {\n composeRefs,\n useComposedRefs\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from 'react';\n\nexport const Logo = () => {\n const id = React.useId();\n return (\n <svg\n fill=\"none\"\n height=\"30\"\n viewBox=\"0 0 180 32\"\n width=\"180\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{ opacity: 0.9 }}\n >\n <g clipPath={`url(#${id})`}>\n <path\n clipRule=\"evenodd\"\n d=\"M24.4558 24.4853C25.2339 23.7073 25.3805 22.6549 25.2947 21.746C25.2078 20.8254 24.8697 19.8258 24.3896 18.8287C23.957 17.9302 23.3802 16.9745 22.6821 16C23.3802 15.0255 23.957 14.0698 24.3896 13.1713C24.8697 12.1742 25.2078 11.1746 25.2947 10.254C25.3805 9.34508 25.2339 8.29273 24.4558 7.51472C23.6778 6.73671 22.6255 6.59004 21.7165 6.67584C20.796 6.76273 19.7964 7.10086 18.7993 7.58094C17.9007 8.01357 16.945 8.59036 15.9706 9.28842C14.9961 8.59036 14.0404 8.01357 13.1418 7.58094C12.1447 7.10086 11.1451 6.76273 10.2246 6.67584C9.31564 6.59004 8.26329 6.73671 7.48528 7.51472C6.70727 8.29273 6.5606 9.34508 6.6464 10.254C6.7333 11.1746 7.07142 12.1742 7.5515 13.1713C7.98414 14.0698 8.56092 15.0255 9.25898 16C8.56092 16.9745 7.98414 17.9302 7.5515 18.8287C7.07142 19.8258 6.7333 20.8254 6.6464 21.746C6.5606 22.6549 6.70727 23.7073 7.48528 24.4853C8.26329 25.2633 9.31564 25.41 10.2246 25.3242C11.1451 25.2373 12.1447 24.8991 13.1418 24.4191C14.0404 23.9864 14.9961 23.4096 15.9706 22.7116C16.945 23.4096 17.9007 23.9864 18.7993 24.4191C19.7964 24.8991 20.796 25.2373 21.7165 25.3242C22.6255 25.41 23.6778 25.2633 24.4558 24.4853ZM15.9706 20.948C16.8399 20.2684 17.724 19.4874 18.591 18.6205C19.458 17.7535 20.239 16.8693 20.9186 16C20.239 15.1307 19.458 14.2465 18.591 13.3795C17.724 12.5126 16.8399 11.7316 15.9706 11.052C15.1012 11.7316 14.2171 12.5126 13.3501 13.3795C12.4831 14.2465 11.7021 15.1307 11.0225 16C11.7021 16.8693 12.4831 17.7535 13.3501 18.6205C14.2171 19.4874 15.1012 20.2684 15.9706 20.948ZM17.1498 21.8145C17.968 21.1558 18.7885 20.4195 19.5893 19.6187C20.39 18.818 21.1264 17.9974 21.7851 17.1792C23.7187 19.9919 24.4627 22.4819 23.4576 23.487C22.4524 24.4922 19.9625 23.7482 17.1498 21.8145ZM10.156 17.1792C10.8148 17.9974 11.5511 18.818 12.3518 19.6187C13.1526 20.4195 13.9731 21.1558 14.7914 21.8145C11.9786 23.7482 9.48871 24.4922 8.48355 23.487C7.47839 22.4819 8.22238 19.9919 10.156 17.1792ZM10.156 14.8208C10.8148 14.0026 11.5511 13.182 12.3518 12.3813C13.1526 11.5805 13.9731 10.8442 14.7914 10.1855C11.9786 8.25182 9.48871 7.50783 8.48355 8.51299C7.47839 9.51815 8.22238 12.0081 10.156 14.8208ZM17.1498 10.1855C17.968 10.8442 18.7885 11.5805 19.5893 12.3813C20.39 13.182 21.1264 14.0026 21.7851 14.8208C23.7187 12.0081 24.4627 9.51815 23.4576 8.51299C22.4524 7.50783 19.9625 8.25182 17.1498 10.1855Z\"\n fill=\"white\"\n fillRule=\"evenodd\"\n stroke=\"white\"\n strokeWidth=\"0.5\"\n />\n </g>\n <text\n x=\"36\"\n y=\"20\"\n fill=\"white\"\n fontSize=\"12\"\n fontFamily=\"system-ui, -apple-system, sans-serif\"\n fontWeight=\"500\"\n >\n React PDF Forge\n </text>\n <defs>\n <clipPath id={id}>\n <rect fill=\"white\" height=\"32\" rx=\"8\" width=\"32\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n","import { type ClassValue, clsx } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\n\nexport const cn = (...inputs: ClassValue[]) => {\n return twMerge(clsx(inputs));\n};\n","/**\n * Sanitizes text by replacing underscores and hyphens with spaces\n */\nexport const sanitize = (text: string): string => {\n return text.replace(/[_-]/g, ' ');\n};\n","import * as React from 'react';\nimport { composeRefs } from '@radix-ui/react-compose-refs';\n\n/* -------------------------------------------------------------------------------------------------\n * Slot\n * -----------------------------------------------------------------------------------------------*/\n\ninterface SlotProps extends React.HTMLAttributes<HTMLElement> {\n children?: React.ReactNode;\n}\n\n/* @__NO_SIDE_EFFECTS__ */ export function createSlot(ownerName: string) {\n const SlotClone = createSlotClone(ownerName);\n const Slot = React.forwardRef<HTMLElement, SlotProps>((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n\n if (slottable) {\n // the new element to render is the one passed as a child of `Slottable`\n const newElement = slottable.props.children;\n\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n // because the new element will be the one rendered, we are only interested\n // in grabbing its children (`newElement.props.children`)\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement)\n ? (newElement.props as { children: React.ReactNode }).children\n : null;\n } else {\n return child;\n }\n });\n\n return (\n <SlotClone {...slotProps} ref={forwardedRef}>\n {React.isValidElement(newElement)\n ? React.cloneElement(newElement, undefined, newChildren)\n : null}\n </SlotClone>\n );\n }\n\n return (\n <SlotClone {...slotProps} ref={forwardedRef}>\n {children}\n </SlotClone>\n );\n });\n\n Slot.displayName = `${ownerName}.Slot`;\n return Slot;\n}\n\nconst Slot = createSlot('Slot');\n\n/* -------------------------------------------------------------------------------------------------\n * SlotClone\n * -----------------------------------------------------------------------------------------------*/\n\ninterface SlotCloneProps {\n children: React.ReactNode;\n}\n\n/* @__NO_SIDE_EFFECTS__ */ function createSlotClone(ownerName: string) {\n const SlotClone = React.forwardRef<any, SlotCloneProps>((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props = mergeProps(slotProps, children.props as AnyProps);\n // do not pass ref to React.Fragment for React 19 compatibility\n if (children.type !== React.Fragment) {\n props.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props);\n }\n\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\n\n/* -------------------------------------------------------------------------------------------------\n * Slottable\n * -----------------------------------------------------------------------------------------------*/\n\nconst SLOTTABLE_IDENTIFIER = Symbol('radix.slottable');\n\ninterface SlottableProps {\n children: React.ReactNode;\n}\n\ninterface SlottableComponent extends React.FC<SlottableProps> {\n __radixId: symbol;\n}\n\n/* @__NO_SIDE_EFFECTS__ */ export function createSlottable(ownerName: string) {\n const Slottable: SlottableComponent = ({ children }) => {\n return <>{children}</>;\n };\n Slottable.displayName = `${ownerName}.Slottable`;\n Slottable.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable;\n}\n\nconst Slottable = createSlottable('Slottable');\n\n/* ---------------------------------------------------------------------------------------------- */\n\ntype AnyProps = Record<string, any>;\n\nfunction isSlottable(\n child: React.ReactNode\n): child is React.ReactElement<SlottableProps, typeof Slottable> {\n return (\n React.isValidElement(child) &&\n typeof child.type === 'function' &&\n '__radixId' in child.type &&\n child.type.__radixId === SLOTTABLE_IDENTIFIER\n );\n}\n\nfunction mergeProps(slotProps: AnyProps, childProps: AnyProps) {\n // all child props should override\n const overrideProps = { ...childProps };\n\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n // if the handler exists on both, we compose them\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args: unknown[]) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n }\n // but if it exists only on the slot, we use only this one\n else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n }\n // if it's `style`, we merge them\n else if (propName === 'style') {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === 'className') {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(' ');\n }\n }\n\n return { ...slotProps, ...overrideProps };\n}\n\n// Before React 19 accessing `element.props.ref` will throw a warning and suggest using `element.ref`\n// After React 19 accessing `element.ref` does the opposite.\n// https://github.com/facebook/react/pull/28348\n//\n// Access the ref using the method that doesn't yield a warning.\nfunction getElementRef(element: React.ReactElement) {\n // React <=18 in DEV\n let getter = Object.getOwnPropertyDescriptor(element.props, 'ref')?.get;\n let mayWarn = getter && 'isReactWarning' in getter && getter.isReactWarning;\n if (mayWarn) {\n return (element as any).ref;\n }\n\n // React 19 in DEV\n getter = Object.getOwnPropertyDescriptor(element, 'ref')?.get;\n mayWarn = getter && 'isReactWarning' in getter && getter.isReactWarning;\n if (mayWarn) {\n return (element.props as { ref?: React.Ref<unknown> }).ref;\n }\n\n // Not DEV\n return (element.props as { ref?: React.Ref<unknown> }).ref || (element as any).ref;\n}\n\nexport {\n Slot,\n Slottable,\n //\n Slot as Root,\n};\nexport type { SlotProps };\n","import * as SlotPrimitive from '@radix-ui/react-slot';\nimport * as React from 'react';\nimport { type As, cn, unreachable } from '../utils';\n\nexport type TextSize = '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9';\nexport type TextColor = 'gray' | 'white';\nexport type TextTransform = 'uppercase' | 'lowercase' | 'capitalize';\nexport type TextWeight = 'normal' | 'medium';\n\ninterface TextOwnProps {\n size?: TextSize;\n color?: TextColor;\n transform?: TextTransform;\n weight?: TextWeight;\n}\n\ntype TextProps = As<'span', 'div', 'p'> & TextOwnProps;\n\nexport const Text = React.forwardRef<HTMLSpanElement, Readonly<TextProps>>(\n (\n {\n as: Tag = 'span',\n size = '2',\n color = 'gray',\n transform,\n weight = 'normal',\n className,\n children,\n ...props\n },\n forwardedRef,\n ) => (\n <SlotPrimitive.Slot\n className={cn(\n className,\n transform,\n getSizesClassNames(size),\n getColorClassNames(color),\n getWeightClassNames(weight),\n )}\n ref={forwardedRef}\n {...props}\n >\n <Tag>{children}</Tag>\n </SlotPrimitive.Slot>\n ),\n);\n\nconst getSizesClassNames = (size: TextSize | undefined) => {\n switch (size) {\n case '1':\n return 'text-xs';\n case undefined:\n case '2':\n return 'text-sm';\n case '3':\n return 'text-base';\n case '4':\n return 'text-lg';\n case '5':\n return ['text-17px', 'md:text-xl tracking-[-0.16px]'];\n case '6':\n return 'text-2xl tracking-[-0.288px]';\n case '7':\n return 'text-[28px] leading-[34px] tracking-[-0.416px]';\n case '8':\n return 'text-[35px] leading-[42px] tracking-[-0.64px]';\n case '9':\n return 'text-6xl leading-[73px] tracking-[-0.896px]';\n default:\n return unreachable(size);\n }\n};\n\nconst getColorClassNames = (color: TextColor | undefined) => {\n switch (color) {\n case 'white':\n return 'text-slate-12';\n case undefined:\n case 'gray':\n return 'text-slate-11';\n default:\n return unreachable(color);\n }\n};\n\nconst getWeightClassNames = (weight: TextWeight | undefined) => {\n switch (weight) {\n case undefined:\n case 'normal':\n return 'font-normal';\n case 'medium':\n return 'font-medium';\n default:\n return unreachable(weight);\n }\n};\n\nText.displayName = 'Text';\n","import * as SlotPrimitive from '@radix-ui/react-slot';\nimport * as React from 'react';\nimport { type As, cn, unreachable } from '../utils';\n\nexport type HeadingSize =\n | '1'\n | '2'\n | '3'\n | '4'\n | '5'\n | '6'\n | '7'\n | '8'\n | '9'\n | '10';\nexport type HeadingColor = 'white' | 'gray';\nexport type HeadingWeight = 'medium' | 'bold';\n\ninterface HeadingOwnProps {\n size?: HeadingSize;\n color?: HeadingColor;\n weight?: HeadingWeight;\n}\n\ntype HeadingProps = As<'h1', 'h2', 'h3', 'h4', 'h5', 'h6'> & HeadingOwnProps;\n\nexport const Heading = React.forwardRef<\n HTMLHeadingElement,\n Readonly<HeadingProps>\n>(\n (\n {\n as: Tag = 'h1',\n size = '3',\n className,\n color = 'white',\n children,\n weight = 'bold',\n ...props\n },\n forwardedRef,\n ) => (\n <SlotPrimitive.Slot\n className={cn(\n className,\n getSizesClassNames(size),\n getColorClassNames(color),\n getWeightClassNames(weight),\n )}\n ref={forwardedRef}\n {...props}\n >\n <Tag>{children}</Tag>\n </SlotPrimitive.Slot>\n ),\n);\n\nconst getSizesClassNames = (size: HeadingSize | undefined) => {\n switch (size) {\n case '1':\n return 'text-xs';\n case '2':\n return 'text-sm';\n case undefined:\n case '3':\n return 'text-base';\n case '4':\n return 'text-lg';\n case '5':\n return 'text-xl tracking-[-0.16px]';\n case '6':\n return 'text-2xl tracking-[-0.288px]';\n case '7':\n return 'text-[28px] leading-[34px] tracking-[-0.416px]';\n case '8':\n return 'text-[35px] leading-[42px] tracking-[-0.64px]';\n case '9':\n return 'text-6xl leading-[73px] tracking-[-0.896px]';\n case '10':\n return [\n 'text-[38px] leading-[46px]',\n 'md:text-[70px] md:leading-[85px] tracking-[-1.024px;]',\n ];\n default:\n return unreachable(size);\n }\n};\n\nconst getColorClassNames = (color: HeadingColor | undefined) => {\n switch (color) {\n case 'gray':\n return 'text-slate-11';\n case 'white':\n case undefined:\n return 'text-slate-12';\n default:\n return unreachable(color);\n }\n};\n\nconst getWeightClassNames = (weight: HeadingWeight | undefined) => {\n switch (weight) {\n case 'medium':\n return 'font-medium';\n case 'bold':\n case undefined:\n return 'font-bold';\n default:\n return unreachable(weight);\n }\n};\n\nHeading.displayName = 'Heading';\n","import * as React from 'react';\n\ntype PossibleRef<T> = React.Ref<T> | undefined;\n\n/**\n * Set a given ref to a given value\n * This utility takes care of different types of refs: callback refs and RefObject(s)\n */\nfunction setRef<T>(ref: PossibleRef<T>, value: T) {\n if (typeof ref === 'function') {\n return ref(value);\n } else if (ref !== null && ref !== undefined) {\n ref.current = value;\n }\n}\n\n/**\n * A utility to compose multiple refs together\n * Accepts callback refs and RefObject(s)\n */\nfunction composeRefs<T>(...refs: PossibleRef<T>[]): React.RefCallback<T> {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == 'function') {\n hasCleanup = true;\n }\n return cleanup;\n });\n\n // React <19 will log an error to the console if a callback ref returns a\n // value. We don't use ref cleanups internally so this will only happen if a\n // user's ref callback returns a value, which we only expect if they are\n // using the cleanup functionality added in React 19.\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == 'function') {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\n\n/**\n * A custom hook that composes multiple refs\n * Accepts callback refs and RefObject(s)\n */\nfunction useComposedRefs<T>(...refs: PossibleRef<T>[]): React.RefCallback<T> {\n // eslint-disable-next-line react-hooks/exhaustive-deps\n return React.useCallback(composeRefs(...refs), refs);\n}\n\nexport { composeRefs, useComposedRefs };\n","// Export is needed because TypeScript complains about an error otherwise:\n// Error: …/tailwind-merge/src/config-utils.ts(8,17): semantic error TS4058: Return type of exported function has or is using name 'LruCache' from external module \"…/tailwind-merge/src/lru-cache\" but cannot be named.\nexport interface LruCache<Key, Value> {\n get(key: Key): Value | undefined\n set(key: Key, value: Value): void\n}\n\n// LRU cache inspired from hashlru (https://github.com/dominictarr/hashlru/blob/v1.0.4/index.js) but object replaced with Map to improve performance\nexport const createLruCache = <Key, Value>(maxCacheSize: number): LruCache<Key, Value> => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {},\n }\n }\n\n let cacheSize = 0\n let cache = new Map<Key, Value>()\n let previousCache = new Map<Key, Value>()\n\n const update = (key: Key, value: Value) => {\n cache.set(key, value)\n cacheSize++\n\n if (cacheSize > maxCacheSize) {\n cacheSize = 0\n previousCache = cache\n cache = new Map()\n }\n }\n\n return {\n get(key) {\n let value = cache.get(key)\n\n if (value !== undefined) {\n return value\n }\n if ((value = previousCache.get(key)) !== undefined) {\n update(key, value)\n return value\n }\n },\n set(key, value) {\n if (cache.has(key)) {\n cache.set(key, value)\n } else {\n update(key, value)\n }\n },\n }\n}\n","import { AnyConfig, ParsedClassName } from './types'\n\nexport const IMPORTANT_MODIFIER = '!'\nconst MODIFIER_SEPARATOR = ':'\nconst MODIFIER_SEPARATOR_LENGTH = MODIFIER_SEPARATOR.length\n\nexport const createParseClassName = (config: AnyConfig) => {\n const { prefix, experimentalParseClassName } = config\n\n /**\n * Parse class name into parts.\n *\n * Inspired by `splitAtTopLevelOnly` used in Tailwind CSS\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n */\n let parseClassName = (className: string): ParsedClassName => {\n const modifiers = []\n\n let bracketDepth = 0\n let parenDepth = 0\n let modifierStart = 0\n let postfixModifierPosition: number | undefined\n\n for (let index = 0; index < className.length; index++) {\n let currentCharacter = className[index]\n\n if (bracketDepth === 0 && parenDepth === 0) {\n if (currentCharacter === MODIFIER_SEPARATOR) {\n modifiers.push(className.slice(modifierStart, index))\n modifierStart = index + MODIFIER_SEPARATOR_LENGTH\n continue\n }\n\n if (currentCharacter === '/') {\n postfixModifierPosition = index\n continue\n }\n }\n\n if (currentCharacter === '[') {\n bracketDepth++\n } else if (currentCharacter === ']') {\n bracketDepth--\n } else if (currentCharacter === '(') {\n parenDepth++\n } else if (currentCharacter === ')') {\n parenDepth--\n }\n }\n\n const baseClassNameWithImportantModifier =\n modifiers.length === 0 ? className : className.substring(modifierStart)\n const baseClassName = stripImportantModifier(baseClassNameWithImportantModifier)\n const hasImportantModifier = baseClassName !== baseClassNameWithImportantModifier\n const maybePostfixModifierPosition =\n postfixModifierPosition && postfixModifierPosition > modifierStart\n ? postfixModifierPosition - modifierStart\n : undefined\n\n return {\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n }\n }\n\n if (prefix) {\n const fullPrefix = prefix + MODIFIER_SEPARATOR\n const parseClassNameOriginal = parseClassName\n parseClassName = (className) =>\n className.startsWith(fullPrefix)\n ? parseClassNameOriginal(className.substring(fullPrefix.length))\n : {\n isExternal: true,\n modifiers: [],\n hasImportantModifier: false,\n baseClassName: className,\n maybePostfixModifierPosition: undefined,\n }\n }\n\n if (experimentalParseClassName) {\n const parseClassNameOriginal = parseClassName\n parseClassName = (className) =>\n experimentalParseClassName({ className, parseClassName: parseClassNameOriginal })\n }\n\n return parseClassName\n}\n\nconst stripImportantModifier = (baseClassName: string) => {\n if (baseClassName.endsWith(IMPORTANT_MODIFIER)) {\n return baseClassName.substring(0, baseClassName.length - 1)\n }\n\n /**\n * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.\n * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864\n */\n if (baseClassName.startsWith(IMPORTANT_MODIFIER)) {\n return baseClassName.substring(1)\n }\n\n return baseClassName\n}\n","import { AnyConfig } from './types'\n\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nexport const createSortModifiers = (config: AnyConfig) => {\n const orderSensitiveModifiers = Object.fromEntries(\n config.orderSensitiveModifiers.map((modifier) => [modifier, true]),\n )\n\n const sortModifiers = (modifiers: string[]) => {\n if (modifiers.length <= 1) {\n return modifiers\n }\n\n const sortedModifiers: string[] = []\n let unsortedModifiers: string[] = []\n\n modifiers.forEach((modifier) => {\n const isPositionSensitive = modifier[0] === '[' || orderSensitiveModifiers[modifier]\n\n if (isPositionSensitive) {\n sortedModifiers.push(...unsortedModifiers.sort(), modifier)\n unsortedModifiers = []\n } else {\n unsortedModifiers.push(modifier)\n }\n })\n\n sortedModifiers.push(...unsortedModifiers.sort())\n\n return sortedModifiers\n }\n\n return sortModifiers\n}\n","import { createClassGroupUtils } from './class-group-utils'\nimport { createLruCache } from './lru-cache'\nimport { createParseClassName } from './parse-class-name'\nimport { createSortModifiers } from './sort-modifiers'\nimport { AnyConfig } from './types'\n\nexport type ConfigUtils = ReturnType<typeof createConfigUtils>\n\nexport const createConfigUtils = (config: AnyConfig) => ({\n cache: createLruCache<string, string>(config.cacheSize),\n parseClassName: createParseClassName(config),\n sortModifiers: createSortModifiers(config),\n ...createClassGroupUtils(config),\n})\n","import { ConfigUtils } from './config-utils'\nimport { IMPORTANT_MODIFIER } from './parse-class-name'\n\nconst SPLIT_CLASSES_REGEX = /\\s+/\n\nexport const mergeClassList = (classList: string, configUtils: ConfigUtils) => {\n const { parseClassName, getClassGroupId, getConflictingClassGroupIds, sortModifiers } =\n configUtils\n\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict: string[] = []\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX)\n\n let result = ''\n\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index]!\n\n const {\n isExternal,\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n } = parseClassName(originalClassName)\n\n if (isExternal) {\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n continue\n }\n\n let hasPostfixModifier = !!maybePostfixModifierPosition\n let classGroupId = getClassGroupId(\n hasPostfixModifier\n ? baseClassName.substring(0, maybePostfixModifierPosition)\n : baseClassName,\n )\n\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n continue\n }\n\n classGroupId = getClassGroupId(baseClassName)\n\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n continue\n }\n\n hasPostfixModifier = false\n }\n\n const variantModifier = sortModifiers(modifiers).join(':')\n\n const modifierId = hasImportantModifier\n ? variantModifier + IMPORTANT_MODIFIER\n : variantModifier\n\n const classId = modifierId + classGroupId\n\n if (classGroupsInConflict.includes(classId)) {\n // Tailwind class omitted due to conflict\n continue\n }\n\n classGroupsInConflict.push(classId)\n\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier)\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i]!\n classGroupsInConflict.push(modifierId + group)\n }\n\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result)\n }\n\n return result\n}\n","/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\n\nexport type ClassNameValue = ClassNameArray | string | null | undefined | 0 | 0n | false\ntype ClassNameArray = ClassNameValue[]\n\nexport function twJoin(...classLists: ClassNameValue[]): string\nexport function twJoin() {\n let index = 0\n let argument: ClassNameValue\n let resolvedValue: string\n let string = ''\n\n while (index < arguments.length) {\n if ((argument = arguments[index++])) {\n if ((resolvedValue = toValue(argument))) {\n string && (string += ' ')\n string += resolvedValue\n }\n }\n }\n return string\n}\n\nconst toValue = (mix: ClassNameArray | string) => {\n if (typeof mix === 'string') {\n return mix\n }\n\n let resolvedValue: string\n let string = ''\n\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if ((resolvedValue = toValue(mix[k] as ClassNameArray | string))) {\n string && (string += ' ')\n string += resolvedValue\n }\n }\n }\n\n return string\n}\n","import { createConfigUtils } from './config-utils'\nimport { mergeClassList } from './merge-classlist'\nimport { ClassNameValue, twJoin } from './tw-join'\nimport { AnyConfig } from './types'\n\ntype CreateConfigFirst = () => AnyConfig\ntype CreateConfigSubsequent = (config: AnyConfig) => AnyConfig\ntype TailwindMerge = (...classLists: ClassNameValue[]) => string\ntype ConfigUtils = ReturnType<typeof createConfigUtils>\n\nexport function createTailwindMerge(\n createConfigFirst: CreateConfigFirst,\n ...createConfigRest: CreateConfigSubsequent[]\n): TailwindMerge {\n let configUtils: ConfigUtils\n let cacheGet: ConfigUtils['cache']['get']\n let cacheSet: ConfigUtils['cache']['set']\n let functionToCall = initTailwindMerge\n\n function initTailwindMerge(classList: string) {\n const config = createConfigRest.reduce(\n (previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig),\n createConfigFirst() as AnyConfig,\n )\n\n configUtils = createConfigUtils(config)\n cacheGet = configUtils.cache.get\n cacheSet = configUtils.cache.set\n functionToCall = tailwindMerge\n\n return tailwindMerge(classList)\n }\n\n function tailwindMerge(classList: string) {\n const cachedResult = cacheGet(classList)\n\n if (cachedResult) {\n return cachedResult\n }\n\n const result = mergeClassList(classList, configUtils)\n cacheSet(classList, result)\n\n return result\n }\n\n return function callTailwindMerge() {\n return functionToCall(twJoin.apply(null, arguments as any))\n }\n}\n","import { DefaultThemeGroupIds, NoInfer, ThemeGetter, ThemeObject } from './types'\n\nexport const fromTheme = <\n AdditionalThemeGroupIds extends string = never,\n DefaultThemeGroupIdsInner extends string = DefaultThemeGroupIds,\n>(key: NoInfer<DefaultThemeGroupIdsInner | AdditionalThemeGroupIds>): ThemeGetter => {\n const themeGetter = (theme: ThemeObject<DefaultThemeGroupIdsInner | AdditionalThemeGroupIds>) =>\n theme[key] || []\n\n themeGetter.isThemeGetter = true as const\n\n return themeGetter\n}\n","const arbitraryValueRegex = /^\\[(?:(\\w[\\w-]*):)?(.+)\\]$/i\nconst arbitraryVariableRegex = /^\\((?:(\\w[\\w-]*):)?(.+)\\)$/i\nconst fractionRegex = /^\\d+\\/\\d+$/\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/\nconst lengthUnitRegex =\n /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch))\\(.+\\)$/\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/\nconst imageRegex =\n /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/\n\nexport const isFraction = (value: string) => fractionRegex.test(value)\n\nexport const isNumber = (value: string) => !!value && !Number.isNaN(Number(value))\n\nexport const isInteger = (value: string) => !!value && Number.isInteger(Number(value))\n\nexport const isPercent = (value: string) => value.endsWith('%') && isNumber(value.slice(0, -1))\n\nexport const isTshirtSize = (value: string) => tshirtUnitRegex.test(value)\n\nexport const isAny = () => true\n\nconst isLengthOnly = (value: string) =>\n // `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n // For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n // I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\n lengthUnitRegex.test(value) && !colorFunctionRegex.test(value)\n\nconst isNever = () => false\n\nconst isShadow = (value: string) => shadowRegex.test(value)\n\nconst isImage = (value: string) => imageRegex.test(value)\n\nexport const isAnyNonArbitrary = (value: string) =>\n !isArbitraryValue(value) && !isArbitraryVariable(value)\n\nexport const isArbitrarySize = (value: string) => getIsArbitraryValue(value, isLabelSize, isNever)\n\nexport const isArbitraryValue = (value: string) => arbitraryValueRegex.test(value)\n\nexport const isArbitraryLength = (value: string) =>\n getIsArbitraryValue(value, isLabelLength, isLengthOnly)\n\nexport const isArbitraryNumber = (value: string) =>\n getIsArbitraryValue(value, isLabelNumber, isNumber)\n\nexport const isArbitraryPosition = (value: string) =>\n getIsArbitraryValue(value, isLabelPosition, isNever)\n\nexport const isArbitraryImage = (value: string) => getIsArbitraryValue(value, isLabelImage, isImage)\n\nexport const isArbitraryShadow = (value: string) =>\n getIsArbitraryValue(value, isLabelShadow, isShadow)\n\nexport const isArbitraryVariable = (value: string) => arbitraryVariableRegex.test(value)\n\nexport const isArbitraryVariableLength = (value: string) =>\n getIsArbitraryVariable(value, isLabelLength)\n\nexport const isArbitraryVariableFamilyName = (value: string) =>\n getIsArbitraryVariable(value, isLabelFamilyName)\n\nexport const isArbitraryVariablePosition = (value: string) =>\n getIsArbitraryVariable(value, isLabelPosition)\n\nexport const isArbitraryVariableSize = (value: string) => getIsArbitraryVariable(value, isLabelSize)\n\nexport const isArbitraryVariableImage = (value: string) =>\n getIsArbitraryVariable(value, isLabelImage)\n\nexport const isArbitraryVariableShadow = (value: string) =>\n getIsArbitraryVariable(value, isLabelShadow, true)\n\n// Helpers\n\nconst getIsArbitraryValue = (\n value: string,\n testLabel: (label: string) => boolean,\n testValue: (value: string) => boolean,\n) => {\n const result = arbitraryValueRegex.exec(value)\n\n if (result) {\n if (result[1]) {\n return testLabel(result[1])\n }\n\n return testValue(result[2]!)\n }\n\n return false\n}\n\nconst getIsArbitraryVariable = (\n value: string,\n testLabel: (label: string) => boolean,\n shouldMatchNoLabel = false,\n) => {\n const result = arbitraryVariableRegex.exec(value)\n\n if (result) {\n if (result[1]) {\n return testLabel(result[1])\n }\n return shouldMatchNoLabel\n }\n\n return false\n}\n\n// Labels\n\nconst isLabelPosition = (label: string) => label === 'position' || label === 'percentage'\n\nconst isLabelImage = (label: string) => label === 'image' || label === 'url'\n\nconst isLabelSize = (label: string) => label === 'length' || label === 'size' || label === 'bg-size'\n\nconst isLabelLength = (label: string) => label === 'length'\n\nconst isLabelNumber = (label: string) => label === 'number'\n\nconst isLabelFamilyName = (label: string) => label === 'family-name'\n\nconst isLabelShadow = (label: string) => label === 'shadow'\n","import { fromTheme } from './from-theme'\nimport { Config, DefaultClassGroupIds, DefaultThemeGroupIds } from './types'\nimport {\n isAny,\n isAnyNonArbitrary,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isArbitraryVariable,\n isArbitraryVariableFamilyName,\n isArbitraryVariableImage,\n isArbitraryVariableLength,\n isArbitraryVariablePosition,\n isArbitraryVariableShadow,\n isArbitraryVariableSize,\n isFraction,\n isInteger,\n isNumber,\n isPercent,\n isTshirtSize,\n} from './validators'\n\nexport const getDefaultConfig = () => {\n /**\n * Theme getters for theme variable namespaces\n * @see https://tailwindcss.com/docs/theme#theme-variable-namespaces\n */\n /***/\n\n const themeColor = fromTheme('color')\n const themeFont = fromTheme('font')\n const themeText = fromTheme('text')\n const themeFontWeight = fromTheme('font-weight')\n const themeTracking = fromTheme('tracking')\n const themeLeading = fromTheme('leading')\n const themeBreakpoint = fromTheme('breakpoint')\n const themeContainer = fromTheme('container')\n const themeSpacing = fromTheme('spacing')\n const themeRadius = fromTheme('radius')\n const themeShadow = fromTheme('shadow')\n const themeInsetShadow = fromTheme('inset-shadow')\n const themeTextShadow = fromTheme('text-shadow')\n const themeDropShadow = fromTheme('drop-shadow')\n const themeBlur = fromTheme('blur')\n const themePerspective = fromTheme('perspective')\n const themeAspect = fromTheme('aspect')\n const themeEase = fromTheme('ease')\n const themeAnimate = fromTheme('animate')\n\n /**\n * Helpers to avoid repeating the same scales\n *\n * We use functions that create a new array every time they're called instead of static arrays.\n * This ensures that users who modify any scale by mutating the array (e.g. with `array.push(element)`) don't accidentally mutate arrays in other parts of the config.\n */\n /***/\n\n const scaleBreak = () =>\n ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'] as const\n const scalePosition = () =>\n [\n 'center',\n 'top',\n 'bottom',\n 'left',\n 'right',\n 'top-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-top',\n 'top-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-top',\n 'bottom-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-bottom',\n 'bottom-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-bottom',\n ] as const\n const scalePositionWithArbitrary = () =>\n [...scalePosition(), isArbitraryVariable, isArbitraryValue] as const\n const scaleOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'] as const\n const scaleOverscroll = () => ['auto', 'contain', 'none'] as const\n const scaleUnambiguousSpacing = () =>\n [isArbitraryVariable, isArbitraryValue, themeSpacing] as const\n const scaleInset = () => [isFraction, 'full', 'auto', ...scaleUnambiguousSpacing()] as const\n const scaleGridTemplateColsRows = () =>\n [isInteger, 'none', 'subgrid', isArbitraryVariable, isArbitraryValue] as const\n const scaleGridColRowStartAndEnd = () =>\n [\n 'auto',\n { span: ['full', isInteger, isArbitraryVariable, isArbitraryValue] },\n isInteger,\n isArbitraryVariable,\n isArbitraryValue,\n ] as const\n const scaleGridColRowStartOrEnd = () =>\n [isInteger, 'auto', isArbitraryVariable, isArbitraryValue] as const\n const scaleGridAutoColsRows = () =>\n ['auto', 'min', 'max', 'fr', isArbitraryVariable, isArbitraryValue] as const\n const scaleAlignPrimaryAxis = () =>\n [\n 'start',\n 'end',\n 'center',\n 'between',\n 'around',\n 'evenly',\n 'stretch',\n 'baseline',\n 'center-safe',\n 'end-safe',\n ] as const\n const scaleAlignSecondaryAxis = () =>\n ['start', 'end', 'center', 'stretch', 'center-safe', 'end-safe'] as const\n const scaleMargin = () => ['auto', ...scaleUnambiguousSpacing()] as const\n const scaleSizing = () =>\n [\n isFraction,\n 'auto',\n 'full',\n 'dvw',\n 'dvh',\n 'lvw',\n 'lvh',\n 'svw',\n 'svh',\n 'min',\n 'max',\n 'fit',\n ...scaleUnambiguousSpacing(),\n ] as const\n const scaleColor = () => [themeColor, isArbitraryVariable, isArbitraryValue] as const\n const scaleBgPosition = () =>\n [\n ...scalePosition(),\n isArbitraryVariablePosition,\n isArbitraryPosition,\n { position: [isArbitraryVariable, isArbitraryValue] },\n ] as const\n const scaleBgRepeat = () => ['no-repeat', { repeat: ['', 'x', 'y', 'space', 'round'] }] as const\n const scaleBgSize = () =>\n [\n 'auto',\n 'cover',\n 'contain',\n isArbitraryVariableSize,\n isArbitrarySize,\n { size: [isArbitraryVariable, isArbitraryValue] },\n ] as const\n const scaleGradientStopPosition = () =>\n [isPercent, isArbitraryVariableLength, isArbitraryLength] as const\n const scaleRadius = () =>\n [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n 'full',\n themeRadius,\n isArbitraryVariable,\n isArbitraryValue,\n ] as const\n const scaleBorderWidth = () =>\n ['', isNumber, isArbitraryVariableLength, isArbitraryLength] as const\n const scaleLineStyle = () => ['solid', 'dashed', 'dotted', 'double'] as const\n const scaleBlendMode = () =>\n [\n 'normal',\n 'multiply',\n 'screen',\n 'overlay',\n 'darken',\n 'lighten',\n 'color-dodge',\n 'color-burn',\n 'hard-light',\n 'soft-light',\n 'difference',\n 'exclusion',\n 'hue',\n 'saturation',\n 'color',\n 'luminosity',\n ] as const\n const scaleMaskImagePosition = () =>\n [isNumber, isPercent, isArbitraryVariablePosition, isArbitraryPosition] as const\n const scaleBlur = () =>\n [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n themeBlur,\n isArbitraryVariable,\n isArbitraryValue,\n ] as const\n const scaleRotate = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue] as const\n const scaleScale = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue] as const\n const scaleSkew = () => [isNumber, isArbitraryVariable, isArbitraryValue] as const\n const scaleTranslate = () => [isFraction, 'full', ...scaleUnambiguousSpacing()] as const\n\n return {\n cacheSize: 500,\n theme: {\n animate: ['spin', 'ping', 'pulse', 'bounce'],\n aspect: ['video'],\n blur: [isTshirtSize],\n breakpoint: [isTshirtSize],\n color: [isAny],\n container: [isTshirtSize],\n 'drop-shadow': [isTshirtSize],\n ease: ['in', 'out', 'in-out'],\n font: [isAnyNonArbitrary],\n 'font-weight': [\n 'thin',\n 'extralight',\n 'light',\n 'normal',\n 'medium',\n 'semibold',\n 'bold',\n 'extrabold',\n 'black',\n ],\n 'inset-shadow': [isTshirtSize],\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose'],\n perspective: ['dramatic', 'near', 'normal', 'midrange', 'distant', 'none'],\n radius: [isTshirtSize],\n shadow: [isTshirtSize],\n spacing: ['px', isNumber],\n text: [isTshirtSize],\n 'text-shadow': [isTshirtSize],\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest'],\n },\n classGroups: {\n // --------------\n // --- Layout ---\n // --------------\n\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [\n {\n aspect: [\n 'auto',\n 'square',\n isFraction,\n isArbitraryValue,\n isArbitraryVariable,\n themeAspect,\n ],\n },\n ],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n * @deprecated since Tailwind CSS v4.0.0\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [\n { columns: [isNumber, isArbitraryValue, isArbitraryVariable, themeContainer] },\n ],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{ 'break-after': scaleBreak() }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{ 'break-before': scaleBreak() }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{ 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column'] }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{ 'box-decoration': ['slice', 'clone'] }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{ box: ['border', 'content'] }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: [\n 'block',\n 'inline-block',\n 'inline',\n 'flex',\n 'inline-flex',\n 'table',\n 'inline-table',\n 'table-caption',\n 'table-cell',\n 'table-column',\n 'table-column-group',\n 'table-footer-group',\n 'table-header-group',\n 'table-row-group',\n 'table-row',\n 'flow-root',\n 'grid',\n 'inline-grid',\n 'contents',\n 'list-item',\n 'hidden',\n ],\n /**\n * Screen Reader Only\n * @see https://tailwindcss.com/docs/display#screen-reader-only\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{ float: ['right', 'left', 'none', 'start', 'end'] }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{ clear: ['left', 'right', 'both', 'none', 'start', 'end'] }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{ object: ['contain', 'cover', 'fill', 'none', 'scale-down'] }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{ object: scalePositionWithArbitrary() }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{ overflow: scaleOverflow() }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{ 'overflow-x': scaleOverflow() }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{ 'overflow-y': scaleOverflow() }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{ overscroll: scaleOverscroll() }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{ 'overscroll-x': scaleOverscroll() }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{ 'overscroll-y': scaleOverscroll() }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Top / Right / Bottom / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{ inset: scaleInset() }],\n /**\n * Right / Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{ 'inset-x': scaleInset() }],\n /**\n * Top / Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{ 'inset-y': scaleInset() }],\n /**\n * Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n start: [{ start: scaleInset() }],\n /**\n * End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n end: [{ end: scaleInset() }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{ top: scaleInset() }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{ right: scaleInset() }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{ bottom: scaleInset() }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{ left: scaleInset() }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{ z: [isInteger, 'auto', isArbitraryVariable, isArbitraryValue] }],\n\n // ------------------------\n // --- Flexbox and Grid ---\n // ------------------------\n\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [\n {\n basis: [\n isFraction,\n 'full',\n 'auto',\n themeContainer,\n ...scaleUnambiguousSpacing(),\n ],\n },\n ],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{ flex: ['row', 'row-reverse', 'col', 'col-reverse'] }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{ flex: ['nowrap', 'wrap', 'wrap-reverse'] }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{ flex: [isNumber, isFraction, 'auto', 'initial', 'none', isArbitraryValue] }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{ grow: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{ shrink: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [\n {\n order: [\n isInteger,\n 'first',\n 'last',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{ 'grid-cols': scaleGridTemplateColsRows() }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{ col: scaleGridColRowStartAndEnd() }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{ 'col-start': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{ 'col-end': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{ 'grid-rows': scaleGridTemplateColsRows() }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{ row: scaleGridColRowStartAndEnd() }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{ 'row-start': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{ 'row-end': scaleGridColRowStartOrEnd() }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{ 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense'] }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{ 'auto-cols': scaleGridAutoColsRows() }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{ 'auto-rows': scaleGridAutoColsRows() }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{ gap: scaleUnambiguousSpacing() }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{ 'gap-x': scaleUnambiguousSpacing() }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{ 'gap-y': scaleUnambiguousSpacing() }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{ justify: [...scaleAlignPrimaryAxis(), 'normal'] }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{ 'justify-items': [...scaleAlignSecondaryAxis(), 'normal'] }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{ 'justify-self': ['auto', ...scaleAlignSecondaryAxis()] }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{ content: ['normal', ...scaleAlignPrimaryAxis()] }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{ items: [...scaleAlignSecondaryAxis(), { baseline: ['', 'last'] }] }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [\n { self: ['auto', ...scaleAlignSecondaryAxis(), { baseline: ['', 'last'] }] },\n ],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{ 'place-content': scaleAlignPrimaryAxis() }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{ 'place-items': [...scaleAlignSecondaryAxis(), 'baseline'] }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{ 'place-self': ['auto', ...scaleAlignSecondaryAxis()] }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{ p: scaleUnambiguousSpacing() }],\n /**\n * Padding X\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{ px: scaleUnambiguousSpacing() }],\n /**\n * Padding Y\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{ py: scaleUnambiguousSpacing() }],\n /**\n * Padding Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{ ps: scaleUnambiguousSpacing() }],\n /**\n * Padding End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{ pe: scaleUnambiguousSpacing() }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{ pt: scaleUnambiguousSpacing() }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{ pr: scaleUnambiguousSpacing() }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{ pb: scaleUnambiguousSpacing() }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{ pl: scaleUnambiguousSpacing() }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{ m: scaleMargin() }],\n /**\n * Margin X\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{ mx: scaleMargin() }],\n /**\n * Margin Y\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{ my: scaleMargin() }],\n /**\n * Margin Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{ ms: scaleMargin() }],\n /**\n * Margin End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{ me: scaleMargin() }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{ mt: scaleMargin() }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{ mr: scaleMargin() }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{ mb: scaleMargin() }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{ ml: scaleMargin() }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x': [{ 'space-x': scaleUnambiguousSpacing() }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y': [{ 'space-y': scaleUnambiguousSpacing() }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y-reverse': ['space-y-reverse'],\n\n // --------------\n // --- Sizing ---\n // --------------\n\n /**\n * Size\n * @see https://tailwindcss.com/docs/width#setting-both-width-and-height\n */\n size: [{ size: scaleSizing() }],\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{ w: [themeContainer, 'screen', ...scaleSizing()] }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [\n {\n 'min-w': [\n themeContainer,\n 'screen',\n /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'none',\n ...scaleSizing(),\n ],\n },\n ],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [\n {\n 'max-w': [\n themeContainer,\n 'screen',\n 'none',\n /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'prose',\n /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n { screen: [themeBreakpoint] },\n ...scaleSizing(),\n ],\n },\n ],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{ h: ['screen', ...scaleSizing()] }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{ 'min-h': ['screen', 'none', ...scaleSizing()] }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{ 'max-h': ['screen', ...scaleSizing()] }],\n\n // ------------------\n // --- Typography ---\n // ------------------\n\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [\n { text: ['base', themeText, isArbitraryVariableLength, isArbitraryLength] },\n ],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [{ font: [themeFontWeight, isArbitraryVariable, isArbitraryNumber] }],\n /**\n * Font Stretch\n * @see https://tailwindcss.com/docs/font-stretch\n */\n 'font-stretch': [\n {\n 'font-stretch': [\n 'ultra-condensed',\n 'extra-condensed',\n 'condensed',\n 'semi-condensed',\n 'normal',\n 'semi-expanded',\n 'expanded',\n 'extra-expanded',\n 'ultra-expanded',\n isPercent,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [{ font: [isArbitraryVariableFamilyName, isArbitraryValue, themeFont] }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{ tracking: [themeTracking, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [\n { 'line-clamp': [isNumber, 'none', isArbitraryVariable, isArbitraryNumber] },\n ],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [\n {\n leading: [\n /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n themeLeading,\n ...scaleUnambiguousSpacing(),\n ],\n },\n ],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{ 'list-image': ['none', isArbitraryVariable, isArbitraryValue] }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{ list: ['inside', 'outside'] }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [\n { list: ['disc', 'decimal', 'none', isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{ text: ['left', 'center', 'right', 'justify', 'start', 'end'] }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://v3.tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{ placeholder: scaleColor() }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{ text: scaleColor() }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{ decoration: [...scaleLineStyle(), 'wavy'] }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [\n {\n decoration: [\n isNumber,\n 'from-font',\n 'auto',\n isArbitraryVariable,\n isArbitraryLength,\n ],\n },\n ],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{ decoration: scaleColor() }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [\n { 'underline-offset': [isNumber, 'auto', isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{ text: ['wrap', 'nowrap', 'balance', 'pretty'] }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{ indent: scaleUnambiguousSpacing() }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [\n {\n align: [\n 'baseline',\n 'top',\n 'middle',\n 'bottom',\n 'text-top',\n 'text-bottom',\n 'sub',\n 'super',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [\n { whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces'] },\n ],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{ break: ['normal', 'words', 'all', 'keep'] }],\n /**\n * Overflow Wrap\n * @see https://tailwindcss.com/docs/overflow-wrap\n */\n wrap: [{ wrap: ['break-word', 'anywhere', 'normal'] }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{ hyphens: ['none', 'manual', 'auto'] }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{ content: ['none', isArbitraryVariable, isArbitraryValue] }],\n\n // -------------------\n // --- Backgrounds ---\n // -------------------\n\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{ bg: ['fixed', 'local', 'scroll'] }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{ 'bg-clip': ['border', 'padding', 'content', 'text'] }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{ 'bg-origin': ['border', 'padding', 'content'] }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{ bg: scaleBgPosition() }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{ bg: scaleBgRepeat() }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{ bg: scaleBgSize() }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [\n {\n bg: [\n 'none',\n {\n linear: [\n { to: ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl'] },\n isInteger,\n isArbitraryVariable,\n isArbitraryValue,\n ],\n radial: ['', isArbitraryVariable, isArbitraryValue],\n conic: [isInteger, isArbitraryVariable, isArbitraryValue],\n },\n isArbitraryVariableImage,\n isArbitraryImage,\n ],\n },\n ],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{ bg: scaleColor() }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{ from: scaleGradientStopPosition() }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{ via: scaleGradientStopPosition() }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{ to: scaleGradientStopPosition() }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{ from: scaleColor() }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{ via: scaleColor() }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{ to: scaleColor() }],\n\n // ---------------\n // --- Borders ---\n // ---------------\n\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{ rounded: scaleRadius() }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{ 'rounded-s': scaleRadius() }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{ 'rounded-e': scaleRadius() }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{ 'rounded-t': scaleRadius() }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{ 'rounded-r': scaleRadius() }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{ 'rounded-b': scaleRadius() }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{ 'rounded-l': scaleRadius() }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{ 'rounded-ss': scaleRadius() }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{ 'rounded-se': scaleRadius() }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{ 'rounded-ee': scaleRadius() }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{ 'rounded-es': scaleRadius() }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{ 'rounded-tl': scaleRadius() }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{ 'rounded-tr': scaleRadius() }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{ 'rounded-br': scaleRadius() }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{ 'rounded-bl': scaleRadius() }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{ border: scaleBorderWidth() }],\n /**\n * Border Width X\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{ 'border-x': scaleBorderWidth() }],\n /**\n * Border Width Y\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{ 'border-y': scaleBorderWidth() }],\n /**\n * Border Width Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{ 'border-s': scaleBorderWidth() }],\n /**\n * Border Width End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{ 'border-e': scaleBorderWidth() }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{ 'border-t': scaleBorderWidth() }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{ 'border-r': scaleBorderWidth() }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{ 'border-b': scaleBorderWidth() }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{ 'border-l': scaleBorderWidth() }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x': [{ 'divide-x': scaleBorderWidth() }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y': [{ 'divide-y': scaleBorderWidth() }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{ border: [...scaleLineStyle(), 'hidden', 'none'] }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style\n */\n 'divide-style': [{ divide: [...scaleLineStyle(), 'hidden', 'none'] }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{ border: scaleColor() }],\n /**\n * Border Color X\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{ 'border-x': scaleColor() }],\n /**\n * Border Color Y\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{ 'border-y': scaleColor() }],\n /**\n * Border Color S\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{ 'border-s': scaleColor() }],\n /**\n * Border Color E\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{ 'border-e': scaleColor() }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{ 'border-t': scaleColor() }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{ 'border-r': scaleColor() }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{ 'border-b': scaleColor() }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{ 'border-l': scaleColor() }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{ divide: scaleColor() }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{ outline: [...scaleLineStyle(), 'none', 'hidden'] }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [\n { 'outline-offset': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [\n { outline: ['', isNumber, isArbitraryVariableLength, isArbitraryLength] },\n ],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{ outline: scaleColor() }],\n\n // ---------------\n // --- Effects ---\n // ---------------\n\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [\n {\n shadow: [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n themeShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color\n */\n 'shadow-color': [{ shadow: scaleColor() }],\n /**\n * Inset Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow\n */\n 'inset-shadow': [\n {\n 'inset-shadow': [\n 'none',\n themeInsetShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Inset Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color\n */\n 'inset-shadow-color': [{ 'inset-shadow': scaleColor() }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring\n */\n 'ring-w': [{ ring: scaleBorderWidth() }],\n /**\n * Ring Width Inset\n * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color\n */\n 'ring-color': [{ ring: scaleColor() }],\n /**\n * Ring Offset Width\n * @see https://v3.tailwindcss.com/docs/ring-offset-width\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-w': [{ 'ring-offset': [isNumber, isArbitraryLength] }],\n /**\n * Ring Offset Color\n * @see https://v3.tailwindcss.com/docs/ring-offset-color\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-color': [{ 'ring-offset': scaleColor() }],\n /**\n * Inset Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring\n */\n 'inset-ring-w': [{ 'inset-ring': scaleBorderWidth() }],\n /**\n * Inset Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color\n */\n 'inset-ring-color': [{ 'inset-ring': scaleColor() }],\n /**\n * Text Shadow\n * @see https://tailwindcss.com/docs/text-shadow\n */\n 'text-shadow': [\n {\n 'text-shadow': [\n 'none',\n themeTextShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Text Shadow Color\n * @see https://tailwindcss.com/docs/text-shadow#setting-the-shadow-color\n */\n 'text-shadow-color': [{ 'text-shadow': scaleColor() }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{ opacity: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{ 'mix-blend': [...scaleBlendMode(), 'plus-darker', 'plus-lighter'] }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{ 'bg-blend': scaleBlendMode() }],\n /**\n * Mask Clip\n * @see https://tailwindcss.com/docs/mask-clip\n */\n 'mask-clip': [\n { 'mask-clip': ['border', 'padding', 'content', 'fill', 'stroke', 'view'] },\n 'mask-no-clip',\n ],\n /**\n * Mask Composite\n * @see https://tailwindcss.com/docs/mask-composite\n */\n 'mask-composite': [{ mask: ['add', 'subtract', 'intersect', 'exclude'] }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image-linear-pos': [{ 'mask-linear': [isNumber] }],\n 'mask-image-linear-from-pos': [{ 'mask-linear-from': scaleMaskImagePosition() }],\n 'mask-image-linear-to-pos': [{ 'mask-linear-to': scaleMaskImagePosition() }],\n 'mask-image-linear-from-color': [{ 'mask-linear-from': scaleColor() }],\n 'mask-image-linear-to-color': [{ 'mask-linear-to': scaleColor() }],\n 'mask-image-t-from-pos': [{ 'mask-t-from': scaleMaskImagePosition() }],\n 'mask-image-t-to-pos': [{ 'mask-t-to': scaleMaskImagePosition() }],\n 'mask-image-t-from-color': [{ 'mask-t-from': scaleColor() }],\n 'mask-image-t-to-color': [{ 'mask-t-to': scaleColor() }],\n 'mask-image-r-from-pos': [{ 'mask-r-from': scaleMaskImagePosition() }],\n 'mask-image-r-to-pos': [{ 'mask-r-to': scaleMaskImagePosition() }],\n 'mask-image-r-from-color': [{ 'mask-r-from': scaleColor() }],\n 'mask-image-r-to-color': [{ 'mask-r-to': scaleColor() }],\n 'mask-image-b-from-pos': [{ 'mask-b-from': scaleMaskImagePosition() }],\n 'mask-image-b-to-pos': [{ 'mask-b-to': scaleMaskImagePosition() }],\n 'mask-image-b-from-color': [{ 'mask-b-from': scaleColor() }],\n 'mask-image-b-to-color': [{ 'mask-b-to': scaleColor() }],\n 'mask-image-l-from-pos': [{ 'mask-l-from': scaleMaskImagePosition() }],\n 'mask-image-l-to-pos': [{ 'mask-l-to': scaleMaskImagePosition() }],\n 'mask-image-l-from-color': [{ 'mask-l-from': scaleColor() }],\n 'mask-image-l-to-color': [{ 'mask-l-to': scaleColor() }],\n 'mask-image-x-from-pos': [{ 'mask-x-from': scaleMaskImagePosition() }],\n 'mask-image-x-to-pos': [{ 'mask-x-to': scaleMaskImagePosition() }],\n 'mask-image-x-from-color': [{ 'mask-x-from': scaleColor() }],\n 'mask-image-x-to-color': [{ 'mask-x-to': scaleColor() }],\n 'mask-image-y-from-pos': [{ 'mask-y-from': scaleMaskImagePosition() }],\n 'mask-image-y-to-pos': [{ 'mask-y-to': scaleMaskImagePosition() }],\n 'mask-image-y-from-color': [{ 'mask-y-from': scaleColor() }],\n 'mask-image-y-to-color': [{ 'mask-y-to': scaleColor() }],\n 'mask-image-radial': [{ 'mask-radial': [isArbitraryVariable, isArbitraryValue] }],\n 'mask-image-radial-from-pos': [{ 'mask-radial-from': scaleMaskImagePosition() }],\n 'mask-image-radial-to-pos': [{ 'mask-radial-to': scaleMaskImagePosition() }],\n 'mask-image-radial-from-color': [{ 'mask-radial-from': scaleColor() }],\n 'mask-image-radial-to-color': [{ 'mask-radial-to': scaleColor() }],\n 'mask-image-radial-shape': [{ 'mask-radial': ['circle', 'ellipse'] }],\n 'mask-image-radial-size': [\n { 'mask-radial': [{ closest: ['side', 'corner'], farthest: ['side', 'corner'] }] },\n ],\n 'mask-image-radial-pos': [{ 'mask-radial-at': scalePosition() }],\n 'mask-image-conic-pos': [{ 'mask-conic': [isNumber] }],\n 'mask-image-conic-from-pos': [{ 'mask-conic-from': scaleMaskImagePosition() }],\n 'mask-image-conic-to-pos': [{ 'mask-conic-to': scaleMaskImagePosition() }],\n 'mask-image-conic-from-color': [{ 'mask-conic-from': scaleColor() }],\n 'mask-image-conic-to-color': [{ 'mask-conic-to': scaleColor() }],\n /**\n * Mask Mode\n * @see https://tailwindcss.com/docs/mask-mode\n */\n 'mask-mode': [{ mask: ['alpha', 'luminance', 'match'] }],\n /**\n * Mask Origin\n * @see https://tailwindcss.com/docs/mask-origin\n */\n 'mask-origin': [\n { 'mask-origin': ['border', 'padding', 'content', 'fill', 'stroke', 'view'] },\n ],\n /**\n * Mask Position\n * @see https://tailwindcss.com/docs/mask-position\n */\n 'mask-position': [{ mask: scaleBgPosition() }],\n /**\n * Mask Repeat\n * @see https://tailwindcss.com/docs/mask-repeat\n */\n 'mask-repeat': [{ mask: scaleBgRepeat() }],\n /**\n * Mask Size\n * @see https://tailwindcss.com/docs/mask-size\n */\n 'mask-size': [{ mask: scaleBgSize() }],\n /**\n * Mask Type\n * @see https://tailwindcss.com/docs/mask-type\n */\n 'mask-type': [{ 'mask-type': ['alpha', 'luminance'] }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image': [{ mask: ['none', isArbitraryVariable, isArbitraryValue] }],\n\n // ---------------\n // --- Filters ---\n // ---------------\n\n /**\n * Filter\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [\n {\n filter: [\n // Deprecated since Tailwind CSS v3.0.0\n '',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{ blur: scaleBlur() }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{ brightness: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{ contrast: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [\n {\n 'drop-shadow': [\n // Deprecated since Tailwind CSS v4.0.0\n '',\n 'none',\n themeDropShadow,\n isArbitraryVariableShadow,\n isArbitraryShadow,\n ],\n },\n ],\n /**\n * Drop Shadow Color\n * @see https://tailwindcss.com/docs/filter-drop-shadow#setting-the-shadow-color\n */\n 'drop-shadow-color': [{ 'drop-shadow': scaleColor() }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{ grayscale: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{ 'hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{ invert: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{ saturate: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{ sepia: ['', isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Backdrop Filter\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [\n {\n 'backdrop-filter': [\n // Deprecated since Tailwind CSS v3.0.0\n '',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{ 'backdrop-blur': scaleBlur() }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [\n { 'backdrop-brightness': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [\n { 'backdrop-contrast': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [\n { 'backdrop-grayscale': ['', isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [\n { 'backdrop-hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [\n { 'backdrop-invert': ['', isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [\n { 'backdrop-opacity': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [\n { 'backdrop-saturate': [isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [\n { 'backdrop-sepia': ['', isNumber, isArbitraryVariable, isArbitraryValue] },\n ],\n\n // --------------\n // --- Tables ---\n // --------------\n\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{ border: ['collapse', 'separate'] }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{ 'border-spacing': scaleUnambiguousSpacing() }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{ 'border-spacing-x': scaleUnambiguousSpacing() }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{ 'border-spacing-y': scaleUnambiguousSpacing() }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{ table: ['auto', 'fixed'] }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{ caption: ['top', 'bottom'] }],\n\n // ---------------------------------\n // --- Transitions and Animation ---\n // ---------------------------------\n\n /**\n * Transition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [\n {\n transition: [\n '',\n 'all',\n 'colors',\n 'opacity',\n 'shadow',\n 'transform',\n 'none',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Transition Behavior\n * @see https://tailwindcss.com/docs/transition-behavior\n */\n 'transition-behavior': [{ transition: ['normal', 'discrete'] }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{ duration: [isNumber, 'initial', isArbitraryVariable, isArbitraryValue] }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [\n { ease: ['linear', 'initial', themeEase, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{ delay: [isNumber, isArbitraryVariable, isArbitraryValue] }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{ animate: ['none', themeAnimate, isArbitraryVariable, isArbitraryValue] }],\n\n // ------------------\n // --- Transforms ---\n // ------------------\n\n /**\n * Backface Visibility\n * @see https://tailwindcss.com/docs/backface-visibility\n */\n backface: [{ backface: ['hidden', 'visible'] }],\n /**\n * Perspective\n * @see https://tailwindcss.com/docs/perspective\n */\n perspective: [\n { perspective: [themePerspective, isArbitraryVariable, isArbitraryValue] },\n ],\n /**\n * Perspective Origin\n * @see https://tailwindcss.com/docs/perspective-origin\n */\n 'perspective-origin': [{ 'perspective-origin': scalePositionWithArbitrary() }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{ rotate: scaleRotate() }],\n /**\n * Rotate X\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-x': [{ 'rotate-x': scaleRotate() }],\n /**\n * Rotate Y\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-y': [{ 'rotate-y': scaleRotate() }],\n /**\n * Rotate Z\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-z': [{ 'rotate-z': scaleRotate() }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{ scale: scaleScale() }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{ 'scale-x': scaleScale() }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{ 'scale-y': scaleScale() }],\n /**\n * Scale Z\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-z': [{ 'scale-z': scaleScale() }],\n /**\n * Scale 3D\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-3d': ['scale-3d'],\n /**\n * Skew\n * @see https://tailwindcss.com/docs/skew\n */\n skew: [{ skew: scaleSkew() }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{ 'skew-x': scaleSkew() }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{ 'skew-y': scaleSkew() }],\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [\n { transform: [isArbitraryVariable, isArbitraryValue, '', 'none', 'gpu', 'cpu'] },\n ],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{ origin: scalePositionWithArbitrary() }],\n /**\n * Transform Style\n * @see https://tailwindcss.com/docs/transform-style\n */\n 'transform-style': [{ transform: ['3d', 'flat'] }],\n /**\n * Translate\n * @see https://tailwindcss.com/docs/translate\n */\n translate: [{ translate: scaleTranslate() }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{ 'translate-x': scaleTranslate() }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{ 'translate-y': scaleTranslate() }],\n /**\n * Translate Z\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-z': [{ 'translate-z': scaleTranslate() }],\n /**\n * Translate None\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-none': ['translate-none'],\n\n // ---------------------\n // --- Interactivity ---\n // ---------------------\n\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{ accent: scaleColor() }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{ appearance: ['none', 'auto'] }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{ caret: scaleColor() }],\n /**\n * Color Scheme\n * @see https://tailwindcss.com/docs/color-scheme\n */\n 'color-scheme': [\n { scheme: ['normal', 'dark', 'light', 'light-dark', 'only-dark', 'only-light'] },\n ],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [\n {\n cursor: [\n 'auto',\n 'default',\n 'pointer',\n 'wait',\n 'text',\n 'move',\n 'help',\n 'not-allowed',\n 'none',\n 'context-menu',\n 'progress',\n 'cell',\n 'crosshair',\n 'vertical-text',\n 'alias',\n 'copy',\n 'no-drop',\n 'grab',\n 'grabbing',\n 'all-scroll',\n 'col-resize',\n 'row-resize',\n 'n-resize',\n 'e-resize',\n 's-resize',\n 'w-resize',\n 'ne-resize',\n 'nw-resize',\n 'se-resize',\n 'sw-resize',\n 'ew-resize',\n 'ns-resize',\n 'nesw-resize',\n 'nwse-resize',\n 'zoom-in',\n 'zoom-out',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n /**\n * Field Sizing\n * @see https://tailwindcss.com/docs/field-sizing\n */\n 'field-sizing': [{ 'field-sizing': ['fixed', 'content'] }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{ 'pointer-events': ['auto', 'none'] }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{ resize: ['none', '', 'y', 'x'] }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{ scroll: ['auto', 'smooth'] }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{ 'scroll-m': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin X\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{ 'scroll-mx': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Y\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{ 'scroll-my': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{ 'scroll-ms': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{ 'scroll-me': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{ 'scroll-mt': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{ 'scroll-mr': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{ 'scroll-mb': scaleUnambiguousSpacing() }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{ 'scroll-ml': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{ 'scroll-p': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding X\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{ 'scroll-px': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Y\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{ 'scroll-py': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{ 'scroll-ps': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{ 'scroll-pe': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{ 'scroll-pt': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{ 'scroll-pr': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{ 'scroll-pb': scaleUnambiguousSpacing() }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{ 'scroll-pl': scaleUnambiguousSpacing() }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{ snap: ['start', 'end', 'center', 'align-none'] }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{ snap: ['normal', 'always'] }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{ snap: ['none', 'x', 'y', 'both'] }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{ snap: ['mandatory', 'proximity'] }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{ touch: ['auto', 'none', 'manipulation'] }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{ 'touch-pan': ['x', 'left', 'right'] }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{ 'touch-pan': ['y', 'up', 'down'] }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{ select: ['none', 'text', 'all', 'auto'] }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [\n {\n 'will-change': [\n 'auto',\n 'scroll',\n 'contents',\n 'transform',\n isArbitraryVariable,\n isArbitraryValue,\n ],\n },\n ],\n\n // -----------\n // --- SVG ---\n // -----------\n\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{ fill: ['none', ...scaleColor()] }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [\n {\n stroke: [\n isNumber,\n isArbitraryVariableLength,\n isArbitraryLength,\n isArbitraryNumber,\n ],\n },\n ],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{ stroke: ['none', ...scaleColor()] }],\n\n // ---------------------\n // --- Accessibility ---\n // ---------------------\n\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{ 'forced-color-adjust': ['auto', 'none'] }],\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: ['inset-x', 'inset-y', 'start', 'end', 'top', 'right', 'bottom', 'left'],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': [\n 'fvn-ordinal',\n 'fvn-slashed-zero',\n 'fvn-figure',\n 'fvn-spacing',\n 'fvn-fraction',\n ],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: [\n 'rounded-s',\n 'rounded-e',\n 'rounded-t',\n 'rounded-r',\n 'rounded-b',\n 'rounded-l',\n 'rounded-ss',\n 'rounded-se',\n 'rounded-ee',\n 'rounded-es',\n 'rounded-tl',\n 'rounded-tr',\n 'rounded-br',\n 'rounded-bl',\n ],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': [\n 'border-w-x',\n 'border-w-y',\n 'border-w-s',\n 'border-w-e',\n 'border-w-t',\n 'border-w-r',\n 'border-w-b',\n 'border-w-l',\n ],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': [\n 'border-color-x',\n 'border-color-y',\n 'border-color-s',\n 'border-color-e',\n 'border-color-t',\n 'border-color-r',\n 'border-color-b',\n 'border-color-l',\n ],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n translate: ['translate-x', 'translate-y', 'translate-none'],\n 'translate-none': ['translate', 'translate-x', 'translate-y', 'translate-z'],\n 'scroll-m': [\n 'scroll-mx',\n 'scroll-my',\n 'scroll-ms',\n 'scroll-me',\n 'scroll-mt',\n 'scroll-mr',\n 'scroll-mb',\n 'scroll-ml',\n ],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': [\n 'scroll-px',\n 'scroll-py',\n 'scroll-ps',\n 'scroll-pe',\n 'scroll-pt',\n 'scroll-pr',\n 'scroll-pb',\n 'scroll-pl',\n ],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch'],\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading'],\n },\n orderSensitiveModifiers: [\n '*',\n '**',\n 'after',\n 'backdrop',\n 'before',\n 'details-content',\n 'file',\n 'first-letter',\n 'first-line',\n 'marker',\n 'placeholder',\n 'selection',\n ],\n } as const satisfies Config<DefaultClassGroupIds, DefaultThemeGroupIds>\n}\n","import { AnyConfig, ConfigExtension, NoInfer } from './types'\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nexport const mergeConfigs = <ClassGroupIds extends string, ThemeGroupIds extends string = never>(\n baseConfig: AnyConfig,\n {\n cacheSize,\n prefix,\n experimentalParseClassName,\n extend = {},\n override = {},\n }: ConfigExtension<ClassGroupIds, ThemeGroupIds>,\n) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize)\n overrideProperty(baseConfig, 'prefix', prefix)\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName)\n\n overrideConfigProperties(baseConfig.theme, override.theme)\n overrideConfigProperties(baseConfig.classGroups, override.classGroups)\n overrideConfigProperties(baseConfig.conflictingClassGroups, override.conflictingClassGroups)\n overrideConfigProperties(\n baseConfig.conflictingClassGroupModifiers,\n override.conflictingClassGroupModifiers,\n )\n overrideProperty(baseConfig, 'orderSensitiveModifiers', override.orderSensitiveModifiers)\n\n mergeConfigProperties(baseConfig.theme, extend.theme)\n mergeConfigProperties(baseConfig.classGroups, extend.classGroups)\n mergeConfigProperties(baseConfig.conflictingClassGroups, extend.conflictingClassGroups)\n mergeConfigProperties(\n baseConfig.conflictingClassGroupModifiers,\n extend.conflictingClassGroupModifiers,\n )\n mergeArrayProperties(baseConfig, extend, 'orderSensitiveModifiers')\n\n return baseConfig\n}\n\nconst overrideProperty = <T extends object, K extends keyof T>(\n baseObject: T,\n overrideKey: K,\n overrideValue: T[K] | undefined,\n) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue\n }\n}\n\nconst overrideConfigProperties = (\n baseObject: Partial<Record<string, readonly unknown[]>>,\n overrideObject: Partial<Record<string, readonly unknown[]>> | undefined,\n) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key])\n }\n }\n}\n\nconst mergeConfigProperties = (\n baseObject: Partial<Record<string, readonly unknown[]>>,\n mergeObject: Partial<Record<string, readonly unknown[]>> | undefined,\n) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n mergeArrayProperties(baseObject, mergeObject, key)\n }\n }\n}\n\nconst mergeArrayProperties = <Key extends string>(\n baseObject: Partial<Record<NoInfer<Key>, readonly unknown[]>>,\n mergeObject: Partial<Record<NoInfer<Key>, readonly unknown[]>>,\n key: Key,\n) => {\n const mergeValue = mergeObject[key]\n\n if (mergeValue !== undefined) {\n baseObject[key] = baseObject[key] ? baseObject[key].concat(mergeValue) : mergeValue\n }\n}\n","import { createTailwindMerge } from './create-tailwind-merge'\nimport { getDefaultConfig } from './default-config'\nimport { mergeConfigs } from './merge-configs'\nimport { AnyConfig, ConfigExtension, DefaultClassGroupIds, DefaultThemeGroupIds } from './types'\n\ntype CreateConfigSubsequent = (config: AnyConfig) => AnyConfig\n\nexport const extendTailwindMerge = <\n AdditionalClassGroupIds extends string = never,\n AdditionalThemeGroupIds extends string = never,\n>(\n configExtension:\n | ConfigExtension<\n DefaultClassGroupIds | AdditionalClassGroupIds,\n DefaultThemeGroupIds | AdditionalThemeGroupIds\n >\n | CreateConfigSubsequent,\n ...createConfig: CreateConfigSubsequent[]\n) =>\n typeof configExtension === 'function'\n ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig)\n : createTailwindMerge(\n () => mergeConfigs(getDefaultConfig(), configExtension),\n ...createConfig,\n )\n","import { createTailwindMerge } from './create-tailwind-merge'\nimport { getDefaultConfig } from './default-config'\n\nexport const twMerge = createTailwindMerge(getDefaultConfig)\n"],"names":["warnOnce","_","process","env","NODE_ENV","warnings","Set","msg","has","console","warn","add","getDeploymentId","getDeploymentIdQueryOrEmptyString","NEXT_DEPLOYMENT_ID","deploymentId","getImageBlurSvg","widthInt","heightInt","blurWidth","blurHeight","blurDataURL","objectFit","std","svgWidth","svgHeight","viewBox","preserveAspectRatio","VALID_LOADERS","imageConfigDefault","deviceSizes","imageSizes","path","loader","loaderFile","domains","disableStaticImages","minimumCacheTTL","formats","maximumRedirects","dangerouslyAllowLocalIP","dangerouslyAllowSVG","contentSecurityPolicy","contentDispositionType","localPatterns","undefined","remotePatterns","qualities","unoptimized","getImgProps","VALID_LOADING_VALUES","INVALID_BACKGROUND_SIZE_VALUES","isStaticRequire","src","default","isStaticImageData","isStaticImport","allImgs","Map","perfObserver","getInt","x","Number","isFinite","NaN","test","parseInt","getWidths","allSizes","width","sizes","viewportWidthRe","percentSizes","match","exec","push","length","smallestRatio","Math","min","widths","filter","s","kind","map","w","find","p","generateImgAttrs","config","quality","startsWith","sep","includes","srcSet","last","i","join","priority","preload","loading","className","height","fill","style","overrideSrc","onLoad","onLoadingComplete","placeholder","fetchPriority","decoding","layout","objectPosition","lazyBoundary","lazyRoot","rest","_state","imgConf","showAltText","blurComplete","defaultLoader","c","sort","a","b","Error","isDefaultLoader","customImageLoader","obj","opts","layoutToStyle","intrinsic","maxWidth","responsive","layoutToSizes","layoutStyle","layoutSizes","staticSrc","staticImageData","JSON","stringify","ratio","round","isLazy","split","endsWith","qualityInt","output","position","isNaN","String","VALID_BLUR_EXT","urlStr","url","URL","err","pathname","search","legacyKey","legacyValue","Object","entries","window","PerformanceObserver","entryList","entry","getEntries","imgSrc","element","lcpImage","get","observe","type","buffered","error","imgStyle","assign","left","top","right","bottom","color","backgroundImage","backgroundSize","placeholderStyle","backgroundPosition","backgroundRepeat","imgAttributes","loadingFinal","fullUrl","e","location","href","set","props","meta","Image","configEnv","__NEXT_IMAGE_OPTS","globalThis","__NEXT_IMAGE_IMPORTED","handleLoading","img","onLoadRef","onLoadingCompleteRef","setBlurComplete","sizesInput","decode","Promise","resolve","catch","then","parentElement","isConnected","current","event","Event","defineProperty","writable","value","prevented","stopped","nativeEvent","currentTarget","target","isDefaultPrevented","isPropagationStopped","persist","preventDefault","stopPropagation","origSrc","searchParams","getAttribute","widthViewportRatio","getBoundingClientRect","innerWidth","getComputedStyle","valid","heightModified","toString","widthModified","getDynamicProps","Boolean","use","fetchpriority","ImageElement","forwardRef","setShowAltText","onError","forwardedRef","ownRef","useCallback","complete","ref","useMergedRef","data-nimg","ImagePreload","isAppRouter","as","imageSrcSet","crossOrigin","referrerPolicy","ReactDOM","Head","link","rel","pagesRouter","useContext","RouterContext","configContext","ImageConfigContext","useMemo","useRef","useEffect","useState","imgMeta","findClosestQuality","q","reduce","prev","cur","abs","missingValues","NEXT_RUNTIME","hasLocalMatch","require","parsedSrc","hasRemoteMatch","hostname","encodeURIComponent","__next_img_default","getImageProps","imgProps","key","LinkComponent","useLinkStatus","isModifiedEvent","eventTarget","metaKey","ctrlKey","shiftKey","altKey","which","linkClicked","linkInstanceRef","replace","scroll","onNavigate","nodeName","isAnchorNodeName","toUpperCase","hasAttribute","isLocalURL","dispatchNavigateAction","React","startTransition","formatStringOrUrl","urlObjOrString","formatUrl","linkStatus","setOptimisticLinkStatus","useOptimistic","IDLE_LINK_STATUS","children","hrefProp","asProp","childrenProp","prefetch","prefetchProp","passHref","shallow","onClick","onMouseEnter","onMouseEnterProp","onTouchStart","onTouchStartProp","legacyBehavior","unstable_dynamicOnHover","restProps","router","AppRouterContext","prefetchEnabled","fetchStrategy","getFetchStrategyFromPrefetchProp","FetchStrategy","PPR","createPropError","args","expected","actual","requiredPropsGuard","requiredProps","keys","forEach","optionalPropsGuard","optionalProps","valType","locale","hasDynamicSegment","some","segment","resolvedHref","child","$$typeof","Symbol","for","Children","only","childRef","observeLinkVisibilityOnMount","mountLinkInstance","unmountLinkForCurrentNavigation","unmountPrefetchableInstance","mergedRef","childProps","defaultPrevented","upgradeToDynamicPrefetch","onNavigationIntent","__NEXT_LINK_NO_TOUCH_START","isAbsoluteUrl","addBasePath","errorOnce","cloneElement","LinkStatusContext","Provider","createContext","__NEXT_CACHE_COMPONENTS","Full","isLegacyBehavior","childIsHostComponent","childIsClientComponent","ClientLinkComponent","classMap","createClassMap","CLASS_PART_SEPARATOR","classParts","shift","getGroupRecursive","getGroupIdForArbitraryProperty","getConflictingClassGroupIds","classGroupId","hasPostfixModifier","conflicts","conflictingClassGroups","conflictingClassGroupModifiers","getClassGroupId","classPartObject","nextClassPartObject","nextPart","currentClassPart","classGroupFromNextClassPart","slice","validators","classRest","validator","arbitraryPropertyRegex","arbitraryPropertyClassName","property","substring","indexOf","classGroups","processClassesRecursively","theme","classGroup","classDefinition","classPartObjectToEdit","getPart","isThemeGetter","currentClassPartObject","pathPart","func","createLruCache","maxCacheSize","cacheSize","cache","previousCache","update","IMPORTANT_MODIFIER","MODIFIER_SEPARATOR","MODIFIER_SEPARATOR_LENGTH","createParseClassName","prefix","experimentalParseClassName","parseClassName","modifiers","bracketDepth","parenDepth","modifierStart","postfixModifierPosition","index","currentCharacter","baseClassNameWithImportantModifier","baseClassName","stripImportantModifier","hasImportantModifier","maybePostfixModifierPosition","fullPrefix","parseClassNameOriginal","isExternal","createSortModifiers","orderSensitiveModifiers","fromEntries","modifier","sortModifiers","sortedModifiers","unsortedModifiers","isPositionSensitive","createConfigUtils","createClassGroupUtils","SPLIT_CLASSES_REGEX","mergeClassList","classList","configUtils","classGroupsInConflict","classNames","trim","result","originalClassName","variantModifier","modifierId","classId","conflictGroups","group","twJoin","argument","resolvedValue","string","arguments","toValue","mix","k","createTailwindMerge","createConfigFirst","createConfigRest","cacheGet","cacheSet","functionToCall","initTailwindMerge","previousConfig","createConfigCurrent","tailwindMerge","cachedResult","callTailwindMerge","apply","fromTheme","themeGetter","arbitraryValueRegex","arbitraryVariableRegex","fractionRegex","tshirtUnitRegex","lengthUnitRegex","colorFunctionRegex","shadowRegex","imageRegex","isFraction","isNumber","isInteger","isPercent","isTshirtSize","isAny","isLengthOnly","isNever","isShadow","isImage","isAnyNonArbitrary","isArbitraryValue","isArbitraryVariable","isArbitrarySize","getIsArbitraryValue","isLabelSize","isArbitraryLength","isLabelLength","isArbitraryNumber","isLabelNumber","isArbitraryPosition","isLabelPosition","isArbitraryImage","isLabelImage","isArbitraryShadow","isLabelShadow","isArbitraryVariableLength","getIsArbitraryVariable","isArbitraryVariableFamilyName","isLabelFamilyName","isArbitraryVariablePosition","isArbitraryVariableSize","isArbitraryVariableImage","isArbitraryVariableShadow","testLabel","testValue","shouldMatchNoLabel","label","getDefaultConfig","themeColor","themeFont","themeText","themeFontWeight","themeTracking","themeLeading","themeBreakpoint","themeContainer","themeSpacing","themeRadius","themeShadow","themeInsetShadow","themeTextShadow","themeDropShadow","themeBlur","themePerspective","themeAspect","themeEase","themeAnimate","scaleBreak","scalePosition","scalePositionWithArbitrary","scaleOverflow","scaleOverscroll","scaleUnambiguousSpacing","scaleInset","scaleGridTemplateColsRows","scaleGridColRowStartAndEnd","span","scaleGridColRowStartOrEnd","scaleGridAutoColsRows","scaleAlignPrimaryAxis","scaleAlignSecondaryAxis","scaleMargin","scaleSizing","scaleColor","scaleBgPosition","scaleBgRepeat","repeat","scaleBgSize","size","scaleGradientStopPosition","scaleRadius","scaleBorderWidth","scaleLineStyle","scaleBlendMode","scaleMaskImagePosition","scaleBlur","scaleRotate","scaleScale","scaleSkew","scaleTranslate","animate","aspect","blur","breakpoint","container","ease","font","leading","perspective","radius","shadow","spacing","text","tracking","columns","box","display","sr","float","clear","isolation","object","overflow","overscroll","inset","start","end","visibility","z","basis","flex","grow","shrink","order","col","row","gap","justify","content","items","baseline","self","px","py","ps","pe","pt","pr","pb","pl","m","mx","my","ms","me","mt","mr","mb","ml","screen","h","list","decoration","indent","align","whitespace","break","wrap","hyphens","bg","linear","to","radial","conic","from","via","rounded","border","divide","outline","ring","opacity","mask","closest","farthest","brightness","contrast","grayscale","invert","saturate","sepia","table","caption","transition","duration","delay","backface","rotate","scale","skew","transform","origin","translate","accent","appearance","caret","scheme","cursor","resize","snap","touch","select","stroke","mergeConfigs","baseConfig","extend","override","overrideProperty","overrideConfigProperties","mergeConfigProperties","mergeArrayProperties","baseObject","overrideKey","overrideValue","overrideObject","mergeObject","mergeValue","concat","extendTailwindMerge","configExtension","createConfig","twMerge"],"mappings":"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","ignoreList":[0,1,2,3,4,5,7,8,9,10,11,13,14,15,16,17,19,20,28,29,33,36,37,38,39,40,41,42,43,44,45,46,47,48,49]}
|