Refactor routing in App component to enhance navigation and improve error handling by integrating dynamic routes and updating the NotFound route.

This commit is contained in:
becarta
2025-05-23 12:43:00 +02:00
parent f40db0f5c9
commit a544759a3b
11127 changed files with 1647032 additions and 0 deletions

View File

@@ -0,0 +1,6 @@
import { type Plugin as VitePlugin } from 'vite';
import type { AstroSettings } from '../@types/astro.js';
/** Returns a Vite plugin used to alias paths from tsconfig.json and jsconfig.json. */
export default function configAliasVitePlugin({ settings, }: {
settings: AstroSettings;
}): VitePlugin | null;

View File

@@ -0,0 +1,93 @@
import path from "node:path";
import { normalizePath } from "vite";
const getConfigAlias = (settings) => {
const { tsConfig, tsConfigPath } = settings;
if (!tsConfig || !tsConfigPath || !tsConfig.compilerOptions) return null;
const { baseUrl, paths } = tsConfig.compilerOptions;
if (!baseUrl) return null;
const resolvedBaseUrl = path.resolve(path.dirname(tsConfigPath), baseUrl);
const aliases = [];
if (paths) {
for (const [alias, values] of Object.entries(paths)) {
const find = new RegExp(
`^${[...alias].map(
(segment) => segment === "*" ? "(.+)" : segment.replace(/[\\^$*+?.()|[\]{}]/, "\\$&")
).join("")}$`
);
let matchId = 0;
for (const value of values) {
const replacement = [...normalizePath(path.resolve(resolvedBaseUrl, value))].map((segment) => segment === "*" ? `$${++matchId}` : segment === "$" ? "$$" : segment).join("");
aliases.push({ find, replacement });
}
}
}
aliases.push({
find: /^(?!\.*\/|\.*$|\w:)(.+)$/,
replacement: `${[...normalizePath(resolvedBaseUrl)].map((segment) => segment === "$" ? "$$" : segment).join("")}/$1`
});
return aliases;
};
function configAliasVitePlugin({
settings
}) {
const configAlias = getConfigAlias(settings);
if (!configAlias) return null;
const plugin = {
name: "astro:tsconfig-alias",
// use post to only resolve ids that all other plugins before it can't
enforce: "post",
configResolved(config) {
patchCreateResolver(config, plugin);
},
async resolveId(id, importer, options) {
if (isVirtualId(id)) return;
for (const alias of configAlias) {
if (alias.find.test(id)) {
const updatedId = id.replace(alias.find, alias.replacement);
if (updatedId.includes("*")) {
return updatedId;
}
const resolved = await this.resolve(updatedId, importer, { skipSelf: true, ...options });
if (resolved) return resolved;
}
}
}
};
return plugin;
}
function patchCreateResolver(config, postPlugin) {
const _createResolver = config.createResolver;
config.createResolver = function(...args1) {
const resolver = _createResolver.apply(config, args1);
return async function(...args2) {
const id = args2[0];
const importer = args2[1];
const ssr = args2[3];
if (importer?.includes("node_modules")) {
return resolver.apply(_createResolver, args2);
}
const fakePluginContext = {
resolve: (_id, _importer) => resolver(_id, _importer, false, ssr)
};
const fakeResolveIdOpts = {
assertions: {},
isEntry: false,
ssr
};
const result = await resolver.apply(_createResolver, args2);
if (result) return result;
const resolved = await postPlugin.resolveId.apply(fakePluginContext, [
id,
importer,
fakeResolveIdOpts
]);
if (resolved) return resolved;
};
};
}
function isVirtualId(id) {
return id.includes("\0") || id.startsWith("virtual:") || id.startsWith("astro:");
}
export {
configAliasVitePlugin as default
};