mirror of
https://github.com/supabase/supabase.git
synced 2026-07-04 03:54:29 +08:00
* set up multiple themes in studio * set up multiple themes in studio * set up multiple themes in docs and www * update all resolvedTheme to also include deep-dark * update all resolvedTheme checks to also include deep-dark * update tailwind.config.js tokens * update tailwind.config.js tokens * update leftover scale12 token * update if resolvedTheme _doesn't_ include 'dark' * update more styling tokens * add dynamic themes to CmdK * fix nav and footer for multi theme * add data-theme selector output to transformTokens.js * update code-hike.css to target data-theme css * update tailwindcss to ^3.3.5 * ThemeImage with light and dark src for www and docs * add brand-button styling token * update old dark theme boolean * update old dark theme boolean * make homepage product visuals themeable * update product page themed images * update badge green with brand * fix roles list appearance * fix auth widget in auth page * update more dark logic * update more dark logic * add button default bg and border * update pricing page theme styling * clean up Themeimage * remove forceDark in homepage * update dark:border-dark occurrences * update dark:border-dark occurrences * fix dark mode base colors * remove foreground-strong * fix notification badge bg * remove some dark: selectors * update dark: selectors * update code-hike deep dark bg color * fix comment typo * update border-button-hover token * fix customer story logo * remove some more dark: selectors * restore forceDark in www homepage * fix auth react icon * fix homepage product visuals * remove theme * add brand-link token * fix checkbox bg * npm install * more visible EntityListItem active bg * fix --background-alternative-default css vars --------- Co-authored-by: Jonathan Summers-Muir <MildTomato@users.noreply.github.com>
59 lines
1.4 KiB
TypeScript
59 lines
1.4 KiB
TypeScript
import { FC } from 'react'
|
|
import { removeAnchor } from './CustomHTMLElements/CustomHTMLElements.utils'
|
|
|
|
const formatSlug = (slug: string) => {
|
|
// [Joshen] We will still provide support for headers declared like this:
|
|
// ## REST API {#rest-api-overview}
|
|
// At least for now, this was a docusaurus thing.
|
|
if (slug.includes('#')) return slug.split('#')[1]
|
|
return slug
|
|
}
|
|
|
|
const formatTOCHeader = (content: string) => {
|
|
let begin = false
|
|
const res = []
|
|
for (const x of content) {
|
|
if (x === '`') {
|
|
if (!begin) {
|
|
begin = true
|
|
res.push(`<code class="text-xs border rounded bg-muted">`)
|
|
} else {
|
|
begin = false
|
|
res.push(`</code>`)
|
|
}
|
|
} else {
|
|
res.push(x)
|
|
}
|
|
}
|
|
return res.join('')
|
|
}
|
|
|
|
interface TOCHeader {
|
|
id: number
|
|
level: number
|
|
text: string
|
|
link: string
|
|
}
|
|
|
|
interface Props {
|
|
list: TOCHeader[]
|
|
}
|
|
|
|
const GuidesTableOfContents: FC<Props> = ({ list }) => {
|
|
return (
|
|
<ul className="toc-menu list-none pl-5 text-[0.8rem] grid gap-2">
|
|
{list.map((item, i) => (
|
|
<li key={`${item.level}-${i}`} className={item.level === 3 ? 'ml-4' : ''}>
|
|
<a
|
|
href={`#${formatSlug(item.link)}`}
|
|
className="text-foreground-lighter hover:text-brand-link transition-colors"
|
|
dangerouslySetInnerHTML={{ __html: formatTOCHeader(removeAnchor(item.text)) }}
|
|
/>
|
|
</li>
|
|
))}
|
|
</ul>
|
|
)
|
|
}
|
|
|
|
export default GuidesTableOfContents
|