mishig's picture
mishig HF Staff
First build
6426ece
<script lang="ts">
import CodeMirror from '$lib/CodeMirror/CodeMirror.svelte';
import CopyButton from '$lib/CopyButton/CopyButton.svelte';
import LineWrapButton from '$lib/LineWrapButton/LineWrapButton.svelte';
import { EditorView } from '@codemirror/view';
export let content = '';
export let error;
let wrapLines = true;
</script>
<div class="h-full overflow-scroll bg-white dark:bg-gray-900">
<div class="sticky top-0 z-10 bg-white dark:bg-gray-900">
<div
class="text-semibold flex items-center gap-x-2 border-b border-gray-500 bg-linear-to-r from-purple-200 to-white px-3 py-1.5 text-lg dark:from-purple-700 dark:to-purple-900 dark:text-gray-200"
>
Rendered Output
</div>
{#if error}
<div class="alert alert-error">
{error}
</div>
{:else}
<div class="flex items-center border-b px-3 py-2">
<div class="ml-auto flex items-center gap-x-2">
<CopyButton
label="Copy"
value={content}
style="button-clear"
classNames="h-6! [&_svg]:text-[0.7rem]! px-1.5! text-black! dark:text-gray-200!"
/>
<LineWrapButton
style="button-clear"
bind:wrapLines
classNames="[&_svg]:text-xs! size-6! p-0!"
/>
</div>
</div>
{/if}
</div>
{#if !error}
<CodeMirror
value={content}
readonly
extensions={[wrapLines ? [EditorView.lineWrapping] : []]}
/>
{/if}
</div>