2023-07-27 11:46:05 +00:00
|
|
|
<template v-if="text">
|
2023-08-13 17:31:57 +00:00
|
|
|
<div class="mx-1 whitespace-pre-wrap py-2">
|
2023-07-27 11:46:05 +00:00
|
|
|
<!-- eslint-disable-next-line vue/no-v-html -->
|
2023-07-22 16:22:57 +00:00
|
|
|
<span v-if="showFullText" v-html="fullText()" />
|
2023-07-27 11:46:05 +00:00
|
|
|
<!-- eslint-disable-next-line vue/no-v-html -->
|
2023-07-22 16:22:57 +00:00
|
|
|
<span v-else v-html="colapsedText()" />
|
2023-09-11 17:13:05 +00:00
|
|
|
<span v-if="text.length > visibleLimit && !showFullText">...</span>
|
2023-05-23 16:24:32 +00:00
|
|
|
<button
|
2023-09-11 17:13:05 +00:00
|
|
|
v-if="text.length > visibleLimit"
|
2023-08-13 17:31:57 +00:00
|
|
|
class="block whitespace-normal font-semibold text-neutral-500 hover:underline"
|
2023-05-23 16:24:32 +00:00
|
|
|
@click="showFullText = !showFullText"
|
|
|
|
>
|
|
|
|
[{{ showFullText ? $t("actions.show_less") : $t("actions.show_more") }}]
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2023-07-22 16:22:57 +00:00
|
|
|
import { purifyHTML, rewriteDescription } from "@/utils/HtmlUtils";
|
|
|
|
|
2023-05-23 16:24:32 +00:00
|
|
|
export default {
|
|
|
|
props: {
|
2023-07-27 11:46:05 +00:00
|
|
|
text: {
|
|
|
|
type: String,
|
|
|
|
default: null,
|
|
|
|
},
|
2023-09-11 17:13:05 +00:00
|
|
|
visibleLimit: {
|
|
|
|
type: Number,
|
|
|
|
default: 100,
|
|
|
|
},
|
2023-05-23 16:24:32 +00:00
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
showFullText: false,
|
|
|
|
};
|
|
|
|
},
|
2023-07-22 16:22:57 +00:00
|
|
|
methods: {
|
|
|
|
fullText() {
|
|
|
|
return purifyHTML(rewriteDescription(this.text));
|
|
|
|
},
|
|
|
|
colapsedText() {
|
2023-09-11 17:13:05 +00:00
|
|
|
return purifyHTML(rewriteDescription(this.text.slice(0, this.visibleLimit)));
|
2023-07-22 16:22:57 +00:00
|
|
|
},
|
|
|
|
},
|
2023-05-23 16:24:32 +00:00
|
|
|
};
|
|
|
|
</script>
|