index.mjs 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. import { ref, onMounted, watchEffect, onBeforeUnmount } from 'vue';
  2. import { addUnit } from '../../utils/dom/style.mjs';
  3. const useDraggable = (targetRef, dragRef, draggable, overflow) => {
  4. const transform = {
  5. offsetX: 0,
  6. offsetY: 0
  7. };
  8. const isDragging = ref(false);
  9. const adjustPosition = (moveX, moveY) => {
  10. if (targetRef.value) {
  11. const { offsetX, offsetY } = transform;
  12. const targetRect = targetRef.value.getBoundingClientRect();
  13. const targetLeft = targetRect.left;
  14. const targetTop = targetRect.top;
  15. const targetWidth = targetRect.width;
  16. const targetHeight = targetRect.height;
  17. const clientWidth = document.documentElement.clientWidth;
  18. const clientHeight = document.documentElement.clientHeight;
  19. const minLeft = -targetLeft + offsetX;
  20. const minTop = -targetTop + offsetY;
  21. const maxLeft = clientWidth - targetLeft - targetWidth + offsetX;
  22. const maxTop = clientHeight - targetTop - (targetHeight < clientHeight ? targetHeight : 0) + offsetY;
  23. if (!(overflow == null ? void 0 : overflow.value)) {
  24. moveX = Math.min(Math.max(moveX, minLeft), maxLeft);
  25. moveY = Math.min(Math.max(moveY, minTop), maxTop);
  26. }
  27. transform.offsetX = moveX;
  28. transform.offsetY = moveY;
  29. targetRef.value.style.transform = `translate(${addUnit(moveX)}, ${addUnit(moveY)})`;
  30. }
  31. };
  32. const onMousedown = (e) => {
  33. const downX = e.clientX;
  34. const downY = e.clientY;
  35. const { offsetX, offsetY } = transform;
  36. const onMousemove = (e2) => {
  37. if (!isDragging.value) {
  38. isDragging.value = true;
  39. }
  40. const moveX = offsetX + e2.clientX - downX;
  41. const moveY = offsetY + e2.clientY - downY;
  42. adjustPosition(moveX, moveY);
  43. };
  44. const onMouseup = () => {
  45. isDragging.value = false;
  46. document.removeEventListener("mousemove", onMousemove);
  47. document.removeEventListener("mouseup", onMouseup);
  48. };
  49. document.addEventListener("mousemove", onMousemove);
  50. document.addEventListener("mouseup", onMouseup);
  51. };
  52. const onDraggable = () => {
  53. if (dragRef.value && targetRef.value) {
  54. dragRef.value.addEventListener("mousedown", onMousedown);
  55. window.addEventListener("resize", updatePosition);
  56. }
  57. };
  58. const offDraggable = () => {
  59. if (dragRef.value && targetRef.value) {
  60. dragRef.value.removeEventListener("mousedown", onMousedown);
  61. window.removeEventListener("resize", updatePosition);
  62. }
  63. };
  64. const resetPosition = () => {
  65. transform.offsetX = 0;
  66. transform.offsetY = 0;
  67. if (targetRef.value) {
  68. targetRef.value.style.transform = "";
  69. }
  70. };
  71. const updatePosition = () => {
  72. const { offsetX, offsetY } = transform;
  73. adjustPosition(offsetX, offsetY);
  74. };
  75. onMounted(() => {
  76. watchEffect(() => {
  77. if (draggable.value) {
  78. onDraggable();
  79. } else {
  80. offDraggable();
  81. }
  82. });
  83. });
  84. onBeforeUnmount(() => {
  85. offDraggable();
  86. });
  87. return {
  88. isDragging,
  89. resetPosition,
  90. updatePosition
  91. };
  92. };
  93. export { useDraggable };
  94. //# sourceMappingURL=index.mjs.map