@ringcentral/juno 2.5.0-beta.0 → 2.5.0
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/components/Buttons/IconButton/IconButton.d.ts +6 -2
- package/components/Buttons/IconButton/IconButton.js +9 -7
- package/components/Buttons/IconButton/styles/StyledIconButton.js +15 -7
- package/components/Buttons/IconButton/utils/IconButtonUtils.d.ts +1 -1
- package/components/Buttons/IconButton/utils/IconButtonUtils.js +9 -1
- package/components/Dialer/DialPad/DialPad.d.ts +25 -7
- package/components/Dialer/DialPad/DialPad.js +6 -6
- package/components/Dialer/DialPad/utils/useDialKeyboard.d.ts +8 -9
- package/components/Dialer/DialTextField/DialTextField.d.ts +3 -1
- package/components/Dialer/DialTextField/DialTextField.js +7 -6
- package/components/Downshift/styles/DownshiftStyle.d.ts +1 -1
- package/components/Forms/Picker/DatePicker/styles/StyledDatePickerHeader.d.ts +1 -1
- package/components/Forms/Picker/DatePicker/styles/StyledYear.d.ts +1 -1
- package/components/Forms/Picker/TimePicker/styles/StyledSelectionItem.d.ts +1 -1
- package/components/Forms/Picker/TimePicker/styles/StyledTimeIconButton.d.ts +1 -1
- package/components/Forms/Picker/styles/PickerBaseIconButton.d.ts +1 -1
- package/components/Forms/TextField/styles/ClearIconButton.d.ts +2 -2
- package/es6/components/Buttons/IconButton/IconButton.js +11 -9
- package/es6/components/Buttons/IconButton/styles/StyledIconButton.js +16 -8
- package/es6/components/Buttons/IconButton/utils/IconButtonUtils.js +9 -1
- package/es6/components/Dialer/DialPad/DialPad.js +6 -6
- package/es6/components/Dialer/DialTextField/DialTextField.js +7 -6
- package/es6/foundation/hooks/useLongPress/useLongPress.js +7 -7
- package/foundation/hooks/useLongPress/useLongPress.d.ts +3 -1
- package/foundation/hooks/useLongPress/useLongPress.js +7 -7
- package/package.json +1 -1
|
@@ -15,7 +15,7 @@ import { isElmEqualOrContain, useTouchMouseEvent, } from '../useTouchMouseEvent'
|
|
|
15
15
|
export var useLongPress = function (_a, _b, _c) {
|
|
16
16
|
var onTap = _a.onTap, onPress = _a.onPress;
|
|
17
17
|
var _d = _b === void 0 ? {} : _b, onTouchStart = _d.onTouchStart, onTouchEnd = _d.onTouchEnd, onMouseDown = _d.onMouseDown, onKeyDown = _d.onKeyDown, onKeyUp = _d.onKeyUp, onContextMenu = _d.onContextMenu, onMouseUpArg = _d.onMouseUp;
|
|
18
|
-
var _e = _c === void 0 ? {} : _c, _f = _e.isPreventDefault, isPreventDefault = _f === void 0 ? true : _f, _g = _e.delay, delay = _g === void 0 ? 300 : _g;
|
|
18
|
+
var _e = _c === void 0 ? {} : _c, _f = _e.isPreventDefault, isPreventDefault = _f === void 0 ? true : _f, _g = _e.delay, delay = _g === void 0 ? 300 : _g, _h = _e.externalWindow, externalWindow = _h === void 0 ? window : _h;
|
|
19
19
|
var isEmittedRef = useRef(false);
|
|
20
20
|
var isA11yDownRef = useRef(false);
|
|
21
21
|
var elmRef = useRef(null);
|
|
@@ -29,7 +29,7 @@ export var useLongPress = function (_a, _b, _c) {
|
|
|
29
29
|
}, delay);
|
|
30
30
|
var end = function (e) {
|
|
31
31
|
// ! mouse up only trigger when up on element, so we host that in document
|
|
32
|
-
document.removeEventListener('mouseup', onMouseUp);
|
|
32
|
+
externalWindow.document.removeEventListener('mouseup', onMouseUp);
|
|
33
33
|
if (!isEmittedRef.current && isElmEqualOrContain(e.target, elmRef)) {
|
|
34
34
|
onTap === null || onTap === void 0 ? void 0 : onTap(e, reasonRef.current);
|
|
35
35
|
}
|
|
@@ -39,7 +39,7 @@ export var useLongPress = function (_a, _b, _c) {
|
|
|
39
39
|
};
|
|
40
40
|
var start = function (e) {
|
|
41
41
|
// ! mouse up only trigger when up on element, so we host that in document
|
|
42
|
-
document.addEventListener('mouseup', onMouseUp);
|
|
42
|
+
externalWindow.document.addEventListener('mouseup', onMouseUp);
|
|
43
43
|
var isTouch = e.type === 'touchstart';
|
|
44
44
|
if (!isTouch)
|
|
45
45
|
e.preventDefault();
|
|
@@ -49,7 +49,7 @@ export var useLongPress = function (_a, _b, _c) {
|
|
|
49
49
|
}
|
|
50
50
|
emitLongPress(e);
|
|
51
51
|
};
|
|
52
|
-
var
|
|
52
|
+
var _j = useTouchMouseEvent({
|
|
53
53
|
onTouchStart: function (e) {
|
|
54
54
|
onTouchStart === null || onTouchStart === void 0 ? void 0 : onTouchStart(e);
|
|
55
55
|
start(e);
|
|
@@ -66,7 +66,7 @@ export var useLongPress = function (_a, _b, _c) {
|
|
|
66
66
|
onMouseUpArg === null || onMouseUpArg === void 0 ? void 0 : onMouseUpArg(e);
|
|
67
67
|
end(e);
|
|
68
68
|
},
|
|
69
|
-
}, { isPreventDefault: isPreventDefault }), onMouseUp =
|
|
69
|
+
}, { isPreventDefault: isPreventDefault }), onMouseUp = _j.onMouseUp, events = __rest(_j, ["onMouseUp"]);
|
|
70
70
|
var handleDeleteKeyDown = useA11yKeyEvent(function (e) {
|
|
71
71
|
reasonRef.current = 'keyboard';
|
|
72
72
|
// * keydown when hold will trigger many time, show when current is a11y down, not trigger again
|
|
@@ -92,8 +92,8 @@ export var useLongPress = function (_a, _b, _c) {
|
|
|
92
92
|
useEffect(function () {
|
|
93
93
|
return function () {
|
|
94
94
|
// * clean when in start remove
|
|
95
|
-
document.removeEventListener('mouseup', onMouseUp);
|
|
95
|
+
externalWindow.document.removeEventListener('mouseup', onMouseUp);
|
|
96
96
|
};
|
|
97
|
-
}, [onMouseUp]);
|
|
97
|
+
}, [onMouseUp, externalWindow]);
|
|
98
98
|
return __assign({ ref: elmRef, onContextMenu: handleContextMenu, onKeyDown: handleKeyDown, onKeyUp: handleKeyUp }, events);
|
|
99
99
|
};
|
|
@@ -5,6 +5,8 @@ export interface UseLongPressOptions {
|
|
|
5
5
|
isPreventDefault?: boolean;
|
|
6
6
|
/** the longPress delay */
|
|
7
7
|
delay?: number;
|
|
8
|
+
/** for custom window */
|
|
9
|
+
externalWindow?: Window;
|
|
8
10
|
}
|
|
9
11
|
export declare type UseLongPressEventReason = 'keyboard' | 'click' | 'tap';
|
|
10
12
|
export declare type UseLongPressOutput<T> = {
|
|
@@ -26,7 +28,7 @@ export declare type UseLongPressInput<T> = {
|
|
|
26
28
|
*
|
|
27
29
|
* @default UseLongPressOptions { isPreventDefault = true, delay = 300 }
|
|
28
30
|
*/
|
|
29
|
-
export declare const useLongPress: <T = unknown>({ onTap, onPress }: UseLongPressOutput<T>, { onTouchStart, onTouchEnd, onMouseDown, onKeyDown, onKeyUp, onContextMenu, onMouseUp: onMouseUpArg, }?: UseLongPressInput<T>, { isPreventDefault, delay }?: UseLongPressOptions) => {
|
|
31
|
+
export declare const useLongPress: <T = unknown>({ onTap, onPress }: UseLongPressOutput<T>, { onTouchStart, onTouchEnd, onMouseDown, onKeyDown, onKeyUp, onContextMenu, onMouseUp: onMouseUpArg, }?: UseLongPressInput<T>, { isPreventDefault, delay, externalWindow, }?: UseLongPressOptions) => {
|
|
30
32
|
onTouchStart: (e: any) => void;
|
|
31
33
|
onTouchEnd: (e: any) => void;
|
|
32
34
|
onMouseDown: (event: React.MouseEvent<T, MouseEvent>) => void;
|
|
@@ -17,7 +17,7 @@ var useTouchMouseEvent_1 = require("../useTouchMouseEvent");
|
|
|
17
17
|
exports.useLongPress = function (_a, _b, _c) {
|
|
18
18
|
var onTap = _a.onTap, onPress = _a.onPress;
|
|
19
19
|
var _d = _b === void 0 ? {} : _b, onTouchStart = _d.onTouchStart, onTouchEnd = _d.onTouchEnd, onMouseDown = _d.onMouseDown, onKeyDown = _d.onKeyDown, onKeyUp = _d.onKeyUp, onContextMenu = _d.onContextMenu, onMouseUpArg = _d.onMouseUp;
|
|
20
|
-
var _e = _c === void 0 ? {} : _c, _f = _e.isPreventDefault, isPreventDefault = _f === void 0 ? true : _f, _g = _e.delay, delay = _g === void 0 ? 300 : _g;
|
|
20
|
+
var _e = _c === void 0 ? {} : _c, _f = _e.isPreventDefault, isPreventDefault = _f === void 0 ? true : _f, _g = _e.delay, delay = _g === void 0 ? 300 : _g, _h = _e.externalWindow, externalWindow = _h === void 0 ? window : _h;
|
|
21
21
|
var isEmittedRef = react_1.useRef(false);
|
|
22
22
|
var isA11yDownRef = react_1.useRef(false);
|
|
23
23
|
var elmRef = react_1.useRef(null);
|
|
@@ -31,7 +31,7 @@ exports.useLongPress = function (_a, _b, _c) {
|
|
|
31
31
|
}, delay);
|
|
32
32
|
var end = function (e) {
|
|
33
33
|
// ! mouse up only trigger when up on element, so we host that in document
|
|
34
|
-
document.removeEventListener('mouseup', onMouseUp);
|
|
34
|
+
externalWindow.document.removeEventListener('mouseup', onMouseUp);
|
|
35
35
|
if (!isEmittedRef.current && useTouchMouseEvent_1.isElmEqualOrContain(e.target, elmRef)) {
|
|
36
36
|
onTap === null || onTap === void 0 ? void 0 : onTap(e, reasonRef.current);
|
|
37
37
|
}
|
|
@@ -41,7 +41,7 @@ exports.useLongPress = function (_a, _b, _c) {
|
|
|
41
41
|
};
|
|
42
42
|
var start = function (e) {
|
|
43
43
|
// ! mouse up only trigger when up on element, so we host that in document
|
|
44
|
-
document.addEventListener('mouseup', onMouseUp);
|
|
44
|
+
externalWindow.document.addEventListener('mouseup', onMouseUp);
|
|
45
45
|
var isTouch = e.type === 'touchstart';
|
|
46
46
|
if (!isTouch)
|
|
47
47
|
e.preventDefault();
|
|
@@ -51,7 +51,7 @@ exports.useLongPress = function (_a, _b, _c) {
|
|
|
51
51
|
}
|
|
52
52
|
emitLongPress(e);
|
|
53
53
|
};
|
|
54
|
-
var
|
|
54
|
+
var _j = useTouchMouseEvent_1.useTouchMouseEvent({
|
|
55
55
|
onTouchStart: function (e) {
|
|
56
56
|
onTouchStart === null || onTouchStart === void 0 ? void 0 : onTouchStart(e);
|
|
57
57
|
start(e);
|
|
@@ -68,7 +68,7 @@ exports.useLongPress = function (_a, _b, _c) {
|
|
|
68
68
|
onMouseUpArg === null || onMouseUpArg === void 0 ? void 0 : onMouseUpArg(e);
|
|
69
69
|
end(e);
|
|
70
70
|
},
|
|
71
|
-
}, { isPreventDefault: isPreventDefault }), onMouseUp =
|
|
71
|
+
}, { isPreventDefault: isPreventDefault }), onMouseUp = _j.onMouseUp, events = tslib_1.__rest(_j, ["onMouseUp"]);
|
|
72
72
|
var handleDeleteKeyDown = useA11yKeyEvent_1.useA11yKeyEvent(function (e) {
|
|
73
73
|
reasonRef.current = 'keyboard';
|
|
74
74
|
// * keydown when hold will trigger many time, show when current is a11y down, not trigger again
|
|
@@ -94,8 +94,8 @@ exports.useLongPress = function (_a, _b, _c) {
|
|
|
94
94
|
react_1.useEffect(function () {
|
|
95
95
|
return function () {
|
|
96
96
|
// * clean when in start remove
|
|
97
|
-
document.removeEventListener('mouseup', onMouseUp);
|
|
97
|
+
externalWindow.document.removeEventListener('mouseup', onMouseUp);
|
|
98
98
|
};
|
|
99
|
-
}, [onMouseUp]);
|
|
99
|
+
}, [onMouseUp, externalWindow]);
|
|
100
100
|
return tslib_1.__assign({ ref: elmRef, onContextMenu: handleContextMenu, onKeyDown: handleKeyDown, onKeyUp: handleKeyUp }, events);
|
|
101
101
|
};
|