Tabs
Show multiple code blocks in tabs.
content.mdx
<CodeWithTabs>```js !!tabs main.jsfunction lorem(ipsum, dolor = 1) {const sit = ipsum == null ? 0 : ipsum.sitdolor = sit - amet(dolor)return sit ? consectetur(ipsum) : []}``````css !!tabs styles.cssbody {margin: 0;padding: 0;}```</CodeWithTabs>
function lorem(ipsum, dolor = 1) {const sit = ipsum == null ? 0 : ipsum.sitdolor = sit - amet(dolor)return sit ? consectetur(ipsum) : []}
Implementation
We use the Tabs
components from shadcn/ui:
npx shadcn-ui@latest add tabs
And then create a component to handle multiple codeblocks as tabs:
code.tsx
import { Block, CodeBlock, parseProps } from "codehike/blocks"import { Pre, highlight } from "codehike/code"import { z } from "zod"import { Tabs, TabsContent, TabsList, TabsTrigger } from "@/components/ui/tabs"const Schema = Block.extend({ tabs: z.array(CodeBlock) })async function CodeWithTabs(props: unknown) {const { tabs } = parseProps(props, Schema)return <CodeTabs tabs={tabs} />}export async function CodeTabs(props: { tabs: RawCode[] }) {const { tabs } = propsconst highlighted = await Promise.all(tabs.map((tab) => highlight(tab, "github-dark")),)return (<Tabs defaultValue={tabs[0]?.meta} className=""><TabsList className="">{tabs.map((tab) => (<TabsTrigger key={tab.meta} value={tab.meta}>{tab.meta}</TabsTrigger>))}</TabsList>{tabs.map((tab, i) => (<TabsContent key={tab.meta} value={tab.meta} className=""><Pre code={highlighted[i]} className="" /></TabsContent>))}</Tabs>)}