mirror of
https://github.com/withastro/astro.git
synced 2025-01-20 22:12:38 -05:00
64 lines
1.4 KiB
JavaScript
64 lines
1.4 KiB
JavaScript
|
import fs from 'node:fs/promises';
|
||
|
import { loremIpsumMd } from './_util.js';
|
||
|
|
||
|
/**
|
||
|
* @param {URL} projectDir
|
||
|
*/
|
||
|
export async function run(projectDir) {
|
||
|
await fs.rm(projectDir, { recursive: true, force: true });
|
||
|
await fs.mkdir(new URL('./src/pages/blog', projectDir), { recursive: true });
|
||
|
await fs.mkdir(new URL('./src/content/blog', projectDir), { recursive: true });
|
||
|
await fs.copyFile(new URL('./image.jpg', import.meta.url), new URL('./src/image.jpg', projectDir));
|
||
|
|
||
|
const promises = [];
|
||
|
|
||
|
|
||
|
for (let i = 0; i < 10000; i++) {
|
||
|
const content = `\
|
||
|
# Article ${i}
|
||
|
|
||
|
${loremIpsumMd}
|
||
|
|
||
|
![image ${i}](../../image.jpg)
|
||
|
|
||
|
|
||
|
`;
|
||
|
promises.push(
|
||
|
fs.writeFile(new URL(`./src/content/blog/article-${i}.md`, projectDir), content, 'utf-8')
|
||
|
);
|
||
|
}
|
||
|
|
||
|
|
||
|
await fs.writeFile(
|
||
|
new URL(`./src/pages/blog/[...slug].astro`, projectDir),
|
||
|
`\
|
||
|
---
|
||
|
import { getCollection } from 'astro:content';
|
||
|
export async function getStaticPaths() {
|
||
|
const blogEntries = await getCollection('blog');
|
||
|
return blogEntries.map(entry => ({
|
||
|
params: { slug: entry.slug }, props: { entry },
|
||
|
}));
|
||
|
}
|
||
|
const { entry } = Astro.props;
|
||
|
const { Content } = await entry.render();
|
||
|
---
|
||
|
<h1>{entry.data.title}</h1>
|
||
|
<Content />
|
||
|
`,
|
||
|
'utf-8'
|
||
|
);
|
||
|
|
||
|
await Promise.all(promises);
|
||
|
|
||
|
await fs.writeFile(
|
||
|
new URL('./astro.config.js', projectDir),
|
||
|
`\
|
||
|
import { defineConfig } from 'astro/config';
|
||
|
|
||
|
export default defineConfig({
|
||
|
});`,
|
||
|
'utf-8'
|
||
|
);
|
||
|
}
|