mirror of
https://github.com/supabase/supabase.git
synced 2026-05-07 09:20:21 -04:00
dda0b526ac
wip <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit # Release Notes * **New Features** * Added a new Learn application offering foundational Supabase courses with interactive documentation * Courses include Architecture, Authentication, Data Fundamentals, Security, Storage, Realtime, and Edge Functions * Chapter tracking and progress indicators for course completions * Responsive sidebar navigation with search/command menu * Theme switching support (light, dark, classic dark modes) * Mobile-friendly course interface <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: Alan Daniel <stylesshjs@gmail.com> Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com>
80 lines
1.5 KiB
TypeScript
80 lines
1.5 KiB
TypeScript
// @ts-nocheck
|
|
// TODO: I'll fix this later.
|
|
|
|
import { toc } from 'mdast-util-toc'
|
|
import { remark } from 'remark'
|
|
import { visit } from 'unist-util-visit'
|
|
|
|
const textTypes = ['text', 'emphasis', 'strong', 'inlineCode']
|
|
|
|
function flattenNode(node) {
|
|
const p = []
|
|
visit(node, (node) => {
|
|
if (!textTypes.includes(node.type)) return
|
|
p.push(node.value)
|
|
})
|
|
return p.join(``)
|
|
}
|
|
|
|
interface Item {
|
|
title: string
|
|
url: string
|
|
items?: Item[]
|
|
}
|
|
|
|
interface Items {
|
|
items?: Item[]
|
|
}
|
|
|
|
function getItems(node, current): Items {
|
|
if (!node) {
|
|
return {}
|
|
}
|
|
|
|
if (node.type === 'paragraph') {
|
|
visit(node, (item) => {
|
|
if (item.type === 'link') {
|
|
current.url = item.url
|
|
current.title = flattenNode(node)
|
|
}
|
|
|
|
if (item.type === 'text') {
|
|
current.title = flattenNode(node)
|
|
}
|
|
})
|
|
|
|
return current
|
|
}
|
|
|
|
if (node.type === 'list') {
|
|
current.items = node.children.map((i) => getItems(i, {}))
|
|
|
|
return current
|
|
} else if (node.type === 'listItem') {
|
|
const heading = getItems(node.children[0], {})
|
|
|
|
if (node.children.length > 1) {
|
|
getItems(node.children[1], heading)
|
|
}
|
|
|
|
return heading
|
|
}
|
|
|
|
return {}
|
|
}
|
|
|
|
const getToc = () => (node, file) => {
|
|
const table = toc(node)
|
|
const items = getItems(table.map, {})
|
|
|
|
file.data = items
|
|
}
|
|
|
|
export type TableOfContents = Items
|
|
|
|
export async function getTableOfContents(content: string): Promise<TableOfContents> {
|
|
const result = await remark().use(getToc).process(content)
|
|
|
|
return result.data
|
|
}
|