@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.
Files changed (88) hide show
  1. package/app/builder.d.ts +53 -53
  2. package/app/components/answers/answer/answer.component.d.ts +11 -11
  3. package/app/components/answers/answers.component.d.ts +8 -8
  4. package/app/components/answers/answers.module.d.ts +2 -2
  5. package/app/components/selections/selections.component.d.ts +22 -22
  6. package/app/components/selections/selections.module.d.ts +2 -2
  7. package/app/components/shared/loader/loader.component.d.ts +2 -2
  8. package/app/components/shared/shared.module.d.ts +2 -2
  9. package/app/directives/visibility-observer-master.directive.d.ts +9 -9
  10. package/app/directives/visibility-observer.directive.d.ts +13 -13
  11. package/app/services/configurator.service.d.ts +22 -22
  12. package/app/services/image-cache.service.d.ts +10 -10
  13. package/app/services/locator.service.d.ts +4 -4
  14. package/bundles/colijnit-configurator.umd.js +2455 -2455
  15. package/bundles/colijnit-configurator.umd.js.map +1 -1
  16. package/bundles/colijnit-configurator.umd.min.js +2 -2
  17. package/bundles/colijnit-configurator.umd.min.js.map +1 -1
  18. package/colijnit-configurator.d.ts +10 -10
  19. package/colijnit-configurator.metadata.json +1 -1
  20. package/esm2015/app/builder.js +477 -477
  21. package/esm2015/app/components/answers/answer/answer.component.js +66 -61
  22. package/esm2015/app/components/answers/answers.component.js +40 -37
  23. package/esm2015/app/components/answers/answers.module.js +28 -28
  24. package/esm2015/app/components/selections/selections.component.js +128 -108
  25. package/esm2015/app/components/selections/selections.module.js +22 -22
  26. package/esm2015/app/components/shared/loader/loader.component.js +12 -12
  27. package/esm2015/app/components/shared/shared.module.js +20 -20
  28. package/esm2015/app/directives/visibility-observer-master.directive.js +50 -50
  29. package/esm2015/app/directives/visibility-observer.directive.js +56 -56
  30. package/esm2015/app/services/configurator.service.js +94 -94
  31. package/esm2015/app/services/image-cache.service.js +66 -66
  32. package/esm2015/app/services/locator.service.js +9 -9
  33. package/esm2015/colijnit-configurator.js +10 -10
  34. package/esm2015/helper/variation-helper.js +215 -215
  35. package/esm2015/model/material.js +10 -10
  36. package/esm2015/model/variation-settings.js +5 -5
  37. package/esm2015/model/variation.js +2 -2
  38. package/esm2015/public_api.js +6 -6
  39. package/esm2015/utils/asset.utils.js +73 -73
  40. package/esm2015/utils/file.utils.js +138 -138
  41. package/esm2015/utils/image.utils.js +51 -51
  42. package/esm2015/utils/object.utils.js +48 -48
  43. package/esm2015/utils/scene-utils.js +93 -93
  44. package/esm2015/utils/threed.utils.js +221 -221
  45. package/esm2015/utils/variation-utils.js +223 -223
  46. package/esm5/app/builder.js +591 -591
  47. package/esm5/app/components/answers/answer/answer.component.js +64 -64
  48. package/esm5/app/components/answers/answers.component.js +27 -27
  49. package/esm5/app/components/answers/answers.module.js +31 -31
  50. package/esm5/app/components/selections/selections.component.js +104 -104
  51. package/esm5/app/components/selections/selections.module.js +25 -25
  52. package/esm5/app/components/shared/loader/loader.component.js +15 -15
  53. package/esm5/app/components/shared/shared.module.js +23 -23
  54. package/esm5/app/directives/visibility-observer-master.directive.js +63 -63
  55. package/esm5/app/directives/visibility-observer.directive.js +58 -58
  56. package/esm5/app/services/configurator.service.js +160 -160
  57. package/esm5/app/services/image-cache.service.js +69 -69
  58. package/esm5/app/services/locator.service.js +12 -12
  59. package/esm5/colijnit-configurator.js +10 -10
  60. package/esm5/helper/variation-helper.js +267 -267
  61. package/esm5/model/material.js +12 -12
  62. package/esm5/model/variation-settings.js +7 -7
  63. package/esm5/model/variation.js +6 -6
  64. package/esm5/public_api.js +6 -6
  65. package/esm5/utils/asset.utils.js +105 -105
  66. package/esm5/utils/file.utils.js +150 -150
  67. package/esm5/utils/image.utils.js +55 -55
  68. package/esm5/utils/object.utils.js +55 -55
  69. package/esm5/utils/scene-utils.js +97 -97
  70. package/esm5/utils/threed.utils.js +278 -278
  71. package/esm5/utils/variation-utils.js +326 -326
  72. package/fesm2015/colijnit-configurator.js +2016 -1988
  73. package/fesm2015/colijnit-configurator.js.map +1 -1
  74. package/fesm5/colijnit-configurator.js +2457 -2457
  75. package/fesm5/colijnit-configurator.js.map +1 -1
  76. package/helper/variation-helper.d.ts +14 -14
  77. package/model/material.d.ts +17 -17
  78. package/model/variation-settings.d.ts +14 -14
  79. package/model/variation.d.ts +10 -10
  80. package/package.json +3 -2
  81. package/public_api.d.ts +6 -6
  82. package/utils/asset.utils.d.ts +13 -13
  83. package/utils/file.utils.d.ts +27 -27
  84. package/utils/image.utils.d.ts +8 -8
  85. package/utils/object.utils.d.ts +7 -7
  86. package/utils/scene-utils.d.ts +7 -7
  87. package/utils/threed.utils.d.ts +16 -16
  88. 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"]}