diff --git a/packages/integrations/sitemap/package.json b/packages/integrations/sitemap/package.json index 833b9c0b3e64d..0e8d40dffef3d 100644 --- a/packages/integrations/sitemap/package.json +++ b/packages/integrations/sitemap/package.json @@ -33,7 +33,6 @@ "test": "mocha --timeout 20000" }, "dependencies": { - "fast-glob": "^3.2.11", "sitemap": "^7.1.1", "zod": "^3.17.3" }, diff --git a/packages/integrations/sitemap/src/index.ts b/packages/integrations/sitemap/src/index.ts index 0346ee8e8159b..33e72fa232171 100644 --- a/packages/integrations/sitemap/src/index.ts +++ b/packages/integrations/sitemap/src/index.ts @@ -5,14 +5,11 @@ import { type LinkItem as LinkItemBase, type SitemapItemLoose, } from 'sitemap'; -import { resolve } from 'path'; import { fileURLToPath } from 'url'; -import fg from 'fast-glob'; import { ZodError } from 'zod'; import { generateSitemap } from './generate-sitemap.js'; import { Logger } from './utils/logger.js'; -import { isRoutePrerendered } from './utils/is-route-prerendered.js'; import { validateOptions } from './validate-options.js'; export type ChangeFreq = `${EnumChangefreq}`; @@ -61,61 +58,15 @@ const createPlugin = (options?: SitemapOptions): AstroIntegration => { hooks: { 'astro:config:done': async ({ config: cfg }) => { - if (cfg.site) { - config = cfg; - } else { - // eslint-disable-next-line no-console - console.warn( - 'The Sitemap integration requires the `site` astro.config option. Skipping.' - ); - return; - } - }, - - 'astro:build:start': async () => { - if (config.output !== 'server' || !config.site) { - return; - } - - const srcPath = fileURLToPath(config.srcDir); - const pagesPath = resolve(srcPath, 'pages'); - - const pageFiles = await fg(`${pagesPath}/**/*.{astro,ts,js}`); - - const routes = ( - await Promise.all( - pageFiles.map(async (filePath) => { - const isPrerendered = await isRoutePrerendered(filePath); - const index = filePath.indexOf('pages/') + 6; - const routeSegment = filePath - .substring(index) - .replace(/\.(astro|ts|js)/, '') - .replace(/index$/, ''); - - /** - * @TODO - * figure out how to run `getStaticPaths` here. - */ - const isDynamicRoute = routeSegment.endsWith(']'); - const shouldIndex = !isDynamicRoute && !isPrerendered; - - return shouldIndex ? `${config.site}/${routeSegment}` : undefined; - }) - ) - ).filter((route): route is string => Boolean(route)); - const opts = validateOptions(config.site, options); - - opts.customPages = opts.customPages - ? Array.from(new Set([...routes, ...opts.customPages])) - : routes; - options = opts; - - logger.info(`build is starting + ${JSON.stringify(opts.customPages, null, 2)}`); + config = cfg; }, - 'astro:build:done': async ({ dir, pages }) => { + 'astro:build:done': async ({ dir, routes }) => { try { if (!config.site) { + logger.warn( + 'The Sitemap integration requires the `site` astro.config option. Skipping.' + ); return; } @@ -134,10 +85,22 @@ const createPlugin = (options?: SitemapOptions): AstroIntegration => { return; } - let pageUrls = pages.map((p) => { - const path = finalSiteUrl.pathname + p.pathname; - return new URL(path, finalSiteUrl).href; - }); + let pageUrls = routes.reduce((urls, r) => { + /** + * Dynamic URLs have entries with `undefined` pathnames + */ + if (r.pathname) { + /** + * remove the initial slash from relative pathname + * because `finalSiteUrl` always has trailing slash + */ + const path = finalSiteUrl.pathname + r.pathname.substring(1); + const newUrl = new URL(path, finalSiteUrl).href; + urls.push(newUrl); + } + + return urls; + }, []); try { if (filter) { @@ -149,7 +112,7 @@ const createPlugin = (options?: SitemapOptions): AstroIntegration => { } if (customPages) { - pageUrls = [...pageUrls, ...customPages]; + pageUrls = Array.from(new Set([...pageUrls, ...customPages])); } if (pageUrls.length === 0) { diff --git a/packages/integrations/sitemap/src/utils/is-route-prerendered.ts b/packages/integrations/sitemap/src/utils/is-route-prerendered.ts deleted file mode 100644 index 468e09ba8489e..0000000000000 --- a/packages/integrations/sitemap/src/utils/is-route-prerendered.ts +++ /dev/null @@ -1,8 +0,0 @@ -const REGEX_PRERENDER = /const prerender = true/g; -import { readFile } from 'fs/promises'; - -export async function isRoutePrerendered(filePath: string) { - const contents = await readFile(filePath, 'utf-8'); - - return REGEX_PRERENDER.test(contents); -} diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 9b41779ea4d54..d5adbfa94a77e 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -3575,13 +3575,11 @@ importers: astro: workspace:* astro-scripts: workspace:* chai: ^4.3.6 - fast-glob: ^3.2.11 mocha: ^9.2.2 sitemap: ^7.1.1 xml2js: 0.4.23 zod: ^3.17.3 dependencies: - fast-glob: 3.2.12 sitemap: 7.1.1 zod: 3.20.6 devDependencies: