@shopify/react-native-skia 1.7.7 → 1.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (663) hide show
  1. package/lib/commonjs/dom/nodes/JsiSkDOM.d.ts +3 -7
  2. package/lib/commonjs/dom/nodes/JsiSkDOM.js +58 -70
  3. package/lib/commonjs/dom/nodes/JsiSkDOM.js.map +1 -1
  4. package/lib/commonjs/dom/nodes/datatypes/Circle.js +4 -1
  5. package/lib/commonjs/dom/nodes/datatypes/Circle.js.map +1 -1
  6. package/lib/commonjs/dom/nodes/datatypes/Enum.js +5 -2
  7. package/lib/commonjs/dom/nodes/datatypes/Enum.js.map +1 -1
  8. package/lib/commonjs/dom/nodes/datatypes/Fitting.js +10 -1
  9. package/lib/commonjs/dom/nodes/datatypes/Fitting.js.map +1 -1
  10. package/lib/commonjs/dom/nodes/datatypes/Gradient.js +17 -10
  11. package/lib/commonjs/dom/nodes/datatypes/Gradient.js.map +1 -1
  12. package/lib/commonjs/dom/nodes/datatypes/Path.js +4 -1
  13. package/lib/commonjs/dom/nodes/datatypes/Path.js.map +1 -1
  14. package/lib/commonjs/dom/nodes/datatypes/Radius.js +2 -1
  15. package/lib/commonjs/dom/nodes/datatypes/Radius.js.map +1 -1
  16. package/lib/commonjs/dom/nodes/datatypes/Rect.js +16 -2
  17. package/lib/commonjs/dom/nodes/datatypes/Rect.js.map +1 -1
  18. package/lib/commonjs/dom/nodes/datatypes/Transform.js +4 -1
  19. package/lib/commonjs/dom/nodes/datatypes/Transform.js.map +1 -1
  20. package/lib/commonjs/dom/types/Node.d.ts +2 -5
  21. package/lib/commonjs/dom/types/Node.js.map +1 -1
  22. package/lib/commonjs/dom/types/index.d.ts +0 -2
  23. package/lib/commonjs/dom/types/index.js +0 -22
  24. package/lib/commonjs/dom/types/index.js.map +1 -1
  25. package/lib/commonjs/headless/index.js +3 -5
  26. package/lib/commonjs/headless/index.js.map +1 -1
  27. package/lib/commonjs/index.d.ts +1 -0
  28. package/lib/commonjs/index.js +12 -0
  29. package/lib/commonjs/index.js.map +1 -1
  30. package/lib/commonjs/renderer/Canvas.js +9 -26
  31. package/lib/commonjs/renderer/Canvas.js.map +1 -1
  32. package/lib/commonjs/renderer/Canvas.web.d.ts +10 -0
  33. package/lib/commonjs/renderer/Canvas.web.js +110 -0
  34. package/lib/commonjs/renderer/Canvas.web.js.map +1 -0
  35. package/lib/commonjs/renderer/Canvas2.d.ts +10 -0
  36. package/lib/commonjs/renderer/Canvas2.js +104 -0
  37. package/lib/commonjs/renderer/Canvas2.js.map +1 -0
  38. package/lib/commonjs/renderer/Canvas2.web.d.ts +3 -0
  39. package/lib/commonjs/renderer/Canvas2.web.js +9 -0
  40. package/lib/commonjs/renderer/Canvas2.web.js.map +1 -0
  41. package/lib/commonjs/renderer/Container.d.ts +3 -5
  42. package/lib/commonjs/renderer/Container.js +2 -7
  43. package/lib/commonjs/renderer/Container.js.map +1 -1
  44. package/lib/commonjs/renderer/HostComponents.d.ts +3 -6
  45. package/lib/commonjs/renderer/HostComponents.js +1 -4
  46. package/lib/commonjs/renderer/HostComponents.js.map +1 -1
  47. package/lib/commonjs/renderer/Offscreen.js +3 -5
  48. package/lib/commonjs/renderer/Offscreen.js.map +1 -1
  49. package/lib/commonjs/renderer/Reconciler.d.ts +2 -3
  50. package/lib/commonjs/renderer/Reconciler.js +2 -2
  51. package/lib/commonjs/renderer/Reconciler.js.map +1 -1
  52. package/lib/commonjs/skia/types/Shader/Shader.js +6 -1
  53. package/lib/commonjs/skia/types/Shader/Shader.js.map +1 -1
  54. package/lib/commonjs/sksg/Container.js +2 -2
  55. package/lib/commonjs/sksg/Container.js.map +1 -1
  56. package/lib/commonjs/sksg/DeclarationContext.d.ts +56 -0
  57. package/lib/commonjs/sksg/DeclarationContext.js +77 -0
  58. package/lib/commonjs/sksg/DeclarationContext.js.map +1 -0
  59. package/lib/commonjs/sksg/DrawingContext.d.ts +9 -12
  60. package/lib/commonjs/sksg/DrawingContext.js +63 -77
  61. package/lib/commonjs/sksg/DrawingContext.js.map +1 -1
  62. package/lib/commonjs/sksg/Reconciler.d.ts +2 -0
  63. package/lib/commonjs/sksg/Reconciler.js +7 -0
  64. package/lib/commonjs/sksg/Reconciler.js.map +1 -1
  65. package/lib/commonjs/sksg/nodes/colorFilters.d.ts +9 -6
  66. package/lib/commonjs/sksg/nodes/colorFilters.js +26 -2
  67. package/lib/commonjs/sksg/nodes/colorFilters.js.map +1 -1
  68. package/lib/commonjs/sksg/nodes/context.js +58 -112
  69. package/lib/commonjs/sksg/nodes/context.js.map +1 -1
  70. package/lib/commonjs/sksg/nodes/drawings.d.ts +1 -2
  71. package/lib/commonjs/sksg/nodes/drawings.js +43 -6
  72. package/lib/commonjs/sksg/nodes/drawings.js.map +1 -1
  73. package/lib/commonjs/sksg/nodes/imageFilters.d.ts +4 -1
  74. package/lib/commonjs/sksg/nodes/imageFilters.js +64 -2
  75. package/lib/commonjs/sksg/nodes/imageFilters.js.map +1 -1
  76. package/lib/commonjs/sksg/nodes/paint.d.ts +2 -1
  77. package/lib/commonjs/sksg/nodes/paint.js +2 -1
  78. package/lib/commonjs/sksg/nodes/paint.js.map +1 -1
  79. package/lib/commonjs/sksg/nodes/pathEffects.d.ts +10 -7
  80. package/lib/commonjs/sksg/nodes/pathEffects.js +30 -3
  81. package/lib/commonjs/sksg/nodes/pathEffects.js.map +1 -1
  82. package/lib/commonjs/sksg/nodes/shaders.d.ts +2 -1
  83. package/lib/commonjs/sksg/nodes/shaders.js +18 -1
  84. package/lib/commonjs/sksg/nodes/shaders.js.map +1 -1
  85. package/lib/commonjs/sksg/nodes/utils.js +4 -1
  86. package/lib/commonjs/sksg/nodes/utils.js.map +1 -1
  87. package/lib/commonjs/views/SkiaDomView.web.d.ts +0 -7
  88. package/lib/commonjs/views/SkiaDomView.web.js +0 -30
  89. package/lib/commonjs/views/SkiaDomView.web.js.map +1 -1
  90. package/lib/commonjs/views/SkiaPictureView.web.d.ts +3 -1
  91. package/lib/commonjs/views/SkiaPictureView.web.js +10 -0
  92. package/lib/commonjs/views/SkiaPictureView.web.js.map +1 -1
  93. package/lib/commonjs/views/types.d.ts +2 -7
  94. package/lib/commonjs/views/types.js.map +1 -1
  95. package/lib/module/dom/nodes/JsiSkDOM.d.ts +3 -7
  96. package/lib/module/dom/nodes/JsiSkDOM.js +58 -70
  97. package/lib/module/dom/nodes/JsiSkDOM.js.map +1 -1
  98. package/lib/module/dom/nodes/datatypes/Circle.js +4 -2
  99. package/lib/module/dom/nodes/datatypes/Circle.js.map +1 -1
  100. package/lib/module/dom/nodes/datatypes/Enum.js +4 -2
  101. package/lib/module/dom/nodes/datatypes/Enum.js.map +1 -1
  102. package/lib/module/dom/nodes/datatypes/Fitting.js +10 -2
  103. package/lib/module/dom/nodes/datatypes/Fitting.js.map +1 -1
  104. package/lib/module/dom/nodes/datatypes/Gradient.js +17 -11
  105. package/lib/module/dom/nodes/datatypes/Gradient.js.map +1 -1
  106. package/lib/module/dom/nodes/datatypes/Path.js +4 -2
  107. package/lib/module/dom/nodes/datatypes/Path.js.map +1 -1
  108. package/lib/module/dom/nodes/datatypes/Radius.js +2 -2
  109. package/lib/module/dom/nodes/datatypes/Radius.js.map +1 -1
  110. package/lib/module/dom/nodes/datatypes/Rect.js +15 -2
  111. package/lib/module/dom/nodes/datatypes/Rect.js.map +1 -1
  112. package/lib/module/dom/nodes/datatypes/Transform.js +4 -2
  113. package/lib/module/dom/nodes/datatypes/Transform.js.map +1 -1
  114. package/lib/module/dom/types/Node.d.ts +2 -5
  115. package/lib/module/dom/types/Node.js.map +1 -1
  116. package/lib/module/dom/types/index.d.ts +0 -2
  117. package/lib/module/dom/types/index.js +0 -2
  118. package/lib/module/dom/types/index.js.map +1 -1
  119. package/lib/module/headless/index.js +3 -5
  120. package/lib/module/headless/index.js.map +1 -1
  121. package/lib/module/index.d.ts +1 -0
  122. package/lib/module/index.js +1 -0
  123. package/lib/module/index.js.map +1 -1
  124. package/lib/module/renderer/Canvas.js +9 -26
  125. package/lib/module/renderer/Canvas.js.map +1 -1
  126. package/lib/module/renderer/Canvas.web.d.ts +10 -0
  127. package/lib/module/renderer/Canvas.web.js +105 -0
  128. package/lib/module/renderer/Canvas.web.js.map +1 -0
  129. package/lib/module/renderer/Canvas2.d.ts +10 -0
  130. package/lib/module/renderer/Canvas2.js +97 -0
  131. package/lib/module/renderer/Canvas2.js.map +1 -0
  132. package/lib/module/renderer/Canvas2.web.d.ts +3 -0
  133. package/lib/module/renderer/Canvas2.web.js +3 -0
  134. package/lib/module/renderer/Canvas2.web.js.map +1 -0
  135. package/lib/module/renderer/Container.d.ts +3 -5
  136. package/lib/module/renderer/Container.js +2 -7
  137. package/lib/module/renderer/Container.js.map +1 -1
  138. package/lib/module/renderer/HostComponents.d.ts +3 -6
  139. package/lib/module/renderer/HostComponents.js +0 -3
  140. package/lib/module/renderer/HostComponents.js.map +1 -1
  141. package/lib/module/renderer/Offscreen.js +3 -5
  142. package/lib/module/renderer/Offscreen.js.map +1 -1
  143. package/lib/module/renderer/Reconciler.d.ts +2 -3
  144. package/lib/module/renderer/Reconciler.js +2 -2
  145. package/lib/module/renderer/Reconciler.js.map +1 -1
  146. package/lib/module/skia/types/Shader/Shader.js +6 -2
  147. package/lib/module/skia/types/Shader/Shader.js.map +1 -1
  148. package/lib/module/sksg/Container.js +3 -3
  149. package/lib/module/sksg/Container.js.map +1 -1
  150. package/lib/module/sksg/DeclarationContext.d.ts +56 -0
  151. package/lib/module/sksg/DeclarationContext.js +69 -0
  152. package/lib/module/sksg/DeclarationContext.js.map +1 -0
  153. package/lib/module/sksg/DrawingContext.d.ts +9 -12
  154. package/lib/module/sksg/DrawingContext.js +54 -69
  155. package/lib/module/sksg/DrawingContext.js.map +1 -1
  156. package/lib/module/sksg/Reconciler.d.ts +2 -0
  157. package/lib/module/sksg/Reconciler.js +7 -0
  158. package/lib/module/sksg/Reconciler.js.map +1 -1
  159. package/lib/module/sksg/nodes/colorFilters.d.ts +9 -6
  160. package/lib/module/sksg/nodes/colorFilters.js +24 -2
  161. package/lib/module/sksg/nodes/colorFilters.js.map +1 -1
  162. package/lib/module/sksg/nodes/context.js +45 -101
  163. package/lib/module/sksg/nodes/context.js.map +1 -1
  164. package/lib/module/sksg/nodes/drawings.d.ts +1 -2
  165. package/lib/module/sksg/nodes/drawings.js +42 -5
  166. package/lib/module/sksg/nodes/drawings.js.map +1 -1
  167. package/lib/module/sksg/nodes/imageFilters.d.ts +4 -1
  168. package/lib/module/sksg/nodes/imageFilters.js +61 -2
  169. package/lib/module/sksg/nodes/imageFilters.js.map +1 -1
  170. package/lib/module/sksg/nodes/paint.d.ts +2 -1
  171. package/lib/module/sksg/nodes/paint.js +2 -2
  172. package/lib/module/sksg/nodes/paint.js.map +1 -1
  173. package/lib/module/sksg/nodes/pathEffects.d.ts +10 -7
  174. package/lib/module/sksg/nodes/pathEffects.js +28 -3
  175. package/lib/module/sksg/nodes/pathEffects.js.map +1 -1
  176. package/lib/module/sksg/nodes/shaders.d.ts +2 -1
  177. package/lib/module/sksg/nodes/shaders.js +18 -2
  178. package/lib/module/sksg/nodes/shaders.js.map +1 -1
  179. package/lib/module/sksg/nodes/utils.js +4 -2
  180. package/lib/module/sksg/nodes/utils.js.map +1 -1
  181. package/lib/module/views/SkiaDomView.web.d.ts +0 -7
  182. package/lib/module/views/SkiaDomView.web.js +1 -24
  183. package/lib/module/views/SkiaDomView.web.js.map +1 -1
  184. package/lib/module/views/SkiaPictureView.web.d.ts +3 -1
  185. package/lib/module/views/SkiaPictureView.web.js +10 -0
  186. package/lib/module/views/SkiaPictureView.web.js.map +1 -1
  187. package/lib/module/views/types.d.ts +2 -7
  188. package/lib/module/views/types.js.map +1 -1
  189. package/lib/typescript/lib/commonjs/dom/nodes/JsiSkDOM.d.ts +57 -67
  190. package/lib/typescript/lib/commonjs/renderer/Canvas.web.d.ts +3 -0
  191. package/lib/typescript/lib/commonjs/renderer/Canvas2.d.ts +3 -0
  192. package/lib/typescript/lib/commonjs/{dom/nodes/drawings/index.d.ts → renderer/Canvas2.web.d.ts} +1 -0
  193. package/lib/typescript/lib/commonjs/renderer/Container.d.ts +1 -2
  194. package/lib/typescript/lib/commonjs/renderer/HostComponents.d.ts +0 -1
  195. package/lib/typescript/lib/commonjs/renderer/Reconciler.d.ts +1 -1
  196. package/lib/typescript/lib/commonjs/sksg/DeclarationContext.d.ts +53 -0
  197. package/lib/typescript/lib/commonjs/sksg/DrawingContext.d.ts +8 -12
  198. package/lib/typescript/lib/commonjs/sksg/Reconciler.d.ts +2 -0
  199. package/lib/typescript/lib/commonjs/sksg/nodes/colorFilters.d.ts +1 -0
  200. package/lib/typescript/lib/commonjs/sksg/nodes/drawings.d.ts +0 -1
  201. package/lib/typescript/lib/commonjs/sksg/nodes/imageFilters.d.ts +2 -0
  202. package/lib/typescript/lib/commonjs/sksg/nodes/pathEffects.d.ts +1 -0
  203. package/lib/typescript/lib/commonjs/views/SkiaDomView.web.d.ts +0 -5
  204. package/lib/typescript/lib/commonjs/views/SkiaPictureView.web.d.ts +2 -0
  205. package/lib/typescript/lib/module/dom/nodes/JsiSkDOM.d.ts +57 -117
  206. package/lib/typescript/lib/module/dom/types/index.d.ts +0 -2
  207. package/lib/typescript/lib/module/index.d.ts +1 -0
  208. package/lib/typescript/lib/module/mock/index.d.ts +0 -3
  209. package/lib/typescript/lib/module/renderer/Canvas.web.d.ts +1 -0
  210. package/lib/typescript/lib/module/renderer/Canvas2.d.ts +1 -0
  211. package/lib/typescript/lib/module/renderer/Canvas2.web.d.ts +1 -0
  212. package/lib/typescript/lib/module/renderer/Container.d.ts +3 -4
  213. package/lib/typescript/lib/module/renderer/HostComponents.d.ts +0 -1
  214. package/lib/typescript/lib/module/renderer/Reconciler.d.ts +2 -2
  215. package/lib/typescript/lib/module/sksg/DeclarationContext.d.ts +52 -0
  216. package/lib/typescript/lib/module/sksg/DrawingContext.d.ts +8 -13
  217. package/lib/typescript/lib/module/sksg/Reconciler.d.ts +2 -0
  218. package/lib/typescript/lib/module/sksg/nodes/colorFilters.d.ts +1 -0
  219. package/lib/typescript/lib/module/sksg/nodes/drawings.d.ts +0 -1
  220. package/lib/typescript/lib/module/sksg/nodes/imageFilters.d.ts +2 -0
  221. package/lib/typescript/lib/module/sksg/nodes/pathEffects.d.ts +1 -0
  222. package/lib/typescript/lib/module/views/SkiaDomView.web.d.ts +0 -4
  223. package/lib/typescript/lib/module/views/SkiaPictureView.web.d.ts +2 -0
  224. package/lib/typescript/src/dom/nodes/JsiSkDOM.d.ts +3 -7
  225. package/lib/typescript/src/dom/types/Node.d.ts +2 -5
  226. package/lib/typescript/src/dom/types/index.d.ts +0 -2
  227. package/lib/typescript/src/index.d.ts +1 -0
  228. package/lib/typescript/src/renderer/Canvas.web.d.ts +10 -0
  229. package/lib/typescript/src/renderer/Canvas2.d.ts +10 -0
  230. package/lib/typescript/src/renderer/Canvas2.web.d.ts +3 -0
  231. package/lib/typescript/src/renderer/Container.d.ts +3 -5
  232. package/lib/typescript/src/renderer/HostComponents.d.ts +3 -6
  233. package/lib/typescript/src/renderer/Reconciler.d.ts +2 -3
  234. package/lib/typescript/src/sksg/DeclarationContext.d.ts +56 -0
  235. package/lib/typescript/src/sksg/DrawingContext.d.ts +9 -12
  236. package/lib/typescript/src/sksg/Reconciler.d.ts +2 -0
  237. package/lib/typescript/src/sksg/nodes/colorFilters.d.ts +9 -6
  238. package/lib/typescript/src/sksg/nodes/drawings.d.ts +1 -2
  239. package/lib/typescript/src/sksg/nodes/imageFilters.d.ts +4 -1
  240. package/lib/typescript/src/sksg/nodes/paint.d.ts +2 -1
  241. package/lib/typescript/src/sksg/nodes/pathEffects.d.ts +10 -7
  242. package/lib/typescript/src/sksg/nodes/shaders.d.ts +2 -1
  243. package/lib/typescript/src/views/SkiaDomView.web.d.ts +0 -7
  244. package/lib/typescript/src/views/SkiaPictureView.web.d.ts +3 -1
  245. package/lib/typescript/src/views/types.d.ts +2 -7
  246. package/package.json +1 -1
  247. package/src/dom/nodes/JsiSkDOM.ts +58 -239
  248. package/src/dom/nodes/datatypes/Circle.ts +2 -2
  249. package/src/dom/nodes/datatypes/Enum.ts +4 -4
  250. package/src/dom/nodes/datatypes/Fitting.ts +5 -2
  251. package/src/dom/nodes/datatypes/Gradient.ts +12 -9
  252. package/src/dom/nodes/datatypes/Path.ts +2 -2
  253. package/src/dom/nodes/datatypes/Radius.ts +1 -2
  254. package/src/dom/nodes/datatypes/Rect.ts +7 -2
  255. package/src/dom/nodes/datatypes/Transform.ts +4 -2
  256. package/src/dom/types/Node.ts +2 -5
  257. package/src/dom/types/index.ts +0 -2
  258. package/src/headless/index.ts +3 -5
  259. package/src/index.ts +1 -0
  260. package/src/renderer/Canvas.tsx +12 -31
  261. package/src/renderer/Canvas.web.tsx +134 -0
  262. package/src/renderer/Canvas2.tsx +128 -0
  263. package/src/renderer/Canvas2.web.tsx +6 -0
  264. package/src/renderer/Container.tsx +4 -16
  265. package/src/renderer/HostComponents.ts +2 -10
  266. package/src/renderer/Offscreen.tsx +3 -6
  267. package/src/renderer/Reconciler.tsx +1 -5
  268. package/src/skia/types/Shader/Shader.ts +3 -2
  269. package/src/sksg/Container.ts +3 -3
  270. package/src/sksg/DeclarationContext.ts +85 -0
  271. package/src/sksg/DrawingContext.ts +81 -76
  272. package/src/sksg/Reconciler.ts +8 -1
  273. package/src/sksg/__tests__/MockDeclaration.ts +0 -2
  274. package/src/sksg/nodes/colorFilters.ts +22 -3
  275. package/src/sksg/nodes/context.ts +46 -123
  276. package/src/sksg/nodes/drawings.ts +21 -9
  277. package/src/sksg/nodes/imageFilters.ts +55 -3
  278. package/src/sksg/nodes/paint.ts +3 -3
  279. package/src/sksg/nodes/pathEffects.ts +27 -4
  280. package/src/sksg/nodes/shaders.ts +10 -3
  281. package/src/sksg/nodes/utils.ts +2 -2
  282. package/src/views/SkiaDomView.web.tsx +0 -23
  283. package/src/views/SkiaPictureView.web.tsx +10 -1
  284. package/src/views/types.ts +2 -8
  285. package/lib/commonjs/dom/nodes/DrawingNode.d.ts +0 -14
  286. package/lib/commonjs/dom/nodes/DrawingNode.js +0 -69
  287. package/lib/commonjs/dom/nodes/DrawingNode.js.map +0 -1
  288. package/lib/commonjs/dom/nodes/GroupNode.d.ts +0 -7
  289. package/lib/commonjs/dom/nodes/GroupNode.js +0 -22
  290. package/lib/commonjs/dom/nodes/GroupNode.js.map +0 -1
  291. package/lib/commonjs/dom/nodes/LayerNode.d.ts +0 -8
  292. package/lib/commonjs/dom/nodes/LayerNode.js +0 -39
  293. package/lib/commonjs/dom/nodes/LayerNode.js.map +0 -1
  294. package/lib/commonjs/dom/nodes/Node.d.ts +0 -34
  295. package/lib/commonjs/dom/nodes/Node.js +0 -102
  296. package/lib/commonjs/dom/nodes/Node.js.map +0 -1
  297. package/lib/commonjs/dom/nodes/PaintNode.d.ts +0 -8
  298. package/lib/commonjs/dom/nodes/PaintNode.js +0 -90
  299. package/lib/commonjs/dom/nodes/PaintNode.js.map +0 -1
  300. package/lib/commonjs/dom/nodes/RenderNode.d.ts +0 -26
  301. package/lib/commonjs/dom/nodes/RenderNode.js +0 -132
  302. package/lib/commonjs/dom/nodes/RenderNode.js.map +0 -1
  303. package/lib/commonjs/dom/nodes/drawings/AtlasNode.d.ts +0 -8
  304. package/lib/commonjs/dom/nodes/drawings/AtlasNode.js +0 -36
  305. package/lib/commonjs/dom/nodes/drawings/AtlasNode.js.map +0 -1
  306. package/lib/commonjs/dom/nodes/drawings/BackdropFilterNode.d.ts +0 -8
  307. package/lib/commonjs/dom/nodes/drawings/BackdropFilterNode.js +0 -42
  308. package/lib/commonjs/dom/nodes/drawings/BackdropFilterNode.js.map +0 -1
  309. package/lib/commonjs/dom/nodes/drawings/Box.d.ts +0 -15
  310. package/lib/commonjs/dom/nodes/drawings/Box.js +0 -81
  311. package/lib/commonjs/dom/nodes/drawings/Box.js.map +0 -1
  312. package/lib/commonjs/dom/nodes/drawings/CircleNode.d.ts +0 -9
  313. package/lib/commonjs/dom/nodes/drawings/CircleNode.js +0 -32
  314. package/lib/commonjs/dom/nodes/drawings/CircleNode.js.map +0 -1
  315. package/lib/commonjs/dom/nodes/drawings/DiffRectNode.d.ts +0 -8
  316. package/lib/commonjs/dom/nodes/drawings/DiffRectNode.js +0 -28
  317. package/lib/commonjs/dom/nodes/drawings/DiffRectNode.js.map +0 -1
  318. package/lib/commonjs/dom/nodes/drawings/FillNode.d.ts +0 -8
  319. package/lib/commonjs/dom/nodes/drawings/FillNode.js +0 -24
  320. package/lib/commonjs/dom/nodes/drawings/FillNode.js.map +0 -1
  321. package/lib/commonjs/dom/nodes/drawings/ImageNode.d.ts +0 -25
  322. package/lib/commonjs/dom/nodes/drawings/ImageNode.js +0 -71
  323. package/lib/commonjs/dom/nodes/drawings/ImageNode.js.map +0 -1
  324. package/lib/commonjs/dom/nodes/drawings/ImageSVG.d.ts +0 -13
  325. package/lib/commonjs/dom/nodes/drawings/ImageSVG.js +0 -57
  326. package/lib/commonjs/dom/nodes/drawings/ImageSVG.js.map +0 -1
  327. package/lib/commonjs/dom/nodes/drawings/LineNode.d.ts +0 -8
  328. package/lib/commonjs/dom/nodes/drawings/LineNode.js +0 -28
  329. package/lib/commonjs/dom/nodes/drawings/LineNode.js.map +0 -1
  330. package/lib/commonjs/dom/nodes/drawings/OvalNode.d.ts +0 -9
  331. package/lib/commonjs/dom/nodes/drawings/OvalNode.js +0 -28
  332. package/lib/commonjs/dom/nodes/drawings/OvalNode.js.map +0 -1
  333. package/lib/commonjs/dom/nodes/drawings/ParagraphNode.d.ts +0 -8
  334. package/lib/commonjs/dom/nodes/drawings/ParagraphNode.js +0 -32
  335. package/lib/commonjs/dom/nodes/drawings/ParagraphNode.js.map +0 -1
  336. package/lib/commonjs/dom/nodes/drawings/PatchNode.d.ts +0 -18
  337. package/lib/commonjs/dom/nodes/drawings/PatchNode.js +0 -53
  338. package/lib/commonjs/dom/nodes/drawings/PatchNode.js.map +0 -1
  339. package/lib/commonjs/dom/nodes/drawings/PathNode.d.ts +0 -9
  340. package/lib/commonjs/dom/nodes/drawings/PathNode.js +0 -55
  341. package/lib/commonjs/dom/nodes/drawings/PathNode.js.map +0 -1
  342. package/lib/commonjs/dom/nodes/drawings/PictureNode.d.ts +0 -8
  343. package/lib/commonjs/dom/nodes/drawings/PictureNode.js +0 -26
  344. package/lib/commonjs/dom/nodes/drawings/PictureNode.js.map +0 -1
  345. package/lib/commonjs/dom/nodes/drawings/PointsNode.d.ts +0 -8
  346. package/lib/commonjs/dom/nodes/drawings/PointsNode.js +0 -30
  347. package/lib/commonjs/dom/nodes/drawings/PointsNode.js.map +0 -1
  348. package/lib/commonjs/dom/nodes/drawings/RRectNode.d.ts +0 -10
  349. package/lib/commonjs/dom/nodes/drawings/RRectNode.js +0 -32
  350. package/lib/commonjs/dom/nodes/drawings/RRectNode.js.map +0 -1
  351. package/lib/commonjs/dom/nodes/drawings/RectNode.d.ts +0 -9
  352. package/lib/commonjs/dom/nodes/drawings/RectNode.js +0 -28
  353. package/lib/commonjs/dom/nodes/drawings/RectNode.js.map +0 -1
  354. package/lib/commonjs/dom/nodes/drawings/Text.d.ts +0 -30
  355. package/lib/commonjs/dom/nodes/drawings/Text.js +0 -159
  356. package/lib/commonjs/dom/nodes/drawings/Text.js.map +0 -1
  357. package/lib/commonjs/dom/nodes/drawings/VerticesNode.d.ts +0 -9
  358. package/lib/commonjs/dom/nodes/drawings/VerticesNode.js +0 -43
  359. package/lib/commonjs/dom/nodes/drawings/VerticesNode.js.map +0 -1
  360. package/lib/commonjs/dom/nodes/drawings/index.d.ts +0 -18
  361. package/lib/commonjs/dom/nodes/drawings/index.js +0 -204
  362. package/lib/commonjs/dom/nodes/drawings/index.js.map +0 -1
  363. package/lib/commonjs/dom/nodes/paint/BlendNode.d.ts +0 -8
  364. package/lib/commonjs/dom/nodes/paint/BlendNode.js +0 -37
  365. package/lib/commonjs/dom/nodes/paint/BlendNode.js.map +0 -1
  366. package/lib/commonjs/dom/nodes/paint/ColorFilters.d.ts +0 -35
  367. package/lib/commonjs/dom/nodes/paint/ColorFilters.js +0 -102
  368. package/lib/commonjs/dom/nodes/paint/ColorFilters.js.map +0 -1
  369. package/lib/commonjs/dom/nodes/paint/ImageFilters.d.ts +0 -42
  370. package/lib/commonjs/dom/nodes/paint/ImageFilters.js +0 -183
  371. package/lib/commonjs/dom/nodes/paint/ImageFilters.js.map +0 -1
  372. package/lib/commonjs/dom/nodes/paint/MaskFilters.d.ts +0 -8
  373. package/lib/commonjs/dom/nodes/paint/MaskFilters.js +0 -26
  374. package/lib/commonjs/dom/nodes/paint/MaskFilters.js.map +0 -1
  375. package/lib/commonjs/dom/nodes/paint/PathEffects.d.ts +0 -39
  376. package/lib/commonjs/dom/nodes/paint/PathEffects.js +0 -136
  377. package/lib/commonjs/dom/nodes/paint/PathEffects.js.map +0 -1
  378. package/lib/commonjs/dom/nodes/paint/Shaders.d.ts +0 -43
  379. package/lib/commonjs/dom/nodes/paint/Shaders.js +0 -209
  380. package/lib/commonjs/dom/nodes/paint/Shaders.js.map +0 -1
  381. package/lib/commonjs/dom/nodes/paint/index.d.ts +0 -6
  382. package/lib/commonjs/dom/nodes/paint/index.js +0 -72
  383. package/lib/commonjs/dom/nodes/paint/index.js.map +0 -1
  384. package/lib/commonjs/dom/types/DeclarationContext.d.ts +0 -29
  385. package/lib/commonjs/dom/types/DeclarationContext.js +0 -97
  386. package/lib/commonjs/dom/types/DeclarationContext.js.map +0 -1
  387. package/lib/commonjs/dom/types/DrawingContext.d.ts +0 -22
  388. package/lib/commonjs/dom/types/DrawingContext.js +0 -263
  389. package/lib/commonjs/dom/types/DrawingContext.js.map +0 -1
  390. package/lib/commonjs/renderer/DrawingContext.d.ts +0 -7
  391. package/lib/commonjs/renderer/DrawingContext.js +0 -6
  392. package/lib/commonjs/renderer/DrawingContext.js.map +0 -1
  393. package/lib/commonjs/views/SkiaJSDomView.d.ts +0 -38
  394. package/lib/commonjs/views/SkiaJSDomView.js +0 -131
  395. package/lib/commonjs/views/SkiaJSDomView.js.map +0 -1
  396. package/lib/commonjs/views/SkiaJSDomView.web.d.ts +0 -1
  397. package/lib/commonjs/views/SkiaJSDomView.web.js +0 -13
  398. package/lib/commonjs/views/SkiaJSDomView.web.js.map +0 -1
  399. package/lib/module/dom/nodes/DrawingNode.d.ts +0 -14
  400. package/lib/module/dom/nodes/DrawingNode.js +0 -62
  401. package/lib/module/dom/nodes/DrawingNode.js.map +0 -1
  402. package/lib/module/dom/nodes/GroupNode.d.ts +0 -7
  403. package/lib/module/dom/nodes/GroupNode.js +0 -15
  404. package/lib/module/dom/nodes/GroupNode.js.map +0 -1
  405. package/lib/module/dom/nodes/LayerNode.d.ts +0 -8
  406. package/lib/module/dom/nodes/LayerNode.js +0 -32
  407. package/lib/module/dom/nodes/LayerNode.js.map +0 -1
  408. package/lib/module/dom/nodes/Node.d.ts +0 -34
  409. package/lib/module/dom/nodes/Node.js +0 -94
  410. package/lib/module/dom/nodes/Node.js.map +0 -1
  411. package/lib/module/dom/nodes/PaintNode.d.ts +0 -8
  412. package/lib/module/dom/nodes/PaintNode.js +0 -83
  413. package/lib/module/dom/nodes/PaintNode.js.map +0 -1
  414. package/lib/module/dom/nodes/RenderNode.d.ts +0 -26
  415. package/lib/module/dom/nodes/RenderNode.js +0 -125
  416. package/lib/module/dom/nodes/RenderNode.js.map +0 -1
  417. package/lib/module/dom/nodes/drawings/AtlasNode.d.ts +0 -8
  418. package/lib/module/dom/nodes/drawings/AtlasNode.js +0 -29
  419. package/lib/module/dom/nodes/drawings/AtlasNode.js.map +0 -1
  420. package/lib/module/dom/nodes/drawings/BackdropFilterNode.d.ts +0 -8
  421. package/lib/module/dom/nodes/drawings/BackdropFilterNode.js +0 -35
  422. package/lib/module/dom/nodes/drawings/BackdropFilterNode.js.map +0 -1
  423. package/lib/module/dom/nodes/drawings/Box.d.ts +0 -15
  424. package/lib/module/dom/nodes/drawings/Box.js +0 -73
  425. package/lib/module/dom/nodes/drawings/Box.js.map +0 -1
  426. package/lib/module/dom/nodes/drawings/CircleNode.d.ts +0 -9
  427. package/lib/module/dom/nodes/drawings/CircleNode.js +0 -25
  428. package/lib/module/dom/nodes/drawings/CircleNode.js.map +0 -1
  429. package/lib/module/dom/nodes/drawings/DiffRectNode.d.ts +0 -8
  430. package/lib/module/dom/nodes/drawings/DiffRectNode.js +0 -21
  431. package/lib/module/dom/nodes/drawings/DiffRectNode.js.map +0 -1
  432. package/lib/module/dom/nodes/drawings/FillNode.d.ts +0 -8
  433. package/lib/module/dom/nodes/drawings/FillNode.js +0 -17
  434. package/lib/module/dom/nodes/drawings/FillNode.js.map +0 -1
  435. package/lib/module/dom/nodes/drawings/ImageNode.d.ts +0 -25
  436. package/lib/module/dom/nodes/drawings/ImageNode.js +0 -64
  437. package/lib/module/dom/nodes/drawings/ImageNode.js.map +0 -1
  438. package/lib/module/dom/nodes/drawings/ImageSVG.d.ts +0 -13
  439. package/lib/module/dom/nodes/drawings/ImageSVG.js +0 -50
  440. package/lib/module/dom/nodes/drawings/ImageSVG.js.map +0 -1
  441. package/lib/module/dom/nodes/drawings/LineNode.d.ts +0 -8
  442. package/lib/module/dom/nodes/drawings/LineNode.js +0 -21
  443. package/lib/module/dom/nodes/drawings/LineNode.js.map +0 -1
  444. package/lib/module/dom/nodes/drawings/OvalNode.d.ts +0 -9
  445. package/lib/module/dom/nodes/drawings/OvalNode.js +0 -21
  446. package/lib/module/dom/nodes/drawings/OvalNode.js.map +0 -1
  447. package/lib/module/dom/nodes/drawings/ParagraphNode.d.ts +0 -8
  448. package/lib/module/dom/nodes/drawings/ParagraphNode.js +0 -25
  449. package/lib/module/dom/nodes/drawings/ParagraphNode.js.map +0 -1
  450. package/lib/module/dom/nodes/drawings/PatchNode.d.ts +0 -18
  451. package/lib/module/dom/nodes/drawings/PatchNode.js +0 -46
  452. package/lib/module/dom/nodes/drawings/PatchNode.js.map +0 -1
  453. package/lib/module/dom/nodes/drawings/PathNode.d.ts +0 -9
  454. package/lib/module/dom/nodes/drawings/PathNode.js +0 -48
  455. package/lib/module/dom/nodes/drawings/PathNode.js.map +0 -1
  456. package/lib/module/dom/nodes/drawings/PictureNode.d.ts +0 -8
  457. package/lib/module/dom/nodes/drawings/PictureNode.js +0 -19
  458. package/lib/module/dom/nodes/drawings/PictureNode.js.map +0 -1
  459. package/lib/module/dom/nodes/drawings/PointsNode.d.ts +0 -8
  460. package/lib/module/dom/nodes/drawings/PointsNode.js +0 -23
  461. package/lib/module/dom/nodes/drawings/PointsNode.js.map +0 -1
  462. package/lib/module/dom/nodes/drawings/RRectNode.d.ts +0 -10
  463. package/lib/module/dom/nodes/drawings/RRectNode.js +0 -25
  464. package/lib/module/dom/nodes/drawings/RRectNode.js.map +0 -1
  465. package/lib/module/dom/nodes/drawings/RectNode.d.ts +0 -9
  466. package/lib/module/dom/nodes/drawings/RectNode.js +0 -21
  467. package/lib/module/dom/nodes/drawings/RectNode.js.map +0 -1
  468. package/lib/module/dom/nodes/drawings/Text.d.ts +0 -30
  469. package/lib/module/dom/nodes/drawings/Text.js +0 -149
  470. package/lib/module/dom/nodes/drawings/Text.js.map +0 -1
  471. package/lib/module/dom/nodes/drawings/VerticesNode.d.ts +0 -9
  472. package/lib/module/dom/nodes/drawings/VerticesNode.js +0 -36
  473. package/lib/module/dom/nodes/drawings/VerticesNode.js.map +0 -1
  474. package/lib/module/dom/nodes/drawings/index.d.ts +0 -18
  475. package/lib/module/dom/nodes/drawings/index.js +0 -19
  476. package/lib/module/dom/nodes/drawings/index.js.map +0 -1
  477. package/lib/module/dom/nodes/paint/BlendNode.d.ts +0 -8
  478. package/lib/module/dom/nodes/paint/BlendNode.js +0 -30
  479. package/lib/module/dom/nodes/paint/BlendNode.js.map +0 -1
  480. package/lib/module/dom/nodes/paint/ColorFilters.d.ts +0 -35
  481. package/lib/module/dom/nodes/paint/ColorFilters.js +0 -89
  482. package/lib/module/dom/nodes/paint/ColorFilters.js.map +0 -1
  483. package/lib/module/dom/nodes/paint/ImageFilters.d.ts +0 -42
  484. package/lib/module/dom/nodes/paint/ImageFilters.js +0 -169
  485. package/lib/module/dom/nodes/paint/ImageFilters.js.map +0 -1
  486. package/lib/module/dom/nodes/paint/MaskFilters.d.ts +0 -8
  487. package/lib/module/dom/nodes/paint/MaskFilters.js +0 -19
  488. package/lib/module/dom/nodes/paint/MaskFilters.js.map +0 -1
  489. package/lib/module/dom/nodes/paint/PathEffects.d.ts +0 -39
  490. package/lib/module/dom/nodes/paint/PathEffects.js +0 -123
  491. package/lib/module/dom/nodes/paint/PathEffects.js.map +0 -1
  492. package/lib/module/dom/nodes/paint/Shaders.d.ts +0 -43
  493. package/lib/module/dom/nodes/paint/Shaders.js +0 -193
  494. package/lib/module/dom/nodes/paint/Shaders.js.map +0 -1
  495. package/lib/module/dom/nodes/paint/index.d.ts +0 -6
  496. package/lib/module/dom/nodes/paint/index.js +0 -7
  497. package/lib/module/dom/nodes/paint/index.js.map +0 -1
  498. package/lib/module/dom/types/DeclarationContext.d.ts +0 -29
  499. package/lib/module/dom/types/DeclarationContext.js +0 -90
  500. package/lib/module/dom/types/DeclarationContext.js.map +0 -1
  501. package/lib/module/dom/types/DrawingContext.d.ts +0 -22
  502. package/lib/module/dom/types/DrawingContext.js +0 -256
  503. package/lib/module/dom/types/DrawingContext.js.map +0 -1
  504. package/lib/module/renderer/DrawingContext.d.ts +0 -7
  505. package/lib/module/renderer/DrawingContext.js +0 -2
  506. package/lib/module/renderer/DrawingContext.js.map +0 -1
  507. package/lib/module/views/SkiaJSDomView.d.ts +0 -38
  508. package/lib/module/views/SkiaJSDomView.js +0 -123
  509. package/lib/module/views/SkiaJSDomView.js.map +0 -1
  510. package/lib/module/views/SkiaJSDomView.web.d.ts +0 -1
  511. package/lib/module/views/SkiaJSDomView.web.js +0 -2
  512. package/lib/module/views/SkiaJSDomView.web.js.map +0 -1
  513. package/lib/typescript/lib/commonjs/dom/nodes/DrawingNode.d.ts +0 -6
  514. package/lib/typescript/lib/commonjs/dom/nodes/GroupNode.d.ts +0 -6
  515. package/lib/typescript/lib/commonjs/dom/nodes/LayerNode.d.ts +0 -6
  516. package/lib/typescript/lib/commonjs/dom/nodes/Node.d.ts +0 -20
  517. package/lib/typescript/lib/commonjs/dom/nodes/PaintNode.d.ts +0 -6
  518. package/lib/typescript/lib/commonjs/dom/nodes/RenderNode.d.ts +0 -16
  519. package/lib/typescript/lib/commonjs/dom/nodes/drawings/AtlasNode.d.ts +0 -10
  520. package/lib/typescript/lib/commonjs/dom/nodes/drawings/BackdropFilterNode.d.ts +0 -10
  521. package/lib/typescript/lib/commonjs/dom/nodes/drawings/Box.d.ts +0 -15
  522. package/lib/typescript/lib/commonjs/dom/nodes/drawings/CircleNode.d.ts +0 -10
  523. package/lib/typescript/lib/commonjs/dom/nodes/drawings/DiffRectNode.d.ts +0 -10
  524. package/lib/typescript/lib/commonjs/dom/nodes/drawings/FillNode.d.ts +0 -10
  525. package/lib/typescript/lib/commonjs/dom/nodes/drawings/ImageNode.d.ts +0 -13
  526. package/lib/typescript/lib/commonjs/dom/nodes/drawings/ImageSVG.d.ts +0 -9
  527. package/lib/typescript/lib/commonjs/dom/nodes/drawings/LineNode.d.ts +0 -10
  528. package/lib/typescript/lib/commonjs/dom/nodes/drawings/OvalNode.d.ts +0 -10
  529. package/lib/typescript/lib/commonjs/dom/nodes/drawings/ParagraphNode.d.ts +0 -9
  530. package/lib/typescript/lib/commonjs/dom/nodes/drawings/PatchNode.d.ts +0 -14
  531. package/lib/typescript/lib/commonjs/dom/nodes/drawings/PathNode.d.ts +0 -10
  532. package/lib/typescript/lib/commonjs/dom/nodes/drawings/PictureNode.d.ts +0 -9
  533. package/lib/typescript/lib/commonjs/dom/nodes/drawings/PointsNode.d.ts +0 -10
  534. package/lib/typescript/lib/commonjs/dom/nodes/drawings/RRectNode.d.ts +0 -10
  535. package/lib/typescript/lib/commonjs/dom/nodes/drawings/RectNode.d.ts +0 -10
  536. package/lib/typescript/lib/commonjs/dom/nodes/drawings/Text.d.ts +0 -34
  537. package/lib/typescript/lib/commonjs/dom/nodes/drawings/VerticesNode.d.ts +0 -10
  538. package/lib/typescript/lib/commonjs/dom/nodes/paint/BlendNode.d.ts +0 -6
  539. package/lib/typescript/lib/commonjs/dom/nodes/paint/ColorFilters.d.ts +0 -29
  540. package/lib/typescript/lib/commonjs/dom/nodes/paint/ImageFilters.d.ts +0 -35
  541. package/lib/typescript/lib/commonjs/dom/nodes/paint/MaskFilters.d.ts +0 -6
  542. package/lib/typescript/lib/commonjs/dom/nodes/paint/PathEffects.d.ts +0 -34
  543. package/lib/typescript/lib/commonjs/dom/nodes/paint/Shaders.d.ts +0 -40
  544. package/lib/typescript/lib/commonjs/dom/nodes/paint/index.d.ts +0 -1
  545. package/lib/typescript/lib/commonjs/dom/types/DeclarationContext.d.ts +0 -26
  546. package/lib/typescript/lib/commonjs/dom/types/DrawingContext.d.ts +0 -13
  547. package/lib/typescript/lib/commonjs/renderer/DrawingContext.d.ts +0 -1
  548. package/lib/typescript/lib/commonjs/views/SkiaJSDomView.d.ts +0 -29
  549. package/lib/typescript/lib/commonjs/views/SkiaJSDomView.web.d.ts +0 -3
  550. package/lib/typescript/lib/module/dom/nodes/DrawingNode.d.ts +0 -5
  551. package/lib/typescript/lib/module/dom/nodes/GroupNode.d.ts +0 -5
  552. package/lib/typescript/lib/module/dom/nodes/LayerNode.d.ts +0 -5
  553. package/lib/typescript/lib/module/dom/nodes/Node.d.ts +0 -19
  554. package/lib/typescript/lib/module/dom/nodes/PaintNode.d.ts +0 -5
  555. package/lib/typescript/lib/module/dom/nodes/RenderNode.d.ts +0 -15
  556. package/lib/typescript/lib/module/dom/nodes/drawings/AtlasNode.d.ts +0 -9
  557. package/lib/typescript/lib/module/dom/nodes/drawings/BackdropFilterNode.d.ts +0 -9
  558. package/lib/typescript/lib/module/dom/nodes/drawings/Box.d.ts +0 -14
  559. package/lib/typescript/lib/module/dom/nodes/drawings/CircleNode.d.ts +0 -9
  560. package/lib/typescript/lib/module/dom/nodes/drawings/DiffRectNode.d.ts +0 -9
  561. package/lib/typescript/lib/module/dom/nodes/drawings/FillNode.d.ts +0 -9
  562. package/lib/typescript/lib/module/dom/nodes/drawings/ImageNode.d.ts +0 -22
  563. package/lib/typescript/lib/module/dom/nodes/drawings/ImageSVG.d.ts +0 -8
  564. package/lib/typescript/lib/module/dom/nodes/drawings/LineNode.d.ts +0 -9
  565. package/lib/typescript/lib/module/dom/nodes/drawings/OvalNode.d.ts +0 -9
  566. package/lib/typescript/lib/module/dom/nodes/drawings/ParagraphNode.d.ts +0 -8
  567. package/lib/typescript/lib/module/dom/nodes/drawings/PatchNode.d.ts +0 -13
  568. package/lib/typescript/lib/module/dom/nodes/drawings/PathNode.d.ts +0 -9
  569. package/lib/typescript/lib/module/dom/nodes/drawings/PictureNode.d.ts +0 -8
  570. package/lib/typescript/lib/module/dom/nodes/drawings/PointsNode.d.ts +0 -9
  571. package/lib/typescript/lib/module/dom/nodes/drawings/RRectNode.d.ts +0 -9
  572. package/lib/typescript/lib/module/dom/nodes/drawings/RectNode.d.ts +0 -9
  573. package/lib/typescript/lib/module/dom/nodes/drawings/Text.d.ts +0 -33
  574. package/lib/typescript/lib/module/dom/nodes/drawings/VerticesNode.d.ts +0 -9
  575. package/lib/typescript/lib/module/dom/nodes/drawings/index.d.ts +0 -18
  576. package/lib/typescript/lib/module/dom/nodes/paint/BlendNode.d.ts +0 -5
  577. package/lib/typescript/lib/module/dom/nodes/paint/ColorFilters.d.ts +0 -28
  578. package/lib/typescript/lib/module/dom/nodes/paint/ImageFilters.d.ts +0 -34
  579. package/lib/typescript/lib/module/dom/nodes/paint/MaskFilters.d.ts +0 -5
  580. package/lib/typescript/lib/module/dom/nodes/paint/PathEffects.d.ts +0 -33
  581. package/lib/typescript/lib/module/dom/nodes/paint/Shaders.d.ts +0 -39
  582. package/lib/typescript/lib/module/dom/nodes/paint/index.d.ts +0 -6
  583. package/lib/typescript/lib/module/dom/types/DeclarationContext.d.ts +0 -25
  584. package/lib/typescript/lib/module/dom/types/DrawingContext.d.ts +0 -12
  585. package/lib/typescript/lib/module/renderer/DrawingContext.d.ts +0 -1
  586. package/lib/typescript/lib/module/views/SkiaJSDomView.d.ts +0 -26
  587. package/lib/typescript/lib/module/views/SkiaJSDomView.web.d.ts +0 -1
  588. package/lib/typescript/src/dom/nodes/DrawingNode.d.ts +0 -14
  589. package/lib/typescript/src/dom/nodes/GroupNode.d.ts +0 -7
  590. package/lib/typescript/src/dom/nodes/LayerNode.d.ts +0 -8
  591. package/lib/typescript/src/dom/nodes/Node.d.ts +0 -34
  592. package/lib/typescript/src/dom/nodes/PaintNode.d.ts +0 -8
  593. package/lib/typescript/src/dom/nodes/RenderNode.d.ts +0 -26
  594. package/lib/typescript/src/dom/nodes/drawings/AtlasNode.d.ts +0 -8
  595. package/lib/typescript/src/dom/nodes/drawings/BackdropFilterNode.d.ts +0 -8
  596. package/lib/typescript/src/dom/nodes/drawings/Box.d.ts +0 -15
  597. package/lib/typescript/src/dom/nodes/drawings/CircleNode.d.ts +0 -9
  598. package/lib/typescript/src/dom/nodes/drawings/DiffRectNode.d.ts +0 -8
  599. package/lib/typescript/src/dom/nodes/drawings/FillNode.d.ts +0 -8
  600. package/lib/typescript/src/dom/nodes/drawings/ImageNode.d.ts +0 -25
  601. package/lib/typescript/src/dom/nodes/drawings/ImageSVG.d.ts +0 -13
  602. package/lib/typescript/src/dom/nodes/drawings/LineNode.d.ts +0 -8
  603. package/lib/typescript/src/dom/nodes/drawings/OvalNode.d.ts +0 -9
  604. package/lib/typescript/src/dom/nodes/drawings/ParagraphNode.d.ts +0 -8
  605. package/lib/typescript/src/dom/nodes/drawings/PatchNode.d.ts +0 -18
  606. package/lib/typescript/src/dom/nodes/drawings/PathNode.d.ts +0 -9
  607. package/lib/typescript/src/dom/nodes/drawings/PictureNode.d.ts +0 -8
  608. package/lib/typescript/src/dom/nodes/drawings/PointsNode.d.ts +0 -8
  609. package/lib/typescript/src/dom/nodes/drawings/RRectNode.d.ts +0 -10
  610. package/lib/typescript/src/dom/nodes/drawings/RectNode.d.ts +0 -9
  611. package/lib/typescript/src/dom/nodes/drawings/Text.d.ts +0 -30
  612. package/lib/typescript/src/dom/nodes/drawings/VerticesNode.d.ts +0 -9
  613. package/lib/typescript/src/dom/nodes/drawings/index.d.ts +0 -18
  614. package/lib/typescript/src/dom/nodes/paint/BlendNode.d.ts +0 -8
  615. package/lib/typescript/src/dom/nodes/paint/ColorFilters.d.ts +0 -35
  616. package/lib/typescript/src/dom/nodes/paint/ImageFilters.d.ts +0 -42
  617. package/lib/typescript/src/dom/nodes/paint/MaskFilters.d.ts +0 -8
  618. package/lib/typescript/src/dom/nodes/paint/PathEffects.d.ts +0 -39
  619. package/lib/typescript/src/dom/nodes/paint/Shaders.d.ts +0 -43
  620. package/lib/typescript/src/dom/nodes/paint/index.d.ts +0 -6
  621. package/lib/typescript/src/dom/types/DeclarationContext.d.ts +0 -29
  622. package/lib/typescript/src/dom/types/DrawingContext.d.ts +0 -22
  623. package/lib/typescript/src/renderer/DrawingContext.d.ts +0 -7
  624. package/lib/typescript/src/views/SkiaJSDomView.d.ts +0 -38
  625. package/lib/typescript/src/views/SkiaJSDomView.web.d.ts +0 -1
  626. package/src/dom/nodes/DrawingNode.ts +0 -74
  627. package/src/dom/nodes/GroupNode.ts +0 -19
  628. package/src/dom/nodes/LayerNode.ts +0 -37
  629. package/src/dom/nodes/Node.ts +0 -121
  630. package/src/dom/nodes/PaintNode.ts +0 -91
  631. package/src/dom/nodes/RenderNode.ts +0 -172
  632. package/src/dom/nodes/drawings/AtlasNode.ts +0 -24
  633. package/src/dom/nodes/drawings/BackdropFilterNode.ts +0 -37
  634. package/src/dom/nodes/drawings/Box.ts +0 -82
  635. package/src/dom/nodes/drawings/CircleNode.ts +0 -24
  636. package/src/dom/nodes/drawings/DiffRectNode.ts +0 -19
  637. package/src/dom/nodes/drawings/FillNode.ts +0 -18
  638. package/src/dom/nodes/drawings/ImageNode.ts +0 -49
  639. package/src/dom/nodes/drawings/ImageSVG.ts +0 -38
  640. package/src/dom/nodes/drawings/LineNode.ts +0 -19
  641. package/src/dom/nodes/drawings/OvalNode.ts +0 -23
  642. package/src/dom/nodes/drawings/ParagraphNode.ts +0 -22
  643. package/src/dom/nodes/drawings/PatchNode.ts +0 -54
  644. package/src/dom/nodes/drawings/PathNode.ts +0 -51
  645. package/src/dom/nodes/drawings/PictureNode.ts +0 -19
  646. package/src/dom/nodes/drawings/PointsNode.ts +0 -21
  647. package/src/dom/nodes/drawings/RRectNode.ts +0 -25
  648. package/src/dom/nodes/drawings/RectNode.ts +0 -23
  649. package/src/dom/nodes/drawings/Text.ts +0 -145
  650. package/src/dom/nodes/drawings/VerticesNode.ts +0 -35
  651. package/src/dom/nodes/drawings/index.ts +0 -18
  652. package/src/dom/nodes/paint/BlendNode.ts +0 -32
  653. package/src/dom/nodes/paint/ColorFilters.ts +0 -106
  654. package/src/dom/nodes/paint/ImageFilters.ts +0 -221
  655. package/src/dom/nodes/paint/MaskFilters.ts +0 -23
  656. package/src/dom/nodes/paint/PathEffects.ts +0 -139
  657. package/src/dom/nodes/paint/Shaders.ts +0 -233
  658. package/src/dom/nodes/paint/index.ts +0 -6
  659. package/src/dom/types/DeclarationContext.ts +0 -115
  660. package/src/dom/types/DrawingContext.ts +0 -322
  661. package/src/renderer/DrawingContext.ts +0 -8
  662. package/src/views/SkiaJSDomView.tsx +0 -143
  663. package/src/views/SkiaJSDomView.web.tsx +0 -1
@@ -1,14 +1,14 @@
1
- "worklet";
2
-
3
1
  import type { CircleDef, ScalarCircleDef } from "../../types";
4
2
 
5
3
  export const isCircleScalarDef = (def: CircleDef): def is ScalarCircleDef => {
4
+ "worklet";
6
5
  // We have an issue to check property existence on JSI backed instances
7
6
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
8
7
  return (def as any).cx !== undefined;
9
8
  };
10
9
 
11
10
  export const processCircle = (def: CircleDef) => {
11
+ "worklet";
12
12
  if (isCircleScalarDef(def)) {
13
13
  return { c: { x: def.cx, y: def.cy }, r: def.r };
14
14
  }
@@ -1,4 +1,4 @@
1
- "worklet";
2
-
3
- export const enumKey = <K extends string>(k: K) =>
4
- (k.charAt(0).toUpperCase() + k.slice(1)) as Capitalize<K>;
1
+ export const enumKey = <K extends string>(k: K) => {
2
+ "worklet";
3
+ return (k.charAt(0).toUpperCase() + k.slice(1)) as Capitalize<K>;
4
+ };
@@ -1,5 +1,3 @@
1
- "worklet";
2
-
3
1
  import { exhaustiveCheck } from "../../../renderer/typeddash";
4
2
  import type { SkRect } from "../../../skia/types";
5
3
  import type { Fit } from "../../types";
@@ -10,6 +8,7 @@ export interface Size {
10
8
  }
11
9
 
12
10
  export const size = (width = 0, height = 0) => {
11
+ "worklet";
13
12
  return { width, height };
14
13
  };
15
14
 
@@ -22,6 +21,7 @@ export const rect2rect = (
22
21
  { scaleX: number },
23
22
  { scaleY: number }
24
23
  ] => {
24
+ "worklet";
25
25
  const scaleX = dst.width / src.width;
26
26
  const scaleY = dst.height / src.height;
27
27
  const translateX = dst.x - src.x * scaleX;
@@ -33,6 +33,7 @@ const inscribe = (
33
33
  { width, height }: Size,
34
34
  rect: { x: number; y: number; width: number; height: number }
35
35
  ) => {
36
+ "worklet";
36
37
  const halfWidthDelta = (rect.width - width) / 2.0;
37
38
  const halfHeightDelta = (rect.height - height) / 2.0;
38
39
  return {
@@ -44,6 +45,7 @@ const inscribe = (
44
45
  };
45
46
 
46
47
  const applyBoxFit = (fit: Fit, input: Size, output: Size) => {
48
+ "worklet";
47
49
  let src = size(),
48
50
  dst = size();
49
51
  if (
@@ -112,6 +114,7 @@ export const fitRects = (
112
114
  rect: SkRect,
113
115
  { x, y, width, height }: SkRect
114
116
  ) => {
117
+ "worklet";
115
118
  const sizes = applyBoxFit(
116
119
  fit,
117
120
  { width: rect.width, height: rect.height },
@@ -1,5 +1,3 @@
1
- "worklet";
2
-
3
1
  import type { Skia, SkRect, Transforms3d, Vector } from "../../../skia/types";
4
2
  import { TileMode } from "../../../skia/types";
5
3
  import type { GradientProps, ImageShaderProps } from "../../types";
@@ -7,18 +5,22 @@ import type { GradientProps, ImageShaderProps } from "../../types";
7
5
  import { enumKey } from "./Enum";
8
6
  import { processTransformProps } from "./Transform";
9
7
 
10
- export const transformOrigin = (origin: Vector, transform: Transforms3d) => [
11
- { translateX: origin.x },
12
- { translateY: origin.y },
13
- ...transform,
14
- { translateX: -origin.x },
15
- { translateY: -origin.y },
16
- ];
8
+ export const transformOrigin = (origin: Vector, transform: Transforms3d) => {
9
+ "worklet";
10
+ return [
11
+ { translateX: origin.x },
12
+ { translateY: origin.y },
13
+ ...transform,
14
+ { translateX: -origin.x },
15
+ { translateY: -origin.y },
16
+ ];
17
+ };
17
18
 
18
19
  export const processGradientProps = (
19
20
  Skia: Skia,
20
21
  { colors, positions, mode, flags, ...transform }: GradientProps
21
22
  ) => {
23
+ "worklet";
22
24
  const localMatrix = Skia.Matrix();
23
25
  processTransformProps(localMatrix, transform);
24
26
  return {
@@ -34,6 +36,7 @@ export const getRect = (
34
36
  Skia: Skia,
35
37
  props: Omit<ImageShaderProps, "tx" | "ty" | "fm" | "mm" | "fit" | "image">
36
38
  ): SkRect | undefined => {
39
+ "worklet";
37
40
  const { x, y, width, height } = props;
38
41
  if (props.rect) {
39
42
  return props.rect;
@@ -1,10 +1,9 @@
1
- "worklet";
2
-
3
1
  import type { Skia } from "../../../skia/types";
4
2
  import { isPath } from "../../../skia/types";
5
3
  import type { PathDef } from "../../types";
6
4
 
7
5
  export const processPath = (Skia: Skia, rawPath: PathDef) => {
6
+ "worklet";
8
7
  const path =
9
8
  typeof rawPath === "string"
10
9
  ? Skia.Path.MakeFromSVGString(rawPath)
@@ -17,5 +16,6 @@ export const processPath = (Skia: Skia, rawPath: PathDef) => {
17
16
 
18
17
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
19
18
  export const isPathDef = (def: any): def is PathDef => {
19
+ "worklet";
20
20
  return typeof def === "string" || isPath(def);
21
21
  };
@@ -1,9 +1,8 @@
1
- "worklet";
2
-
3
1
  import type { Skia, Vector } from "../../../skia/types";
4
2
  import type { Radius } from "../../types";
5
3
 
6
4
  export const processRadius = (Skia: Skia, radius: Radius): Vector => {
5
+ "worklet";
7
6
  if (typeof radius === "number") {
8
7
  return Skia.Point(radius, radius);
9
8
  }
@@ -1,5 +1,3 @@
1
- "worklet";
2
-
3
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
4
2
  import type { Skia, SkRect, SkRRect, Vector } from "../../../skia/types";
5
3
  import type { RectCtor, RectDef, RRectCtor, RRectDef } from "../../types";
@@ -7,6 +5,7 @@ import type { RectCtor, RectDef, RRectCtor, RRectDef } from "../../types";
7
5
  import { processRadius } from "./Radius";
8
6
 
9
7
  export const isEdge = (pos: Vector, b: SkRect) => {
8
+ "worklet";
10
9
  return (
11
10
  pos.x === b.x || pos.y === b.y || pos.x === b.width || pos.y === b.height
12
11
  );
@@ -14,14 +13,17 @@ export const isEdge = (pos: Vector, b: SkRect) => {
14
13
 
15
14
  // We have an issue to check property existence on JSI backed instances
16
15
  const isRRectCtor = (def: RRectDef): def is RRectCtor => {
16
+ "worklet";
17
17
  return (def as any).rect === undefined;
18
18
  };
19
19
  // We have an issue to check property existence on JSI backed instances
20
20
  const isRectCtor = (def: RectDef): def is RectCtor => {
21
+ "worklet";
21
22
  return (def as any).rect === undefined;
22
23
  };
23
24
 
24
25
  export const processRect = (Skia: Skia, def: RectDef) => {
26
+ "worklet";
25
27
  if (isRectCtor(def)) {
26
28
  return Skia.XYWHRect(def.x ?? 0, def.y ?? 0, def.width, def.height);
27
29
  } else {
@@ -30,6 +32,7 @@ export const processRect = (Skia: Skia, def: RectDef) => {
30
32
  };
31
33
 
32
34
  export const processRRect = (Skia: Skia, def: RRectDef) => {
35
+ "worklet";
33
36
  if (isRRectCtor(def)) {
34
37
  const r = processRadius(Skia, def.r ?? 0);
35
38
  return Skia.RRectXY(
@@ -50,6 +53,7 @@ export const inflate = (
50
53
  tx = 0,
51
54
  ty = 0
52
55
  ) => {
56
+ "worklet";
53
57
  return Skia.RRectXY(
54
58
  Skia.XYWHRect(
55
59
  box.rect.x - dx + tx,
@@ -70,5 +74,6 @@ export const deflate = (
70
74
  tx = 0,
71
75
  ty = 0
72
76
  ) => {
77
+ "worklet";
73
78
  return inflate(Skia, box, -dx, -dy, tx, ty);
74
79
  };
@@ -1,10 +1,10 @@
1
- "worklet";
2
-
3
1
  import type { TransformProps } from "../../types";
4
2
  import type { Skia, SkMatrix } from "../../../skia/types";
5
3
  import { processTransform } from "../../../skia/types";
6
4
 
7
5
  export const processTransformProps = (m3: SkMatrix, props: TransformProps) => {
6
+ "worklet";
7
+
8
8
  const { transform, origin, matrix } = props;
9
9
  if (matrix) {
10
10
  if (origin) {
@@ -26,6 +26,8 @@ export const processTransformProps = (m3: SkMatrix, props: TransformProps) => {
26
26
  };
27
27
 
28
28
  export const processTransformProps2 = (Skia: Skia, props: TransformProps) => {
29
+ "worklet";
30
+
29
31
  const { transform, origin, matrix } = props;
30
32
  if (matrix) {
31
33
  const m3 = Skia.Matrix();
@@ -1,7 +1,6 @@
1
1
  import type { GroupProps } from "./Common";
2
2
  import type { NodeType } from "./NodeType";
3
- import type { DeclarationContext } from "./DeclarationContext";
4
- import type { DrawingContext } from "./DrawingContext";
3
+ import type { DeclarationContext } from "../../sksg/DeclarationContext";
5
4
 
6
5
  export interface Node<P> {
7
6
  type: NodeType;
@@ -25,6 +24,4 @@ export interface DeclarationNode<P> extends Node<P> {
25
24
  setInvalidate(invalidate: Invalidate): void;
26
25
  }
27
26
 
28
- export interface RenderNode<P extends GroupProps> extends Node<P> {
29
- render(ctx: DrawingContext): void;
30
- }
27
+ export type RenderNode<P extends GroupProps> = Node<P>;
@@ -1,5 +1,3 @@
1
- export * from "./DrawingContext";
2
- export * from "./DeclarationContext";
3
1
  export * from "./Node";
4
2
  export * from "./NodeType";
5
3
  export * from "./SkDOM";
@@ -4,9 +4,8 @@ import CanvasKitInit from "canvaskit-wasm/bin/full/canvaskit";
4
4
  import type { ReactNode } from "react";
5
5
 
6
6
  import { JsiSkApi } from "../skia/web";
7
- import { SkiaRoot } from "../renderer/Reconciler";
8
- import { JsiDrawingContext } from "../dom/types";
9
7
  import type { SkSurface } from "../skia";
8
+ import { SkiaSGRoot } from "../sksg/Reconciler";
10
9
 
11
10
  export * from "../renderer/components";
12
11
 
@@ -31,11 +30,10 @@ export const getSkiaExports = () => {
31
30
  };
32
31
 
33
32
  export const drawOffscreen = (surface: SkSurface, element: ReactNode) => {
34
- const root = new SkiaRoot(Skia, false);
33
+ const root = new SkiaSGRoot(Skia);
35
34
  root.render(element);
36
35
  const canvas = surface.getCanvas();
37
- const ctx = new JsiDrawingContext(Skia, canvas);
38
- root.dom.render(ctx);
36
+ root.drawOnCanvas(canvas);
39
37
  root.unmount();
40
38
  surface.flush();
41
39
  return surface.makeImageSnapshot();
package/src/index.ts CHANGED
@@ -2,6 +2,7 @@ import "./skia/NativeSetup";
2
2
  export { JsiSkImage } from "./skia/web/JsiSkImage";
3
3
  export * from "./renderer";
4
4
  export * from "./renderer/Canvas";
5
+ export * from "./renderer/Canvas2";
5
6
  export * from "./renderer/Offscreen";
6
7
  export * from "./views";
7
8
  export * from "./skia";
@@ -15,12 +15,9 @@ import type {
15
15
  import type { LayoutChangeEvent } from "react-native";
16
16
 
17
17
  import { SkiaDomView } from "../views";
18
- import { Skia } from "../skia/Skia";
19
18
  import type { SkiaBaseViewProps } from "../views";
20
- import { SkiaJSDomView } from "../views/SkiaJSDomView";
21
19
 
22
20
  import { SkiaRoot } from "./Reconciler";
23
- import { NATIVE_DOM } from "./HostComponents";
24
21
 
25
22
  export const useCanvasRef = () => useRef<SkiaDomView>(null);
26
23
 
@@ -74,7 +71,7 @@ export const Canvas = forwardRef<SkiaDomView, CanvasProps>(
74
71
  }, [innerRef]);
75
72
 
76
73
  const root = useMemo(
77
- () => new SkiaRoot(Skia, NATIVE_DOM, redraw, getNativeId),
74
+ () => new SkiaRoot(redraw, getNativeId),
78
75
  [redraw, getNativeId]
79
76
  );
80
77
 
@@ -89,33 +86,17 @@ export const Canvas = forwardRef<SkiaDomView, CanvasProps>(
89
86
  };
90
87
  }, [root]);
91
88
 
92
- if (NATIVE_DOM) {
93
- return (
94
- <SkiaDomView
95
- ref={ref}
96
- style={style}
97
- root={root.dom}
98
- onLayout={onLayout}
99
- debug={debug}
100
- mode={mode}
101
- {...props}
102
- />
103
- );
104
- } else {
105
- return (
106
- <SkiaJSDomView
107
- Skia={Skia}
108
- mode={mode}
109
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
110
- ref={ref as any}
111
- style={style}
112
- root={root.dom}
113
- onLayout={onLayout}
114
- debug={debug}
115
- {...props}
116
- />
117
- );
118
- }
89
+ return (
90
+ <SkiaDomView
91
+ ref={ref}
92
+ style={style}
93
+ root={root.dom}
94
+ onLayout={onLayout}
95
+ debug={debug}
96
+ mode={mode}
97
+ {...props}
98
+ />
99
+ );
119
100
  }
120
101
  ) as FunctionComponent<CanvasProps & React.RefAttributes<SkiaDomView>>;
121
102
 
@@ -0,0 +1,134 @@
1
+ import {
2
+ forwardRef,
3
+ useCallback,
4
+ useEffect,
5
+ useImperativeHandle,
6
+ useMemo,
7
+ useRef,
8
+ } from "react";
9
+ import type { LayoutChangeEvent, ViewProps } from "react-native";
10
+ import type { SharedValue } from "react-native-reanimated";
11
+
12
+ import { SkiaViewNativeId } from "../views/SkiaViewNativeId";
13
+ import type { SkRect, SkSize } from "../skia/types";
14
+ import { SkiaSGRoot } from "../sksg/Reconciler";
15
+ import { Skia } from "../skia";
16
+ import type { SkiaBaseViewProps } from "../views";
17
+ import { SkiaPictureView } from "../views/SkiaPictureView.web";
18
+
19
+ // TODO: no need to go through the JS thread for this
20
+ const useOnSizeEvent = (
21
+ resultValue: SkiaBaseViewProps["onSize"],
22
+ onLayout?: (event: LayoutChangeEvent) => void
23
+ ) => {
24
+ return useCallback(
25
+ (event: LayoutChangeEvent) => {
26
+ if (onLayout) {
27
+ onLayout(event);
28
+ }
29
+ const { width, height } = event.nativeEvent.layout;
30
+
31
+ if (resultValue) {
32
+ resultValue.value = { width, height };
33
+ }
34
+ },
35
+ [onLayout, resultValue]
36
+ );
37
+ };
38
+
39
+ export interface CanvasProps extends ViewProps {
40
+ debug?: boolean;
41
+ opaque?: boolean;
42
+ onSize?: SharedValue<SkSize>;
43
+ mode?: "continuous" | "default";
44
+ }
45
+
46
+ export const Canvas = forwardRef(
47
+ (
48
+ {
49
+ mode,
50
+ debug,
51
+ opaque,
52
+ children,
53
+ onSize,
54
+ onLayout: _onLayout,
55
+ ...viewProps
56
+ }: CanvasProps,
57
+ ref
58
+ ) => {
59
+ const viewRef = useRef<SkiaPictureView>(null);
60
+ const rafId = useRef<number | null>(null);
61
+ const onLayout = useOnSizeEvent(onSize, _onLayout);
62
+ // Native ID
63
+ const nativeId = useMemo(() => {
64
+ return SkiaViewNativeId.current++;
65
+ }, []);
66
+
67
+ // Root
68
+ const root = useMemo(() => new SkiaSGRoot(Skia), []);
69
+
70
+ // Render effects
71
+ useEffect(() => {
72
+ root.render(children);
73
+ if (viewRef.current) {
74
+ viewRef.current.setPicture(root.getPicture());
75
+ }
76
+ }, [children, root]);
77
+
78
+ useEffect(() => {
79
+ return () => {
80
+ root.unmount();
81
+ };
82
+ }, [root]);
83
+
84
+ const requestRedraw = useCallback(() => {
85
+ rafId.current = requestAnimationFrame(() => {
86
+ root.render(children);
87
+ if (viewRef.current) {
88
+ viewRef.current.setPicture(root.getPicture());
89
+ }
90
+ if (mode === "continuous") {
91
+ requestRedraw();
92
+ }
93
+ });
94
+ }, [children, mode, root]);
95
+
96
+ useEffect(() => {
97
+ if (mode === "continuous") {
98
+ requestRedraw();
99
+ }
100
+ return () => {
101
+ if (rafId.current !== null) {
102
+ cancelAnimationFrame(rafId.current);
103
+ }
104
+ };
105
+ }, [mode, requestRedraw]);
106
+
107
+ // Component methods
108
+ useImperativeHandle(ref, () => ({
109
+ makeImageSnapshot: (rect?: SkRect) => {
110
+ return SkiaViewApi.makeImageSnapshot(nativeId, rect);
111
+ },
112
+ makeImageSnapshotAsync: (rect?: SkRect) => {
113
+ return SkiaViewApi.makeImageSnapshotAsync(nativeId, rect);
114
+ },
115
+ redraw: () => {
116
+ viewRef.current?.redraw();
117
+ },
118
+ getNativeId: () => {
119
+ return nativeId;
120
+ },
121
+ }));
122
+ return (
123
+ <SkiaPictureView
124
+ ref={viewRef}
125
+ collapsable={false}
126
+ nativeID={`${nativeId}`}
127
+ debug={debug}
128
+ opaque={opaque}
129
+ onLayout={onLayout}
130
+ {...viewProps}
131
+ />
132
+ );
133
+ }
134
+ );
@@ -0,0 +1,128 @@
1
+ import {
2
+ forwardRef,
3
+ useCallback,
4
+ useEffect,
5
+ useImperativeHandle,
6
+ useMemo,
7
+ useRef,
8
+ } from "react";
9
+ import type { LayoutChangeEvent, ViewProps } from "react-native";
10
+ import type { SharedValue } from "react-native-reanimated";
11
+
12
+ import { SkiaViewNativeId } from "../views/SkiaViewNativeId";
13
+ import SkiaPictureViewNativeComponent from "../specs/SkiaPictureViewNativeComponent";
14
+ import type { SkRect, SkSize } from "../skia/types";
15
+ import { SkiaSGRoot } from "../sksg/Reconciler";
16
+ import { Skia } from "../skia";
17
+ import type { SkiaBaseViewProps } from "../views";
18
+
19
+ const NativeSkiaPictureView = SkiaPictureViewNativeComponent;
20
+
21
+ // TODO: no need to go through the JS thread for this
22
+ const useOnSizeEvent = (
23
+ resultValue: SkiaBaseViewProps["onSize"],
24
+ onLayout?: (event: LayoutChangeEvent) => void
25
+ ) => {
26
+ return useCallback(
27
+ (event: LayoutChangeEvent) => {
28
+ if (onLayout) {
29
+ onLayout(event);
30
+ }
31
+ const { width, height } = event.nativeEvent.layout;
32
+
33
+ if (resultValue) {
34
+ resultValue.value = { width, height };
35
+ }
36
+ },
37
+ [onLayout, resultValue]
38
+ );
39
+ };
40
+
41
+ export interface Canvas2Props extends ViewProps {
42
+ debug?: boolean;
43
+ opaque?: boolean;
44
+ onSize?: SharedValue<SkSize>;
45
+ mode?: "continuous" | "default";
46
+ }
47
+
48
+ export const Canvas2 = forwardRef(
49
+ (
50
+ {
51
+ mode,
52
+ debug,
53
+ opaque,
54
+ children,
55
+ onSize,
56
+ onLayout: _onLayout,
57
+ ...viewProps
58
+ }: Canvas2Props,
59
+ ref
60
+ ) => {
61
+ const rafId = useRef<number | null>(null);
62
+ const onLayout = useOnSizeEvent(onSize, _onLayout);
63
+ // Native ID
64
+ const nativeId = useMemo(() => {
65
+ return SkiaViewNativeId.current++;
66
+ }, []);
67
+
68
+ // Root
69
+ const root = useMemo(() => new SkiaSGRoot(Skia, nativeId), [nativeId]);
70
+
71
+ // Render effects
72
+ useEffect(() => {
73
+ root.render(children);
74
+ }, [children, root]);
75
+
76
+ useEffect(() => {
77
+ return () => {
78
+ root.unmount();
79
+ };
80
+ }, [root]);
81
+
82
+ const requestRedraw = useCallback(() => {
83
+ rafId.current = requestAnimationFrame(() => {
84
+ root.render(children);
85
+ if (mode === "continuous") {
86
+ requestRedraw();
87
+ }
88
+ });
89
+ }, [children, mode, root]);
90
+
91
+ useEffect(() => {
92
+ if (mode === "continuous") {
93
+ requestRedraw();
94
+ }
95
+ return () => {
96
+ if (rafId.current !== null) {
97
+ cancelAnimationFrame(rafId.current);
98
+ }
99
+ };
100
+ }, [mode, requestRedraw]);
101
+
102
+ // Component methods
103
+ useImperativeHandle(ref, () => ({
104
+ makeImageSnapshot: (rect?: SkRect) => {
105
+ return SkiaViewApi.makeImageSnapshot(nativeId, rect);
106
+ },
107
+ makeImageSnapshotAsync: (rect?: SkRect) => {
108
+ return SkiaViewApi.makeImageSnapshotAsync(nativeId, rect);
109
+ },
110
+ redraw: () => {
111
+ SkiaViewApi.requestRedraw(nativeId);
112
+ },
113
+ getNativeId: () => {
114
+ return nativeId;
115
+ },
116
+ }));
117
+ return (
118
+ <NativeSkiaPictureView
119
+ collapsable={false}
120
+ nativeID={`${nativeId}`}
121
+ debug={debug}
122
+ opaque={opaque}
123
+ onLayout={onLayout}
124
+ {...viewProps}
125
+ />
126
+ );
127
+ }
128
+ );
@@ -0,0 +1,6 @@
1
+ import type { CanvasProps } from "./Canvas";
2
+ import { Canvas } from "./Canvas";
3
+
4
+ export type Canvas2Props = CanvasProps;
5
+
6
+ export const Canvas2 = Canvas;
@@ -1,30 +1,18 @@
1
1
  import { JsiSkDOM } from "../dom/nodes";
2
- import type {
3
- GroupProps,
4
- DrawingContext,
5
- RenderNode,
6
- SkDOM,
7
- } from "../dom/types";
8
- import type { Skia } from "../skia/types";
2
+ import type { Node, SkDOM } from "../dom/types";
9
3
 
10
4
  export class Container {
11
- private _root: RenderNode<GroupProps>;
5
+ private _root: Node<unknown>;
12
6
  public Sk: SkDOM;
13
7
  public unmounted = false;
14
8
  constructor(
15
- Skia: Skia,
16
9
  public redraw: () => void = () => {},
17
- public getNativeId: () => number = () => 0,
18
- native: boolean
10
+ public getNativeId: () => number = () => 0
19
11
  ) {
20
- this.Sk = new JsiSkDOM({ Skia }, native);
12
+ this.Sk = new JsiSkDOM();
21
13
  this._root = this.Sk.Group();
22
14
  }
23
15
 
24
- draw(ctx: DrawingContext) {
25
- this._root.render(ctx);
26
- }
27
-
28
16
  get root() {
29
17
  return this._root;
30
18
  }
@@ -57,23 +57,15 @@ import type {
57
57
  BlendProps,
58
58
  MorphologyImageFilterProps,
59
59
  } from "../dom/types/ImageFilters";
60
- import type { SkRect, SkRRect } from "../skia/types";
61
- import type { JsiDrawingNode } from "../dom/nodes/DrawingNode";
62
60
 
63
61
  import type { Container } from "./Container";
64
62
  import { exhaustiveCheck } from "./typeddash";
65
63
  import type { SkiaProps } from "./processors";
66
64
 
67
- // This flag should only be turned on for debugging/testing
68
- const shouldUseJSDomOnNative = false;
69
- export const NATIVE_DOM = shouldUseJSDomOnNative ? false : !!global.SkiaDomApi;
70
-
71
65
  declare global {
72
66
  var SkiaDomApi: {
73
- RectNode: (props: RectProps) => JsiDrawingNode<RectProps, SkRect>;
74
- RRectNode: (
75
- props: RoundedRectProps
76
- ) => JsiDrawingNode<RoundedRectProps, SkRRect>;
67
+ RectNode: (props: RectProps) => RenderNode<RectProps>;
68
+ RRectNode: (props: RoundedRectProps) => RenderNode<RoundedRectProps>;
77
69
  GroupNode: (props: GroupProps) => RenderNode<GroupProps>;
78
70
  PaintNode: (props: PaintProps) => DeclarationNode<PaintProps>;
79
71
  FillNode: (props: PaintProps) => RenderNode<PaintProps>;