@twick/2d 0.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/editor/editor/NodeInspectorConfig.d.ts +3 -0
- package/editor/editor/NodeInspectorConfig.d.ts.map +1 -0
- package/editor/editor/PreviewOverlayConfig.d.ts +3 -0
- package/editor/editor/PreviewOverlayConfig.d.ts.map +1 -0
- package/editor/editor/Provider.d.ts +17 -0
- package/editor/editor/Provider.d.ts.map +1 -0
- package/editor/editor/SceneGraphTabConfig.d.ts +3 -0
- package/editor/editor/SceneGraphTabConfig.d.ts.map +1 -0
- package/editor/editor/icons/CircleIcon.d.ts +2 -0
- package/editor/editor/icons/CircleIcon.d.ts.map +1 -0
- package/editor/editor/icons/CodeBlockIcon.d.ts +2 -0
- package/editor/editor/icons/CodeBlockIcon.d.ts.map +1 -0
- package/editor/editor/icons/CurveIcon.d.ts +2 -0
- package/editor/editor/icons/CurveIcon.d.ts.map +1 -0
- package/editor/editor/icons/GridIcon.d.ts +2 -0
- package/editor/editor/icons/GridIcon.d.ts.map +1 -0
- package/editor/editor/icons/IconMap.d.ts +3 -0
- package/editor/editor/icons/IconMap.d.ts.map +1 -0
- package/editor/editor/icons/ImgIcon.d.ts +2 -0
- package/editor/editor/icons/ImgIcon.d.ts.map +1 -0
- package/editor/editor/icons/LayoutIcon.d.ts +2 -0
- package/editor/editor/icons/LayoutIcon.d.ts.map +1 -0
- package/editor/editor/icons/LineIcon.d.ts +2 -0
- package/editor/editor/icons/LineIcon.d.ts.map +1 -0
- package/editor/editor/icons/NodeIcon.d.ts +2 -0
- package/editor/editor/icons/NodeIcon.d.ts.map +1 -0
- package/editor/editor/icons/RayIcon.d.ts +2 -0
- package/editor/editor/icons/RayIcon.d.ts.map +1 -0
- package/editor/editor/icons/RectIcon.d.ts +2 -0
- package/editor/editor/icons/RectIcon.d.ts.map +1 -0
- package/editor/editor/icons/ShapeIcon.d.ts +2 -0
- package/editor/editor/icons/ShapeIcon.d.ts.map +1 -0
- package/editor/editor/icons/TxtIcon.d.ts +2 -0
- package/editor/editor/icons/TxtIcon.d.ts.map +1 -0
- package/editor/editor/icons/VideoIcon.d.ts +2 -0
- package/editor/editor/icons/VideoIcon.d.ts.map +1 -0
- package/editor/editor/icons/View2DIcon.d.ts +2 -0
- package/editor/editor/icons/View2DIcon.d.ts.map +1 -0
- package/editor/editor/index.d.ts +4 -0
- package/editor/editor/index.d.ts.map +1 -0
- package/editor/editor/tree/DetachedRoot.d.ts +2 -0
- package/editor/editor/tree/DetachedRoot.d.ts.map +1 -0
- package/editor/editor/tree/NodeElement.d.ts +8 -0
- package/editor/editor/tree/NodeElement.d.ts.map +1 -0
- package/editor/editor/tree/TreeElement.d.ts +15 -0
- package/editor/editor/tree/TreeElement.d.ts.map +1 -0
- package/editor/editor/tree/TreeRoot.d.ts +3 -0
- package/editor/editor/tree/TreeRoot.d.ts.map +1 -0
- package/editor/editor/tree/ViewRoot.d.ts +2 -0
- package/editor/editor/tree/ViewRoot.d.ts.map +1 -0
- package/editor/editor/tree/index.d.ts +4 -0
- package/editor/editor/tree/index.d.ts.map +1 -0
- package/editor/editor/tsconfig.build.tsbuildinfo +1 -0
- package/editor/index.css +33 -0
- package/editor/index.js +341 -0
- package/editor/index.js.map +1 -0
- package/lib/code/CodeCursor.d.ts +83 -0
- package/lib/code/CodeCursor.d.ts.map +1 -0
- package/lib/code/CodeCursor.js +306 -0
- package/lib/code/CodeDiffer.d.ts +28 -0
- package/lib/code/CodeDiffer.d.ts.map +1 -0
- package/lib/code/CodeDiffer.js +51 -0
- package/lib/code/CodeFragment.d.ts +42 -0
- package/lib/code/CodeFragment.d.ts.map +1 -0
- package/lib/code/CodeFragment.js +72 -0
- package/lib/code/CodeHighlighter.d.ts +71 -0
- package/lib/code/CodeHighlighter.d.ts.map +1 -0
- package/lib/code/CodeHighlighter.js +2 -0
- package/lib/code/CodeMetrics.d.ts +11 -0
- package/lib/code/CodeMetrics.d.ts.map +1 -0
- package/lib/code/CodeMetrics.js +29 -0
- package/lib/code/CodeRange.d.ts +41 -0
- package/lib/code/CodeRange.d.ts.map +1 -0
- package/lib/code/CodeRange.js +179 -0
- package/lib/code/CodeScope.d.ts +16 -0
- package/lib/code/CodeScope.d.ts.map +1 -0
- package/lib/code/CodeScope.js +72 -0
- package/lib/code/CodeSelection.d.ts +6 -0
- package/lib/code/CodeSelection.d.ts.map +1 -0
- package/lib/code/CodeSelection.js +13 -0
- package/lib/code/CodeSignal.d.ts +60 -0
- package/lib/code/CodeSignal.d.ts.map +1 -0
- package/lib/code/CodeSignal.js +194 -0
- package/lib/code/CodeTokenizer.d.ts +8 -0
- package/lib/code/CodeTokenizer.d.ts.map +1 -0
- package/lib/code/CodeTokenizer.js +50 -0
- package/lib/code/DefaultHighlightStyle.d.ts +3 -0
- package/lib/code/DefaultHighlightStyle.d.ts.map +1 -0
- package/lib/code/DefaultHighlightStyle.js +98 -0
- package/lib/code/LezerHighlighter.d.ts +22 -0
- package/lib/code/LezerHighlighter.d.ts.map +1 -0
- package/lib/code/LezerHighlighter.js +89 -0
- package/lib/code/diff.d.ts +31 -0
- package/lib/code/diff.d.ts.map +1 -0
- package/lib/code/diff.js +236 -0
- package/lib/code/extractRange.d.ts +17 -0
- package/lib/code/extractRange.d.ts.map +1 -0
- package/lib/code/extractRange.js +102 -0
- package/lib/code/index.d.ts +14 -0
- package/lib/code/index.d.ts.map +1 -0
- package/lib/code/index.js +14 -0
- package/lib/components/Audio.d.ts +14 -0
- package/lib/components/Audio.d.ts.map +1 -0
- package/lib/components/Audio.js +118 -0
- package/lib/components/Bezier.d.ts +23 -0
- package/lib/components/Bezier.d.ts.map +1 -0
- package/lib/components/Bezier.js +81 -0
- package/lib/components/Circle.d.ts +193 -0
- package/lib/components/Circle.d.ts.map +1 -0
- package/lib/components/Circle.js +178 -0
- package/lib/components/Code.d.ts +231 -0
- package/lib/components/Code.d.ts.map +1 -0
- package/lib/components/Code.js +325 -0
- package/lib/components/CodeBlock.d.ts +133 -0
- package/lib/components/CodeBlock.d.ts.map +1 -0
- package/lib/components/CodeBlock.js +461 -0
- package/lib/components/CubicBezier.d.ts +70 -0
- package/lib/components/CubicBezier.d.ts.map +1 -0
- package/lib/components/CubicBezier.js +81 -0
- package/lib/components/Curve.d.ts +204 -0
- package/lib/components/Curve.d.ts.map +1 -0
- package/lib/components/Curve.js +284 -0
- package/lib/components/Grid.d.ts +76 -0
- package/lib/components/Grid.d.ts.map +1 -0
- package/lib/components/Grid.js +91 -0
- package/lib/components/Icon.d.ts +59 -0
- package/lib/components/Icon.d.ts.map +1 -0
- package/lib/components/Icon.js +58 -0
- package/lib/components/Img.d.ts +118 -0
- package/lib/components/Img.d.ts.map +1 -0
- package/lib/components/Img.js +245 -0
- package/lib/components/Knot.d.ts +90 -0
- package/lib/components/Knot.d.ts.map +1 -0
- package/lib/components/Knot.js +68 -0
- package/lib/components/Latex.d.ts +39 -0
- package/lib/components/Latex.d.ts.map +1 -0
- package/lib/components/Latex.js +101 -0
- package/lib/components/Layout.d.ts +419 -0
- package/lib/components/Layout.d.ts.map +1 -0
- package/lib/components/Layout.js +706 -0
- package/lib/components/Line.d.ts +160 -0
- package/lib/components/Line.d.ts.map +1 -0
- package/lib/components/Line.js +346 -0
- package/lib/components/Media.d.ts +65 -0
- package/lib/components/Media.d.ts.map +1 -0
- package/lib/components/Media.js +303 -0
- package/lib/components/Node.d.ts +836 -0
- package/lib/components/Node.d.ts.map +1 -0
- package/lib/components/Node.js +1317 -0
- package/lib/components/Path.d.ts +20 -0
- package/lib/components/Path.d.ts.map +1 -0
- package/lib/components/Path.js +97 -0
- package/lib/components/Polygon.d.ts +113 -0
- package/lib/components/Polygon.d.ts.map +1 -0
- package/lib/components/Polygon.js +123 -0
- package/lib/components/QuadBezier.d.ts +62 -0
- package/lib/components/QuadBezier.d.ts.map +1 -0
- package/lib/components/QuadBezier.js +76 -0
- package/lib/components/Ray.d.ts +62 -0
- package/lib/components/Ray.d.ts.map +1 -0
- package/lib/components/Ray.js +96 -0
- package/lib/components/Rect.d.ts +114 -0
- package/lib/components/Rect.d.ts.map +1 -0
- package/lib/components/Rect.js +76 -0
- package/lib/components/Rive.d.ts +22 -0
- package/lib/components/Rive.d.ts.map +1 -0
- package/lib/components/Rive.js +117 -0
- package/lib/components/SVG.d.ts +178 -0
- package/lib/components/SVG.d.ts.map +1 -0
- package/lib/components/SVG.js +577 -0
- package/lib/components/Shape.d.ts +40 -0
- package/lib/components/Shape.d.ts.map +1 -0
- package/lib/components/Shape.js +134 -0
- package/lib/components/Spline.d.ts +89 -0
- package/lib/components/Spline.d.ts.map +1 -0
- package/lib/components/Spline.js +256 -0
- package/lib/components/Txt.d.ts +53 -0
- package/lib/components/Txt.d.ts.map +1 -0
- package/lib/components/Txt.js +173 -0
- package/lib/components/TxtLeaf.d.ts +21 -0
- package/lib/components/TxtLeaf.d.ts.map +1 -0
- package/lib/components/TxtLeaf.js +181 -0
- package/lib/components/Video.d.ts +69 -0
- package/lib/components/Video.d.ts.map +1 -0
- package/lib/components/Video.js +283 -0
- package/lib/components/View2D.d.ts +28 -0
- package/lib/components/View2D.d.ts.map +1 -0
- package/lib/components/View2D.js +93 -0
- package/lib/components/index.d.ts +29 -0
- package/lib/components/index.d.ts.map +1 -0
- package/lib/components/index.js +29 -0
- package/lib/components/types.d.ts +17 -0
- package/lib/components/types.d.ts.map +1 -0
- package/lib/components/types.js +2 -0
- package/lib/curves/ArcSegment.d.ts +26 -0
- package/lib/curves/ArcSegment.d.ts.map +1 -0
- package/lib/curves/ArcSegment.js +97 -0
- package/lib/curves/CircleSegment.d.ts +18 -0
- package/lib/curves/CircleSegment.d.ts.map +1 -0
- package/lib/curves/CircleSegment.js +52 -0
- package/lib/curves/CubicBezierSegment.d.ts +18 -0
- package/lib/curves/CubicBezierSegment.d.ts.map +1 -0
- package/lib/curves/CubicBezierSegment.js +55 -0
- package/lib/curves/CurveDrawingInfo.d.ts +11 -0
- package/lib/curves/CurveDrawingInfo.d.ts.map +1 -0
- package/lib/curves/CurveDrawingInfo.js +2 -0
- package/lib/curves/CurvePoint.d.ts +15 -0
- package/lib/curves/CurvePoint.d.ts.map +1 -0
- package/lib/curves/CurvePoint.js +2 -0
- package/lib/curves/CurveProfile.d.ts +7 -0
- package/lib/curves/CurveProfile.d.ts.map +1 -0
- package/lib/curves/CurveProfile.js +2 -0
- package/lib/curves/KnotInfo.d.ts +12 -0
- package/lib/curves/KnotInfo.d.ts.map +1 -0
- package/lib/curves/KnotInfo.js +2 -0
- package/lib/curves/LineSegment.d.ts +16 -0
- package/lib/curves/LineSegment.d.ts.map +1 -0
- package/lib/curves/LineSegment.js +45 -0
- package/lib/curves/Polynomial.d.ts +118 -0
- package/lib/curves/Polynomial.d.ts.map +1 -0
- package/lib/curves/Polynomial.js +259 -0
- package/lib/curves/Polynomial2D.d.ts +22 -0
- package/lib/curves/Polynomial2D.d.ts.map +1 -0
- package/lib/curves/Polynomial2D.js +45 -0
- package/lib/curves/PolynomialSegment.d.ts +39 -0
- package/lib/curves/PolynomialSegment.d.ts.map +1 -0
- package/lib/curves/PolynomialSegment.js +86 -0
- package/lib/curves/QuadBezierSegment.d.ts +17 -0
- package/lib/curves/QuadBezierSegment.d.ts.map +1 -0
- package/lib/curves/QuadBezierSegment.js +49 -0
- package/lib/curves/Segment.d.ts +9 -0
- package/lib/curves/Segment.d.ts.map +1 -0
- package/lib/curves/Segment.js +3 -0
- package/lib/curves/UniformPolynomialCurveSampler.d.ts +43 -0
- package/lib/curves/UniformPolynomialCurveSampler.d.ts.map +1 -0
- package/lib/curves/UniformPolynomialCurveSampler.js +73 -0
- package/lib/curves/createCurveProfileLerp.d.ts +32 -0
- package/lib/curves/createCurveProfileLerp.d.ts.map +1 -0
- package/lib/curves/createCurveProfileLerp.js +351 -0
- package/lib/curves/getBezierSplineProfile.d.ts +12 -0
- package/lib/curves/getBezierSplineProfile.d.ts.map +1 -0
- package/lib/curves/getBezierSplineProfile.js +137 -0
- package/lib/curves/getCircleProfile.d.ts +4 -0
- package/lib/curves/getCircleProfile.d.ts.map +1 -0
- package/lib/curves/getCircleProfile.js +44 -0
- package/lib/curves/getPathProfile.d.ts +3 -0
- package/lib/curves/getPathProfile.d.ts.map +1 -0
- package/lib/curves/getPathProfile.js +128 -0
- package/lib/curves/getPointAtDistance.d.ts +4 -0
- package/lib/curves/getPointAtDistance.d.ts.map +1 -0
- package/lib/curves/getPointAtDistance.js +15 -0
- package/lib/curves/getPolylineProfile.d.ts +4 -0
- package/lib/curves/getPolylineProfile.d.ts.map +1 -0
- package/lib/curves/getPolylineProfile.js +58 -0
- package/lib/curves/getRectProfile.d.ts +4 -0
- package/lib/curves/getRectProfile.d.ts.map +1 -0
- package/lib/curves/getRectProfile.js +57 -0
- package/lib/curves/index.d.ts +17 -0
- package/lib/curves/index.d.ts.map +1 -0
- package/lib/curves/index.js +17 -0
- package/lib/decorators/canvasStyleSignal.d.ts +5 -0
- package/lib/decorators/canvasStyleSignal.d.ts.map +1 -0
- package/lib/decorators/canvasStyleSignal.js +12 -0
- package/lib/decorators/colorSignal.d.ts +2 -0
- package/lib/decorators/colorSignal.d.ts.map +1 -0
- package/lib/decorators/colorSignal.js +9 -0
- package/lib/decorators/compound.d.ts +26 -0
- package/lib/decorators/compound.d.ts.map +1 -0
- package/lib/decorators/compound.js +49 -0
- package/lib/decorators/computed.d.ts +9 -0
- package/lib/decorators/computed.d.ts.map +1 -0
- package/lib/decorators/computed.js +18 -0
- package/lib/decorators/defaultStyle.d.ts +2 -0
- package/lib/decorators/defaultStyle.d.ts.map +1 -0
- package/lib/decorators/defaultStyle.js +14 -0
- package/lib/decorators/filtersSignal.d.ts +13 -0
- package/lib/decorators/filtersSignal.d.ts.map +1 -0
- package/lib/decorators/filtersSignal.js +73 -0
- package/lib/decorators/index.d.ts +11 -0
- package/lib/decorators/index.d.ts.map +1 -0
- package/lib/decorators/index.js +11 -0
- package/lib/decorators/initializers.d.ts +4 -0
- package/lib/decorators/initializers.d.ts.map +1 -0
- package/lib/decorators/initializers.js +27 -0
- package/lib/decorators/nodeName.d.ts +9 -0
- package/lib/decorators/nodeName.d.ts.map +1 -0
- package/lib/decorators/nodeName.js +13 -0
- package/lib/decorators/signal.d.ts +183 -0
- package/lib/decorators/signal.d.ts.map +1 -0
- package/lib/decorators/signal.js +285 -0
- package/lib/decorators/spacingSignal.d.ts +2 -0
- package/lib/decorators/spacingSignal.d.ts.map +1 -0
- package/lib/decorators/spacingSignal.js +15 -0
- package/lib/decorators/vector2Signal.d.ts +9 -0
- package/lib/decorators/vector2Signal.d.ts.map +1 -0
- package/lib/decorators/vector2Signal.js +15 -0
- package/lib/index.d.ts +9 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +9 -0
- package/lib/jsx-dev-runtime.d.ts +3 -0
- package/lib/jsx-dev-runtime.d.ts.map +1 -0
- package/lib/jsx-dev-runtime.js +3 -0
- package/lib/jsx-runtime.d.ts +12 -0
- package/lib/jsx-runtime.d.ts.map +1 -0
- package/lib/jsx-runtime.js +23 -0
- package/lib/partials/Filter.d.ts +82 -0
- package/lib/partials/Filter.d.ts.map +1 -0
- package/lib/partials/Filter.js +135 -0
- package/lib/partials/Gradient.d.ts +31 -0
- package/lib/partials/Gradient.d.ts.map +1 -0
- package/lib/partials/Gradient.js +63 -0
- package/lib/partials/Pattern.d.ts +13 -0
- package/lib/partials/Pattern.d.ts.map +1 -0
- package/lib/partials/Pattern.js +27 -0
- package/lib/partials/ShaderConfig.d.ts +81 -0
- package/lib/partials/ShaderConfig.d.ts.map +1 -0
- package/lib/partials/ShaderConfig.js +25 -0
- package/lib/partials/index.d.ts +5 -0
- package/lib/partials/index.d.ts.map +1 -0
- package/lib/partials/index.js +5 -0
- package/lib/partials/types.d.ts +35 -0
- package/lib/partials/types.d.ts.map +1 -0
- package/lib/partials/types.js +2 -0
- package/lib/scenes/Scene2D.d.ts +29 -0
- package/lib/scenes/Scene2D.d.ts.map +1 -0
- package/lib/scenes/Scene2D.js +180 -0
- package/lib/scenes/index.d.ts +4 -0
- package/lib/scenes/index.d.ts.map +1 -0
- package/lib/scenes/index.js +4 -0
- package/lib/scenes/makeScene2D.d.ts +5 -0
- package/lib/scenes/makeScene2D.d.ts.map +1 -0
- package/lib/scenes/makeScene2D.js +11 -0
- package/lib/scenes/useScene2D.d.ts +3 -0
- package/lib/scenes/useScene2D.d.ts.map +1 -0
- package/lib/scenes/useScene2D.js +5 -0
- package/lib/tsconfig.build.tsbuildinfo +1 -0
- package/lib/utils/CanvasUtils.d.ts +23 -0
- package/lib/utils/CanvasUtils.d.ts.map +1 -0
- package/lib/utils/CanvasUtils.js +138 -0
- package/lib/utils/diff.d.ts +31 -0
- package/lib/utils/diff.d.ts.map +1 -0
- package/lib/utils/diff.js +97 -0
- package/lib/utils/index.d.ts +3 -0
- package/lib/utils/index.d.ts.map +1 -0
- package/lib/utils/index.js +3 -0
- package/lib/utils/is.d.ts +8 -0
- package/lib/utils/is.d.ts.map +1 -0
- package/lib/utils/is.js +10 -0
- package/lib/utils/makeSignalExtensions.d.ts +4 -0
- package/lib/utils/makeSignalExtensions.d.ts.map +1 -0
- package/lib/utils/makeSignalExtensions.js +20 -0
- package/lib/utils/video/ffmpeg-client.d.ts +5 -0
- package/lib/utils/video/ffmpeg-client.d.ts.map +1 -0
- package/lib/utils/video/ffmpeg-client.js +32 -0
- package/lib/utils/video/mp4-parser-manager.d.ts +3 -0
- package/lib/utils/video/mp4-parser-manager.d.ts.map +1 -0
- package/lib/utils/video/mp4-parser-manager.js +55 -0
- package/lib/utils/video/parser/index.d.ts +2 -0
- package/lib/utils/video/parser/index.d.ts.map +1 -0
- package/lib/utils/video/parser/index.js +2 -0
- package/lib/utils/video/parser/parser.d.ts +21 -0
- package/lib/utils/video/parser/parser.d.ts.map +1 -0
- package/lib/utils/video/parser/parser.js +168 -0
- package/lib/utils/video/parser/sampler.d.ts +16 -0
- package/lib/utils/video/parser/sampler.d.ts.map +1 -0
- package/lib/utils/video/parser/sampler.js +56 -0
- package/lib/utils/video/parser/segment.d.ts +48 -0
- package/lib/utils/video/parser/segment.d.ts.map +1 -0
- package/lib/utils/video/parser/segment.js +239 -0
- package/lib/utils/video/parser/sink.d.ts +9 -0
- package/lib/utils/video/parser/sink.d.ts.map +1 -0
- package/lib/utils/video/parser/sink.js +22 -0
- package/lib/utils/video/parser/utils.d.ts +10 -0
- package/lib/utils/video/parser/utils.d.ts.map +1 -0
- package/lib/utils/video/parser/utils.js +22 -0
- package/package.json +53 -0
- package/src/editor/NodeInspectorConfig.tsx +76 -0
- package/src/editor/PreviewOverlayConfig.tsx +67 -0
- package/src/editor/Provider.tsx +93 -0
- package/src/editor/SceneGraphTabConfig.tsx +81 -0
- package/src/editor/icons/CircleIcon.tsx +7 -0
- package/src/editor/icons/CodeBlockIcon.tsx +8 -0
- package/src/editor/icons/CurveIcon.tsx +7 -0
- package/src/editor/icons/GridIcon.tsx +7 -0
- package/src/editor/icons/IconMap.ts +35 -0
- package/src/editor/icons/ImgIcon.tsx +8 -0
- package/src/editor/icons/LayoutIcon.tsx +9 -0
- package/src/editor/icons/LineIcon.tsx +7 -0
- package/src/editor/icons/NodeIcon.tsx +7 -0
- package/src/editor/icons/RayIcon.tsx +7 -0
- package/src/editor/icons/RectIcon.tsx +7 -0
- package/src/editor/icons/ShapeIcon.tsx +7 -0
- package/src/editor/icons/TxtIcon.tsx +8 -0
- package/src/editor/icons/VideoIcon.tsx +7 -0
- package/src/editor/icons/View2DIcon.tsx +10 -0
- package/src/editor/index.css +0 -0
- package/src/editor/index.ts +17 -0
- package/src/editor/tree/DetachedRoot.tsx +23 -0
- package/src/editor/tree/NodeElement.tsx +74 -0
- package/src/editor/tree/TreeElement.tsx +72 -0
- package/src/editor/tree/TreeRoot.tsx +10 -0
- package/src/editor/tree/ViewRoot.tsx +20 -0
- package/src/editor/tree/index.module.scss +38 -0
- package/src/editor/tree/index.ts +3 -0
- package/src/editor/tsconfig.build.json +5 -0
- package/src/editor/tsconfig.json +12 -0
- package/src/editor/tsdoc.json +4 -0
- package/src/editor/vite-env.d.ts +1 -0
- package/src/lib/code/CodeCursor.ts +445 -0
- package/src/lib/code/CodeDiffer.ts +78 -0
- package/src/lib/code/CodeFragment.ts +97 -0
- package/src/lib/code/CodeHighlighter.ts +75 -0
- package/src/lib/code/CodeMetrics.ts +47 -0
- package/src/lib/code/CodeRange.test.ts +74 -0
- package/src/lib/code/CodeRange.ts +216 -0
- package/src/lib/code/CodeScope.ts +101 -0
- package/src/lib/code/CodeSelection.ts +24 -0
- package/src/lib/code/CodeSignal.ts +327 -0
- package/src/lib/code/CodeTokenizer.ts +54 -0
- package/src/lib/code/DefaultHighlightStyle.ts +98 -0
- package/src/lib/code/LezerHighlighter.ts +113 -0
- package/src/lib/code/diff.test.ts +311 -0
- package/src/lib/code/diff.ts +319 -0
- package/src/lib/code/extractRange.ts +126 -0
- package/src/lib/code/index.ts +13 -0
- package/src/lib/components/Audio.ts +131 -0
- package/src/lib/components/Bezier.ts +105 -0
- package/src/lib/components/Circle.ts +266 -0
- package/src/lib/components/Code.ts +526 -0
- package/src/lib/components/CodeBlock.ts +576 -0
- package/src/lib/components/CubicBezier.ts +112 -0
- package/src/lib/components/Curve.ts +455 -0
- package/src/lib/components/Grid.ts +135 -0
- package/src/lib/components/Icon.ts +96 -0
- package/src/lib/components/Img.ts +319 -0
- package/src/lib/components/Knot.ts +157 -0
- package/src/lib/components/Latex.ts +122 -0
- package/src/lib/components/Layout.ts +1092 -0
- package/src/lib/components/Line.ts +429 -0
- package/src/lib/components/Media.ts +379 -0
- package/src/lib/components/Node.ts +1940 -0
- package/src/lib/components/Path.ts +137 -0
- package/src/lib/components/Polygon.ts +171 -0
- package/src/lib/components/QuadBezier.ts +100 -0
- package/src/lib/components/Ray.ts +125 -0
- package/src/lib/components/Rect.ts +187 -0
- package/src/lib/components/Rive.ts +156 -0
- package/src/lib/components/SVG.ts +797 -0
- package/src/lib/components/Shape.ts +143 -0
- package/src/lib/components/Spline.ts +344 -0
- package/src/lib/components/Txt.test.tsx +81 -0
- package/src/lib/components/Txt.ts +203 -0
- package/src/lib/components/TxtLeaf.ts +205 -0
- package/src/lib/components/Video.ts +397 -0
- package/src/lib/components/View2D.ts +98 -0
- package/src/lib/components/__tests__/children.test.tsx +142 -0
- package/src/lib/components/__tests__/clone.test.tsx +126 -0
- package/src/lib/components/__tests__/generatorTest.ts +28 -0
- package/src/lib/components/__tests__/mockScene2D.ts +45 -0
- package/src/lib/components/__tests__/query.test.tsx +122 -0
- package/src/lib/components/__tests__/state.test.tsx +60 -0
- package/src/lib/components/index.ts +28 -0
- package/src/lib/components/types.ts +35 -0
- package/src/lib/curves/ArcSegment.ts +159 -0
- package/src/lib/curves/CircleSegment.ts +77 -0
- package/src/lib/curves/CubicBezierSegment.ts +78 -0
- package/src/lib/curves/CurveDrawingInfo.ts +11 -0
- package/src/lib/curves/CurvePoint.ts +15 -0
- package/src/lib/curves/CurveProfile.ts +7 -0
- package/src/lib/curves/KnotInfo.ts +10 -0
- package/src/lib/curves/LineSegment.ts +62 -0
- package/src/lib/curves/Polynomial.ts +355 -0
- package/src/lib/curves/Polynomial2D.ts +62 -0
- package/src/lib/curves/PolynomialSegment.ts +124 -0
- package/src/lib/curves/QuadBezierSegment.ts +64 -0
- package/src/lib/curves/Segment.ts +17 -0
- package/src/lib/curves/UniformPolynomialCurveSampler.ts +94 -0
- package/src/lib/curves/createCurveProfileLerp.ts +471 -0
- package/src/lib/curves/getBezierSplineProfile.ts +223 -0
- package/src/lib/curves/getCircleProfile.ts +86 -0
- package/src/lib/curves/getPathProfile.ts +178 -0
- package/src/lib/curves/getPointAtDistance.ts +21 -0
- package/src/lib/curves/getPolylineProfile.test.ts +21 -0
- package/src/lib/curves/getPolylineProfile.ts +89 -0
- package/src/lib/curves/getRectProfile.ts +139 -0
- package/src/lib/curves/index.ts +16 -0
- package/src/lib/decorators/canvasStyleSignal.ts +16 -0
- package/src/lib/decorators/colorSignal.ts +9 -0
- package/src/lib/decorators/compound.ts +72 -0
- package/src/lib/decorators/computed.ts +18 -0
- package/src/lib/decorators/defaultStyle.ts +18 -0
- package/src/lib/decorators/filtersSignal.ts +136 -0
- package/src/lib/decorators/index.ts +10 -0
- package/src/lib/decorators/initializers.ts +32 -0
- package/src/lib/decorators/nodeName.ts +13 -0
- package/src/lib/decorators/signal.test.ts +90 -0
- package/src/lib/decorators/signal.ts +345 -0
- package/src/lib/decorators/spacingSignal.ts +15 -0
- package/src/lib/decorators/vector2Signal.ts +30 -0
- package/src/lib/globals.d.ts +2 -0
- package/src/lib/index.ts +8 -0
- package/src/lib/jsx-dev-runtime.ts +2 -0
- package/src/lib/jsx-runtime.ts +46 -0
- package/src/lib/parse-svg-path.d.ts +14 -0
- package/src/lib/partials/Filter.ts +180 -0
- package/src/lib/partials/Gradient.ts +102 -0
- package/src/lib/partials/Pattern.ts +34 -0
- package/src/lib/partials/ShaderConfig.ts +117 -0
- package/src/lib/partials/index.ts +4 -0
- package/src/lib/partials/types.ts +58 -0
- package/src/lib/scenes/Scene2D.ts +242 -0
- package/src/lib/scenes/index.ts +3 -0
- package/src/lib/scenes/makeScene2D.ts +16 -0
- package/src/lib/scenes/useScene2D.ts +6 -0
- package/src/lib/tsconfig.build.json +5 -0
- package/src/lib/tsconfig.json +10 -0
- package/src/lib/tsdoc.json +4 -0
- package/src/lib/utils/CanvasUtils.ts +306 -0
- package/src/lib/utils/diff.test.ts +453 -0
- package/src/lib/utils/diff.ts +148 -0
- package/src/lib/utils/index.ts +2 -0
- package/src/lib/utils/is.ts +11 -0
- package/src/lib/utils/makeSignalExtensions.ts +30 -0
- package/src/lib/utils/video/declarations.d.ts +1 -0
- package/src/lib/utils/video/ffmpeg-client.ts +50 -0
- package/src/lib/utils/video/mp4-parser-manager.ts +72 -0
- package/src/lib/utils/video/parser/index.ts +1 -0
- package/src/lib/utils/video/parser/parser.ts +257 -0
- package/src/lib/utils/video/parser/sampler.ts +72 -0
- package/src/lib/utils/video/parser/segment.ts +302 -0
- package/src/lib/utils/video/parser/sink.ts +29 -0
- package/src/lib/utils/video/parser/utils.ts +31 -0
- package/src/tsconfig.base.json +19 -0
- package/src/tsconfig.build.json +8 -0
- package/src/tsconfig.json +5 -0
- package/tsconfig.project.json +7 -0
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { SignalValue, SimpleSignal } from '@twick/core';
|
|
2
|
+
import type { OptionList } from 'mathjax-full/js/util/Options';
|
|
3
|
+
import type { ImgProps } from './Img';
|
|
4
|
+
import { Img } from './Img';
|
|
5
|
+
export interface LatexProps extends ImgProps {
|
|
6
|
+
tex?: SignalValue<string>;
|
|
7
|
+
renderProps?: SignalValue<OptionList>;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* A node for rendering equations with LaTeX.
|
|
11
|
+
*
|
|
12
|
+
* @preview
|
|
13
|
+
* ```tsx editor
|
|
14
|
+
* import {Latex, makeScene2D} from '@twick/2d';
|
|
15
|
+
*
|
|
16
|
+
* export default makeScene2D(function* (view) {
|
|
17
|
+
* view.add(
|
|
18
|
+
* <Latex
|
|
19
|
+
* // Note how this uses \color to set the color.
|
|
20
|
+
* tex="{\color{white} ax^2+bx+c=0 \implies x=\frac{-b \pm \sqrt{b^2-4ac}}{2a}}"
|
|
21
|
+
* width={600} // height and width can calculate based on each other
|
|
22
|
+
* />,
|
|
23
|
+
* );
|
|
24
|
+
* });
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare class Latex extends Img {
|
|
28
|
+
private static svgContentsPool;
|
|
29
|
+
private static mathJaxInitialized;
|
|
30
|
+
private static adaptor;
|
|
31
|
+
private static jaxDocument;
|
|
32
|
+
private static initializeMathJax;
|
|
33
|
+
private readonly imageElement;
|
|
34
|
+
readonly options: SimpleSignal<OptionList, this>;
|
|
35
|
+
readonly tex: SimpleSignal<string, this>;
|
|
36
|
+
constructor(props: LatexProps);
|
|
37
|
+
protected image(): HTMLImageElement;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=Latex.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Latex.d.ts","sourceRoot":"","sources":["../../src/lib/components/Latex.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,WAAW,EAAE,YAAY,EAAC,MAAM,aAAa,CAAC;AAU3D,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,8BAA8B,CAAC;AAE7D,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,OAAO,CAAC;AACpC,OAAO,EAAC,GAAG,EAAC,MAAM,OAAO,CAAC;AAE1B,MAAM,WAAW,UAAW,SAAQ,QAAQ;IAC1C,GAAG,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC;CACvC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,qBAAa,KAAM,SAAQ,GAAG;IAC5B,OAAO,CAAC,MAAM,CAAC,eAAe,CAA8B;IAC5D,OAAO,CAAC,MAAM,CAAC,kBAAkB,CAAS;IAC1C,OAAO,CAAC,MAAM,CAAC,OAAO,CAAc;IACpC,OAAO,CAAC,MAAM,CAAC,WAAW,CAA0C;IAEpE,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAehC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAiC;IAE9D,SAEwB,OAAO,EAAE,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;IAEhE,SACwB,GAAG,EAAE,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;gBAErC,KAAK,EAAE,UAAU;cAKjB,KAAK,IAAI,gBAAgB;CAgD7C"}
|
|
@@ -0,0 +1,101 @@
|
|
|
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
|
+
import { DependencyContext, useLogger } from '@twick/core';
|
|
8
|
+
import { liteAdaptor } from 'mathjax-full/js/adaptors/liteAdaptor';
|
|
9
|
+
import { RegisterHTMLHandler } from 'mathjax-full/js/handlers/html';
|
|
10
|
+
import { TeX } from 'mathjax-full/js/input/tex';
|
|
11
|
+
import { AllPackages } from 'mathjax-full/js/input/tex/AllPackages';
|
|
12
|
+
import { mathjax } from 'mathjax-full/js/mathjax';
|
|
13
|
+
import { SVG } from 'mathjax-full/js/output/svg';
|
|
14
|
+
import { initial, signal } from '../decorators';
|
|
15
|
+
import { Img } from './Img';
|
|
16
|
+
/**
|
|
17
|
+
* A node for rendering equations with LaTeX.
|
|
18
|
+
*
|
|
19
|
+
* @preview
|
|
20
|
+
* ```tsx editor
|
|
21
|
+
* import {Latex, makeScene2D} from '@twick/2d';
|
|
22
|
+
*
|
|
23
|
+
* export default makeScene2D(function* (view) {
|
|
24
|
+
* view.add(
|
|
25
|
+
* <Latex
|
|
26
|
+
* // Note how this uses \color to set the color.
|
|
27
|
+
* tex="{\color{white} ax^2+bx+c=0 \implies x=\frac{-b \pm \sqrt{b^2-4ac}}{2a}}"
|
|
28
|
+
* width={600} // height and width can calculate based on each other
|
|
29
|
+
* />,
|
|
30
|
+
* );
|
|
31
|
+
* });
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
export class Latex extends Img {
|
|
35
|
+
static initializeMathJax() {
|
|
36
|
+
if (this.mathJaxInitialized) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
this.adaptor = liteAdaptor();
|
|
40
|
+
RegisterHTMLHandler(this.adaptor);
|
|
41
|
+
this.jaxDocument = mathjax.document('', {
|
|
42
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
43
|
+
InputJax: new TeX({ packages: AllPackages }),
|
|
44
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
45
|
+
OutputJax: new SVG({ fontCache: 'local' }),
|
|
46
|
+
});
|
|
47
|
+
this.mathJaxInitialized = true;
|
|
48
|
+
}
|
|
49
|
+
constructor(props) {
|
|
50
|
+
super({ ...props, src: null });
|
|
51
|
+
this.imageElement = document.createElement('img');
|
|
52
|
+
Latex.initializeMathJax();
|
|
53
|
+
}
|
|
54
|
+
image() {
|
|
55
|
+
// Render props may change the look of the TeX, so we need to cache both
|
|
56
|
+
// source and render props together.
|
|
57
|
+
const src = `${this.tex()}::${JSON.stringify(this.options())}`;
|
|
58
|
+
if (Latex.svgContentsPool[src]) {
|
|
59
|
+
this.imageElement.src = Latex.svgContentsPool[src];
|
|
60
|
+
if (!this.imageElement.complete) {
|
|
61
|
+
DependencyContext.collectPromise(new Promise((resolve, reject) => {
|
|
62
|
+
this.imageElement.addEventListener('load', resolve);
|
|
63
|
+
this.imageElement.addEventListener('error', reject);
|
|
64
|
+
}));
|
|
65
|
+
}
|
|
66
|
+
return this.imageElement;
|
|
67
|
+
}
|
|
68
|
+
// Convert to TeX, look for any errors
|
|
69
|
+
const tex = this.tex();
|
|
70
|
+
const svg = Latex.adaptor.innerHTML(Latex.jaxDocument.convert(tex, this.options()));
|
|
71
|
+
if (svg.includes('data-mjx-error')) {
|
|
72
|
+
const errors = svg.match(/data-mjx-error="(.*?)"/);
|
|
73
|
+
if (errors && errors.length > 0) {
|
|
74
|
+
useLogger().error(`Invalid MathJax: ${errors[1]}`);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
// Encode to raw base64 image format
|
|
78
|
+
const text = `data:image/svg+xml;base64,${btoa(`<?xml version="1.0" encoding="UTF-8" standalone="no" ?>\n${svg}`)}`;
|
|
79
|
+
Latex.svgContentsPool[src] = text;
|
|
80
|
+
const image = document.createElement('img');
|
|
81
|
+
image.src = text;
|
|
82
|
+
image.src = text;
|
|
83
|
+
if (!image.complete) {
|
|
84
|
+
DependencyContext.collectPromise(new Promise((resolve, reject) => {
|
|
85
|
+
image.addEventListener('load', resolve);
|
|
86
|
+
image.addEventListener('error', reject);
|
|
87
|
+
}));
|
|
88
|
+
}
|
|
89
|
+
return image;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
Latex.svgContentsPool = {};
|
|
93
|
+
Latex.mathJaxInitialized = false;
|
|
94
|
+
__decorate([
|
|
95
|
+
initial({}),
|
|
96
|
+
signal()
|
|
97
|
+
], Latex.prototype, "options", void 0);
|
|
98
|
+
__decorate([
|
|
99
|
+
signal()
|
|
100
|
+
], Latex.prototype, "tex", void 0);
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGF0ZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvTGF0ZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsT0FBTyxFQUFDLGlCQUFpQixFQUFFLFNBQVMsRUFBQyxNQUFNLGFBQWEsQ0FBQztBQUV6RCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFFakUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzlDLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUNsRSxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDaEQsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBRS9DLE9BQU8sRUFBQyxPQUFPLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTlDLE9BQU8sRUFBQyxHQUFHLEVBQUMsTUFBTSxPQUFPLENBQUM7QUFPMUI7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJHO0FBQ0gsTUFBTSxPQUFPLEtBQU0sU0FBUSxHQUFHO0lBTXBCLE1BQU0sQ0FBQyxpQkFBaUI7UUFDOUIsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztZQUM1QixPQUFPO1FBQ1QsQ0FBQztRQUNELElBQUksQ0FBQyxPQUFPLEdBQUcsV0FBVyxFQUFFLENBQUM7UUFDN0IsbUJBQW1CLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2xDLElBQUksQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUU7WUFDdEMsZ0VBQWdFO1lBQ2hFLFFBQVEsRUFBRSxJQUFJLEdBQUcsQ0FBQyxFQUFDLFFBQVEsRUFBRSxXQUFXLEVBQUMsQ0FBQztZQUMxQyxnRUFBZ0U7WUFDaEUs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
|
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
import type { InterpolationFunction, PossibleSpacing, PossibleVector2, SerializedVector2, Signal, SignalValue, SimpleSignal, SimpleVector2Signal, SpacingSignal, ThreadGenerator, TimingFunction, Vector2Signal } from '@twick/core';
|
|
2
|
+
import { BBox, Origin, Vector2 } from '@twick/core';
|
|
3
|
+
import type { Vector2LengthSignal } from '../decorators';
|
|
4
|
+
import type { DesiredLength, FlexBasis, FlexContent, FlexDirection, FlexItems, FlexWrap, LayoutMode, Length, LengthLimit, TextWrap } from '../partials';
|
|
5
|
+
import type { NodeProps } from './Node';
|
|
6
|
+
import { Node } from './Node';
|
|
7
|
+
export interface LayoutProps extends NodeProps {
|
|
8
|
+
layout?: LayoutMode;
|
|
9
|
+
tagName?: keyof HTMLElementTagNameMap;
|
|
10
|
+
width?: SignalValue<Length>;
|
|
11
|
+
height?: SignalValue<Length>;
|
|
12
|
+
maxWidth?: SignalValue<LengthLimit>;
|
|
13
|
+
maxHeight?: SignalValue<LengthLimit>;
|
|
14
|
+
minWidth?: SignalValue<LengthLimit>;
|
|
15
|
+
minHeight?: SignalValue<LengthLimit>;
|
|
16
|
+
ratio?: SignalValue<number>;
|
|
17
|
+
marginTop?: SignalValue<number>;
|
|
18
|
+
marginBottom?: SignalValue<number>;
|
|
19
|
+
marginLeft?: SignalValue<number>;
|
|
20
|
+
marginRight?: SignalValue<number>;
|
|
21
|
+
margin?: SignalValue<PossibleSpacing>;
|
|
22
|
+
paddingTop?: SignalValue<number>;
|
|
23
|
+
paddingBottom?: SignalValue<number>;
|
|
24
|
+
paddingLeft?: SignalValue<number>;
|
|
25
|
+
paddingRight?: SignalValue<number>;
|
|
26
|
+
padding?: SignalValue<PossibleSpacing>;
|
|
27
|
+
direction?: SignalValue<FlexDirection>;
|
|
28
|
+
basis?: SignalValue<FlexBasis>;
|
|
29
|
+
grow?: SignalValue<number>;
|
|
30
|
+
shrink?: SignalValue<number>;
|
|
31
|
+
wrap?: SignalValue<FlexWrap>;
|
|
32
|
+
justifyContent?: SignalValue<FlexContent>;
|
|
33
|
+
alignContent?: SignalValue<FlexContent>;
|
|
34
|
+
alignItems?: SignalValue<FlexItems>;
|
|
35
|
+
alignSelf?: SignalValue<FlexItems>;
|
|
36
|
+
rowGap?: SignalValue<Length>;
|
|
37
|
+
columnGap?: SignalValue<Length>;
|
|
38
|
+
gap?: SignalValue<Length>;
|
|
39
|
+
fontFamily?: SignalValue<string>;
|
|
40
|
+
fontSize?: SignalValue<number>;
|
|
41
|
+
fontStyle?: SignalValue<string>;
|
|
42
|
+
fontWeight?: SignalValue<number>;
|
|
43
|
+
lineHeight?: SignalValue<Length>;
|
|
44
|
+
letterSpacing?: SignalValue<number>;
|
|
45
|
+
textWrap?: SignalValue<TextWrap>;
|
|
46
|
+
textDirection?: SignalValue<CanvasDirection>;
|
|
47
|
+
textAlign?: SignalValue<CanvasTextAlign>;
|
|
48
|
+
size?: SignalValue<PossibleVector2<Length>>;
|
|
49
|
+
offsetX?: SignalValue<number>;
|
|
50
|
+
offsetY?: SignalValue<number>;
|
|
51
|
+
offset?: SignalValue<PossibleVector2>;
|
|
52
|
+
/**
|
|
53
|
+
* The position of the center of this node.
|
|
54
|
+
*
|
|
55
|
+
* @remarks
|
|
56
|
+
* This shortcut property will set the node's position so that the center ends
|
|
57
|
+
* up in the given place.
|
|
58
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
59
|
+
* When {@link offset} is not set, this will be the same as the
|
|
60
|
+
* {@link NodeProps.position}.
|
|
61
|
+
*/
|
|
62
|
+
middle?: SignalValue<PossibleVector2>;
|
|
63
|
+
/**
|
|
64
|
+
* The position of the top edge of this node.
|
|
65
|
+
*
|
|
66
|
+
* @remarks
|
|
67
|
+
* This shortcut property will set the node's position so that the top edge
|
|
68
|
+
* ends up in the given place.
|
|
69
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
70
|
+
*/
|
|
71
|
+
top?: SignalValue<PossibleVector2>;
|
|
72
|
+
/**
|
|
73
|
+
* The position of the bottom edge of this node.
|
|
74
|
+
*
|
|
75
|
+
* @remarks
|
|
76
|
+
* This shortcut property will set the node's position so that the bottom edge
|
|
77
|
+
* ends up in the given place.
|
|
78
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
79
|
+
*/
|
|
80
|
+
bottom?: SignalValue<PossibleVector2>;
|
|
81
|
+
/**
|
|
82
|
+
* The position of the left edge of this node.
|
|
83
|
+
*
|
|
84
|
+
* @remarks
|
|
85
|
+
* This shortcut property will set the node's position so that the left edge
|
|
86
|
+
* ends up in the given place.
|
|
87
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
88
|
+
*/
|
|
89
|
+
left?: SignalValue<PossibleVector2>;
|
|
90
|
+
/**
|
|
91
|
+
* The position of the right edge of this node.
|
|
92
|
+
*
|
|
93
|
+
* @remarks
|
|
94
|
+
* This shortcut property will set the node's position so that the right edge
|
|
95
|
+
* ends up in the given place.
|
|
96
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
97
|
+
*/
|
|
98
|
+
right?: SignalValue<PossibleVector2>;
|
|
99
|
+
/**
|
|
100
|
+
* The position of the top left corner of this node.
|
|
101
|
+
*
|
|
102
|
+
* @remarks
|
|
103
|
+
* This shortcut property will set the node's position so that the top left
|
|
104
|
+
* corner ends up in the given place.
|
|
105
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
106
|
+
*/
|
|
107
|
+
topLeft?: SignalValue<PossibleVector2>;
|
|
108
|
+
/**
|
|
109
|
+
* The position of the top right corner of this node.
|
|
110
|
+
*
|
|
111
|
+
* @remarks
|
|
112
|
+
* This shortcut property will set the node's position so that the top right
|
|
113
|
+
* corner ends up in the given place.
|
|
114
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
115
|
+
*/
|
|
116
|
+
topRight?: SignalValue<PossibleVector2>;
|
|
117
|
+
/**
|
|
118
|
+
* The position of the bottom left corner of this node.
|
|
119
|
+
*
|
|
120
|
+
* @remarks
|
|
121
|
+
* This shortcut property will set the node's position so that the bottom left
|
|
122
|
+
* corner ends up in the given place.
|
|
123
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
124
|
+
*/
|
|
125
|
+
bottomLeft?: SignalValue<PossibleVector2>;
|
|
126
|
+
/**
|
|
127
|
+
* The position of the bottom right corner of this node.
|
|
128
|
+
*
|
|
129
|
+
* @remarks
|
|
130
|
+
* This shortcut property will set the node's position so that the bottom
|
|
131
|
+
* right corner ends up in the given place.
|
|
132
|
+
* If present, overrides the {@link NodeProps.position} property.
|
|
133
|
+
*/
|
|
134
|
+
bottomRight?: SignalValue<PossibleVector2>;
|
|
135
|
+
clip?: SignalValue<boolean>;
|
|
136
|
+
}
|
|
137
|
+
export declare class Layout extends Node {
|
|
138
|
+
readonly layout: SimpleSignal<LayoutMode, this>;
|
|
139
|
+
readonly maxWidth: SimpleSignal<LengthLimit, this>;
|
|
140
|
+
readonly maxHeight: SimpleSignal<LengthLimit, this>;
|
|
141
|
+
readonly minWidth: SimpleSignal<LengthLimit, this>;
|
|
142
|
+
readonly minHeight: SimpleSignal<LengthLimit, this>;
|
|
143
|
+
readonly ratio: SimpleSignal<number | null, this>;
|
|
144
|
+
readonly margin: SpacingSignal<this>;
|
|
145
|
+
readonly padding: SpacingSignal<this>;
|
|
146
|
+
readonly direction: SimpleSignal<FlexDirection, this>;
|
|
147
|
+
readonly basis: SimpleSignal<FlexBasis, this>;
|
|
148
|
+
readonly grow: SimpleSignal<number, this>;
|
|
149
|
+
readonly shrink: SimpleSignal<number, this>;
|
|
150
|
+
readonly wrap: SimpleSignal<FlexWrap, this>;
|
|
151
|
+
readonly justifyContent: SimpleSignal<FlexContent, this>;
|
|
152
|
+
readonly alignContent: SimpleSignal<FlexContent, this>;
|
|
153
|
+
readonly alignItems: SimpleSignal<FlexItems, this>;
|
|
154
|
+
readonly alignSelf: SimpleSignal<FlexItems, this>;
|
|
155
|
+
readonly gap: Vector2LengthSignal<this>;
|
|
156
|
+
get columnGap(): Signal<Length, number, this>;
|
|
157
|
+
get rowGap(): Signal<Length, number, this>;
|
|
158
|
+
readonly fontFamily: SimpleSignal<string, this>;
|
|
159
|
+
readonly fontSize: SimpleSignal<number, this>;
|
|
160
|
+
readonly fontStyle: SimpleSignal<string, this>;
|
|
161
|
+
readonly fontWeight: SimpleSignal<number, this>;
|
|
162
|
+
readonly lineHeight: SimpleSignal<Length, this>;
|
|
163
|
+
readonly letterSpacing: SimpleSignal<number, this>;
|
|
164
|
+
readonly textWrap: SimpleSignal<TextWrap, this>;
|
|
165
|
+
readonly textDirection: SimpleSignal<CanvasDirection, this>;
|
|
166
|
+
readonly textAlign: SimpleSignal<CanvasTextAlign, this>;
|
|
167
|
+
protected getX(): number;
|
|
168
|
+
protected setX(value: SignalValue<number>): void;
|
|
169
|
+
protected getY(): number;
|
|
170
|
+
protected setY(value: SignalValue<number>): void;
|
|
171
|
+
/**
|
|
172
|
+
* Represents the size of this node.
|
|
173
|
+
*
|
|
174
|
+
* @remarks
|
|
175
|
+
* A size is a two-dimensional vector, where `x` represents the `width`, and `y`
|
|
176
|
+
* represents the `height`.
|
|
177
|
+
*
|
|
178
|
+
* The value of both x and y is of type {@link partials.Length} which is
|
|
179
|
+
* either:
|
|
180
|
+
* - `number` - the desired length in pixels
|
|
181
|
+
* - `${number}%` - a string with the desired length in percents, for example
|
|
182
|
+
* `'50%'`
|
|
183
|
+
* - `null` - an automatic length
|
|
184
|
+
*
|
|
185
|
+
* When retrieving the size, all units are converted to pixels, using the
|
|
186
|
+
* current state of the layout. For example, retrieving the width set to
|
|
187
|
+
* `'50%'`, while the parent has a width of `200px` will result in the number
|
|
188
|
+
* `100` being returned.
|
|
189
|
+
*
|
|
190
|
+
* When the node is not part of the layout, setting its size using percents
|
|
191
|
+
* refers to the size of the entire scene.
|
|
192
|
+
*
|
|
193
|
+
* @example
|
|
194
|
+
* Initializing the size:
|
|
195
|
+
* ```tsx
|
|
196
|
+
* // with a possible vector:
|
|
197
|
+
* <Node size={['50%', 200]} />
|
|
198
|
+
* // with individual components:
|
|
199
|
+
* <Node width={'50%'} height={200} />
|
|
200
|
+
* ```
|
|
201
|
+
*
|
|
202
|
+
* Accessing the size:
|
|
203
|
+
* ```tsx
|
|
204
|
+
* // retrieving the vector:
|
|
205
|
+
* const size = node.size();
|
|
206
|
+
* // retrieving an individual component:
|
|
207
|
+
* const width = node.size.x();
|
|
208
|
+
* ```
|
|
209
|
+
*
|
|
210
|
+
* Setting the size:
|
|
211
|
+
* ```tsx
|
|
212
|
+
* // with a possible vector:
|
|
213
|
+
* node.size(['50%', 200]);
|
|
214
|
+
* node.size(() => ['50%', 200]);
|
|
215
|
+
* // with individual components:
|
|
216
|
+
* node.size.x('50%');
|
|
217
|
+
* node.size.x(() => '50%');
|
|
218
|
+
* ```
|
|
219
|
+
*/
|
|
220
|
+
readonly size: Vector2LengthSignal<this>;
|
|
221
|
+
get width(): Signal<Length, number, this>;
|
|
222
|
+
get height(): Signal<Length, number, this>;
|
|
223
|
+
protected getWidth(): number;
|
|
224
|
+
protected setWidth(value: SignalValue<Length>): void;
|
|
225
|
+
protected tweenWidth(value: SignalValue<Length>, time: number, timingFunction: TimingFunction, interpolationFunction: InterpolationFunction<Length>): ThreadGenerator;
|
|
226
|
+
protected getHeight(): number;
|
|
227
|
+
protected setHeight(value: SignalValue<Length>): void;
|
|
228
|
+
protected tweenHeight(value: SignalValue<Length>, time: number, timingFunction: TimingFunction, interpolationFunction: InterpolationFunction<Length>): ThreadGenerator;
|
|
229
|
+
/**
|
|
230
|
+
* Get the desired size of this node.
|
|
231
|
+
*
|
|
232
|
+
* @remarks
|
|
233
|
+
* This method can be used to control the size using external factors.
|
|
234
|
+
* By default, the returned size is the same as the one declared by the user.
|
|
235
|
+
*/
|
|
236
|
+
protected desiredSize(): SerializedVector2<DesiredLength>;
|
|
237
|
+
protected tweenSize(value: SignalValue<SerializedVector2<Length>>, time: number, timingFunction: TimingFunction, interpolationFunction: InterpolationFunction<Vector2>): ThreadGenerator;
|
|
238
|
+
/**
|
|
239
|
+
* Represents the offset of this node's origin.
|
|
240
|
+
*
|
|
241
|
+
* @remarks
|
|
242
|
+
* By default, the origin of a node is located at its center. The origin
|
|
243
|
+
* serves as the pivot point when rotating and scaling a node, but it doesn't
|
|
244
|
+
* affect the placement of its children.
|
|
245
|
+
*
|
|
246
|
+
* The value is relative to the size of this node. A value of `1` means as far
|
|
247
|
+
* to the right/bottom as possible. Here are a few examples of offsets:
|
|
248
|
+
* - `[-1, -1]` - top left corner
|
|
249
|
+
* - `[1, -1]` - top right corner
|
|
250
|
+
* - `[0, 1]` - bottom edge
|
|
251
|
+
* - `[-1, 1]` - bottom left corner
|
|
252
|
+
*/
|
|
253
|
+
readonly offset: Vector2Signal<this>;
|
|
254
|
+
/**
|
|
255
|
+
* The position of the center of this node.
|
|
256
|
+
*
|
|
257
|
+
* @remarks
|
|
258
|
+
* When set, this shortcut property will modify the node's position so that
|
|
259
|
+
* the center ends up in the given place.
|
|
260
|
+
*
|
|
261
|
+
* If the {@link offset} has not been changed, this will be the same as the
|
|
262
|
+
* {@link position}.
|
|
263
|
+
*
|
|
264
|
+
* When retrieved, it will return the position of the center in the parent
|
|
265
|
+
* space.
|
|
266
|
+
*/
|
|
267
|
+
readonly middle: SimpleVector2Signal<this>;
|
|
268
|
+
/**
|
|
269
|
+
* The position of the top edge of this node.
|
|
270
|
+
*
|
|
271
|
+
* @remarks
|
|
272
|
+
* When set, this shortcut property will modify the node's position so that
|
|
273
|
+
* the top edge ends up in the given place.
|
|
274
|
+
*
|
|
275
|
+
* When retrieved, it will return the position of the top edge in the parent
|
|
276
|
+
* space.
|
|
277
|
+
*/
|
|
278
|
+
readonly top: SimpleVector2Signal<this>;
|
|
279
|
+
/**
|
|
280
|
+
* The position of the bottom edge of this node.
|
|
281
|
+
*
|
|
282
|
+
* @remarks
|
|
283
|
+
* When set, this shortcut property will modify the node's position so that
|
|
284
|
+
* the bottom edge ends up in the given place.
|
|
285
|
+
*
|
|
286
|
+
* When retrieved, it will return the position of the bottom edge in the
|
|
287
|
+
* parent space.
|
|
288
|
+
*/
|
|
289
|
+
readonly bottom: SimpleVector2Signal<this>;
|
|
290
|
+
/**
|
|
291
|
+
* The position of the left edge of this node.
|
|
292
|
+
*
|
|
293
|
+
* @remarks
|
|
294
|
+
* When set, this shortcut property will modify the node's position so that
|
|
295
|
+
* the left edge ends up in the given place.
|
|
296
|
+
*
|
|
297
|
+
* When retrieved, it will return the position of the left edge in the parent
|
|
298
|
+
* space.
|
|
299
|
+
*/
|
|
300
|
+
readonly left: SimpleVector2Signal<this>;
|
|
301
|
+
/**
|
|
302
|
+
* The position of the right edge of this node.
|
|
303
|
+
*
|
|
304
|
+
* @remarks
|
|
305
|
+
* When set, this shortcut property will modify the node's position so that
|
|
306
|
+
* the right edge ends up in the given place.
|
|
307
|
+
*
|
|
308
|
+
* When retrieved, it will return the position of the right edge in the parent
|
|
309
|
+
* space.
|
|
310
|
+
*/
|
|
311
|
+
readonly right: SimpleVector2Signal<this>;
|
|
312
|
+
/**
|
|
313
|
+
* The position of the top left corner of this node.
|
|
314
|
+
*
|
|
315
|
+
* @remarks
|
|
316
|
+
* When set, this shortcut property will modify the node's position so that
|
|
317
|
+
* the top left corner ends up in the given place.
|
|
318
|
+
*
|
|
319
|
+
* When retrieved, it will return the position of the top left corner in the
|
|
320
|
+
* parent space.
|
|
321
|
+
*/
|
|
322
|
+
readonly topLeft: SimpleVector2Signal<this>;
|
|
323
|
+
/**
|
|
324
|
+
* The position of the top right corner of this node.
|
|
325
|
+
*
|
|
326
|
+
* @remarks
|
|
327
|
+
* When set, this shortcut property will modify the node's position so that
|
|
328
|
+
* the top right corner ends up in the given place.
|
|
329
|
+
*
|
|
330
|
+
* When retrieved, it will return the position of the top right corner in the
|
|
331
|
+
* parent space.
|
|
332
|
+
*/
|
|
333
|
+
readonly topRight: SimpleVector2Signal<this>;
|
|
334
|
+
/**
|
|
335
|
+
* The position of the bottom left corner of this node.
|
|
336
|
+
*
|
|
337
|
+
* @remarks
|
|
338
|
+
* When set, this shortcut property will modify the node's position so that
|
|
339
|
+
* the bottom left corner ends up in the given place.
|
|
340
|
+
*
|
|
341
|
+
* When retrieved, it will return the position of the bottom left corner in
|
|
342
|
+
* the parent space.
|
|
343
|
+
*/
|
|
344
|
+
readonly bottomLeft: SimpleVector2Signal<this>;
|
|
345
|
+
/**
|
|
346
|
+
* The position of the bottom right corner of this node.
|
|
347
|
+
*
|
|
348
|
+
* @remarks
|
|
349
|
+
* When set, this shortcut property will modify the node's position so that
|
|
350
|
+
* the bottom right corner ends up in the given place.
|
|
351
|
+
*
|
|
352
|
+
* When retrieved, it will return the position of the bottom right corner in
|
|
353
|
+
* the parent space.
|
|
354
|
+
*/
|
|
355
|
+
readonly bottomRight: SimpleVector2Signal<this>;
|
|
356
|
+
readonly clip: SimpleSignal<boolean, this>;
|
|
357
|
+
element: HTMLElement;
|
|
358
|
+
styles: CSSStyleDeclaration;
|
|
359
|
+
protected readonly sizeLockCounter: SimpleSignal<number, this>;
|
|
360
|
+
constructor(props: LayoutProps);
|
|
361
|
+
lockSize(): void;
|
|
362
|
+
releaseSize(): void;
|
|
363
|
+
protected parentTransform(): Layout | null;
|
|
364
|
+
anchorPosition(): Vector2;
|
|
365
|
+
/**
|
|
366
|
+
* Get the resolved layout mode of this node.
|
|
367
|
+
*
|
|
368
|
+
* @remarks
|
|
369
|
+
* When the mode is `null`, its value will be inherited from the parent.
|
|
370
|
+
*
|
|
371
|
+
* Use {@link layout} to get the raw mode set for this node (without
|
|
372
|
+
* inheritance).
|
|
373
|
+
*/
|
|
374
|
+
layoutEnabled(): boolean;
|
|
375
|
+
isLayoutRoot(): boolean;
|
|
376
|
+
localToParent(): DOMMatrix;
|
|
377
|
+
/**
|
|
378
|
+
* A simplified version of {@link localToParent} matrix used for transforming
|
|
379
|
+
* direction vectors.
|
|
380
|
+
*
|
|
381
|
+
* @internal
|
|
382
|
+
*/
|
|
383
|
+
protected scalingRotationMatrix(): DOMMatrix;
|
|
384
|
+
protected getComputedLayout(): BBox;
|
|
385
|
+
computedPosition(): Vector2;
|
|
386
|
+
protected computedSize(): Vector2;
|
|
387
|
+
/**
|
|
388
|
+
* Find the closest layout root and apply any new layout changes.
|
|
389
|
+
*/
|
|
390
|
+
protected requestLayoutUpdate(): void;
|
|
391
|
+
protected appendedToView(): boolean;
|
|
392
|
+
/**
|
|
393
|
+
* Apply any new layout changes to this node and its children.
|
|
394
|
+
*/
|
|
395
|
+
protected updateLayout(): void;
|
|
396
|
+
protected layoutChildren(): Layout[];
|
|
397
|
+
/**
|
|
398
|
+
* Apply any new font changes to this node and all of its ancestors.
|
|
399
|
+
*/
|
|
400
|
+
protected requestFontUpdate(): void;
|
|
401
|
+
protected getCacheBBox(): BBox;
|
|
402
|
+
protected draw(context: CanvasRenderingContext2D): Promise<void>;
|
|
403
|
+
drawOverlay(context: CanvasRenderingContext2D, matrix: DOMMatrix): void;
|
|
404
|
+
getOriginDelta(origin: Origin): Vector2;
|
|
405
|
+
/**
|
|
406
|
+
* Update the offset of this node and adjust the position to keep it in the
|
|
407
|
+
* same place.
|
|
408
|
+
*
|
|
409
|
+
* @param offset - The new offset.
|
|
410
|
+
*/
|
|
411
|
+
moveOffset(offset: Vector2): void;
|
|
412
|
+
protected parsePixels(value: number | null): string;
|
|
413
|
+
protected parseLength(value: number | string | null): string;
|
|
414
|
+
protected applyFlex(): void;
|
|
415
|
+
protected applyFont(): void;
|
|
416
|
+
dispose(): void;
|
|
417
|
+
hit(position: Vector2): Node | null;
|
|
418
|
+
}
|
|
419
|
+
//# sourceMappingURL=Layout.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Layout.d.ts","sourceRoot":"","sources":["../../src/lib/components/Layout.ts"],"names":[],"mappings":"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"}
|