@colijnit/configurator 1.0.16 → 1.0.18
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/app/builder.d.ts +53 -53
- package/app/components/answers/answer/answer.component.d.ts +11 -11
- package/app/components/answers/answers.component.d.ts +8 -8
- package/app/components/answers/answers.module.d.ts +2 -2
- package/app/components/selections/selections.component.d.ts +22 -22
- package/app/components/selections/selections.module.d.ts +2 -2
- package/app/components/shared/loader/loader.component.d.ts +2 -2
- package/app/components/shared/shared.module.d.ts +2 -2
- package/app/directives/visibility-observer-master.directive.d.ts +9 -9
- package/app/directives/visibility-observer.directive.d.ts +13 -13
- package/app/services/configurator.service.d.ts +22 -22
- package/app/services/image-cache.service.d.ts +10 -10
- package/app/services/locator.service.d.ts +4 -4
- package/bundles/colijnit-configurator.umd.js +2455 -2455
- package/bundles/colijnit-configurator.umd.js.map +1 -1
- package/bundles/colijnit-configurator.umd.min.js +2 -2
- package/bundles/colijnit-configurator.umd.min.js.map +1 -1
- package/colijnit-configurator.d.ts +10 -10
- package/colijnit-configurator.metadata.json +1 -1
- package/esm2015/app/builder.js +477 -477
- package/esm2015/app/components/answers/answer/answer.component.js +66 -61
- package/esm2015/app/components/answers/answers.component.js +40 -37
- package/esm2015/app/components/answers/answers.module.js +28 -28
- package/esm2015/app/components/selections/selections.component.js +128 -108
- package/esm2015/app/components/selections/selections.module.js +22 -22
- package/esm2015/app/components/shared/loader/loader.component.js +12 -12
- package/esm2015/app/components/shared/shared.module.js +20 -20
- package/esm2015/app/directives/visibility-observer-master.directive.js +50 -50
- package/esm2015/app/directives/visibility-observer.directive.js +56 -56
- package/esm2015/app/services/configurator.service.js +94 -94
- package/esm2015/app/services/image-cache.service.js +66 -66
- package/esm2015/app/services/locator.service.js +9 -9
- package/esm2015/colijnit-configurator.js +10 -10
- package/esm2015/helper/variation-helper.js +215 -215
- package/esm2015/model/material.js +10 -10
- package/esm2015/model/variation-settings.js +5 -5
- package/esm2015/model/variation.js +2 -2
- package/esm2015/public_api.js +6 -6
- package/esm2015/utils/asset.utils.js +73 -73
- package/esm2015/utils/file.utils.js +138 -138
- package/esm2015/utils/image.utils.js +51 -51
- package/esm2015/utils/object.utils.js +48 -48
- package/esm2015/utils/scene-utils.js +93 -93
- package/esm2015/utils/threed.utils.js +221 -221
- package/esm2015/utils/variation-utils.js +223 -223
- package/esm5/app/builder.js +591 -591
- package/esm5/app/components/answers/answer/answer.component.js +64 -64
- package/esm5/app/components/answers/answers.component.js +27 -27
- package/esm5/app/components/answers/answers.module.js +31 -31
- package/esm5/app/components/selections/selections.component.js +104 -104
- package/esm5/app/components/selections/selections.module.js +25 -25
- package/esm5/app/components/shared/loader/loader.component.js +15 -15
- package/esm5/app/components/shared/shared.module.js +23 -23
- package/esm5/app/directives/visibility-observer-master.directive.js +63 -63
- package/esm5/app/directives/visibility-observer.directive.js +58 -58
- package/esm5/app/services/configurator.service.js +160 -160
- package/esm5/app/services/image-cache.service.js +69 -69
- package/esm5/app/services/locator.service.js +12 -12
- package/esm5/colijnit-configurator.js +10 -10
- package/esm5/helper/variation-helper.js +267 -267
- package/esm5/model/material.js +12 -12
- package/esm5/model/variation-settings.js +7 -7
- package/esm5/model/variation.js +6 -6
- package/esm5/public_api.js +6 -6
- package/esm5/utils/asset.utils.js +105 -105
- package/esm5/utils/file.utils.js +150 -150
- package/esm5/utils/image.utils.js +55 -55
- package/esm5/utils/object.utils.js +55 -55
- package/esm5/utils/scene-utils.js +97 -97
- package/esm5/utils/threed.utils.js +278 -278
- package/esm5/utils/variation-utils.js +326 -326
- package/fesm2015/colijnit-configurator.js +2016 -1988
- package/fesm2015/colijnit-configurator.js.map +1 -1
- package/fesm5/colijnit-configurator.js +2457 -2457
- package/fesm5/colijnit-configurator.js.map +1 -1
- package/helper/variation-helper.d.ts +14 -14
- package/model/material.d.ts +17 -17
- package/model/variation-settings.d.ts +14 -14
- package/model/variation.d.ts +10 -10
- package/package.json +3 -2
- package/public_api.d.ts +6 -6
- package/utils/asset.utils.d.ts +13 -13
- package/utils/file.utils.d.ts +27 -27
- package/utils/image.utils.d.ts +8 -8
- package/utils/object.utils.d.ts +7 -7
- package/utils/scene-utils.d.ts +7 -7
- package/utils/threed.utils.d.ts +16 -16
- package/utils/variation-utils.d.ts +12 -12
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Material } from '../model/material';
|
|
3
|
-
import { ImageUtils } from './image.utils';
|
|
4
|
-
import * as THREE from 'three';
|
|
5
|
-
import { sRGBEncoding } from 'three';
|
|
6
|
-
export class FurnitureMaterial extends Material {
|
|
7
|
-
}
|
|
8
|
-
export class AssetUtils {
|
|
9
|
-
static CreateMaterialFromAsset(asset) {
|
|
10
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
11
|
-
const material = new Material();
|
|
12
|
-
if (!asset) {
|
|
13
|
-
return material;
|
|
14
|
-
}
|
|
15
|
-
if (asset.settings) {
|
|
16
|
-
AssetUtils.setSettingsOfMaterial(material, asset.settings);
|
|
17
|
-
}
|
|
18
|
-
if (asset.texture) {
|
|
19
|
-
material.texture = yield ImageUtils.CreateTextureFromBase64(asset.id + '_texture', asset.texture, material);
|
|
20
|
-
material.texture.encoding = sRGBEncoding;
|
|
21
|
-
material.textureFilename = asset.textureFilename;
|
|
22
|
-
}
|
|
23
|
-
if (asset.normal) {
|
|
24
|
-
material.normal = yield ImageUtils.CreateTextureFromBase64(asset.id + '_normal', asset.normal, material);
|
|
25
|
-
material.normalFilename = asset.normalFilename;
|
|
26
|
-
// material.normal.anisotropy = 1;
|
|
27
|
-
// material.normal.repeat.set(1, 1);
|
|
28
|
-
// material.normal.flipY = false;
|
|
29
|
-
}
|
|
30
|
-
if (asset.ao) {
|
|
31
|
-
material.ao = yield ImageUtils.CreateTextureFromBase64(asset.id + '_ao', asset.ao, material);
|
|
32
|
-
material.aoFilename = asset.aoFilename;
|
|
33
|
-
}
|
|
34
|
-
if (asset.metalness) {
|
|
35
|
-
material.metalness = yield ImageUtils.CreateTextureFromBase64(asset.id + '_metalness', asset.metalness, material);
|
|
36
|
-
material.metalnessFilename = asset.metalnessFilename;
|
|
37
|
-
}
|
|
38
|
-
if (asset.roughness) {
|
|
39
|
-
material.roughness = yield ImageUtils.CreateTextureFromBase64(asset.id + '_roughness', asset.roughness, material);
|
|
40
|
-
material.roughnessFilename = asset.roughnessFilename;
|
|
41
|
-
}
|
|
42
|
-
return material;
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
static setSettingsOfMaterial(material, settings) {
|
|
46
|
-
const shininess = parseFloat(settings['power']);
|
|
47
|
-
if (!isNaN(shininess)) {
|
|
48
|
-
material.shininess = shininess;
|
|
49
|
-
// material.roughness = 1 - (shininess / 100);
|
|
50
|
-
}
|
|
51
|
-
const level = parseFloat(settings['level']);
|
|
52
|
-
if (!isNaN(level)) {
|
|
53
|
-
material.specular = new THREE.Color(level, level, level);
|
|
54
|
-
}
|
|
55
|
-
const repeatObjectUsed = settings.hasOwnProperty('repeat');
|
|
56
|
-
const repeatx = repeatObjectUsed ? parseFloat(settings['repeat']['repeatx']) : parseFloat(settings['repeatx']);
|
|
57
|
-
if (!isNaN(repeatx)) {
|
|
58
|
-
material.repeatX = Math.max(1, repeatx);
|
|
59
|
-
}
|
|
60
|
-
const repeaty = repeatObjectUsed ? parseFloat(settings['repeat']['repeaty']) : parseFloat(settings['repeaty']);
|
|
61
|
-
if (!isNaN(repeaty)) {
|
|
62
|
-
material.repeatY = Math.max(1, repeaty);
|
|
63
|
-
}
|
|
64
|
-
const metalness = parseFloat(settings['metalness']);
|
|
65
|
-
if (!isNaN(metalness)) {
|
|
66
|
-
material.metalnessValue = Math.min(1, metalness);
|
|
67
|
-
}
|
|
68
|
-
const roughness = parseFloat(settings['roughness']);
|
|
69
|
-
if (!isNaN(roughness)) {
|
|
70
|
-
material.roughnessValue = Math.min(1, roughness);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Material } from '../model/material';
|
|
3
|
+
import { ImageUtils } from './image.utils';
|
|
4
|
+
import * as THREE from 'three';
|
|
5
|
+
import { sRGBEncoding } from 'three';
|
|
6
|
+
export class FurnitureMaterial extends Material {
|
|
7
|
+
}
|
|
8
|
+
export class AssetUtils {
|
|
9
|
+
static CreateMaterialFromAsset(asset) {
|
|
10
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
11
|
+
const material = new Material();
|
|
12
|
+
if (!asset) {
|
|
13
|
+
return material;
|
|
14
|
+
}
|
|
15
|
+
if (asset.settings) {
|
|
16
|
+
AssetUtils.setSettingsOfMaterial(material, asset.settings);
|
|
17
|
+
}
|
|
18
|
+
if (asset.texture) {
|
|
19
|
+
material.texture = yield ImageUtils.CreateTextureFromBase64(asset.id + '_texture', asset.texture, material);
|
|
20
|
+
material.texture.encoding = sRGBEncoding;
|
|
21
|
+
material.textureFilename = asset.textureFilename;
|
|
22
|
+
}
|
|
23
|
+
if (asset.normal) {
|
|
24
|
+
material.normal = yield ImageUtils.CreateTextureFromBase64(asset.id + '_normal', asset.normal, material);
|
|
25
|
+
material.normalFilename = asset.normalFilename;
|
|
26
|
+
// material.normal.anisotropy = 1;
|
|
27
|
+
// material.normal.repeat.set(1, 1);
|
|
28
|
+
// material.normal.flipY = false;
|
|
29
|
+
}
|
|
30
|
+
if (asset.ao) {
|
|
31
|
+
material.ao = yield ImageUtils.CreateTextureFromBase64(asset.id + '_ao', asset.ao, material);
|
|
32
|
+
material.aoFilename = asset.aoFilename;
|
|
33
|
+
}
|
|
34
|
+
if (asset.metalness) {
|
|
35
|
+
material.metalness = yield ImageUtils.CreateTextureFromBase64(asset.id + '_metalness', asset.metalness, material);
|
|
36
|
+
material.metalnessFilename = asset.metalnessFilename;
|
|
37
|
+
}
|
|
38
|
+
if (asset.roughness) {
|
|
39
|
+
material.roughness = yield ImageUtils.CreateTextureFromBase64(asset.id + '_roughness', asset.roughness, material);
|
|
40
|
+
material.roughnessFilename = asset.roughnessFilename;
|
|
41
|
+
}
|
|
42
|
+
return material;
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
static setSettingsOfMaterial(material, settings) {
|
|
46
|
+
const shininess = parseFloat(settings['power']);
|
|
47
|
+
if (!isNaN(shininess)) {
|
|
48
|
+
material.shininess = shininess;
|
|
49
|
+
// material.roughness = 1 - (shininess / 100);
|
|
50
|
+
}
|
|
51
|
+
const level = parseFloat(settings['level']);
|
|
52
|
+
if (!isNaN(level)) {
|
|
53
|
+
material.specular = new THREE.Color(level, level, level);
|
|
54
|
+
}
|
|
55
|
+
const repeatObjectUsed = settings.hasOwnProperty('repeat');
|
|
56
|
+
const repeatx = repeatObjectUsed ? parseFloat(settings['repeat']['repeatx']) : parseFloat(settings['repeatx']);
|
|
57
|
+
if (!isNaN(repeatx)) {
|
|
58
|
+
material.repeatX = Math.max(1, repeatx);
|
|
59
|
+
}
|
|
60
|
+
const repeaty = repeatObjectUsed ? parseFloat(settings['repeat']['repeaty']) : parseFloat(settings['repeaty']);
|
|
61
|
+
if (!isNaN(repeaty)) {
|
|
62
|
+
material.repeatY = Math.max(1, repeaty);
|
|
63
|
+
}
|
|
64
|
+
const metalness = parseFloat(settings['metalness']);
|
|
65
|
+
if (!isNaN(metalness)) {
|
|
66
|
+
material.metalnessValue = Math.min(1, metalness);
|
|
67
|
+
}
|
|
68
|
+
const roughness = parseFloat(settings['roughness']);
|
|
69
|
+
if (!isNaN(roughness)) {
|
|
70
|
+
material.roughnessValue = Math.min(1, roughness);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
74
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset.utils.js","sourceRoot":"ng://@colijnit/configurator/","sources":["utils/asset.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {Material} from '../model/material';\nimport {ImageUtils} from './image.utils';\nimport * as THREE from 'three';\nimport {sRGBEncoding} from 'three';\nimport {VariationSettings} from '../model/variation-settings';\n\nexport class FurnitureMaterial extends Material {\n\n  public textureFilename?: string;\n  public normalFilename?: string;\n  public aoFilename?: string;\n  public metalnessFilename?: string;\n  public roughnessFilename?: string;\n\n}\n\nexport class AssetUtils {\n\n  public static async CreateMaterialFromAsset(asset: VariationSettings): Promise<Material> {\n    const material: FurnitureMaterial = new Material();\n    if (!asset) {\n      return material;\n    }\n    if (asset.settings) {\n      AssetUtils.setSettingsOfMaterial(material, asset.settings);\n    }\n    if (asset.texture) {\n      material.texture = await ImageUtils.CreateTextureFromBase64(asset.id + '_texture', asset.texture, material);\n      material.texture.encoding = sRGBEncoding;\n\n      material.textureFilename = asset.textureFilename;\n    }\n    if (asset.normal) {\n      material.normal = await ImageUtils.CreateTextureFromBase64(asset.id + '_normal', asset.normal, material);\n      material.normalFilename = asset.normalFilename;\n      // material.normal.anisotropy = 1;\n      // material.normal.repeat.set(1, 1);\n      // material.normal.flipY = false;\n    }\n    if (asset.ao) {\n      material.ao = await ImageUtils.CreateTextureFromBase64(asset.id + '_ao', asset.ao, material);\n      material.aoFilename = asset.aoFilename;\n    }\n    if (asset.metalness) {\n      material.metalness = await ImageUtils.CreateTextureFromBase64(asset.id + '_metalness', asset.metalness, material);\n      material.metalnessFilename = asset.metalnessFilename;\n    }\n    if (asset.roughness) {\n      material.roughness = await ImageUtils.CreateTextureFromBase64(asset.id + '_roughness', asset.roughness, material);\n      material.roughnessFilename = asset.roughnessFilename;\n    }\n    return material;\n  }\n\n  public static setSettingsOfMaterial(material: Material, settings: any): void {\n    const shininess = parseFloat(settings['power']);\n    if (!isNaN(shininess)) {\n      material.shininess = shininess;\n      // material.roughness = 1 - (shininess / 100);\n    }\n\n    const level = parseFloat(settings['level']);\n    if (!isNaN(level)) {\n      material.specular = new THREE.Color(level, level, level);\n    }\n\n    const repeatObjectUsed: boolean = settings.hasOwnProperty('repeat');\n    const repeatx = repeatObjectUsed ? parseFloat(settings['repeat']['repeatx']) : parseFloat(settings['repeatx']);\n    if (!isNaN(repeatx)) {\n      material.repeatX = Math.max(1, repeatx);\n    }\n\n    const repeaty = repeatObjectUsed ? parseFloat(settings['repeat']['repeaty']) : parseFloat(settings['repeaty']);\n    if (!isNaN(repeaty)) {\n      material.repeatY = Math.max(1, repeaty);\n    }\n\n    const metalness = parseFloat(settings['metalness']);\n    if (!isNaN(metalness)) {\n      material.metalnessValue = Math.min(1, metalness);\n    }\n\n    const roughness = parseFloat(settings['roughness']);\n    if (!isNaN(roughness)) {\n      material.roughnessValue = Math.min(1, roughness);\n    }\n  }\n}\n"]}
|
|
@@ -1,139 +1,139 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import axios from "axios";
|
|
3
|
-
// Static utility functions holder related to files.
|
|
4
|
-
// @dynamic
|
|
5
|
-
export class FileUtils {
|
|
6
|
-
// Returns the given dataUri string stripped of the mimetype part.
|
|
7
|
-
static StripMimeStringFromDataUri(dataUri) {
|
|
8
|
-
if (!dataUri) {
|
|
9
|
-
return '';
|
|
10
|
-
}
|
|
11
|
-
const mimeString = this.GetMimeStringFromDataUri(dataUri);
|
|
12
|
-
return dataUri.substr(mimeString.length + 1);
|
|
13
|
-
}
|
|
14
|
-
static GetMimeStringFromDataUri(dataUri) {
|
|
15
|
-
if (!dataUri) {
|
|
16
|
-
return '';
|
|
17
|
-
}
|
|
18
|
-
return dataUri.split(',')[0];
|
|
19
|
-
}
|
|
20
|
-
static FileExists(url, assetPath) {
|
|
21
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
const result = yield axios({
|
|
23
|
-
method: 'get',
|
|
24
|
-
url: `${assetPath}getFiles.php?assetUrl=${url}`,
|
|
25
|
-
responseType: "json"
|
|
26
|
-
});
|
|
27
|
-
return !!result.data;
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* There is some discrepancy regarding locations of h3d objects
|
|
32
|
-
* Therefor we need to (temporarily?!) fix the content url
|
|
33
|
-
* Also we need to change some additionals
|
|
34
|
-
*/
|
|
35
|
-
static FixUrl(assetUrl) {
|
|
36
|
-
if (!assetUrl) {
|
|
37
|
-
return '';
|
|
38
|
-
}
|
|
39
|
-
let fixedUrl = assetUrl;
|
|
40
|
-
if (!fixedUrl.endsWith('glb') && !fixedUrl.endsWith('obj') && !fixedUrl.endsWith('glb.gz') && !fixedUrl.endsWith('obj.gz')) {
|
|
41
|
-
fixedUrl = FileUtils.FixUnityUrl(fixedUrl);
|
|
42
|
-
}
|
|
43
|
-
fixedUrl = fixedUrl.replace('/content/', '/content43/');
|
|
44
|
-
return fixedUrl;
|
|
45
|
-
}
|
|
46
|
-
static FixGlbUrl(assetUrl) {
|
|
47
|
-
if (!assetUrl) {
|
|
48
|
-
return '';
|
|
49
|
-
}
|
|
50
|
-
let fixedUrl = assetUrl;
|
|
51
|
-
if (assetUrl.indexOf('_webplayer') === -1) {
|
|
52
|
-
fixedUrl = assetUrl.concat('_webplayer');
|
|
53
|
-
}
|
|
54
|
-
fixedUrl = fixedUrl.replace('/content/', '/content43/');
|
|
55
|
-
if (!fixedUrl.endsWith('.glb')) {
|
|
56
|
-
fixedUrl = fixedUrl.concat('.glb');
|
|
57
|
-
}
|
|
58
|
-
return fixedUrl;
|
|
59
|
-
}
|
|
60
|
-
// Return the mimetype of the given filename.
|
|
61
|
-
static MimeTypeFromFilename(fileName) {
|
|
62
|
-
const regEx = /(?:\.([^.]+))?$/; // regex to find extension
|
|
63
|
-
const extension = regEx.exec(fileName)[1];
|
|
64
|
-
switch (extension) {
|
|
65
|
-
case 'jpg':
|
|
66
|
-
case 'jpeg':
|
|
67
|
-
return 'image/jpeg';
|
|
68
|
-
case 'png':
|
|
69
|
-
return 'image/png';
|
|
70
|
-
case 'bmp':
|
|
71
|
-
return 'image/bmp';
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* Downloads the given file to the users default download location.
|
|
76
|
-
* @param fileName With or without extension
|
|
77
|
-
* @param content File content as a string
|
|
78
|
-
* @param [mimeType = 'text/plain']
|
|
79
|
-
*/
|
|
80
|
-
static DownloadFile(fileName, content, mimeType = 'text/plain') {
|
|
81
|
-
const element = document.createElement('a');
|
|
82
|
-
element.setAttribute('href', 'data:' + mimeType + ';charset=utf-8,' + encodeURIComponent(content));
|
|
83
|
-
element.setAttribute('download', fileName);
|
|
84
|
-
element.style.display = 'none';
|
|
85
|
-
document.body.appendChild(element);
|
|
86
|
-
element.click();
|
|
87
|
-
document.body.removeChild(element);
|
|
88
|
-
}
|
|
89
|
-
// Returns the contents of given file as a text string.
|
|
90
|
-
static ReadAsText(file) {
|
|
91
|
-
return new Promise((resolve) => {
|
|
92
|
-
const reader = new FileReader();
|
|
93
|
-
reader.readAsText(file);
|
|
94
|
-
reader.onloadend = (event) => {
|
|
95
|
-
if (event.target.readyState === 2) {
|
|
96
|
-
resolve(event.target.result);
|
|
97
|
-
}
|
|
98
|
-
};
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
static GetExtensionFromDataUri(dataUri) {
|
|
102
|
-
return dataUri.replace(/(data:image\/)(.*?)(;base64.*)/gi, '$2');
|
|
103
|
-
}
|
|
104
|
-
static CreateDownloadFileNameFromBase64(dataUri) {
|
|
105
|
-
const ext = this.GetExtensionFromDataUri(dataUri);
|
|
106
|
-
return 'preview.' + ext;
|
|
107
|
-
}
|
|
108
|
-
static DownloadFromDataUri(dataUri, fileName) {
|
|
109
|
-
const link = document.createElement('a');
|
|
110
|
-
link.download = fileName;
|
|
111
|
-
link.href = dataUri;
|
|
112
|
-
document.body.appendChild(link);
|
|
113
|
-
link.click();
|
|
114
|
-
document.body.removeChild(link);
|
|
115
|
-
}
|
|
116
|
-
// todo remove once Connector deals with mimetypes and this method isn't used anymore
|
|
117
|
-
static DocumentBodyToDataUri(documentBody, mimeType) {
|
|
118
|
-
if (!!documentBody) {
|
|
119
|
-
return 'data:' + mimeType + ';base64,' + documentBody;
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
return '';
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
static FixUnityUrl(url) {
|
|
126
|
-
if (url.indexOf('_webplayer') === -1) {
|
|
127
|
-
url = url.concat('_webplayer.ione3d');
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
url = url.replace('_webplayer', '_webplayer.ione3d');
|
|
131
|
-
}
|
|
132
|
-
if (!url.endsWith('.gz')) {
|
|
133
|
-
url = url.concat('.gz');
|
|
134
|
-
}
|
|
135
|
-
return url.replace('.unity3d', '');
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
FileUtils._cachedTextureUploads = new Map();
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import axios from "axios";
|
|
3
|
+
// Static utility functions holder related to files.
|
|
4
|
+
// @dynamic
|
|
5
|
+
export class FileUtils {
|
|
6
|
+
// Returns the given dataUri string stripped of the mimetype part.
|
|
7
|
+
static StripMimeStringFromDataUri(dataUri) {
|
|
8
|
+
if (!dataUri) {
|
|
9
|
+
return '';
|
|
10
|
+
}
|
|
11
|
+
const mimeString = this.GetMimeStringFromDataUri(dataUri);
|
|
12
|
+
return dataUri.substr(mimeString.length + 1);
|
|
13
|
+
}
|
|
14
|
+
static GetMimeStringFromDataUri(dataUri) {
|
|
15
|
+
if (!dataUri) {
|
|
16
|
+
return '';
|
|
17
|
+
}
|
|
18
|
+
return dataUri.split(',')[0];
|
|
19
|
+
}
|
|
20
|
+
static FileExists(url, assetPath) {
|
|
21
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
+
const result = yield axios({
|
|
23
|
+
method: 'get',
|
|
24
|
+
url: `${assetPath}getFiles.php?assetUrl=${url}`,
|
|
25
|
+
responseType: "json"
|
|
26
|
+
});
|
|
27
|
+
return !!result.data;
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* There is some discrepancy regarding locations of h3d objects
|
|
32
|
+
* Therefor we need to (temporarily?!) fix the content url
|
|
33
|
+
* Also we need to change some additionals
|
|
34
|
+
*/
|
|
35
|
+
static FixUrl(assetUrl) {
|
|
36
|
+
if (!assetUrl) {
|
|
37
|
+
return '';
|
|
38
|
+
}
|
|
39
|
+
let fixedUrl = assetUrl;
|
|
40
|
+
if (!fixedUrl.endsWith('glb') && !fixedUrl.endsWith('obj') && !fixedUrl.endsWith('glb.gz') && !fixedUrl.endsWith('obj.gz')) {
|
|
41
|
+
fixedUrl = FileUtils.FixUnityUrl(fixedUrl);
|
|
42
|
+
}
|
|
43
|
+
fixedUrl = fixedUrl.replace('/content/', '/content43/');
|
|
44
|
+
return fixedUrl;
|
|
45
|
+
}
|
|
46
|
+
static FixGlbUrl(assetUrl) {
|
|
47
|
+
if (!assetUrl) {
|
|
48
|
+
return '';
|
|
49
|
+
}
|
|
50
|
+
let fixedUrl = assetUrl;
|
|
51
|
+
if (assetUrl.indexOf('_webplayer') === -1) {
|
|
52
|
+
fixedUrl = assetUrl.concat('_webplayer');
|
|
53
|
+
}
|
|
54
|
+
fixedUrl = fixedUrl.replace('/content/', '/content43/');
|
|
55
|
+
if (!fixedUrl.endsWith('.glb')) {
|
|
56
|
+
fixedUrl = fixedUrl.concat('.glb');
|
|
57
|
+
}
|
|
58
|
+
return fixedUrl;
|
|
59
|
+
}
|
|
60
|
+
// Return the mimetype of the given filename.
|
|
61
|
+
static MimeTypeFromFilename(fileName) {
|
|
62
|
+
const regEx = /(?:\.([^.]+))?$/; // regex to find extension
|
|
63
|
+
const extension = regEx.exec(fileName)[1];
|
|
64
|
+
switch (extension) {
|
|
65
|
+
case 'jpg':
|
|
66
|
+
case 'jpeg':
|
|
67
|
+
return 'image/jpeg';
|
|
68
|
+
case 'png':
|
|
69
|
+
return 'image/png';
|
|
70
|
+
case 'bmp':
|
|
71
|
+
return 'image/bmp';
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Downloads the given file to the users default download location.
|
|
76
|
+
* @param fileName With or without extension
|
|
77
|
+
* @param content File content as a string
|
|
78
|
+
* @param [mimeType = 'text/plain']
|
|
79
|
+
*/
|
|
80
|
+
static DownloadFile(fileName, content, mimeType = 'text/plain') {
|
|
81
|
+
const element = document.createElement('a');
|
|
82
|
+
element.setAttribute('href', 'data:' + mimeType + ';charset=utf-8,' + encodeURIComponent(content));
|
|
83
|
+
element.setAttribute('download', fileName);
|
|
84
|
+
element.style.display = 'none';
|
|
85
|
+
document.body.appendChild(element);
|
|
86
|
+
element.click();
|
|
87
|
+
document.body.removeChild(element);
|
|
88
|
+
}
|
|
89
|
+
// Returns the contents of given file as a text string.
|
|
90
|
+
static ReadAsText(file) {
|
|
91
|
+
return new Promise((resolve) => {
|
|
92
|
+
const reader = new FileReader();
|
|
93
|
+
reader.readAsText(file);
|
|
94
|
+
reader.onloadend = (event) => {
|
|
95
|
+
if (event.target.readyState === 2) {
|
|
96
|
+
resolve(event.target.result);
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
static GetExtensionFromDataUri(dataUri) {
|
|
102
|
+
return dataUri.replace(/(data:image\/)(.*?)(;base64.*)/gi, '$2');
|
|
103
|
+
}
|
|
104
|
+
static CreateDownloadFileNameFromBase64(dataUri) {
|
|
105
|
+
const ext = this.GetExtensionFromDataUri(dataUri);
|
|
106
|
+
return 'preview.' + ext;
|
|
107
|
+
}
|
|
108
|
+
static DownloadFromDataUri(dataUri, fileName) {
|
|
109
|
+
const link = document.createElement('a');
|
|
110
|
+
link.download = fileName;
|
|
111
|
+
link.href = dataUri;
|
|
112
|
+
document.body.appendChild(link);
|
|
113
|
+
link.click();
|
|
114
|
+
document.body.removeChild(link);
|
|
115
|
+
}
|
|
116
|
+
// todo remove once Connector deals with mimetypes and this method isn't used anymore
|
|
117
|
+
static DocumentBodyToDataUri(documentBody, mimeType) {
|
|
118
|
+
if (!!documentBody) {
|
|
119
|
+
return 'data:' + mimeType + ';base64,' + documentBody;
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
return '';
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
static FixUnityUrl(url) {
|
|
126
|
+
if (url.indexOf('_webplayer') === -1) {
|
|
127
|
+
url = url.concat('_webplayer.ione3d');
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
url = url.replace('_webplayer', '_webplayer.ione3d');
|
|
131
|
+
}
|
|
132
|
+
if (!url.endsWith('.gz')) {
|
|
133
|
+
url = url.concat('.gz');
|
|
134
|
+
}
|
|
135
|
+
return url.replace('.unity3d', '');
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
FileUtils._cachedTextureUploads = new Map();
|
|
139
139
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.utils.js","sourceRoot":"ng://@colijnit/configurator/","sources":["utils/file.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import axios from \"axios\";\n// Static utility functions holder related to files.\n// @dynamic\nexport class FileUtils {\n\n  private static _cachedTextureUploads: Map<string, Object> = new Map();\n\n  // Returns the given dataUri string stripped of the mimetype part.\n  public static StripMimeStringFromDataUri(dataUri: string): string {\n    if (!dataUri) {\n      return '';\n    }\n\n    const mimeString: string = this.GetMimeStringFromDataUri(dataUri);\n    return dataUri.substr(mimeString.length + 1);\n  }\n\n  public static GetMimeStringFromDataUri(dataUri: string): string {\n    if (!dataUri) {\n      return '';\n    }\n\n    return dataUri.split(',')[0];\n  }\n\n  public static async FileExists(url: string, assetPath: string): Promise<boolean> {\n      const result = await axios({\n        method: 'get',\n        url: `${assetPath}getFiles.php?assetUrl=${url}`,\n        responseType: \"json\"\n      })\n      return !!result.data;\n  }\n\n  /**\n   * There is some discrepancy regarding locations of h3d objects\n   * Therefor we need to (temporarily?!) fix the content url\n   * Also we need to change some additionals\n   */\n  public static FixUrl(assetUrl: string): string {\n    if (!assetUrl) {\n      return '';\n    }\n    let fixedUrl: string = assetUrl;\n    if (!fixedUrl.endsWith('glb') && !fixedUrl.endsWith('obj') && !fixedUrl.endsWith('glb.gz') && !fixedUrl.endsWith('obj.gz')) {\n      fixedUrl = FileUtils.FixUnityUrl(fixedUrl);\n    }\n    fixedUrl = fixedUrl.replace('/content/', '/content43/');\n    return fixedUrl;\n  }\n\n  public static FixGlbUrl(assetUrl: string): string {\n    if (!assetUrl) {\n      return '';\n    }\n    let fixedUrl: string = assetUrl;\n    if (assetUrl.indexOf('_webplayer') === -1) {\n      fixedUrl = assetUrl.concat('_webplayer');\n    }\n    fixedUrl = fixedUrl.replace('/content/', '/content43/');\n    if (!fixedUrl.endsWith('.glb')) {\n      fixedUrl = fixedUrl.concat('.glb');\n    }\n    return fixedUrl;\n  }\n\n  // Return the mimetype of the given filename.\n  public static MimeTypeFromFilename(fileName: string): string {\n    const regEx: RegExp = /(?:\\.([^.]+))?$/; // regex to find extension\n    const extension: any = regEx.exec(fileName)[1];\n    switch (extension) {\n      case 'jpg':\n      case 'jpeg':\n        return 'image/jpeg';\n      case 'png':\n        return 'image/png';\n      case 'bmp':\n        return 'image/bmp';\n    }\n  }\n\n  /**\n   * Downloads the given file to the users default download location.\n   * @param fileName With or without extension\n   * @param content File content as a string\n   * @param [mimeType = 'text/plain']\n   */\n  public static DownloadFile(\n    fileName: string,\n    content: string,\n    mimeType: string = 'text/plain'\n  ): void {\n    const element: HTMLAnchorElement = document.createElement('a');\n    element.setAttribute('href', 'data:' + mimeType + ';charset=utf-8,' + encodeURIComponent(content));\n    element.setAttribute('download', fileName);\n\n    element.style.display = 'none';\n    document.body.appendChild(element);\n\n    element.click();\n\n    document.body.removeChild(element);\n  }\n\n  // Returns the contents of given file as a text string.\n  public static ReadAsText(file: File): Promise<string> {\n    return new Promise<string>((resolve: Function) => {\n      const reader: FileReader = new FileReader();\n      reader.readAsText(file);\n      reader.onloadend = (event: any) => {\n        if (event.target.readyState === 2) {\n          resolve(event.target.result);\n        }\n      };\n    });\n  }\n\n  public static GetExtensionFromDataUri(dataUri: string): string {\n    return dataUri.replace(/(data:image\\/)(.*?)(;base64.*)/gi, '$2');\n  }\n\n  public static CreateDownloadFileNameFromBase64(dataUri: string): string {\n    const ext: string = this.GetExtensionFromDataUri(dataUri);\n    return 'preview.' + ext;\n  }\n\n  public static DownloadFromDataUri(dataUri: string, fileName: string): void {\n    const link: any = document.createElement('a');\n    link.download = fileName;\n    link.href = dataUri;\n    document.body.appendChild(link);\n    link.click();\n    document.body.removeChild(link);\n  }\n\n  // todo remove once Connector deals with mimetypes and this method isn't used anymore\n  public static DocumentBodyToDataUri(documentBody: string, mimeType: string): string {\n    if (!!documentBody) {\n      return 'data:' + mimeType + ';base64,' + documentBody;\n    } else {\n      return '';\n    }\n  }\n\n  private static FixUnityUrl(url): string {\n    if (url.indexOf('_webplayer') === -1) {\n      url = url.concat('_webplayer.ione3d');\n    } else {\n      url = url.replace('_webplayer', '_webplayer.ione3d');\n    }\n    if (!url.endsWith('.gz')) {\n      url = url.concat('.gz');\n    }\n    return url.replace('.unity3d', '');\n  }\n}\n"]}
|
|
@@ -1,52 +1,52 @@
|
|
|
1
|
-
import * as THREE from 'three';
|
|
2
|
-
// @dynamic
|
|
3
|
-
export class ImageUtils {
|
|
4
|
-
static CreateTextureFromBase64(id, base64, material) {
|
|
5
|
-
return new Promise((resolve) => {
|
|
6
|
-
if (ImageUtils.textures.has(id)) {
|
|
7
|
-
resolve(ImageUtils.textures.get(id));
|
|
8
|
-
}
|
|
9
|
-
else {
|
|
10
|
-
if (!base64) {
|
|
11
|
-
resolve(new THREE.Texture());
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
const loader = new THREE.TextureLoader();
|
|
15
|
-
loader.load(base64, (texture) => {
|
|
16
|
-
texture.anisotropy = 16;
|
|
17
|
-
texture.wrapS = THREE.RepeatWrapping;
|
|
18
|
-
texture.wrapT = THREE.RepeatWrapping;
|
|
19
|
-
texture.repeat = new THREE.Vector2(material ? material.repeatX : 1, material ? material.repeatY : 1);
|
|
20
|
-
texture.needsUpdate = true;
|
|
21
|
-
ImageUtils.textures.set(id, texture);
|
|
22
|
-
resolve(texture);
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
static getDocBodyWithMimeTypeDefinition(fileName, documentBody) {
|
|
29
|
-
if (documentBody === null) {
|
|
30
|
-
return documentBody;
|
|
31
|
-
}
|
|
32
|
-
const fileExtension = fileName.substr(fileName.lastIndexOf('.') + 1);
|
|
33
|
-
switch (fileExtension.toLowerCase()) {
|
|
34
|
-
case "jpg":
|
|
35
|
-
case "jpeg":
|
|
36
|
-
return "data:image/jpg;base64," + documentBody;
|
|
37
|
-
case "png":
|
|
38
|
-
return "data:image/png;base64," + documentBody;
|
|
39
|
-
case "gif":
|
|
40
|
-
return "data:image/gif;base64," + documentBody;
|
|
41
|
-
case "bmp":
|
|
42
|
-
return "data:image/bmp;base64," + documentBody;
|
|
43
|
-
default:
|
|
44
|
-
return "data:image/png;base64," + documentBody;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
static getFixedImageFilepathUrl(imageFilepathUrl) {
|
|
48
|
-
return imageFilepathUrl.replace("/content/", "/content43/");
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
ImageUtils.textures = new Map();
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
// @dynamic
|
|
3
|
+
export class ImageUtils {
|
|
4
|
+
static CreateTextureFromBase64(id, base64, material) {
|
|
5
|
+
return new Promise((resolve) => {
|
|
6
|
+
if (ImageUtils.textures.has(id)) {
|
|
7
|
+
resolve(ImageUtils.textures.get(id));
|
|
8
|
+
}
|
|
9
|
+
else {
|
|
10
|
+
if (!base64) {
|
|
11
|
+
resolve(new THREE.Texture());
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
const loader = new THREE.TextureLoader();
|
|
15
|
+
loader.load(base64, (texture) => {
|
|
16
|
+
texture.anisotropy = 16;
|
|
17
|
+
texture.wrapS = THREE.RepeatWrapping;
|
|
18
|
+
texture.wrapT = THREE.RepeatWrapping;
|
|
19
|
+
texture.repeat = new THREE.Vector2(material ? material.repeatX : 1, material ? material.repeatY : 1);
|
|
20
|
+
texture.needsUpdate = true;
|
|
21
|
+
ImageUtils.textures.set(id, texture);
|
|
22
|
+
resolve(texture);
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
static getDocBodyWithMimeTypeDefinition(fileName, documentBody) {
|
|
29
|
+
if (documentBody === null) {
|
|
30
|
+
return documentBody;
|
|
31
|
+
}
|
|
32
|
+
const fileExtension = fileName.substr(fileName.lastIndexOf('.') + 1);
|
|
33
|
+
switch (fileExtension.toLowerCase()) {
|
|
34
|
+
case "jpg":
|
|
35
|
+
case "jpeg":
|
|
36
|
+
return "data:image/jpg;base64," + documentBody;
|
|
37
|
+
case "png":
|
|
38
|
+
return "data:image/png;base64," + documentBody;
|
|
39
|
+
case "gif":
|
|
40
|
+
return "data:image/gif;base64," + documentBody;
|
|
41
|
+
case "bmp":
|
|
42
|
+
return "data:image/bmp;base64," + documentBody;
|
|
43
|
+
default:
|
|
44
|
+
return "data:image/png;base64," + documentBody;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
static getFixedImageFilepathUrl(imageFilepathUrl) {
|
|
48
|
+
return imageFilepathUrl.replace("/content/", "/content43/");
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
ImageUtils.textures = new Map();
|
|
52
52
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UudXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY29saWpuaXQvY29uZmlndXJhdG9yLyIsInNvdXJjZXMiOlsidXRpbHMvaW1hZ2UudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEtBQUssTUFBTSxPQUFPLENBQUM7QUFFL0IsV0FBVztBQUNYLE1BQU0sT0FBTyxVQUFVO0lBSWQsTUFBTSxDQUFDLHVCQUF1QixDQUFDLEVBQVUsRUFBRSxNQUFjLEVBQUUsUUFBa0I7UUFDbEYsT0FBTyxJQUFJLE9BQU8sQ0FBZ0IsQ0FBQyxPQUFPLEVBQUUsRUFBRTtZQUM1QyxJQUFJLFVBQVUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFO2dCQUMvQixPQUFPLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQzthQUN0QztpQkFBTTtnQkFDTCxJQUFJLENBQUMsTUFBTSxFQUFFO29CQUNYLE9BQU8sQ0FBQyxJQUFJLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2lCQUM5QjtxQkFBTTtvQkFDTCxNQUFNLE1BQU0sR0FBd0IsSUFBSSxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7b0JBQzlELE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsT0FBc0IsRUFBRSxFQUFFO3dCQUM3QyxPQUFPLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQzt3QkFDeEIsT0FBTyxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsY0FBYyxDQUFDO3dCQUNyQyxPQUFPLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQyxjQUFjLENBQUM7d0JBQ3JDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7d0JBQ3JHLE9BQU8sQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO3dCQUMzQixVQUFVLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7d0JBQ3JDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDbkIsQ0FBQyxDQUFDLENBQUM7aUJBQ0o7YUFDRjtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLE1BQU0sQ0FBQyxnQ0FBZ0MsQ0FBQyxRQUFnQixFQUFFLFlBQW9CO1FBQ25GLElBQUksWUFBWSxLQUFLLElBQUksRUFBRTtZQUN6QixPQUFPLFlBQVksQ0FBQztTQUNyQjtRQUNELE1BQU0sYUFBYSxHQUFXLFFBQVEsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUM3RSxRQUFRLGFBQWEsQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUNuQyxLQUFLLEtBQUssQ0FBQztZQUNYLEtBQUssTUFBTTtnQkFDVCxPQUFPLHdCQUF3QixHQUFHLFlBQVksQ0FBQztZQUNqRCxLQUFLLEtBQUs7Z0JBQ1IsT0FBTyx3QkFBd0IsR0FBRyxZQUFZLENBQUM7WUFDakQsS0FBSyxLQUFLO2dCQUNSLE9BQU8sd0JBQXdCLEdBQUcsWUFBWSxDQUFDO1lBQ2pELEtBQUssS0FBSztnQkFDUixPQUFPLHdCQUF3QixHQUFHLFlBQVksQ0FBQztZQUNqRDtnQkFDRSxPQUFPLHdCQUF3QixHQUFHLFlBQVksQ0FBQztTQUNsRDtJQUNILENBQUM7SUFFTSxNQUFNLENBQUMsd0JBQXdCLENBQUMsZ0JBQXdCO1FBQzdELE9BQU8sZ0JBQWdCLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUM5RCxDQUFDOztBQS9DYSxtQkFBUSxHQUErQixJQUFJLEdBQUcsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgVEhSRUUgZnJvbSAndGhyZWUnO1xuaW1wb3J0IHtNYXRlcmlhbH0gZnJvbSAnLi4vbW9kZWwvbWF0ZXJpYWwnO1xuLy8gQGR5bmFtaWNcbmV4cG9ydCBjbGFzcyBJbWFnZVV0aWxzIHtcblxuICBwdWJsaWMgc3RhdGljIHRleHR1cmVzOiBNYXA8c3RyaW5nLCBUSFJFRS5UZXh0dXJlPiA9IG5ldyBNYXAoKTtcblxuICBwdWJsaWMgc3RhdGljIENyZWF0ZVRleHR1cmVGcm9tQmFzZTY0KGlkOiBzdHJpbmcsIGJhc2U2NDogc3RyaW5nLCBtYXRlcmlhbDogTWF0ZXJpYWwpOiBQcm9taXNlPFRIUkVFLlRleHR1cmU+IHtcbiAgICByZXR1cm4gbmV3IFByb21pc2U8VEhSRUUuVGV4dHVyZT4oKHJlc29sdmUpID0+IHtcbiAgICAgIGlmIChJbWFnZVV0aWxzLnRleHR1cmVzLmhhcyhpZCkpIHtcbiAgICAgICAgcmVzb2x2ZShJbWFnZVV0aWxzLnRleHR1cmVzLmdldChpZCkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKCFiYXNlNjQpIHtcbiAgICAgICAgICByZXNvbHZlKG5ldyBUSFJFRS5UZXh0dXJlKCkpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnN0IGxvYWRlcjogVEhSRUUuVGV4dHVyZUxvYWRlciA9IG5ldyBUSFJFRS5UZXh0dXJlTG9hZGVyKCk7XG4gICAgICAgICAgbG9hZGVyLmxvYWQoYmFzZTY0LCAodGV4dHVyZTogVEhSRUUuVGV4dHVyZSkgPT4ge1xuICAgICAgICAgICAgdGV4dHVyZS5hbmlzb3Ryb3B5ID0gMTY7XG4gICAgICAgICAgICB0ZXh0dXJlLndyYXBTID0gVEhSRUUuUmVwZWF0V3JhcHBpbmc7XG4gICAgICAgICAgICB0ZXh0dXJlLndyYXBUID0gVEhSRUUuUmVwZWF0V3JhcHBpbmc7XG4gICAgICAgICAgICB0ZXh0dXJlLnJlcGVhdCA9IG5ldyBUSFJFRS5WZWN0b3IyKG1hdGVyaWFsID8gbWF0ZXJpYWwucmVwZWF0WCA6IDEsIG1hdGVyaWFsID8gbWF0ZXJpYWwucmVwZWF0WSA6IDEpO1xuICAgICAgICAgICAgdGV4dHVyZS5uZWVkc1VwZGF0ZSA9IHRydWU7XG4gICAgICAgICAgICBJbWFnZVV0aWxzLnRleHR1cmVzLnNldChpZCwgdGV4dHVyZSk7XG4gICAgICAgICAgICByZXNvbHZlKHRleHR1cmUpO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGdldERvY0JvZHlXaXRoTWltZVR5cGVEZWZpbml0aW9uKGZpbGVOYW1lOiBzdHJpbmcsIGRvY3VtZW50Qm9keTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBpZiAoZG9jdW1lbnRCb2R5ID09PSBudWxsKSB7XG4gICAgICByZXR1cm4gZG9jdW1lbnRCb2R5O1xuICAgIH1cbiAgICBjb25zdCBmaWxlRXh0ZW5zaW9uOiBzdHJpbmcgPSBmaWxlTmFtZS5zdWJzdHIoZmlsZU5hbWUubGFzdEluZGV4T2YoJy4nKSArIDEpO1xuICAgIHN3aXRjaCAoZmlsZUV4dGVuc2lvbi50b0xvd2VyQ2FzZSgpKSB7XG4gICAgICBjYXNlIFwianBnXCI6XG4gICAgICBjYXNlIFwianBlZ1wiOlxuICAgICAgICByZXR1cm4gXCJkYXRhOmltYWdlL2pwZztiYXNlNjQsXCIgKyBkb2N1bWVudEJvZHk7XG4gICAgICBjYXNlIFwicG5nXCI6XG4gICAgICAgIHJldHVybiBcImRhdGE6aW1hZ2UvcG5nO2Jhc2U2NCxcIiArIGRvY3VtZW50Qm9keTtcbiAgICAgIGNhc2UgXCJnaWZcIjpcbiAgICAgICAgcmV0dXJuIFwiZGF0YTppbWFnZS9naWY7YmFzZTY0LFwiICsgZG9jdW1lbnRCb2R5O1xuICAgICAgY2FzZSBcImJtcFwiOlxuICAgICAgICByZXR1cm4gXCJkYXRhOmltYWdlL2JtcDtiYXNlNjQsXCIgKyBkb2N1bWVudEJvZHk7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gXCJkYXRhOmltYWdlL3BuZztiYXNlNjQsXCIgKyBkb2N1bWVudEJvZHk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHN0YXRpYyBnZXRGaXhlZEltYWdlRmlsZXBhdGhVcmwoaW1hZ2VGaWxlcGF0aFVybDogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gaW1hZ2VGaWxlcGF0aFVybC5yZXBsYWNlKFwiL2NvbnRlbnQvXCIsIFwiL2NvbnRlbnQ0My9cIik7XG4gIH1cbn1cbiJdfQ==
|