mirror of
https://github.com/elk-zone/elk.git
synced 2024-12-25 22:18:16 +03:00
1234fb2dd1
Co-authored-by: Sebastian Di Luzio <sebastian.di-luzio@iu.org> Co-authored-by: Emanuel Pina <contacto@emanuelpina.pt> Co-authored-by: lazzzis <lazzzis@outlook.com> Co-authored-by: Joaquín Sánchez <userquin@gmail.com> Co-authored-by: TAKAHASHI Shuuji <shuuji3@gmail.com> Co-authored-by: Francesco <129339155+katullo11@users.noreply.github.com> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: patak-dev <matias.capeletto@gmail.com>
45 lines
1.4 KiB
Vue
45 lines
1.4 KiB
Vue
<script setup lang="ts">
|
|
const props = defineProps<{
|
|
draftKey: string
|
|
draftItemIndex: number
|
|
}>()
|
|
|
|
const { threadIsActive, addThreadItem, threadItems, removeThreadItem } = useThreadComposer(props.draftKey)
|
|
|
|
const isRemovableItem = computed(() => threadIsActive.value && props.draftItemIndex < threadItems.value.length - 1)
|
|
|
|
function addOrRemoveItem() {
|
|
if (isRemovableItem.value)
|
|
removeThreadItem(props.draftItemIndex)
|
|
|
|
else
|
|
addThreadItem()
|
|
}
|
|
|
|
const { t } = useI18n()
|
|
|
|
const label = computed(() => {
|
|
if (!isRemovableItem.value && props.draftItemIndex === 0)
|
|
return t('tooltip.start_thread')
|
|
|
|
return isRemovableItem.value ? t('tooltip.remove_thread_item') : t('tooltip.add_thread_item')
|
|
})
|
|
</script>
|
|
|
|
<template>
|
|
<div flex flex-row rounded-3 :class="{ 'bg-border': threadIsActive }">
|
|
<div
|
|
v-if="threadIsActive" dir="ltr" pointer-events-none pe-1 pt-2 pl-2 text-sm tabular-nums text-secondary flex
|
|
gap="0.5"
|
|
>
|
|
{{ draftItemIndex + 1 }}<span text-secondary-light>/</span><span text-secondary-light>{{ threadItems.length
|
|
}}</span>
|
|
</div>
|
|
<CommonTooltip placement="top" :content="label">
|
|
<button btn-action-icon :aria-label="label" @click="addOrRemoveItem">
|
|
<div v-if="isRemovableItem" i-ri:chat-delete-line />
|
|
<div v-else i-ri:chat-new-line />
|
|
</button>
|
|
</CommonTooltip>
|
|
</div>
|
|
</template>
|