2023-07-27 00:31:52 -05:00
|
|
|
<!--
|
2024-02-13 09:59:27 -06:00
|
|
|
SPDX-FileCopyrightText: syuilo and misskey-project
|
2023-07-27 00:31:52 -05:00
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
-->
|
|
|
|
|
2020-01-29 13:37:25 -06:00
|
|
|
<template>
|
2024-03-02 01:05:17 -06:00
|
|
|
<MkCustomEmoji v-if="reaction[0] === ':'" ref="elRef" :name="reaction" :normal="true" :noStyle="noStyle" :url="emojiUrl" :fallbackToImage="true"/>
|
2023-11-02 05:59:18 -05:00
|
|
|
<MkEmoji v-else ref="elRef" :emoji="reaction" :normal="true" :noStyle="noStyle"/>
|
2020-01-29 13:37:25 -06:00
|
|
|
</template>
|
|
|
|
|
2022-01-13 19:35:32 -06:00
|
|
|
<script lang="ts" setup>
|
2023-11-02 05:59:18 -05:00
|
|
|
import { defineAsyncComponent, shallowRef } from 'vue';
|
|
|
|
import { useTooltip } from '@/scripts/use-tooltip.js';
|
|
|
|
import * as os from '@/os.js';
|
2020-10-17 06:12:00 -05:00
|
|
|
|
2022-01-13 19:35:32 -06:00
|
|
|
const props = defineProps<{
|
|
|
|
reaction: string;
|
|
|
|
noStyle?: boolean;
|
2023-01-26 00:48:12 -06:00
|
|
|
emojiUrl?: string;
|
2023-11-02 05:59:18 -05:00
|
|
|
withTooltip?: boolean;
|
2022-01-13 19:35:32 -06:00
|
|
|
}>();
|
2023-11-02 05:59:18 -05:00
|
|
|
|
|
|
|
const elRef = shallowRef();
|
|
|
|
|
|
|
|
if (props.withTooltip) {
|
|
|
|
useTooltip(elRef, (showing) => {
|
2024-07-03 23:14:49 -05:00
|
|
|
const { dispose } = os.popup(defineAsyncComponent(() => import('@/components/MkReactionTooltip.vue')), {
|
2023-11-02 05:59:18 -05:00
|
|
|
showing,
|
|
|
|
reaction: props.reaction.replace(/^:(\w+):$/, ':$1@.:'),
|
|
|
|
targetElement: elRef.value.$el,
|
2024-07-03 23:14:49 -05:00
|
|
|
}, {
|
|
|
|
closed: () => dispose(),
|
|
|
|
});
|
2023-11-02 05:59:18 -05:00
|
|
|
});
|
|
|
|
}
|
2020-01-29 13:37:25 -06:00
|
|
|
</script>
|