@awesome-ecs/abstract 0.1.3 → 0.2.2

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.
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=component.js.map
@@ -1,5 +1,8 @@
1
- export var BasicComponentType;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BasicComponentType = void 0;
4
+ var BasicComponentType;
2
5
  (function (BasicComponentType) {
3
6
  BasicComponentType["identity"] = "identity";
4
- })(BasicComponentType || (BasicComponentType = {}));
7
+ })(BasicComponentType = exports.BasicComponentType || (exports.BasicComponentType = {}));
5
8
  //# sourceMappingURL=identity-component.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"identity-component.js","sourceRoot":"","sources":["../../src/components/identity-component.ts"],"names":[],"mappings":"AAIA,MAAM,CAAN,IAAY,kBAEX;AAFD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;AACvB,CAAC,EAFW,kBAAkB,KAAlB,kBAAkB,QAE7B"}
1
+ {"version":3,"file":"identity-component.js","sourceRoot":"","sources":["../../src/components/identity-component.ts"],"names":[],"mappings":";;;AAIA,IAAY,kBAEX;AAFD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;AACvB,CAAC,EAFW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAE7B"}
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=entity-proxy.js.map
@@ -1,3 +1,4 @@
1
+ import { EntityTriggerUid } from "..";
1
2
  import { IEntityModel } from "./entity";
2
3
  import { IEntityProxy } from "./entity-proxy";
3
4
  import { IEntityTrigger, ITriggerData } from "./entity-trigger";
@@ -15,7 +16,7 @@ export interface IEntityUpdate {
15
16
  type: EntityUpdateType;
16
17
  entity: IEntityProxy;
17
18
  model?: IEntityModel;
18
- trigger?: IEntityTrigger<ITriggerData>;
19
+ triggers?: Map<EntityTriggerUid, IEntityTrigger<ITriggerData>>;
19
20
  forceUpdate?: boolean;
20
21
  }
21
22
  /**
@@ -1,9 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EntityUpdateType = void 0;
1
4
  /**
2
5
  * The Entity update state for this change.
3
6
  */
4
- export var EntityUpdateType;
7
+ var EntityUpdateType;
5
8
  (function (EntityUpdateType) {
6
9
  EntityUpdateType["update"] = "update";
7
10
  EntityUpdateType["remove"] = "remove";
8
- })(EntityUpdateType || (EntityUpdateType = {}));
11
+ })(EntityUpdateType = exports.EntityUpdateType || (exports.EntityUpdateType = {}));
9
12
  //# sourceMappingURL=entity-queue.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"entity-queue.js","sourceRoot":"","sources":["../../src/entities/entity-queue.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,MAAM,CAAN,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,qCAAiB,CAAA;AACnB,CAAC,EAHW,gBAAgB,KAAhB,gBAAgB,QAG3B"}
1
+ {"version":3,"file":"entity-queue.js","sourceRoot":"","sources":["../../src/entities/entity-queue.ts"],"names":[],"mappings":";;;AAKA;;GAEG;AACH,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,qCAAiB,CAAA;AACnB,CAAC,EAHW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAG3B"}
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=entity-repository.js.map
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=entity-scheduler.js.map
@@ -2,7 +2,8 @@ import { IEntityProxy } from "./entity-proxy";
2
2
  import { EntityUpdateType } from "./entity-queue";
3
3
  export declare type EntityTriggerUid = string | number;
4
4
  export interface ITriggerData {
5
- action: EntityUpdateType;
5
+ uid: EntityTriggerUid;
6
+ action?: EntityUpdateType;
6
7
  }
7
8
  /**
8
9
  * Entity Triggers represent a basic inter-Entity messaging mechanism.
@@ -11,7 +12,6 @@ export interface ITriggerData {
11
12
  * The Triggers will be enqueued as part of an Entity Update envelope.
12
13
  */
13
14
  export interface IEntityTrigger<TTriggerData extends ITriggerData> {
14
- uid: EntityTriggerUid;
15
15
  origin: IEntityProxy;
16
16
  data: TTriggerData;
17
17
  }
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=entity-trigger.js.map
@@ -13,6 +13,7 @@ export interface IEntityModel {
13
13
  export interface IEntity {
14
14
  readonly components: Map<ComponentUid, IComponent>;
15
15
  readonly proxies: Map<EntityTypeUid, Map<EntityUid, IEntityProxy>>;
16
- readonly triggers: Map<EntityTriggerUid, IEntityTrigger<ITriggerData>>;
16
+ readonly triggers: Map<EntityTriggerUid, IEntityTrigger<ITriggerData>[]>;
17
17
  readonly identity: IdentityComponent<IEntityModel>;
18
+ readonly myProxy: IEntityProxy;
18
19
  }
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=entity.js.map
package/dist/index.js CHANGED
@@ -1,17 +1,29 @@
1
- export * from './components/component';
2
- export * from './components/identity-component';
3
- export * from './entities/entity';
4
- export * from './entities/entity-proxy';
5
- export * from './entities/entity-queue';
6
- export * from './entities/entity-repository';
7
- export * from './entities/entity-scheduler';
8
- export * from './entities/entity-trigger';
9
- export * from './pipelines/middleware';
10
- export * from './pipelines/pipeline';
11
- export * from './systems/system-middleware';
12
- export * from './systems/system-pipeline';
13
- export * from './systems/system-pipeline-context';
14
- export * from './systems/system-pipeline-type';
15
- export * from './systems/system-runtime';
16
- export * from './utils/performance-timer';
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./components/component"), exports);
14
+ __exportStar(require("./components/identity-component"), exports);
15
+ __exportStar(require("./entities/entity"), exports);
16
+ __exportStar(require("./entities/entity-proxy"), exports);
17
+ __exportStar(require("./entities/entity-queue"), exports);
18
+ __exportStar(require("./entities/entity-repository"), exports);
19
+ __exportStar(require("./entities/entity-scheduler"), exports);
20
+ __exportStar(require("./entities/entity-trigger"), exports);
21
+ __exportStar(require("./pipelines/middleware"), exports);
22
+ __exportStar(require("./pipelines/pipeline"), exports);
23
+ __exportStar(require("./systems/system-middleware"), exports);
24
+ __exportStar(require("./systems/system-pipeline"), exports);
25
+ __exportStar(require("./systems/system-pipeline-context"), exports);
26
+ __exportStar(require("./systems/system-pipeline-type"), exports);
27
+ __exportStar(require("./systems/system-runtime"), exports);
28
+ __exportStar(require("./utils/performance-timer"), exports);
17
29
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA;AACtC,cAAc,iCAAiC,CAAA;AAE/C,cAAc,mBAAmB,CAAA;AACjC,cAAc,yBAAyB,CAAA;AACvC,cAAc,yBAAyB,CAAA;AACvC,cAAc,8BAA8B,CAAA;AAC5C,cAAc,6BAA6B,CAAA;AAC3C,cAAc,2BAA2B,CAAA;AAEzC,cAAc,wBAAwB,CAAA;AACtC,cAAc,sBAAsB,CAAA;AAEpC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,2BAA2B,CAAA;AACzC,cAAc,mCAAmC,CAAA;AACjD,cAAc,gCAAgC,CAAA;AAC9C,cAAc,0BAA0B,CAAA;AAExC,cAAc,2BAA2B,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAsC;AACtC,kEAA+C;AAE/C,oDAAiC;AACjC,0DAAuC;AACvC,0DAAuC;AACvC,+DAA4C;AAC5C,8DAA2C;AAC3C,4DAAyC;AAEzC,yDAAsC;AACtC,uDAAoC;AAEpC,8DAA2C;AAC3C,4DAAyC;AACzC,oEAAiD;AACjD,iEAA8C;AAC9C,2DAAwC;AAExC,4DAAyC"}
@@ -2,6 +2,9 @@
2
2
  * 'Stop' function, passed to a middleware. Call it to break the pipeline execution.
3
3
  */
4
4
  export declare type Stop = () => void;
5
+ /**
6
+ * A middleware, the building block of a Pipeline. The middlewares will get called in the same order they get registered in the Pipeline.
7
+ */
5
8
  export interface IMiddleware<TContext> {
6
9
  /**
7
10
  * This (optional) function gets called before executing the middleware. It acts as a boolean gateway whether enough conditions are
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=middleware.js.map
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=pipeline.js.map
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=system-middleware.js.map
@@ -1,14 +1,13 @@
1
1
  import { EntityTypeUid, IEntity, IEntityModel } from "../entities/entity";
2
2
  import { EntityProxy, IEntityProxy } from "../entities/entity-proxy";
3
- import { ITriggerData } from "../entities/entity-trigger";
3
+ import { EntityTriggerUid, IEntityTrigger, ITriggerData } from "../entities/entity-trigger";
4
4
  export interface IEntitySchedule {
5
5
  target: IEntityProxy;
6
6
  intervalMs?: number;
7
7
  }
8
8
  export interface ISystemPipelineContext<TEntity extends IEntity> {
9
9
  readonly entity: TEntity;
10
- addEntity(entityType: EntityTypeUid, model: IEntityModel): void;
11
- addTrigger<TTriggerData extends ITriggerData>(target: IEntityProxy, data: TTriggerData): void;
10
+ addEntity(entityType: EntityTypeUid, model: IEntityModel, triggers?: ITriggerData[]): void;
12
11
  updateEntity(target?: IEntityProxy, model?: IEntityModel): void;
13
12
  removeEntity(target?: IEntityProxy): void;
14
13
  scheduleUpdateOnInterval(target?: IEntityProxy, intervalMs?: number): void;
@@ -17,4 +16,14 @@ export interface ISystemPipelineContext<TEntity extends IEntity> {
17
16
  registerProxy(proxy: IEntityProxy, cleanup?: boolean): void;
18
17
  registerProxies(proxies: IEntityProxy[], cleanup?: boolean): void;
19
18
  removeProxies(proxyEntityType?: EntityTypeUid): void;
19
+ addTrigger<TTriggerData extends ITriggerData>(target: IEntityProxy, data: TTriggerData): void;
20
+ addTriggers<TTriggerData extends ITriggerData>(target: IEntityProxy, data: TTriggerData[]): void;
21
+ /**
22
+ * Retrieve the first Trigger of the specified type.
23
+ * @param uid The Trigger type.
24
+ */
25
+ getTrigger<TTriggerData extends ITriggerData>(uid: EntityTriggerUid): IEntityTrigger<TTriggerData>;
26
+ getTriggers<TTriggerData extends ITriggerData>(uid: EntityTriggerUid): IEntityTrigger<TTriggerData>[];
27
+ hasTriggers(uid?: EntityTriggerUid): boolean;
28
+ removeTriggers(uid?: EntityTriggerUid): void;
20
29
  }
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=system-pipeline-context.js.map
@@ -1,9 +1,12 @@
1
- export var SystemPipelineType;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SystemPipelineType = void 0;
4
+ var SystemPipelineType;
2
5
  (function (SystemPipelineType) {
3
6
  SystemPipelineType["initialize"] = "initialize";
4
7
  SystemPipelineType["update"] = "update";
5
8
  SystemPipelineType["render"] = "render";
6
9
  SystemPipelineType["sync"] = "sync";
7
10
  SystemPipelineType["dispatch"] = "dispatch";
8
- })(SystemPipelineType || (SystemPipelineType = {}));
11
+ })(SystemPipelineType = exports.SystemPipelineType || (exports.SystemPipelineType = {}));
9
12
  //# sourceMappingURL=system-pipeline-type.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"system-pipeline-type.js","sourceRoot":"","sources":["../../src/systems/system-pipeline-type.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,kBAMX;AAND,WAAY,kBAAkB;IAC5B,+CAAyB,CAAA;IACzB,uCAAiB,CAAA;IACjB,uCAAiB,CAAA;IACjB,mCAAa,CAAA;IACb,2CAAqB,CAAA;AACvB,CAAC,EANW,kBAAkB,KAAlB,kBAAkB,QAM7B"}
1
+ {"version":3,"file":"system-pipeline-type.js","sourceRoot":"","sources":["../../src/systems/system-pipeline-type.ts"],"names":[],"mappings":";;;AAAA,IAAY,kBAMX;AAND,WAAY,kBAAkB;IAC5B,+CAAyB,CAAA;IACzB,uCAAiB,CAAA;IACjB,uCAAiB,CAAA;IACjB,mCAAa,CAAA;IACb,2CAAqB,CAAA;AACvB,CAAC,EANW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAM7B"}
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=system-pipeline.js.map
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=system-runtime.js.map
@@ -1,2 +1,3 @@
1
- export {};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
2
3
  //# sourceMappingURL=performance-timer.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@awesome-ecs/abstract",
3
- "version": "0.1.3",
3
+ "version": "0.2.2",
4
4
  "description": "A comprehensive Entity-Component-System (ECS) Architecture implementation. Abstract components.",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.ts",
@@ -32,5 +32,5 @@
32
32
  "url": "https://github.com/andreicojocaru/awesome-ecs/issues"
33
33
  },
34
34
  "homepage": "https://github.com/andreicojocaru/awesome-ecs#readme",
35
- "gitHead": "bcdeb43206b71fd2b5aa020b1c0824b83222c790"
35
+ "gitHead": "ee7686721914451579e349f1d106501ae616399d"
36
36
  }