[ci] format
This commit is contained in:
parent
00fab4ce13
commit
41f4a8f9cb
7 changed files with 33 additions and 31 deletions
|
@ -52,7 +52,7 @@ const ASTRO_CONFIG_DEFAULTS: AstroUserConfig & any = {
|
||||||
vite: {},
|
vite: {},
|
||||||
legacy: {
|
legacy: {
|
||||||
astroFlavoredMarkdown: false,
|
astroFlavoredMarkdown: false,
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
async function resolvePostcssConfig(inlineOptions: any, root: URL): Promise<PostCSSConfigResult> {
|
async function resolvePostcssConfig(inlineOptions: any, root: URL): Promise<PostCSSConfigResult> {
|
||||||
|
@ -214,7 +214,10 @@ export const AstroConfigSchema = z.object({
|
||||||
.default(ASTRO_CONFIG_DEFAULTS.vite),
|
.default(ASTRO_CONFIG_DEFAULTS.vite),
|
||||||
legacy: z
|
legacy: z
|
||||||
.object({
|
.object({
|
||||||
astroFlavoredMarkdown: z.boolean().optional().default(ASTRO_CONFIG_DEFAULTS.legacy.astroFlavoredMarkdown),
|
astroFlavoredMarkdown: z
|
||||||
|
.boolean()
|
||||||
|
.optional()
|
||||||
|
.default(ASTRO_CONFIG_DEFAULTS.legacy.astroFlavoredMarkdown),
|
||||||
})
|
})
|
||||||
.optional()
|
.optional()
|
||||||
.default({}),
|
.default({}),
|
||||||
|
|
|
@ -175,7 +175,7 @@ export async function render(
|
||||||
logging,
|
logging,
|
||||||
markdown: {
|
markdown: {
|
||||||
...astroConfig.markdown,
|
...astroConfig.markdown,
|
||||||
isAstroFlavoredMd: astroConfig.legacy.astroFlavoredMarkdown
|
isAstroFlavoredMd: astroConfig.legacy.astroFlavoredMarkdown,
|
||||||
},
|
},
|
||||||
mod,
|
mod,
|
||||||
mode,
|
mode,
|
||||||
|
|
|
@ -59,7 +59,7 @@ export async function renderJSX(result: SSRResult, vnode: any): Promise<any> {
|
||||||
|
|
||||||
if (vnode.type) {
|
if (vnode.type) {
|
||||||
if (typeof vnode.type === 'function' && (vnode.type as any)['astro:renderer']) {
|
if (typeof vnode.type === 'function' && (vnode.type as any)['astro:renderer']) {
|
||||||
skipAstroJSXCheck.add(vnode.type)
|
skipAstroJSXCheck.add(vnode.type);
|
||||||
}
|
}
|
||||||
if (typeof vnode.type === 'function' && vnode.props['server:root']) {
|
if (typeof vnode.type === 'function' && vnode.props['server:root']) {
|
||||||
const output = await vnode.type(vnode.props ?? {});
|
const output = await vnode.type(vnode.props ?? {});
|
||||||
|
@ -91,7 +91,7 @@ export async function renderJSX(result: SSRResult, vnode: any): Promise<any> {
|
||||||
}
|
}
|
||||||
if (!isVNode(child)) {
|
if (!isVNode(child)) {
|
||||||
_slots.default.push(child);
|
_slots.default.push(child);
|
||||||
return
|
return;
|
||||||
}
|
}
|
||||||
if ('slot' in child.props) {
|
if ('slot' in child.props) {
|
||||||
_slots[child.props.slot] = [...(_slots[child.props.slot] ?? []), child];
|
_slots[child.props.slot] = [...(_slots[child.props.slot] ?? []), child];
|
||||||
|
@ -110,10 +110,12 @@ export async function renderJSX(result: SSRResult, vnode: any): Promise<any> {
|
||||||
const slotPromises = [];
|
const slotPromises = [];
|
||||||
const slots: Record<string, any> = {};
|
const slots: Record<string, any> = {};
|
||||||
for (const [key, value] of Object.entries(_slots)) {
|
for (const [key, value] of Object.entries(_slots)) {
|
||||||
slotPromises.push(renderJSX(result, value).then(output => {
|
slotPromises.push(
|
||||||
|
renderJSX(result, value).then((output) => {
|
||||||
if (output.toString().trim().length === 0) return;
|
if (output.toString().trim().length === 0) return;
|
||||||
slots[key] = () => output;
|
slots[key] = () => output;
|
||||||
}))
|
})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
await Promise.all(slotPromises);
|
await Promise.all(slotPromises);
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,7 @@ export const DEFAULT_REHYPE_PLUGINS = [];
|
||||||
/** Shared utility for rendering markdown */
|
/** Shared utility for rendering markdown */
|
||||||
export async function renderMarkdown(
|
export async function renderMarkdown(
|
||||||
content: string,
|
content: string,
|
||||||
opts: MarkdownRenderingOptions,
|
opts: MarkdownRenderingOptions
|
||||||
): Promise<MarkdownRenderingResult> {
|
): Promise<MarkdownRenderingResult> {
|
||||||
let {
|
let {
|
||||||
fileURL,
|
fileURL,
|
||||||
|
|
|
@ -35,7 +35,7 @@ describe('autolinking', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('astro-flavored md', () => {
|
describe('astro-flavored md', () => {
|
||||||
const renderAstroMd = text => renderMarkdown(text, { isAstroFlavoredMd: true });
|
const renderAstroMd = (text) => renderMarkdown(text, { isAstroFlavoredMd: true });
|
||||||
|
|
||||||
it('does not autolink URLs in code blocks', async () => {
|
it('does not autolink URLs in code blocks', async () => {
|
||||||
const { code } = await renderAstroMd(
|
const { code } = await renderAstroMd(
|
||||||
|
@ -104,5 +104,5 @@ describe('autolinking', () => {
|
||||||
`</strong></a>`
|
`</strong></a>`
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
})
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -67,10 +67,7 @@ describe('strictness in Astro-flavored markdown', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should allow attribute names starting with "@" after attribute names', async () => {
|
it('should allow attribute names starting with "@" after attribute names', async () => {
|
||||||
const { code } = await renderAstroMd(
|
const { code } = await renderAstroMd(`<button disabled @click="handleClick">Test</button>`, {});
|
||||||
`<button disabled @click="handleClick">Test</button>`,
|
|
||||||
{}
|
|
||||||
);
|
|
||||||
|
|
||||||
chai.expect(code.trim()).to.equal(`<button disabled @click="handleClick">Test</button>`);
|
chai.expect(code.trim()).to.equal(`<button disabled @click="handleClick">Test</button>`);
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue