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:
150
node_modules/astro/dist/core/util.js
generated
vendored
Normal file
150
node_modules/astro/dist/core/util.js
generated
vendored
Normal file
@@ -0,0 +1,150 @@
|
||||
import fs from "node:fs";
|
||||
import path from "node:path";
|
||||
import { fileURLToPath } from "node:url";
|
||||
import { SUPPORTED_MARKDOWN_FILE_EXTENSIONS } from "./constants.js";
|
||||
import { removeTrailingForwardSlash, slash } from "./path.js";
|
||||
function isObject(value) {
|
||||
return typeof value === "object" && value != null;
|
||||
}
|
||||
function isURL(value) {
|
||||
return Object.prototype.toString.call(value) === "[object URL]";
|
||||
}
|
||||
function isMarkdownFile(fileId, option) {
|
||||
const _suffix = option?.suffix ?? "";
|
||||
for (let markdownFileExtension of SUPPORTED_MARKDOWN_FILE_EXTENSIONS) {
|
||||
if (fileId.endsWith(`${markdownFileExtension}${_suffix}`)) return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
function arraify(target) {
|
||||
return Array.isArray(target) ? target : [target];
|
||||
}
|
||||
function padMultilineString(source, n = 2) {
|
||||
const lines = source.split(/\r?\n/);
|
||||
return lines.map((l) => ` `.repeat(n) + l).join(`
|
||||
`);
|
||||
}
|
||||
const STATUS_CODE_PAGES = /* @__PURE__ */ new Set(["/404", "/500"]);
|
||||
function getOutputFilename(astroConfig, name, type) {
|
||||
if (type === "endpoint") {
|
||||
return name;
|
||||
}
|
||||
if (name === "/" || name === "") {
|
||||
return path.posix.join(name, "index.html");
|
||||
}
|
||||
if (astroConfig.build.format === "file" || STATUS_CODE_PAGES.has(name)) {
|
||||
return `${removeTrailingForwardSlash(name || "index")}.html`;
|
||||
}
|
||||
return path.posix.join(name, "index.html");
|
||||
}
|
||||
function parseNpmName(spec) {
|
||||
if (!spec || spec[0] === "." || spec[0] === "/") return void 0;
|
||||
let scope;
|
||||
let name = "";
|
||||
let parts = spec.split("/");
|
||||
if (parts[0][0] === "@") {
|
||||
scope = parts[0];
|
||||
name = parts.shift() + "/";
|
||||
}
|
||||
name += parts.shift();
|
||||
let subpath = parts.length ? `./${parts.join("/")}` : void 0;
|
||||
return {
|
||||
scope,
|
||||
name,
|
||||
subpath
|
||||
};
|
||||
}
|
||||
function viteID(filePath) {
|
||||
return slash(fileURLToPath(filePath) + filePath.search);
|
||||
}
|
||||
const VALID_ID_PREFIX = `/@id/`;
|
||||
const NULL_BYTE_PLACEHOLDER = `__x00__`;
|
||||
function unwrapId(id) {
|
||||
return id.startsWith(VALID_ID_PREFIX) ? id.slice(VALID_ID_PREFIX.length).replace(NULL_BYTE_PLACEHOLDER, "\0") : id;
|
||||
}
|
||||
function resolvePages(config) {
|
||||
return new URL("./pages", config.srcDir);
|
||||
}
|
||||
function isInPagesDir(file, config) {
|
||||
const pagesDir = resolvePages(config);
|
||||
return file.toString().startsWith(pagesDir.toString());
|
||||
}
|
||||
function isInjectedRoute(file, settings) {
|
||||
let fileURL = file.toString();
|
||||
for (const route of settings.resolvedInjectedRoutes) {
|
||||
if (route.resolvedEntryPoint && fileURL === route.resolvedEntryPoint.toString()) return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
function isPublicRoute(file, config) {
|
||||
const rootDir = config.root.toString();
|
||||
const pagesDir = resolvePages(config).toString();
|
||||
const fileDir = file.toString();
|
||||
const normalizedDir = fileDir.startsWith(pagesDir) ? fileDir.slice(pagesDir.length) : fileDir.slice(rootDir.length);
|
||||
const parts = normalizedDir.replace(pagesDir.toString(), "").split("/").slice(1);
|
||||
for (const part of parts) {
|
||||
if (part.startsWith("_")) return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
function endsWithPageExt(file, settings) {
|
||||
for (const ext of settings.pageExtensions) {
|
||||
if (file.toString().endsWith(ext)) return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
function isPage(file, settings) {
|
||||
if (!isInPagesDir(file, settings.config) && !isInjectedRoute(file, settings)) return false;
|
||||
if (!isPublicRoute(file, settings.config)) return false;
|
||||
return endsWithPageExt(file, settings);
|
||||
}
|
||||
function isEndpoint(file, settings) {
|
||||
if (!isInPagesDir(file, settings.config) && !isInjectedRoute(file, settings)) return false;
|
||||
if (!isPublicRoute(file, settings.config)) return false;
|
||||
return !endsWithPageExt(file, settings) && !file.toString().includes("?astro");
|
||||
}
|
||||
function isServerLikeOutput(config) {
|
||||
return config.output === "server" || config.output === "hybrid";
|
||||
}
|
||||
function isModeServerWithNoAdapter(settings) {
|
||||
return isServerLikeOutput(settings.config) && !settings.adapter;
|
||||
}
|
||||
function isContentCollectionsCacheEnabled(config) {
|
||||
return config.experimental.contentCollectionCache && // contentCollectionsCache is an SSG only feature
|
||||
!isServerLikeOutput(config);
|
||||
}
|
||||
function resolveJsToTs(filePath) {
|
||||
if (filePath.endsWith(".jsx") && !fs.existsSync(filePath)) {
|
||||
const tryPath = filePath.slice(0, -4) + ".tsx";
|
||||
if (fs.existsSync(tryPath)) {
|
||||
return tryPath;
|
||||
}
|
||||
}
|
||||
return filePath;
|
||||
}
|
||||
function ensureProcessNodeEnv(defaultNodeEnv) {
|
||||
if (!process.env.NODE_ENV) {
|
||||
process.env.NODE_ENV = defaultNodeEnv;
|
||||
}
|
||||
}
|
||||
export {
|
||||
NULL_BYTE_PLACEHOLDER,
|
||||
VALID_ID_PREFIX,
|
||||
arraify,
|
||||
ensureProcessNodeEnv,
|
||||
getOutputFilename,
|
||||
isContentCollectionsCacheEnabled,
|
||||
isEndpoint,
|
||||
isMarkdownFile,
|
||||
isModeServerWithNoAdapter,
|
||||
isObject,
|
||||
isPage,
|
||||
isServerLikeOutput,
|
||||
isURL,
|
||||
padMultilineString,
|
||||
parseNpmName,
|
||||
resolveJsToTs,
|
||||
resolvePages,
|
||||
unwrapId,
|
||||
viteID
|
||||
};
|
Reference in New Issue
Block a user