mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 06:37:23 +01:00
* highlight egg on dragging a potion - hide popover while dragging - flat show more button * Show EquipGearModal on Item-Click - misc fixes * disable dragging * hide egg notes while dragging * rename headgear to helm * sort equipment by name & attributes * set welcome-dialog flag * show feeding notification * select animals on click * add hatchable popover back * fix stable sortby A-Z * remove property brackets
99 lines
2.8 KiB
JavaScript
99 lines
2.8 KiB
JavaScript
/*
|
|
import {emit} from './directive.common';
|
|
|
|
|
|
import _keys from 'lodash/keys';
|
|
import _without from 'lodash/without';
|
|
*/
|
|
/**
|
|
* DRAG_GROUP is a static custom value
|
|
* KEY_OF_ITEM
|
|
*
|
|
* v-drag.DRAG_GROUP="KEY_OF_ITEM" @itemDragEnd="optional" @itemDragStart="optional"
|
|
* v-drag.drop.DRAG_GROUP="KEY_OF_ITEM" @itemDropped="callback" @itemDragOver="optional"
|
|
*/
|
|
|
|
/*
|
|
const DROPPED_EVENT_NAME = 'itemDropped';
|
|
const DRAGSTART_EVENT_NAME = 'itemDragStart';
|
|
const DRAGEND_EVENT_NAME = 'itemDragEnd';
|
|
const DRAGOVER_EVENT_NAME = 'itemDragOver';
|
|
const DRAGLEAVE_EVENT_NAME = 'itemDragLeave';
|
|
*/
|
|
export default {
|
|
/* bind (el, binding, vnode) {
|
|
el.isDropHandler = binding.modifiers.drop === true;
|
|
el.dragGroup = _without(_keys(binding.modifiers), 'drop')[0];
|
|
el.key = binding.value;
|
|
|
|
if (!el.isDropHandler) {
|
|
el.draggable = true;
|
|
el.handleDrag = (ev) => {
|
|
ev.dataTransfer.setData('KEY', binding.value);
|
|
let dragStartEventData = {
|
|
event: ev,
|
|
};
|
|
|
|
emit(vnode, DRAGSTART_EVENT_NAME, dragStartEventData);
|
|
|
|
if(!el.handleDragEnd) {
|
|
el.handleDragEnd = () => {
|
|
let dragEndEventData = {};
|
|
emit(vnode, DRAGEND_EVENT_NAME, dragEndEventData);
|
|
};
|
|
|
|
// need to add the listener after the drag begin, cause its fired right after start :/
|
|
setTimeout(function () {
|
|
el.addEventListener('dragend', el.handleDragEnd);
|
|
}, 50);
|
|
}
|
|
};
|
|
el.addEventListener('dragstart', el.handleDrag);
|
|
} else {
|
|
el.handleDragOver = (ev) => {
|
|
let dragOverEventData = {
|
|
dropable: true,
|
|
draggingKey: ev.dataTransfer.getData('KEY'),
|
|
event: ev,
|
|
};
|
|
|
|
console.info('dragover');
|
|
emit(vnode, DRAGOVER_EVENT_NAME, dragOverEventData);
|
|
|
|
if (dragOverEventData.dropable) {
|
|
ev.preventDefault();
|
|
}
|
|
};
|
|
el.handleDrop = (ev) => {
|
|
let dropEventData = {
|
|
draggingKey: ev.dataTransfer.getData('KEY'),
|
|
};
|
|
|
|
console.info('dragdrop');
|
|
emit(vnode, DROPPED_EVENT_NAME, dropEventData);
|
|
};
|
|
|
|
el.handleDragLeave = () => {
|
|
|
|
console.info('dragleave');
|
|
emit(vnode, DRAGLEAVE_EVENT_NAME, {});
|
|
};
|
|
|
|
el.addEventListener('dragover', el.handleDragOver);
|
|
el.addEventListener('dragleave', el.handleDragLeave);
|
|
el.addEventListener('drop', el.handleDrop);
|
|
}
|
|
}, */
|
|
|
|
unbind (el) {
|
|
if (!el.isDropHandler) {
|
|
el.removeEventListener('dragstart', el.handleDrag);
|
|
el.removeEventListener('dragend', el.handleDragEnd);
|
|
} else {
|
|
el.removeEventListener('dragover', el.handleDragOver);
|
|
el.removeEventListener('dragleave', el.handleDragLeave);
|
|
el.removeEventListener('drop', el.handleDrop);
|
|
}
|
|
},
|
|
};
|