@shopify/react-native-skia 1.11.1 → 1.11.3

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 (266) hide show
  1. package/android/CMakeLists.txt +0 -8
  2. package/android/cpp/jni/JniLoad.cpp +0 -2
  3. package/android/src/main/java/com/shopify/reactnative/skia/RNSkiaPackage.java +1 -1
  4. package/android/src/paper/java/com/facebook/react/viewmanagers/SkiaPictureViewManagerDelegate.java +4 -2
  5. package/cpp/jsi/ViewProperty.h +5 -16
  6. package/cpp/rnskia/RNSkManager.cpp +1 -7
  7. package/lib/commonjs/dom/nodes/index.d.ts +0 -1
  8. package/lib/commonjs/dom/nodes/index.js +0 -11
  9. package/lib/commonjs/dom/nodes/index.js.map +1 -1
  10. package/lib/commonjs/external/reanimated/renderHelpers.d.ts +0 -6
  11. package/lib/commonjs/external/reanimated/renderHelpers.js +0 -73
  12. package/lib/commonjs/external/reanimated/renderHelpers.js.map +1 -1
  13. package/lib/commonjs/index.d.ts +0 -1
  14. package/lib/commonjs/index.js +0 -12
  15. package/lib/commonjs/index.js.map +1 -1
  16. package/lib/commonjs/renderer/Canvas.d.ts +10 -1
  17. package/lib/commonjs/renderer/Canvas.js +3 -1
  18. package/lib/commonjs/renderer/Canvas.js.map +1 -1
  19. package/lib/commonjs/sksg/Container.d.ts +2 -0
  20. package/lib/commonjs/sksg/Container.js +10 -0
  21. package/lib/commonjs/sksg/Container.js.map +1 -1
  22. package/lib/commonjs/sksg/Elements.d.ts +65 -0
  23. package/lib/commonjs/sksg/Elements.js +6 -0
  24. package/lib/commonjs/sksg/Elements.js.map +1 -0
  25. package/lib/commonjs/sksg/Reconciler.d.ts +1 -0
  26. package/lib/commonjs/sksg/Reconciler.js +2 -0
  27. package/lib/commonjs/sksg/Reconciler.js.map +1 -1
  28. package/lib/commonjs/views/index.d.ts +0 -1
  29. package/lib/commonjs/views/index.js +0 -11
  30. package/lib/commonjs/views/index.js.map +1 -1
  31. package/lib/module/dom/nodes/index.d.ts +0 -1
  32. package/lib/module/dom/nodes/index.js +0 -1
  33. package/lib/module/dom/nodes/index.js.map +1 -1
  34. package/lib/module/external/reanimated/renderHelpers.d.ts +0 -6
  35. package/lib/module/external/reanimated/renderHelpers.js +0 -68
  36. package/lib/module/external/reanimated/renderHelpers.js.map +1 -1
  37. package/lib/module/index.d.ts +0 -1
  38. package/lib/module/index.js +0 -1
  39. package/lib/module/index.js.map +1 -1
  40. package/lib/module/renderer/Canvas.d.ts +10 -1
  41. package/lib/module/renderer/Canvas.js +1 -0
  42. package/lib/module/renderer/Canvas.js.map +1 -1
  43. package/lib/module/sksg/Container.d.ts +2 -0
  44. package/lib/module/sksg/Container.js +10 -0
  45. package/lib/module/sksg/Container.js.map +1 -1
  46. package/lib/module/sksg/Elements.d.ts +65 -0
  47. package/lib/module/sksg/Elements.js +2 -0
  48. package/lib/module/sksg/Elements.js.map +1 -0
  49. package/lib/module/sksg/Reconciler.d.ts +1 -0
  50. package/lib/module/sksg/Reconciler.js +2 -0
  51. package/lib/module/sksg/Reconciler.js.map +1 -1
  52. package/lib/module/views/index.d.ts +0 -1
  53. package/lib/module/views/index.js +0 -1
  54. package/lib/module/views/index.js.map +1 -1
  55. package/lib/typescript/lib/commonjs/external/reanimated/renderHelpers.d.ts +0 -3
  56. package/lib/typescript/lib/commonjs/renderer/Canvas.d.ts +1 -0
  57. package/lib/typescript/lib/commonjs/sksg/Container.d.ts +2 -0
  58. package/lib/typescript/lib/commonjs/sksg/Elements.d.ts +1 -0
  59. package/lib/typescript/lib/commonjs/sksg/Reconciler.d.ts +6 -0
  60. package/lib/typescript/lib/module/dom/nodes/index.d.ts +0 -1
  61. package/lib/typescript/lib/module/external/reanimated/renderHelpers.d.ts +0 -3
  62. package/lib/typescript/lib/module/index.d.ts +0 -1
  63. package/lib/typescript/lib/module/mock/index.d.ts +0 -1
  64. package/lib/typescript/lib/module/renderer/Canvas.d.ts +1 -0
  65. package/lib/typescript/lib/module/sksg/Container.d.ts +2 -0
  66. package/lib/typescript/lib/module/sksg/Elements.d.ts +1 -0
  67. package/lib/typescript/lib/module/sksg/Reconciler.d.ts +6 -0
  68. package/lib/typescript/lib/module/views/index.d.ts +0 -1
  69. package/lib/typescript/src/dom/nodes/index.d.ts +0 -1
  70. package/lib/typescript/src/external/reanimated/renderHelpers.d.ts +0 -6
  71. package/lib/typescript/src/index.d.ts +0 -1
  72. package/lib/typescript/src/renderer/Canvas.d.ts +10 -1
  73. package/lib/typescript/src/sksg/Container.d.ts +2 -0
  74. package/lib/typescript/src/sksg/Elements.d.ts +65 -0
  75. package/lib/typescript/src/sksg/Reconciler.d.ts +1 -0
  76. package/lib/typescript/src/views/index.d.ts +0 -1
  77. package/package.json +1 -1
  78. package/react-native-skia.podspec +1 -1
  79. package/src/dom/nodes/index.ts +0 -1
  80. package/src/external/reanimated/renderHelpers.ts +1 -78
  81. package/src/index.ts +0 -1
  82. package/src/renderer/Canvas.tsx +11 -1
  83. package/src/sksg/Container.ts +11 -0
  84. package/src/sksg/Elements.tsx +136 -0
  85. package/src/sksg/Reconciler.ts +2 -0
  86. package/src/views/index.ts +0 -1
  87. package/android/cpp/jni/include/JniSkiaDomView.h +0 -82
  88. package/android/src/main/java/com/shopify/reactnative/skia/SkiaDomView.java +0 -41
  89. package/android/src/main/java/com/shopify/reactnative/skia/SkiaDomViewManager.java +0 -32
  90. package/android/src/paper/java/com/facebook/react/viewmanagers/SkiaDomViewManagerDelegate.java +0 -34
  91. package/android/src/paper/java/com/facebook/react/viewmanagers/SkiaDomViewManagerInterface.java +0 -18
  92. package/cpp/rnskia/RNSkDomView.cpp +0 -121
  93. package/cpp/rnskia/RNSkDomView.h +0 -97
  94. package/cpp/rnskia/dom/JsiDomApi.h +0 -165
  95. package/cpp/rnskia/dom/base/BaseNodeProp.h +0 -72
  96. package/cpp/rnskia/dom/base/ConcatablePaint.cpp +0 -117
  97. package/cpp/rnskia/dom/base/ConcatablePaint.h +0 -49
  98. package/cpp/rnskia/dom/base/Declaration.h +0 -86
  99. package/cpp/rnskia/dom/base/DeclarationContext.h +0 -79
  100. package/cpp/rnskia/dom/base/DerivedNodeProp.h +0 -203
  101. package/cpp/rnskia/dom/base/DrawingContext.cpp +0 -55
  102. package/cpp/rnskia/dom/base/DrawingContext.h +0 -104
  103. package/cpp/rnskia/dom/base/JsiDomDeclarationNode.h +0 -119
  104. package/cpp/rnskia/dom/base/JsiDomDrawingNode.h +0 -71
  105. package/cpp/rnskia/dom/base/JsiDomNode.h +0 -572
  106. package/cpp/rnskia/dom/base/JsiDomRenderNode.h +0 -262
  107. package/cpp/rnskia/dom/base/NodeProp.h +0 -139
  108. package/cpp/rnskia/dom/base/NodePropsContainer.h +0 -158
  109. package/cpp/rnskia/dom/nodes/JsiAtlasNode.h +0 -64
  110. package/cpp/rnskia/dom/nodes/JsiBackdropFilterNode.h +0 -49
  111. package/cpp/rnskia/dom/nodes/JsiBlendNode.h +0 -94
  112. package/cpp/rnskia/dom/nodes/JsiBlurMaskNode.h +0 -75
  113. package/cpp/rnskia/dom/nodes/JsiBoxNode.h +0 -94
  114. package/cpp/rnskia/dom/nodes/JsiBoxShadowNode.h +0 -33
  115. package/cpp/rnskia/dom/nodes/JsiCircleNode.h +0 -35
  116. package/cpp/rnskia/dom/nodes/JsiColorFilterNodes.h +0 -164
  117. package/cpp/rnskia/dom/nodes/JsiDiffRectNode.h +0 -37
  118. package/cpp/rnskia/dom/nodes/JsiFillNode.h +0 -22
  119. package/cpp/rnskia/dom/nodes/JsiGlyphsNode.h +0 -53
  120. package/cpp/rnskia/dom/nodes/JsiGroupNode.h +0 -25
  121. package/cpp/rnskia/dom/nodes/JsiImageFilterNodes.h +0 -361
  122. package/cpp/rnskia/dom/nodes/JsiImageNode.h +0 -43
  123. package/cpp/rnskia/dom/nodes/JsiImageSvgNode.h +0 -63
  124. package/cpp/rnskia/dom/nodes/JsiLayerNode.h +0 -74
  125. package/cpp/rnskia/dom/nodes/JsiLineNode.h +0 -38
  126. package/cpp/rnskia/dom/nodes/JsiOvalNode.h +0 -32
  127. package/cpp/rnskia/dom/nodes/JsiPaintNode.h +0 -119
  128. package/cpp/rnskia/dom/nodes/JsiParagraphNode.h +0 -62
  129. package/cpp/rnskia/dom/nodes/JsiPatchNode.h +0 -50
  130. package/cpp/rnskia/dom/nodes/JsiPathEffectNodes.h +0 -268
  131. package/cpp/rnskia/dom/nodes/JsiPathNode.h +0 -181
  132. package/cpp/rnskia/dom/nodes/JsiPictureNode.h +0 -31
  133. package/cpp/rnskia/dom/nodes/JsiPointsNode.h +0 -48
  134. package/cpp/rnskia/dom/nodes/JsiRRectNode.h +0 -33
  135. package/cpp/rnskia/dom/nodes/JsiRectNode.h +0 -33
  136. package/cpp/rnskia/dom/nodes/JsiShaderNodes.h +0 -434
  137. package/cpp/rnskia/dom/nodes/JsiTextBlobNode.h +0 -44
  138. package/cpp/rnskia/dom/nodes/JsiTextNode.h +0 -51
  139. package/cpp/rnskia/dom/nodes/JsiTextPathNode.h +0 -33
  140. package/cpp/rnskia/dom/nodes/JsiVerticesNode.h +0 -41
  141. package/cpp/rnskia/dom/props/BezierProps.h +0 -65
  142. package/cpp/rnskia/dom/props/BlendModeProp.h +0 -103
  143. package/cpp/rnskia/dom/props/BoxShadowProps.h +0 -62
  144. package/cpp/rnskia/dom/props/CircleProp.h +0 -49
  145. package/cpp/rnskia/dom/props/ClipProp.h +0 -57
  146. package/cpp/rnskia/dom/props/ColorProp.h +0 -96
  147. package/cpp/rnskia/dom/props/FontProp.h +0 -42
  148. package/cpp/rnskia/dom/props/GlyphsProp.h +0 -55
  149. package/cpp/rnskia/dom/props/LayerProp.h +0 -52
  150. package/cpp/rnskia/dom/props/MatrixProp.h +0 -54
  151. package/cpp/rnskia/dom/props/NumbersProp.h +0 -67
  152. package/cpp/rnskia/dom/props/PaintProps.h +0 -133
  153. package/cpp/rnskia/dom/props/ParagraphProp.h +0 -45
  154. package/cpp/rnskia/dom/props/PathProp.h +0 -59
  155. package/cpp/rnskia/dom/props/PictureProp.h +0 -40
  156. package/cpp/rnskia/dom/props/PointProp.h +0 -65
  157. package/cpp/rnskia/dom/props/PointsProp.h +0 -81
  158. package/cpp/rnskia/dom/props/RRectProp.h +0 -222
  159. package/cpp/rnskia/dom/props/RSXformProp.h +0 -52
  160. package/cpp/rnskia/dom/props/RadiusProp.h +0 -43
  161. package/cpp/rnskia/dom/props/RectProp.h +0 -164
  162. package/cpp/rnskia/dom/props/SamplingProp.h +0 -54
  163. package/cpp/rnskia/dom/props/SkImageProps.h +0 -196
  164. package/cpp/rnskia/dom/props/StrokeProps.h +0 -79
  165. package/cpp/rnskia/dom/props/SvgProp.h +0 -45
  166. package/cpp/rnskia/dom/props/TextBlobProp.h +0 -133
  167. package/cpp/rnskia/dom/props/TileModeProp.h +0 -52
  168. package/cpp/rnskia/dom/props/TransformProp.h +0 -147
  169. package/cpp/rnskia/dom/props/TransformsProps.h +0 -66
  170. package/cpp/rnskia/dom/props/UniformsProp.h +0 -159
  171. package/cpp/rnskia/dom/props/VertexModeProp.h +0 -49
  172. package/cpp/rnskia/dom/props/VerticesProps.h +0 -63
  173. package/ios/RNSkia-iOS/SkiaDomView.h +0 -7
  174. package/ios/RNSkia-iOS/SkiaDomView.mm +0 -63
  175. package/ios/RNSkia-iOS/SkiaDomViewManager.h +0 -8
  176. package/ios/RNSkia-iOS/SkiaDomViewManager.mm +0 -51
  177. package/lib/commonjs/dom/nodes/JsiSkDOM.d.ts +0 -64
  178. package/lib/commonjs/dom/nodes/JsiSkDOM.js +0 -196
  179. package/lib/commonjs/dom/nodes/JsiSkDOM.js.map +0 -1
  180. package/lib/commonjs/renderer/CanvasOld.d.ts +0 -11
  181. package/lib/commonjs/renderer/CanvasOld.js +0 -96
  182. package/lib/commonjs/renderer/CanvasOld.js.map +0 -1
  183. package/lib/commonjs/renderer/Container.d.ts +0 -10
  184. package/lib/commonjs/renderer/Container.js +0 -26
  185. package/lib/commonjs/renderer/Container.js.map +0 -1
  186. package/lib/commonjs/renderer/HostComponents.d.ts +0 -129
  187. package/lib/commonjs/renderer/HostComponents.js +0 -141
  188. package/lib/commonjs/renderer/HostComponents.js.map +0 -1
  189. package/lib/commonjs/renderer/HostConfig.d.ts +0 -18
  190. package/lib/commonjs/renderer/HostConfig.js +0 -157
  191. package/lib/commonjs/renderer/HostConfig.js.map +0 -1
  192. package/lib/commonjs/renderer/Reconciler.d.ts +0 -9
  193. package/lib/commonjs/renderer/Reconciler.js +0 -44
  194. package/lib/commonjs/renderer/Reconciler.js.map +0 -1
  195. package/lib/commonjs/specs/SkiaDomViewNativeComponent.d.ts +0 -6
  196. package/lib/commonjs/specs/SkiaDomViewNativeComponent.js +0 -11
  197. package/lib/commonjs/specs/SkiaDomViewNativeComponent.js.map +0 -1
  198. package/lib/commonjs/views/SkiaDomView.d.ts +0 -33
  199. package/lib/commonjs/views/SkiaDomView.js +0 -119
  200. package/lib/commonjs/views/SkiaDomView.js.map +0 -1
  201. package/lib/commonjs/views/SkiaDomView.web.d.ts +0 -0
  202. package/lib/commonjs/views/SkiaDomView.web.js +0 -2
  203. package/lib/commonjs/views/SkiaDomView.web.js.map +0 -1
  204. package/lib/module/dom/nodes/JsiSkDOM.d.ts +0 -64
  205. package/lib/module/dom/nodes/JsiSkDOM.js +0 -189
  206. package/lib/module/dom/nodes/JsiSkDOM.js.map +0 -1
  207. package/lib/module/renderer/CanvasOld.d.ts +0 -11
  208. package/lib/module/renderer/CanvasOld.js +0 -87
  209. package/lib/module/renderer/CanvasOld.js.map +0 -1
  210. package/lib/module/renderer/Container.d.ts +0 -10
  211. package/lib/module/renderer/Container.js +0 -19
  212. package/lib/module/renderer/Container.js.map +0 -1
  213. package/lib/module/renderer/HostComponents.d.ts +0 -129
  214. package/lib/module/renderer/HostComponents.js +0 -134
  215. package/lib/module/renderer/HostComponents.js.map +0 -1
  216. package/lib/module/renderer/HostConfig.d.ts +0 -18
  217. package/lib/module/renderer/HostConfig.js +0 -150
  218. package/lib/module/renderer/HostConfig.js.map +0 -1
  219. package/lib/module/renderer/Reconciler.d.ts +0 -9
  220. package/lib/module/renderer/Reconciler.js +0 -36
  221. package/lib/module/renderer/Reconciler.js.map +0 -1
  222. package/lib/module/specs/SkiaDomViewNativeComponent.d.ts +0 -6
  223. package/lib/module/specs/SkiaDomViewNativeComponent.js +0 -4
  224. package/lib/module/specs/SkiaDomViewNativeComponent.js.map +0 -1
  225. package/lib/module/views/SkiaDomView.d.ts +0 -33
  226. package/lib/module/views/SkiaDomView.js +0 -111
  227. package/lib/module/views/SkiaDomView.js.map +0 -1
  228. package/lib/module/views/SkiaDomView.web.d.ts +0 -0
  229. package/lib/module/views/SkiaDomView.web.js +0 -2
  230. package/lib/module/views/SkiaDomView.web.js.map +0 -1
  231. package/lib/typescript/lib/commonjs/dom/nodes/JsiSkDOM.d.ts +0 -60
  232. package/lib/typescript/lib/commonjs/renderer/CanvasOld.d.ts +0 -3
  233. package/lib/typescript/lib/commonjs/renderer/Container.d.ts +0 -9
  234. package/lib/typescript/lib/commonjs/renderer/HostComponents.d.ts +0 -2
  235. package/lib/typescript/lib/commonjs/renderer/HostConfig.d.ts +0 -40
  236. package/lib/typescript/lib/commonjs/renderer/Reconciler.d.ts +0 -10
  237. package/lib/typescript/lib/commonjs/specs/SkiaDomViewNativeComponent.d.ts +0 -3
  238. package/lib/typescript/lib/commonjs/views/SkiaDomView.d.ts +0 -30
  239. package/lib/typescript/lib/commonjs/views/SkiaDomView.web.d.ts +0 -0
  240. package/lib/typescript/lib/module/dom/nodes/JsiSkDOM.d.ts +0 -59
  241. package/lib/typescript/lib/module/renderer/CanvasOld.d.ts +0 -3
  242. package/lib/typescript/lib/module/renderer/Container.d.ts +0 -9
  243. package/lib/typescript/lib/module/renderer/HostComponents.d.ts +0 -1
  244. package/lib/typescript/lib/module/renderer/HostConfig.d.ts +0 -39
  245. package/lib/typescript/lib/module/renderer/Reconciler.d.ts +0 -9
  246. package/lib/typescript/lib/module/specs/SkiaDomViewNativeComponent.d.ts +0 -2
  247. package/lib/typescript/lib/module/views/SkiaDomView.d.ts +0 -27
  248. package/lib/typescript/lib/module/views/SkiaDomView.web.d.ts +0 -0
  249. package/lib/typescript/src/dom/nodes/JsiSkDOM.d.ts +0 -64
  250. package/lib/typescript/src/renderer/CanvasOld.d.ts +0 -11
  251. package/lib/typescript/src/renderer/Container.d.ts +0 -10
  252. package/lib/typescript/src/renderer/HostComponents.d.ts +0 -129
  253. package/lib/typescript/src/renderer/HostConfig.d.ts +0 -18
  254. package/lib/typescript/src/renderer/Reconciler.d.ts +0 -9
  255. package/lib/typescript/src/specs/SkiaDomViewNativeComponent.d.ts +0 -6
  256. package/lib/typescript/src/views/SkiaDomView.d.ts +0 -33
  257. package/lib/typescript/src/views/SkiaDomView.web.d.ts +0 -0
  258. package/src/dom/nodes/JsiSkDOM.ts +0 -298
  259. package/src/renderer/CanvasOld.tsx +0 -126
  260. package/src/renderer/Container.tsx +0 -19
  261. package/src/renderer/HostComponents.ts +0 -399
  262. package/src/renderer/HostConfig.ts +0 -258
  263. package/src/renderer/Reconciler.tsx +0 -54
  264. package/src/specs/SkiaDomViewNativeComponent.ts +0 -9
  265. package/src/views/SkiaDomView.tsx +0 -124
  266. package/src/views/SkiaDomView.web.tsx +0 -0
@@ -1,33 +0,0 @@
1
- import React from "react";
2
- import type { SkRect } from "../skia/types";
3
- import type { SkiaDomViewNativeProps } from "./types";
4
- interface SkiaDomViewProps extends SkiaDomViewNativeProps {
5
- mode?: "default" | "continuous";
6
- }
7
- export declare class SkiaDomView extends React.Component<SkiaDomViewProps> {
8
- constructor(props: SkiaDomViewProps);
9
- private _nativeId;
10
- private requestId;
11
- get nativeId(): number;
12
- componentDidUpdate(prevProps: SkiaDomViewProps): void;
13
- componentWillUnmount(): void;
14
- private tick;
15
- /**
16
- * Creates a snapshot from the canvas in the surface
17
- * @param rect Rect to use as bounds. Optional.
18
- * @returns An Image object.
19
- */
20
- makeImageSnapshot(rect?: SkRect): import("../skia/types").SkImage;
21
- /**
22
- * Creates a snapshot from the canvas in the surface
23
- * @param rect Rect to use as bounds. Optional.
24
- * @returns An Image object.
25
- */
26
- makeImageSnapshotAsync(rect?: SkRect): Promise<import("../skia/types").SkImage>;
27
- /**
28
- * Sends a redraw request to the native SkiaView.
29
- */
30
- redraw(): void;
31
- render(): React.JSX.Element;
32
- }
33
- export {};
File without changes
@@ -1,298 +0,0 @@
1
- import type {
2
- PathProps,
3
- SkDOM,
4
- GroupProps,
5
- ImageProps,
6
- BlurImageFilterProps,
7
- MatrixColorFilterProps,
8
- CircleProps,
9
- BlurMaskFilterProps,
10
- LinearGradientProps,
11
- PaintProps,
12
- ShaderProps,
13
- ImageShaderProps,
14
- LineProps,
15
- OvalProps,
16
- PatchProps,
17
- PointsProps,
18
- RectProps,
19
- RoundedRectProps,
20
- VerticesProps,
21
- TextProps,
22
- DiffRectProps,
23
- OffsetImageFilterProps,
24
- BlendColorFilterProps,
25
- TextPathProps,
26
- TextBlobProps,
27
- GlyphsProps,
28
- TwoPointConicalGradientProps,
29
- TurbulenceProps,
30
- SweepGradientProps,
31
- RadialGradientProps,
32
- FractalNoiseProps,
33
- ColorProps,
34
- PictureProps,
35
- ImageSVGProps,
36
- LerpColorFilterProps,
37
- DrawingNodeProps,
38
- BoxProps,
39
- BoxShadowProps,
40
- ChildrenProps,
41
- AtlasProps,
42
- } from "../types";
43
- import type {
44
- BlendImageFilterProps,
45
- BlendProps,
46
- DisplacementMapImageFilterProps,
47
- DropShadowImageFilterProps,
48
- MorphologyImageFilterProps,
49
- RuntimeShaderImageFilterProps,
50
- } from "../types/ImageFilters";
51
- import type {
52
- CornerPathEffectProps,
53
- DashPathEffectProps,
54
- DiscretePathEffectProps,
55
- Line2DPathEffectProps,
56
- Path1DPathEffectProps,
57
- Path2DPathEffectProps,
58
- } from "../types/PathEffects";
59
- import type { ParagraphProps } from "../types/Paragraph";
60
-
61
- export class JsiSkDOM implements SkDOM {
62
- constructor() {}
63
-
64
- Layer(props?: ChildrenProps) {
65
- return global.SkiaDomApi.LayerNode(props ?? {});
66
- }
67
-
68
- Group(props?: GroupProps) {
69
- return global.SkiaDomApi.GroupNode(props ?? {});
70
- }
71
-
72
- Paint(props: PaintProps) {
73
- return global.SkiaDomApi.PaintNode(props ?? {});
74
- }
75
-
76
- // Drawings
77
- Fill(props?: DrawingNodeProps) {
78
- return global.SkiaDomApi.FillNode(props ?? {});
79
- }
80
-
81
- Image(props: ImageProps) {
82
- return global.SkiaDomApi.ImageNode(props ?? {});
83
- }
84
-
85
- Circle(props: CircleProps) {
86
- return global.SkiaDomApi.CircleNode(props ?? {});
87
- }
88
-
89
- Path(props: PathProps) {
90
- return global.SkiaDomApi.PathNode(props ?? {});
91
- }
92
-
93
- Line(props: LineProps) {
94
- return global.SkiaDomApi.LineNode(props ?? {});
95
- }
96
-
97
- Oval(props: OvalProps) {
98
- return global.SkiaDomApi.OvalNode(props ?? {});
99
- }
100
-
101
- Patch(props: PatchProps) {
102
- return global.SkiaDomApi.PatchNode(props ?? {});
103
- }
104
-
105
- Points(props: PointsProps) {
106
- return global.SkiaDomApi.PointsNode(props ?? {});
107
- }
108
-
109
- Rect(props: RectProps) {
110
- return global.SkiaDomApi.RectNode(props);
111
- }
112
-
113
- RRect(props: RoundedRectProps) {
114
- return global.SkiaDomApi.RRectNode(props);
115
- }
116
-
117
- Vertices(props: VerticesProps) {
118
- return global.SkiaDomApi.VerticesNode(props);
119
- }
120
-
121
- Text(props: TextProps) {
122
- return global.SkiaDomApi.TextNode(props);
123
- }
124
-
125
- TextPath(props: TextPathProps) {
126
- return global.SkiaDomApi.TextPathNode(props);
127
- }
128
-
129
- TextBlob(props: TextBlobProps) {
130
- return global.SkiaDomApi.TextBlobNode(props);
131
- }
132
-
133
- Glyphs(props: GlyphsProps) {
134
- return global.SkiaDomApi.GlyphsNode(props);
135
- }
136
-
137
- DiffRect(props: DiffRectProps) {
138
- return global.SkiaDomApi.DiffRectNode(props);
139
- }
140
-
141
- Picture(props: PictureProps) {
142
- return global.SkiaDomApi.PictureNode(props);
143
- }
144
-
145
- Atlas(props: AtlasProps) {
146
- return global.SkiaDomApi.AtlasNode(props);
147
- }
148
-
149
- ImageSVG(props: ImageSVGProps) {
150
- return global.SkiaDomApi.ImageSVGNode(props);
151
- }
152
-
153
- // BlurMaskFilters
154
- BlurMaskFilter(props: BlurMaskFilterProps) {
155
- return global.SkiaDomApi.BlurMaskFilterNode(props);
156
- }
157
-
158
- // ImageFilters
159
- BlendImageFilter(props: BlendImageFilterProps) {
160
- return global.SkiaDomApi.BlendImageFilterNode(props);
161
- }
162
-
163
- DropShadowImageFilter(props: DropShadowImageFilterProps) {
164
- return global.SkiaDomApi.DropShadowImageFilterNode(props);
165
- }
166
-
167
- DisplacementMapImageFilter(props: DisplacementMapImageFilterProps) {
168
- return global.SkiaDomApi.DisplacementMapImageFilterNode(props);
169
- }
170
-
171
- BlurImageFilter(props: BlurImageFilterProps) {
172
- return global.SkiaDomApi.BlurImageFilterNode(props);
173
- }
174
-
175
- OffsetImageFilter(props: OffsetImageFilterProps) {
176
- return global.SkiaDomApi.OffsetImageFilterNode(props);
177
- }
178
-
179
- MorphologyImageFilter(props: MorphologyImageFilterProps) {
180
- return global.SkiaDomApi.MorphologyImageFilterNode(props);
181
- }
182
-
183
- RuntimeShaderImageFilter(props: RuntimeShaderImageFilterProps) {
184
- return global.SkiaDomApi.RuntimeShaderImageFilterNode(props);
185
- }
186
-
187
- // Color Filters
188
- MatrixColorFilter(props: MatrixColorFilterProps) {
189
- return global.SkiaDomApi.MatrixColorFilterNode(props);
190
- }
191
-
192
- BlendColorFilter(props: BlendColorFilterProps) {
193
- return global.SkiaDomApi.BlendColorFilterNode(props);
194
- }
195
-
196
- LumaColorFilter() {
197
- return global.SkiaDomApi.LumaColorFilterNode();
198
- }
199
-
200
- LinearToSRGBGammaColorFilter() {
201
- return global.SkiaDomApi.LinearToSRGBGammaColorFilterNode();
202
- }
203
-
204
- SRGBToLinearGammaColorFilter() {
205
- return global.SkiaDomApi.SRGBToLinearGammaColorFilterNode();
206
- }
207
-
208
- LerpColorFilter(props: LerpColorFilterProps) {
209
- return global.SkiaDomApi.LerpColorFilterNode(props);
210
- }
211
-
212
- // Shaders
213
- Shader(props: ShaderProps) {
214
- return global.SkiaDomApi.ShaderNode(props);
215
- }
216
-
217
- ImageShader(props: ImageShaderProps) {
218
- return global.SkiaDomApi.ImageShaderNode(props);
219
- }
220
-
221
- ColorShader(props: ColorProps) {
222
- return global.SkiaDomApi.ColorShaderNode(props);
223
- }
224
-
225
- SweepGradient(props: SweepGradientProps) {
226
- return global.SkiaDomApi.SweepGradientNode(props);
227
- }
228
-
229
- Turbulence(props: TurbulenceProps) {
230
- return global.SkiaDomApi.TurbulenceNode(props);
231
- }
232
-
233
- FractalNoise(props: FractalNoiseProps) {
234
- return global.SkiaDomApi.FractalNoiseNode(props);
235
- }
236
-
237
- LinearGradient(props: LinearGradientProps) {
238
- return global.SkiaDomApi.LinearGradientNode(props);
239
- }
240
-
241
- RadialGradient(props: RadialGradientProps) {
242
- return global.SkiaDomApi.RadialGradientNode(props);
243
- }
244
-
245
- TwoPointConicalGradient(props: TwoPointConicalGradientProps) {
246
- return global.SkiaDomApi.TwoPointConicalGradientNode(props);
247
- }
248
-
249
- // Path Effects
250
- CornerPathEffect(props: CornerPathEffectProps) {
251
- return global.SkiaDomApi.CornerPathEffectNode(props);
252
- }
253
-
254
- DiscretePathEffect(props: DiscretePathEffectProps) {
255
- return global.SkiaDomApi.DiscretePathEffectNode(props);
256
- }
257
-
258
- DashPathEffect(props: DashPathEffectProps) {
259
- return global.SkiaDomApi.DashPathEffectNode(props);
260
- }
261
-
262
- Path1DPathEffect(props: Path1DPathEffectProps) {
263
- return global.SkiaDomApi.Path1DPathEffectNode(props);
264
- }
265
-
266
- Path2DPathEffect(props: Path2DPathEffectProps) {
267
- return global.SkiaDomApi.Path2DPathEffectNode(props);
268
- }
269
-
270
- SumPathEffect() {
271
- return global.SkiaDomApi.SumPathEffectNode();
272
- }
273
-
274
- Line2DPathEffect(props: Line2DPathEffectProps) {
275
- return global.SkiaDomApi.Line2DPathEffectNode(props);
276
- }
277
-
278
- Blend(props: BlendProps) {
279
- return global.SkiaDomApi.BlendNode(props);
280
- }
281
-
282
- BackdropFilter(props: ChildrenProps) {
283
- return global.SkiaDomApi.BackdropFilterNode(props);
284
- }
285
-
286
- Box(props: BoxProps) {
287
- return global.SkiaDomApi.BoxNode(props);
288
- }
289
-
290
- BoxShadow(props: BoxShadowProps) {
291
- return global.SkiaDomApi.BoxShadowNode(props);
292
- }
293
-
294
- // Paragraph
295
- Paragraph(props: ParagraphProps) {
296
- return global.SkiaDomApi.ParagraphNode(props);
297
- }
298
- }
@@ -1,126 +0,0 @@
1
- import React, {
2
- useEffect,
3
- useCallback,
4
- useMemo,
5
- forwardRef,
6
- useRef,
7
- } from "react";
8
- import type {
9
- RefObject,
10
- ReactNode,
11
- MutableRefObject,
12
- ForwardedRef,
13
- FunctionComponent,
14
- } from "react";
15
- import type { LayoutChangeEvent } from "react-native";
16
-
17
- import { SkiaDomView } from "../views";
18
- import type { SkiaBaseViewProps } from "../views";
19
-
20
- import { SkiaRoot } from "./Reconciler";
21
-
22
- export const useCanvasRef = () => useRef<SkiaDomView>(null);
23
-
24
- export interface CanvasOldProps extends SkiaBaseViewProps {
25
- ref?: RefObject<SkiaDomView>;
26
- children: ReactNode;
27
- mode?: "default" | "continuous";
28
- }
29
-
30
- const useOnSizeEvent = (
31
- resultValue: SkiaBaseViewProps["onSize"],
32
- onLayout?: (event: LayoutChangeEvent) => void
33
- ) => {
34
- return useCallback(
35
- (event: LayoutChangeEvent) => {
36
- if (onLayout) {
37
- onLayout(event);
38
- }
39
- const { width, height } = event.nativeEvent.layout;
40
-
41
- if (resultValue) {
42
- resultValue.value = { width, height };
43
- }
44
- },
45
- [onLayout, resultValue]
46
- );
47
- };
48
-
49
- export const CanvasOld = forwardRef<SkiaDomView, CanvasOldProps>(
50
- (
51
- {
52
- children,
53
- style,
54
- debug,
55
- mode = "default",
56
- onSize: _onSize,
57
- onLayout: _onLayout,
58
- ...props
59
- },
60
- forwardedRef
61
- ) => {
62
- const onLayout = useOnSizeEvent(_onSize, _onLayout);
63
- const innerRef = useCanvasRef();
64
- const ref = useCombinedRefs(forwardedRef, innerRef);
65
- const redraw = useCallback(() => {
66
- innerRef.current?.redraw();
67
- }, [innerRef]);
68
- const getNativeId = useCallback(() => {
69
- const id = innerRef.current?.nativeId ?? -1;
70
- return id;
71
- }, [innerRef]);
72
-
73
- const root = useMemo(
74
- () => new SkiaRoot(redraw, getNativeId),
75
- [redraw, getNativeId]
76
- );
77
-
78
- // Render effect
79
- useEffect(() => {
80
- root.render(children);
81
- }, [children, root, redraw]);
82
-
83
- useEffect(() => {
84
- return () => {
85
- root.unmount();
86
- };
87
- }, [root]);
88
-
89
- return (
90
- <SkiaDomView
91
- ref={ref}
92
- style={style}
93
- root={root.dom}
94
- onLayout={onLayout}
95
- debug={debug}
96
- mode={mode}
97
- {...props}
98
- />
99
- );
100
- }
101
- ) as FunctionComponent<CanvasOldProps & React.RefAttributes<SkiaDomView>>;
102
-
103
- /**
104
- * Combines a list of refs into a single ref. This can be used to provide
105
- * both a forwarded ref and an internal ref keeping the same functionality
106
- * on both of the refs.
107
- * @param refs Array of refs to combine
108
- * @returns A single ref that can be used in a ref prop.
109
- */
110
- const useCombinedRefs = <T,>(
111
- ...refs: Array<MutableRefObject<T> | ForwardedRef<T>>
112
- ) => {
113
- const targetRef = React.useRef<T>(null);
114
- React.useEffect(() => {
115
- refs.forEach((ref) => {
116
- if (ref) {
117
- if (typeof ref === "function") {
118
- ref(targetRef.current);
119
- } else {
120
- ref.current = targetRef.current;
121
- }
122
- }
123
- });
124
- }, [refs]);
125
- return targetRef;
126
- };
@@ -1,19 +0,0 @@
1
- import { JsiSkDOM } from "../dom/nodes";
2
- import type { Node, SkDOM } from "../dom/types";
3
-
4
- export class Container {
5
- private _root: Node<unknown>;
6
- public Sk: SkDOM;
7
- public unmounted = false;
8
- constructor(
9
- public redraw: () => void = () => {},
10
- public getNativeId: () => number = () => 0
11
- ) {
12
- this.Sk = new JsiSkDOM();
13
- this._root = this.Sk.Group();
14
- }
15
-
16
- get root() {
17
- return this._root;
18
- }
19
- }