WIP: chore: update to astro v5 #1

Draft
nicolas wants to merge 10 commits from update/v5 into main
19 changed files with 38 additions and 103 deletions
Showing only changes of commit 99ef7634e3 - Show all commits

3
.gitignore vendored
View File

@ -17,3 +17,6 @@ pnpm-debug.log*
# macOS-specific files # macOS-specific files
.DS_Store .DS_Store
# i18n
astro_tmp_pages_*

View File

@ -1,8 +1,5 @@
import { defineConfig } from "astro/config"; import { defineConfig } from "astro/config";
// https://github.com/alexandre-fernandez/astro-i18n
import i18n from "astro-i18n";
// https://astro.build/config // https://astro.build/config
import mdx from "@astrojs/mdx"; import mdx from "@astrojs/mdx";
import sitemap from "@astrojs/sitemap"; import sitemap from "@astrojs/sitemap";
@ -10,24 +7,15 @@ import sitemap from "@astrojs/sitemap";
// https://astro.build/config // https://astro.build/config
export default defineConfig({ export default defineConfig({
site: "https://www.nardu.in", site: "https://www.nardu.in",
build: {
format: "directory",
},
image: { image: {
domains: ["assets.nardu.in"], domains: ["assets.nardu.in"],
remotePatterns: [{ protocol: "https" }], remotePatterns: [{ protocol: "https" }],
}, },
markdown: {
syntaxHighlight: "prism",
},
integrations: [ integrations: [
i18n(),
mdx(), mdx(),
sitemap({ sitemap(),
i18n: {
defaultLocale: "fr", // All urls that don't contain `en`
locales: {
fr: "fr-FR", // The `defaultLocale` value must present in `locales` keys
en: "en-US",
},
},
}),
], ],
}); });

BIN
bun.lockb

Binary file not shown.

View File

@ -13,15 +13,14 @@
"i18n:sync": "astro-i18n sync" "i18n:sync": "astro-i18n sync"
}, },
"dependencies": { "dependencies": {
"@astrojs/mdx": "^1.1.0", "@astrojs/mdx": "4.0.3",
"@astrojs/rss": "^3.0.0", "@astrojs/rss": "4.0.10",
"@astrojs/sitemap": "^3.0.0", "@astrojs/sitemap": "3.2.1",
"astro": "3.1.4", "astro": "5.1.1",
"astro-i18n": "1.8.1", "sharp": "^0.33.4"
"sharp": "^0.32.6"
}, },
"devDependencies": { "devDependencies": {
"autoprefixer": "^10.4.13", "autoprefixer": "^10.4.19",
"postcss": "^8.4.20" "postcss": "^8.4.38"
} }
} }

View File

@ -1,11 +1,11 @@
--- ---
// import { renderContent } from "astro-i18n"; import { render } from "astro:content";
import MetaDate from "./MetaDate.astro"; import MetaDate from "./MetaDate.astro";
import TOC from "./TOC.astro"; import TOC from "./TOC.astro";
const { content } = Astro.props; const { content } = Astro.props;
const { Content, headings } = await content.render(); const { Content, headings } = await render(content);
// const { html, headings } = await renderContent(Astro, content);
const toc = headings.map((heading) => { const toc = headings.map((heading) => {
return heading; return heading;

View File

@ -1,6 +1,8 @@
import { z, defineCollection } from "astro:content"; import { z, defineCollection } from "astro:content";
import { glob } from 'astro/loaders';
const articles = defineCollection({ const articles = defineCollection({
loader: glob({ pattern: '**/[^_]*.md', base: "./src/content/articles" }),
schema: z.object({ schema: z.object({
title: z.string(), title: z.string(),
subtitle: z.string(), subtitle: z.string(),
@ -20,6 +22,7 @@ const articles = defineCollection({
}); });
const fragments = defineCollection({ const fragments = defineCollection({
loader: glob({ pattern: '**/[^_]*.md', base: "./src/content/fragments" }),
schema: z.object({ schema: z.object({
title: z.string(), title: z.string(),
subtitle: z.string(), subtitle: z.string(),
@ -39,6 +42,7 @@ const fragments = defineCollection({
}); });
const references = defineCollection({ const references = defineCollection({
loader: glob({ pattern: '**/[^_]*.md', base: "./src/content/references" }),
schema: z.object({ schema: z.object({
title: z.string(), title: z.string(),
subtitle: z.string(), subtitle: z.string(),

View File

@ -13,7 +13,7 @@ export const getStaticPaths = createStaticPaths(
return data.lang === langCode; return data.lang === langCode;
}); });
return articles.map((article) => ({ return articles.map((article) => ({
params: { slug: article.data.permalink }, params: { id: article.data.permalink },
props: { article }, props: { article },
})); }));
}, },

View File

@ -1,15 +0,0 @@
---
import Page from "../../articles/[slug].astro"
import { getStaticPaths as proxyGetStaticPaths } from "../../articles/[slug].astro"
import { extractRouteLangCode } from "astro-i18n"
/* @ts-ignore */
export const getStaticPaths = (props) => proxyGetStaticPaths({
...props,
langCode: extractRouteLangCode(import.meta.url),
})
const { props } = Astro
---
<Page {...props} />

View File

@ -1,6 +0,0 @@
---
import Page from "../../articles/index.astro"
const { props } = Astro
---
<Page {...props} />

View File

@ -1,6 +0,0 @@
---
import Page from "../index.astro"
const { props } = Astro
---
<Page {...props} />

View File

@ -1,6 +0,0 @@
---
import Page from "../plan-du-site.astro"
const { props } = Astro
---
<Page {...props} />

View File

@ -1,15 +0,0 @@
---
import Page from "../../fragments/[slug].astro"
import { getStaticPaths as proxyGetStaticPaths } from "../../fragments/[slug].astro"
import { extractRouteLangCode } from "astro-i18n"
/* @ts-ignore */
export const getStaticPaths = (props) => proxyGetStaticPaths({
...props,
langCode: extractRouteLangCode(import.meta.url),
})
const { props } = Astro
---
<Page {...props} />

View File

@ -1,6 +0,0 @@
---
import Page from "../../fragments/index.astro"
const { props } = Astro
---
<Page {...props} />

View File

@ -1,6 +0,0 @@
---
import Page from "../../veille/index.astro"
const { props } = Astro
---
<Page {...props} />

View File

@ -1,6 +0,0 @@
---
import Page from "../../references/index.astro"
const { props } = Astro
---
<Page {...props} />

View File

@ -13,7 +13,7 @@ export const getStaticPaths = createStaticPaths(
return data.lang === langCode; return data.lang === langCode;
}); });
return snippets.map((snippet) => ({ return snippets.map((snippet) => ({
params: { slug: snippet.data.permalink }, params: { id: snippet.data.permalink },
props: { snippet }, props: { snippet },
})); }));
}, },

View File

@ -1,7 +1,8 @@
--- ---
// init i18n // init i18n
import { l, t, astroI18n } from "astro-i18n"; import { getLocale } from "astro-i18n-aut";
astroI18n.init(Astro);
const locale = getLocale(Astro.url);
// import stuff // import stuff
import BaseLayout from "../layouts/BaseLayout.astro"; import BaseLayout from "../layouts/BaseLayout.astro";
@ -11,17 +12,19 @@ import ListCards from "../components/ListCards.astro";
const pageTitle = t("accueil"); const pageTitle = t("accueil");
// get all HP sections // get all HP sections
const allSections = await Astro.glob("../data/HP/**/*.md"); const allSections = Object.values(
import.meta.glob("../data/HP/**/*.md", { eager: true })
);
// only keep the right locale version // only keep the right locale version
const localizedSections = allSections.filter((section) => { const localizedSections = allSections.filter((section) => {
return section.frontmatter.lang === astroI18n.langCode; return section.frontmatter.lang === locale;
}); });
// New astro content collections // New astro content collections
import { getCollection } from "astro:content"; import { getCollection } from "astro:content";
// Only return posts with correct lang in the frontmatter // Only return posts with correct lang in the frontmatter
const localizedArticles = await getCollection("articles", ({ data }) => { const localizedArticles = await getCollection("articles", ({ data }) => {
return data.lang === astroI18n.langCode && !data.draft; return data.lang === locale && !data.draft;
}); });
// sort articles by descending publication date // sort articles by descending publication date
const sortedArticles = localizedArticles.sort( const sortedArticles = localizedArticles.sort(
@ -29,14 +32,14 @@ const sortedArticles = localizedArticles.sort(
); );
// Only return snippets with correct lang in the frontmatter // Only return snippets with correct lang in the frontmatter
const localizedSnippets = await getCollection("fragments", ({ data }) => { const localizedSnippets = await getCollection("fragments", ({ data }) => {
return data.lang === astroI18n.langCode && !data.draft; return data.lang === locale && !data.draft;
}); });
// sort articles by descending publication date // sort articles by descending publication date
const sortedSnippets = localizedSnippets.sort( const sortedSnippets = localizedSnippets.sort(
(a, b) => b.data.createdAt - a.data.createdAt (a, b) => b.data.createdAt - a.data.createdAt
); );
const localizedReferences = await getCollection("references", ({ data }) => { const localizedReferences = await getCollection("references", ({ data }) => {
return data.lang === astroI18n.langCode && !data.draft; return data.lang === locale && !data.draft;
}); });
--- ---

View File

@ -8,7 +8,9 @@ import BaseLayout from "../../layouts/BaseLayout.astro";
import MetaDate from "../../components/MetaDate.astro"; import MetaDate from "../../components/MetaDate.astro";
// get all content // get all content
const allSections = await Astro.glob("../../data/veille/**/*.md"); const allSections = Object.values(
import.meta.glob("../../data/veille/**/*.md", { eager: true })
);
// only keep the right locale version // only keep the right locale version
const localizedSections = allSections.filter((section) => { const localizedSections = allSections.filter((section) => {
return section.frontmatter.lang === astroI18n.langCode; return section.frontmatter.lang === astroI18n.langCode;

View File

@ -1,5 +1,7 @@
{ {
"extends": "astro/tsconfigs/base", "extends": "astro/tsconfigs/base",
"include": [".astro/types.d.ts", "**/*"],
"exclude": ["dist"],
"compilerOptions": { "compilerOptions": {
"strictNullChecks": true "strictNullChecks": true
} }