elk/components/conversation/ConversationPaginator.vue

26 lines
906 B
Vue
Raw Normal View History

2022-11-18 10:37:22 +01:00
<script setup lang="ts">
2024-01-09 09:56:15 +01:00
import type { mastodon } from 'masto'
2022-11-18 10:37:22 +01:00
const { paginator } = defineProps<{
2024-01-09 09:56:15 +01:00
paginator: mastodon.Paginator<mastodon.v1.Conversation[], mastodon.DefaultPaginationParams>
2022-11-18 10:37:22 +01:00
}>()
function preprocess(items: mastodon.v1.Conversation[]): mastodon.v1.Conversation[] {
2023-02-05 16:05:42 +01:00
const isAuthored = (conversation: mastodon.v1.Conversation) => conversation.lastStatus ? conversation.lastStatus.account.id === currentUser.value?.account.id : false
return items.filter(item => isAuthored(item) || !item.lastStatus?.filtered?.find(
filter => filter.filter.filterAction === 'hide' && filter.filter.context.includes('thread'),
))
}
2022-11-18 10:37:22 +01:00
</script>
<template>
<CommonPaginator :paginator="paginator" :preprocess="preprocess">
2022-11-18 10:37:22 +01:00
<template #default="{ item }">
<ConversationCard
:conversation="item"
2022-11-23 10:16:31 +08:00
border="b base" py-1
2022-11-18 10:37:22 +01:00
/>
</template>
</CommonPaginator>
</template>