2023-07-27 08:31:52 +03:00
|
|
|
<!--
|
|
|
|
SPDX-FileCopyrightText: syuilo and other misskey contributors
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
-->
|
|
|
|
|
2020-01-29 21:37:25 +02:00
|
|
|
<template>
|
2023-12-16 04:56:58 +02:00
|
|
|
<MkStickyContainer>
|
|
|
|
<template #header>
|
|
|
|
<MkTab v-model="tab" :class="$style.tab">
|
|
|
|
<option value="featured">{{ i18n.ts.featured }}</option>
|
|
|
|
<option :value="null">{{ i18n.ts.notes }}</option>
|
|
|
|
<option value="all">{{ i18n.ts.all }}</option>
|
|
|
|
<option value="files">{{ i18n.ts.withFiles }}</option>
|
|
|
|
</MkTab>
|
|
|
|
</template>
|
|
|
|
<MkNotes :noGap="true" :pagination="pagination" :class="$style.tl"/>
|
|
|
|
</MkStickyContainer>
|
2020-01-29 21:37:25 +02:00
|
|
|
</template>
|
|
|
|
|
2022-01-09 14:35:35 +02:00
|
|
|
<script lang="ts" setup>
|
|
|
|
import { ref, computed } from 'vue';
|
2023-09-04 07:33:38 +03:00
|
|
|
import * as Misskey from 'misskey-js';
|
2023-02-22 04:00:34 +02:00
|
|
|
import MkNotes from '@/components/MkNotes.vue';
|
2022-08-30 18:24:33 +03:00
|
|
|
import MkTab from '@/components/MkTab.vue';
|
2023-09-19 10:37:43 +03:00
|
|
|
import { i18n } from '@/i18n.js';
|
2020-01-29 21:37:25 +02:00
|
|
|
|
2022-01-09 14:35:35 +02:00
|
|
|
const props = defineProps<{
|
2023-09-04 07:33:38 +03:00
|
|
|
user: Misskey.entities.UserDetailed;
|
2022-01-09 14:35:35 +02:00
|
|
|
}>();
|
2020-01-29 21:37:25 +02:00
|
|
|
|
2023-12-16 04:56:58 +02:00
|
|
|
const tab = ref<string | null>('all');
|
2020-01-29 21:37:25 +02:00
|
|
|
|
2023-12-16 04:56:58 +02:00
|
|
|
const pagination = computed(() => tab.value === 'featured' ? {
|
|
|
|
endpoint: 'users/featured-notes' as const,
|
|
|
|
limit: 10,
|
|
|
|
params: {
|
|
|
|
userId: props.user.id,
|
|
|
|
},
|
|
|
|
} : {
|
2022-01-09 14:35:35 +02:00
|
|
|
endpoint: 'users/notes' as const,
|
|
|
|
limit: 10,
|
2023-12-16 04:56:58 +02:00
|
|
|
params: {
|
2022-01-09 14:35:35 +02:00
|
|
|
userId: props.user.id,
|
2023-12-16 04:56:58 +02:00
|
|
|
withRenotes: tab.value === 'all',
|
|
|
|
withReplies: tab.value === 'all',
|
|
|
|
withChannelNotes: tab.value === 'all',
|
|
|
|
withFiles: tab.value === 'files',
|
|
|
|
},
|
|
|
|
});
|
2020-01-29 21:37:25 +02:00
|
|
|
</script>
|
2021-04-13 21:23:29 +03:00
|
|
|
|
2022-07-14 17:31:01 +03:00
|
|
|
<style lang="scss" module>
|
|
|
|
.tab {
|
|
|
|
padding: calc(var(--margin) / 2) 0;
|
|
|
|
background: var(--bg);
|
2021-04-13 21:23:29 +03:00
|
|
|
}
|
2023-02-11 06:08:18 +02:00
|
|
|
|
|
|
|
.tl {
|
|
|
|
background: var(--bg);
|
2023-09-28 05:02:01 +03:00
|
|
|
border-radius: var(--radius);
|
|
|
|
overflow: clip;
|
2023-02-11 06:08:18 +02:00
|
|
|
}
|
2021-04-13 21:23:29 +03:00
|
|
|
</style>
|