@vived/core 1.4.0 → 1.4.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/package.json +3 -6
- package/dist/cjs/AppObject/AppObject.js +0 -59
- package/dist/cjs/AppObject/AppObject.js.map +0 -1
- package/dist/cjs/AppObject/AppObject.test.js +0 -113
- package/dist/cjs/AppObject/AppObject.test.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectComponent.js +0 -82
- package/dist/cjs/AppObject/AppObjectComponent.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectComponent.test.js +0 -132
- package/dist/cjs/AppObject/AppObjectComponent.test.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectController.js +0 -12
- package/dist/cjs/AppObject/AppObjectController.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectEntity.js +0 -38
- package/dist/cjs/AppObject/AppObjectEntity.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectEntity.test.js +0 -108
- package/dist/cjs/AppObject/AppObjectEntity.test.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectEntityRepo.js +0 -56
- package/dist/cjs/AppObject/AppObjectEntityRepo.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectEntityRepo.test.js +0 -149
- package/dist/cjs/AppObject/AppObjectEntityRepo.test.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectPM.js +0 -40
- package/dist/cjs/AppObject/AppObjectPM.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectPM.test.js +0 -103
- package/dist/cjs/AppObject/AppObjectPM.test.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectRepo.js +0 -133
- package/dist/cjs/AppObject/AppObjectRepo.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectRepo.test.js +0 -213
- package/dist/cjs/AppObject/AppObjectRepo.test.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectUC.js +0 -12
- package/dist/cjs/AppObject/AppObjectUC.js.map +0 -1
- package/dist/cjs/AppObject/AppObjectView.js +0 -12
- package/dist/cjs/AppObject/AppObjectView.js.map +0 -1
- package/dist/cjs/AppObject/getSingletonComponent.js +0 -7
- package/dist/cjs/AppObject/getSingletonComponent.js.map +0 -1
- package/dist/cjs/AppObject/getSingletonComponent.test.js +0 -13
- package/dist/cjs/AppObject/getSingletonComponent.test.js.map +0 -1
- package/dist/cjs/AppObject/index.js +0 -27
- package/dist/cjs/AppObject/index.js.map +0 -1
- package/dist/cjs/AppObject/printAppObjectDetails.js +0 -18
- package/dist/cjs/AppObject/printAppObjectDetails.js.map +0 -1
- package/dist/cjs/Entities/MemoizedAngle.js +0 -23
- package/dist/cjs/Entities/MemoizedAngle.js.map +0 -1
- package/dist/cjs/Entities/MemoizedAngle.test.js +0 -30
- package/dist/cjs/Entities/MemoizedAngle.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedBoolean.js +0 -23
- package/dist/cjs/Entities/MemoizedBoolean.js.map +0 -1
- package/dist/cjs/Entities/MemoizedBoolean.test.js +0 -34
- package/dist/cjs/Entities/MemoizedBoolean.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedColor.js +0 -24
- package/dist/cjs/Entities/MemoizedColor.js.map +0 -1
- package/dist/cjs/Entities/MemoizedColor.test.js +0 -32
- package/dist/cjs/Entities/MemoizedColor.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedNumber.js +0 -23
- package/dist/cjs/Entities/MemoizedNumber.js.map +0 -1
- package/dist/cjs/Entities/MemoizedNumber.test.js +0 -29
- package/dist/cjs/Entities/MemoizedNumber.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedQuaternion.js +0 -24
- package/dist/cjs/Entities/MemoizedQuaternion.js.map +0 -1
- package/dist/cjs/Entities/MemoizedQuaternion.test.js +0 -32
- package/dist/cjs/Entities/MemoizedQuaternion.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedString.js +0 -23
- package/dist/cjs/Entities/MemoizedString.js.map +0 -1
- package/dist/cjs/Entities/MemoizedString.test.js +0 -29
- package/dist/cjs/Entities/MemoizedString.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedVector2.js +0 -24
- package/dist/cjs/Entities/MemoizedVector2.js.map +0 -1
- package/dist/cjs/Entities/MemoizedVector2.test.js +0 -32
- package/dist/cjs/Entities/MemoizedVector2.test.js.map +0 -1
- package/dist/cjs/Entities/MemoizedVector3.js +0 -24
- package/dist/cjs/Entities/MemoizedVector3.js.map +0 -1
- package/dist/cjs/Entities/MemoizedVector3.test.js +0 -32
- package/dist/cjs/Entities/MemoizedVector3.test.js.map +0 -1
- package/dist/cjs/Entities/ObservableEntity.js +0 -20
- package/dist/cjs/Entities/ObservableEntity.js.map +0 -1
- package/dist/cjs/Entities/ObservableEntity.test.js +0 -25
- package/dist/cjs/Entities/ObservableEntity.test.js.map +0 -1
- package/dist/cjs/Entities/ObserverList.js +0 -27
- package/dist/cjs/Entities/ObserverList.js.map +0 -1
- package/dist/cjs/Entities/ObserverList.test.js +0 -44
- package/dist/cjs/Entities/ObserverList.test.js.map +0 -1
- package/dist/cjs/Entities/RangedNumber.js +0 -36
- package/dist/cjs/Entities/RangedNumber.js.map +0 -1
- package/dist/cjs/Entities/RangedNumber.test.js +0 -96
- package/dist/cjs/Entities/RangedNumber.test.js.map +0 -1
- package/dist/cjs/Entities/index.js +0 -28
- package/dist/cjs/Entities/index.js.map +0 -1
- package/dist/cjs/Types/AppBoundary.js +0 -3
- package/dist/cjs/Types/AppBoundary.js.map +0 -1
- package/dist/cjs/Types/EaseFn.js +0 -3
- package/dist/cjs/Types/EaseFn.js.map +0 -1
- package/dist/cjs/Types/PmAdapter.js +0 -3
- package/dist/cjs/Types/PmAdapter.js.map +0 -1
- package/dist/cjs/Types/SingletonPmAdapter.js +0 -3
- package/dist/cjs/Types/SingletonPmAdapter.js.map +0 -1
- package/dist/cjs/Types/index.js +0 -21
- package/dist/cjs/Types/index.js.map +0 -1
- package/dist/cjs/Utilities/LengthConverters.js +0 -21
- package/dist/cjs/Utilities/LengthConverters.js.map +0 -1
- package/dist/cjs/Utilities/LengthConverters.test.js +0 -24
- package/dist/cjs/Utilities/LengthConverters.test.js.map +0 -1
- package/dist/cjs/Utilities/LerpNumber.js +0 -85
- package/dist/cjs/Utilities/LerpNumber.js.map +0 -1
- package/dist/cjs/Utilities/LerpNumber.test.js +0 -90
- package/dist/cjs/Utilities/LerpNumber.test.js.map +0 -1
- package/dist/cjs/Utilities/addAlphaToHex.js +0 -16
- package/dist/cjs/Utilities/addAlphaToHex.js.map +0 -1
- package/dist/cjs/Utilities/addAlphaToHex.test.js +0 -34
- package/dist/cjs/Utilities/addAlphaToHex.test.js.map +0 -1
- package/dist/cjs/Utilities/alphaToHex.js +0 -21
- package/dist/cjs/Utilities/alphaToHex.js.map +0 -1
- package/dist/cjs/Utilities/alphaToHex.test.js +0 -75
- package/dist/cjs/Utilities/alphaToHex.test.js.map +0 -1
- package/dist/cjs/Utilities/degreesToRadians.js +0 -7
- package/dist/cjs/Utilities/degreesToRadians.js.map +0 -1
- package/dist/cjs/Utilities/degreesToRadians.test.js +0 -9
- package/dist/cjs/Utilities/degreesToRadians.test.js.map +0 -1
- package/dist/cjs/Utilities/downloadFile.js +0 -14
- package/dist/cjs/Utilities/downloadFile.js.map +0 -1
- package/dist/cjs/Utilities/easeFunctions.js +0 -208
- package/dist/cjs/Utilities/easeFunctions.js.map +0 -1
- package/dist/cjs/Utilities/easeFunctions.test.js +0 -209
- package/dist/cjs/Utilities/easeFunctions.test.js.map +0 -1
- package/dist/cjs/Utilities/generateUniqueID.js +0 -8
- package/dist/cjs/Utilities/generateUniqueID.js.map +0 -1
- package/dist/cjs/Utilities/index.js +0 -25
- package/dist/cjs/Utilities/index.js.map +0 -1
- package/dist/cjs/Utilities/interpolateNumber.js +0 -18
- package/dist/cjs/Utilities/interpolateNumber.js.map +0 -1
- package/dist/cjs/Utilities/interpolateNumber.test.js +0 -26
- package/dist/cjs/Utilities/interpolateNumber.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Angle.js +0 -47
- package/dist/cjs/ValueObjects/Angle.js.map +0 -1
- package/dist/cjs/ValueObjects/Angle.test.js +0 -28
- package/dist/cjs/ValueObjects/Angle.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Color.js +0 -859
- package/dist/cjs/ValueObjects/Color.js.map +0 -1
- package/dist/cjs/ValueObjects/Color.test.js +0 -147
- package/dist/cjs/ValueObjects/Color.test.js.map +0 -1
- package/dist/cjs/ValueObjects/LineSegment2D.js +0 -72
- package/dist/cjs/ValueObjects/LineSegment2D.js.map +0 -1
- package/dist/cjs/ValueObjects/LineSegment2D.test.js +0 -102
- package/dist/cjs/ValueObjects/LineSegment2D.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Matrix.js +0 -466
- package/dist/cjs/ValueObjects/Matrix.js.map +0 -1
- package/dist/cjs/ValueObjects/Matrix.test.js +0 -385
- package/dist/cjs/ValueObjects/Matrix.test.js.map +0 -1
- package/dist/cjs/ValueObjects/ParametricLine.js +0 -77
- package/dist/cjs/ValueObjects/ParametricLine.js.map +0 -1
- package/dist/cjs/ValueObjects/ParametricLine.test.js +0 -126
- package/dist/cjs/ValueObjects/ParametricLine.test.js.map +0 -1
- package/dist/cjs/ValueObjects/ParametricPlane.js +0 -65
- package/dist/cjs/ValueObjects/ParametricPlane.js.map +0 -1
- package/dist/cjs/ValueObjects/ParametricPlane.test.js +0 -101
- package/dist/cjs/ValueObjects/ParametricPlane.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Quaternion.js +0 -290
- package/dist/cjs/ValueObjects/Quaternion.js.map +0 -1
- package/dist/cjs/ValueObjects/Quaternion.test.js +0 -240
- package/dist/cjs/ValueObjects/Quaternion.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Rectangle.js +0 -24
- package/dist/cjs/ValueObjects/Rectangle.js.map +0 -1
- package/dist/cjs/ValueObjects/Rectangle.test.js +0 -32
- package/dist/cjs/ValueObjects/Rectangle.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Vector2.js +0 -184
- package/dist/cjs/ValueObjects/Vector2.js.map +0 -1
- package/dist/cjs/ValueObjects/Vector2.test.js +0 -136
- package/dist/cjs/ValueObjects/Vector2.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Vector3.js +0 -231
- package/dist/cjs/ValueObjects/Vector3.js.map +0 -1
- package/dist/cjs/ValueObjects/Vector3.test.js +0 -188
- package/dist/cjs/ValueObjects/Vector3.test.js.map +0 -1
- package/dist/cjs/ValueObjects/Version.js +0 -171
- package/dist/cjs/ValueObjects/Version.js.map +0 -1
- package/dist/cjs/ValueObjects/Version.test.js +0 -310
- package/dist/cjs/ValueObjects/Version.test.js.map +0 -1
- package/dist/cjs/ValueObjects/index.js +0 -28
- package/dist/cjs/ValueObjects/index.js.map +0 -1
- package/dist/cjs/index.js +0 -22
- package/dist/cjs/index.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,23 +1,20 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vived/core",
|
|
3
|
-
"version": "1.4.
|
|
3
|
+
"version": "1.4.1",
|
|
4
4
|
"description": "Core Components for VIVED Apps and Hosts",
|
|
5
|
-
"main": "./dist/
|
|
5
|
+
"main": "./dist/esm/index.js",
|
|
6
6
|
"module": "./dist/esm/index.js",
|
|
7
7
|
"types": "./dist/types/index.d.ts",
|
|
8
8
|
"exports": {
|
|
9
9
|
".": {
|
|
10
10
|
"import": "./dist/esm/index.js",
|
|
11
|
-
"require": "./dist/cjs/index.js",
|
|
12
11
|
"types": "./dist/types/index.d.ts"
|
|
13
12
|
}
|
|
14
13
|
},
|
|
15
14
|
"scripts": {
|
|
16
15
|
"test": "jest --watch --config jestconfig.json",
|
|
17
16
|
"testOnce": "jest --config jestconfig.json",
|
|
18
|
-
"build": "
|
|
19
|
-
"build:esm": "tsc",
|
|
20
|
-
"build:cjs": "tsc -p tsconfig.cjs.json",
|
|
17
|
+
"build": "tsc",
|
|
21
18
|
"format": "prettier --write \"src/**/*.ts\" \"src/**/*.js\"",
|
|
22
19
|
"lint": "tslint -p tsconfig.json",
|
|
23
20
|
"prepare": "npm run build",
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AppObject = void 0;
|
|
4
|
-
exports.makeAppObject = makeAppObject;
|
|
5
|
-
const Entities_1 = require("../Entities");
|
|
6
|
-
class AppObject extends Entities_1.ObservableEntity {
|
|
7
|
-
}
|
|
8
|
-
exports.AppObject = AppObject;
|
|
9
|
-
function makeAppObject(id, repo) {
|
|
10
|
-
return new AppObjectImp(id, repo);
|
|
11
|
-
}
|
|
12
|
-
class AppObjectImp extends AppObject {
|
|
13
|
-
hasComponent(type) {
|
|
14
|
-
return this.componentLookup.has(type);
|
|
15
|
-
}
|
|
16
|
-
addComponent(component) {
|
|
17
|
-
const currentComponent = this.componentLookup.get(component.type);
|
|
18
|
-
if (currentComponent) {
|
|
19
|
-
console.warn(`[AppObject] Component ${component.type} is being replaced on ${this.id}`);
|
|
20
|
-
currentComponent.dispose();
|
|
21
|
-
}
|
|
22
|
-
this.componentLookup.set(component.type, component);
|
|
23
|
-
this.notify();
|
|
24
|
-
}
|
|
25
|
-
getComponent(type) {
|
|
26
|
-
if (this.componentLookup.has(type)) {
|
|
27
|
-
return this.componentLookup.get(type);
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
return undefined;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
removeComponent(type) {
|
|
34
|
-
const component = this.componentLookup.get(type);
|
|
35
|
-
if (!component)
|
|
36
|
-
return;
|
|
37
|
-
this.componentLookup.delete(type);
|
|
38
|
-
this.notify();
|
|
39
|
-
}
|
|
40
|
-
allComponents() {
|
|
41
|
-
return Array.from(this.componentLookup.values());
|
|
42
|
-
}
|
|
43
|
-
constructor(id, repo) {
|
|
44
|
-
super();
|
|
45
|
-
this.componentLookup = new Map();
|
|
46
|
-
this.dispose = () => {
|
|
47
|
-
const components = Array.from(this.componentLookup.values());
|
|
48
|
-
this.componentLookup.clear();
|
|
49
|
-
components.forEach(c => c.dispose());
|
|
50
|
-
if (this.appObjectRepo.has(this.id)) {
|
|
51
|
-
this.appObjectRepo.remove(this.id);
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
this.id = id;
|
|
55
|
-
this.appObjectRepo = repo;
|
|
56
|
-
this.appObjectRepo.add(this);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=AppObject.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppObject.js","sourceRoot":"","sources":["../../../src/AppObject/AppObject.ts"],"names":[],"mappings":";;;AAiBA,sCAEC;AAnBD,0CAA+C;AAI/C,MAAsB,SAAU,SAAQ,2BAAgB;CAWvD;AAXD,8BAWC;AAED,SAAgB,aAAa,CAAC,EAAU,EAAE,IAAmB;IAC3D,OAAO,IAAI,YAAY,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;AACpC,CAAC;AAED,MAAM,YAAa,SAAQ,SAAS;IAMlC,YAAY,CAAC,IAAY;QACvB,OAAO,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;IAED,YAAY,CAAC,SAA6B;QACxC,MAAM,gBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAClE,IAAI,gBAAgB,EAAE,CAAC;YACrB,OAAO,CAAC,IAAI,CACV,yBAAyB,SAAS,CAAC,IAAI,yBAAyB,IAAI,CAAC,EAAE,EAAE,CAC1E,CAAC;YACF,gBAAgB,CAAC,OAAO,EAAE,CAAC;QAC7B,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACpD,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,YAAY,CAA+B,IAAY;QACrD,IAAI,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YACnC,OAAO,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAM,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAED,eAAe,CAAC,IAAY;QAC1B,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAEjD,IAAI,CAAC,SAAS;YAAE,OAAO;QAEvB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,aAAa;QACX,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC;IACnD,CAAC;IAaD,YAAY,EAAU,EAAE,IAAmB;QACzC,KAAK,EAAE,CAAC;QApDF,oBAAe,GAAG,IAAI,GAAG,EAA8B,CAAC;QAyChE,YAAO,GAAG,GAAS,EAAE;YACnB,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,CAAC;YAC7D,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;YAC7B,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YAErC,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBACpC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACrC,CAAC;QACH,CAAC,CAAC;QAIA,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;CACF","sourcesContent":["import { ObservableEntity } from \"../Entities\";\r\nimport { AppObjectComponent } from \"./AppObjectComponent\";\r\nimport { AppObjectRepo } from \"./AppObjectRepo\";\r\n\r\nexport abstract class AppObject extends ObservableEntity {\r\n abstract readonly id: string;\r\n abstract readonly appObjectRepo: AppObjectRepo;\r\n\r\n abstract hasComponent(type: string): boolean;\r\n abstract addComponent(component: AppObjectComponent): void;\r\n abstract getComponent<T extends AppObjectComponent>(type: string): T | undefined;\r\n abstract removeComponent(type: string): void;\r\n abstract allComponents(): AppObjectComponent[];\r\n\r\n abstract dispose(): void;\r\n}\r\n\r\nexport function makeAppObject(id: string, repo: AppObjectRepo): AppObject {\r\n return new AppObjectImp(id, repo);\r\n}\r\n\r\nclass AppObjectImp extends AppObject {\r\n readonly id: string;\r\n readonly appObjectRepo: AppObjectRepo;\r\n\r\n private componentLookup = new Map<string, AppObjectComponent>();\r\n\r\n hasComponent(type: string): boolean {\r\n return this.componentLookup.has(type);\r\n }\r\n\r\n addComponent(component: AppObjectComponent): void {\r\n const currentComponent = this.componentLookup.get(component.type);\r\n if (currentComponent) {\r\n console.warn(\r\n `[AppObject] Component ${component.type} is being replaced on ${this.id}`\r\n );\r\n currentComponent.dispose();\r\n }\r\n\r\n this.componentLookup.set(component.type, component);\r\n this.notify();\r\n }\r\n\r\n getComponent<T extends AppObjectComponent>(type: string): T | undefined {\r\n if (this.componentLookup.has(type)) {\r\n return this.componentLookup.get(type) as T;\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n removeComponent(type: string): void {\r\n const component = this.componentLookup.get(type);\r\n\r\n if (!component) return;\r\n\r\n this.componentLookup.delete(type);\r\n this.notify();\r\n }\r\n\r\n allComponents(): AppObjectComponent[] {\r\n return Array.from(this.componentLookup.values());\r\n }\r\n\r\n\r\n dispose = (): void => {\r\n const components = Array.from(this.componentLookup.values());\r\n this.componentLookup.clear();\r\n components.forEach(c => c.dispose());\r\n\r\n if (this.appObjectRepo.has(this.id)) {\r\n this.appObjectRepo.remove(this.id);\r\n }\r\n };\r\n\r\n constructor(id: string, repo: AppObjectRepo) {\r\n super();\r\n this.id = id;\r\n this.appObjectRepo = repo;\r\n this.appObjectRepo.add(this);\r\n }\r\n}\r\n"]}
|
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.makeTestRig = makeTestRig;
|
|
4
|
-
const AppObject_1 = require("./AppObject");
|
|
5
|
-
const AppObjectComponent_1 = require("./AppObjectComponent");
|
|
6
|
-
const AppObjectRepo_1 = require("./AppObjectRepo");
|
|
7
|
-
function makeTestRig() {
|
|
8
|
-
const repo = (0, AppObjectRepo_1.makeAppObjectRepo)();
|
|
9
|
-
const appObj = (0, AppObject_1.makeAppObject)("obj id", repo);
|
|
10
|
-
const observer = jest.fn();
|
|
11
|
-
appObj.addObserver(observer);
|
|
12
|
-
return { repo, appObj, observer };
|
|
13
|
-
}
|
|
14
|
-
describe("App Object", () => {
|
|
15
|
-
it("Adds itself to the repo", () => {
|
|
16
|
-
const { repo, appObj } = makeTestRig();
|
|
17
|
-
expect(repo.has(appObj.id)).toEqual(true);
|
|
18
|
-
});
|
|
19
|
-
it("Removes itself from the repo when disposed", () => {
|
|
20
|
-
const { repo, appObj } = makeTestRig();
|
|
21
|
-
appObj.dispose();
|
|
22
|
-
expect(repo.has(appObj.id)).toEqual(false);
|
|
23
|
-
});
|
|
24
|
-
it("Checks to see it has a component", () => {
|
|
25
|
-
const { appObj } = makeTestRig();
|
|
26
|
-
expect(appObj.hasComponent(MockComponent.type)).toEqual(false);
|
|
27
|
-
new MockComponent(appObj);
|
|
28
|
-
expect(appObj.hasComponent(MockComponent.type)).toEqual(true);
|
|
29
|
-
});
|
|
30
|
-
it("Notifies when an component is added", () => {
|
|
31
|
-
const { appObj, observer } = makeTestRig();
|
|
32
|
-
new MockComponent(appObj);
|
|
33
|
-
expect(observer).toBeCalled();
|
|
34
|
-
});
|
|
35
|
-
it("Gets a component", () => {
|
|
36
|
-
const { appObj } = makeTestRig();
|
|
37
|
-
expect(appObj.getComponent(MockComponent.type)).toEqual(undefined);
|
|
38
|
-
const mockComponent = new MockComponent(appObj);
|
|
39
|
-
expect(appObj.getComponent(MockComponent.type)).toEqual(mockComponent);
|
|
40
|
-
});
|
|
41
|
-
it("Warns if a component is replaced", () => {
|
|
42
|
-
const { appObj } = makeTestRig();
|
|
43
|
-
console.warn = jest.fn();
|
|
44
|
-
const mockComponent = new MockComponent(appObj);
|
|
45
|
-
appObj.addComponent(mockComponent);
|
|
46
|
-
appObj.addComponent(new MockComponent(appObj));
|
|
47
|
-
expect(console.warn).toBeCalled();
|
|
48
|
-
});
|
|
49
|
-
it("Returns the component list", () => {
|
|
50
|
-
const { appObj } = makeTestRig();
|
|
51
|
-
expect(appObj.allComponents()).toEqual([]);
|
|
52
|
-
const mockComponent = new MockComponent(appObj);
|
|
53
|
-
appObj.addComponent(mockComponent);
|
|
54
|
-
const anotherMockComponent = new AnotherMockComponent(appObj);
|
|
55
|
-
appObj.addComponent(anotherMockComponent);
|
|
56
|
-
expect(appObj.allComponents()).toEqual([mockComponent, anotherMockComponent]);
|
|
57
|
-
});
|
|
58
|
-
it("Removes a component", () => {
|
|
59
|
-
const { appObj } = makeTestRig();
|
|
60
|
-
const comp = new MockComponent(appObj);
|
|
61
|
-
appObj.addComponent(comp);
|
|
62
|
-
expect(appObj.hasComponent(MockComponent.type)).toEqual(true);
|
|
63
|
-
appObj.removeComponent(MockComponent.type);
|
|
64
|
-
expect(appObj.hasComponent(MockComponent.type)).toEqual(false);
|
|
65
|
-
});
|
|
66
|
-
it("Notifies when an component is removed", () => {
|
|
67
|
-
const { appObj, observer } = makeTestRig();
|
|
68
|
-
const comp = new MockComponent(appObj);
|
|
69
|
-
appObj.addComponent(comp);
|
|
70
|
-
observer.mockClear();
|
|
71
|
-
appObj.removeComponent(MockComponent.type);
|
|
72
|
-
appObj.removeComponent(MockComponent.type);
|
|
73
|
-
appObj.removeComponent(MockComponent.type);
|
|
74
|
-
expect(observer).toHaveBeenCalledTimes(1);
|
|
75
|
-
});
|
|
76
|
-
it("Disposes all components when the App Object is disposed", () => {
|
|
77
|
-
const { appObj } = makeTestRig();
|
|
78
|
-
const comp = new MockComponent(appObj);
|
|
79
|
-
appObj.addComponent(comp);
|
|
80
|
-
const spy = jest.spyOn(comp, "dispose");
|
|
81
|
-
appObj.dispose();
|
|
82
|
-
expect(spy).toBeCalled();
|
|
83
|
-
});
|
|
84
|
-
it("Clears the component list when disposed", () => {
|
|
85
|
-
const { appObj } = makeTestRig();
|
|
86
|
-
const comp = new MockComponent(appObj);
|
|
87
|
-
appObj.addComponent(comp);
|
|
88
|
-
expect(appObj.allComponents()).toHaveLength(1);
|
|
89
|
-
appObj.dispose();
|
|
90
|
-
expect(appObj.allComponents()).toHaveLength(0);
|
|
91
|
-
});
|
|
92
|
-
it("If an entity is replace, it disposes the original", () => {
|
|
93
|
-
const { appObj } = makeTestRig();
|
|
94
|
-
const comp = new MockComponent(appObj);
|
|
95
|
-
appObj.addComponent(comp);
|
|
96
|
-
const spy = jest.spyOn(comp, "dispose");
|
|
97
|
-
appObj.addComponent(new MockComponent(appObj));
|
|
98
|
-
expect(spy).toBeCalled();
|
|
99
|
-
});
|
|
100
|
-
});
|
|
101
|
-
class MockComponent extends AppObjectComponent_1.AppObjectComponent {
|
|
102
|
-
constructor(appObject) {
|
|
103
|
-
super(appObject, MockComponent.type);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
MockComponent.type = "mockComponent";
|
|
107
|
-
class AnotherMockComponent extends AppObjectComponent_1.AppObjectComponent {
|
|
108
|
-
constructor(appObject) {
|
|
109
|
-
super(appObject, AnotherMockComponent.type);
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
AnotherMockComponent.type = "mockComponent2";
|
|
113
|
-
//# sourceMappingURL=AppObject.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppObject.test.js","sourceRoot":"","sources":["../../../src/AppObject/AppObject.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { AppObject, makeAppObject } from \"./AppObject\";\r\nimport { AppObjectComponent } from \"./AppObjectComponent\";\r\nimport { makeAppObjectRepo } from \"./AppObjectRepo\";\r\n\r\nexport function makeTestRig() {\r\n const repo = makeAppObjectRepo();\r\n const appObj = makeAppObject(\"obj id\", repo);\r\n const observer = jest.fn();\r\n appObj.addObserver(observer);\r\n\r\n return { repo, appObj, observer };\r\n}\r\n\r\ndescribe(\"App Object\", () => {\r\n it(\"Adds itself to the repo\", () => {\r\n const { repo, appObj } = makeTestRig();\r\n\r\n expect(repo.has(appObj.id)).toEqual(true);\r\n });\r\n\r\n it(\"Removes itself from the repo when disposed\", () => {\r\n const { repo, appObj } = makeTestRig();\r\n\r\n appObj.dispose();\r\n expect(repo.has(appObj.id)).toEqual(false);\r\n });\r\n\r\n it(\"Checks to see it has a component\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n expect(appObj.hasComponent(MockComponent.type)).toEqual(false);\r\n\r\n new MockComponent(appObj);\r\n\r\n expect(appObj.hasComponent(MockComponent.type)).toEqual(true);\r\n });\r\n\r\n it(\"Notifies when an component is added\", () => {\r\n const { appObj, observer } = makeTestRig();\r\n\r\n new MockComponent(appObj);\r\n\r\n expect(observer).toBeCalled();\r\n });\r\n\r\n it(\"Gets a component\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n expect(appObj.getComponent(MockComponent.type)).toEqual(undefined);\r\n\r\n const mockComponent = new MockComponent(appObj);\r\n\r\n expect(appObj.getComponent(MockComponent.type)).toEqual(mockComponent);\r\n });\r\n\r\n it(\"Warns if a component is replaced\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n console.warn = jest.fn();\r\n\r\n const mockComponent = new MockComponent(appObj);\r\n appObj.addComponent(mockComponent);\r\n appObj.addComponent(new MockComponent(appObj));\r\n\r\n expect(console.warn).toBeCalled();\r\n });\r\n\r\n it(\"Returns the component list\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n expect(appObj.allComponents()).toEqual([]);\r\n\r\n const mockComponent = new MockComponent(appObj);\r\n appObj.addComponent(mockComponent);\r\n\r\n const anotherMockComponent = new AnotherMockComponent(appObj);\r\n appObj.addComponent(anotherMockComponent)\r\n\r\n expect(appObj.allComponents()).toEqual([mockComponent, anotherMockComponent]);\r\n });\r\n\r\n it(\"Removes a component\", () => {\r\n const { appObj } = makeTestRig();\r\n const comp = new MockComponent(appObj);\r\n appObj.addComponent(comp)\r\n\r\n expect(appObj.hasComponent(MockComponent.type)).toEqual(true);\r\n\r\n appObj.removeComponent(MockComponent.type);\r\n\r\n expect(appObj.hasComponent(MockComponent.type)).toEqual(false);\r\n });\r\n\r\n it(\"Notifies when an component is removed\", () => {\r\n const { appObj, observer } = makeTestRig();\r\n const comp = new MockComponent(appObj);\r\n appObj.addComponent(comp)\r\n observer.mockClear();\r\n\r\n appObj.removeComponent(MockComponent.type);\r\n appObj.removeComponent(MockComponent.type);\r\n appObj.removeComponent(MockComponent.type);\r\n\r\n expect(observer).toHaveBeenCalledTimes(1);\r\n });\r\n\r\n it(\"Disposes all components when the App Object is disposed\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n const comp = new MockComponent(appObj);\r\n appObj.addComponent(comp)\r\n\r\n const spy = jest.spyOn(comp, \"dispose\");\r\n\r\n appObj.dispose();\r\n\r\n expect(spy).toBeCalled();\r\n });\r\n\r\n it(\"Clears the component list when disposed\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n const comp = new MockComponent(appObj);\r\n appObj.addComponent(comp)\r\n\r\n expect(appObj.allComponents()).toHaveLength(1);\r\n\r\n appObj.dispose();\r\n\r\n expect(appObj.allComponents()).toHaveLength(0);\r\n });\r\n\r\n it(\"If an entity is replace, it disposes the original\", () => {\r\n const { appObj } = makeTestRig();\r\n\r\n const comp = new MockComponent(appObj);\r\n appObj.addComponent(comp)\r\n\r\n const spy = jest.spyOn(comp, \"dispose\");\r\n appObj.addComponent(new MockComponent(appObj))\r\n\r\n expect(spy).toBeCalled();\r\n });\r\n});\r\n\r\nclass MockComponent extends AppObjectComponent {\r\n static readonly type: string = \"mockComponent\";\r\n constructor(appObject: AppObject) {\r\n super(appObject, MockComponent.type)\r\n }\r\n}\r\n\r\nclass AnotherMockComponent extends AppObjectComponent {\r\n static readonly type: string = \"mockComponent2\";\r\n constructor(appObject: AppObject) {\r\n super(appObject, AnotherMockComponent.type)\r\n }\r\n}"]}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AppObjectComponent = exports.AppObjectComponentType = void 0;
|
|
4
|
-
var AppObjectComponentType;
|
|
5
|
-
(function (AppObjectComponentType) {
|
|
6
|
-
AppObjectComponentType["ENTITY"] = "Entity";
|
|
7
|
-
AppObjectComponentType["PM"] = "Presentation Manager";
|
|
8
|
-
AppObjectComponentType["UC"] = "Use Case";
|
|
9
|
-
AppObjectComponentType["CONTROLLER"] = "Controller";
|
|
10
|
-
AppObjectComponentType["VIEW"] = "View";
|
|
11
|
-
AppObjectComponentType["UNKNOWN"] = "Unknown";
|
|
12
|
-
})(AppObjectComponentType || (exports.AppObjectComponentType = AppObjectComponentType = {}));
|
|
13
|
-
class AppObjectComponent {
|
|
14
|
-
get appObjects() {
|
|
15
|
-
return this.appObject.appObjectRepo;
|
|
16
|
-
}
|
|
17
|
-
getCachedSingleton(type) {
|
|
18
|
-
if (!this.cachedComponents.has(type)) {
|
|
19
|
-
const component = this.appObjects.getSingleton(type);
|
|
20
|
-
if (!component) {
|
|
21
|
-
this.warn("Unable to get cached singleton type " + type);
|
|
22
|
-
}
|
|
23
|
-
else {
|
|
24
|
-
this.cachedComponents.set(type, component);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
return this.cachedComponents.get(type);
|
|
28
|
-
}
|
|
29
|
-
getCachedLocalComponent(type) {
|
|
30
|
-
if (!this.cachedComponents.has(type)) {
|
|
31
|
-
const component = this.appObject.getComponent(type);
|
|
32
|
-
if (!component) {
|
|
33
|
-
this.warn("Unable to get local component of type " + type);
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
this.cachedComponents.set(type, component);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
return this.cachedComponents.get(type);
|
|
40
|
-
}
|
|
41
|
-
getSingleton(type, logType = "WARN") {
|
|
42
|
-
const comp = this.appObjects.getSingleton(type);
|
|
43
|
-
if (!comp) {
|
|
44
|
-
const msg = "Unable to get singleton type " + type;
|
|
45
|
-
switch (logType) {
|
|
46
|
-
case "ERROR":
|
|
47
|
-
this.error(msg);
|
|
48
|
-
break;
|
|
49
|
-
case "LOG":
|
|
50
|
-
this.log(msg);
|
|
51
|
-
break;
|
|
52
|
-
case "WARN":
|
|
53
|
-
this.warn(msg);
|
|
54
|
-
break;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
return comp;
|
|
58
|
-
}
|
|
59
|
-
dispose() {
|
|
60
|
-
if (this.appObject.getComponent(this.type) === this) {
|
|
61
|
-
this.appObject.removeComponent(this.type);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
log(message) {
|
|
65
|
-
this.appObjects.submitLog(`${this.appObject.id}/${this.type}`, message);
|
|
66
|
-
}
|
|
67
|
-
warn(message) {
|
|
68
|
-
this.appObjects.submitWarning(`${this.appObject.id}/${this.type}`, message);
|
|
69
|
-
}
|
|
70
|
-
error(message) {
|
|
71
|
-
this.appObjects.submitError(`${this.appObject.id}/${this.type}`, message);
|
|
72
|
-
}
|
|
73
|
-
constructor(appObject, type) {
|
|
74
|
-
this.componentType = AppObjectComponentType.UNKNOWN;
|
|
75
|
-
this.cachedComponents = new Map();
|
|
76
|
-
this.appObject = appObject;
|
|
77
|
-
this.type = type;
|
|
78
|
-
appObject.addComponent(this);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
exports.AppObjectComponent = AppObjectComponent;
|
|
82
|
-
//# sourceMappingURL=AppObjectComponent.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppObjectComponent.js","sourceRoot":"","sources":["../../../src/AppObject/AppObjectComponent.ts"],"names":[],"mappings":"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","sourcesContent":["import { AppObject } from \"./AppObject\";\r\nimport { AppObjectRepo } from \"./AppObjectRepo\";\r\n\r\nexport enum AppObjectComponentType {\r\n ENTITY = \"Entity\",\r\n PM = \"Presentation Manager\",\r\n UC = \"Use Case\",\r\n CONTROLLER = \"Controller\",\r\n VIEW = \"View\",\r\n UNKNOWN = \"Unknown\",\r\n}\r\n\r\nexport class AppObjectComponent {\r\n readonly componentType: AppObjectComponentType = AppObjectComponentType.UNKNOWN;\r\n readonly type: string;\r\n readonly appObject: AppObject;\r\n get appObjects(): AppObjectRepo {\r\n return this.appObject.appObjectRepo;\r\n }\r\n\r\n private cachedComponents = new Map<string, AppObjectComponent>();\r\n getCachedSingleton<T extends AppObjectComponent>(\r\n type: string\r\n ): T | undefined {\r\n if (!this.cachedComponents.has(type)) {\r\n const component = this.appObjects.getSingleton(type);\r\n if (!component) {\r\n this.warn(\"Unable to get cached singleton type \" + type);\r\n } else {\r\n this.cachedComponents.set(type, component);\r\n }\r\n }\r\n\r\n return this.cachedComponents.get(type) as T;\r\n }\r\n\r\n getCachedLocalComponent<T extends AppObjectComponent>(\r\n type: string\r\n ): T | undefined {\r\n if (!this.cachedComponents.has(type)) {\r\n const component = this.appObject.getComponent(type);\r\n\r\n if (!component) {\r\n this.warn(\"Unable to get local component of type \" + type);\r\n } else {\r\n this.cachedComponents.set(type, component);\r\n }\r\n }\r\n\r\n return this.cachedComponents.get(type) as T;\r\n }\r\n\r\n getSingleton<T extends AppObjectComponent>(\r\n type: string,\r\n logType: \"LOG\" | \"WARN\" | \"ERROR\" = \"WARN\"\r\n ): T | undefined {\r\n const comp = this.appObjects.getSingleton<T>(type);\r\n\r\n if (!comp) {\r\n const msg = \"Unable to get singleton type \" + type;\r\n switch (logType) {\r\n case \"ERROR\":\r\n this.error(msg);\r\n break;\r\n case \"LOG\":\r\n this.log(msg);\r\n break;\r\n case \"WARN\":\r\n this.warn(msg);\r\n break;\r\n }\r\n }\r\n\r\n return comp;\r\n }\r\n\r\n dispose() {\r\n if (this.appObject.getComponent(this.type) === this) {\r\n this.appObject.removeComponent(this.type);\r\n }\r\n }\r\n\r\n log(message: string) {\r\n this.appObjects.submitLog(`${this.appObject.id}/${this.type}`, message);\r\n }\r\n\r\n warn(message: string) {\r\n this.appObjects.submitWarning(`${this.appObject.id}/${this.type}`, message);\r\n }\r\n\r\n error(message: string) {\r\n this.appObjects.submitError(`${this.appObject.id}/${this.type}`, message);\r\n }\r\n\r\n constructor(appObject: AppObject, type: string) {\r\n this.appObject = appObject;\r\n this.type = type;\r\n appObject.addComponent(this);\r\n }\r\n}\r\n"]}
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const AppObject_1 = require("./AppObject");
|
|
4
|
-
const AppObjectComponent_1 = require("./AppObjectComponent");
|
|
5
|
-
const AppObjectRepo_1 = require("./AppObjectRepo");
|
|
6
|
-
function makeTestRig() {
|
|
7
|
-
const appObjectRepo = (0, AppObjectRepo_1.makeAppObjectRepo)();
|
|
8
|
-
const appObj = (0, AppObject_1.makeAppObject)("appObj", appObjectRepo);
|
|
9
|
-
const appObjectComponent = new AppObjectComponent_1.AppObjectComponent(appObj, "aComponent");
|
|
10
|
-
return { appObjectComponent, appObj, appObjectRepo };
|
|
11
|
-
}
|
|
12
|
-
describe("App Object Component", () => {
|
|
13
|
-
it("Sets the type", () => {
|
|
14
|
-
const { appObjectComponent } = makeTestRig();
|
|
15
|
-
expect(appObjectComponent.type).toEqual("aComponent");
|
|
16
|
-
});
|
|
17
|
-
it("Stores the app object", () => {
|
|
18
|
-
const { appObjectComponent, appObj } = makeTestRig();
|
|
19
|
-
expect(appObjectComponent.appObject).toEqual(appObj);
|
|
20
|
-
});
|
|
21
|
-
it("Adds itself to the app object", () => {
|
|
22
|
-
const { appObjectComponent, appObj } = makeTestRig();
|
|
23
|
-
expect(appObj.hasComponent(appObjectComponent.type)).toEqual(true);
|
|
24
|
-
});
|
|
25
|
-
it("Removes itself from the app object when disposed", () => {
|
|
26
|
-
const { appObjectComponent, appObj } = makeTestRig();
|
|
27
|
-
appObjectComponent.dispose();
|
|
28
|
-
expect(appObj.hasComponent(appObjectComponent.type)).toEqual(false);
|
|
29
|
-
});
|
|
30
|
-
it("Returns the repo", () => {
|
|
31
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
32
|
-
expect(appObjectComponent.appObjects).toEqual(appObjectRepo);
|
|
33
|
-
});
|
|
34
|
-
it("Forwards a warn to the App Object Repo warn", () => {
|
|
35
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
36
|
-
appObjectRepo.submitWarning = jest.fn();
|
|
37
|
-
appObjectComponent.warn("Some warning");
|
|
38
|
-
expect(appObjectRepo.submitWarning).toBeCalledWith(`appObj/aComponent`, "Some warning");
|
|
39
|
-
});
|
|
40
|
-
it("Forwards a log to the App Object Repo log", () => {
|
|
41
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
42
|
-
appObjectRepo.submitLog = jest.fn();
|
|
43
|
-
appObjectComponent.log("Some log");
|
|
44
|
-
expect(appObjectRepo.submitLog).toBeCalledWith(`appObj/aComponent`, "Some log");
|
|
45
|
-
});
|
|
46
|
-
it("Forwards an error to the App Object Repo error", () => {
|
|
47
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
48
|
-
appObjectRepo.submitError = jest.fn();
|
|
49
|
-
appObjectComponent.error("Some error");
|
|
50
|
-
expect(appObjectRepo.submitError).toBeCalledWith(`appObj/aComponent`, "Some error");
|
|
51
|
-
});
|
|
52
|
-
it("Gets a singleton", () => {
|
|
53
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
54
|
-
const mockSingleton = new MockComponent(appObjectRepo.getOrCreate("Some other"));
|
|
55
|
-
const returned = appObjectComponent.getSingleton(MockComponent.type);
|
|
56
|
-
expect(returned).toEqual(mockSingleton);
|
|
57
|
-
});
|
|
58
|
-
it("Warns by default if the singleton cannot be found", () => {
|
|
59
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
60
|
-
appObjectComponent.warn = jest.fn();
|
|
61
|
-
appObjectRepo.submitWarning = jest.fn();
|
|
62
|
-
appObjectComponent.getSingleton(MockComponent.type);
|
|
63
|
-
expect(appObjectComponent.warn).toBeCalled();
|
|
64
|
-
});
|
|
65
|
-
it("Errors if the singleton cannot be found", () => {
|
|
66
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
67
|
-
appObjectComponent.error = jest.fn();
|
|
68
|
-
appObjectRepo.submitWarning = jest.fn();
|
|
69
|
-
appObjectComponent.getSingleton(MockComponent.type, "ERROR");
|
|
70
|
-
expect(appObjectComponent.error).toBeCalled();
|
|
71
|
-
});
|
|
72
|
-
it("Logs if the singleton cannot be found", () => {
|
|
73
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
74
|
-
appObjectComponent.log = jest.fn();
|
|
75
|
-
appObjectRepo.submitWarning = jest.fn();
|
|
76
|
-
appObjectComponent.getSingleton(MockComponent.type, "LOG");
|
|
77
|
-
expect(appObjectComponent.log).toBeCalled();
|
|
78
|
-
});
|
|
79
|
-
it("Warns if the singleton cannot be found", () => {
|
|
80
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
81
|
-
appObjectComponent.warn = jest.fn();
|
|
82
|
-
appObjectRepo.submitWarning = jest.fn();
|
|
83
|
-
appObjectComponent.getSingleton(MockComponent.type, "WARN");
|
|
84
|
-
expect(appObjectComponent.warn).toBeCalled();
|
|
85
|
-
});
|
|
86
|
-
it("Gets a cached singleton", () => {
|
|
87
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
88
|
-
const mockSingleton = new MockComponent(appObjectRepo.getOrCreate("Some other"));
|
|
89
|
-
const returned = appObjectComponent.getCachedSingleton(MockComponent.type);
|
|
90
|
-
expect(returned).toEqual(mockSingleton);
|
|
91
|
-
});
|
|
92
|
-
it("Gets a cached singleton from the local cache", () => {
|
|
93
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
94
|
-
const spy = jest.spyOn(appObjectRepo, "getSingleton");
|
|
95
|
-
new MockComponent(appObjectRepo.getOrCreate("Some other"));
|
|
96
|
-
appObjectComponent.getCachedSingleton(MockComponent.type);
|
|
97
|
-
appObjectComponent.getCachedSingleton(MockComponent.type);
|
|
98
|
-
appObjectComponent.getCachedSingleton(MockComponent.type);
|
|
99
|
-
appObjectComponent.getCachedSingleton(MockComponent.type);
|
|
100
|
-
expect(spy).toBeCalledTimes(1);
|
|
101
|
-
});
|
|
102
|
-
it("Warns if the cached singleton cannot be found", () => {
|
|
103
|
-
const { appObjectComponent, appObjectRepo } = makeTestRig();
|
|
104
|
-
appObjectComponent.warn = jest.fn();
|
|
105
|
-
appObjectRepo.submitWarning = jest.fn();
|
|
106
|
-
appObjectComponent.getCachedSingleton(MockComponent.type);
|
|
107
|
-
expect(appObjectComponent.warn).toBeCalled();
|
|
108
|
-
});
|
|
109
|
-
it("Gets a local component", () => {
|
|
110
|
-
const { appObjectComponent, appObjectRepo, appObj } = makeTestRig();
|
|
111
|
-
const b1 = new MockComponent(appObj);
|
|
112
|
-
new MockComponent(appObjectRepo.getOrCreate("otherAO"));
|
|
113
|
-
expect(appObjectComponent.getCachedLocalComponent(MockComponent.type)).toEqual(b1);
|
|
114
|
-
});
|
|
115
|
-
it("Caches the local component", () => {
|
|
116
|
-
const { appObjectComponent, appObj } = makeTestRig();
|
|
117
|
-
const spy = jest.spyOn(appObj, "getComponent");
|
|
118
|
-
new MockComponent(appObj);
|
|
119
|
-
appObjectComponent.getCachedLocalComponent(MockComponent.type);
|
|
120
|
-
appObjectComponent.getCachedLocalComponent(MockComponent.type);
|
|
121
|
-
appObjectComponent.getCachedLocalComponent(MockComponent.type);
|
|
122
|
-
appObjectComponent.getCachedLocalComponent(MockComponent.type);
|
|
123
|
-
expect(spy).toBeCalledTimes(1);
|
|
124
|
-
});
|
|
125
|
-
});
|
|
126
|
-
class MockComponent extends AppObjectComponent_1.AppObjectComponent {
|
|
127
|
-
constructor(appObject) {
|
|
128
|
-
super(appObject, MockComponent.type);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
MockComponent.type = "MockComponent";
|
|
132
|
-
//# sourceMappingURL=AppObjectComponent.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppObjectComponent.test.js","sourceRoot":"","sources":["../../../src/AppObject/AppObjectComponent.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { AppObject, makeAppObject } from \"./AppObject\";\r\nimport { AppObjectComponent } from \"./AppObjectComponent\";\r\nimport { makeAppObjectRepo } from \"./AppObjectRepo\";\r\n\r\nfunction makeTestRig() {\r\n const appObjectRepo = makeAppObjectRepo();\r\n const appObj = makeAppObject(\"appObj\", appObjectRepo);\r\n const appObjectComponent = new AppObjectComponent(appObj, \"aComponent\");\r\n\r\n return { appObjectComponent, appObj, appObjectRepo };\r\n}\r\n\r\ndescribe(\"App Object Component\", () => {\r\n it(\"Sets the type\", () => {\r\n const { appObjectComponent } = makeTestRig();\r\n expect(appObjectComponent.type).toEqual(\"aComponent\");\r\n });\r\n\r\n it(\"Stores the app object\", () => {\r\n const { appObjectComponent, appObj } = makeTestRig();\r\n expect(appObjectComponent.appObject).toEqual(appObj);\r\n });\r\n\r\n it(\"Adds itself to the app object\", () => {\r\n const { appObjectComponent, appObj } = makeTestRig();\r\n\r\n expect(appObj.hasComponent(appObjectComponent.type)).toEqual(true);\r\n });\r\n\r\n it(\"Removes itself from the app object when disposed\", () => {\r\n const { appObjectComponent, appObj } = makeTestRig();\r\n\r\n appObjectComponent.dispose();\r\n\r\n expect(appObj.hasComponent(appObjectComponent.type)).toEqual(false);\r\n });\r\n\r\n it(\"Returns the repo\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n expect(appObjectComponent.appObjects).toEqual(appObjectRepo);\r\n });\r\n\r\n it(\"Forwards a warn to the App Object Repo warn\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n appObjectRepo.submitWarning = jest.fn();\r\n\r\n appObjectComponent.warn(\"Some warning\");\r\n\r\n expect(appObjectRepo.submitWarning).toBeCalledWith(\r\n `appObj/aComponent`,\r\n \"Some warning\"\r\n );\r\n });\r\n\r\n it(\"Forwards a log to the App Object Repo log\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n appObjectRepo.submitLog = jest.fn();\r\n\r\n appObjectComponent.log(\"Some log\");\r\n\r\n expect(appObjectRepo.submitLog).toBeCalledWith(\r\n `appObj/aComponent`,\r\n \"Some log\"\r\n );\r\n });\r\n\r\n it(\"Forwards an error to the App Object Repo error\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n appObjectRepo.submitError = jest.fn();\r\n\r\n appObjectComponent.error(\"Some error\");\r\n\r\n expect(appObjectRepo.submitError).toBeCalledWith(\r\n `appObj/aComponent`,\r\n \"Some error\"\r\n );\r\n });\r\n\r\n it(\"Gets a singleton\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n const mockSingleton = new MockComponent(\r\n appObjectRepo.getOrCreate(\"Some other\")\r\n );\r\n\r\n const returned = appObjectComponent.getSingleton<MockComponent>(\r\n MockComponent.type\r\n );\r\n\r\n expect(returned).toEqual(mockSingleton);\r\n });\r\n\r\n it(\"Warns by default if the singleton cannot be found\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n\r\n appObjectComponent.warn = jest.fn();\r\n appObjectRepo.submitWarning = jest.fn();\r\n\r\n appObjectComponent.getSingleton<MockComponent>(MockComponent.type);\r\n\r\n expect(appObjectComponent.warn).toBeCalled();\r\n });\r\n\r\n it(\"Errors if the singleton cannot be found\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n\r\n appObjectComponent.error = jest.fn();\r\n appObjectRepo.submitWarning = jest.fn();\r\n\r\n appObjectComponent.getSingleton<MockComponent>(MockComponent.type, \"ERROR\");\r\n\r\n expect(appObjectComponent.error).toBeCalled();\r\n });\r\n\r\n it(\"Logs if the singleton cannot be found\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n\r\n appObjectComponent.log = jest.fn();\r\n appObjectRepo.submitWarning = jest.fn();\r\n\r\n appObjectComponent.getSingleton<MockComponent>(MockComponent.type, \"LOG\");\r\n\r\n expect(appObjectComponent.log).toBeCalled();\r\n });\r\n\r\n it(\"Warns if the singleton cannot be found\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n\r\n appObjectComponent.warn = jest.fn();\r\n appObjectRepo.submitWarning = jest.fn();\r\n\r\n appObjectComponent.getSingleton<MockComponent>(MockComponent.type, \"WARN\");\r\n\r\n expect(appObjectComponent.warn).toBeCalled();\r\n });\r\n\r\n it(\"Gets a cached singleton\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n const mockSingleton = new MockComponent(\r\n appObjectRepo.getOrCreate(\"Some other\")\r\n );\r\n\r\n const returned = appObjectComponent.getCachedSingleton<MockComponent>(\r\n MockComponent.type\r\n );\r\n\r\n expect(returned).toEqual(mockSingleton);\r\n });\r\n\r\n it(\"Gets a cached singleton from the local cache\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n\r\n const spy = jest.spyOn(appObjectRepo, \"getSingleton\");\r\n\r\n new MockComponent(appObjectRepo.getOrCreate(\"Some other\"));\r\n\r\n appObjectComponent.getCachedSingleton<MockComponent>(MockComponent.type);\r\n appObjectComponent.getCachedSingleton<MockComponent>(MockComponent.type);\r\n appObjectComponent.getCachedSingleton<MockComponent>(MockComponent.type);\r\n appObjectComponent.getCachedSingleton<MockComponent>(MockComponent.type);\r\n\r\n expect(spy).toBeCalledTimes(1);\r\n });\r\n\r\n it(\"Warns if the cached singleton cannot be found\", () => {\r\n const { appObjectComponent, appObjectRepo } = makeTestRig();\r\n\r\n appObjectComponent.warn = jest.fn();\r\n appObjectRepo.submitWarning = jest.fn();\r\n\r\n appObjectComponent.getCachedSingleton<MockComponent>(MockComponent.type);\r\n\r\n expect(appObjectComponent.warn).toBeCalled();\r\n });\r\n\r\n it(\"Gets a local component\", () => {\r\n const { appObjectComponent, appObjectRepo, appObj } = makeTestRig();\r\n\r\n const b1 = new MockComponent(appObj);\r\n\r\n new MockComponent(appObjectRepo.getOrCreate(\"otherAO\"));\r\n\r\n expect(\r\n appObjectComponent.getCachedLocalComponent<MockComponent>(\r\n MockComponent.type\r\n )\r\n ).toEqual(b1);\r\n });\r\n\r\n it(\"Caches the local component\", () => {\r\n const { appObjectComponent, appObj } = makeTestRig();\r\n\r\n const spy = jest.spyOn(appObj, \"getComponent\");\r\n\r\n new MockComponent(appObj);\r\n\r\n appObjectComponent.getCachedLocalComponent<MockComponent>(\r\n MockComponent.type\r\n );\r\n appObjectComponent.getCachedLocalComponent<MockComponent>(\r\n MockComponent.type\r\n );\r\n appObjectComponent.getCachedLocalComponent<MockComponent>(\r\n MockComponent.type\r\n );\r\n appObjectComponent.getCachedLocalComponent<MockComponent>(\r\n MockComponent.type\r\n );\r\n\r\n expect(spy).toBeCalledTimes(1);\r\n });\r\n});\r\n\r\nclass MockComponent extends AppObjectComponent {\r\n static type = \"MockComponent\";\r\n\r\n constructor(appObject: AppObject) {\r\n super(appObject, MockComponent.type);\r\n }\r\n}\r\n"]}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AppObjectController = void 0;
|
|
4
|
-
const AppObjectComponent_1 = require("./AppObjectComponent");
|
|
5
|
-
class AppObjectController extends AppObjectComponent_1.AppObjectComponent {
|
|
6
|
-
constructor() {
|
|
7
|
-
super(...arguments);
|
|
8
|
-
this.componentType = AppObjectComponent_1.AppObjectComponentType.CONTROLLER;
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
exports.AppObjectController = AppObjectController;
|
|
12
|
-
//# sourceMappingURL=AppObjectController.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppObjectController.js","sourceRoot":"","sources":["../../../src/AppObject/AppObjectController.ts"],"names":[],"mappings":";;;AAAA,6DAG8B;AAE9B,MAAa,mBAAoB,SAAQ,uCAAkB;IAA3D;;QACW,kBAAa,GAAG,2CAAsB,CAAC,UAAU,CAAC;IAC7D,CAAC;CAAA;AAFD,kDAEC","sourcesContent":["import {\r\n AppObjectComponent,\r\n AppObjectComponentType,\r\n} from \"./AppObjectComponent\";\r\n\r\nexport class AppObjectController extends AppObjectComponent {\r\n readonly componentType = AppObjectComponentType.CONTROLLER;\r\n}\r\n"]}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AppObjectEntity = void 0;
|
|
4
|
-
const Entities_1 = require("../Entities");
|
|
5
|
-
const AppObjectComponent_1 = require("./AppObjectComponent");
|
|
6
|
-
class AppObjectEntity extends AppObjectComponent_1.AppObjectComponent {
|
|
7
|
-
dispose() {
|
|
8
|
-
this.removeChangeObserver(this.appObject.notify);
|
|
9
|
-
this.onDisposeObserverList.notify();
|
|
10
|
-
this.onChangeObserverList.clear();
|
|
11
|
-
this.onDisposeObserverList.clear();
|
|
12
|
-
super.dispose();
|
|
13
|
-
}
|
|
14
|
-
constructor(appObject, type) {
|
|
15
|
-
super(appObject, type);
|
|
16
|
-
this.componentType = AppObjectComponent_1.AppObjectComponentType.ENTITY;
|
|
17
|
-
this.onDisposeObserverList = new Entities_1.ObserverList();
|
|
18
|
-
this.addOnDisposeObserver = (observer) => {
|
|
19
|
-
this.onDisposeObserverList.add(observer);
|
|
20
|
-
};
|
|
21
|
-
this.removeOnDisposeObserver = (observer) => {
|
|
22
|
-
this.onDisposeObserverList.remove(observer);
|
|
23
|
-
};
|
|
24
|
-
this.onChangeObserverList = new Entities_1.ObserverList();
|
|
25
|
-
this.addChangeObserver = (observer) => {
|
|
26
|
-
this.onChangeObserverList.add(observer);
|
|
27
|
-
};
|
|
28
|
-
this.removeChangeObserver = (observer) => {
|
|
29
|
-
this.onChangeObserverList.remove(observer);
|
|
30
|
-
};
|
|
31
|
-
this.notifyOnChange = () => {
|
|
32
|
-
this.onChangeObserverList.notify();
|
|
33
|
-
};
|
|
34
|
-
this.addChangeObserver(appObject.notify);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
exports.AppObjectEntity = AppObjectEntity;
|
|
38
|
-
//# sourceMappingURL=AppObjectEntity.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppObjectEntity.js","sourceRoot":"","sources":["../../../src/AppObject/AppObjectEntity.ts"],"names":[],"mappings":";;;AAAA,0CAA2C;AAE3C,6DAAkF;AAIlF,MAAa,eAAgB,SAAQ,uCAAkB;IAuBrD,OAAO;QACL,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEjD,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;QACpC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC;QAClC,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,CAAC;QAEnC,KAAK,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC;IAED,YAAY,SAAoB,EAAE,IAAY;QAC5C,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,CAAA;QAjCf,kBAAa,GAAG,2CAAsB,CAAC,MAAM,CAAC;QAE/C,0BAAqB,GAAG,IAAI,uBAAY,EAAQ,CAAC;QACzD,yBAAoB,GAAG,CAAC,QAAiC,EAAE,EAAE;YAC3D,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC,CAAC;QACF,4BAAuB,GAAG,CAAC,QAAiC,EAAQ,EAAE;YACpE,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9C,CAAC,CAAC;QAEM,yBAAoB,GAAG,IAAI,uBAAY,EAAQ,CAAC;QACxD,sBAAiB,GAAG,CAAC,QAAiC,EAAQ,EAAE;YAC9D,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC1C,CAAC,CAAC;QACF,yBAAoB,GAAG,CAAC,QAAiC,EAAQ,EAAE;YACjE,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC7C,CAAC,CAAC;QAEF,mBAAc,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;QACrC,CAAC,CAAC;QAeA,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;CACF;AAtCD,0CAsCC","sourcesContent":["import { ObserverList } from \"../Entities\";\r\nimport { AppObject } from \"./AppObject\";\r\nimport { AppObjectComponent, AppObjectComponentType } from \"./AppObjectComponent\";\r\n\r\nexport type AppObjectEntityObserver = () => void;\r\n\r\nexport class AppObjectEntity extends AppObjectComponent {\r\n readonly componentType = AppObjectComponentType.ENTITY;\r\n \r\n private onDisposeObserverList = new ObserverList<void>();\r\n addOnDisposeObserver = (observer: AppObjectEntityObserver) => {\r\n this.onDisposeObserverList.add(observer);\r\n };\r\n removeOnDisposeObserver = (observer: AppObjectEntityObserver): void => {\r\n this.onDisposeObserverList.remove(observer);\r\n };\r\n\r\n private onChangeObserverList = new ObserverList<void>();\r\n addChangeObserver = (observer: AppObjectEntityObserver): void => {\r\n this.onChangeObserverList.add(observer);\r\n };\r\n removeChangeObserver = (observer: AppObjectEntityObserver): void => {\r\n this.onChangeObserverList.remove(observer);\r\n };\r\n\r\n notifyOnChange = () => {\r\n this.onChangeObserverList.notify();\r\n };\r\n\r\n dispose() {\r\n this.removeChangeObserver(this.appObject.notify);\r\n\r\n this.onDisposeObserverList.notify();\r\n this.onChangeObserverList.clear();\r\n this.onDisposeObserverList.clear();\r\n\r\n super.dispose();\r\n }\r\n\r\n constructor(appObject: AppObject, type: string) {\r\n super(appObject, type)\r\n \r\n this.addChangeObserver(appObject.notify);\r\n }\r\n}\r\n"]}
|