summaryrefslogtreecommitdiff
path: root/packages/client/src/components
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2022-09-05 18:37:41 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2022-09-05 18:37:41 +0900
commit9132c7254550da8d3f8d7f75bbee48a54ffd2680 (patch)
treec24e3e938ebf0b5c078fb262e39081fee4b5a494 /packages/client/src/components
parentrefactor(client): use setup syntax (diff)
downloadmisskey-9132c7254550da8d3f8d7f75bbee48a54ffd2680.tar.gz
misskey-9132c7254550da8d3f8d7f75bbee48a54ffd2680.tar.bz2
misskey-9132c7254550da8d3f8d7f75bbee48a54ffd2680.zip
refactor(client): use setup syntax
Diffstat (limited to 'packages/client/src/components')
-rw-r--r--packages/client/src/components/MkUrlPreviewPopup.vue55
1 files changed, 20 insertions, 35 deletions
diff --git a/packages/client/src/components/MkUrlPreviewPopup.vue b/packages/client/src/components/MkUrlPreviewPopup.vue
index 2f0ffaa388..f343c6d8a6 100644
--- a/packages/client/src/components/MkUrlPreviewPopup.vue
+++ b/packages/client/src/components/MkUrlPreviewPopup.vue
@@ -1,52 +1,37 @@
<template>
<div class="fgmtyycl" :style="{ zIndex, top: top + 'px', left: left + 'px' }">
- <transition :name="$store.state.animation ? 'zoom' : ''" @after-leave="$emit('closed')">
+ <transition :name="$store.state.animation ? 'zoom' : ''" @after-leave="emit('closed')">
<MkUrlPreview v-if="showing" class="_popup _shadow" :url="url"/>
</transition>
</div>
</template>
-<script lang="ts">
-import { defineComponent } from 'vue';
+<script lang="ts" setup>
+import { onMounted } from 'vue';
import MkUrlPreview from '@/components/MkUrlPreview.vue';
import * as os from '@/os';
-export default defineComponent({
- components: {
- MkUrlPreview,
- },
+const props = defineProps<{
+ showing: boolean;
+ url: string;
+ source: HTMLElement;
+}>();
- props: {
- url: {
- type: String,
- required: true,
- },
- source: {
- required: true,
- },
- showing: {
- type: Boolean,
- required: true,
- },
- },
+const emit = defineEmits<{
+ (ev: 'closed'): void;
+}>();
- data() {
- return {
- u: null,
- top: 0,
- left: 0,
- zIndex: os.claimZIndex('middle'),
- };
- },
+const zIndex = os.claimZIndex('middle');
+let top = $ref(0);
+let left = $ref(0);
- mounted() {
- const rect = this.source.getBoundingClientRect();
- const x = Math.max((rect.left + (this.source.offsetWidth / 2)) - (300 / 2), 6) + window.pageXOffset;
- const y = rect.top + this.source.offsetHeight + window.pageYOffset;
+onMounted(() => {
+ const rect = props.source.getBoundingClientRect();
+ const x = Math.max((rect.left + (props.source.offsetWidth / 2)) - (300 / 2), 6) + window.pageXOffset;
+ const y = rect.top + props.source.offsetHeight + window.pageYOffset;
- this.top = y;
- this.left = x;
- },
+ top = y;
+ left = x;
});
</script>