41 lines
990 B
Vue
41 lines
990 B
Vue
<!--
|
|
SPDX-FileCopyrightText: syuilo and misskey-project
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
-->
|
|
|
|
<template>
|
|
<XColumn :column="column" :isStacked="isStacked" :refresher="() => reloadTimeline()">
|
|
<template #header><i class="ti ti-at" style="margin-right: 8px;"></i>{{ column.name || i18n.ts._deck._columns.mentions }}</template>
|
|
|
|
<MkNotesTimeline ref="tlComponent" :pagination="pagination"/>
|
|
</XColumn>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { ref, useTemplateRef } from 'vue';
|
|
import XColumn from './column.vue';
|
|
import type { Column } from '@/deck.js';
|
|
import { i18n } from '@/i18n.js';
|
|
import MkNotesTimeline from '@/components/MkNotesTimeline.vue';
|
|
|
|
defineProps<{
|
|
column: Column;
|
|
isStacked: boolean;
|
|
}>();
|
|
|
|
const tlComponent = useTemplateRef('tlComponent');
|
|
|
|
function reloadTimeline() {
|
|
return new Promise<void>((res) => {
|
|
tlComponent.value?.reload().then(() => {
|
|
res();
|
|
});
|
|
});
|
|
}
|
|
|
|
const pagination = {
|
|
endpoint: 'notes/mentions' as const,
|
|
limit: 10,
|
|
};
|
|
</script>
|