reroute-js 0.40.2 → 0.41.1
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/cli/bin.d.ts +1 -1
- package/cli/bin.js +206 -71
- package/cli/bin.js.map +13 -13
- package/cli/index.d.ts +1 -1
- package/cli/index.js +4 -4
- package/cli/index.js.map +1 -1
- package/cli/src/cli.d.ts +1 -1
- package/cli/src/commands/analyze.d.ts +1 -1
- package/cli/src/commands/build.d.ts +1 -1
- package/cli/src/commands/dev.d.ts +1 -1
- package/cli/src/commands/gen.d.ts +1 -1
- package/cli/src/commands/gen.d.ts.map +1 -1
- package/cli/src/commands/index.d.ts +1 -1
- package/cli/src/commands/init.d.ts +1 -1
- package/cli/src/commands/lib/assets.d.ts +1 -1
- package/cli/src/commands/lib/bundler.d.ts +1 -1
- package/cli/src/commands/lib/command.d.ts +1 -1
- package/cli/src/commands/lib/env.d.ts +1 -1
- package/cli/src/commands/lib/index.d.ts +1 -1
- package/cli/src/commands/lib/log.d.ts +1 -1
- package/cli/src/commands/lib/markdown/availability.d.ts +1 -1
- package/cli/src/commands/lib/markdown/index.d.ts +1 -1
- package/cli/src/commands/lib/markdown/processor.d.ts +1 -1
- package/cli/src/commands/lib/production.d.ts +1 -1
- package/cli/src/commands/lib/server.d.ts +1 -1
- package/cli/src/commands/lib/streaming/analyzer.d.ts +1 -1
- package/cli/src/commands/lib/streaming/suspense.d.ts +1 -1
- package/cli/src/commands/lib/tailwind.d.ts +1 -1
- package/cli/src/commands/lib/terminal-ui.d.ts +1 -1
- package/cli/src/commands/lib/version.d.ts +1 -1
- package/cli/src/commands/og.d.ts +1 -1
- package/cli/src/commands/start.d.ts +1 -1
- package/cli/src/index.d.ts +1 -1
- package/core/index.d.ts +1 -1
- package/core/index.js +148 -46
- package/core/index.js.map +12 -12
- package/core/src/bundler/hash.d.ts +1 -1
- package/core/src/bundler/index.d.ts +1 -1
- package/core/src/config.d.ts +42 -2
- package/core/src/config.d.ts.map +1 -1
- package/core/src/content/discovery.d.ts +1 -1
- package/core/src/content/index.d.ts +1 -1
- package/core/src/content/metadata.d.ts +7 -2
- package/core/src/content/metadata.d.ts.map +1 -1
- package/core/src/index.d.ts +1 -1
- package/core/src/llms/extractor.d.ts +1 -1
- package/core/src/llms/formatter.d.ts +1 -1
- package/core/src/llms/full-generator.d.ts +1 -1
- package/core/src/llms/index-generator.d.ts +1 -1
- package/core/src/llms/index.d.ts +1 -1
- package/core/src/og/discovery.d.ts +1 -1
- package/core/src/og/index.d.ts +1 -1
- package/core/src/og/meta.d.ts +1 -1
- package/core/src/og/render.d.ts +1 -1
- package/core/src/og/types.d.ts +1 -1
- package/core/src/robots/discovery.d.ts +1 -1
- package/core/src/robots/generator.d.ts +1 -1
- package/core/src/robots/index.d.ts +1 -1
- package/core/src/robots/policies.d.ts +1 -1
- package/core/src/rss/discovery.d.ts +1 -1
- package/core/src/rss/discovery.d.ts.map +1 -1
- package/core/src/rss/generator.d.ts +1 -1
- package/core/src/rss/index.d.ts +1 -1
- package/core/src/sitemap/discovery.d.ts +1 -1
- package/core/src/sitemap/discovery.d.ts.map +1 -1
- package/core/src/sitemap/generator.d.ts +1 -1
- package/core/src/sitemap/index.d.ts +1 -1
- package/core/src/ssr/index.d.ts +1 -1
- package/core/src/ssr/lib/cache.d.ts +1 -1
- package/core/src/ssr/lib/collections.d.ts +1 -1
- package/core/src/ssr/lib/compression.d.ts +1 -1
- package/core/src/ssr/lib/compute/content.d.ts +1 -1
- package/core/src/ssr/lib/compute/index.d.ts +1 -1
- package/core/src/ssr/lib/compute/layouts.d.ts +1 -1
- package/core/src/ssr/lib/compute/routes.d.ts +1 -1
- package/core/src/ssr/lib/data.d.ts +1 -1
- package/core/src/ssr/lib/html.d.ts +6 -1
- package/core/src/ssr/lib/html.d.ts.map +1 -1
- package/core/src/ssr/lib/imports.d.ts +1 -1
- package/core/src/ssr/lib/index.d.ts +1 -1
- package/core/src/ssr/lib/layouts.d.ts +1 -1
- package/core/src/ssr/lib/metadata.d.ts +3 -3
- package/core/src/ssr/lib/metadata.d.ts.map +1 -1
- package/core/src/ssr/lib/mime.d.ts +1 -1
- package/core/src/ssr/lib/modules.d.ts +1 -1
- package/core/src/ssr/lib/path.d.ts +1 -1
- package/core/src/ssr/lib/preload.d.ts +1 -1
- package/core/src/ssr/lib/scripts/collections.d.ts +1 -1
- package/core/src/ssr/lib/scripts/data.d.ts +1 -1
- package/core/src/ssr/lib/scripts/escape.d.ts +1 -1
- package/core/src/ssr/lib/scripts/feeds.d.ts +1 -1
- package/core/src/ssr/lib/scripts/index.d.ts +1 -1
- package/core/src/ssr/lib/seed.d.ts +1 -1
- package/core/src/ssr/lib/serialize.d.ts +1 -1
- package/core/src/ssr/lib/setup.d.ts +3 -2
- package/core/src/ssr/lib/setup.d.ts.map +1 -1
- package/core/src/ssr/lib/styles.d.ts +1 -1
- package/core/src/ssr/lib/template.d.ts +1 -1
- package/core/src/ssr/lib/types.d.ts +1 -1
- package/core/src/ssr/render.d.ts +3 -2
- package/core/src/ssr/render.d.ts.map +1 -1
- package/core/src/ssr/stream.d.ts +3 -2
- package/core/src/ssr/stream.d.ts.map +1 -1
- package/elysia/index.d.ts +1 -1
- package/elysia/index.js +326 -127
- package/elysia/index.js.map +18 -18
- package/elysia/src/index.d.ts +1 -1
- package/elysia/src/libs/assets.d.ts +1 -1
- package/elysia/src/libs/cache.d.ts +1 -1
- package/elysia/src/libs/caching.d.ts +1 -1
- package/elysia/src/libs/http.d.ts +1 -1
- package/elysia/src/libs/image.d.ts +1 -1
- package/elysia/src/libs/index.d.ts +1 -1
- package/elysia/src/libs/llms.d.ts +1 -1
- package/elysia/src/libs/response.d.ts +1 -1
- package/elysia/src/libs/serving.d.ts +1 -1
- package/elysia/src/plugin.d.ts +1 -1
- package/elysia/src/plugin.d.ts.map +1 -1
- package/elysia/src/routes/artifacts.d.ts +1 -1
- package/elysia/src/routes/content.d.ts +1 -1
- package/elysia/src/routes/image.d.ts +1 -1
- package/elysia/src/routes/index.d.ts +1 -1
- package/elysia/src/routes/internal.d.ts +1 -1
- package/elysia/src/routes/internal.d.ts.map +1 -1
- package/elysia/src/routes/llms.d.ts +1 -1
- package/elysia/src/routes/og.d.ts +1 -1
- package/elysia/src/routes/og.d.ts.map +1 -1
- package/elysia/src/routes/redirects.d.ts +1 -1
- package/elysia/src/routes/robots.d.ts +1 -1
- package/elysia/src/routes/rss.d.ts +2 -2
- package/elysia/src/routes/rss.d.ts.map +1 -1
- package/elysia/src/routes/search.d.ts +1 -1
- package/elysia/src/routes/sitemap.d.ts +2 -2
- package/elysia/src/routes/sitemap.d.ts.map +1 -1
- package/elysia/src/routes/ssr.d.ts +3 -2
- package/elysia/src/routes/ssr.d.ts.map +1 -1
- package/elysia/src/routes/static.d.ts +1 -1
- package/elysia/src/types.d.ts +1 -1
- package/package.json +1 -1
- package/react/index.d.ts +1 -1
- package/react/index.js +2 -2
- package/react/index.js.map +1 -1
- package/react/src/components/ClientOnly.d.ts +1 -1
- package/react/src/components/ContentRoute.d.ts +1 -1
- package/react/src/components/Image.d.ts +1 -1
- package/react/src/components/LazyRoute.d.ts +1 -1
- package/react/src/components/Link.d.ts +1 -1
- package/react/src/components/Markdown.d.ts +1 -1
- package/react/src/components/Outlet.d.ts +1 -1
- package/react/src/components/index.d.ts +1 -1
- package/react/src/hooks/index.d.ts +1 -1
- package/react/src/hooks/useContent.d.ts +1 -1
- package/react/src/hooks/useData.d.ts +1 -1
- package/react/src/hooks/useFeed.d.ts +1 -1
- package/react/src/hooks/useLayoutData.d.ts +1 -1
- package/react/src/hooks/useLlms.d.ts +1 -1
- package/react/src/hooks/useNavigate.d.ts +1 -1
- package/react/src/hooks/useParams.d.ts +1 -1
- package/react/src/hooks/useRouter.d.ts +1 -1
- package/react/src/hooks/useSearch.d.ts +1 -1
- package/react/src/hooks/useSearchParams.d.ts +1 -1
- package/react/src/hooks/useToc.d.ts +1 -1
- package/react/src/index.d.ts +1 -1
- package/react/src/lib/collection.d.ts +1 -1
- package/react/src/lib/content.d.ts +1 -1
- package/react/src/lib/head.d.ts +1 -1
- package/react/src/lib/index.d.ts +1 -1
- package/react/src/lib/lazy-route.d.ts +1 -1
- package/react/src/lib/route-loader.d.ts +1 -1
- package/react/src/providers/ContentProvider.d.ts +1 -1
- package/react/src/providers/RerouteProvider.d.ts +1 -1
- package/react/src/providers/RouterProvider.d.ts +1 -1
- package/react/src/providers/index.d.ts +1 -1
- package/react/src/types/any.d.ts +1 -1
- package/react/src/types/index.d.ts +1 -1
- package/react/src/types/router.d.ts +1 -1
- package/telemetry/react.d.ts +1 -1
- package/telemetry/react.js +2 -2
- package/telemetry/react.js.map +1 -1
- package/telemetry/server.d.ts +1 -1
- package/telemetry/server.js +2 -2
- package/telemetry/server.js.map +8 -8
- package/telemetry/src/react/api.d.ts +1 -1
- package/telemetry/src/react/context.d.ts +1 -1
- package/telemetry/src/react/index.d.ts +1 -1
- package/telemetry/src/react/telemetry.d.ts +1 -1
- package/telemetry/src/server/context.d.ts +1 -1
- package/telemetry/src/server/headers/extractor.d.ts +1 -1
- package/telemetry/src/server/headers/index.d.ts +1 -1
- package/telemetry/src/server/headers/presets.d.ts +1 -1
- package/telemetry/src/server/index.d.ts +1 -1
- package/telemetry/src/server/instrumentation.d.ts +1 -1
- package/telemetry/src/server/plugin.d.ts +1 -1
- package/telemetry/src/server/sourcemap.d.ts +1 -1
package/core/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* reroute-js v0.
|
|
2
|
+
* reroute-js v0.41.1
|
|
3
3
|
*
|
|
4
4
|
* @license MIT
|
|
5
5
|
* @copyright 2026 stewones <hi@stewan.io>
|
|
@@ -168,7 +168,7 @@ async function getContentMeta(absPath, isWatchMode) {
|
|
|
168
168
|
}
|
|
169
169
|
}
|
|
170
170
|
}
|
|
171
|
-
function buildHeadFromMeta(meta) {
|
|
171
|
+
function buildHeadFromMeta(meta, ogConfig) {
|
|
172
172
|
if (!meta || typeof meta !== "object")
|
|
173
173
|
return "";
|
|
174
174
|
const parts = [];
|
|
@@ -178,6 +178,23 @@ function buildHeadFromMeta(meta) {
|
|
|
178
178
|
parts.push(`<title>${escapeHtml(title)}</title>`);
|
|
179
179
|
if (description)
|
|
180
180
|
parts.push(`<meta name="description" content="${escapeHtml(description)}" />`);
|
|
181
|
+
const ogType = typeof meta.ogType === "string" ? meta.ogType : ogConfig?.defaultType || "website";
|
|
182
|
+
parts.push(`<meta property="og:type" content="${escapeHtml(ogType)}" />`);
|
|
183
|
+
if (title) {
|
|
184
|
+
parts.push(`<meta property="og:title" content="${escapeHtml(title)}" />`);
|
|
185
|
+
}
|
|
186
|
+
const finalDescription = description || ogConfig?.siteDescription;
|
|
187
|
+
if (finalDescription) {
|
|
188
|
+
parts.push(`<meta property="og:description" content="${escapeHtml(finalDescription)}" />`);
|
|
189
|
+
}
|
|
190
|
+
const twitterCard = ogConfig?.twitterCard || "summary_large_image";
|
|
191
|
+
parts.push(`<meta name="twitter:card" content="${twitterCard}" />`);
|
|
192
|
+
if (title) {
|
|
193
|
+
parts.push(`<meta name="twitter:title" content="${escapeHtml(title)}" />`);
|
|
194
|
+
}
|
|
195
|
+
if (finalDescription) {
|
|
196
|
+
parts.push(`<meta name="twitter:description" content="${escapeHtml(finalDescription)}" />`);
|
|
197
|
+
}
|
|
181
198
|
return parts.length ? `
|
|
182
199
|
${parts.join(`
|
|
183
200
|
`)}` : "";
|
|
@@ -1640,6 +1657,28 @@ function removeDefaultMetaTags(templateHtml) {
|
|
|
1640
1657
|
} catch {}
|
|
1641
1658
|
return result;
|
|
1642
1659
|
}
|
|
1660
|
+
function removeOverriddenMetaTags(templateHtml, injectedHead) {
|
|
1661
|
+
let result = templateHtml;
|
|
1662
|
+
try {
|
|
1663
|
+
const injectedOgProps = [
|
|
1664
|
+
...injectedHead.matchAll(/<meta\s+property\s*=\s*['"]([^'"]+)['"][^>]*>/gi)
|
|
1665
|
+
].map((m) => m[1].toLowerCase());
|
|
1666
|
+
const injectedNameMetas = [
|
|
1667
|
+
...injectedHead.matchAll(/<meta\s+name\s*=\s*['"]([^'"]+)['"][^>]*>/gi)
|
|
1668
|
+
].map((m) => m[1].toLowerCase());
|
|
1669
|
+
for (const prop of injectedOgProps) {
|
|
1670
|
+
const escapedProp = prop.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
1671
|
+
const regex = new RegExp(`<meta\\s+property\\s*=\\s*['"]${escapedProp}['"][^>]*>`, "gi");
|
|
1672
|
+
result = result.replace(regex, "");
|
|
1673
|
+
}
|
|
1674
|
+
for (const name of injectedNameMetas) {
|
|
1675
|
+
const escapedName = name.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
1676
|
+
const regex = new RegExp(`<meta\\s+name\\s*=\\s*['"]${escapedName}['"][^>]*>`, "gi");
|
|
1677
|
+
result = result.replace(regex, "");
|
|
1678
|
+
}
|
|
1679
|
+
} catch {}
|
|
1680
|
+
return result;
|
|
1681
|
+
}
|
|
1643
1682
|
function deduplicateHeadContent(templateHtml, headToInject) {
|
|
1644
1683
|
let cleanedTemplate = templateHtml;
|
|
1645
1684
|
let cleanedHead = headToInject;
|
|
@@ -1650,6 +1689,7 @@ function deduplicateHeadContent(templateHtml, headToInject) {
|
|
|
1650
1689
|
} else if (/<meta\s+name\s*=\s*['"]description['"][^>]*>/i.test(cleanedHead)) {
|
|
1651
1690
|
cleanedTemplate = cleanedTemplate.replace(/<meta\s+name\s*=\s*['"]description['"][^>]*>/i, "");
|
|
1652
1691
|
}
|
|
1692
|
+
cleanedTemplate = removeOverriddenMetaTags(cleanedTemplate, cleanedHead);
|
|
1653
1693
|
} catch {}
|
|
1654
1694
|
return { cleanedTemplate, cleanedHead };
|
|
1655
1695
|
}
|
|
@@ -1768,7 +1808,6 @@ async function generateOGImageMetaTags(pathname, clientDir, ogConfig) {
|
|
|
1768
1808
|
return `<meta property="og:image" content="${ogImagePath}" />
|
|
1769
1809
|
<meta property="og:image:width" content="${width}" />
|
|
1770
1810
|
<meta property="og:image:height" content="${height}" />
|
|
1771
|
-
<meta name="twitter:card" content="summary_large_image" />
|
|
1772
1811
|
<meta name="twitter:image" content="${ogImagePath}" />`;
|
|
1773
1812
|
}
|
|
1774
1813
|
var init_meta = __esm(() => {
|
|
@@ -1806,7 +1845,25 @@ function generateOgUrl(baseUrl, pathname) {
|
|
|
1806
1845
|
const ogUrl = `${cleanBaseUrl}${normalizedPath}`;
|
|
1807
1846
|
return `<meta property="og:url" content="${ogUrl}" />`;
|
|
1808
1847
|
}
|
|
1809
|
-
|
|
1848
|
+
function generateGlobalOGTags(ogConfig) {
|
|
1849
|
+
const tags = [];
|
|
1850
|
+
if (ogConfig.siteName) {
|
|
1851
|
+
tags.push(`<meta property="og:site_name" content="${escapeHtml2(ogConfig.siteName)}" />`);
|
|
1852
|
+
}
|
|
1853
|
+
if (ogConfig.locale) {
|
|
1854
|
+
tags.push(`<meta property="og:locale" content="${escapeHtml2(ogConfig.locale)}" />`);
|
|
1855
|
+
}
|
|
1856
|
+
if (ogConfig.twitterSite) {
|
|
1857
|
+
const handle = ogConfig.twitterSite.startsWith("@") ? ogConfig.twitterSite : `@${ogConfig.twitterSite}`;
|
|
1858
|
+
tags.push(`<meta name="twitter:site" content="${escapeHtml2(handle)}" />`);
|
|
1859
|
+
}
|
|
1860
|
+
return tags.length ? tags.join(`
|
|
1861
|
+
`) : "";
|
|
1862
|
+
}
|
|
1863
|
+
function escapeHtml2(input) {
|
|
1864
|
+
return input.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, """).replace(/'/g, "'");
|
|
1865
|
+
}
|
|
1866
|
+
async function extractPageMetadata(pathname, clientDir, cwd, isWatchMode, currentStatusOverride, ogImageConfig, ogConfig, baseUrl, autoCanonical, ssrData) {
|
|
1810
1867
|
let perPageHead = "";
|
|
1811
1868
|
let pageLang;
|
|
1812
1869
|
let statusOverride = currentStatusOverride;
|
|
@@ -1815,7 +1872,7 @@ async function extractPageMetadata(pathname, clientDir, cwd, isWatchMode, curren
|
|
|
1815
1872
|
}, (lang) => {
|
|
1816
1873
|
if (!pageLang)
|
|
1817
1874
|
pageLang = lang;
|
|
1818
|
-
});
|
|
1875
|
+
}, ogConfig);
|
|
1819
1876
|
const shouldGenerateCanonical = autoCanonical !== false && baseUrl !== undefined;
|
|
1820
1877
|
if (shouldGenerateCanonical) {
|
|
1821
1878
|
const canonicalTag = generateCanonicalUrl(baseUrl, pathname);
|
|
@@ -1825,8 +1882,15 @@ ${canonicalTag}`;
|
|
|
1825
1882
|
perPageHead += `
|
|
1826
1883
|
${ogUrlTag}`;
|
|
1827
1884
|
}
|
|
1885
|
+
if (ogConfig) {
|
|
1886
|
+
const ogGlobalTags = generateGlobalOGTags(ogConfig);
|
|
1887
|
+
if (ogGlobalTags) {
|
|
1888
|
+
perPageHead += `
|
|
1889
|
+
${ogGlobalTags}`;
|
|
1890
|
+
}
|
|
1891
|
+
}
|
|
1828
1892
|
try {
|
|
1829
|
-
const ogMetaTags = await generateOGImageMetaTags(pathname, clientDir,
|
|
1893
|
+
const ogMetaTags = await generateOGImageMetaTags(pathname, clientDir, ogImageConfig);
|
|
1830
1894
|
if (ogMetaTags) {
|
|
1831
1895
|
perPageHead += `
|
|
1832
1896
|
${ogMetaTags}`;
|
|
@@ -1838,22 +1902,22 @@ ${ogMetaTags}`;
|
|
|
1838
1902
|
perPageHead += head;
|
|
1839
1903
|
}, (lang) => {
|
|
1840
1904
|
pageLang = lang;
|
|
1841
|
-
});
|
|
1842
|
-
const routeResult = await extractRouteMetadata(pathname, clientDir, cwd, isWatchMode, statusOverride, ssrData);
|
|
1905
|
+
}, ogConfig);
|
|
1906
|
+
const routeResult = await extractRouteMetadata(pathname, clientDir, cwd, isWatchMode, statusOverride, ssrData, ogConfig);
|
|
1843
1907
|
perPageHead += routeResult.head;
|
|
1844
1908
|
if (routeResult.lang)
|
|
1845
1909
|
pageLang = routeResult.lang;
|
|
1846
1910
|
statusOverride = routeResult.statusOverride;
|
|
1847
1911
|
return { perPageHead, pageLang, statusOverride };
|
|
1848
1912
|
}
|
|
1849
|
-
async function processLayoutForMetadata(layout, clientDir, isWatchMode, addHead, setLang) {
|
|
1913
|
+
async function processLayoutForMetadata(layout, clientDir, isWatchMode, addHead, setLang, ogConfig) {
|
|
1850
1914
|
if (typeof layout?.path !== "string")
|
|
1851
1915
|
return;
|
|
1852
1916
|
try {
|
|
1853
1917
|
const abs = join(clientDir, "routes", String(layout.path));
|
|
1854
1918
|
const { meta, ssr } = await loadModuleMetaAndSSR(layout, abs, isWatchMode);
|
|
1855
1919
|
if (meta)
|
|
1856
|
-
addHead(buildHeadFromMeta(meta));
|
|
1920
|
+
addHead(buildHeadFromMeta(meta, ogConfig));
|
|
1857
1921
|
if (ssr) {
|
|
1858
1922
|
const ssrHead = extractSSRHead(ssr);
|
|
1859
1923
|
if (ssrHead)
|
|
@@ -1865,16 +1929,16 @@ ${ssrHead}`);
|
|
|
1865
1929
|
}
|
|
1866
1930
|
} catch {}
|
|
1867
1931
|
}
|
|
1868
|
-
async function extractLayoutMetadata(pathname, clientDir, cwd, isWatchMode, addHead, setLang) {
|
|
1932
|
+
async function extractLayoutMetadata(pathname, clientDir, cwd, isWatchMode, addHead, setLang, ogConfig) {
|
|
1869
1933
|
try {
|
|
1870
1934
|
const m = await loadRoutesModule(cwd, isWatchMode);
|
|
1871
1935
|
const matchingLayouts = getMatchingLayouts(pathname, m?.layouts);
|
|
1872
1936
|
for (const layout of matchingLayouts) {
|
|
1873
|
-
await processLayoutForMetadata(layout, clientDir, isWatchMode, addHead, setLang);
|
|
1937
|
+
await processLayoutForMetadata(layout, clientDir, isWatchMode, addHead, setLang, ogConfig);
|
|
1874
1938
|
}
|
|
1875
1939
|
} catch {}
|
|
1876
1940
|
}
|
|
1877
|
-
function extractContentMetadata(pathname, addHead, setLang) {
|
|
1941
|
+
function extractContentMetadata(pathname, addHead, setLang, ogConfig) {
|
|
1878
1942
|
try {
|
|
1879
1943
|
const parts = pathname.split("/").filter(Boolean);
|
|
1880
1944
|
if (parts.length < 2)
|
|
@@ -1884,7 +1948,7 @@ function extractContentMetadata(pathname, addHead, setLang) {
|
|
|
1884
1948
|
const exp = g.__REROUTE_SSR_EXPORTS__?.[key];
|
|
1885
1949
|
const meta = exp?.meta;
|
|
1886
1950
|
const ssr = exp?.ssr;
|
|
1887
|
-
addHead(buildHeadFromMeta(meta));
|
|
1951
|
+
addHead(buildHeadFromMeta(meta, ogConfig));
|
|
1888
1952
|
const ssrHead = extractSSRHead(ssr);
|
|
1889
1953
|
if (ssrHead)
|
|
1890
1954
|
addHead(`
|
|
@@ -1894,7 +1958,7 @@ ${ssrHead}`);
|
|
|
1894
1958
|
setLang(lang);
|
|
1895
1959
|
} catch {}
|
|
1896
1960
|
}
|
|
1897
|
-
async function extractMatchedRouteMetadata(pathname, clientDir, m, isWatchMode, statusOverride, ssrData) {
|
|
1961
|
+
async function extractMatchedRouteMetadata(pathname, clientDir, m, isWatchMode, statusOverride, ssrData, ogConfig) {
|
|
1898
1962
|
const pathnameOnly = pathname.split("?")[0];
|
|
1899
1963
|
const match = typeof m.matchRoute === "function" ? m.matchRoute(pathnameOnly) : null;
|
|
1900
1964
|
const r = match?.route;
|
|
@@ -1907,7 +1971,7 @@ async function extractMatchedRouteMetadata(pathname, clientDir, m, isWatchMode,
|
|
|
1907
1971
|
const { meta, ssr } = await loadModuleMetaAndSSR(r, abs, isWatchMode);
|
|
1908
1972
|
let head = "";
|
|
1909
1973
|
if (meta)
|
|
1910
|
-
head += buildHeadFromMeta(meta);
|
|
1974
|
+
head += buildHeadFromMeta(meta, ogConfig);
|
|
1911
1975
|
if (ssr) {
|
|
1912
1976
|
const routeData = ssrData && typeof ssrData === "object" ? ssrData[pathname] : undefined;
|
|
1913
1977
|
const ssrHead = extractSSRHead(ssr, routeData);
|
|
@@ -1921,7 +1985,7 @@ ${ssrHead}`;
|
|
|
1921
1985
|
}
|
|
1922
1986
|
return { head: "", statusOverride };
|
|
1923
1987
|
}
|
|
1924
|
-
async function extractRouteMetadata(pathname, clientDir, cwd, isWatchMode, currentStatusOverride, ssrData) {
|
|
1988
|
+
async function extractRouteMetadata(pathname, clientDir, cwd, isWatchMode, currentStatusOverride, ssrData, ogConfig) {
|
|
1925
1989
|
let head = "";
|
|
1926
1990
|
let lang;
|
|
1927
1991
|
let statusOverride = currentStatusOverride;
|
|
@@ -1937,14 +2001,14 @@ async function extractRouteMetadata(pathname, clientDir, cwd, isWatchMode, curre
|
|
|
1937
2001
|
statusOverride = statusOverride || 404;
|
|
1938
2002
|
}
|
|
1939
2003
|
if (r && typeof r.path === "string") {
|
|
1940
|
-
const result = await extractMatchedRouteMetadata(pathname, clientDir, m, isWatchMode, statusOverride, ssrData);
|
|
2004
|
+
const result = await extractMatchedRouteMetadata(pathname, clientDir, m, isWatchMode, statusOverride, ssrData, ogConfig);
|
|
1941
2005
|
head = result.head;
|
|
1942
2006
|
lang = result.lang;
|
|
1943
2007
|
statusOverride = result.statusOverride;
|
|
1944
2008
|
} else {
|
|
1945
2009
|
head += await extractNotFoundMetadata(pathname, clientDir, m, isWatchMode, (l) => {
|
|
1946
2010
|
lang = l;
|
|
1947
|
-
});
|
|
2011
|
+
}, ogConfig);
|
|
1948
2012
|
}
|
|
1949
2013
|
} catch {}
|
|
1950
2014
|
return { head, lang, statusOverride };
|
|
@@ -1964,7 +2028,7 @@ function findBestNotFoundRoute(list, pathname) {
|
|
|
1964
2028
|
}
|
|
1965
2029
|
return chosen;
|
|
1966
2030
|
}
|
|
1967
|
-
async function extractNotFoundMetadata(pathname, clientDir, routesModule, isWatchMode, setLang) {
|
|
2031
|
+
async function extractNotFoundMetadata(pathname, clientDir, routesModule, isWatchMode, setLang, ogConfig) {
|
|
1968
2032
|
let head = "";
|
|
1969
2033
|
try {
|
|
1970
2034
|
const list = routesModule?.notFoundRoutes;
|
|
@@ -1975,7 +2039,7 @@ async function extractNotFoundMetadata(pathname, clientDir, routesModule, isWatc
|
|
|
1975
2039
|
const abs = join(clientDir, "routes", String(chosen.path));
|
|
1976
2040
|
const { meta, ssr } = await loadModuleMetaAndSSR(chosen, abs, isWatchMode);
|
|
1977
2041
|
if (meta)
|
|
1978
|
-
head += buildHeadFromMeta(meta);
|
|
2042
|
+
head += buildHeadFromMeta(meta, ogConfig);
|
|
1979
2043
|
const ssrHead = extractSSRHead(ssr);
|
|
1980
2044
|
if (ssrHead)
|
|
1981
2045
|
head += `
|
|
@@ -2562,7 +2626,7 @@ async function performSSRSetupInternal(options, streaming) {
|
|
|
2562
2626
|
statusOverride = computeResult.statusContainer.value;
|
|
2563
2627
|
}
|
|
2564
2628
|
const metadataResult = await withSpan("ssr.extract.metadata", async (span) => {
|
|
2565
|
-
const result = await extractPageMetadata(pathname, clientDir, cwd, isWatchMode, statusOverride, ogConfig, options.baseUrl, options.autoCanonical, computeResult.data);
|
|
2629
|
+
const result = await extractPageMetadata(pathname, clientDir, cwd, isWatchMode, statusOverride, ogConfig, options.ogMetaConfig, options.baseUrl, options.autoCanonical, computeResult.data);
|
|
2566
2630
|
span.setAttributes({
|
|
2567
2631
|
"reroute.pathname": pathname,
|
|
2568
2632
|
"reroute.metadata.exists": !!result.perPageHead
|
|
@@ -2732,6 +2796,7 @@ async function renderSSRDocument(options) {
|
|
|
2732
2796
|
maxAge,
|
|
2733
2797
|
searchParams,
|
|
2734
2798
|
ogConfig,
|
|
2799
|
+
ogMetaConfig: options.ogMetaConfig,
|
|
2735
2800
|
baseUrl: options.baseUrl,
|
|
2736
2801
|
autoCanonical: options.autoCanonical,
|
|
2737
2802
|
cachedCollections: options.cachedCollections,
|
|
@@ -3996,13 +4061,13 @@ async function discoverSSRDataRoutes2(cwd, staticRoutes, isWatchMode, baseUrl, s
|
|
|
3996
4061
|
const ssrDataRoutes = new Map;
|
|
3997
4062
|
const bundledRoutes = globalThis.__REROUTE_ROUTES__;
|
|
3998
4063
|
if (bundledRoutes && Array.isArray(bundledRoutes)) {
|
|
3999
|
-
|
|
4064
|
+
const routePromises = staticRoutes.map(async (route) => {
|
|
4000
4065
|
if (sitemapConfig?.excludeDiscovery?.some((excluded) => route.pattern.startsWith(excluded))) {
|
|
4001
|
-
|
|
4066
|
+
return null;
|
|
4002
4067
|
}
|
|
4003
4068
|
const bundledRoute = bundledRoutes.find((r) => r?.pattern === route.pattern);
|
|
4004
4069
|
if (!bundledRoute)
|
|
4005
|
-
|
|
4070
|
+
return null;
|
|
4006
4071
|
const ssr = bundledRoute?.ssr;
|
|
4007
4072
|
const dataFn = ssr?.data;
|
|
4008
4073
|
if (typeof dataFn === "function") {
|
|
@@ -4015,15 +4080,22 @@ async function discoverSSRDataRoutes2(cwd, staticRoutes, isWatchMode, baseUrl, s
|
|
|
4015
4080
|
});
|
|
4016
4081
|
const entries = extractEntriesFromData(result, route.pattern, baseUrl, sitemapConfig);
|
|
4017
4082
|
if (entries.length > 0) {
|
|
4018
|
-
|
|
4083
|
+
return { pattern: route.pattern, entries };
|
|
4019
4084
|
}
|
|
4020
4085
|
} catch {}
|
|
4021
4086
|
}
|
|
4087
|
+
return null;
|
|
4088
|
+
});
|
|
4089
|
+
const results = await Promise.all(routePromises);
|
|
4090
|
+
for (const result of results) {
|
|
4091
|
+
if (result) {
|
|
4092
|
+
ssrDataRoutes.set(result.pattern, result.entries);
|
|
4093
|
+
}
|
|
4022
4094
|
}
|
|
4023
4095
|
} else {
|
|
4024
|
-
|
|
4096
|
+
const routePromises = staticRoutes.map(async (route) => {
|
|
4025
4097
|
if (sitemapConfig?.excludeDiscovery?.some((excluded) => route.pattern.startsWith(excluded))) {
|
|
4026
|
-
|
|
4098
|
+
return null;
|
|
4027
4099
|
}
|
|
4028
4100
|
try {
|
|
4029
4101
|
const routeModulePath = join(cwd, "src", "client", "routes", route.path);
|
|
@@ -4039,10 +4111,17 @@ async function discoverSSRDataRoutes2(cwd, staticRoutes, isWatchMode, baseUrl, s
|
|
|
4039
4111
|
});
|
|
4040
4112
|
const entries = extractEntriesFromData(result, route.pattern, baseUrl, sitemapConfig);
|
|
4041
4113
|
if (entries.length > 0) {
|
|
4042
|
-
|
|
4114
|
+
return { pattern: route.pattern, entries };
|
|
4043
4115
|
}
|
|
4044
4116
|
}
|
|
4045
4117
|
} catch {}
|
|
4118
|
+
return null;
|
|
4119
|
+
});
|
|
4120
|
+
const results = await Promise.all(routePromises);
|
|
4121
|
+
for (const result of results) {
|
|
4122
|
+
if (result) {
|
|
4123
|
+
ssrDataRoutes.set(result.pattern, result.entries);
|
|
4124
|
+
}
|
|
4046
4125
|
}
|
|
4047
4126
|
}
|
|
4048
4127
|
return ssrDataRoutes;
|
|
@@ -4418,24 +4497,28 @@ function createRSSItemFromData(item, routePattern, baseUrl, rssConfig) {
|
|
|
4418
4497
|
}
|
|
4419
4498
|
async function discoverRSSData(cwd, collections2, baseUrl, isWatchMode, rssConfig) {
|
|
4420
4499
|
const collectionsMap = new Map;
|
|
4421
|
-
|
|
4500
|
+
const collectionPromises = collections2.map(async (collection) => {
|
|
4422
4501
|
const items = await discoverCollectionFeedItems(cwd, collection, isWatchMode, baseUrl, rssConfig);
|
|
4423
|
-
|
|
4424
|
-
|
|
4502
|
+
return items.length > 0 ? { collection, items } : null;
|
|
4503
|
+
});
|
|
4504
|
+
const collectionResults = await Promise.all(collectionPromises);
|
|
4505
|
+
for (const result of collectionResults) {
|
|
4506
|
+
if (result) {
|
|
4507
|
+
collectionsMap.set(result.collection, result.items);
|
|
4425
4508
|
}
|
|
4426
4509
|
}
|
|
4427
4510
|
const ssrDataFeeds = new Map;
|
|
4428
4511
|
const bundledRoutes = globalThis.__REROUTE_ROUTES__;
|
|
4512
|
+
const { discoverRoutes: discoverRoutes2 } = await Promise.resolve().then(() => (init_discovery4(), exports_discovery));
|
|
4513
|
+
const { staticRoutes } = await discoverRoutes2(cwd, isWatchMode);
|
|
4429
4514
|
if (bundledRoutes && Array.isArray(bundledRoutes)) {
|
|
4430
|
-
const
|
|
4431
|
-
const { staticRoutes } = await discoverRoutes2(cwd, isWatchMode);
|
|
4432
|
-
for (const route of staticRoutes) {
|
|
4515
|
+
const routePromises = staticRoutes.map(async (route) => {
|
|
4433
4516
|
if (rssConfig?.excludeDiscovery?.some((excluded) => route.pattern.startsWith(excluded))) {
|
|
4434
|
-
|
|
4517
|
+
return null;
|
|
4435
4518
|
}
|
|
4436
4519
|
const bundledRoute = bundledRoutes.find((r) => r?.pattern === route.pattern);
|
|
4437
4520
|
if (!bundledRoute)
|
|
4438
|
-
|
|
4521
|
+
return null;
|
|
4439
4522
|
const ssr = bundledRoute?.ssr;
|
|
4440
4523
|
const dataFn = ssr?.data;
|
|
4441
4524
|
if (typeof dataFn === "function") {
|
|
@@ -4448,21 +4531,33 @@ async function discoverRSSData(cwd, collections2, baseUrl, isWatchMode, rssConfi
|
|
|
4448
4531
|
});
|
|
4449
4532
|
const items = extractRSSItemsFromData(result, route.pattern, baseUrl, rssConfig);
|
|
4450
4533
|
if (items.length > 0) {
|
|
4451
|
-
|
|
4534
|
+
return { pattern: route.pattern, items };
|
|
4452
4535
|
}
|
|
4453
4536
|
} catch {}
|
|
4454
4537
|
}
|
|
4538
|
+
return null;
|
|
4539
|
+
});
|
|
4540
|
+
const results = await Promise.all(routePromises);
|
|
4541
|
+
for (const result of results) {
|
|
4542
|
+
if (result) {
|
|
4543
|
+
ssrDataFeeds.set(result.pattern, result.items);
|
|
4544
|
+
}
|
|
4455
4545
|
}
|
|
4456
4546
|
} else {
|
|
4457
|
-
const
|
|
4458
|
-
const { staticRoutes } = await discoverRoutes2(cwd, isWatchMode);
|
|
4459
|
-
for (const route of staticRoutes) {
|
|
4547
|
+
const routePromises = staticRoutes.map(async (route) => {
|
|
4460
4548
|
if (rssConfig?.excludeDiscovery?.some((excluded) => route.pattern.startsWith(excluded))) {
|
|
4461
|
-
|
|
4549
|
+
return null;
|
|
4462
4550
|
}
|
|
4463
4551
|
const items = await discoverSSRDataFeedItems(cwd, route.pattern, route.path, isWatchMode, baseUrl, rssConfig);
|
|
4464
4552
|
if (items.length > 0) {
|
|
4465
|
-
|
|
4553
|
+
return { pattern: route.pattern, items };
|
|
4554
|
+
}
|
|
4555
|
+
return null;
|
|
4556
|
+
});
|
|
4557
|
+
const results = await Promise.all(routePromises);
|
|
4558
|
+
for (const result of results) {
|
|
4559
|
+
if (result) {
|
|
4560
|
+
ssrDataFeeds.set(result.pattern, result.items);
|
|
4466
4561
|
}
|
|
4467
4562
|
}
|
|
4468
4563
|
}
|
|
@@ -4842,6 +4937,7 @@ async function renderSSRDocumentStream(options) {
|
|
|
4842
4937
|
maxAge,
|
|
4843
4938
|
searchParams,
|
|
4844
4939
|
ogConfig,
|
|
4940
|
+
ogMetaConfig: options.ogMetaConfig,
|
|
4845
4941
|
baseUrl: options.baseUrl,
|
|
4846
4942
|
autoCanonical: options.autoCanonical,
|
|
4847
4943
|
cachedCollections: options.cachedCollections,
|
|
@@ -4876,7 +4972,11 @@ async function renderSSRDocumentStream(options) {
|
|
|
4876
4972
|
};
|
|
4877
4973
|
});
|
|
4878
4974
|
const pageLang = setup2.metadataResult.pageLang || lang;
|
|
4879
|
-
let headWithLang = htmlHead.replace(/<html([^>]*)>/i,
|
|
4975
|
+
let headWithLang = htmlHead.replace(/<html([^>]*)>/i, (_m, attrs) => {
|
|
4976
|
+
const hasLang = /(^|\s)lang\s*=/.test(attrs);
|
|
4977
|
+
const newAttrs = hasLang ? attrs.replace(/lang\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/i, `lang="${pageLang}"`) : `${attrs} lang="${pageLang}"`;
|
|
4978
|
+
return `<html${newAttrs}>`;
|
|
4979
|
+
});
|
|
4880
4980
|
const extraHead = setup2.bundlePreload + setup2.preloadExtraHead + setup2.metadataResult.perPageHead;
|
|
4881
4981
|
if (/<title[\s\S]*?<\/title>/i.test(extraHead)) {
|
|
4882
4982
|
headWithLang = headWithLang.replace(/<title[\s\S]*?<\/title>/i, "");
|
|
@@ -4884,6 +4984,7 @@ async function renderSSRDocumentStream(options) {
|
|
|
4884
4984
|
if (/<meta\s+name\s*=\s*['"]description['"][^>]*>/i.test(extraHead)) {
|
|
4885
4985
|
headWithLang = headWithLang.replace(/<meta\s+name\s*=\s*['"]description['"][^>]*>/i, "");
|
|
4886
4986
|
}
|
|
4987
|
+
headWithLang = removeOverriddenMetaTags(headWithLang, extraHead);
|
|
4887
4988
|
const config = await loadConfig(cwd);
|
|
4888
4989
|
const browserTelemetryConfigRaw = config.telemetry?.browser;
|
|
4889
4990
|
const { serializeBrowserTelemetryConfig: serializeBrowserTelemetryConfig2 } = await Promise.resolve().then(() => exports_serialize);
|
|
@@ -4932,7 +5033,7 @@ async function streamSSRContent(writer, encoder, ctx) {
|
|
|
4932
5033
|
try {
|
|
4933
5034
|
const combinedHead = deduplicateMetaTags([ctx.inlineStyleTag, ctx.head, ctx.extraHead].filter(Boolean).join(`
|
|
4934
5035
|
`));
|
|
4935
|
-
const headWithLangAndContent = ctx.headWithLang.replace(
|
|
5036
|
+
const headWithLangAndContent = ctx.headWithLang.replace(/<\/head>/i, `${combinedHead ? `${combinedHead}
|
|
4936
5037
|
` : ""}</head>`);
|
|
4937
5038
|
const headContent = `${headWithLangAndContent}`;
|
|
4938
5039
|
await writer.write(encoder.encode(headContent));
|
|
@@ -5076,6 +5177,7 @@ export {
|
|
|
5076
5177
|
renderSSRDocumentStream,
|
|
5077
5178
|
renderSSRDocument,
|
|
5078
5179
|
renderOGImageToPNG,
|
|
5180
|
+
removeOverriddenMetaTags,
|
|
5079
5181
|
processCollections,
|
|
5080
5182
|
preloadContentModule,
|
|
5081
5183
|
performSSRSetup,
|
|
@@ -5167,4 +5269,4 @@ export {
|
|
|
5167
5269
|
AI_CRAWLERS
|
|
5168
5270
|
};
|
|
5169
5271
|
|
|
5170
|
-
//# debugId=
|
|
5272
|
+
//# debugId=DE3402C7BA2E034A64756E2164756E21
|