@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,224 +1,224 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import * as JSZip from 'jszip';
|
|
3
|
-
import { VariationSettings } from "../model/variation-settings";
|
|
4
|
-
// @dynamic
|
|
5
|
-
export class VariationUtils {
|
|
6
|
-
static LoadVariation(assetPath, fileName) {
|
|
7
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
8
|
-
if (!fileName) {
|
|
9
|
-
return null;
|
|
10
|
-
}
|
|
11
|
-
if (fileName.indexOf('ione3d') < 0) {
|
|
12
|
-
fileName = fileName.concat('.ione3d');
|
|
13
|
-
}
|
|
14
|
-
const id = fileName.substr(0, fileName.lastIndexOf('.ione3d'));
|
|
15
|
-
try {
|
|
16
|
-
if (!assetPath.endsWith('/')) {
|
|
17
|
-
assetPath += '/';
|
|
18
|
-
}
|
|
19
|
-
if (!window.hasOwnProperty('downloadVariation')) {
|
|
20
|
-
console.error('downloadVariation not defined in window global');
|
|
21
|
-
return null;
|
|
22
|
-
}
|
|
23
|
-
const file = yield window.downloadVariation(`${assetPath.replace('https://cdn1.colijn-it.nl/', '')}variation/${fileName}`);
|
|
24
|
-
return yield VariationUtils.GetVariationSettingsFromFile(id, file);
|
|
25
|
-
}
|
|
26
|
-
catch (err) {
|
|
27
|
-
const mute = err;
|
|
28
|
-
return null;
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
// public static GetMaterialFromName(variationFolder: string, material: any): Promise<MeshStandardMaterial> {
|
|
33
|
-
// return new Promise((resolve: Function) => {
|
|
34
|
-
// if (!material) {
|
|
35
|
-
// resolve(null);
|
|
36
|
-
// }
|
|
37
|
-
// if (this.MaterialCache.has(material.name)) {
|
|
38
|
-
// resolve(this.MaterialCache.get(material.name).clone());
|
|
39
|
-
// } else {
|
|
40
|
-
// VariationUtils.LoadVariation(variationFolder, material.name, false).then((settings: VariationSettings) => {
|
|
41
|
-
// if (settings) {
|
|
42
|
-
// AssetUtils.CreateMaterialFromAsset(settings).then((materialObj: Material) => {
|
|
43
|
-
// const materialParams: MeshStandardMaterialParameters = {};
|
|
44
|
-
// materialParams.name = material.name;
|
|
45
|
-
// materialParams.map = materialObj.texture;
|
|
46
|
-
// materialParams.normalMap = materialObj.normal;
|
|
47
|
-
// materialParams.aoMap = materialObj.ao;
|
|
48
|
-
// materialParams.roughnessMap = materialObj.roughness;
|
|
49
|
-
// materialParams.metalnessMap = materialObj.metalness;
|
|
50
|
-
// materialParams.roughness = 1;
|
|
51
|
-
// materialParams.metalness = 1;
|
|
52
|
-
// const pbrMat: MeshStandardMaterial = new MeshStandardMaterial(materialParams);
|
|
53
|
-
// this.MaterialCache.set(material.name, pbrMat);
|
|
54
|
-
// resolve(pbrMat.clone());
|
|
55
|
-
// });
|
|
56
|
-
// } else {
|
|
57
|
-
// resolve(material);
|
|
58
|
-
// }
|
|
59
|
-
// });
|
|
60
|
-
// }
|
|
61
|
-
// });
|
|
62
|
-
// }
|
|
63
|
-
static GetVariationSettingsFromFile(id, compressedFile) {
|
|
64
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
65
|
-
if (!compressedFile) {
|
|
66
|
-
return null;
|
|
67
|
-
}
|
|
68
|
-
const zipContent = yield VariationUtils.GetZipContent(compressedFile);
|
|
69
|
-
const variationSettings = new VariationSettings();
|
|
70
|
-
let index;
|
|
71
|
-
variationSettings.id = id;
|
|
72
|
-
if (zipContent.files['index.json']) {
|
|
73
|
-
const indexFile = yield zipContent.files['index.json'].async('string');
|
|
74
|
-
index = JSON.parse(indexFile);
|
|
75
|
-
}
|
|
76
|
-
if (index) {
|
|
77
|
-
yield VariationUtils.CreateSettingsBasedOnIndex(index, variationSettings, zipContent);
|
|
78
|
-
}
|
|
79
|
-
else {
|
|
80
|
-
yield VariationUtils.CreateSettingsBasedOnFileName(variationSettings, zipContent);
|
|
81
|
-
}
|
|
82
|
-
return variationSettings;
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
static CreateSettingsBasedOnIndex(index, variationSettings, zipContent) {
|
|
86
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
-
if (index.normalFile) {
|
|
88
|
-
variationSettings.normal = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.normalFile], index.normalFile);
|
|
89
|
-
variationSettings.normalFilename = index.normalFile;
|
|
90
|
-
}
|
|
91
|
-
if (index.aoFile) {
|
|
92
|
-
variationSettings.ao = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.aoFile], index.aoFile);
|
|
93
|
-
variationSettings.aoFilename = index.aoFile;
|
|
94
|
-
}
|
|
95
|
-
if (index.metalnessFile) {
|
|
96
|
-
variationSettings.metalness = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.metalnessFile], index.metalnessFile);
|
|
97
|
-
variationSettings.metalnessFilename = index.metalnessFile;
|
|
98
|
-
}
|
|
99
|
-
if (index.roughnessFile) {
|
|
100
|
-
variationSettings.roughness = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.roughnessFile], index.roughnessFile);
|
|
101
|
-
variationSettings.roughnessFilename = index.roughnessFile;
|
|
102
|
-
}
|
|
103
|
-
if (index.diffuseFile) {
|
|
104
|
-
variationSettings.texture = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.diffuseFile], index.diffuseFile);
|
|
105
|
-
variationSettings.textureFilename = index.diffuseFile;
|
|
106
|
-
}
|
|
107
|
-
variationSettings.settings =
|
|
108
|
-
(yield VariationUtils.LoadFileContentFromZip(zipContent.files['repeat.json'], 'repeat.json', false)) || {};
|
|
109
|
-
Object.assign(variationSettings.settings, index.repeat);
|
|
110
|
-
variationSettings.settings.metalness = index.metalness;
|
|
111
|
-
variationSettings.settings.roughness = index.roughness;
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
static CreateSettingsBasedOnFileName(variationSettings, zipContent) {
|
|
115
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
116
|
-
const allLoaded = [];
|
|
117
|
-
for (const fileName in zipContent.files) {
|
|
118
|
-
if (zipContent.files[fileName]) {
|
|
119
|
-
const file = yield zipContent.files[fileName];
|
|
120
|
-
if (file.name.toLowerCase().indexOf('normal') > -1 && this.FileIsImage(file.name)) {
|
|
121
|
-
allLoaded.push(zipContent.files[fileName].async('base64').then((normalFile) => {
|
|
122
|
-
variationSettings.normal = `data:image/${this.GetBase64FileType(file.name)};base64,${normalFile}`;
|
|
123
|
-
variationSettings.normalFilename = fileName;
|
|
124
|
-
}));
|
|
125
|
-
}
|
|
126
|
-
else if (file.name.toLowerCase().indexOf('ao') > -1 && this.FileIsImage(file.name)) {
|
|
127
|
-
allLoaded.push(zipContent.files[fileName].async('base64').then((aoFile) => {
|
|
128
|
-
variationSettings.ao = `data:image/${this.GetBase64FileType(file.name)};base64,${aoFile}`;
|
|
129
|
-
variationSettings.aoFilename = fileName;
|
|
130
|
-
}));
|
|
131
|
-
}
|
|
132
|
-
else if (file.name.toLowerCase().indexOf('metalness') > -1 && this.FileIsImage(file.name)) {
|
|
133
|
-
allLoaded.push(zipContent.files[fileName].async('base64').then((metalnessFile) => {
|
|
134
|
-
variationSettings.metalness = `data:image/${this.GetBase64FileType(file.name)};base64,${metalnessFile}`;
|
|
135
|
-
variationSettings.metalnessFilename = fileName;
|
|
136
|
-
}));
|
|
137
|
-
}
|
|
138
|
-
else if (file.name.toLowerCase().indexOf('roughness') > -1 && this.FileIsImage(file.name)) {
|
|
139
|
-
allLoaded.push(zipContent.files[fileName].async('base64').then((roughnessFile) => {
|
|
140
|
-
variationSettings.roughness = `data:image/${this.GetBase64FileType(file.name)};base64,${roughnessFile}`;
|
|
141
|
-
variationSettings.roughnessFilename = fileName;
|
|
142
|
-
}));
|
|
143
|
-
}
|
|
144
|
-
else if (file.name.toLowerCase().indexOf('diffuse') > -1 && this.FileIsImage(file.name)) {
|
|
145
|
-
allLoaded.push(zipContent.files[fileName].async('base64').then((diffuseFile) => {
|
|
146
|
-
variationSettings.texture = `data:image/${this.GetBase64FileType(file.name)};base64,${diffuseFile}`;
|
|
147
|
-
variationSettings.textureFilename = fileName;
|
|
148
|
-
}));
|
|
149
|
-
}
|
|
150
|
-
else if (file.name.indexOf('.jp') > -1) {
|
|
151
|
-
allLoaded.push(zipContent.files[fileName].async('base64').then((textureFile) => {
|
|
152
|
-
variationSettings.texture = 'data:image/jpeg;base64,' + textureFile;
|
|
153
|
-
variationSettings.textureFilename = fileName;
|
|
154
|
-
}));
|
|
155
|
-
}
|
|
156
|
-
else if (file.name.indexOf('.json') > -1) {
|
|
157
|
-
allLoaded.push(zipContent.files[fileName].async('string').then((settingsFile) => {
|
|
158
|
-
const settingsFileObj = JSON.parse(settingsFile);
|
|
159
|
-
for (const key in settingsFileObj) {
|
|
160
|
-
if (settingsFileObj[key]) {
|
|
161
|
-
variationSettings.settings[key] = settingsFileObj[key];
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
}));
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
yield Promise.all(allLoaded);
|
|
169
|
-
});
|
|
170
|
-
}
|
|
171
|
-
static LoadFileContentFromZip(zip, fileName, base64 = true) {
|
|
172
|
-
return new Promise((resolve) => {
|
|
173
|
-
if (zip && fileName) {
|
|
174
|
-
zip.async(base64 ? 'base64' : 'string').then((fileContent) => {
|
|
175
|
-
if (base64) {
|
|
176
|
-
resolve(`data:image/${this.GetBase64FileType(fileName)};base64,${fileContent}`);
|
|
177
|
-
}
|
|
178
|
-
else {
|
|
179
|
-
resolve(fileContent);
|
|
180
|
-
}
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
else {
|
|
184
|
-
resolve(undefined);
|
|
185
|
-
}
|
|
186
|
-
});
|
|
187
|
-
}
|
|
188
|
-
static FileIsImage(fileName) {
|
|
189
|
-
const ext = fileName.substring(fileName.lastIndexOf('.') + 1, fileName.length).toLowerCase();
|
|
190
|
-
switch (ext) {
|
|
191
|
-
case 'jpg':
|
|
192
|
-
case 'jpeg':
|
|
193
|
-
case 'png':
|
|
194
|
-
case 'bmp':
|
|
195
|
-
return true;
|
|
196
|
-
default:
|
|
197
|
-
return false;
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
static GetBase64FileType(fileName) {
|
|
201
|
-
const ext = fileName.substring(fileName.lastIndexOf('.') + 1, fileName.length).toLowerCase();
|
|
202
|
-
switch (ext) {
|
|
203
|
-
case 'jpg':
|
|
204
|
-
case 'jpeg':
|
|
205
|
-
return 'jpeg';
|
|
206
|
-
case 'png':
|
|
207
|
-
return 'png';
|
|
208
|
-
case 'bmp':
|
|
209
|
-
return 'bmp';
|
|
210
|
-
default:
|
|
211
|
-
return 'jpeg';
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
// Get the content
|
|
215
|
-
static GetZipContent(file) {
|
|
216
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
217
|
-
const jszip = new JSZip();
|
|
218
|
-
const content = yield jszip.loadAsync(file);
|
|
219
|
-
return content;
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
VariationUtils.MaterialCache = new Map();
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import * as JSZip from 'jszip';
|
|
3
|
+
import { VariationSettings } from "../model/variation-settings";
|
|
4
|
+
// @dynamic
|
|
5
|
+
export class VariationUtils {
|
|
6
|
+
static LoadVariation(assetPath, fileName) {
|
|
7
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
8
|
+
if (!fileName) {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
if (fileName.indexOf('ione3d') < 0) {
|
|
12
|
+
fileName = fileName.concat('.ione3d');
|
|
13
|
+
}
|
|
14
|
+
const id = fileName.substr(0, fileName.lastIndexOf('.ione3d'));
|
|
15
|
+
try {
|
|
16
|
+
if (!assetPath.endsWith('/')) {
|
|
17
|
+
assetPath += '/';
|
|
18
|
+
}
|
|
19
|
+
if (!window.hasOwnProperty('downloadVariation')) {
|
|
20
|
+
console.error('downloadVariation not defined in window global');
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
23
|
+
const file = yield window.downloadVariation(`${assetPath.replace('https://cdn1.colijn-it.nl/', '')}variation/${fileName}`);
|
|
24
|
+
return yield VariationUtils.GetVariationSettingsFromFile(id, file);
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
const mute = err;
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
// public static GetMaterialFromName(variationFolder: string, material: any): Promise<MeshStandardMaterial> {
|
|
33
|
+
// return new Promise((resolve: Function) => {
|
|
34
|
+
// if (!material) {
|
|
35
|
+
// resolve(null);
|
|
36
|
+
// }
|
|
37
|
+
// if (this.MaterialCache.has(material.name)) {
|
|
38
|
+
// resolve(this.MaterialCache.get(material.name).clone());
|
|
39
|
+
// } else {
|
|
40
|
+
// VariationUtils.LoadVariation(variationFolder, material.name, false).then((settings: VariationSettings) => {
|
|
41
|
+
// if (settings) {
|
|
42
|
+
// AssetUtils.CreateMaterialFromAsset(settings).then((materialObj: Material) => {
|
|
43
|
+
// const materialParams: MeshStandardMaterialParameters = {};
|
|
44
|
+
// materialParams.name = material.name;
|
|
45
|
+
// materialParams.map = materialObj.texture;
|
|
46
|
+
// materialParams.normalMap = materialObj.normal;
|
|
47
|
+
// materialParams.aoMap = materialObj.ao;
|
|
48
|
+
// materialParams.roughnessMap = materialObj.roughness;
|
|
49
|
+
// materialParams.metalnessMap = materialObj.metalness;
|
|
50
|
+
// materialParams.roughness = 1;
|
|
51
|
+
// materialParams.metalness = 1;
|
|
52
|
+
// const pbrMat: MeshStandardMaterial = new MeshStandardMaterial(materialParams);
|
|
53
|
+
// this.MaterialCache.set(material.name, pbrMat);
|
|
54
|
+
// resolve(pbrMat.clone());
|
|
55
|
+
// });
|
|
56
|
+
// } else {
|
|
57
|
+
// resolve(material);
|
|
58
|
+
// }
|
|
59
|
+
// });
|
|
60
|
+
// }
|
|
61
|
+
// });
|
|
62
|
+
// }
|
|
63
|
+
static GetVariationSettingsFromFile(id, compressedFile) {
|
|
64
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
65
|
+
if (!compressedFile) {
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
const zipContent = yield VariationUtils.GetZipContent(compressedFile);
|
|
69
|
+
const variationSettings = new VariationSettings();
|
|
70
|
+
let index;
|
|
71
|
+
variationSettings.id = id;
|
|
72
|
+
if (zipContent.files['index.json']) {
|
|
73
|
+
const indexFile = yield zipContent.files['index.json'].async('string');
|
|
74
|
+
index = JSON.parse(indexFile);
|
|
75
|
+
}
|
|
76
|
+
if (index) {
|
|
77
|
+
yield VariationUtils.CreateSettingsBasedOnIndex(index, variationSettings, zipContent);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
yield VariationUtils.CreateSettingsBasedOnFileName(variationSettings, zipContent);
|
|
81
|
+
}
|
|
82
|
+
return variationSettings;
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
static CreateSettingsBasedOnIndex(index, variationSettings, zipContent) {
|
|
86
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
+
if (index.normalFile) {
|
|
88
|
+
variationSettings.normal = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.normalFile], index.normalFile);
|
|
89
|
+
variationSettings.normalFilename = index.normalFile;
|
|
90
|
+
}
|
|
91
|
+
if (index.aoFile) {
|
|
92
|
+
variationSettings.ao = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.aoFile], index.aoFile);
|
|
93
|
+
variationSettings.aoFilename = index.aoFile;
|
|
94
|
+
}
|
|
95
|
+
if (index.metalnessFile) {
|
|
96
|
+
variationSettings.metalness = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.metalnessFile], index.metalnessFile);
|
|
97
|
+
variationSettings.metalnessFilename = index.metalnessFile;
|
|
98
|
+
}
|
|
99
|
+
if (index.roughnessFile) {
|
|
100
|
+
variationSettings.roughness = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.roughnessFile], index.roughnessFile);
|
|
101
|
+
variationSettings.roughnessFilename = index.roughnessFile;
|
|
102
|
+
}
|
|
103
|
+
if (index.diffuseFile) {
|
|
104
|
+
variationSettings.texture = yield VariationUtils.LoadFileContentFromZip(zipContent.files[index.diffuseFile], index.diffuseFile);
|
|
105
|
+
variationSettings.textureFilename = index.diffuseFile;
|
|
106
|
+
}
|
|
107
|
+
variationSettings.settings =
|
|
108
|
+
(yield VariationUtils.LoadFileContentFromZip(zipContent.files['repeat.json'], 'repeat.json', false)) || {};
|
|
109
|
+
Object.assign(variationSettings.settings, index.repeat);
|
|
110
|
+
variationSettings.settings.metalness = index.metalness;
|
|
111
|
+
variationSettings.settings.roughness = index.roughness;
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
static CreateSettingsBasedOnFileName(variationSettings, zipContent) {
|
|
115
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
116
|
+
const allLoaded = [];
|
|
117
|
+
for (const fileName in zipContent.files) {
|
|
118
|
+
if (zipContent.files[fileName]) {
|
|
119
|
+
const file = yield zipContent.files[fileName];
|
|
120
|
+
if (file.name.toLowerCase().indexOf('normal') > -1 && this.FileIsImage(file.name)) {
|
|
121
|
+
allLoaded.push(zipContent.files[fileName].async('base64').then((normalFile) => {
|
|
122
|
+
variationSettings.normal = `data:image/${this.GetBase64FileType(file.name)};base64,${normalFile}`;
|
|
123
|
+
variationSettings.normalFilename = fileName;
|
|
124
|
+
}));
|
|
125
|
+
}
|
|
126
|
+
else if (file.name.toLowerCase().indexOf('ao') > -1 && this.FileIsImage(file.name)) {
|
|
127
|
+
allLoaded.push(zipContent.files[fileName].async('base64').then((aoFile) => {
|
|
128
|
+
variationSettings.ao = `data:image/${this.GetBase64FileType(file.name)};base64,${aoFile}`;
|
|
129
|
+
variationSettings.aoFilename = fileName;
|
|
130
|
+
}));
|
|
131
|
+
}
|
|
132
|
+
else if (file.name.toLowerCase().indexOf('metalness') > -1 && this.FileIsImage(file.name)) {
|
|
133
|
+
allLoaded.push(zipContent.files[fileName].async('base64').then((metalnessFile) => {
|
|
134
|
+
variationSettings.metalness = `data:image/${this.GetBase64FileType(file.name)};base64,${metalnessFile}`;
|
|
135
|
+
variationSettings.metalnessFilename = fileName;
|
|
136
|
+
}));
|
|
137
|
+
}
|
|
138
|
+
else if (file.name.toLowerCase().indexOf('roughness') > -1 && this.FileIsImage(file.name)) {
|
|
139
|
+
allLoaded.push(zipContent.files[fileName].async('base64').then((roughnessFile) => {
|
|
140
|
+
variationSettings.roughness = `data:image/${this.GetBase64FileType(file.name)};base64,${roughnessFile}`;
|
|
141
|
+
variationSettings.roughnessFilename = fileName;
|
|
142
|
+
}));
|
|
143
|
+
}
|
|
144
|
+
else if (file.name.toLowerCase().indexOf('diffuse') > -1 && this.FileIsImage(file.name)) {
|
|
145
|
+
allLoaded.push(zipContent.files[fileName].async('base64').then((diffuseFile) => {
|
|
146
|
+
variationSettings.texture = `data:image/${this.GetBase64FileType(file.name)};base64,${diffuseFile}`;
|
|
147
|
+
variationSettings.textureFilename = fileName;
|
|
148
|
+
}));
|
|
149
|
+
}
|
|
150
|
+
else if (file.name.indexOf('.jp') > -1) {
|
|
151
|
+
allLoaded.push(zipContent.files[fileName].async('base64').then((textureFile) => {
|
|
152
|
+
variationSettings.texture = 'data:image/jpeg;base64,' + textureFile;
|
|
153
|
+
variationSettings.textureFilename = fileName;
|
|
154
|
+
}));
|
|
155
|
+
}
|
|
156
|
+
else if (file.name.indexOf('.json') > -1) {
|
|
157
|
+
allLoaded.push(zipContent.files[fileName].async('string').then((settingsFile) => {
|
|
158
|
+
const settingsFileObj = JSON.parse(settingsFile);
|
|
159
|
+
for (const key in settingsFileObj) {
|
|
160
|
+
if (settingsFileObj[key]) {
|
|
161
|
+
variationSettings.settings[key] = settingsFileObj[key];
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}));
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
yield Promise.all(allLoaded);
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
static LoadFileContentFromZip(zip, fileName, base64 = true) {
|
|
172
|
+
return new Promise((resolve) => {
|
|
173
|
+
if (zip && fileName) {
|
|
174
|
+
zip.async(base64 ? 'base64' : 'string').then((fileContent) => {
|
|
175
|
+
if (base64) {
|
|
176
|
+
resolve(`data:image/${this.GetBase64FileType(fileName)};base64,${fileContent}`);
|
|
177
|
+
}
|
|
178
|
+
else {
|
|
179
|
+
resolve(fileContent);
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
resolve(undefined);
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
static FileIsImage(fileName) {
|
|
189
|
+
const ext = fileName.substring(fileName.lastIndexOf('.') + 1, fileName.length).toLowerCase();
|
|
190
|
+
switch (ext) {
|
|
191
|
+
case 'jpg':
|
|
192
|
+
case 'jpeg':
|
|
193
|
+
case 'png':
|
|
194
|
+
case 'bmp':
|
|
195
|
+
return true;
|
|
196
|
+
default:
|
|
197
|
+
return false;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
static GetBase64FileType(fileName) {
|
|
201
|
+
const ext = fileName.substring(fileName.lastIndexOf('.') + 1, fileName.length).toLowerCase();
|
|
202
|
+
switch (ext) {
|
|
203
|
+
case 'jpg':
|
|
204
|
+
case 'jpeg':
|
|
205
|
+
return 'jpeg';
|
|
206
|
+
case 'png':
|
|
207
|
+
return 'png';
|
|
208
|
+
case 'bmp':
|
|
209
|
+
return 'bmp';
|
|
210
|
+
default:
|
|
211
|
+
return 'jpeg';
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
// Get the content
|
|
215
|
+
static GetZipContent(file) {
|
|
216
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
217
|
+
const jszip = new JSZip();
|
|
218
|
+
const content = yield jszip.loadAsync(file);
|
|
219
|
+
return content;
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
VariationUtils.MaterialCache = new Map();
|
|
224
224
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"variation-utils.js","sourceRoot":"ng://@colijnit/configurator/","sources":["utils/variation-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import * as JSZip from 'jszip';\r\nimport * as THREE from 'three';\r\nimport {FileUtils} from \"./file.utils\";\r\nimport {VariationSettings} from \"../model/variation-settings\";\r\nimport axios from \"axios\";\r\n\r\n// @dynamic\r\nexport class VariationUtils {\r\n  private static MaterialCache: Map<string, THREE.MeshStandardMaterial> = new Map();\r\n\r\n  public static async LoadVariation(assetPath: string, fileName: string): Promise<VariationSettings> {\r\n    if (!fileName) {\r\n      return null;\r\n    }\r\n    if (fileName.indexOf('ione3d') < 0) {\r\n      fileName = fileName.concat('.ione3d');\r\n    }\r\n    const id: string = fileName.substr(0, fileName.lastIndexOf('.ione3d'));\r\n    try {\r\n      if (!assetPath.endsWith('/')) {\r\n        assetPath += '/';\r\n      }\r\n      if (!window.hasOwnProperty('downloadVariation')) {\r\n        console.error('downloadVariation not defined in window global');\r\n        return null;\r\n      }\r\n      const file: any = await (window as any).downloadVariation(`${assetPath.replace('https://cdn1.colijn-it.nl/', '')}variation/${fileName}`);\r\n      return await VariationUtils.GetVariationSettingsFromFile(id, file);\r\n    } catch (err) {\r\n      const mute = err;\r\n      return null;\r\n    }\r\n  }\r\n\r\n  // public static GetMaterialFromName(variationFolder: string, material: any): Promise<MeshStandardMaterial> {\r\n  //   return new Promise((resolve: Function) => {\r\n  //     if (!material) {\r\n  //       resolve(null);\r\n  //     }\r\n  //     if (this.MaterialCache.has(material.name)) {\r\n  //       resolve(this.MaterialCache.get(material.name).clone());\r\n  //     } else {\r\n  //       VariationUtils.LoadVariation(variationFolder, material.name, false).then((settings: VariationSettings) => {\r\n  //         if (settings) {\r\n  //           AssetUtils.CreateMaterialFromAsset(settings).then((materialObj: Material) => {\r\n  //             const materialParams: MeshStandardMaterialParameters = {};\r\n  //             materialParams.name = material.name;\r\n  //             materialParams.map = materialObj.texture;\r\n  //             materialParams.normalMap = materialObj.normal;\r\n  //             materialParams.aoMap = materialObj.ao;\r\n  //             materialParams.roughnessMap = materialObj.roughness;\r\n  //             materialParams.metalnessMap = materialObj.metalness;\r\n  //             materialParams.roughness = 1;\r\n  //             materialParams.metalness = 1;\r\n  //             const pbrMat: MeshStandardMaterial = new MeshStandardMaterial(materialParams);\r\n  //             this.MaterialCache.set(material.name, pbrMat);\r\n  //             resolve(pbrMat.clone());\r\n  //           });\r\n  //         } else {\r\n  //           resolve(material);\r\n  //         }\r\n  //       });\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  private static async GetVariationSettingsFromFile(id: string, compressedFile: any): Promise<VariationSettings> {\r\n    if (!compressedFile) {\r\n      return null;\r\n    }\r\n    const zipContent = await VariationUtils.GetZipContent(compressedFile);\r\n    const variationSettings: VariationSettings = new VariationSettings();\r\n    let index;\r\n    variationSettings.id = id;\r\n\r\n    if (zipContent.files['index.json']) {\r\n      const indexFile: string = await zipContent.files['index.json'].async('string');\r\n      index = JSON.parse(indexFile);\r\n    }\r\n    if (index) {\r\n      await VariationUtils.CreateSettingsBasedOnIndex(index, variationSettings, zipContent);\r\n    } else {\r\n      await VariationUtils.CreateSettingsBasedOnFileName(variationSettings, zipContent);\r\n    }\r\n    return variationSettings;\r\n  }\r\n\r\n  private static async CreateSettingsBasedOnIndex(index: any, variationSettings: VariationSettings, zipContent: any): Promise<void> {\r\n    if (index.normalFile) {\r\n      variationSettings.normal = await VariationUtils.LoadFileContentFromZip(zipContent.files[index.normalFile], index.normalFile);\r\n      variationSettings.normalFilename = index.normalFile;\r\n    }\r\n    if (index.aoFile) {\r\n      variationSettings.ao = await VariationUtils.LoadFileContentFromZip(zipContent.files[index.aoFile], index.aoFile);\r\n      variationSettings.aoFilename = index.aoFile;\r\n    }\r\n    if (index.metalnessFile) {\r\n      variationSettings.metalness = await VariationUtils.LoadFileContentFromZip(zipContent.files[index.metalnessFile], index.metalnessFile);\r\n      variationSettings.metalnessFilename = index.metalnessFile;\r\n    }\r\n    if (index.roughnessFile) {\r\n      variationSettings.roughness = await VariationUtils.LoadFileContentFromZip(zipContent.files[index.roughnessFile], index.roughnessFile);\r\n      variationSettings.roughnessFilename = index.roughnessFile;\r\n    }\r\n    if (index.diffuseFile) {\r\n      variationSettings.texture = await VariationUtils.LoadFileContentFromZip(zipContent.files[index.diffuseFile], index.diffuseFile);\r\n      variationSettings.textureFilename = index.diffuseFile;\r\n    }\r\n    variationSettings.settings =\r\n      await VariationUtils.LoadFileContentFromZip(zipContent.files['repeat.json'], 'repeat.json', false) || {};\r\n    Object.assign(variationSettings.settings, index.repeat);\r\n    variationSettings.settings.metalness = index.metalness;\r\n    variationSettings.settings.roughness = index.roughness;\r\n  }\r\n\r\n  private static async CreateSettingsBasedOnFileName(variationSettings: VariationSettings, zipContent: any): Promise<void> {\r\n    const allLoaded: Promise<VariationSettings>[] = [];\r\n    for (const fileName in zipContent.files) {\r\n      if (zipContent.files[fileName]) {\r\n        const file: any = await zipContent.files[fileName];\r\n        if (file.name.toLowerCase().indexOf('normal') > -1 && this.FileIsImage(file.name)) {\r\n          allLoaded.push(zipContent.files[fileName].async('base64').then((normalFile: any) => {\r\n            variationSettings.normal = `data:image/${this.GetBase64FileType(file.name)};base64,${normalFile}`;\r\n            variationSettings.normalFilename = fileName;\r\n          }));\r\n        } else if (file.name.toLowerCase().indexOf('ao') > -1 && this.FileIsImage(file.name)) {\r\n          allLoaded.push(zipContent.files[fileName].async('base64').then((aoFile: any) => {\r\n            variationSettings.ao = `data:image/${this.GetBase64FileType(file.name)};base64,${aoFile}`;\r\n            variationSettings.aoFilename = fileName;\r\n          }));\r\n        } else if (file.name.toLowerCase().indexOf('metalness') > -1 && this.FileIsImage(file.name)) {\r\n          allLoaded.push(zipContent.files[fileName].async('base64').then((metalnessFile: any) => {\r\n            variationSettings.metalness = `data:image/${this.GetBase64FileType(file.name)};base64,${metalnessFile}`;\r\n            variationSettings.metalnessFilename = fileName;\r\n          }));\r\n        } else if (file.name.toLowerCase().indexOf('roughness') > -1 && this.FileIsImage(file.name)) {\r\n          allLoaded.push(zipContent.files[fileName].async('base64').then((roughnessFile: any) => {\r\n            variationSettings.roughness = `data:image/${this.GetBase64FileType(file.name)};base64,${roughnessFile}`;\r\n            variationSettings.roughnessFilename = fileName;\r\n          }));\r\n        } else if (file.name.toLowerCase().indexOf('diffuse') > -1 && this.FileIsImage(file.name)) {\r\n          allLoaded.push(zipContent.files[fileName].async('base64').then((diffuseFile: any) => {\r\n            variationSettings.texture = `data:image/${this.GetBase64FileType(file.name)};base64,${diffuseFile}`;\r\n            variationSettings.textureFilename = fileName;\r\n          }));\r\n        } else if (file.name.indexOf('.jp') > -1) {\r\n          allLoaded.push(zipContent.files[fileName].async('base64').then((textureFile: any) => {\r\n            variationSettings.texture = 'data:image/jpeg;base64,' + textureFile;\r\n            variationSettings.textureFilename = fileName;\r\n          }));\r\n        } else if (file.name.indexOf('.json') > -1) {\r\n          allLoaded.push(zipContent.files[fileName].async('string').then((settingsFile: any) => {\r\n            const settingsFileObj = JSON.parse(settingsFile);\r\n            for (const key in settingsFileObj) {\r\n              if (settingsFileObj[key]) {\r\n                variationSettings.settings[key] = settingsFileObj[key];\r\n              }\r\n            }\r\n          }));\r\n        }\r\n      }\r\n    }\r\n    await Promise.all(allLoaded);\r\n  }\r\n\r\n  private static LoadFileContentFromZip(zip: any, fileName: string, base64: boolean = true): Promise<string> {\r\n    return new Promise((resolve: Function) => {\r\n      if (zip && fileName) {\r\n        zip.async(base64 ? 'base64' : 'string').then((fileContent: any) => {\r\n          if (base64) {\r\n            resolve(`data:image/${this.GetBase64FileType(fileName)};base64,${fileContent}`);\r\n          } else {\r\n            resolve(fileContent);\r\n          }\r\n        });\r\n      } else {\r\n        resolve(undefined);\r\n      }\r\n    });\r\n  }\r\n\r\n  private static FileIsImage(fileName: string): boolean {\r\n    const ext: string = fileName.substring(fileName.lastIndexOf('.') + 1, fileName.length).toLowerCase();\r\n    switch (ext) {\r\n      case 'jpg':\r\n      case 'jpeg':\r\n      case 'png':\r\n      case 'bmp':\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private static GetBase64FileType(fileName: string): string {\r\n    const ext: string = fileName.substring(fileName.lastIndexOf('.') + 1, fileName.length).toLowerCase();\r\n    switch (ext) {\r\n      case 'jpg':\r\n      case 'jpeg':\r\n        return 'jpeg';\r\n      case 'png':\r\n        return 'png';\r\n      case 'bmp':\r\n        return 'bmp';\r\n      default:\r\n        return 'jpeg';\r\n    }\r\n  }\r\n\r\n  // Get the content\r\n  private static async GetZipContent(file): Promise<any> {\r\n    const jszip = new JSZip();\r\n    const content = await jszip.loadAsync(file);\r\n    return content;\r\n  }\r\n}\r\n"]}
|