@combeenation/3d-viewer 4.0.0-alpha9 → 4.0.0-beta4

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 (105) hide show
  1. package/README.md +112 -111
  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 +125 -130
  7. package/dist/lib-cjs/api/classes/element.js +682 -739
  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 +312 -326
  12. package/dist/lib-cjs/api/classes/event.js +357 -371
  13. package/dist/lib-cjs/api/classes/event.js.map +1 -1
  14. package/dist/lib-cjs/api/classes/eventBroadcaster.d.ts +26 -26
  15. package/dist/lib-cjs/api/classes/eventBroadcaster.js +53 -53
  16. package/dist/lib-cjs/api/classes/parameter.d.ts +165 -259
  17. package/dist/lib-cjs/api/classes/parameter.js +267 -387
  18. package/dist/lib-cjs/api/classes/parameter.js.map +1 -1
  19. package/dist/lib-cjs/api/classes/parameterObservable.d.ts +36 -36
  20. package/dist/lib-cjs/api/classes/parameterObservable.js +126 -101
  21. package/dist/lib-cjs/api/classes/parameterObservable.js.map +1 -1
  22. package/dist/lib-cjs/api/classes/parameterizable.d.ts +15 -15
  23. package/dist/lib-cjs/api/classes/parameterizable.js +149 -149
  24. package/dist/lib-cjs/api/classes/placementAnimation.d.ts +38 -38
  25. package/dist/lib-cjs/api/classes/placementAnimation.js +138 -138
  26. package/dist/lib-cjs/api/classes/variant.d.ts +190 -224
  27. package/dist/lib-cjs/api/classes/variant.js +873 -1137
  28. package/dist/lib-cjs/api/classes/variant.js.map +1 -1
  29. package/dist/lib-cjs/api/classes/variantInstance.d.ts +41 -45
  30. package/dist/lib-cjs/api/classes/variantInstance.js +98 -108
  31. package/dist/lib-cjs/api/classes/variantInstance.js.map +1 -1
  32. package/dist/lib-cjs/api/classes/variantParameterizable.d.ts +17 -17
  33. package/dist/lib-cjs/api/classes/variantParameterizable.js +92 -92
  34. package/dist/lib-cjs/api/classes/viewer.d.ts +128 -131
  35. package/dist/lib-cjs/api/classes/viewer.js +486 -538
  36. package/dist/lib-cjs/api/classes/viewer.js.map +1 -1
  37. package/dist/lib-cjs/api/classes/viewerLight.d.ts +65 -66
  38. package/dist/lib-cjs/api/classes/viewerLight.js +322 -389
  39. package/dist/lib-cjs/api/classes/viewerLight.js.map +1 -1
  40. package/dist/lib-cjs/api/internal/debugViewer.d.ts +13 -13
  41. package/dist/lib-cjs/api/internal/debugViewer.js +87 -87
  42. package/dist/lib-cjs/api/internal/lensRendering.d.ts +8 -8
  43. package/dist/lib-cjs/api/internal/lensRendering.js +11 -11
  44. package/dist/lib-cjs/api/internal/sceneSetup.d.ts +6 -10
  45. package/dist/lib-cjs/api/internal/sceneSetup.js +227 -231
  46. package/dist/lib-cjs/api/internal/sceneSetup.js.map +1 -1
  47. package/dist/lib-cjs/api/manager/animationManager.d.ts +29 -29
  48. package/dist/lib-cjs/api/manager/animationManager.js +121 -121
  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 +125 -175
  56. package/dist/lib-cjs/api/util/babylonHelper.js +368 -520
  57. package/dist/lib-cjs/api/util/babylonHelper.js.map +1 -1
  58. package/dist/lib-cjs/api/util/globalTypes.d.ts +279 -321
  59. package/dist/lib-cjs/api/util/globalTypes.js +1 -1
  60. package/dist/lib-cjs/api/util/resourceHelper.d.ts +51 -26
  61. package/dist/lib-cjs/api/util/resourceHelper.js +243 -237
  62. package/dist/lib-cjs/api/util/resourceHelper.js.map +1 -1
  63. package/dist/lib-cjs/api/util/stringHelper.d.ts +9 -9
  64. package/dist/lib-cjs/api/util/stringHelper.js +25 -25
  65. package/dist/lib-cjs/buildinfo.json +3 -3
  66. package/dist/lib-cjs/index.d.ts +46 -48
  67. package/dist/lib-cjs/index.js +82 -86
  68. package/dist/lib-cjs/index.js.map +1 -1
  69. package/dist/webpack-stats.json +0 -0
  70. package/package.json +83 -83
  71. package/src/api/classes/animationInterface.ts +11 -11
  72. package/src/api/classes/dottedPath.ts +189 -189
  73. package/src/api/classes/element.ts +617 -635
  74. package/src/api/classes/{parameterizable.ts → elementParameterizable.ts} +78 -89
  75. package/src/api/classes/event.ts +355 -370
  76. package/src/api/classes/eventBroadcaster.ts +54 -54
  77. package/src/api/classes/parameter.ts +277 -408
  78. package/src/api/classes/parameterObservable.ts +121 -99
  79. package/src/api/classes/placementAnimation.ts +133 -133
  80. package/src/api/classes/variant.ts +670 -806
  81. package/src/api/classes/variantInstance.ts +81 -88
  82. package/src/api/classes/viewer.ts +421 -473
  83. package/src/api/internal/debugViewer.ts +81 -81
  84. package/src/api/internal/lensRendering.ts +10 -10
  85. package/src/api/internal/sceneSetup.ts +204 -194
  86. package/src/api/manager/animationManager.ts +116 -116
  87. package/src/api/manager/sceneManager.ts +105 -105
  88. package/src/api/manager/variantInstanceManager.ts +236 -236
  89. package/src/api/store/specStorage.ts +53 -53
  90. package/src/api/util/babylonHelper.ts +392 -553
  91. package/src/api/util/globalTypes.ts +318 -369
  92. package/src/api/util/resourceHelper.ts +187 -157
  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 +46 -44
  97. package/src/es6.tsconfig.json +13 -13
  98. package/src/index.ts +87 -91
  99. package/src/pagesconfig.json +57 -52
  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/src/api/classes/variantParameterizable.ts +0 -73
  104. package/src/api/classes/viewerLight.ts +0 -330
  105. package/src/api/util/stringHelper.ts +0 -26
@@ -1,26 +1,51 @@
1
- /**
2
- * Loads a JSON from a given path.
3
- * @emits {@link Event.LOADING_START}
4
- * @emits {@link Event.LOADING_END}
5
- */
6
- declare const loadJson: <T>(path: string) => Promise<T>;
7
- /**
8
- * Loads a Text from a given path.
9
- * @emits {@link Event.LOADING_START}
10
- * @emits {@link Event.LOADING_END}
11
- */
12
- declare const loadText: (path: string) => Promise<string>;
13
- /**
14
- * Debounces: it limits the rate at which a function can fire.
15
- */
16
- declare const debounce: (func: Function, wait: number, immediate?: boolean) => () => void;
17
- /**
18
- * Merges multiple maps.
19
- */
20
- declare const mergeMaps: <TKey, TValue>(...maps: Map<TKey, TValue>[]) => Map<TKey, TValue>;
21
- /**
22
- * Creates an `ImageBitmap` from a SVG string using native `createImageBitmap` functionality.
23
- */
24
- declare const createImageBitmapFromSvg: (svgSrc: string) => Promise<ImageBitmap>;
25
- declare const createImageBitmapFromImgSrc: (imgSrc: string) => Promise<ImageBitmap>;
26
- export { loadJson, loadText, debounce, mergeMaps, createImageBitmapFromSvg, createImageBitmapFromImgSrc };
1
+ /**
2
+ * Loads a JSON from a given path.
3
+ * @emits {@link Event.LOADING_START}
4
+ * @emits {@link Event.LOADING_END}
5
+ */
6
+ declare const loadJson: <T>(path: string) => Promise<T>;
7
+ /**
8
+ * Loads a Text from a given path.
9
+ * @emits {@link Event.LOADING_START}
10
+ * @emits {@link Event.LOADING_END}
11
+ */
12
+ declare const loadText: (path: string) => Promise<string>;
13
+ /**
14
+ * Debounces: it limits the rate at which a function can fire.
15
+ */
16
+ declare const debounce: (func: Function, wait: number, immediate?: boolean) => () => void;
17
+ /**
18
+ * Creates a random uuidv4.
19
+ */
20
+ declare const uuidv4: () => any;
21
+ /**
22
+ * Merges multiple maps.
23
+ */
24
+ declare const mergeMaps: <TKey, TValue>(...maps: Map<TKey, TValue>[]) => Map<TKey, TValue>;
25
+ /**
26
+ * Creates a HTML image element based on a SVG string, whereas all the embedded assets in the SVG
27
+ * (eg: fonts, images) are already loaded and exchanged by their base64 representation.\
28
+ * There the output image can exist as "standalone" image and may be used for example as a paintable.
29
+ *
30
+ * !!CAUTION!!: The used functions within this code section are very well evaluated since most alternatives
31
+ * somehow don't work in Safari, as mentioned in the following BJS forum entries:
32
+ * - https://forum.babylonjs.com/t/drawing-svg-content-text-into-dynamictexture-doesnt-work-in-safari-v15/25048
33
+ * - https://forum.babylonjs.com/t/texture-createfrombase64string-doesnt-seem-to-work-for-ios-devices-initially/25502
34
+ */
35
+ declare const createImageFromSvg: (svgSrc: string) => Promise<HTMLImageElement>;
36
+ /**
37
+ * Creates an HTML image element from a dedicated image source.\
38
+ * Also waits until the image has loaded.
39
+ *
40
+ * !!CAUTION!!: The `setTimeout` after loading is finished is required due to a Safari bug:
41
+ * - https://bugs.webkit.org/show_bug.cgi?id=39059
42
+ * - https://bugs.webkit.org/show_bug.cgi?id=219770
43
+ *
44
+ * It's not 100% ensured that the timeout solves the issue in every case, but there is no other way unfortunately.\
45
+ * => Keep an eye on it in future projects
46
+ *
47
+ * @param imgSrc Theoretically every source is valid which is also supported by [HTMLImageElement.src](https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/src).\
48
+ * Known exceptions are SVGs with embedded assets that are provided as object URL. (see comments in {@link createImageFromSvg})
49
+ */
50
+ declare const createImageFromImgSrc: (imgSrc: string) => Promise<HTMLImageElement>;
51
+ export { loadJson, loadText, debounce, uuidv4, mergeMaps, createImageFromSvg, createImageFromImgSrc };
@@ -1,238 +1,244 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createImageBitmapFromImgSrc = exports.createImageBitmapFromSvg = exports.mergeMaps = exports.debounce = exports.loadText = exports.loadJson = void 0;
4
- var tslib_1 = require("tslib");
5
- var event_1 = require("../classes/event");
6
- /**
7
- * Loads any kind of response from given path.
8
- * @emits {@link Event.LOADING_START}
9
- * @emits {@link Event.LOADING_END}
10
- */
11
- var load = function (path) {
12
- return tslib_1.__awaiter(this, void 0, void 0, function () {
13
- var data;
14
- return tslib_1.__generator(this, function (_a) {
15
- switch (_a.label) {
16
- case 0:
17
- event_1.emitter.emit(event_1.Event.LOADING_START, path);
18
- return [4 /*yield*/, fetch(path)];
19
- case 1:
20
- data = _a.sent();
21
- event_1.emitter.emit(event_1.Event.LOADING_END, path);
22
- return [2 /*return*/, data];
23
- }
24
- });
25
- });
26
- };
27
- /**
28
- * Loads a JSON from a given path.
29
- * @emits {@link Event.LOADING_START}
30
- * @emits {@link Event.LOADING_END}
31
- */
32
- var loadJson = function (path) {
33
- return tslib_1.__awaiter(this, void 0, void 0, function () {
34
- var response;
35
- return tslib_1.__generator(this, function (_a) {
36
- switch (_a.label) {
37
- case 0: return [4 /*yield*/, load(path)];
38
- case 1:
39
- response = _a.sent();
40
- return [2 /*return*/, response.json()];
41
- }
42
- });
43
- });
44
- };
45
- exports.loadJson = loadJson;
46
- /**
47
- * Loads a Text from a given path.
48
- * @emits {@link Event.LOADING_START}
49
- * @emits {@link Event.LOADING_END}
50
- */
51
- var loadText = function (path) {
52
- return tslib_1.__awaiter(this, void 0, void 0, function () {
53
- var response;
54
- return tslib_1.__generator(this, function (_a) {
55
- switch (_a.label) {
56
- case 0: return [4 /*yield*/, load(path)];
57
- case 1:
58
- response = _a.sent();
59
- return [2 /*return*/, response.text()];
60
- }
61
- });
62
- });
63
- };
64
- exports.loadText = loadText;
65
- /**
66
- * Debounces: it limits the rate at which a function can fire.
67
- */
68
- var debounce = function (func, wait, immediate) {
69
- if (immediate === void 0) { immediate = false; }
70
- var timeout;
71
- return function () {
72
- // @ts-ignore
73
- var context = this;
74
- var args = arguments;
75
- var later = function () {
76
- timeout = null;
77
- if (!immediate) {
78
- func.apply(context, args);
79
- }
80
- };
81
- var callNow = immediate && !timeout;
82
- clearTimeout(timeout);
83
- timeout = setTimeout(later, wait);
84
- if (callNow) {
85
- func.apply(context, args);
86
- }
87
- };
88
- };
89
- exports.debounce = debounce;
90
- /**
91
- * Merges multiple maps.
92
- */
93
- var mergeMaps = function () {
94
- var maps = [];
95
- for (var _i = 0; _i < arguments.length; _i++) {
96
- maps[_i] = arguments[_i];
97
- }
98
- var resultMap = new Map();
99
- maps.forEach(function (map) {
100
- map.forEach(function (v, k) {
101
- resultMap.set(k, v);
102
- });
103
- });
104
- return resultMap;
105
- };
106
- exports.mergeMaps = mergeMaps;
107
- /**
108
- * Creates an `ImageBitmap` from a SVG string using native `createImageBitmap` functionality.
109
- */
110
- var createImageBitmapFromSvg = function (svgSrc) {
111
- return tslib_1.__awaiter(this, void 0, void 0, function () {
112
- var _this = this;
113
- return tslib_1.__generator(this, function (_a) {
114
- return [2 /*return*/, new Promise(function (resolve) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
115
- var svgWithAssetsEmbedded, svgBlob, svgBase64, img;
116
- var _this = this;
117
- return tslib_1.__generator(this, function (_a) {
118
- switch (_a.label) {
119
- case 0: return [4 /*yield*/, _embedAssets(svgSrc)];
120
- case 1:
121
- svgWithAssetsEmbedded = _a.sent();
122
- svgBlob = new Blob([svgWithAssetsEmbedded], { type: 'image/svg+xml;charset=utf-8' });
123
- svgBase64 = URL.createObjectURL(svgBlob);
124
- img = new Image();
125
- img.onload = function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
126
- var imgBitmap;
127
- return tslib_1.__generator(this, function (_a) {
128
- switch (_a.label) {
129
- case 0: return [4 /*yield*/, createImageBitmap(img)];
130
- case 1:
131
- imgBitmap = _a.sent();
132
- resolve(imgBitmap);
133
- return [2 /*return*/];
134
- }
135
- });
136
- }); };
137
- img.src = svgBase64;
138
- return [2 /*return*/];
139
- }
140
- });
141
- }); })];
142
- });
143
- });
144
- };
145
- exports.createImageBitmapFromSvg = createImageBitmapFromSvg;
146
- var createImageBitmapFromImgSrc = function (imgSrc) {
147
- return tslib_1.__awaiter(this, void 0, void 0, function () {
148
- var img;
149
- var _this = this;
150
- return tslib_1.__generator(this, function (_a) {
151
- img = new Image();
152
- img.src = imgSrc;
153
- return [2 /*return*/, new Promise(function (resolve) {
154
- img.onload = function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
155
- var imgBitmap;
156
- return tslib_1.__generator(this, function (_a) {
157
- switch (_a.label) {
158
- case 0: return [4 /*yield*/, createImageBitmap(img)];
159
- case 1:
160
- imgBitmap = _a.sent();
161
- resolve(imgBitmap);
162
- return [2 /*return*/];
163
- }
164
- });
165
- }); };
166
- })];
167
- });
168
- });
169
- };
170
- exports.createImageBitmapFromImgSrc = createImageBitmapFromImgSrc;
171
- /**
172
- * Replaces all supported image & font URLs in the given SVG with their base64 representation.
173
- */
174
- var _embedAssets = function (svgSrc) {
175
- return tslib_1.__awaiter(this, void 0, void 0, function () {
176
- var _imageExtensions, _fontExtensions, _assetExtensions, urlRegex, allUrls, assetUrls, assetBase64Fetcher, assetFetcherResults;
177
- return tslib_1.__generator(this, function (_a) {
178
- switch (_a.label) {
179
- case 0:
180
- _imageExtensions = ['png', 'gif', 'jpg', 'jpeg', 'svg', 'bmp'];
181
- _fontExtensions = ['woff2', 'woff', 'ttf', 'otf'];
182
- _assetExtensions = tslib_1.__spreadArrays(_imageExtensions, _fontExtensions);
183
- urlRegex = /(\bhttps?:\/\/[-A-Z0-9+&@#/%?=~_|!:,.;]*[-A-Z0-9+&@#/%=~_|])/gi;
184
- allUrls = svgSrc.match(urlRegex);
185
- assetUrls = allUrls.filter(function (url) { return _assetExtensions.some(function (extension) { return url.toLowerCase().endsWith("." + extension); }); });
186
- assetBase64Fetcher = assetUrls.map(_fetchBase64AssetUrl);
187
- return [4 /*yield*/, Promise.all(assetBase64Fetcher)];
188
- case 1:
189
- assetFetcherResults = _a.sent();
190
- return [2 /*return*/, assetFetcherResults.reduce(function (svgSrc, x) { return svgSrc.replace(x.url, x.base64); }, svgSrc)];
191
- }
192
- });
193
- });
194
- };
195
- /**
196
- * Fetch asset (image or font) and convert it to base64 string representation.
197
- */
198
- var _fetchBase64AssetUrl = function (assetUrl) {
199
- return tslib_1.__awaiter(this, void 0, void 0, function () {
200
- var _this = this;
201
- return tslib_1.__generator(this, function (_a) {
202
- // TODO: Cache known base64 representation and only fetch/convert when not already known.
203
- // Usually the fetch shouldn't hit the network but the browser cache since the SVG was already drawn.
204
- // See comments of "createImageBitmapFromSvg" for some considerations...
205
- return [2 /*return*/, new Promise(function (resolve, reject) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
206
- var resp, blob, reader;
207
- return tslib_1.__generator(this, function (_a) {
208
- switch (_a.label) {
209
- case 0: return [4 /*yield*/, fetch(assetUrl)];
210
- case 1:
211
- resp = _a.sent();
212
- return [4 /*yield*/, resp.blob()];
213
- case 2:
214
- blob = _a.sent();
215
- reader = new FileReader();
216
- reader.onloadend = function (event) {
217
- var target = event.target;
218
- if (!target) {
219
- return reject("Asset with URL \"" + assetUrl + "\" could not be loaded.");
220
- }
221
- var result = target.result;
222
- if (!result) {
223
- return reject("Asset with URL \"" + assetUrl + "\" returned an empty result.");
224
- }
225
- resolve({
226
- url: assetUrl,
227
- base64: result.toString(),
228
- });
229
- };
230
- reader.readAsDataURL(blob);
231
- return [2 /*return*/];
232
- }
233
- });
234
- }); })];
235
- });
236
- });
237
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createImageFromImgSrc = exports.createImageFromSvg = exports.mergeMaps = exports.uuidv4 = exports.debounce = exports.loadText = exports.loadJson = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var event_1 = require("../classes/event");
6
+ /**
7
+ * Loads any kind of response from given path.
8
+ * @emits {@link Event.LOADING_START}
9
+ * @emits {@link Event.LOADING_END}
10
+ */
11
+ var load = function (path) {
12
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
13
+ var data;
14
+ return tslib_1.__generator(this, function (_a) {
15
+ switch (_a.label) {
16
+ case 0:
17
+ event_1.emitter.emit(event_1.Event.LOADING_START, path);
18
+ return [4 /*yield*/, fetch(path)];
19
+ case 1:
20
+ data = _a.sent();
21
+ event_1.emitter.emit(event_1.Event.LOADING_END, path);
22
+ return [2 /*return*/, data];
23
+ }
24
+ });
25
+ });
26
+ };
27
+ /**
28
+ * Loads a JSON from a given path.
29
+ * @emits {@link Event.LOADING_START}
30
+ * @emits {@link Event.LOADING_END}
31
+ */
32
+ var loadJson = function (path) {
33
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
34
+ var response;
35
+ return tslib_1.__generator(this, function (_a) {
36
+ switch (_a.label) {
37
+ case 0: return [4 /*yield*/, load(path)];
38
+ case 1:
39
+ response = _a.sent();
40
+ return [2 /*return*/, response.json()];
41
+ }
42
+ });
43
+ });
44
+ };
45
+ exports.loadJson = loadJson;
46
+ /**
47
+ * Loads a Text from a given path.
48
+ * @emits {@link Event.LOADING_START}
49
+ * @emits {@link Event.LOADING_END}
50
+ */
51
+ var loadText = function (path) {
52
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
53
+ var response;
54
+ return tslib_1.__generator(this, function (_a) {
55
+ switch (_a.label) {
56
+ case 0: return [4 /*yield*/, load(path)];
57
+ case 1:
58
+ response = _a.sent();
59
+ return [2 /*return*/, response.text()];
60
+ }
61
+ });
62
+ });
63
+ };
64
+ exports.loadText = loadText;
65
+ /**
66
+ * Debounces: it limits the rate at which a function can fire.
67
+ */
68
+ var debounce = function (func, wait, immediate) {
69
+ if (immediate === void 0) { immediate = false; }
70
+ var timeout;
71
+ return function () {
72
+ // @ts-ignore
73
+ var context = this;
74
+ var args = arguments;
75
+ var later = function () {
76
+ timeout = null;
77
+ if (!immediate) {
78
+ func.apply(context, args);
79
+ }
80
+ };
81
+ var callNow = immediate && !timeout;
82
+ clearTimeout(timeout);
83
+ timeout = setTimeout(later, wait);
84
+ if (callNow) {
85
+ func.apply(context, args);
86
+ }
87
+ };
88
+ };
89
+ exports.debounce = debounce;
90
+ /**
91
+ * Creates a random uuidv4.
92
+ */
93
+ var uuidv4 = function () {
94
+ // @ts-ignore
95
+ return ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, function (c) {
96
+ return (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16);
97
+ });
98
+ };
99
+ exports.uuidv4 = uuidv4;
100
+ /**
101
+ * Merges multiple maps.
102
+ */
103
+ var mergeMaps = function () {
104
+ var maps = [];
105
+ for (var _i = 0; _i < arguments.length; _i++) {
106
+ maps[_i] = arguments[_i];
107
+ }
108
+ var resultMap = new Map();
109
+ maps.forEach(function (map) {
110
+ map.forEach(function (v, k) {
111
+ resultMap.set(k, v);
112
+ });
113
+ });
114
+ return resultMap;
115
+ };
116
+ exports.mergeMaps = mergeMaps;
117
+ /**
118
+ * Creates a HTML image element based on a SVG string, whereas all the embedded assets in the SVG
119
+ * (eg: fonts, images) are already loaded and exchanged by their base64 representation.\
120
+ * There the output image can exist as "standalone" image and may be used for example as a paintable.
121
+ *
122
+ * !!CAUTION!!: The used functions within this code section are very well evaluated since most alternatives
123
+ * somehow don't work in Safari, as mentioned in the following BJS forum entries:
124
+ * - https://forum.babylonjs.com/t/drawing-svg-content-text-into-dynamictexture-doesnt-work-in-safari-v15/25048
125
+ * - https://forum.babylonjs.com/t/texture-createfrombase64string-doesnt-seem-to-work-for-ios-devices-initially/25502
126
+ */
127
+ var createImageFromSvg = function (svgSrc) {
128
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
129
+ var svgWithAssetsEmbedded, svgEncoded;
130
+ return tslib_1.__generator(this, function (_a) {
131
+ switch (_a.label) {
132
+ case 0: return [4 /*yield*/, _embedAssets(svgSrc)];
133
+ case 1:
134
+ svgWithAssetsEmbedded = _a.sent();
135
+ svgEncoded = 'data:image/svg+xml,' + encodeURIComponent(svgWithAssetsEmbedded);
136
+ return [2 /*return*/, createImageFromImgSrc(svgEncoded)];
137
+ }
138
+ });
139
+ });
140
+ };
141
+ exports.createImageFromSvg = createImageFromSvg;
142
+ /**
143
+ * Creates an HTML image element from a dedicated image source.\
144
+ * Also waits until the image has loaded.
145
+ *
146
+ * !!CAUTION!!: The `setTimeout` after loading is finished is required due to a Safari bug:
147
+ * - https://bugs.webkit.org/show_bug.cgi?id=39059
148
+ * - https://bugs.webkit.org/show_bug.cgi?id=219770
149
+ *
150
+ * It's not 100% ensured that the timeout solves the issue in every case, but there is no other way unfortunately.\
151
+ * => Keep an eye on it in future projects
152
+ *
153
+ * @param imgSrc Theoretically every source is valid which is also supported by [HTMLImageElement.src](https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/src).\
154
+ * Known exceptions are SVGs with embedded assets that are provided as object URL. (see comments in {@link createImageFromSvg})
155
+ */
156
+ var createImageFromImgSrc = function (imgSrc) {
157
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
158
+ var img;
159
+ return tslib_1.__generator(this, function (_a) {
160
+ switch (_a.label) {
161
+ case 0:
162
+ img = new Image();
163
+ return [4 /*yield*/, new Promise(function (resolve) {
164
+ img.onload = function () {
165
+ setTimeout(resolve, 0);
166
+ };
167
+ img.src = imgSrc;
168
+ })];
169
+ case 1:
170
+ _a.sent();
171
+ return [2 /*return*/, img];
172
+ }
173
+ });
174
+ });
175
+ };
176
+ exports.createImageFromImgSrc = createImageFromImgSrc;
177
+ /**
178
+ * Replaces all supported image & font URLs in the given SVG with their base64 representation.
179
+ */
180
+ var _embedAssets = function (svgSrc) {
181
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
182
+ var _imageExtensions, _fontExtensions, _assetExtensions, urlRegex, allUrls, assetUrls, assetBase64Fetcher, assetFetcherResults;
183
+ return tslib_1.__generator(this, function (_a) {
184
+ switch (_a.label) {
185
+ case 0:
186
+ _imageExtensions = ['png', 'gif', 'jpg', 'jpeg', 'svg', 'bmp'];
187
+ _fontExtensions = ['woff2', 'woff', 'ttf', 'otf'];
188
+ _assetExtensions = tslib_1.__spreadArrays(_imageExtensions, _fontExtensions);
189
+ urlRegex = /(\bhttps?:\/\/[-A-Z0-9+&@#/%?=~_|!:,.;]*[-A-Z0-9+&@#/%=~_|])/gi;
190
+ allUrls = svgSrc.match(urlRegex);
191
+ assetUrls = allUrls.filter(function (url) { return _assetExtensions.some(function (extension) { return url.toLowerCase().endsWith("." + extension); }); });
192
+ assetBase64Fetcher = assetUrls.map(_fetchBase64AssetUrl);
193
+ return [4 /*yield*/, Promise.all(assetBase64Fetcher)];
194
+ case 1:
195
+ assetFetcherResults = _a.sent();
196
+ return [2 /*return*/, assetFetcherResults.reduce(function (svgSrc, x) { return svgSrc.replace(x.url, x.base64); }, svgSrc)];
197
+ }
198
+ });
199
+ });
200
+ };
201
+ /**
202
+ * Fetch asset (image or font) and convert it to base64 string representation.
203
+ */
204
+ var _fetchBase64AssetUrl = function (assetUrl) {
205
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
206
+ var _this = this;
207
+ return tslib_1.__generator(this, function (_a) {
208
+ // TODO: Cache known base64 representation and only fetch/convert when not already known.
209
+ // Usually the fetch shouldn't hit the network but the browser cache since the SVG was already drawn.
210
+ // See comments of "createImageBitmapFromSvg" for some considerations...
211
+ return [2 /*return*/, new Promise(function (resolve, reject) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
212
+ var resp, blob, reader;
213
+ return tslib_1.__generator(this, function (_a) {
214
+ switch (_a.label) {
215
+ case 0: return [4 /*yield*/, fetch(assetUrl)];
216
+ case 1:
217
+ resp = _a.sent();
218
+ return [4 /*yield*/, resp.blob()];
219
+ case 2:
220
+ blob = _a.sent();
221
+ reader = new FileReader();
222
+ reader.onloadend = function (event) {
223
+ var target = event.target;
224
+ if (!target) {
225
+ return reject("Asset with URL \"" + assetUrl + "\" could not be loaded.");
226
+ }
227
+ var result = target.result;
228
+ if (!result) {
229
+ return reject("Asset with URL \"" + assetUrl + "\" returned an empty result.");
230
+ }
231
+ resolve({
232
+ url: assetUrl,
233
+ base64: result.toString(),
234
+ });
235
+ };
236
+ reader.readAsDataURL(blob);
237
+ return [2 /*return*/];
238
+ }
239
+ });
240
+ }); })];
241
+ });
242
+ });
243
+ };
238
244
  //# sourceMappingURL=resourceHelper.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"resourceHelper.js","sourceRoot":"","sources":["../../../../src/api/util/resourceHelper.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"resourceHelper.js","sourceRoot":"","sources":["../../../../src/api/util/resourceHelper.ts"],"names":[],"mappings":"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"}
@@ -1,9 +1,9 @@
1
- /**
2
- * Creates a random uuidv4.
3
- */
4
- declare const uuidv4: () => any;
5
- /**
6
- * Converts a string from camel case to snake case.
7
- */
8
- declare const camelToSnakeCase: (str: string) => string;
9
- export { uuidv4, camelToSnakeCase, };
1
+ /**
2
+ * Creates a random uuidv4.
3
+ */
4
+ declare const uuidv4: () => any;
5
+ /**
6
+ * Converts a string from camel case to snake case.
7
+ */
8
+ declare const camelToSnakeCase: (str: string) => string;
9
+ export { uuidv4, camelToSnakeCase, };