@colijnit/product 256.1.3 → 256.1.4
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/components/product-external-source/product-external-source.component.d.ts +16 -0
- package/app/components/product-hd/product-hd.component.d.ts +22 -0
- package/app/components/product-hd/product-hd.module.d.ts +2 -0
- package/app/ione-product.component.d.ts +1 -0
- package/app/service/product-script-loader.service.d.ts +9 -0
- package/bundles/colijnit-product.umd.js +312 -34
- package/bundles/colijnit-product.umd.js.map +1 -1
- package/colijnit-product-256.1.3.tgz +0 -0
- package/colijnit-product.d.ts +3 -0
- package/colijnit-product.metadata.json +1 -1
- package/esm2015/app/components/product-external-source/product-external-source.component.js +82 -20
- package/esm2015/app/components/product-external-source/product-external-source.module.js +4 -2
- package/esm2015/app/components/product-hd/product-hd.component.js +99 -0
- package/esm2015/app/components/product-hd/product-hd.module.js +23 -0
- package/esm2015/app/ione-product.component.js +4 -2
- package/esm2015/app/ione-product.module.js +14 -6
- package/esm2015/app/product-version.js +3 -3
- package/esm2015/app/service/product-script-loader.service.js +68 -0
- package/esm2015/colijnit-product.js +4 -1
- package/fesm2015/colijnit-product.js +296 -44
- package/fesm2015/colijnit-product.js.map +1 -1
- package/package.json +1 -1
- package/colijnit-product-256.1.2.tgz +0 -0
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
|
|
2
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ProductScriptLoaderService {
|
|
5
|
+
constructor(platformId) {
|
|
6
|
+
this.platformId = platformId;
|
|
7
|
+
this._scriptsOrLinksElements = [];
|
|
8
|
+
}
|
|
9
|
+
loadScript(url, renderer) {
|
|
10
|
+
return new Promise((resolve, reject) => {
|
|
11
|
+
if (!isPlatformBrowser(this.platformId)) {
|
|
12
|
+
reject('Not in browser environment');
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const existingScript = document.getElementById(url);
|
|
16
|
+
if (existingScript) {
|
|
17
|
+
resolve(); // Script already loaded
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const script = renderer.createElement('script');
|
|
21
|
+
script.id = url;
|
|
22
|
+
script.src = url;
|
|
23
|
+
script.type = 'text/javascript';
|
|
24
|
+
script.async = true;
|
|
25
|
+
script.onload = () => resolve();
|
|
26
|
+
script.onerror = (error) => reject(`Error loading script: ${url}`);
|
|
27
|
+
renderer.appendChild(document.head, script);
|
|
28
|
+
this._scriptsOrLinksElements.push(script);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
unloadScripts(renderer) {
|
|
32
|
+
for (let i = this._scriptsOrLinksElements.length - 1; i >= 0; i--) {
|
|
33
|
+
renderer.removeChild(document.head, this._scriptsOrLinksElements[i]);
|
|
34
|
+
this._scriptsOrLinksElements.pop();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
addStyleSheet(url, renderer) {
|
|
38
|
+
return new Promise((resolve, reject) => {
|
|
39
|
+
if (!isPlatformBrowser(this.platformId)) {
|
|
40
|
+
reject('Not in browser environment');
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const existingStyleSheet = document.getElementById(url);
|
|
44
|
+
if (existingStyleSheet) {
|
|
45
|
+
resolve(); // Script already loaded
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const link = renderer.createElement('link');
|
|
49
|
+
link.id = url;
|
|
50
|
+
link.href = url;
|
|
51
|
+
link.rel = 'stylesheet';
|
|
52
|
+
link.onload = () => resolve();
|
|
53
|
+
link.onerror = (error) => reject(`Error loading styleSheet: ${url}`);
|
|
54
|
+
renderer.appendChild(document.head, link);
|
|
55
|
+
this._scriptsOrLinksElements.push(link);
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
ProductScriptLoaderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProductScriptLoaderService_Factory() { return new ProductScriptLoaderService(i0.ɵɵinject(i0.PLATFORM_ID)); }, token: ProductScriptLoaderService, providedIn: "root" });
|
|
60
|
+
ProductScriptLoaderService.decorators = [
|
|
61
|
+
{ type: Injectable, args: [{
|
|
62
|
+
providedIn: 'root'
|
|
63
|
+
},] }
|
|
64
|
+
];
|
|
65
|
+
ProductScriptLoaderService.ctorParameters = () => [
|
|
66
|
+
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
|
|
67
|
+
];
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1zY3JpcHQtbG9hZGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL3NlcnZpY2UvcHJvZHVjdC1zY3JpcHQtbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLGlCQUFpQixDQUFDOztBQUtsRCxNQUFNLE9BQU8sMEJBQTBCO0lBSXJDLFlBRVUsVUFBZTtRQUFmLGVBQVUsR0FBVixVQUFVLENBQUs7UUFKakIsNEJBQXVCLEdBQVUsRUFBRSxDQUFDO0lBTzVDLENBQUM7SUFFTSxVQUFVLENBQUMsR0FBVyxFQUFFLFFBQW1CO1FBQ2hELE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDckMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRTtnQkFDdkMsTUFBTSxDQUFDLDRCQUE0QixDQUFDLENBQUM7Z0JBQ3JDLE9BQU87YUFDUjtZQUVELE1BQU0sY0FBYyxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDcEQsSUFBSSxjQUFjLEVBQUU7Z0JBQ2xCLE9BQU8sRUFBRSxDQUFDLENBQUMsd0JBQXdCO2dCQUNuQyxPQUFPO2FBQ1I7WUFFRCxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBRWhELE1BQU0sQ0FBQyxFQUFFLEdBQUcsR0FBRyxDQUFDO1lBQ2hCLE1BQU0sQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1lBQ2pCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsaUJBQWlCLENBQUM7WUFDaEMsTUFBTSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7WUFFcEIsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQyxNQUFNLENBQUMsT0FBTyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMseUJBQXlCLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFFbkUsUUFBUSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQzVDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU0sYUFBYSxDQUFDLFFBQW1CO1FBQ3RDLEtBQUssSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLHVCQUF1QixDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUNqRSxRQUFRLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDckUsSUFBSSxDQUFDLHVCQUF1QixDQUFDLEdBQUcsRUFBRSxDQUFDO1NBQ3BDO0lBQ0gsQ0FBQztJQUVNLGFBQWEsQ0FBQyxHQUFXLEVBQUUsUUFBbUI7UUFDbkQsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUNyQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFO2dCQUN2QyxNQUFNLENBQUMsNEJBQTRCLENBQUMsQ0FBQztnQkFDckMsT0FBTzthQUNSO1lBRUQsTUFBTSxrQkFBa0IsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3hELElBQUksa0JBQWtCLEVBQUU7Z0JBQ3RCLE9BQU8sRUFBRSxDQUFDLENBQUMsd0JBQXdCO2dCQUNuQyxPQUFPO2FBQ1I7WUFFRCxNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzVDLElBQUksQ0FBQyxFQUFFLEdBQUcsR0FBRyxDQUFDO1lBQ2QsSUFBSSxDQUFDLElBQUksR0FBRyxHQUFHLENBQUM7WUFDaEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxZQUFZLENBQUM7WUFFeEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUM5QixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsNkJBQTZCLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFFckUsUUFBUSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO1lBQzFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOzs7O1lBekVGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7OzRDQU1JLE1BQU0sU0FBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3QsIEluamVjdGFibGUsIFBMQVRGT1JNX0lELCBSZW5kZXJlcjJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge2lzUGxhdGZvcm1Ccm93c2VyfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUHJvZHVjdFNjcmlwdExvYWRlclNlcnZpY2Uge1xyXG5cclxuICBwcml2YXRlIF9zY3JpcHRzT3JMaW5rc0VsZW1lbnRzOiBhbnlbXSA9IFtdO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIEBJbmplY3QoUExBVEZPUk1fSUQpXHJcbiAgICBwcml2YXRlIHBsYXRmb3JtSWQ6IGFueVxyXG4gICkge1xyXG5cclxuICB9XHJcblxyXG4gIHB1YmxpYyBsb2FkU2NyaXB0KHVybDogc3RyaW5nLCByZW5kZXJlcjogUmVuZGVyZXIyKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xyXG4gICAgICBpZiAoIWlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHtcclxuICAgICAgICByZWplY3QoJ05vdCBpbiBicm93c2VyIGVudmlyb25tZW50Jyk7XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBjb25zdCBleGlzdGluZ1NjcmlwdCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKHVybCk7XHJcbiAgICAgIGlmIChleGlzdGluZ1NjcmlwdCkge1xyXG4gICAgICAgIHJlc29sdmUoKTsgLy8gU2NyaXB0IGFscmVhZHkgbG9hZGVkXHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBjb25zdCBzY3JpcHQgPSByZW5kZXJlci5jcmVhdGVFbGVtZW50KCdzY3JpcHQnKTtcclxuXHJcbiAgICAgIHNjcmlwdC5pZCA9IHVybDtcclxuICAgICAgc2NyaXB0LnNyYyA9IHVybDtcclxuICAgICAgc2NyaXB0LnR5cGUgPSAndGV4dC9qYXZhc2NyaXB0JztcclxuICAgICAgc2NyaXB0LmFzeW5jID0gdHJ1ZTtcclxuXHJcbiAgICAgIHNjcmlwdC5vbmxvYWQgPSAoKSA9PiByZXNvbHZlKCk7XHJcbiAgICAgIHNjcmlwdC5vbmVycm9yID0gKGVycm9yKSA9PiByZWplY3QoYEVycm9yIGxvYWRpbmcgc2NyaXB0OiAke3VybH1gKTtcclxuXHJcbiAgICAgIHJlbmRlcmVyLmFwcGVuZENoaWxkKGRvY3VtZW50LmhlYWQsIHNjcmlwdCk7XHJcbiAgICAgIHRoaXMuX3NjcmlwdHNPckxpbmtzRWxlbWVudHMucHVzaChzY3JpcHQpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgdW5sb2FkU2NyaXB0cyhyZW5kZXJlcjogUmVuZGVyZXIyKTogdm9pZCB7XHJcbiAgICBmb3IgKGxldCBpID0gdGhpcy5fc2NyaXB0c09yTGlua3NFbGVtZW50cy5sZW5ndGggLSAxOyBpID49IDA7IGktLSkge1xyXG4gICAgICByZW5kZXJlci5yZW1vdmVDaGlsZChkb2N1bWVudC5oZWFkLCB0aGlzLl9zY3JpcHRzT3JMaW5rc0VsZW1lbnRzW2ldKTtcclxuICAgICAgdGhpcy5fc2NyaXB0c09yTGlua3NFbGVtZW50cy5wb3AoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBhZGRTdHlsZVNoZWV0KHVybDogc3RyaW5nLCByZW5kZXJlcjogUmVuZGVyZXIyKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xyXG4gICAgICBpZiAoIWlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHtcclxuICAgICAgICByZWplY3QoJ05vdCBpbiBicm93c2VyIGVudmlyb25tZW50Jyk7XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBjb25zdCBleGlzdGluZ1N0eWxlU2hlZXQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh1cmwpO1xyXG4gICAgICBpZiAoZXhpc3RpbmdTdHlsZVNoZWV0KSB7XHJcbiAgICAgICAgcmVzb2x2ZSgpOyAvLyBTY3JpcHQgYWxyZWFkeSBsb2FkZWRcclxuICAgICAgICByZXR1cm47XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIGNvbnN0IGxpbmsgPSByZW5kZXJlci5jcmVhdGVFbGVtZW50KCdsaW5rJyk7XHJcbiAgICAgIGxpbmsuaWQgPSB1cmw7XHJcbiAgICAgIGxpbmsuaHJlZiA9IHVybDtcclxuICAgICAgbGluay5yZWwgPSAnc3R5bGVzaGVldCc7XHJcblxyXG4gICAgICBsaW5rLm9ubG9hZCA9ICgpID0+IHJlc29sdmUoKTtcclxuICAgICAgbGluay5vbmVycm9yID0gKGVycm9yKSA9PiByZWplY3QoYEVycm9yIGxvYWRpbmcgc3R5bGVTaGVldDogJHt1cmx9YCk7XHJcblxyXG4gICAgICByZW5kZXJlci5hcHBlbmRDaGlsZChkb2N1bWVudC5oZWFkLCBsaW5rKTtcclxuICAgICAgdGhpcy5fc2NyaXB0c09yTGlua3NFbGVtZW50cy5wdXNoKGxpbmspO1xyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -20,6 +20,8 @@ export { ProductDialogComponent as ɵbl } from './app/components/product-dialog/
|
|
|
20
20
|
export { ProductDialogModule as ɵbk } from './app/components/product-dialog/product-dialog.module';
|
|
21
21
|
export { ProductDocumentModule as ɵbf } from './app/components/product-documents/product-document.module';
|
|
22
22
|
export { ProductDocumentsComponent as ɵbg } from './app/components/product-documents/product-documents.component';
|
|
23
|
+
export { ProductHdComponent as ɵbo } from './app/components/product-hd/product-hd.component';
|
|
24
|
+
export { ProductHdModule as ɵbn } from './app/components/product-hd/product-hd.module';
|
|
23
25
|
export { ProductInfoTabsComponent as ɵbj } from './app/components/product-info-tabs/product-info-tabs.component';
|
|
24
26
|
export { ProductInfoTabsModule as ɵba } from './app/components/product-info-tabs/product-info-tabs.module';
|
|
25
27
|
export { ProductPageComponent as ɵbm } from './app/components/product-page/product-page.component';
|
|
@@ -40,5 +42,6 @@ export { LocalizePipe as ɵd } from './app/pipe/localize.pipe';
|
|
|
40
42
|
export { PipeModule as ɵc } from './app/pipe/pipe.module';
|
|
41
43
|
export { DictionaryService as ɵe } from './app/service/dictionary.service';
|
|
42
44
|
export { IconCacheService as ɵh } from './app/service/icon-cache.service';
|
|
45
|
+
export { ProductScriptLoaderService as ɵbp } from './app/service/product-script-loader.service';
|
|
43
46
|
export { JsonUtilsService as ɵf } from './app/utils/json-utils.service';
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colijnit-product.js","sourceRoot":"","sources":["../../src/colijnit-product.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n\nexport {HeaderComponent as ɵu} from './app/components/core/header/header.component';\nexport {HeaderModule as ɵt} from './app/components/core/header/header.module';\nexport {ImageCarouselComponent as ɵj} from './app/components/image-carousel/image-carousel.component';\nexport {ImageCarouselModule as ɵi} from './app/components/image-carousel/image-carousel.module';\nexport {ProductAdditionalDescriptionComponent as ɵn} from './app/components/product-additional-description/product-additional-description.component';\nexport {ProductAdditionalDescriptionModule as ɵm} from './app/components/product-additional-description/product-additional-description.module';\nexport {ProductAdditionalInfoComponent as ɵbc} from './app/components/product-additional-info/product-additional-info.component';\nexport {ProductAdditionalInfoModule as ɵbb} from './app/components/product-additional-info/product-additional-info.module';\nexport {ProductAddtocartComponent as ɵr} from './app/components/product-addtocart/product-addtocart.component';\nexport {ProductAddtocartModule as ɵq} from './app/components/product-addtocart/product-addtocart.module';\nexport {ProductDeliveryComponent as ɵz} from './app/components/product-delivery/product-delivery.component';\nexport {ProductDeliveryModule as ɵy} from './app/components/product-delivery/product-delivery.module';\nexport {ProductDescriptionComponent as ɵl} from './app/components/product-description/product-description.component';\nexport {ProductDescriptionModule as ɵk} from './app/components/product-description/product-description.module';\nexport {ProductDialogComponent as ɵbl} from './app/components/product-dialog/product-dialog.component';\nexport {ProductDialogModule as ɵbk} from './app/components/product-dialog/product-dialog.module';\nexport {ProductDocumentModule as ɵbf} from './app/components/product-documents/product-document.module';\nexport {ProductDocumentsComponent as ɵbg} from './app/components/product-documents/product-documents.component';\nexport {ProductHdComponent as ɵbo} from './app/components/product-hd/product-hd.component';\nexport {ProductHdModule as ɵbn} from './app/components/product-hd/product-hd.module';\nexport {ProductInfoTabsComponent as ɵbj} from './app/components/product-info-tabs/product-info-tabs.component';\nexport {ProductInfoTabsModule as ɵba} from './app/components/product-info-tabs/product-info-tabs.module';\nexport {ProductPageComponent as ɵbm} from './app/components/product-page/product-page.component';\nexport {ProductPageModule as ɵa} from './app/components/product-page/product-page.module';\nexport {ProductPriceComponent as ɵp} from './app/components/product-price/product-price.component';\nexport {ProductPriceModule as ɵo} from './app/components/product-price/product-price.module';\nexport {ProductPropertiesComponent as ɵbe} from './app/components/product-properties/product-properties.component';\nexport {ProductPropertiesModule as ɵbd} from './app/components/product-properties/product-properties.module';\nexport {ProductRelatedComponent as ɵv} from './app/components/product-related/product-related.component';\nexport {ProductRelatedModule as ɵs} from './app/components/product-related/product-related.module';\nexport {ProductSelectorTypeComponent as ɵg} from './app/components/product-selector-type/product-selector-type.component';\nexport {ProductSelectorTypeModule as ɵb} from './app/components/product-selector-type/product-selector-type.module';\nexport {ProductStockComponent as ɵx} from './app/components/product-stock/product-stock.component';\nexport {ProductStockModule as ɵw} from './app/components/product-stock/product-stock.module';\nexport {ProductSymbolsComponent as ɵbi} from './app/components/product-symbols/product-symbols.component';\nexport {ProductSymbolsModule as ɵbh} from './app/components/product-symbols/product-symbols.module';\nexport {LocalizePipe as ɵd} from './app/pipe/localize.pipe';\nexport {PipeModule as ɵc} from './app/pipe/pipe.module';\nexport {DictionaryService as ɵe} from './app/service/dictionary.service';\nexport {IconCacheService as ɵh} from './app/service/icon-cache.service';\nexport {ProductScriptLoaderService as ɵbp} from './app/service/product-script-loader.service';\nexport {JsonUtilsService as ɵf} from './app/utils/json-utils.service';"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, Directive, EventEmitter, Component, ViewEncapsulation, ChangeDetectorRef, Input, Output, Renderer2, ViewChild, ElementRef, Pipe, NgModule, HostListener, HostBinding, SecurityContext, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
2
|
+
import { Injectable, Directive, EventEmitter, Component, ViewEncapsulation, ChangeDetectorRef, Input, Output, Renderer2, ViewChild, ElementRef, Pipe, NgModule, HostListener, HostBinding, SecurityContext, CUSTOM_ELEMENTS_SCHEMA, Inject, PLATFORM_ID, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
3
3
|
import { __awaiter } from 'tslib';
|
|
4
4
|
import { Subject, BehaviorSubject } from 'rxjs';
|
|
5
5
|
import { Options } from '@colijnit/ioneconnector/build/model/options';
|
|
@@ -16,22 +16,22 @@ import { ArticleListObjectExtended } from '@colijnit/articleapi/build/model/arti
|
|
|
16
16
|
import * as i1 from '@angular/common/http';
|
|
17
17
|
import { HttpClient } from '@angular/common/http';
|
|
18
18
|
import { StringUtils } from '@colijnit/ioneconnector/build/utils/string-utils';
|
|
19
|
-
import { CommonModule } from '@angular/common';
|
|
19
|
+
import { CommonModule, isPlatformBrowser } from '@angular/common';
|
|
20
20
|
import { trigger, state, style, transition, animate } from '@angular/animations';
|
|
21
21
|
import * as i1$1 from '@angular/platform-browser';
|
|
22
22
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
23
23
|
import { IconModule, LoaderModule, ScrollContainerModule, PriceDisplayPipeModule, NumberPickerModule, ButtonModule, FilesUploadModule, TileModule } from '@colijnit/corecomponents';
|
|
24
24
|
import { CoDocument } from '@colijnit/mainapi/build/model/co-document';
|
|
25
25
|
import { ConfiguratorStatisticsEnvironment } from '@colijnit/articleapi/build/model/configurator-statistics-environment';
|
|
26
|
-
import { LoaderModule as LoaderModule$1, ArticleTileModule } from '@colijnit/corecomponents_v12';
|
|
26
|
+
import { LoaderModule as LoaderModule$1, ArticleTileModule, ButtonModule as ButtonModule$1 } from '@colijnit/corecomponents_v12';
|
|
27
27
|
|
|
28
28
|
// this file is dynamically created, do not change this
|
|
29
29
|
class Version {
|
|
30
30
|
constructor() {
|
|
31
31
|
this.name = "@colijnit/product";
|
|
32
32
|
this.description = "Product detail page project for iOne";
|
|
33
|
-
this.symVer = "256.1.
|
|
34
|
-
this.publishDate = "
|
|
33
|
+
this.symVer = "256.1.4";
|
|
34
|
+
this.publishDate = "22-1-2025 20:45:30";
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
|
|
@@ -662,6 +662,7 @@ class IoneProductComponent {
|
|
|
662
662
|
this.onAddToQuote = new EventEmitter();
|
|
663
663
|
this.openStockEvent = new EventEmitter();
|
|
664
664
|
this.settingsLoaded = false;
|
|
665
|
+
this.showHD = false;
|
|
665
666
|
this._subs = [];
|
|
666
667
|
this._subs.push(
|
|
667
668
|
// this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),
|
|
@@ -721,7 +722,8 @@ IoneProductComponent.decorators = [
|
|
|
721
722
|
[sku]="sku"
|
|
722
723
|
[showRelatedProductsPopup]="showRelatedProductsPopup"
|
|
723
724
|
></app-product-page>
|
|
724
|
-
|
|
725
|
+
<!-- <co-button [label]="'click'" (click)="showHD = !showHD"></co-button>
|
|
726
|
+
<co-product-hd [sku]="'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'" *ngIf="showHD"></co-product-hd>-->
|
|
725
727
|
`,
|
|
726
728
|
encapsulation: ViewEncapsulation.Emulated,
|
|
727
729
|
styles: [""]
|
|
@@ -2613,30 +2615,183 @@ ProductPageModule.decorators = [
|
|
|
2613
2615
|
},] }
|
|
2614
2616
|
];
|
|
2615
2617
|
|
|
2616
|
-
class
|
|
2618
|
+
class ProductScriptLoaderService {
|
|
2619
|
+
constructor(platformId) {
|
|
2620
|
+
this.platformId = platformId;
|
|
2621
|
+
this._scriptsOrLinksElements = [];
|
|
2622
|
+
}
|
|
2623
|
+
loadScript(url, renderer) {
|
|
2624
|
+
return new Promise((resolve, reject) => {
|
|
2625
|
+
if (!isPlatformBrowser(this.platformId)) {
|
|
2626
|
+
reject('Not in browser environment');
|
|
2627
|
+
return;
|
|
2628
|
+
}
|
|
2629
|
+
const existingScript = document.getElementById(url);
|
|
2630
|
+
if (existingScript) {
|
|
2631
|
+
resolve(); // Script already loaded
|
|
2632
|
+
return;
|
|
2633
|
+
}
|
|
2634
|
+
const script = renderer.createElement('script');
|
|
2635
|
+
script.id = url;
|
|
2636
|
+
script.src = url;
|
|
2637
|
+
script.type = 'text/javascript';
|
|
2638
|
+
script.async = true;
|
|
2639
|
+
script.onload = () => resolve();
|
|
2640
|
+
script.onerror = (error) => reject(`Error loading script: ${url}`);
|
|
2641
|
+
renderer.appendChild(document.head, script);
|
|
2642
|
+
this._scriptsOrLinksElements.push(script);
|
|
2643
|
+
});
|
|
2644
|
+
}
|
|
2645
|
+
unloadScripts(renderer) {
|
|
2646
|
+
for (let i = this._scriptsOrLinksElements.length - 1; i >= 0; i--) {
|
|
2647
|
+
renderer.removeChild(document.head, this._scriptsOrLinksElements[i]);
|
|
2648
|
+
this._scriptsOrLinksElements.pop();
|
|
2649
|
+
}
|
|
2650
|
+
}
|
|
2651
|
+
addStyleSheet(url, renderer) {
|
|
2652
|
+
return new Promise((resolve, reject) => {
|
|
2653
|
+
if (!isPlatformBrowser(this.platformId)) {
|
|
2654
|
+
reject('Not in browser environment');
|
|
2655
|
+
return;
|
|
2656
|
+
}
|
|
2657
|
+
const existingStyleSheet = document.getElementById(url);
|
|
2658
|
+
if (existingStyleSheet) {
|
|
2659
|
+
resolve(); // Script already loaded
|
|
2660
|
+
return;
|
|
2661
|
+
}
|
|
2662
|
+
const link = renderer.createElement('link');
|
|
2663
|
+
link.id = url;
|
|
2664
|
+
link.href = url;
|
|
2665
|
+
link.rel = 'stylesheet';
|
|
2666
|
+
link.onload = () => resolve();
|
|
2667
|
+
link.onerror = (error) => reject(`Error loading styleSheet: ${url}`);
|
|
2668
|
+
renderer.appendChild(document.head, link);
|
|
2669
|
+
this._scriptsOrLinksElements.push(link);
|
|
2670
|
+
});
|
|
2671
|
+
}
|
|
2617
2672
|
}
|
|
2618
|
-
|
|
2673
|
+
ProductScriptLoaderService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProductScriptLoaderService_Factory() { return new ProductScriptLoaderService(i0.ɵɵinject(i0.PLATFORM_ID)); }, token: ProductScriptLoaderService, providedIn: "root" });
|
|
2674
|
+
ProductScriptLoaderService.decorators = [
|
|
2675
|
+
{ type: Injectable, args: [{
|
|
2676
|
+
providedIn: 'root'
|
|
2677
|
+
},] }
|
|
2678
|
+
];
|
|
2679
|
+
ProductScriptLoaderService.ctorParameters = () => [
|
|
2680
|
+
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
|
|
2681
|
+
];
|
|
2682
|
+
|
|
2683
|
+
class ProductHdComponent {
|
|
2684
|
+
constructor(_scriptLoader, _renderer) {
|
|
2685
|
+
this._scriptLoader = _scriptLoader;
|
|
2686
|
+
this._renderer = _renderer;
|
|
2687
|
+
this.variant = '';
|
|
2688
|
+
this.configuratorFinished = new EventEmitter();
|
|
2689
|
+
this.configurationError = new EventEmitter();
|
|
2690
|
+
this.showClass = true;
|
|
2691
|
+
}
|
|
2692
|
+
set content(child) {
|
|
2693
|
+
this.hdeConfigurator = child;
|
|
2694
|
+
this._prepareAttributes();
|
|
2695
|
+
}
|
|
2696
|
+
set sku(value) {
|
|
2697
|
+
this._sku = value;
|
|
2698
|
+
this._prepareAttributes();
|
|
2699
|
+
}
|
|
2700
|
+
get sku() {
|
|
2701
|
+
return this._sku;
|
|
2702
|
+
}
|
|
2703
|
+
ngOnDestroy() {
|
|
2704
|
+
this._scriptLoader.unloadScripts(this._renderer);
|
|
2705
|
+
}
|
|
2706
|
+
handleConfigurationFinished(event) {
|
|
2707
|
+
if (event.detail.variant && typeof event.detail.variant === 'string') {
|
|
2708
|
+
this.configuratorFinished.emit(event.detail.variant);
|
|
2709
|
+
}
|
|
2710
|
+
else {
|
|
2711
|
+
this.configuratorFinished.emit(this.variant);
|
|
2712
|
+
}
|
|
2713
|
+
}
|
|
2714
|
+
handleError(event) {
|
|
2715
|
+
this.configurationError.emit(event.detail.status);
|
|
2716
|
+
}
|
|
2717
|
+
_prepareAttributes() {
|
|
2718
|
+
if (this.hdeConfigurator && this.hdeConfigurator.nativeElement && this.token && (this.sku || this.variant)) {
|
|
2719
|
+
this.hdeConfigurator.nativeElement.setAttribute('bearerToken', this.token);
|
|
2720
|
+
if (this._sku) {
|
|
2721
|
+
this.hdeConfigurator.nativeElement.setAttribute('data-productId', this._sku);
|
|
2722
|
+
}
|
|
2723
|
+
if (this.variant) {
|
|
2724
|
+
this.hdeConfigurator.nativeElement.setAttribute('data-productVariantId', this.variant);
|
|
2725
|
+
}
|
|
2726
|
+
this._loadTheScripts();
|
|
2727
|
+
}
|
|
2728
|
+
}
|
|
2729
|
+
// load external scripts
|
|
2730
|
+
_loadTheScripts() {
|
|
2731
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
2732
|
+
const scripts = [
|
|
2733
|
+
// hard-coded for now, should come from the external source
|
|
2734
|
+
'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/polyfills.js',
|
|
2735
|
+
'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/runtime.js',
|
|
2736
|
+
'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/main.js'
|
|
2737
|
+
];
|
|
2738
|
+
for (let i = 0; i < scripts.length; i++) {
|
|
2739
|
+
yield this._scriptLoader.loadScript(scripts[i], this._renderer).catch((error) => console.error(error));
|
|
2740
|
+
}
|
|
2741
|
+
yield this._scriptLoader.addStyleSheet('https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/styles.css', this._renderer);
|
|
2742
|
+
});
|
|
2743
|
+
}
|
|
2744
|
+
}
|
|
2745
|
+
ProductHdComponent.decorators = [
|
|
2746
|
+
{ type: Component, args: [{
|
|
2747
|
+
selector: 'co-product-hd',
|
|
2748
|
+
template: `
|
|
2749
|
+
<hde-configurator #hdeConfigurator
|
|
2750
|
+
apiurl="https://bmsproductconfigurator-acceptance.azurewebsites.net/api/configurator/"
|
|
2751
|
+
productVariantCommandApiUrl="https://bmsproductvariantcommand-acceptance.azurewebsites.net/"
|
|
2752
|
+
productVariantQueryApiUrl="https://bmsproductvariantquery-acceptance.azurewebsites.net/"
|
|
2753
|
+
language="nl"
|
|
2754
|
+
localizationApiUrl="https://hde-cdn.azureedge.net/libs/BMS.DST.Localization/"
|
|
2755
|
+
localizationFileExtension=".json"
|
|
2756
|
+
(configurationFinished)="handleConfigurationFinished($event)"
|
|
2757
|
+
(configurationFailed)="handleError($event)"
|
|
2758
|
+
>
|
|
2759
|
+
<hde-progress-bar></hde-progress-bar>
|
|
2760
|
+
</hde-configurator>
|
|
2761
|
+
`,
|
|
2762
|
+
encapsulation: ViewEncapsulation.None
|
|
2763
|
+
},] }
|
|
2764
|
+
];
|
|
2765
|
+
ProductHdComponent.ctorParameters = () => [
|
|
2766
|
+
{ type: ProductScriptLoaderService },
|
|
2767
|
+
{ type: Renderer2 }
|
|
2768
|
+
];
|
|
2769
|
+
ProductHdComponent.propDecorators = {
|
|
2770
|
+
content: [{ type: ViewChild, args: ['hdeConfigurator', { read: ElementRef },] }],
|
|
2771
|
+
sku: [{ type: Input }],
|
|
2772
|
+
token: [{ type: Input }],
|
|
2773
|
+
variant: [{ type: Input }],
|
|
2774
|
+
configuratorFinished: [{ type: Output }],
|
|
2775
|
+
configurationError: [{ type: Output }],
|
|
2776
|
+
showClass: [{ type: HostBinding, args: ['class.co-product-hd',] }]
|
|
2777
|
+
};
|
|
2778
|
+
|
|
2779
|
+
class ProductHdModule {
|
|
2780
|
+
}
|
|
2781
|
+
ProductHdModule.decorators = [
|
|
2619
2782
|
{ type: NgModule, args: [{
|
|
2620
2783
|
imports: [
|
|
2621
|
-
|
|
2622
|
-
CommonModule,
|
|
2623
|
-
ProductPageModule,
|
|
2624
|
-
LoaderModule$1
|
|
2784
|
+
CommonModule
|
|
2625
2785
|
],
|
|
2626
2786
|
declarations: [
|
|
2627
|
-
|
|
2628
|
-
],
|
|
2629
|
-
exports: [
|
|
2630
|
-
IoneProductComponent
|
|
2787
|
+
ProductHdComponent
|
|
2631
2788
|
],
|
|
2632
|
-
|
|
2633
|
-
|
|
2789
|
+
schemas: [
|
|
2790
|
+
CUSTOM_ELEMENTS_SCHEMA,
|
|
2791
|
+
NO_ERRORS_SCHEMA
|
|
2634
2792
|
],
|
|
2635
|
-
|
|
2636
|
-
|
|
2637
|
-
ProductConnectorService,
|
|
2638
|
-
ProductEventService,
|
|
2639
|
-
ProductConnectorAdapterService
|
|
2793
|
+
exports: [
|
|
2794
|
+
ProductHdComponent
|
|
2640
2795
|
]
|
|
2641
2796
|
},] }
|
|
2642
2797
|
];
|
|
@@ -2649,9 +2804,14 @@ class ProductExternalSourceComponent {
|
|
|
2649
2804
|
this.addToCart = new EventEmitter();
|
|
2650
2805
|
this.addToQuote = new EventEmitter();
|
|
2651
2806
|
this.alternativeClick = new EventEmitter();
|
|
2807
|
+
this.configuratorFinished = new EventEmitter();
|
|
2652
2808
|
this.showProduct = false;
|
|
2809
|
+
this.showConfigurator = false;
|
|
2810
|
+
this.showSource = false;
|
|
2653
2811
|
this.loaded = false;
|
|
2654
2812
|
this.externalSettings = {};
|
|
2813
|
+
this.token = ""; //= "eyJhbGciOiJSUzI1NiIsImtpZCI6IkYxOThERkVEOEUwQTQ1MzY3M0M1MUE2Rjk1QUVDQzU3RTM0NjM4RkRSUzI1NiIsInR5cCI6ImF0K2p3dCIsIng1dCI6IjhaamY3WTRLUlRaenhScHZsYTdNVi1OR09QMCJ9.eyJuYmYiOjE3MzIxOTkyOTUsImV4cCI6MTczMjIwMjg5NSwiaXNzIjoiaHR0cHM6Ly9ibXNpZGVudGl0eS1hY2NlcHRhbmNlLmF6dXJld2Vic2l0ZXMubmV0IiwiYXVkIjpbImNhdGFsb2dxdWVyeWFwaSIsImNvbmZpZ3VyYXRvcmFwaSIsInByb2R1Y3R2YXJpYW50Y29tbWFuZGFwaSIsInByb2R1Y3R2YXJpYW50cXVlcnlhcGkiXSwiY2xpZW50X2lkIjoiaW1wZXJzb25hdGlvbi5jbGllbnQiLCJzdWIiOiIwOTMwZDI4Mi05NGU4LTQ5MGEtOGI2NC1mYTk1YmIyYzE1ODIiLCJhdXRoX3RpbWUiOjE3MzIxOTkyOTUsImlkcCI6ImxvY2FsIiwiZW52aXJvbm1lbnQiOiJNU0wiLCJzZWxsZXIiOiJTRTAwMDA5NiIsInNlbGxlcmd1aWQiOiIxMDk1MWJjNS1hZmMzLTQ1MGEtNmVkMS0wOGQ4NDNlNmE5OTQiLCJwZXJtaXNzaW9uIjpbInNhbGVzLmV4cG9ydHRlbXBsYXRlcy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LnRhZy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LmRvY3VtZW50LnJlYWQiLCJkb2N1bWVudGxpYnJhcnkudGFnZ3JvdXAucmVhZCIsInNhbGVzLm9yZGVyLndyaXRlIiwic2FsZXMuY3VzdG9tZXIucmVhZCIsInNhbGVzLm9yZGVyLmRlbGl2ZXJ5YWRkcmVzcy53cml0ZSIsInNlcnZpY2UucmVxdWVzdC5yZWFkIiwiY2F0YWxvZy50YWcucmVhZCIsInNhbGVzLm9yZGVyLnJlYWQiLCJzYWxlcy5jdXN0b21lci53cml0ZSIsInJlcXVlc3Rmb3JxdW90ZS53cml0ZSIsInNhbGVzLm9yZGVyLmJvb2siLCJyZXF1ZXN0Zm9ycXVvdGUucmVhZCIsInNhbGVzLmxlYWQucmVhZCIsInB1cmNoYXNlLm9yZGVyLnJlYWQiLCJzYWxlcy5xdW90ZS5yZWFkIiwic2FsZXMucXVvdGUud3JpdGUiLCJjYXRhbG9nLml0ZW0ucmVhZCIsInNhbGVzLmxlYWQud3JpdGUiLCJzZXJ2aWNlLnJlcXVlc3Quc3VibWl0Iiwic2FsZXMub3JkZXIuZGVsaXZlcnlhZGRyZXNzLnJlYWQiLCJwdXJjaGFzZS5vcmRlci53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy5yZWFkIiwic2VydmljZS5yZXF1ZXN0LndyaXRlIiwiY2F0YWxvZy5jYXRhbG9nLnJlYWQiLCJjYXRhbG9nLmNhdGFsb2cud3JpdGUiLCJjYXRhbG9nLmN1cnJlbmN5LnJlYWQiLCJjYXRhbG9nLmN1cnJlbmN5LndyaXRlIiwiY2F0YWxvZy5pdGVtLndyaXRlIiwiY2F0YWxvZy5sb2NhbGl6YXRpb24ucmVhZCIsImNhdGFsb2cubG9jYWxpemF0aW9uLndyaXRlIiwiY2F0YWxvZy5wcm9kdWN0LnJlYWQiLCJjYXRhbG9nLnByb2R1Y3Qud3JpdGUiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLnJlYWQiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLndyaXRlIiwiY2F0YWxvZy5zZWxsZXIucmVhZCIsImNhdGFsb2cuc2VsbGVyLndyaXRlIiwiY2F0YWxvZy50YWcud3JpdGUiLCJjYXRhbG9nLnVvbS5yZWFkIiwiY2F0YWxvZy51b20ud3JpdGUiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LnJlYWQiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LndyaXRlIiwiY2F0YWxvZy52ZW5kb3IucmVhZCIsImNhdGFsb2cudmVuZG9yLndyaXRlIiwicHVyY2hhc2Uuc2VsbGVyLnJlYWQiLCJwdXJjaGFzZS5zZWxsZXIud3JpdGUiLCJjYXRhbG9nLmFydGljbGUucmVhZCIsImNhdGFsb2cuYXJ0aWNsZS53cml0ZSIsInNhbGVzLnF1b3RlLmxpbmVzLnJlYWQiLCJzYWxlcy5xdW90ZS5saW5lcy53cml0ZSIsInNhbGVzLnNlbGxlci5yZWFkIiwic2FsZXMuc2VsbGVyLndyaXRlIiwiYWNjb3VudGluZy52ZW5kb3JpbnZvaWNlLnJlYWQiLCJpZGVudGl0eS51c2VyLnJlYWQiLCJpZGVudGl0eS51c2VyLndyaXRlIiwiaWRlbnRpdHkucm9sZS5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy53cml0ZSIsImNvbmZpZ3VyYXRvci5wdXJjaGFzZXByaWNlLnJlYWQiLCJzdG9jay5mYWJyaWMucmVhZCJdLCJuYW1lIjoiUm9iaW4iLCJmYW1pbHlfbmFtZSI6ImRlIFdpbnRlciAoQ29saWpuLUlUKSIsInJvbGUiOlsic2VsbGVyIiwiZGVhbGVyX21hbmFnZXIiXSwiaWF0IjoxNzMyMTk5Mjk1LCJzY29wZSI6WyJjYXRhbG9ncXVlcnlhcGkiLCJjb25maWd1cmF0b3JhcGkiLCJwcm9kdWN0dmFyaWFudGNvbW1hbmRhcGkiLCJwcm9kdWN0dmFyaWFudHF1ZXJ5YXBpIl0sImFtciI6WyJpbXBlcnNvbmF0aW9uIl19.rbguVPnkXXDzsM6QKgXulhrF41jIjCuGDV13ig1GC8MewLCJ7wA038OSwT26sx2mCexjvuGYt45YScfPwfTkDy3ErPmHRods64X1dJWZnf-23NTP2iI32K_1vMZH5GOGbMzuFtbKAFQv4hgFAxoyWqFVWyJvuOtQcWyZStROyPHwjAnpnj-x1cVQpOhbO-kQUFvy_VUrPpF3aYVCcO2cFirQTXR6kxSGcYGGcsPY-_eiAd93UdG2EM6xLAocDLaFV72CQI6XEs0WQG1f4SqvH52v3OTkgWBLgYV35gpyIe0-2nazGL0R8pTNuDqrOb7OGmuTRMoTIiRi67-wTxx8cQ";
|
|
2814
|
+
this.variant = "";
|
|
2655
2815
|
this._subs = [];
|
|
2656
2816
|
}
|
|
2657
2817
|
set externalSource(value) {
|
|
@@ -2662,6 +2822,15 @@ class ProductExternalSourceComponent {
|
|
|
2662
2822
|
get externalSource() {
|
|
2663
2823
|
return this._externalSource;
|
|
2664
2824
|
}
|
|
2825
|
+
set externalCatalogStartupInfo(value) {
|
|
2826
|
+
this._externalCatalogStartupInfo = value;
|
|
2827
|
+
this.externalSource = value.externalSource;
|
|
2828
|
+
this.loaded = false;
|
|
2829
|
+
this._prepareExternalSource();
|
|
2830
|
+
}
|
|
2831
|
+
get externalCatalogStartupInfo() {
|
|
2832
|
+
return this._externalCatalogStartupInfo;
|
|
2833
|
+
}
|
|
2665
2834
|
showClass() {
|
|
2666
2835
|
return true;
|
|
2667
2836
|
}
|
|
@@ -2685,6 +2854,9 @@ class ProductExternalSourceComponent {
|
|
|
2685
2854
|
ngOnDestroy() {
|
|
2686
2855
|
this._subs.forEach(s => s.unsubscribe());
|
|
2687
2856
|
}
|
|
2857
|
+
handleConfigurationFinished(variantString) {
|
|
2858
|
+
this.configuratorFinished.emit(variantString);
|
|
2859
|
+
}
|
|
2688
2860
|
_prepareExternalSource() {
|
|
2689
2861
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2690
2862
|
if (!this._externalSource) {
|
|
@@ -2693,30 +2865,66 @@ class ProductExternalSourceComponent {
|
|
|
2693
2865
|
this.externalUrl = undefined;
|
|
2694
2866
|
this.externalSettings = {};
|
|
2695
2867
|
if (this.externalSource.type === 'CATF') {
|
|
2696
|
-
|
|
2697
|
-
|
|
2698
|
-
|
|
2699
|
-
|
|
2700
|
-
this.externalSettings.options = this.options;
|
|
2701
|
-
}
|
|
2702
|
-
// this.externalSettings.assetPath = "https://cdn1.colijn-it.nl/content43";
|
|
2703
|
-
// this.externalSettings.threeDAssetPath = "https://cdn1.colijn-it.nl/content43";
|
|
2704
|
-
if (this.externalSource.username && this.externalSource.password) {
|
|
2705
|
-
this.externalSettings.useLoginEncryption = true;
|
|
2706
|
-
this.externalSettings.username = this.externalSource.username;
|
|
2707
|
-
this.externalSettings.password = this.externalSource.password;
|
|
2708
|
-
}
|
|
2709
|
-
// finally show the catalog
|
|
2710
|
-
this.showProduct = true;
|
|
2868
|
+
yield this._prepareCatFarm();
|
|
2869
|
+
}
|
|
2870
|
+
else if (this.externalSource.type === 'HTDL') {
|
|
2871
|
+
this._prepareConfigurator();
|
|
2711
2872
|
}
|
|
2712
2873
|
else {
|
|
2713
|
-
this.
|
|
2714
|
-
this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);
|
|
2715
|
-
this.showProduct = false;
|
|
2874
|
+
this._prepareSource();
|
|
2716
2875
|
}
|
|
2876
|
+
});
|
|
2877
|
+
}
|
|
2878
|
+
_prepareCatFarm() {
|
|
2879
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
2880
|
+
// get bundle settings from external source
|
|
2881
|
+
const bundleSettings = yield this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));
|
|
2882
|
+
this.externalSettings = JSON.parse(bundleSettings);
|
|
2883
|
+
if (this.options) {
|
|
2884
|
+
this.externalSettings.options = this.options;
|
|
2885
|
+
}
|
|
2886
|
+
// this.externalSettings.assetPath = "https://cdn1.colijn-it.nl/content43";
|
|
2887
|
+
// this.externalSettings.threeDAssetPath = "https://cdn1.colijn-it.nl/content43";
|
|
2888
|
+
if (this.externalSource.username && this.externalSource.password) {
|
|
2889
|
+
this.externalSettings.useLoginEncryption = true;
|
|
2890
|
+
this.externalSettings.username = this.externalSource.username;
|
|
2891
|
+
this.externalSettings.password = this.externalSource.password;
|
|
2892
|
+
}
|
|
2893
|
+
// finally show the catalog
|
|
2894
|
+
this.switchToProduct();
|
|
2717
2895
|
this.loaded = true;
|
|
2718
2896
|
});
|
|
2719
2897
|
}
|
|
2898
|
+
_prepareConfigurator() {
|
|
2899
|
+
if (this.externalCatalogStartupInfo) {
|
|
2900
|
+
this.token = this.externalCatalogStartupInfo.token;
|
|
2901
|
+
this.sku = this.externalCatalogStartupInfo.externalGoodId;
|
|
2902
|
+
this.variant = this.externalCatalogStartupInfo.flattenedGoodId;
|
|
2903
|
+
this.switchToConfigurator();
|
|
2904
|
+
this.loaded = true;
|
|
2905
|
+
}
|
|
2906
|
+
}
|
|
2907
|
+
_prepareSource() {
|
|
2908
|
+
this.externalUrl = this.externalSource.url;
|
|
2909
|
+
this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);
|
|
2910
|
+
this.switchToSource();
|
|
2911
|
+
this.loaded = true;
|
|
2912
|
+
}
|
|
2913
|
+
switchToProduct() {
|
|
2914
|
+
this.showProduct = true;
|
|
2915
|
+
this.showConfigurator = false;
|
|
2916
|
+
this.showSource = false;
|
|
2917
|
+
}
|
|
2918
|
+
switchToConfigurator() {
|
|
2919
|
+
this.showProduct = false;
|
|
2920
|
+
this.showConfigurator = true;
|
|
2921
|
+
this.showSource = false;
|
|
2922
|
+
}
|
|
2923
|
+
switchToSource() {
|
|
2924
|
+
this.showProduct = false;
|
|
2925
|
+
this.showConfigurator = false;
|
|
2926
|
+
this.showSource = true;
|
|
2927
|
+
}
|
|
2720
2928
|
}
|
|
2721
2929
|
ProductExternalSourceComponent.decorators = [
|
|
2722
2930
|
{ type: Component, args: [{
|
|
@@ -2730,9 +2938,16 @@ ProductExternalSourceComponent.decorators = [
|
|
|
2730
2938
|
[externalSource]="externalSource"
|
|
2731
2939
|
></app-product-page>
|
|
2732
2940
|
</ng-container>
|
|
2733
|
-
<ng-container *ngIf="
|
|
2941
|
+
<ng-container *ngIf="showSource">
|
|
2734
2942
|
<iframe width="100%" height="100%" [src]="safeUrl" frameborder="0" allowfullscreen></iframe>
|
|
2735
2943
|
</ng-container>
|
|
2944
|
+
<ng-container *ngIf="showConfigurator">
|
|
2945
|
+
<co-product-hd width="100%" height="100%"
|
|
2946
|
+
[sku]="sku"
|
|
2947
|
+
[variant]="variant"
|
|
2948
|
+
[token]="token"
|
|
2949
|
+
(configuratorFinished)="handleConfigurationFinished($event)"></co-product-hd>
|
|
2950
|
+
</ng-container>
|
|
2736
2951
|
</ng-container>
|
|
2737
2952
|
`,
|
|
2738
2953
|
providers: [
|
|
@@ -2752,10 +2967,12 @@ ProductExternalSourceComponent.propDecorators = {
|
|
|
2752
2967
|
sku: [{ type: Input }],
|
|
2753
2968
|
catalogDefinition: [{ type: Input }],
|
|
2754
2969
|
externalSource: [{ type: Input }],
|
|
2970
|
+
externalCatalogStartupInfo: [{ type: Input }],
|
|
2755
2971
|
options: [{ type: Input }],
|
|
2756
2972
|
addToCart: [{ type: Output }],
|
|
2757
2973
|
addToQuote: [{ type: Output }],
|
|
2758
2974
|
alternativeClick: [{ type: Output }],
|
|
2975
|
+
configuratorFinished: [{ type: Output }],
|
|
2759
2976
|
showClass: [{ type: HostBinding, args: ['class.co-product-external-source',] }]
|
|
2760
2977
|
};
|
|
2761
2978
|
|
|
@@ -2765,7 +2982,8 @@ ProductExternalSourceModule.decorators = [
|
|
|
2765
2982
|
{ type: NgModule, args: [{
|
|
2766
2983
|
imports: [
|
|
2767
2984
|
CommonModule,
|
|
2768
|
-
ProductPageModule
|
|
2985
|
+
ProductPageModule,
|
|
2986
|
+
ProductHdModule
|
|
2769
2987
|
],
|
|
2770
2988
|
declarations: [
|
|
2771
2989
|
ProductExternalSourceComponent
|
|
@@ -2776,9 +2994,43 @@ ProductExternalSourceModule.decorators = [
|
|
|
2776
2994
|
},] }
|
|
2777
2995
|
];
|
|
2778
2996
|
|
|
2997
|
+
class IoneProductModule {
|
|
2998
|
+
}
|
|
2999
|
+
IoneProductModule.decorators = [
|
|
3000
|
+
{ type: NgModule, args: [{
|
|
3001
|
+
imports: [
|
|
3002
|
+
//BrowserAnimationsModule,
|
|
3003
|
+
CommonModule,
|
|
3004
|
+
ProductPageModule,
|
|
3005
|
+
ProductHdModule,
|
|
3006
|
+
ProductExternalSourceModule,
|
|
3007
|
+
ButtonModule$1
|
|
3008
|
+
],
|
|
3009
|
+
declarations: [
|
|
3010
|
+
IoneProductComponent
|
|
3011
|
+
],
|
|
3012
|
+
exports: [
|
|
3013
|
+
IoneProductComponent
|
|
3014
|
+
],
|
|
3015
|
+
schemas: [
|
|
3016
|
+
CUSTOM_ELEMENTS_SCHEMA,
|
|
3017
|
+
NO_ERRORS_SCHEMA
|
|
3018
|
+
],
|
|
3019
|
+
bootstrap: [
|
|
3020
|
+
IoneProductComponent
|
|
3021
|
+
],
|
|
3022
|
+
providers: [
|
|
3023
|
+
ProductSettingsService,
|
|
3024
|
+
ProductConnectorService,
|
|
3025
|
+
ProductEventService,
|
|
3026
|
+
ProductConnectorAdapterService
|
|
3027
|
+
]
|
|
3028
|
+
},] }
|
|
3029
|
+
];
|
|
3030
|
+
|
|
2779
3031
|
/**
|
|
2780
3032
|
* Generated bundle index. Do not edit.
|
|
2781
3033
|
*/
|
|
2782
3034
|
|
|
2783
|
-
export { IoneProductComponent, IoneProductModule, ProductConnectorAdapterService, ProductConnectorService, ProductEventService, ProductExternalSourceComponent, ProductExternalSourceModule, ProductSettingsService, Version, ProductPageModule as ɵa, ProductSelectorTypeModule as ɵb, ProductInfoTabsModule as ɵba, ProductAdditionalInfoModule as ɵbb, ProductAdditionalInfoComponent as ɵbc, ProductPropertiesModule as ɵbd, ProductPropertiesComponent as ɵbe, ProductDocumentModule as ɵbf, ProductDocumentsComponent as ɵbg, ProductSymbolsModule as ɵbh, ProductSymbolsComponent as ɵbi, ProductInfoTabsComponent as ɵbj, ProductDialogModule as ɵbk, ProductDialogComponent as ɵbl, ProductPageComponent as ɵbm, PipeModule as ɵc, LocalizePipe as ɵd, DictionaryService as ɵe, JsonUtilsService as ɵf, ProductSelectorTypeComponent as ɵg, IconCacheService as ɵh, ImageCarouselModule as ɵi, ImageCarouselComponent as ɵj, ProductDescriptionModule as ɵk, ProductDescriptionComponent as ɵl, ProductAdditionalDescriptionModule as ɵm, ProductAdditionalDescriptionComponent as ɵn, ProductPriceModule as ɵo, ProductPriceComponent as ɵp, ProductAddtocartModule as ɵq, ProductAddtocartComponent as ɵr, ProductRelatedModule as ɵs, HeaderModule as ɵt, HeaderComponent as ɵu, ProductRelatedComponent as ɵv, ProductStockModule as ɵw, ProductStockComponent as ɵx, ProductDeliveryModule as ɵy, ProductDeliveryComponent as ɵz };
|
|
3035
|
+
export { IoneProductComponent, IoneProductModule, ProductConnectorAdapterService, ProductConnectorService, ProductEventService, ProductExternalSourceComponent, ProductExternalSourceModule, ProductSettingsService, Version, ProductPageModule as ɵa, ProductSelectorTypeModule as ɵb, ProductInfoTabsModule as ɵba, ProductAdditionalInfoModule as ɵbb, ProductAdditionalInfoComponent as ɵbc, ProductPropertiesModule as ɵbd, ProductPropertiesComponent as ɵbe, ProductDocumentModule as ɵbf, ProductDocumentsComponent as ɵbg, ProductSymbolsModule as ɵbh, ProductSymbolsComponent as ɵbi, ProductInfoTabsComponent as ɵbj, ProductDialogModule as ɵbk, ProductDialogComponent as ɵbl, ProductPageComponent as ɵbm, ProductHdModule as ɵbn, ProductHdComponent as ɵbo, ProductScriptLoaderService as ɵbp, PipeModule as ɵc, LocalizePipe as ɵd, DictionaryService as ɵe, JsonUtilsService as ɵf, ProductSelectorTypeComponent as ɵg, IconCacheService as ɵh, ImageCarouselModule as ɵi, ImageCarouselComponent as ɵj, ProductDescriptionModule as ɵk, ProductDescriptionComponent as ɵl, ProductAdditionalDescriptionModule as ɵm, ProductAdditionalDescriptionComponent as ɵn, ProductPriceModule as ɵo, ProductPriceComponent as ɵp, ProductAddtocartModule as ɵq, ProductAddtocartComponent as ɵr, ProductRelatedModule as ɵs, HeaderModule as ɵt, HeaderComponent as ɵu, ProductRelatedComponent as ɵv, ProductStockModule as ɵw, ProductStockComponent as ɵx, ProductDeliveryModule as ɵy, ProductDeliveryComponent as ɵz };
|
|
2784
3036
|
//# sourceMappingURL=colijnit-product.js.map
|