summaryrefslogtreecommitdiff
path: root/packages/frontend/src/components/MkMenu.child.vue
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2022-12-27 14:36:33 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2022-12-27 14:36:33 +0900
commit9384f5399da39e53855beb8e7f8ded1aa56bf72e (patch)
treece5959571a981b9c4047da3c7b3fd080aa44222c /packages/frontend/src/components/MkMenu.child.vue
parentwip: retention for dashboard (diff)
downloadsharkey-9384f5399da39e53855beb8e7f8ded1aa56bf72e.tar.gz
sharkey-9384f5399da39e53855beb8e7f8ded1aa56bf72e.tar.bz2
sharkey-9384f5399da39e53855beb8e7f8ded1aa56bf72e.zip
rename: client -> frontend
Diffstat (limited to 'packages/frontend/src/components/MkMenu.child.vue')
-rw-r--r--packages/frontend/src/components/MkMenu.child.vue65
1 files changed, 65 insertions, 0 deletions
diff --git a/packages/frontend/src/components/MkMenu.child.vue b/packages/frontend/src/components/MkMenu.child.vue
new file mode 100644
index 0000000000..3ada4afbdc
--- /dev/null
+++ b/packages/frontend/src/components/MkMenu.child.vue
@@ -0,0 +1,65 @@
+<template>
+<div ref="el" class="sfhdhdhr">
+ <MkMenu ref="menu" :items="items" :align="align" :width="width" :as-drawer="false" @close="onChildClosed"/>
+</div>
+</template>
+
+<script lang="ts" setup>
+import { on } from 'events';
+import { nextTick, onBeforeUnmount, onMounted, onUnmounted, ref, watch } from 'vue';
+import MkMenu from './MkMenu.vue';
+import { MenuItem } from '@/types/menu';
+import * as os from '@/os';
+
+const props = defineProps<{
+ items: MenuItem[];
+ targetElement: HTMLElement;
+ rootElement: HTMLElement;
+ width?: number;
+ viaKeyboard?: boolean;
+}>();
+
+const emit = defineEmits<{
+ (ev: 'closed'): void;
+ (ev: 'actioned'): void;
+}>();
+
+const el = ref<HTMLElement>();
+const align = 'left';
+
+function setPosition() {
+ const rootRect = props.rootElement.getBoundingClientRect();
+ const rect = props.targetElement.getBoundingClientRect();
+ const left = props.targetElement.offsetWidth;
+ const top = (rect.top - rootRect.top) - 8;
+ el.value.style.left = left + 'px';
+ el.value.style.top = top + 'px';
+}
+
+function onChildClosed(actioned?: boolean) {
+ if (actioned) {
+ emit('actioned');
+ } else {
+ emit('closed');
+ }
+}
+
+onMounted(() => {
+ setPosition();
+ nextTick(() => {
+ setPosition();
+ });
+});
+
+defineExpose({
+ checkHit: (ev: MouseEvent) => {
+ return (ev.target === el.value || el.value.contains(ev.target));
+ },
+});
+</script>
+
+<style lang="scss" scoped>
+.sfhdhdhr {
+ position: absolute;
+}
+</style>