(fix) reactionViewer mock
This commit is contained in:
		| @@ -84,7 +84,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 				</div> | ||||
| 				<MkA v-if="appearNote.channel && !inChannel" :class="$style.channel" :to="`/channels/${appearNote.channel.id}`"><i class="ti ti-device-tv"></i> {{ appearNote.channel.name }}</MkA> | ||||
| 			</div> | ||||
| 			<MkReactionsViewer :note="appearNote" :maxNumber="16"> | ||||
| 			<MkReactionsViewer :note="appearNote" :maxNumber="16" :mock="mock"> | ||||
| 				<template #more> | ||||
| 					<div :class="$style.reactionOmitted">{{ i18n.ts.more }}</div> | ||||
| 				</template> | ||||
|   | ||||
| @@ -34,6 +34,7 @@ const props = defineProps<{ | ||||
| 	count: number; | ||||
| 	isInitial: boolean; | ||||
| 	note: Misskey.entities.Note; | ||||
| 	mock?: boolean; | ||||
| }>(); | ||||
|  | ||||
| const buttonEl = shallowRef<HTMLElement>(); | ||||
| @@ -51,7 +52,7 @@ async function toggleReaction() { | ||||
| 			type: 'warning', | ||||
| 			text: oldReaction !== props.reaction ? i18n.ts.changeReactionConfirm : i18n.ts.cancelReactionConfirm, | ||||
| 		}); | ||||
| 		if (confirm.canceled) return; | ||||
| 		if (confirm.canceled || props.mock) return; | ||||
|  | ||||
| 		os.api('notes/reactions/delete', { | ||||
| 			noteId: props.note.id, | ||||
| @@ -92,24 +93,26 @@ onMounted(() => { | ||||
| 	if (!props.isInitial) anime(); | ||||
| }); | ||||
|  | ||||
| useTooltip(buttonEl, async (showing) => { | ||||
| 	const reactions = await os.apiGet('notes/reactions', { | ||||
| 		noteId: props.note.id, | ||||
| 		type: props.reaction, | ||||
| 		limit: 11, | ||||
| 		_cacheKey_: props.count, | ||||
| 	}); | ||||
| if (!props.mock) { | ||||
| 	useTooltip(buttonEl, async (showing) => { | ||||
| 		const reactions = await os.apiGet('notes/reactions', { | ||||
| 			noteId: props.note.id, | ||||
| 			type: props.reaction, | ||||
| 			limit: 11, | ||||
| 			_cacheKey_: props.count, | ||||
| 		}); | ||||
|  | ||||
| 	const users = reactions.map(x => x.user); | ||||
| 		const users = reactions.map(x => x.user); | ||||
|  | ||||
| 	os.popup(XDetails, { | ||||
| 		showing, | ||||
| 		reaction: props.reaction, | ||||
| 		users, | ||||
| 		count: props.count, | ||||
| 		targetElement: buttonEl.value, | ||||
| 	}, {}, 'closed'); | ||||
| }, 100); | ||||
| 		os.popup(XDetails, { | ||||
| 			showing, | ||||
| 			reaction: props.reaction, | ||||
| 			users, | ||||
| 			count: props.count, | ||||
| 			targetElement: buttonEl.value, | ||||
| 		}, {}, 'closed'); | ||||
| 	}, 100); | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" module> | ||||
|   | ||||
| @@ -12,7 +12,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 	:moveClass="defaultStore.state.animation ? $style.transition_x_move : ''" | ||||
| 	tag="div" :class="$style.root" | ||||
| > | ||||
| 	<XReaction v-for="[reaction, count] in reactions" :key="reaction" :reaction="reaction" :count="count" :isInitial="initialReactions.has(reaction)" :note="note"/> | ||||
| 	<XReaction v-for="[reaction, count] in reactions" :key="reaction" :reaction="reaction" :count="count" :isInitial="initialReactions.has(reaction)" :note="note" :mock="mock"/> | ||||
| 	<slot v-if="hasMoreReactions" name="more"/> | ||||
| </TransitionGroup> | ||||
| </template> | ||||
| @@ -26,8 +26,10 @@ import { defaultStore } from '@/store.js'; | ||||
| const props = withDefaults(defineProps<{ | ||||
| 	note: Misskey.entities.Note; | ||||
| 	maxNumber?: number; | ||||
| 	mock?: boolean; | ||||
| }>(), { | ||||
| 	maxNumber: Infinity, | ||||
| 	mock: false, | ||||
| }); | ||||
|  | ||||
| const initialReactions = new Set(Object.keys(props.note.reactions)); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 kakkokari-gtyih
					kakkokari-gtyih