2020-01-29 20:37:25 +01:00
|
|
|
<template>
|
2022-07-14 16:31:01 +02:00
|
|
|
<MkStickyContainer>
|
|
|
|
<template #header>
|
|
|
|
<MkTab v-model="include" :class="$style.tab">
|
2022-07-20 15:24:26 +02:00
|
|
|
<option :value="null">{{ i18n.ts.notes }}</option>
|
|
|
|
<option value="replies">{{ i18n.ts.notesAndReplies }}</option>
|
|
|
|
<option value="files">{{ i18n.ts.withFiles }}</option>
|
2022-07-14 16:31:01 +02:00
|
|
|
</MkTab>
|
|
|
|
</template>
|
2022-01-21 08:43:56 +01:00
|
|
|
<XNotes :no-gap="true" :pagination="pagination"/>
|
2022-07-14 16:31:01 +02:00
|
|
|
</MkStickyContainer>
|
2020-01-29 20:37:25 +01:00
|
|
|
</template>
|
|
|
|
|
2022-01-09 13:35:35 +01:00
|
|
|
<script lang="ts" setup>
|
|
|
|
import { ref, computed } from 'vue';
|
2022-12-12 04:24:12 +01:00
|
|
|
import * as misskey from 'calckey-js';
|
2022-08-30 17:24:33 +02:00
|
|
|
import XNotes from '@/components/MkNotes.vue';
|
|
|
|
import MkTab from '@/components/MkTab.vue';
|
2021-11-11 18:02:25 +01:00
|
|
|
import * as os from '@/os';
|
2022-07-20 15:24:26 +02:00
|
|
|
import { i18n } from '@/i18n';
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2022-01-09 13:35:35 +01:00
|
|
|
const props = defineProps<{
|
|
|
|
user: misskey.entities.UserDetailed;
|
|
|
|
}>();
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2022-01-09 13:35:35 +01:00
|
|
|
const include = ref<string | null>(null);
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2022-01-09 13:35:35 +01:00
|
|
|
const pagination = {
|
|
|
|
endpoint: 'users/notes' as const,
|
|
|
|
limit: 10,
|
|
|
|
params: computed(() => ({
|
|
|
|
userId: props.user.id,
|
|
|
|
includeReplies: include.value === 'replies',
|
|
|
|
withFiles: include.value === 'files',
|
|
|
|
})),
|
|
|
|
};
|
2020-01-29 20:37:25 +01:00
|
|
|
</script>
|
2021-04-13 20:23:29 +02:00
|
|
|
|
2022-07-14 16:31:01 +02:00
|
|
|
<style lang="scss" module>
|
|
|
|
.tab {
|
|
|
|
margin: calc(var(--margin) / 2) 0;
|
|
|
|
padding: calc(var(--margin) / 2) 0;
|
|
|
|
background: var(--bg);
|
2021-04-13 20:23:29 +02:00
|
|
|
}
|
|
|
|
</style>
|