@aiszlab/relax 2.0.8-beta.2 → 2.0.8-beta.4
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/dist/dom/contains.cjs +1 -1
- package/dist/dom/contains.mjs +1 -1
- package/dist/hooks/use-hover.cjs +24 -14
- package/dist/hooks/use-hover.d.ts +9 -4
- package/dist/hooks/use-hover.mjs +24 -14
- package/package.json +1 -1
package/dist/dom/contains.cjs
CHANGED
package/dist/dom/contains.mjs
CHANGED
package/dist/hooks/use-hover.cjs
CHANGED
|
@@ -1,34 +1,44 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
+
var _objectSpread = require('@babel/runtime/helpers/objectSpread2');
|
|
3
4
|
var _slicedToArray = require('@babel/runtime/helpers/slicedToArray');
|
|
5
|
+
var react = require('react');
|
|
4
6
|
var useBoolean = require('./use-boolean.cjs');
|
|
5
|
-
var chain = require('../utils/chain.cjs');
|
|
6
7
|
var useEvent = require('./use-event.cjs');
|
|
7
|
-
var
|
|
8
|
+
var contains = require('../dom/contains.cjs');
|
|
8
9
|
|
|
9
10
|
var useHover = function useHover() {
|
|
10
11
|
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|
11
12
|
onEnter = _ref.onEnter,
|
|
12
|
-
onLeave = _ref.onLeave
|
|
13
|
+
onLeave = _ref.onLeave,
|
|
14
|
+
ref = _ref.ref;
|
|
13
15
|
var _useBoolean = useBoolean.useBoolean(false),
|
|
14
16
|
_useBoolean2 = _slicedToArray(_useBoolean, 2),
|
|
15
17
|
isHovered = _useBoolean2[0],
|
|
16
18
|
_useBoolean2$ = _useBoolean2[1],
|
|
17
19
|
turnOn = _useBoolean2$.turnOn,
|
|
18
20
|
turnOff = _useBoolean2$.turnOff;
|
|
19
|
-
var
|
|
20
|
-
|
|
21
|
+
var enter = useEvent.useEvent(function (event) {
|
|
22
|
+
onEnter === null || onEnter === void 0 || onEnter(event);
|
|
23
|
+
turnOn();
|
|
21
24
|
});
|
|
22
|
-
var
|
|
23
|
-
|
|
25
|
+
var leave = useEvent.useEvent(function (event) {
|
|
26
|
+
onLeave === null || onLeave === void 0 || onLeave(event);
|
|
27
|
+
turnOff();
|
|
24
28
|
});
|
|
25
|
-
var
|
|
26
|
-
return
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
29
|
+
var moveOut = react.useCallback(function (event) {
|
|
30
|
+
if (!(ref !== null && ref !== void 0 && ref.current)) return;
|
|
31
|
+
if (contains.contains(ref === null || ref === void 0 ? void 0 : ref.current, event.relatedTarget)) return;
|
|
32
|
+
leave(event);
|
|
33
|
+
}, []);
|
|
34
|
+
return [isHovered, _objectSpread({
|
|
35
|
+
onMouseEnter: enter,
|
|
36
|
+
onPointerEnter: enter,
|
|
37
|
+
onMouseLeave: leave,
|
|
38
|
+
onPointerLeave: leave
|
|
39
|
+
}, !!ref && {
|
|
40
|
+
onMouseOut: moveOut
|
|
41
|
+
})];
|
|
32
42
|
};
|
|
33
43
|
|
|
34
44
|
exports.useHover = useHover;
|
|
@@ -1,14 +1,19 @@
|
|
|
1
|
-
import { type PointerEventHandler } from "react";
|
|
1
|
+
import { type PointerEventHandler, type MouseEventHandler, type RefObject } from "react";
|
|
2
|
+
import type { Nullable } from "../types";
|
|
2
3
|
type UsingHover<T> = {
|
|
3
|
-
onEnter?:
|
|
4
|
-
onLeave?:
|
|
4
|
+
onEnter?: MouseEventHandler<T>;
|
|
5
|
+
onLeave?: MouseEventHandler<T>;
|
|
6
|
+
ref?: RefObject<Nullable<T>>;
|
|
5
7
|
};
|
|
6
8
|
type UsedHover<T> = [
|
|
7
9
|
boolean,
|
|
8
10
|
{
|
|
9
11
|
onPointerEnter: PointerEventHandler<T>;
|
|
10
12
|
onPointerLeave: PointerEventHandler<T>;
|
|
13
|
+
onMouseEnter: MouseEventHandler<T>;
|
|
14
|
+
onMouseLeave: MouseEventHandler<T>;
|
|
15
|
+
onMouseOut?: MouseEventHandler<T>;
|
|
11
16
|
}
|
|
12
17
|
];
|
|
13
|
-
export declare const useHover: <T extends Element = Element>({ onEnter, onLeave, }?: UsingHover<T>) => UsedHover<T>;
|
|
18
|
+
export declare const useHover: <T extends Element = Element>({ onEnter, onLeave, ref, }?: UsingHover<T>) => UsedHover<T>;
|
|
14
19
|
export {};
|
package/dist/hooks/use-hover.mjs
CHANGED
|
@@ -1,32 +1,42 @@
|
|
|
1
|
+
import _objectSpread from '@babel/runtime/helpers/objectSpread2';
|
|
1
2
|
import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
|
|
3
|
+
import { useCallback } from 'react';
|
|
2
4
|
import { useBoolean } from './use-boolean.mjs';
|
|
3
|
-
import { chain } from '../utils/chain.mjs';
|
|
4
5
|
import { useEvent } from './use-event.mjs';
|
|
5
|
-
import {
|
|
6
|
+
import { contains } from '../dom/contains.mjs';
|
|
6
7
|
|
|
7
8
|
var useHover = function useHover() {
|
|
8
9
|
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|
9
10
|
onEnter = _ref.onEnter,
|
|
10
|
-
onLeave = _ref.onLeave
|
|
11
|
+
onLeave = _ref.onLeave,
|
|
12
|
+
ref = _ref.ref;
|
|
11
13
|
var _useBoolean = useBoolean(false),
|
|
12
14
|
_useBoolean2 = _slicedToArray(_useBoolean, 2),
|
|
13
15
|
isHovered = _useBoolean2[0],
|
|
14
16
|
_useBoolean2$ = _useBoolean2[1],
|
|
15
17
|
turnOn = _useBoolean2$.turnOn,
|
|
16
18
|
turnOff = _useBoolean2$.turnOff;
|
|
17
|
-
var
|
|
18
|
-
|
|
19
|
+
var enter = useEvent(function (event) {
|
|
20
|
+
onEnter === null || onEnter === void 0 || onEnter(event);
|
|
21
|
+
turnOn();
|
|
19
22
|
});
|
|
20
|
-
var
|
|
21
|
-
|
|
23
|
+
var leave = useEvent(function (event) {
|
|
24
|
+
onLeave === null || onLeave === void 0 || onLeave(event);
|
|
25
|
+
turnOff();
|
|
22
26
|
});
|
|
23
|
-
var
|
|
24
|
-
return
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
27
|
+
var moveOut = useCallback(function (event) {
|
|
28
|
+
if (!(ref !== null && ref !== void 0 && ref.current)) return;
|
|
29
|
+
if (contains(ref === null || ref === void 0 ? void 0 : ref.current, event.relatedTarget)) return;
|
|
30
|
+
leave(event);
|
|
31
|
+
}, []);
|
|
32
|
+
return [isHovered, _objectSpread({
|
|
33
|
+
onMouseEnter: enter,
|
|
34
|
+
onPointerEnter: enter,
|
|
35
|
+
onMouseLeave: leave,
|
|
36
|
+
onPointerLeave: leave
|
|
37
|
+
}, !!ref && {
|
|
38
|
+
onMouseOut: moveOut
|
|
39
|
+
})];
|
|
30
40
|
};
|
|
31
41
|
|
|
32
42
|
export { useHover };
|