From 602106ac9dff2510683560d508ebcd1e4040e328 Mon Sep 17 00:00:00 2001 From: zenn Date: Wed, 27 May 2026 11:29:33 +0900 Subject: [PATCH] =?UTF-8?q?=EA=B2=8C=EC=8B=9C=EA=B8=80=20=EC=83=81?= =?UTF-8?q?=EC=84=B8=20=EB=AA=A9=EC=B0=A8=20=EC=82=AC=EC=9D=B4=EB=93=9C?= =?UTF-8?q?=EB=B0=94=20=EC=B6=94=EA=B0=80=20v1.5.12?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../content/ContentMarkdownRenderer.vue | 15 +++- components/content/ProseHeading.vue | 7 +- components/site/RightSidebar.vue | 38 +++++++- docs/changelog.md | 6 ++ docs/history.md | 4 + docs/map.md | 5 +- docs/spec.md | 1 + docs/update.md | 6 ++ lib/markdown-toc.js | 89 +++++++++++++++++++ package-lock.json | 4 +- package.json | 2 +- pages/post/[slug].vue | 12 +++ 12 files changed, 181 insertions(+), 8 deletions(-) create mode 100644 lib/markdown-toc.js diff --git a/components/content/ContentMarkdownRenderer.vue b/components/content/ContentMarkdownRenderer.vue index 4102177..2d11d87 100644 --- a/components/content/ContentMarkdownRenderer.vue +++ b/components/content/ContentMarkdownRenderer.vue @@ -21,6 +21,7 @@ import { import { buildCodeBlockLines, parseCodeFenceLine } from '../../lib/markdown-code-block.js' import { buildToggleBlockLines } from '../../lib/markdown-toggle.js' import { CALLOUT_BACKGROUND_OPTIONS, parseCalloutOptions } from '../../lib/markdown-callout.js' +import { createHeadingIdFactory } from '../../lib/markdown-toc.js' import ContentMarkdownCodeBlockEditor from './ContentMarkdownCodeBlockEditor.vue' import ProseCodeBlock from './ProseCodeBlock.vue' import ContentMarkdownCalloutEditor from './ContentMarkdownCalloutEditor.vue' @@ -731,6 +732,18 @@ const parseMarkdownBlocks = (markdown) => { } const blocks = computed(() => parseMarkdownBlocks(props.content)) +const headingIdsByBlock = computed(() => { + const createHeadingId = createHeadingIdFactory() + const ids = {} + + for (const block of blocks.value) { + if (block.type === 'heading' && block.level >= 1 && block.level <= 3) { + ids[block.id] = createHeadingId(block.text) + } + } + + return ids +}) /** @type {import('vue').ComputedRef} 문서 맨 아래 단일 이미지 삽입 줄 */ const tailInsertBeforeLine = computed(() => { @@ -2323,7 +2336,7 @@ onBeforeUnmount(() => { @delete-line="onDeleteLine" @merge-with-previous="onMergeWithPreviousLine(block.meta.startLine, $event)" /> - +