motion-script 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/attributes/bounds/bounds.d.ts +10 -0
- package/dist/attributes/bounds/bounds.d.ts.map +1 -0
- package/dist/attributes/bounds/bounds.js +2 -0
- package/dist/attributes/bounds/bounds.js.map +1 -0
- package/dist/attributes/fill/blend.d.ts +4 -0
- package/dist/attributes/fill/blend.d.ts.map +1 -0
- package/dist/attributes/fill/blend.js +14 -0
- package/dist/attributes/fill/blend.js.map +1 -0
- package/dist/attributes/fill/fill.d.ts +28 -0
- package/dist/attributes/fill/fill.d.ts.map +1 -0
- package/dist/attributes/fill/fill.js +23 -0
- package/dist/attributes/fill/fill.js.map +1 -0
- package/dist/attributes/fill/registry.d.ts +23 -0
- package/dist/attributes/fill/registry.d.ts.map +1 -0
- package/dist/attributes/fill/registry.js +106 -0
- package/dist/attributes/fill/registry.js.map +1 -0
- package/dist/attributes/index.d.ts +9 -0
- package/dist/attributes/index.d.ts.map +1 -0
- package/dist/attributes/index.js +9 -0
- package/dist/attributes/index.js.map +1 -0
- package/dist/attributes/insets/inset.d.ts +7 -0
- package/dist/attributes/insets/inset.d.ts.map +1 -0
- package/dist/attributes/insets/inset.js +2 -0
- package/dist/attributes/insets/inset.js.map +1 -0
- package/dist/attributes/position/vector2.d.ts +5 -0
- package/dist/attributes/position/vector2.d.ts.map +1 -0
- package/dist/attributes/position/vector2.js +2 -0
- package/dist/attributes/position/vector2.js.map +1 -0
- package/dist/attributes/size/constraints.d.ts +5 -0
- package/dist/attributes/size/constraints.d.ts.map +1 -0
- package/dist/attributes/size/constraints.js +2 -0
- package/dist/attributes/size/constraints.js.map +1 -0
- package/dist/attributes/size/size.d.ts +6 -0
- package/dist/attributes/size/size.d.ts.map +1 -0
- package/dist/attributes/size/size.js +2 -0
- package/dist/attributes/size/size.js.map +1 -0
- package/dist/attributes/stroke/stroke.d.ts +6 -0
- package/dist/attributes/stroke/stroke.d.ts.map +1 -0
- package/dist/attributes/stroke/stroke.js +2 -0
- package/dist/attributes/stroke/stroke.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/jsx/jsx-dev-runtime.d.ts +4 -0
- package/dist/jsx/jsx-dev-runtime.d.ts.map +1 -0
- package/dist/jsx/jsx-dev-runtime.js +16 -0
- package/dist/jsx/jsx-dev-runtime.js.map +1 -0
- package/dist/jsx/jsx-runtime.d.ts +4 -0
- package/dist/jsx/jsx-runtime.d.ts.map +1 -0
- package/dist/jsx/jsx-runtime.js +16 -0
- package/dist/jsx/jsx-runtime.js.map +1 -0
- package/dist/nodes/base/node.d.ts +37 -0
- package/dist/nodes/base/node.d.ts.map +1 -0
- package/dist/nodes/base/node.js +107 -0
- package/dist/nodes/base/node.js.map +1 -0
- package/dist/nodes/flex/node.d.ts +35 -0
- package/dist/nodes/flex/node.d.ts.map +1 -0
- package/dist/nodes/flex/node.js +318 -0
- package/dist/nodes/flex/node.js.map +1 -0
- package/dist/nodes/flex/props.d.ts +27 -0
- package/dist/nodes/flex/props.d.ts.map +1 -0
- package/dist/nodes/flex/props.js +2 -0
- package/dist/nodes/flex/props.js.map +1 -0
- package/dist/nodes/index.d.ts +13 -0
- package/dist/nodes/index.d.ts.map +1 -0
- package/dist/nodes/index.js +13 -0
- package/dist/nodes/index.js.map +1 -0
- package/dist/nodes/rect/node.d.ts +14 -0
- package/dist/nodes/rect/node.d.ts.map +1 -0
- package/dist/nodes/rect/node.js +55 -0
- package/dist/nodes/rect/node.js.map +1 -0
- package/dist/nodes/rect/props.d.ts +10 -0
- package/dist/nodes/rect/props.d.ts.map +1 -0
- package/dist/nodes/rect/props.js +2 -0
- package/dist/nodes/rect/props.js.map +1 -0
- package/dist/nodes/registry.d.ts +3 -0
- package/dist/nodes/registry.d.ts.map +1 -0
- package/dist/nodes/registry.js +31 -0
- package/dist/nodes/registry.js.map +1 -0
- package/dist/nodes/shape/node.d.ts +15 -0
- package/dist/nodes/shape/node.d.ts.map +1 -0
- package/dist/nodes/shape/node.js +32 -0
- package/dist/nodes/shape/node.js.map +1 -0
- package/dist/nodes/shape/props.d.ts +8 -0
- package/dist/nodes/shape/props.d.ts.map +1 -0
- package/dist/nodes/shape/props.js +2 -0
- package/dist/nodes/shape/props.js.map +1 -0
- package/dist/nodes/text/node.d.ts +18 -0
- package/dist/nodes/text/node.d.ts.map +1 -0
- package/dist/nodes/text/node.js +76 -0
- package/dist/nodes/text/node.js.map +1 -0
- package/dist/nodes/text/props.d.ts +11 -0
- package/dist/nodes/text/props.d.ts.map +1 -0
- package/dist/nodes/text/props.js +2 -0
- package/dist/nodes/text/props.js.map +1 -0
- package/dist/nodes/transform/node.d.ts +39 -0
- package/dist/nodes/transform/node.d.ts.map +1 -0
- package/dist/nodes/transform/node.js +160 -0
- package/dist/nodes/transform/node.js.map +1 -0
- package/dist/nodes/transform/props.d.ts +11 -0
- package/dist/nodes/transform/props.d.ts.map +1 -0
- package/dist/nodes/transform/props.js +2 -0
- package/dist/nodes/transform/props.js.map +1 -0
- package/dist/project/generator.d.ts +2 -0
- package/dist/project/generator.d.ts.map +1 -0
- package/dist/project/generator.js +2 -0
- package/dist/project/generator.js.map +1 -0
- package/dist/project/index.d.ts +4 -0
- package/dist/project/index.d.ts.map +1 -0
- package/dist/project/index.js +4 -0
- package/dist/project/index.js.map +1 -0
- package/dist/project/project.d.ts +14 -0
- package/dist/project/project.d.ts.map +1 -0
- package/dist/project/project.js +2 -0
- package/dist/project/project.js.map +1 -0
- package/dist/project/scene.d.ts +49 -0
- package/dist/project/scene.d.ts.map +1 -0
- package/dist/project/scene.js +2 -0
- package/dist/project/scene.js.map +1 -0
- package/dist/rendering/contexts/draw-context.d.ts +17 -0
- package/dist/rendering/contexts/draw-context.d.ts.map +1 -0
- package/dist/rendering/contexts/draw-context.js +12 -0
- package/dist/rendering/contexts/draw-context.js.map +1 -0
- package/dist/rendering/contexts/pixi-context.d.ts +29 -0
- package/dist/rendering/contexts/pixi-context.d.ts.map +1 -0
- package/dist/rendering/contexts/pixi-context.js +117 -0
- package/dist/rendering/contexts/pixi-context.js.map +1 -0
- package/dist/rendering/index.d.ts +11 -0
- package/dist/rendering/index.d.ts.map +1 -0
- package/dist/rendering/index.js +11 -0
- package/dist/rendering/index.js.map +1 -0
- package/dist/rendering/painters/base/painter.d.ts +9 -0
- package/dist/rendering/painters/base/painter.d.ts.map +1 -0
- package/dist/rendering/painters/base/painter.js +12 -0
- package/dist/rendering/painters/base/painter.js.map +1 -0
- package/dist/rendering/painters/ellipse/ellipse.d.ts +9 -0
- package/dist/rendering/painters/ellipse/ellipse.d.ts.map +1 -0
- package/dist/rendering/painters/ellipse/ellipse.js +2 -0
- package/dist/rendering/painters/ellipse/ellipse.js.map +1 -0
- package/dist/rendering/painters/latex/state.d.ts +6 -0
- package/dist/rendering/painters/latex/state.d.ts.map +1 -0
- package/dist/rendering/painters/latex/state.js +2 -0
- package/dist/rendering/painters/latex/state.js.map +1 -0
- package/dist/rendering/painters/rect/cache.d.ts +22 -0
- package/dist/rendering/painters/rect/cache.d.ts.map +1 -0
- package/dist/rendering/painters/rect/cache.js +106 -0
- package/dist/rendering/painters/rect/cache.js.map +1 -0
- package/dist/rendering/painters/rect/painter.d.ts +13 -0
- package/dist/rendering/painters/rect/painter.d.ts.map +1 -0
- package/dist/rendering/painters/rect/painter.js +66 -0
- package/dist/rendering/painters/rect/painter.js.map +1 -0
- package/dist/rendering/painters/rect/state.d.ts +11 -0
- package/dist/rendering/painters/rect/state.d.ts.map +1 -0
- package/dist/rendering/painters/rect/state.js +21 -0
- package/dist/rendering/painters/rect/state.js.map +1 -0
- package/dist/rendering/painters/shape/state.d.ts +9 -0
- package/dist/rendering/painters/shape/state.d.ts.map +1 -0
- package/dist/rendering/painters/shape/state.js +2 -0
- package/dist/rendering/painters/shape/state.js.map +1 -0
- package/dist/rendering/painters/text/cache.d.ts +30 -0
- package/dist/rendering/painters/text/cache.d.ts.map +1 -0
- package/dist/rendering/painters/text/cache.js +525 -0
- package/dist/rendering/painters/text/cache.js.map +1 -0
- package/dist/rendering/painters/text/geometry/font/cache.d.ts +9 -0
- package/dist/rendering/painters/text/geometry/font/cache.d.ts.map +1 -0
- package/dist/rendering/painters/text/geometry/font/cache.js +20 -0
- package/dist/rendering/painters/text/geometry/font/cache.js.map +1 -0
- package/dist/rendering/painters/text/geometry/font/fonts.json +3844 -0
- package/dist/rendering/painters/text/geometry/font/loader.d.ts +4 -0
- package/dist/rendering/painters/text/geometry/font/loader.d.ts.map +1 -0
- package/dist/rendering/painters/text/geometry/font/loader.js +33 -0
- package/dist/rendering/painters/text/geometry/font/loader.js.map +1 -0
- package/dist/rendering/painters/text/geometry/font/ttf.d.ts +27 -0
- package/dist/rendering/painters/text/geometry/font/ttf.d.ts.map +1 -0
- package/dist/rendering/painters/text/geometry/font/ttf.js +26 -0
- package/dist/rendering/painters/text/geometry/font/ttf.js.map +1 -0
- package/dist/rendering/painters/text/geometry/path.d.ts +16 -0
- package/dist/rendering/painters/text/geometry/path.d.ts.map +1 -0
- package/dist/rendering/painters/text/geometry/path.js +40 -0
- package/dist/rendering/painters/text/geometry/path.js.map +1 -0
- package/dist/rendering/painters/text/painter.d.ts +13 -0
- package/dist/rendering/painters/text/painter.d.ts.map +1 -0
- package/dist/rendering/painters/text/painter.js +69 -0
- package/dist/rendering/painters/text/painter.js.map +1 -0
- package/dist/rendering/painters/text/state.d.ts +12 -0
- package/dist/rendering/painters/text/state.d.ts.map +1 -0
- package/dist/rendering/painters/text/state.js +22 -0
- package/dist/rendering/painters/text/state.js.map +1 -0
- package/dist/rendering/painters/transform/painter.d.ts +9 -0
- package/dist/rendering/painters/transform/painter.d.ts.map +1 -0
- package/dist/rendering/painters/transform/painter.js +18 -0
- package/dist/rendering/painters/transform/painter.js.map +1 -0
- package/dist/rendering/painters/transform/state.d.ts +9 -0
- package/dist/rendering/painters/transform/state.d.ts.map +1 -0
- package/dist/rendering/painters/transform/state.js +2 -0
- package/dist/rendering/painters/transform/state.js.map +1 -0
- package/dist/rendering/textures/multi-fill.d.ts +1 -0
- package/dist/rendering/textures/multi-fill.d.ts.map +1 -0
- package/dist/rendering/textures/multi-fill.js +18 -0
- package/dist/rendering/textures/multi-fill.js.map +1 -0
- package/dist/signal/collector.d.ts +6 -0
- package/dist/signal/collector.d.ts.map +1 -0
- package/dist/signal/collector.js +18 -0
- package/dist/signal/collector.js.map +1 -0
- package/dist/signal/index.d.ts +3 -0
- package/dist/signal/index.d.ts.map +1 -0
- package/dist/signal/index.js +3 -0
- package/dist/signal/index.js.map +1 -0
- package/dist/signal/signal.d.ts +7 -0
- package/dist/signal/signal.d.ts.map +1 -0
- package/dist/signal/signal.js +217 -0
- package/dist/signal/signal.js.map +1 -0
- package/dist/signal/type.d.ts +40 -0
- package/dist/signal/type.d.ts.map +1 -0
- package/dist/signal/type.js +2 -0
- package/dist/signal/type.js.map +1 -0
- package/dist/tween/ease.d.ts +13 -0
- package/dist/tween/ease.d.ts.map +1 -0
- package/dist/tween/ease.js +40 -0
- package/dist/tween/ease.js.map +1 -0
- package/dist/tween/eases.d.ts +12 -0
- package/dist/tween/eases.d.ts.map +1 -0
- package/dist/tween/eases.js +69 -0
- package/dist/tween/eases.js.map +1 -0
- package/dist/tween/index.d.ts +7 -0
- package/dist/tween/index.d.ts.map +1 -0
- package/dist/tween/index.js +7 -0
- package/dist/tween/index.js.map +1 -0
- package/dist/tween/parallel.d.ts +3 -0
- package/dist/tween/parallel.d.ts.map +1 -0
- package/dist/tween/parallel.js +24 -0
- package/dist/tween/parallel.js.map +1 -0
- package/dist/tween/sequence.d.ts +3 -0
- package/dist/tween/sequence.d.ts.map +1 -0
- package/dist/tween/sequence.js +7 -0
- package/dist/tween/sequence.js.map +1 -0
- package/dist/tween/tests/realtime.test.d.ts +2 -0
- package/dist/tween/tests/realtime.test.d.ts.map +1 -0
- package/dist/tween/tests/realtime.test.js +76 -0
- package/dist/tween/tests/realtime.test.js.map +1 -0
- package/dist/tween/tween.d.ts +3 -0
- package/dist/tween/tween.d.ts.map +1 -0
- package/dist/tween/tween.js +14 -0
- package/dist/tween/tween.js.map +1 -0
- package/dist/tween/wait.d.ts +3 -0
- package/dist/tween/wait.d.ts.map +1 -0
- package/dist/tween/wait.js +10 -0
- package/dist/tween/wait.js.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ShapeProps } from "../shape/props";
|
|
2
|
+
export interface RectProps extends ShapeProps, BorderRadiusProps {
|
|
3
|
+
}
|
|
4
|
+
export interface BorderRadiusProps {
|
|
5
|
+
topLeftRadius: number;
|
|
6
|
+
topRightRadius: number;
|
|
7
|
+
bottomLeftRadius: number;
|
|
8
|
+
bottomRightRadius: number;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=props.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.d.ts","sourceRoot":"","sources":["../../../src/nodes/rect/props.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGjD,MAAM,WAAW,SAAU,SAAQ,UAAU,EAAE,iBAAiB;CAI/D;AAED,MAAM,WAAW,iBAAiB;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,cAAc,EAAE,MAAM,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;IACzB,iBAAiB,EAAE,MAAM,CAAC;CAC7B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.js","sourceRoot":"","sources":["../../../src/nodes/rect/props.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/nodes/registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAiC,MAAM,IAAI,CAAC;AA2B7D,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,SAAS,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,QAAQ,CAEvH"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { FlexNode, RRectNode, TextNode } from "..";
|
|
2
|
+
class NodeRegistry {
|
|
3
|
+
factories = new Map();
|
|
4
|
+
register(type, factory) {
|
|
5
|
+
this.factories.set(type, factory);
|
|
6
|
+
}
|
|
7
|
+
get(type) {
|
|
8
|
+
return this.factories.get(type);
|
|
9
|
+
}
|
|
10
|
+
has(type) {
|
|
11
|
+
return this.factories.has(type);
|
|
12
|
+
}
|
|
13
|
+
create(type, id, parentId, props) {
|
|
14
|
+
const factory = this.factories.get(type);
|
|
15
|
+
if (!factory)
|
|
16
|
+
throw new Error(`Unknown node type: ${type}`);
|
|
17
|
+
return factory(id, parentId, props);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export function createNode(type, id, parentId, props) {
|
|
21
|
+
return nodeRegistry.create(type, id, parentId, props);
|
|
22
|
+
}
|
|
23
|
+
const nodeRegistry = new NodeRegistry();
|
|
24
|
+
nodeRegistry.register("rect", (id, parentId, props) => new RRectNode(id, parentId, props));
|
|
25
|
+
nodeRegistry.register("row", (id, parentId, props) => new FlexNode(id, "row", parentId, props));
|
|
26
|
+
nodeRegistry.register("column", (id, parentId, props) => new FlexNode(id, "column", parentId, props));
|
|
27
|
+
nodeRegistry.register("text", (id, parentId, props) => new TextNode(id, parentId, props));
|
|
28
|
+
// nodeRegistry.register("ellipse", (id, parentId, props) => new EllipseNode(id, parentId, props as EllipseProps));
|
|
29
|
+
// nodeRegistry.register("latex", (id, parentId, props) => new LatexNode(id, parentId, props as LatexProps));
|
|
30
|
+
// nodeRegistry.register("text", (id, parentId, props) => new TextNode(id, parentId, props as TextProps));
|
|
31
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/nodes/registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AAM7D,MAAM,YAAY;IACG,SAAS,GAAG,IAAI,GAAG,EAAuB,CAAC;IAE5D,QAAQ,CAAC,IAAY,EAAE,OAAoB;QACvC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,GAAG,CAAC,IAAY;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,GAAG,CAAC,IAAY;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,IAAY,EAAE,EAAU,EAAE,QAA4B,EAAE,KAA0B;QACrF,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,IAAI,EAAE,CAAC,CAAC;QAC5D,OAAO,OAAO,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;IACxC,CAAC;CACJ;AACD,MAAM,UAAU,UAAU,CAAC,IAAY,EAAE,EAAU,EAAE,QAA4B,EAAE,KAA0B;IACzG,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC1D,CAAC;AACD,MAAM,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;AAExC,YAAY,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,SAAS,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;AAC3F,YAAY,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,QAAQ,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;AAChG,YAAY,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,QAAQ,CAAC,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;AACtG,YAAY,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,QAAQ,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;AAC1F,mHAAmH;AACnH,6GAA6G;AAC7G,0GAA0G"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { IFill } from "@/attributes/fill/fill";
|
|
2
|
+
import { Signal } from "@/signal/type";
|
|
3
|
+
import { TransformNode } from "../transform/node";
|
|
4
|
+
import { IStroke } from "@/attributes/stroke/stroke";
|
|
5
|
+
import { ShapeProps } from "./props";
|
|
6
|
+
export declare abstract class ShapeNode extends TransformNode {
|
|
7
|
+
protected readonly fillSignal: Signal<IFill[]>;
|
|
8
|
+
protected readonly strokeSignal: Signal<IStroke[]>;
|
|
9
|
+
constructor(id: string, type: string, parentId: string | undefined, props: Partial<ShapeProps>);
|
|
10
|
+
protected get fill(): IFill[];
|
|
11
|
+
protected get stroke(): IStroke[];
|
|
12
|
+
createSignalMap(): Record<string, Signal<any>>;
|
|
13
|
+
protected interpolatePropValue(key: string, fromValue: any, toValue: any, progress: number): any;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/nodes/shape/node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AAErD,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAIrC,8BAAsB,SAAU,SAAQ,aAAa;IACjD,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;IAC/C,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;gBAEvC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,SAAS,EAAE,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC;IAM9F,SAAS,KAAK,IAAI,IAAI,KAAK,EAAE,CAE5B;IAED,SAAS,KAAK,MAAM,IAAI,OAAO,EAAE,CAEhC;IAEQ,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;cAQpC,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,GAAG,GAAG;CAO5G"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { TransformNode } from "../transform/node";
|
|
2
|
+
import createSignal from "@/signal/signal";
|
|
3
|
+
import { FillLerp } from "@/attributes/fill/registry";
|
|
4
|
+
export class ShapeNode extends TransformNode {
|
|
5
|
+
fillSignal;
|
|
6
|
+
strokeSignal;
|
|
7
|
+
constructor(id, type, parentId, props) {
|
|
8
|
+
super(id, type, parentId, props);
|
|
9
|
+
this.fillSignal = createSignal(props.fill ?? []);
|
|
10
|
+
this.strokeSignal = createSignal(props.stroke ?? []);
|
|
11
|
+
}
|
|
12
|
+
get fill() {
|
|
13
|
+
return this.fillSignal.get();
|
|
14
|
+
}
|
|
15
|
+
get stroke() {
|
|
16
|
+
return this.strokeSignal.get();
|
|
17
|
+
}
|
|
18
|
+
createSignalMap() {
|
|
19
|
+
return {
|
|
20
|
+
...super.createSignalMap(),
|
|
21
|
+
fill: this.fillSignal,
|
|
22
|
+
stroke: this.strokeSignal,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
interpolatePropValue(key, fromValue, toValue, progress) {
|
|
26
|
+
if (key === "fill" && Array.isArray(fromValue) && Array.isArray(toValue)) {
|
|
27
|
+
return FillLerp.lerpArray(fromValue, toValue, progress);
|
|
28
|
+
}
|
|
29
|
+
return super.interpolatePropValue(key, fromValue, toValue, progress);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../src/nodes/shape/node.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,OAAO,YAAY,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAGtD,MAAM,OAAgB,SAAU,SAAQ,aAAa;IAC9B,UAAU,CAAkB;IAC5B,YAAY,CAAoB;IAEnD,YAAY,EAAU,EAAE,IAAY,EAAE,QAA4B,EAAE,KAA0B;QAC1F,KAAK,CAAC,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;IACzD,CAAC;IAED,IAAc,IAAI;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;IACjC,CAAC;IAED,IAAc,MAAM;QAChB,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC;IACnC,CAAC;IAEQ,eAAe;QACpB,OAAO;YACH,GAAG,KAAK,CAAC,eAAe,EAAE;YAC1B,IAAI,EAAE,IAAI,CAAC,UAAU;YACrB,MAAM,EAAE,IAAI,CAAC,YAAY;SAC5B,CAAC;IACN,CAAC;IAEkB,oBAAoB,CAAC,GAAW,EAAE,SAAc,EAAE,OAAY,EAAE,QAAgB;QAC/F,IAAI,GAAG,KAAK,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACvE,OAAO,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC5D,CAAC;QAED,OAAO,KAAK,CAAC,oBAAoB,CAAC,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;IACzE,CAAC;CACJ"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { IFill } from "@/attributes/fill/fill";
|
|
2
|
+
import type { TransformProps } from "../transform/props";
|
|
3
|
+
import { IStroke } from "@/attributes/stroke/stroke";
|
|
4
|
+
export interface ShapeProps extends TransformProps {
|
|
5
|
+
fill: IFill[];
|
|
6
|
+
stroke: IStroke[];
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=props.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.d.ts","sourceRoot":"","sources":["../../../src/nodes/shape/props.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AAErD,MAAM,WAAW,UAAW,SAAQ,cAAc;IAC9C,IAAI,EAAE,KAAK,EAAE,CAAC;IACd,MAAM,EAAE,OAAO,EAAE,CAAC;CAErB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.js","sourceRoot":"","sources":["../../../src/nodes/shape/props.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Signal } from "@/signal/type";
|
|
2
|
+
import { ShapeNode } from "../shape/node";
|
|
3
|
+
import { TextProps } from "./props";
|
|
4
|
+
import { DrawContext } from "@/rendering/contexts/draw-context";
|
|
5
|
+
export declare class TextNode extends ShapeNode {
|
|
6
|
+
private readonly textSignal;
|
|
7
|
+
private readonly fontSizeSignal;
|
|
8
|
+
private readonly fontFamilySignal;
|
|
9
|
+
private readonly fontWeightSignal;
|
|
10
|
+
private readonly letterSpacingSignal;
|
|
11
|
+
private readonly lineHeightSignal;
|
|
12
|
+
private readonly alignSignal;
|
|
13
|
+
constructor(id: string, parentId: string | undefined, props: Partial<TextProps>);
|
|
14
|
+
createSignalMap(): Record<string, Signal<any>>;
|
|
15
|
+
protected interpolatePropValue(key: string, fromValue: any, toValue: any, progress: number): any;
|
|
16
|
+
protected drawSelf(ctx: DrawContext): void;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/nodes/text/node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAGhE,qBAAa,QAAS,SAAQ,SAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAiB;IAC5C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAChD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAiB;IAClD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAiB;IAClD,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAiB;IACrD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAiB;IAClD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAiB;gBAEjC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,SAAS,EAAE,KAAK,EAAE,OAAO,CAAC,SAAS,CAAC;IAWtE,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;cAapC,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,GAAG,GAAG;cAQtF,QAAQ,CAAC,GAAG,EAAE,WAAW,GAAG,IAAI;CAsCtD"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { ShapeNode } from "../shape/node";
|
|
2
|
+
import createSignal from "@/signal/signal";
|
|
3
|
+
export class TextNode extends ShapeNode {
|
|
4
|
+
textSignal;
|
|
5
|
+
fontSizeSignal;
|
|
6
|
+
fontFamilySignal;
|
|
7
|
+
fontWeightSignal;
|
|
8
|
+
letterSpacingSignal;
|
|
9
|
+
lineHeightSignal;
|
|
10
|
+
alignSignal;
|
|
11
|
+
constructor(id, parentId, props) {
|
|
12
|
+
super(id, "text", parentId, props);
|
|
13
|
+
this.textSignal = createSignal(props.text ?? "");
|
|
14
|
+
this.fontSizeSignal = createSignal(props.fontSize ?? 16);
|
|
15
|
+
this.fontFamilySignal = createSignal(props.fontFamily ?? "sans-serif");
|
|
16
|
+
this.fontWeightSignal = createSignal(props.fontWeight ?? 400);
|
|
17
|
+
this.letterSpacingSignal = createSignal(props.letterSpacing ?? 0);
|
|
18
|
+
this.lineHeightSignal = createSignal(props.lineHeight ?? 1.2);
|
|
19
|
+
this.alignSignal = createSignal(props.align ?? 0);
|
|
20
|
+
}
|
|
21
|
+
createSignalMap() {
|
|
22
|
+
return {
|
|
23
|
+
...super.createSignalMap(),
|
|
24
|
+
text: this.textSignal,
|
|
25
|
+
fontSize: this.fontSizeSignal,
|
|
26
|
+
fontFamily: this.fontFamilySignal,
|
|
27
|
+
fontWeight: this.fontWeightSignal,
|
|
28
|
+
letterSpacing: this.letterSpacingSignal,
|
|
29
|
+
lineHeight: this.lineHeightSignal,
|
|
30
|
+
align: this.alignSignal,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
interpolatePropValue(key, fromValue, toValue, progress) {
|
|
34
|
+
if ((key === "text" || key === "fontFamily") && progress > 0) {
|
|
35
|
+
return toValue;
|
|
36
|
+
}
|
|
37
|
+
return super.interpolatePropValue(key, fromValue, toValue, progress);
|
|
38
|
+
}
|
|
39
|
+
drawSelf(ctx) {
|
|
40
|
+
const text = this.textSignal.get();
|
|
41
|
+
const fontSize = this.fontSizeSignal.get();
|
|
42
|
+
const fontFamily = this.fontFamilySignal.get();
|
|
43
|
+
const letterSpacing = this.letterSpacingSignal.get();
|
|
44
|
+
const lineHeight = this.lineHeightSignal.get();
|
|
45
|
+
const align = this.alignSignal.get();
|
|
46
|
+
const fills = this.fill;
|
|
47
|
+
for (let i = 0; i < fills.length; i++) {
|
|
48
|
+
ctx.text(`fill_${i}`, {
|
|
49
|
+
text,
|
|
50
|
+
fontSize,
|
|
51
|
+
fontFamily,
|
|
52
|
+
letterSpacing,
|
|
53
|
+
lineHeight,
|
|
54
|
+
align,
|
|
55
|
+
fill: [fills[i]],
|
|
56
|
+
paintStyle: "fill",
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
const strokes = this.stroke;
|
|
60
|
+
for (let i = 0; i < strokes.length; i++) {
|
|
61
|
+
const stroke = strokes[i];
|
|
62
|
+
ctx.text(`stroke_${i}`, {
|
|
63
|
+
text,
|
|
64
|
+
fontSize,
|
|
65
|
+
fontFamily,
|
|
66
|
+
letterSpacing,
|
|
67
|
+
lineHeight,
|
|
68
|
+
align,
|
|
69
|
+
fill: [stroke.fill],
|
|
70
|
+
strokeWidth: stroke.weight ?? 0,
|
|
71
|
+
paintStyle: "stroke",
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../src/nodes/text/node.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ShapeProps } from "../shape/props";
|
|
2
|
+
export interface TextProps extends ShapeProps {
|
|
3
|
+
text: string;
|
|
4
|
+
fontSize: number;
|
|
5
|
+
fontFamily: string;
|
|
6
|
+
fontWeight: number;
|
|
7
|
+
letterSpacing: number;
|
|
8
|
+
lineHeight: number;
|
|
9
|
+
align: number;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=props.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.d.ts","sourceRoot":"","sources":["../../../src/nodes/text/props.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,MAAM,WAAW,SAAU,SAAQ,UAAU;IACzC,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;CAEjB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.js","sourceRoot":"","sources":["../../../src/nodes/text/props.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { BoxBounds } from "@/attributes/bounds/bounds";
|
|
2
|
+
import { SizeConstraints } from "@/attributes/size/constraints";
|
|
3
|
+
import { Size2D } from "@/attributes/size/size";
|
|
4
|
+
import { DrawContext } from "@/rendering/contexts/draw-context";
|
|
5
|
+
import { Signal } from "@/signal/type";
|
|
6
|
+
import { BaseNode } from "../base/node";
|
|
7
|
+
import type { TransformProps } from "./props";
|
|
8
|
+
export declare abstract class TransformNode extends BaseNode {
|
|
9
|
+
private widthAuto;
|
|
10
|
+
private heightAuto;
|
|
11
|
+
private layoutAnchorX;
|
|
12
|
+
private layoutAnchorY;
|
|
13
|
+
private readonly xSignal;
|
|
14
|
+
private readonly ySignal;
|
|
15
|
+
private readonly widthSignal;
|
|
16
|
+
private readonly heightSignal;
|
|
17
|
+
private readonly scaleSignal;
|
|
18
|
+
private readonly rotateSignal;
|
|
19
|
+
private readonly opacitySignal;
|
|
20
|
+
private readonly blurSignal;
|
|
21
|
+
private readonly localXSignal;
|
|
22
|
+
private readonly localYSignal;
|
|
23
|
+
constructor(id: string, type: string, parentId: string | undefined, props: Partial<TransformProps>);
|
|
24
|
+
createSignalMap(): Record<string, Signal<any>>;
|
|
25
|
+
protected onBeforePropUpdate(key: string): void;
|
|
26
|
+
isAutoSize(axis: "width" | "height"): boolean;
|
|
27
|
+
setLayoutAnchor(x: number, y: number): void;
|
|
28
|
+
setLayoutTransform(props: Partial<Pick<TransformProps, "x" | "y" | "width" | "height">>): void;
|
|
29
|
+
get width(): number;
|
|
30
|
+
get height(): number;
|
|
31
|
+
get x(): number;
|
|
32
|
+
get y(): number;
|
|
33
|
+
get props(): TransformProps;
|
|
34
|
+
draw(ctx: DrawContext): void;
|
|
35
|
+
measure(constraints: SizeConstraints): Partial<Size2D>;
|
|
36
|
+
layout(rect: BoxBounds): void;
|
|
37
|
+
private createLayoutRelativeSignal;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/nodes/transform/node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAE9C,8BAAsB,aAAc,SAAQ,QAAQ;IAChD,OAAO,CAAC,SAAS,CAAU;IAC3B,OAAO,CAAC,UAAU,CAAU;IAC5B,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,aAAa,CAAS;IAE9B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAiB;IACzC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAiB;IACzC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAiB;IAC7C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAiB;IAC9C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAiB;IAC7C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAiB;IAC9C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAiB;IAC/C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAiB;IAE5C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAiB;IAC9C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAiB;gBAElC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,SAAS,EAAE,KAAK,EAAE,OAAO,CAAC,cAAc,CAAC;IAoBlG,eAAe,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;cAa3B,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IASxD,UAAU,CAAC,IAAI,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO;IAI7C,eAAe,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI;IAa3C,kBAAkB,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,GAAG,GAAG,GAAG,OAAO,GAAG,QAAQ,CAAC,CAAC,GAAG,IAAI;IAO9F,IAAI,KAAK,IAAI,MAAM,CAElB;IAED,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,IAAI,CAAC,IAAI,MAAM,CAEd;IAED,IAAI,CAAC,IAAI,MAAM,CAEd;IAED,IAAI,KAAK,IAAI,cAAc,CAW1B;IAED,IAAI,CAAC,GAAG,EAAE,WAAW;IAOrB,OAAO,CAAC,WAAW,EAAE,eAAe,GAAG,OAAO,CAAC,MAAM,CAAC;IAStD,MAAM,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI;IAoB7B,OAAO,CAAC,0BAA0B;CA6BrC"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import createSignal from "@/signal/signal";
|
|
2
|
+
import { BaseNode } from "../base/node";
|
|
3
|
+
export class TransformNode extends BaseNode {
|
|
4
|
+
widthAuto;
|
|
5
|
+
heightAuto;
|
|
6
|
+
layoutAnchorX;
|
|
7
|
+
layoutAnchorY;
|
|
8
|
+
xSignal;
|
|
9
|
+
ySignal;
|
|
10
|
+
widthSignal;
|
|
11
|
+
heightSignal;
|
|
12
|
+
scaleSignal;
|
|
13
|
+
rotateSignal;
|
|
14
|
+
opacitySignal;
|
|
15
|
+
blurSignal;
|
|
16
|
+
localXSignal;
|
|
17
|
+
localYSignal;
|
|
18
|
+
constructor(id, type, parentId, props) {
|
|
19
|
+
super(id, type, parentId);
|
|
20
|
+
this.widthAuto = props.width === undefined;
|
|
21
|
+
this.heightAuto = props.height === undefined;
|
|
22
|
+
this.layoutAnchorX = 0;
|
|
23
|
+
this.layoutAnchorY = 0;
|
|
24
|
+
this.xSignal = createSignal(props.x ?? 0);
|
|
25
|
+
this.ySignal = createSignal(props.y ?? 0);
|
|
26
|
+
this.widthSignal = createSignal(props.width ?? 0);
|
|
27
|
+
this.heightSignal = createSignal(props.height ?? 0);
|
|
28
|
+
this.scaleSignal = createSignal(props.scale ?? 1);
|
|
29
|
+
this.rotateSignal = createSignal(props.rotate ?? 0);
|
|
30
|
+
this.opacitySignal = createSignal(props.opacity ?? 1);
|
|
31
|
+
this.blurSignal = createSignal(props.blur ?? 0);
|
|
32
|
+
this.localXSignal = this.createLayoutRelativeSignal(this.xSignal, () => this.layoutAnchorX);
|
|
33
|
+
this.localYSignal = this.createLayoutRelativeSignal(this.ySignal, () => this.layoutAnchorY);
|
|
34
|
+
}
|
|
35
|
+
createSignalMap() {
|
|
36
|
+
return {
|
|
37
|
+
x: this.localXSignal,
|
|
38
|
+
y: this.localYSignal,
|
|
39
|
+
width: this.widthSignal,
|
|
40
|
+
height: this.heightSignal,
|
|
41
|
+
scale: this.scaleSignal,
|
|
42
|
+
rotate: this.rotateSignal,
|
|
43
|
+
opacity: this.opacitySignal,
|
|
44
|
+
blur: this.blurSignal,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
onBeforePropUpdate(key) {
|
|
48
|
+
if (key === "width") {
|
|
49
|
+
this.widthAuto = false;
|
|
50
|
+
}
|
|
51
|
+
if (key === "height") {
|
|
52
|
+
this.heightAuto = false;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
isAutoSize(axis) {
|
|
56
|
+
return axis === "width" ? this.widthAuto : this.heightAuto;
|
|
57
|
+
}
|
|
58
|
+
setLayoutAnchor(x, y) {
|
|
59
|
+
const relativeX = this.x - this.layoutAnchorX;
|
|
60
|
+
const relativeY = this.y - this.layoutAnchorY;
|
|
61
|
+
this.layoutAnchorX = x;
|
|
62
|
+
this.layoutAnchorY = y;
|
|
63
|
+
this.setLayoutTransform({
|
|
64
|
+
x: this.layoutAnchorX + relativeX,
|
|
65
|
+
y: this.layoutAnchorY + relativeY,
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
setLayoutTransform(props) {
|
|
69
|
+
if (props.x !== undefined)
|
|
70
|
+
this.xSignal.set(props.x);
|
|
71
|
+
if (props.y !== undefined)
|
|
72
|
+
this.ySignal.set(props.y);
|
|
73
|
+
if (props.width !== undefined)
|
|
74
|
+
this.widthSignal.set(props.width);
|
|
75
|
+
if (props.height !== undefined)
|
|
76
|
+
this.heightSignal.set(props.height);
|
|
77
|
+
}
|
|
78
|
+
get width() {
|
|
79
|
+
return this.widthSignal.get();
|
|
80
|
+
}
|
|
81
|
+
get height() {
|
|
82
|
+
return this.heightSignal.get();
|
|
83
|
+
}
|
|
84
|
+
get x() {
|
|
85
|
+
return this.xSignal.get();
|
|
86
|
+
}
|
|
87
|
+
get y() {
|
|
88
|
+
return this.ySignal.get();
|
|
89
|
+
}
|
|
90
|
+
get props() {
|
|
91
|
+
return {
|
|
92
|
+
x: this.xSignal.get(),
|
|
93
|
+
y: this.ySignal.get(),
|
|
94
|
+
width: this.widthSignal.get(),
|
|
95
|
+
height: this.heightSignal.get(),
|
|
96
|
+
scale: this.scaleSignal.get(),
|
|
97
|
+
rotate: this.rotateSignal.get(),
|
|
98
|
+
opacity: this.opacitySignal.get(),
|
|
99
|
+
blur: this.blurSignal.get(),
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
draw(ctx) {
|
|
103
|
+
ctx.withNode(this.id, this.parentId, () => {
|
|
104
|
+
ctx.transform(this.id, this.props);
|
|
105
|
+
this.drawSelf(ctx);
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
measure(constraints) {
|
|
109
|
+
const measuredWidth = this.width;
|
|
110
|
+
const measuredHeight = this.height;
|
|
111
|
+
return {
|
|
112
|
+
width: measuredWidth > 0 ? measuredWidth : constraints.maxWidth,
|
|
113
|
+
height: measuredHeight > 0 ? measuredHeight : constraints.maxHeight,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
layout(rect) {
|
|
117
|
+
this.rect = rect;
|
|
118
|
+
this.setLayoutAnchor(rect.x, rect.y);
|
|
119
|
+
this.setLayoutTransform({ width: rect.width, height: rect.height });
|
|
120
|
+
const constraints = {
|
|
121
|
+
maxWidth: rect.width,
|
|
122
|
+
maxHeight: rect.height,
|
|
123
|
+
};
|
|
124
|
+
this.children.forEach((child) => {
|
|
125
|
+
const size = child.measure(constraints);
|
|
126
|
+
child.layout({
|
|
127
|
+
x: 0,
|
|
128
|
+
y: 0,
|
|
129
|
+
width: size.width ?? rect.width,
|
|
130
|
+
height: size.height ?? rect.height,
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
createLayoutRelativeSignal(signal, getAnchor) {
|
|
135
|
+
const mapped = function (arg, duration, easing, lerp) {
|
|
136
|
+
if (arguments.length === 0)
|
|
137
|
+
return mapped.get();
|
|
138
|
+
if (arguments.length >= 2 && typeof duration === "number") {
|
|
139
|
+
return mapped.tween(arg, duration, easing, lerp);
|
|
140
|
+
}
|
|
141
|
+
return mapped.set(arg);
|
|
142
|
+
};
|
|
143
|
+
mapped.get = () => signal.get() - getAnchor();
|
|
144
|
+
mapped.set = (next) => {
|
|
145
|
+
if (typeof next === "function") {
|
|
146
|
+
const prev = mapped.get();
|
|
147
|
+
const local = next(prev);
|
|
148
|
+
signal.set(getAnchor() + local);
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
signal.set(getAnchor() + next);
|
|
152
|
+
};
|
|
153
|
+
mapped.subscribe = (subscriber) => signal.subscribe((value) => subscriber(value - getAnchor()));
|
|
154
|
+
mapped.tween = (next, duration, easing, lerp) => {
|
|
155
|
+
return signal.tween(getAnchor() + next, duration, easing, lerp);
|
|
156
|
+
};
|
|
157
|
+
return mapped;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
//# sourceMappingURL=node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.js","sourceRoot":"","sources":["../../../src/nodes/transform/node.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.d.ts","sourceRoot":"","sources":["../../../src/nodes/transform/props.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC3B,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CAEhB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.js","sourceRoot":"","sources":["../../../src/nodes/transform/props.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator.d.ts","sourceRoot":"","sources":["../../src/project/generator.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../src/project/generator.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/project/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/project/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Scene } from "./scene";
|
|
2
|
+
export interface Project {
|
|
3
|
+
scenes: ProjectScene[];
|
|
4
|
+
resolution: Resolution;
|
|
5
|
+
}
|
|
6
|
+
export interface ProjectScene {
|
|
7
|
+
name: string;
|
|
8
|
+
scene: Scene;
|
|
9
|
+
}
|
|
10
|
+
export type Resolution = {
|
|
11
|
+
width: number;
|
|
12
|
+
height: number;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=project.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.d.ts","sourceRoot":"","sources":["../../src/project/project.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAErC,MAAM,WAAW,OAAO;IACpB,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAC1B;AAED,MAAM,WAAW,YAAY;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,KAAK,CAAC;CAChB;AAED,MAAM,MAAM,UAAU,GAAG;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/project/project.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
export interface INode {
|
|
2
|
+
id: string;
|
|
3
|
+
type: string;
|
|
4
|
+
parentId?: string;
|
|
5
|
+
/** Initial attribute values merged with registry defaults. */
|
|
6
|
+
props: Record<string, any>;
|
|
7
|
+
}
|
|
8
|
+
export interface NodeState {
|
|
9
|
+
id: string;
|
|
10
|
+
/** Attribute overrides applied when this state is active. */
|
|
11
|
+
attrs: Record<string, any>;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* A single condition that must hold for a transition to fire.
|
|
15
|
+
*
|
|
16
|
+
* Built-in inputIds:
|
|
17
|
+
* - `"globalTime"` — global scene time in seconds
|
|
18
|
+
* - `"nodeTime"` — seconds since the machine's own node was created
|
|
19
|
+
*/
|
|
20
|
+
export interface TransitionCondition {
|
|
21
|
+
inputId: "globalTime";
|
|
22
|
+
gte: number;
|
|
23
|
+
}
|
|
24
|
+
export interface Transition {
|
|
25
|
+
id: string;
|
|
26
|
+
/** Source state id. `null` = transitions from ANY state. */
|
|
27
|
+
from: string | null;
|
|
28
|
+
to: string;
|
|
29
|
+
/** All conditions must hold simultaneously for the transition to fire. */
|
|
30
|
+
conditions: TransitionCondition[];
|
|
31
|
+
/** Animation duration in milliseconds. Defaults to 0 (instant snap). */
|
|
32
|
+
duration?: number;
|
|
33
|
+
ease?: string;
|
|
34
|
+
/** Higher priority wins when multiple transitions qualify simultaneously. */
|
|
35
|
+
priority?: number;
|
|
36
|
+
}
|
|
37
|
+
export interface StateMachine {
|
|
38
|
+
/** Id of the node this machine controls. */
|
|
39
|
+
nodeId: string;
|
|
40
|
+
states: NodeState[];
|
|
41
|
+
transitions: Transition[];
|
|
42
|
+
/** Id of the state the machine starts in. */
|
|
43
|
+
initial: string;
|
|
44
|
+
}
|
|
45
|
+
export interface Scene {
|
|
46
|
+
nodes: INode[];
|
|
47
|
+
machines?: StateMachine[];
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=scene.d.ts.map
|