tdesign-vue
Version:
59 lines (55 loc) • 1.89 kB
JavaScript
/**
* tdesign v1.14.1
* (c) 2025 tdesign
* @license MIT
*/
import { ref } from '@vue/composition-api';
import { getFileList } from '../../_common/js/upload/utils.js';
import '../../_common/js/log/log.js';
function useDrag(props, accept) {
var target = ref(null);
var dragActive = ref(false);
var handleDrop = function handleDrop(event) {
var _props$onDragFileChan, _props$onDrop;
event.preventDefault();
dragActive.value = false;
var files = event.dataTransfer.files;
var dragFiles = getFileList(files, accept.value);
if (!dragFiles.length) return;
(_props$onDragFileChan = props.onDragFileChange) === null || _props$onDragFileChan === void 0 || _props$onDragFileChan.call(props, dragFiles);
(_props$onDrop = props.onDrop) === null || _props$onDrop === void 0 || _props$onDrop.call(props, {
e: event
});
};
var handleDragenter = function handleDragenter(event) {
var _props$onDragenter;
event.preventDefault();
target.value = event.target;
(_props$onDragenter = props.onDragenter) === null || _props$onDragenter === void 0 || _props$onDragenter.call(props, {
e: event
});
dragActive.value = true;
};
var handleDragleave = function handleDragleave(event) {
var _props$onDragleave;
if (event.target !== target.value) return;
event.preventDefault();
(_props$onDragleave = props.onDragleave) === null || _props$onDragleave === void 0 || _props$onDragleave.call(props, {
e: event
});
dragActive.value = false;
};
var handleDragover = function handleDragover(event) {
event.preventDefault();
};
return {
target: target,
dragActive: dragActive,
handleDrop: handleDrop,
handleDragenter: handleDragenter,
handleDragleave: handleDragleave,
handleDragover: handleDragover
};
}
export { useDrag as default };
//# sourceMappingURL=useDrag.js.map