refactor: page.text.vue to use composition api

This commit is contained in:
Norm 2022-07-23 17:42:00 -04:00
parent 2f432dce65
commit d79fe1dee0

View file

@ -1,53 +1,38 @@
<template> <template>
<div class="mrdgzndn"> <div class="mrdgzndn">
<Mfm :key="text" :text="text" :is-note="false" :i="$i"/> <Mfm :key="text" :text="text" :is-note="false"/>
<MkUrlPreview v-for="url in urls" :key="url" :url="url" class="url"/> <MkUrlPreview v-for="url in urls" :key="url" :url="url" class="url"/>
</div> </div>
</template> </template>
<script lang="ts"> <script lang="ts" setup>
import { defineAsyncComponent, watch, computed } from 'vue';
import * as mfm from 'mfm-js';
import { TextBlock } from '@/scripts/hpml/block'; import { TextBlock } from '@/scripts/hpml/block';
import { Hpml } from '@/scripts/hpml/evaluator'; import { Hpml } from '@/scripts/hpml/evaluator';
import { defineAsyncComponent, defineComponent, PropType } from 'vue';
import * as mfm from 'mfm-js';
import { extractUrlFromMfm } from '@/scripts/extract-url-from-mfm'; import { extractUrlFromMfm } from '@/scripts/extract-url-from-mfm';
export default defineComponent({ const props = defineProps<{
components: { block: TextBlock;
MkUrlPreview: defineAsyncComponent(() => import('@/components/url-preview.vue')), hpml: Hpml;
}, }>();
props: {
block: { const MkUrlPreview = defineAsyncComponent(() => import('@/components/url-preview.vue'));
type: Object as PropType<TextBlock>,
required: true let text: string = $ref(props.hpml.interpolate(props.block.text) ?? '');
},
hpml: { const urls = computed((): string[] => {
type: Object as PropType<Hpml>, if (text) {
required: true return extractUrlFromMfm(mfm.parse(text));
} } else {
}, return [];
data() { }
return { });
text: this.hpml.interpolate(this.block.text),
}; watch(props.hpml.vars, () => {
}, text = props.hpml.interpolate(props.block.text) ?? '';
computed: { }, {
urls(): string[] { deep: true,
if (this.text) {
return extractUrlFromMfm(mfm.parse(this.text));
} else {
return [];
}
}
},
watch: {
'hpml.vars': {
handler() {
this.text = this.hpml.interpolate(this.block.text);
},
deep: true
}
},
}); });
</script> </script>