diff options
| author | dakkar <dakkar@thenautilus.net> | 2024-11-13 11:14:59 +0000 |
|---|---|---|
| committer | dakkar <dakkar@thenautilus.net> | 2024-11-13 11:14:59 +0000 |
| commit | 0a05841f33f97a67cb0ea1f920fbcc21275c9c4d (patch) | |
| tree | cef32afb02833f12830ce90a5a82d0849ce5c0af | |
| parent | merge: Styling of following feed. (!738) (diff) | |
| parent | remove `idea` section (diff) | |
| download | sharkey-0a05841f33f97a67cb0ea1f920fbcc21275c9c4d.tar.gz sharkey-0a05841f33f97a67cb0ea1f920fbcc21275c9c4d.tar.bz2 sharkey-0a05841f33f97a67cb0ea1f920fbcc21275c9c4d.zip | |
merge: Add "pinned" section to notes tab on user profiles (!689)
View MR for information: https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/689
Approved-by: dakkar <dakkar@thenautilus.net>
Approved-by: Tess K <me@thvxl.se>
| -rw-r--r-- | packages/frontend/src/pages/user/home.vue | 10 | ||||
| -rw-r--r-- | packages/frontend/src/pages/user/index.timeline.vue | 22 |
2 files changed, 23 insertions, 9 deletions
diff --git a/packages/frontend/src/pages/user/home.vue b/packages/frontend/src/pages/user/home.vue index 279f301d78..398be8e9ab 100644 --- a/packages/frontend/src/pages/user/home.vue +++ b/packages/frontend/src/pages/user/home.vue @@ -141,8 +141,8 @@ SPDX-License-Identifier: AGPL-3.0-only <MkLazy> <XActivity :key="user.id" :user="user" :collapsed="true"/> </MkLazy> - <MkLazy> - <XListenBrainz v-if="user.listenbrainz && listenbrainzdata" :key="user.id" :user="user" :collapsed="true"/> + <MkLazy v-if="user.listenbrainz && listenbrainzdata"> + <XListenBrainz :key="user.id" :user="user" :collapsed="true"/> </MkLazy> </template> <!-- <div v-if="!disableNotes"> @@ -303,7 +303,7 @@ const pagination = { endpoint: 'users/featured-notes' as const, limit: 10, params: computed(() => ({ - userId: props.user.id, + userId: props.user.id })), }; @@ -820,10 +820,6 @@ onUnmounted(() => { color: var(--success); } -.pinnedNote:not(:last-child) { - border-bottom: solid 0.5px var(--divider); -} - .infoBadges { position: absolute; top: 12px; diff --git a/packages/frontend/src/pages/user/index.timeline.vue b/packages/frontend/src/pages/user/index.timeline.vue index 8dbf90f344..28a5091059 100644 --- a/packages/frontend/src/pages/user/index.timeline.vue +++ b/packages/frontend/src/pages/user/index.timeline.vue @@ -7,22 +7,40 @@ SPDX-License-Identifier: AGPL-3.0-only <MkStickyContainer> <template #header> <MkTab v-model="tab" :class="$style.tab"> + <option value="pinned">{{ i18n.ts.pinnedOnly }}</option> <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"/> + <div v-if="tab === 'pinned'" class="_gaps"> + <div v-if="user.pinnedNotes.length < 1" class="_fullinfo"> + <img :src="infoImageUrl" class="_ghost" aria-hidden="true" :alt="i18n.ts.noNotes"/> + <div>{{ i18n.ts.noNotes }}</div> + </div> + <div v-else class="_panel"> + <MkNote v-for="note of user.pinnedNotes" :key="note.id" class="note" :class="$style.pinnedNote" :note="note" :pinned="true"/> + </div> + </div> + <MkNotes v-else :noGap="true" :pagination="pagination" :class="$style.tl"/> </MkStickyContainer> </template> <script lang="ts" setup> -import { ref, computed } from 'vue'; +import { ref, computed, defineAsyncComponent } from 'vue'; import * as Misskey from 'misskey-js'; import MkNotes from '@/components/MkNotes.vue'; import MkTab from '@/components/MkTab.vue'; import { i18n } from '@/i18n.js'; +import { infoImageUrl } from '@/instance.js'; +import { defaultStore } from '@/store.js'; + +const MkNote = defineAsyncComponent(() => + defaultStore.state.noteDesign === 'sharkey' + ? import('@/components/SkNote.vue') + : import('@/components/MkNote.vue'), +); const props = defineProps<{ user: Misskey.entities.UserDetailed; |