@twick/2d 0.14.17 → 0.14.19

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 (536) hide show
  1. package/LICENSE +21 -21
  2. package/package.json +4 -4
  3. package/src/editor/NodeInspectorConfig.tsx +76 -76
  4. package/src/editor/PreviewOverlayConfig.tsx +67 -67
  5. package/src/editor/Provider.tsx +93 -93
  6. package/src/editor/SceneGraphTabConfig.tsx +81 -81
  7. package/src/editor/icons/CircleIcon.tsx +7 -7
  8. package/src/editor/icons/CodeBlockIcon.tsx +8 -8
  9. package/src/editor/icons/CurveIcon.tsx +7 -7
  10. package/src/editor/icons/GridIcon.tsx +7 -7
  11. package/src/editor/icons/IconMap.ts +35 -35
  12. package/src/editor/icons/ImgIcon.tsx +8 -8
  13. package/src/editor/icons/LayoutIcon.tsx +9 -9
  14. package/src/editor/icons/LineIcon.tsx +7 -7
  15. package/src/editor/icons/NodeIcon.tsx +7 -7
  16. package/src/editor/icons/RayIcon.tsx +7 -7
  17. package/src/editor/icons/RectIcon.tsx +7 -7
  18. package/src/editor/icons/ShapeIcon.tsx +7 -7
  19. package/src/editor/icons/TxtIcon.tsx +8 -8
  20. package/src/editor/icons/VideoIcon.tsx +7 -7
  21. package/src/editor/icons/View2DIcon.tsx +10 -10
  22. package/src/editor/index.ts +17 -17
  23. package/src/editor/tree/DetachedRoot.tsx +23 -23
  24. package/src/editor/tree/NodeElement.tsx +74 -74
  25. package/src/editor/tree/TreeElement.tsx +72 -72
  26. package/src/editor/tree/TreeRoot.tsx +10 -10
  27. package/src/editor/tree/ViewRoot.tsx +20 -20
  28. package/src/editor/tree/index.module.scss +38 -38
  29. package/src/editor/tree/index.ts +3 -3
  30. package/src/editor/tsconfig.build.json +5 -5
  31. package/src/editor/tsconfig.json +12 -12
  32. package/src/editor/tsdoc.json +4 -4
  33. package/src/editor/vite-env.d.ts +1 -1
  34. package/src/lib/code/CodeCursor.ts +445 -445
  35. package/src/lib/code/CodeDiffer.ts +78 -78
  36. package/src/lib/code/CodeFragment.ts +97 -97
  37. package/src/lib/code/CodeHighlighter.ts +75 -75
  38. package/src/lib/code/CodeMetrics.ts +47 -47
  39. package/src/lib/code/CodeRange.test.ts +74 -74
  40. package/src/lib/code/CodeRange.ts +216 -216
  41. package/src/lib/code/CodeScope.ts +101 -101
  42. package/src/lib/code/CodeSelection.ts +24 -24
  43. package/src/lib/code/CodeSignal.ts +327 -327
  44. package/src/lib/code/CodeTokenizer.ts +54 -54
  45. package/src/lib/code/DefaultHighlightStyle.ts +98 -98
  46. package/src/lib/code/LezerHighlighter.ts +113 -113
  47. package/src/lib/code/diff.test.ts +311 -311
  48. package/src/lib/code/diff.ts +319 -319
  49. package/src/lib/code/extractRange.ts +126 -126
  50. package/src/lib/code/index.ts +13 -13
  51. package/src/lib/components/Audio.ts +168 -168
  52. package/src/lib/components/Bezier.ts +105 -105
  53. package/src/lib/components/Circle.ts +266 -266
  54. package/src/lib/components/Code.ts +526 -526
  55. package/src/lib/components/CodeBlock.ts +576 -576
  56. package/src/lib/components/CubicBezier.ts +112 -112
  57. package/src/lib/components/Curve.ts +455 -455
  58. package/src/lib/components/Grid.ts +135 -135
  59. package/src/lib/components/Icon.ts +96 -96
  60. package/src/lib/components/Img.ts +319 -319
  61. package/src/lib/components/Knot.ts +157 -157
  62. package/src/lib/components/Latex.ts +122 -122
  63. package/src/lib/components/Layout.ts +1092 -1092
  64. package/src/lib/components/Line.ts +429 -429
  65. package/src/lib/components/Media.ts +576 -576
  66. package/src/lib/components/Node.ts +1940 -1940
  67. package/src/lib/components/Path.ts +137 -137
  68. package/src/lib/components/Polygon.ts +171 -171
  69. package/src/lib/components/QuadBezier.ts +100 -100
  70. package/src/lib/components/Ray.ts +125 -125
  71. package/src/lib/components/Rect.ts +187 -187
  72. package/src/lib/components/Rive.ts +156 -156
  73. package/src/lib/components/SVG.ts +797 -797
  74. package/src/lib/components/Shape.ts +143 -143
  75. package/src/lib/components/Spline.ts +344 -344
  76. package/src/lib/components/Txt.test.tsx +81 -81
  77. package/src/lib/components/Txt.ts +203 -203
  78. package/src/lib/components/TxtLeaf.ts +205 -205
  79. package/src/lib/components/Video.ts +461 -461
  80. package/src/lib/components/View2D.ts +98 -98
  81. package/src/lib/components/__tests__/children.test.tsx +142 -142
  82. package/src/lib/components/__tests__/clone.test.tsx +126 -126
  83. package/src/lib/components/__tests__/generatorTest.ts +28 -28
  84. package/src/lib/components/__tests__/mockScene2D.ts +45 -45
  85. package/src/lib/components/__tests__/query.test.tsx +122 -122
  86. package/src/lib/components/__tests__/state.test.tsx +60 -60
  87. package/src/lib/components/index.ts +28 -28
  88. package/src/lib/components/types.ts +35 -35
  89. package/src/lib/curves/ArcSegment.ts +159 -159
  90. package/src/lib/curves/CircleSegment.ts +77 -77
  91. package/src/lib/curves/CubicBezierSegment.ts +78 -78
  92. package/src/lib/curves/CurveDrawingInfo.ts +11 -11
  93. package/src/lib/curves/CurvePoint.ts +15 -15
  94. package/src/lib/curves/CurveProfile.ts +7 -7
  95. package/src/lib/curves/KnotInfo.ts +10 -10
  96. package/src/lib/curves/LineSegment.ts +62 -62
  97. package/src/lib/curves/Polynomial.ts +355 -355
  98. package/src/lib/curves/Polynomial2D.ts +62 -62
  99. package/src/lib/curves/PolynomialSegment.ts +124 -124
  100. package/src/lib/curves/QuadBezierSegment.ts +64 -64
  101. package/src/lib/curves/Segment.ts +17 -17
  102. package/src/lib/curves/UniformPolynomialCurveSampler.ts +94 -94
  103. package/src/lib/curves/createCurveProfileLerp.ts +471 -471
  104. package/src/lib/curves/getBezierSplineProfile.ts +223 -223
  105. package/src/lib/curves/getCircleProfile.ts +86 -86
  106. package/src/lib/curves/getPathProfile.ts +178 -178
  107. package/src/lib/curves/getPointAtDistance.ts +21 -21
  108. package/src/lib/curves/getPolylineProfile.test.ts +21 -21
  109. package/src/lib/curves/getPolylineProfile.ts +89 -89
  110. package/src/lib/curves/getRectProfile.ts +139 -139
  111. package/src/lib/curves/index.ts +16 -16
  112. package/src/lib/decorators/canvasStyleSignal.ts +16 -16
  113. package/src/lib/decorators/colorSignal.ts +9 -9
  114. package/src/lib/decorators/compound.ts +72 -72
  115. package/src/lib/decorators/computed.ts +18 -18
  116. package/src/lib/decorators/defaultStyle.ts +18 -18
  117. package/src/lib/decorators/filtersSignal.ts +136 -136
  118. package/src/lib/decorators/index.ts +10 -10
  119. package/src/lib/decorators/initializers.ts +32 -32
  120. package/src/lib/decorators/nodeName.ts +13 -13
  121. package/src/lib/decorators/signal.test.ts +90 -90
  122. package/src/lib/decorators/signal.ts +345 -345
  123. package/src/lib/decorators/spacingSignal.ts +15 -15
  124. package/src/lib/decorators/vector2Signal.ts +30 -30
  125. package/src/lib/globals.d.ts +2 -2
  126. package/src/lib/index.ts +8 -8
  127. package/src/lib/jsx-dev-runtime.ts +2 -2
  128. package/src/lib/jsx-runtime.ts +46 -46
  129. package/src/lib/parse-svg-path.d.ts +14 -14
  130. package/src/lib/partials/Filter.ts +180 -180
  131. package/src/lib/partials/Gradient.ts +102 -102
  132. package/src/lib/partials/Pattern.ts +34 -34
  133. package/src/lib/partials/ShaderConfig.ts +117 -117
  134. package/src/lib/partials/index.ts +4 -4
  135. package/src/lib/partials/types.ts +58 -58
  136. package/src/lib/scenes/Scene2D.ts +242 -242
  137. package/src/lib/scenes/index.ts +3 -3
  138. package/src/lib/scenes/makeScene2D.ts +16 -16
  139. package/src/lib/scenes/useScene2D.ts +6 -6
  140. package/src/lib/tsconfig.build.json +5 -5
  141. package/src/lib/tsconfig.json +10 -10
  142. package/src/lib/tsdoc.json +4 -4
  143. package/src/lib/utils/CanvasUtils.ts +306 -306
  144. package/src/lib/utils/diff.test.ts +453 -453
  145. package/src/lib/utils/diff.ts +148 -148
  146. package/src/lib/utils/index.ts +2 -2
  147. package/src/lib/utils/is.ts +11 -11
  148. package/src/lib/utils/makeSignalExtensions.ts +30 -30
  149. package/src/lib/utils/video/declarations.d.ts +1 -1
  150. package/src/lib/utils/video/ffmpeg-client.ts +50 -50
  151. package/src/lib/utils/video/mp4-parser-manager.ts +72 -72
  152. package/src/lib/utils/video/parser/index.ts +1 -1
  153. package/src/lib/utils/video/parser/parser.ts +257 -257
  154. package/src/lib/utils/video/parser/sampler.ts +72 -72
  155. package/src/lib/utils/video/parser/segment.ts +302 -302
  156. package/src/lib/utils/video/parser/sink.ts +29 -29
  157. package/src/lib/utils/video/parser/utils.ts +31 -31
  158. package/src/tsconfig.base.json +19 -19
  159. package/src/tsconfig.build.json +8 -8
  160. package/src/tsconfig.json +5 -5
  161. package/tsconfig.project.json +7 -7
  162. package/editor/editor/NodeInspectorConfig.d.ts +0 -3
  163. package/editor/editor/NodeInspectorConfig.d.ts.map +0 -1
  164. package/editor/editor/PreviewOverlayConfig.d.ts +0 -3
  165. package/editor/editor/PreviewOverlayConfig.d.ts.map +0 -1
  166. package/editor/editor/Provider.d.ts +0 -17
  167. package/editor/editor/Provider.d.ts.map +0 -1
  168. package/editor/editor/SceneGraphTabConfig.d.ts +0 -3
  169. package/editor/editor/SceneGraphTabConfig.d.ts.map +0 -1
  170. package/editor/editor/icons/CircleIcon.d.ts +0 -2
  171. package/editor/editor/icons/CircleIcon.d.ts.map +0 -1
  172. package/editor/editor/icons/CodeBlockIcon.d.ts +0 -2
  173. package/editor/editor/icons/CodeBlockIcon.d.ts.map +0 -1
  174. package/editor/editor/icons/CurveIcon.d.ts +0 -2
  175. package/editor/editor/icons/CurveIcon.d.ts.map +0 -1
  176. package/editor/editor/icons/GridIcon.d.ts +0 -2
  177. package/editor/editor/icons/GridIcon.d.ts.map +0 -1
  178. package/editor/editor/icons/IconMap.d.ts +0 -3
  179. package/editor/editor/icons/IconMap.d.ts.map +0 -1
  180. package/editor/editor/icons/ImgIcon.d.ts +0 -2
  181. package/editor/editor/icons/ImgIcon.d.ts.map +0 -1
  182. package/editor/editor/icons/LayoutIcon.d.ts +0 -2
  183. package/editor/editor/icons/LayoutIcon.d.ts.map +0 -1
  184. package/editor/editor/icons/LineIcon.d.ts +0 -2
  185. package/editor/editor/icons/LineIcon.d.ts.map +0 -1
  186. package/editor/editor/icons/NodeIcon.d.ts +0 -2
  187. package/editor/editor/icons/NodeIcon.d.ts.map +0 -1
  188. package/editor/editor/icons/RayIcon.d.ts +0 -2
  189. package/editor/editor/icons/RayIcon.d.ts.map +0 -1
  190. package/editor/editor/icons/RectIcon.d.ts +0 -2
  191. package/editor/editor/icons/RectIcon.d.ts.map +0 -1
  192. package/editor/editor/icons/ShapeIcon.d.ts +0 -2
  193. package/editor/editor/icons/ShapeIcon.d.ts.map +0 -1
  194. package/editor/editor/icons/TxtIcon.d.ts +0 -2
  195. package/editor/editor/icons/TxtIcon.d.ts.map +0 -1
  196. package/editor/editor/icons/VideoIcon.d.ts +0 -2
  197. package/editor/editor/icons/VideoIcon.d.ts.map +0 -1
  198. package/editor/editor/icons/View2DIcon.d.ts +0 -2
  199. package/editor/editor/icons/View2DIcon.d.ts.map +0 -1
  200. package/editor/editor/index.d.ts +0 -4
  201. package/editor/editor/index.d.ts.map +0 -1
  202. package/editor/editor/tree/DetachedRoot.d.ts +0 -2
  203. package/editor/editor/tree/DetachedRoot.d.ts.map +0 -1
  204. package/editor/editor/tree/NodeElement.d.ts +0 -8
  205. package/editor/editor/tree/NodeElement.d.ts.map +0 -1
  206. package/editor/editor/tree/TreeElement.d.ts +0 -15
  207. package/editor/editor/tree/TreeElement.d.ts.map +0 -1
  208. package/editor/editor/tree/TreeRoot.d.ts +0 -3
  209. package/editor/editor/tree/TreeRoot.d.ts.map +0 -1
  210. package/editor/editor/tree/ViewRoot.d.ts +0 -2
  211. package/editor/editor/tree/ViewRoot.d.ts.map +0 -1
  212. package/editor/editor/tree/index.d.ts +0 -4
  213. package/editor/editor/tree/index.d.ts.map +0 -1
  214. package/editor/editor/tsconfig.build.tsbuildinfo +0 -1
  215. package/editor/index.css +0 -33
  216. package/editor/index.js +0 -341
  217. package/editor/index.js.map +0 -1
  218. package/lib/code/CodeCursor.d.ts +0 -83
  219. package/lib/code/CodeCursor.d.ts.map +0 -1
  220. package/lib/code/CodeCursor.js +0 -306
  221. package/lib/code/CodeDiffer.d.ts +0 -28
  222. package/lib/code/CodeDiffer.d.ts.map +0 -1
  223. package/lib/code/CodeDiffer.js +0 -51
  224. package/lib/code/CodeFragment.d.ts +0 -42
  225. package/lib/code/CodeFragment.d.ts.map +0 -1
  226. package/lib/code/CodeFragment.js +0 -72
  227. package/lib/code/CodeHighlighter.d.ts +0 -71
  228. package/lib/code/CodeHighlighter.d.ts.map +0 -1
  229. package/lib/code/CodeHighlighter.js +0 -2
  230. package/lib/code/CodeMetrics.d.ts +0 -11
  231. package/lib/code/CodeMetrics.d.ts.map +0 -1
  232. package/lib/code/CodeMetrics.js +0 -29
  233. package/lib/code/CodeRange.d.ts +0 -41
  234. package/lib/code/CodeRange.d.ts.map +0 -1
  235. package/lib/code/CodeRange.js +0 -179
  236. package/lib/code/CodeScope.d.ts +0 -16
  237. package/lib/code/CodeScope.d.ts.map +0 -1
  238. package/lib/code/CodeScope.js +0 -72
  239. package/lib/code/CodeSelection.d.ts +0 -6
  240. package/lib/code/CodeSelection.d.ts.map +0 -1
  241. package/lib/code/CodeSelection.js +0 -13
  242. package/lib/code/CodeSignal.d.ts +0 -60
  243. package/lib/code/CodeSignal.d.ts.map +0 -1
  244. package/lib/code/CodeSignal.js +0 -194
  245. package/lib/code/CodeTokenizer.d.ts +0 -8
  246. package/lib/code/CodeTokenizer.d.ts.map +0 -1
  247. package/lib/code/CodeTokenizer.js +0 -50
  248. package/lib/code/DefaultHighlightStyle.d.ts +0 -3
  249. package/lib/code/DefaultHighlightStyle.d.ts.map +0 -1
  250. package/lib/code/DefaultHighlightStyle.js +0 -98
  251. package/lib/code/LezerHighlighter.d.ts +0 -22
  252. package/lib/code/LezerHighlighter.d.ts.map +0 -1
  253. package/lib/code/LezerHighlighter.js +0 -89
  254. package/lib/code/diff.d.ts +0 -31
  255. package/lib/code/diff.d.ts.map +0 -1
  256. package/lib/code/diff.js +0 -236
  257. package/lib/code/extractRange.d.ts +0 -17
  258. package/lib/code/extractRange.d.ts.map +0 -1
  259. package/lib/code/extractRange.js +0 -102
  260. package/lib/code/index.d.ts +0 -14
  261. package/lib/code/index.d.ts.map +0 -1
  262. package/lib/code/index.js +0 -14
  263. package/lib/components/Audio.d.ts +0 -14
  264. package/lib/components/Audio.d.ts.map +0 -1
  265. package/lib/components/Audio.js +0 -148
  266. package/lib/components/Bezier.d.ts +0 -23
  267. package/lib/components/Bezier.d.ts.map +0 -1
  268. package/lib/components/Bezier.js +0 -81
  269. package/lib/components/Circle.d.ts +0 -193
  270. package/lib/components/Circle.d.ts.map +0 -1
  271. package/lib/components/Circle.js +0 -178
  272. package/lib/components/Code.d.ts +0 -231
  273. package/lib/components/Code.d.ts.map +0 -1
  274. package/lib/components/Code.js +0 -325
  275. package/lib/components/CodeBlock.d.ts +0 -133
  276. package/lib/components/CodeBlock.d.ts.map +0 -1
  277. package/lib/components/CodeBlock.js +0 -461
  278. package/lib/components/CubicBezier.d.ts +0 -70
  279. package/lib/components/CubicBezier.d.ts.map +0 -1
  280. package/lib/components/CubicBezier.js +0 -81
  281. package/lib/components/Curve.d.ts +0 -204
  282. package/lib/components/Curve.d.ts.map +0 -1
  283. package/lib/components/Curve.js +0 -284
  284. package/lib/components/Grid.d.ts +0 -76
  285. package/lib/components/Grid.d.ts.map +0 -1
  286. package/lib/components/Grid.js +0 -91
  287. package/lib/components/Icon.d.ts +0 -59
  288. package/lib/components/Icon.d.ts.map +0 -1
  289. package/lib/components/Icon.js +0 -58
  290. package/lib/components/Img.d.ts +0 -118
  291. package/lib/components/Img.d.ts.map +0 -1
  292. package/lib/components/Img.js +0 -245
  293. package/lib/components/Knot.d.ts +0 -90
  294. package/lib/components/Knot.d.ts.map +0 -1
  295. package/lib/components/Knot.js +0 -68
  296. package/lib/components/Latex.d.ts +0 -39
  297. package/lib/components/Latex.d.ts.map +0 -1
  298. package/lib/components/Latex.js +0 -101
  299. package/lib/components/Layout.d.ts +0 -419
  300. package/lib/components/Layout.d.ts.map +0 -1
  301. package/lib/components/Layout.js +0 -706
  302. package/lib/components/Line.d.ts +0 -160
  303. package/lib/components/Line.d.ts.map +0 -1
  304. package/lib/components/Line.js +0 -346
  305. package/lib/components/Media.d.ts +0 -70
  306. package/lib/components/Media.d.ts.map +0 -1
  307. package/lib/components/Media.js +0 -493
  308. package/lib/components/Node.d.ts +0 -836
  309. package/lib/components/Node.d.ts.map +0 -1
  310. package/lib/components/Node.js +0 -1317
  311. package/lib/components/Path.d.ts +0 -20
  312. package/lib/components/Path.d.ts.map +0 -1
  313. package/lib/components/Path.js +0 -97
  314. package/lib/components/Polygon.d.ts +0 -113
  315. package/lib/components/Polygon.d.ts.map +0 -1
  316. package/lib/components/Polygon.js +0 -123
  317. package/lib/components/QuadBezier.d.ts +0 -62
  318. package/lib/components/QuadBezier.d.ts.map +0 -1
  319. package/lib/components/QuadBezier.js +0 -76
  320. package/lib/components/Ray.d.ts +0 -62
  321. package/lib/components/Ray.d.ts.map +0 -1
  322. package/lib/components/Ray.js +0 -96
  323. package/lib/components/Rect.d.ts +0 -114
  324. package/lib/components/Rect.d.ts.map +0 -1
  325. package/lib/components/Rect.js +0 -76
  326. package/lib/components/Rive.d.ts +0 -22
  327. package/lib/components/Rive.d.ts.map +0 -1
  328. package/lib/components/Rive.js +0 -117
  329. package/lib/components/SVG.d.ts +0 -178
  330. package/lib/components/SVG.d.ts.map +0 -1
  331. package/lib/components/SVG.js +0 -577
  332. package/lib/components/Shape.d.ts +0 -40
  333. package/lib/components/Shape.d.ts.map +0 -1
  334. package/lib/components/Shape.js +0 -134
  335. package/lib/components/Spline.d.ts +0 -89
  336. package/lib/components/Spline.d.ts.map +0 -1
  337. package/lib/components/Spline.js +0 -256
  338. package/lib/components/Txt.d.ts +0 -53
  339. package/lib/components/Txt.d.ts.map +0 -1
  340. package/lib/components/Txt.js +0 -173
  341. package/lib/components/TxtLeaf.d.ts +0 -21
  342. package/lib/components/TxtLeaf.d.ts.map +0 -1
  343. package/lib/components/TxtLeaf.js +0 -181
  344. package/lib/components/Video.d.ts +0 -69
  345. package/lib/components/Video.d.ts.map +0 -1
  346. package/lib/components/Video.js +0 -342
  347. package/lib/components/View2D.d.ts +0 -28
  348. package/lib/components/View2D.d.ts.map +0 -1
  349. package/lib/components/View2D.js +0 -93
  350. package/lib/components/index.d.ts +0 -29
  351. package/lib/components/index.d.ts.map +0 -1
  352. package/lib/components/index.js +0 -29
  353. package/lib/components/types.d.ts +0 -17
  354. package/lib/components/types.d.ts.map +0 -1
  355. package/lib/components/types.js +0 -2
  356. package/lib/curves/ArcSegment.d.ts +0 -26
  357. package/lib/curves/ArcSegment.d.ts.map +0 -1
  358. package/lib/curves/ArcSegment.js +0 -97
  359. package/lib/curves/CircleSegment.d.ts +0 -18
  360. package/lib/curves/CircleSegment.d.ts.map +0 -1
  361. package/lib/curves/CircleSegment.js +0 -52
  362. package/lib/curves/CubicBezierSegment.d.ts +0 -18
  363. package/lib/curves/CubicBezierSegment.d.ts.map +0 -1
  364. package/lib/curves/CubicBezierSegment.js +0 -55
  365. package/lib/curves/CurveDrawingInfo.d.ts +0 -11
  366. package/lib/curves/CurveDrawingInfo.d.ts.map +0 -1
  367. package/lib/curves/CurveDrawingInfo.js +0 -2
  368. package/lib/curves/CurvePoint.d.ts +0 -15
  369. package/lib/curves/CurvePoint.d.ts.map +0 -1
  370. package/lib/curves/CurvePoint.js +0 -2
  371. package/lib/curves/CurveProfile.d.ts +0 -7
  372. package/lib/curves/CurveProfile.d.ts.map +0 -1
  373. package/lib/curves/CurveProfile.js +0 -2
  374. package/lib/curves/KnotInfo.d.ts +0 -12
  375. package/lib/curves/KnotInfo.d.ts.map +0 -1
  376. package/lib/curves/KnotInfo.js +0 -2
  377. package/lib/curves/LineSegment.d.ts +0 -16
  378. package/lib/curves/LineSegment.d.ts.map +0 -1
  379. package/lib/curves/LineSegment.js +0 -45
  380. package/lib/curves/Polynomial.d.ts +0 -118
  381. package/lib/curves/Polynomial.d.ts.map +0 -1
  382. package/lib/curves/Polynomial.js +0 -259
  383. package/lib/curves/Polynomial2D.d.ts +0 -22
  384. package/lib/curves/Polynomial2D.d.ts.map +0 -1
  385. package/lib/curves/Polynomial2D.js +0 -45
  386. package/lib/curves/PolynomialSegment.d.ts +0 -39
  387. package/lib/curves/PolynomialSegment.d.ts.map +0 -1
  388. package/lib/curves/PolynomialSegment.js +0 -86
  389. package/lib/curves/QuadBezierSegment.d.ts +0 -17
  390. package/lib/curves/QuadBezierSegment.d.ts.map +0 -1
  391. package/lib/curves/QuadBezierSegment.js +0 -49
  392. package/lib/curves/Segment.d.ts +0 -9
  393. package/lib/curves/Segment.d.ts.map +0 -1
  394. package/lib/curves/Segment.js +0 -3
  395. package/lib/curves/UniformPolynomialCurveSampler.d.ts +0 -43
  396. package/lib/curves/UniformPolynomialCurveSampler.d.ts.map +0 -1
  397. package/lib/curves/UniformPolynomialCurveSampler.js +0 -73
  398. package/lib/curves/createCurveProfileLerp.d.ts +0 -32
  399. package/lib/curves/createCurveProfileLerp.d.ts.map +0 -1
  400. package/lib/curves/createCurveProfileLerp.js +0 -351
  401. package/lib/curves/getBezierSplineProfile.d.ts +0 -12
  402. package/lib/curves/getBezierSplineProfile.d.ts.map +0 -1
  403. package/lib/curves/getBezierSplineProfile.js +0 -137
  404. package/lib/curves/getCircleProfile.d.ts +0 -4
  405. package/lib/curves/getCircleProfile.d.ts.map +0 -1
  406. package/lib/curves/getCircleProfile.js +0 -44
  407. package/lib/curves/getPathProfile.d.ts +0 -3
  408. package/lib/curves/getPathProfile.d.ts.map +0 -1
  409. package/lib/curves/getPathProfile.js +0 -128
  410. package/lib/curves/getPointAtDistance.d.ts +0 -4
  411. package/lib/curves/getPointAtDistance.d.ts.map +0 -1
  412. package/lib/curves/getPointAtDistance.js +0 -15
  413. package/lib/curves/getPolylineProfile.d.ts +0 -4
  414. package/lib/curves/getPolylineProfile.d.ts.map +0 -1
  415. package/lib/curves/getPolylineProfile.js +0 -58
  416. package/lib/curves/getRectProfile.d.ts +0 -4
  417. package/lib/curves/getRectProfile.d.ts.map +0 -1
  418. package/lib/curves/getRectProfile.js +0 -57
  419. package/lib/curves/index.d.ts +0 -17
  420. package/lib/curves/index.d.ts.map +0 -1
  421. package/lib/curves/index.js +0 -17
  422. package/lib/decorators/canvasStyleSignal.d.ts +0 -5
  423. package/lib/decorators/canvasStyleSignal.d.ts.map +0 -1
  424. package/lib/decorators/canvasStyleSignal.js +0 -12
  425. package/lib/decorators/colorSignal.d.ts +0 -2
  426. package/lib/decorators/colorSignal.d.ts.map +0 -1
  427. package/lib/decorators/colorSignal.js +0 -9
  428. package/lib/decorators/compound.d.ts +0 -26
  429. package/lib/decorators/compound.d.ts.map +0 -1
  430. package/lib/decorators/compound.js +0 -49
  431. package/lib/decorators/computed.d.ts +0 -9
  432. package/lib/decorators/computed.d.ts.map +0 -1
  433. package/lib/decorators/computed.js +0 -18
  434. package/lib/decorators/defaultStyle.d.ts +0 -2
  435. package/lib/decorators/defaultStyle.d.ts.map +0 -1
  436. package/lib/decorators/defaultStyle.js +0 -14
  437. package/lib/decorators/filtersSignal.d.ts +0 -13
  438. package/lib/decorators/filtersSignal.d.ts.map +0 -1
  439. package/lib/decorators/filtersSignal.js +0 -73
  440. package/lib/decorators/index.d.ts +0 -11
  441. package/lib/decorators/index.d.ts.map +0 -1
  442. package/lib/decorators/index.js +0 -11
  443. package/lib/decorators/initializers.d.ts +0 -4
  444. package/lib/decorators/initializers.d.ts.map +0 -1
  445. package/lib/decorators/initializers.js +0 -27
  446. package/lib/decorators/nodeName.d.ts +0 -9
  447. package/lib/decorators/nodeName.d.ts.map +0 -1
  448. package/lib/decorators/nodeName.js +0 -13
  449. package/lib/decorators/signal.d.ts +0 -183
  450. package/lib/decorators/signal.d.ts.map +0 -1
  451. package/lib/decorators/signal.js +0 -285
  452. package/lib/decorators/spacingSignal.d.ts +0 -2
  453. package/lib/decorators/spacingSignal.d.ts.map +0 -1
  454. package/lib/decorators/spacingSignal.js +0 -15
  455. package/lib/decorators/vector2Signal.d.ts +0 -9
  456. package/lib/decorators/vector2Signal.d.ts.map +0 -1
  457. package/lib/decorators/vector2Signal.js +0 -15
  458. package/lib/index.d.ts +0 -9
  459. package/lib/index.d.ts.map +0 -1
  460. package/lib/index.js +0 -9
  461. package/lib/jsx-dev-runtime.d.ts +0 -3
  462. package/lib/jsx-dev-runtime.d.ts.map +0 -1
  463. package/lib/jsx-dev-runtime.js +0 -3
  464. package/lib/jsx-runtime.d.ts +0 -12
  465. package/lib/jsx-runtime.d.ts.map +0 -1
  466. package/lib/jsx-runtime.js +0 -23
  467. package/lib/partials/Filter.d.ts +0 -82
  468. package/lib/partials/Filter.d.ts.map +0 -1
  469. package/lib/partials/Filter.js +0 -135
  470. package/lib/partials/Gradient.d.ts +0 -31
  471. package/lib/partials/Gradient.d.ts.map +0 -1
  472. package/lib/partials/Gradient.js +0 -63
  473. package/lib/partials/Pattern.d.ts +0 -13
  474. package/lib/partials/Pattern.d.ts.map +0 -1
  475. package/lib/partials/Pattern.js +0 -27
  476. package/lib/partials/ShaderConfig.d.ts +0 -81
  477. package/lib/partials/ShaderConfig.d.ts.map +0 -1
  478. package/lib/partials/ShaderConfig.js +0 -25
  479. package/lib/partials/index.d.ts +0 -5
  480. package/lib/partials/index.d.ts.map +0 -1
  481. package/lib/partials/index.js +0 -5
  482. package/lib/partials/types.d.ts +0 -35
  483. package/lib/partials/types.d.ts.map +0 -1
  484. package/lib/partials/types.js +0 -2
  485. package/lib/scenes/Scene2D.d.ts +0 -29
  486. package/lib/scenes/Scene2D.d.ts.map +0 -1
  487. package/lib/scenes/Scene2D.js +0 -180
  488. package/lib/scenes/index.d.ts +0 -4
  489. package/lib/scenes/index.d.ts.map +0 -1
  490. package/lib/scenes/index.js +0 -4
  491. package/lib/scenes/makeScene2D.d.ts +0 -5
  492. package/lib/scenes/makeScene2D.d.ts.map +0 -1
  493. package/lib/scenes/makeScene2D.js +0 -11
  494. package/lib/scenes/useScene2D.d.ts +0 -3
  495. package/lib/scenes/useScene2D.d.ts.map +0 -1
  496. package/lib/scenes/useScene2D.js +0 -5
  497. package/lib/tsconfig.build.tsbuildinfo +0 -1
  498. package/lib/utils/CanvasUtils.d.ts +0 -23
  499. package/lib/utils/CanvasUtils.d.ts.map +0 -1
  500. package/lib/utils/CanvasUtils.js +0 -138
  501. package/lib/utils/diff.d.ts +0 -31
  502. package/lib/utils/diff.d.ts.map +0 -1
  503. package/lib/utils/diff.js +0 -97
  504. package/lib/utils/index.d.ts +0 -3
  505. package/lib/utils/index.d.ts.map +0 -1
  506. package/lib/utils/index.js +0 -3
  507. package/lib/utils/is.d.ts +0 -8
  508. package/lib/utils/is.d.ts.map +0 -1
  509. package/lib/utils/is.js +0 -10
  510. package/lib/utils/makeSignalExtensions.d.ts +0 -4
  511. package/lib/utils/makeSignalExtensions.d.ts.map +0 -1
  512. package/lib/utils/makeSignalExtensions.js +0 -20
  513. package/lib/utils/video/ffmpeg-client.d.ts +0 -5
  514. package/lib/utils/video/ffmpeg-client.d.ts.map +0 -1
  515. package/lib/utils/video/ffmpeg-client.js +0 -32
  516. package/lib/utils/video/mp4-parser-manager.d.ts +0 -3
  517. package/lib/utils/video/mp4-parser-manager.d.ts.map +0 -1
  518. package/lib/utils/video/mp4-parser-manager.js +0 -55
  519. package/lib/utils/video/parser/index.d.ts +0 -2
  520. package/lib/utils/video/parser/index.d.ts.map +0 -1
  521. package/lib/utils/video/parser/index.js +0 -2
  522. package/lib/utils/video/parser/parser.d.ts +0 -21
  523. package/lib/utils/video/parser/parser.d.ts.map +0 -1
  524. package/lib/utils/video/parser/parser.js +0 -168
  525. package/lib/utils/video/parser/sampler.d.ts +0 -16
  526. package/lib/utils/video/parser/sampler.d.ts.map +0 -1
  527. package/lib/utils/video/parser/sampler.js +0 -56
  528. package/lib/utils/video/parser/segment.d.ts +0 -48
  529. package/lib/utils/video/parser/segment.d.ts.map +0 -1
  530. package/lib/utils/video/parser/segment.js +0 -239
  531. package/lib/utils/video/parser/sink.d.ts +0 -9
  532. package/lib/utils/video/parser/sink.d.ts.map +0 -1
  533. package/lib/utils/video/parser/sink.js +0 -22
  534. package/lib/utils/video/parser/utils.d.ts +0 -10
  535. package/lib/utils/video/parser/utils.d.ts.map +0 -1
  536. package/lib/utils/video/parser/utils.js +0 -22
@@ -1,139 +1,139 @@
1
- import type {BBox, Spacing} from '@twick/core';
2
- import {Vector2} from '@twick/core';
3
- import {adjustRectRadius} from '../utils';
4
- import {CircleSegment} from './CircleSegment';
5
- import {CubicBezierSegment} from './CubicBezierSegment';
6
- import type {CurveProfile} from './CurveProfile';
7
- import {LineSegment} from './LineSegment';
8
- import type {Segment} from './Segment';
9
-
10
- export function getRectProfile(
11
- rect: BBox,
12
- radius: Spacing,
13
- smoothCorners: boolean,
14
- cornerSharpness: number,
15
- ): CurveProfile {
16
- const profile: CurveProfile = {
17
- arcLength: 0,
18
- segments: [],
19
- minSin: 1,
20
- };
21
-
22
- const topLeft = adjustRectRadius(radius.top, radius.right, radius.left, rect);
23
- const topRight = adjustRectRadius(
24
- radius.right,
25
- radius.top,
26
- radius.bottom,
27
- rect,
28
- );
29
- const bottomRight = adjustRectRadius(
30
- radius.bottom,
31
- radius.left,
32
- radius.right,
33
- rect,
34
- );
35
- const bottomLeft = adjustRectRadius(
36
- radius.left,
37
- radius.bottom,
38
- radius.top,
39
- rect,
40
- );
41
-
42
- let from = new Vector2(rect.left + topLeft, rect.top);
43
- let to = new Vector2(rect.right - topRight, rect.top);
44
- addSegment(profile, new LineSegment(from, to));
45
-
46
- from = new Vector2(rect.right, rect.top + topRight);
47
- to = new Vector2(rect.right, rect.bottom - bottomRight);
48
- if (topRight > 0) {
49
- addCornerSegment(
50
- profile,
51
- from.addX(-topRight),
52
- topRight,
53
- Vector2.down,
54
- Vector2.right,
55
- smoothCorners,
56
- cornerSharpness,
57
- );
58
- }
59
- addSegment(profile, new LineSegment(from, to));
60
-
61
- from = new Vector2(rect.right - bottomRight, rect.bottom);
62
- to = new Vector2(rect.left + bottomLeft, rect.bottom);
63
- if (bottomRight > 0) {
64
- addCornerSegment(
65
- profile,
66
- from.addY(-bottomRight),
67
- bottomRight,
68
- Vector2.right,
69
- Vector2.up,
70
- smoothCorners,
71
- cornerSharpness,
72
- );
73
- }
74
- addSegment(profile, new LineSegment(from, to));
75
-
76
- from = new Vector2(rect.left, rect.bottom - bottomLeft);
77
- to = new Vector2(rect.left, rect.top + topLeft);
78
- if (bottomLeft > 0) {
79
- addCornerSegment(
80
- profile,
81
- from.addX(bottomLeft),
82
- bottomLeft,
83
- Vector2.up,
84
- Vector2.left,
85
- smoothCorners,
86
- cornerSharpness,
87
- );
88
- }
89
- addSegment(profile, new LineSegment(from, to));
90
-
91
- from = new Vector2(rect.left + topLeft, rect.top);
92
- if (topLeft > 0) {
93
- addCornerSegment(
94
- profile,
95
- from.addY(topLeft),
96
- topLeft,
97
- Vector2.left,
98
- Vector2.down,
99
- smoothCorners,
100
- cornerSharpness,
101
- );
102
- }
103
-
104
- return profile;
105
- }
106
-
107
- function addSegment(profile: CurveProfile, segment: Segment) {
108
- profile.segments.push(segment);
109
- profile.arcLength += segment.arcLength;
110
- }
111
-
112
- function addCornerSegment(
113
- profile: CurveProfile,
114
- center: Vector2,
115
- radius: number,
116
- fromNormal: Vector2,
117
- toNormal: Vector2,
118
- smooth: boolean,
119
- sharpness: number,
120
- ) {
121
- const from = center.add(fromNormal.scale(radius));
122
- const to = center.add(toNormal.scale(radius));
123
- if (smooth) {
124
- addSegment(
125
- profile,
126
- new CubicBezierSegment(
127
- from,
128
- from.add(toNormal.scale(sharpness * radius)),
129
- to.add(fromNormal.scale(sharpness * radius)),
130
- to,
131
- ),
132
- );
133
- } else {
134
- addSegment(
135
- profile,
136
- new CircleSegment(center, radius, fromNormal, toNormal, false),
137
- );
138
- }
139
- }
1
+ import type {BBox, Spacing} from '@twick/core';
2
+ import {Vector2} from '@twick/core';
3
+ import {adjustRectRadius} from '../utils';
4
+ import {CircleSegment} from './CircleSegment';
5
+ import {CubicBezierSegment} from './CubicBezierSegment';
6
+ import type {CurveProfile} from './CurveProfile';
7
+ import {LineSegment} from './LineSegment';
8
+ import type {Segment} from './Segment';
9
+
10
+ export function getRectProfile(
11
+ rect: BBox,
12
+ radius: Spacing,
13
+ smoothCorners: boolean,
14
+ cornerSharpness: number,
15
+ ): CurveProfile {
16
+ const profile: CurveProfile = {
17
+ arcLength: 0,
18
+ segments: [],
19
+ minSin: 1,
20
+ };
21
+
22
+ const topLeft = adjustRectRadius(radius.top, radius.right, radius.left, rect);
23
+ const topRight = adjustRectRadius(
24
+ radius.right,
25
+ radius.top,
26
+ radius.bottom,
27
+ rect,
28
+ );
29
+ const bottomRight = adjustRectRadius(
30
+ radius.bottom,
31
+ radius.left,
32
+ radius.right,
33
+ rect,
34
+ );
35
+ const bottomLeft = adjustRectRadius(
36
+ radius.left,
37
+ radius.bottom,
38
+ radius.top,
39
+ rect,
40
+ );
41
+
42
+ let from = new Vector2(rect.left + topLeft, rect.top);
43
+ let to = new Vector2(rect.right - topRight, rect.top);
44
+ addSegment(profile, new LineSegment(from, to));
45
+
46
+ from = new Vector2(rect.right, rect.top + topRight);
47
+ to = new Vector2(rect.right, rect.bottom - bottomRight);
48
+ if (topRight > 0) {
49
+ addCornerSegment(
50
+ profile,
51
+ from.addX(-topRight),
52
+ topRight,
53
+ Vector2.down,
54
+ Vector2.right,
55
+ smoothCorners,
56
+ cornerSharpness,
57
+ );
58
+ }
59
+ addSegment(profile, new LineSegment(from, to));
60
+
61
+ from = new Vector2(rect.right - bottomRight, rect.bottom);
62
+ to = new Vector2(rect.left + bottomLeft, rect.bottom);
63
+ if (bottomRight > 0) {
64
+ addCornerSegment(
65
+ profile,
66
+ from.addY(-bottomRight),
67
+ bottomRight,
68
+ Vector2.right,
69
+ Vector2.up,
70
+ smoothCorners,
71
+ cornerSharpness,
72
+ );
73
+ }
74
+ addSegment(profile, new LineSegment(from, to));
75
+
76
+ from = new Vector2(rect.left, rect.bottom - bottomLeft);
77
+ to = new Vector2(rect.left, rect.top + topLeft);
78
+ if (bottomLeft > 0) {
79
+ addCornerSegment(
80
+ profile,
81
+ from.addX(bottomLeft),
82
+ bottomLeft,
83
+ Vector2.up,
84
+ Vector2.left,
85
+ smoothCorners,
86
+ cornerSharpness,
87
+ );
88
+ }
89
+ addSegment(profile, new LineSegment(from, to));
90
+
91
+ from = new Vector2(rect.left + topLeft, rect.top);
92
+ if (topLeft > 0) {
93
+ addCornerSegment(
94
+ profile,
95
+ from.addY(topLeft),
96
+ topLeft,
97
+ Vector2.left,
98
+ Vector2.down,
99
+ smoothCorners,
100
+ cornerSharpness,
101
+ );
102
+ }
103
+
104
+ return profile;
105
+ }
106
+
107
+ function addSegment(profile: CurveProfile, segment: Segment) {
108
+ profile.segments.push(segment);
109
+ profile.arcLength += segment.arcLength;
110
+ }
111
+
112
+ function addCornerSegment(
113
+ profile: CurveProfile,
114
+ center: Vector2,
115
+ radius: number,
116
+ fromNormal: Vector2,
117
+ toNormal: Vector2,
118
+ smooth: boolean,
119
+ sharpness: number,
120
+ ) {
121
+ const from = center.add(fromNormal.scale(radius));
122
+ const to = center.add(toNormal.scale(radius));
123
+ if (smooth) {
124
+ addSegment(
125
+ profile,
126
+ new CubicBezierSegment(
127
+ from,
128
+ from.add(toNormal.scale(sharpness * radius)),
129
+ to.add(fromNormal.scale(sharpness * radius)),
130
+ to,
131
+ ),
132
+ );
133
+ } else {
134
+ addSegment(
135
+ profile,
136
+ new CircleSegment(center, radius, fromNormal, toNormal, false),
137
+ );
138
+ }
139
+ }
@@ -1,16 +1,16 @@
1
- export * from './CircleSegment';
2
- export * from './CubicBezierSegment';
3
- export * from './CurveDrawingInfo';
4
- export * from './CurvePoint';
5
- export * from './CurveProfile';
6
- export * from './getBezierSplineProfile';
7
- export * from './getCircleProfile';
8
- export * from './getPointAtDistance';
9
- export * from './getPolylineProfile';
10
- export * from './getRectProfile';
11
- export * from './KnotInfo';
12
- export * from './LineSegment';
13
- export * from './Polynomial';
14
- export * from './Polynomial2D';
15
- export * from './QuadBezierSegment';
16
- export * from './Segment';
1
+ export * from './CircleSegment';
2
+ export * from './CubicBezierSegment';
3
+ export * from './CurveDrawingInfo';
4
+ export * from './CurvePoint';
5
+ export * from './CurveProfile';
6
+ export * from './getBezierSplineProfile';
7
+ export * from './getCircleProfile';
8
+ export * from './getPointAtDistance';
9
+ export * from './getPolylineProfile';
10
+ export * from './getRectProfile';
11
+ export * from './KnotInfo';
12
+ export * from './LineSegment';
13
+ export * from './Polynomial';
14
+ export * from './Polynomial2D';
15
+ export * from './QuadBezierSegment';
16
+ export * from './Segment';
@@ -1,16 +1,16 @@
1
- import type {Signal} from '@twick/core';
2
- import {Color} from '@twick/core';
3
- import type {CanvasStyle, PossibleCanvasStyle} from '../partials';
4
- import {canvasStyleParser} from '../utils';
5
- import {initial, interpolation, parser, signal} from './signal';
6
-
7
- export type CanvasStyleSignal<T> = Signal<PossibleCanvasStyle, CanvasStyle, T>;
8
-
9
- export function canvasStyleSignal(): PropertyDecorator {
10
- return (target, key) => {
11
- signal()(target, key);
12
- parser(canvasStyleParser)(target, key);
13
- interpolation(Color.lerp)(target, key);
14
- initial(null)(target, key);
15
- };
16
- }
1
+ import type {Signal} from '@twick/core';
2
+ import {Color} from '@twick/core';
3
+ import type {CanvasStyle, PossibleCanvasStyle} from '../partials';
4
+ import {canvasStyleParser} from '../utils';
5
+ import {initial, interpolation, parser, signal} from './signal';
6
+
7
+ export type CanvasStyleSignal<T> = Signal<PossibleCanvasStyle, CanvasStyle, T>;
8
+
9
+ export function canvasStyleSignal(): PropertyDecorator {
10
+ return (target, key) => {
11
+ signal()(target, key);
12
+ parser(canvasStyleParser)(target, key);
13
+ interpolation(Color.lerp)(target, key);
14
+ initial(null)(target, key);
15
+ };
16
+ }
@@ -1,9 +1,9 @@
1
- import {Color} from '@twick/core';
2
- import {signal, wrapper} from './signal';
3
-
4
- export function colorSignal(): PropertyDecorator {
5
- return (target, key) => {
6
- signal()(target, key);
7
- wrapper(Color)(target, key);
8
- };
9
- }
1
+ import {Color} from '@twick/core';
2
+ import {signal, wrapper} from './signal';
3
+
4
+ export function colorSignal(): PropertyDecorator {
5
+ return (target, key) => {
6
+ signal()(target, key);
7
+ wrapper(Color)(target, key);
8
+ };
9
+ }
@@ -1,72 +1,72 @@
1
- import {
2
- CompoundSignalContext,
3
- SignalContext,
4
- deepLerp,
5
- map,
6
- modify,
7
- useLogger,
8
- } from '@twick/core';
9
- import {makeSignalExtensions} from '../utils/makeSignalExtensions';
10
- import {addInitializer} from './initializers';
11
- import {getPropertyMetaOrCreate} from './signal';
12
-
13
- /**
14
- * Create a compound property decorator.
15
- *
16
- * @remarks
17
- * This decorator turns a given property into a signal consisting of one or more
18
- * nested signals.
19
- *
20
- * @example
21
- * ```ts
22
- * class Example {
23
- * \@compound({x: 'scaleX', y: 'scaleY'})
24
- * public declare readonly scale: Signal<Vector2, this>;
25
- *
26
- * public setScale() {
27
- * this.scale({x: 7, y: 3});
28
- * // same as:
29
- * this.scale.x(7).scale.y(3);
30
- * }
31
- * }
32
- * ```
33
- *
34
- * @param entries - A record mapping the property in the compound object to the
35
- * corresponding property on the owner node.
36
- */
37
- export function compound(entries: Record<string, string>): PropertyDecorator {
38
- return (target, key) => {
39
- const meta = getPropertyMetaOrCreate<any>(target, key);
40
- meta.compound = true;
41
- meta.compoundEntries = Object.entries(entries);
42
-
43
- addInitializer(target, (instance: any) => {
44
- if (!meta.parser) {
45
- useLogger().error(`Missing parser decorator for "${key.toString()}"`);
46
- return;
47
- }
48
-
49
- const initial = meta.default;
50
- const parser = meta.parser.bind(instance);
51
- const signalContext = new CompoundSignalContext(
52
- meta.compoundEntries.map(([key, property]) => {
53
- const signal = new SignalContext(
54
- modify(initial, value => parser(value)[key]),
55
- <any>map,
56
- instance,
57
- undefined,
58
- makeSignalExtensions(undefined, instance, property),
59
- ).toSignal();
60
- return [key, signal];
61
- }),
62
- parser,
63
- initial,
64
- meta.interpolationFunction ?? deepLerp,
65
- instance,
66
- makeSignalExtensions(meta, instance, <string>key),
67
- );
68
-
69
- instance[key] = signalContext.toSignal();
70
- });
71
- };
72
- }
1
+ import {
2
+ CompoundSignalContext,
3
+ SignalContext,
4
+ deepLerp,
5
+ map,
6
+ modify,
7
+ useLogger,
8
+ } from '@twick/core';
9
+ import {makeSignalExtensions} from '../utils/makeSignalExtensions';
10
+ import {addInitializer} from './initializers';
11
+ import {getPropertyMetaOrCreate} from './signal';
12
+
13
+ /**
14
+ * Create a compound property decorator.
15
+ *
16
+ * @remarks
17
+ * This decorator turns a given property into a signal consisting of one or more
18
+ * nested signals.
19
+ *
20
+ * @example
21
+ * ```ts
22
+ * class Example {
23
+ * \@compound({x: 'scaleX', y: 'scaleY'})
24
+ * public declare readonly scale: Signal<Vector2, this>;
25
+ *
26
+ * public setScale() {
27
+ * this.scale({x: 7, y: 3});
28
+ * // same as:
29
+ * this.scale.x(7).scale.y(3);
30
+ * }
31
+ * }
32
+ * ```
33
+ *
34
+ * @param entries - A record mapping the property in the compound object to the
35
+ * corresponding property on the owner node.
36
+ */
37
+ export function compound(entries: Record<string, string>): PropertyDecorator {
38
+ return (target, key) => {
39
+ const meta = getPropertyMetaOrCreate<any>(target, key);
40
+ meta.compound = true;
41
+ meta.compoundEntries = Object.entries(entries);
42
+
43
+ addInitializer(target, (instance: any) => {
44
+ if (!meta.parser) {
45
+ useLogger().error(`Missing parser decorator for "${key.toString()}"`);
46
+ return;
47
+ }
48
+
49
+ const initial = meta.default;
50
+ const parser = meta.parser.bind(instance);
51
+ const signalContext = new CompoundSignalContext(
52
+ meta.compoundEntries.map(([key, property]) => {
53
+ const signal = new SignalContext(
54
+ modify(initial, value => parser(value)[key]),
55
+ <any>map,
56
+ instance,
57
+ undefined,
58
+ makeSignalExtensions(undefined, instance, property),
59
+ ).toSignal();
60
+ return [key, signal];
61
+ }),
62
+ parser,
63
+ initial,
64
+ meta.interpolationFunction ?? deepLerp,
65
+ instance,
66
+ makeSignalExtensions(meta, instance, <string>key),
67
+ );
68
+
69
+ instance[key] = signalContext.toSignal();
70
+ });
71
+ };
72
+ }
@@ -1,18 +1,18 @@
1
- import {createComputed} from '@twick/core';
2
- import {addInitializer} from './initializers';
3
-
4
- /**
5
- * Create a computed method decorator.
6
- *
7
- * @remarks
8
- * This decorator turns the given method into a computed value.
9
- * See {@link createComputed} for more information.
10
- */
11
- export function computed(): MethodDecorator {
12
- return (target: any, key) => {
13
- addInitializer(target, (instance: any) => {
14
- const method = Object.getPrototypeOf(instance)[key];
15
- instance[key] = createComputed(method.bind(instance), instance);
16
- });
17
- };
18
- }
1
+ import {createComputed} from '@twick/core';
2
+ import {addInitializer} from './initializers';
3
+
4
+ /**
5
+ * Create a computed method decorator.
6
+ *
7
+ * @remarks
8
+ * This decorator turns the given method into a computed value.
9
+ * See {@link createComputed} for more information.
10
+ */
11
+ export function computed(): MethodDecorator {
12
+ return (target: any, key) => {
13
+ addInitializer(target, (instance: any) => {
14
+ const method = Object.getPrototypeOf(instance)[key];
15
+ instance[key] = createComputed(method.bind(instance), instance);
16
+ });
17
+ };
18
+ }
@@ -1,18 +1,18 @@
1
- import {capitalize} from '@twick/core';
2
- import type {Layout} from '../components';
3
-
4
- export function defaultStyle<T>(
5
- styleName: string,
6
- parse: (value: string) => T = value => value as T,
7
- ): PropertyDecorator {
8
- return (target: any, key) => {
9
- target[`getDefault${capitalize(<string>key)}`] = function (this: Layout) {
10
- this.requestLayoutUpdate();
11
- const old = (<any>this.element.style)[styleName];
12
- (<any>this.element.style)[styleName] = '';
13
- const ret = parse.call(this, this.styles.getPropertyValue(styleName));
14
- (<any>this.element.style)[styleName] = old;
15
- return ret;
16
- };
17
- };
18
- }
1
+ import {capitalize} from '@twick/core';
2
+ import type {Layout} from '../components';
3
+
4
+ export function defaultStyle<T>(
5
+ styleName: string,
6
+ parse: (value: string) => T = value => value as T,
7
+ ): PropertyDecorator {
8
+ return (target: any, key) => {
9
+ target[`getDefault${capitalize(<string>key)}`] = function (this: Layout) {
10
+ this.requestLayoutUpdate();
11
+ const old = (<any>this.element.style)[styleName];
12
+ (<any>this.element.style)[styleName] = '';
13
+ const ret = parse.call(this, this.styles.getPropertyValue(styleName));
14
+ (<any>this.element.style)[styleName] = old;
15
+ return ret;
16
+ };
17
+ };
18
+ }