UNPKG

beautiful-react-hooks

Version:

A collection of beautiful (and hopefully useful) React hooks to speed-up your components and hooks development

45 lines (44 loc) 1.8 kB
"use strict"; var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); var react_1 = require("react"); var useDragEvents_1 = __importDefault(require("./useDragEvents")); var defaultOptions = { dragImageXOffset: 0, dragImageYOffset: 0, transferFormat: 'text', }; var useDrag = function (targetRef, options) { if (options === void 0) { options = defaultOptions; } var _a = (0, useDragEvents_1.default)(targetRef, true), onDragStart = _a.onDragStart, onDragEnd = _a.onDragEnd; var _b = (0, react_1.useState)(false), isDragging = _b[0], setIsDragging = _b[1]; var opts = __assign(__assign({}, defaultOptions), (options || {})); onDragStart(function (event) { setIsDragging(true); if (opts.dragImage) { var img = new Image(); img.src = opts.dragImage; event.dataTransfer.setDragImage(img, opts.dragImageXOffset, opts.dragImageYOffset); } if (opts.transfer) { var data = typeof opts.transfer === 'object' ? JSON.stringify(opts.transfer) : "".concat(opts.transfer); event.dataTransfer.setData(opts.transferFormat, data); } }); onDragEnd(function () { return setIsDragging(false); }); return isDragging; }; exports.default = useDrag;