react-native-skia-gesture 0.1.6 → 0.1.172
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/README.md +16 -14
- package/lib/commonjs/canvas/canvas.js +24 -10
- package/lib/commonjs/canvas/canvas.js.map +1 -1
- package/lib/commonjs/components/index.js +24 -0
- package/lib/commonjs/components/index.js.map +1 -0
- package/lib/commonjs/hoc/with-touchable-handler.js +2 -0
- package/lib/commonjs/hoc/with-touchable-handler.js.map +1 -1
- package/lib/commonjs/index.js +9 -11
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/utils/get-rect-path.js +5 -2
- package/lib/commonjs/utils/get-rect-path.js.map +1 -1
- package/lib/commonjs/utils/unwrap-animated-value.js +4 -0
- package/lib/commonjs/utils/unwrap-animated-value.js.map +1 -1
- package/lib/module/canvas/canvas.js +25 -11
- package/lib/module/canvas/canvas.js.map +1 -1
- package/lib/module/components/index.js +8 -0
- package/lib/module/components/index.js.map +1 -0
- package/lib/module/hoc/with-touchable-handler.js +2 -0
- package/lib/module/hoc/with-touchable-handler.js.map +1 -1
- package/lib/module/index.js +2 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/utils/get-rect-path.js +5 -2
- package/lib/module/utils/get-rect-path.js.map +1 -1
- package/lib/module/utils/unwrap-animated-value.js +4 -0
- package/lib/module/utils/unwrap-animated-value.js.map +1 -1
- package/lib/typescript/canvas/canvas.d.ts +1 -1
- package/lib/typescript/canvas/canvas.d.ts.map +1 -1
- package/lib/typescript/components/index.d.ts +9 -0
- package/lib/typescript/components/index.d.ts.map +1 -0
- package/lib/typescript/hoc/with-touchable-handler.d.ts +2 -2
- package/lib/typescript/hoc/with-touchable-handler.d.ts.map +1 -1
- package/lib/typescript/hooks/use-gesture-handler.d.ts +1 -1
- package/lib/typescript/hooks/use-gesture-handler.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +2 -1
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/utils/get-rect-path.d.ts +1 -1
- package/lib/typescript/utils/get-rect-path.d.ts.map +1 -1
- package/lib/typescript/utils/unwrap-animated-value.d.ts +5 -1
- package/lib/typescript/utils/unwrap-animated-value.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/canvas/canvas.tsx +34 -12
- package/src/components/index.ts +14 -0
- package/src/hoc/with-touchable-handler.tsx +9 -9
- package/src/hooks/use-gesture-handler.ts +2 -2
- package/src/index.ts +3 -1
- package/src/utils/get-rect-path.ts +7 -3
- package/src/utils/unwrap-animated-value.ts +13 -1
package/README.md
CHANGED
@@ -10,7 +10,7 @@ _A detection system for React Native Skia components._
|
|
10
10
|
|
11
11
|
### Motivation
|
12
12
|
|
13
|
-
React Native Skia, provides many declarative APIs for building screens using React Components. However, [Skia components are not real components, but abstract representations of a part of a drawing](https://github.com/Shopify/react-native-skia/issues/513#issuecomment-1290126304).
|
13
|
+
React Native Skia, provides many declarative APIs for building screens using React Components. However, [Skia components are not real components, but abstract representations of a part of a drawing](https://github.com/Shopify/react-native-skia/issues/513#issuecomment-1290126304).
|
14
14
|
Therefore direct interactions with individual Skia components can only be achieved indirectly from the Canvas (trying to figure out if the point on the screen that was clicked is within the element we want to interact with).
|
15
15
|
|
16
16
|
This package, simply provides a set of APIs to be able to interact directly with individual components.
|
@@ -35,18 +35,13 @@ npm install react-native-skia-gesture
|
|
35
35
|
|
36
36
|
```jsx
|
37
37
|
import {
|
38
|
-
Circle,
|
39
38
|
useValue,
|
40
39
|
} from '@shopify/react-native-skia';
|
41
40
|
|
42
|
-
import {
|
43
|
-
withTouchableHandler,
|
44
|
-
Canvas,
|
41
|
+
import Touchable, {
|
45
42
|
useGestureHandler,
|
46
43
|
} from 'react-native-skia-gesture';
|
47
44
|
|
48
|
-
const TouchableCircle = withTouchableHandler(Circle);
|
49
|
-
|
50
45
|
export default function App() {
|
51
46
|
const cx = useValue(100);
|
52
47
|
const cy = useValue(100);
|
@@ -63,14 +58,14 @@ export default function App() {
|
|
63
58
|
});
|
64
59
|
|
65
60
|
return (
|
66
|
-
<Canvas style={styles.fill}>
|
67
|
-
<
|
68
|
-
</Canvas>
|
61
|
+
<Touchable.Canvas style={styles.fill}>
|
62
|
+
<Touchable.Circle cx={cx} cy={cy} r={50} color="red" {...circleGesture} />
|
63
|
+
</Touchable.Canvas>
|
69
64
|
);
|
70
65
|
}
|
71
66
|
```
|
72
67
|
|
73
|
-
If the element is a **Circle**, **Rect** or **
|
68
|
+
If the element is a **Circle**, **Rect**, **RoundedRect**, or a **Path** the package will automatically derive its **touchablePath**. Alternatively it will have to be passed as a parameter to the TouchableComponent.
|
74
69
|
|
75
70
|
```jsx
|
76
71
|
...
|
@@ -81,9 +76,9 @@ const touchablePath = useComputedValue(() => {
|
|
81
76
|
}, [cx, cy]);
|
82
77
|
|
83
78
|
return (
|
84
|
-
<Canvas style={styles.fill}>
|
85
|
-
<
|
86
|
-
</Canvas>
|
79
|
+
<Touchable.Canvas style={styles.fill}>
|
80
|
+
<Touchable.Circle cx={cx} cy={cy} r={50} color="red" touchablePath={touchablePath} {...circleGesture} />
|
81
|
+
</Touchable.Canvas>
|
87
82
|
);
|
88
83
|
...
|
89
84
|
```
|
@@ -100,6 +95,13 @@ It's simply a Wrapper of Skia's Canvas.
|
|
100
95
|
|
101
96
|
It's a HOC with which to wrap all Skia components with which you want to interact directly.
|
102
97
|
|
98
|
+
```jsx
|
99
|
+
import { Image } from '@shopify/react-native-skia';
|
100
|
+
import { withTouchableHandler } from 'react-native-skia-gesture';
|
101
|
+
|
102
|
+
const TouchableImage = withTouchableHandler(Image);
|
103
|
+
```
|
104
|
+
|
103
105
|
---
|
104
106
|
|
105
107
|
### `useGestureHandler`
|
@@ -17,8 +17,8 @@ const Canvas = _ref => {
|
|
17
17
|
...props
|
18
18
|
} = _ref;
|
19
19
|
const touchableRefs = (0, _reactNativeSkia.useValue)({});
|
20
|
-
const activeKey = (0, _reactNativeSkia.useValue)(
|
21
|
-
const touchHandler = (0, _reactNativeSkia.
|
20
|
+
const activeKey = (0, _reactNativeSkia.useValue)([]);
|
21
|
+
const touchHandler = (0, _reactNativeSkia.useMultiTouchHandler)({
|
22
22
|
onStart: event => {
|
23
23
|
const keys = Object.keys(touchableRefs.current);
|
24
24
|
for (let i = 0; i < keys.length; i++) {
|
@@ -26,23 +26,37 @@ const Canvas = _ref => {
|
|
26
26
|
const touchableItem = touchableRefs.current[key];
|
27
27
|
if (touchableItem !== null && touchableItem !== void 0 && touchableItem.isPointInPath(event)) {
|
28
28
|
var _touchableItem$onStar;
|
29
|
-
activeKey.current
|
29
|
+
activeKey.current.push(`${key}__${event.id}`);
|
30
30
|
(_touchableItem$onStar = touchableItem.onStart) === null || _touchableItem$onStar === void 0 ? void 0 : _touchableItem$onStar.call(touchableItem, event);
|
31
31
|
return;
|
32
32
|
}
|
33
33
|
}
|
34
34
|
},
|
35
35
|
onActive: event => {
|
36
|
-
var _touchableItem$onActi;
|
37
|
-
|
38
|
-
|
36
|
+
var _activatedKey$split, _touchableItem$onActi;
|
37
|
+
const activatedKey = activeKey.current.find(key => key.includes(event.id.toString()));
|
38
|
+
if (!activatedKey) {
|
39
|
+
return;
|
40
|
+
}
|
41
|
+
const indexedKey = (_activatedKey$split = activatedKey.split('__')) === null || _activatedKey$split === void 0 ? void 0 : _activatedKey$split[0];
|
42
|
+
if (!indexedKey) {
|
43
|
+
return;
|
44
|
+
}
|
45
|
+
const touchableItem = touchableRefs.current[indexedKey];
|
39
46
|
return touchableItem === null || touchableItem === void 0 ? void 0 : (_touchableItem$onActi = touchableItem.onActive) === null || _touchableItem$onActi === void 0 ? void 0 : _touchableItem$onActi.call(touchableItem, event);
|
40
47
|
},
|
41
48
|
onEnd: event => {
|
42
|
-
var _touchableItem$onEnd;
|
43
|
-
|
44
|
-
|
45
|
-
|
49
|
+
var _activatedKey$split2, _touchableItem$onEnd;
|
50
|
+
const activatedKey = activeKey.current.find(key => key.includes(event.id.toString()));
|
51
|
+
if (!activatedKey) {
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
const indexedKey = (_activatedKey$split2 = activatedKey.split('__')) === null || _activatedKey$split2 === void 0 ? void 0 : _activatedKey$split2[0];
|
55
|
+
if (!indexedKey) {
|
56
|
+
return;
|
57
|
+
}
|
58
|
+
const touchableItem = touchableRefs.current[indexedKey];
|
59
|
+
activeKey.current = activeKey.current.filter(key => !key.includes(event.id.toString()));
|
46
60
|
return touchableItem === null || touchableItem === void 0 ? void 0 : (_touchableItem$onEnd = touchableItem.onEnd) === null || _touchableItem$onEnd === void 0 ? void 0 : _touchableItem$onEnd.call(touchableItem, event);
|
47
61
|
}
|
48
62
|
}, [touchableRefs, activeKey]);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["Canvas","children","onTouch","props","touchableRefs","useValue","activeKey","touchHandler","
|
1
|
+
{"version":3,"names":["Canvas","children","onTouch","props","touchableRefs","useValue","activeKey","touchHandler","useMultiTouchHandler","onStart","event","keys","Object","current","i","length","key","touchableItem","isPointInPath","push","id","onActive","activatedKey","find","includes","toString","indexedKey","split","onEnd","filter","useEffect","touchInfo"],"sourceRoot":"../../src","sources":["canvas.tsx"],"mappings":"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"}
|
@@ -0,0 +1,24 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
Object.defineProperty(exports, "Canvas", {
|
7
|
+
enumerable: true,
|
8
|
+
get: function () {
|
9
|
+
return _canvas.Canvas;
|
10
|
+
}
|
11
|
+
});
|
12
|
+
exports.RoundedRect = exports.Rect = exports.Path = exports.Circle = void 0;
|
13
|
+
var _reactNativeSkia = require("@shopify/react-native-skia");
|
14
|
+
var _hoc = require("../hoc");
|
15
|
+
var _canvas = require("../canvas");
|
16
|
+
const Circle = (0, _hoc.withTouchableHandler)(_reactNativeSkia.Circle);
|
17
|
+
exports.Circle = Circle;
|
18
|
+
const RoundedRect = (0, _hoc.withTouchableHandler)(_reactNativeSkia.RoundedRect);
|
19
|
+
exports.RoundedRect = RoundedRect;
|
20
|
+
const Rect = (0, _hoc.withTouchableHandler)(_reactNativeSkia.Rect);
|
21
|
+
exports.Rect = Rect;
|
22
|
+
const Path = (0, _hoc.withTouchableHandler)(_reactNativeSkia.Path);
|
23
|
+
exports.Path = Path;
|
24
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":["Circle","withTouchableHandler","SkiaCircle","RoundedRect","SkiaRoundedRect","Rect","SkiaRect","Path","SkiaPath"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;;;;;;;;;;;AAAA;AAMA;AAEA;AAEO,MAAMA,MAAM,GAAG,IAAAC,yBAAoB,EAACC,uBAAU,CAAC;AAAC;AAChD,MAAMC,WAAW,GAAG,IAAAF,yBAAoB,EAACG,4BAAe,CAAC;AAAC;AAC1D,MAAMC,IAAI,GAAG,IAAAJ,yBAAoB,EAACK,qBAAQ,CAAC;AAAC;AAC5C,MAAMC,IAAI,GAAG,IAAAN,yBAAoB,EAACO,qBAAQ,CAAC;AAAC"}
|
@@ -19,6 +19,8 @@ const getSkiaPath = (key, props) => {
|
|
19
19
|
return (0, _getRectPath.getRectPath)(unwrappedProps);
|
20
20
|
case 'RoundedRect':
|
21
21
|
return (0, _getRectPath.getRoundedRectPath)(unwrappedProps);
|
22
|
+
case 'Path':
|
23
|
+
return unwrappedProps.path;
|
22
24
|
default:
|
23
25
|
return null;
|
24
26
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["getSkiaPath","key","props","unwrappedProps","unwrapAnimatedValueObject","getCirclePath","getRectPath","getRoundedRectPath","withTouchableHandler","Component","onStart","onStartProp","onActive","onActiveProp","onEnd","onEndProp","touchablePath","id","useId","ref","useTouchHandlerContext","startingPoint","useValue","useCallback","event","current","x","y","translationX","translationY","isPointInPath","point","unwrapAnimatedValue","contains","
|
1
|
+
{"version":3,"names":["getSkiaPath","key","props","unwrappedProps","unwrapAnimatedValueObject","getCirclePath","getRectPath","getRoundedRectPath","path","withTouchableHandler","Component","onStart","onStartProp","onActive","onActiveProp","onEnd","onEndProp","touchablePath","id","useId","ref","useTouchHandlerContext","startingPoint","useValue","useCallback","event","current","x","y","translationX","translationY","isPointInPath","point","unwrapAnimatedValue","contains","name","Error","useEffect"],"sourceRoot":"../../src","sources":["with-touchable-handler.tsx"],"mappings":"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"}
|
package/lib/commonjs/index.js
CHANGED
@@ -3,20 +3,12 @@
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
4
4
|
value: true
|
5
5
|
});
|
6
|
-
var
|
7
|
-
|
8
|
-
if (key === "default" || key === "__esModule") return;
|
9
|
-
if (key in exports && exports[key] === _canvas[key]) return;
|
10
|
-
Object.defineProperty(exports, key, {
|
11
|
-
enumerable: true,
|
12
|
-
get: function () {
|
13
|
-
return _canvas[key];
|
14
|
-
}
|
15
|
-
});
|
16
|
-
});
|
6
|
+
var _exportNames = {};
|
7
|
+
exports.default = void 0;
|
17
8
|
var _hoc = require("./hoc");
|
18
9
|
Object.keys(_hoc).forEach(function (key) {
|
19
10
|
if (key === "default" || key === "__esModule") return;
|
11
|
+
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
20
12
|
if (key in exports && exports[key] === _hoc[key]) return;
|
21
13
|
Object.defineProperty(exports, key, {
|
22
14
|
enumerable: true,
|
@@ -28,6 +20,7 @@ Object.keys(_hoc).forEach(function (key) {
|
|
28
20
|
var _useGestureHandler = require("./hooks/use-gesture-handler");
|
29
21
|
Object.keys(_useGestureHandler).forEach(function (key) {
|
30
22
|
if (key === "default" || key === "__esModule") return;
|
23
|
+
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
31
24
|
if (key in exports && exports[key] === _useGestureHandler[key]) return;
|
32
25
|
Object.defineProperty(exports, key, {
|
33
26
|
enumerable: true,
|
@@ -36,4 +29,9 @@ Object.keys(_useGestureHandler).forEach(function (key) {
|
|
36
29
|
}
|
37
30
|
});
|
38
31
|
});
|
32
|
+
var Touchable = _interopRequireWildcard(require("./components"));
|
33
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
34
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
35
|
+
var _default = Touchable;
|
36
|
+
exports.default = _default;
|
39
37
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":[],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"
|
1
|
+
{"version":3,"names":["Touchable"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;;;;;;AAAA;AAAA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AACA;AAAA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AACA;AAA0C;AAAA;AAAA,eAE3BA,SAAS;AAAA"}
|
@@ -29,12 +29,14 @@ const getRoundedRectPath = params => {
|
|
29
29
|
const {
|
30
30
|
r
|
31
31
|
} = params;
|
32
|
+
const skPath = _reactNativeSkia.Skia.Path.Make();
|
32
33
|
if ('rect' in params) {
|
33
34
|
// eslint-disable-next-line @typescript-eslint/no-shadow
|
34
35
|
const {
|
35
36
|
rect
|
36
37
|
} = params;
|
37
|
-
|
38
|
+
skPath.addRRect((0, _reactNativeSkia.rrect)(rect, r, r));
|
39
|
+
return skPath;
|
38
40
|
}
|
39
41
|
const {
|
40
42
|
x,
|
@@ -42,7 +44,8 @@ const getRoundedRectPath = params => {
|
|
42
44
|
width,
|
43
45
|
height
|
44
46
|
} = params;
|
45
|
-
|
47
|
+
skPath.addRRect((0, _reactNativeSkia.rrect)((0, _reactNativeSkia.rect)(x, y, width, height), r, r));
|
48
|
+
return skPath;
|
46
49
|
};
|
47
50
|
exports.getRoundedRectPath = getRoundedRectPath;
|
48
51
|
//# sourceMappingURL=get-rect-path.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["getRectPath","params","skPath","Skia","Path","Make","rect","addRect","x","y","width","height","getRoundedRectPath","r","addRRect","rrect"],"sourceRoot":"../../src","sources":["get-rect-path.ts"],"mappings":";;;;;;AAAA;AAWA,MAAMA,WAAW,GAAIC,MAAyB,IAAK;EACjD,MAAMC,MAAM,GAAGC,qBAAI,CAACC,IAAI,CAACC,IAAI,EAAE;EAC/B,IAAI,MAAM,IAAIJ,MAAM,EAAE;IACpB;IACA,MAAM;MAAEK;IAAK,CAAC,GAAGL,MAAM;IAEvBC,MAAM,CAACK,OAAO,CAACD,IAAI,CAAC;IACpB,OAAOJ,MAAM;EACf;EACA,MAAM;IAAEM,CAAC;IAAEC,CAAC;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGV,MAAM;EACtCC,MAAM,CAACK,OAAO,CAAC,IAAAD,qBAAI,EAACE,CAAC,EAAEC,CAAC,EAAEC,KAAK,EAAEC,MAAM,CAAC,CAAC;EACzC,OAAOT,MAAM;AACf,CAAC;AAAC;AAMF,MAAMU,kBAAkB,GAAIX,MAAgC,IAAK;EAC/D,MAAM;IAAEY;EAAE,CAAC,GAAGZ,MAAM;EACpB,IAAI,MAAM,
|
1
|
+
{"version":3,"names":["getRectPath","params","skPath","Skia","Path","Make","rect","addRect","x","y","width","height","getRoundedRectPath","r","addRRect","rrect"],"sourceRoot":"../../src","sources":["get-rect-path.ts"],"mappings":";;;;;;AAAA;AAWA,MAAMA,WAAW,GAAIC,MAAyB,IAAK;EACjD,MAAMC,MAAM,GAAGC,qBAAI,CAACC,IAAI,CAACC,IAAI,EAAE;EAC/B,IAAI,MAAM,IAAIJ,MAAM,EAAE;IACpB;IACA,MAAM;MAAEK;IAAK,CAAC,GAAGL,MAAM;IAEvBC,MAAM,CAACK,OAAO,CAACD,IAAI,CAAC;IACpB,OAAOJ,MAAM;EACf;EACA,MAAM;IAAEM,CAAC;IAAEC,CAAC;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGV,MAAM;EACtCC,MAAM,CAACK,OAAO,CAAC,IAAAD,qBAAI,EAACE,CAAC,EAAEC,CAAC,EAAEC,KAAK,EAAEC,MAAM,CAAC,CAAC;EACzC,OAAOT,MAAM;AACf,CAAC;AAAC;AAMF,MAAMU,kBAAkB,GAAIX,MAAgC,IAAK;EAC/D,MAAM;IAAEY;EAAE,CAAC,GAAGZ,MAAM;EACpB,MAAMC,MAAM,GAAGC,qBAAI,CAACC,IAAI,CAACC,IAAI,EAAE;EAC/B,IAAI,MAAM,IAAIJ,MAAM,EAAE;IACpB;IACA,MAAM;MAAEK;IAAK,CAAC,GAAGL,MAAM;IACvBC,MAAM,CAACY,QAAQ,CAAC,IAAAC,sBAAK,EAACT,IAAI,EAAEO,CAAC,EAAEA,CAAC,CAAC,CAAC;IAClC,OAAOX,MAAM;EACf;EACA,MAAM;IAAEM,CAAC;IAAEC,CAAC;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGV,MAAM;EAEtCC,MAAM,CAACY,QAAQ,CAAC,IAAAC,sBAAK,EAAC,IAAAT,qBAAI,EAACE,CAAC,EAAEC,CAAC,EAAEC,KAAK,EAAEC,MAAM,CAAC,EAAEE,CAAC,EAAEA,CAAC,CAAC,CAAC;EACvD,OAAOX,MAAM;AACf,CAAC;AAAC"}
|
@@ -8,6 +8,10 @@ const unwrapAnimatedValue = value => {
|
|
8
8
|
if (value.current != null) {
|
9
9
|
return value.current;
|
10
10
|
}
|
11
|
+
if (value.selector != null) {
|
12
|
+
const skiaValueWithSelector = value;
|
13
|
+
return skiaValueWithSelector.selector(skiaValueWithSelector.value.current);
|
14
|
+
}
|
11
15
|
return value;
|
12
16
|
};
|
13
17
|
exports.unwrapAnimatedValue = unwrapAnimatedValue;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["unwrapAnimatedValue","value","current","unwrapAnimatedValueObject","Object","keys","reduce","acc","key"],"sourceRoot":"../../src","sources":["unwrap-animated-value.ts"],"mappings":";;;;;;
|
1
|
+
{"version":3,"names":["unwrapAnimatedValue","value","current","selector","skiaValueWithSelector","unwrapAnimatedValueObject","Object","keys","reduce","acc","key"],"sourceRoot":"../../src","sources":["unwrap-animated-value.ts"],"mappings":";;;;;;AAMA,MAAMA,mBAAmB,GACvBC,KAAkD,IAC5C;EACN,IAAKA,KAAK,CAAkBC,OAAO,IAAI,IAAI,EAAE;IAC3C,OAAQD,KAAK,CAAkBC,OAAO;EACxC;EAEA,IAAKD,KAAK,CAA8BE,QAAQ,IAAI,IAAI,EAAE;IACxD,MAAMC,qBAAqB,GAAGH,KAAiC;IAC/D,OAAOG,qBAAqB,CAACD,QAAQ,CAACC,qBAAqB,CAACH,KAAK,CAACC,OAAO,CAAC;EAC5E;EAEA,OAAOD,KAAK;AACd,CAAC;AAAC;AAEF,MAAMI,yBAAyB,GAC7BJ,KAAoC,IACjB;EACnB,OAAOK,MAAM,CAACC,IAAI,CAACN,KAAK,CAAC,CAACO,MAAM,CAAC,CAACC,GAAG,EAAEC,GAAG,KAAK;IAC7C,OAAO;MAAE,GAAGD,GAAG;MAAE,CAACC,GAAG,GAAGV,mBAAmB,CAACC,KAAK,CAACS,GAAG,CAAC;IAAE,CAAC;EAC3D,CAAC,EAAE,CAAC,CAAC,CAAC;AACR,CAAC;AAAC"}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
2
|
-
import { Canvas as SkiaCanvas,
|
2
|
+
import { Canvas as SkiaCanvas, useMultiTouchHandler, useValue } from '@shopify/react-native-skia';
|
3
3
|
import React, { useEffect } from 'react';
|
4
4
|
import { TouchHandlerContext } from './context';
|
5
5
|
const Canvas = _ref => {
|
@@ -9,8 +9,8 @@ const Canvas = _ref => {
|
|
9
9
|
...props
|
10
10
|
} = _ref;
|
11
11
|
const touchableRefs = useValue({});
|
12
|
-
const activeKey = useValue(
|
13
|
-
const touchHandler =
|
12
|
+
const activeKey = useValue([]);
|
13
|
+
const touchHandler = useMultiTouchHandler({
|
14
14
|
onStart: event => {
|
15
15
|
const keys = Object.keys(touchableRefs.current);
|
16
16
|
for (let i = 0; i < keys.length; i++) {
|
@@ -18,23 +18,37 @@ const Canvas = _ref => {
|
|
18
18
|
const touchableItem = touchableRefs.current[key];
|
19
19
|
if (touchableItem !== null && touchableItem !== void 0 && touchableItem.isPointInPath(event)) {
|
20
20
|
var _touchableItem$onStar;
|
21
|
-
activeKey.current
|
21
|
+
activeKey.current.push(`${key}__${event.id}`);
|
22
22
|
(_touchableItem$onStar = touchableItem.onStart) === null || _touchableItem$onStar === void 0 ? void 0 : _touchableItem$onStar.call(touchableItem, event);
|
23
23
|
return;
|
24
24
|
}
|
25
25
|
}
|
26
26
|
},
|
27
27
|
onActive: event => {
|
28
|
-
var _touchableItem$onActi;
|
29
|
-
|
30
|
-
|
28
|
+
var _activatedKey$split, _touchableItem$onActi;
|
29
|
+
const activatedKey = activeKey.current.find(key => key.includes(event.id.toString()));
|
30
|
+
if (!activatedKey) {
|
31
|
+
return;
|
32
|
+
}
|
33
|
+
const indexedKey = (_activatedKey$split = activatedKey.split('__')) === null || _activatedKey$split === void 0 ? void 0 : _activatedKey$split[0];
|
34
|
+
if (!indexedKey) {
|
35
|
+
return;
|
36
|
+
}
|
37
|
+
const touchableItem = touchableRefs.current[indexedKey];
|
31
38
|
return touchableItem === null || touchableItem === void 0 ? void 0 : (_touchableItem$onActi = touchableItem.onActive) === null || _touchableItem$onActi === void 0 ? void 0 : _touchableItem$onActi.call(touchableItem, event);
|
32
39
|
},
|
33
40
|
onEnd: event => {
|
34
|
-
var _touchableItem$onEnd;
|
35
|
-
|
36
|
-
|
37
|
-
|
41
|
+
var _activatedKey$split2, _touchableItem$onEnd;
|
42
|
+
const activatedKey = activeKey.current.find(key => key.includes(event.id.toString()));
|
43
|
+
if (!activatedKey) {
|
44
|
+
return;
|
45
|
+
}
|
46
|
+
const indexedKey = (_activatedKey$split2 = activatedKey.split('__')) === null || _activatedKey$split2 === void 0 ? void 0 : _activatedKey$split2[0];
|
47
|
+
if (!indexedKey) {
|
48
|
+
return;
|
49
|
+
}
|
50
|
+
const touchableItem = touchableRefs.current[indexedKey];
|
51
|
+
activeKey.current = activeKey.current.filter(key => !key.includes(event.id.toString()));
|
38
52
|
return touchableItem === null || touchableItem === void 0 ? void 0 : (_touchableItem$onEnd = touchableItem.onEnd) === null || _touchableItem$onEnd === void 0 ? void 0 : _touchableItem$onEnd.call(touchableItem, event);
|
39
53
|
}
|
40
54
|
}, [touchableRefs, activeKey]);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["Canvas","SkiaCanvas","
|
1
|
+
{"version":3,"names":["Canvas","SkiaCanvas","useMultiTouchHandler","useValue","React","useEffect","TouchHandlerContext","children","onTouch","props","touchableRefs","activeKey","touchHandler","onStart","event","keys","Object","current","i","length","key","touchableItem","isPointInPath","push","id","onActive","activatedKey","find","includes","toString","indexedKey","split","onEnd","filter","touchInfo"],"sourceRoot":"../../src","sources":["canvas.tsx"],"mappings":"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"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import { Circle as SkiaCircle, RoundedRect as SkiaRoundedRect, Rect as SkiaRect, Path as SkiaPath } from '@shopify/react-native-skia';
|
2
|
+
import { withTouchableHandler } from '../hoc';
|
3
|
+
export { Canvas } from '../canvas';
|
4
|
+
export const Circle = withTouchableHandler(SkiaCircle);
|
5
|
+
export const RoundedRect = withTouchableHandler(SkiaRoundedRect);
|
6
|
+
export const Rect = withTouchableHandler(SkiaRect);
|
7
|
+
export const Path = withTouchableHandler(SkiaPath);
|
8
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":["Circle","SkiaCircle","RoundedRect","SkiaRoundedRect","Rect","SkiaRect","Path","SkiaPath","withTouchableHandler","Canvas"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,SACEA,MAAM,IAAIC,UAAU,EACpBC,WAAW,IAAIC,eAAe,EAC9BC,IAAI,IAAIC,QAAQ,EAChBC,IAAI,IAAIC,QAAQ,QACX,4BAA4B;AACnC,SAASC,oBAAoB,QAAQ,QAAQ;AAE7C,SAASC,MAAM,QAAQ,WAAW;AAElC,OAAO,MAAMT,MAAM,GAAGQ,oBAAoB,CAACP,UAAU,CAAC;AACtD,OAAO,MAAMC,WAAW,GAAGM,oBAAoB,CAACL,eAAe,CAAC;AAChE,OAAO,MAAMC,IAAI,GAAGI,oBAAoB,CAACH,QAAQ,CAAC;AAClD,OAAO,MAAMC,IAAI,GAAGE,oBAAoB,CAACD,QAAQ,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["useValue","useCallback","useEffect","useId","getCirclePath","getRectPath","getRoundedRectPath","unwrapAnimatedValue","unwrapAnimatedValueObject","useTouchHandlerContext","getSkiaPath","key","props","unwrappedProps","withTouchableHandler","Component","onStart","onStartProp","onActive","onActiveProp","onEnd","onEndProp","touchablePath","id","ref","startingPoint","event","current","x","y","translationX","translationY","isPointInPath","point","contains","
|
1
|
+
{"version":3,"names":["useValue","useCallback","useEffect","useId","getCirclePath","getRectPath","getRoundedRectPath","unwrapAnimatedValue","unwrapAnimatedValueObject","useTouchHandlerContext","getSkiaPath","key","props","unwrappedProps","path","withTouchableHandler","Component","onStart","onStartProp","onActive","onActiveProp","onEnd","onEndProp","touchablePath","id","ref","startingPoint","event","current","x","y","translationX","translationY","isPointInPath","point","contains","name","Error"],"sourceRoot":"../../src","sources":["with-touchable-handler.tsx"],"mappings":"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"}
|
package/lib/module/index.js
CHANGED
package/lib/module/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":[],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,cAAc,
|
1
|
+
{"version":3,"names":["Touchable"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"AAAA,cAAc,OAAO;AACrB,cAAc,6BAA6B;AAC3C,OAAO,KAAKA,SAAS,MAAM,cAAc;AAEzC,eAAeA,SAAS"}
|
@@ -22,12 +22,14 @@ const getRoundedRectPath = params => {
|
|
22
22
|
const {
|
23
23
|
r
|
24
24
|
} = params;
|
25
|
+
const skPath = Skia.Path.Make();
|
25
26
|
if ('rect' in params) {
|
26
27
|
// eslint-disable-next-line @typescript-eslint/no-shadow
|
27
28
|
const {
|
28
29
|
rect
|
29
30
|
} = params;
|
30
|
-
|
31
|
+
skPath.addRRect(rrect(rect, r, r));
|
32
|
+
return skPath;
|
31
33
|
}
|
32
34
|
const {
|
33
35
|
x,
|
@@ -35,7 +37,8 @@ const getRoundedRectPath = params => {
|
|
35
37
|
width,
|
36
38
|
height
|
37
39
|
} = params;
|
38
|
-
|
40
|
+
skPath.addRRect(rrect(rect(x, y, width, height), r, r));
|
41
|
+
return skPath;
|
39
42
|
};
|
40
43
|
export { getRectPath, getRoundedRectPath };
|
41
44
|
//# sourceMappingURL=get-rect-path.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["rect","rrect","Skia","getRectPath","params","skPath","Path","Make","addRect","x","y","width","height","getRoundedRectPath","r","addRRect"],"sourceRoot":"../../src","sources":["get-rect-path.ts"],"mappings":"AAAA,SAASA,IAAI,EAAEC,KAAK,EAAEC,IAAI,
|
1
|
+
{"version":3,"names":["rect","rrect","Skia","getRectPath","params","skPath","Path","Make","addRect","x","y","width","height","getRoundedRectPath","r","addRRect"],"sourceRoot":"../../src","sources":["get-rect-path.ts"],"mappings":"AAAA,SAASA,IAAI,EAAEC,KAAK,EAAEC,IAAI,QAAqB,4BAA4B;AAW3E,MAAMC,WAAW,GAAIC,MAAyB,IAAK;EACjD,MAAMC,MAAM,GAAGH,IAAI,CAACI,IAAI,CAACC,IAAI,EAAE;EAC/B,IAAI,MAAM,IAAIH,MAAM,EAAE;IACpB;IACA,MAAM;MAAEJ;IAAK,CAAC,GAAGI,MAAM;IAEvBC,MAAM,CAACG,OAAO,CAACR,IAAI,CAAC;IACpB,OAAOK,MAAM;EACf;EACA,MAAM;IAAEI,CAAC;IAAEC,CAAC;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGR,MAAM;EACtCC,MAAM,CAACG,OAAO,CAACR,IAAI,CAACS,CAAC,EAAEC,CAAC,EAAEC,KAAK,EAAEC,MAAM,CAAC,CAAC;EACzC,OAAOP,MAAM;AACf,CAAC;AAMD,MAAMQ,kBAAkB,GAAIT,MAAgC,IAAK;EAC/D,MAAM;IAAEU;EAAE,CAAC,GAAGV,MAAM;EACpB,MAAMC,MAAM,GAAGH,IAAI,CAACI,IAAI,CAACC,IAAI,EAAE;EAC/B,IAAI,MAAM,IAAIH,MAAM,EAAE;IACpB;IACA,MAAM;MAAEJ;IAAK,CAAC,GAAGI,MAAM;IACvBC,MAAM,CAACU,QAAQ,CAACd,KAAK,CAACD,IAAI,EAAEc,CAAC,EAAEA,CAAC,CAAC,CAAC;IAClC,OAAOT,MAAM;EACf;EACA,MAAM;IAAEI,CAAC;IAAEC,CAAC;IAAEC,KAAK;IAAEC;EAAO,CAAC,GAAGR,MAAM;EAEtCC,MAAM,CAACU,QAAQ,CAACd,KAAK,CAACD,IAAI,CAACS,CAAC,EAAEC,CAAC,EAAEC,KAAK,EAAEC,MAAM,CAAC,EAAEE,CAAC,EAAEA,CAAC,CAAC,CAAC;EACvD,OAAOT,MAAM;AACf,CAAC;AAED,SAASF,WAAW,EAAEU,kBAAkB"}
|
@@ -2,6 +2,10 @@ const unwrapAnimatedValue = value => {
|
|
2
2
|
if (value.current != null) {
|
3
3
|
return value.current;
|
4
4
|
}
|
5
|
+
if (value.selector != null) {
|
6
|
+
const skiaValueWithSelector = value;
|
7
|
+
return skiaValueWithSelector.selector(skiaValueWithSelector.value.current);
|
8
|
+
}
|
5
9
|
return value;
|
6
10
|
};
|
7
11
|
const unwrapAnimatedValueObject = value => {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["unwrapAnimatedValue","value","current","unwrapAnimatedValueObject","Object","keys","reduce","acc","key"],"sourceRoot":"../../src","sources":["unwrap-animated-value.ts"],"mappings":"
|
1
|
+
{"version":3,"names":["unwrapAnimatedValue","value","current","selector","skiaValueWithSelector","unwrapAnimatedValueObject","Object","keys","reduce","acc","key"],"sourceRoot":"../../src","sources":["unwrap-animated-value.ts"],"mappings":"AAMA,MAAMA,mBAAmB,GACvBC,KAAkD,IAC5C;EACN,IAAKA,KAAK,CAAkBC,OAAO,IAAI,IAAI,EAAE;IAC3C,OAAQD,KAAK,CAAkBC,OAAO;EACxC;EAEA,IAAKD,KAAK,CAA8BE,QAAQ,IAAI,IAAI,EAAE;IACxD,MAAMC,qBAAqB,GAAGH,KAAiC;IAC/D,OAAOG,qBAAqB,CAACD,QAAQ,CAACC,qBAAqB,CAACH,KAAK,CAACC,OAAO,CAAC;EAC5E;EAEA,OAAOD,KAAK;AACd,CAAC;AAED,MAAMI,yBAAyB,GAC7BJ,KAAoC,IACjB;EACnB,OAAOK,MAAM,CAACC,IAAI,CAACN,KAAK,CAAC,CAACO,MAAM,CAAC,CAACC,GAAG,EAAEC,GAAG,KAAK;IAC7C,OAAO;MAAE,GAAGD,GAAG;MAAE,CAACC,GAAG,GAAGV,mBAAmB,CAACC,KAAK,CAACS,GAAG,CAAC;IAAE,CAAC;EAC3D,CAAC,EAAE,CAAC,CAAC,CAAC;AACR,CAAC;AAED,SAASV,mBAAmB,EAAEK,yBAAyB"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"canvas.d.ts","sourceRoot":"","sources":["../../../src/canvas/canvas.tsx"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,
|
1
|
+
{"version":3,"file":"canvas.d.ts","sourceRoot":"","sources":["../../../src/canvas/canvas.tsx"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,WAAW,EAGjB,MAAM,4BAA4B,CAAC;AACpC,OAAO,KAAoB,MAAM,OAAO,CAAC;AAMzC,QAAA,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,WAAW,CAyEjC,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,CAAC"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
export { Canvas } from '../canvas';
|
2
|
+
export declare const Circle: ({ onStart: onStartProp, onActive: onActiveProp, onEnd: onEndProp, touchablePath, ...props }: import("@shopify/react-native-skia").AnimatedProps<import("@shopify/react-native-skia").CircleProps, never> & Partial<import("../hoc").TouchableHandlerProps>) => JSX.Element;
|
3
|
+
export declare const RoundedRect: ({ onStart: onStartProp, onActive: onActiveProp, onEnd: onEndProp, touchablePath, ...props }: import("@shopify/react-native-skia").AnimatedProps<import("@shopify/react-native-skia").RoundedRectProps, never> & Partial<import("../hoc").TouchableHandlerProps>) => JSX.Element;
|
4
|
+
export declare const Rect: ({ onStart: onStartProp, onActive: onActiveProp, onEnd: onEndProp, touchablePath, ...props }: import("@shopify/react-native-skia").AnimatedProps<import("@shopify/react-native-skia").RectProps, never> & Partial<import("../hoc").TouchableHandlerProps>) => JSX.Element;
|
5
|
+
export declare const Path: ({ onStart: onStartProp, onActive: onActiveProp, onEnd: onEndProp, touchablePath, ...props }: Omit<import("@shopify/react-native-skia").AnimatedProps<import("@shopify/react-native-skia").PathProps, never>, "start" | "end"> & {
|
6
|
+
start?: import("@shopify/react-native-skia").AnimatedProp<number, any> | undefined;
|
7
|
+
end?: import("@shopify/react-native-skia").AnimatedProp<number, any> | undefined;
|
8
|
+
} & Partial<import("../hoc").TouchableHandlerProps>) => JSX.Element;
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAEnC,eAAO,MAAM,MAAM,6QAAmC,CAAC;AACvD,eAAO,MAAM,WAAW,kRAAwC,CAAC;AACjE,eAAO,MAAM,IAAI,2QAAiC,CAAC;AACnD,eAAO,MAAM,IAAI;;;mEAAiC,CAAC"}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { ExtendedTouchInfo,
|
1
|
+
import { type ExtendedTouchInfo, type SkiaValue, type SkPath, type TouchInfo } from '@shopify/react-native-skia';
|
2
2
|
export type TranslationInfo = {
|
3
3
|
translationX: number;
|
4
4
|
translationY: number;
|
@@ -9,7 +9,7 @@ export type TouchableHandlerProps = {
|
|
9
9
|
onEnd: (touchInfo: ExtendedTouchInfo & TranslationInfo) => void;
|
10
10
|
touchablePath: SkPath | SkiaValue<SkPath>;
|
11
11
|
};
|
12
|
-
type WithTouchableHandlerProps<T> =
|
12
|
+
type WithTouchableHandlerProps<T> = T & Partial<TouchableHandlerProps>;
|
13
13
|
declare const withTouchableHandler: <T>(Component: (props: WithTouchableHandlerProps<T>) => JSX.Element) => ({ onStart: onStartProp, onActive: onActiveProp, onEnd: onEndProp, touchablePath, ...props }: WithTouchableHandlerProps<T>) => JSX.Element;
|
14
14
|
export { withTouchableHandler };
|
15
15
|
//# sourceMappingURL=with-touchable-handler.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"with-touchable-handler.d.ts","sourceRoot":"","sources":["../../../src/hoc/with-touchable-handler.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,
|
1
|
+
{"version":3,"file":"with-touchable-handler.d.ts","sourceRoot":"","sources":["../../../src/hoc/with-touchable-handler.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,SAAS,EACd,KAAK,MAAM,EACX,KAAK,SAAS,EAGf,MAAM,4BAA4B,CAAC;AAUpC,MAAM,MAAM,eAAe,GAAG;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,OAAO,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,IAAI,CAAC;IACxC,QAAQ,EAAE,CAAC,SAAS,EAAE,iBAAiB,GAAG,eAAe,KAAK,IAAI,CAAC;IACnE,KAAK,EAAE,CAAC,SAAS,EAAE,iBAAiB,GAAG,eAAe,KAAK,IAAI,CAAC;IAChE,aAAa,EAAE,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;CAC3C,CAAC;AAEF,KAAK,yBAAyB,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC;AAmBvE,QAAA,MAAM,oBAAoB,0DAC4B,WAAW,+IA2EhE,CAAC;AAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { ExtendedTouchInfo, TouchInfo } from '@shopify/react-native-skia';
|
1
|
+
import { type ExtendedTouchInfo, type TouchInfo } from '@shopify/react-native-skia';
|
2
2
|
import type { TranslationInfo } from '../hoc';
|
3
3
|
type UseGestureHandlerParams<ContextType> = {
|
4
4
|
onStart?: (touchInfo: TouchInfo, context: ContextType) => void;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"use-gesture-handler.d.ts","sourceRoot":"","sources":["../../../src/hooks/use-gesture-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,
|
1
|
+
{"version":3,"file":"use-gesture-handler.d.ts","sourceRoot":"","sources":["../../../src/hooks/use-gesture-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,SAAS,EAEf,MAAM,4BAA4B,CAAC;AAEpC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAE9C,KAAK,uBAAuB,CAAC,WAAW,IAAI;IAC1C,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,KAAK,IAAI,CAAC;IAC/D,QAAQ,CAAC,EAAE,CACT,iBAAiB,EAAE,iBAAiB,GAAG,eAAe,EACtD,OAAO,EAAE,WAAW,KACjB,IAAI,CAAC;IACV,KAAK,CAAC,EAAE,CACN,iBAAiB,EAAE,iBAAiB,GAAG,eAAe,EACtD,OAAO,EAAE,WAAW,KACjB,IAAI,CAAC;CACX,CAAC;AAEF,QAAA,MAAM,iBAAiB;yBAQP,SAAS;kCAQD,iBAAiB,GAAG,eAAe;+BAQnC,iBAAiB,GAAG,eAAe;CAY1D,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAAE,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,6BAA6B,CAAC;AAC5C,OAAO,KAAK,SAAS,MAAM,cAAc,CAAC;AAE1C,eAAe,SAAS,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"get-rect-path.d.ts","sourceRoot":"","sources":["../../../src/utils/get-rect-path.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,MAAM,EAAE,MAAM,4BAA4B,CAAC;
|
1
|
+
{"version":3,"file":"get-rect-path.d.ts","sourceRoot":"","sources":["../../../src/utils/get-rect-path.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,KAAK,MAAM,EAAE,MAAM,4BAA4B,CAAC;AAE5E,KAAK,iBAAiB,GAClB;IACE,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,GACD;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC;AAErB,QAAA,MAAM,WAAW,WAAY,iBAAiB,gDAY7C,CAAC;AAEF,KAAK,wBAAwB,GAAG,iBAAiB,GAAG;IAClD,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAEF,QAAA,MAAM,kBAAkB,WAAY,wBAAwB,gDAa3D,CAAC;AAEF,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,CAAC"}
|
@@ -1,5 +1,9 @@
|
|
1
1
|
import type { SkiaValue } from '@shopify/react-native-skia';
|
2
|
-
|
2
|
+
type SkiaValueWithSelector<T> = {
|
3
|
+
value: SkiaValue<T>;
|
4
|
+
selector: (v: T) => T;
|
5
|
+
};
|
6
|
+
declare const unwrapAnimatedValue: <T>(value: T | SkiaValue<T> | SkiaValueWithSelector<T>) => T;
|
3
7
|
declare const unwrapAnimatedValueObject: <T>(value: Record<any, T | SkiaValue<T>>) => Record<any, T>;
|
4
8
|
export { unwrapAnimatedValue, unwrapAnimatedValueObject };
|
5
9
|
//# sourceMappingURL=unwrap-animated-value.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"unwrap-animated-value.d.ts","sourceRoot":"","sources":["../../../src/utils/unwrap-animated-value.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAE5D,QAAA,MAAM,mBAAmB,
|
1
|
+
{"version":3,"file":"unwrap-animated-value.d.ts","sourceRoot":"","sources":["../../../src/utils/unwrap-animated-value.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAE5D,KAAK,qBAAqB,CAAC,CAAC,IAAI;IAC9B,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;IACpB,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;CACvB,CAAC;AACF,QAAA,MAAM,mBAAmB,8DAaxB,CAAC;AAEF,QAAA,MAAM,yBAAyB,6DAM9B,CAAC;AAEF,OAAO,EAAE,mBAAmB,EAAE,yBAAyB,EAAE,CAAC"}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "react-native-skia-gesture",
|
3
|
-
"version": "0.1.
|
3
|
+
"version": "0.1.172",
|
4
4
|
"description": "A detection system for React Native Skia components",
|
5
5
|
"main": "lib/commonjs/index",
|
6
6
|
"module": "lib/module/index",
|
@@ -55,7 +55,7 @@
|
|
55
55
|
"@evilmartians/lefthook": "^1.2.2",
|
56
56
|
"@react-native-community/eslint-config": "^3.0.2",
|
57
57
|
"@release-it/conventional-changelog": "^5.0.0",
|
58
|
-
"@shopify/react-native-skia": "0.1.
|
58
|
+
"@shopify/react-native-skia": "0.1.172",
|
59
59
|
"@types/jest": "^28.1.2",
|
60
60
|
"@types/react": "18.0.26",
|
61
61
|
"@types/react-native": "0.70.0",
|
package/src/canvas/canvas.tsx
CHANGED
@@ -1,41 +1,63 @@
|
|
1
1
|
import {
|
2
2
|
Canvas as SkiaCanvas,
|
3
|
-
CanvasProps,
|
4
|
-
|
3
|
+
type CanvasProps,
|
4
|
+
useMultiTouchHandler,
|
5
5
|
useValue,
|
6
6
|
} from '@shopify/react-native-skia';
|
7
7
|
import React, { useEffect } from 'react';
|
8
|
-
import {
|
8
|
+
import {
|
9
|
+
TouchHandlerContext,
|
10
|
+
type TouchableHandlerContextType,
|
11
|
+
} from './context';
|
9
12
|
|
10
13
|
const Canvas: React.FC<CanvasProps> = ({ children, onTouch, ...props }) => {
|
11
14
|
const touchableRefs = useValue<TouchableHandlerContextType['current']>({});
|
12
15
|
|
13
|
-
const activeKey = useValue<string
|
16
|
+
const activeKey = useValue<string[]>([]);
|
14
17
|
|
15
|
-
const touchHandler =
|
18
|
+
const touchHandler = useMultiTouchHandler(
|
16
19
|
{
|
17
20
|
onStart: (event) => {
|
18
21
|
const keys = Object.keys(touchableRefs.current);
|
19
22
|
for (let i = 0; i < keys.length; i++) {
|
20
23
|
const key = keys[i] as string;
|
21
24
|
const touchableItem = touchableRefs.current[key];
|
22
|
-
|
23
25
|
if (touchableItem?.isPointInPath(event)) {
|
24
|
-
activeKey.current
|
26
|
+
activeKey.current.push(`${key}__${event.id}`);
|
25
27
|
touchableItem.onStart?.(event);
|
26
28
|
return;
|
27
29
|
}
|
28
30
|
}
|
29
31
|
},
|
30
32
|
onActive: (event) => {
|
31
|
-
|
32
|
-
|
33
|
+
const activatedKey = activeKey.current.find((key) =>
|
34
|
+
key.includes(event.id.toString())
|
35
|
+
);
|
36
|
+
if (!activatedKey) {
|
37
|
+
return;
|
38
|
+
}
|
39
|
+
const indexedKey = activatedKey.split('__')?.[0];
|
40
|
+
if (!indexedKey) {
|
41
|
+
return;
|
42
|
+
}
|
43
|
+
const touchableItem = touchableRefs.current[indexedKey];
|
33
44
|
return touchableItem?.onActive?.(event);
|
34
45
|
},
|
35
46
|
onEnd: (event) => {
|
36
|
-
|
37
|
-
|
38
|
-
|
47
|
+
const activatedKey = activeKey.current.find((key) =>
|
48
|
+
key.includes(event.id.toString())
|
49
|
+
);
|
50
|
+
if (!activatedKey) {
|
51
|
+
return;
|
52
|
+
}
|
53
|
+
const indexedKey = activatedKey.split('__')?.[0];
|
54
|
+
if (!indexedKey) {
|
55
|
+
return;
|
56
|
+
}
|
57
|
+
const touchableItem = touchableRefs.current[indexedKey];
|
58
|
+
activeKey.current = activeKey.current.filter(
|
59
|
+
(key) => !key.includes(event.id.toString())
|
60
|
+
);
|
39
61
|
return touchableItem?.onEnd?.(event);
|
40
62
|
},
|
41
63
|
},
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import {
|
2
|
+
Circle as SkiaCircle,
|
3
|
+
RoundedRect as SkiaRoundedRect,
|
4
|
+
Rect as SkiaRect,
|
5
|
+
Path as SkiaPath,
|
6
|
+
} from '@shopify/react-native-skia';
|
7
|
+
import { withTouchableHandler } from '../hoc';
|
8
|
+
|
9
|
+
export { Canvas } from '../canvas';
|
10
|
+
|
11
|
+
export const Circle = withTouchableHandler(SkiaCircle);
|
12
|
+
export const RoundedRect = withTouchableHandler(SkiaRoundedRect);
|
13
|
+
export const Rect = withTouchableHandler(SkiaRect);
|
14
|
+
export const Path = withTouchableHandler(SkiaPath);
|
@@ -1,11 +1,10 @@
|
|
1
1
|
import {
|
2
|
-
ExtendedTouchInfo,
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
2
|
+
type ExtendedTouchInfo,
|
3
|
+
type SkiaValue,
|
4
|
+
type SkPath,
|
5
|
+
type TouchInfo,
|
6
|
+
type Vector,
|
7
7
|
useValue,
|
8
|
-
Vector,
|
9
8
|
} from '@shopify/react-native-skia';
|
10
9
|
import { useCallback, useEffect, useId } from 'react';
|
11
10
|
import { getCirclePath } from '../utils/get-circle-path';
|
@@ -28,8 +27,7 @@ export type TouchableHandlerProps = {
|
|
28
27
|
touchablePath: SkPath | SkiaValue<SkPath>;
|
29
28
|
};
|
30
29
|
|
31
|
-
type WithTouchableHandlerProps<T> =
|
32
|
-
Partial<TouchableHandlerProps>;
|
30
|
+
type WithTouchableHandlerProps<T> = T & Partial<TouchableHandlerProps>;
|
33
31
|
|
34
32
|
const getSkiaPath = (key: string, props: any) => {
|
35
33
|
const unwrappedProps = unwrapAnimatedValueObject(props) as any;
|
@@ -41,6 +39,8 @@ const getSkiaPath = (key: string, props: any) => {
|
|
41
39
|
return getRectPath(unwrappedProps);
|
42
40
|
case 'RoundedRect':
|
43
41
|
return getRoundedRectPath(unwrappedProps);
|
42
|
+
case 'Path':
|
43
|
+
return unwrappedProps.path;
|
44
44
|
default:
|
45
45
|
return null;
|
46
46
|
}
|
@@ -94,8 +94,8 @@ const withTouchableHandler = <T,>(
|
|
94
94
|
if (touchablePath) {
|
95
95
|
return unwrapAnimatedValue(touchablePath).contains(point.x, point.y);
|
96
96
|
}
|
97
|
-
|
98
97
|
const path = getSkiaPath(Component.name, props);
|
98
|
+
|
99
99
|
if (!path) {
|
100
100
|
throw Error('No touchablePath provided');
|
101
101
|
}
|
package/src/index.ts
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
import { rect, rrect, Skia, SkRect } from '@shopify/react-native-skia';
|
1
|
+
import { rect, rrect, Skia, type SkRect } from '@shopify/react-native-skia';
|
2
2
|
|
3
3
|
type GetRectPathParams =
|
4
4
|
| {
|
@@ -29,13 +29,17 @@ type GetRoundedRectPathParams = GetRectPathParams & {
|
|
29
29
|
|
30
30
|
const getRoundedRectPath = (params: GetRoundedRectPathParams) => {
|
31
31
|
const { r } = params;
|
32
|
+
const skPath = Skia.Path.Make();
|
32
33
|
if ('rect' in params) {
|
33
34
|
// eslint-disable-next-line @typescript-eslint/no-shadow
|
34
35
|
const { rect } = params;
|
35
|
-
|
36
|
+
skPath.addRRect(rrect(rect, r, r));
|
37
|
+
return skPath;
|
36
38
|
}
|
37
39
|
const { x, y, width, height } = params;
|
38
|
-
|
40
|
+
|
41
|
+
skPath.addRRect(rrect(rect(x, y, width, height), r, r));
|
42
|
+
return skPath;
|
39
43
|
};
|
40
44
|
|
41
45
|
export { getRectPath, getRoundedRectPath };
|
@@ -1,9 +1,21 @@
|
|
1
1
|
import type { SkiaValue } from '@shopify/react-native-skia';
|
2
2
|
|
3
|
-
|
3
|
+
type SkiaValueWithSelector<T> = {
|
4
|
+
value: SkiaValue<T>;
|
5
|
+
selector: (v: T) => T;
|
6
|
+
};
|
7
|
+
const unwrapAnimatedValue = <T>(
|
8
|
+
value: SkiaValue<T> | SkiaValueWithSelector<T> | T
|
9
|
+
): T => {
|
4
10
|
if ((value as SkiaValue<T>).current != null) {
|
5
11
|
return (value as SkiaValue<T>).current;
|
6
12
|
}
|
13
|
+
|
14
|
+
if ((value as SkiaValueWithSelector<T>).selector != null) {
|
15
|
+
const skiaValueWithSelector = value as SkiaValueWithSelector<T>;
|
16
|
+
return skiaValueWithSelector.selector(skiaValueWithSelector.value.current);
|
17
|
+
}
|
18
|
+
|
7
19
|
return value as T;
|
8
20
|
};
|
9
21
|
|