2023-12-02 18:26:06 -05:00
|
|
|
<script setup lang="ts">
|
2023-12-02 21:27:47 -05:00
|
|
|
import { useElementSize, useStorage } from '@vueuse/core';
|
2023-12-02 21:09:24 -05:00
|
|
|
import { renderMarkdown } from './markdown-viewer.service';
|
2023-12-02 22:24:43 -05:00
|
|
|
|
2023-12-02 18:26:06 -05:00
|
|
|
const inputElement = ref<HTMLElement>();
|
2023-12-02 22:17:53 -05:00
|
|
|
const rawMd = useStorage('markdown-viewer:raw-md', '# Hello World');
|
2023-12-02 21:27:47 -05:00
|
|
|
const { height } = useElementSize(inputElement);
|
|
|
|
|
2023-12-02 22:17:53 -05:00
|
|
|
const cardStyles = computed(() => ({
|
|
|
|
width: '100%',
|
|
|
|
overflow: 'scroll',
|
|
|
|
maxHeight: `${height.value}px`,
|
|
|
|
}));
|
2023-12-02 18:26:06 -05:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<n-form-item
|
2023-12-02 21:09:24 -05:00
|
|
|
label="Your raw markdown"
|
2023-12-02 18:26:06 -05:00
|
|
|
>
|
|
|
|
<c-input-text
|
2023-12-02 21:09:24 -05:00
|
|
|
ref="inputElement"
|
|
|
|
v-model:value="rawMd"
|
|
|
|
placeholder="Paste your raw markdown here..."
|
|
|
|
rows="35"
|
|
|
|
multiline
|
|
|
|
autocomplete="off"
|
|
|
|
autocorrect="off"
|
|
|
|
autocapitalize="off"
|
|
|
|
spellcheck="false"
|
|
|
|
monospace
|
2023-12-02 18:26:06 -05:00
|
|
|
/>
|
|
|
|
</n-form-item>
|
2023-12-02 21:09:24 -05:00
|
|
|
<n-form-item label="Prettified version of your markdown">
|
2023-12-02 22:17:53 -05:00
|
|
|
<c-card :style="cardStyles" v-html="renderMarkdown(rawMd)" />
|
2023-12-02 18:26:06 -05:00
|
|
|
</n-form-item>
|
|
|
|
</template>
|