@shopify/react-native-skia 1.3.12 → 1.3.13

Sign up to get free protection for your applications and to get access to all the features.
Files changed (616) hide show
  1. package/lib/commonjs/__tests__/globalSetup.d.ts +9 -0
  2. package/lib/commonjs/__tests__/globalTeardown.d.ts +2 -0
  3. package/lib/commonjs/__tests__/setup.d.ts +18 -0
  4. package/lib/commonjs/dom/__tests__/Compose.spec.d.ts +1 -0
  5. package/lib/commonjs/dom/__tests__/Demos.spec.d.ts +1 -0
  6. package/lib/commonjs/dom/__tests__/DrawingContext.spec.d.ts +1 -0
  7. package/lib/commonjs/dom/__tests__/Drawings.spec.d.ts +1 -0
  8. package/lib/commonjs/dom/__tests__/Group.spec.d.ts +1 -0
  9. package/lib/commonjs/dom/__tests__/Paint.spec.d.ts +1 -0
  10. package/lib/commonjs/dom/__tests__/RenderNodes.spec.d.ts +1 -0
  11. package/lib/commonjs/dom/__tests__/Shaders.spec.d.ts +1 -0
  12. package/lib/commonjs/renderer/__tests__/Data.spec.d.ts +1 -0
  13. package/lib/commonjs/renderer/__tests__/Drawings.spec.d.ts +1 -0
  14. package/lib/commonjs/renderer/__tests__/FitBox.spec.d.ts +1 -0
  15. package/lib/commonjs/renderer/__tests__/Glyphs.spec.d.ts +1 -0
  16. package/lib/commonjs/renderer/__tests__/Image.spec.d.ts +1 -0
  17. package/lib/commonjs/renderer/__tests__/Paths.spec.d.ts +1 -0
  18. package/lib/commonjs/renderer/__tests__/Picture.spec.d.ts +1 -0
  19. package/lib/commonjs/renderer/__tests__/Simple.spec.d.ts +1 -0
  20. package/lib/commonjs/renderer/__tests__/SkiaDOM.spec.d.ts +1 -0
  21. package/lib/commonjs/renderer/__tests__/Surfaces.spec.d.ts +1 -0
  22. package/lib/commonjs/renderer/__tests__/Text.spec.d.ts +1 -0
  23. package/lib/commonjs/renderer/__tests__/TouchHandler.spec.d.ts +1 -0
  24. package/lib/commonjs/renderer/__tests__/Transform.spec.d.ts +1 -0
  25. package/lib/commonjs/renderer/__tests__/documentation/Group.spec.d.ts +1 -0
  26. package/lib/commonjs/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +1 -0
  27. package/lib/commonjs/renderer/__tests__/documentation/paint/Overview.spec.d.ts +1 -0
  28. package/lib/commonjs/renderer/__tests__/documentation/shapes/Box.spec.d.ts +1 -0
  29. package/lib/commonjs/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +1 -0
  30. package/lib/commonjs/renderer/__tests__/e2e/Atlas.spec.d.ts +1 -0
  31. package/lib/commonjs/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +1 -0
  32. package/lib/commonjs/renderer/__tests__/e2e/Blending.spec.d.ts +1 -0
  33. package/lib/commonjs/renderer/__tests__/e2e/Blur.spec.d.ts +1 -0
  34. package/lib/commonjs/renderer/__tests__/e2e/Box.spec.d.ts +1 -0
  35. package/lib/commonjs/renderer/__tests__/e2e/ColorFilters.spec.d.ts +1 -0
  36. package/lib/commonjs/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +1 -0
  37. package/lib/commonjs/renderer/__tests__/e2e/CoonPatch.spec.d.ts +1 -0
  38. package/lib/commonjs/renderer/__tests__/e2e/DataEncoding.spec.d.ts +1 -0
  39. package/lib/commonjs/renderer/__tests__/e2e/Drawings.spec.d.ts +1 -0
  40. package/lib/commonjs/renderer/__tests__/e2e/FontMgr.spec.d.ts +1 -0
  41. package/lib/commonjs/renderer/__tests__/e2e/Gradient.spec.d.ts +1 -0
  42. package/lib/commonjs/renderer/__tests__/e2e/Group.spec.d.ts +1 -0
  43. package/lib/commonjs/renderer/__tests__/e2e/Image.spec.d.ts +1 -0
  44. package/lib/commonjs/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +1 -0
  45. package/lib/commonjs/renderer/__tests__/e2e/ImageFilters.spec.d.ts +1 -0
  46. package/lib/commonjs/renderer/__tests__/e2e/Mask.spec.d.ts +1 -0
  47. package/lib/commonjs/renderer/__tests__/e2e/Matrix4.spec.d.ts +1 -0
  48. package/lib/commonjs/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +1 -0
  49. package/lib/commonjs/renderer/__tests__/e2e/Offscreen.spec.d.ts +1 -0
  50. package/lib/commonjs/renderer/__tests__/e2e/Opacity.spec.d.ts +1 -0
  51. package/lib/commonjs/renderer/__tests__/e2e/Paint.spec.d.ts +1 -0
  52. package/lib/commonjs/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +1 -0
  53. package/lib/commonjs/renderer/__tests__/e2e/Paragraphs.spec.d.ts +1 -0
  54. package/lib/commonjs/renderer/__tests__/e2e/PathEffects.spec.d.ts +1 -0
  55. package/lib/commonjs/renderer/__tests__/e2e/Paths.spec.d.ts +1 -0
  56. package/lib/commonjs/renderer/__tests__/e2e/Picture.spec.d.ts +1 -0
  57. package/lib/commonjs/renderer/__tests__/e2e/Point.spec.d.ts +1 -0
  58. package/lib/commonjs/renderer/__tests__/e2e/Rect.spec.d.ts +1 -0
  59. package/lib/commonjs/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +1 -0
  60. package/lib/commonjs/renderer/__tests__/e2e/SDF.spec.d.ts +1 -0
  61. package/lib/commonjs/renderer/__tests__/e2e/SVG.spec.d.ts +1 -0
  62. package/lib/commonjs/renderer/__tests__/e2e/Shader.spec.d.ts +1 -0
  63. package/lib/commonjs/renderer/__tests__/e2e/Snapshot.spec.d.ts +1 -0
  64. package/lib/commonjs/renderer/__tests__/e2e/Surfaces.spec.d.ts +1 -0
  65. package/lib/commonjs/renderer/__tests__/e2e/Text.spec.d.ts +1 -0
  66. package/lib/commonjs/renderer/__tests__/e2e/TextPath.spec.d.ts +1 -0
  67. package/lib/commonjs/renderer/__tests__/e2e/Transforms.spec.d.ts +1 -0
  68. package/lib/commonjs/renderer/__tests__/e2e/Vertices.spec.d.ts +1 -0
  69. package/lib/commonjs/renderer/__tests__/e2e/Video.d.ts +1 -0
  70. package/lib/commonjs/renderer/__tests__/e2e/setup/Paragraph.d.ts +19 -0
  71. package/lib/commonjs/renderer/__tests__/e2e/setup/SVG.d.ts +12 -0
  72. package/lib/commonjs/renderer/__tests__/e2e/setup/SkiaObject.d.ts +11 -0
  73. package/lib/commonjs/renderer/__tests__/e2e/setup/index.d.ts +3 -0
  74. package/lib/commonjs/renderer/__tests__/examples/BlendModes.spec.d.ts +1 -0
  75. package/lib/commonjs/renderer/__tests__/setup.d.ts +66 -0
  76. package/lib/commonjs/skia/__tests__/ColorFilter.spec.d.ts +1 -0
  77. package/lib/commonjs/skia/__tests__/Data.spec.d.ts +1 -0
  78. package/lib/commonjs/skia/__tests__/Drawings.spec.d.ts +1 -0
  79. package/lib/commonjs/skia/__tests__/Enums.spec.d.ts +1 -0
  80. package/lib/commonjs/skia/__tests__/Geometry.spec.d.ts +1 -0
  81. package/lib/commonjs/skia/__tests__/ImageFilter.spec.d.ts +1 -0
  82. package/lib/commonjs/skia/__tests__/Mock.spec.d.ts +0 -0
  83. package/lib/commonjs/skia/__tests__/Paint.spec.d.ts +1 -0
  84. package/lib/commonjs/skia/__tests__/Path.spec.d.ts +1 -0
  85. package/lib/commonjs/skia/__tests__/RuntimeEffect.spec.d.ts +1 -0
  86. package/lib/commonjs/skia/__tests__/Shader.spec.d.ts +1 -0
  87. package/lib/commonjs/skia/__tests__/Text.spec.d.ts +1 -0
  88. package/lib/commonjs/skia/__tests__/Transform.spec.d.ts +1 -0
  89. package/lib/commonjs/skia/__tests__/Vertices.spec.d.ts +1 -0
  90. package/lib/commonjs/skia/__tests__/setup.d.ts +19 -0
  91. package/lib/module/__tests__/globalSetup.d.ts +9 -0
  92. package/lib/module/__tests__/globalTeardown.d.ts +2 -0
  93. package/lib/module/__tests__/setup.d.ts +18 -0
  94. package/lib/module/dom/__tests__/Compose.spec.d.ts +1 -0
  95. package/lib/module/dom/__tests__/Demos.spec.d.ts +1 -0
  96. package/lib/module/dom/__tests__/DrawingContext.spec.d.ts +1 -0
  97. package/lib/module/dom/__tests__/Drawings.spec.d.ts +1 -0
  98. package/lib/module/dom/__tests__/Group.spec.d.ts +1 -0
  99. package/lib/module/dom/__tests__/Paint.spec.d.ts +1 -0
  100. package/lib/module/dom/__tests__/RenderNodes.spec.d.ts +1 -0
  101. package/lib/module/dom/__tests__/Shaders.spec.d.ts +1 -0
  102. package/lib/module/renderer/__tests__/Data.spec.d.ts +1 -0
  103. package/lib/module/renderer/__tests__/Drawings.spec.d.ts +1 -0
  104. package/lib/module/renderer/__tests__/FitBox.spec.d.ts +1 -0
  105. package/lib/module/renderer/__tests__/Glyphs.spec.d.ts +1 -0
  106. package/lib/module/renderer/__tests__/Image.spec.d.ts +1 -0
  107. package/lib/module/renderer/__tests__/Paths.spec.d.ts +1 -0
  108. package/lib/module/renderer/__tests__/Picture.spec.d.ts +1 -0
  109. package/lib/module/renderer/__tests__/Simple.spec.d.ts +1 -0
  110. package/lib/module/renderer/__tests__/SkiaDOM.spec.d.ts +1 -0
  111. package/lib/module/renderer/__tests__/Surfaces.spec.d.ts +1 -0
  112. package/lib/module/renderer/__tests__/Text.spec.d.ts +1 -0
  113. package/lib/module/renderer/__tests__/TouchHandler.spec.d.ts +1 -0
  114. package/lib/module/renderer/__tests__/Transform.spec.d.ts +1 -0
  115. package/lib/module/renderer/__tests__/documentation/Group.spec.d.ts +1 -0
  116. package/lib/module/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +1 -0
  117. package/lib/module/renderer/__tests__/documentation/paint/Overview.spec.d.ts +1 -0
  118. package/lib/module/renderer/__tests__/documentation/shapes/Box.spec.d.ts +1 -0
  119. package/lib/module/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +1 -0
  120. package/lib/module/renderer/__tests__/e2e/Atlas.spec.d.ts +1 -0
  121. package/lib/module/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +1 -0
  122. package/lib/module/renderer/__tests__/e2e/Blending.spec.d.ts +1 -0
  123. package/lib/module/renderer/__tests__/e2e/Blur.spec.d.ts +1 -0
  124. package/lib/module/renderer/__tests__/e2e/Box.spec.d.ts +1 -0
  125. package/lib/module/renderer/__tests__/e2e/ColorFilters.spec.d.ts +1 -0
  126. package/lib/module/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +1 -0
  127. package/lib/module/renderer/__tests__/e2e/CoonPatch.spec.d.ts +1 -0
  128. package/lib/module/renderer/__tests__/e2e/DataEncoding.spec.d.ts +1 -0
  129. package/lib/module/renderer/__tests__/e2e/Drawings.spec.d.ts +1 -0
  130. package/lib/module/renderer/__tests__/e2e/FontMgr.spec.d.ts +1 -0
  131. package/lib/module/renderer/__tests__/e2e/Gradient.spec.d.ts +1 -0
  132. package/lib/module/renderer/__tests__/e2e/Group.spec.d.ts +1 -0
  133. package/lib/module/renderer/__tests__/e2e/Image.spec.d.ts +1 -0
  134. package/lib/module/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +1 -0
  135. package/lib/module/renderer/__tests__/e2e/ImageFilters.spec.d.ts +1 -0
  136. package/lib/module/renderer/__tests__/e2e/Mask.spec.d.ts +1 -0
  137. package/lib/module/renderer/__tests__/e2e/Matrix4.spec.d.ts +1 -0
  138. package/lib/module/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +1 -0
  139. package/lib/module/renderer/__tests__/e2e/Offscreen.spec.d.ts +1 -0
  140. package/lib/module/renderer/__tests__/e2e/Opacity.spec.d.ts +1 -0
  141. package/lib/module/renderer/__tests__/e2e/Paint.spec.d.ts +1 -0
  142. package/lib/module/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +1 -0
  143. package/lib/module/renderer/__tests__/e2e/Paragraphs.spec.d.ts +1 -0
  144. package/lib/module/renderer/__tests__/e2e/PathEffects.spec.d.ts +1 -0
  145. package/lib/module/renderer/__tests__/e2e/Paths.spec.d.ts +1 -0
  146. package/lib/module/renderer/__tests__/e2e/Picture.spec.d.ts +1 -0
  147. package/lib/module/renderer/__tests__/e2e/Point.spec.d.ts +1 -0
  148. package/lib/module/renderer/__tests__/e2e/Rect.spec.d.ts +1 -0
  149. package/lib/module/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +1 -0
  150. package/lib/module/renderer/__tests__/e2e/SDF.spec.d.ts +1 -0
  151. package/lib/module/renderer/__tests__/e2e/SVG.spec.d.ts +1 -0
  152. package/lib/module/renderer/__tests__/e2e/Shader.spec.d.ts +1 -0
  153. package/lib/module/renderer/__tests__/e2e/Snapshot.spec.d.ts +1 -0
  154. package/lib/module/renderer/__tests__/e2e/Surfaces.spec.d.ts +1 -0
  155. package/lib/module/renderer/__tests__/e2e/Text.spec.d.ts +1 -0
  156. package/lib/module/renderer/__tests__/e2e/TextPath.spec.d.ts +1 -0
  157. package/lib/module/renderer/__tests__/e2e/Transforms.spec.d.ts +1 -0
  158. package/lib/module/renderer/__tests__/e2e/Vertices.spec.d.ts +1 -0
  159. package/lib/module/renderer/__tests__/e2e/Video.d.ts +1 -0
  160. package/lib/module/renderer/__tests__/e2e/setup/Paragraph.d.ts +19 -0
  161. package/lib/module/renderer/__tests__/e2e/setup/SVG.d.ts +12 -0
  162. package/lib/module/renderer/__tests__/e2e/setup/SkiaObject.d.ts +11 -0
  163. package/lib/module/renderer/__tests__/e2e/setup/index.d.ts +3 -0
  164. package/lib/module/renderer/__tests__/examples/BlendModes.spec.d.ts +1 -0
  165. package/lib/module/renderer/__tests__/setup.d.ts +66 -0
  166. package/lib/module/skia/__tests__/ColorFilter.spec.d.ts +1 -0
  167. package/lib/module/skia/__tests__/Data.spec.d.ts +1 -0
  168. package/lib/module/skia/__tests__/Drawings.spec.d.ts +1 -0
  169. package/lib/module/skia/__tests__/Enums.spec.d.ts +1 -0
  170. package/lib/module/skia/__tests__/Geometry.spec.d.ts +1 -0
  171. package/lib/module/skia/__tests__/ImageFilter.spec.d.ts +1 -0
  172. package/lib/module/skia/__tests__/Mock.spec.d.ts +0 -0
  173. package/lib/module/skia/__tests__/Paint.spec.d.ts +1 -0
  174. package/lib/module/skia/__tests__/Path.spec.d.ts +1 -0
  175. package/lib/module/skia/__tests__/RuntimeEffect.spec.d.ts +1 -0
  176. package/lib/module/skia/__tests__/Shader.spec.d.ts +1 -0
  177. package/lib/module/skia/__tests__/Text.spec.d.ts +1 -0
  178. package/lib/module/skia/__tests__/Transform.spec.d.ts +1 -0
  179. package/lib/module/skia/__tests__/Vertices.spec.d.ts +1 -0
  180. package/lib/module/skia/__tests__/setup.d.ts +19 -0
  181. package/lib/typescript/src/__tests__/globalSetup.d.ts +9 -0
  182. package/lib/typescript/src/__tests__/globalTeardown.d.ts +2 -0
  183. package/lib/typescript/src/__tests__/setup.d.ts +18 -0
  184. package/lib/typescript/src/dom/__tests__/Compose.spec.d.ts +1 -0
  185. package/lib/typescript/src/dom/__tests__/Demos.spec.d.ts +1 -0
  186. package/lib/typescript/src/dom/__tests__/DrawingContext.spec.d.ts +1 -0
  187. package/lib/typescript/src/dom/__tests__/Drawings.spec.d.ts +1 -0
  188. package/lib/typescript/src/dom/__tests__/Group.spec.d.ts +1 -0
  189. package/lib/typescript/src/dom/__tests__/Paint.spec.d.ts +1 -0
  190. package/lib/typescript/src/dom/__tests__/RenderNodes.spec.d.ts +1 -0
  191. package/lib/typescript/src/dom/__tests__/Shaders.spec.d.ts +1 -0
  192. package/lib/typescript/src/renderer/__tests__/Data.spec.d.ts +1 -0
  193. package/lib/typescript/src/renderer/__tests__/Drawings.spec.d.ts +1 -0
  194. package/lib/typescript/src/renderer/__tests__/FitBox.spec.d.ts +1 -0
  195. package/lib/typescript/src/renderer/__tests__/Glyphs.spec.d.ts +1 -0
  196. package/lib/typescript/src/renderer/__tests__/Image.spec.d.ts +1 -0
  197. package/lib/typescript/src/renderer/__tests__/Paths.spec.d.ts +1 -0
  198. package/lib/typescript/src/renderer/__tests__/Picture.spec.d.ts +1 -0
  199. package/lib/typescript/src/renderer/__tests__/Simple.spec.d.ts +1 -0
  200. package/lib/typescript/src/renderer/__tests__/SkiaDOM.spec.d.ts +1 -0
  201. package/lib/typescript/src/renderer/__tests__/Surfaces.spec.d.ts +1 -0
  202. package/lib/typescript/src/renderer/__tests__/Text.spec.d.ts +1 -0
  203. package/lib/typescript/src/renderer/__tests__/TouchHandler.spec.d.ts +1 -0
  204. package/lib/typescript/src/renderer/__tests__/Transform.spec.d.ts +1 -0
  205. package/lib/typescript/src/renderer/__tests__/documentation/Group.spec.d.ts +1 -0
  206. package/lib/typescript/src/renderer/__tests__/documentation/getting-started/HelloWorld.spec.d.ts +1 -0
  207. package/lib/typescript/src/renderer/__tests__/documentation/paint/Overview.spec.d.ts +1 -0
  208. package/lib/typescript/src/renderer/__tests__/documentation/shapes/Box.spec.d.ts +1 -0
  209. package/lib/typescript/src/renderer/__tests__/e2e/AnimatedImages.spec.d.ts +1 -0
  210. package/lib/typescript/src/renderer/__tests__/e2e/Atlas.spec.d.ts +1 -0
  211. package/lib/typescript/src/renderer/__tests__/e2e/BackdropFilters.spec.d.ts +1 -0
  212. package/lib/typescript/src/renderer/__tests__/e2e/Blending.spec.d.ts +1 -0
  213. package/lib/typescript/src/renderer/__tests__/e2e/Blur.spec.d.ts +1 -0
  214. package/lib/typescript/src/renderer/__tests__/e2e/Box.spec.d.ts +1 -0
  215. package/lib/typescript/src/renderer/__tests__/e2e/ColorFilters.spec.d.ts +1 -0
  216. package/lib/typescript/src/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.d.ts +1 -0
  217. package/lib/typescript/src/renderer/__tests__/e2e/CoonPatch.spec.d.ts +1 -0
  218. package/lib/typescript/src/renderer/__tests__/e2e/DataEncoding.spec.d.ts +1 -0
  219. package/lib/typescript/src/renderer/__tests__/e2e/Drawings.spec.d.ts +1 -0
  220. package/lib/typescript/src/renderer/__tests__/e2e/FontMgr.spec.d.ts +1 -0
  221. package/lib/typescript/src/renderer/__tests__/e2e/Gradient.spec.d.ts +1 -0
  222. package/lib/typescript/src/renderer/__tests__/e2e/Group.spec.d.ts +1 -0
  223. package/lib/typescript/src/renderer/__tests__/e2e/Image.spec.d.ts +1 -0
  224. package/lib/typescript/src/renderer/__tests__/e2e/ImageEncoding.spec.d.ts +1 -0
  225. package/lib/typescript/src/renderer/__tests__/e2e/ImageFilters.spec.d.ts +1 -0
  226. package/lib/typescript/src/renderer/__tests__/e2e/Mask.spec.d.ts +1 -0
  227. package/lib/typescript/src/renderer/__tests__/e2e/Matrix4.spec.d.ts +1 -0
  228. package/lib/typescript/src/renderer/__tests__/e2e/NativeBuffer.spec.d.ts +1 -0
  229. package/lib/typescript/src/renderer/__tests__/e2e/Offscreen.spec.d.ts +1 -0
  230. package/lib/typescript/src/renderer/__tests__/e2e/Opacity.spec.d.ts +1 -0
  231. package/lib/typescript/src/renderer/__tests__/e2e/Paint.spec.d.ts +1 -0
  232. package/lib/typescript/src/renderer/__tests__/e2e/ParagraphPaint.spec.d.ts +1 -0
  233. package/lib/typescript/src/renderer/__tests__/e2e/Paragraphs.spec.d.ts +1 -0
  234. package/lib/typescript/src/renderer/__tests__/e2e/PathEffects.spec.d.ts +1 -0
  235. package/lib/typescript/src/renderer/__tests__/e2e/Paths.spec.d.ts +1 -0
  236. package/lib/typescript/src/renderer/__tests__/e2e/Picture.spec.d.ts +1 -0
  237. package/lib/typescript/src/renderer/__tests__/e2e/Point.spec.d.ts +1 -0
  238. package/lib/typescript/src/renderer/__tests__/e2e/Rect.spec.d.ts +1 -0
  239. package/lib/typescript/src/renderer/__tests__/e2e/RuntimeShader.spec.d.ts +1 -0
  240. package/lib/typescript/src/renderer/__tests__/e2e/SDF.spec.d.ts +1 -0
  241. package/lib/typescript/src/renderer/__tests__/e2e/SVG.spec.d.ts +1 -0
  242. package/lib/typescript/src/renderer/__tests__/e2e/Shader.spec.d.ts +1 -0
  243. package/lib/typescript/src/renderer/__tests__/e2e/Snapshot.spec.d.ts +1 -0
  244. package/lib/typescript/src/renderer/__tests__/e2e/Surfaces.spec.d.ts +1 -0
  245. package/lib/typescript/src/renderer/__tests__/e2e/Text.spec.d.ts +1 -0
  246. package/lib/typescript/src/renderer/__tests__/e2e/TextPath.spec.d.ts +1 -0
  247. package/lib/typescript/src/renderer/__tests__/e2e/Transforms.spec.d.ts +1 -0
  248. package/lib/typescript/src/renderer/__tests__/e2e/Vertices.spec.d.ts +1 -0
  249. package/lib/typescript/src/renderer/__tests__/e2e/Video.d.ts +1 -0
  250. package/lib/typescript/src/renderer/__tests__/e2e/setup/Paragraph.d.ts +19 -0
  251. package/lib/typescript/src/renderer/__tests__/e2e/setup/SVG.d.ts +12 -0
  252. package/lib/typescript/src/renderer/__tests__/e2e/setup/SkiaObject.d.ts +11 -0
  253. package/lib/typescript/src/renderer/__tests__/e2e/setup/index.d.ts +3 -0
  254. package/lib/typescript/src/renderer/__tests__/examples/BlendModes.spec.d.ts +1 -0
  255. package/lib/typescript/src/renderer/__tests__/setup.d.ts +66 -0
  256. package/lib/typescript/src/skia/__tests__/ColorFilter.spec.d.ts +1 -0
  257. package/lib/typescript/src/skia/__tests__/Data.spec.d.ts +1 -0
  258. package/lib/typescript/src/skia/__tests__/Drawings.spec.d.ts +1 -0
  259. package/lib/typescript/src/skia/__tests__/Enums.spec.d.ts +1 -0
  260. package/lib/typescript/src/skia/__tests__/Geometry.spec.d.ts +1 -0
  261. package/lib/typescript/src/skia/__tests__/ImageFilter.spec.d.ts +1 -0
  262. package/lib/typescript/src/skia/__tests__/Mock.spec.d.ts +0 -0
  263. package/lib/typescript/src/skia/__tests__/Paint.spec.d.ts +1 -0
  264. package/lib/typescript/src/skia/__tests__/Path.spec.d.ts +1 -0
  265. package/lib/typescript/src/skia/__tests__/RuntimeEffect.spec.d.ts +1 -0
  266. package/lib/typescript/src/skia/__tests__/Shader.spec.d.ts +1 -0
  267. package/lib/typescript/src/skia/__tests__/Text.spec.d.ts +1 -0
  268. package/lib/typescript/src/skia/__tests__/Transform.spec.d.ts +1 -0
  269. package/lib/typescript/src/skia/__tests__/Vertices.spec.d.ts +1 -0
  270. package/lib/typescript/src/skia/__tests__/setup.d.ts +19 -0
  271. package/libs/ios/libskia.xcframework/Info.plist +46 -0
  272. package/libs/ios/libskia.xcframework/ios-arm64_arm64e/libskia.a +0 -0
  273. package/libs/ios/libskia.xcframework/ios-arm64_arm64e_x86_64-simulator/libskia.a +0 -0
  274. package/libs/ios/libskottie.xcframework/Info.plist +46 -0
  275. package/libs/ios/libskottie.xcframework/ios-arm64_arm64e/libskottie.a +0 -0
  276. package/libs/ios/libskottie.xcframework/ios-arm64_arm64e_x86_64-simulator/libskottie.a +0 -0
  277. package/libs/ios/libskparagraph.xcframework/Info.plist +46 -0
  278. package/libs/ios/libskparagraph.xcframework/ios-arm64_arm64e/libskparagraph.a +0 -0
  279. package/libs/ios/libskparagraph.xcframework/ios-arm64_arm64e_x86_64-simulator/libskparagraph.a +0 -0
  280. package/libs/ios/libsksg.xcframework/Info.plist +46 -0
  281. package/libs/ios/libsksg.xcframework/ios-arm64_arm64e/libsksg.a +0 -0
  282. package/libs/ios/libsksg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsksg.a +0 -0
  283. package/libs/ios/libskshaper.xcframework/Info.plist +46 -0
  284. package/libs/ios/libskshaper.xcframework/ios-arm64_arm64e/libskshaper.a +0 -0
  285. package/libs/ios/libskshaper.xcframework/ios-arm64_arm64e_x86_64-simulator/libskshaper.a +0 -0
  286. package/libs/ios/libskunicode.xcframework/Info.plist +46 -0
  287. package/libs/ios/libskunicode.xcframework/ios-arm64_arm64e/libskunicode.a +0 -0
  288. package/libs/ios/libskunicode.xcframework/ios-arm64_arm64e_x86_64-simulator/libskunicode.a +0 -0
  289. package/libs/ios/libsvg.xcframework/Info.plist +46 -0
  290. package/libs/ios/libsvg.xcframework/ios-arm64_arm64e/libsvg.a +0 -0
  291. package/libs/ios/libsvg.xcframework/ios-arm64_arm64e_x86_64-simulator/libsvg.a +0 -0
  292. package/package.json +11 -14
  293. package/src/__tests__/globalSetup.ts +51 -0
  294. package/src/__tests__/globalTeardown.ts +11 -0
  295. package/src/__tests__/setup.ts +129 -0
  296. package/src/__tests__/snapshots/animated-images/bird.png +0 -0
  297. package/src/__tests__/snapshots/animations/green.png +0 -0
  298. package/src/__tests__/snapshots/animations/lightblue.png +0 -0
  299. package/src/__tests__/snapshots/animations/quarter-lightblue.png +0 -0
  300. package/src/__tests__/snapshots/animations/red.png +0 -0
  301. package/src/__tests__/snapshots/atlas/identity.png +0 -0
  302. package/src/__tests__/snapshots/atlas/rsxform.png +0 -0
  303. package/src/__tests__/snapshots/atlas/rsxform1.png +0 -0
  304. package/src/__tests__/snapshots/atlas/simple.png +0 -0
  305. package/src/__tests__/snapshots/atlas/simple2.png +0 -0
  306. package/src/__tests__/snapshots/box/box-shadow.png +0 -0
  307. package/src/__tests__/snapshots/box/box-shadow2.png +0 -0
  308. package/src/__tests__/snapshots/box/box-shadow3.png +0 -0
  309. package/src/__tests__/snapshots/box/box-stroke.png +0 -0
  310. package/src/__tests__/snapshots/color-filter/color-filter-composition.png +0 -0
  311. package/src/__tests__/snapshots/color-filter/matrix1.png +0 -0
  312. package/src/__tests__/snapshots/color-filter/matrix3.png +0 -0
  313. package/src/__tests__/snapshots/color-filter/zurich-sepia.png +0 -0
  314. package/src/__tests__/snapshots/coons-patch/patch-with-opacity.png +0 -0
  315. package/src/__tests__/snapshots/coons-patch/simple.png +0 -0
  316. package/src/__tests__/snapshots/cyan-buffer.png +0 -0
  317. package/src/__tests__/snapshots/data/oslo.png +0 -0
  318. package/src/__tests__/snapshots/data/red.png +0 -0
  319. package/src/__tests__/snapshots/data/zurich.png +0 -0
  320. package/src/__tests__/snapshots/demos/apple-breathe.png +0 -0
  321. package/src/__tests__/snapshots/demos/apple-breathe1.png +0 -0
  322. package/src/__tests__/snapshots/demos/breathe.png +0 -0
  323. package/src/__tests__/snapshots/demos/breathe2.png +0 -0
  324. package/src/__tests__/snapshots/demos/product.png +0 -0
  325. package/src/__tests__/snapshots/demos/product2.png +0 -0
  326. package/src/__tests__/snapshots/demos/skia-neon.png +0 -0
  327. package/src/__tests__/snapshots/demos/skia-neon1.png +0 -0
  328. package/src/__tests__/snapshots/drawings/arc.png +0 -0
  329. package/src/__tests__/snapshots/drawings/blend-mode-multiply.png +0 -0
  330. package/src/__tests__/snapshots/drawings/blend-modes.png +0 -0
  331. package/src/__tests__/snapshots/drawings/blur-node.png +0 -0
  332. package/src/__tests__/snapshots/drawings/blur.png +0 -0
  333. package/src/__tests__/snapshots/drawings/blur2.png +0 -0
  334. package/src/__tests__/snapshots/drawings/custom-drawing.png +0 -0
  335. package/src/__tests__/snapshots/drawings/cyan-circle.png +0 -0
  336. package/src/__tests__/snapshots/drawings/cyan.png +0 -0
  337. package/src/__tests__/snapshots/drawings/default-props.png +0 -0
  338. package/src/__tests__/snapshots/drawings/hello-world.png +0 -0
  339. package/src/__tests__/snapshots/drawings/image-default-props.png +0 -0
  340. package/src/__tests__/snapshots/drawings/lightblue-quarter-circle.png +0 -0
  341. package/src/__tests__/snapshots/drawings/lightblue-rect.png +0 -0
  342. package/src/__tests__/snapshots/drawings/line.png +0 -0
  343. package/src/__tests__/snapshots/drawings/multiple-paints.png +0 -0
  344. package/src/__tests__/snapshots/drawings/nested-shader.png +0 -0
  345. package/src/__tests__/snapshots/drawings/nested-shader2.png +0 -0
  346. package/src/__tests__/snapshots/drawings/opacity-image.png +0 -0
  347. package/src/__tests__/snapshots/drawings/opacity-multiplication.png +0 -0
  348. package/src/__tests__/snapshots/drawings/opacity-multiplication2.png +0 -0
  349. package/src/__tests__/snapshots/drawings/points.png +0 -0
  350. package/src/__tests__/snapshots/drawings/purple.png +0 -0
  351. package/src/__tests__/snapshots/drawings/rotated-image.png +0 -0
  352. package/src/__tests__/snapshots/drawings/rotated-scaled-image.png +0 -0
  353. package/src/__tests__/snapshots/drawings/rrect-aa.png +0 -0
  354. package/src/__tests__/snapshots/drawings/rrect-no-aa.png +0 -0
  355. package/src/__tests__/snapshots/drawings/scaled-image.png +0 -0
  356. package/src/__tests__/snapshots/drawings/scaled-image2.png +0 -0
  357. package/src/__tests__/snapshots/drawings/shader-opacity-reference.png +0 -0
  358. package/src/__tests__/snapshots/drawings/skew-transform.png +0 -0
  359. package/src/__tests__/snapshots/drawings/skew-transform2.png +0 -0
  360. package/src/__tests__/snapshots/drawings/small-lightblue-rect.png +0 -0
  361. package/src/__tests__/snapshots/drawings/stroke.png +0 -0
  362. package/src/__tests__/snapshots/drawings/transform-origin.png +0 -0
  363. package/src/__tests__/snapshots/drawings/transparent.png +0 -0
  364. package/src/__tests__/snapshots/drawings/violet.png +0 -0
  365. package/src/__tests__/snapshots/font/green.png +0 -0
  366. package/src/__tests__/snapshots/font/red.png +0 -0
  367. package/src/__tests__/snapshots/glyphs/simple.png +0 -0
  368. package/src/__tests__/snapshots/gradient/linear-with-opacity.png +0 -0
  369. package/src/__tests__/snapshots/gradient/linear.png +0 -0
  370. package/src/__tests__/snapshots/green.png +0 -0
  371. package/src/__tests__/snapshots/image-filter/blur.png +0 -0
  372. package/src/__tests__/snapshots/image-filter/test-shadow.png +0 -0
  373. package/src/__tests__/snapshots/images/bundle-android.png +0 -0
  374. package/src/__tests__/snapshots/images/bundle-ios.png +0 -0
  375. package/src/__tests__/snapshots/images/bundle-node.png +0 -0
  376. package/src/__tests__/snapshots/images/bundle.png +0 -0
  377. package/src/__tests__/snapshots/images/filter.png +0 -0
  378. package/src/__tests__/snapshots/leak.png +0 -0
  379. package/src/__tests__/snapshots/matrix4/perspective.png +0 -0
  380. package/src/__tests__/snapshots/paint/blend-mode.png +0 -0
  381. package/src/__tests__/snapshots/paint/circle.png +0 -0
  382. package/src/__tests__/snapshots/paint/colors.png +0 -0
  383. package/src/__tests__/snapshots/paint/dither.png +0 -0
  384. package/src/__tests__/snapshots/paint/path-paint.png +0 -0
  385. package/src/__tests__/snapshots/paint/without-dither.png +0 -0
  386. package/src/__tests__/snapshots/paragraph/paragraph-auto-linebreaks-android.png +0 -0
  387. package/src/__tests__/snapshots/paragraph/paragraph-auto-linebreaks-ios.png +0 -0
  388. package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-android.png +0 -0
  389. package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-ios.png +0 -0
  390. package/src/__tests__/snapshots/paragraph/paragraph-bounding-box-node.png +0 -0
  391. package/src/__tests__/snapshots/paragraph/paragraph-ellipse-android.png +0 -0
  392. package/src/__tests__/snapshots/paragraph/paragraph-ellipse-ios.png +0 -0
  393. package/src/__tests__/snapshots/paragraph/paragraph-linebreaks-android.png +0 -0
  394. package/src/__tests__/snapshots/paragraph/paragraph-linebreaks-ios.png +0 -0
  395. package/src/__tests__/snapshots/paragraph/paragraph-text-align-center-android.png +0 -0
  396. package/src/__tests__/snapshots/paragraph/paragraph-text-align-center-ios.png +0 -0
  397. package/src/__tests__/snapshots/paragraph/paragraph-text-align-justify-android.png +0 -0
  398. package/src/__tests__/snapshots/paragraph/paragraph-text-align-justify-ios.png +0 -0
  399. package/src/__tests__/snapshots/paragraph/paragraph-text-align-left-android.png +0 -0
  400. package/src/__tests__/snapshots/paragraph/paragraph-text-align-left-ios.png +0 -0
  401. package/src/__tests__/snapshots/paragraph/paragraph-text-align-right-android.png +0 -0
  402. package/src/__tests__/snapshots/paragraph/paragraph-text-align-right-ios.png +0 -0
  403. package/src/__tests__/snapshots/paragraph/paragraph-text-align-rtl-android.png +0 -0
  404. package/src/__tests__/snapshots/paragraph/paragraph-text-align-rtl-ios.png +0 -0
  405. package/src/__tests__/snapshots/paragraph/paragraph-text-style-colors-android.png +0 -0
  406. package/src/__tests__/snapshots/paragraph/paragraph-text-style-colors-ios.png +0 -0
  407. package/src/__tests__/snapshots/paragraph/paragraph-text-style-decoration-android.png +0 -0
  408. package/src/__tests__/snapshots/paragraph/paragraph-text-style-decoration-ios.png +0 -0
  409. package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-shadow-android.png +0 -0
  410. package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-shadow-ios.png +0 -0
  411. package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-android-box.png +0 -0
  412. package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-android.png +0 -0
  413. package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-ios-box.png +0 -0
  414. package/src/__tests__/snapshots/paragraph/paragraph-text-style-font-style-ios.png +0 -0
  415. package/src/__tests__/snapshots/paragraph/paragraph-text-style-in-paragraph-style-android.png +0 -0
  416. package/src/__tests__/snapshots/paragraph/paragraph-text-style-in-paragraph-style-ios.png +0 -0
  417. package/src/__tests__/snapshots/paragraph/simple-paragraph-android.png +0 -0
  418. package/src/__tests__/snapshots/paragraph/simple-paragraph-ios.png +0 -0
  419. package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-android.png +0 -0
  420. package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-ios.png +0 -0
  421. package/src/__tests__/snapshots/paragraph/simple-paragraph-with-provider-node.png +0 -0
  422. package/src/__tests__/snapshots/path/interpolate.png +0 -0
  423. package/src/__tests__/snapshots/path/logo.png +0 -0
  424. package/src/__tests__/snapshots/path-effects/discrete.png +0 -0
  425. package/src/__tests__/snapshots/path-effects/sum.png +0 -0
  426. package/src/__tests__/snapshots/path-effects/sum2.png +0 -0
  427. package/src/__tests__/snapshots/paths/arc.png +0 -0
  428. package/src/__tests__/snapshots/paths/emptyPath.png +0 -0
  429. package/src/__tests__/snapshots/paths/interpolation1.png +0 -0
  430. package/src/__tests__/snapshots/paths/oval.png +0 -0
  431. package/src/__tests__/snapshots/paths/pattern.png +0 -0
  432. package/src/__tests__/snapshots/paths/poly.png +0 -0
  433. package/src/__tests__/snapshots/paths/rrect.png +0 -0
  434. package/src/__tests__/snapshots/paths/skia-trimmed.png +0 -0
  435. package/src/__tests__/snapshots/paths/skia.png +0 -0
  436. package/src/__tests__/snapshots/pictures/create-picture.png +0 -0
  437. package/src/__tests__/snapshots/pictures/green.png +0 -0
  438. package/src/__tests__/snapshots/pictures/hello-world.png +0 -0
  439. package/src/__tests__/snapshots/pictures/red.png +0 -0
  440. package/src/__tests__/snapshots/pictures/simple-picture.png +0 -0
  441. package/src/__tests__/snapshots/platform-buffer-bgra.png +0 -0
  442. package/src/__tests__/snapshots/platform-buffer.png +0 -0
  443. package/src/__tests__/snapshots/points/points.png +0 -0
  444. package/src/__tests__/snapshots/points/points2.png +0 -0
  445. package/src/__tests__/snapshots/render-nodes/simple.png +0 -0
  446. package/src/__tests__/snapshots/render-nodes/simple2.png +0 -0
  447. package/src/__tests__/snapshots/runtime-effects/blend-color-burn.png +0 -0
  448. package/src/__tests__/snapshots/runtime-effects/blend-color-burn2.png +0 -0
  449. package/src/__tests__/snapshots/runtime-effects/blend-color-burn3.png +0 -0
  450. package/src/__tests__/snapshots/runtime-effects/blend-color-dodge.png +0 -0
  451. package/src/__tests__/snapshots/runtime-effects/blend-multiply.png +0 -0
  452. package/src/__tests__/snapshots/runtime-effects/int-uniform.png +0 -0
  453. package/src/__tests__/snapshots/runtime-effects/linear-gradient.png +0 -0
  454. package/src/__tests__/snapshots/runtime-effects/linear-gradient2.png +0 -0
  455. package/src/__tests__/snapshots/runtime-effects/small-spiral.png +0 -0
  456. package/src/__tests__/snapshots/runtime-effects/spiral.png +0 -0
  457. package/src/__tests__/snapshots/runtime-shader/scaled-circle.png +0 -0
  458. package/src/__tests__/snapshots/runtime-shader/scaled-circle2.png +0 -0
  459. package/src/__tests__/snapshots/runtime-shader/simple.png +0 -0
  460. package/src/__tests__/snapshots/runtime-shader/spiral.png +0 -0
  461. package/src/__tests__/snapshots/runtime-shader/unscaled-image.png +0 -0
  462. package/src/__tests__/snapshots/screens/snapshot1-android-ci.png +0 -0
  463. package/src/__tests__/snapshots/screens/snapshot1-android.png +0 -0
  464. package/src/__tests__/snapshots/screens/snapshot1-ios.png +0 -0
  465. package/src/__tests__/snapshots/screens/snapshot2-android-ci.png +0 -0
  466. package/src/__tests__/snapshots/screens/snapshot2-android.png +0 -0
  467. package/src/__tests__/snapshots/screens/snapshot2-ios.png +0 -0
  468. package/src/__tests__/snapshots/screens/snapshot3-android-ci.png +0 -0
  469. package/src/__tests__/snapshots/screens/snapshot3-android.png +0 -0
  470. package/src/__tests__/snapshots/screens/snapshot3-ios.png +0 -0
  471. package/src/__tests__/snapshots/screens/snapshot4-android-ci.png +0 -0
  472. package/src/__tests__/snapshots/screens/snapshot4-android.png +0 -0
  473. package/src/__tests__/snapshots/screens/snapshot4-ios.png +0 -0
  474. package/src/__tests__/snapshots/screens/snapshot5-android.png +0 -0
  475. package/src/__tests__/snapshots/screens/snapshot5-ios.png +0 -0
  476. package/src/__tests__/snapshots/sdf/circle.png +0 -0
  477. package/src/__tests__/snapshots/sdf/heart.png +0 -0
  478. package/src/__tests__/snapshots/sdf/line.png +0 -0
  479. package/src/__tests__/snapshots/sdf/rectangle.png +0 -0
  480. package/src/__tests__/snapshots/shader/bilinear-interpolation.png +0 -0
  481. package/src/__tests__/snapshots/shader/hue.png +0 -0
  482. package/src/__tests__/snapshots/shader/hue2.png +0 -0
  483. package/src/__tests__/snapshots/shader/shader1.png +0 -0
  484. package/src/__tests__/snapshots/shader/shader2.png +0 -0
  485. package/src/__tests__/snapshots/shader/sweep-gradient.png +0 -0
  486. package/src/__tests__/snapshots/text/text-bounds-android.png +0 -0
  487. package/src/__tests__/snapshots/text/text-bounds-ios.png +0 -0
  488. package/src/__tests__/snapshots/text/text-default-font-android.png +0 -0
  489. package/src/__tests__/snapshots/text/text-default-font-ios.png +0 -0
  490. package/src/__tests__/snapshots/text/text-path-bug-android.png +0 -0
  491. package/src/__tests__/snapshots/text/text-path-bug-ios.png +0 -0
  492. package/src/__tests__/snapshots/text/text-path-bug-node.png +0 -0
  493. package/src/__tests__/snapshots/text/text-path1-android.png +0 -0
  494. package/src/__tests__/snapshots/text/text-path1-ios.png +0 -0
  495. package/src/__tests__/snapshots/text/text-path1-node.png +0 -0
  496. package/src/__tests__/snapshots/text/text-path2-android.png +0 -0
  497. package/src/__tests__/snapshots/text/text-path2-ios.png +0 -0
  498. package/src/__tests__/snapshots/text/text-path2-node.png +0 -0
  499. package/src/__tests__/snapshots/transform/rectangles.png +0 -0
  500. package/src/__tests__/snapshots/transform/rotate-radiants.png +0 -0
  501. package/src/__tests__/snapshots/transform/rotate.png +0 -0
  502. package/src/__tests__/snapshots/transform/scale-origin.png +0 -0
  503. package/src/__tests__/snapshots/transform/scale.png +0 -0
  504. package/src/__tests__/snapshots/transform/skew.png +0 -0
  505. package/src/__tests__/snapshots/transparent.png +0 -0
  506. package/src/__tests__/snapshots/vertices/billinear-gradient.png +0 -0
  507. package/src/__tests__/snapshots/vertices/strip.png +0 -0
  508. package/src/__tests__/snapshots/vertices/vertices.png +0 -0
  509. package/src/dom/__tests__/Compose.spec.tsx +42 -0
  510. package/src/dom/__tests__/Demos.spec.tsx +145 -0
  511. package/src/dom/__tests__/DrawingContext.spec.tsx +99 -0
  512. package/src/dom/__tests__/Drawings.spec.tsx +95 -0
  513. package/src/dom/__tests__/Group.spec.tsx +132 -0
  514. package/src/dom/__tests__/Paint.spec.tsx +100 -0
  515. package/src/dom/__tests__/RenderNodes.spec.tsx +44 -0
  516. package/src/dom/__tests__/Shaders.spec.tsx +123 -0
  517. package/src/renderer/__tests__/Data.spec.tsx +67 -0
  518. package/src/renderer/__tests__/Drawings.spec.tsx +96 -0
  519. package/src/renderer/__tests__/FitBox.spec.tsx +126 -0
  520. package/src/renderer/__tests__/Glyphs.spec.tsx +46 -0
  521. package/src/renderer/__tests__/Image.spec.tsx +45 -0
  522. package/src/renderer/__tests__/Paths.spec.tsx +75 -0
  523. package/src/renderer/__tests__/Picture.spec.tsx +82 -0
  524. package/src/renderer/__tests__/Simple.spec.tsx +81 -0
  525. package/src/renderer/__tests__/SkiaDOM.spec.tsx +46 -0
  526. package/src/renderer/__tests__/Surfaces.spec.tsx +73 -0
  527. package/src/renderer/__tests__/Text.spec.tsx +134 -0
  528. package/src/renderer/__tests__/TouchHandler.spec.tsx +113 -0
  529. package/src/renderer/__tests__/Transform.spec.tsx +72 -0
  530. package/src/renderer/__tests__/documentation/Group.spec.tsx +171 -0
  531. package/src/renderer/__tests__/documentation/getting-started/HelloWorld.spec.tsx +51 -0
  532. package/src/renderer/__tests__/documentation/paint/Overview.spec.tsx +84 -0
  533. package/src/renderer/__tests__/documentation/shapes/Box.spec.tsx +46 -0
  534. package/src/renderer/__tests__/e2e/AnimatedImages.spec.tsx +88 -0
  535. package/src/renderer/__tests__/e2e/Atlas.spec.tsx +358 -0
  536. package/src/renderer/__tests__/e2e/BackdropFilters.spec.tsx +141 -0
  537. package/src/renderer/__tests__/e2e/Blending.spec.tsx +115 -0
  538. package/src/renderer/__tests__/e2e/Blur.spec.tsx +56 -0
  539. package/src/renderer/__tests__/e2e/Box.spec.tsx +83 -0
  540. package/src/renderer/__tests__/e2e/ColorFilters.spec.tsx +212 -0
  541. package/src/renderer/__tests__/e2e/Composition/ColorFilterComposition.spec.tsx +81 -0
  542. package/src/renderer/__tests__/e2e/CoonPatch.spec.tsx +74 -0
  543. package/src/renderer/__tests__/e2e/DataEncoding.spec.tsx +75 -0
  544. package/src/renderer/__tests__/e2e/Drawings.spec.tsx +209 -0
  545. package/src/renderer/__tests__/e2e/FontMgr.spec.tsx +150 -0
  546. package/src/renderer/__tests__/e2e/Gradient.spec.tsx +40 -0
  547. package/src/renderer/__tests__/e2e/Group.spec.tsx +129 -0
  548. package/src/renderer/__tests__/e2e/Image.spec.tsx +139 -0
  549. package/src/renderer/__tests__/e2e/ImageEncoding.spec.tsx +255 -0
  550. package/src/renderer/__tests__/e2e/ImageFilters.spec.tsx +230 -0
  551. package/src/renderer/__tests__/e2e/Mask.spec.tsx +85 -0
  552. package/src/renderer/__tests__/e2e/Matrix4.spec.tsx +275 -0
  553. package/src/renderer/__tests__/e2e/NativeBuffer.spec.tsx +156 -0
  554. package/src/renderer/__tests__/e2e/Offscreen.spec.tsx +109 -0
  555. package/src/renderer/__tests__/e2e/Opacity.spec.tsx +278 -0
  556. package/src/renderer/__tests__/e2e/Paint.spec.tsx +170 -0
  557. package/src/renderer/__tests__/e2e/ParagraphPaint.spec.tsx +262 -0
  558. package/src/renderer/__tests__/e2e/Paragraphs.spec.tsx +615 -0
  559. package/src/renderer/__tests__/e2e/PathEffects.spec.tsx +73 -0
  560. package/src/renderer/__tests__/e2e/Paths.spec.tsx +390 -0
  561. package/src/renderer/__tests__/e2e/Picture.spec.tsx +134 -0
  562. package/src/renderer/__tests__/e2e/Point.spec.tsx +35 -0
  563. package/src/renderer/__tests__/e2e/Rect.spec.tsx +139 -0
  564. package/src/renderer/__tests__/e2e/RuntimeShader.spec.tsx +324 -0
  565. package/src/renderer/__tests__/e2e/SDF.spec.tsx +148 -0
  566. package/src/renderer/__tests__/e2e/SVG.spec.tsx +191 -0
  567. package/src/renderer/__tests__/e2e/Shader.spec.tsx +260 -0
  568. package/src/renderer/__tests__/e2e/Snapshot.spec.tsx +29 -0
  569. package/src/renderer/__tests__/e2e/Surfaces.spec.tsx +17 -0
  570. package/src/renderer/__tests__/e2e/Text.spec.tsx +109 -0
  571. package/src/renderer/__tests__/e2e/TextPath.spec.tsx +45 -0
  572. package/src/renderer/__tests__/e2e/Transforms.spec.tsx +63 -0
  573. package/src/renderer/__tests__/e2e/Vertices.spec.tsx +30 -0
  574. package/src/renderer/__tests__/e2e/Video.ts +69 -0
  575. package/src/renderer/__tests__/e2e/setup/Paragraph.ts +56 -0
  576. package/src/renderer/__tests__/e2e/setup/SVG.ts +27 -0
  577. package/src/renderer/__tests__/e2e/setup/SkiaObject.ts +31 -0
  578. package/src/renderer/__tests__/e2e/setup/index.ts +3 -0
  579. package/src/renderer/__tests__/examples/BlendModes.spec.tsx +123 -0
  580. package/src/renderer/__tests__/setup.tsx +489 -0
  581. package/src/skia/__tests__/ColorFilter.spec.ts +67 -0
  582. package/src/skia/__tests__/Data.spec.ts +29 -0
  583. package/src/skia/__tests__/Drawings.spec.ts +119 -0
  584. package/src/skia/__tests__/Enums.spec.ts +114 -0
  585. package/src/skia/__tests__/Geometry.spec.ts +39 -0
  586. package/src/skia/__tests__/ImageFilter.spec.ts +19 -0
  587. package/src/skia/__tests__/Mock.spec.ts +7 -0
  588. package/src/skia/__tests__/Paint.spec.ts +25 -0
  589. package/src/skia/__tests__/Path.spec.ts +386 -0
  590. package/src/skia/__tests__/RuntimeEffect.spec.ts +66 -0
  591. package/src/skia/__tests__/Shader.spec.ts +96 -0
  592. package/src/skia/__tests__/Text.spec.ts +32 -0
  593. package/src/skia/__tests__/Transform.spec.ts +89 -0
  594. package/src/skia/__tests__/Vertices.spec.ts +40 -0
  595. package/src/skia/__tests__/assets/DIN-Medium.ttf +0 -0
  596. package/src/skia/__tests__/assets/NotoColorEmoji.ttf +0 -0
  597. package/src/skia/__tests__/assets/NotoSansSC-Regular.otf +0 -0
  598. package/src/skia/__tests__/assets/Pacifico-Regular.ttf +0 -0
  599. package/src/skia/__tests__/assets/Roboto-BlackItalic.ttf +0 -0
  600. package/src/skia/__tests__/assets/Roboto-Bold.ttf +0 -0
  601. package/src/skia/__tests__/assets/Roboto-Italic.ttf +0 -0
  602. package/src/skia/__tests__/assets/Roboto-Medium.ttf +0 -0
  603. package/src/skia/__tests__/assets/Roboto-Regular.ttf +0 -0
  604. package/src/skia/__tests__/assets/UberMove-Medium_mono.ttf +0 -0
  605. package/src/skia/__tests__/assets/bird.gif +0 -0
  606. package/src/skia/__tests__/assets/box.png +0 -0
  607. package/src/skia/__tests__/assets/box2.png +0 -0
  608. package/src/skia/__tests__/assets/card.png +0 -0
  609. package/src/skia/__tests__/assets/mask.png +0 -0
  610. package/src/skia/__tests__/assets/oslo.jpg +0 -0
  611. package/src/skia/__tests__/assets/product.png +0 -0
  612. package/src/skia/__tests__/assets/skia_logo.png +0 -0
  613. package/src/skia/__tests__/assets/skia_logo_jpeg.jpg +0 -0
  614. package/src/skia/__tests__/assets/tiger.svg +724 -0
  615. package/src/skia/__tests__/assets/zurich.jpg +0 -0
  616. package/src/skia/__tests__/setup.ts +77 -0
@@ -0,0 +1,42 @@
1
+ import {
2
+ importSkia,
3
+ width,
4
+ height,
5
+ loadImage,
6
+ getSkDOM,
7
+ } from "../../renderer/__tests__/setup";
8
+ import { setupSkia } from "../../skia/__tests__/setup";
9
+ import { docPath, processResult } from "../../__tests__/setup";
10
+ import { JsiDrawingContext } from "../types";
11
+
12
+ describe("Compose", () => {
13
+ it("should compose image filters", () => {
14
+ const size = width;
15
+ const { surface, canvas } = setupSkia(width, height);
16
+ const { Skia, rect, vec } = importSkia();
17
+ const Sk = getSkDOM();
18
+ const image = loadImage("skia/__tests__/assets/oslo.jpg");
19
+
20
+ const root = Sk.Group();
21
+ const img = Sk.Image({
22
+ image,
23
+ fit: "cover",
24
+ rect: rect(0, 0, size, size),
25
+ });
26
+ root.addChild(img);
27
+
28
+ const matrix = [
29
+ -0.578, 0.99, 0.588, 0, 0, 0.469, 0.535, -0.003, 0, 0, 0.015, 1.69,
30
+ -0.703, 0, 0, 0, 0, 0, 1, 0,
31
+ ];
32
+ const cf = Sk.MatrixColorFilter({ matrix });
33
+
34
+ const blur = Sk.BlurImageFilter({ blur: vec(10, 10), mode: "decal" });
35
+ blur.addChild(cf);
36
+ root.addChild(blur);
37
+
38
+ const ctx = new JsiDrawingContext(Skia, canvas);
39
+ root.render(ctx);
40
+ processResult(surface, docPath("image-filters/composing.png"));
41
+ });
42
+ });
@@ -0,0 +1,145 @@
1
+ import {
2
+ importSkia,
3
+ width,
4
+ height,
5
+ getSkDOM,
6
+ } from "../../renderer/__tests__/setup";
7
+ import { setupSkia } from "../../skia/__tests__/setup";
8
+ import { processResult } from "../../__tests__/setup";
9
+ import { JsiDrawingContext } from "../types";
10
+
11
+ describe("Drawings", () => {
12
+ it("Apple Breathe Demo", () => {
13
+ const { surface, canvas } = setupSkia(width, height);
14
+ const { Skia, vec, polar2Canvas } = importSkia();
15
+ const Sk = getSkDOM();
16
+ const c = vec(width / 2, height / 2);
17
+ const c1 = Skia.Color("#61bea2");
18
+ const c2 = Skia.Color("#529ca0");
19
+ const R = width / 4;
20
+ const color = Skia.Color("rgb(36,43,56)");
21
+ const root = Sk.Group({ color });
22
+ root.addChild(Sk.Fill());
23
+ const rings = Sk.Group({
24
+ blendMode: "screen",
25
+ });
26
+ const blur = Sk.BlurMaskFilter({
27
+ blur: 10,
28
+ style: "solid",
29
+ respectCTM: true,
30
+ });
31
+ rings.addChild(blur);
32
+ for (let i = 0; i < 6; i++) {
33
+ const theta = (i * (2 * Math.PI)) / 6;
34
+ const matrix = Skia.Matrix();
35
+ const { x, y } = polar2Canvas({ theta, radius: R }, { x: 0, y: 0 });
36
+ matrix.translate(x, y);
37
+ const ring = Sk.Group({
38
+ matrix,
39
+ color: i % 2 ? c1 : c2,
40
+ });
41
+ ring.addChild(Sk.Circle({ c, r: R }));
42
+ rings.addChild(ring);
43
+ }
44
+ root.addChild(rings);
45
+ const ctx = new JsiDrawingContext(Skia, canvas);
46
+ root.render(ctx);
47
+ processResult(surface, "snapshots/demos/breathe.png");
48
+ });
49
+
50
+ it("Apple Breathe Demo with the new API", () => {
51
+ const { surface, canvas } = setupSkia(width, height);
52
+ const { Skia, vec, polar2Canvas } = importSkia();
53
+ const Sk = getSkDOM();
54
+ const c = vec(width / 2, height / 2);
55
+ const c1 = Skia.Color("#61bea2");
56
+ const c2 = Skia.Color("#529ca0");
57
+ const R = width / 4;
58
+ const color = Skia.Color("rgb(36,43,56)");
59
+ const root = Sk.Group({ color });
60
+ root.addChild(Sk.Fill());
61
+ const rings = Sk.Group({
62
+ blendMode: "screen",
63
+ });
64
+ const blur = Sk.BlurMaskFilter({
65
+ blur: 10,
66
+ style: "solid",
67
+ respectCTM: true,
68
+ });
69
+ rings.addChild(blur);
70
+ for (let i = 0; i < 6; i++) {
71
+ const theta = (i * (2 * Math.PI)) / 6;
72
+ const matrix = Skia.Matrix();
73
+ const { x, y } = polar2Canvas({ theta, radius: R }, { x: 0, y: 0 });
74
+ matrix.translate(x, y);
75
+ rings.addChild(Sk.Circle({ c, r: R, matrix, color: i % 2 ? c1 : c2 }));
76
+ }
77
+ root.addChild(rings);
78
+ const ctx = new JsiDrawingContext(Skia, canvas);
79
+ root.render(ctx);
80
+ processResult(surface, "snapshots/demos/breathe.png");
81
+ });
82
+
83
+ it("Apple Breathe Demo with animations", () => {
84
+ const { surface, canvas } = setupSkia(width, height);
85
+ const { Skia, vec, polar2Canvas } = importSkia();
86
+ const Sk = getSkDOM();
87
+ const c = vec(width / 2, height / 2);
88
+ const c1 = Skia.Color("#61bea2");
89
+ const c2 = Skia.Color("#529ca0");
90
+ const R = width / 4;
91
+ const color = Skia.Color("rgb(36,43,56)");
92
+ const root = Sk.Group({ color });
93
+ root.addChild(Sk.Fill());
94
+ const rings = Sk.Group({
95
+ blendMode: "screen",
96
+ });
97
+ const blur = Sk.BlurMaskFilter({
98
+ blur: 10,
99
+ style: "solid",
100
+ respectCTM: true,
101
+ });
102
+ rings.addChild(blur);
103
+ for (let i = 0; i < 6; i++) {
104
+ const theta = (i * (2 * Math.PI)) / 6;
105
+ const matrix = Skia.Matrix();
106
+ const { x, y } = polar2Canvas({ theta, radius: R }, { x: 0, y: 0 });
107
+ matrix.translate(x, y);
108
+ rings.addChild(Sk.Circle({ c, r: R, matrix, color: i % 2 ? c1 : c2 }));
109
+ }
110
+ root.addChild(rings);
111
+ const ctx = new JsiDrawingContext(Skia, canvas);
112
+ root.render(ctx);
113
+ processResult(surface, "snapshots/demos/breathe.png");
114
+
115
+ blur.setProp("blur", 0);
116
+ root.setProp("transform", [
117
+ { translateX: c.x },
118
+ { translateY: c.y },
119
+ { rotate: Math.PI / 4 },
120
+ { translateX: -c.x },
121
+ { translateY: -c.y },
122
+ ]);
123
+ for (let i = 0; i < 6; i++) {
124
+ const theta = (i * (2 * Math.PI)) / 6;
125
+ const matrix = Skia.Matrix();
126
+ const scale = 0.5;
127
+ const { x, y } = polar2Canvas({ theta, radius: 0.5 * R }, { x: 0, y: 0 });
128
+ matrix.translate(x, y);
129
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
130
+ const ring = rings.children()[i + 1] as any;
131
+ ring.setProp("matrix", undefined);
132
+ ring.setProp("transform", [
133
+ { translateX: c.x },
134
+ { translateY: c.y },
135
+ { translateX: x },
136
+ { translateY: y },
137
+ { scale },
138
+ { translateX: -c.x },
139
+ { translateY: -c.y },
140
+ ]);
141
+ }
142
+ root.render(ctx);
143
+ processResult(surface, "snapshots/demos/breathe2.png");
144
+ });
145
+ });
@@ -0,0 +1,99 @@
1
+ import {
2
+ importSkia,
3
+ width,
4
+ height,
5
+ getSkDOM,
6
+ } from "../../renderer/__tests__/setup";
7
+ import { setupSkia } from "../../skia/__tests__/setup";
8
+ import type { Node, PaintProps } from "../types";
9
+ import { JsiDrawingContext } from "../types";
10
+
11
+ describe("DrawingContext", () => {
12
+ it("should create contextes properly", () => {
13
+ const { canvas } = setupSkia(width, height);
14
+ const { Skia } = importSkia();
15
+ const Sk = getSkDOM();
16
+ const group = Sk.Group({ color: "red" });
17
+ const ctx = new JsiDrawingContext(Skia, canvas);
18
+ const rootPaint = ctx.paint;
19
+ expect(rootPaint).toBeDefined();
20
+
21
+ const shouldRestore = ctx.saveAndConcat(group);
22
+ expect(shouldRestore).toBe(true);
23
+ expect(ctx.paint).not.toBe(rootPaint);
24
+ expect(ctx.paint.getColor()).toEqual(Skia.Color("red"));
25
+ ctx.restore();
26
+
27
+ expect(ctx.paint).toBe(rootPaint);
28
+ });
29
+
30
+ it("should only create a context if necessary", () => {
31
+ const { canvas } = setupSkia(width, height);
32
+ const { Skia } = importSkia();
33
+ const Sk = getSkDOM();
34
+ const group = Sk.Group();
35
+ group.addChild(Sk.Group({ color: "red" }));
36
+ const ctx = new JsiDrawingContext(Skia, canvas);
37
+ const rootPaint = ctx.paint;
38
+ expect(rootPaint).toBeDefined();
39
+
40
+ let shouldRestore = ctx.saveAndConcat(group);
41
+ expect(shouldRestore).toBe(false);
42
+ expect(ctx.paint).toBe(rootPaint);
43
+ expect(ctx.paint.getColor()).toEqual(Skia.Color("black"));
44
+
45
+ shouldRestore = ctx.saveAndConcat(group.children()[0] as Node<PaintProps>);
46
+ expect(shouldRestore).toBe(true);
47
+ expect(ctx.paint).not.toBe(rootPaint);
48
+ expect(ctx.paint.getColor()).toEqual(Skia.Color("red"));
49
+ });
50
+
51
+ it("should only visit declarations if needed", () => {
52
+ const { canvas } = setupSkia(width, height);
53
+ const { Skia } = importSkia();
54
+ const Sk = getSkDOM();
55
+ const group = Sk.Group({ color: "red" });
56
+ const ctx = new JsiDrawingContext(Skia, canvas);
57
+ const rootPaint = ctx.paint;
58
+ expect(rootPaint).toBeDefined();
59
+
60
+ ctx.saveAndConcat(group);
61
+ const cachedPaint = ctx.paint;
62
+ ctx.restore();
63
+
64
+ ctx.saveAndConcat(group);
65
+ expect(ctx.paint).not.toBe(cachedPaint);
66
+ ctx.restore();
67
+
68
+ ctx.saveAndConcat(group, cachedPaint);
69
+ expect(ctx.paint).toBe(cachedPaint);
70
+ ctx.restore();
71
+ });
72
+
73
+ it("should keep a paint stable if the parent doesn't change", () => {
74
+ const { canvas } = setupSkia(width, height);
75
+ const { Skia } = importSkia();
76
+ const Sk = getSkDOM();
77
+ const root = Sk.Group({});
78
+ const child = Sk.Group({ color: "red" });
79
+ root.addChild(child);
80
+
81
+ const ctx = new JsiDrawingContext(Skia, canvas);
82
+ const rootPaint = ctx.paint;
83
+ expect(rootPaint).toBeDefined();
84
+
85
+ ctx.saveAndConcat(root);
86
+
87
+ ctx.saveAndConcat(child);
88
+ const p1 = ctx.paint;
89
+ ctx.restore();
90
+
91
+ ctx.saveAndConcat(child, p1);
92
+ const p2 = ctx.paint;
93
+ ctx.restore();
94
+
95
+ ctx.restore();
96
+
97
+ expect(p1).toBe(p2);
98
+ });
99
+ });
@@ -0,0 +1,95 @@
1
+ import {
2
+ importSkia,
3
+ width,
4
+ height,
5
+ getSkDOM,
6
+ } from "../../renderer/__tests__/setup";
7
+ import { setupSkia } from "../../skia/__tests__/setup";
8
+ import { processResult } from "../../__tests__/setup";
9
+ import { fitRects, rect2rect } from "../nodes/datatypes";
10
+ import { JsiDrawingContext } from "../types/DrawingContext";
11
+
12
+ describe("Drawings", () => {
13
+ it("Hello World", () => {
14
+ const { surface, canvas } = setupSkia(width, height);
15
+ const { Skia, vec } = importSkia();
16
+ const Sk = getSkDOM();
17
+
18
+ const r = width * 0.33;
19
+ // Root
20
+ const root = Sk.Group({
21
+ blendMode: "multiply",
22
+ });
23
+ // C1
24
+ const c1 = Sk.Group({ color: Skia.Color("cyan") });
25
+ c1.addChild(Sk.Circle({ c: vec(r, r), r }));
26
+ root.addChild(c1);
27
+ // C2
28
+ const c2 = Sk.Group({ color: Skia.Color("magenta") });
29
+ c2.addChild(Sk.Circle({ c: vec(width - r, r), r }));
30
+ root.addChild(c2);
31
+ // C3
32
+ const c3 = Sk.Group({ color: Skia.Color("yellow") });
33
+ c3.addChild(Sk.Circle({ c: vec(width / 2, height - r), r }));
34
+ root.addChild(c3);
35
+
36
+ const ctx = new JsiDrawingContext(Skia, canvas);
37
+ root.render(ctx);
38
+ processResult(surface, "snapshots/drawings/blend-mode-multiply.png");
39
+ });
40
+
41
+ it("Should draw a path", () => {
42
+ const { surface, canvas } = setupSkia(width, height);
43
+ const { Skia, processTransform2d } = importSkia();
44
+ const Sk = getSkDOM();
45
+ const size = width;
46
+ const path = Skia.Path.MakeFromSVGString(
47
+ // eslint-disable-next-line max-len
48
+ "M512.213 204.005C500.312 185.697 406.758 105.581 332.94 105.581C259.122 105.581 219.088 132 204.638 149.85C157.952 207.52 141.933 264.275 156.579 320.115C175.803 387.854 228.896 449.644 315.859 505.483C415.638 562.238 479.716 626.774 508.093 699.091C518.163 731.13 519.536 762.711 512.213 793.835C504.889 824.959 490.243 853.336 468.273 878.967C449.965 903.683 425.707 921.534 395.499 932.518C365.291 942.588 328.675 950.369 285.651 955.861C182.21 964.1 97.9935 948.538 33 909.176M595.972 733.419C710.397 564.985 795.529 424.47 851.369 311.876C865.1 279.837 875.169 255.579 881.577 239.102C887.985 221.709 894.393 198.824 900.801 170.447C907.208 142.069 909.497 115.98 907.666 92.1797C904.92 68.3793 893.02 51.9021 871.965 40.0019C850.911 28.1016 835.5 31.3101 811.549 44.1212C772.187 65.1754 745.64 101.334 731.909 152.596C723.67 174.566 715.432 200.197 707.193 229.49C699.87 258.783 694.378 281.21 690.716 296.772C687.97 312.334 682.935 340.711 675.612 381.904C668.289 422.182 663.712 445.982 661.881 453.306C643.573 567.731 621.603 733.876 595.972 951.742C624.349 852.878 656.846 774.154 693.462 715.568C706.278 689.937 717.263 669.798 726.417 655.152C735.571 640.505 748.844 624.486 766.237 607.093C784.545 589.701 803.768 576.885 823.907 568.646C892.562 543.015 941.994 545.304 972.202 575.512C990.51 594.735 999.664 618.078 999.664 645.54C1000.58 673.002 990.052 694.514 968.083 710.076C925.059 733.876 859.608 741.657 771.729 733.419C786.375 737.996 797.36 742.115 804.683 745.776C812.922 748.523 822.992 753.1 834.892 759.508C847.707 765.915 857.319 773.696 863.727 782.85C871.05 792.004 875.627 802.531 877.458 814.432C878.373 819.009 879.746 827.705 881.577 840.521C884.323 853.336 886.612 862.948 888.443 869.356C890.273 875.763 892.562 884.002 895.308 894.072C898.97 904.141 903.089 912.837 907.666 920.16C913.159 926.568 919.566 932.976 926.89 939.384C949.775 961.354 987.764 958.607 1040.86 931.145C1056.42 923.822 1070.61 914.668 1083.42 903.683C1097.15 892.698 1109.97 879.425 1121.87 863.863C1134.69 847.386 1144.76 834.113 1152.08 824.043C1159.4 813.058 1169.47 797.039 1182.29 775.985C1195.1 754.931 1204.26 740.742 1209.75 733.419C1239.04 674.833 1268.33 616.247 1297.63 557.661C1252.77 670.256 1223.94 756.304 1211.12 815.805C1205.63 833.197 1203.34 853.336 1204.26 876.221C1205.17 899.106 1212.04 917.414 1224.85 931.145C1234.01 942.13 1245.45 949.453 1259.18 953.115C1273.83 956.777 1287.56 956.319 1300.37 951.742C1356.21 935.265 1401.53 903.226 1436.31 855.625C1456.45 828.163 1483.45 787.427 1517.32 733.419M1360.79 390.143C1347.97 390.143 1340.19 384.193 1337.45 372.293C1335.62 359.477 1336.99 348.492 1341.57 339.338C1345.24 332 1357.13 333.846 1369.03 333.846C1380.93 333.846 1390.5 340.5 1391 348.95M1925.13 697.718C1902.25 633.64 1874.33 593.82 1841.38 578.258C1810.25 559.95 1775.47 551.254 1737.02 552.169C1698.57 552.169 1664.25 562.238 1634.04 582.377C1605.66 598.855 1581.4 620.824 1561.26 648.286C1541.12 674.833 1527.39 704.126 1520.07 736.165C1513.66 767.288 1514.58 798.87 1522.82 830.909C1531.97 862.032 1547.53 888.579 1569.5 910.549C1604.29 939.842 1646.4 954.488 1695.83 954.488C1745.26 954.488 1787.82 939.842 1823.53 910.549C1838.17 895.902 1848.7 885.375 1855.11 878.967C1861.51 872.56 1868.84 863.406 1877.08 851.505C1886.23 839.605 1893.55 827.247 1899.05 814.432M1958.09 556.288C1933.37 657.898 1916.9 746.234 1908.66 821.297C1900.42 878.967 1911.4 918.787 1941.61 940.757C1964.5 959.065 2000.2 956.319 2048.71 932.518C2090.82 912.38 2131.1 873.017 2169.55 814.432"
49
+ )!;
50
+ expect(path).toBeDefined();
51
+ const PADDING = width / 16;
52
+ const src = Skia.XYWHRect(0, 0, 2139, 928);
53
+ const dst = Skia.XYWHRect(
54
+ PADDING,
55
+ PADDING,
56
+ size - PADDING * 2,
57
+ size - PADDING * 2
58
+ );
59
+ const rects = fitRects("contain", src, dst);
60
+ const matrix = processTransform2d(rect2rect(rects.src, rects.dst));
61
+ const root = Sk.Group({
62
+ matrix,
63
+ style: "stroke",
64
+ strokeWidth: 116,
65
+ strokeJoin: "round",
66
+ strokeCap: "round",
67
+ });
68
+ const colors = [
69
+ "#3FCEBC",
70
+ "#3CBCEB",
71
+ "#5F96E7",
72
+ "#816FE3",
73
+ "#9F5EE2",
74
+ "#DE589F",
75
+ "#FF645E",
76
+ "#FDA859",
77
+ "#FAEC54",
78
+ "#9EE671",
79
+ "#41E08D",
80
+ ].map((cl) => Skia.Color(cl));
81
+ root.addChild(
82
+ Sk.LinearGradient({
83
+ start: path.getPoint(0),
84
+ end: path.getLastPt(),
85
+ colors,
86
+ mode: "clamp",
87
+ })
88
+ );
89
+ const pathNode = Sk.Path({ path, start: 0, end: 1 });
90
+ root.addChild(pathNode);
91
+ const ctx = new JsiDrawingContext(Skia, canvas);
92
+ root.render(ctx);
93
+ processResult(surface, "snapshots/paths/skia.png");
94
+ });
95
+ });
@@ -0,0 +1,132 @@
1
+ import { fitbox } from "../../renderer";
2
+ import {
3
+ importSkia,
4
+ width,
5
+ height,
6
+ loadImage,
7
+ PIXEL_RATIO,
8
+ getSkDOM,
9
+ } from "../../renderer/__tests__/setup";
10
+ import { setupSkia } from "../../skia/__tests__/setup";
11
+ import { docPath, processResult } from "../../__tests__/setup";
12
+ import { JsiDrawingContext } from "../types/DrawingContext";
13
+
14
+ const size = width;
15
+ const padding = 48;
16
+ const r = 24;
17
+
18
+ describe("Group", () => {
19
+ it("should clip rect", () => {
20
+ const { surface, canvas } = setupSkia(width, height);
21
+ const { Skia, rect } = importSkia();
22
+ const Sk = getSkDOM();
23
+ const image = loadImage("skia/__tests__/assets/oslo.jpg");
24
+ const clipRect = rect(
25
+ padding,
26
+ padding,
27
+ size - padding * 2,
28
+ size - padding * 2
29
+ );
30
+ // Root
31
+ const root = Sk.Group({
32
+ color: Skia.Color("lightblue"),
33
+ });
34
+ root.addChild(Sk.Fill());
35
+ const clipNode = Sk.Group({ clip: clipRect });
36
+ clipNode.addChild(
37
+ Sk.Image({ image, fit: "cover", x: 0, y: 0, width: size, height: size })
38
+ );
39
+ root.addChild(clipNode);
40
+ const ctx = new JsiDrawingContext(Skia, canvas);
41
+ root.render(ctx);
42
+ processResult(surface, docPath("group/clip-rect.png"));
43
+ });
44
+ it("should clip rounded rect", () => {
45
+ const { surface, canvas } = setupSkia(width, height);
46
+ const { Skia, rect, rrect } = importSkia();
47
+ const Sk = getSkDOM();
48
+ const image = loadImage("skia/__tests__/assets/oslo.jpg");
49
+ const clipRRect = rrect(
50
+ rect(padding, padding, size - padding * 2, size - padding * 2),
51
+ r,
52
+ r
53
+ );
54
+ const root = Sk.Group({ clip: clipRRect });
55
+ root.addChild(
56
+ Sk.Image({ image, fit: "cover", x: 0, y: 0, width: size, height: size })
57
+ );
58
+ const ctx = new JsiDrawingContext(Skia, canvas);
59
+ root.render(ctx);
60
+ processResult(surface, docPath("group/clip-rrect.png"));
61
+ });
62
+ it("Should use a path as a clip", () => {
63
+ const { surface, canvas } = setupSkia(width, height);
64
+ const { Skia, processTransform2d } = importSkia();
65
+ const Sk = getSkDOM();
66
+ const image = loadImage("skia/__tests__/assets/oslo.jpg");
67
+ const clipPath = Skia.Path.MakeFromSVGString(
68
+ "M 128 0 L 168 80 L 256 93 L 192 155 L 207 244 L 128 202 L 49 244 L 64 155 L 0 93 L 88 80 L 128 0 Z"
69
+ )!;
70
+ expect(clipPath).toBeTruthy();
71
+ clipPath.transform(processTransform2d([{ scale: 3 }]));
72
+
73
+ const root = Sk.Group({ clip: clipPath });
74
+
75
+ root.addChild(
76
+ Sk.Image({ image, fit: "cover", x: 0, y: 0, width: size, height: size })
77
+ );
78
+
79
+ const ctx = new JsiDrawingContext(Skia, canvas);
80
+ root.render(ctx);
81
+ processResult(surface, docPath("group/clip-path.png"));
82
+ });
83
+ it("Should invert a clip", () => {
84
+ const { surface, canvas } = setupSkia(width, height);
85
+ const { Skia, processTransform2d } = importSkia();
86
+ const Sk = getSkDOM();
87
+ const image = loadImage("skia/__tests__/assets/oslo.jpg");
88
+ const clipPath = Skia.Path.MakeFromSVGString(
89
+ "M 128 0 L 168 80 L 256 93 L 192 155 L 207 244 L 128 202 L 49 244 L 64 155 L 0 93 L 88 80 L 128 0 Z"
90
+ )!;
91
+ expect(clipPath).toBeTruthy();
92
+ clipPath.transform(processTransform2d([{ scale: 3 }]));
93
+
94
+ const root = Sk.Group({ clip: clipPath, invertClip: true });
95
+ root.addChild(
96
+ Sk.Image({ image, fit: "cover", x: 0, y: 0, width: size, height: size })
97
+ );
98
+ const ctx = new JsiDrawingContext(Skia, canvas);
99
+ root.render(ctx);
100
+ processResult(surface, docPath("group/invert-clip.png"));
101
+ });
102
+ it("Drawing elements inherits group properties", () => {
103
+ const { surface, canvas } = setupSkia(width, height);
104
+ const { Skia, rect } = importSkia();
105
+ const Sk = getSkDOM();
106
+
107
+ const svgPath =
108
+ // eslint-disable-next-line max-len
109
+ "M481.586 193.457C470.446 176.319 382.871 101.323 313.771 101.323C244.671 101.323 207.195 126.054 193.668 142.763C149.967 196.747 134.971 249.875 148.681 302.146C166.676 365.556 216.376 423.397 297.781 475.668C391.183 528.795 451.166 589.207 477.73 656.902C487.156 686.893 488.441 716.456 481.586 745.591C474.731 774.725 461.021 801.289 440.455 825.282C423.317 848.419 400.609 865.128 372.332 875.411C344.054 884.837 309.778 892.12 269.504 897.262C172.674 904.974 93.8398 890.407 33 853.56M559.992 689.035C667.105 531.366 746.796 399.832 799.067 294.434C811.92 264.442 821.346 241.735 827.344 226.31C833.343 210.029 839.341 188.607 845.339 162.043C851.338 135.479 853.48 111.058 851.766 88.7783C849.195 66.4989 838.056 51.0748 818.347 39.9351C798.638 28.7954 784.212 31.7989 761.792 43.7911C724.945 63.4998 700.095 97.3473 687.242 145.334C679.53 165.899 671.817 189.892 664.105 217.313C657.25 244.734 652.109 265.728 648.681 280.295C646.111 294.862 641.398 321.426 634.542 359.987C627.687 397.69 623.403 419.969 621.689 426.825C604.551 533.937 583.985 689.464 559.992 893.406C586.556 800.861 616.976 727.167 651.252 672.326C663.248 648.333 673.531 629.481 682.1 615.771C690.669 602.06 703.094 587.065 719.375 570.784C736.513 554.502 754.508 542.506 773.36 534.794C837.627 510.801 883.9 512.943 912.177 541.221C929.315 559.215 937.884 581.066 937.884 606.773C938.741 632.48 928.887 652.617 908.321 667.185C868.047 689.464 806.779 696.748 724.517 689.035C738.227 693.32 748.51 697.176 755.365 700.604C763.077 703.174 772.503 707.459 783.643 713.457C795.639 719.455 804.637 726.739 810.635 735.308C817.49 743.877 821.775 753.731 823.488 764.871C824.345 769.155 825.631 777.296 827.344 789.293C829.915 801.289 832.057 810.287 833.771 816.285C835.485 822.283 837.627 829.995 840.198 839.421C843.626 848.847 847.482 856.987 851.766 863.843C856.907 869.841 862.906 875.839 869.761 881.838C891.183 902.403 926.745 899.832 976.445 874.125C991.012 867.27 1004.29 858.701 1016.29 848.418C1029.14 838.136 1041.14 825.711 1052.28 811.143C1064.28 795.719 1073.7 783.294 1080.56 773.868C1087.41 763.586 1096.84 748.59 1108.84 728.881C1120.83 709.173 1129.4 695.891 1134.54 689.035C1161.96 634.194 1189.38 579.352 1216.8 524.511C1174.82 629.909 1147.82 710.458 1135.83 766.156C1130.69 782.437 1128.54 801.289 1129.4 822.712C1130.26 844.134 1136.68 861.272 1148.68 874.125C1157.25 884.408 1167.96 891.263 1180.81 894.691C1194.53 898.119 1207.38 897.69 1219.38 893.406C1271.65 877.981 1314.06 847.99 1346.62 803.431C1365.48 777.724 1390.75 739.592 1422.46 689.035M1275.93 367.699C1263.93 367.699 1256.65 362.129 1254.08 350.989C1252.37 338.993 1253.65 328.71 1257.94 320.141C1261.37 313.272 1272.5 314.999 1283.64 314.999C1294.78 314.999 1303.74 321.228 1304.21 329.138M1804.21 655.616C1782.79 595.634 1756.65 558.358 1725.8 543.791C1696.67 526.653 1664.11 518.513 1628.12 519.37C1592.13 519.37 1559.99 528.796 1531.71 547.647C1505.15 563.071 1482.44 583.637 1463.59 609.344C1444.74 634.194 1431.89 661.615 1425.03 691.606C1419.03 720.741 1419.89 750.304 1427.6 780.295C1436.17 809.43 1450.74 834.28 1471.3 854.845C1503.87 882.266 1543.28 895.976 1589.56 895.976C1635.83 895.976 1675.67 882.266 1709.09 854.845C1722.8 841.135 1732.66 831.281 1738.66 825.282C1744.65 819.284 1751.51 810.715 1759.22 799.575C1767.79 788.436 1774.65 776.868 1779.79 764.871M1835.06 523.226C1811.92 618.341 1796.5 701.032 1788.78 771.298C1781.07 825.282 1791.35 862.557 1819.63 883.123C1841.05 900.261 1874.47 897.69 1919.89 875.411C1959.31 856.559 1997.01 819.712 2033 764.871";
110
+ const path = Skia.Path.MakeFromSVGString(svgPath)!;
111
+ expect(path).toBeTruthy();
112
+ const src = path.computeTightBounds();
113
+ const strokeWidth = 30 * PIXEL_RATIO;
114
+ const dst = rect(0, 0, width, height);
115
+ const transform = fitbox("contain", src, dst);
116
+ const root = Sk.Group({ transform });
117
+ root.addChild(
118
+ Sk.Path({
119
+ path,
120
+ strokeCap: "round",
121
+ strokeJoin: "round",
122
+ style: "stroke",
123
+ strokeWidth,
124
+ start: 0,
125
+ end: 1,
126
+ })
127
+ );
128
+ const ctx = new JsiDrawingContext(Skia, canvas);
129
+ root.render(ctx);
130
+ processResult(surface, docPath("group/scale-path.png"));
131
+ });
132
+ });