<template> <MkStickyContainer> <template #header><MkPageHeader :actions="headerActions" :tabs="headerTabs"/></template> <MkSpacer :content-max="800"> <XNotes ref="notes" :pagination="pagination"/> </MkSpacer> </MkStickyContainer> </template> <script lang="ts" setup> import { computed } from 'vue'; import XNotes from '@/components/MkNotes.vue'; import { i18n } from '@/i18n'; import { definePageMetadata } from '@/scripts/page-metadata'; import * as os from '@/os'; import { useRouter } from '@/router'; import { $i } from '@/account'; const router = useRouter(); const props = defineProps<{ query: string; channel?: string; }>(); const query = props.query; if ($i != null) { if (query.startsWith('https://') || (query.startsWith('@') && !query.includes(' '))) { const promise = os.api('ap/show', { uri: props.query, }); os.promiseDialog(promise, null, null, i18n.ts.fetchingAsApObject); const res = await promise; if (res.type === 'User') { router.replace(`/@${res.object.username}@${res.object.host}`); } else if (res.type === 'Note') { router.replace(`/notes/${res.object.id}`); } } } const pagination = { endpoint: 'notes/search' as const, limit: 10, params: computed(() => ({ query: props.query, channelId: props.channel, })), }; const headerActions = $computed(() => []); const headerTabs = $computed(() => []); definePageMetadata(computed(() => ({ title: i18n.t('searchWith', { q: props.query }), icon: 'ti ti-search', }))); </script>