Appearance
Code block header customization
The code block component exposes a flexible header API to adapt the header to your app UX:
- Toggle header on/off
- Show or hide built-in toolbar buttons (copy, expand, preview, font-size)
- Replace the left/right header content via named slots (
header-left,header-right)
Slots
header-left— Replace the left side of the headerheader-right— Replace the right side of the headerloading— Customize loading placeholder when streaming is disabled
Examples
Below are a few common examples. You can find the full set of examples in the project README; these are the most useful patterns to re-use in your app.
Hide the header (simple)
vue
<CodeBlockNode
:node="{ type: 'code_block', language: 'javascript', code: 'console.log(1)', raw: 'console.log(1)' }"
:showHeader="false"
:loading="false"
/>Replace the default header using the #header-left and #header-right named slots
vue
<CodeBlockNode
:node="{ type: 'code_block', language: 'html', code: '<div>Hello</div>', raw: '<div>Hello</div>' }"
:loading="false"
:showCopyButton="false"
>
<template #header-left>
<div class="flex items-center space-x-2">
<!-- custom icon or label -->
<span class="text-sm font-medium">My HTML</span>
</div>
</template>
<template #header-right>
<div class="flex items-center space-x-2">
<button class="px-2 py-1 bg-blue-600 text-white rounded">Run</button>
<button class="px-2 py-1 bg-gray-200 dark:bg-gray-700 rounded">Inspect</button>
</div>
</template>
</CodeBlockNode>Custom loading placeholder (shown when stream is false and loading is true)
vue
<CodeBlockNode
:node="{ type: 'code_block', language: 'python', code: code, raw: code }"
:stream="false"
:loading="isLoading"
>
<template #loading="{ loading, stream }">
<div v-if="loading && !stream" class="p-4 text-center">
<div class="animate-spin inline-block w-6 h-6 border-2 border-current border-t-transparent rounded-full" />
<p class="mt-2 text-sm text-gray-500">Initializing editor...</p>
</div>
</template>
</CodeBlockNode>Events and notes
- The component emits
copywhen the copy button is clicked (the copy text is supplied as the event payload). Use@copy="onCopy"to listen for it. - The component emits
previewCodewhen the preview action is triggered; payload contains{ type, content, title }wheretypeis the MIME type. - To hide a specific toolbar button set, use the boolean props
showCopyButton,showExpandButton,showPreviewButton,showFontSizeButtons. - The
showHeaderprop controls whether the header is rendered at all.
Troubleshooting
If you run into style conflicts (for instance, Tailwind reset/utility rules changing the header's layout), see the main Troubleshooting page which covers Tailwind import ordering and quick fixes: /guide/troubleshooting.