diff options
| author | nsfisis <nsfisis@gmail.com> | 2025-11-02 17:49:34 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2025-11-02 17:49:34 +0900 |
| commit | 57315c52be96d2a2c013f0cfb0de5429980e301a (patch) | |
| tree | 5d691497772fddfe401cd970ead4e9a74b34ef38 /services/nuldoc/nuldoc-src/components/TableOfContents.tsx | |
| parent | cf4091a93ed831456e8b30e2a9e1fc2650dcae02 (diff) | |
| download | nsfisis.dev-57315c52be96d2a2c013f0cfb0de5429980e301a.tar.gz nsfisis.dev-57315c52be96d2a2c013f0cfb0de5429980e301a.tar.zst nsfisis.dev-57315c52be96d2a2c013f0cfb0de5429980e301a.zip | |
refactor(blog): rename directory, services/{blog => nuldoc}/
Diffstat (limited to 'services/nuldoc/nuldoc-src/components/TableOfContents.tsx')
| -rw-r--r-- | services/nuldoc/nuldoc-src/components/TableOfContents.tsx | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/services/nuldoc/nuldoc-src/components/TableOfContents.tsx b/services/nuldoc/nuldoc-src/components/TableOfContents.tsx new file mode 100644 index 0000000..29907d0 --- /dev/null +++ b/services/nuldoc/nuldoc-src/components/TableOfContents.tsx @@ -0,0 +1,33 @@ +import { TocEntry, TocRoot } from "../djot/document.ts"; + +type Props = { + toc: TocRoot; +}; + +export default function TableOfContents({ toc }: Props) { + return ( + <nav className="toc"> + <h2>目次</h2> + <ul> + {toc.entries.map((entry, index) => ( + <TocEntryComponent key={String(index)} entry={entry} /> + ))} + </ul> + </nav> + ); +} + +function TocEntryComponent({ entry }: { entry: TocEntry }) { + return ( + <li> + <a href={`#${entry.id}`}>{entry.text}</a> + {entry.children.length > 0 && ( + <ul> + {entry.children.map((child, index) => ( + <TocEntryComponent key={String(index)} entry={child} /> + ))} + </ul> + )} + </li> + ); +} |
