funda-ui 4.1.143 → 4.1.171

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/Accordion/index.js +114 -4
  2. package/BackToTop/index.js +114 -4
  3. package/CascadingSelect/index.js +114 -4
  4. package/CascadingSelectE2E/index.js +114 -4
  5. package/Date/index.js +114 -4
  6. package/DigitalClock/index.js +114 -4
  7. package/DropdownMenu/index.js +114 -4
  8. package/EventCalendar/index.js +151 -23
  9. package/EventCalendarTimeline/index.js +265 -27
  10. package/LiveSearch/index.js +114 -4
  11. package/MasonryLayout/index.js +114 -4
  12. package/ModalDialog/index.d.ts +5 -0
  13. package/ModalDialog/index.js +135 -7
  14. package/MultiFuncSelect/index.js +114 -4
  15. package/MultilevelDropdownMenu/index.js +114 -4
  16. package/MultipleCheckboxes/index.js +114 -4
  17. package/MultipleSelect/index.js +114 -4
  18. package/Radio/index.js +114 -4
  19. package/Scrollbar/index.js +114 -4
  20. package/Select/index.js +114 -4
  21. package/Table/index.js +114 -4
  22. package/TagInput/index.js +114 -4
  23. package/Textarea/index.js +114 -4
  24. package/Tooltip/index.js +114 -4
  25. package/Tree/index.js +114 -4
  26. package/Utils/index.js +114 -4
  27. package/lib/cjs/Accordion/index.js +114 -4
  28. package/lib/cjs/BackToTop/index.js +114 -4
  29. package/lib/cjs/CascadingSelect/index.js +114 -4
  30. package/lib/cjs/CascadingSelectE2E/index.js +114 -4
  31. package/lib/cjs/Date/index.js +114 -4
  32. package/lib/cjs/DigitalClock/index.js +114 -4
  33. package/lib/cjs/DropdownMenu/index.js +114 -4
  34. package/lib/cjs/EventCalendar/index.js +151 -23
  35. package/lib/cjs/EventCalendarTimeline/index.js +265 -27
  36. package/lib/cjs/LiveSearch/index.js +114 -4
  37. package/lib/cjs/MasonryLayout/index.js +114 -4
  38. package/lib/cjs/ModalDialog/index.d.ts +5 -0
  39. package/lib/cjs/ModalDialog/index.js +135 -7
  40. package/lib/cjs/MultiFuncSelect/index.js +114 -4
  41. package/lib/cjs/MultilevelDropdownMenu/index.js +114 -4
  42. package/lib/cjs/MultipleCheckboxes/index.js +114 -4
  43. package/lib/cjs/MultipleSelect/index.js +114 -4
  44. package/lib/cjs/Radio/index.js +114 -4
  45. package/lib/cjs/Scrollbar/index.js +114 -4
  46. package/lib/cjs/Select/index.js +114 -4
  47. package/lib/cjs/Table/index.js +114 -4
  48. package/lib/cjs/TagInput/index.js +114 -4
  49. package/lib/cjs/Textarea/index.js +114 -4
  50. package/lib/cjs/Tooltip/index.js +114 -4
  51. package/lib/cjs/Tree/index.js +114 -4
  52. package/lib/cjs/Utils/index.js +114 -4
  53. package/lib/esm/ModalDialog/index.tsx +37 -4
  54. package/lib/esm/Utils/hooks/useDraggable.tsx +146 -8
  55. package/package.json +1 -1
@@ -3473,7 +3473,21 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3473
3473
 
3474
3474
 
3475
3475
  const App = () => {
3476
- const [dragContentHandle, dragHandle] = useDraggable(true); // or Disable drag and drop: `useDraggable(false)`
3476
+ const [dragContentHandle, dragHandle] = useDraggable({
3477
+ enabled: true, // if `false`, drag and drop is disabled
3478
+ preventOutsideScreen: true,
3479
+ onStart: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3480
+
3481
+ },
3482
+ onDrag: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3483
+ console.log(coordinates); // {dx: -164, dy: -37}
3484
+
3485
+ },
3486
+ onStop: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3487
+
3488
+ }
3489
+ });
3490
+
3477
3491
  return (
3478
3492
  <div className="container" ref={dragContentHandle}>
3479
3493
  <div ref={dragHandle} className="handle">Drag me</div>
@@ -3487,8 +3501,14 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3487
3501
 
3488
3502
  */
3489
3503
 
3490
- var useDraggable = function useDraggable(enabled) {
3504
+ var useDraggable = function useDraggable(_ref) {
3505
+ var enabled = _ref.enabled,
3506
+ preventOutsideScreen = _ref.preventOutsideScreen,
3507
+ onStart = _ref.onStart,
3508
+ onStop = _ref.onStop,
3509
+ onDrag = _ref.onDrag;
3491
3510
  if (typeof enabled === 'undefined' || enabled === false) return [null, null];
3511
+ var dragging = false; // DO NOT USE 'useState()'
3492
3512
  var _useState = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useState)(null),
3493
3513
  _useState2 = useDraggable_slicedToArray(_useState, 2),
3494
3514
  node = _useState2[0],
@@ -3512,48 +3532,138 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3512
3532
  var targetRef = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (nodeEle) {
3513
3533
  setTargetNode(nodeEle);
3514
3534
  }, []);
3535
+ var withoutViewport = function withoutViewport(startPos, e, targetEl) {
3536
+ if (!targetEl || typeof preventOutsideScreen === 'undefined') return null;
3537
+
3538
+ // latest mouse coordinates
3539
+ var mouseX = e.clientX;
3540
+ var mouseY = e.clientY;
3541
+
3542
+ // the size of the parent element
3543
+ var parentWidth = window.innerWidth;
3544
+ var parentHeight = window.innerHeight;
3545
+
3546
+ // the size of the child element
3547
+ var childrenWidth = targetEl.clientWidth;
3548
+ var childrenHight = targetEl.clientHeight;
3549
+ var minLeft = -(parentWidth - childrenWidth) / 2;
3550
+ var maxLeft = (parentWidth - childrenWidth) / 2;
3551
+ var minTop = -(parentHeight - childrenHight) / 2;
3552
+ var maxTop = (parentHeight - childrenHight) / 2;
3553
+
3554
+ // calculates the left and top offsets after the move
3555
+ var nLeft = mouseX - startPos.x;
3556
+ var nTop = mouseY - startPos.y;
3557
+
3558
+ // calculates the right and bottom offsets after the move
3559
+ var nRight = nLeft + childrenWidth;
3560
+ var nBottom = nTop + childrenHight;
3561
+
3562
+ // Determine whether the left or right distance is out of bounds
3563
+ if (preventOutsideScreen.xAxis) {
3564
+ nLeft = nLeft <= minLeft ? minLeft : nLeft;
3565
+ nLeft = nLeft >= maxLeft ? maxLeft : nLeft;
3566
+ }
3567
+ if (preventOutsideScreen.yAxis) {
3568
+ nTop = nTop <= minTop ? minTop : nTop;
3569
+ nTop = nTop >= maxTop ? maxTop : nTop;
3570
+ }
3571
+ return [nLeft, nTop];
3572
+ };
3515
3573
  var handleMouseDown = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (e) {
3574
+ dragging = true;
3575
+ onStart === null || onStart === void 0 ? void 0 : onStart({
3576
+ dx: dx,
3577
+ dy: dy
3578
+ }, targetNode, node);
3516
3579
  var startPos = {
3517
3580
  x: e.clientX - dx,
3518
3581
  y: e.clientY - dy
3519
3582
  };
3520
3583
  var handleMouseMove = function handleMouseMove(e) {
3584
+ if (!dragging) return;
3521
3585
  var dx = e.clientX - startPos.x;
3522
3586
  var dy = e.clientY - startPos.y;
3587
+
3588
+ // prevent dragged item to be dragged outside of screen
3589
+ if (preventOutsideScreen && node) {
3590
+ var _data = withoutViewport(startPos, e, node);
3591
+ if (_data !== null) {
3592
+ dx = _data[0];
3593
+ dy = _data[1];
3594
+ }
3595
+ }
3523
3596
  setOffset({
3524
3597
  dx: dx,
3525
3598
  dy: dy
3526
3599
  });
3600
+ onDrag === null || onDrag === void 0 ? void 0 : onDrag({
3601
+ dx: dx,
3602
+ dy: dy
3603
+ }, targetNode, node);
3604
+ e.stopPropagation();
3605
+ e.preventDefault();
3527
3606
  };
3528
3607
  var handleMouseUp = function handleMouseUp() {
3608
+ dragging = false;
3609
+ onStop === null || onStop === void 0 ? void 0 : onStop({
3610
+ dx: dx,
3611
+ dy: dy
3612
+ }, targetNode, node);
3529
3613
  document.removeEventListener('mousemove', handleMouseMove);
3530
3614
  document.removeEventListener('mouseup', handleMouseUp);
3531
3615
  };
3532
3616
  document.addEventListener('mousemove', handleMouseMove);
3533
3617
  document.addEventListener('mouseup', handleMouseUp);
3534
- }, [dx, dy]);
3618
+ }, [dx, dy, node]);
3535
3619
  var handleTouchStart = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (e) {
3620
+ dragging = true;
3621
+ onStart === null || onStart === void 0 ? void 0 : onStart({
3622
+ dx: dx,
3623
+ dy: dy
3624
+ }, targetNode, node);
3536
3625
  var touch = e.touches[0];
3537
3626
  var startPos = {
3538
3627
  x: touch.clientX - dx,
3539
3628
  y: touch.clientY - dy
3540
3629
  };
3541
3630
  var handleTouchMove = function handleTouchMove(e) {
3631
+ if (!dragging) return;
3542
3632
  var touch = e.touches[0];
3543
3633
  var dx = touch.clientX - startPos.x;
3544
3634
  var dy = touch.clientY - startPos.y;
3635
+
3636
+ // prevent dragged item to be dragged outside of screen
3637
+ if (preventOutsideScreen && node) {
3638
+ var _data = withoutViewport(startPos, touch, node);
3639
+ if (_data !== null) {
3640
+ dx = _data[0];
3641
+ dy = _data[1];
3642
+ }
3643
+ }
3545
3644
  setOffset({
3546
3645
  dx: dx,
3547
3646
  dy: dy
3548
3647
  });
3648
+ onDrag === null || onDrag === void 0 ? void 0 : onDrag({
3649
+ dx: dx,
3650
+ dy: dy
3651
+ }, targetNode, node);
3652
+ e.stopPropagation();
3653
+ e.preventDefault();
3549
3654
  };
3550
3655
  var handleTouchEnd = function handleTouchEnd() {
3656
+ dragging = false;
3657
+ onStop === null || onStop === void 0 ? void 0 : onStop({
3658
+ dx: dx,
3659
+ dy: dy
3660
+ }, targetNode, node);
3551
3661
  document.removeEventListener('touchmove', handleTouchMove);
3552
3662
  document.removeEventListener('touchend', handleTouchEnd);
3553
3663
  };
3554
3664
  document.addEventListener('touchmove', handleTouchMove);
3555
3665
  document.addEventListener('touchend', handleTouchEnd);
3556
- }, [dx, dy]);
3666
+ }, [dx, dy, node]);
3557
3667
  (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useEffect)(function () {
3558
3668
  if (node) {
3559
3669
  node.style.transform = "translate3d(".concat(dx, "px, ").concat(dy, "px, 0)");
@@ -3473,7 +3473,21 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3473
3473
 
3474
3474
 
3475
3475
  const App = () => {
3476
- const [dragContentHandle, dragHandle] = useDraggable(true); // or Disable drag and drop: `useDraggable(false)`
3476
+ const [dragContentHandle, dragHandle] = useDraggable({
3477
+ enabled: true, // if `false`, drag and drop is disabled
3478
+ preventOutsideScreen: true,
3479
+ onStart: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3480
+
3481
+ },
3482
+ onDrag: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3483
+ console.log(coordinates); // {dx: -164, dy: -37}
3484
+
3485
+ },
3486
+ onStop: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3487
+
3488
+ }
3489
+ });
3490
+
3477
3491
  return (
3478
3492
  <div className="container" ref={dragContentHandle}>
3479
3493
  <div ref={dragHandle} className="handle">Drag me</div>
@@ -3487,8 +3501,14 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3487
3501
 
3488
3502
  */
3489
3503
 
3490
- var useDraggable = function useDraggable(enabled) {
3504
+ var useDraggable = function useDraggable(_ref) {
3505
+ var enabled = _ref.enabled,
3506
+ preventOutsideScreen = _ref.preventOutsideScreen,
3507
+ onStart = _ref.onStart,
3508
+ onStop = _ref.onStop,
3509
+ onDrag = _ref.onDrag;
3491
3510
  if (typeof enabled === 'undefined' || enabled === false) return [null, null];
3511
+ var dragging = false; // DO NOT USE 'useState()'
3492
3512
  var _useState = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useState)(null),
3493
3513
  _useState2 = useDraggable_slicedToArray(_useState, 2),
3494
3514
  node = _useState2[0],
@@ -3512,48 +3532,138 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3512
3532
  var targetRef = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (nodeEle) {
3513
3533
  setTargetNode(nodeEle);
3514
3534
  }, []);
3535
+ var withoutViewport = function withoutViewport(startPos, e, targetEl) {
3536
+ if (!targetEl || typeof preventOutsideScreen === 'undefined') return null;
3537
+
3538
+ // latest mouse coordinates
3539
+ var mouseX = e.clientX;
3540
+ var mouseY = e.clientY;
3541
+
3542
+ // the size of the parent element
3543
+ var parentWidth = window.innerWidth;
3544
+ var parentHeight = window.innerHeight;
3545
+
3546
+ // the size of the child element
3547
+ var childrenWidth = targetEl.clientWidth;
3548
+ var childrenHight = targetEl.clientHeight;
3549
+ var minLeft = -(parentWidth - childrenWidth) / 2;
3550
+ var maxLeft = (parentWidth - childrenWidth) / 2;
3551
+ var minTop = -(parentHeight - childrenHight) / 2;
3552
+ var maxTop = (parentHeight - childrenHight) / 2;
3553
+
3554
+ // calculates the left and top offsets after the move
3555
+ var nLeft = mouseX - startPos.x;
3556
+ var nTop = mouseY - startPos.y;
3557
+
3558
+ // calculates the right and bottom offsets after the move
3559
+ var nRight = nLeft + childrenWidth;
3560
+ var nBottom = nTop + childrenHight;
3561
+
3562
+ // Determine whether the left or right distance is out of bounds
3563
+ if (preventOutsideScreen.xAxis) {
3564
+ nLeft = nLeft <= minLeft ? minLeft : nLeft;
3565
+ nLeft = nLeft >= maxLeft ? maxLeft : nLeft;
3566
+ }
3567
+ if (preventOutsideScreen.yAxis) {
3568
+ nTop = nTop <= minTop ? minTop : nTop;
3569
+ nTop = nTop >= maxTop ? maxTop : nTop;
3570
+ }
3571
+ return [nLeft, nTop];
3572
+ };
3515
3573
  var handleMouseDown = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (e) {
3574
+ dragging = true;
3575
+ onStart === null || onStart === void 0 ? void 0 : onStart({
3576
+ dx: dx,
3577
+ dy: dy
3578
+ }, targetNode, node);
3516
3579
  var startPos = {
3517
3580
  x: e.clientX - dx,
3518
3581
  y: e.clientY - dy
3519
3582
  };
3520
3583
  var handleMouseMove = function handleMouseMove(e) {
3584
+ if (!dragging) return;
3521
3585
  var dx = e.clientX - startPos.x;
3522
3586
  var dy = e.clientY - startPos.y;
3587
+
3588
+ // prevent dragged item to be dragged outside of screen
3589
+ if (preventOutsideScreen && node) {
3590
+ var _data = withoutViewport(startPos, e, node);
3591
+ if (_data !== null) {
3592
+ dx = _data[0];
3593
+ dy = _data[1];
3594
+ }
3595
+ }
3523
3596
  setOffset({
3524
3597
  dx: dx,
3525
3598
  dy: dy
3526
3599
  });
3600
+ onDrag === null || onDrag === void 0 ? void 0 : onDrag({
3601
+ dx: dx,
3602
+ dy: dy
3603
+ }, targetNode, node);
3604
+ e.stopPropagation();
3605
+ e.preventDefault();
3527
3606
  };
3528
3607
  var handleMouseUp = function handleMouseUp() {
3608
+ dragging = false;
3609
+ onStop === null || onStop === void 0 ? void 0 : onStop({
3610
+ dx: dx,
3611
+ dy: dy
3612
+ }, targetNode, node);
3529
3613
  document.removeEventListener('mousemove', handleMouseMove);
3530
3614
  document.removeEventListener('mouseup', handleMouseUp);
3531
3615
  };
3532
3616
  document.addEventListener('mousemove', handleMouseMove);
3533
3617
  document.addEventListener('mouseup', handleMouseUp);
3534
- }, [dx, dy]);
3618
+ }, [dx, dy, node]);
3535
3619
  var handleTouchStart = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (e) {
3620
+ dragging = true;
3621
+ onStart === null || onStart === void 0 ? void 0 : onStart({
3622
+ dx: dx,
3623
+ dy: dy
3624
+ }, targetNode, node);
3536
3625
  var touch = e.touches[0];
3537
3626
  var startPos = {
3538
3627
  x: touch.clientX - dx,
3539
3628
  y: touch.clientY - dy
3540
3629
  };
3541
3630
  var handleTouchMove = function handleTouchMove(e) {
3631
+ if (!dragging) return;
3542
3632
  var touch = e.touches[0];
3543
3633
  var dx = touch.clientX - startPos.x;
3544
3634
  var dy = touch.clientY - startPos.y;
3635
+
3636
+ // prevent dragged item to be dragged outside of screen
3637
+ if (preventOutsideScreen && node) {
3638
+ var _data = withoutViewport(startPos, touch, node);
3639
+ if (_data !== null) {
3640
+ dx = _data[0];
3641
+ dy = _data[1];
3642
+ }
3643
+ }
3545
3644
  setOffset({
3546
3645
  dx: dx,
3547
3646
  dy: dy
3548
3647
  });
3648
+ onDrag === null || onDrag === void 0 ? void 0 : onDrag({
3649
+ dx: dx,
3650
+ dy: dy
3651
+ }, targetNode, node);
3652
+ e.stopPropagation();
3653
+ e.preventDefault();
3549
3654
  };
3550
3655
  var handleTouchEnd = function handleTouchEnd() {
3656
+ dragging = false;
3657
+ onStop === null || onStop === void 0 ? void 0 : onStop({
3658
+ dx: dx,
3659
+ dy: dy
3660
+ }, targetNode, node);
3551
3661
  document.removeEventListener('touchmove', handleTouchMove);
3552
3662
  document.removeEventListener('touchend', handleTouchEnd);
3553
3663
  };
3554
3664
  document.addEventListener('touchmove', handleTouchMove);
3555
3665
  document.addEventListener('touchend', handleTouchEnd);
3556
- }, [dx, dy]);
3666
+ }, [dx, dy, node]);
3557
3667
  (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useEffect)(function () {
3558
3668
  if (node) {
3559
3669
  node.style.transform = "translate3d(".concat(dx, "px, ").concat(dy, "px, 0)");
@@ -3668,7 +3668,21 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3668
3668
 
3669
3669
 
3670
3670
  const App = () => {
3671
- const [dragContentHandle, dragHandle] = useDraggable(true); // or Disable drag and drop: `useDraggable(false)`
3671
+ const [dragContentHandle, dragHandle] = useDraggable({
3672
+ enabled: true, // if `false`, drag and drop is disabled
3673
+ preventOutsideScreen: true,
3674
+ onStart: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3675
+
3676
+ },
3677
+ onDrag: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3678
+ console.log(coordinates); // {dx: -164, dy: -37}
3679
+
3680
+ },
3681
+ onStop: (coordinates: Record<string, number>, handleEl: HTMLElement | null, contentEl: HTMLElement | null) => {
3682
+
3683
+ }
3684
+ });
3685
+
3672
3686
  return (
3673
3687
  <div className="container" ref={dragContentHandle}>
3674
3688
  <div ref={dragHandle} className="handle">Drag me</div>
@@ -3682,8 +3696,14 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3682
3696
 
3683
3697
  */
3684
3698
 
3685
- var useDraggable = function useDraggable(enabled) {
3699
+ var useDraggable = function useDraggable(_ref) {
3700
+ var enabled = _ref.enabled,
3701
+ preventOutsideScreen = _ref.preventOutsideScreen,
3702
+ onStart = _ref.onStart,
3703
+ onStop = _ref.onStop,
3704
+ onDrag = _ref.onDrag;
3686
3705
  if (typeof enabled === 'undefined' || enabled === false) return [null, null];
3706
+ var dragging = false; // DO NOT USE 'useState()'
3687
3707
  var _useState = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useState)(null),
3688
3708
  _useState2 = useDraggable_slicedToArray(_useState, 2),
3689
3709
  node = _useState2[0],
@@ -3707,48 +3727,138 @@ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_
3707
3727
  var targetRef = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (nodeEle) {
3708
3728
  setTargetNode(nodeEle);
3709
3729
  }, []);
3730
+ var withoutViewport = function withoutViewport(startPos, e, targetEl) {
3731
+ if (!targetEl || typeof preventOutsideScreen === 'undefined') return null;
3732
+
3733
+ // latest mouse coordinates
3734
+ var mouseX = e.clientX;
3735
+ var mouseY = e.clientY;
3736
+
3737
+ // the size of the parent element
3738
+ var parentWidth = window.innerWidth;
3739
+ var parentHeight = window.innerHeight;
3740
+
3741
+ // the size of the child element
3742
+ var childrenWidth = targetEl.clientWidth;
3743
+ var childrenHight = targetEl.clientHeight;
3744
+ var minLeft = -(parentWidth - childrenWidth) / 2;
3745
+ var maxLeft = (parentWidth - childrenWidth) / 2;
3746
+ var minTop = -(parentHeight - childrenHight) / 2;
3747
+ var maxTop = (parentHeight - childrenHight) / 2;
3748
+
3749
+ // calculates the left and top offsets after the move
3750
+ var nLeft = mouseX - startPos.x;
3751
+ var nTop = mouseY - startPos.y;
3752
+
3753
+ // calculates the right and bottom offsets after the move
3754
+ var nRight = nLeft + childrenWidth;
3755
+ var nBottom = nTop + childrenHight;
3756
+
3757
+ // Determine whether the left or right distance is out of bounds
3758
+ if (preventOutsideScreen.xAxis) {
3759
+ nLeft = nLeft <= minLeft ? minLeft : nLeft;
3760
+ nLeft = nLeft >= maxLeft ? maxLeft : nLeft;
3761
+ }
3762
+ if (preventOutsideScreen.yAxis) {
3763
+ nTop = nTop <= minTop ? minTop : nTop;
3764
+ nTop = nTop >= maxTop ? maxTop : nTop;
3765
+ }
3766
+ return [nLeft, nTop];
3767
+ };
3710
3768
  var handleMouseDown = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (e) {
3769
+ dragging = true;
3770
+ onStart === null || onStart === void 0 ? void 0 : onStart({
3771
+ dx: dx,
3772
+ dy: dy
3773
+ }, targetNode, node);
3711
3774
  var startPos = {
3712
3775
  x: e.clientX - dx,
3713
3776
  y: e.clientY - dy
3714
3777
  };
3715
3778
  var handleMouseMove = function handleMouseMove(e) {
3779
+ if (!dragging) return;
3716
3780
  var dx = e.clientX - startPos.x;
3717
3781
  var dy = e.clientY - startPos.y;
3782
+
3783
+ // prevent dragged item to be dragged outside of screen
3784
+ if (preventOutsideScreen && node) {
3785
+ var _data = withoutViewport(startPos, e, node);
3786
+ if (_data !== null) {
3787
+ dx = _data[0];
3788
+ dy = _data[1];
3789
+ }
3790
+ }
3718
3791
  setOffset({
3719
3792
  dx: dx,
3720
3793
  dy: dy
3721
3794
  });
3795
+ onDrag === null || onDrag === void 0 ? void 0 : onDrag({
3796
+ dx: dx,
3797
+ dy: dy
3798
+ }, targetNode, node);
3799
+ e.stopPropagation();
3800
+ e.preventDefault();
3722
3801
  };
3723
3802
  var handleMouseUp = function handleMouseUp() {
3803
+ dragging = false;
3804
+ onStop === null || onStop === void 0 ? void 0 : onStop({
3805
+ dx: dx,
3806
+ dy: dy
3807
+ }, targetNode, node);
3724
3808
  document.removeEventListener('mousemove', handleMouseMove);
3725
3809
  document.removeEventListener('mouseup', handleMouseUp);
3726
3810
  };
3727
3811
  document.addEventListener('mousemove', handleMouseMove);
3728
3812
  document.addEventListener('mouseup', handleMouseUp);
3729
- }, [dx, dy]);
3813
+ }, [dx, dy, node]);
3730
3814
  var handleTouchStart = (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useCallback)(function (e) {
3815
+ dragging = true;
3816
+ onStart === null || onStart === void 0 ? void 0 : onStart({
3817
+ dx: dx,
3818
+ dy: dy
3819
+ }, targetNode, node);
3731
3820
  var touch = e.touches[0];
3732
3821
  var startPos = {
3733
3822
  x: touch.clientX - dx,
3734
3823
  y: touch.clientY - dy
3735
3824
  };
3736
3825
  var handleTouchMove = function handleTouchMove(e) {
3826
+ if (!dragging) return;
3737
3827
  var touch = e.touches[0];
3738
3828
  var dx = touch.clientX - startPos.x;
3739
3829
  var dy = touch.clientY - startPos.y;
3830
+
3831
+ // prevent dragged item to be dragged outside of screen
3832
+ if (preventOutsideScreen && node) {
3833
+ var _data = withoutViewport(startPos, touch, node);
3834
+ if (_data !== null) {
3835
+ dx = _data[0];
3836
+ dy = _data[1];
3837
+ }
3838
+ }
3740
3839
  setOffset({
3741
3840
  dx: dx,
3742
3841
  dy: dy
3743
3842
  });
3843
+ onDrag === null || onDrag === void 0 ? void 0 : onDrag({
3844
+ dx: dx,
3845
+ dy: dy
3846
+ }, targetNode, node);
3847
+ e.stopPropagation();
3848
+ e.preventDefault();
3744
3849
  };
3745
3850
  var handleTouchEnd = function handleTouchEnd() {
3851
+ dragging = false;
3852
+ onStop === null || onStop === void 0 ? void 0 : onStop({
3853
+ dx: dx,
3854
+ dy: dy
3855
+ }, targetNode, node);
3746
3856
  document.removeEventListener('touchmove', handleTouchMove);
3747
3857
  document.removeEventListener('touchend', handleTouchEnd);
3748
3858
  };
3749
3859
  document.addEventListener('touchmove', handleTouchMove);
3750
3860
  document.addEventListener('touchend', handleTouchEnd);
3751
- }, [dx, dy]);
3861
+ }, [dx, dy, node]);
3752
3862
  (0, external_root_React_commonjs2_react_commonjs_react_amd_react_.useEffect)(function () {
3753
3863
  if (node) {
3754
3864
  node.style.transform = "translate3d(".concat(dx, "px, ").concat(dy, "px, 0)");