mirror of
https://github.com/withastro/astro.git
synced 2025-01-13 22:11:20 -05:00
refactor(astro): code refactor (#11343)
This commit is contained in:
parent
e30cf49ee4
commit
6e459f03c6
7 changed files with 26 additions and 26 deletions
|
@ -215,14 +215,15 @@ async function ssrBuild(
|
|||
if (isContentCache) {
|
||||
prefix += `${buildID}/`;
|
||||
suffix = '.mjs';
|
||||
}
|
||||
|
||||
if (isContentCache && name.includes('/content/')) {
|
||||
if (name.includes('/content/')) {
|
||||
const parts = name.split('/');
|
||||
if (parts.at(1) === 'content') {
|
||||
return encodeName(parts.slice(1).join('/'));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Sometimes chunks have the `@_@astro` suffix due to SSR logic. Remove it!
|
||||
// TODO: refactor our build logic to avoid this
|
||||
if (name.includes(ASTRO_PAGE_EXTENSION_POST_PATTERN)) {
|
||||
|
|
|
@ -146,8 +146,7 @@ export async function getViteErrorPayload(err: ErrorWithMetadata): Promise<Astro
|
|||
let highlighterLang = err.loc?.file?.split('.').pop();
|
||||
if (ALTERNATIVE_JS_EXTS.includes(highlighterLang ?? '')) {
|
||||
highlighterLang = 'js';
|
||||
}
|
||||
if (ALTERNATIVE_MD_EXTS.includes(highlighterLang ?? '')) {
|
||||
} else if (ALTERNATIVE_MD_EXTS.includes(highlighterLang ?? '')) {
|
||||
highlighterLang = 'md';
|
||||
}
|
||||
const highlightedCode = err.fullCode
|
||||
|
|
|
@ -695,6 +695,10 @@ class ErrorOverlay extends HTMLElement {
|
|||
|
||||
const el = this.root.querySelector(selector);
|
||||
|
||||
if (!el) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (html) {
|
||||
// Automatically detect links
|
||||
text = text
|
||||
|
@ -706,14 +710,10 @@ class ErrorOverlay extends HTMLElement {
|
|||
return `<a target="_blank" href="${v}">${v}</a>`;
|
||||
})
|
||||
.join(' ');
|
||||
}
|
||||
|
||||
if (el) {
|
||||
if (!html) {
|
||||
el.textContent = text.trim();
|
||||
} else {
|
||||
el.innerHTML = text.trim();
|
||||
}
|
||||
} else {
|
||||
el.textContent = text.trim();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -56,15 +56,16 @@ export async function callMiddleware(
|
|||
let responseFunctionPromise: Promise<Response> | Response | undefined = undefined;
|
||||
const next: MiddlewareNext = async (payload) => {
|
||||
nextCalled = true;
|
||||
if (!enableRerouting && payload) {
|
||||
|
||||
if (enableRerouting) {
|
||||
responseFunctionPromise = responseFunction(apiContext, payload);
|
||||
} else {
|
||||
if (payload) {
|
||||
logger.warn(
|
||||
'router',
|
||||
'The rewrite API is experimental. To use this feature, add the `rewriting` flag to the `experimental` object in your Astro config.'
|
||||
);
|
||||
}
|
||||
if (enableRerouting) {
|
||||
responseFunctionPromise = responseFunction(apiContext, payload);
|
||||
} else {
|
||||
responseFunctionPromise = responseFunction(apiContext);
|
||||
}
|
||||
// We need to pass the APIContext pass to `callMiddleware` because it can be mutated across middleware functions
|
||||
|
|
|
@ -25,8 +25,7 @@ function redirectRouteGenerate(renderContext: RenderContext): string {
|
|||
let target = redirect;
|
||||
for (const param of Object.keys(params)) {
|
||||
const paramValue = params[param]!;
|
||||
target = target.replace(`[${param}]`, paramValue);
|
||||
target = target.replace(`[...${param}]`, paramValue);
|
||||
target = target.replace(`[${param}]`, paramValue).replace(`[...${param}]`, paramValue);
|
||||
}
|
||||
return target;
|
||||
} else if (typeof redirect === 'undefined') {
|
||||
|
|
|
@ -29,8 +29,7 @@ export function transformSlots(vnode: AstroVNode) {
|
|||
slots[name]['$$slot'] = true;
|
||||
delete child.props.slot;
|
||||
delete vnode.props.children;
|
||||
}
|
||||
if (Array.isArray(vnode.props.children)) {
|
||||
} else if (Array.isArray(vnode.props.children)) {
|
||||
// Handle many children with slot attributes
|
||||
vnode.props.children = vnode.props.children
|
||||
.map((child) => {
|
||||
|
|
|
@ -92,8 +92,9 @@ document.addEventListener('DOMContentLoaded', async () => {
|
|||
if (!(evt instanceof CustomEvent)) return;
|
||||
|
||||
const target = overlay.shadowRoot?.querySelector(`[data-app-id="${app.id}"]`);
|
||||
const notificationElement = target?.querySelector('.notification');
|
||||
if (!target || !notificationElement) return;
|
||||
if (!target) return;
|
||||
const notificationElement = target.querySelector('.notification');
|
||||
if (!notificationElement) return;
|
||||
|
||||
let newState = evt.detail.state ?? true;
|
||||
let level = notificationLevels.includes(evt?.detail?.level)
|
||||
|
|
Loading…
Add table
Reference in a new issue