@safe-engine/cocos 1.7.1 → 1.8.1
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/animation/AnimationComponent.d.ts +1 -1
- package/dist/animation/AnimationComponent.d.ts.map +1 -1
- package/dist/animation/AnimationComponent.js +2 -2
- package/dist/animation/AnimationSystem.js +1 -1
- package/dist/app.js +3 -3
- package/dist/box2d-wasm/PhysicsComponent.d.ts +1 -1
- package/dist/box2d-wasm/PhysicsComponent.d.ts.map +1 -1
- package/dist/box2d-wasm/PhysicsComponent.js +1 -1
- package/dist/collider/CollideComponent.d.ts +1 -1
- package/dist/collider/CollideComponent.d.ts.map +1 -1
- package/dist/collider/CollideComponent.js +1 -1
- package/dist/collider/CollideSystem.js +1 -1
- package/dist/collider/index.d.ts +1 -0
- package/dist/collider/index.d.ts.map +1 -1
- package/dist/collider/index.js +1 -0
- package/dist/dragonbones/index.d.ts +1 -1
- package/dist/dragonbones/index.d.ts.map +1 -1
- package/dist/dragonbones/index.js +2 -2
- package/dist/gui/GUIComponent.d.ts +93 -0
- package/dist/gui/GUIComponent.d.ts.map +1 -0
- package/dist/gui/GUIComponent.js +77 -0
- package/dist/gui/GUISystem.d.ts +15 -0
- package/dist/gui/GUISystem.d.ts.map +1 -0
- package/dist/gui/GUISystem.js +112 -0
- package/dist/gui/index.d.ts +3 -0
- package/dist/gui/index.d.ts.map +1 -0
- package/dist/gui/index.js +2 -0
- package/dist/gworld/EnhancedComponent.d.ts +22 -0
- package/dist/gworld/EnhancedComponent.d.ts.map +1 -0
- package/dist/gworld/EnhancedComponent.js +44 -0
- package/dist/gworld/NodeComp.d.ts +153 -0
- package/dist/gworld/NodeComp.d.ts.map +1 -0
- package/dist/gworld/NodeComp.js +337 -0
- package/dist/gworld/NodePool.d.ts +9 -0
- package/dist/gworld/NodePool.d.ts.map +1 -0
- package/dist/gworld/NodePool.js +23 -0
- package/dist/gworld/Scene.d.ts +5 -0
- package/dist/gworld/Scene.d.ts.map +1 -0
- package/dist/gworld/Scene.js +14 -0
- package/dist/gworld/components/CollideComponent.d.ts +2 -2
- package/dist/gworld/components/EnhancedComponent.d.ts +2 -2
- package/dist/gworld/components/GUIComponent.d.ts +4 -4
- package/dist/gworld/components/NoRenderComponent.d.ts +3 -3
- package/dist/gworld/components/NodeComp.d.ts +2 -2
- package/dist/gworld/components/RenderComponent.d.ts +4 -4
- package/dist/gworld/core/NodePool.d.ts +1 -1
- package/dist/gworld/core/Scene.d.ts +1 -1
- package/dist/gworld/core/decorator.d.ts +2 -2
- package/dist/gworld/decorator.d.ts +9 -0
- package/dist/gworld/decorator.d.ts.map +1 -0
- package/dist/gworld/decorator.js +13 -0
- package/dist/gworld/index.d.ts +5 -0
- package/dist/gworld/index.d.ts.map +1 -1
- package/dist/gworld/index.js +5 -0
- package/dist/index.d.ts +3 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -7
- package/dist/norender/NoRenderComponent.d.ts +37 -0
- package/dist/norender/NoRenderComponent.d.ts.map +1 -0
- package/dist/norender/NoRenderComponent.js +41 -0
- package/dist/norender/NoRenderSystem.d.ts +16 -0
- package/dist/norender/NoRenderSystem.d.ts.map +1 -0
- package/dist/norender/NoRenderSystem.js +75 -0
- package/dist/norender/index.d.ts +3 -0
- package/dist/norender/index.d.ts.map +1 -0
- package/dist/norender/index.js +2 -0
- package/dist/render/RenderComponent.d.ts +48 -0
- package/dist/render/RenderComponent.d.ts.map +1 -0
- package/dist/render/RenderComponent.js +80 -0
- package/dist/render/RenderSystem.d.ts +21 -0
- package/dist/render/RenderSystem.d.ts.map +1 -0
- package/dist/render/RenderSystem.js +74 -0
- package/dist/render/index.d.ts +3 -0
- package/dist/render/index.d.ts.map +1 -0
- package/dist/render/index.js +2 -0
- package/dist/richtext/RichTextComp.d.ts +1 -1
- package/dist/richtext/RichTextComp.d.ts.map +1 -1
- package/dist/richtext/RichTextComp.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { EnhancedComponent } from './EnhancedComponent';
|
|
2
|
+
import { NodeComp } from './NodeComp';
|
|
3
|
+
export declare class NoRenderComponentX<Props = object, C extends cc.Node = cc.Node> extends EnhancedComponent<Props, NodeComp<C>> {
|
|
4
|
+
static hasRender: boolean;
|
|
5
|
+
}
|
|
6
|
+
export declare class ComponentX<Props = object, C extends cc.Node = cc.Node> extends EnhancedComponent<Props, NodeComp<C>> {
|
|
7
|
+
render?(): this;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=decorator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"decorator.d.ts","sourceRoot":"","sources":["../../src/gworld/decorator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,qBAAa,kBAAkB,CAAC,KAAK,GAAG,MAAM,EAAE,CAAC,SAAS,EAAE,CAAC,IAAI,GAAG,EAAE,CAAC,IAAI,CAAE,SAAQ,iBAAiB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;IACxH,MAAM,CAAC,SAAS,UAAQ;CACzB;AAED,qBAAa,UAAU,CAAC,KAAK,GAAG,MAAM,EAAE,CAAC,SAAS,EAAE,CAAC,IAAI,GAAG,EAAE,CAAC,IAAI,CAAE,SAAQ,iBAAiB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;IAChH,MAAM,CAAC;CAMR"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { GameWorld } from '.';
|
|
2
|
+
import { EnhancedComponent } from './EnhancedComponent';
|
|
3
|
+
export class NoRenderComponentX extends EnhancedComponent {
|
|
4
|
+
static hasRender = false;
|
|
5
|
+
}
|
|
6
|
+
export class ComponentX extends EnhancedComponent {
|
|
7
|
+
render() {
|
|
8
|
+
const world = GameWorld.Instance;
|
|
9
|
+
const root = world.entities.create();
|
|
10
|
+
const comp = root.assign(this);
|
|
11
|
+
return comp;
|
|
12
|
+
}
|
|
13
|
+
}
|
package/dist/gworld/index.d.ts
CHANGED
|
@@ -1,4 +1,9 @@
|
|
|
1
1
|
import { Constructor, System, World } from 'entityx-ts';
|
|
2
|
+
export * from './decorator';
|
|
3
|
+
export * from './EnhancedComponent';
|
|
4
|
+
export * from './NodeComp';
|
|
5
|
+
export * from './NodePool';
|
|
6
|
+
export * from './Scene';
|
|
2
7
|
export declare class GameWorld extends World {
|
|
3
8
|
listUpdate: (System | Constructor<System>)[];
|
|
4
9
|
update(dt: number): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/gworld/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAEvD,qBAAa,SAAU,SAAQ,KAAK;IAClC,UAAU,EAAE,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE,CAAK;IACjD,MAAM,CAAC,EAAE,EAAE,MAAM;IAMjB,OAAO,CAAC,MAAM,CAAC,SAAS,CAAW;IAEnC,WAAkB,QAAQ,cAGzB;CACF"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/gworld/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAEvD,cAAc,aAAa,CAAA;AAC3B,cAAc,qBAAqB,CAAA;AACnC,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA;AAEvB,qBAAa,SAAU,SAAQ,KAAK;IAClC,UAAU,EAAE,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE,CAAK;IACjD,MAAM,CAAC,EAAE,EAAE,MAAM;IAMjB,OAAO,CAAC,MAAM,CAAC,SAAS,CAAW;IAEnC,WAAkB,QAAQ,cAGzB;CACF"}
|
package/dist/gworld/index.js
CHANGED
|
@@ -1,4 +1,9 @@
|
|
|
1
1
|
import { World } from 'entityx-ts';
|
|
2
|
+
export * from './decorator';
|
|
3
|
+
export * from './EnhancedComponent';
|
|
4
|
+
export * from './NodeComp';
|
|
5
|
+
export * from './NodePool';
|
|
6
|
+
export * from './Scene';
|
|
2
7
|
export class GameWorld extends World {
|
|
3
8
|
listUpdate = [];
|
|
4
9
|
update(dt) {
|
package/dist/index.d.ts
CHANGED
|
@@ -1,20 +1,16 @@
|
|
|
1
1
|
export * from './app';
|
|
2
2
|
export * from './collider';
|
|
3
3
|
export * from './dragonbones';
|
|
4
|
+
export * from './gui';
|
|
4
5
|
export * from './gworld';
|
|
5
|
-
export * from './gworld/components/GUIComponent';
|
|
6
|
-
export * from './gworld/components/NodeComp';
|
|
7
|
-
export * from './gworld/components/NoRenderComponent';
|
|
8
|
-
export * from './gworld/components/RenderComponent';
|
|
9
|
-
export * from './gworld/core/decorator';
|
|
10
|
-
export * from './gworld/core/Scene';
|
|
11
|
-
export * from './gworld/systems/GUISystem';
|
|
12
6
|
export * from './helper/action';
|
|
13
7
|
export * from './helper/director';
|
|
14
8
|
export * from './helper/math';
|
|
15
9
|
export * from './helper/utils';
|
|
10
|
+
export * from './norender';
|
|
16
11
|
export * from './polyfills';
|
|
17
12
|
export { type Touch } from './polyfills';
|
|
13
|
+
export * from './render';
|
|
18
14
|
export * from './richtext';
|
|
19
15
|
export * from './safex';
|
|
20
16
|
export * from './spine';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAA;AACrB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAC7B,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAA;AACrB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAC7B,cAAc,OAAO,CAAA;AACrB,cAAc,UAAU,CAAA;AACxB,cAAc,iBAAiB,CAAA;AAC/B,cAAc,mBAAmB,CAAA;AACjC,cAAc,eAAe,CAAA;AAC7B,cAAc,gBAAgB,CAAA;AAC9B,cAAc,YAAY,CAAA;AAC1B,cAAc,aAAa,CAAA;AAC3B,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,aAAa,CAAA;AACxC,cAAc,UAAU,CAAA;AACxB,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA;AACvB,cAAc,SAAS,CAAA"}
|
package/dist/index.js
CHANGED
|
@@ -1,19 +1,15 @@
|
|
|
1
1
|
export * from './app';
|
|
2
2
|
export * from './collider';
|
|
3
3
|
export * from './dragonbones';
|
|
4
|
+
export * from './gui';
|
|
4
5
|
export * from './gworld';
|
|
5
|
-
export * from './gworld/components/GUIComponent';
|
|
6
|
-
export * from './gworld/components/NodeComp';
|
|
7
|
-
export * from './gworld/components/NoRenderComponent';
|
|
8
|
-
export * from './gworld/components/RenderComponent';
|
|
9
|
-
export * from './gworld/core/decorator';
|
|
10
|
-
export * from './gworld/core/Scene';
|
|
11
|
-
export * from './gworld/systems/GUISystem';
|
|
12
6
|
export * from './helper/action';
|
|
13
7
|
export * from './helper/director';
|
|
14
8
|
export * from './helper/math';
|
|
15
9
|
export * from './helper/utils';
|
|
10
|
+
export * from './norender';
|
|
16
11
|
export * from './polyfills';
|
|
12
|
+
export * from './render';
|
|
17
13
|
export * from './richtext';
|
|
18
14
|
export * from './safex';
|
|
19
15
|
export * from './spine';
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { NoRenderComponentX, Touch } from "..";
|
|
2
|
+
import { EventCallbackType, NodeComp } from "../gworld";
|
|
3
|
+
type TouchEVentCallback = (touch?: Touch, node?: NodeComp) => void;
|
|
4
|
+
export interface EventMap {
|
|
5
|
+
[key: string]: [EventCallbackType];
|
|
6
|
+
}
|
|
7
|
+
export declare class EventRegister extends NoRenderComponentX {
|
|
8
|
+
events: EventMap;
|
|
9
|
+
on(name: string, callback: EventCallbackType, target?: any): void;
|
|
10
|
+
off(name: string, callback?: EventCallbackType, target?: any): any;
|
|
11
|
+
emit(name: string, ...params: any): void;
|
|
12
|
+
}
|
|
13
|
+
interface TouchEventProps {
|
|
14
|
+
onTouchStart?: TouchEVentCallback;
|
|
15
|
+
onTouchMove?: TouchEVentCallback;
|
|
16
|
+
onTouchEnd?: TouchEVentCallback;
|
|
17
|
+
onTouchCancel?: TouchEVentCallback;
|
|
18
|
+
}
|
|
19
|
+
export declare class TouchEventRegister extends NoRenderComponentX<TouchEventProps> {
|
|
20
|
+
listener: cc.EventListener;
|
|
21
|
+
touch: cc.Touch;
|
|
22
|
+
setEnabled(enabled: boolean): void;
|
|
23
|
+
}
|
|
24
|
+
interface ExtraDataProps {
|
|
25
|
+
key: string;
|
|
26
|
+
value: Integer | Float | string;
|
|
27
|
+
}
|
|
28
|
+
export declare class ExtraDataComp extends NoRenderComponentX<ExtraDataProps> {
|
|
29
|
+
data: {
|
|
30
|
+
[key: string]: any;
|
|
31
|
+
};
|
|
32
|
+
getData<T>(key: string): T;
|
|
33
|
+
setData<T>(key: string, val: T): void;
|
|
34
|
+
removeData(key: string): void;
|
|
35
|
+
}
|
|
36
|
+
export {};
|
|
37
|
+
//# sourceMappingURL=NoRenderComponent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NoRenderComponent.d.ts","sourceRoot":"","sources":["../../src/norender/NoRenderComponent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,KAAK,EAAE,MAAM,IAAI,CAAA;AAC9C,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAA;AAEvD,KAAK,kBAAkB,GAAG,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,QAAQ,KAAK,IAAI,CAAA;AAElE,MAAM,WAAW,QAAQ;IACvB,CAAC,GAAG,EAAE,MAAM,GAAG,CAAC,iBAAiB,CAAC,CAAA;CACnC;AAED,qBAAa,aAAc,SAAQ,kBAAkB;IACnD,MAAM,EAAE,QAAQ,CAAK;IAErB,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,CAAC,EAAE,GAAG;IAS1D,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,iBAAiB,EAAE,MAAM,CAAC,EAAE,GAAG;IAK5D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,GAAG;CAMlC;AAED,UAAU,eAAe;IACvB,YAAY,CAAC,EAAE,kBAAkB,CAAA;IACjC,WAAW,CAAC,EAAE,kBAAkB,CAAA;IAChC,UAAU,CAAC,EAAE,kBAAkB,CAAA;IAC/B,aAAa,CAAC,EAAE,kBAAkB,CAAA;CACnC;AACD,qBAAa,kBAAmB,SAAQ,kBAAkB,CAAC,eAAe,CAAC;IACzE,QAAQ,EAAE,EAAE,CAAC,aAAa,CAAA;IAC1B,KAAK,EAAE,EAAE,CAAC,KAAK,CAAA;IACf,UAAU,CAAC,OAAO,EAAE,OAAO;CAG5B;AAED,UAAU,cAAc;IACtB,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,OAAO,GAAG,KAAK,GAAG,MAAM,CAAA;CAChC;AACD,qBAAa,aAAc,SAAQ,kBAAkB,CAAC,cAAc,CAAC;IACnE,IAAI,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAE,CAAK;IACjC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,GAAG,CAAC;IAG1B,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;IAG9B,UAAU,CAAC,GAAG,EAAE,MAAM;CAGvB"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { NoRenderComponentX } from "..";
|
|
2
|
+
export class EventRegister extends NoRenderComponentX {
|
|
3
|
+
events = {};
|
|
4
|
+
on(name, callback, target) {
|
|
5
|
+
const bound = target ? callback.bind(target) : callback;
|
|
6
|
+
if (this.events[name]) {
|
|
7
|
+
this.events[name].push(bound);
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
this.events[name] = [bound];
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
off(name) {
|
|
14
|
+
this.events[name] = undefined;
|
|
15
|
+
}
|
|
16
|
+
emit(name, ...params) {
|
|
17
|
+
// if (!this.node || !this.node.active || !this.enabled) return
|
|
18
|
+
if (this.events[name]) {
|
|
19
|
+
this.events[name].forEach((fc) => fc(...params));
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export class TouchEventRegister extends NoRenderComponentX {
|
|
24
|
+
listener;
|
|
25
|
+
touch;
|
|
26
|
+
setEnabled(enabled) {
|
|
27
|
+
this.listener.setEnabled(enabled);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
export class ExtraDataComp extends NoRenderComponentX {
|
|
31
|
+
data = {};
|
|
32
|
+
getData(key) {
|
|
33
|
+
return this.data[key];
|
|
34
|
+
}
|
|
35
|
+
setData(key, val) {
|
|
36
|
+
this.data[key] = val;
|
|
37
|
+
}
|
|
38
|
+
removeData(key) {
|
|
39
|
+
delete this.data[key];
|
|
40
|
+
}
|
|
41
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EntityManager, EventManager, System } from 'entityx-ts';
|
|
2
|
+
export declare class NoRenderSystem implements System {
|
|
3
|
+
configure(event_manager: EventManager): void;
|
|
4
|
+
onAddTouchEventRegister: ({ entity, component }: {
|
|
5
|
+
entity: any;
|
|
6
|
+
component: any;
|
|
7
|
+
}) => void;
|
|
8
|
+
onAddExtraDataComp: ({ component }: {
|
|
9
|
+
component: any;
|
|
10
|
+
}) => void;
|
|
11
|
+
onRemovedTouchEventRegister: ({ component }: {
|
|
12
|
+
component: any;
|
|
13
|
+
}) => void;
|
|
14
|
+
update(entities: EntityManager, events: EventManager, dt: number): any;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=NoRenderSystem.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NoRenderSystem.d.ts","sourceRoot":"","sources":["../../src/norender/NoRenderSystem.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAc,MAAM,EAAE,MAAM,YAAY,CAAA;AAM5E,qBAAa,cAAe,YAAW,MAAM;IAC3C,SAAS,CAAC,aAAa,EAAE,YAAY;IAMrC,uBAAuB,GAAI;;;KAAqB,UAiD/C;IAED,kBAAkB,GAAI;;KAAa,UAIlC;IAED,2BAA2B,GAAI;;KAAa,UAM3C;IAED,MAAM,CAAC,QAAQ,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,EAAE,MAAM;CAIjE"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { EventTypes } from 'entityx-ts';
|
|
2
|
+
import { NodeComp } from '../gworld/NodeComp';
|
|
3
|
+
import { ExtraDataComp, TouchEventRegister } from './NoRenderComponent';
|
|
4
|
+
export class NoRenderSystem {
|
|
5
|
+
configure(event_manager) {
|
|
6
|
+
event_manager.subscribe(EventTypes.ComponentAdded, ExtraDataComp, this.onAddExtraDataComp);
|
|
7
|
+
event_manager.subscribe(EventTypes.ComponentAdded, TouchEventRegister, this.onAddTouchEventRegister);
|
|
8
|
+
event_manager.subscribe(EventTypes.ComponentRemoved, TouchEventRegister, this.onRemovedTouchEventRegister);
|
|
9
|
+
}
|
|
10
|
+
onAddTouchEventRegister = ({ entity, component }) => {
|
|
11
|
+
const ett = entity;
|
|
12
|
+
const touchComp = component;
|
|
13
|
+
const nodeComp = ett.getComponent(NodeComp);
|
|
14
|
+
touchComp.node = nodeComp;
|
|
15
|
+
touchComp.listener = cc.eventManager.addListener({
|
|
16
|
+
event: cc.EventListener.TOUCH_ONE_BY_ONE,
|
|
17
|
+
swallowTouches: true,
|
|
18
|
+
onTouchBegan: function (touch) {
|
|
19
|
+
const { onTouchStart } = touchComp.props;
|
|
20
|
+
// console.log('onTouchBegan', onTouchStart)
|
|
21
|
+
if (!nodeComp.parent) {
|
|
22
|
+
if (onTouchStart) {
|
|
23
|
+
onTouchStart(touch, nodeComp);
|
|
24
|
+
}
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
const p = touch.getLocation();
|
|
28
|
+
const rect = nodeComp.getBoundingBox();
|
|
29
|
+
const nodeSpaceLocation = nodeComp.parent.convertToNodeSpace(p);
|
|
30
|
+
if (rect.contains(nodeSpaceLocation)) {
|
|
31
|
+
if (onTouchStart) {
|
|
32
|
+
onTouchStart(touch, nodeComp);
|
|
33
|
+
}
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
onTouchMoved: function (touch) {
|
|
38
|
+
const { onTouchMove } = touchComp.props;
|
|
39
|
+
if (!onTouchMove)
|
|
40
|
+
return false;
|
|
41
|
+
onTouchMove(touch, nodeComp);
|
|
42
|
+
return true;
|
|
43
|
+
},
|
|
44
|
+
onTouchEnded: function (touch) {
|
|
45
|
+
const { onTouchEnd } = touchComp.props;
|
|
46
|
+
if (!onTouchEnd)
|
|
47
|
+
return false;
|
|
48
|
+
onTouchEnd(touch, nodeComp);
|
|
49
|
+
return true;
|
|
50
|
+
},
|
|
51
|
+
onTouchCancelled: function (touch) {
|
|
52
|
+
const { onTouchCancel } = touchComp.props;
|
|
53
|
+
if (!onTouchCancel)
|
|
54
|
+
return false;
|
|
55
|
+
onTouchCancel(touch, nodeComp);
|
|
56
|
+
return true;
|
|
57
|
+
},
|
|
58
|
+
}, nodeComp.instance);
|
|
59
|
+
};
|
|
60
|
+
onAddExtraDataComp = ({ component }) => {
|
|
61
|
+
const extra = component;
|
|
62
|
+
const { key, value } = extra.props;
|
|
63
|
+
extra.data[key] = value;
|
|
64
|
+
};
|
|
65
|
+
onRemovedTouchEventRegister = ({ component }) => {
|
|
66
|
+
const touchComp = component;
|
|
67
|
+
if (touchComp.listener) {
|
|
68
|
+
cc.eventManager.removeListener(touchComp.listener);
|
|
69
|
+
touchComp.listener = null;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
update() {
|
|
73
|
+
// throw new Error('Method not implemented.');
|
|
74
|
+
}
|
|
75
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/norender/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA;AACnC,cAAc,kBAAkB,CAAA"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { BaseComponentProps, ColorSource, ComponentX } from "..";
|
|
2
|
+
import { Color4B, Vec2 } from "../polyfills";
|
|
3
|
+
export declare class NodeRender extends ComponentX {
|
|
4
|
+
nodeName: string;
|
|
5
|
+
}
|
|
6
|
+
interface SpriteRenderProps {
|
|
7
|
+
spriteFrame: string;
|
|
8
|
+
texType?: number;
|
|
9
|
+
type?: number;
|
|
10
|
+
}
|
|
11
|
+
export declare class SpriteRender extends ComponentX<SpriteRenderProps & BaseComponentProps<SpriteRender>, cc.Sprite> {
|
|
12
|
+
get spriteFrame(): string;
|
|
13
|
+
set spriteFrame(frame: string);
|
|
14
|
+
}
|
|
15
|
+
interface MaskRenderProps {
|
|
16
|
+
type?: number;
|
|
17
|
+
segments?: number;
|
|
18
|
+
inverted?: boolean;
|
|
19
|
+
}
|
|
20
|
+
export declare class MaskRender extends ComponentX<MaskRenderProps, cc.ClippingNode> {
|
|
21
|
+
}
|
|
22
|
+
interface ParticleCompProps {
|
|
23
|
+
plistFile: string;
|
|
24
|
+
}
|
|
25
|
+
export declare class ParticleComp extends ComponentX<ParticleCompProps, cc.ParticleSystem> {
|
|
26
|
+
}
|
|
27
|
+
interface GraphicsRenderProps {
|
|
28
|
+
lineWidth?: number;
|
|
29
|
+
strokeColor?: ColorSource;
|
|
30
|
+
fillColor?: ColorSource;
|
|
31
|
+
}
|
|
32
|
+
export declare class GraphicsRender extends ComponentX<GraphicsRenderProps & BaseComponentProps<GraphicsRender>, cc.DrawNode> {
|
|
33
|
+
drawDot(x: any, y: any, r: any): void;
|
|
34
|
+
drawLine(origin: Vec2, destination: Vec2, thickness?: Float, color?: Color4B): void;
|
|
35
|
+
drawRect(origin: Vec2, destination: Vec2, color?: Color4B): void;
|
|
36
|
+
drawCircle(center: Vec2, radius: Float, angle?: number, segments?: number, drawLineToCenter?: boolean, lineWidth?: Float, color?: Color4B): void;
|
|
37
|
+
drawPoly(points: Vec2[], color?: Color4B, thickness?: Float): void;
|
|
38
|
+
clear(): void;
|
|
39
|
+
}
|
|
40
|
+
interface TiledMapProps {
|
|
41
|
+
mapFile: string;
|
|
42
|
+
}
|
|
43
|
+
export declare class TiledMap extends ComponentX<TiledMapProps & {
|
|
44
|
+
$ref?: TiledMap;
|
|
45
|
+
}, cc.TMXTiledMap> {
|
|
46
|
+
}
|
|
47
|
+
export {};
|
|
48
|
+
//# sourceMappingURL=RenderComponent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RenderComponent.d.ts","sourceRoot":"","sources":["../../src/render/RenderComponent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,IAAI,CAAA;AAChE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAE5C,qBAAa,UAAW,SAAQ,UAAU;IACxC,QAAQ,EAAE,MAAM,CAAA;CACjB;AAED,UAAU,iBAAiB;IACzB,WAAW,EAAE,MAAM,CAAA;IACnB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAED,qBAAa,YAAa,SAAQ,UAAU,CAAC,iBAAiB,GAAG,kBAAkB,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC;IAC3G,IAAI,WAAW,WAEd;IAED,IAAI,WAAW,CAAC,KAAK,QAAA,EAepB;CACF;AACD,UAAU,eAAe;IACvB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AACD,qBAAa,UAAW,SAAQ,UAAU,CAAC,eAAe,EAAE,EAAE,CAAC,YAAY,CAAC;CAAI;AAEhF,UAAU,iBAAiB;IACzB,SAAS,EAAE,MAAM,CAAA;CAClB;AACD,qBAAa,YAAa,SAAQ,UAAU,CAAC,iBAAiB,EAAE,EAAE,CAAC,cAAc,CAAC;CAAI;AAEtF,UAAU,mBAAmB;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,WAAW,CAAC,EAAE,WAAW,CAAA;IACzB,SAAS,CAAC,EAAE,WAAW,CAAA;CACxB;AAED,qBAAa,cAAe,SAAQ,UAAU,CAAC,mBAAmB,GAAG,kBAAkB,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC;IAEnH,OAAO,CAAC,CAAC,KAAA,EAAE,CAAC,KAAA,EAAE,CAAC,KAAA;IASf,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,SAAS,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE,OAAO;IAG5E,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,CAAC,EAAE,OAAO;IAMzD,UAAU,CACR,MAAM,EAAE,IAAI,EACZ,MAAM,EAAE,KAAK,EACb,KAAK,SAAI,EACT,QAAQ,SAAK,EACb,gBAAgB,UAAO,EACvB,SAAS,CAAC,EAAE,KAAK,EACjB,KAAK,CAAC,EAAE,OAAO;IAkBjB,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,KAAK;IAe3D,KAAK;CAKN;AAED,UAAU,aAAa;IACrB,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,qBAAa,QAAS,SAAQ,UAAU,CAAC,aAAa,GAAG;IAAE,IAAI,CAAC,EAAE,QAAQ,CAAA;CAAE,EAAE,EAAE,CAAC,WAAW,CAAC;CAAI"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { ComponentX } from "..";
|
|
2
|
+
export class NodeRender extends ComponentX {
|
|
3
|
+
nodeName;
|
|
4
|
+
}
|
|
5
|
+
export class SpriteRender extends ComponentX {
|
|
6
|
+
get spriteFrame() {
|
|
7
|
+
return this.props.spriteFrame;
|
|
8
|
+
}
|
|
9
|
+
set spriteFrame(frame) {
|
|
10
|
+
this.props.spriteFrame = frame;
|
|
11
|
+
if (this.node && this.node.instance instanceof cc.Sprite) {
|
|
12
|
+
this.node.instance.setTexture(frame);
|
|
13
|
+
}
|
|
14
|
+
// } else if (this.node.instance instanceof ccui.ImageView) {
|
|
15
|
+
// if (this.texType) {
|
|
16
|
+
// this.node.instance.loadTexture(frame, this.texType)
|
|
17
|
+
// } else {
|
|
18
|
+
// this.node.instance.loadTexture(frame)
|
|
19
|
+
// }
|
|
20
|
+
// const sprite = new cc.Sprite(frame)
|
|
21
|
+
// this.node.setContentSize(sprite.getContentSize())
|
|
22
|
+
// } else if (this.node.instance instanceof ccui.Button) {
|
|
23
|
+
// this.node.instance.loadTextureNormal(frame)
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export class MaskRender extends ComponentX {
|
|
27
|
+
}
|
|
28
|
+
export class ParticleComp extends ComponentX {
|
|
29
|
+
}
|
|
30
|
+
export class GraphicsRender extends ComponentX {
|
|
31
|
+
drawDot(x, y, r) {
|
|
32
|
+
this.node.instance.drawDot(cc.p(x, y), r, this.props.fillColor);
|
|
33
|
+
}
|
|
34
|
+
// drawPoint(position: Vec2, pointSize: Float, color: Color4B, pointType = PointType.Rect) {
|
|
35
|
+
// }
|
|
36
|
+
// // drawPoints(points: Vec2[], color: Color4B) {
|
|
37
|
+
// // }
|
|
38
|
+
drawLine(origin, destination, thickness, color) {
|
|
39
|
+
this.node.instance.drawSegment(origin, destination, thickness || this.props.lineWidth, color || this.props.strokeColor);
|
|
40
|
+
}
|
|
41
|
+
drawRect(origin, destination, color) {
|
|
42
|
+
this.node.instance.drawRect(origin, destination, color || this.props.fillColor);
|
|
43
|
+
}
|
|
44
|
+
// drawSolidRect(origin: Vec2, destination: Vec2, color: Color4B) {
|
|
45
|
+
// }
|
|
46
|
+
drawCircle(center, radius, angle = 0, segments = 64, drawLineToCenter = true, lineWidth, color) {
|
|
47
|
+
this.node.instance.drawCircle(center, radius, angle, segments, drawLineToCenter, lineWidth || this.props.lineWidth, color || this.props.fillColor);
|
|
48
|
+
}
|
|
49
|
+
// drawSolidCircle(origin: Vec2, destination: Vec2, color: Color4B) {
|
|
50
|
+
// }
|
|
51
|
+
// drawQuadBezier(origin: Vec2, destination: Vec2, color: Color4B) {
|
|
52
|
+
// }
|
|
53
|
+
// drawCubicBezier(origin: Vec2, destination: Vec2, color: Color4B) {
|
|
54
|
+
// }
|
|
55
|
+
// drawCardinalSpline(points: Vec2[], color: Color4B) {
|
|
56
|
+
// }
|
|
57
|
+
// drawCatmullRom(points: Vec2[], color: Color4B) {
|
|
58
|
+
// }
|
|
59
|
+
drawPoly(points, color, thickness) {
|
|
60
|
+
this.node.instance.drawPoly(points, color || this.props.fillColor, thickness || this.props.lineWidth);
|
|
61
|
+
}
|
|
62
|
+
// drawSolidPoly(points: Vec2[], color: Color4B) {
|
|
63
|
+
// this.node.instance.drawPoly(points, color)
|
|
64
|
+
// }
|
|
65
|
+
// drawDot(points: Vec2[], color: Color4B) {
|
|
66
|
+
// }
|
|
67
|
+
// drawSegment(from: Vec2, to: Vec2, color: Color4B) {
|
|
68
|
+
// }
|
|
69
|
+
// drawTriangle(p1: Vec2, p2: Vec2, p3: Vec2, color: Color4B) {
|
|
70
|
+
// this.node.instance.poly([p1, p2, p3], true)
|
|
71
|
+
// this.node.instance.fill(color)
|
|
72
|
+
// }
|
|
73
|
+
clear() {
|
|
74
|
+
if (this.node.instance instanceof cc.DrawNode) {
|
|
75
|
+
this.node.instance.clear();
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
export class TiledMap extends ComponentX {
|
|
80
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { EntityManager, EventManager, System } from 'entityx-ts';
|
|
2
|
+
export declare enum SpriteTypes {
|
|
3
|
+
SIMPLE = 0,
|
|
4
|
+
SLICED = 1,
|
|
5
|
+
TILED = 2,
|
|
6
|
+
FILLED = 3,
|
|
7
|
+
MESH = 4,
|
|
8
|
+
ANIMATION = 5
|
|
9
|
+
}
|
|
10
|
+
export declare class RenderSystem implements System {
|
|
11
|
+
configure(event_manager: EventManager): void;
|
|
12
|
+
private onAddNodeRender;
|
|
13
|
+
private onAddSpriteRender;
|
|
14
|
+
private onAddMaskRender;
|
|
15
|
+
private onAddGraphicsRender;
|
|
16
|
+
private onAddParticleComp;
|
|
17
|
+
private onAddTiledMap;
|
|
18
|
+
private onRemovedNodeComp;
|
|
19
|
+
update(entities: EntityManager, events: EventManager, dt: number): any;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=RenderSystem.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RenderSystem.d.ts","sourceRoot":"","sources":["../../src/render/RenderSystem.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,YAAY,EAAoC,MAAM,EAAE,MAAM,YAAY,CAAA;AAMlG,oBAAY,WAAW;IACrB,MAAM,IAAA;IACN,MAAM,IAAA;IACN,KAAK,IAAA;IACL,MAAM,IAAA;IACN,IAAI,IAAA;IACJ,SAAS,IAAA;CACV;AAED,qBAAa,YAAa,YAAW,MAAM;IACzC,SAAS,CAAC,aAAa,EAAE,YAAY;IAUrC,OAAO,CAAC,eAAe,CAKtB;IAED,OAAO,CAAC,iBAAiB,CAOxB;IAED,OAAO,CAAC,eAAe,CAKtB;IAED,OAAO,CAAC,mBAAmB,CAQ1B;IAED,OAAO,CAAC,iBAAiB,CAKxB;IAED,OAAO,CAAC,aAAa,CAKpB;IAED,OAAO,CAAC,iBAAiB,CAKxB;IAED,MAAM,CAAC,QAAQ,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,EAAE,MAAM;CAIjE"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { EventTypes } from 'entityx-ts';
|
|
2
|
+
import { NodeComp } from '../gworld/NodeComp';
|
|
3
|
+
import { BLUE, RED } from '../polyfills';
|
|
4
|
+
import { GraphicsRender, MaskRender, NodeRender, ParticleComp, SpriteRender, TiledMap } from './RenderComponent';
|
|
5
|
+
export var SpriteTypes;
|
|
6
|
+
(function (SpriteTypes) {
|
|
7
|
+
SpriteTypes[SpriteTypes["SIMPLE"] = 0] = "SIMPLE";
|
|
8
|
+
SpriteTypes[SpriteTypes["SLICED"] = 1] = "SLICED";
|
|
9
|
+
SpriteTypes[SpriteTypes["TILED"] = 2] = "TILED";
|
|
10
|
+
SpriteTypes[SpriteTypes["FILLED"] = 3] = "FILLED";
|
|
11
|
+
SpriteTypes[SpriteTypes["MESH"] = 4] = "MESH";
|
|
12
|
+
SpriteTypes[SpriteTypes["ANIMATION"] = 5] = "ANIMATION";
|
|
13
|
+
})(SpriteTypes || (SpriteTypes = {}));
|
|
14
|
+
export class RenderSystem {
|
|
15
|
+
configure(event_manager) {
|
|
16
|
+
event_manager.subscribe(EventTypes.ComponentAdded, NodeRender, this.onAddNodeRender);
|
|
17
|
+
event_manager.subscribe(EventTypes.ComponentAdded, SpriteRender, this.onAddSpriteRender);
|
|
18
|
+
event_manager.subscribe(EventTypes.ComponentAdded, MaskRender, this.onAddMaskRender);
|
|
19
|
+
event_manager.subscribe(EventTypes.ComponentAdded, GraphicsRender, this.onAddGraphicsRender);
|
|
20
|
+
event_manager.subscribe(EventTypes.ComponentAdded, ParticleComp, this.onAddParticleComp);
|
|
21
|
+
event_manager.subscribe(EventTypes.ComponentAdded, TiledMap, this.onAddTiledMap);
|
|
22
|
+
event_manager.subscribe(EventTypes.ComponentRemoved, NodeComp, this.onRemovedNodeComp);
|
|
23
|
+
}
|
|
24
|
+
onAddNodeRender = ({ entity }) => {
|
|
25
|
+
const nodeRenderComp = entity.getComponent(NodeRender);
|
|
26
|
+
const node = new cc.Node();
|
|
27
|
+
const ett = entity;
|
|
28
|
+
nodeRenderComp.node = ett.assign(new NodeComp(node, ett));
|
|
29
|
+
};
|
|
30
|
+
onAddSpriteRender = ({ entity, component: spriteComp }) => {
|
|
31
|
+
const { spriteFrame } = spriteComp.props;
|
|
32
|
+
const frame = cc.spriteFrameCache.getSpriteFrame(spriteFrame);
|
|
33
|
+
// console.log('frame', spriteFrame, frame)
|
|
34
|
+
const node = new cc.Sprite(frame || spriteFrame);
|
|
35
|
+
const ett = entity;
|
|
36
|
+
spriteComp.node = ett.assign(new NodeComp(node, ett));
|
|
37
|
+
};
|
|
38
|
+
onAddMaskRender = ({ entity, component: maskComp }) => {
|
|
39
|
+
const { inverted } = maskComp.props;
|
|
40
|
+
const node = new cc.ClippingNode();
|
|
41
|
+
node.setInverted(inverted);
|
|
42
|
+
maskComp.node = entity.assign(new NodeComp(node, entity));
|
|
43
|
+
};
|
|
44
|
+
onAddGraphicsRender = ({ entity }) => {
|
|
45
|
+
const graphicsComp = entity.getComponent(GraphicsRender);
|
|
46
|
+
const { lineWidth = 5, strokeColor = RED, fillColor = BLUE } = graphicsComp.props;
|
|
47
|
+
const node = new cc.DrawNode();
|
|
48
|
+
node.setColor(strokeColor);
|
|
49
|
+
node.setDrawColor(fillColor);
|
|
50
|
+
node.setLineWidth(lineWidth);
|
|
51
|
+
graphicsComp.node = entity.assign(new NodeComp(node, entity));
|
|
52
|
+
};
|
|
53
|
+
onAddParticleComp = ({ entity }) => {
|
|
54
|
+
const particleComp = entity.getComponent(ParticleComp);
|
|
55
|
+
const { plistFile } = particleComp.props;
|
|
56
|
+
const node = new cc.ParticleSystem(plistFile);
|
|
57
|
+
particleComp.node = entity.assign(new NodeComp(node, entity));
|
|
58
|
+
};
|
|
59
|
+
onAddTiledMap = ({ entity }) => {
|
|
60
|
+
const tiledMapComp = entity.getComponent(TiledMap);
|
|
61
|
+
const { mapFile } = tiledMapComp.props;
|
|
62
|
+
const node = new cc.TMXTiledMap(mapFile);
|
|
63
|
+
tiledMapComp.node = entity.assign(new NodeComp(node, entity));
|
|
64
|
+
};
|
|
65
|
+
onRemovedNodeComp = ({ component }) => {
|
|
66
|
+
const node = component;
|
|
67
|
+
if (node.instance) {
|
|
68
|
+
node.instance.removeFromParent(true);
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
update() {
|
|
72
|
+
// throw new Error('Method not implemented.');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/render/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA;AACjC,cAAc,gBAAgB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RichTextComp.d.ts","sourceRoot":"","sources":["../../src/richtext/RichTextComp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"RichTextComp.d.ts","sourceRoot":"","sources":["../../src/richtext/RichTextComp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAA;AAK7C,UAAU,iBAAiB;IACzB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAED,qBAAa,YAAa,SAAQ,UAAU,CAAC,iBAAiB,GAAG,kBAAkB,CAAC,YAAY,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC;IAC/G,IAAI,MAAM,IAIM,MAAM,CAFrB;IAED,IAAI,MAAM,CAAC,GAAG,EAAE,MAAM,EAoBrB;CACF"}
|