You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
824 B
38 lines
824 B
<script setup lang="ts">
|
|
import {computed} from 'vue'
|
|
import {MathStatement} from '../support/parse'
|
|
|
|
const props = defineProps<{
|
|
statement: MathStatement,
|
|
size?: 'big' | 'small',
|
|
}>()
|
|
|
|
const getRenderedHTML = () => {
|
|
console.log('getRenderedHTML', props.statement)
|
|
try {
|
|
return props.statement.toHTMLString()
|
|
} catch (_) {
|
|
return ''
|
|
}
|
|
}
|
|
|
|
let renderedHtml = getRenderedHTML()
|
|
computed(() => renderedHtml = getRenderedHTML())
|
|
</script>
|
|
|
|
<style>
|
|
.big {
|
|
font-size: 1.3em;
|
|
}
|
|
|
|
.small {
|
|
font-size: 0.9em;
|
|
}
|
|
</style>
|
|
|
|
<template>
|
|
<div ref="container" class="big" v-if="props?.size === 'big'" v-html="renderedHtml"></div>
|
|
<div ref="container" class="small" v-else-if="props?.size === 'small'" v-html="renderedHtml"></div>
|
|
<div ref="container" v-else v-html="renderedHtml"></div>
|
|
</template>
|