@twick/2d 0.14.19 → 0.14.21

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 (376) hide show
  1. package/editor/editor/NodeInspectorConfig.d.ts +3 -0
  2. package/editor/editor/NodeInspectorConfig.d.ts.map +1 -0
  3. package/editor/editor/PreviewOverlayConfig.d.ts +3 -0
  4. package/editor/editor/PreviewOverlayConfig.d.ts.map +1 -0
  5. package/editor/editor/Provider.d.ts +17 -0
  6. package/editor/editor/Provider.d.ts.map +1 -0
  7. package/editor/editor/SceneGraphTabConfig.d.ts +3 -0
  8. package/editor/editor/SceneGraphTabConfig.d.ts.map +1 -0
  9. package/editor/editor/icons/CircleIcon.d.ts +2 -0
  10. package/editor/editor/icons/CircleIcon.d.ts.map +1 -0
  11. package/editor/editor/icons/CodeBlockIcon.d.ts +2 -0
  12. package/editor/editor/icons/CodeBlockIcon.d.ts.map +1 -0
  13. package/editor/editor/icons/CurveIcon.d.ts +2 -0
  14. package/editor/editor/icons/CurveIcon.d.ts.map +1 -0
  15. package/editor/editor/icons/GridIcon.d.ts +2 -0
  16. package/editor/editor/icons/GridIcon.d.ts.map +1 -0
  17. package/editor/editor/icons/IconMap.d.ts +3 -0
  18. package/editor/editor/icons/IconMap.d.ts.map +1 -0
  19. package/editor/editor/icons/ImgIcon.d.ts +2 -0
  20. package/editor/editor/icons/ImgIcon.d.ts.map +1 -0
  21. package/editor/editor/icons/LayoutIcon.d.ts +2 -0
  22. package/editor/editor/icons/LayoutIcon.d.ts.map +1 -0
  23. package/editor/editor/icons/LineIcon.d.ts +2 -0
  24. package/editor/editor/icons/LineIcon.d.ts.map +1 -0
  25. package/editor/editor/icons/NodeIcon.d.ts +2 -0
  26. package/editor/editor/icons/NodeIcon.d.ts.map +1 -0
  27. package/editor/editor/icons/RayIcon.d.ts +2 -0
  28. package/editor/editor/icons/RayIcon.d.ts.map +1 -0
  29. package/editor/editor/icons/RectIcon.d.ts +2 -0
  30. package/editor/editor/icons/RectIcon.d.ts.map +1 -0
  31. package/editor/editor/icons/ShapeIcon.d.ts +2 -0
  32. package/editor/editor/icons/ShapeIcon.d.ts.map +1 -0
  33. package/editor/editor/icons/TxtIcon.d.ts +2 -0
  34. package/editor/editor/icons/TxtIcon.d.ts.map +1 -0
  35. package/editor/editor/icons/VideoIcon.d.ts +2 -0
  36. package/editor/editor/icons/VideoIcon.d.ts.map +1 -0
  37. package/editor/editor/icons/View2DIcon.d.ts +2 -0
  38. package/editor/editor/icons/View2DIcon.d.ts.map +1 -0
  39. package/editor/editor/index.d.ts +4 -0
  40. package/editor/editor/index.d.ts.map +1 -0
  41. package/editor/editor/tree/DetachedRoot.d.ts +2 -0
  42. package/editor/editor/tree/DetachedRoot.d.ts.map +1 -0
  43. package/editor/editor/tree/NodeElement.d.ts +8 -0
  44. package/editor/editor/tree/NodeElement.d.ts.map +1 -0
  45. package/editor/editor/tree/TreeElement.d.ts +15 -0
  46. package/editor/editor/tree/TreeElement.d.ts.map +1 -0
  47. package/editor/editor/tree/TreeRoot.d.ts +3 -0
  48. package/editor/editor/tree/TreeRoot.d.ts.map +1 -0
  49. package/editor/editor/tree/ViewRoot.d.ts +2 -0
  50. package/editor/editor/tree/ViewRoot.d.ts.map +1 -0
  51. package/editor/editor/tree/index.d.ts +4 -0
  52. package/editor/editor/tree/index.d.ts.map +1 -0
  53. package/editor/editor/tsconfig.build.tsbuildinfo +1 -0
  54. package/editor/index.css +33 -0
  55. package/editor/index.js +341 -0
  56. package/editor/index.js.map +1 -0
  57. package/lib/code/CodeCursor.d.ts +83 -0
  58. package/lib/code/CodeCursor.d.ts.map +1 -0
  59. package/lib/code/CodeCursor.js +306 -0
  60. package/lib/code/CodeDiffer.d.ts +28 -0
  61. package/lib/code/CodeDiffer.d.ts.map +1 -0
  62. package/lib/code/CodeDiffer.js +51 -0
  63. package/lib/code/CodeFragment.d.ts +42 -0
  64. package/lib/code/CodeFragment.d.ts.map +1 -0
  65. package/lib/code/CodeFragment.js +72 -0
  66. package/lib/code/CodeHighlighter.d.ts +71 -0
  67. package/lib/code/CodeHighlighter.d.ts.map +1 -0
  68. package/lib/code/CodeHighlighter.js +2 -0
  69. package/lib/code/CodeMetrics.d.ts +11 -0
  70. package/lib/code/CodeMetrics.d.ts.map +1 -0
  71. package/lib/code/CodeMetrics.js +29 -0
  72. package/lib/code/CodeRange.d.ts +41 -0
  73. package/lib/code/CodeRange.d.ts.map +1 -0
  74. package/lib/code/CodeRange.js +179 -0
  75. package/lib/code/CodeScope.d.ts +16 -0
  76. package/lib/code/CodeScope.d.ts.map +1 -0
  77. package/lib/code/CodeScope.js +72 -0
  78. package/lib/code/CodeSelection.d.ts +6 -0
  79. package/lib/code/CodeSelection.d.ts.map +1 -0
  80. package/lib/code/CodeSelection.js +13 -0
  81. package/lib/code/CodeSignal.d.ts +60 -0
  82. package/lib/code/CodeSignal.d.ts.map +1 -0
  83. package/lib/code/CodeSignal.js +194 -0
  84. package/lib/code/CodeTokenizer.d.ts +8 -0
  85. package/lib/code/CodeTokenizer.d.ts.map +1 -0
  86. package/lib/code/CodeTokenizer.js +50 -0
  87. package/lib/code/DefaultHighlightStyle.d.ts +3 -0
  88. package/lib/code/DefaultHighlightStyle.d.ts.map +1 -0
  89. package/lib/code/DefaultHighlightStyle.js +98 -0
  90. package/lib/code/LezerHighlighter.d.ts +22 -0
  91. package/lib/code/LezerHighlighter.d.ts.map +1 -0
  92. package/lib/code/LezerHighlighter.js +89 -0
  93. package/lib/code/diff.d.ts +31 -0
  94. package/lib/code/diff.d.ts.map +1 -0
  95. package/lib/code/diff.js +236 -0
  96. package/lib/code/extractRange.d.ts +17 -0
  97. package/lib/code/extractRange.d.ts.map +1 -0
  98. package/lib/code/extractRange.js +102 -0
  99. package/lib/code/index.d.ts +14 -0
  100. package/lib/code/index.d.ts.map +1 -0
  101. package/lib/code/index.js +14 -0
  102. package/lib/components/Audio.d.ts +14 -0
  103. package/lib/components/Audio.d.ts.map +1 -0
  104. package/lib/components/Audio.js +148 -0
  105. package/lib/components/Bezier.d.ts +23 -0
  106. package/lib/components/Bezier.d.ts.map +1 -0
  107. package/lib/components/Bezier.js +81 -0
  108. package/lib/components/Circle.d.ts +193 -0
  109. package/lib/components/Circle.d.ts.map +1 -0
  110. package/lib/components/Circle.js +178 -0
  111. package/lib/components/Code.d.ts +231 -0
  112. package/lib/components/Code.d.ts.map +1 -0
  113. package/lib/components/Code.js +325 -0
  114. package/lib/components/CodeBlock.d.ts +133 -0
  115. package/lib/components/CodeBlock.d.ts.map +1 -0
  116. package/lib/components/CodeBlock.js +461 -0
  117. package/lib/components/CubicBezier.d.ts +70 -0
  118. package/lib/components/CubicBezier.d.ts.map +1 -0
  119. package/lib/components/CubicBezier.js +81 -0
  120. package/lib/components/Curve.d.ts +204 -0
  121. package/lib/components/Curve.d.ts.map +1 -0
  122. package/lib/components/Curve.js +284 -0
  123. package/lib/components/Grid.d.ts +76 -0
  124. package/lib/components/Grid.d.ts.map +1 -0
  125. package/lib/components/Grid.js +91 -0
  126. package/lib/components/Icon.d.ts +59 -0
  127. package/lib/components/Icon.d.ts.map +1 -0
  128. package/lib/components/Icon.js +58 -0
  129. package/lib/components/Img.d.ts +118 -0
  130. package/lib/components/Img.d.ts.map +1 -0
  131. package/lib/components/Img.js +245 -0
  132. package/lib/components/Knot.d.ts +90 -0
  133. package/lib/components/Knot.d.ts.map +1 -0
  134. package/lib/components/Knot.js +68 -0
  135. package/lib/components/Latex.d.ts +39 -0
  136. package/lib/components/Latex.d.ts.map +1 -0
  137. package/lib/components/Latex.js +101 -0
  138. package/lib/components/Layout.d.ts +419 -0
  139. package/lib/components/Layout.d.ts.map +1 -0
  140. package/lib/components/Layout.js +706 -0
  141. package/lib/components/Line.d.ts +160 -0
  142. package/lib/components/Line.d.ts.map +1 -0
  143. package/lib/components/Line.js +346 -0
  144. package/lib/components/Media.d.ts +70 -0
  145. package/lib/components/Media.d.ts.map +1 -0
  146. package/lib/components/Media.js +493 -0
  147. package/lib/components/Node.d.ts +836 -0
  148. package/lib/components/Node.d.ts.map +1 -0
  149. package/lib/components/Node.js +1317 -0
  150. package/lib/components/Path.d.ts +20 -0
  151. package/lib/components/Path.d.ts.map +1 -0
  152. package/lib/components/Path.js +97 -0
  153. package/lib/components/Polygon.d.ts +113 -0
  154. package/lib/components/Polygon.d.ts.map +1 -0
  155. package/lib/components/Polygon.js +123 -0
  156. package/lib/components/QuadBezier.d.ts +62 -0
  157. package/lib/components/QuadBezier.d.ts.map +1 -0
  158. package/lib/components/QuadBezier.js +76 -0
  159. package/lib/components/Ray.d.ts +62 -0
  160. package/lib/components/Ray.d.ts.map +1 -0
  161. package/lib/components/Ray.js +96 -0
  162. package/lib/components/Rect.d.ts +114 -0
  163. package/lib/components/Rect.d.ts.map +1 -0
  164. package/lib/components/Rect.js +76 -0
  165. package/lib/components/Rive.d.ts +22 -0
  166. package/lib/components/Rive.d.ts.map +1 -0
  167. package/lib/components/Rive.js +117 -0
  168. package/lib/components/SVG.d.ts +178 -0
  169. package/lib/components/SVG.d.ts.map +1 -0
  170. package/lib/components/SVG.js +577 -0
  171. package/lib/components/Shape.d.ts +40 -0
  172. package/lib/components/Shape.d.ts.map +1 -0
  173. package/lib/components/Shape.js +134 -0
  174. package/lib/components/Spline.d.ts +89 -0
  175. package/lib/components/Spline.d.ts.map +1 -0
  176. package/lib/components/Spline.js +256 -0
  177. package/lib/components/Txt.d.ts +53 -0
  178. package/lib/components/Txt.d.ts.map +1 -0
  179. package/lib/components/Txt.js +173 -0
  180. package/lib/components/TxtLeaf.d.ts +21 -0
  181. package/lib/components/TxtLeaf.d.ts.map +1 -0
  182. package/lib/components/TxtLeaf.js +181 -0
  183. package/lib/components/Video.d.ts +69 -0
  184. package/lib/components/Video.d.ts.map +1 -0
  185. package/lib/components/Video.js +342 -0
  186. package/lib/components/View2D.d.ts +28 -0
  187. package/lib/components/View2D.d.ts.map +1 -0
  188. package/lib/components/View2D.js +93 -0
  189. package/lib/components/index.d.ts +29 -0
  190. package/lib/components/index.d.ts.map +1 -0
  191. package/lib/components/index.js +29 -0
  192. package/lib/components/types.d.ts +17 -0
  193. package/lib/components/types.d.ts.map +1 -0
  194. package/lib/components/types.js +2 -0
  195. package/lib/curves/ArcSegment.d.ts +26 -0
  196. package/lib/curves/ArcSegment.d.ts.map +1 -0
  197. package/lib/curves/ArcSegment.js +97 -0
  198. package/lib/curves/CircleSegment.d.ts +18 -0
  199. package/lib/curves/CircleSegment.d.ts.map +1 -0
  200. package/lib/curves/CircleSegment.js +52 -0
  201. package/lib/curves/CubicBezierSegment.d.ts +18 -0
  202. package/lib/curves/CubicBezierSegment.d.ts.map +1 -0
  203. package/lib/curves/CubicBezierSegment.js +55 -0
  204. package/lib/curves/CurveDrawingInfo.d.ts +11 -0
  205. package/lib/curves/CurveDrawingInfo.d.ts.map +1 -0
  206. package/lib/curves/CurveDrawingInfo.js +2 -0
  207. package/lib/curves/CurvePoint.d.ts +15 -0
  208. package/lib/curves/CurvePoint.d.ts.map +1 -0
  209. package/lib/curves/CurvePoint.js +2 -0
  210. package/lib/curves/CurveProfile.d.ts +7 -0
  211. package/lib/curves/CurveProfile.d.ts.map +1 -0
  212. package/lib/curves/CurveProfile.js +2 -0
  213. package/lib/curves/KnotInfo.d.ts +12 -0
  214. package/lib/curves/KnotInfo.d.ts.map +1 -0
  215. package/lib/curves/KnotInfo.js +2 -0
  216. package/lib/curves/LineSegment.d.ts +16 -0
  217. package/lib/curves/LineSegment.d.ts.map +1 -0
  218. package/lib/curves/LineSegment.js +45 -0
  219. package/lib/curves/Polynomial.d.ts +118 -0
  220. package/lib/curves/Polynomial.d.ts.map +1 -0
  221. package/lib/curves/Polynomial.js +259 -0
  222. package/lib/curves/Polynomial2D.d.ts +22 -0
  223. package/lib/curves/Polynomial2D.d.ts.map +1 -0
  224. package/lib/curves/Polynomial2D.js +45 -0
  225. package/lib/curves/PolynomialSegment.d.ts +39 -0
  226. package/lib/curves/PolynomialSegment.d.ts.map +1 -0
  227. package/lib/curves/PolynomialSegment.js +86 -0
  228. package/lib/curves/QuadBezierSegment.d.ts +17 -0
  229. package/lib/curves/QuadBezierSegment.d.ts.map +1 -0
  230. package/lib/curves/QuadBezierSegment.js +49 -0
  231. package/lib/curves/Segment.d.ts +9 -0
  232. package/lib/curves/Segment.d.ts.map +1 -0
  233. package/lib/curves/Segment.js +3 -0
  234. package/lib/curves/UniformPolynomialCurveSampler.d.ts +43 -0
  235. package/lib/curves/UniformPolynomialCurveSampler.d.ts.map +1 -0
  236. package/lib/curves/UniformPolynomialCurveSampler.js +73 -0
  237. package/lib/curves/createCurveProfileLerp.d.ts +32 -0
  238. package/lib/curves/createCurveProfileLerp.d.ts.map +1 -0
  239. package/lib/curves/createCurveProfileLerp.js +351 -0
  240. package/lib/curves/getBezierSplineProfile.d.ts +12 -0
  241. package/lib/curves/getBezierSplineProfile.d.ts.map +1 -0
  242. package/lib/curves/getBezierSplineProfile.js +137 -0
  243. package/lib/curves/getCircleProfile.d.ts +4 -0
  244. package/lib/curves/getCircleProfile.d.ts.map +1 -0
  245. package/lib/curves/getCircleProfile.js +44 -0
  246. package/lib/curves/getPathProfile.d.ts +3 -0
  247. package/lib/curves/getPathProfile.d.ts.map +1 -0
  248. package/lib/curves/getPathProfile.js +128 -0
  249. package/lib/curves/getPointAtDistance.d.ts +4 -0
  250. package/lib/curves/getPointAtDistance.d.ts.map +1 -0
  251. package/lib/curves/getPointAtDistance.js +15 -0
  252. package/lib/curves/getPolylineProfile.d.ts +4 -0
  253. package/lib/curves/getPolylineProfile.d.ts.map +1 -0
  254. package/lib/curves/getPolylineProfile.js +58 -0
  255. package/lib/curves/getRectProfile.d.ts +4 -0
  256. package/lib/curves/getRectProfile.d.ts.map +1 -0
  257. package/lib/curves/getRectProfile.js +57 -0
  258. package/lib/curves/index.d.ts +17 -0
  259. package/lib/curves/index.d.ts.map +1 -0
  260. package/lib/curves/index.js +17 -0
  261. package/lib/decorators/canvasStyleSignal.d.ts +5 -0
  262. package/lib/decorators/canvasStyleSignal.d.ts.map +1 -0
  263. package/lib/decorators/canvasStyleSignal.js +12 -0
  264. package/lib/decorators/colorSignal.d.ts +2 -0
  265. package/lib/decorators/colorSignal.d.ts.map +1 -0
  266. package/lib/decorators/colorSignal.js +9 -0
  267. package/lib/decorators/compound.d.ts +26 -0
  268. package/lib/decorators/compound.d.ts.map +1 -0
  269. package/lib/decorators/compound.js +49 -0
  270. package/lib/decorators/computed.d.ts +9 -0
  271. package/lib/decorators/computed.d.ts.map +1 -0
  272. package/lib/decorators/computed.js +18 -0
  273. package/lib/decorators/defaultStyle.d.ts +2 -0
  274. package/lib/decorators/defaultStyle.d.ts.map +1 -0
  275. package/lib/decorators/defaultStyle.js +14 -0
  276. package/lib/decorators/filtersSignal.d.ts +13 -0
  277. package/lib/decorators/filtersSignal.d.ts.map +1 -0
  278. package/lib/decorators/filtersSignal.js +73 -0
  279. package/lib/decorators/index.d.ts +11 -0
  280. package/lib/decorators/index.d.ts.map +1 -0
  281. package/lib/decorators/index.js +11 -0
  282. package/lib/decorators/initializers.d.ts +4 -0
  283. package/lib/decorators/initializers.d.ts.map +1 -0
  284. package/lib/decorators/initializers.js +27 -0
  285. package/lib/decorators/nodeName.d.ts +9 -0
  286. package/lib/decorators/nodeName.d.ts.map +1 -0
  287. package/lib/decorators/nodeName.js +13 -0
  288. package/lib/decorators/signal.d.ts +183 -0
  289. package/lib/decorators/signal.d.ts.map +1 -0
  290. package/lib/decorators/signal.js +285 -0
  291. package/lib/decorators/spacingSignal.d.ts +2 -0
  292. package/lib/decorators/spacingSignal.d.ts.map +1 -0
  293. package/lib/decorators/spacingSignal.js +15 -0
  294. package/lib/decorators/vector2Signal.d.ts +9 -0
  295. package/lib/decorators/vector2Signal.d.ts.map +1 -0
  296. package/lib/decorators/vector2Signal.js +15 -0
  297. package/lib/index.d.ts +9 -0
  298. package/lib/index.d.ts.map +1 -0
  299. package/lib/index.js +9 -0
  300. package/lib/jsx-dev-runtime.d.ts +3 -0
  301. package/lib/jsx-dev-runtime.d.ts.map +1 -0
  302. package/lib/jsx-dev-runtime.js +3 -0
  303. package/lib/jsx-runtime.d.ts +12 -0
  304. package/lib/jsx-runtime.d.ts.map +1 -0
  305. package/lib/jsx-runtime.js +23 -0
  306. package/lib/partials/Filter.d.ts +82 -0
  307. package/lib/partials/Filter.d.ts.map +1 -0
  308. package/lib/partials/Filter.js +135 -0
  309. package/lib/partials/Gradient.d.ts +31 -0
  310. package/lib/partials/Gradient.d.ts.map +1 -0
  311. package/lib/partials/Gradient.js +63 -0
  312. package/lib/partials/Pattern.d.ts +13 -0
  313. package/lib/partials/Pattern.d.ts.map +1 -0
  314. package/lib/partials/Pattern.js +27 -0
  315. package/lib/partials/ShaderConfig.d.ts +81 -0
  316. package/lib/partials/ShaderConfig.d.ts.map +1 -0
  317. package/lib/partials/ShaderConfig.js +25 -0
  318. package/lib/partials/index.d.ts +5 -0
  319. package/lib/partials/index.d.ts.map +1 -0
  320. package/lib/partials/index.js +5 -0
  321. package/lib/partials/types.d.ts +35 -0
  322. package/lib/partials/types.d.ts.map +1 -0
  323. package/lib/partials/types.js +2 -0
  324. package/lib/scenes/Scene2D.d.ts +29 -0
  325. package/lib/scenes/Scene2D.d.ts.map +1 -0
  326. package/lib/scenes/Scene2D.js +180 -0
  327. package/lib/scenes/index.d.ts +4 -0
  328. package/lib/scenes/index.d.ts.map +1 -0
  329. package/lib/scenes/index.js +4 -0
  330. package/lib/scenes/makeScene2D.d.ts +5 -0
  331. package/lib/scenes/makeScene2D.d.ts.map +1 -0
  332. package/lib/scenes/makeScene2D.js +11 -0
  333. package/lib/scenes/useScene2D.d.ts +3 -0
  334. package/lib/scenes/useScene2D.d.ts.map +1 -0
  335. package/lib/scenes/useScene2D.js +5 -0
  336. package/lib/tsconfig.build.tsbuildinfo +1 -0
  337. package/lib/utils/CanvasUtils.d.ts +23 -0
  338. package/lib/utils/CanvasUtils.d.ts.map +1 -0
  339. package/lib/utils/CanvasUtils.js +138 -0
  340. package/lib/utils/diff.d.ts +31 -0
  341. package/lib/utils/diff.d.ts.map +1 -0
  342. package/lib/utils/diff.js +97 -0
  343. package/lib/utils/index.d.ts +3 -0
  344. package/lib/utils/index.d.ts.map +1 -0
  345. package/lib/utils/index.js +3 -0
  346. package/lib/utils/is.d.ts +8 -0
  347. package/lib/utils/is.d.ts.map +1 -0
  348. package/lib/utils/is.js +10 -0
  349. package/lib/utils/makeSignalExtensions.d.ts +4 -0
  350. package/lib/utils/makeSignalExtensions.d.ts.map +1 -0
  351. package/lib/utils/makeSignalExtensions.js +20 -0
  352. package/lib/utils/video/ffmpeg-client.d.ts +5 -0
  353. package/lib/utils/video/ffmpeg-client.d.ts.map +1 -0
  354. package/lib/utils/video/ffmpeg-client.js +32 -0
  355. package/lib/utils/video/mp4-parser-manager.d.ts +3 -0
  356. package/lib/utils/video/mp4-parser-manager.d.ts.map +1 -0
  357. package/lib/utils/video/mp4-parser-manager.js +55 -0
  358. package/lib/utils/video/parser/index.d.ts +2 -0
  359. package/lib/utils/video/parser/index.d.ts.map +1 -0
  360. package/lib/utils/video/parser/index.js +2 -0
  361. package/lib/utils/video/parser/parser.d.ts +21 -0
  362. package/lib/utils/video/parser/parser.d.ts.map +1 -0
  363. package/lib/utils/video/parser/parser.js +168 -0
  364. package/lib/utils/video/parser/sampler.d.ts +16 -0
  365. package/lib/utils/video/parser/sampler.d.ts.map +1 -0
  366. package/lib/utils/video/parser/sampler.js +56 -0
  367. package/lib/utils/video/parser/segment.d.ts +48 -0
  368. package/lib/utils/video/parser/segment.d.ts.map +1 -0
  369. package/lib/utils/video/parser/segment.js +239 -0
  370. package/lib/utils/video/parser/sink.d.ts +9 -0
  371. package/lib/utils/video/parser/sink.d.ts.map +1 -0
  372. package/lib/utils/video/parser/sink.js +22 -0
  373. package/lib/utils/video/parser/utils.d.ts +10 -0
  374. package/lib/utils/video/parser/utils.d.ts.map +1 -0
  375. package/lib/utils/video/parser/utils.js +22 -0
  376. package/package.json +4 -4
@@ -0,0 +1,342 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var Video_1;
8
+ import { BBox, DependencyContext, PlaybackState } from '@twick/core';
9
+ import Hls from 'hls.js';
10
+ import { computed, initial, nodeName, signal } from '../decorators';
11
+ import { drawImage } from '../utils';
12
+ import { ImageCommunication } from '../utils/video/ffmpeg-client';
13
+ import { dropExtractor, getFrame } from '../utils/video/mp4-parser-manager';
14
+ import { Media } from './Media';
15
+ let Video = Video_1 = class Video extends Media {
16
+ constructor(props) {
17
+ super(props);
18
+ this.detectedFileType = 'unknown';
19
+ this.fileTypeWasDetected = false;
20
+ this.lastFrame = null;
21
+ }
22
+ desiredSize() {
23
+ const custom = super.desiredSize();
24
+ if (custom.x === null && custom.y === null) {
25
+ const image = this.video();
26
+ return {
27
+ x: image.videoWidth,
28
+ y: image.videoHeight,
29
+ };
30
+ }
31
+ return custom;
32
+ }
33
+ mediaElement() {
34
+ return this.video();
35
+ }
36
+ seekedMedia() {
37
+ return this.seekedVideo();
38
+ }
39
+ fastSeekedMedia() {
40
+ return this.fastSeekedVideo();
41
+ }
42
+ video() {
43
+ const src = this.src();
44
+ // Use a temporary key for undefined src to avoid conflicts
45
+ const key = `${this.key}/${src || 'pending'}`;
46
+ let video = Video_1.pool[key];
47
+ if (!video) {
48
+ video = document.createElement('video');
49
+ video.crossOrigin = 'anonymous';
50
+ // Only set src if it's valid, otherwise leave it empty
51
+ if (src && src !== 'undefined') {
52
+ try {
53
+ const parsedSrc = new URL(src, window.location.origin);
54
+ if (parsedSrc.pathname.endsWith('.m3u8')) {
55
+ const hls = new Hls();
56
+ hls.loadSource(src);
57
+ hls.attachMedia(video);
58
+ }
59
+ else {
60
+ video.src = src;
61
+ }
62
+ }
63
+ catch (error) {
64
+ // Fallback to direct assignment
65
+ video.src = src;
66
+ }
67
+ }
68
+ Video_1.pool[key] = video;
69
+ }
70
+ else if (src && src !== 'undefined' && video.src !== src) {
71
+ // Update existing video element if src has changed and is now valid
72
+ try {
73
+ const parsedSrc = new URL(src, window.location.origin);
74
+ if (parsedSrc.pathname.endsWith('.m3u8')) {
75
+ const hls = new Hls();
76
+ hls.loadSource(src);
77
+ hls.attachMedia(video);
78
+ }
79
+ else {
80
+ video.src = src;
81
+ }
82
+ }
83
+ catch (error) {
84
+ // Fallback to direct assignment
85
+ video.src = src;
86
+ }
87
+ // Move video to correct pool key
88
+ delete Video_1.pool[key];
89
+ const newKey = `${this.key}/${src}`;
90
+ Video_1.pool[newKey] = video;
91
+ }
92
+ // If src is still undefined, wait for it to become available
93
+ if (!src || src === 'undefined') {
94
+ DependencyContext.collectPromise(new Promise(resolve => {
95
+ // Check periodically for valid src
96
+ const checkSrc = () => {
97
+ const currentSrc = this.src();
98
+ if (currentSrc && currentSrc !== 'undefined') {
99
+ resolve();
100
+ }
101
+ else {
102
+ setTimeout(checkSrc, 10);
103
+ }
104
+ };
105
+ checkSrc();
106
+ }));
107
+ }
108
+ const weNeedToWait = this.waitForCanPlayNecessary(video);
109
+ if (!weNeedToWait) {
110
+ return video;
111
+ }
112
+ DependencyContext.collectPromise(new Promise(resolve => {
113
+ this.waitForCanPlay(video, resolve);
114
+ }));
115
+ return video;
116
+ }
117
+ seekedVideo() {
118
+ const video = this.video();
119
+ const time = this.clampTime(this.time());
120
+ video.playbackRate = this.playbackRate();
121
+ if (!video.paused) {
122
+ video.pause();
123
+ }
124
+ if (this.lastTime === time) {
125
+ return video;
126
+ }
127
+ this.setCurrentTime(time);
128
+ return video;
129
+ }
130
+ fastSeekedVideo() {
131
+ const video = this.video();
132
+ const time = this.clampTime(this.time());
133
+ video.playbackRate = this.playbackRate();
134
+ if (this.lastTime === time) {
135
+ return video;
136
+ }
137
+ const playing = this.playing() && time < video.duration && video.playbackRate > 0;
138
+ if (playing) {
139
+ if (video.paused) {
140
+ DependencyContext.collectPromise(video.play());
141
+ }
142
+ }
143
+ else {
144
+ if (!video.paused) {
145
+ video.pause();
146
+ }
147
+ }
148
+ // reseek when video is out of sync by more than one second
149
+ if (Math.abs(video.currentTime - time) > 1) {
150
+ this.setCurrentTime(time);
151
+ }
152
+ else if (!playing) {
153
+ video.currentTime = time;
154
+ }
155
+ return video;
156
+ }
157
+ async webcodecSeekedVideo() {
158
+ const video = this.video();
159
+ const time = this.clampTime(this.time());
160
+ video.playbackRate = this.playbackRate();
161
+ if (this.lastFrame && this.lastTime === time) {
162
+ return this.lastFrame;
163
+ }
164
+ const fps = this.view().fps() / this.playbackRate();
165
+ return getFrame(this.key, video.src, time, fps);
166
+ }
167
+ async ffmpegSeekedVideo() {
168
+ const video = this.video();
169
+ const time = this.clampTime(this.time());
170
+ const duration = this.getDuration();
171
+ video.playbackRate = this.playbackRate();
172
+ if (this.lastFrame && this.lastTime === time) {
173
+ return this.lastFrame;
174
+ }
175
+ const fps = this.view().fps() / this.playbackRate();
176
+ if (!Video_1.imageCommunication) {
177
+ throw new Error('ServerSeekedVideo can only be used with HMR.');
178
+ }
179
+ const frame = await Video_1.imageCommunication.getFrame(this.key, video.src, time, duration, fps);
180
+ this.lastFrame = frame;
181
+ this.lastTime = time;
182
+ return frame;
183
+ }
184
+ async seekFunction() {
185
+ const playbackState = this.view().playbackState();
186
+ // During playback
187
+ if (playbackState === PlaybackState.Playing ||
188
+ playbackState === PlaybackState.Presenting) {
189
+ return this.fastSeekedVideo();
190
+ }
191
+ if (playbackState === PlaybackState.Paused) {
192
+ return this.seekedVideo();
193
+ }
194
+ // During rendering, if set explicitly
195
+ if (this.decoder() === 'slow') {
196
+ return this.seekedVideo();
197
+ }
198
+ if (this.decoder() === 'ffmpeg') {
199
+ return this.ffmpegSeekedVideo();
200
+ }
201
+ if (this.decoder() === 'web') {
202
+ return this.webcodecSeekedVideo();
203
+ }
204
+ if (!this.fileTypeWasDetected) {
205
+ this.detectFileType();
206
+ }
207
+ // If not set explicitly, use detected file type to determine decoder
208
+ if (this.detectedFileType === 'webm') {
209
+ return this.ffmpegSeekedVideo();
210
+ }
211
+ if (this.detectedFileType === 'hls') {
212
+ return this.seekedVideo();
213
+ }
214
+ return this.webcodecSeekedVideo();
215
+ }
216
+ async draw(context) {
217
+ // Auto-start playback if Twick is playing but media isn't
218
+ this.autoPlayBasedOnTwick();
219
+ this.drawShape(context);
220
+ const alpha = this.alpha();
221
+ if (alpha > 0) {
222
+ const video = await this.seekFunction();
223
+ const box = BBox.fromSizeCentered(this.computedSize());
224
+ context.save();
225
+ context.clip(this.getPath());
226
+ if (alpha < 1) {
227
+ context.globalAlpha *= alpha;
228
+ }
229
+ context.imageSmoothingEnabled = this.smoothing();
230
+ drawImage(context, video, box);
231
+ context.restore();
232
+ }
233
+ if (this.clip()) {
234
+ context.clip(this.getPath());
235
+ }
236
+ await this.drawChildren(context);
237
+ }
238
+ applyFlex() {
239
+ super.applyFlex();
240
+ try {
241
+ const video = this.video();
242
+ // Only set aspect ratio if video element is available and has valid dimensions
243
+ if (video && video.videoWidth > 0 && video.videoHeight > 0) {
244
+ this.element.style.aspectRatio = (this.ratio() ?? video.videoWidth / video.videoHeight).toString();
245
+ }
246
+ }
247
+ catch (error) {
248
+ // If video element is not ready yet, skip setting aspect ratio
249
+ // It will be set later when the video becomes available
250
+ }
251
+ }
252
+ remove() {
253
+ super.remove();
254
+ dropExtractor(this.key, this.src());
255
+ return this;
256
+ }
257
+ handleUnknownFileType(src) {
258
+ console.warn(`WARNING: Could not detect file type of video (${src}), will default to using mp4 decoder. If your video file is not an mp4 file, this will lead to an error - to fix this, reencode your video as an mp4 file (better performance) or specify a different decoder: https://docs.re.video/common-issues/slow-rendering#use-mp4-decoder`);
259
+ this.detectedFileType = 'unknown';
260
+ this.fileTypeWasDetected = true;
261
+ }
262
+ detectFileType() {
263
+ return DependencyContext.collectPromise((async () => {
264
+ const src = this.src();
265
+ const extension = src.split('?')[0].split('.').pop()?.toLowerCase();
266
+ if (extension === 'mp4' ||
267
+ extension === 'webm' ||
268
+ extension === 'mov') {
269
+ this.detectedFileType = extension;
270
+ this.fileTypeWasDetected = true;
271
+ return;
272
+ }
273
+ if (extension === 'm3u8') {
274
+ this.detectedFileType = 'hls';
275
+ this.fileTypeWasDetected = true;
276
+ return;
277
+ }
278
+ if (!src.startsWith('http://') && !src.startsWith('https://')) {
279
+ this.handleUnknownFileType(src);
280
+ return;
281
+ }
282
+ const response = await fetch(src, { method: 'HEAD' });
283
+ const contentType = response.headers.get('Content-Type');
284
+ if (!contentType) {
285
+ this.handleUnknownFileType(src);
286
+ return;
287
+ }
288
+ if (contentType.includes('video/mp4')) {
289
+ this.detectedFileType = 'mp4';
290
+ this.fileTypeWasDetected = true;
291
+ return;
292
+ }
293
+ if (contentType.includes('video/webm')) {
294
+ this.detectedFileType = 'webm';
295
+ this.fileTypeWasDetected = true;
296
+ return;
297
+ }
298
+ if (contentType.includes('video/quicktime')) {
299
+ this.detectedFileType = 'mov';
300
+ this.fileTypeWasDetected = true;
301
+ return;
302
+ }
303
+ if (contentType.includes('application/vnd.apple.mpegurl') ||
304
+ contentType.includes('application/x-mpegURL')) {
305
+ this.detectedFileType = 'hls';
306
+ this.fileTypeWasDetected = true;
307
+ return;
308
+ }
309
+ this.handleUnknownFileType(src);
310
+ })());
311
+ }
312
+ };
313
+ Video.pool = {};
314
+ Video.imageCommunication = !import.meta.hot
315
+ ? null
316
+ : new ImageCommunication();
317
+ __decorate([
318
+ initial(1),
319
+ signal()
320
+ ], Video.prototype, "alpha", void 0);
321
+ __decorate([
322
+ initial(true),
323
+ signal()
324
+ ], Video.prototype, "smoothing", void 0);
325
+ __decorate([
326
+ initial(null),
327
+ signal()
328
+ ], Video.prototype, "decoder", void 0);
329
+ __decorate([
330
+ computed()
331
+ ], Video.prototype, "video", null);
332
+ __decorate([
333
+ computed()
334
+ ], Video.prototype, "seekedVideo", null);
335
+ __decorate([
336
+ computed()
337
+ ], Video.prototype, "fastSeekedVideo", null);
338
+ Video = Video_1 = __decorate([
339
+ nodeName('Video')
340
+ ], Video);
341
+ export { Video };
342
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVmlkZW8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvVmlkZW8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUNBLE9BQU8sRUFBQyxJQUFJLEVBQUUsaUJBQWlCLEVBQUUsYUFBYSxFQUFDLE1BQU0sYUFBYSxDQUFDO0FBQ25FLE9BQU8sR0FBRyxNQUFNLFFBQVEsQ0FBQztBQUN6QixPQUFPLEVBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWxFLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxVQUFVLENBQUM7QUFDbkMsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGFBQWEsRUFBRSxRQUFRLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUUxRSxPQUFPLEVBQUMsS0FBSyxFQUFDLE1BQU0sU0FBUyxDQUFDO0FBa0J2QixJQUFNLEtBQUssYUFBWCxNQUFNLEtBQU0sU0FBUSxLQUFLO0lBa0Q5QixZQUFtQixLQUFpQjtRQUNsQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFYUixxQkFBZ0IsR0FDckIsU0FBUyxDQUFDO1FBQ0osd0JBQW1CLEdBQVksS0FBSyxDQUFDO1FBa0xuQyxjQUFTLEdBQXVCLElBQUksQ0FBQztJQXhLL0MsQ0FBQztJQUVrQixXQUFXO1FBQzVCLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNuQyxJQUFJLE1BQU0sQ0FBQyxDQUFDLEtBQUssSUFBSSxJQUFJLE1BQU0sQ0FBQyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7WUFDM0MsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQzNCLE9BQU87Z0JBQ0wsQ0FBQyxFQUFFLEtBQUssQ0FBQyxVQUFVO2dCQUNuQixDQUFDLEVBQUUsS0FBSyxD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
@@ -0,0 +1,28 @@
1
+ import type { SimpleSignal } from '@twick/core';
2
+ import { PlaybackState } from '@twick/core';
3
+ import type { Node } from './Node';
4
+ import type { RectProps } from './Rect';
5
+ import { Rect } from './Rect';
6
+ export interface View2DProps extends RectProps {
7
+ assetHash: string;
8
+ }
9
+ export declare class View2D extends Rect {
10
+ static shadowRoot: ShadowRoot;
11
+ readonly playbackState: SimpleSignal<PlaybackState, this>;
12
+ readonly globalTime: SimpleSignal<number, this>;
13
+ readonly fps: SimpleSignal<number, this>;
14
+ readonly assetHash: SimpleSignal<string, this>;
15
+ constructor(props: View2DProps);
16
+ dispose(): void;
17
+ render(context: CanvasRenderingContext2D): Promise<void>;
18
+ /**
19
+ * Find a node by its key.
20
+ *
21
+ * @param key - The key of the node.
22
+ */
23
+ findKey<T extends Node = Node>(key: string): T | null;
24
+ protected requestLayoutUpdate(): void;
25
+ protected requestFontUpdate(): void;
26
+ view(): View2D;
27
+ }
28
+ //# sourceMappingURL=View2D.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"View2D.d.ts","sourceRoot":"","sources":["../../src/lib/components/View2D.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAC,aAAa,EAAO,MAAM,aAAa,CAAC;AAIhD,OAAO,KAAK,EAAC,IAAI,EAAC,MAAM,QAAQ,CAAC;AACjC,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAC,IAAI,EAAC,MAAM,QAAQ,CAAC;AAE5B,MAAM,WAAW,WAAY,SAAQ,SAAS;IAC5C,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBACa,MAAO,SAAQ,IAAI;IAE9B,OAiBc,UAAU,EAAE,UAAU,CAAC;IAErC,SAEwB,aAAa,EAAE,YAAY,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;IAEzE,SAEwB,UAAU,EAAE,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAE/D,SAEwB,GAAG,EAAE,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAExD,SACwB,SAAS,EAAE,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;gBAE3C,KAAK,EAAE,WAAW;IAgBrB,OAAO;IAKD,MAAM,CAAC,OAAO,EAAE,wBAAwB;IAM9D;;;;OAIG;IACI,OAAO,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,EAAE,GAAG,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI;cAIzC,mBAAmB;cAInB,iBAAiB;IAIpB,IAAI,IAAI,MAAM;CAG/B"}
@@ -0,0 +1,93 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var View2D_1;
8
+ import { PlaybackState, lazy } from '@twick/core';
9
+ import { initial, signal } from '../decorators';
10
+ import { nodeName } from '../decorators/nodeName';
11
+ import { useScene2D } from '../scenes/useScene2D';
12
+ import { Rect } from './Rect';
13
+ let View2D = View2D_1 = class View2D extends Rect {
14
+ constructor(props) {
15
+ super({
16
+ composite: true,
17
+ fontFamily: 'Roboto',
18
+ fontSize: 48,
19
+ lineHeight: '120%',
20
+ textWrap: false,
21
+ fontStyle: 'normal',
22
+ ...props,
23
+ });
24
+ this.view2D = this;
25
+ View2D_1.shadowRoot.append(this.element);
26
+ this.applyFlex();
27
+ }
28
+ dispose() {
29
+ this.removeChildren();
30
+ super.dispose();
31
+ }
32
+ async render(context) {
33
+ this.computedSize();
34
+ this.computedPosition();
35
+ await super.render(context);
36
+ }
37
+ /**
38
+ * Find a node by its key.
39
+ *
40
+ * @param key - The key of the node.
41
+ */
42
+ findKey(key) {
43
+ return useScene2D().getNode(key) ?? null;
44
+ }
45
+ requestLayoutUpdate() {
46
+ this.updateLayout();
47
+ }
48
+ requestFontUpdate() {
49
+ this.applyFont();
50
+ }
51
+ view() {
52
+ return this;
53
+ }
54
+ };
55
+ __decorate([
56
+ initial(PlaybackState.Paused),
57
+ signal()
58
+ ], View2D.prototype, "playbackState", void 0);
59
+ __decorate([
60
+ initial(0),
61
+ signal()
62
+ ], View2D.prototype, "globalTime", void 0);
63
+ __decorate([
64
+ initial(0),
65
+ signal()
66
+ ], View2D.prototype, "fps", void 0);
67
+ __decorate([
68
+ signal()
69
+ ], View2D.prototype, "assetHash", void 0);
70
+ __decorate([
71
+ lazy(() => {
72
+ const frameID = 'twick-2d-frame';
73
+ let frame = document.querySelector(`#${frameID}`);
74
+ if (!frame) {
75
+ frame = document.createElement('div');
76
+ frame.id = frameID;
77
+ frame.style.position = 'absolute';
78
+ frame.style.pointerEvents = 'none';
79
+ frame.style.top = '0';
80
+ frame.style.left = '0';
81
+ frame.style.fontFeatureSettings = 'normal'; // TODO: find solution that fully isolates CSS
82
+ frame.style.opacity = '0';
83
+ frame.style.overflow = 'hidden';
84
+ document.body.prepend(frame);
85
+ }
86
+ return frame.shadowRoot ?? frame.attachShadow({ mode: 'open' });
87
+ })
88
+ ], View2D, "shadowRoot", void 0);
89
+ View2D = View2D_1 = __decorate([
90
+ nodeName('View2D')
91
+ ], View2D);
92
+ export { View2D };
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVmlldzJELmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL1ZpZXcyRC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0EsT0FBTyxFQUFDLGFBQWEsRUFBRSxJQUFJLEVBQUMsTUFBTSxhQUFhLENBQUM7QUFDaEQsT0FBTyxFQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDOUMsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2hELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUdoRCxPQUFPLEVBQUMsSUFBSSxFQUFDLE1BQU0sUUFBUSxDQUFDO0FBT3JCLElBQU0sTUFBTSxjQUFaLE1BQU0sTUFBTyxTQUFRLElBQUk7SUFvQzlCLFlBQW1CLEtBQWtCO1FBQ25DLEtBQUssQ0FBQztZQUNKLFNBQVMsRUFBRSxJQUFJO1lBQ2YsVUFBVSxFQUFFLFFBQVE7WUFDcEIsUUFBUSxFQUFFLEVBQUU7WUFDWixVQUFVLEVBQUUsTUFBTTtZQUNsQixRQUFRLEVBQUUsS0FBSztZQUNmLFNBQVMsRUFBRSxRQUFRO1lBQ25CLEdBQUcsS0FBSztTQUNULENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDO1FBRW5CLFFBQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2QyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUVlLE9BQU87UUFDckIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3RCLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNsQixDQUFDO0lBRWUsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFpQztRQUM1RCxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDcEIsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDeEIsTUFBTSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksT0FBTyxDQUF3QixHQUFXO1FBQy9DLE9BQVEsVUFBVSxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBTyxJQUFJLElBQUksQ0FBQztJQUNsRCxDQUFDO0lBRWtCLG1CQUFtQjtRQUNwQyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVrQixpQkFBaUI7UUFDbEMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFZSxJQUFJO1FBQ2xCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztDQUNGLENBQUE7QUE1RHlCO0lBRnZCLE9BQU8sQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDO0lBQzdCLE1BQU0sRUFBRTs2Q0FDZ0U7QUFJakQ7SUFGdkIsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNWLE1BQU0sRUFBRTswQ0FDc0Q7QUFJdkM7SUFGdkIsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNWLE1BQU0sRUFBRTttQ0FDK0M7QUFHaEM7SUFEdkIsTUFBTSxFQUFFO3lDQUNxRDtBQWZoRDtJQWpCYixJQUFJLENBQUMsR0FBRyxFQUFFO1FBQ1QsTUFBTSxPQUFPLEdBQUcsZ0JBQWdCLENBQUM7UUFDakMsSUFBSSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBaUIsSUFBSSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNYLEtBQUssR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3RDLEtBQUssQ0FBQyxFQUFFLEdBQUcsT0FBTyxDQUFDO1lBQ25CLEtBQUssQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztZQUNsQyxLQUFLLENBQUMsS0FBSyxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7WUFDbkMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1lBQ3RCLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztZQUN2QixLQUFLLENBQUMsS0FBSyxDQUFDLG1CQUFtQixHQUFHLFFBQVEsQ0FBQyxDQUFDLDhDQUE4QztZQUMxRixLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7WUFDMUIsS0FBSyxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1lBQ2hDLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUM7UUFDRCxPQUFPLEtBQUssQ0FBQyxVQUFVLElBQUksS0FBSyxDQUFDLFlBQVksQ0FBQyxFQUFDLElBQUksRUFBRSxNQUFNLEVBQUMsQ0FBQyxDQUFDO0lBQ2hFLENBQUMsQ0FBQztnQ0FDbUM7QUFuQjFCLE1BQU07SUFEbEIsUUFBUSxDQUFDLFFBQVEsQ0FBQztHQUNOLE1BQU0sQ0FtRmxCIn0=
@@ -0,0 +1,29 @@
1
+ export * from './Audio';
2
+ export * from './Bezier';
3
+ export * from './Circle';
4
+ export * from './Code';
5
+ export * from './CubicBezier';
6
+ export * from './Curve';
7
+ export * from './Grid';
8
+ export * from './Icon';
9
+ export * from './Img';
10
+ export * from './Knot';
11
+ export * from './Latex';
12
+ export * from './Layout';
13
+ export * from './Line';
14
+ export * from './Media';
15
+ export * from './Node';
16
+ export * from './Path';
17
+ export * from './Polygon';
18
+ export * from './QuadBezier';
19
+ export * from './Ray';
20
+ export * from './Rect';
21
+ export * from './Rive';
22
+ export * from './Shape';
23
+ export * from './Spline';
24
+ export * from './SVG';
25
+ export * from './Txt';
26
+ export * from './types';
27
+ export * from './Video';
28
+ export * from './View2D';
29
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/lib/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,eAAe,CAAC;AAC9B,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,OAAO,CAAC;AACtB,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,OAAO,CAAC;AACtB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,OAAO,CAAC;AACtB,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC"}
@@ -0,0 +1,29 @@
1
+ export * from './Audio';
2
+ export * from './Bezier';
3
+ export * from './Circle';
4
+ export * from './Code';
5
+ export * from './CubicBezier';
6
+ export * from './Curve';
7
+ export * from './Grid';
8
+ export * from './Icon';
9
+ export * from './Img';
10
+ export * from './Knot';
11
+ export * from './Latex';
12
+ export * from './Layout';
13
+ export * from './Line';
14
+ export * from './Media';
15
+ export * from './Node';
16
+ export * from './Path';
17
+ export * from './Polygon';
18
+ export * from './QuadBezier';
19
+ export * from './Ray';
20
+ export * from './Rect';
21
+ export * from './Rive';
22
+ export * from './Shape';
23
+ export * from './Spline';
24
+ export * from './SVG';
25
+ export * from './Txt';
26
+ export * from './types';
27
+ export * from './Video';
28
+ export * from './View2D';
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUMifQ==
@@ -0,0 +1,17 @@
1
+ import type { ReferenceReceiver } from '@twick/core';
2
+ import type { Node } from './Node';
3
+ export type ComponentChild = Node | object | string | number | bigint | boolean | null | undefined;
4
+ export type ComponentChildren = ComponentChild | ComponentChild[];
5
+ export type NodeChildren = Node | Node[];
6
+ export type PropsOf<T> = T extends NodeConstructor<infer P> ? P : T extends FunctionComponent<infer P> ? P : never;
7
+ export interface JSXProps {
8
+ children?: ComponentChildren;
9
+ ref?: ReferenceReceiver<Node>;
10
+ }
11
+ export interface FunctionComponent<T = any> {
12
+ (props: T): Node | null;
13
+ }
14
+ export interface NodeConstructor<TProps = any, TNode = Node> {
15
+ new (props: TProps): TNode;
16
+ }
17
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/lib/components/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,aAAa,CAAC;AACnD,OAAO,KAAK,EAAC,IAAI,EAAC,MAAM,QAAQ,CAAC;AAEjC,MAAM,MAAM,cAAc,GACtB,IAAI,GACJ,MAAM,GACN,MAAM,GACN,MAAM,GACN,MAAM,GACN,OAAO,GACP,IAAI,GACJ,SAAS,CAAC;AAEd,MAAM,MAAM,iBAAiB,GAAG,cAAc,GAAG,cAAc,EAAE,CAAC;AAClE,MAAM,MAAM,YAAY,GAAG,IAAI,GAAG,IAAI,EAAE,CAAC;AAEzC,MAAM,MAAM,OAAO,CAAC,CAAC,IACnB,CAAC,SAAS,eAAe,CAAC,MAAM,CAAC,CAAC,GAC9B,CAAC,GACD,CAAC,SAAS,iBAAiB,CAAC,MAAM,CAAC,CAAC,GAClC,CAAC,GACD,KAAK,CAAC;AAEd,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,EAAE,iBAAiB,CAAC;IAC7B,GAAG,CAAC,EAAE,iBAAiB,CAAC,IAAI,CAAC,CAAC;CAC/B;AAED,MAAM,WAAW,iBAAiB,CAAC,CAAC,GAAG,GAAG;IACxC,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC;CACzB;AAED,MAAM,WAAW,eAAe,CAAC,MAAM,GAAG,GAAG,EAAE,KAAK,GAAG,IAAI;IACzD,KAAK,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC;CAC5B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -0,0 +1,26 @@
1
+ import { Vector2 } from '@twick/core';
2
+ import type { CurvePoint } from './CurvePoint';
3
+ import { Segment } from './Segment';
4
+ export declare class ArcSegment extends Segment {
5
+ readonly startPoint: Vector2;
6
+ readonly radius: Vector2;
7
+ readonly xAxisRotationDegree: number;
8
+ readonly largeArcFlag: number;
9
+ readonly sweepFlag: number;
10
+ readonly endPoint: Vector2;
11
+ private static el;
12
+ readonly center: Vector2;
13
+ readonly startAngle: number;
14
+ readonly deltaAngle: number;
15
+ readonly xAxisRotation: number;
16
+ private xAxisRotationMatrix;
17
+ readonly points: Vector2[];
18
+ private length;
19
+ constructor(startPoint: Vector2, radius: Vector2, xAxisRotationDegree: number, largeArcFlag: number, sweepFlag: number, endPoint: Vector2);
20
+ getAnglePosition(angle: number): Vector2;
21
+ getAngleDerivative(angle: number): Vector2;
22
+ draw(context: CanvasRenderingContext2D | Path2D, start: number, end: number, move: boolean): [CurvePoint, CurvePoint];
23
+ getPoint(distance: number): CurvePoint;
24
+ get arcLength(): number;
25
+ }
26
+ //# sourceMappingURL=ArcSegment.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ArcSegment.d.ts","sourceRoot":"","sources":["../../src/lib/curves/ArcSegment.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,OAAO,EAGR,MAAM,aAAa,CAAC;AAErB,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAC;AAElC,qBAAa,UAAW,SAAQ,OAAO;aAmBnB,UAAU,EAAE,OAAO;aACnB,MAAM,EAAE,OAAO;aACf,mBAAmB,EAAE,MAAM;aAC3B,YAAY,EAAE,MAAM;aACpB,SAAS,EAAE,MAAM;aACjB,QAAQ,EAAE,OAAO;IAhBnC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAiB;IAClC,SAAgB,MAAM,EAAE,OAAO,CAAC;IAEhC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,aAAa,EAAE,MAAM,CAAC;IACtC,OAAO,CAAC,mBAAmB,CAAY;IACvC,SAAyB,MAAM,EAAE,OAAO,EAAE,CAAC;IAC3C,OAAO,CAAC,MAAM,CAAS;gBAGL,UAAU,EAAE,OAAO,EACnB,MAAM,EAAE,OAAO,EACf,mBAAmB,EAAE,MAAM,EAC3B,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,OAAO;IA8D5B,gBAAgB,CAAC,KAAK,EAAE,MAAM;IAQ9B,kBAAkB,CAAC,KAAK,EAAE,MAAM;IAQhC,IAAI,CACT,OAAO,EAAE,wBAAwB,GAAG,MAAM,EAC1C,KAAK,EAAE,MAAM,EACb,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,OAAO,GACZ,CAAC,UAAU,EAAE,UAAU,CAAC;IAsBpB,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,UAAU;IAc7C,IAAW,SAAS,IAAI,MAAM,CAE7B;CACF"}