iceshrimp/packages/client/src/components/MkStarButton.vue

42 lines
1019 B
Vue
Raw Normal View History

2022-10-26 12:20:41 +09:00
<template>
2022-11-27 14:37:23 +09:00
<button v-tooltip.noDelay.bottom="i18n.ts._gallery.like" class="skdfgljsdkf _button" @click="star($event)">
2022-11-07 11:49:47 +09:00
<i class="ph-star-bold ph-lg"></i>
2022-10-26 12:20:41 +09:00
</button>
</template>
<script lang="ts" setup>
2022-12-13 03:19:18 +09:00
import type { Note } from 'calckey-js/built/entities';
2022-10-26 12:33:09 +09:00
import Ripple from '@/components/MkRipple.vue';
2022-10-26 12:20:41 +09:00
import { pleaseLogin } from '@/scripts/please-login';
import * as os from '@/os';
2022-11-27 14:37:23 +09:00
import { i18n } from '@/i18n';
2022-11-25 20:46:10 +09:00
2022-10-26 12:20:41 +09:00
const props = defineProps<{
note: Note;
}>();
2022-10-26 12:33:09 +09:00
function star(ev?: MouseEvent): void {
2022-10-26 12:20:41 +09:00
pleaseLogin();
os.api('notes/reactions/create', {
noteId: props.note.id,
reaction: '⭐',
});
2022-10-26 12:33:09 +09:00
const el = ev && (ev.currentTarget ?? ev.target) as HTMLElement | null | undefined;
if (el) {
const rect = el.getBoundingClientRect();
const x = rect.left + (el.offsetWidth / 2);
const y = rect.top + (el.offsetHeight / 2);
os.popup(Ripple, { x, y }, {}, 'end');
}
2022-10-26 12:20:41 +09:00
}
</script>
<style lang="scss" scoped>
.skdfgljsdkf {
display: inline-block;
height: 32px;
margin: 2px;
padding: 0 6px;
}
</style>