mirror of
https://github.com/TeamPiped/Piped.git
synced 2024-08-14 23:57:27 +00:00
46 lines
1.3 KiB
Vue
46 lines
1.3 KiB
Vue
<template v-if="text">
|
|
<div class="mx-1 whitespace-pre-wrap py-2">
|
|
<!-- eslint-disable-next-line vue/no-v-html -->
|
|
<span v-if="showFullText" v-html="fullText()" />
|
|
<!-- eslint-disable-next-line vue/no-v-html -->
|
|
<span v-else v-html="colapsedText()" />
|
|
<span v-if="text.length > visibleLimit && !showFullText">...</span>
|
|
<button
|
|
v-if="text.length > visibleLimit"
|
|
class="block whitespace-normal text-neutral-500 font-semibold hover:underline"
|
|
@click="showFullText = !showFullText"
|
|
>
|
|
[{{ showFullText ? $t("actions.show_less") : $t("actions.show_more") }}]
|
|
</button>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import { purifyHTML, rewriteDescription } from "@/utils/HtmlUtils";
|
|
|
|
export default {
|
|
props: {
|
|
text: {
|
|
type: String,
|
|
default: null,
|
|
},
|
|
visibleLimit: {
|
|
type: Number,
|
|
default: 100,
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
showFullText: false,
|
|
};
|
|
},
|
|
methods: {
|
|
fullText() {
|
|
return purifyHTML(rewriteDescription(this.text));
|
|
},
|
|
colapsedText() {
|
|
return purifyHTML(rewriteDescription(this.text.slice(0, this.visibleLimit)));
|
|
},
|
|
},
|
|
};
|
|
</script>
|