summaryrefslogtreecommitdiff
path: root/packages/frontend/src
diff options
context:
space:
mode:
authordakkar <dakkar@thenautilus.net>2024-11-13 11:14:59 +0000
committerdakkar <dakkar@thenautilus.net>2024-11-13 11:14:59 +0000
commit0a05841f33f97a67cb0ea1f920fbcc21275c9c4d (patch)
treecef32afb02833f12830ce90a5a82d0849ce5c0af /packages/frontend/src
parentmerge: Styling of following feed. (!738) (diff)
parentremove `idea` section (diff)
downloadsharkey-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>
Diffstat (limited to 'packages/frontend/src')
-rw-r--r--packages/frontend/src/pages/user/home.vue10
-rw-r--r--packages/frontend/src/pages/user/index.timeline.vue22
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;