@combeenation/3d-viewer 4.0.0-rc1 → 4.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (103) hide show
  1. package/README.md +114 -114
  2. package/dist/lib-cjs/api/classes/animationInterface.d.ts +8 -8
  3. package/dist/lib-cjs/api/classes/animationInterface.js +1 -1
  4. package/dist/lib-cjs/api/classes/dottedPath.d.ts +79 -79
  5. package/dist/lib-cjs/api/classes/dottedPath.js +190 -190
  6. package/dist/lib-cjs/api/classes/element.d.ts +130 -130
  7. package/dist/lib-cjs/api/classes/element.js +746 -743
  8. package/dist/lib-cjs/api/classes/element.js.map +1 -1
  9. package/dist/lib-cjs/api/classes/elementParameterizable.d.ts +14 -14
  10. package/dist/lib-cjs/api/classes/elementParameterizable.js +134 -134
  11. package/dist/lib-cjs/api/classes/event.d.ts +326 -326
  12. package/dist/lib-cjs/api/classes/event.js +371 -371
  13. package/dist/lib-cjs/api/classes/eventBroadcaster.d.ts +26 -26
  14. package/dist/lib-cjs/api/classes/eventBroadcaster.js +53 -53
  15. package/dist/lib-cjs/api/classes/parameter.d.ts +259 -259
  16. package/dist/lib-cjs/api/classes/parameter.js +387 -387
  17. package/dist/lib-cjs/api/classes/parameter.js.map +1 -1
  18. package/dist/lib-cjs/api/classes/parameterObservable.d.ts +36 -36
  19. package/dist/lib-cjs/api/classes/parameterObservable.js +101 -101
  20. package/dist/lib-cjs/api/classes/parameterizable.d.ts +15 -15
  21. package/dist/lib-cjs/api/classes/parameterizable.js +149 -149
  22. package/dist/lib-cjs/api/classes/placementAnimation.d.ts +43 -38
  23. package/dist/lib-cjs/api/classes/placementAnimation.js +160 -149
  24. package/dist/lib-cjs/api/classes/placementAnimation.js.map +1 -1
  25. package/dist/lib-cjs/api/classes/variant.d.ts +234 -234
  26. package/dist/lib-cjs/api/classes/variant.js +1147 -1147
  27. package/dist/lib-cjs/api/classes/variantInstance.d.ts +45 -45
  28. package/dist/lib-cjs/api/classes/variantInstance.js +108 -108
  29. package/dist/lib-cjs/api/classes/variantParameterizable.d.ts +17 -17
  30. package/dist/lib-cjs/api/classes/variantParameterizable.js +99 -92
  31. package/dist/lib-cjs/api/classes/variantParameterizable.js.map +1 -1
  32. package/dist/lib-cjs/api/classes/viewer.d.ts +131 -131
  33. package/dist/lib-cjs/api/classes/viewer.js +567 -567
  34. package/dist/lib-cjs/api/classes/viewer.js.map +1 -1
  35. package/dist/lib-cjs/api/classes/viewerLight.d.ts +66 -66
  36. package/dist/lib-cjs/api/classes/viewerLight.js +392 -389
  37. package/dist/lib-cjs/api/classes/viewerLight.js.map +1 -1
  38. package/dist/lib-cjs/api/internal/debugViewer.d.ts +13 -13
  39. package/dist/lib-cjs/api/internal/debugViewer.js +87 -87
  40. package/dist/lib-cjs/api/internal/lensRendering.d.ts +8 -8
  41. package/dist/lib-cjs/api/internal/lensRendering.js +11 -11
  42. package/dist/lib-cjs/api/internal/sceneSetup.d.ts +10 -10
  43. package/dist/lib-cjs/api/internal/sceneSetup.js +231 -231
  44. package/dist/lib-cjs/api/manager/animationManager.d.ts +29 -29
  45. package/dist/lib-cjs/api/manager/animationManager.js +121 -121
  46. package/dist/lib-cjs/api/manager/gltfExportManager.d.ts +35 -0
  47. package/dist/lib-cjs/api/manager/gltfExportManager.js +108 -0
  48. package/dist/lib-cjs/api/manager/gltfExportManager.js.map +1 -0
  49. package/dist/lib-cjs/api/manager/sceneManager.d.ts +32 -32
  50. package/dist/lib-cjs/api/manager/sceneManager.js +132 -132
  51. package/dist/lib-cjs/api/manager/variantInstanceManager.d.ts +90 -90
  52. package/dist/lib-cjs/api/manager/variantInstanceManager.js +321 -321
  53. package/dist/lib-cjs/api/store/specStorage.d.ts +24 -24
  54. package/dist/lib-cjs/api/store/specStorage.js +51 -51
  55. package/dist/lib-cjs/api/util/babylonHelper.d.ts +166 -175
  56. package/dist/lib-cjs/api/util/babylonHelper.js +500 -520
  57. package/dist/lib-cjs/api/util/babylonHelper.js.map +1 -1
  58. package/dist/lib-cjs/api/util/globalTypes.d.ts +338 -333
  59. package/dist/lib-cjs/api/util/globalTypes.js +1 -1
  60. package/dist/lib-cjs/api/util/resourceHelper.d.ts +53 -53
  61. package/dist/lib-cjs/api/util/resourceHelper.js +240 -240
  62. package/dist/lib-cjs/api/util/stringHelper.d.ts +9 -9
  63. package/dist/lib-cjs/api/util/stringHelper.js +25 -25
  64. package/dist/lib-cjs/buildinfo.json +3 -3
  65. package/dist/lib-cjs/index.d.ts +48 -48
  66. package/dist/lib-cjs/index.js +86 -86
  67. package/package.json +83 -83
  68. package/src/api/classes/animationInterface.ts +11 -11
  69. package/src/api/classes/dottedPath.ts +189 -189
  70. package/src/api/classes/element.ts +648 -644
  71. package/src/api/classes/event.ts +370 -370
  72. package/src/api/classes/eventBroadcaster.ts +54 -54
  73. package/src/api/classes/parameter.ts +408 -408
  74. package/src/api/classes/parameterObservable.ts +99 -99
  75. package/src/api/classes/parameterizable.ts +89 -89
  76. package/src/api/classes/placementAnimation.ts +157 -143
  77. package/src/api/classes/variant.ts +817 -817
  78. package/src/api/classes/variantInstance.ts +88 -88
  79. package/src/api/classes/variantParameterizable.ts +80 -73
  80. package/src/api/classes/viewer.ts +487 -487
  81. package/src/api/classes/viewerLight.ts +334 -330
  82. package/src/api/internal/debugViewer.ts +81 -81
  83. package/src/api/internal/lensRendering.ts +10 -10
  84. package/src/api/internal/sceneSetup.ts +193 -193
  85. package/src/api/manager/animationManager.ts +116 -116
  86. package/src/api/manager/sceneManager.ts +105 -105
  87. package/src/api/manager/variantInstanceManager.ts +236 -236
  88. package/src/api/store/specStorage.ts +53 -53
  89. package/src/api/util/babylonHelper.ts +534 -555
  90. package/src/api/util/globalTypes.ts +385 -379
  91. package/src/api/util/resourceHelper.ts +184 -184
  92. package/src/api/util/stringHelper.ts +25 -25
  93. package/src/buildinfo.json +2 -2
  94. package/src/commonjs.tsconfig.json +13 -13
  95. package/src/declaration.tsconfig.json +10 -10
  96. package/src/dev.ts +42 -42
  97. package/src/es6.tsconfig.json +13 -13
  98. package/src/index.ts +91 -91
  99. package/src/pagesconfig.json +65 -61
  100. package/src/tsconfig.json +43 -43
  101. package/src/tsconfig.types.json +9 -9
  102. package/src/types.d.ts +4 -4
  103. package/dist/webpack-stats.json +0 -0
@@ -1,322 +1,322 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.VariantInstanceManager = void 0;
4
- var tslib_1 = require("tslib");
5
- var lodash_es_1 = require("lodash-es");
6
- var dottedPath_1 = require("../classes/dottedPath");
7
- var event_1 = require("../classes/event");
8
- var eventBroadcaster_1 = require("../classes/eventBroadcaster");
9
- var parameter_1 = require("../classes/parameter");
10
- var variantInstance_1 = require("../classes/variantInstance");
11
- /**
12
- * There's usually no need to instantiate a {@link VariantInstanceManager} yourself as it is provided by each
13
- * {@link Viewer} instance via its {@link Viewer.variantInstances}
14
- */
15
- var VariantInstanceManager = /** @class */ (function (_super) {
16
- tslib_1.__extends(VariantInstanceManager, _super);
17
- /**
18
- * Constructor.
19
- */
20
- function VariantInstanceManager(rootVariant) {
21
- var _this = _super.call(this) || this;
22
- _this.rootVariant = rootVariant;
23
- _this.variantInstances = new Map();
24
- _this.variantInstanceDefinitions = new Map();
25
- _this.parameters = {};
26
- _this.queues = {};
27
- return _this;
28
- }
29
- /**
30
- * Creates a {@link VariantInstanceManager} based on given root Variant.
31
- */
32
- VariantInstanceManager.create = function (rootVariant) {
33
- return tslib_1.__awaiter(this, void 0, void 0, function () {
34
- return tslib_1.__generator(this, function (_a) {
35
- return [2 /*return*/, new VariantInstanceManager(rootVariant)];
36
- });
37
- });
38
- };
39
- Object.defineProperty(VariantInstanceManager.prototype, "all", {
40
- /**
41
- * Gets all instances.
42
- */
43
- get: function () {
44
- var all = [];
45
- this.variantInstances.forEach(function (variantInstance) { return all.push(variantInstance); });
46
- return all;
47
- },
48
- enumerable: false,
49
- configurable: true
50
- });
51
- Object.defineProperty(VariantInstanceManager.prototype, "allDefinitions", {
52
- /**
53
- * Gets all instance definitions.
54
- */
55
- get: function () {
56
- var all = [];
57
- this.variantInstanceDefinitions.forEach(function (definition) { return all.push(definition); });
58
- return all;
59
- },
60
- enumerable: false,
61
- configurable: true
62
- });
63
- /**
64
- * Checks whether a {@link VariantInstance} is either registered or created.
65
- */
66
- VariantInstanceManager.prototype.has = function (name) {
67
- return this.variantInstances.has(name) || this.variantInstanceDefinitions.has(name);
68
- };
69
- /**
70
- * Retrieves a {@link VariantInstance}.
71
- * If the instance has been created, the created instance will be returned.
72
- * If the instance is registered, the instance will be created.
73
- * If none of these apply, an Error is thrown.
74
- *
75
- * @emits {@link Event.VARIANT_INSTANCE_CREATED}
76
- */
77
- VariantInstanceManager.prototype.get = function (name) {
78
- return tslib_1.__awaiter(this, void 0, void 0, function () {
79
- var definition;
80
- return tslib_1.__generator(this, function (_a) {
81
- switch (_a.label) {
82
- case 0:
83
- if (this.variantInstances.has(name)) {
84
- return [2 /*return*/, this.variantInstances.get(name)];
85
- }
86
- if (!this.variantInstanceDefinitions.has(name)) return [3 /*break*/, 2];
87
- definition = this.variantInstanceDefinitions.get(name);
88
- return [4 /*yield*/, this.createFromDefinition(definition)];
89
- case 1: return [2 /*return*/, _a.sent()];
90
- case 2: throw Error("VariantInstance with name \"" + name + "\" neither created nor configured.");
91
- }
92
- });
93
- });
94
- };
95
- /**
96
- * Creates and registers a unique {@link VariantInstance}.
97
- *
98
- * @emits {@link Event.VARIANT_INSTANCE_CREATED}
99
- */
100
- VariantInstanceManager.prototype.create = function (dottedPath, name, parameters) {
101
- return tslib_1.__awaiter(this, void 0, void 0, function () {
102
- var variant, definition;
103
- return tslib_1.__generator(this, function (_a) {
104
- switch (_a.label) {
105
- case 0:
106
- variant = dottedPath_1.DottedPath.create(dottedPath).path;
107
- definition = {
108
- name: this.ensureUniqueName(name ? name : variant),
109
- variant: variant,
110
- parameters: parameters
111
- };
112
- return [4 /*yield*/, this.createFromDefinition(definition)];
113
- case 1: return [2 /*return*/, _a.sent()];
114
- }
115
- });
116
- });
117
- };
118
- /**
119
- * Registers a unique {@link VariantInstanceDefinition}.
120
- *
121
- * @emits {@link Event.VARIANT_INSTANCE_REGISTERED}
122
- */
123
- VariantInstanceManager.prototype.register = function (instanceDefinition) {
124
- var name = instanceDefinition.name ? instanceDefinition.name
125
- : dottedPath_1.DottedPath.create(instanceDefinition.variant).path;
126
- instanceDefinition.name = this.ensureUniqueName(name);
127
- this.variantInstanceDefinitions.set(instanceDefinition.name, instanceDefinition);
128
- this.broadcastEvent(event_1.Event.VARIANT_INSTANCE_REGISTERED, instanceDefinition);
129
- return instanceDefinition;
130
- };
131
- /**
132
- * Commits the {@link ParameterBag} to all registered and created {@link VariantInstance}s.
133
- */
134
- VariantInstanceManager.prototype.commitParameters = function (parameters, onlyVisible) {
135
- if (parameters === void 0) { parameters = {}; }
136
- if (onlyVisible === void 0) { onlyVisible = true; }
137
- return tslib_1.__awaiter(this, void 0, void 0, function () {
138
- var instances, promises;
139
- var _this = this;
140
- return tslib_1.__generator(this, function (_a) {
141
- switch (_a.label) {
142
- case 0:
143
- this.parameters = lodash_es_1.merge(this.parameters, parameters);
144
- this.allDefinitions.forEach(function (definition) { return definition.parameters = lodash_es_1.merge(definition.parameters, _this.parameters); });
145
- instances = this.all;
146
- if (onlyVisible) {
147
- instances = this.all.filter(function (instance) { return instance.variant.visible; });
148
- }
149
- promises = instances.map(function (instance) { return instance.variant.commitParameters(_this.parameters); });
150
- return [4 /*yield*/, Promise.all(promises)];
151
- case 1:
152
- _a.sent();
153
- return [2 /*return*/, this];
154
- }
155
- });
156
- });
157
- };
158
- /**
159
- * Show one {@link VariantInstance}. If `exclusive` is set to `true` it will hide all other
160
- * instances handled by this {@link VariantInstanceManager}. If the function is called synchronously,
161
- * the calls end up in a queue according to the FIFO principle (the last one wins).
162
- */
163
- VariantInstanceManager.prototype.show = function (name, exclusive) {
164
- if (exclusive === void 0) { exclusive = false; }
165
- return tslib_1.__awaiter(this, void 0, void 0, function () {
166
- var promise, i, instance;
167
- var _this = this;
168
- return tslib_1.__generator(this, function (_a) {
169
- switch (_a.label) {
170
- case 0:
171
- promise = new Promise(function (resolve) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
172
- var instance;
173
- return tslib_1.__generator(this, function (_a) {
174
- switch (_a.label) {
175
- case 0:
176
- if (!exclusive) return [3 /*break*/, 2];
177
- this.allDefinitions.filter(function (definition) { return definition.name !== name; }).forEach(function (definition) {
178
- var parameters = {};
179
- parameters[parameter_1.Parameter.VISIBLE] = false;
180
- definition.parameters = lodash_es_1.merge(definition.parameters, parameters);
181
- });
182
- return [4 /*yield*/, Promise.all(this.all.filter(function (_instance) { return _instance.name !== name; }).map(function (_instance) {
183
- return _instance.variant.hide();
184
- }))];
185
- case 1:
186
- _a.sent();
187
- _a.label = 2;
188
- case 2: return [4 /*yield*/, this.get(name)];
189
- case 3:
190
- instance = _a.sent();
191
- return [4 /*yield*/, instance.variant.show()];
192
- case 4:
193
- _a.sent();
194
- resolve(instance);
195
- return [2 /*return*/];
196
- }
197
- });
198
- }); });
199
- if (!this.queues['show']) {
200
- this.queues['show'] = [];
201
- }
202
- this.queues['show'].push(promise);
203
- i = 0;
204
- _a.label = 1;
205
- case 1:
206
- if (!(i < this.queues['show'].length)) return [3 /*break*/, 5];
207
- return [4 /*yield*/, this.queues['show'][i]];
208
- case 2:
209
- instance = _a.sent();
210
- if (!exclusive) return [3 /*break*/, 4];
211
- if (!(i + 1 < this.queues['show'].length)) return [3 /*break*/, 4];
212
- return [4 /*yield*/, instance.variant.hide()];
213
- case 3:
214
- _a.sent();
215
- _a.label = 4;
216
- case 4:
217
- i++;
218
- return [3 /*break*/, 1];
219
- case 5:
220
- this.queues['show'] = [];
221
- return [2 /*return*/, promise];
222
- }
223
- });
224
- });
225
- };
226
- /**
227
- * Clones and registers a new {@link VariantInstance} with a new, unique name.
228
- *
229
- * @emits {@link Event.VARIANT_INSTANCE_CLONED}
230
- */
231
- VariantInstanceManager.prototype.clone = function (name, newName, parameters) {
232
- return tslib_1.__awaiter(this, void 0, void 0, function () {
233
- var variantInstance, definition, living, variantInstanceClone;
234
- return tslib_1.__generator(this, function (_a) {
235
- switch (_a.label) {
236
- case 0:
237
- if (!this.variantInstances.has(name)) {
238
- throw Error("VariantInstance with name \"" + name + "\" does not exist.");
239
- }
240
- variantInstance = this.variantInstances.get(name);
241
- definition = {
242
- name: this.ensureUniqueName(newName ? newName : name),
243
- variant: variantInstance.variant.id,
244
- parameters: parameters
245
- };
246
- return [4 /*yield*/, variantInstance.variant.createLiving(definition.parameters)];
247
- case 1:
248
- living = _a.sent();
249
- variantInstanceClone = new variantInstance_1.VariantInstance(living, definition.name);
250
- this.variantInstances.set(definition.name, variantInstanceClone);
251
- variantInstance.broadcastEvent(event_1.Event.VARIANT_INSTANCE_CLONED, variantInstanceClone);
252
- return [2 /*return*/, variantInstanceClone];
253
- }
254
- });
255
- });
256
- };
257
- /**
258
- * Destroys the instance by removing the {@link Variant} and de-registering the instance.
259
- *
260
- * @emits {@link Event.VARIANT_INSTANCE_DESTROYED}
261
- */
262
- VariantInstanceManager.prototype.destroy = function (name) {
263
- if (!this.variantInstances.has(name)) {
264
- throw Error("VariantInstance with name \"" + name + "\" does not exist.");
265
- }
266
- var variantInstance = this.variantInstances.get(name);
267
- variantInstance.variant.destroy();
268
- this.variantInstances.delete(name);
269
- variantInstance.broadcastEvent(event_1.Event.VARIANT_INSTANCE_DESTROYED, variantInstance);
270
- return this;
271
- };
272
- /**
273
- * Creates and registers a unique {@link VariantInstance} from `definition`.
274
- *
275
- * @emits {@link Event.VARIANT_INSTANCE_CREATED}
276
- */
277
- VariantInstanceManager.prototype.createFromDefinition = function (definition) {
278
- return tslib_1.__awaiter(this, void 0, void 0, function () {
279
- var variant, living, variantInstance;
280
- return tslib_1.__generator(this, function (_a) {
281
- switch (_a.label) {
282
- case 0:
283
- if (!definition.name) {
284
- throw new Error("Given VariantInstanceDefinition " + definition.variant + " is missing a name property.");
285
- }
286
- if (this.variantInstances.has(definition.name)) {
287
- throw new Error("VariantInstance with name \"" + definition.name + "\" is already created.");
288
- }
289
- if (!this.rootVariant) {
290
- throw new Error("Viewer has not been properly bootstrapped (rootVariant missing).");
291
- }
292
- return [4 /*yield*/, this.rootVariant.getDescendant(definition.variant)];
293
- case 1:
294
- variant = _a.sent();
295
- return [4 /*yield*/, variant.createLiving(definition.parameters)];
296
- case 2:
297
- living = _a.sent();
298
- variantInstance = new variantInstance_1.VariantInstance(living, definition.name);
299
- this.variantInstances.set(definition.name, variantInstance);
300
- this.broadcastEvent(event_1.Event.VARIANT_INSTANCE_CREATED, variantInstance);
301
- return [2 /*return*/, variantInstance];
302
- }
303
- });
304
- });
305
- };
306
- /**
307
- * Creates a unique instance name based on already registered instance names on the {@link VariantInstanceManager}.
308
- * Appends an `_i` to the name where `i = 0` and increments as long as the name is not registered.
309
- */
310
- VariantInstanceManager.prototype.ensureUniqueName = function (name) {
311
- var instanceName = name;
312
- var i = 1;
313
- while (this.has(instanceName)) {
314
- instanceName = name + "_" + i;
315
- i++;
316
- }
317
- return instanceName;
318
- };
319
- return VariantInstanceManager;
320
- }(eventBroadcaster_1.EventBroadcaster));
321
- exports.VariantInstanceManager = VariantInstanceManager;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.VariantInstanceManager = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var lodash_es_1 = require("lodash-es");
6
+ var dottedPath_1 = require("../classes/dottedPath");
7
+ var event_1 = require("../classes/event");
8
+ var eventBroadcaster_1 = require("../classes/eventBroadcaster");
9
+ var parameter_1 = require("../classes/parameter");
10
+ var variantInstance_1 = require("../classes/variantInstance");
11
+ /**
12
+ * There's usually no need to instantiate a {@link VariantInstanceManager} yourself as it is provided by each
13
+ * {@link Viewer} instance via its {@link Viewer.variantInstances}
14
+ */
15
+ var VariantInstanceManager = /** @class */ (function (_super) {
16
+ tslib_1.__extends(VariantInstanceManager, _super);
17
+ /**
18
+ * Constructor.
19
+ */
20
+ function VariantInstanceManager(rootVariant) {
21
+ var _this = _super.call(this) || this;
22
+ _this.rootVariant = rootVariant;
23
+ _this.variantInstances = new Map();
24
+ _this.variantInstanceDefinitions = new Map();
25
+ _this.parameters = {};
26
+ _this.queues = {};
27
+ return _this;
28
+ }
29
+ /**
30
+ * Creates a {@link VariantInstanceManager} based on given root Variant.
31
+ */
32
+ VariantInstanceManager.create = function (rootVariant) {
33
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
34
+ return tslib_1.__generator(this, function (_a) {
35
+ return [2 /*return*/, new VariantInstanceManager(rootVariant)];
36
+ });
37
+ });
38
+ };
39
+ Object.defineProperty(VariantInstanceManager.prototype, "all", {
40
+ /**
41
+ * Gets all instances.
42
+ */
43
+ get: function () {
44
+ var all = [];
45
+ this.variantInstances.forEach(function (variantInstance) { return all.push(variantInstance); });
46
+ return all;
47
+ },
48
+ enumerable: false,
49
+ configurable: true
50
+ });
51
+ Object.defineProperty(VariantInstanceManager.prototype, "allDefinitions", {
52
+ /**
53
+ * Gets all instance definitions.
54
+ */
55
+ get: function () {
56
+ var all = [];
57
+ this.variantInstanceDefinitions.forEach(function (definition) { return all.push(definition); });
58
+ return all;
59
+ },
60
+ enumerable: false,
61
+ configurable: true
62
+ });
63
+ /**
64
+ * Checks whether a {@link VariantInstance} is either registered or created.
65
+ */
66
+ VariantInstanceManager.prototype.has = function (name) {
67
+ return this.variantInstances.has(name) || this.variantInstanceDefinitions.has(name);
68
+ };
69
+ /**
70
+ * Retrieves a {@link VariantInstance}.
71
+ * If the instance has been created, the created instance will be returned.
72
+ * If the instance is registered, the instance will be created.
73
+ * If none of these apply, an Error is thrown.
74
+ *
75
+ * @emits {@link Event.VARIANT_INSTANCE_CREATED}
76
+ */
77
+ VariantInstanceManager.prototype.get = function (name) {
78
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
79
+ var definition;
80
+ return tslib_1.__generator(this, function (_a) {
81
+ switch (_a.label) {
82
+ case 0:
83
+ if (this.variantInstances.has(name)) {
84
+ return [2 /*return*/, this.variantInstances.get(name)];
85
+ }
86
+ if (!this.variantInstanceDefinitions.has(name)) return [3 /*break*/, 2];
87
+ definition = this.variantInstanceDefinitions.get(name);
88
+ return [4 /*yield*/, this.createFromDefinition(definition)];
89
+ case 1: return [2 /*return*/, _a.sent()];
90
+ case 2: throw Error("VariantInstance with name \"" + name + "\" neither created nor configured.");
91
+ }
92
+ });
93
+ });
94
+ };
95
+ /**
96
+ * Creates and registers a unique {@link VariantInstance}.
97
+ *
98
+ * @emits {@link Event.VARIANT_INSTANCE_CREATED}
99
+ */
100
+ VariantInstanceManager.prototype.create = function (dottedPath, name, parameters) {
101
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
102
+ var variant, definition;
103
+ return tslib_1.__generator(this, function (_a) {
104
+ switch (_a.label) {
105
+ case 0:
106
+ variant = dottedPath_1.DottedPath.create(dottedPath).path;
107
+ definition = {
108
+ name: this.ensureUniqueName(name ? name : variant),
109
+ variant: variant,
110
+ parameters: parameters
111
+ };
112
+ return [4 /*yield*/, this.createFromDefinition(definition)];
113
+ case 1: return [2 /*return*/, _a.sent()];
114
+ }
115
+ });
116
+ });
117
+ };
118
+ /**
119
+ * Registers a unique {@link VariantInstanceDefinition}.
120
+ *
121
+ * @emits {@link Event.VARIANT_INSTANCE_REGISTERED}
122
+ */
123
+ VariantInstanceManager.prototype.register = function (instanceDefinition) {
124
+ var name = instanceDefinition.name ? instanceDefinition.name
125
+ : dottedPath_1.DottedPath.create(instanceDefinition.variant).path;
126
+ instanceDefinition.name = this.ensureUniqueName(name);
127
+ this.variantInstanceDefinitions.set(instanceDefinition.name, instanceDefinition);
128
+ this.broadcastEvent(event_1.Event.VARIANT_INSTANCE_REGISTERED, instanceDefinition);
129
+ return instanceDefinition;
130
+ };
131
+ /**
132
+ * Commits the {@link ParameterBag} to all registered and created {@link VariantInstance}s.
133
+ */
134
+ VariantInstanceManager.prototype.commitParameters = function (parameters, onlyVisible) {
135
+ if (parameters === void 0) { parameters = {}; }
136
+ if (onlyVisible === void 0) { onlyVisible = true; }
137
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
138
+ var instances, promises;
139
+ var _this = this;
140
+ return tslib_1.__generator(this, function (_a) {
141
+ switch (_a.label) {
142
+ case 0:
143
+ this.parameters = lodash_es_1.merge(this.parameters, parameters);
144
+ this.allDefinitions.forEach(function (definition) { return definition.parameters = lodash_es_1.merge(definition.parameters, _this.parameters); });
145
+ instances = this.all;
146
+ if (onlyVisible) {
147
+ instances = this.all.filter(function (instance) { return instance.variant.visible; });
148
+ }
149
+ promises = instances.map(function (instance) { return instance.variant.commitParameters(_this.parameters); });
150
+ return [4 /*yield*/, Promise.all(promises)];
151
+ case 1:
152
+ _a.sent();
153
+ return [2 /*return*/, this];
154
+ }
155
+ });
156
+ });
157
+ };
158
+ /**
159
+ * Show one {@link VariantInstance}. If `exclusive` is set to `true` it will hide all other
160
+ * instances handled by this {@link VariantInstanceManager}. If the function is called synchronously,
161
+ * the calls end up in a queue according to the FIFO principle (the last one wins).
162
+ */
163
+ VariantInstanceManager.prototype.show = function (name, exclusive) {
164
+ if (exclusive === void 0) { exclusive = false; }
165
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
166
+ var promise, i, instance;
167
+ var _this = this;
168
+ return tslib_1.__generator(this, function (_a) {
169
+ switch (_a.label) {
170
+ case 0:
171
+ promise = new Promise(function (resolve) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
172
+ var instance;
173
+ return tslib_1.__generator(this, function (_a) {
174
+ switch (_a.label) {
175
+ case 0:
176
+ if (!exclusive) return [3 /*break*/, 2];
177
+ this.allDefinitions.filter(function (definition) { return definition.name !== name; }).forEach(function (definition) {
178
+ var parameters = {};
179
+ parameters[parameter_1.Parameter.VISIBLE] = false;
180
+ definition.parameters = lodash_es_1.merge(definition.parameters, parameters);
181
+ });
182
+ return [4 /*yield*/, Promise.all(this.all.filter(function (_instance) { return _instance.name !== name; }).map(function (_instance) {
183
+ return _instance.variant.hide();
184
+ }))];
185
+ case 1:
186
+ _a.sent();
187
+ _a.label = 2;
188
+ case 2: return [4 /*yield*/, this.get(name)];
189
+ case 3:
190
+ instance = _a.sent();
191
+ return [4 /*yield*/, instance.variant.show()];
192
+ case 4:
193
+ _a.sent();
194
+ resolve(instance);
195
+ return [2 /*return*/];
196
+ }
197
+ });
198
+ }); });
199
+ if (!this.queues['show']) {
200
+ this.queues['show'] = [];
201
+ }
202
+ this.queues['show'].push(promise);
203
+ i = 0;
204
+ _a.label = 1;
205
+ case 1:
206
+ if (!(i < this.queues['show'].length)) return [3 /*break*/, 5];
207
+ return [4 /*yield*/, this.queues['show'][i]];
208
+ case 2:
209
+ instance = _a.sent();
210
+ if (!exclusive) return [3 /*break*/, 4];
211
+ if (!(i + 1 < this.queues['show'].length)) return [3 /*break*/, 4];
212
+ return [4 /*yield*/, instance.variant.hide()];
213
+ case 3:
214
+ _a.sent();
215
+ _a.label = 4;
216
+ case 4:
217
+ i++;
218
+ return [3 /*break*/, 1];
219
+ case 5:
220
+ this.queues['show'] = [];
221
+ return [2 /*return*/, promise];
222
+ }
223
+ });
224
+ });
225
+ };
226
+ /**
227
+ * Clones and registers a new {@link VariantInstance} with a new, unique name.
228
+ *
229
+ * @emits {@link Event.VARIANT_INSTANCE_CLONED}
230
+ */
231
+ VariantInstanceManager.prototype.clone = function (name, newName, parameters) {
232
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
233
+ var variantInstance, definition, living, variantInstanceClone;
234
+ return tslib_1.__generator(this, function (_a) {
235
+ switch (_a.label) {
236
+ case 0:
237
+ if (!this.variantInstances.has(name)) {
238
+ throw Error("VariantInstance with name \"" + name + "\" does not exist.");
239
+ }
240
+ variantInstance = this.variantInstances.get(name);
241
+ definition = {
242
+ name: this.ensureUniqueName(newName ? newName : name),
243
+ variant: variantInstance.variant.id,
244
+ parameters: parameters
245
+ };
246
+ return [4 /*yield*/, variantInstance.variant.createLiving(definition.parameters)];
247
+ case 1:
248
+ living = _a.sent();
249
+ variantInstanceClone = new variantInstance_1.VariantInstance(living, definition.name);
250
+ this.variantInstances.set(definition.name, variantInstanceClone);
251
+ variantInstance.broadcastEvent(event_1.Event.VARIANT_INSTANCE_CLONED, variantInstanceClone);
252
+ return [2 /*return*/, variantInstanceClone];
253
+ }
254
+ });
255
+ });
256
+ };
257
+ /**
258
+ * Destroys the instance by removing the {@link Variant} and de-registering the instance.
259
+ *
260
+ * @emits {@link Event.VARIANT_INSTANCE_DESTROYED}
261
+ */
262
+ VariantInstanceManager.prototype.destroy = function (name) {
263
+ if (!this.variantInstances.has(name)) {
264
+ throw Error("VariantInstance with name \"" + name + "\" does not exist.");
265
+ }
266
+ var variantInstance = this.variantInstances.get(name);
267
+ variantInstance.variant.destroy();
268
+ this.variantInstances.delete(name);
269
+ variantInstance.broadcastEvent(event_1.Event.VARIANT_INSTANCE_DESTROYED, variantInstance);
270
+ return this;
271
+ };
272
+ /**
273
+ * Creates and registers a unique {@link VariantInstance} from `definition`.
274
+ *
275
+ * @emits {@link Event.VARIANT_INSTANCE_CREATED}
276
+ */
277
+ VariantInstanceManager.prototype.createFromDefinition = function (definition) {
278
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
279
+ var variant, living, variantInstance;
280
+ return tslib_1.__generator(this, function (_a) {
281
+ switch (_a.label) {
282
+ case 0:
283
+ if (!definition.name) {
284
+ throw new Error("Given VariantInstanceDefinition " + definition.variant + " is missing a name property.");
285
+ }
286
+ if (this.variantInstances.has(definition.name)) {
287
+ throw new Error("VariantInstance with name \"" + definition.name + "\" is already created.");
288
+ }
289
+ if (!this.rootVariant) {
290
+ throw new Error("Viewer has not been properly bootstrapped (rootVariant missing).");
291
+ }
292
+ return [4 /*yield*/, this.rootVariant.getDescendant(definition.variant)];
293
+ case 1:
294
+ variant = _a.sent();
295
+ return [4 /*yield*/, variant.createLiving(definition.parameters)];
296
+ case 2:
297
+ living = _a.sent();
298
+ variantInstance = new variantInstance_1.VariantInstance(living, definition.name);
299
+ this.variantInstances.set(definition.name, variantInstance);
300
+ this.broadcastEvent(event_1.Event.VARIANT_INSTANCE_CREATED, variantInstance);
301
+ return [2 /*return*/, variantInstance];
302
+ }
303
+ });
304
+ });
305
+ };
306
+ /**
307
+ * Creates a unique instance name based on already registered instance names on the {@link VariantInstanceManager}.
308
+ * Appends an `_i` to the name where `i = 0` and increments as long as the name is not registered.
309
+ */
310
+ VariantInstanceManager.prototype.ensureUniqueName = function (name) {
311
+ var instanceName = name;
312
+ var i = 1;
313
+ while (this.has(instanceName)) {
314
+ instanceName = name + "_" + i;
315
+ i++;
316
+ }
317
+ return instanceName;
318
+ };
319
+ return VariantInstanceManager;
320
+ }(eventBroadcaster_1.EventBroadcaster));
321
+ exports.VariantInstanceManager = VariantInstanceManager;
322
322
  //# sourceMappingURL=variantInstanceManager.js.map