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.
- package/Accordion/index.js +114 -4
- package/BackToTop/index.js +114 -4
- package/CascadingSelect/index.js +114 -4
- package/CascadingSelectE2E/index.js +114 -4
- package/Date/index.js +114 -4
- package/DigitalClock/index.js +114 -4
- package/DropdownMenu/index.js +114 -4
- package/EventCalendar/index.js +151 -23
- package/EventCalendarTimeline/index.js +265 -27
- package/LiveSearch/index.js +114 -4
- package/MasonryLayout/index.js +114 -4
- package/ModalDialog/index.d.ts +5 -0
- package/ModalDialog/index.js +135 -7
- package/MultiFuncSelect/index.js +114 -4
- package/MultilevelDropdownMenu/index.js +114 -4
- package/MultipleCheckboxes/index.js +114 -4
- package/MultipleSelect/index.js +114 -4
- package/Radio/index.js +114 -4
- package/Scrollbar/index.js +114 -4
- package/Select/index.js +114 -4
- package/Table/index.js +114 -4
- package/TagInput/index.js +114 -4
- package/Textarea/index.js +114 -4
- package/Tooltip/index.js +114 -4
- package/Tree/index.js +114 -4
- package/Utils/index.js +114 -4
- package/lib/cjs/Accordion/index.js +114 -4
- package/lib/cjs/BackToTop/index.js +114 -4
- package/lib/cjs/CascadingSelect/index.js +114 -4
- package/lib/cjs/CascadingSelectE2E/index.js +114 -4
- package/lib/cjs/Date/index.js +114 -4
- package/lib/cjs/DigitalClock/index.js +114 -4
- package/lib/cjs/DropdownMenu/index.js +114 -4
- package/lib/cjs/EventCalendar/index.js +151 -23
- package/lib/cjs/EventCalendarTimeline/index.js +265 -27
- package/lib/cjs/LiveSearch/index.js +114 -4
- package/lib/cjs/MasonryLayout/index.js +114 -4
- package/lib/cjs/ModalDialog/index.d.ts +5 -0
- package/lib/cjs/ModalDialog/index.js +135 -7
- package/lib/cjs/MultiFuncSelect/index.js +114 -4
- package/lib/cjs/MultilevelDropdownMenu/index.js +114 -4
- package/lib/cjs/MultipleCheckboxes/index.js +114 -4
- package/lib/cjs/MultipleSelect/index.js +114 -4
- package/lib/cjs/Radio/index.js +114 -4
- package/lib/cjs/Scrollbar/index.js +114 -4
- package/lib/cjs/Select/index.js +114 -4
- package/lib/cjs/Table/index.js +114 -4
- package/lib/cjs/TagInput/index.js +114 -4
- package/lib/cjs/Textarea/index.js +114 -4
- package/lib/cjs/Tooltip/index.js +114 -4
- package/lib/cjs/Tree/index.js +114 -4
- package/lib/cjs/Utils/index.js +114 -4
- package/lib/esm/ModalDialog/index.tsx +37 -4
- package/lib/esm/Utils/hooks/useDraggable.tsx +146 -8
- package/package.json +1 -1
package/Accordion/index.js
CHANGED
|
@@ -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(
|
|
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(
|
|
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)");
|
package/BackToTop/index.js
CHANGED
|
@@ -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(
|
|
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(
|
|
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)");
|
package/CascadingSelect/index.js
CHANGED
|
@@ -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(
|
|
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(
|
|
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)");
|