mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-10-10 05:46:47 +08:00
56 lines
1.8 KiB
Vue
56 lines
1.8 KiB
Vue
<template>
|
|
<template v-if="params.dtComponent.currentViewRender === 'table'">
|
|
<div class="group relative flex items-center group-hover:marker text-xs h-full w-full leading-[unset]">
|
|
<div ref="descripitonBox" class="flex gap-2 w-full items-center text-sm leading-[unset]">
|
|
<span class="cursor-pointer line-clamp-1 leading-[unset]"
|
|
@click.stop="showDescriptionModal">
|
|
{{ params.data.description }}
|
|
</span>
|
|
<span @click.stop="showDescriptionModal" class="text-sn-blue cursor-pointer shrink-0 inline-block text-sm leading-[unset]">
|
|
{{ i18n.t('experiments.card.more') }}
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<template v-else>
|
|
<div class="group relative flex items-center group-hover:marker text-xs h-full w-full">
|
|
<div ref="descripitonBox" class="flex gap-2 w-full items-end text-xs">
|
|
<span v-if="shouldTruncateText"
|
|
class="cursor-pointer grow line-clamp-2"
|
|
@click.stop="showDescriptionModal">
|
|
{{ params.data.description }}
|
|
</span>
|
|
<span v-else class="grow">{{ params.data.description }}</span>
|
|
<span v-if="shouldTruncateText" @click.stop="showDescriptionModal" class="text-sn-blue cursor-pointer shrink-0 inline-block text-xs">
|
|
{{ i18n.t('experiments.card.more') }}
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
name: 'DescriptionRenderer',
|
|
props: {
|
|
params: {
|
|
required: true
|
|
}
|
|
},
|
|
mounted() {
|
|
this.$nextTick(() => {
|
|
window.renderElementSmartAnnotations(this.$refs.descripitonBox, 'span');
|
|
});
|
|
},
|
|
computed: {
|
|
shouldTruncateText() {
|
|
return this.params.data.description?.length > 60;
|
|
}
|
|
},
|
|
methods: {
|
|
showDescriptionModal() {
|
|
this.params.dtComponent.$emit('showDescription', null, [this.params.data]);
|
|
},
|
|
},
|
|
};
|
|
</script>
|