@shopify/react-native-skia 0.1.146 → 0.1.148

Sign up to get free protection for your applications and to get access to all the features.
Files changed (841) hide show
  1. package/cpp/api/JsiSkMatrix.h +9 -0
  2. package/cpp/api/JsiSkPath.h +2 -2
  3. package/lib/commonjs/dom/nodes/DrawingNode.js +84 -0
  4. package/lib/commonjs/dom/nodes/DrawingNode.js.map +1 -0
  5. package/lib/commonjs/dom/nodes/GroupNode.js +28 -0
  6. package/lib/commonjs/dom/nodes/GroupNode.js.map +1 -0
  7. package/lib/commonjs/dom/nodes/JsiSkDOM.js +256 -0
  8. package/lib/commonjs/dom/nodes/JsiSkDOM.js.map +1 -0
  9. package/lib/commonjs/dom/nodes/Node.js +158 -0
  10. package/lib/commonjs/dom/nodes/Node.js.map +1 -0
  11. package/lib/commonjs/dom/nodes/PaintContext.js +6 -0
  12. package/lib/commonjs/dom/nodes/PaintContext.js.map +1 -0
  13. package/lib/commonjs/dom/nodes/PaintNode.js +96 -0
  14. package/lib/commonjs/dom/nodes/PaintNode.js.map +1 -0
  15. package/lib/commonjs/dom/nodes/RenderNode.js +346 -0
  16. package/lib/commonjs/dom/nodes/RenderNode.js.map +1 -0
  17. package/lib/commonjs/{renderer/processors/Circles.js → dom/nodes/datatypes/Circle.js} +4 -2
  18. package/lib/commonjs/dom/nodes/datatypes/Circle.js.map +1 -0
  19. package/lib/commonjs/{renderer/processors → dom/nodes/datatypes}/Color.js +0 -0
  20. package/lib/commonjs/{renderer/processors → dom/nodes/datatypes}/Color.js.map +1 -1
  21. package/lib/commonjs/dom/nodes/datatypes/Enum.js +11 -0
  22. package/lib/commonjs/dom/nodes/datatypes/Enum.js.map +1 -0
  23. package/lib/commonjs/{renderer/components/image/BoxFit.js → dom/nodes/datatypes/Fitting.js} +2 -2
  24. package/lib/commonjs/{renderer/components/image/BoxFit.js.map → dom/nodes/datatypes/Fitting.js.map} +1 -1
  25. package/lib/commonjs/dom/nodes/datatypes/Gradient.js +65 -0
  26. package/lib/commonjs/dom/nodes/datatypes/Gradient.js.map +1 -0
  27. package/lib/commonjs/{renderer/processors/Paths.js → dom/nodes/datatypes/Path.js} +2 -2
  28. package/lib/commonjs/dom/nodes/datatypes/Path.js.map +1 -0
  29. package/lib/commonjs/{renderer/processors → dom/nodes/datatypes}/Radius.js +0 -0
  30. package/lib/commonjs/dom/nodes/datatypes/Radius.js.map +1 -0
  31. package/lib/commonjs/{renderer/processors/Rects.js → dom/nodes/datatypes/Rect.js} +1 -1
  32. package/lib/commonjs/dom/nodes/datatypes/Rect.js.map +1 -0
  33. package/lib/commonjs/dom/nodes/datatypes/Transform.js +42 -0
  34. package/lib/commonjs/dom/nodes/datatypes/Transform.js.map +1 -0
  35. package/lib/commonjs/dom/nodes/datatypes/index.js +123 -0
  36. package/lib/commonjs/dom/nodes/datatypes/index.js.map +1 -0
  37. package/lib/commonjs/dom/nodes/drawings/BackdropFilterNode.js +38 -0
  38. package/lib/commonjs/dom/nodes/drawings/BackdropFilterNode.js.map +1 -0
  39. package/lib/commonjs/dom/nodes/drawings/Box.js +105 -0
  40. package/lib/commonjs/dom/nodes/drawings/Box.js.map +1 -0
  41. package/lib/commonjs/dom/nodes/drawings/CircleNode.js +43 -0
  42. package/lib/commonjs/dom/nodes/drawings/CircleNode.js.map +1 -0
  43. package/lib/commonjs/dom/nodes/drawings/CustomDrawingNode.js +28 -0
  44. package/lib/commonjs/dom/nodes/drawings/CustomDrawingNode.js.map +1 -0
  45. package/lib/commonjs/dom/nodes/drawings/DiffRectNode.js +36 -0
  46. package/lib/commonjs/dom/nodes/drawings/DiffRectNode.js.map +1 -0
  47. package/lib/commonjs/dom/nodes/drawings/FillNode.js +33 -0
  48. package/lib/commonjs/dom/nodes/drawings/FillNode.js.map +1 -0
  49. package/lib/commonjs/dom/nodes/drawings/ImageNode.js +63 -0
  50. package/lib/commonjs/dom/nodes/drawings/ImageNode.js.map +1 -0
  51. package/lib/commonjs/dom/nodes/drawings/ImageSVG.js +45 -0
  52. package/lib/commonjs/dom/nodes/drawings/ImageSVG.js.map +1 -0
  53. package/lib/commonjs/dom/nodes/drawings/LineNode.js +36 -0
  54. package/lib/commonjs/dom/nodes/drawings/LineNode.js.map +1 -0
  55. package/lib/commonjs/dom/nodes/drawings/OvalNode.js +39 -0
  56. package/lib/commonjs/dom/nodes/drawings/OvalNode.js.map +1 -0
  57. package/lib/commonjs/dom/nodes/drawings/PatchNode.js +69 -0
  58. package/lib/commonjs/dom/nodes/drawings/PatchNode.js.map +1 -0
  59. package/lib/commonjs/dom/nodes/drawings/PathNode.js +68 -0
  60. package/lib/commonjs/dom/nodes/drawings/PathNode.js.map +1 -0
  61. package/lib/commonjs/dom/nodes/drawings/PictureNode.js +34 -0
  62. package/lib/commonjs/dom/nodes/drawings/PictureNode.js.map +1 -0
  63. package/lib/commonjs/dom/nodes/drawings/PointsNode.js +40 -0
  64. package/lib/commonjs/dom/nodes/drawings/PointsNode.js.map +1 -0
  65. package/lib/commonjs/dom/nodes/drawings/RRectNode.js +43 -0
  66. package/lib/commonjs/dom/nodes/drawings/RRectNode.js.map +1 -0
  67. package/lib/commonjs/dom/nodes/drawings/RectNode.js +39 -0
  68. package/lib/commonjs/dom/nodes/drawings/RectNode.js.map +1 -0
  69. package/lib/commonjs/dom/nodes/drawings/Text.js +185 -0
  70. package/lib/commonjs/dom/nodes/drawings/Text.js.map +1 -0
  71. package/lib/commonjs/dom/nodes/drawings/VerticesNode.js +55 -0
  72. package/lib/commonjs/dom/nodes/drawings/VerticesNode.js.map +1 -0
  73. package/lib/commonjs/dom/nodes/drawings/index.js +240 -0
  74. package/lib/commonjs/dom/nodes/drawings/index.js.map +1 -0
  75. package/lib/commonjs/dom/nodes/index.js +45 -0
  76. package/lib/commonjs/dom/nodes/index.js.map +1 -0
  77. package/lib/commonjs/dom/nodes/paint/BlendNode.js +82 -0
  78. package/lib/commonjs/dom/nodes/paint/BlendNode.js.map +1 -0
  79. package/lib/commonjs/dom/nodes/paint/ColorFilters.js +152 -0
  80. package/lib/commonjs/dom/nodes/paint/ColorFilters.js.map +1 -0
  81. package/lib/commonjs/dom/nodes/paint/ImageFilters.js +225 -0
  82. package/lib/commonjs/dom/nodes/paint/ImageFilters.js.map +1 -0
  83. package/lib/commonjs/dom/nodes/paint/MaskFilters.js +33 -0
  84. package/lib/commonjs/dom/nodes/paint/MaskFilters.js.map +1 -0
  85. package/lib/commonjs/dom/nodes/paint/PathEffects.js +223 -0
  86. package/lib/commonjs/dom/nodes/paint/PathEffects.js.map +1 -0
  87. package/lib/commonjs/dom/nodes/paint/Shaders.js +242 -0
  88. package/lib/commonjs/dom/nodes/paint/Shaders.js.map +1 -0
  89. package/lib/commonjs/dom/nodes/paint/index.js +84 -0
  90. package/lib/commonjs/dom/nodes/paint/index.js.map +1 -0
  91. package/lib/commonjs/dom/types/ColorFilters.js +6 -0
  92. package/lib/commonjs/dom/types/ColorFilters.js.map +1 -0
  93. package/lib/commonjs/dom/types/Common.js +6 -0
  94. package/lib/commonjs/dom/types/Common.js.map +1 -0
  95. package/lib/commonjs/dom/types/DrawingContext.js +6 -0
  96. package/lib/commonjs/dom/types/DrawingContext.js.map +1 -0
  97. package/lib/commonjs/dom/types/Drawings.js +6 -0
  98. package/lib/commonjs/dom/types/Drawings.js.map +1 -0
  99. package/lib/commonjs/dom/types/ImageFilters.js +6 -0
  100. package/lib/commonjs/dom/types/ImageFilters.js.map +1 -0
  101. package/lib/commonjs/dom/types/MaskFilters.js +6 -0
  102. package/lib/commonjs/dom/types/MaskFilters.js.map +1 -0
  103. package/lib/commonjs/dom/types/Node.js +6 -0
  104. package/lib/commonjs/dom/types/Node.js.map +1 -0
  105. package/lib/commonjs/dom/types/NodeType.js +80 -0
  106. package/lib/commonjs/dom/types/NodeType.js.map +1 -0
  107. package/lib/commonjs/dom/types/PathEffects.js +6 -0
  108. package/lib/commonjs/dom/types/PathEffects.js.map +1 -0
  109. package/lib/commonjs/dom/types/Shaders.js +6 -0
  110. package/lib/commonjs/dom/types/Shaders.js.map +1 -0
  111. package/lib/commonjs/dom/types/SkDOM.js +6 -0
  112. package/lib/commonjs/dom/types/SkDOM.js.map +1 -0
  113. package/lib/commonjs/dom/types/index.js +149 -0
  114. package/lib/commonjs/dom/types/index.js.map +1 -0
  115. package/lib/commonjs/index.js +26 -0
  116. package/lib/commonjs/index.js.map +1 -1
  117. package/lib/commonjs/renderer/Canvas.js +7 -3
  118. package/lib/commonjs/renderer/Canvas.js.map +1 -1
  119. package/lib/commonjs/renderer/Container.js +39 -0
  120. package/lib/commonjs/renderer/Container.js.map +1 -0
  121. package/lib/commonjs/renderer/DependencyManager.js +17 -5
  122. package/lib/commonjs/renderer/DependencyManager.js.map +1 -1
  123. package/lib/commonjs/renderer/HostComponents.js +196 -0
  124. package/lib/commonjs/renderer/HostComponents.js.map +1 -0
  125. package/lib/commonjs/renderer/HostConfig.js +47 -125
  126. package/lib/commonjs/renderer/HostConfig.js.map +1 -1
  127. package/lib/commonjs/renderer/components/Blend.js +1 -46
  128. package/lib/commonjs/renderer/components/Blend.js.map +1 -1
  129. package/lib/commonjs/renderer/components/Drawing.js +1 -15
  130. package/lib/commonjs/renderer/components/Drawing.js.map +1 -1
  131. package/lib/commonjs/renderer/components/Group.js +1 -69
  132. package/lib/commonjs/renderer/components/Group.js.map +1 -1
  133. package/lib/commonjs/renderer/components/Paint.js +2 -14
  134. package/lib/commonjs/renderer/components/Paint.js.map +1 -1
  135. package/lib/commonjs/renderer/components/Picture.js +1 -19
  136. package/lib/commonjs/renderer/components/Picture.js.map +1 -1
  137. package/lib/commonjs/renderer/components/backdrop/BackdropBlur.js.map +1 -1
  138. package/lib/commonjs/renderer/components/backdrop/BackdropFilter.js +2 -32
  139. package/lib/commonjs/renderer/components/backdrop/BackdropFilter.js.map +1 -1
  140. package/lib/commonjs/renderer/components/colorFilters/BlendColor.js +1 -25
  141. package/lib/commonjs/renderer/components/colorFilters/BlendColor.js.map +1 -1
  142. package/lib/commonjs/renderer/components/colorFilters/Lerp.js +1 -23
  143. package/lib/commonjs/renderer/components/colorFilters/Lerp.js.map +1 -1
  144. package/lib/commonjs/renderer/components/colorFilters/LinearToSRGBGamma.js +1 -17
  145. package/lib/commonjs/renderer/components/colorFilters/LinearToSRGBGamma.js.map +1 -1
  146. package/lib/commonjs/renderer/components/colorFilters/LumaColorFilter.js +1 -17
  147. package/lib/commonjs/renderer/components/colorFilters/LumaColorFilter.js.map +1 -1
  148. package/lib/commonjs/renderer/components/colorFilters/Matrix.js +1 -20
  149. package/lib/commonjs/renderer/components/colorFilters/Matrix.js.map +1 -1
  150. package/lib/commonjs/renderer/components/colorFilters/SRGBToLinearGamma.js +1 -17
  151. package/lib/commonjs/renderer/components/colorFilters/SRGBToLinearGamma.js.map +1 -1
  152. package/lib/commonjs/renderer/components/image/Image.js +1 -35
  153. package/lib/commonjs/renderer/components/image/Image.js.map +1 -1
  154. package/lib/commonjs/renderer/components/image/ImageSVG.js +1 -30
  155. package/lib/commonjs/renderer/components/image/ImageSVG.js.map +1 -1
  156. package/lib/commonjs/renderer/components/image/ImageShader.js +1 -61
  157. package/lib/commonjs/renderer/components/image/ImageShader.js.map +1 -1
  158. package/lib/commonjs/renderer/components/image/index.js +0 -13
  159. package/lib/commonjs/renderer/components/image/index.js.map +1 -1
  160. package/lib/commonjs/renderer/components/imageFilters/Blur.js +1 -27
  161. package/lib/commonjs/renderer/components/imageFilters/Blur.js.map +1 -1
  162. package/lib/commonjs/renderer/components/imageFilters/DisplacementMap.js +1 -38
  163. package/lib/commonjs/renderer/components/imageFilters/DisplacementMap.js.map +1 -1
  164. package/lib/commonjs/renderer/components/imageFilters/Morphology.js +1 -25
  165. package/lib/commonjs/renderer/components/imageFilters/Morphology.js.map +1 -1
  166. package/lib/commonjs/renderer/components/imageFilters/Offset.js +1 -20
  167. package/lib/commonjs/renderer/components/imageFilters/Offset.js.map +1 -1
  168. package/lib/commonjs/renderer/components/imageFilters/RuntimeShader.js +1 -28
  169. package/lib/commonjs/renderer/components/imageFilters/RuntimeShader.js.map +1 -1
  170. package/lib/commonjs/renderer/components/imageFilters/Shadow.js +1 -39
  171. package/lib/commonjs/renderer/components/imageFilters/Shadow.js.map +1 -1
  172. package/lib/commonjs/renderer/components/index.js +0 -13
  173. package/lib/commonjs/renderer/components/index.js.map +1 -1
  174. package/lib/commonjs/renderer/components/maskFilters/Blur.js +1 -23
  175. package/lib/commonjs/renderer/components/maskFilters/Blur.js.map +1 -1
  176. package/lib/commonjs/renderer/components/pathEffects/Corner.js +1 -30
  177. package/lib/commonjs/renderer/components/pathEffects/Corner.js.map +1 -1
  178. package/lib/commonjs/renderer/components/pathEffects/Dash.js +1 -27
  179. package/lib/commonjs/renderer/components/pathEffects/Dash.js.map +1 -1
  180. package/lib/commonjs/renderer/components/pathEffects/Discrete.js +1 -28
  181. package/lib/commonjs/renderer/components/pathEffects/Discrete.js.map +1 -1
  182. package/lib/commonjs/renderer/components/pathEffects/Line2D.js +1 -31
  183. package/lib/commonjs/renderer/components/pathEffects/Line2D.js.map +1 -1
  184. package/lib/commonjs/renderer/components/pathEffects/Path1D.js +1 -37
  185. package/lib/commonjs/renderer/components/pathEffects/Path1D.js.map +1 -1
  186. package/lib/commonjs/renderer/components/pathEffects/Path2D.js +1 -33
  187. package/lib/commonjs/renderer/components/pathEffects/Path2D.js.map +1 -1
  188. package/lib/commonjs/renderer/components/pathEffects/Sum.js +1 -17
  189. package/lib/commonjs/renderer/components/pathEffects/Sum.js.map +1 -1
  190. package/lib/commonjs/renderer/components/shaders/Color.js +1 -19
  191. package/lib/commonjs/renderer/components/shaders/Color.js.map +1 -1
  192. package/lib/commonjs/renderer/components/shaders/FractalNoise.js +1 -22
  193. package/lib/commonjs/renderer/components/shaders/FractalNoise.js.map +1 -1
  194. package/lib/commonjs/renderer/components/shaders/LinearGradient.js +1 -28
  195. package/lib/commonjs/renderer/components/shaders/LinearGradient.js.map +1 -1
  196. package/lib/commonjs/renderer/components/shaders/RadialGradient.js +1 -28
  197. package/lib/commonjs/renderer/components/shaders/RadialGradient.js.map +1 -1
  198. package/lib/commonjs/renderer/components/shaders/Shader.js +1 -23
  199. package/lib/commonjs/renderer/components/shaders/Shader.js.map +1 -1
  200. package/lib/commonjs/renderer/components/shaders/SweepGradient.js +1 -29
  201. package/lib/commonjs/renderer/components/shaders/SweepGradient.js.map +1 -1
  202. package/lib/commonjs/renderer/components/shaders/Turbulence.js +1 -22
  203. package/lib/commonjs/renderer/components/shaders/Turbulence.js.map +1 -1
  204. package/lib/commonjs/renderer/components/shaders/TwoPointConicalGradient.js +1 -30
  205. package/lib/commonjs/renderer/components/shaders/TwoPointConicalGradient.js.map +1 -1
  206. package/lib/commonjs/renderer/components/shapes/Box.js +2 -102
  207. package/lib/commonjs/renderer/components/shapes/Box.js.map +1 -1
  208. package/lib/commonjs/renderer/components/shapes/Circle.js +1 -22
  209. package/lib/commonjs/renderer/components/shapes/Circle.js.map +1 -1
  210. package/lib/commonjs/renderer/components/shapes/DiffRect.js +1 -19
  211. package/lib/commonjs/renderer/components/shapes/DiffRect.js.map +1 -1
  212. package/lib/commonjs/renderer/components/shapes/Fill.js +1 -15
  213. package/lib/commonjs/renderer/components/shapes/Fill.js.map +1 -1
  214. package/lib/commonjs/renderer/components/shapes/FitBox.js +3 -3
  215. package/lib/commonjs/renderer/components/shapes/FitBox.js.map +1 -1
  216. package/lib/commonjs/renderer/components/shapes/Line.js +1 -19
  217. package/lib/commonjs/renderer/components/shapes/Line.js.map +1 -1
  218. package/lib/commonjs/renderer/components/shapes/Oval.js +1 -19
  219. package/lib/commonjs/renderer/components/shapes/Oval.js.map +1 -1
  220. package/lib/commonjs/renderer/components/shapes/Patch.js +1 -37
  221. package/lib/commonjs/renderer/components/shapes/Patch.js.map +1 -1
  222. package/lib/commonjs/renderer/components/shapes/Path.js +1 -47
  223. package/lib/commonjs/renderer/components/shapes/Path.js.map +1 -1
  224. package/lib/commonjs/renderer/components/shapes/Points.js +1 -26
  225. package/lib/commonjs/renderer/components/shapes/Points.js.map +1 -1
  226. package/lib/commonjs/renderer/components/shapes/Rect.js +1 -19
  227. package/lib/commonjs/renderer/components/shapes/Rect.js.map +1 -1
  228. package/lib/commonjs/renderer/components/shapes/RoundedRect.js +1 -19
  229. package/lib/commonjs/renderer/components/shapes/RoundedRect.js.map +1 -1
  230. package/lib/commonjs/renderer/components/shapes/Vertices.js +1 -36
  231. package/lib/commonjs/renderer/components/shapes/Vertices.js.map +1 -1
  232. package/lib/commonjs/renderer/components/text/Glyphs.js +1 -39
  233. package/lib/commonjs/renderer/components/text/Glyphs.js.map +1 -1
  234. package/lib/commonjs/renderer/components/text/Text.js +1 -24
  235. package/lib/commonjs/renderer/components/text/Text.js.map +1 -1
  236. package/lib/commonjs/renderer/components/text/TextBlob.js +1 -20
  237. package/lib/commonjs/renderer/components/text/TextBlob.js.map +1 -1
  238. package/lib/commonjs/renderer/components/text/TextPath.js +1 -71
  239. package/lib/commonjs/renderer/components/text/TextPath.js.map +1 -1
  240. package/lib/commonjs/renderer/index.js +0 -13
  241. package/lib/commonjs/renderer/index.js.map +1 -1
  242. package/lib/commonjs/renderer/processors/Animations/Animations.js.map +1 -1
  243. package/lib/commonjs/renderer/processors/index.js +0 -117
  244. package/lib/commonjs/renderer/processors/index.js.map +1 -1
  245. package/lib/commonjs/skia/types/Matrix.js.map +1 -1
  246. package/lib/commonjs/skia/web/JsiSkMatrix.js +4 -0
  247. package/lib/commonjs/skia/web/JsiSkMatrix.js.map +1 -1
  248. package/lib/commonjs/web/WithSkiaWeb.js +3 -1
  249. package/lib/commonjs/web/WithSkiaWeb.js.map +1 -1
  250. package/lib/module/dom/nodes/DrawingNode.js +72 -0
  251. package/lib/module/dom/nodes/DrawingNode.js.map +1 -0
  252. package/lib/module/dom/nodes/GroupNode.js +17 -0
  253. package/lib/module/dom/nodes/GroupNode.js.map +1 -0
  254. package/lib/module/dom/nodes/JsiSkDOM.js +240 -0
  255. package/lib/module/dom/nodes/JsiSkDOM.js.map +1 -0
  256. package/lib/module/dom/nodes/Node.js +145 -0
  257. package/lib/module/dom/nodes/Node.js.map +1 -0
  258. package/lib/module/dom/nodes/PaintContext.js +2 -0
  259. package/lib/module/dom/nodes/PaintContext.js.map +1 -0
  260. package/lib/module/dom/nodes/PaintNode.js +83 -0
  261. package/lib/module/dom/nodes/PaintNode.js.map +1 -0
  262. package/lib/module/dom/nodes/RenderNode.js +329 -0
  263. package/lib/module/dom/nodes/RenderNode.js.map +1 -0
  264. package/lib/module/{renderer/processors/Circles.js → dom/nodes/datatypes/Circle.js} +2 -3
  265. package/lib/module/dom/nodes/datatypes/Circle.js.map +1 -0
  266. package/lib/module/{renderer/processors → dom/nodes/datatypes}/Color.js +0 -0
  267. package/lib/module/{renderer/processors → dom/nodes/datatypes}/Color.js.map +1 -1
  268. package/lib/module/dom/nodes/datatypes/Enum.js +2 -0
  269. package/lib/module/dom/nodes/datatypes/Enum.js.map +1 -0
  270. package/lib/module/{renderer/components/image/BoxFit.js → dom/nodes/datatypes/Fitting.js} +2 -2
  271. package/lib/module/{renderer/components/image/BoxFit.js.map → dom/nodes/datatypes/Fitting.js.map} +1 -1
  272. package/lib/module/dom/nodes/datatypes/Gradient.js +47 -0
  273. package/lib/module/dom/nodes/datatypes/Gradient.js.map +1 -0
  274. package/lib/module/{renderer/processors/Paths.js → dom/nodes/datatypes/Path.js} +2 -2
  275. package/lib/module/dom/nodes/datatypes/Path.js.map +1 -0
  276. package/lib/module/{renderer/processors → dom/nodes/datatypes}/Radius.js +0 -0
  277. package/lib/module/dom/nodes/datatypes/Radius.js.map +1 -0
  278. package/lib/module/{renderer/processors/Rects.js → dom/nodes/datatypes/Rect.js} +1 -1
  279. package/lib/module/dom/nodes/datatypes/Rect.js.map +1 -0
  280. package/lib/module/dom/nodes/datatypes/Transform.js +32 -0
  281. package/lib/module/dom/nodes/datatypes/Transform.js.map +1 -0
  282. package/lib/module/dom/nodes/datatypes/index.js +10 -0
  283. package/lib/module/dom/nodes/datatypes/index.js.map +1 -0
  284. package/lib/module/dom/nodes/drawings/BackdropFilterNode.js +25 -0
  285. package/lib/module/dom/nodes/drawings/BackdropFilterNode.js.map +1 -0
  286. package/lib/module/dom/nodes/drawings/Box.js +89 -0
  287. package/lib/module/dom/nodes/drawings/Box.js.map +1 -0
  288. package/lib/module/dom/nodes/drawings/CircleNode.js +31 -0
  289. package/lib/module/dom/nodes/drawings/CircleNode.js.map +1 -0
  290. package/lib/module/dom/nodes/drawings/CustomDrawingNode.js +17 -0
  291. package/lib/module/dom/nodes/drawings/CustomDrawingNode.js.map +1 -0
  292. package/lib/module/dom/nodes/drawings/DiffRectNode.js +25 -0
  293. package/lib/module/dom/nodes/drawings/DiffRectNode.js.map +1 -0
  294. package/lib/module/dom/nodes/drawings/FillNode.js +22 -0
  295. package/lib/module/dom/nodes/drawings/FillNode.js.map +1 -0
  296. package/lib/module/dom/nodes/drawings/ImageNode.js +51 -0
  297. package/lib/module/dom/nodes/drawings/ImageNode.js.map +1 -0
  298. package/lib/module/dom/nodes/drawings/ImageSVG.js +33 -0
  299. package/lib/module/dom/nodes/drawings/ImageSVG.js.map +1 -0
  300. package/lib/module/dom/nodes/drawings/LineNode.js +25 -0
  301. package/lib/module/dom/nodes/drawings/LineNode.js.map +1 -0
  302. package/lib/module/dom/nodes/drawings/OvalNode.js +27 -0
  303. package/lib/module/dom/nodes/drawings/OvalNode.js.map +1 -0
  304. package/lib/module/dom/nodes/drawings/PatchNode.js +56 -0
  305. package/lib/module/dom/nodes/drawings/PatchNode.js.map +1 -0
  306. package/lib/module/dom/nodes/drawings/PathNode.js +55 -0
  307. package/lib/module/dom/nodes/drawings/PathNode.js.map +1 -0
  308. package/lib/module/dom/nodes/drawings/PictureNode.js +23 -0
  309. package/lib/module/dom/nodes/drawings/PictureNode.js.map +1 -0
  310. package/lib/module/dom/nodes/drawings/PointsNode.js +27 -0
  311. package/lib/module/dom/nodes/drawings/PointsNode.js.map +1 -0
  312. package/lib/module/dom/nodes/drawings/RRectNode.js +31 -0
  313. package/lib/module/dom/nodes/drawings/RRectNode.js.map +1 -0
  314. package/lib/module/dom/nodes/drawings/RectNode.js +27 -0
  315. package/lib/module/dom/nodes/drawings/RectNode.js.map +1 -0
  316. package/lib/module/dom/nodes/drawings/Text.js +164 -0
  317. package/lib/module/dom/nodes/drawings/Text.js.map +1 -0
  318. package/lib/module/dom/nodes/drawings/VerticesNode.js +42 -0
  319. package/lib/module/dom/nodes/drawings/VerticesNode.js.map +1 -0
  320. package/lib/module/dom/nodes/drawings/index.js +19 -0
  321. package/lib/module/dom/nodes/drawings/index.js.map +1 -0
  322. package/lib/module/dom/nodes/index.js +4 -0
  323. package/lib/module/dom/nodes/index.js.map +1 -0
  324. package/lib/module/dom/nodes/paint/BlendNode.js +66 -0
  325. package/lib/module/dom/nodes/paint/BlendNode.js.map +1 -0
  326. package/lib/module/dom/nodes/paint/ColorFilters.js +120 -0
  327. package/lib/module/dom/nodes/paint/ColorFilters.js.map +1 -0
  328. package/lib/module/dom/nodes/paint/ImageFilters.js +191 -0
  329. package/lib/module/dom/nodes/paint/ImageFilters.js.map +1 -0
  330. package/lib/module/dom/nodes/paint/MaskFilters.js +20 -0
  331. package/lib/module/dom/nodes/paint/MaskFilters.js.map +1 -0
  332. package/lib/module/dom/nodes/paint/PathEffects.js +192 -0
  333. package/lib/module/dom/nodes/paint/PathEffects.js.map +1 -0
  334. package/lib/module/dom/nodes/paint/Shaders.js +201 -0
  335. package/lib/module/dom/nodes/paint/Shaders.js.map +1 -0
  336. package/lib/module/dom/nodes/paint/index.js +7 -0
  337. package/lib/module/dom/nodes/paint/index.js.map +1 -0
  338. package/lib/module/dom/types/ColorFilters.js +2 -0
  339. package/lib/module/dom/types/ColorFilters.js.map +1 -0
  340. package/lib/module/dom/types/Common.js +2 -0
  341. package/lib/module/dom/types/Common.js.map +1 -0
  342. package/lib/module/dom/types/DrawingContext.js +2 -0
  343. package/lib/module/dom/types/DrawingContext.js.map +1 -0
  344. package/lib/module/dom/types/Drawings.js +2 -0
  345. package/lib/module/dom/types/Drawings.js.map +1 -0
  346. package/lib/module/dom/types/ImageFilters.js +2 -0
  347. package/lib/module/dom/types/ImageFilters.js.map +1 -0
  348. package/lib/module/dom/types/MaskFilters.js +2 -0
  349. package/lib/module/dom/types/MaskFilters.js.map +1 -0
  350. package/lib/module/dom/types/Node.js +2 -0
  351. package/lib/module/dom/types/Node.js.map +1 -0
  352. package/lib/module/dom/types/NodeType.js +72 -0
  353. package/lib/module/dom/types/NodeType.js.map +1 -0
  354. package/lib/module/dom/types/PathEffects.js +2 -0
  355. package/lib/module/dom/types/PathEffects.js.map +1 -0
  356. package/lib/module/dom/types/Shaders.js +2 -0
  357. package/lib/module/dom/types/Shaders.js.map +1 -0
  358. package/lib/module/dom/types/SkDOM.js +2 -0
  359. package/lib/module/dom/types/SkDOM.js.map +1 -0
  360. package/lib/module/dom/types/index.js +12 -0
  361. package/lib/module/dom/types/index.js.map +1 -0
  362. package/lib/module/index.js +2 -0
  363. package/lib/module/index.js.map +1 -1
  364. package/lib/module/renderer/Canvas.js +7 -3
  365. package/lib/module/renderer/Canvas.js.map +1 -1
  366. package/lib/module/renderer/Container.js +29 -0
  367. package/lib/module/renderer/Container.js.map +1 -0
  368. package/lib/module/renderer/DependencyManager.js +17 -5
  369. package/lib/module/renderer/DependencyManager.js.map +1 -1
  370. package/lib/module/renderer/HostComponents.js +185 -0
  371. package/lib/module/renderer/HostComponents.js.map +1 -0
  372. package/lib/module/renderer/HostConfig.js +47 -126
  373. package/lib/module/renderer/HostConfig.js.map +1 -1
  374. package/lib/module/renderer/components/Blend.js +1 -42
  375. package/lib/module/renderer/components/Blend.js.map +1 -1
  376. package/lib/module/renderer/components/Drawing.js +1 -13
  377. package/lib/module/renderer/components/Drawing.js.map +1 -1
  378. package/lib/module/renderer/components/Group.js +1 -65
  379. package/lib/module/renderer/components/Group.js.map +1 -1
  380. package/lib/module/renderer/components/Paint.js +3 -12
  381. package/lib/module/renderer/components/Paint.js.map +1 -1
  382. package/lib/module/renderer/components/Picture.js +1 -17
  383. package/lib/module/renderer/components/Picture.js.map +1 -1
  384. package/lib/module/renderer/components/backdrop/BackdropBlur.js.map +1 -1
  385. package/lib/module/renderer/components/backdrop/BackdropFilter.js +2 -30
  386. package/lib/module/renderer/components/backdrop/BackdropFilter.js.map +1 -1
  387. package/lib/module/renderer/components/colorFilters/BlendColor.js +1 -20
  388. package/lib/module/renderer/components/colorFilters/BlendColor.js.map +1 -1
  389. package/lib/module/renderer/components/colorFilters/Lerp.js +1 -19
  390. package/lib/module/renderer/components/colorFilters/Lerp.js.map +1 -1
  391. package/lib/module/renderer/components/colorFilters/LinearToSRGBGamma.js +1 -15
  392. package/lib/module/renderer/components/colorFilters/LinearToSRGBGamma.js.map +1 -1
  393. package/lib/module/renderer/components/colorFilters/LumaColorFilter.js +1 -15
  394. package/lib/module/renderer/components/colorFilters/LumaColorFilter.js.map +1 -1
  395. package/lib/module/renderer/components/colorFilters/Matrix.js +1 -17
  396. package/lib/module/renderer/components/colorFilters/Matrix.js.map +1 -1
  397. package/lib/module/renderer/components/colorFilters/SRGBToLinearGamma.js +1 -15
  398. package/lib/module/renderer/components/colorFilters/SRGBToLinearGamma.js.map +1 -1
  399. package/lib/module/renderer/components/image/Image.js +1 -31
  400. package/lib/module/renderer/components/image/Image.js.map +1 -1
  401. package/lib/module/renderer/components/image/ImageSVG.js +1 -27
  402. package/lib/module/renderer/components/image/ImageSVG.js.map +1 -1
  403. package/lib/module/renderer/components/image/ImageShader.js +1 -57
  404. package/lib/module/renderer/components/image/ImageShader.js.map +1 -1
  405. package/lib/module/renderer/components/image/index.js +0 -1
  406. package/lib/module/renderer/components/image/index.js.map +1 -1
  407. package/lib/module/renderer/components/imageFilters/Blur.js +1 -21
  408. package/lib/module/renderer/components/imageFilters/Blur.js.map +1 -1
  409. package/lib/module/renderer/components/imageFilters/DisplacementMap.js +1 -30
  410. package/lib/module/renderer/components/imageFilters/DisplacementMap.js.map +1 -1
  411. package/lib/module/renderer/components/imageFilters/Morphology.js +1 -21
  412. package/lib/module/renderer/components/imageFilters/Morphology.js.map +1 -1
  413. package/lib/module/renderer/components/imageFilters/Offset.js +1 -17
  414. package/lib/module/renderer/components/imageFilters/Offset.js.map +1 -1
  415. package/lib/module/renderer/components/imageFilters/RuntimeShader.js +1 -24
  416. package/lib/module/renderer/components/imageFilters/RuntimeShader.js.map +1 -1
  417. package/lib/module/renderer/components/imageFilters/Shadow.js +1 -34
  418. package/lib/module/renderer/components/imageFilters/Shadow.js.map +1 -1
  419. package/lib/module/renderer/components/index.js +0 -1
  420. package/lib/module/renderer/components/index.js.map +1 -1
  421. package/lib/module/renderer/components/maskFilters/Blur.js +1 -19
  422. package/lib/module/renderer/components/maskFilters/Blur.js.map +1 -1
  423. package/lib/module/renderer/components/pathEffects/Corner.js +1 -27
  424. package/lib/module/renderer/components/pathEffects/Corner.js.map +1 -1
  425. package/lib/module/renderer/components/pathEffects/Dash.js +1 -24
  426. package/lib/module/renderer/components/pathEffects/Dash.js.map +1 -1
  427. package/lib/module/renderer/components/pathEffects/Discrete.js +1 -25
  428. package/lib/module/renderer/components/pathEffects/Discrete.js.map +1 -1
  429. package/lib/module/renderer/components/pathEffects/Line2D.js +1 -28
  430. package/lib/module/renderer/components/pathEffects/Line2D.js.map +1 -1
  431. package/lib/module/renderer/components/pathEffects/Path1D.js +1 -32
  432. package/lib/module/renderer/components/pathEffects/Path1D.js.map +1 -1
  433. package/lib/module/renderer/components/pathEffects/Path2D.js +1 -29
  434. package/lib/module/renderer/components/pathEffects/Path2D.js.map +1 -1
  435. package/lib/module/renderer/components/pathEffects/Sum.js +1 -14
  436. package/lib/module/renderer/components/pathEffects/Sum.js.map +1 -1
  437. package/lib/module/renderer/components/shaders/Color.js +1 -16
  438. package/lib/module/renderer/components/shaders/Color.js.map +1 -1
  439. package/lib/module/renderer/components/shaders/FractalNoise.js +1 -20
  440. package/lib/module/renderer/components/shaders/FractalNoise.js.map +1 -1
  441. package/lib/module/renderer/components/shaders/LinearGradient.js +1 -25
  442. package/lib/module/renderer/components/shaders/LinearGradient.js.map +1 -1
  443. package/lib/module/renderer/components/shaders/RadialGradient.js +1 -25
  444. package/lib/module/renderer/components/shaders/RadialGradient.js.map +1 -1
  445. package/lib/module/renderer/components/shaders/Shader.js +1 -19
  446. package/lib/module/renderer/components/shaders/Shader.js.map +1 -1
  447. package/lib/module/renderer/components/shaders/SweepGradient.js +1 -26
  448. package/lib/module/renderer/components/shaders/SweepGradient.js.map +1 -1
  449. package/lib/module/renderer/components/shaders/Turbulence.js +1 -20
  450. package/lib/module/renderer/components/shaders/Turbulence.js.map +1 -1
  451. package/lib/module/renderer/components/shaders/TwoPointConicalGradient.js +1 -27
  452. package/lib/module/renderer/components/shaders/TwoPointConicalGradient.js.map +1 -1
  453. package/lib/module/renderer/components/shapes/Box.js +2 -97
  454. package/lib/module/renderer/components/shapes/Box.js.map +1 -1
  455. package/lib/module/renderer/components/shapes/Circle.js +1 -19
  456. package/lib/module/renderer/components/shapes/Circle.js.map +1 -1
  457. package/lib/module/renderer/components/shapes/DiffRect.js +1 -17
  458. package/lib/module/renderer/components/shapes/DiffRect.js.map +1 -1
  459. package/lib/module/renderer/components/shapes/Fill.js +1 -13
  460. package/lib/module/renderer/components/shapes/Fill.js.map +1 -1
  461. package/lib/module/renderer/components/shapes/FitBox.js +1 -1
  462. package/lib/module/renderer/components/shapes/FitBox.js.map +1 -1
  463. package/lib/module/renderer/components/shapes/Line.js +1 -17
  464. package/lib/module/renderer/components/shapes/Line.js.map +1 -1
  465. package/lib/module/renderer/components/shapes/Oval.js +1 -16
  466. package/lib/module/renderer/components/shapes/Oval.js.map +1 -1
  467. package/lib/module/renderer/components/shapes/Patch.js +1 -32
  468. package/lib/module/renderer/components/shapes/Patch.js.map +1 -1
  469. package/lib/module/renderer/components/shapes/Path.js +1 -43
  470. package/lib/module/renderer/components/shapes/Path.js.map +1 -1
  471. package/lib/module/renderer/components/shapes/Points.js +1 -20
  472. package/lib/module/renderer/components/shapes/Points.js.map +1 -1
  473. package/lib/module/renderer/components/shapes/Rect.js +1 -16
  474. package/lib/module/renderer/components/shapes/Rect.js.map +1 -1
  475. package/lib/module/renderer/components/shapes/RoundedRect.js +1 -16
  476. package/lib/module/renderer/components/shapes/RoundedRect.js.map +1 -1
  477. package/lib/module/renderer/components/shapes/Vertices.js +1 -31
  478. package/lib/module/renderer/components/shapes/Vertices.js.map +1 -1
  479. package/lib/module/renderer/components/text/Glyphs.js +1 -37
  480. package/lib/module/renderer/components/text/Glyphs.js.map +1 -1
  481. package/lib/module/renderer/components/text/Text.js +1 -22
  482. package/lib/module/renderer/components/text/Text.js.map +1 -1
  483. package/lib/module/renderer/components/text/TextBlob.js +1 -18
  484. package/lib/module/renderer/components/text/TextBlob.js.map +1 -1
  485. package/lib/module/renderer/components/text/TextPath.js +1 -69
  486. package/lib/module/renderer/components/text/TextPath.js.map +1 -1
  487. package/lib/module/renderer/index.js +0 -1
  488. package/lib/module/renderer/index.js.map +1 -1
  489. package/lib/module/renderer/processors/Animations/Animations.js.map +1 -1
  490. package/lib/module/renderer/processors/index.js +0 -9
  491. package/lib/module/renderer/processors/index.js.map +1 -1
  492. package/lib/module/skia/types/Matrix.js.map +1 -1
  493. package/lib/module/skia/web/JsiSkMatrix.js +4 -0
  494. package/lib/module/skia/web/JsiSkMatrix.js.map +1 -1
  495. package/lib/module/web/WithSkiaWeb.js +3 -1
  496. package/lib/module/web/WithSkiaWeb.js.map +1 -1
  497. package/lib/typescript/src/dom/nodes/DrawingNode.d.ts +14 -0
  498. package/lib/typescript/src/dom/nodes/GroupNode.d.ts +8 -0
  499. package/lib/typescript/src/dom/nodes/JsiSkDOM.d.ts +70 -0
  500. package/lib/typescript/src/dom/nodes/Node.d.ts +43 -0
  501. package/lib/typescript/src/dom/nodes/PaintContext.d.ts +18 -0
  502. package/lib/typescript/src/dom/nodes/PaintNode.d.ts +8 -0
  503. package/lib/typescript/src/dom/nodes/RenderNode.d.ts +29 -0
  504. package/lib/typescript/src/dom/nodes/datatypes/Circle.d.ts +4 -0
  505. package/lib/typescript/src/{renderer/processors → dom/nodes/datatypes}/Color.d.ts +1 -1
  506. package/lib/typescript/src/dom/nodes/datatypes/Enum.d.ts +1 -0
  507. package/lib/typescript/src/{renderer/components/image/BoxFit.d.ts → dom/nodes/datatypes/Fitting.d.ts} +1 -1
  508. package/lib/typescript/src/{renderer/processors/Transform.d.ts → dom/nodes/datatypes/Gradient.d.ts} +11 -9
  509. package/lib/typescript/src/dom/nodes/datatypes/Path.d.ts +4 -0
  510. package/lib/typescript/src/dom/nodes/datatypes/Radius.d.ts +3 -0
  511. package/lib/typescript/src/dom/nodes/datatypes/Rect.d.ts +5 -0
  512. package/lib/typescript/src/dom/nodes/datatypes/Transform.d.ts +3 -0
  513. package/lib/typescript/src/dom/nodes/datatypes/index.d.ts +9 -0
  514. package/lib/typescript/src/dom/nodes/drawings/BackdropFilterNode.d.ts +8 -0
  515. package/lib/typescript/src/dom/nodes/drawings/Box.d.ts +13 -0
  516. package/lib/typescript/src/dom/nodes/drawings/CircleNode.d.ts +9 -0
  517. package/lib/typescript/src/dom/nodes/drawings/CustomDrawingNode.d.ts +8 -0
  518. package/lib/typescript/src/dom/nodes/drawings/DiffRectNode.d.ts +8 -0
  519. package/lib/typescript/src/dom/nodes/drawings/FillNode.d.ts +8 -0
  520. package/lib/typescript/src/dom/nodes/drawings/ImageNode.d.ts +25 -0
  521. package/lib/typescript/src/dom/nodes/drawings/ImageSVG.d.ts +8 -0
  522. package/lib/typescript/src/dom/nodes/drawings/LineNode.d.ts +8 -0
  523. package/lib/typescript/src/dom/nodes/drawings/OvalNode.d.ts +9 -0
  524. package/lib/typescript/src/dom/nodes/drawings/PatchNode.d.ts +18 -0
  525. package/lib/typescript/src/dom/nodes/drawings/PathNode.d.ts +9 -0
  526. package/lib/typescript/src/dom/nodes/drawings/PictureNode.d.ts +8 -0
  527. package/lib/typescript/src/dom/nodes/drawings/PointsNode.d.ts +8 -0
  528. package/lib/typescript/src/dom/nodes/drawings/RRectNode.d.ts +10 -0
  529. package/lib/typescript/src/dom/nodes/drawings/RectNode.d.ts +9 -0
  530. package/lib/typescript/src/dom/nodes/drawings/Text.d.ts +30 -0
  531. package/lib/typescript/src/dom/nodes/drawings/VerticesNode.d.ts +9 -0
  532. package/lib/typescript/src/dom/nodes/drawings/index.d.ts +18 -0
  533. package/lib/typescript/src/dom/nodes/index.d.ts +3 -0
  534. package/lib/typescript/src/dom/nodes/paint/BlendNode.d.ts +12 -0
  535. package/lib/typescript/src/dom/nodes/paint/ColorFilters.d.ts +36 -0
  536. package/lib/typescript/src/dom/nodes/paint/ImageFilters.d.ts +42 -0
  537. package/lib/typescript/src/dom/nodes/paint/MaskFilters.d.ts +8 -0
  538. package/lib/typescript/src/dom/nodes/paint/PathEffects.d.ts +42 -0
  539. package/lib/typescript/src/dom/nodes/paint/Shaders.d.ts +44 -0
  540. package/lib/typescript/src/dom/nodes/paint/index.d.ts +6 -0
  541. package/lib/typescript/src/dom/types/ColorFilters.d.ts +12 -0
  542. package/lib/typescript/src/dom/types/Common.d.ts +57 -0
  543. package/lib/typescript/src/dom/types/DrawingContext.d.ts +6 -0
  544. package/lib/typescript/src/dom/types/Drawings.d.ts +106 -0
  545. package/lib/typescript/src/dom/types/ImageFilters.d.ts +37 -0
  546. package/lib/typescript/src/dom/types/MaskFilters.d.ts +7 -0
  547. package/lib/typescript/src/dom/types/Node.d.ts +29 -0
  548. package/lib/typescript/src/dom/types/NodeType.d.ts +66 -0
  549. package/lib/typescript/src/dom/types/PathEffects.d.ts +28 -0
  550. package/lib/typescript/src/dom/types/Shaders.d.ts +59 -0
  551. package/lib/typescript/src/dom/types/SkDOM.d.ts +71 -0
  552. package/lib/typescript/src/dom/types/index.d.ts +11 -0
  553. package/lib/typescript/src/index.d.ts +2 -0
  554. package/lib/typescript/src/renderer/Canvas.d.ts +3 -3
  555. package/lib/typescript/src/renderer/Container.d.ts +12 -0
  556. package/lib/typescript/src/renderer/DependencyManager.d.ts +5 -4
  557. package/lib/typescript/src/renderer/HostComponents.d.ts +72 -0
  558. package/lib/typescript/src/renderer/HostConfig.d.ts +5 -13
  559. package/lib/typescript/src/renderer/components/Blend.d.ts +4 -9
  560. package/lib/typescript/src/renderer/components/Drawing.d.ts +2 -6
  561. package/lib/typescript/src/renderer/components/Group.d.ts +4 -9
  562. package/lib/typescript/src/renderer/components/Paint.d.ts +4 -8
  563. package/lib/typescript/src/renderer/components/Picture.d.ts +3 -5
  564. package/lib/typescript/src/renderer/components/backdrop/BackdropBlur.d.ts +2 -1
  565. package/lib/typescript/src/renderer/components/backdrop/BackdropFilter.d.ts +3 -3
  566. package/lib/typescript/src/renderer/components/colorFilters/BlendColor.d.ts +4 -10
  567. package/lib/typescript/src/renderer/components/colorFilters/Lerp.d.ts +4 -7
  568. package/lib/typescript/src/renderer/components/colorFilters/LinearToSRGBGamma.d.ts +3 -4
  569. package/lib/typescript/src/renderer/components/colorFilters/LumaColorFilter.d.ts +3 -4
  570. package/lib/typescript/src/renderer/components/colorFilters/Matrix.d.ts +4 -8
  571. package/lib/typescript/src/renderer/components/colorFilters/SRGBToLinearGamma.d.ts +3 -4
  572. package/lib/typescript/src/renderer/components/image/Image.d.ts +3 -11
  573. package/lib/typescript/src/renderer/components/image/ImageSVG.d.ts +2 -5
  574. package/lib/typescript/src/renderer/components/image/ImageShader.d.ts +3 -15
  575. package/lib/typescript/src/renderer/components/image/index.d.ts +0 -1
  576. package/lib/typescript/src/renderer/components/imageFilters/Blur.d.ts +4 -10
  577. package/lib/typescript/src/renderer/components/imageFilters/DisplacementMap.d.ts +4 -10
  578. package/lib/typescript/src/renderer/components/imageFilters/Morphology.d.ts +4 -8
  579. package/lib/typescript/src/renderer/components/imageFilters/Offset.d.ts +4 -8
  580. package/lib/typescript/src/renderer/components/imageFilters/RuntimeShader.d.ts +3 -7
  581. package/lib/typescript/src/renderer/components/imageFilters/Shadow.d.ts +3 -11
  582. package/lib/typescript/src/renderer/components/index.d.ts +0 -1
  583. package/lib/typescript/src/renderer/components/maskFilters/Blur.d.ts +3 -9
  584. package/lib/typescript/src/renderer/components/pathEffects/Corner.d.ts +4 -7
  585. package/lib/typescript/src/renderer/components/pathEffects/Dash.d.ts +4 -8
  586. package/lib/typescript/src/renderer/components/pathEffects/Discrete.d.ts +4 -9
  587. package/lib/typescript/src/renderer/components/pathEffects/Line2D.d.ts +4 -9
  588. package/lib/typescript/src/renderer/components/pathEffects/Path1D.d.ts +4 -13
  589. package/lib/typescript/src/renderer/components/pathEffects/Path2D.d.ts +4 -10
  590. package/lib/typescript/src/renderer/components/pathEffects/Sum.d.ts +3 -6
  591. package/lib/typescript/src/renderer/components/shaders/Color.d.ts +3 -6
  592. package/lib/typescript/src/renderer/components/shaders/FractalNoise.d.ts +3 -10
  593. package/lib/typescript/src/renderer/components/shaders/LinearGradient.d.ts +3 -8
  594. package/lib/typescript/src/renderer/components/shaders/RadialGradient.d.ts +3 -8
  595. package/lib/typescript/src/renderer/components/shaders/Shader.d.ts +4 -9
  596. package/lib/typescript/src/renderer/components/shaders/SweepGradient.d.ts +3 -9
  597. package/lib/typescript/src/renderer/components/shaders/Turbulence.d.ts +3 -10
  598. package/lib/typescript/src/renderer/components/shaders/TwoPointConicalGradient.d.ts +3 -10
  599. package/lib/typescript/src/renderer/components/shapes/Box.d.ts +4 -21
  600. package/lib/typescript/src/renderer/components/shapes/Circle.d.ts +3 -3
  601. package/lib/typescript/src/renderer/components/shapes/DiffRect.d.ts +3 -8
  602. package/lib/typescript/src/renderer/components/shapes/Fill.d.ts +3 -4
  603. package/lib/typescript/src/renderer/components/shapes/FitBox.d.ts +1 -1
  604. package/lib/typescript/src/renderer/components/shapes/Line.d.ts +3 -7
  605. package/lib/typescript/src/renderer/components/shapes/Oval.d.ts +3 -3
  606. package/lib/typescript/src/renderer/components/shapes/Patch.d.ts +3 -20
  607. package/lib/typescript/src/renderer/components/shapes/Path.d.ts +3 -16
  608. package/lib/typescript/src/renderer/components/shapes/Points.d.ts +3 -9
  609. package/lib/typescript/src/renderer/components/shapes/Rect.d.ts +3 -3
  610. package/lib/typescript/src/renderer/components/shapes/RoundedRect.d.ts +3 -3
  611. package/lib/typescript/src/renderer/components/shapes/Vertices.d.ts +3 -12
  612. package/lib/typescript/src/renderer/components/text/Glyphs.d.ts +3 -13
  613. package/lib/typescript/src/renderer/components/text/Text.d.ts +3 -8
  614. package/lib/typescript/src/renderer/components/text/TextBlob.d.ts +3 -8
  615. package/lib/typescript/src/renderer/components/text/TextPath.d.ts +3 -9
  616. package/lib/typescript/src/renderer/index.d.ts +0 -1
  617. package/lib/typescript/src/renderer/processors/Animations/Animations.d.ts +1 -0
  618. package/lib/typescript/src/renderer/processors/index.d.ts +0 -9
  619. package/lib/typescript/src/skia/types/Matrix.d.ts +1 -0
  620. package/lib/typescript/src/skia/web/JsiSkMatrix.d.ts +1 -0
  621. package/package.json +1 -1
  622. package/src/dom/nodes/DrawingNode.ts +72 -0
  623. package/src/dom/nodes/GroupNode.ts +23 -0
  624. package/src/dom/nodes/JsiSkDOM.ts +353 -0
  625. package/src/dom/nodes/Node.ts +158 -0
  626. package/src/dom/nodes/PaintContext.ts +30 -0
  627. package/src/dom/nodes/PaintNode.ts +77 -0
  628. package/src/dom/nodes/RenderNode.ts +349 -0
  629. package/src/{renderer/processors/Circles.ts → dom/nodes/datatypes/Circle.ts} +3 -15
  630. package/src/{renderer/processors → dom/nodes/datatypes}/Color.ts +1 -1
  631. package/src/dom/nodes/datatypes/Enum.ts +2 -0
  632. package/src/{renderer/components/image/BoxFit.ts → dom/nodes/datatypes/Fitting.ts} +2 -11
  633. package/src/dom/nodes/datatypes/Gradient.ts +48 -0
  634. package/src/{renderer/processors/Paths.ts → dom/nodes/datatypes/Path.ts} +3 -4
  635. package/src/{renderer/processors → dom/nodes/datatypes}/Radius.ts +2 -3
  636. package/src/{renderer/processors/Rects.ts → dom/nodes/datatypes/Rect.ts} +2 -16
  637. package/src/dom/nodes/datatypes/Transform.ts +26 -0
  638. package/src/dom/nodes/datatypes/index.ts +9 -0
  639. package/src/dom/nodes/drawings/BackdropFilterNode.ts +30 -0
  640. package/src/dom/nodes/drawings/Box.ts +105 -0
  641. package/src/dom/nodes/drawings/CircleNode.ts +24 -0
  642. package/src/dom/nodes/drawings/CustomDrawingNode.ts +21 -0
  643. package/src/dom/nodes/drawings/DiffRectNode.ts +19 -0
  644. package/src/dom/nodes/drawings/FillNode.ts +18 -0
  645. package/src/dom/nodes/drawings/ImageNode.ts +40 -0
  646. package/src/dom/nodes/drawings/ImageSVG.ts +24 -0
  647. package/src/dom/nodes/drawings/LineNode.ts +19 -0
  648. package/src/dom/nodes/drawings/OvalNode.ts +23 -0
  649. package/src/dom/nodes/drawings/PatchNode.ts +68 -0
  650. package/src/dom/nodes/drawings/PathNode.ts +42 -0
  651. package/src/dom/nodes/drawings/PictureNode.ts +19 -0
  652. package/src/dom/nodes/drawings/PointsNode.ts +21 -0
  653. package/src/dom/nodes/drawings/RRectNode.ts +25 -0
  654. package/src/dom/nodes/drawings/RectNode.ts +23 -0
  655. package/src/dom/nodes/drawings/Text.ts +122 -0
  656. package/src/dom/nodes/drawings/VerticesNode.ts +35 -0
  657. package/src/dom/nodes/drawings/index.ts +18 -0
  658. package/src/dom/nodes/index.ts +3 -0
  659. package/src/dom/nodes/paint/BlendNode.ts +79 -0
  660. package/src/dom/nodes/paint/ColorFilters.ts +130 -0
  661. package/src/dom/nodes/paint/ImageFilters.ts +210 -0
  662. package/src/dom/nodes/paint/MaskFilters.ts +25 -0
  663. package/src/dom/nodes/paint/PathEffects.ts +192 -0
  664. package/src/dom/nodes/paint/Shaders.ts +228 -0
  665. package/src/dom/nodes/paint/index.ts +6 -0
  666. package/src/dom/types/ColorFilters.ts +16 -0
  667. package/src/dom/types/Common.ts +90 -0
  668. package/src/dom/types/DrawingContext.ts +7 -0
  669. package/src/dom/types/Drawings.ts +157 -0
  670. package/src/dom/types/ImageFilters.ts +53 -0
  671. package/src/dom/types/MaskFilters.ts +9 -0
  672. package/src/dom/types/Node.ts +46 -0
  673. package/src/dom/types/NodeType.ts +80 -0
  674. package/src/dom/types/PathEffects.ts +35 -0
  675. package/src/dom/types/Shaders.ts +86 -0
  676. package/src/dom/types/SkDOM.ts +202 -0
  677. package/src/dom/types/index.ts +11 -0
  678. package/src/index.ts +2 -0
  679. package/src/renderer/Canvas.tsx +7 -6
  680. package/src/renderer/Container.tsx +31 -0
  681. package/src/renderer/DependencyManager.tsx +23 -15
  682. package/src/renderer/HostComponents.ts +269 -0
  683. package/src/renderer/HostConfig.ts +60 -123
  684. package/src/renderer/components/Blend.tsx +4 -45
  685. package/src/renderer/components/Drawing.tsx +3 -12
  686. package/src/renderer/components/Group.tsx +4 -79
  687. package/src/renderer/components/Paint.tsx +7 -24
  688. package/src/renderer/components/Picture.tsx +4 -13
  689. package/src/renderer/components/backdrop/BackdropBlur.tsx +2 -1
  690. package/src/renderer/components/backdrop/BackdropFilter.tsx +5 -29
  691. package/src/renderer/components/colorFilters/BlendColor.tsx +4 -26
  692. package/src/renderer/components/colorFilters/Lerp.tsx +4 -23
  693. package/src/renderer/components/colorFilters/LinearToSRGBGamma.tsx +4 -16
  694. package/src/renderer/components/colorFilters/LumaColorFilter.tsx +4 -14
  695. package/src/renderer/components/colorFilters/Matrix.tsx +4 -19
  696. package/src/renderer/components/colorFilters/SRGBToLinearGamma.tsx +4 -16
  697. package/src/renderer/components/image/Image.tsx +4 -40
  698. package/src/renderer/components/image/ImageSVG.tsx +3 -19
  699. package/src/renderer/components/image/ImageShader.tsx +4 -69
  700. package/src/renderer/components/image/index.ts +0 -1
  701. package/src/renderer/components/imageFilters/Blur.tsx +4 -29
  702. package/src/renderer/components/imageFilters/DisplacementMap.tsx +6 -30
  703. package/src/renderer/components/imageFilters/Morphology.tsx +4 -25
  704. package/src/renderer/components/imageFilters/Offset.tsx +4 -19
  705. package/src/renderer/components/imageFilters/RuntimeShader.tsx +6 -27
  706. package/src/renderer/components/imageFilters/Shadow.tsx +4 -38
  707. package/src/renderer/components/index.ts +0 -1
  708. package/src/renderer/components/maskFilters/Blur.tsx +4 -23
  709. package/src/renderer/components/pathEffects/Corner.tsx +4 -27
  710. package/src/renderer/components/pathEffects/Dash.tsx +4 -23
  711. package/src/renderer/components/pathEffects/Discrete.tsx +4 -24
  712. package/src/renderer/components/pathEffects/Line2D.tsx +4 -29
  713. package/src/renderer/components/pathEffects/Path1D.tsx +4 -39
  714. package/src/renderer/components/pathEffects/Path2D.tsx +4 -31
  715. package/src/renderer/components/pathEffects/Sum.tsx +3 -17
  716. package/src/renderer/components/shaders/Color.tsx +4 -16
  717. package/src/renderer/components/shaders/FractalNoise.tsx +4 -26
  718. package/src/renderer/components/shaders/LinearGradient.tsx +4 -29
  719. package/src/renderer/components/shaders/RadialGradient.tsx +4 -29
  720. package/src/renderer/components/shaders/Shader.tsx +4 -24
  721. package/src/renderer/components/shaders/SweepGradient.tsx +4 -32
  722. package/src/renderer/components/shaders/Turbulence.tsx +4 -26
  723. package/src/renderer/components/shaders/TwoPointConicalGradient.tsx +4 -33
  724. package/src/renderer/components/shapes/Box.tsx +6 -109
  725. package/src/renderer/components/shapes/Circle.tsx +4 -16
  726. package/src/renderer/components/shapes/DiffRect.tsx +4 -17
  727. package/src/renderer/components/shapes/Fill.tsx +4 -11
  728. package/src/renderer/components/shapes/FitBox.tsx +2 -2
  729. package/src/renderer/components/shapes/Line.tsx +4 -13
  730. package/src/renderer/components/shapes/Oval.tsx +4 -18
  731. package/src/renderer/components/shapes/Patch.tsx +4 -59
  732. package/src/renderer/components/shapes/Path.tsx +4 -48
  733. package/src/renderer/components/shapes/Points.tsx +4 -20
  734. package/src/renderer/components/shapes/Rect.tsx +4 -18
  735. package/src/renderer/components/shapes/RoundedRect.tsx +4 -17
  736. package/src/renderer/components/shapes/Vertices.tsx +4 -37
  737. package/src/renderer/components/text/Glyphs.tsx +4 -39
  738. package/src/renderer/components/text/Text.tsx +4 -22
  739. package/src/renderer/components/text/TextBlob.tsx +4 -17
  740. package/src/renderer/components/text/TextPath.tsx +4 -59
  741. package/src/renderer/index.ts +0 -1
  742. package/src/renderer/processors/Animations/Animations.ts +5 -0
  743. package/src/renderer/processors/index.ts +0 -9
  744. package/src/skia/types/Matrix.ts +1 -0
  745. package/src/skia/web/JsiSkMatrix.ts +4 -0
  746. package/src/web/WithSkiaWeb.tsx +3 -1
  747. package/lib/commonjs/renderer/components/Compose.js +0 -40
  748. package/lib/commonjs/renderer/components/Compose.js.map +0 -1
  749. package/lib/commonjs/renderer/components/colorFilters/Compose.js +0 -24
  750. package/lib/commonjs/renderer/components/colorFilters/Compose.js.map +0 -1
  751. package/lib/commonjs/renderer/components/imageFilters/InnerShadow.js +0 -28
  752. package/lib/commonjs/renderer/components/imageFilters/InnerShadow.js.map +0 -1
  753. package/lib/commonjs/renderer/components/imageFilters/getInput.js +0 -33
  754. package/lib/commonjs/renderer/components/imageFilters/getInput.js.map +0 -1
  755. package/lib/commonjs/renderer/components/shaders/Gradient.js +0 -32
  756. package/lib/commonjs/renderer/components/shaders/Gradient.js.map +0 -1
  757. package/lib/commonjs/renderer/nodes/Container.js +0 -28
  758. package/lib/commonjs/renderer/nodes/Container.js.map +0 -1
  759. package/lib/commonjs/renderer/nodes/Declaration.js +0 -57
  760. package/lib/commonjs/renderer/nodes/Declaration.js.map +0 -1
  761. package/lib/commonjs/renderer/nodes/Drawing.js +0 -56
  762. package/lib/commonjs/renderer/nodes/Drawing.js.map +0 -1
  763. package/lib/commonjs/renderer/nodes/Node.js +0 -73
  764. package/lib/commonjs/renderer/nodes/Node.js.map +0 -1
  765. package/lib/commonjs/renderer/nodes/index.js +0 -58
  766. package/lib/commonjs/renderer/nodes/index.js.map +0 -1
  767. package/lib/commonjs/renderer/processors/Circles.js.map +0 -1
  768. package/lib/commonjs/renderer/processors/Clips.js +0 -24
  769. package/lib/commonjs/renderer/processors/Clips.js.map +0 -1
  770. package/lib/commonjs/renderer/processors/Font.js +0 -13
  771. package/lib/commonjs/renderer/processors/Font.js.map +0 -1
  772. package/lib/commonjs/renderer/processors/Paint.js +0 -98
  773. package/lib/commonjs/renderer/processors/Paint.js.map +0 -1
  774. package/lib/commonjs/renderer/processors/Paths.js.map +0 -1
  775. package/lib/commonjs/renderer/processors/Radius.js.map +0 -1
  776. package/lib/commonjs/renderer/processors/Rects.js.map +0 -1
  777. package/lib/commonjs/renderer/processors/Transform.js +0 -58
  778. package/lib/commonjs/renderer/processors/Transform.js.map +0 -1
  779. package/lib/module/renderer/components/Compose.js +0 -25
  780. package/lib/module/renderer/components/Compose.js.map +0 -1
  781. package/lib/module/renderer/components/colorFilters/Compose.js +0 -14
  782. package/lib/module/renderer/components/colorFilters/Compose.js.map +0 -1
  783. package/lib/module/renderer/components/imageFilters/InnerShadow.js +0 -17
  784. package/lib/module/renderer/components/imageFilters/InnerShadow.js.map +0 -1
  785. package/lib/module/renderer/components/imageFilters/getInput.js +0 -23
  786. package/lib/module/renderer/components/imageFilters/getInput.js.map +0 -1
  787. package/lib/module/renderer/components/shaders/Gradient.js +0 -20
  788. package/lib/module/renderer/components/shaders/Gradient.js.map +0 -1
  789. package/lib/module/renderer/nodes/Container.js +0 -18
  790. package/lib/module/renderer/nodes/Container.js.map +0 -1
  791. package/lib/module/renderer/nodes/Declaration.js +0 -36
  792. package/lib/module/renderer/nodes/Declaration.js.map +0 -1
  793. package/lib/module/renderer/nodes/Drawing.js +0 -37
  794. package/lib/module/renderer/nodes/Drawing.js.map +0 -1
  795. package/lib/module/renderer/nodes/Node.js +0 -63
  796. package/lib/module/renderer/nodes/Node.js.map +0 -1
  797. package/lib/module/renderer/nodes/index.js +0 -5
  798. package/lib/module/renderer/nodes/index.js.map +0 -1
  799. package/lib/module/renderer/processors/Circles.js.map +0 -1
  800. package/lib/module/renderer/processors/Clips.js +0 -13
  801. package/lib/module/renderer/processors/Clips.js.map +0 -1
  802. package/lib/module/renderer/processors/Font.js +0 -4
  803. package/lib/module/renderer/processors/Font.js.map +0 -1
  804. package/lib/module/renderer/processors/Paint.js +0 -84
  805. package/lib/module/renderer/processors/Paint.js.map +0 -1
  806. package/lib/module/renderer/processors/Paths.js.map +0 -1
  807. package/lib/module/renderer/processors/Radius.js.map +0 -1
  808. package/lib/module/renderer/processors/Rects.js.map +0 -1
  809. package/lib/module/renderer/processors/Transform.js +0 -42
  810. package/lib/module/renderer/processors/Transform.js.map +0 -1
  811. package/lib/typescript/src/renderer/components/Compose.d.ts +0 -6
  812. package/lib/typescript/src/renderer/components/colorFilters/Compose.d.ts +0 -3
  813. package/lib/typescript/src/renderer/components/imageFilters/InnerShadow.d.ts +0 -2
  814. package/lib/typescript/src/renderer/components/imageFilters/getInput.d.ts +0 -3
  815. package/lib/typescript/src/renderer/components/shaders/Gradient.d.ts +0 -17
  816. package/lib/typescript/src/renderer/nodes/Container.d.ts +0 -8
  817. package/lib/typescript/src/renderer/nodes/Declaration.d.ts +0 -22
  818. package/lib/typescript/src/renderer/nodes/Drawing.d.ts +0 -21
  819. package/lib/typescript/src/renderer/nodes/Node.d.ts +0 -24
  820. package/lib/typescript/src/renderer/nodes/index.d.ts +0 -4
  821. package/lib/typescript/src/renderer/processors/Circles.d.ts +0 -13
  822. package/lib/typescript/src/renderer/processors/Clips.d.ts +0 -4
  823. package/lib/typescript/src/renderer/processors/Font.d.ts +0 -7
  824. package/lib/typescript/src/renderer/processors/Paint.d.ts +0 -22
  825. package/lib/typescript/src/renderer/processors/Paths.d.ts +0 -4
  826. package/lib/typescript/src/renderer/processors/Radius.d.ts +0 -3
  827. package/lib/typescript/src/renderer/processors/Rects.d.ts +0 -20
  828. package/src/renderer/components/Compose.tsx +0 -26
  829. package/src/renderer/components/colorFilters/Compose.ts +0 -18
  830. package/src/renderer/components/imageFilters/InnerShadow.tsx +0 -38
  831. package/src/renderer/components/imageFilters/getInput.ts +0 -20
  832. package/src/renderer/components/shaders/Gradient.ts +0 -24
  833. package/src/renderer/nodes/Container.tsx +0 -17
  834. package/src/renderer/nodes/Declaration.tsx +0 -65
  835. package/src/renderer/nodes/Drawing.tsx +0 -65
  836. package/src/renderer/nodes/Node.ts +0 -59
  837. package/src/renderer/nodes/index.ts +0 -4
  838. package/src/renderer/processors/Clips.ts +0 -23
  839. package/src/renderer/processors/Font.ts +0 -8
  840. package/src/renderer/processors/Paint.ts +0 -118
  841. package/src/renderer/processors/Transform.ts +0 -50
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["Shaders.ts"],"names":["processUniforms","FilterMode","MipmapMode","TileMode","JsiDeclarationNode","DeclarationType","NodeType","processColor","enumKey","fitRects","getRect","processGradientProps","processTransformProps","rect2rect","ShaderDeclaration","constructor","ctx","type","props","Shader","ShaderNode","materialize","source","uniforms","transform","m3","Skia","Matrix","makeShaderWithChildren","children","filter","child","isShader","map","ImageShaderNode","ImageShader","fit","image","tx","ty","fm","mm","imageShaderProps","rct","rects","x","y","width","height","src","dst","lm","makeShaderOptions","ColorNode","ColorShader","color","MakeColor","TurbulenceNode","Turbulence","freqX","freqY","octaves","seed","tileWidth","tileHeight","MakeTurbulence","FractalNoiseNode","FractalNoise","MakeFractalNoise","LinearGradientNode","LinearGradient","start","end","colors","positions","mode","localMatrix","flags","MakeLinearGradient","RadialGradientNode","RadialGradient","c","r","MakeRadialGradient","SweepGradientNode","SweepGradient","MakeSweepGradient","TwoPointConicalGradientNode","TwoPointConicalGradient","startR","endR","MakeTwoPointConicalGradient"],"mappings":"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","sourcesContent":["import {\n processUniforms,\n FilterMode,\n MipmapMode,\n TileMode,\n} from \"../../../skia/types\";\nimport type { SkShader } from \"../../../skia/types\";\nimport type { NodeContext } from \"../Node\";\nimport { JsiDeclarationNode } from \"../Node\";\nimport type {\n ColorProps,\n FractalNoiseProps,\n ImageShaderProps,\n LinearGradientProps,\n RadialGradientProps,\n ShaderProps,\n SweepGradientProps,\n TurbulenceProps,\n TwoPointConicalGradientProps,\n} from \"../../types\";\nimport { DeclarationType, NodeType } from \"../../types\";\nimport { processColor } from \"../datatypes/Color\";\nimport {\n enumKey,\n fitRects,\n getRect,\n processGradientProps,\n processTransformProps,\n rect2rect,\n} from \"../datatypes\";\n\nexport abstract class ShaderDeclaration<P> extends JsiDeclarationNode<\n P,\n SkShader\n> {\n constructor(ctx: NodeContext, type: NodeType, props: P) {\n super(ctx, DeclarationType.Shader, type, props);\n }\n}\n\nexport class ShaderNode extends ShaderDeclaration<ShaderProps> {\n constructor(ctx: NodeContext, props: ShaderProps) {\n super(ctx, NodeType.Shader, props);\n }\n\n materialize() {\n const { source, uniforms, ...transform } = this.props;\n const m3 = this.Skia.Matrix();\n processTransformProps(m3, transform);\n return source.makeShaderWithChildren(\n processUniforms(source, uniforms),\n this.children()\n .filter(\n (child): child is JsiDeclarationNode<unknown, SkShader> =>\n child instanceof JsiDeclarationNode && child.isShader()\n )\n .map((child) => child.materialize()),\n m3\n );\n }\n}\n\nexport class ImageShaderNode extends ShaderDeclaration<ImageShaderProps> {\n constructor(ctx: NodeContext, props: ImageShaderProps) {\n super(ctx, NodeType.ImageShader, props);\n }\n\n materialize() {\n const { fit, image, tx, ty, fm, mm, ...imageShaderProps } = this.props;\n const rct = getRect(this.Skia, imageShaderProps);\n if (rct) {\n const rects = fitRects(\n fit,\n { x: 0, y: 0, width: image.width(), height: image.height() },\n rct\n );\n const m3 = rect2rect(rects.src, rects.dst);\n imageShaderProps.transform = [\n ...(imageShaderProps.transform ?? []),\n ...m3,\n ];\n }\n const lm = this.Skia.Matrix();\n processTransformProps(lm, imageShaderProps);\n return image.makeShaderOptions(\n TileMode[enumKey(tx)],\n TileMode[enumKey(ty)],\n FilterMode[enumKey(fm)],\n MipmapMode[enumKey(mm)],\n lm\n );\n }\n}\n\nexport class ColorNode extends ShaderDeclaration<ColorProps> {\n constructor(ctx: NodeContext, props: ColorProps) {\n super(ctx, NodeType.ColorShader, props);\n }\n\n materialize() {\n const { color } = this.props;\n return this.Skia.Shader.MakeColor(processColor(this.Skia, color, 1));\n }\n}\n\nexport class TurbulenceNode extends ShaderDeclaration<TurbulenceProps> {\n constructor(ctx: NodeContext, props: TurbulenceProps) {\n super(ctx, NodeType.Turbulence, props);\n }\n\n materialize() {\n const { freqX, freqY, octaves, seed, tileWidth, tileHeight } = this.props;\n return this.Skia.Shader.MakeTurbulence(\n freqX,\n freqY,\n octaves,\n seed,\n tileWidth,\n tileHeight\n );\n }\n}\n\nexport class FractalNoiseNode extends ShaderDeclaration<FractalNoiseProps> {\n constructor(ctx: NodeContext, props: FractalNoiseProps) {\n super(ctx, NodeType.FractalNoise, props);\n }\n\n materialize() {\n const { freqX, freqY, octaves, seed, tileWidth, tileHeight } = this.props;\n return this.Skia.Shader.MakeFractalNoise(\n freqX,\n freqY,\n octaves,\n seed,\n tileWidth,\n tileHeight\n );\n }\n}\n\nexport class LinearGradientNode extends ShaderDeclaration<LinearGradientProps> {\n constructor(ctx: NodeContext, props: LinearGradientProps) {\n super(ctx, NodeType.LinearGradient, props);\n }\n\n materialize() {\n const { start, end } = this.props;\n const { colors, positions, mode, localMatrix, flags } =\n processGradientProps(this.Skia, this.props);\n return this.Skia.Shader.MakeLinearGradient(\n start,\n end,\n colors,\n positions ?? null,\n mode,\n localMatrix,\n flags\n );\n }\n}\n\nexport class RadialGradientNode extends ShaderDeclaration<RadialGradientProps> {\n constructor(ctx: NodeContext, props: RadialGradientProps) {\n super(ctx, NodeType.RadialGradient, props);\n }\n\n materialize() {\n const { c, r } = this.props;\n const { colors, positions, mode, localMatrix, flags } =\n processGradientProps(this.Skia, this.props);\n return this.Skia.Shader.MakeRadialGradient(\n c,\n r,\n colors,\n positions,\n mode,\n localMatrix,\n flags\n );\n }\n}\n\nexport class SweepGradientNode extends ShaderDeclaration<SweepGradientProps> {\n constructor(ctx: NodeContext, props: SweepGradientProps) {\n super(ctx, NodeType.SweepGradient, props);\n }\n\n materialize() {\n const { c, start, end } = this.props;\n const { colors, positions, mode, localMatrix, flags } =\n processGradientProps(this.Skia, this.props);\n return this.Skia.Shader.MakeSweepGradient(\n c.x,\n c.y,\n colors,\n positions,\n mode,\n localMatrix,\n flags,\n start,\n end\n );\n }\n}\n\nexport class TwoPointConicalGradientNode extends ShaderDeclaration<TwoPointConicalGradientProps> {\n constructor(ctx: NodeContext, props: TwoPointConicalGradientProps) {\n super(ctx, NodeType.TwoPointConicalGradient, props);\n }\n\n materialize() {\n const { startR, endR, start, end } = this.props;\n const { colors, positions, mode, localMatrix, flags } =\n processGradientProps(this.Skia, this.props);\n return this.Skia.Shader.MakeTwoPointConicalGradient(\n start,\n startR,\n end,\n endR,\n colors,\n positions,\n mode,\n localMatrix,\n flags\n );\n }\n}\n"]}
@@ -0,0 +1,7 @@
1
+ export * from "./Shaders";
2
+ export * from "./MaskFilters";
3
+ export * from "./ColorFilters";
4
+ export * from "./ImageFilters";
5
+ export * from "./PathEffects";
6
+ export * from "./BlendNode";
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAd;AACA,cAAc,eAAd;AACA,cAAc,gBAAd;AACA,cAAc,gBAAd;AACA,cAAc,eAAd;AACA,cAAc,aAAd","sourcesContent":["export * from \"./Shaders\";\nexport * from \"./MaskFilters\";\nexport * from \"./ColorFilters\";\nexport * from \"./ImageFilters\";\nexport * from \"./PathEffects\";\nexport * from \"./BlendNode\";\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ColorFilters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Common.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=DrawingContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Drawings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ImageFilters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=MaskFilters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Node.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,72 @@
1
+ export let NodeType;
2
+
3
+ (function (NodeType) {
4
+ NodeType["Shader"] = "skShader";
5
+ NodeType["ImageShader"] = "skImageShader";
6
+ NodeType["ColorShader"] = "skColorShader";
7
+ NodeType["Turbulence"] = "skTurbulence";
8
+ NodeType["FractalNoise"] = "skFractalNoise";
9
+ NodeType["LinearGradient"] = "skLinearGradient";
10
+ NodeType["RadialGradient"] = "skRadialGradient";
11
+ NodeType["SweepGradient"] = "skSweepGradient";
12
+ NodeType["TwoPointConicalGradient"] = "skTwoPointConicalGradient";
13
+ NodeType["BlurMaskFilter"] = "skBlurMaskFilter";
14
+ NodeType["DiscretePathEffect"] = "skDiscretePathEffect";
15
+ NodeType["DashPathEffect"] = "skDashPathEffect";
16
+ NodeType["Path1DPathEffect"] = "skPath1DPathEffect";
17
+ NodeType["Path2DPathEffect"] = "skPath2DPathEffect";
18
+ NodeType["CornerPathEffect"] = "skCornerPathEffect";
19
+ NodeType["SumPathEffect"] = "skSumPathEffect";
20
+ NodeType["Line2DPathEffect"] = "skLine2DPathEffect";
21
+ NodeType["MatrixColorFilter"] = "skMatrixColorFilter";
22
+ NodeType["BlendColorFilter"] = "skBlendColorFilter";
23
+ NodeType["LinearToSRGBGammaColorFilter"] = "skLinearToSRGBGammaColorFilter";
24
+ NodeType["SRGBToLinearGammaColorFilter"] = "skSRGBToLinearGammaColorFilter";
25
+ NodeType["LumaColorFilter"] = "skLumaColorFilter";
26
+ NodeType["LerpColorFilter"] = "skLerpColorFilter";
27
+ NodeType["OffsetImageFilter"] = "skOffsetImageFilter";
28
+ NodeType["DisplacementMapImageFilter"] = "skDisplacementMapImageFilter";
29
+ NodeType["BlurImageFilter"] = "skBlurImageFilter";
30
+ NodeType["DropShadowImageFilter"] = "skDropShadowImageFilter";
31
+ NodeType["MorphologyImageFilter"] = "skMorphologyImageFilter";
32
+ NodeType["BlendImageFilter"] = "skBlendImageFilter";
33
+ NodeType["RuntimeShaderImageFilter"] = "skRuntimeShaderImageFilter";
34
+ NodeType["Blend"] = "skBlend";
35
+ NodeType["BackdropFilter"] = "skBackdropFilter";
36
+ NodeType["Box"] = "skBox";
37
+ NodeType["BoxShadow"] = "skBoxShadow";
38
+ NodeType["Group"] = "skGroup";
39
+ NodeType["Drawing"] = "skDrawing";
40
+ NodeType["Paint"] = "skPaint";
41
+ NodeType["Circle"] = "skCircle";
42
+ NodeType["Fill"] = "skFill";
43
+ NodeType["Image"] = "skImage";
44
+ NodeType["Points"] = "skPoints";
45
+ NodeType["Path"] = "skPath";
46
+ NodeType["Rect"] = "skRect";
47
+ NodeType["RRect"] = "skRRect";
48
+ NodeType["Oval"] = "skOval";
49
+ NodeType["Line"] = "skLine";
50
+ NodeType["Patch"] = "skPatch";
51
+ NodeType["Vertices"] = "skVertices";
52
+ NodeType["DiffRect"] = "skDiffRect";
53
+ NodeType["Text"] = "skText";
54
+ NodeType["TextPath"] = "skTextPath";
55
+ NodeType["TextBlob"] = "skTextBlob";
56
+ NodeType["Glyphs"] = "skGlyphs";
57
+ NodeType["Picture"] = "skPicture";
58
+ NodeType["ImageSVG"] = "skImageSVG";
59
+ })(NodeType || (NodeType = {}));
60
+
61
+ export let DeclarationType;
62
+
63
+ (function (DeclarationType) {
64
+ DeclarationType[DeclarationType["Paint"] = 0] = "Paint";
65
+ DeclarationType[DeclarationType["Shader"] = 1] = "Shader";
66
+ DeclarationType[DeclarationType["ImageFilter"] = 2] = "ImageFilter";
67
+ DeclarationType[DeclarationType["ColorFilter"] = 3] = "ColorFilter";
68
+ DeclarationType[DeclarationType["PathEffect"] = 4] = "PathEffect";
69
+ DeclarationType[DeclarationType["MaskFilter"] = 5] = "MaskFilter";
70
+ DeclarationType[DeclarationType["Unknown"] = 6] = "Unknown";
71
+ })(DeclarationType || (DeclarationType = {}));
72
+ //# sourceMappingURL=NodeType.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["NodeType.ts"],"names":["NodeType","DeclarationType"],"mappings":"AAAA,WAAkBA,QAAlB;;WAAkBA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;AAAAA,EAAAA,Q;GAAAA,Q,KAAAA,Q;;AAuElB,WAAkBC,eAAlB;;WAAkBA,e;AAAAA,EAAAA,e,CAAAA,e;AAAAA,EAAAA,e,CAAAA,e;AAAAA,EAAAA,e,CAAAA,e;AAAAA,EAAAA,e,CAAAA,e;AAAAA,EAAAA,e,CAAAA,e;AAAAA,EAAAA,e,CAAAA,e;AAAAA,EAAAA,e,CAAAA,e;GAAAA,e,KAAAA,e","sourcesContent":["export const enum NodeType {\n // Shaders\n Shader = \"skShader\",\n ImageShader = \"skImageShader\",\n ColorShader = \"skColorShader\",\n Turbulence = \"skTurbulence\",\n FractalNoise = \"skFractalNoise\",\n LinearGradient = \"skLinearGradient\",\n RadialGradient = \"skRadialGradient\",\n SweepGradient = \"skSweepGradient\",\n TwoPointConicalGradient = \"skTwoPointConicalGradient\",\n\n // Mask Filters\n BlurMaskFilter = \"skBlurMaskFilter\",\n\n // Path Effects\n DiscretePathEffect = \"skDiscretePathEffect\",\n DashPathEffect = \"skDashPathEffect\",\n Path1DPathEffect = \"skPath1DPathEffect\",\n Path2DPathEffect = \"skPath2DPathEffect\",\n CornerPathEffect = \"skCornerPathEffect\",\n SumPathEffect = \"skSumPathEffect\",\n Line2DPathEffect = \"skLine2DPathEffect\",\n\n // Color Filters\n MatrixColorFilter = \"skMatrixColorFilter\",\n BlendColorFilter = \"skBlendColorFilter\",\n LinearToSRGBGammaColorFilter = \"skLinearToSRGBGammaColorFilter\",\n SRGBToLinearGammaColorFilter = \"skSRGBToLinearGammaColorFilter\",\n LumaColorFilter = \"skLumaColorFilter\",\n LerpColorFilter = \"skLerpColorFilter\",\n\n // Image Filters\n OffsetImageFilter = \"skOffsetImageFilter\",\n DisplacementMapImageFilter = \"skDisplacementMapImageFilter\",\n BlurImageFilter = \"skBlurImageFilter\",\n DropShadowImageFilter = \"skDropShadowImageFilter\",\n MorphologyImageFilter = \"skMorphologyImageFilter\",\n BlendImageFilter = \"skBlendImageFilter\",\n RuntimeShaderImageFilter = \"skRuntimeShaderImageFilter\",\n\n // Mixed\n Blend = \"skBlend\",\n BackdropFilter = \"skBackdropFilter\",\n Box = \"skBox\",\n BoxShadow = \"skBoxShadow\",\n\n // Drawings\n Group = \"skGroup\",\n Drawing = \"skDrawing\",\n Paint = \"skPaint\",\n Circle = \"skCircle\",\n Fill = \"skFill\",\n Image = \"skImage\",\n Points = \"skPoints\",\n Path = \"skPath\",\n Rect = \"skRect\",\n RRect = \"skRRect\",\n Oval = \"skOval\",\n Line = \"skLine\",\n Patch = \"skPatch\",\n Vertices = \"skVertices\",\n DiffRect = \"skDiffRect\",\n Text = \"skText\",\n TextPath = \"skTextPath\",\n TextBlob = \"skTextBlob\",\n Glyphs = \"skGlyphs\",\n Picture = \"skPicture\",\n ImageSVG = \"skImageSVG\",\n}\n\nexport const enum DeclarationType {\n Paint,\n Shader,\n ImageFilter,\n ColorFilter,\n PathEffect,\n MaskFilter,\n Unknown,\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=PathEffects.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Shaders.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=SkDOM.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
@@ -0,0 +1,12 @@
1
+ export * from "./DrawingContext";
2
+ export * from "./Node";
3
+ export * from "./NodeType";
4
+ export * from "./SkDOM";
5
+ export * from "./Common";
6
+ export * from "./Drawings";
7
+ export * from "./ImageFilters";
8
+ export * from "./ColorFilters";
9
+ export * from "./MaskFilters";
10
+ export * from "./PathEffects";
11
+ export * from "./Shaders";
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAd;AACA,cAAc,QAAd;AACA,cAAc,YAAd;AACA,cAAc,SAAd;AACA,cAAc,UAAd;AACA,cAAc,YAAd;AACA,cAAc,gBAAd;AACA,cAAc,gBAAd;AACA,cAAc,eAAd;AACA,cAAc,eAAd;AACA,cAAc,WAAd","sourcesContent":["export * from \"./DrawingContext\";\nexport * from \"./Node\";\nexport * from \"./NodeType\";\nexport * from \"./SkDOM\";\nexport * from \"./Common\";\nexport * from \"./Drawings\";\nexport * from \"./ImageFilters\";\nexport * from \"./ColorFilters\";\nexport * from \"./MaskFilters\";\nexport * from \"./PathEffects\";\nexport * from \"./Shaders\";\n"]}
@@ -6,4 +6,6 @@ export * from "./skia";
6
6
  export * from "./external";
7
7
  export * from "./values";
8
8
  export * from "./animation";
9
+ export * from "./dom/types";
10
+ export * from "./dom/nodes";
9
11
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,oBAAP;AACA,cAAc,YAAd;AACA,cAAc,mBAAd;AACA,cAAc,SAAd;AACA,cAAc,QAAd;AACA,cAAc,YAAd;AACA,cAAc,UAAd;AACA,cAAc,aAAd","sourcesContent":["import \"./skia/NativeSetup\";\nexport * from \"./renderer\";\nexport * from \"./renderer/Canvas\";\nexport * from \"./views\";\nexport * from \"./skia\";\nexport * from \"./external\";\nexport * from \"./values\";\nexport * from \"./animation\";\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,oBAAP;AACA,cAAc,YAAd;AACA,cAAc,mBAAd;AACA,cAAc,SAAd;AACA,cAAc,QAAd;AACA,cAAc,YAAd;AACA,cAAc,UAAd;AACA,cAAc,aAAd;AACA,cAAc,aAAd;AACA,cAAc,aAAd","sourcesContent":["import \"./skia/NativeSetup\";\nexport * from \"./renderer\";\nexport * from \"./renderer/Canvas\";\nexport * from \"./views\";\nexport * from \"./skia\";\nexport * from \"./external\";\nexport * from \"./values\";\nexport * from \"./animation\";\nexport * from \"./dom/types\";\nexport * from \"./dom/nodes\";\n"]}
@@ -5,7 +5,7 @@ import { useValue } from "../values/hooks/useValue";
5
5
  import { Skia } from "../skia/Skia";
6
6
  import { debug as hostDebug, skHostConfig } from "./HostConfig"; // import { debugTree } from "./nodes";
7
7
 
8
- import { Container } from "./nodes";
8
+ import { Container } from "./Container";
9
9
  import { DependencyManager } from "./DependencyManager";
10
10
  import { CanvasProvider } from "./useCanvas";
11
11
  export const skiaReconciler = ReactReconciler(skHostConfig);
@@ -42,7 +42,9 @@ export const Canvas = /*#__PURE__*/forwardRef((_ref, forwardedRef) => {
42
42
  const innerRef = useCanvasRef();
43
43
  const ref = useCombinedRefs(forwardedRef, innerRef);
44
44
  const [tick, setTick] = useState(0);
45
- const redraw = useCallback(() => setTick(t => t + 1), []);
45
+ const redraw = useCallback(() => {
46
+ setTick(t => t + 1);
47
+ }, []);
46
48
  const registerValues = useCallback(values => {
47
49
  if (ref.current === null) {
48
50
  throw new Error("Canvas ref is not set");
@@ -50,7 +52,9 @@ export const Canvas = /*#__PURE__*/forwardRef((_ref, forwardedRef) => {
50
52
 
51
53
  return ref.current.registerValues(values);
52
54
  }, [ref]);
53
- const container = useMemo(() => new Container(new DependencyManager(registerValues), redraw), [redraw, registerValues]);
55
+ const container = useMemo(() => {
56
+ return new Container(Skia, new DependencyManager(registerValues), redraw);
57
+ }, [redraw, registerValues]);
54
58
  const root = useMemo(() => skiaReconciler.createContainer(container, 0, false, null), [container]); // Render effect
55
59
 
56
60
  useEffect(() => {
@@ -1 +1 @@
1
- {"version":3,"sources":["Canvas.tsx"],"names":["React","useEffect","useState","useCallback","useMemo","forwardRef","useRef","ReactReconciler","SkiaView","useDrawCallback","useValue","Skia","debug","hostDebug","skHostConfig","Container","DependencyManager","CanvasProvider","skiaReconciler","injectIntoDevTools","bundleType","version","rendererPackageName","render","element","root","container","updateContainer","depMgr","update","useCanvasRef","Canvas","forwardedRef","children","style","mode","onTouch","size","width","height","canvasCtx","innerRef","ref","useCombinedRefs","tick","setTick","redraw","t","registerValues","values","current","Error","createContainer","paint","Paint","onDraw","canvas","info","timestamp","touches","reset","ctx","opacity","center","x","y","draw","remove","refs","targetRef","forEach"],"mappings":"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","sourcesContent":["import React, {\n useEffect,\n useState,\n useCallback,\n useMemo,\n forwardRef,\n useRef,\n} from \"react\";\nimport type {\n RefObject,\n ReactNode,\n ComponentProps,\n MutableRefObject,\n ForwardedRef,\n} from \"react\";\nimport type { OpaqueRoot } from \"react-reconciler\";\nimport ReactReconciler from \"react-reconciler\";\n\nimport { SkiaView, useDrawCallback } from \"../views\";\nimport type { TouchHandler } from \"../views\";\nimport { useValue } from \"../values/hooks/useValue\";\nimport { Skia } from \"../skia/Skia\";\nimport type { SkiaValue } from \"../values\";\n\nimport { debug as hostDebug, skHostConfig } from \"./HostConfig\";\n// import { debugTree } from \"./nodes\";\nimport { Container } from \"./nodes\";\nimport { DependencyManager } from \"./DependencyManager\";\nimport { CanvasProvider } from \"./useCanvas\";\n\nexport const skiaReconciler = ReactReconciler(skHostConfig);\n\nskiaReconciler.injectIntoDevTools({\n bundleType: 1,\n version: \"0.0.1\",\n rendererPackageName: \"react-native-skia\",\n});\n\nconst render = (element: ReactNode, root: OpaqueRoot, container: Container) => {\n skiaReconciler.updateContainer(element, root, null, () => {\n hostDebug(\"updateContainer\");\n container.depMgr.update();\n });\n};\n\nexport const useCanvasRef = () => useRef<SkiaView>(null);\n\nexport interface CanvasProps extends ComponentProps<typeof SkiaView> {\n ref?: RefObject<SkiaView>;\n children: ReactNode;\n onTouch?: TouchHandler;\n}\n\nexport const Canvas = forwardRef<SkiaView, CanvasProps>(\n ({ children, style, debug, mode, onTouch }, forwardedRef) => {\n const size = useValue({ width: 0, height: 0 });\n const canvasCtx = useMemo(() => ({ Skia, size }), [size]);\n const innerRef = useCanvasRef();\n const ref = useCombinedRefs(forwardedRef, innerRef);\n const [tick, setTick] = useState(0);\n const redraw = useCallback(() => setTick((t) => t + 1), []);\n\n const registerValues = useCallback(\n (values: Array<SkiaValue<unknown>>) => {\n if (ref.current === null) {\n throw new Error(\"Canvas ref is not set\");\n }\n return ref.current.registerValues(values);\n },\n [ref]\n );\n\n const container = useMemo(\n () => new Container(new DependencyManager(registerValues), redraw),\n [redraw, registerValues]\n );\n\n const root = useMemo(\n () => skiaReconciler.createContainer(container, 0, false, null),\n [container]\n );\n // Render effect\n useEffect(() => {\n render(\n <CanvasProvider value={canvasCtx}>{children}</CanvasProvider>,\n root,\n container\n );\n }, [children, root, redraw, container, canvasCtx]);\n\n const paint = useMemo(() => Skia.Paint(), []);\n\n // Draw callback\n const onDraw = useDrawCallback(\n (canvas, info) => {\n // TODO: if tree is empty (count === 1) maybe we should not render?\n const { width, height, timestamp } = info;\n if (onTouch) {\n onTouch(info.touches);\n }\n if (\n width !== canvasCtx.size.current.width ||\n height !== canvasCtx.size.current.height\n ) {\n canvasCtx.size.current = { width, height };\n }\n paint.reset();\n const ctx = {\n width,\n height,\n timestamp,\n canvas,\n paint,\n opacity: 1,\n ref,\n center: { x: width / 2, y: height / 2 },\n Skia,\n };\n container.draw(ctx);\n },\n [tick, onTouch]\n );\n\n useEffect(() => {\n return () => {\n skiaReconciler.updateContainer(null, root, null, () => {\n container.depMgr.remove();\n });\n };\n }, [container, root]);\n\n return (\n <SkiaView\n ref={ref}\n style={style}\n onDraw={onDraw}\n mode={mode}\n debug={debug}\n />\n );\n }\n);\n\n/**\n * Combines a list of refs into a single ref. This can be used to provide\n * both a forwarded ref and an internal ref keeping the same functionality\n * on both of the refs.\n * @param refs Array of refs to combine\n * @returns A single ref that can be used in a ref prop.\n */\nconst useCombinedRefs = <T,>(\n ...refs: Array<MutableRefObject<T> | ForwardedRef<T>>\n) => {\n const targetRef = React.useRef<T>(null);\n React.useEffect(() => {\n refs.forEach((ref) => {\n if (ref) {\n if (typeof ref === \"function\") {\n ref(targetRef.current);\n } else {\n ref.current = targetRef.current;\n }\n }\n });\n }, [refs]);\n return targetRef;\n};\n"]}
1
+ {"version":3,"sources":["Canvas.tsx"],"names":["React","useEffect","useState","useCallback","useMemo","forwardRef","useRef","ReactReconciler","SkiaView","useDrawCallback","useValue","Skia","debug","hostDebug","skHostConfig","Container","DependencyManager","CanvasProvider","skiaReconciler","injectIntoDevTools","bundleType","version","rendererPackageName","render","element","root","container","updateContainer","depMgr","update","useCanvasRef","Canvas","forwardedRef","children","style","mode","onTouch","size","width","height","canvasCtx","innerRef","ref","useCombinedRefs","tick","setTick","redraw","t","registerValues","values","current","Error","createContainer","paint","Paint","onDraw","canvas","info","timestamp","touches","reset","ctx","opacity","center","x","y","draw","remove","refs","targetRef","forEach"],"mappings":"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","sourcesContent":["import React, {\n useEffect,\n useState,\n useCallback,\n useMemo,\n forwardRef,\n useRef,\n} from \"react\";\nimport type {\n RefObject,\n ReactNode,\n ComponentProps,\n MutableRefObject,\n ForwardedRef,\n} from \"react\";\nimport type { OpaqueRoot } from \"react-reconciler\";\nimport ReactReconciler from \"react-reconciler\";\n\nimport { SkiaView, useDrawCallback } from \"../views\";\nimport type { TouchHandler } from \"../views\";\nimport { useValue } from \"../values/hooks/useValue\";\nimport { Skia } from \"../skia/Skia\";\nimport type { SkiaValue } from \"../values\";\n\nimport { debug as hostDebug, skHostConfig } from \"./HostConfig\";\n// import { debugTree } from \"./nodes\";\nimport { Container } from \"./Container\";\nimport { DependencyManager } from \"./DependencyManager\";\nimport { CanvasProvider } from \"./useCanvas\";\n\nexport const skiaReconciler = ReactReconciler(skHostConfig);\n\nskiaReconciler.injectIntoDevTools({\n bundleType: 1,\n version: \"0.0.1\",\n rendererPackageName: \"react-native-skia\",\n});\n\nconst render = (element: ReactNode, root: OpaqueRoot, container: Container) => {\n skiaReconciler.updateContainer(element, root, null, () => {\n hostDebug(\"updateContainer\");\n container.depMgr.update();\n });\n};\n\nexport const useCanvasRef = () => useRef<SkiaView>(null);\n\nexport interface CanvasProps extends ComponentProps<typeof SkiaView> {\n ref?: RefObject<SkiaView>;\n children: ReactNode;\n onTouch?: TouchHandler;\n}\n\nexport const Canvas = forwardRef<SkiaView, CanvasProps>(\n ({ children, style, debug, mode, onTouch }, forwardedRef) => {\n const size = useValue({ width: 0, height: 0 });\n const canvasCtx = useMemo(() => ({ Skia, size }), [size]);\n const innerRef = useCanvasRef();\n const ref = useCombinedRefs(forwardedRef, innerRef);\n const [tick, setTick] = useState(0);\n const redraw = useCallback(() => {\n setTick((t) => t + 1);\n }, []);\n\n const registerValues = useCallback(\n (values: Array<SkiaValue<unknown>>) => {\n if (ref.current === null) {\n throw new Error(\"Canvas ref is not set\");\n }\n return ref.current.registerValues(values);\n },\n [ref]\n );\n\n const container = useMemo(() => {\n return new Container(Skia, new DependencyManager(registerValues), redraw);\n }, [redraw, registerValues]);\n\n const root = useMemo(\n () => skiaReconciler.createContainer(container, 0, false, null),\n [container]\n );\n // Render effect\n useEffect(() => {\n render(\n <CanvasProvider value={canvasCtx}>{children}</CanvasProvider>,\n root,\n container\n );\n }, [children, root, redraw, container, canvasCtx]);\n\n const paint = useMemo(() => Skia.Paint(), []);\n\n // Draw callback\n const onDraw = useDrawCallback(\n (canvas, info) => {\n // TODO: if tree is empty (count === 1) maybe we should not render?\n const { width, height, timestamp } = info;\n if (onTouch) {\n onTouch(info.touches);\n }\n if (\n width !== canvasCtx.size.current.width ||\n height !== canvasCtx.size.current.height\n ) {\n canvasCtx.size.current = { width, height };\n }\n paint.reset();\n const ctx = {\n width,\n height,\n timestamp,\n canvas,\n paint,\n opacity: 1,\n ref,\n center: { x: width / 2, y: height / 2 },\n Skia,\n };\n container.draw(ctx);\n },\n [tick, onTouch]\n );\n\n useEffect(() => {\n return () => {\n skiaReconciler.updateContainer(null, root, null, () => {\n container.depMgr.remove();\n });\n };\n }, [container, root]);\n\n return (\n <SkiaView\n ref={ref}\n style={style}\n onDraw={onDraw}\n mode={mode}\n debug={debug}\n />\n );\n }\n);\n\n/**\n * Combines a list of refs into a single ref. This can be used to provide\n * both a forwarded ref and an internal ref keeping the same functionality\n * on both of the refs.\n * @param refs Array of refs to combine\n * @returns A single ref that can be used in a ref prop.\n */\nconst useCombinedRefs = <T,>(\n ...refs: Array<MutableRefObject<T> | ForwardedRef<T>>\n) => {\n const targetRef = React.useRef<T>(null);\n React.useEffect(() => {\n refs.forEach((ref) => {\n if (ref) {\n if (typeof ref === \"function\") {\n ref(targetRef.current);\n } else {\n ref.current = targetRef.current;\n }\n }\n });\n }, [refs]);\n return targetRef;\n};\n"]}
@@ -0,0 +1,29 @@
1
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
+
3
+ import { JsiSkDOM } from "../dom/nodes";
4
+ export class Container {
5
+ constructor(Skia, depMgr, redraw) {
6
+ this.depMgr = depMgr;
7
+ this.redraw = redraw;
8
+
9
+ _defineProperty(this, "_root", void 0);
10
+
11
+ _defineProperty(this, "Sk", void 0);
12
+
13
+ this.Sk = new JsiSkDOM({
14
+ Skia,
15
+ depMgr
16
+ });
17
+ this._root = this.Sk.Group();
18
+ }
19
+
20
+ draw(ctx) {
21
+ this._root.render(ctx);
22
+ }
23
+
24
+ get root() {
25
+ return this._root;
26
+ }
27
+
28
+ }
29
+ //# sourceMappingURL=Container.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["Container.tsx"],"names":["JsiSkDOM","Container","constructor","Skia","depMgr","redraw","Sk","_root","Group","draw","ctx","render","root"],"mappings":";;AAAA,SAASA,QAAT,QAAyB,cAAzB;AAWA,OAAO,MAAMC,SAAN,CAAgB;AAGrBC,EAAAA,WAAW,CACTC,IADS,EAEFC,MAFE,EAGFC,MAHE,EAIT;AAAA,SAFOD,MAEP,GAFOA,MAEP;AAAA,SADOC,MACP,GADOA,MACP;;AAAA;;AAAA;;AACA,SAAKC,EAAL,GAAU,IAAIN,QAAJ,CAAa;AAAEG,MAAAA,IAAF;AAAQC,MAAAA;AAAR,KAAb,CAAV;AACA,SAAKG,KAAL,GAAa,KAAKD,EAAL,CAAQE,KAAR,EAAb;AACD;;AAEDC,EAAAA,IAAI,CAACC,GAAD,EAAsB;AACxB,SAAKH,KAAL,CAAWI,MAAX,CAAkBD,GAAlB;AACD;;AAEO,MAAJE,IAAI,GAAG;AACT,WAAO,KAAKL,KAAZ;AACD;;AAlBoB","sourcesContent":["import { JsiSkDOM } from \"../dom/nodes\";\nimport type {\n GroupProps,\n DrawingContext,\n RenderNode,\n SkDOM,\n} from \"../dom/types\";\nimport type { Skia } from \"../skia/types\";\n\nimport type { DependencyManager } from \"./DependencyManager\";\n\nexport class Container {\n private _root: RenderNode<GroupProps>;\n public Sk: SkDOM;\n constructor(\n Skia: Skia,\n public depMgr: DependencyManager,\n public redraw: () => void\n ) {\n this.Sk = new JsiSkDOM({ Skia, depMgr });\n this._root = this.Sk.Group();\n }\n\n draw(ctx: DrawingContext) {\n this._root.render(ctx);\n }\n\n get root() {\n return this._root;\n }\n}\n"]}
@@ -12,6 +12,10 @@ export class DependencyManager {
12
12
 
13
13
  this.registerValues = registerValues;
14
14
  }
15
+
16
+ unsubscribeNodes(nodes) {
17
+ nodes.forEach(n => this.unsubscribeNode(n));
18
+ }
15
19
  /**
16
20
  * Call to unsubscribe all value listeners from the given node based
17
21
  * on the current list of subscriptions for the node. This function
@@ -139,27 +143,35 @@ export class DependencyManager {
139
143
  const initializePropertySubscriptions = (node, props) => {
140
144
  const nodePropSubscriptions = [];
141
145
  mapKeys(props).forEach(key => {
146
+ if (key === "children") {
147
+ return;
148
+ }
149
+
142
150
  const propvalue = props[key];
143
151
 
144
152
  if (isValue(propvalue)) {
145
153
  // Subscribe to changes
146
154
  nodePropSubscriptions.push({
147
155
  value: propvalue,
148
- mutator: v => node.resolvedProps[key] = v
156
+ mutator: v => {
157
+ node.setProp(key, v);
158
+ }
149
159
  }); // Set initial value
150
160
 
151
- node.resolvedProps[key] = propvalue.current;
161
+ node.setProp(key, propvalue.current);
152
162
  } else if (isSelector(propvalue)) {
153
163
  // Subscribe to changes
154
164
  nodePropSubscriptions.push({
155
165
  value: propvalue.value,
156
- mutator: v => node.resolvedProps[key] = propvalue.selector(v)
166
+ mutator: v => {
167
+ node.setProp(key, propvalue.selector(v));
168
+ }
157
169
  }); // Set initial value
158
170
 
159
- node.resolvedProps[key] = propvalue.selector(propvalue.value.current);
171
+ node.setProp(key, propvalue.selector(propvalue.value.current));
160
172
  } else {
161
173
  // Set initial value
162
- node.resolvedProps[key] = propvalue;
174
+ node.setProp(key, propvalue);
163
175
  }
164
176
  });
165
177
  return nodePropSubscriptions;
@@ -1 +1 @@
1
- {"version":3,"sources":["DependencyManager.tsx"],"names":["isSelector","isValue","mapKeys","DependencyManager","constructor","registerValues","Map","unsubscribeNode","node","subscriptions","Array","from","values","filter","p","nodes","has","forEach","si","delete","size","unsubscribe","Error","element","entries","find","_","sub","subscribeNode","props","propSubscriptions","initializePropertySubscriptions","length","ps","subscriptionState","get","value","addListener","v","mutators","m","set","map","mutator","update","unregisterDependantValues","keys","remove","clear","nodePropSubscriptions","key","propvalue","push","resolvedProps","current","selector"],"mappings":"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","sourcesContent":["import type { SkiaValue } from \"../values\";\n\nimport type { Node } from \"./nodes\";\nimport type { AnimatedProps } from \"./processors\";\nimport { isSelector, isValue } from \"./processors\";\nimport { mapKeys } from \"./typeddash\";\n\ntype Unsubscribe = () => void;\ntype Mutator = (value: unknown) => void;\n\ntype SubscriptionState = {\n nodes: Map<Node, Mutator[]>;\n unsubscribe: null | Unsubscribe;\n};\n\nexport class DependencyManager {\n registerValues: (values: Array<SkiaValue<unknown>>) => () => void;\n subscriptions: Map<SkiaValue<unknown>, SubscriptionState> = new Map();\n unregisterDependantValues: null | Unsubscribe = null;\n\n constructor(\n registerValues: (values: Array<SkiaValue<unknown>>) => () => void\n ) {\n this.registerValues = registerValues;\n }\n\n /**\n * Call to unsubscribe all value listeners from the given node based\n * on the current list of subscriptions for the node. This function\n * is typically called when the node is unmounted or when one or more\n * properties have changed.\n * @param node Node to unsubscribe value listeners from\n */\n unsubscribeNode(node: Node) {\n const subscriptions = Array.from(this.subscriptions.values()).filter((p) =>\n p.nodes.has(node)\n );\n\n if (subscriptions) {\n subscriptions.forEach((si) => {\n // Delete node from subscription\n si.nodes.delete(node);\n\n // Remove subscription if there are no listeneres left on the value\n if (si.nodes.size === 0) {\n // There are no more nodes subscribing to this value, we can call\n // unsubscribe on it.\n if (!si.unsubscribe) {\n throw new Error(\"Failed to unsubscribe to value subscription\");\n }\n si.unsubscribe && si.unsubscribe();\n\n // Remove from subscription states as well\n const element = Array.from(this.subscriptions.entries()).find(\n ([_, sub]) => sub === si\n );\n if (!element) {\n throw new Error(\"Failed to find value subscription\");\n }\n if (!this.subscriptions.delete(element[0])) {\n throw new Error(\"Failed to delete value subscription\");\n }\n }\n });\n }\n }\n\n /**\n * Adds listeners to the provided values so that the node is notified\n * when a value changes. This is done in an optimized way so that this\n * class only needs to listen to the value once and then forwards the\n * change to the node and its listener. This method is typically called\n * when the node is mounted and when one or more props on the node changes.\n * @param node Node to subscribe to value changes for\n * @param props Node's properties\n * @param onResolveProp Callback when a property value changes\n */\n subscribeNode<P extends Record<string, unknown>>(\n node: Node,\n props: AnimatedProps<P>\n ) {\n // Get mutators from node's properties\n const propSubscriptions = initializePropertySubscriptions(node, props);\n if (propSubscriptions.length === 0) {\n return;\n }\n\n // Install all mutators for the node\n propSubscriptions.forEach((ps) => {\n // Do we already have a state for this SkiaValue\n let subscriptionState = this.subscriptions.get(ps.value);\n if (!subscriptionState) {\n // Let's create a new subscription state for the skia value\n subscriptionState = {\n nodes: new Map(),\n unsubscribe: null,\n };\n // Add single subscription to the new value\n subscriptionState.unsubscribe = ps.value.addListener((v) => {\n subscriptionState!.nodes.forEach((mutators) =>\n mutators.forEach((m) => m(v))\n );\n });\n this.subscriptions.set(ps.value, subscriptionState);\n }\n // subscription mutators\n subscriptionState.nodes.set(\n node,\n propSubscriptions\n .filter((m) => m.value === ps.value)\n .map((m) => m.mutator)\n );\n });\n }\n\n /**\n * Called when the hosting container is mounted or updated. This ensures that we have\n * a ref to the underlying SkiaView so that we can registers redraw listeners\n * on values used in the current View automatically.\n */\n update() {\n // Remove any previous registrations\n if (this.unregisterDependantValues) {\n this.unregisterDependantValues();\n }\n\n // Register redraw requests on the SkiaView for each unique value\n this.unregisterDependantValues = this.registerValues(\n Array.from(this.subscriptions.keys())\n );\n }\n\n /**\n * Called when the hosting container is unmounted or recreated. This ensures that we remove\n * all subscriptions to Skia values so that we don't have any listeners left after\n * the component is removed.\n */\n remove() {\n // 1) Unregister redraw requests\n if (this.unregisterDependantValues) {\n this.unregisterDependantValues();\n this.unregisterDependantValues = null;\n }\n\n // 2) Unregister nodes\n Array.from(this.subscriptions.values()).forEach((si) => {\n Array.from(si.nodes.keys()).forEach((node) => this.unsubscribeNode(node));\n });\n\n // 3) Clear the rest of the subscriptions\n this.subscriptions.clear();\n }\n}\n\nconst initializePropertySubscriptions = <P,>(\n node: Node<P>,\n props: AnimatedProps<P>\n) => {\n const nodePropSubscriptions: Array<{\n value: SkiaValue<unknown>;\n mutator: Mutator;\n }> = [];\n\n mapKeys(props).forEach((key) => {\n const propvalue = props[key];\n\n if (isValue(propvalue)) {\n // Subscribe to changes\n nodePropSubscriptions.push({\n value: propvalue,\n mutator: (v) => (node.resolvedProps[key] = v as P[typeof key]),\n });\n // Set initial value\n node.resolvedProps[key] = (propvalue as SkiaValue<P[typeof key]>).current;\n } else if (isSelector(propvalue)) {\n // Subscribe to changes\n nodePropSubscriptions.push({\n value: propvalue.value,\n mutator: (v) =>\n (node.resolvedProps[key] = propvalue.selector(v) as P[typeof key]),\n });\n // Set initial value\n node.resolvedProps[key] = propvalue.selector(\n propvalue.value.current\n ) as P[typeof key];\n } else {\n // Set initial value\n node.resolvedProps[key] = propvalue as P[typeof key];\n }\n });\n\n return nodePropSubscriptions;\n};\n"]}
1
+ {"version":3,"sources":["DependencyManager.tsx"],"names":["isSelector","isValue","mapKeys","DependencyManager","constructor","registerValues","Map","unsubscribeNodes","nodes","forEach","n","unsubscribeNode","node","subscriptions","Array","from","values","filter","p","has","si","delete","size","unsubscribe","Error","element","entries","find","_","sub","subscribeNode","props","propSubscriptions","initializePropertySubscriptions","length","ps","subscriptionState","get","value","addListener","v","mutators","m","set","map","mutator","update","unregisterDependantValues","keys","remove","clear","nodePropSubscriptions","key","propvalue","push","setProp","current","selector"],"mappings":"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","sourcesContent":["import type { Node } from \"../dom/types\";\nimport type { SkiaValue } from \"../values\";\n\nimport type { AnimatedProps } from \"./processors\";\nimport { isSelector, isValue } from \"./processors\";\nimport { mapKeys } from \"./typeddash\";\n\ntype Unsubscribe = () => void;\ntype Mutator = (value: unknown) => void;\n\ntype SubscriptionState = {\n nodes: Map<Node<unknown>, Mutator[]>;\n unsubscribe: null | Unsubscribe;\n};\n\nexport class DependencyManager {\n registerValues: (values: Array<SkiaValue<unknown>>) => () => void;\n subscriptions: Map<SkiaValue<unknown>, SubscriptionState> = new Map();\n unregisterDependantValues: null | Unsubscribe = null;\n\n constructor(\n registerValues: (values: Array<SkiaValue<unknown>>) => () => void\n ) {\n this.registerValues = registerValues;\n }\n\n unsubscribeNodes(nodes: Node<unknown>[]) {\n nodes.forEach((n) => this.unsubscribeNode(n));\n }\n\n /**\n * Call to unsubscribe all value listeners from the given node based\n * on the current list of subscriptions for the node. This function\n * is typically called when the node is unmounted or when one or more\n * properties have changed.\n * @param node Node to unsubscribe value listeners from\n */\n unsubscribeNode(node: Node<unknown>) {\n const subscriptions = Array.from(this.subscriptions.values()).filter((p) =>\n p.nodes.has(node)\n );\n\n if (subscriptions) {\n subscriptions.forEach((si) => {\n // Delete node from subscription\n si.nodes.delete(node);\n\n // Remove subscription if there are no listeneres left on the value\n if (si.nodes.size === 0) {\n // There are no more nodes subscribing to this value, we can call\n // unsubscribe on it.\n if (!si.unsubscribe) {\n throw new Error(\"Failed to unsubscribe to value subscription\");\n }\n si.unsubscribe && si.unsubscribe();\n\n // Remove from subscription states as well\n const element = Array.from(this.subscriptions.entries()).find(\n ([_, sub]) => sub === si\n );\n if (!element) {\n throw new Error(\"Failed to find value subscription\");\n }\n if (!this.subscriptions.delete(element[0])) {\n throw new Error(\"Failed to delete value subscription\");\n }\n }\n });\n }\n }\n\n /**\n * Adds listeners to the provided values so that the node is notified\n * when a value changes. This is done in an optimized way so that this\n * class only needs to listen to the value once and then forwards the\n * change to the node and its listener. This method is typically called\n * when the node is mounted and when one or more props on the node changes.\n * @param node Node to subscribe to value changes for\n * @param props Node's properties\n * @param onResolveProp Callback when a property value changes\n */\n subscribeNode<P>(node: Node<unknown>, props: AnimatedProps<P>) {\n // Get mutators from node's properties\n const propSubscriptions = initializePropertySubscriptions(node, props);\n if (propSubscriptions.length === 0) {\n return;\n }\n\n // Install all mutators for the node\n propSubscriptions.forEach((ps) => {\n // Do we already have a state for this SkiaValue\n let subscriptionState = this.subscriptions.get(ps.value);\n if (!subscriptionState) {\n // Let's create a new subscription state for the skia value\n subscriptionState = {\n nodes: new Map(),\n unsubscribe: null,\n };\n // Add single subscription to the new value\n subscriptionState.unsubscribe = ps.value.addListener((v) => {\n subscriptionState!.nodes.forEach((mutators) =>\n mutators.forEach((m) => m(v))\n );\n });\n this.subscriptions.set(ps.value, subscriptionState);\n }\n // subscription mutators\n subscriptionState.nodes.set(\n node,\n propSubscriptions\n .filter((m) => m.value === ps.value)\n .map((m) => m.mutator)\n );\n });\n }\n\n /**\n * Called when the hosting container is mounted or updated. This ensures that we have\n * a ref to the underlying SkiaView so that we can registers redraw listeners\n * on values used in the current View automatically.\n */\n update() {\n // Remove any previous registrations\n if (this.unregisterDependantValues) {\n this.unregisterDependantValues();\n }\n\n // Register redraw requests on the SkiaView for each unique value\n this.unregisterDependantValues = this.registerValues(\n Array.from(this.subscriptions.keys())\n );\n }\n\n /**\n * Called when the hosting container is unmounted or recreated. This ensures that we remove\n * all subscriptions to Skia values so that we don't have any listeners left after\n * the component is removed.\n */\n remove() {\n // 1) Unregister redraw requests\n if (this.unregisterDependantValues) {\n this.unregisterDependantValues();\n this.unregisterDependantValues = null;\n }\n\n // 2) Unregister nodes\n Array.from(this.subscriptions.values()).forEach((si) => {\n Array.from(si.nodes.keys()).forEach((node) => this.unsubscribeNode(node));\n });\n\n // 3) Clear the rest of the subscriptions\n this.subscriptions.clear();\n }\n}\n\nconst initializePropertySubscriptions = <P,>(\n node: Node<P>,\n props: AnimatedProps<P>\n) => {\n const nodePropSubscriptions: Array<{\n value: SkiaValue<unknown>;\n mutator: Mutator;\n }> = [];\n\n mapKeys(props).forEach((key) => {\n if (key === \"children\") {\n return;\n }\n const propvalue = props[key];\n\n if (isValue(propvalue)) {\n // Subscribe to changes\n nodePropSubscriptions.push({\n value: propvalue,\n mutator: (v) => {\n node.setProp(key, v as P[typeof key]);\n },\n });\n // Set initial value\n node.setProp(key, (propvalue as SkiaValue<P[typeof key]>).current);\n } else if (isSelector(propvalue)) {\n // Subscribe to changes\n nodePropSubscriptions.push({\n value: propvalue.value,\n mutator: (v) => {\n node.setProp(key, propvalue.selector(v) as P[typeof key]);\n },\n });\n // Set initial value\n node.setProp(\n key,\n propvalue.selector(propvalue.value.current) as P[typeof key]\n );\n } else {\n // Set initial value\n node.setProp(key, propvalue as P[typeof key]);\n }\n });\n\n return nodePropSubscriptions;\n};\n"]}