it-tools/src/tools/markdown-viewer/markdown-viewer.vue

37 lines
942 B
Vue
Raw Normal View History

2023-12-02 18:26:06 -05:00
<script setup lang="ts">
import { useElementSize, useStorage } from '@vueuse/core';
2023-12-02 21:09:24 -05:00
import { renderMarkdown } from './markdown-viewer.service';
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');
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>