mirror of https://github.com/Lissy93/dashy.git
📱 Trigger section context menu on long-press (#586)
This commit is contained in:
parent
d077b1b9c9
commit
1187787ef3
|
@ -12,7 +12,8 @@
|
||||||
tabIndex="-1"
|
tabIndex="-1"
|
||||||
>
|
>
|
||||||
<label :for="sectionKey" class="lbl-toggle" tabindex="-1"
|
<label :for="sectionKey" class="lbl-toggle" tabindex="-1"
|
||||||
@mouseup.right="openContextMenu" @contextmenu.prevent>
|
@mouseup.right="openContextMenu" @contextmenu.prevent
|
||||||
|
@long-press="openContextMenu" v-longPress="500">
|
||||||
<Icon v-if="icon" :icon="icon" size="small" :url="title" class="section-icon" />
|
<Icon v-if="icon" :icon="icon" size="small" :url="title" class="section-icon" />
|
||||||
<h3>{{ title }}</h3>
|
<h3>{{ title }}</h3>
|
||||||
<EditModeIcon v-if="isEditMode" @click="openEditModal"
|
<EditModeIcon v-if="isEditMode" @click="openEditModal"
|
||||||
|
@ -29,7 +30,7 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
import longPress from '@/directives/LongPress';
|
||||||
import { localStorageKeys } from '@/utils/defaults';
|
import { localStorageKeys } from '@/utils/defaults';
|
||||||
import Icon from '@/components/LinkItems/ItemIcon.vue';
|
import Icon from '@/components/LinkItems/ItemIcon.vue';
|
||||||
import EditModeIcon from '@/assets/interface-icons/interactive-editor-edit-mode.svg';
|
import EditModeIcon from '@/assets/interface-icons/interactive-editor-edit-mode.svg';
|
||||||
|
@ -53,6 +54,9 @@ export default {
|
||||||
EditModeIcon,
|
EditModeIcon,
|
||||||
OpenIcon,
|
OpenIcon,
|
||||||
},
|
},
|
||||||
|
directives: {
|
||||||
|
longPress,
|
||||||
|
},
|
||||||
computed: {
|
computed: {
|
||||||
isEditMode() {
|
isEditMode() {
|
||||||
return this.$store.state.editMode;
|
return this.$store.state.editMode;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<template>
|
<template>
|
||||||
<Collapsable
|
<Collapsable
|
||||||
:title="title"
|
:title="title"
|
||||||
:icon="icon"
|
:icon="icon"
|
||||||
:uniqueKey="groupId"
|
:uniqueKey="groupId"
|
||||||
|
@ -11,6 +11,7 @@
|
||||||
:cutToHeight="displayData.cutToHeight"
|
:cutToHeight="displayData.cutToHeight"
|
||||||
@openEditSection="openEditSection"
|
@openEditSection="openEditSection"
|
||||||
@openContextMenu="openContextMenu"
|
@openContextMenu="openContextMenu"
|
||||||
|
:id="`section-outer-${groupId}`"
|
||||||
>
|
>
|
||||||
<!-- If no items, show message -->
|
<!-- If no items, show message -->
|
||||||
<div v-if="isEmpty" class="no-items">
|
<div v-if="isEmpty" class="no-items">
|
||||||
|
@ -294,13 +295,14 @@ export default {
|
||||||
},
|
},
|
||||||
/* Open custom context menu, and set position */
|
/* Open custom context menu, and set position */
|
||||||
openContextMenu(e) {
|
openContextMenu(e) {
|
||||||
this.contextMenuOpen = true;
|
this.contextMenuOpen = true; // Open context menu
|
||||||
if (e && window) {
|
// If mouse position not set, use section coordinates
|
||||||
this.contextPos = {
|
const sectionOuterId = `section-outer-${this.groupId}`;
|
||||||
posX: e.clientX + window.pageXOffset,
|
const sectionPosition = document.getElementById(sectionOuterId).getBoundingClientRect();
|
||||||
posY: e.clientY + window.pageYOffset,
|
this.contextPos = {
|
||||||
};
|
posX: (e.clientX || sectionPosition.right - 10) + window.pageXOffset,
|
||||||
}
|
posY: (e.clientY || sectionPosition.top + 30) + window.pageYOffset,
|
||||||
|
};
|
||||||
},
|
},
|
||||||
/* Hide the right-click context menu */
|
/* Hide the right-click context menu */
|
||||||
closeContextMenu() {
|
closeContextMenu() {
|
||||||
|
|
Loading…
Reference in New Issue