Files
gpx.studio/website/src/lib/sitemap.ts

38 lines
1.2 KiB
TypeScript
Raw Normal View History

2024-06-26 20:33:01 +02:00
import fs from 'fs';
2024-07-08 19:07:33 +02:00
import { glob } from 'glob';
import { languages } from '$lib/languages';
2024-06-26 20:33:01 +02:00
function generateSitemap() {
2024-07-08 19:07:33 +02:00
const pages = glob.sync('*.html', { cwd: 'build' });
2024-06-26 20:33:01 +02:00
2024-07-08 19:07:33 +02:00
let sitemap = '<?xml version="1.0" encoding="UTF-8"?>\n';
sitemap += '<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"> xmlns:xhtml="http://www.w3.org/1999/xhtml">\n';
pages.forEach((page) => {
const url = page.replace('.html', '').replace('index', '');
if (languages[url]) {
// Skip localized pages
return;
}
Object.keys(languages).forEach((language) => {
sitemap += `<url>\n`;
sitemap += ` <loc>https://gpx.studio/${language === 'en' ? '' : language + '/'}${url}</loc>\n`;
Object.keys(languages).forEach((alternate) => {
if (alternate === language) return;
sitemap += ` <xhtml:link rel="alternate" hreflang="${alternate}" href="https://gpx.studio/${alternate === 'en' ? '' : alternate + '/'}${url}" />\n`;
});
sitemap += `</url>\n`;
});
});
sitemap += '</urlset>';
return sitemap;
2024-06-26 20:33:01 +02:00
}
fs.writeFileSync('build/sitemap.xml', generateSitemap());