summaryrefslogtreecommitdiff
path: root/packages/frontend/src/components/MkNotes.vue
diff options
context:
space:
mode:
authorsyuilo <4439005+syuilo@users.noreply.github.com>2025-03-29 13:34:53 +0900
committersyuilo <4439005+syuilo@users.noreply.github.com>2025-03-29 13:34:53 +0900
commitfc88410c0dd9857cc0432832c4e5f6f6bf8db81a (patch)
tree5bc82aeadc66768239f458ad9dcd52f6b62168b8 /packages/frontend/src/components/MkNotes.vue
parentRevert "test" (diff)
downloadsharkey-fc88410c0dd9857cc0432832c4e5f6f6bf8db81a.tar.gz
sharkey-fc88410c0dd9857cc0432832c4e5f6f6bf8db81a.tar.bz2
sharkey-fc88410c0dd9857cc0432832c4e5f6f6bf8db81a.zip
refactor(frontend): tweak MkNotes and MkNotifications
Diffstat (limited to 'packages/frontend/src/components/MkNotes.vue')
-rw-r--r--packages/frontend/src/components/MkNotes.vue49
1 files changed, 26 insertions, 23 deletions
diff --git a/packages/frontend/src/components/MkNotes.vue b/packages/frontend/src/components/MkNotes.vue
index cee226ee14..1f0f5db42a 100644
--- a/packages/frontend/src/components/MkNotes.vue
+++ b/packages/frontend/src/components/MkNotes.vue
@@ -13,32 +13,26 @@ SPDX-License-Identifier: AGPL-3.0-only
</template>
<template #default="{ items: notes }">
- <div :class="[$style.root, { [$style.noGap]: noGap }]">
- <MkDateSeparatedList
- ref="notes"
- v-slot="{ item: note }"
- :items="notes"
- :direction="pagination.reversed ? 'up' : 'down'"
- :reversed="pagination.reversed"
- :noGap="noGap"
- :ad="true"
- :class="$style.notes"
- >
- <MkNote :key="note._featuredId_ || note._prId_ || note.id" :class="$style.note" :note="note" :withHardMute="true"/>
- </MkDateSeparatedList>
+ <div :class="[$style.root, { [$style.noGap]: noGap, '_gaps': !noGap }]">
+ <template v-for="(note, i) in notes" :key="note.id">
+ <MkNote :class="$style.note" :note="note" :withHardMute="true"/>
+ <div v-if="note._shouldInsertAd_" :class="$style.ad">
+ <MkAd :prefer="['horizontal', 'horizontal-big']"/>
+ </div>
+ </template>
</div>
</template>
</MkPagination>
</template>
<script lang="ts" setup>
-import { useTemplateRef } from 'vue';
+import { useTemplateRef, TransitionGroup } from 'vue';
import type { Paging } from '@/components/MkPagination.vue';
import MkNote from '@/components/MkNote.vue';
-import MkDateSeparatedList from '@/components/MkDateSeparatedList.vue';
import MkPagination from '@/components/MkPagination.vue';
import { i18n } from '@/i18n.js';
import { infoImageUrl } from '@/instance.js';
+import { prefer } from '@/preferences.js';
const props = defineProps<{
pagination: Paging;
@@ -55,20 +49,29 @@ defineExpose({
<style lang="scss" module>
.root {
+ container-type: inline-size;
+
&.noGap {
- > .notes {
- background: var(--MI_THEME-panel);
+ background: var(--MI_THEME-panel);
+
+ .note {
+ border-bottom: solid 0.5px var(--MI_THEME-divider);
+ }
+
+ .ad {
+ padding: 8px;
+ background-size: auto auto;
+ background-image: repeating-linear-gradient(45deg, transparent, transparent 8px, var(--MI_THEME-bg) 8px, var(--MI_THEME-bg) 14px);
+ border-bottom: solid 0.5px var(--MI_THEME-divider);
}
}
&:not(.noGap) {
- > .notes {
- background: var(--MI_THEME-bg);
+ background: var(--MI_THEME-bg);
- .note {
- background: var(--MI_THEME-panel);
- border-radius: var(--MI-radius);
- }
+ .note {
+ background: var(--MI_THEME-panel);
+ border-radius: var(--MI-radius);
}
}
}