From abb3530475da33cc17d4bc108ee9611300a47131 Mon Sep 17 00:00:00 2001 From: Puru Date: Sat, 16 Sep 2023 18:37:47 +0530 Subject: [PATCH 1/3] feat: OnThisPage blog ### Before submitting the PR, please make sure you do the following - [ ] It's really useful if your PR references an issue where it is discussed ahead of time. In many cases, features are absent for a reason. For large changes, please create an RFC: https://github.com/sveltejs/rfcs - [ ] Prefix your PR title with `feat:`, `fix:`, `chore:`, or `docs:`. - [ ] This message body should clearly illustrate what problems it solves. - [ ] Ideally, include a test that fails without this PR but passes with it. ### Tests and linting - [ ] Run the tests with `pnpm test` and lint the project with `pnpm lint` --- sites/svelte.dev/src/lib/server/blog/index.js | 4 +++- sites/svelte.dev/src/lib/server/blog/types.d.ts | 3 +++ sites/svelte.dev/src/lib/server/docs/index.js | 3 ++- .../src/routes/blog/[slug]/+page.svelte | 16 ++++++++++++++-- 4 files changed, 22 insertions(+), 4 deletions(-) diff --git a/sites/svelte.dev/src/lib/server/blog/index.js b/sites/svelte.dev/src/lib/server/blog/index.js index 40bbf4ef48a9..d0bcbe96c70b 100644 --- a/sites/svelte.dev/src/lib/server/blog/index.js +++ b/sites/svelte.dev/src/lib/server/blog/index.js @@ -2,6 +2,7 @@ import { extractFrontmatter } from '@sveltejs/site-kit/markdown'; import { CONTENT_BASE_PATHS } from '../../../constants.js'; import { render_content } from '../renderer.js'; +import { get_sections } from '../docs/index.js'; /** * @param {import('./types').BlogData} blog_data @@ -47,7 +48,8 @@ export async function get_blog_data(base = CONTENT_BASE_PATHS.BLOG) { author: { name: metadata.author, url: metadata.authorURL - } + }, + sections: await get_sections(body) }); } diff --git a/sites/svelte.dev/src/lib/server/blog/types.d.ts b/sites/svelte.dev/src/lib/server/blog/types.d.ts index e962e88953f8..cc2ee90f28ac 100644 --- a/sites/svelte.dev/src/lib/server/blog/types.d.ts +++ b/sites/svelte.dev/src/lib/server/blog/types.d.ts @@ -1,3 +1,5 @@ +import type { Section } from '../docs/types'; + export interface BlogPost { title: string; description: string; @@ -11,6 +13,7 @@ export interface BlogPost { }; draft: boolean; content: string; + sections: Section[]; } export type BlogData = BlogPost[]; diff --git a/sites/svelte.dev/src/lib/server/docs/index.js b/sites/svelte.dev/src/lib/server/docs/index.js index 4a4f9d6e42e7..8e5e591115d4 100644 --- a/sites/svelte.dev/src/lib/server/docs/index.js +++ b/sites/svelte.dev/src/lib/server/docs/index.js @@ -107,11 +107,12 @@ const titled = async (str) => .replace(/"/g, '"') .replace(/</g, '<') .replace(/>/g, '>') + .replace(/&/, '&') .replace(/<(\/)?(em|b|strong|code)>/g, '') ); /** @param {string} markdown */ -async function get_sections(markdown) { +export async function get_sections(markdown) { const lines = markdown.split('\n'); const root = /** @type {import('./types').Section} */ ({ title: 'Root', diff --git a/sites/svelte.dev/src/routes/blog/[slug]/+page.svelte b/sites/svelte.dev/src/routes/blog/[slug]/+page.svelte index 03421d89bb2e..59255b6ea7ef 100644 --- a/sites/svelte.dev/src/routes/blog/[slug]/+page.svelte +++ b/sites/svelte.dev/src/routes/blog/[slug]/+page.svelte @@ -1,6 +1,6 @@