index.mjs 2.9 KB

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