@colijnit/product 256.1.3 → 256.1.5
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 +18 -0
- package/app/components/product-hd/product-hd.component.d.ts +25 -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 +341 -34
- package/bundles/colijnit-product.umd.js.map +1 -1
- 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 +87 -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 +124 -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 +326 -44
- package/fesm2015/colijnit-product.js.map +1 -1
- package/package.json +3 -3
- package/colijnit-product-256.1.2.tgz +0 -0
|
@@ -13,9 +13,15 @@ export class ProductExternalSourceComponent {
|
|
|
13
13
|
this.addToCart = new EventEmitter();
|
|
14
14
|
this.addToQuote = new EventEmitter();
|
|
15
15
|
this.alternativeClick = new EventEmitter();
|
|
16
|
+
this.configuratorFinished = new EventEmitter();
|
|
16
17
|
this.showProduct = false;
|
|
18
|
+
this.showConfigurator = false;
|
|
19
|
+
this.showSource = false;
|
|
17
20
|
this.loaded = false;
|
|
18
21
|
this.externalSettings = {};
|
|
22
|
+
this.token = ""; //= "eyJhbGciOiJSUzI1NiIsImtpZCI6IkYxOThERkVEOEUwQTQ1MzY3M0M1MUE2Rjk1QUVDQzU3RTM0NjM4RkRSUzI1NiIsInR5cCI6ImF0K2p3dCIsIng1dCI6IjhaamY3WTRLUlRaenhScHZsYTdNVi1OR09QMCJ9.eyJuYmYiOjE3MzIxOTkyOTUsImV4cCI6MTczMjIwMjg5NSwiaXNzIjoiaHR0cHM6Ly9ibXNpZGVudGl0eS1hY2NlcHRhbmNlLmF6dXJld2Vic2l0ZXMubmV0IiwiYXVkIjpbImNhdGFsb2dxdWVyeWFwaSIsImNvbmZpZ3VyYXRvcmFwaSIsInByb2R1Y3R2YXJpYW50Y29tbWFuZGFwaSIsInByb2R1Y3R2YXJpYW50cXVlcnlhcGkiXSwiY2xpZW50X2lkIjoiaW1wZXJzb25hdGlvbi5jbGllbnQiLCJzdWIiOiIwOTMwZDI4Mi05NGU4LTQ5MGEtOGI2NC1mYTk1YmIyYzE1ODIiLCJhdXRoX3RpbWUiOjE3MzIxOTkyOTUsImlkcCI6ImxvY2FsIiwiZW52aXJvbm1lbnQiOiJNU0wiLCJzZWxsZXIiOiJTRTAwMDA5NiIsInNlbGxlcmd1aWQiOiIxMDk1MWJjNS1hZmMzLTQ1MGEtNmVkMS0wOGQ4NDNlNmE5OTQiLCJwZXJtaXNzaW9uIjpbInNhbGVzLmV4cG9ydHRlbXBsYXRlcy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LnRhZy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LmRvY3VtZW50LnJlYWQiLCJkb2N1bWVudGxpYnJhcnkudGFnZ3JvdXAucmVhZCIsInNhbGVzLm9yZGVyLndyaXRlIiwic2FsZXMuY3VzdG9tZXIucmVhZCIsInNhbGVzLm9yZGVyLmRlbGl2ZXJ5YWRkcmVzcy53cml0ZSIsInNlcnZpY2UucmVxdWVzdC5yZWFkIiwiY2F0YWxvZy50YWcucmVhZCIsInNhbGVzLm9yZGVyLnJlYWQiLCJzYWxlcy5jdXN0b21lci53cml0ZSIsInJlcXVlc3Rmb3JxdW90ZS53cml0ZSIsInNhbGVzLm9yZGVyLmJvb2siLCJyZXF1ZXN0Zm9ycXVvdGUucmVhZCIsInNhbGVzLmxlYWQucmVhZCIsInB1cmNoYXNlLm9yZGVyLnJlYWQiLCJzYWxlcy5xdW90ZS5yZWFkIiwic2FsZXMucXVvdGUud3JpdGUiLCJjYXRhbG9nLml0ZW0ucmVhZCIsInNhbGVzLmxlYWQud3JpdGUiLCJzZXJ2aWNlLnJlcXVlc3Quc3VibWl0Iiwic2FsZXMub3JkZXIuZGVsaXZlcnlhZGRyZXNzLnJlYWQiLCJwdXJjaGFzZS5vcmRlci53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy5yZWFkIiwic2VydmljZS5yZXF1ZXN0LndyaXRlIiwiY2F0YWxvZy5jYXRhbG9nLnJlYWQiLCJjYXRhbG9nLmNhdGFsb2cud3JpdGUiLCJjYXRhbG9nLmN1cnJlbmN5LnJlYWQiLCJjYXRhbG9nLmN1cnJlbmN5LndyaXRlIiwiY2F0YWxvZy5pdGVtLndyaXRlIiwiY2F0YWxvZy5sb2NhbGl6YXRpb24ucmVhZCIsImNhdGFsb2cubG9jYWxpemF0aW9uLndyaXRlIiwiY2F0YWxvZy5wcm9kdWN0LnJlYWQiLCJjYXRhbG9nLnByb2R1Y3Qud3JpdGUiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLnJlYWQiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLndyaXRlIiwiY2F0YWxvZy5zZWxsZXIucmVhZCIsImNhdGFsb2cuc2VsbGVyLndyaXRlIiwiY2F0YWxvZy50YWcud3JpdGUiLCJjYXRhbG9nLnVvbS5yZWFkIiwiY2F0YWxvZy51b20ud3JpdGUiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LnJlYWQiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LndyaXRlIiwiY2F0YWxvZy52ZW5kb3IucmVhZCIsImNhdGFsb2cudmVuZG9yLndyaXRlIiwicHVyY2hhc2Uuc2VsbGVyLnJlYWQiLCJwdXJjaGFzZS5zZWxsZXIud3JpdGUiLCJjYXRhbG9nLmFydGljbGUucmVhZCIsImNhdGFsb2cuYXJ0aWNsZS53cml0ZSIsInNhbGVzLnF1b3RlLmxpbmVzLnJlYWQiLCJzYWxlcy5xdW90ZS5saW5lcy53cml0ZSIsInNhbGVzLnNlbGxlci5yZWFkIiwic2FsZXMuc2VsbGVyLndyaXRlIiwiYWNjb3VudGluZy52ZW5kb3JpbnZvaWNlLnJlYWQiLCJpZGVudGl0eS51c2VyLnJlYWQiLCJpZGVudGl0eS51c2VyLndyaXRlIiwiaWRlbnRpdHkucm9sZS5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy53cml0ZSIsImNvbmZpZ3VyYXRvci5wdXJjaGFzZXByaWNlLnJlYWQiLCJzdG9jay5mYWJyaWMucmVhZCJdLCJuYW1lIjoiUm9iaW4iLCJmYW1pbHlfbmFtZSI6ImRlIFdpbnRlciAoQ29saWpuLUlUKSIsInJvbGUiOlsic2VsbGVyIiwiZGVhbGVyX21hbmFnZXIiXSwiaWF0IjoxNzMyMTk5Mjk1LCJzY29wZSI6WyJjYXRhbG9ncXVlcnlhcGkiLCJjb25maWd1cmF0b3JhcGkiLCJwcm9kdWN0dmFyaWFudGNvbW1hbmRhcGkiLCJwcm9kdWN0dmFyaWFudHF1ZXJ5YXBpIl0sImFtciI6WyJpbXBlcnNvbmF0aW9uIl19.rbguVPnkXXDzsM6QKgXulhrF41jIjCuGDV13ig1GC8MewLCJ7wA038OSwT26sx2mCexjvuGYt45YScfPwfTkDy3ErPmHRods64X1dJWZnf-23NTP2iI32K_1vMZH5GOGbMzuFtbKAFQv4hgFAxoyWqFVWyJvuOtQcWyZStROyPHwjAnpnj-x1cVQpOhbO-kQUFvy_VUrPpF3aYVCcO2cFirQTXR6kxSGcYGGcsPY-_eiAd93UdG2EM6xLAocDLaFV72CQI6XEs0WQG1f4SqvH52v3OTkgWBLgYV35gpyIe0-2nazGL0R8pTNuDqrOb7OGmuTRMoTIiRi67-wTxx8cQ";
|
|
23
|
+
this.variant = "";
|
|
24
|
+
this.urlParams = [];
|
|
19
25
|
this._subs = [];
|
|
20
26
|
}
|
|
21
27
|
set externalSource(value) {
|
|
@@ -26,6 +32,17 @@ export class ProductExternalSourceComponent {
|
|
|
26
32
|
get externalSource() {
|
|
27
33
|
return this._externalSource;
|
|
28
34
|
}
|
|
35
|
+
set externalCatalogStartupInfo(value) {
|
|
36
|
+
if (value) {
|
|
37
|
+
this._externalCatalogStartupInfo = value;
|
|
38
|
+
this.externalSource = value.externalSource;
|
|
39
|
+
this.loaded = false;
|
|
40
|
+
this._prepareExternalSource();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
get externalCatalogStartupInfo() {
|
|
44
|
+
return this._externalCatalogStartupInfo;
|
|
45
|
+
}
|
|
29
46
|
showClass() {
|
|
30
47
|
return true;
|
|
31
48
|
}
|
|
@@ -49,6 +66,9 @@ export class ProductExternalSourceComponent {
|
|
|
49
66
|
ngOnDestroy() {
|
|
50
67
|
this._subs.forEach(s => s.unsubscribe());
|
|
51
68
|
}
|
|
69
|
+
handleConfigurationFinished(variantString) {
|
|
70
|
+
this.configuratorFinished.emit(variantString);
|
|
71
|
+
}
|
|
52
72
|
_prepareExternalSource() {
|
|
53
73
|
return __awaiter(this, void 0, void 0, function* () {
|
|
54
74
|
if (!this._externalSource) {
|
|
@@ -57,30 +77,67 @@ export class ProductExternalSourceComponent {
|
|
|
57
77
|
this.externalUrl = undefined;
|
|
58
78
|
this.externalSettings = {};
|
|
59
79
|
if (this.externalSource.type === 'CATF') {
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
this.externalSettings.options = this.options;
|
|
65
|
-
}
|
|
66
|
-
// this.externalSettings.assetPath = "https://cdn1.colijn-it.nl/content43";
|
|
67
|
-
// this.externalSettings.threeDAssetPath = "https://cdn1.colijn-it.nl/content43";
|
|
68
|
-
if (this.externalSource.username && this.externalSource.password) {
|
|
69
|
-
this.externalSettings.useLoginEncryption = true;
|
|
70
|
-
this.externalSettings.username = this.externalSource.username;
|
|
71
|
-
this.externalSettings.password = this.externalSource.password;
|
|
72
|
-
}
|
|
73
|
-
// finally show the catalog
|
|
74
|
-
this.showProduct = true;
|
|
80
|
+
yield this._prepareCatFarm();
|
|
81
|
+
}
|
|
82
|
+
else if (this.externalSource.type === 'HTDL') {
|
|
83
|
+
this._prepareConfigurator();
|
|
75
84
|
}
|
|
76
85
|
else {
|
|
77
|
-
this.
|
|
78
|
-
|
|
79
|
-
|
|
86
|
+
this._prepareSource();
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
_prepareCatFarm() {
|
|
91
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
92
|
+
// get bundle settings from external source
|
|
93
|
+
const bundleSettings = yield this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));
|
|
94
|
+
this.externalSettings = JSON.parse(bundleSettings);
|
|
95
|
+
if (this.options) {
|
|
96
|
+
this.externalSettings.options = this.options;
|
|
97
|
+
}
|
|
98
|
+
// this.externalSettings.assetPath = "https://cdn1.colijn-it.nl/content43";
|
|
99
|
+
// this.externalSettings.threeDAssetPath = "https://cdn1.colijn-it.nl/content43";
|
|
100
|
+
if (this.externalSource.username && this.externalSource.password) {
|
|
101
|
+
this.externalSettings.useLoginEncryption = true;
|
|
102
|
+
this.externalSettings.username = this.externalSource.username;
|
|
103
|
+
this.externalSettings.password = this.externalSource.password;
|
|
80
104
|
}
|
|
105
|
+
// finally show the catalog
|
|
106
|
+
this.switchToProduct();
|
|
81
107
|
this.loaded = true;
|
|
82
108
|
});
|
|
83
109
|
}
|
|
110
|
+
_prepareConfigurator() {
|
|
111
|
+
if (this.externalCatalogStartupInfo) {
|
|
112
|
+
this.token = this.externalCatalogStartupInfo.token;
|
|
113
|
+
this.sku = this.externalCatalogStartupInfo.externalGoodId;
|
|
114
|
+
this.variant = this.externalCatalogStartupInfo.flattenedGoodId;
|
|
115
|
+
this.urlParams = this.externalCatalogStartupInfo.externalSource.parameters;
|
|
116
|
+
this.switchToConfigurator();
|
|
117
|
+
this.loaded = true;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
_prepareSource() {
|
|
121
|
+
this.externalUrl = this.externalSource.url;
|
|
122
|
+
this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);
|
|
123
|
+
this.switchToSource();
|
|
124
|
+
this.loaded = true;
|
|
125
|
+
}
|
|
126
|
+
switchToProduct() {
|
|
127
|
+
this.showProduct = true;
|
|
128
|
+
this.showConfigurator = false;
|
|
129
|
+
this.showSource = false;
|
|
130
|
+
}
|
|
131
|
+
switchToConfigurator() {
|
|
132
|
+
this.showProduct = false;
|
|
133
|
+
this.showConfigurator = true;
|
|
134
|
+
this.showSource = false;
|
|
135
|
+
}
|
|
136
|
+
switchToSource() {
|
|
137
|
+
this.showProduct = false;
|
|
138
|
+
this.showConfigurator = false;
|
|
139
|
+
this.showSource = true;
|
|
140
|
+
}
|
|
84
141
|
}
|
|
85
142
|
ProductExternalSourceComponent.decorators = [
|
|
86
143
|
{ type: Component, args: [{
|
|
@@ -94,9 +151,17 @@ ProductExternalSourceComponent.decorators = [
|
|
|
94
151
|
[externalSource]="externalSource"
|
|
95
152
|
></app-product-page>
|
|
96
153
|
</ng-container>
|
|
97
|
-
<ng-container *ngIf="
|
|
154
|
+
<ng-container *ngIf="showSource">
|
|
98
155
|
<iframe width="100%" height="100%" [src]="safeUrl" frameborder="0" allowfullscreen></iframe>
|
|
99
156
|
</ng-container>
|
|
157
|
+
<ng-container *ngIf="showConfigurator">
|
|
158
|
+
<co-product-hd width="100%" height="100%"
|
|
159
|
+
[sku]="sku"
|
|
160
|
+
[variant]="variant"
|
|
161
|
+
[token]="token"
|
|
162
|
+
[urlParams]="urlParams"
|
|
163
|
+
(configuratorFinished)="handleConfigurationFinished($event)"></co-product-hd>
|
|
164
|
+
</ng-container>
|
|
100
165
|
</ng-container>
|
|
101
166
|
`,
|
|
102
167
|
providers: [
|
|
@@ -116,10 +181,12 @@ ProductExternalSourceComponent.propDecorators = {
|
|
|
116
181
|
sku: [{ type: Input }],
|
|
117
182
|
catalogDefinition: [{ type: Input }],
|
|
118
183
|
externalSource: [{ type: Input }],
|
|
184
|
+
externalCatalogStartupInfo: [{ type: Input }],
|
|
119
185
|
options: [{ type: Input }],
|
|
120
186
|
addToCart: [{ type: Output }],
|
|
121
187
|
addToQuote: [{ type: Output }],
|
|
122
188
|
alternativeClick: [{ type: Output }],
|
|
189
|
+
configuratorFinished: [{ type: Output }],
|
|
123
190
|
showClass: [{ type: HostBinding, args: ['class.co-product-external-source',] }]
|
|
124
191
|
};
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-external-source.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-external-source/product-external-source.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAqB,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACxH,OAAO,EAAC,YAAY,EAAkB,MAAM,2BAA2B,CAAC;AAExE,OAAO,EAAC,uBAAuB,EAAC,MAAM,yCAAyC,CAAC;AAEhF,OAAO,EAAC,mBAAmB,EAAC,MAAM,qCAAqC,CAAC;AAExE,OAAO,EAAC,sBAAsB,EAAC,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAC,8BAA8B,EAAC,MAAM,iDAAiD,CAAC;AA4B/F,MAAM,OAAO,8BAA8B;IA6CvC,YACY,UAAwB,EACxB,wBAAiD,EACjD,gBAAqC;QAFrC,eAAU,GAAV,UAAU,CAAc;QACxB,6BAAwB,GAAxB,wBAAwB,CAAyB;QACjD,qBAAgB,GAAhB,gBAAgB,CAAqB;QAzB1C,cAAS,GAAoD,IAAI,YAAY,EAAqC,CAAC;QAGnH,eAAU,GAAoD,IAAI,YAAY,EAAqC,CAAC;QAGpH,qBAAgB,GAAoC,IAAI,YAAY,EAAqB,CAAC;QAO1F,gBAAW,GAAY,KAAK,CAAC;QAE7B,WAAM,GAAY,KAAK,CAAC;QAExB,qBAAgB,GAAQ,EAAE,CAAC;QAG1B,UAAK,GAAmB,EAAE,CAAC;IAOnC,CAAC;IA1CD,IACW,cAAc,CAAC,KAAqB;QAC3C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAED,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAeM,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAkBD,QAAQ;QACJ,IAAI,CAAC,KAAK,CAAC,IAAI,CACX,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAuE,EAAE,EAAE;YACpH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;gBAChB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;gBACzC,cAAc,EAAE,IAAI,CAAC,eAAe;aACvC,CAAC,CAAC;QACP,CAAC,CAAC,EACF,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;gBACjB,OAAO,EAAE,IAAI;gBACb,QAAQ,EAAE,CAAC;gBACX,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;gBACzC,cAAc,EAAE,IAAI,CAAC,eAAe;aACvC,CAAC,CAAC;QACP,CAAC,CAAC,EACF,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CACrG,CAAA;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC7C,CAAC;IAEa,sBAAsB;;YAChC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBACvB,OAAO;aACV;YACD,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;YAC7B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;YAC3B,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE;gBACrC,2CAA2C;gBAC3C,MAAM,cAAc,GAAW,MAAM,IAAI,CAAC,wBAAwB,CAAC,wBAAwB,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;gBAC9J,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;gBACnD,IAAI,IAAI,CAAC,OAAO,EAAE;oBACd,IAAI,CAAC,gBAAgB,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;iBAChD;gBACD,2EAA2E;gBAC3E,iFAAiF;gBACjF,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE;oBAC9D,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,GAAG,IAAI,CAAC;oBAChD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC;oBAC9D,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC;iBACjE;gBACD,2BAA2B;gBAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aAC3B;iBAAM;gBACH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC;gBAC3C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAChF,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC5B;YACD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACvB,CAAC;KAAA;;;YAjIJ,SAAS,SAAC;gBACP,QAAQ,EAAE,4BAA4B;gBACtC,QAAQ,EAAE;;;;;;;;;;;;;KAaT;gBACD,SAAS,EAAE;oBACP,sBAAsB;oBACtB,8BAA8B;oBAC9B,uBAAuB;iBAC1B;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;YAlCO,YAAY;YAEZ,uBAAuB;YAEvB,mBAAmB;;;kBAiCtB,KAAK;gCAGL,KAAK;6BAGL,KAAK;sBAWL,KAAK;wBAGL,MAAM;yBAGN,MAAM;+BAGN,MAAM;wBAGN,WAAW,SAAC,kCAAkC","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {DomSanitizer, SafeResourceUrl} from '@angular/platform-browser';\r\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\r\nimport {ProductConnectorService} from '../../service/product-connector.service';\r\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\r\nimport {ProductEventService} from '../../service/product-event.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {ProductSettingsService} from '../../service/product-settings.service';\r\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\r\nimport {CatalogDefinition} from '@colijnit/articleapi/build/model/catalog-definition.bo';\r\nimport {ExternalSourceArticleAddInterface} from '@colijnit/articleapi/build/interface/external-source-article-add.interface';\r\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\r\n\r\n@Component({\r\n    selector: 'co-product-external-source',\r\n    template: `\r\n        <ng-container *ngIf=\"loaded\">\r\n            <ng-container *ngIf=\"showProduct\">\r\n                <app-product-page\r\n                        [sku]=\"sku\"\r\n                        [settings]=\"externalSettings\"\r\n                        [externalSource]=\"externalSource\"\r\n                ></app-product-page>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!showProduct\">\r\n                <iframe width=\"100%\" height=\"100%\" [src]=\"safeUrl\" frameborder=\"0\" allowfullscreen></iframe>\r\n            </ng-container>\r\n        </ng-container>\r\n    `,\r\n    providers: [\r\n        ProductSettingsService,\r\n        ProductConnectorAdapterService,\r\n        ProductConnectorService\r\n    ],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ProductExternalSourceComponent implements OnInit, OnDestroy {\r\n\r\n    @Input()\r\n    public sku: string;\r\n\r\n    @Input()\r\n    public catalogDefinition: CatalogDefinition;\r\n\r\n    @Input()\r\n    public set externalSource(value: ExternalSource) {\r\n        this._externalSource = value;\r\n        this.loaded = false;\r\n        this._prepareExternalSource();\r\n    }\r\n\r\n    public get externalSource(): ExternalSource {\r\n        return this._externalSource;\r\n    }\r\n\r\n    @Input()\r\n    public options: {};\r\n\r\n    @Output()\r\n    public addToCart: EventEmitter<ExternalSourceArticleAddInterface> = new EventEmitter<ExternalSourceArticleAddInterface>();\r\n\r\n    @Output()\r\n    public addToQuote: EventEmitter<ExternalSourceArticleAddInterface> = new EventEmitter<ExternalSourceArticleAddInterface>();\r\n\r\n    @Output()\r\n    public alternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\r\n\r\n    @HostBinding('class.co-product-external-source')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public showProduct: boolean = false;\r\n    public safeUrl: SafeResourceUrl;\r\n    public loaded: boolean = false;\r\n    public externalUrl: string;\r\n    public externalSettings: any = {};\r\n\r\n    private _externalSource: ExternalSource;\r\n    private _subs: Subscription[] = [];\r\n\r\n    constructor(\r\n        private _sanitizer: DomSanitizer,\r\n        private _productConnectorService: ProductConnectorService,\r\n        private _appEventService: ProductEventService\r\n    ) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this._subs.push(\r\n            this._appEventService.onAddToCart.subscribe((data: { article: string | ArticleListObjectExtended, quantity: number }) => {\r\n                this.addToCart.next({\r\n                    article: data.article,\r\n                    quantity: data.quantity,\r\n                    catalogDefinition: this.catalogDefinition,\r\n                    externalSource: this._externalSource\r\n                });\r\n            }),\r\n            this._appEventService.onAddToQuote.subscribe(json => {\r\n                this.addToQuote.next({\r\n                    article: json,\r\n                    quantity: 1,\r\n                    catalogDefinition: this.catalogDefinition,\r\n                    externalSource: this._externalSource\r\n                });\r\n            }),\r\n            this._appEventService.onAlternativeClick.subscribe(article => this.alternativeClick.next(article))\r\n        )\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.forEach(s => s.unsubscribe());\r\n    }\r\n\r\n    private async _prepareExternalSource(): Promise<void> {\r\n        if (!this._externalSource) {\r\n            return;\r\n        }\r\n        this.externalUrl = undefined;\r\n        this.externalSettings = {};\r\n        if (this.externalSource.type === 'CATF') {\r\n            // get bundle settings from external source\r\n            const bundleSettings: string = await this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));\r\n            this.externalSettings = JSON.parse(bundleSettings);\r\n            if (this.options) {\r\n                this.externalSettings.options = this.options;\r\n            }\r\n            // this.externalSettings.assetPath = \"https://cdn1.colijn-it.nl/content43\";\r\n            // this.externalSettings.threeDAssetPath = \"https://cdn1.colijn-it.nl/content43\";\r\n            if (this.externalSource.username && this.externalSource.password) {\r\n                this.externalSettings.useLoginEncryption = true;\r\n                this.externalSettings.username = this.externalSource.username;\r\n                this.externalSettings.password = this.externalSource.password;\r\n            }\r\n            // finally show the catalog\r\n            this.showProduct = true;\r\n        } else {\r\n            this.externalUrl = this.externalSource.url;\r\n            this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);\r\n            this.showProduct = false;\r\n        }\r\n        this.loaded = true;\r\n    }\r\n}\r\n"]}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-external-source.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-external-source/product-external-source.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {DomSanitizer, SafeResourceUrl} from '@angular/platform-browser';\r\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\r\nimport {ProductConnectorService} from '../../service/product-connector.service';\r\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\r\nimport {ProductEventService} from '../../service/product-event.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {ProductSettingsService} from '../../service/product-settings.service';\r\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\r\nimport {CatalogDefinition} from '@colijnit/articleapi/build/model/catalog-definition.bo';\r\nimport {ExternalSourceArticleAddInterface} from '@colijnit/articleapi/build/interface/external-source-article-add.interface';\r\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\r\nimport {ExternalCatalogStartupInfo} from '@colijnit/articleapi/build/model/external-catalog-startup-info';\r\nimport {ExternalSourceParameter} from '@colijnit/articleapi/build/model/external-source-parameter.bo';\r\n\r\n@Component({\r\n    selector: 'co-product-external-source',\r\n    template: `\r\n        <ng-container *ngIf=\"loaded\">\r\n            <ng-container *ngIf=\"showProduct\">\r\n                <app-product-page\r\n                        [sku]=\"sku\"\r\n                        [settings]=\"externalSettings\"\r\n                        [externalSource]=\"externalSource\"\r\n                ></app-product-page>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"showSource\">\r\n                <iframe width=\"100%\" height=\"100%\" [src]=\"safeUrl\" frameborder=\"0\" allowfullscreen></iframe>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"showConfigurator\">\r\n              <co-product-hd width=\"100%\" height=\"100%\"\r\n                             [sku]=\"sku\"\r\n                             [variant]=\"variant\"\r\n                             [token]=\"token\"\r\n                             [urlParams]=\"urlParams\"\r\n                             (configuratorFinished)=\"handleConfigurationFinished($event)\"></co-product-hd>\r\n            </ng-container>\r\n        </ng-container>\r\n    `,\r\n    providers: [\r\n        ProductSettingsService,\r\n        ProductConnectorAdapterService,\r\n        ProductConnectorService\r\n    ],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ProductExternalSourceComponent implements OnInit, OnDestroy {\r\n\r\n    @Input()\r\n    public sku: string;\r\n\r\n    @Input()\r\n    public catalogDefinition: CatalogDefinition;\r\n\r\n    @Input()\r\n    public set externalSource(value: ExternalSource) {\r\n        this._externalSource = value;\r\n        this.loaded = false;\r\n        this._prepareExternalSource();\r\n    }\r\n\r\n    public get externalSource(): ExternalSource {\r\n        return this._externalSource;\r\n    }\r\n\r\n    @Input()\r\n    public set externalCatalogStartupInfo(value: ExternalCatalogStartupInfo) {\r\n      if (value) {\r\n        this._externalCatalogStartupInfo = value;\r\n        this.externalSource = value.externalSource;\r\n        this.loaded = false;\r\n        this._prepareExternalSource();\r\n      }\r\n    }\r\n\r\n    public get externalCatalogStartupInfo(): ExternalCatalogStartupInfo {\r\n      return this._externalCatalogStartupInfo;\r\n    }\r\n\r\n    @Input()\r\n    public options: {};\r\n\r\n    @Output()\r\n    public addToCart: EventEmitter<ExternalSourceArticleAddInterface> = new EventEmitter<ExternalSourceArticleAddInterface>();\r\n\r\n    @Output()\r\n    public addToQuote: EventEmitter<ExternalSourceArticleAddInterface> = new EventEmitter<ExternalSourceArticleAddInterface>();\r\n\r\n    @Output()\r\n    public alternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\r\n\r\n    @Output()\r\n    public configuratorFinished: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    @HostBinding('class.co-product-external-source')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public showProduct: boolean = false;\r\n    public showConfigurator: boolean = false;\r\n    public showSource: boolean = false;\r\n    public safeUrl: SafeResourceUrl;\r\n    public loaded: boolean = false;\r\n    public externalUrl: string;\r\n    public externalSettings: any = {};\r\n\r\n    public token: string = \"\";//= \"eyJhbGciOiJSUzI1NiIsImtpZCI6IkYxOThERkVEOEUwQTQ1MzY3M0M1MUE2Rjk1QUVDQzU3RTM0NjM4RkRSUzI1NiIsInR5cCI6ImF0K2p3dCIsIng1dCI6IjhaamY3WTRLUlRaenhScHZsYTdNVi1OR09QMCJ9.eyJuYmYiOjE3MzIxOTkyOTUsImV4cCI6MTczMjIwMjg5NSwiaXNzIjoiaHR0cHM6Ly9ibXNpZGVudGl0eS1hY2NlcHRhbmNlLmF6dXJld2Vic2l0ZXMubmV0IiwiYXVkIjpbImNhdGFsb2dxdWVyeWFwaSIsImNvbmZpZ3VyYXRvcmFwaSIsInByb2R1Y3R2YXJpYW50Y29tbWFuZGFwaSIsInByb2R1Y3R2YXJpYW50cXVlcnlhcGkiXSwiY2xpZW50X2lkIjoiaW1wZXJzb25hdGlvbi5jbGllbnQiLCJzdWIiOiIwOTMwZDI4Mi05NGU4LTQ5MGEtOGI2NC1mYTk1YmIyYzE1ODIiLCJhdXRoX3RpbWUiOjE3MzIxOTkyOTUsImlkcCI6ImxvY2FsIiwiZW52aXJvbm1lbnQiOiJNU0wiLCJzZWxsZXIiOiJTRTAwMDA5NiIsInNlbGxlcmd1aWQiOiIxMDk1MWJjNS1hZmMzLTQ1MGEtNmVkMS0wOGQ4NDNlNmE5OTQiLCJwZXJtaXNzaW9uIjpbInNhbGVzLmV4cG9ydHRlbXBsYXRlcy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LnRhZy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LmRvY3VtZW50LnJlYWQiLCJkb2N1bWVudGxpYnJhcnkudGFnZ3JvdXAucmVhZCIsInNhbGVzLm9yZGVyLndyaXRlIiwic2FsZXMuY3VzdG9tZXIucmVhZCIsInNhbGVzLm9yZGVyLmRlbGl2ZXJ5YWRkcmVzcy53cml0ZSIsInNlcnZpY2UucmVxdWVzdC5yZWFkIiwiY2F0YWxvZy50YWcucmVhZCIsInNhbGVzLm9yZGVyLnJlYWQiLCJzYWxlcy5jdXN0b21lci53cml0ZSIsInJlcXVlc3Rmb3JxdW90ZS53cml0ZSIsInNhbGVzLm9yZGVyLmJvb2siLCJyZXF1ZXN0Zm9ycXVvdGUucmVhZCIsInNhbGVzLmxlYWQucmVhZCIsInB1cmNoYXNlLm9yZGVyLnJlYWQiLCJzYWxlcy5xdW90ZS5yZWFkIiwic2FsZXMucXVvdGUud3JpdGUiLCJjYXRhbG9nLml0ZW0ucmVhZCIsInNhbGVzLmxlYWQud3JpdGUiLCJzZXJ2aWNlLnJlcXVlc3Quc3VibWl0Iiwic2FsZXMub3JkZXIuZGVsaXZlcnlhZGRyZXNzLnJlYWQiLCJwdXJjaGFzZS5vcmRlci53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy5yZWFkIiwic2VydmljZS5yZXF1ZXN0LndyaXRlIiwiY2F0YWxvZy5jYXRhbG9nLnJlYWQiLCJjYXRhbG9nLmNhdGFsb2cud3JpdGUiLCJjYXRhbG9nLmN1cnJlbmN5LnJlYWQiLCJjYXRhbG9nLmN1cnJlbmN5LndyaXRlIiwiY2F0YWxvZy5pdGVtLndyaXRlIiwiY2F0YWxvZy5sb2NhbGl6YXRpb24ucmVhZCIsImNhdGFsb2cubG9jYWxpemF0aW9uLndyaXRlIiwiY2F0YWxvZy5wcm9kdWN0LnJlYWQiLCJjYXRhbG9nLnByb2R1Y3Qud3JpdGUiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLnJlYWQiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLndyaXRlIiwiY2F0YWxvZy5zZWxsZXIucmVhZCIsImNhdGFsb2cuc2VsbGVyLndyaXRlIiwiY2F0YWxvZy50YWcud3JpdGUiLCJjYXRhbG9nLnVvbS5yZWFkIiwiY2F0YWxvZy51b20ud3JpdGUiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LnJlYWQiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LndyaXRlIiwiY2F0YWxvZy52ZW5kb3IucmVhZCIsImNhdGFsb2cudmVuZG9yLndyaXRlIiwicHVyY2hhc2Uuc2VsbGVyLnJlYWQiLCJwdXJjaGFzZS5zZWxsZXIud3JpdGUiLCJjYXRhbG9nLmFydGljbGUucmVhZCIsImNhdGFsb2cuYXJ0aWNsZS53cml0ZSIsInNhbGVzLnF1b3RlLmxpbmVzLnJlYWQiLCJzYWxlcy5xdW90ZS5saW5lcy53cml0ZSIsInNhbGVzLnNlbGxlci5yZWFkIiwic2FsZXMuc2VsbGVyLndyaXRlIiwiYWNjb3VudGluZy52ZW5kb3JpbnZvaWNlLnJlYWQiLCJpZGVudGl0eS51c2VyLnJlYWQiLCJpZGVudGl0eS51c2VyLndyaXRlIiwiaWRlbnRpdHkucm9sZS5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy53cml0ZSIsImNvbmZpZ3VyYXRvci5wdXJjaGFzZXByaWNlLnJlYWQiLCJzdG9jay5mYWJyaWMucmVhZCJdLCJuYW1lIjoiUm9iaW4iLCJmYW1pbHlfbmFtZSI6ImRlIFdpbnRlciAoQ29saWpuLUlUKSIsInJvbGUiOlsic2VsbGVyIiwiZGVhbGVyX21hbmFnZXIiXSwiaWF0IjoxNzMyMTk5Mjk1LCJzY29wZSI6WyJjYXRhbG9ncXVlcnlhcGkiLCJjb25maWd1cmF0b3JhcGkiLCJwcm9kdWN0dmFyaWFudGNvbW1hbmRhcGkiLCJwcm9kdWN0dmFyaWFudHF1ZXJ5YXBpIl0sImFtciI6WyJpbXBlcnNvbmF0aW9uIl19.rbguVPnkXXDzsM6QKgXulhrF41jIjCuGDV13ig1GC8MewLCJ7wA038OSwT26sx2mCexjvuGYt45YScfPwfTkDy3ErPmHRods64X1dJWZnf-23NTP2iI32K_1vMZH5GOGbMzuFtbKAFQv4hgFAxoyWqFVWyJvuOtQcWyZStROyPHwjAnpnj-x1cVQpOhbO-kQUFvy_VUrPpF3aYVCcO2cFirQTXR6kxSGcYGGcsPY-_eiAd93UdG2EM6xLAocDLaFV72CQI6XEs0WQG1f4SqvH52v3OTkgWBLgYV35gpyIe0-2nazGL0R8pTNuDqrOb7OGmuTRMoTIiRi67-wTxx8cQ\";\r\n    public variant: string = \"\";\r\n    public urlParams: ExternalSourceParameter[] = [];\r\n\r\n\r\n\r\n    private _externalSource: ExternalSource;\r\n    private _externalCatalogStartupInfo: ExternalCatalogStartupInfo;\r\n    private _subs: Subscription[] = [];\r\n\r\n    constructor(\r\n        private _sanitizer: DomSanitizer,\r\n        private _productConnectorService: ProductConnectorService,\r\n        private _appEventService: ProductEventService\r\n    ) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this._subs.push(\r\n            this._appEventService.onAddToCart.subscribe((data: { article: string | ArticleListObjectExtended, quantity: number }) => {\r\n                this.addToCart.next({\r\n                    article: data.article,\r\n                    quantity: data.quantity,\r\n                    catalogDefinition: this.catalogDefinition,\r\n                    externalSource: this._externalSource\r\n                });\r\n            }),\r\n            this._appEventService.onAddToQuote.subscribe(json => {\r\n                this.addToQuote.next({\r\n                    article: json,\r\n                    quantity: 1,\r\n                    catalogDefinition: this.catalogDefinition,\r\n                    externalSource: this._externalSource\r\n                });\r\n            }),\r\n            this._appEventService.onAlternativeClick.subscribe(article => this.alternativeClick.next(article))\r\n        )\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.forEach(s => s.unsubscribe());\r\n    }\r\n\r\n    public handleConfigurationFinished(variantString: string) {\r\n      this.configuratorFinished.emit(variantString);\r\n    }\r\n\r\n    private async _prepareExternalSource(): Promise<void> {\r\n        if (!this._externalSource) {\r\n            return;\r\n        }\r\n        this.externalUrl = undefined;\r\n        this.externalSettings = {};\r\n        if (this.externalSource.type === 'CATF') {\r\n           await this._prepareCatFarm();\r\n        } else  if (this.externalSource.type === 'HTDL'){\r\n          this._prepareConfigurator();\r\n        } else {\r\n          this._prepareSource();\r\n        }\r\n    }\r\n\r\n  private async _prepareCatFarm(): Promise<void> {\r\n    // get bundle settings from external source\r\n    const bundleSettings: string = await this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));\r\n    this.externalSettings = JSON.parse(bundleSettings);\r\n    if (this.options) {\r\n      this.externalSettings.options = this.options;\r\n    }\r\n    // this.externalSettings.assetPath = \"https://cdn1.colijn-it.nl/content43\";\r\n    // this.externalSettings.threeDAssetPath = \"https://cdn1.colijn-it.nl/content43\";\r\n    if (this.externalSource.username && this.externalSource.password) {\r\n      this.externalSettings.useLoginEncryption = true;\r\n      this.externalSettings.username = this.externalSource.username;\r\n      this.externalSettings.password = this.externalSource.password;\r\n    }\r\n    // finally show the catalog\r\n    this.switchToProduct();\r\n    this.loaded = true;\r\n  }\r\n\r\n  private _prepareConfigurator(): void {\r\n    if(this.externalCatalogStartupInfo) {\r\n      this.token = this.externalCatalogStartupInfo.token;\r\n      this.sku = this.externalCatalogStartupInfo.externalGoodId;\r\n      this.variant = this.externalCatalogStartupInfo.flattenedGoodId;\r\n      this.urlParams = this.externalCatalogStartupInfo.externalSource.parameters;\r\n      this.switchToConfigurator();\r\n      this.loaded = true;\r\n    }\r\n  }\r\n\r\n  private _prepareSource(): void {\r\n    this.externalUrl = this.externalSource.url;\r\n    this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);\r\n    this.switchToSource();\r\n    this.loaded = true;\r\n  }\r\n\r\n  private switchToProduct():void {\r\n    this.showProduct = true;\r\n    this.showConfigurator = false;\r\n    this.showSource = false;\r\n  }\r\n\r\n  private switchToConfigurator():void {\r\n    this.showProduct = false;\r\n    this.showConfigurator = true;\r\n    this.showSource = false;\r\n  }\r\n\r\n  private switchToSource():void {\r\n    this.showProduct = false;\r\n    this.showConfigurator = false;\r\n    this.showSource = true;\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -2,13 +2,15 @@ import { NgModule } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { ProductExternalSourceComponent } from './product-external-source.component';
|
|
4
4
|
import { ProductPageModule } from '../product-page/product-page.module';
|
|
5
|
+
import { ProductHdModule } from '../product-hd/product-hd.module';
|
|
5
6
|
export class ProductExternalSourceModule {
|
|
6
7
|
}
|
|
7
8
|
ProductExternalSourceModule.decorators = [
|
|
8
9
|
{ type: NgModule, args: [{
|
|
9
10
|
imports: [
|
|
10
11
|
CommonModule,
|
|
11
|
-
ProductPageModule
|
|
12
|
+
ProductPageModule,
|
|
13
|
+
ProductHdModule
|
|
12
14
|
],
|
|
13
15
|
declarations: [
|
|
14
16
|
ProductExternalSourceComponent
|
|
@@ -18,4 +20,4 @@ ProductExternalSourceModule.decorators = [
|
|
|
18
20
|
]
|
|
19
21
|
},] }
|
|
20
22
|
];
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1leHRlcm5hbC1zb3VyY2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsOEJBQThCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNuRixPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUN0RSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFlaEUsTUFBTSxPQUFPLDJCQUEyQjs7O1lBYnZDLFFBQVEsU0FBQztnQkFDTixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixpQkFBaUI7b0JBQ2pCLGVBQWU7aUJBQ2xCO2dCQUNELFlBQVksRUFBRTtvQkFDViw4QkFBOEI7aUJBQ2pDO2dCQUNELE9BQU8sRUFBRTtvQkFDTCw4QkFBOEI7aUJBQ2pDO2FBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7UHJvZHVjdEV4dGVybmFsU291cmNlQ29tcG9uZW50fSBmcm9tICcuL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdFBhZ2VNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtcGFnZS9wcm9kdWN0LXBhZ2UubW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0SGRNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtaGQvcHJvZHVjdC1oZC5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgUHJvZHVjdFBhZ2VNb2R1bGUsXHJcbiAgICAgICAgUHJvZHVjdEhkTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgUHJvZHVjdEV4dGVybmFsU291cmNlQ29tcG9uZW50XHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW1xyXG4gICAgICAgIFByb2R1Y3RFeHRlcm5hbFNvdXJjZUNvbXBvbmVudFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUHJvZHVjdEV4dGVybmFsU291cmNlTW9kdWxlIHtcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { ProductScriptLoaderService } from '../../service/product-script-loader.service';
|
|
4
|
+
export class ProductHdComponent {
|
|
5
|
+
constructor(_scriptLoader, _renderer) {
|
|
6
|
+
this._scriptLoader = _scriptLoader;
|
|
7
|
+
this._renderer = _renderer;
|
|
8
|
+
this.variant = '';
|
|
9
|
+
this.urlParams = [];
|
|
10
|
+
this.configuratorFinished = new EventEmitter();
|
|
11
|
+
this.configurationError = new EventEmitter();
|
|
12
|
+
this.showClass = true;
|
|
13
|
+
}
|
|
14
|
+
set content(child) {
|
|
15
|
+
this.hdeConfigurator = child;
|
|
16
|
+
this._prepareAttributes();
|
|
17
|
+
}
|
|
18
|
+
set sku(value) {
|
|
19
|
+
this._sku = value;
|
|
20
|
+
this._prepareAttributes();
|
|
21
|
+
}
|
|
22
|
+
get sku() {
|
|
23
|
+
return this._sku;
|
|
24
|
+
}
|
|
25
|
+
ngOnDestroy() {
|
|
26
|
+
this._scriptLoader.unloadScripts(this._renderer);
|
|
27
|
+
}
|
|
28
|
+
handleConfigurationFinished(event) {
|
|
29
|
+
if (event.detail.variant && typeof event.detail.variant === 'string') {
|
|
30
|
+
this.configuratorFinished.emit(event.detail.variant);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
this.configuratorFinished.emit(this.variant);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
handleError(event) {
|
|
37
|
+
this.configurationError.emit(event.detail.status);
|
|
38
|
+
}
|
|
39
|
+
_prepareAttributes() {
|
|
40
|
+
if (this.hdeConfigurator && this.hdeConfigurator.nativeElement && this.urlParams && this.token && (this.sku || this.variant)) {
|
|
41
|
+
//for local testing please turn off for packing and publishing!
|
|
42
|
+
//this.prepareTestingUrlparams();
|
|
43
|
+
this._prepareConfiguratorUrls();
|
|
44
|
+
this.hdeConfigurator.nativeElement.setAttribute('bearerToken', this.token);
|
|
45
|
+
if (this._sku) {
|
|
46
|
+
this.hdeConfigurator.nativeElement.setAttribute('data-productId', this._sku);
|
|
47
|
+
}
|
|
48
|
+
if (this.variant) {
|
|
49
|
+
this.hdeConfigurator.nativeElement.setAttribute('data-productVariantId', this.variant);
|
|
50
|
+
}
|
|
51
|
+
this._loadTheScripts();
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
//set necessary references to configurator.
|
|
55
|
+
_prepareConfiguratorUrls() {
|
|
56
|
+
//fetch the setting from the external source
|
|
57
|
+
let apiurl = this.urlParams.find((item) => item.key === 'apiurl').value;
|
|
58
|
+
let productVariantCommandApiUrl = this.urlParams.find((item) => item.key === 'productVariantCommandApiUrl').value;
|
|
59
|
+
let productVariantQueryApiUrl = this.urlParams.find((item) => item.key === 'productVariantQueryApiUrl').value;
|
|
60
|
+
let localizationApiUrl = this.urlParams.find((item) => item.key === 'localizationApiUrl').value;
|
|
61
|
+
//apply to configurator
|
|
62
|
+
this.hdeConfigurator.nativeElement.setAttribute('apiurl', apiurl);
|
|
63
|
+
this.hdeConfigurator.nativeElement.setAttribute('productVariantCommandApiUrl', productVariantCommandApiUrl);
|
|
64
|
+
this.hdeConfigurator.nativeElement.setAttribute('productVariantQueryApiUrl', productVariantQueryApiUrl);
|
|
65
|
+
this.hdeConfigurator.nativeElement.setAttribute('localizationApiUrl', localizationApiUrl);
|
|
66
|
+
}
|
|
67
|
+
// load external scripts into client
|
|
68
|
+
_loadTheScripts() {
|
|
69
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
70
|
+
let headerUrls = this.urlParams.find((item) => item.key === 'header').value;
|
|
71
|
+
let headerArray = headerUrls.replace(/\s+/g, '').split(',');
|
|
72
|
+
for (let i = 0; i < headerArray.length; i++) {
|
|
73
|
+
yield this._scriptLoader.loadScript(headerArray[i], this._renderer).catch((error) => console.error(error));
|
|
74
|
+
}
|
|
75
|
+
let styles = this.urlParams.find((item) => item.key === 'stylesheet').value;
|
|
76
|
+
let stylesArray = styles.replace(/\s+/g, '').split(',');
|
|
77
|
+
for (let j = 0; j < stylesArray.length; j++) {
|
|
78
|
+
yield this._scriptLoader.addStyleSheet(stylesArray[j], this._renderer);
|
|
79
|
+
}
|
|
80
|
+
//for local testing please turn off for packing and publishing!
|
|
81
|
+
/*const scripts: string[] = [
|
|
82
|
+
// hard-coded for now, should come from the external source
|
|
83
|
+
'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/polyfills.js',
|
|
84
|
+
'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/runtime.js',
|
|
85
|
+
'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/main.js'
|
|
86
|
+
]
|
|
87
|
+
for (let i = 0; i < scripts.length; i++) {
|
|
88
|
+
await this._scriptLoader.loadScript(scripts[i], this._renderer).catch((error) => console.error(error));
|
|
89
|
+
}
|
|
90
|
+
await this._scriptLoader.addStyleSheet('https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/styles.css', this._renderer);*/
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
ProductHdComponent.decorators = [
|
|
95
|
+
{ type: Component, args: [{
|
|
96
|
+
selector: 'co-product-hd',
|
|
97
|
+
template: `
|
|
98
|
+
<hde-configurator #hdeConfigurator
|
|
99
|
+
language="nl"
|
|
100
|
+
localizationFileExtension=".json"
|
|
101
|
+
(configurationFinished)="handleConfigurationFinished($event)"
|
|
102
|
+
(configurationFailed)="handleError($event)"
|
|
103
|
+
>
|
|
104
|
+
<hde-progress-bar></hde-progress-bar>
|
|
105
|
+
</hde-configurator>
|
|
106
|
+
`,
|
|
107
|
+
encapsulation: ViewEncapsulation.None
|
|
108
|
+
},] }
|
|
109
|
+
];
|
|
110
|
+
ProductHdComponent.ctorParameters = () => [
|
|
111
|
+
{ type: ProductScriptLoaderService },
|
|
112
|
+
{ type: Renderer2 }
|
|
113
|
+
];
|
|
114
|
+
ProductHdComponent.propDecorators = {
|
|
115
|
+
content: [{ type: ViewChild, args: ['hdeConfigurator', { read: ElementRef },] }],
|
|
116
|
+
sku: [{ type: Input }],
|
|
117
|
+
token: [{ type: Input }],
|
|
118
|
+
variant: [{ type: Input }],
|
|
119
|
+
urlParams: [{ type: Input }],
|
|
120
|
+
configuratorFinished: [{ type: Output }],
|
|
121
|
+
configurationError: [{ type: Output }],
|
|
122
|
+
showClass: [{ type: HostBinding, args: ['class.co-product-hd',] }]
|
|
123
|
+
};
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-hd.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-hd/product-hd.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  Renderer2,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {ProductScriptLoaderService} from '../../service/product-script-loader.service';\r\nimport {ExternalSourceParameter} from '@colijnit/articleapi/build/model/external-source-parameter.bo';\r\n\r\n@Component({\r\n  selector: 'co-product-hd',\r\n  template: `\r\n    <hde-configurator #hdeConfigurator\r\n                      language=\"nl\"\r\n                      localizationFileExtension=\".json\"\r\n                      (configurationFinished)=\"handleConfigurationFinished($event)\"\r\n                      (configurationFailed)=\"handleError($event)\"\r\n    >\r\n      <hde-progress-bar></hde-progress-bar>\r\n    </hde-configurator>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ProductHdComponent implements OnDestroy {\r\n  @ViewChild('hdeConfigurator', {read: ElementRef}) set content(child) {\r\n    this.hdeConfigurator = child;\r\n    this._prepareAttributes();\r\n  }\r\n\r\n  @Input()\r\n  public set sku(value: string) {\r\n    this._sku = value;\r\n    this._prepareAttributes();\r\n  }\r\n\r\n  public get sku(): string {\r\n    return this._sku;\r\n  }\r\n\r\n  @Input()\r\n  public token: string; //= \"eyJhbGciOiJSUzI1NiIsImtpZCI6IkYxOThERkVEOEUwQTQ1MzY3M0M1MUE2Rjk1QUVDQzU3RTM0NjM4RkRSUzI1NiIsInR5cCI6ImF0K2p3dCIsIng1dCI6IjhaamY3WTRLUlRaenhScHZsYTdNVi1OR09QMCJ9.eyJuYmYiOjE3MzcxMjQ2NDQsImV4cCI6MTczNzEyODI0NCwiaXNzIjoiaHR0cHM6Ly9ibXNpZGVudGl0eS1hY2NlcHRhbmNlLmF6dXJld2Vic2l0ZXMubmV0IiwiYXVkIjpbImNhdGFsb2dxdWVyeWFwaSIsImNvbmZpZ3VyYXRvcmFwaSIsInByb2R1Y3R2YXJpYW50Y29tbWFuZGFwaSIsInByb2R1Y3R2YXJpYW50cXVlcnlhcGkiXSwiY2xpZW50X2lkIjoiaW1wZXJzb25hdGlvbi5jbGllbnQiLCJzdWIiOiIwOTMwZDI4Mi05NGU4LTQ5MGEtOGI2NC1mYTk1YmIyYzE1ODIiLCJhdXRoX3RpbWUiOjE3MzcxMjQ2NDQsImlkcCI6ImxvY2FsIiwiZW52aXJvbm1lbnQiOiJNU0wiLCJzZWxsZXIiOiJTRTAwMDA5NiIsInNlbGxlcmd1aWQiOiIxMDk1MWJjNS1hZmMzLTQ1MGEtNmVkMS0wOGQ4NDNlNmE5OTQiLCJwZXJtaXNzaW9uIjpbInNhbGVzLmV4cG9ydHRlbXBsYXRlcy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LnRhZy5yZWFkIiwiZG9jdW1lbnRsaWJyYXJ5LmRvY3VtZW50LnJlYWQiLCJkb2N1bWVudGxpYnJhcnkudGFnZ3JvdXAucmVhZCIsInNhbGVzLm9yZGVyLndyaXRlIiwic2FsZXMuY3VzdG9tZXIucmVhZCIsInNhbGVzLm9yZGVyLmRlbGl2ZXJ5YWRkcmVzcy53cml0ZSIsInNlcnZpY2UucmVxdWVzdC5yZWFkIiwiY2F0YWxvZy50YWcucmVhZCIsInNhbGVzLm9yZGVyLnJlYWQiLCJzYWxlcy5jdXN0b21lci53cml0ZSIsInJlcXVlc3Rmb3JxdW90ZS53cml0ZSIsInNhbGVzLm9yZGVyLmJvb2siLCJyZXF1ZXN0Zm9ycXVvdGUucmVhZCIsInNhbGVzLmxlYWQucmVhZCIsInB1cmNoYXNlLm9yZGVyLnJlYWQiLCJzYWxlcy5xdW90ZS5yZWFkIiwic2FsZXMucXVvdGUud3JpdGUiLCJjYXRhbG9nLml0ZW0ucmVhZCIsInNhbGVzLmxlYWQud3JpdGUiLCJzZXJ2aWNlLnJlcXVlc3Quc3VibWl0Iiwic2FsZXMub3JkZXIuZGVsaXZlcnlhZGRyZXNzLnJlYWQiLCJwdXJjaGFzZS5vcmRlci53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy53cml0ZSIsInB1cmNoYXNlLm9yZGVyLnByaWNlcy5yZWFkIiwic2VydmljZS5yZXF1ZXN0LndyaXRlIiwiY2F0YWxvZy5jYXRhbG9nLnJlYWQiLCJjYXRhbG9nLmNhdGFsb2cud3JpdGUiLCJjYXRhbG9nLmN1cnJlbmN5LnJlYWQiLCJjYXRhbG9nLmN1cnJlbmN5LndyaXRlIiwiY2F0YWxvZy5pdGVtLndyaXRlIiwiY2F0YWxvZy5sb2NhbGl6YXRpb24ucmVhZCIsImNhdGFsb2cubG9jYWxpemF0aW9uLndyaXRlIiwiY2F0YWxvZy5wcm9kdWN0LnJlYWQiLCJjYXRhbG9nLnByb2R1Y3Qud3JpdGUiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLnJlYWQiLCJjYXRhbG9nLnByb2R1Y3RzZXR0aW5nLndyaXRlIiwiY2F0YWxvZy5zZWxsZXIucmVhZCIsImNhdGFsb2cuc2VsbGVyLndyaXRlIiwiY2F0YWxvZy50YWcud3JpdGUiLCJjYXRhbG9nLnVvbS5yZWFkIiwiY2F0YWxvZy51b20ud3JpdGUiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LnJlYWQiLCJjYXRhbG9nLnZhdGNhdGVnb3J5LndyaXRlIiwiY2F0YWxvZy52ZW5kb3IucmVhZCIsImNhdGFsb2cudmVuZG9yLndyaXRlIiwicHVyY2hhc2Uuc2VsbGVyLnJlYWQiLCJwdXJjaGFzZS5zZWxsZXIud3JpdGUiLCJjYXRhbG9nLmFydGljbGUucmVhZCIsImNhdGFsb2cuYXJ0aWNsZS53cml0ZSIsInNhbGVzLnF1b3RlLmxpbmVzLnJlYWQiLCJzYWxlcy5xdW90ZS5saW5lcy53cml0ZSIsInNhbGVzLnNlbGxlci5yZWFkIiwic2FsZXMuc2VsbGVyLndyaXRlIiwiYWNjb3VudGluZy52ZW5kb3JpbnZvaWNlLnJlYWQiLCJpZGVudGl0eS51c2VyLnJlYWQiLCJpZGVudGl0eS51c2VyLndyaXRlIiwiaWRlbnRpdHkucm9sZS5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy5yZWFkIiwic2VsbGVyLnByb2R1Y3RwcmljZS5zZXR0aW5ncy53cml0ZSIsImNvbmZpZ3VyYXRvci5wdXJjaGFzZXByaWNlLnJlYWQiLCJzdG9jay5mYWJyaWMucmVhZCIsInNhbGVzLm9yZGVyLnBsYWNlIl0sIm5hbWUiOiJSb2JpbiIsImZhbWlseV9uYW1lIjoiZGUgV2ludGVyIChDb2xpam4tSVQpIiwicm9sZSI6WyJzZWxsZXIiLCJkZWFsZXJfbWFuYWdlciJdLCJpYXQiOjE3MzcxMjQ2NDQsInNjb3BlIjpbImNhdGFsb2dxdWVyeWFwaSIsImNvbmZpZ3VyYXRvcmFwaSIsInByb2R1Y3R2YXJpYW50Y29tbWFuZGFwaSIsInByb2R1Y3R2YXJpYW50cXVlcnlhcGkiXSwiYW1yIjpbImltcGVyc29uYXRpb24iXX0.IrmgJbyPrWwNYO1xgyFcV3OsmQ7qF5nbhux8opLz8VW4za3co4aXUE4E9HYBzJFpurcv9T7oL0AhbQq4zbjNSW973GYAFI_euIMZobtzXHK_coBuTxWXnfDC8MmFAJhduIt1HXgYVX6dtY_RWwaHfEIy4J5YBjxzWgHgDrRG_Edn5_QKfC6PuTzLUoHkIaulehGk8ptlRKwNoHiGAxkHt-grefBjPlyeW98O9PqPzl4_wR6P_c8wJQiFCjAPpADvkKuwdN06BJ2Q9mXQasYOom5M6f-B51PBRyajX-f20rA3jj16bRLnIqvWRZ-p-U2zxfWUKwBAXa-aEcLH6LHTAQ\";\r\n\r\n  @Input()\r\n  public variant: string = '';\r\n\r\n  @Input()\r\n  public urlParams: ExternalSourceParameter[] = [];\r\n\r\n  @Output()\r\n  public configuratorFinished: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @Output()\r\n  public configurationError: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  @HostBinding('class.co-product-hd')\r\n  public showClass: boolean = true;\r\n\r\n  public hdeConfigurator: ElementRef;\r\n\r\n  private _sku: string;\r\n\r\n  constructor(\r\n    private _scriptLoader: ProductScriptLoaderService,\r\n    private _renderer: Renderer2\r\n  ) {\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._scriptLoader.unloadScripts(this._renderer);\r\n  }\r\n\r\n  public handleConfigurationFinished(event: CustomEvent): void {\r\n    if (event.detail.variant && typeof event.detail.variant === 'string') {\r\n      this.configuratorFinished.emit(event.detail.variant);\r\n    } else {\r\n      this.configuratorFinished.emit(this.variant);\r\n    }\r\n  }\r\n\r\n  public handleError(event: CustomEvent): void {\r\n    this.configurationError.emit(event.detail.status);\r\n  }\r\n\r\n  private _prepareAttributes(): void {\r\n    if (this.hdeConfigurator && this.hdeConfigurator.nativeElement && this.urlParams && this.token && (this.sku || this.variant)) {\r\n      //for local testing please turn off for packing and publishing!\r\n      //this.prepareTestingUrlparams();\r\n\r\n      this._prepareConfiguratorUrls();\r\n      this.hdeConfigurator.nativeElement.setAttribute('bearerToken', this.token);\r\n      if (this._sku) {\r\n        this.hdeConfigurator.nativeElement.setAttribute('data-productId', this._sku);\r\n      }\r\n      if (this.variant) {\r\n        this.hdeConfigurator.nativeElement.setAttribute('data-productVariantId', this.variant);\r\n      }\r\n      this._loadTheScripts();\r\n    }\r\n  }\r\n\r\n  //set necessary references to configurator.\r\n  private _prepareConfiguratorUrls(): void {\r\n    //fetch the setting from the external source\r\n    let apiurl: string = this.urlParams.find((item: ExternalSourceParameter) => item.key === 'apiurl').value;\r\n    let productVariantCommandApiUrl: string =  this.urlParams.find((item: ExternalSourceParameter) => item.key === 'productVariantCommandApiUrl').value;\r\n    let productVariantQueryApiUrl: string =  this.urlParams.find((item: ExternalSourceParameter) => item.key === 'productVariantQueryApiUrl').value;\r\n    let localizationApiUrl: string =  this.urlParams.find((item: ExternalSourceParameter) => item.key === 'localizationApiUrl').value;\r\n\r\n    //apply to configurator\r\n    this.hdeConfigurator.nativeElement.setAttribute('apiurl', apiurl);\r\n    this.hdeConfigurator.nativeElement.setAttribute('productVariantCommandApiUrl', productVariantCommandApiUrl);\r\n    this.hdeConfigurator.nativeElement.setAttribute('productVariantQueryApiUrl', productVariantQueryApiUrl);\r\n    this.hdeConfigurator.nativeElement.setAttribute('localizationApiUrl', localizationApiUrl)\r\n  }\r\n\r\n  // load external scripts into client\r\n  private async _loadTheScripts(): Promise<void> {\r\n    let headerUrls: string = this.urlParams.find((item: ExternalSourceParameter) => item.key === 'header').value;\r\n    let headerArray: string[] = headerUrls.replace(/\\s+/g, '').split(',');\r\n    for (let i = 0; i < headerArray.length; i++) {\r\n      await this._scriptLoader.loadScript(headerArray[i], this._renderer).catch((error) => console.error(error));\r\n    }\r\n\r\n    let styles: string = this.urlParams.find((item: ExternalSourceParameter) => item.key === 'stylesheet').value;\r\n    let stylesArray: string[] = styles.replace(/\\s+/g, '').split(',');\r\n    for (let j = 0; j < stylesArray.length; j++) {\r\n      await this._scriptLoader.addStyleSheet(stylesArray[j], this._renderer);\r\n    }\r\n\r\n    //for local testing please turn off for packing and publishing!\r\n    /*const scripts: string[] = [\r\n      // hard-coded for now, should come from the external source\r\n      'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/polyfills.js',\r\n      'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/runtime.js',\r\n      'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/main.js'\r\n    ]\r\n    for (let i = 0; i < scripts.length; i++) {\r\n      await this._scriptLoader.loadScript(scripts[i], this._renderer).catch((error) => console.error(error));\r\n    }\r\n    await this._scriptLoader.addStyleSheet('https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/styles.css', this._renderer);*/\r\n  }\r\n\r\n\r\n\r\n  //for local testing please turn off for packing and publishing!\r\n  /*private prepareTestingUrlparams(): void {\r\n    let headers: ExternalSourceParameter = new ExternalSourceParameter();\r\n    headers.id = 1;\r\n    headers.key = 'header';\r\n    headers.value = 'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/polyfills.js,https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/runtime.js,https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/main.js';\r\n    let styles: ExternalSourceParameter = new ExternalSourceParameter();\r\n    styles.id = 2;\r\n    styles.key = 'stylesheet';\r\n    styles.value = 'https://hde-cdn.azureedge.net/libs/components/Configurator/1.0.33/styles.css';\r\n    this.urlParams.push(headers);\r\n    this.urlParams.push(styles);\r\n    let aurl: ExternalSourceParameter = new ExternalSourceParameter();\r\n    aurl.id = 3;\r\n    aurl.key = 'apiurl';\r\n    aurl.value = 'https://bmsproductconfigurator-acceptance.azurewebsites.net/api/configurator/';\r\n    let purl: ExternalSourceParameter = new ExternalSourceParameter();\r\n    purl.id = 4;\r\n    purl.key = 'productVariantCommandApiUrl';\r\n    purl.value = 'https://bmsproductvariantcommand-acceptance.azurewebsites.net/';\r\n    let qurl: ExternalSourceParameter = new ExternalSourceParameter();\r\n    qurl.id = 5;\r\n    qurl.key = 'productVariantQueryApiUrl';\r\n    qurl.value = 'https://bmsproductvariantquery-acceptance.azurewebsites.net/';\r\n    let lurl: ExternalSourceParameter = new ExternalSourceParameter();\r\n    lurl.id = 6;\r\n    lurl.key = 'localizationApiUrl';\r\n    lurl.value = 'https://hde-cdn.azureedge.net/libs/BMS.DST.Localization/';\r\n    this.urlParams.push(headers);\r\n    this.urlParams.push(styles);\r\n    this.urlParams.push(aurl);\r\n    this.urlParams.push(purl);\r\n    this.urlParams.push(qurl);\r\n    this.urlParams.push(lurl);\r\n  }*/\r\n}\r\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { ProductHdComponent } from './product-hd.component';
|
|
4
|
+
export class ProductHdModule {
|
|
5
|
+
}
|
|
6
|
+
ProductHdModule.decorators = [
|
|
7
|
+
{ type: NgModule, args: [{
|
|
8
|
+
imports: [
|
|
9
|
+
CommonModule
|
|
10
|
+
],
|
|
11
|
+
declarations: [
|
|
12
|
+
ProductHdComponent
|
|
13
|
+
],
|
|
14
|
+
schemas: [
|
|
15
|
+
CUSTOM_ELEMENTS_SCHEMA,
|
|
16
|
+
NO_ERRORS_SCHEMA
|
|
17
|
+
],
|
|
18
|
+
exports: [
|
|
19
|
+
ProductHdComponent
|
|
20
|
+
]
|
|
21
|
+
},] }
|
|
22
|
+
];
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1oZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvcHJvZHVjdC1oZC9wcm9kdWN0LWhkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQWlCMUQsTUFBTSxPQUFPLGVBQWU7OztZQWYzQixRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLFlBQVk7aUJBQ2Y7Z0JBQ0QsWUFBWSxFQUFFO29CQUNWLGtCQUFrQjtpQkFDckI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLHNCQUFzQjtvQkFDdEIsZ0JBQWdCO2lCQUNuQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ0wsa0JBQWtCO2lCQUNyQjthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBOZ01vZHVsZSwgTk9fRVJST1JTX1NDSEVNQX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge1Byb2R1Y3RIZENvbXBvbmVudH0gZnJvbSAnLi9wcm9kdWN0LWhkLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIFByb2R1Y3RIZENvbXBvbmVudFxyXG4gICAgXSxcclxuICAgIHNjaGVtYXM6IFtcclxuICAgICAgICBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLFxyXG4gICAgICAgIE5PX0VSUk9SU19TQ0hFTUFcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgUHJvZHVjdEhkQ29tcG9uZW50XHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQcm9kdWN0SGRNb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -35,6 +35,7 @@ export class IoneProductComponent {
|
|
|
35
35
|
this.onAddToQuote = new EventEmitter();
|
|
36
36
|
this.openStockEvent = new EventEmitter();
|
|
37
37
|
this.settingsLoaded = false;
|
|
38
|
+
this.showHD = false;
|
|
38
39
|
this._subs = [];
|
|
39
40
|
this._subs.push(
|
|
40
41
|
// this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),
|
|
@@ -94,7 +95,8 @@ IoneProductComponent.decorators = [
|
|
|
94
95
|
[sku]="sku"
|
|
95
96
|
[showRelatedProductsPopup]="showRelatedProductsPopup"
|
|
96
97
|
></app-product-page>
|
|
97
|
-
|
|
98
|
+
<!-- <co-button [label]="'click'" (click)="showHD = !showHD"></co-button>
|
|
99
|
+
<co-product-hd [sku]="'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'" *ngIf="showHD"></co-product-hd>-->
|
|
98
100
|
`,
|
|
99
101
|
encapsulation: ViewEncapsulation.Emulated,
|
|
100
102
|
styles: [""]
|
|
@@ -123,4 +125,4 @@ IoneProductComponent.propDecorators = {
|
|
|
123
125
|
onAddToQuote: [{ type: Output }],
|
|
124
126
|
openStockEvent: [{ type: Output }]
|
|
125
127
|
};
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ione-product.component.js","sourceRoot":"","sources":["../../../src/app/ione-product.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAIL,MAAM,EAEN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,gBAAgB,EAAC,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAC,uBAAuB,EAAC,MAAM,qCAAqC,CAAC;AAC5E,OAAO,EAAC,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AAE/D,OAAO,EAAC,mBAAmB,EAAC,MAAM,iCAAiC,CAAC;AAEpE,OAAO,EAAC,sBAAsB,EAAC,MAAM,oCAAoC,CAAC;AAoB1E,MAAM,OAAO,oBAAoB;IA0D/B,YACU,WAA8B,EAC9B,UAA4B,EAC5B,KAA8B,EAC9B,eAAkC,EAClC,gBAAqC,EACrC,gBAAwC;QAEhD,wBAAwB;QACxB,0BAA0B;QAC1B,4BAA4B;QAC5B,4BAA4B;QAC5B,oBAAoB;QACpB,2BAA2B;QAC3B,2BAA2B;QAC3B,2BAA2B;QAC3B,qBAAqB;QACrB,oBAAoB;QACpB,yBAAyB;QACzB,uBAAuB;QAlBf,gBAAW,GAAX,WAAW,CAAmB;QAC9B,eAAU,GAAV,UAAU,CAAkB;QAC5B,UAAK,GAAL,KAAK,CAAyB;QAC9B,oBAAe,GAAf,eAAe,CAAmB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAqB;QACrC,qBAAgB,GAAhB,gBAAgB,CAAwB;QArC3C,+BAA0B,GAAY,IAAI,CAAC;QAG3C,gBAAW,GAAoF,IAAI,YAAY,EAAqE,CAAC;QAGrL,qBAAgB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAGhE,uBAAkB,GAAoC,IAAI,YAAY,EAAqB,CAAC;QAG5F,0BAAqB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAGzE,sBAAiB,GAAkC,IAAI,YAAY,EAAmB,CAAC;QAGvF,yBAAoB,GAA8B,IAAI,YAAY,EAAe,CAAC;QAGlF,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;QAGhE,mBAAc,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAE9D,mBAAc,GAAY,KAAK,CAAC;QAG/B,UAAK,GAAmB,EAAE,CAAC;QAuBjC,IAAI,CAAC,KAAK,CAAC,IAAI;QACb,6EAA6E;QAC7E,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAuE,EAAE,EAAE;YACtH,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC,CAAC,EACF,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAClF,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EACpG,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,EACnG,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAClG,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EAC9G,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACtD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;QAC/B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAlFD,IACW,QAAQ,CAAC,KAAU;QAC5B,IAAI,KAAK,EAAE;YACT,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;aACpC;iBAAM;gBACL,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;aACxB;SACF;IACH,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAuEK,QAAQ;;YACZ,MAAM,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;YAC7E,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,gBAAgB,CAAC,wBAAwB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAChE;QACH,CAAC;KAAA;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC3C,CAAC;IAEO,yBAAyB,CAAC,IAAY;QAC5C,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;IAEa,gBAAgB,CAAC,IAAuE;;YACpG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;KAAA;IACM,SAAS;QACd,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;;;YAtIF,SAAS,SAAC;gBACT,QAAQ,EAAE,kBAAkB;gBAC5B,QAAQ,EAAE;;;;;;;;;GAST;gBACD,aAAa,EAAE,iBAAiB,CAAC,QAAQ;;aAE1C;;;YAvBO,iBAAiB;YAFjB,gBAAgB;YAChB,uBAAuB;YAZ7B,iBAAiB;YAeX,mBAAmB;YAEnB,sBAAsB;;;kBAsB3B,KAAK;uBAGL,KAAK;uCAGL,KAAK;uBAGL,KAAK;yCAeL,KAAK;0BAGL,MAAM;+BAGN,MAAM;iCAGN,MAAM;oCAGN,MAAM;gCAGN,MAAM;mCAGN,MAAM;2BAGN,MAAM;6BAGN,MAAM","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {JsonUtilsService} from './utils/json-utils.service';\nimport {ProductConnectorService} from './service/product-connector.service';\nimport {DictionaryService} from './service/dictionary.service';\nimport {Subscription} from 'rxjs';\nimport {ProductEventService} from './service/product-event.service';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductSettingsService} from './service/product-settings.service';\nimport {Selection} from '@colijnit/articleapi/build/model/selection';\nimport {ArticleQuickSel} from '@colijnit/articleapi/build/model/article-quick-sel';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\n\n@Component({\n  selector: 'app-ione-product',\n  template: `\n      <app-product-page *ngIf=\"settingsLoaded\"\n                        [createFrozenArticle]=\"handleAddArticleInternally\"\n                        [isReturn]=\"isReturn\"\n                        (openStockEvent)=\"openStock()\"\n                        [sku]=\"sku\"\n                        [showRelatedProductsPopup]=\"showRelatedProductsPopup\"\n      ></app-product-page>\n\n  `,\n  encapsulation: ViewEncapsulation.Emulated,\n  styleUrls: ['./ione-product.component.css']\n})\nexport class IoneProductComponent implements OnInit, OnChanges, OnDestroy {\n\n  @Input()\n  public sku: string;\n\n  @Input()\n  public isReturn: boolean;\n\n  @Input()\n  public showRelatedProductsPopup: boolean;\n\n  @Input()\n  public set settings(value: any) {\n    if (value) {\n      if (typeof value === 'string') {\n        this._settings = JSON.parse(value);\n      } else {\n        this._settings = value;\n      }\n    }\n  }\n\n  public get settings(): any {\n    return this._settings;\n  }\n\n  @Input()\n  public handleAddArticleInternally: boolean = true;\n\n  @Output()\n  public onAddToCart: EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }> = new EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }>();\n\n  @Output()\n  public forceRenderImage: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public onAlternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\n\n  @Output()\n  public onArticleInfoReceived: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public onArticleReceived: EventEmitter<ArticleQuickSel> = new EventEmitter<ArticleQuickSel>();\n\n  @Output()\n  public onSelectionsReceived: EventEmitter<Selection[]> = new EventEmitter<Selection[]>();\n\n  @Output()\n  public onAddToQuote: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public openStockEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  public settingsLoaded: boolean = false;\n\n  private _settings: any;\n  private _subs: Subscription[] = [];\n\n  constructor (\n    private _dictionary: DictionaryService,\n    private _jsonUtils: JsonUtilsService,\n    private _ione: ProductConnectorService,\n    private _changeDetector: ChangeDetectorRef,\n    private _appEventService: ProductEventService,\n    private _settingsService: ProductSettingsService\n  ) {\n    // this.sku = 'CF-HILL';\n    // this.sku = 'CF-ALMADA';\n    // this.sku = 'CF-39904ANT';\n    // this.sku = 'CF-22346001';\n    // this.sku = '104';\n    // this.sku = '1000561986';\n    // this.sku = '1000567768';\n    // this.sku = '1000234793';\n    // this.sku = '1066';\n    // this.sku = '104';\n    // this.sku = \"70000107\";\n    // this.sku = \"grover\";\n\n    this._subs.push(\n      // this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),\n      this._appEventService.onAddToCart.subscribe((data: { article: string | ArticleListObjectExtended, quantity: number }) => {\n        this._handleAddToCart(data);\n      }),\n      this._appEventService.onAddToQuote.subscribe(json => this.onAddToQuote.emit(json)),\n      this._appEventService.onAlternativeClick.subscribe(article => this.onAlternativeClick.emit(article)),\n      this._appEventService.onArticleInfoReceived.subscribe(info => this._handleAnswerInfoReceived(info)),\n      this._appEventService.onArticleReceived.subscribe(article => this.onArticleReceived.emit(article)),\n      this._appEventService.onSelectionsReceived.subscribe(selections => this.onSelectionsReceived.emit(selections)),\n      this._settingsService.settingsLoaded.subscribe(loaded => {\n        this.settingsLoaded = loaded;\n      }),\n    );\n  }\n\n  async ngOnInit(): Promise<void> {\n    await this._settingsService.initializeSettings(this._settings === undefined);\n    if (this._settings) {\n      this._settingsService.createSettingsFromObject(this._settings);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this._changeDetector.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  private _handleAnswerInfoReceived(info: string): void {\n    this.onArticleInfoReceived.next(info);\n  }\n\n  private async _handleAddToCart(data: { article: string | ArticleListObjectExtended, quantity: number }): Promise<void> {\n    this.onAddToCart.emit(data);\n  }\n  public openStock() {\n    this.openStockEvent.emit();\n  }\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ione-product.component.js","sourceRoot":"","sources":["../../../src/app/ione-product.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {JsonUtilsService} from './utils/json-utils.service';\nimport {ProductConnectorService} from './service/product-connector.service';\nimport {DictionaryService} from './service/dictionary.service';\nimport {Subscription} from 'rxjs';\nimport {ProductEventService} from './service/product-event.service';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductSettingsService} from './service/product-settings.service';\nimport {Selection} from '@colijnit/articleapi/build/model/selection';\nimport {ArticleQuickSel} from '@colijnit/articleapi/build/model/article-quick-sel';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\n\n@Component({\n  selector: 'app-ione-product',\n  template: `\n      <app-product-page *ngIf=\"settingsLoaded\"\n                        [createFrozenArticle]=\"handleAddArticleInternally\"\n                        [isReturn]=\"isReturn\"\n                        (openStockEvent)=\"openStock()\"\n                        [sku]=\"sku\"\n                        [showRelatedProductsPopup]=\"showRelatedProductsPopup\"\n      ></app-product-page>\n<!--    <co-button [label]=\"'click'\" (click)=\"showHD = !showHD\"></co-button>\n      <co-product-hd [sku]=\"'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'\" *ngIf=\"showHD\"></co-product-hd>-->\n  `,\n  encapsulation: ViewEncapsulation.Emulated,\n  styleUrls: ['./ione-product.component.css']\n})\nexport class IoneProductComponent implements OnInit, OnChanges, OnDestroy {\n\n  @Input()\n  public sku: string;\n\n  @Input()\n  public isReturn: boolean;\n\n  @Input()\n  public showRelatedProductsPopup: boolean;\n\n  @Input()\n  public set settings(value: any) {\n    if (value) {\n      if (typeof value === 'string') {\n        this._settings = JSON.parse(value);\n      } else {\n        this._settings = value;\n      }\n    }\n  }\n\n  public get settings(): any {\n    return this._settings;\n  }\n\n  @Input()\n  public handleAddArticleInternally: boolean = true;\n\n  @Output()\n  public onAddToCart: EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }> = new EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }>();\n\n  @Output()\n  public forceRenderImage: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public onAlternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\n\n  @Output()\n  public onArticleInfoReceived: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public onArticleReceived: EventEmitter<ArticleQuickSel> = new EventEmitter<ArticleQuickSel>();\n\n  @Output()\n  public onSelectionsReceived: EventEmitter<Selection[]> = new EventEmitter<Selection[]>();\n\n  @Output()\n  public onAddToQuote: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public openStockEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  public settingsLoaded: boolean = false;\n  public showHD: boolean = false;\n\n  private _settings: any;\n  private _subs: Subscription[] = [];\n\n  constructor (\n    private _dictionary: DictionaryService,\n    private _jsonUtils: JsonUtilsService,\n    private _ione: ProductConnectorService,\n    private _changeDetector: ChangeDetectorRef,\n    private _appEventService: ProductEventService,\n    private _settingsService: ProductSettingsService\n  ) {\n    // this.sku = 'CF-HILL';\n    // this.sku = 'CF-ALMADA';\n    // this.sku = 'CF-39904ANT';\n    // this.sku = 'CF-22346001';\n    // this.sku = '104';\n    // this.sku = '1000561986';\n    // this.sku = '1000567768';\n    // this.sku = '1000234793';\n    // this.sku = '1066';\n    // this.sku = '104';\n    // this.sku = \"70000107\";\n    // this.sku = \"grover\";\n\n    this._subs.push(\n      // this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),\n      this._appEventService.onAddToCart.subscribe((data: { article: string | ArticleListObjectExtended, quantity: number }) => {\n        this._handleAddToCart(data);\n      }),\n      this._appEventService.onAddToQuote.subscribe(json => this.onAddToQuote.emit(json)),\n      this._appEventService.onAlternativeClick.subscribe(article => this.onAlternativeClick.emit(article)),\n      this._appEventService.onArticleInfoReceived.subscribe(info => this._handleAnswerInfoReceived(info)),\n      this._appEventService.onArticleReceived.subscribe(article => this.onArticleReceived.emit(article)),\n      this._appEventService.onSelectionsReceived.subscribe(selections => this.onSelectionsReceived.emit(selections)),\n      this._settingsService.settingsLoaded.subscribe(loaded => {\n        this.settingsLoaded = loaded;\n      }),\n    );\n  }\n\n  async ngOnInit(): Promise<void> {\n    await this._settingsService.initializeSettings(this._settings === undefined);\n    if (this._settings) {\n      this._settingsService.createSettingsFromObject(this._settings);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this._changeDetector.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  private _handleAnswerInfoReceived(info: string): void {\n    this.onArticleInfoReceived.next(info);\n  }\n\n  private async _handleAddToCart(data: { article: string | ArticleListObjectExtended, quantity: number }): Promise<void> {\n    this.onAddToCart.emit(data);\n  }\n  public openStock() {\n    this.openStockEvent.emit();\n  }\n}\n"]}
|
|
@@ -1,22 +1,26 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
2
2
|
import { IoneProductComponent } from './ione-product.component';
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
|
-
//
|
|
4
|
+
//import {BrowserAnimationsModule} from '@angular/platform-browser/animations';
|
|
5
5
|
import { ProductPageModule } from './components/product-page/product-page.module';
|
|
6
6
|
import { ProductSettingsService } from './service/product-settings.service';
|
|
7
7
|
import { ProductConnectorService } from './service/product-connector.service';
|
|
8
8
|
import { ProductConnectorAdapterService } from './service/product-connector-adapter.service';
|
|
9
9
|
import { ProductEventService } from './service/product-event.service';
|
|
10
|
-
import {
|
|
10
|
+
import { ProductHdModule } from './components/product-hd/product-hd.module';
|
|
11
|
+
import { ProductExternalSourceModule } from './components/product-external-source/product-external-source.module';
|
|
12
|
+
import { ButtonModule } from '@colijnit/corecomponents_v12';
|
|
11
13
|
export class IoneProductModule {
|
|
12
14
|
}
|
|
13
15
|
IoneProductModule.decorators = [
|
|
14
16
|
{ type: NgModule, args: [{
|
|
15
17
|
imports: [
|
|
16
|
-
//
|
|
18
|
+
//BrowserAnimationsModule,
|
|
17
19
|
CommonModule,
|
|
18
20
|
ProductPageModule,
|
|
19
|
-
|
|
21
|
+
ProductHdModule,
|
|
22
|
+
ProductExternalSourceModule,
|
|
23
|
+
ButtonModule
|
|
20
24
|
],
|
|
21
25
|
declarations: [
|
|
22
26
|
IoneProductComponent
|
|
@@ -24,6 +28,10 @@ IoneProductModule.decorators = [
|
|
|
24
28
|
exports: [
|
|
25
29
|
IoneProductComponent
|
|
26
30
|
],
|
|
31
|
+
schemas: [
|
|
32
|
+
CUSTOM_ELEMENTS_SCHEMA,
|
|
33
|
+
NO_ERRORS_SCHEMA
|
|
34
|
+
],
|
|
27
35
|
bootstrap: [
|
|
28
36
|
IoneProductComponent
|
|
29
37
|
],
|
|
@@ -35,4 +43,4 @@ IoneProductModule.decorators = [
|
|
|
35
43
|
]
|
|
36
44
|
},] }
|
|
37
45
|
];
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uZS1wcm9kdWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcHAvaW9uZS1wcm9kdWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QywrRUFBK0U7QUFDL0UsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDaEYsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDMUUsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDNUUsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFDM0YsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQzFFLE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLHFFQUFxRSxDQUFDO0FBQ2hILE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQStCMUQsTUFBTSxPQUFPLGlCQUFpQjs7O1lBN0I3QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLDBCQUEwQjtvQkFDMUIsWUFBWTtvQkFDWixpQkFBaUI7b0JBQ2pCLGVBQWU7b0JBQ2YsMkJBQTJCO29CQUMzQixZQUFZO2lCQUNiO2dCQUNDLFlBQVksRUFBRTtvQkFDVixvQkFBb0I7aUJBQ3ZCO2dCQUNELE9BQU8sRUFBRTtvQkFDTCxvQkFBb0I7aUJBQ3ZCO2dCQUNELE9BQU8sRUFBRTtvQkFDTCxzQkFBc0I7b0JBQ3RCLGdCQUFnQjtpQkFDbkI7Z0JBQ0QsU0FBUyxFQUFFO29CQUNQLG9CQUFvQjtpQkFDdkI7Z0JBQ0QsU0FBUyxFQUFFO29CQUNQLHNCQUFzQjtvQkFDdEIsdUJBQXVCO29CQUN2QixtQkFBbUI7b0JBQ25CLDhCQUE4QjtpQkFDakM7YUFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTmdNb2R1bGUsIE5PX0VSUk9SU19TQ0hFTUF9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtJb25lUHJvZHVjdENvbXBvbmVudH0gZnJvbSAnLi9pb25lLXByb2R1Y3QuY29tcG9uZW50JztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuLy9pbXBvcnQge0Jyb3dzZXJBbmltYXRpb25zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHtQcm9kdWN0UGFnZU1vZHVsZX0gZnJvbSAnLi9jb21wb25lbnRzL3Byb2R1Y3QtcGFnZS9wcm9kdWN0LXBhZ2UubW9kdWxlJztcbmltcG9ydCB7UHJvZHVjdFNldHRpbmdzU2VydmljZX0gZnJvbSAnLi9zZXJ2aWNlL3Byb2R1Y3Qtc2V0dGluZ3Muc2VydmljZSc7XG5pbXBvcnQge1Byb2R1Y3RDb25uZWN0b3JTZXJ2aWNlfSBmcm9tICcuL3NlcnZpY2UvcHJvZHVjdC1jb25uZWN0b3Iuc2VydmljZSc7XG5pbXBvcnQge1Byb2R1Y3RDb25uZWN0b3JBZGFwdGVyU2VydmljZX0gZnJvbSAnLi9zZXJ2aWNlL3Byb2R1Y3QtY29ubmVjdG9yLWFkYXB0ZXIuc2VydmljZSc7XG5pbXBvcnQge1Byb2R1Y3RFdmVudFNlcnZpY2V9IGZyb20gJy4vc2VydmljZS9wcm9kdWN0LWV2ZW50LnNlcnZpY2UnO1xuaW1wb3J0IHtQcm9kdWN0SGRNb2R1bGV9IGZyb20gJy4vY29tcG9uZW50cy9wcm9kdWN0LWhkL3Byb2R1Y3QtaGQubW9kdWxlJztcbmltcG9ydCB7UHJvZHVjdEV4dGVybmFsU291cmNlTW9kdWxlfSBmcm9tICcuL2NvbXBvbmVudHMvcHJvZHVjdC1leHRlcm5hbC1zb3VyY2UvcHJvZHVjdC1leHRlcm5hbC1zb3VyY2UubW9kdWxlJztcbmltcG9ydCB7QnV0dG9uTW9kdWxlfSBmcm9tICdAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIC8vQnJvd3NlckFuaW1hdGlvbnNNb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFByb2R1Y3RQYWdlTW9kdWxlLFxuICAgIFByb2R1Y3RIZE1vZHVsZSxcbiAgICBQcm9kdWN0RXh0ZXJuYWxTb3VyY2VNb2R1bGUsXG4gICAgQnV0dG9uTW9kdWxlXG4gIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIElvbmVQcm9kdWN0Q29tcG9uZW50XG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIElvbmVQcm9kdWN0Q29tcG9uZW50XG4gICAgXSxcbiAgICBzY2hlbWFzOiBbXG4gICAgICAgIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsXG4gICAgICAgIE5PX0VSUk9SU19TQ0hFTUFcbiAgICBdLFxuICAgIGJvb3RzdHJhcDogW1xuICAgICAgICBJb25lUHJvZHVjdENvbXBvbmVudFxuICAgIF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIFByb2R1Y3RTZXR0aW5nc1NlcnZpY2UsXG4gICAgICAgIFByb2R1Y3RDb25uZWN0b3JTZXJ2aWNlLFxuICAgICAgICBQcm9kdWN0RXZlbnRTZXJ2aWNlLFxuICAgICAgICBQcm9kdWN0Q29ubmVjdG9yQWRhcHRlclNlcnZpY2VcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIElvbmVQcm9kdWN0TW9kdWxlIHtcbn1cbiJdfQ==
|
|
@@ -3,8 +3,8 @@ export class Version {
|
|
|
3
3
|
constructor() {
|
|
4
4
|
this.name = "@colijnit/product";
|
|
5
5
|
this.description = "Product detail page project for iOne";
|
|
6
|
-
this.symVer = "256.1.
|
|
7
|
-
this.publishDate = "
|
|
6
|
+
this.symVer = "256.1.5";
|
|
7
|
+
this.publishDate = "8-2-2025 23:16:14";
|
|
8
8
|
}
|
|
9
9
|
}
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9wcm9kdWN0LXZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELE1BQU0sT0FBTyxPQUFPO0lBQXBCO1FBQ1MsU0FBSSxHQUFHLG1CQUFtQixDQUFDO1FBQzNCLGdCQUFXLEdBQUcsc0NBQXNDLENBQUM7UUFDckQsV0FBTSxHQUFHLFNBQVMsQ0FBQztRQUNuQixnQkFBVyxHQUFHLG1CQUFtQixDQUFDO0lBQzNDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRoaXMgZmlsZSBpcyBkeW5hbWljYWxseSBjcmVhdGVkLCBkbyBub3QgY2hhbmdlIHRoaXNcbmV4cG9ydCBjbGFzcyBWZXJzaW9uIHtcbiAgcHVibGljIG5hbWUgPSBcIkBjb2xpam5pdC9wcm9kdWN0XCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiUHJvZHVjdCBkZXRhaWwgcGFnZSBwcm9qZWN0IGZvciBpT25lXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1Ni4xLjVcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCI4LTItMjAyNSAyMzoxNjoxNFwiO1xufSJdfQ==
|