UNPKG

tdesign-vue

Version:
59 lines (55 loc) 1.89 kB
/** * 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