@solidtv/renderer 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (424) hide show
  1. package/LICENSE +202 -0
  2. package/NOTICE +7 -0
  3. package/README.md +137 -0
  4. package/dist/exports/canvas-shaders.d.ts +10 -0
  5. package/dist/exports/canvas-shaders.js +11 -0
  6. package/dist/exports/canvas-shaders.js.map +1 -0
  7. package/dist/exports/canvas.d.ts +26 -0
  8. package/dist/exports/canvas.js +27 -0
  9. package/dist/exports/canvas.js.map +1 -0
  10. package/dist/exports/index.d.ts +50 -0
  11. package/dist/exports/index.js +40 -0
  12. package/dist/exports/index.js.map +1 -0
  13. package/dist/exports/inspector.d.ts +4 -0
  14. package/dist/exports/inspector.js +5 -0
  15. package/dist/exports/inspector.js.map +1 -0
  16. package/dist/exports/utils.d.ts +27 -0
  17. package/dist/exports/utils.js +28 -0
  18. package/dist/exports/utils.js.map +1 -0
  19. package/dist/exports/webgl-shaders.d.ts +11 -0
  20. package/dist/exports/webgl-shaders.js +12 -0
  21. package/dist/exports/webgl-shaders.js.map +1 -0
  22. package/dist/exports/webgl.d.ts +28 -0
  23. package/dist/exports/webgl.js +29 -0
  24. package/dist/exports/webgl.js.map +1 -0
  25. package/dist/src/common/CommonTypes.d.ts +110 -0
  26. package/dist/src/common/CommonTypes.js +2 -0
  27. package/dist/src/common/CommonTypes.js.map +1 -0
  28. package/dist/src/common/EventEmitter.d.ts +12 -0
  29. package/dist/src/common/EventEmitter.js +48 -0
  30. package/dist/src/common/EventEmitter.js.map +1 -0
  31. package/dist/src/common/IAnimationController.d.ts +58 -0
  32. package/dist/src/common/IAnimationController.js +2 -0
  33. package/dist/src/common/IAnimationController.js.map +1 -0
  34. package/dist/src/common/IEventEmitter.d.ts +8 -0
  35. package/dist/src/common/IEventEmitter.js +2 -0
  36. package/dist/src/common/IEventEmitter.js.map +1 -0
  37. package/dist/src/core/Autosizer.d.ts +35 -0
  38. package/dist/src/core/Autosizer.js +178 -0
  39. package/dist/src/core/Autosizer.js.map +1 -0
  40. package/dist/src/core/CoreNode.d.ts +908 -0
  41. package/dist/src/core/CoreNode.js +1837 -0
  42. package/dist/src/core/CoreNode.js.map +1 -0
  43. package/dist/src/core/CoreShaderManager.d.ts +38 -0
  44. package/dist/src/core/CoreShaderManager.js +123 -0
  45. package/dist/src/core/CoreShaderManager.js.map +1 -0
  46. package/dist/src/core/CoreTextNode.d.ts +91 -0
  47. package/dist/src/core/CoreTextNode.js +440 -0
  48. package/dist/src/core/CoreTextNode.js.map +1 -0
  49. package/dist/src/core/CoreTextureManager.d.ts +264 -0
  50. package/dist/src/core/CoreTextureManager.js +318 -0
  51. package/dist/src/core/CoreTextureManager.js.map +1 -0
  52. package/dist/src/core/Stage.d.ts +238 -0
  53. package/dist/src/core/Stage.js +804 -0
  54. package/dist/src/core/Stage.js.map +1 -0
  55. package/dist/src/core/TextureError.d.ts +11 -0
  56. package/dist/src/core/TextureError.js +37 -0
  57. package/dist/src/core/TextureError.js.map +1 -0
  58. package/dist/src/core/TextureMemoryManager.d.ts +150 -0
  59. package/dist/src/core/TextureMemoryManager.js +239 -0
  60. package/dist/src/core/TextureMemoryManager.js.map +1 -0
  61. package/dist/src/core/animations/AnimationManager.d.ts +33 -0
  62. package/dist/src/core/animations/AnimationManager.js +137 -0
  63. package/dist/src/core/animations/AnimationManager.js.map +1 -0
  64. package/dist/src/core/animations/CoreAnimation.d.ts +12 -0
  65. package/dist/src/core/animations/CoreAnimation.js +107 -0
  66. package/dist/src/core/animations/CoreAnimation.js.map +1 -0
  67. package/dist/src/core/lib/ContextSpy.d.ts +12 -0
  68. package/dist/src/core/lib/ContextSpy.js +20 -0
  69. package/dist/src/core/lib/ContextSpy.js.map +1 -0
  70. package/dist/src/core/lib/ImageWorker.d.ts +16 -0
  71. package/dist/src/core/lib/ImageWorker.js +202 -0
  72. package/dist/src/core/lib/ImageWorker.js.map +1 -0
  73. package/dist/src/core/lib/Matrix3d.d.ts +74 -0
  74. package/dist/src/core/lib/Matrix3d.js +218 -0
  75. package/dist/src/core/lib/Matrix3d.js.map +1 -0
  76. package/dist/src/core/lib/RenderCoords.d.ts +12 -0
  77. package/dist/src/core/lib/RenderCoords.js +35 -0
  78. package/dist/src/core/lib/RenderCoords.js.map +1 -0
  79. package/dist/src/core/lib/WebGlContextWrapper.d.ts +782 -0
  80. package/dist/src/core/lib/WebGlContextWrapper.js +1143 -0
  81. package/dist/src/core/lib/WebGlContextWrapper.js.map +1 -0
  82. package/dist/src/core/lib/collectionUtils.d.ts +5 -0
  83. package/dist/src/core/lib/collectionUtils.js +82 -0
  84. package/dist/src/core/lib/collectionUtils.js.map +1 -0
  85. package/dist/src/core/lib/colorCache.d.ts +1 -0
  86. package/dist/src/core/lib/colorCache.js +19 -0
  87. package/dist/src/core/lib/colorCache.js.map +1 -0
  88. package/dist/src/core/lib/colorParser.d.ts +21 -0
  89. package/dist/src/core/lib/colorParser.js +54 -0
  90. package/dist/src/core/lib/colorParser.js.map +1 -0
  91. package/dist/src/core/lib/textureCompression.d.ts +28 -0
  92. package/dist/src/core/lib/textureCompression.js +363 -0
  93. package/dist/src/core/lib/textureCompression.js.map +1 -0
  94. package/dist/src/core/lib/textureSvg.d.ts +16 -0
  95. package/dist/src/core/lib/textureSvg.js +45 -0
  96. package/dist/src/core/lib/textureSvg.js.map +1 -0
  97. package/dist/src/core/lib/utils.d.ts +66 -0
  98. package/dist/src/core/lib/utils.js +268 -0
  99. package/dist/src/core/lib/utils.js.map +1 -0
  100. package/dist/src/core/lib/validateImageBitmap.d.ts +7 -0
  101. package/dist/src/core/lib/validateImageBitmap.js +68 -0
  102. package/dist/src/core/lib/validateImageBitmap.js.map +1 -0
  103. package/dist/src/core/platforms/Platform.d.ts +42 -0
  104. package/dist/src/core/platforms/Platform.js +4 -0
  105. package/dist/src/core/platforms/Platform.js.map +1 -0
  106. package/dist/src/core/platforms/web/WebPlatform.d.ts +10 -0
  107. package/dist/src/core/platforms/web/WebPlatform.js +90 -0
  108. package/dist/src/core/platforms/web/WebPlatform.js.map +1 -0
  109. package/dist/src/core/renderers/CoreContextTexture.d.ts +13 -0
  110. package/dist/src/core/renderers/CoreContextTexture.js +16 -0
  111. package/dist/src/core/renderers/CoreContextTexture.js.map +1 -0
  112. package/dist/src/core/renderers/CoreRenderOp.d.ts +3 -0
  113. package/dist/src/core/renderers/CoreRenderOp.js +3 -0
  114. package/dist/src/core/renderers/CoreRenderOp.js.map +1 -0
  115. package/dist/src/core/renderers/CoreRenderer.d.ts +81 -0
  116. package/dist/src/core/renderers/CoreRenderer.js +14 -0
  117. package/dist/src/core/renderers/CoreRenderer.js.map +1 -0
  118. package/dist/src/core/renderers/CoreShaderNode.d.ts +69 -0
  119. package/dist/src/core/renderers/CoreShaderNode.js +130 -0
  120. package/dist/src/core/renderers/CoreShaderNode.js.map +1 -0
  121. package/dist/src/core/renderers/CoreShaderProgram.d.ts +4 -0
  122. package/dist/src/core/renderers/CoreShaderProgram.js +2 -0
  123. package/dist/src/core/renderers/CoreShaderProgram.js.map +1 -0
  124. package/dist/src/core/renderers/canvas/CanvasRenderer.d.ts +36 -0
  125. package/dist/src/core/renderers/canvas/CanvasRenderer.js +221 -0
  126. package/dist/src/core/renderers/canvas/CanvasRenderer.js.map +1 -0
  127. package/dist/src/core/renderers/canvas/CanvasShaderNode.d.ts +21 -0
  128. package/dist/src/core/renderers/canvas/CanvasShaderNode.js +42 -0
  129. package/dist/src/core/renderers/canvas/CanvasShaderNode.js.map +1 -0
  130. package/dist/src/core/renderers/canvas/CanvasTexture.d.ts +17 -0
  131. package/dist/src/core/renderers/canvas/CanvasTexture.js +110 -0
  132. package/dist/src/core/renderers/canvas/CanvasTexture.js.map +1 -0
  133. package/dist/src/core/renderers/webgl/SdfRenderOp.d.ts +41 -0
  134. package/dist/src/core/renderers/webgl/SdfRenderOp.js +88 -0
  135. package/dist/src/core/renderers/webgl/SdfRenderOp.js.map +1 -0
  136. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.d.ts +14 -0
  137. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js +45 -0
  138. package/dist/src/core/renderers/webgl/WebGlCtxRenderTexture.js.map +1 -0
  139. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.d.ts +22 -0
  140. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js +49 -0
  141. package/dist/src/core/renderers/webgl/WebGlCtxSubTexture.js.map +1 -0
  142. package/dist/src/core/renderers/webgl/WebGlCtxTexture.d.ts +67 -0
  143. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js +259 -0
  144. package/dist/src/core/renderers/webgl/WebGlCtxTexture.js.map +1 -0
  145. package/dist/src/core/renderers/webgl/WebGlRenderer.d.ts +221 -0
  146. package/dist/src/core/renderers/webgl/WebGlRenderer.js +1015 -0
  147. package/dist/src/core/renderers/webgl/WebGlRenderer.js.map +1 -0
  148. package/dist/src/core/renderers/webgl/WebGlShaderNode.d.ts +213 -0
  149. package/dist/src/core/renderers/webgl/WebGlShaderNode.js +331 -0
  150. package/dist/src/core/renderers/webgl/WebGlShaderNode.js.map +1 -0
  151. package/dist/src/core/renderers/webgl/WebGlShaderProgram.d.ts +37 -0
  152. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js +240 -0
  153. package/dist/src/core/renderers/webgl/WebGlShaderProgram.js.map +1 -0
  154. package/dist/src/core/renderers/webgl/internal/BufferCollection.d.ts +28 -0
  155. package/dist/src/core/renderers/webgl/internal/BufferCollection.js +39 -0
  156. package/dist/src/core/renderers/webgl/internal/BufferCollection.js.map +1 -0
  157. package/dist/src/core/renderers/webgl/internal/RendererUtils.d.ts +55 -0
  158. package/dist/src/core/renderers/webgl/internal/RendererUtils.js +88 -0
  159. package/dist/src/core/renderers/webgl/internal/RendererUtils.js.map +1 -0
  160. package/dist/src/core/renderers/webgl/internal/ShaderUtils.d.ts +74 -0
  161. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js +83 -0
  162. package/dist/src/core/renderers/webgl/internal/ShaderUtils.js.map +1 -0
  163. package/dist/src/core/renderers/webgl/internal/WebGlUtils.d.ts +10 -0
  164. package/dist/src/core/renderers/webgl/internal/WebGlUtils.js +13 -0
  165. package/dist/src/core/renderers/webgl/internal/WebGlUtils.js.map +1 -0
  166. package/dist/src/core/shaders/canvas/Border.d.ts +15 -0
  167. package/dist/src/core/shaders/canvas/Border.js +83 -0
  168. package/dist/src/core/shaders/canvas/Border.js.map +1 -0
  169. package/dist/src/core/shaders/canvas/HolePunch.d.ts +7 -0
  170. package/dist/src/core/shaders/canvas/HolePunch.js +22 -0
  171. package/dist/src/core/shaders/canvas/HolePunch.js.map +1 -0
  172. package/dist/src/core/shaders/canvas/LinearGradient.d.ts +10 -0
  173. package/dist/src/core/shaders/canvas/LinearGradient.js +32 -0
  174. package/dist/src/core/shaders/canvas/LinearGradient.js.map +1 -0
  175. package/dist/src/core/shaders/canvas/RadialGradient.d.ts +11 -0
  176. package/dist/src/core/shaders/canvas/RadialGradient.js +54 -0
  177. package/dist/src/core/shaders/canvas/RadialGradient.js.map +1 -0
  178. package/dist/src/core/shaders/canvas/Rounded.d.ts +7 -0
  179. package/dist/src/core/shaders/canvas/Rounded.js +17 -0
  180. package/dist/src/core/shaders/canvas/Rounded.js.map +1 -0
  181. package/dist/src/core/shaders/canvas/RoundedWithBorder.d.ts +10 -0
  182. package/dist/src/core/shaders/canvas/RoundedWithBorder.js +57 -0
  183. package/dist/src/core/shaders/canvas/RoundedWithBorder.js.map +1 -0
  184. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.d.ts +7 -0
  185. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js +61 -0
  186. package/dist/src/core/shaders/canvas/RoundedWithBorderAndShadow.js.map +1 -0
  187. package/dist/src/core/shaders/canvas/RoundedWithShadow.d.ts +7 -0
  188. package/dist/src/core/shaders/canvas/RoundedWithShadow.js +26 -0
  189. package/dist/src/core/shaders/canvas/RoundedWithShadow.js.map +1 -0
  190. package/dist/src/core/shaders/canvas/Shadow.d.ts +8 -0
  191. package/dist/src/core/shaders/canvas/Shadow.js +15 -0
  192. package/dist/src/core/shaders/canvas/Shadow.js.map +1 -0
  193. package/dist/src/core/shaders/canvas/utils/render.d.ts +5 -0
  194. package/dist/src/core/shaders/canvas/utils/render.js +81 -0
  195. package/dist/src/core/shaders/canvas/utils/render.js.map +1 -0
  196. package/dist/src/core/shaders/templates/BorderTemplate.d.ts +47 -0
  197. package/dist/src/core/shaders/templates/BorderTemplate.js +77 -0
  198. package/dist/src/core/shaders/templates/BorderTemplate.js.map +1 -0
  199. package/dist/src/core/shaders/templates/HolePunchTemplate.d.ts +46 -0
  200. package/dist/src/core/shaders/templates/HolePunchTemplate.js +19 -0
  201. package/dist/src/core/shaders/templates/HolePunchTemplate.js.map +1 -0
  202. package/dist/src/core/shaders/templates/LinearGradientTemplate.d.ts +23 -0
  203. package/dist/src/core/shaders/templates/LinearGradientTemplate.js +31 -0
  204. package/dist/src/core/shaders/templates/LinearGradientTemplate.js.map +1 -0
  205. package/dist/src/core/shaders/templates/RadialGradientTemplate.d.ts +33 -0
  206. package/dist/src/core/shaders/templates/RadialGradientTemplate.js +33 -0
  207. package/dist/src/core/shaders/templates/RadialGradientTemplate.js.map +1 -0
  208. package/dist/src/core/shaders/templates/RoundedTemplate.d.ts +29 -0
  209. package/dist/src/core/shaders/templates/RoundedTemplate.js +51 -0
  210. package/dist/src/core/shaders/templates/RoundedTemplate.js.map +1 -0
  211. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.d.ts +7 -0
  212. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js +8 -0
  213. package/dist/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.js.map +1 -0
  214. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.d.ts +8 -0
  215. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js +9 -0
  216. package/dist/src/core/shaders/templates/RoundedWithBorderTemplate.js.map +1 -0
  217. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.d.ts +6 -0
  218. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js +7 -0
  219. package/dist/src/core/shaders/templates/RoundedWithShadowTemplate.js.map +1 -0
  220. package/dist/src/core/shaders/templates/ShadowTemplate.d.ts +34 -0
  221. package/dist/src/core/shaders/templates/ShadowTemplate.js +50 -0
  222. package/dist/src/core/shaders/templates/ShadowTemplate.js.map +1 -0
  223. package/dist/src/core/shaders/utils.d.ts +5 -0
  224. package/dist/src/core/shaders/utils.js +25 -0
  225. package/dist/src/core/shaders/utils.js.map +1 -0
  226. package/dist/src/core/shaders/webgl/Border.d.ts +3 -0
  227. package/dist/src/core/shaders/webgl/Border.js +153 -0
  228. package/dist/src/core/shaders/webgl/Border.js.map +1 -0
  229. package/dist/src/core/shaders/webgl/Default.d.ts +2 -0
  230. package/dist/src/core/shaders/webgl/Default.js +51 -0
  231. package/dist/src/core/shaders/webgl/Default.js.map +1 -0
  232. package/dist/src/core/shaders/webgl/HolePunch.d.ts +3 -0
  233. package/dist/src/core/shaders/webgl/HolePunch.js +49 -0
  234. package/dist/src/core/shaders/webgl/HolePunch.js.map +1 -0
  235. package/dist/src/core/shaders/webgl/LinearGradient.d.ts +3 -0
  236. package/dist/src/core/shaders/webgl/LinearGradient.js +114 -0
  237. package/dist/src/core/shaders/webgl/LinearGradient.js.map +1 -0
  238. package/dist/src/core/shaders/webgl/RadialGradient.d.ts +3 -0
  239. package/dist/src/core/shaders/webgl/RadialGradient.js +81 -0
  240. package/dist/src/core/shaders/webgl/RadialGradient.js.map +1 -0
  241. package/dist/src/core/shaders/webgl/Rounded.d.ts +7 -0
  242. package/dist/src/core/shaders/webgl/Rounded.js +88 -0
  243. package/dist/src/core/shaders/webgl/Rounded.js.map +1 -0
  244. package/dist/src/core/shaders/webgl/RoundedWithBorder.d.ts +3 -0
  245. package/dist/src/core/shaders/webgl/RoundedWithBorder.js +202 -0
  246. package/dist/src/core/shaders/webgl/RoundedWithBorder.js.map +1 -0
  247. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.d.ts +3 -0
  248. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js +223 -0
  249. package/dist/src/core/shaders/webgl/RoundedWithBorderAndShadow.js.map +1 -0
  250. package/dist/src/core/shaders/webgl/RoundedWithShadow.d.ts +3 -0
  251. package/dist/src/core/shaders/webgl/RoundedWithShadow.js +123 -0
  252. package/dist/src/core/shaders/webgl/RoundedWithShadow.js.map +1 -0
  253. package/dist/src/core/shaders/webgl/SdfShader.d.ts +13 -0
  254. package/dist/src/core/shaders/webgl/SdfShader.js +72 -0
  255. package/dist/src/core/shaders/webgl/SdfShader.js.map +1 -0
  256. package/dist/src/core/shaders/webgl/Shadow.d.ts +3 -0
  257. package/dist/src/core/shaders/webgl/Shadow.js +115 -0
  258. package/dist/src/core/shaders/webgl/Shadow.js.map +1 -0
  259. package/dist/src/core/text-rendering/CanvasFontHandler.d.ts +59 -0
  260. package/dist/src/core/text-rendering/CanvasFontHandler.js +206 -0
  261. package/dist/src/core/text-rendering/CanvasFontHandler.js.map +1 -0
  262. package/dist/src/core/text-rendering/CanvasTextRenderer.d.ts +17 -0
  263. package/dist/src/core/text-rendering/CanvasTextRenderer.js +139 -0
  264. package/dist/src/core/text-rendering/CanvasTextRenderer.js.map +1 -0
  265. package/dist/src/core/text-rendering/SdfFontHandler.d.ts +167 -0
  266. package/dist/src/core/text-rendering/SdfFontHandler.js +371 -0
  267. package/dist/src/core/text-rendering/SdfFontHandler.js.map +1 -0
  268. package/dist/src/core/text-rendering/SdfTextRenderer.d.ts +17 -0
  269. package/dist/src/core/text-rendering/SdfTextRenderer.js +249 -0
  270. package/dist/src/core/text-rendering/SdfTextRenderer.js.map +1 -0
  271. package/dist/src/core/text-rendering/TextLayoutEngine.d.ts +18 -0
  272. package/dist/src/core/text-rendering/TextLayoutEngine.js +380 -0
  273. package/dist/src/core/text-rendering/TextLayoutEngine.js.map +1 -0
  274. package/dist/src/core/text-rendering/TextRenderer.d.ts +406 -0
  275. package/dist/src/core/text-rendering/TextRenderer.js +2 -0
  276. package/dist/src/core/text-rendering/TextRenderer.js.map +1 -0
  277. package/dist/src/core/text-rendering/Utils.d.ts +30 -0
  278. package/dist/src/core/text-rendering/Utils.js +66 -0
  279. package/dist/src/core/text-rendering/Utils.js.map +1 -0
  280. package/dist/src/core/textures/ColorTexture.d.ts +36 -0
  281. package/dist/src/core/textures/ColorTexture.js +57 -0
  282. package/dist/src/core/textures/ColorTexture.js.map +1 -0
  283. package/dist/src/core/textures/ImageTexture.d.ts +131 -0
  284. package/dist/src/core/textures/ImageTexture.js +211 -0
  285. package/dist/src/core/textures/ImageTexture.js.map +1 -0
  286. package/dist/src/core/textures/NoiseTexture.d.ts +43 -0
  287. package/dist/src/core/textures/NoiseTexture.js +50 -0
  288. package/dist/src/core/textures/NoiseTexture.js.map +1 -0
  289. package/dist/src/core/textures/RenderTexture.d.ts +29 -0
  290. package/dist/src/core/textures/RenderTexture.js +36 -0
  291. package/dist/src/core/textures/RenderTexture.js.map +1 -0
  292. package/dist/src/core/textures/SubTexture.d.ts +61 -0
  293. package/dist/src/core/textures/SubTexture.js +99 -0
  294. package/dist/src/core/textures/SubTexture.js.map +1 -0
  295. package/dist/src/core/textures/Texture.d.ts +275 -0
  296. package/dist/src/core/textures/Texture.js +326 -0
  297. package/dist/src/core/textures/Texture.js.map +1 -0
  298. package/dist/src/core/utils.d.ts +23 -0
  299. package/dist/src/core/utils.js +155 -0
  300. package/dist/src/core/utils.js.map +1 -0
  301. package/dist/src/main-api/INode.d.ts +65 -0
  302. package/dist/src/main-api/INode.js +2 -0
  303. package/dist/src/main-api/INode.js.map +1 -0
  304. package/dist/src/main-api/Inspector.d.ts +154 -0
  305. package/dist/src/main-api/Inspector.js +844 -0
  306. package/dist/src/main-api/Inspector.js.map +1 -0
  307. package/dist/src/main-api/Renderer.d.ts +629 -0
  308. package/dist/src/main-api/Renderer.js +471 -0
  309. package/dist/src/main-api/Renderer.js.map +1 -0
  310. package/dist/src/main-api/utils.d.ts +2 -0
  311. package/dist/src/main-api/utils.js +34 -0
  312. package/dist/src/main-api/utils.js.map +1 -0
  313. package/dist/src/utils.d.ts +123 -0
  314. package/dist/src/utils.js +234 -0
  315. package/dist/src/utils.js.map +1 -0
  316. package/dist/tsconfig.dist.tsbuildinfo +1 -0
  317. package/exports/canvas-shaders.ts +11 -0
  318. package/exports/canvas.ts +27 -0
  319. package/exports/index.ts +69 -0
  320. package/exports/inspector.ts +5 -0
  321. package/exports/utils.ts +32 -0
  322. package/exports/webgl-shaders.ts +12 -0
  323. package/exports/webgl.ts +33 -0
  324. package/package.json +99 -0
  325. package/src/common/CommonTypes.ts +145 -0
  326. package/src/common/EventEmitter.ts +58 -0
  327. package/src/common/IAnimationController.ts +65 -0
  328. package/src/common/IEventEmitter.ts +11 -0
  329. package/src/core/Autosizer.ts +205 -0
  330. package/src/core/CoreNode.test.ts +535 -0
  331. package/src/core/CoreNode.ts +2883 -0
  332. package/src/core/CoreShaderManager.ts +170 -0
  333. package/src/core/CoreTextNode.ts +573 -0
  334. package/src/core/CoreTextureManager.ts +552 -0
  335. package/src/core/Stage.ts +1037 -0
  336. package/src/core/TextureError.ts +46 -0
  337. package/src/core/TextureMemoryManager.ts +378 -0
  338. package/src/core/animations/AnimationManager.ts +178 -0
  339. package/src/core/animations/CoreAnimation.ts +138 -0
  340. package/src/core/lib/ContextSpy.ts +22 -0
  341. package/src/core/lib/ImageWorker.ts +292 -0
  342. package/src/core/lib/Matrix3d.ts +231 -0
  343. package/src/core/lib/RenderCoords.ts +55 -0
  344. package/src/core/lib/WebGlContextWrapper.ts +1448 -0
  345. package/src/core/lib/collectionUtils.ts +99 -0
  346. package/src/core/lib/colorCache.ts +20 -0
  347. package/src/core/lib/colorParser.ts +66 -0
  348. package/src/core/lib/textureCompression.ts +492 -0
  349. package/src/core/lib/textureSvg.ts +59 -0
  350. package/src/core/lib/utils.ts +400 -0
  351. package/src/core/lib/validateImageBitmap.ts +87 -0
  352. package/src/core/platforms/Platform.ts +64 -0
  353. package/src/core/platforms/web/WebPlatform.ts +132 -0
  354. package/src/core/renderers/CoreContextTexture.ts +25 -0
  355. package/src/core/renderers/CoreRenderOp.ts +3 -0
  356. package/src/core/renderers/CoreRenderer.ts +101 -0
  357. package/src/core/renderers/CoreShaderNode.ts +202 -0
  358. package/src/core/renderers/CoreShaderProgram.ts +4 -0
  359. package/src/core/renderers/canvas/CanvasRenderer.ts +274 -0
  360. package/src/core/renderers/canvas/CanvasShaderNode.ts +79 -0
  361. package/src/core/renderers/canvas/CanvasTexture.ts +141 -0
  362. package/src/core/renderers/webgl/SdfRenderOp.ts +103 -0
  363. package/src/core/renderers/webgl/WebGlCtxRenderTexture.ts +70 -0
  364. package/src/core/renderers/webgl/WebGlCtxSubTexture.ts +76 -0
  365. package/src/core/renderers/webgl/WebGlCtxTexture.ts +332 -0
  366. package/src/core/renderers/webgl/WebGlRenderer.ts +1323 -0
  367. package/src/core/renderers/webgl/WebGlShaderNode.ts +423 -0
  368. package/src/core/renderers/webgl/WebGlShaderProgram.ts +346 -0
  369. package/src/core/renderers/webgl/internal/BufferCollection.ts +46 -0
  370. package/src/core/renderers/webgl/internal/RendererUtils.ts +136 -0
  371. package/src/core/renderers/webgl/internal/ShaderUtils.ts +262 -0
  372. package/src/core/renderers/webgl/internal/WebGlUtils.ts +16 -0
  373. package/src/core/shaders/canvas/Border.ts +119 -0
  374. package/src/core/shaders/canvas/HolePunch.ts +38 -0
  375. package/src/core/shaders/canvas/LinearGradient.ts +54 -0
  376. package/src/core/shaders/canvas/RadialGradient.ts +82 -0
  377. package/src/core/shaders/canvas/Rounded.ts +38 -0
  378. package/src/core/shaders/canvas/RoundedWithBorder.ts +105 -0
  379. package/src/core/shaders/canvas/RoundedWithBorderAndShadow.ts +118 -0
  380. package/src/core/shaders/canvas/RoundedWithShadow.ts +56 -0
  381. package/src/core/shaders/canvas/Shadow.ts +35 -0
  382. package/src/core/shaders/canvas/utils/render.ts +143 -0
  383. package/src/core/shaders/templates/BorderTemplate.ts +128 -0
  384. package/src/core/shaders/templates/HolePunchTemplate.ts +65 -0
  385. package/src/core/shaders/templates/LinearGradientTemplate.ts +54 -0
  386. package/src/core/shaders/templates/RadialGradientTemplate.ts +66 -0
  387. package/src/core/shaders/templates/RoundedTemplate.ts +81 -0
  388. package/src/core/shaders/templates/RoundedWithBorderAndShadowTemplate.ts +21 -0
  389. package/src/core/shaders/templates/RoundedWithBorderTemplate.ts +23 -0
  390. package/src/core/shaders/templates/RoundedWithShadowTemplate.ts +18 -0
  391. package/src/core/shaders/templates/ShadowTemplate.ts +89 -0
  392. package/src/core/shaders/utils.ts +30 -0
  393. package/src/core/shaders/webgl/Border.ts +158 -0
  394. package/src/core/shaders/webgl/Default.ts +52 -0
  395. package/src/core/shaders/webgl/HolePunch.ts +58 -0
  396. package/src/core/shaders/webgl/LinearGradient.ts +119 -0
  397. package/src/core/shaders/webgl/RadialGradient.ts +91 -0
  398. package/src/core/shaders/webgl/Rounded.ts +97 -0
  399. package/src/core/shaders/webgl/RoundedWithBorder.ts +212 -0
  400. package/src/core/shaders/webgl/RoundedWithBorderAndShadow.ts +235 -0
  401. package/src/core/shaders/webgl/RoundedWithShadow.ts +132 -0
  402. package/src/core/shaders/webgl/SdfShader.ts +73 -0
  403. package/src/core/shaders/webgl/Shadow.ts +119 -0
  404. package/src/core/text-rendering/CanvasFontHandler.ts +285 -0
  405. package/src/core/text-rendering/CanvasTextRenderer.ts +236 -0
  406. package/src/core/text-rendering/SdfFontHandler.ts +566 -0
  407. package/src/core/text-rendering/SdfTextRenderer.ts +352 -0
  408. package/src/core/text-rendering/TextLayoutEngine.ts +672 -0
  409. package/src/core/text-rendering/TextRenderer.ts +449 -0
  410. package/src/core/text-rendering/Utils.ts +80 -0
  411. package/src/core/text-rendering/tests/TextLayoutEngine.test.ts +434 -0
  412. package/src/core/textures/ColorTexture.ts +85 -0
  413. package/src/core/textures/ImageTexture.ts +394 -0
  414. package/src/core/textures/NoiseTexture.ts +87 -0
  415. package/src/core/textures/RenderTexture.ts +68 -0
  416. package/src/core/textures/SubTexture.ts +165 -0
  417. package/src/core/textures/Texture.ts +505 -0
  418. package/src/core/utils.ts +210 -0
  419. package/src/env.d.ts +7 -0
  420. package/src/main-api/INode.ts +92 -0
  421. package/src/main-api/Inspector.ts +1267 -0
  422. package/src/main-api/Renderer.ts +1011 -0
  423. package/src/main-api/utils.ts +45 -0
  424. package/src/utils.ts +302 -0
@@ -0,0 +1,505 @@
1
+ import type { CoreTextureManager } from '../CoreTextureManager.js';
2
+ import type { SubTextureProps } from './SubTexture.js';
3
+ import type { Dimensions } from '../../common/CommonTypes.js';
4
+ import { EventEmitter } from '../../common/EventEmitter.js';
5
+ import type { CoreContextTexture } from '../renderers/CoreContextTexture.js';
6
+ import type { Bound } from '../lib/utils.js';
7
+ import type { TextureError } from '../TextureError.js';
8
+
9
+ /**
10
+ * Event handler for when a Texture is freed
11
+ */
12
+ export type TextureFreedEventHandler = (target: any) => void;
13
+
14
+ /**
15
+ * Event handler for when a Texture is loading
16
+ */
17
+ export type TextureLoadingEventHandler = (target: any) => void;
18
+
19
+ /**
20
+ * Event handler for when a Texture is loaded
21
+ */
22
+ export type TextureLoadedEventHandler = (
23
+ target: any,
24
+ dimensions: Readonly<Dimensions>,
25
+ ) => void;
26
+
27
+ /**
28
+ * Represents compressed texture data.
29
+ */
30
+ export interface CompressedData {
31
+ /**
32
+ * GLenum spcifying compression format
33
+ */
34
+ glInternalFormat: number;
35
+
36
+ /**
37
+ * All mipmap levels
38
+ */
39
+ mipmaps: ArrayBuffer[];
40
+
41
+ /**
42
+ * Supported container types ('pvr' or 'ktx').
43
+ */
44
+ type: 'pvr' | 'ktx' | 'astc';
45
+
46
+ /**
47
+ * The width of the compressed texture in pixels. Defaults to 0.
48
+ *
49
+ * @default 0
50
+ */
51
+ w: number;
52
+
53
+ /**
54
+ * The height of the compressed texture in pixels.
55
+ **/
56
+ h: number;
57
+
58
+ /**
59
+ * block info compressed texture format
60
+ */
61
+ blockInfo: {
62
+ width: number;
63
+ height: number;
64
+ bytes: number;
65
+ };
66
+ }
67
+
68
+ /**
69
+ * Event handler for when a Texture fails to load
70
+ */
71
+ export type TextureFailedEventHandler = (
72
+ target: any,
73
+ error: TextureError,
74
+ ) => void;
75
+
76
+ /**
77
+ * TextureData that is used to populate a CoreContextTexture
78
+ */
79
+ export interface TextureData {
80
+ /**
81
+ * The texture data
82
+ */
83
+ data:
84
+ | ImageBitmap
85
+ | ImageData
86
+ | SubTextureProps
87
+ | CompressedData
88
+ | HTMLImageElement
89
+ | Uint8Array
90
+ | null;
91
+ /**
92
+ * Premultiply alpha when uploading texture data to the GPU
93
+ *
94
+ * @defaultValue `false`
95
+ */
96
+ premultiplyAlpha?: boolean | null;
97
+ }
98
+ /**
99
+ * TextureCoords generally numbers between 0 - 1
100
+ */
101
+ export type TextureCoords = Bound;
102
+
103
+ export type TextureState =
104
+ | 'initial' // Before anything is loaded
105
+ | 'fetching' // Fetching or generating texture source
106
+ | 'fetched' // Texture source is ready
107
+ | 'loading' // Uploading to GPU
108
+ | 'loaded' // Fully loaded and usable
109
+ | 'failed' // Failed to load
110
+ | 'freed'; // Released and must be reloaded
111
+
112
+ export enum TextureType {
113
+ 'generic' = 0,
114
+ 'color' = 1,
115
+ 'image' = 2,
116
+ 'noise' = 3,
117
+ 'renderToTexture' = 4,
118
+ 'subTexture' = 5,
119
+ }
120
+
121
+ /**
122
+ * Represents a source of texture data for a CoreContextTexture.
123
+ *
124
+ * @remarks
125
+ * Texture sources are used to populate a CoreContextTexture when that texture
126
+ * is loaded. Texture data retrieved by the CoreContextTexture by the
127
+ * `getTextureData` method. It's the responsibility of the concerete `Texture`
128
+ * subclass to implement this method appropriately.
129
+ */
130
+ export abstract class Texture extends EventEmitter {
131
+ /**
132
+ * The dimensions of the texture
133
+ *
134
+ * @remarks
135
+ * Until the texture data is loaded for the first time the value will be
136
+ * `null`.
137
+ */
138
+ private _dimensions: Dimensions | null = null;
139
+ private _error: TextureError | null = null;
140
+
141
+ // aggregate state
142
+ public state: TextureState = 'initial';
143
+
144
+ readonly renderableOwners: any[] = [];
145
+
146
+ readonly renderable: boolean = false;
147
+
148
+ public type: TextureType = TextureType.generic;
149
+
150
+ public preventCleanup = false;
151
+
152
+ public ctxTexture: CoreContextTexture | undefined;
153
+
154
+ public textureData: TextureData | null = null;
155
+
156
+ public memUsed = 0;
157
+
158
+ /**
159
+ * Memory used by this texture in bytes
160
+ *
161
+ * @remarks
162
+ * This is tracked by the TextureMemoryManager and updated when the texture
163
+ * is loaded/freed. Set to 0 when texture is not loaded.
164
+ */
165
+ public retryCount = 0;
166
+ public maxRetryCount: number;
167
+
168
+ /**
169
+ * Timestamp when texture was created (for startup grace period)
170
+ */
171
+ private createdAt: number = Date.now();
172
+
173
+ /**
174
+ * Flag to track if grace period has expired to avoid repeated Date.now() calls
175
+ */
176
+ private gracePeriodExpired: boolean = false;
177
+
178
+ /**
179
+ * Grace period in milliseconds to prevent premature cleanup during app startup
180
+ * This helps prevent race conditions when bounds calculation is delayed
181
+ */
182
+ private static readonly STARTUP_GRACE_PERIOD = 2000; // 2 seconds
183
+
184
+ constructor(protected txManager: CoreTextureManager) {
185
+ super();
186
+ this.maxRetryCount = this.txManager.maxRetryCount;
187
+ }
188
+
189
+ get dimensions(): Dimensions | null {
190
+ return this._dimensions;
191
+ }
192
+
193
+ get error(): TextureError | null {
194
+ return this._error;
195
+ }
196
+
197
+ /**
198
+ * Checks if the texture is within the startup grace period.
199
+ * During this period, textures are protected from cleanup to prevent
200
+ * race conditions during app initialization.
201
+ */
202
+ isWithinStartupGracePeriod(): boolean {
203
+ // If grace period already expired, return false immediately
204
+ if (this.gracePeriodExpired === true) {
205
+ return false;
206
+ }
207
+
208
+ // Check if grace period has expired now
209
+ const hasExpired =
210
+ Date.now() - this.createdAt >= Texture.STARTUP_GRACE_PERIOD;
211
+
212
+ if (hasExpired) {
213
+ // Cache the result to avoid future Date.now() calls
214
+ this.gracePeriodExpired = true;
215
+ return false;
216
+ }
217
+
218
+ return true;
219
+ }
220
+
221
+ /**
222
+ * Checks if the texture can be safely cleaned up.
223
+ * Considers the renderable state, startup grace period, and renderable owners.
224
+ */
225
+ canBeCleanedUp(): boolean {
226
+ // Never cleanup if explicitly prevented
227
+ if (this.preventCleanup) {
228
+ return false;
229
+ }
230
+
231
+ // Don't cleanup if still within startup grace period
232
+ if (this.isWithinStartupGracePeriod()) {
233
+ return false;
234
+ }
235
+
236
+ // Don't cleanup if not renderable
237
+ if (this.renderable === true) {
238
+ return false;
239
+ }
240
+
241
+ // Don't cleanup if there are still renderable owners
242
+ if (this.renderableOwners.length > 0) {
243
+ return false;
244
+ }
245
+
246
+ // Safe to cleanup
247
+ return true;
248
+ }
249
+
250
+ /**
251
+ * Add/remove an owner to/from the Texture based on its renderability.
252
+ *
253
+ * @remarks
254
+ * Any object can own a texture, be it a CoreNode or even the state object
255
+ * from a Text Renderer.
256
+ *
257
+ * When the reference to the texture that an owner object holds is replaced
258
+ * or cleared it must call this with `renderable=false` to release the owner
259
+ * association.
260
+ *
261
+ * @param owner
262
+ * @param renderable
263
+ */
264
+ setRenderableOwner(owner: string | number, renderable: boolean): void {
265
+ const oldSize = this.renderableOwners.length;
266
+ const hasOwnerIndex = this.renderableOwners.indexOf(owner);
267
+
268
+ if (renderable === true) {
269
+ if (hasOwnerIndex === -1) {
270
+ // Add the owner to the set
271
+ this.renderableOwners.push(owner);
272
+ }
273
+
274
+ const newSize = this.renderableOwners.length;
275
+ if (oldSize !== newSize && newSize === 1) {
276
+ (this.renderable as boolean) = true;
277
+ this.onChangeIsRenderable?.(true);
278
+ this.load();
279
+ }
280
+ } else {
281
+ if (hasOwnerIndex !== -1) {
282
+ this.renderableOwners.splice(hasOwnerIndex, 1);
283
+ }
284
+
285
+ const newSize = this.renderableOwners.length;
286
+ if (oldSize !== newSize && newSize === 0) {
287
+ (this.renderable as boolean) = false;
288
+ this.onChangeIsRenderable?.(false);
289
+
290
+ // note, not doing a cleanup here, cleanup is managed by the Stage/TextureMemoryManager
291
+ // when it deems appropriate based on memory pressure
292
+ }
293
+ }
294
+ }
295
+
296
+ load(): void {
297
+ if (this.retryCount > this.maxRetryCount) {
298
+ // We've exceeded the max retry count, do not attempt to load again
299
+ return;
300
+ }
301
+ this.txManager.loadTexture(this);
302
+ }
303
+
304
+ /**
305
+ * Event called when the Texture becomes renderable or unrenderable.
306
+ *
307
+ * @remarks
308
+ * Used by subclasses like SubTexture propogate then renderability of the
309
+ * Texture to other referenced Textures.
310
+ *
311
+ * @param isRenderable `true` if this Texture has renderable owners.
312
+ */
313
+ onChangeIsRenderable?(isRenderable: boolean): void;
314
+
315
+ /**
316
+ * Load the core context texture for this Texture.
317
+ * The ctxTexture is created by the renderer and lives on the GPU.
318
+ *
319
+ * @returns
320
+ */
321
+ loadCtxTexture(): CoreContextTexture {
322
+ if (this.ctxTexture === undefined) {
323
+ this.ctxTexture = this.txManager.renderer.createCtxTexture(this);
324
+ }
325
+
326
+ return this.ctxTexture;
327
+ }
328
+
329
+ /**
330
+ * Free the core context texture for this Texture.
331
+ *
332
+ * @remarks
333
+ * The ctxTexture is created by the renderer and lives on the GPU.
334
+ */
335
+ free(): void {
336
+ this.ctxTexture?.free();
337
+ }
338
+
339
+ /**
340
+ * Release the texture data and core context texture for this Texture without changing state.
341
+ *
342
+ * @remarks
343
+ * The ctxTexture is created by the renderer and lives on the GPU.
344
+ */
345
+ release(): void {
346
+ this.ctxTexture?.release();
347
+ this.ctxTexture = undefined;
348
+ this.freeTextureData();
349
+ }
350
+
351
+ /**
352
+ * Destroy the texture.
353
+ *
354
+ * @remarks
355
+ * This method is called when the texture is no longer needed and should be
356
+ * cleaned up.
357
+ */
358
+ destroy(): void {
359
+ // Only free GPU resources if we're in a state where they exist
360
+ if (this.state === 'loaded') {
361
+ this.free();
362
+ }
363
+
364
+ // Always free texture data regardless of state
365
+ this.freeTextureData();
366
+ }
367
+
368
+ /**
369
+ * Free the source texture data for this Texture.
370
+ *
371
+ * @remarks
372
+ * The texture data is the source data that is used to populate the CoreContextTexture.
373
+ * e.g. ImageData that is downloaded from a URL.
374
+ */
375
+ freeTextureData(): void {
376
+ queueMicrotask(this.freeTextureDataTask);
377
+ }
378
+
379
+ public setState(
380
+ state: TextureState,
381
+ errorOrDimensions?: TextureError | Dimensions,
382
+ ): void {
383
+ if (this.state === state) {
384
+ return;
385
+ }
386
+
387
+ let payload: TextureError | Dimensions | null = null;
388
+ if (state === 'loaded') {
389
+ if (
390
+ errorOrDimensions !== undefined &&
391
+ 'w' in errorOrDimensions === true &&
392
+ 'h' in errorOrDimensions === true &&
393
+ errorOrDimensions.w !== undefined &&
394
+ errorOrDimensions.h !== undefined
395
+ ) {
396
+ this._dimensions = errorOrDimensions;
397
+ }
398
+
399
+ payload = this._dimensions;
400
+ } else if (state === 'failed') {
401
+ this._error = errorOrDimensions as TextureError;
402
+ payload = this._error;
403
+
404
+ // increment the retry count for the texture
405
+ // this is used to compare against maxRetryCount, if set
406
+ // to determine if we should try loading again
407
+ this.retryCount += 1;
408
+
409
+ queueMicrotask(this.releaseTask);
410
+ } else if (state === 'loading') {
411
+ this._error = null;
412
+ this._dimensions = null;
413
+ } else {
414
+ this._error = null;
415
+ }
416
+
417
+ // emit the new state
418
+ this.state = state;
419
+ this.emit(state, payload);
420
+ }
421
+
422
+ /**
423
+ * Get the texture data for this texture.
424
+ *
425
+ * @remarks
426
+ * This method is called by the CoreContextTexture when the texture is loaded.
427
+ * The texture data is then used to populate the CoreContextTexture.
428
+ *
429
+ * @returns
430
+ * The texture data for this texture.
431
+ */
432
+ async getTextureData(): Promise<TextureData> {
433
+ if (this.textureData === null) {
434
+ this.textureData = await this.getTextureSource();
435
+ }
436
+
437
+ return this.textureData;
438
+ }
439
+
440
+ /**
441
+ * Task for queueMicrotask to free texture data.
442
+ *
443
+ * @remarks
444
+ * This method is called in a microtask to free the texture data.
445
+ */
446
+ private freeTextureDataTask = (): void => {
447
+ this.textureData = null;
448
+ };
449
+
450
+ /**
451
+ * Task for queueMicrotask to release the texture.
452
+ *
453
+ * @remarks
454
+ * This method is called in a microtask to release the texture.
455
+ */
456
+ private releaseTask = (): void => {
457
+ this.release();
458
+ };
459
+
460
+ /**
461
+ * Get the texture source for this texture.
462
+ *
463
+ * @remarks
464
+ * This method is called by the CoreContextTexture when the texture is loaded.
465
+ * The texture source is then used to populate the CoreContextTexture.
466
+ */
467
+ abstract getTextureSource(): Promise<TextureData>;
468
+
469
+ /**
470
+ * Make a cache key for this texture.
471
+ *
472
+ * @remarks
473
+ * Each concrete `Texture` subclass must implement this method to provide an
474
+ * appropriate cache key for the texture type including the texture's
475
+ * properties that uniquely identify a copy of the texture. If the texture
476
+ * type does not support caching, then this method should return `false`.
477
+ *
478
+ * @param props
479
+ * @returns
480
+ * A cache key for this texture or `false` if the texture type does not
481
+ * support caching.
482
+ */
483
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
484
+ static makeCacheKey(props: unknown): string | false {
485
+ return false;
486
+ }
487
+
488
+ /**
489
+ * Resolve the default values for the texture's properties.
490
+ *
491
+ * @remarks
492
+ * Each concrete `Texture` subclass must implement this method to provide
493
+ * default values for the texture's optional properties.
494
+ *
495
+ * @param props
496
+ * @returns
497
+ * The default values for the texture's properties.
498
+ */
499
+ static resolveDefaults(
500
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
501
+ props: unknown,
502
+ ): Record<string, any> {
503
+ return {};
504
+ }
505
+ }
@@ -0,0 +1,210 @@
1
+ /**
2
+ * Core Utility Functions
3
+ *
4
+ * @module
5
+ */
6
+
7
+ export const EPSILON = 0.000001;
8
+ export let ARRAY_TYPE =
9
+ typeof Float32Array !== 'undefined' ? Float32Array : Array;
10
+ export const RANDOM = Math.random;
11
+ export const ANGLE_ORDER = 'zyx';
12
+ const degree = Math.PI / 180;
13
+
14
+ export type TimingFunction = (t: number) => number;
15
+
16
+ export const setMatrixArrayType = (
17
+ type: Float32ArrayConstructor | ArrayConstructor,
18
+ ) => {
19
+ ARRAY_TYPE = type;
20
+ };
21
+
22
+ export const toRadian = (a: number) => {
23
+ return a * degree;
24
+ };
25
+
26
+ export const equals = (a: number, b: number) => {
27
+ return Math.abs(a - b) <= EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));
28
+ };
29
+
30
+ export const rand = (min: number, max: number) => {
31
+ return Math.floor(Math.random() * (max - min + 1) + min);
32
+ };
33
+
34
+ export const isPowerOfTwo = (value: number) => {
35
+ return value && !(value & (value - 1));
36
+ };
37
+
38
+ const getTimingBezier = (
39
+ a: number,
40
+ b: number,
41
+ c: number,
42
+ d: number,
43
+ ): TimingFunction => {
44
+ const xc = 3.0 * a;
45
+ const xb = 3.0 * (c - a) - xc;
46
+ const xa = 1.0 - xc - xb;
47
+ const yc = 3.0 * b;
48
+ const yb = 3.0 * (d - b) - yc;
49
+ const ya = 1.0 - yc - yb;
50
+
51
+ return function (time) {
52
+ if (time >= 1.0) {
53
+ return 1;
54
+ }
55
+ if (time <= 0) {
56
+ return 0;
57
+ }
58
+
59
+ let t = 0.5,
60
+ cbx,
61
+ cbxd,
62
+ dx;
63
+
64
+ for (let it = 0; it < 20; it++) {
65
+ cbx = t * (t * (t * xa + xb) + xc);
66
+ dx = time - cbx;
67
+ if (dx > -1e-8 && dx < 1e-8) {
68
+ return t * (t * (t * ya + yb) + yc);
69
+ }
70
+
71
+ // Cubic bezier derivative.
72
+ cbxd = t * (t * (3 * xa) + 2 * xb) + xc;
73
+
74
+ if (cbxd > 1e-10 && cbxd < 1e-10) {
75
+ // Problematic. Fall back to binary search method.
76
+ break;
77
+ }
78
+
79
+ t += dx / cbxd;
80
+ }
81
+
82
+ // Fallback: binary search method. This is more reliable when there are near-0 slopes.
83
+ let minT = 0;
84
+ let maxT = 1;
85
+ for (let it = 0; it < 20; it++) {
86
+ t = 0.5 * (minT + maxT);
87
+
88
+ cbx = t * (t * (t * xa + xb) + xc);
89
+
90
+ dx = time - cbx;
91
+ if (dx > -1e-8 && dx < 1e-8) {
92
+ // Solution found!
93
+ return t * (t * (t * ya + yb) + yc);
94
+ }
95
+
96
+ if (dx < 0) {
97
+ maxT = t;
98
+ } else {
99
+ minT = t;
100
+ }
101
+ }
102
+
103
+ return time;
104
+ };
105
+ };
106
+
107
+ interface TimingFunctionMap {
108
+ [key: string]: TimingFunction;
109
+ }
110
+
111
+ type TimingLookupArray = number[];
112
+ interface TimingLookup {
113
+ [key: string]: TimingLookupArray;
114
+ }
115
+
116
+ const timingMapping: TimingFunctionMap = {};
117
+
118
+ const timingLookup: TimingLookup = {
119
+ ease: [0.25, 0.1, 0.25, 1.0],
120
+ 'ease-in': [0.42, 0, 1.0, 1.0],
121
+ 'ease-out': [0, 0, 0.58, 1.0],
122
+ 'ease-in-out': [0.42, 0, 0.58, 1.0],
123
+ 'ease-in-sine': [0.12, 0, 0.39, 0],
124
+ 'ease-out-sine': [0.12, 0, 0.39, 0],
125
+ 'ease-in-out-sine': [0.37, 0, 0.63, 1],
126
+ 'ease-in-cubic': [0.32, 0, 0.67, 0],
127
+ 'ease-out-cubic': [0.33, 1, 0.68, 1],
128
+ 'ease-in-out-cubic': [0.65, 0, 0.35, 1],
129
+ 'ease-in-circ': [0.55, 0, 1, 0.45],
130
+ 'ease-out-circ': [0, 0.55, 0.45, 1],
131
+ 'ease-in-out-circ': [0.85, 0, 0.15, 1],
132
+ 'ease-in-back': [0.36, 0, 0.66, -0.56],
133
+ 'ease-out-back': [0.34, 1.56, 0.64, 1],
134
+ 'ease-in-out-back': [0.68, -0.6, 0.32, 1.6],
135
+ };
136
+
137
+ const defaultTiming = (t: number): number => t;
138
+
139
+ const parseCubicBezier = (str: string) => {
140
+ //cubic-bezier(0.84, 0.52, 0.56, 0.6)
141
+ const regex = /-?\d*\.?\d+/g;
142
+ const match = str.match(regex);
143
+
144
+ if (match) {
145
+ const [num1, num2, num3, num4] = match;
146
+ const a = parseFloat(num1 || '0.42');
147
+ const b = parseFloat(num2 || '0');
148
+ const c = parseFloat(num3 || '1');
149
+ const d = parseFloat(num4 || '1');
150
+
151
+ const timing = getTimingBezier(a, b, c, d);
152
+ timingMapping[str] = timing;
153
+
154
+ return timing;
155
+ }
156
+
157
+ // parse failed, return linear
158
+ console.warn('Unknown cubic-bezier timing: ' + str);
159
+ return defaultTiming;
160
+ };
161
+
162
+ export const getTimingFunction = (str: string): TimingFunction => {
163
+ if (str === 'linear') {
164
+ return defaultTiming;
165
+ }
166
+
167
+ if (timingMapping[str] !== undefined) {
168
+ return timingMapping[str] || defaultTiming;
169
+ }
170
+
171
+ if (str === 'step-start') {
172
+ return () => {
173
+ return 1;
174
+ };
175
+ }
176
+
177
+ if (str === 'step-end') {
178
+ return (time: number) => {
179
+ return time === 1 ? 1 : 0;
180
+ };
181
+ }
182
+
183
+ const lookup = timingLookup[str];
184
+ if (lookup !== undefined) {
185
+ const [a, b, c, d] = lookup;
186
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
187
+ // @ts-ignore - TS doesn't understand that we've checked for undefined
188
+
189
+ const timing = getTimingBezier(a, b, c, d);
190
+ timingMapping[str] = timing;
191
+ return timing;
192
+ }
193
+
194
+ if (str.startsWith('cubic-bezier')) {
195
+ return parseCubicBezier(str);
196
+ }
197
+
198
+ console.warn('Unknown timing function: ' + str);
199
+ return defaultTiming;
200
+ };
201
+
202
+ /**
203
+ * Convert bytes to string of megabytes with 2 decimal points
204
+ *
205
+ * @param bytes
206
+ * @returns
207
+ */
208
+ export function bytesToMb(bytes: number) {
209
+ return (bytes / 1024 / 1024).toFixed(2);
210
+ }
package/src/env.d.ts ADDED
@@ -0,0 +1,7 @@
1
+ interface ImportMetaEnv {
2
+ readonly PROD: boolean;
3
+ }
4
+
5
+ interface ImportMeta {
6
+ readonly env: ImportMetaEnv;
7
+ }