@colijnit/product 1.9.5 → 2.9.0
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-additional-info/product-additional-info.component.d.ts +4 -3
- package/app/components/product-external-source/product-external-source.component.d.ts +30 -0
- package/app/components/product-external-source/product-external-source.module.d.ts +2 -0
- package/app/components/product-page/product-page.component.d.ts +4 -0
- package/app/components/product-page/product-page.module.d.ts +2 -0
- package/app/ione-product.component.d.ts +1 -3
- package/app/model/{settings.d.ts → productSettings.d.ts} +3 -2
- package/app/pipe/pipe.module.d.ts +2 -0
- package/app/service/product-connector-adapter.service.d.ts +8 -2
- package/app/service/product-connector.service.d.ts +10 -5
- package/app/service/product-settings.service.d.ts +3 -3
- package/bundles/colijnit-product.umd.js +1476 -1262
- package/bundles/colijnit-product.umd.js.map +1 -1
- package/bundles/colijnit-product.umd.min.js +2 -2
- package/bundles/colijnit-product.umd.min.js.map +1 -1
- package/colijnit-product.d.ts +29 -28
- package/colijnit-product.metadata.json +1 -1
- package/esm2015/app/components/product-additional-info/product-additional-info.component.js +23 -16
- package/esm2015/app/components/product-addtocart/product-addtocart.component.js +2 -2
- package/esm2015/app/components/product-delivery/product-delivery.component.js +1 -2
- package/esm2015/app/components/product-external-source/product-external-source.component.js +123 -0
- package/esm2015/app/components/product-external-source/product-external-source.module.js +23 -0
- package/esm2015/app/components/product-page/product-page.component.js +45 -15
- package/esm2015/app/components/product-page/product-page.module.js +66 -0
- package/esm2015/app/ione-product.component.js +38 -19
- package/esm2015/app/ione-product.module.js +8 -61
- package/esm2015/app/model/productSettings.js +16 -0
- package/esm2015/app/pipe/pipe.module.js +20 -0
- package/esm2015/app/product-version.js +3 -3
- package/esm2015/app/service/dictionary.service.js +1 -1
- package/esm2015/app/service/product-connector-adapter.service.js +34 -9
- package/esm2015/app/service/product-connector.service.js +33 -35
- package/esm2015/app/service/product-event.service.js +2 -6
- package/esm2015/app/service/product-settings.service.js +13 -74
- package/esm2015/colijnit-product.js +30 -29
- package/esm2015/public_api.js +3 -1
- package/esm5/app/components/product-additional-info/product-additional-info.component.js +43 -24
- package/esm5/app/components/product-addtocart/product-addtocart.component.js +2 -2
- package/esm5/app/components/product-delivery/product-delivery.component.js +1 -2
- package/esm5/app/components/product-external-source/product-external-source.component.js +126 -0
- package/esm5/app/components/product-external-source/product-external-source.module.js +26 -0
- package/esm5/app/components/product-page/product-page.component.js +49 -15
- package/esm5/app/components/product-page/product-page.module.js +69 -0
- package/esm5/app/ione-product.component.js +47 -20
- package/esm5/app/ione-product.module.js +8 -61
- package/esm5/app/model/productSettings.js +18 -0
- package/esm5/app/pipe/pipe.module.js +23 -0
- package/esm5/app/product-version.js +3 -3
- package/esm5/app/service/dictionary.service.js +1 -1
- package/esm5/app/service/product-connector-adapter.service.js +61 -10
- package/esm5/app/service/product-connector.service.js +65 -52
- package/esm5/app/service/product-event.service.js +2 -6
- package/esm5/app/service/product-settings.service.js +14 -74
- package/esm5/colijnit-product.js +30 -29
- package/esm5/public_api.js +3 -1
- package/fesm2015/colijnit-product.js +1189 -1043
- package/fesm2015/colijnit-product.js.map +1 -1
- package/fesm5/colijnit-product.js +1447 -1234
- package/fesm5/colijnit-product.js.map +1 -1
- package/package.json +5 -4
- package/public_api.d.ts +2 -0
- package/app/service/product-module.service.d.ts +0 -9
- package/esm2015/app/model/settings.js +0 -15
- package/esm2015/app/service/product-module.service.js +0 -39
- package/esm5/app/model/settings.js +0 -17
- package/esm5/app/service/product-module.service.js +0 -50
|
@@ -31,8 +31,8 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
31
31
|
if (_this.selections.nativeElement) {
|
|
32
32
|
_this.selections.nativeElement.forceRenderImage();
|
|
33
33
|
}
|
|
34
|
-
}), this.settingsService.settingsLoaded.subscribe(function (loaded) {
|
|
35
|
-
_this.settingsLoaded =
|
|
34
|
+
}), this.settingsService.settingsLoaded.subscribe(function (loaded) { return _this._handleSettingsLoaded(loaded); }), this._ione.controllerInitialized.subscribe(function (initialized) {
|
|
35
|
+
_this.settingsLoaded = initialized;
|
|
36
36
|
}));
|
|
37
37
|
}
|
|
38
38
|
Object.defineProperty(ProductPageComponent.prototype, "sku", {
|
|
@@ -54,6 +54,23 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
54
54
|
enumerable: true,
|
|
55
55
|
configurable: true
|
|
56
56
|
});
|
|
57
|
+
Object.defineProperty(ProductPageComponent.prototype, "settings", {
|
|
58
|
+
get: function () {
|
|
59
|
+
return this._settings;
|
|
60
|
+
},
|
|
61
|
+
set: function (value) {
|
|
62
|
+
if (value) {
|
|
63
|
+
if (typeof value === 'string') {
|
|
64
|
+
this._settings = JSON.parse(value);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
this._settings = value;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
},
|
|
71
|
+
enumerable: true,
|
|
72
|
+
configurable: true
|
|
73
|
+
});
|
|
57
74
|
Object.defineProperty(ProductPageComponent.prototype, "fullScreen", {
|
|
58
75
|
get: function () {
|
|
59
76
|
return this._fullScreen;
|
|
@@ -90,6 +107,13 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
90
107
|
configurable: true
|
|
91
108
|
});
|
|
92
109
|
ProductPageComponent.prototype.ngOnInit = function () {
|
|
110
|
+
if (this._settings) {
|
|
111
|
+
this.settingsService.settings = undefined;
|
|
112
|
+
this.settingsService.createSettingsFromObject(this._settings);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
this._settings = this.settingsService.settings;
|
|
116
|
+
}
|
|
93
117
|
};
|
|
94
118
|
ProductPageComponent.prototype.ngAfterViewInit = function () {
|
|
95
119
|
};
|
|
@@ -114,6 +138,11 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
114
138
|
ProductPageComponent.prototype.showFullScreen = function () {
|
|
115
139
|
this.fullScreen = !this.fullScreen;
|
|
116
140
|
};
|
|
141
|
+
ProductPageComponent.prototype._handleSettingsLoaded = function (loaded) {
|
|
142
|
+
if (loaded) {
|
|
143
|
+
this._ione.initConnection();
|
|
144
|
+
}
|
|
145
|
+
};
|
|
117
146
|
ProductPageComponent.prototype._getArticle = function () {
|
|
118
147
|
return __awaiter(this, void 0, void 0, function () {
|
|
119
148
|
var _this = this;
|
|
@@ -127,18 +156,20 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
127
156
|
if (init) {
|
|
128
157
|
this._ione.getFullArticle(this._sku).then(function (article) {
|
|
129
158
|
_this.article = article;
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
_this.
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
159
|
+
if (_this.article) {
|
|
160
|
+
_this.configurable = _this.article.goodType === 'B';
|
|
161
|
+
if (_this.configurable) {
|
|
162
|
+
_this.currentView = SelectorType.TwoD;
|
|
163
|
+
}
|
|
164
|
+
_this.threeD = _this.article.is3D;
|
|
165
|
+
_this.selectorType = _this.article.selectorTypeCustomer;
|
|
166
|
+
_this._ione.getDeliveryPrognosis(_this.article.goodId).then(function (stockInfo) {
|
|
167
|
+
var stockAndDelivery = stockInfo;
|
|
168
|
+
_this.stockAndDelivery = new StockAndDelivery(0, stockAndDelivery.returnValue ? stockAndDelivery.returnValue : ' ');
|
|
169
|
+
_this._changeDetector.detectChanges();
|
|
170
|
+
});
|
|
139
171
|
_this._changeDetector.detectChanges();
|
|
140
|
-
}
|
|
141
|
-
_this._changeDetector.detectChanges();
|
|
172
|
+
}
|
|
142
173
|
});
|
|
143
174
|
}
|
|
144
175
|
return [2 /*return*/];
|
|
@@ -168,10 +199,13 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
168
199
|
__decorate([
|
|
169
200
|
Input()
|
|
170
201
|
], ProductPageComponent.prototype, "sku", null);
|
|
202
|
+
__decorate([
|
|
203
|
+
Input()
|
|
204
|
+
], ProductPageComponent.prototype, "settings", null);
|
|
171
205
|
ProductPageComponent = __decorate([
|
|
172
206
|
Component({
|
|
173
207
|
selector: 'app-product-page',
|
|
174
|
-
template: "<div class=\"page-wrapper\">\r\n
|
|
208
|
+
template: "<ng-container *ngIf=\"settingsLoaded\">\r\n <div class=\"page-wrapper\">\r\n <div class=\"page-wrapper-content\">\r\n <div class=\"page-wrapper-left\">\r\n <div class=\"product-image-container\">\r\n <div class=\"product-page-block-selector-type\">\r\n <app-product-selector-type class=\"default-padding\"\r\n [(currentType)]=\"currentView\"\r\n [show2D]=\"configurable\"\r\n [show3D]=\"threeD\"\r\n ></app-product-selector-type>\r\n </div>\r\n <div class=\"product-page-block-image default-padding\" [class.full]=\"fullScreen\">\r\n <app-image-carousel [@toggleVisibilityByState]=\"show2D ? 'show' : 'hide'\" [images]=\"article?.images\" [showRefresh]=\"configurable && threeD\"></app-image-carousel>\r\n <ng-container *ngIf=\"settingsLoaded\">\r\n <threed-configurator #configurator class=\"threed-configurator\"\r\n [class.configurator-full-screen]=\"fullScreen\"\r\n [@toggleVisibilityByState]=\"show3D ? 'show' : 'hide'\"\r\n [@toggleFullScreen]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n ></threed-configurator>\r\n </ng-container>\r\n <co-icon #fullscreenbutton class=\"fullscreen-button\" *ngIf=\"show3D\"\r\n [@toggleTopLeft]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n [iconData]=\"iconCache.getIcon(fullScreenIcon)\"\r\n (click)=\"showFullScreen()\"></co-icon>\r\n <co-icon class=\"threed-watermark\" *ngIf=\"show3D && fullScreen\"\r\n [iconData]=\"iconCache.getIcon(icon.Logo)\"></co-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-right\">\r\n <div class=\"product-page-block-description\">\r\n <app-product-description class=\"default-padding\" [article]=\"article\"></app-product-description>\r\n </div>\r\n <div class=\"product-page-block-additional\">\r\n <div class=\"product-page-block-additional-description\">\r\n <app-product-additional-description class=\"default-padding\" [article]=\"article\"></app-product-additional-description>\r\n </div>\r\n <div class=\"product-page-block-price\" [class.full]=\"configuring\">\r\n <app-product-price class=\"s-padding\" *ngIf=\"!configuring\"\r\n [pricing]=\"article?.pricing\"\r\n [configurable]=\"configurable\"\r\n ></app-product-price>\r\n <ng-container *ngIf=\"settingsLoaded\">\r\n <threed-selections #selections class=\"threed-selections\" [class.show-selections]=\"configuring\" [@toggleFullScreenRight]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n [class.default-padding]=\"!fullScreen\"\r\n [class.show-full-screen]=\"fullScreen\"\r\n [class.mini-scrollbar]=\"fullScreen\"\r\n [sku]=\"sku\"\r\n [settings]=\"settings\"\r\n (onUserActionFromThreeD)=\"configuring = true\"\r\n (instanceSet)=\"setInstance($event)\"\r\n (onImageReceived)=\"appEventService.onImageReceived.next($event)\"\r\n (onRenderStarted)=\"appEventService.onRenderStarted.next()\"\r\n (onDraftRenderImageReceived)=\"appEventService.onDraftRenderImageReceived.next($event)\"\r\n (onArticleReceived)=\"appEventService.onArticleReceived.next($event.detail)\"\r\n (onSelectionsReceived)=\"appEventService.onSelectionsReceived.next($event.detail)\"\r\n (onArticleInfoReceived)=\"appEventService.onArticleInfoReceived.next($event.detail)\"\r\n ></threed-selections>\r\n </ng-container>\r\n </div>\r\n <div class=\"product-page-block-addtocart no-padding product-action-buttons\" *ngIf=\"!configuring\" [@toggleTopRight]=\"fullScreen ? 'fullscreen' : 'halfscreen'\">\r\n <app-product-addtocart\r\n [configurable]=\"configurable\"\r\n [configuring]=\"configuring\"\r\n [article]=\"article\"\r\n (startConfiguration)=\"handleStartConfiguration()\"\r\n ></app-product-addtocart>\r\n </div>\r\n <div class=\"addtocart-reserved product-action-buttons\" *ngIf=\"configuring\" [class.full-screen]=\"fullScreen\">\r\n <app-product-addtocart class=\"default-padding\"\r\n [configurable]=\"false\"\r\n [fullscreen]=\"fullScreen\"\r\n [configuring]=\"configuring\"\r\n [article]=\"article\"\r\n (startConfiguration)=\"handleStartConfiguration()\"\r\n ></app-product-addtocart>\r\n </div>\r\n <div class=\"product-page-block-variants\">\r\n <app-product-related class=\"no-padding\" *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [articles]=\"article?.relatedArticles\" [refType]=\"64\" [label]=\"'VARIANTS' | localize\"></app-product-related>\r\n </div>\r\n <div class=\"product-page-block-stock\">\r\n <app-product-stock class=\"no-padding\" [stockAndDelivery]=\"stockAndDelivery\"></app-product-stock>\r\n </div>\r\n <div class=\"product-page-block-delivery\">\r\n <app-product-delivery class=\"no-padding\" [stockAndDelivery]=\"stockAndDelivery\"></app-product-delivery>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-content\">\r\n <div class=\"page-wrapper-left\">\r\n <app-product-info-tabs class=\"no-padding\" [article]=\"article\"></app-product-info-tabs>\r\n </div>\r\n <div class=\"page-wrapper-right\">\r\n <div class=\"product-page-block-related s-padding\">\r\n <app-product-related *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [articles]=\"article?.relatedArticles\" [refType]=\"1\" [label]=\"'RELATED_PRODUCTS' | localize\"></app-product-related>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-content no-top-margin\">\r\n <div class=\"page-wrapper-full\">\r\n <div class=\"product-page-block-alternatives s-padding\">\r\n <app-product-related *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [articles]=\"article?.relatedArticles\" [refType]=\"4\" [isSmallModus]=\"false\" [label]=\"'ALTERNATIVE_PRODUCTS' | localize\"></app-product-related>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-container>\r\n",
|
|
175
209
|
animations: [
|
|
176
210
|
trigger('toggleFullScreen', [
|
|
177
211
|
state('fullscreen', style({ 'position': 'fixed', 'top': '0', 'left': '0', 'width': '100%', 'height': '100%' })),
|
|
@@ -210,4 +244,4 @@ var ProductPageComponent = /** @class */ (function () {
|
|
|
210
244
|
return ProductPageComponent;
|
|
211
245
|
}());
|
|
212
246
|
export { ProductPageComponent };
|
|
213
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-page.component.js","sourceRoot":"ng://@colijnit/product/","sources":["app/components/product-page/product-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport { Subscription } from 'rxjs';\nimport { StockAndDelivery } from '../../model/stock-and-delivery';\nimport { SelectorType } from '../../enum/selector-type.enum';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport { ProductSettingsService } from '../../service/product-settings.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport {DeliveryPrognosis} from '@colijnit/articleapi/build/model/delivery-prognosis';\n\n@Component({\n  selector: 'app-product-page',\n  templateUrl: './product-page.component.html',\n  styleUrls: ['./product-page.component.scss'],\n  animations: [\n    trigger('toggleFullScreen', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0', 'width': '100%', 'height': '100%'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'left': '*', 'width': '*', 'height': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopLeft', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0'})),\n      state('halfscreen', style({'position': 'absolute', 'top': '*', 'left': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopRight', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleFullScreenRight', [\n      state('fullscreen', style({'position': 'fixed', 'width': '400px', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'width': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleVisibilityByState', [\n      state('hide', style({'opacity': '0', 'display': 'none'})),\n      state('show', style({'display': 'block', 'opacity': '1'})),\n      transition('hide <=> show', animate('200ms 100ms ease-in-out')),\n    ]),\n    trigger('toggleVisibility', [\n      state('void', style({'opacity': '0'})),\n      state('*', style({'opacity': '1'})),\n      transition('void => *', animate('200ms ease-in-out')),\n    ])\n  ]\n})\nexport class ProductPageComponent implements OnInit, OnDestroy, AfterViewInit {\n\n  public readonly icon: typeof IconEnum = IconEnum;\n\n  @ViewChild('configurator', { read: ElementRef })\n  public configurator: ElementRef;\n\n  @ViewChild('selections', { read: ElementRef })\n  public selections: ElementRef;\n\n  @ViewChild('fullscreenbutton', { read: ElementRef })\n  public fullscreenbutton: ElementRef;\n\n  @Input()\n  public set sku(value: string) {\n    if (value) {\n      if (this.configuring) {\n        this.show3D = false;\n        this.fullScreen = false;\n        this.configuring = false;\n        this._changeDetector.detectChanges();\n      }\n      this._sku = value;\n      this._getArticle();\n    }\n  }\n\n  public get sku(): string {\n    return this._sku;\n  }\n\n  public set fullScreen(value: boolean) {\n    this._fullScreen = value;\n    this.fullscreenAnimationEnd = true;\n    this._changeDetector.detectChanges();\n    // setTimeout(() => {\n    //   this.fullscreenAnimationEnd = true;\n    // }, 400)\n  }\n\n  public get fullScreen(): boolean {\n    return this._fullScreen;\n  }\n\n  public get fullScreenIcon(): IconEnum {\n    return this.fullScreen ? this.icon.NormalScreen : this.icon.FullScreen;\n  }\n\n  public set currentView(value: SelectorType) {\n    this._currentView = value;\n    this.show2D = this._currentView === SelectorType.TwoD;\n    this.show3D = this._currentView === SelectorType.ThreeD;\n    this._changeDetector.detectChanges();\n  }\n\n  public get currentView(): SelectorType {\n    return this._currentView;\n  }\n\n  public article: ArticleFullObject;\n  public stockAndDelivery: StockAndDelivery;\n  public configurable = false;\n  public threeD = false;\n  public selectorType: SelectorType;\n  public show2D = true;\n  public show3D = false;\n  public configuring: boolean = false;\n  public fullscreenAnimationEnd: boolean = false;\n  public settingsLoaded: boolean = false;\n  private _sku: string;\n  private _initializedSub: Subscription;\n  private _fullScreen: boolean = false;\n  private _currentView: SelectorType;\n  private _subs: Subscription[] = [];\n\n  constructor(private _ione: ProductConnectorService,\n              private _renderer: Renderer2,\n              private _changeDetector: ChangeDetectorRef,\n              public iconCache: IconCacheService,\n              public settingsService: ProductSettingsService,\n              public appEventService: ProductEventService\n  ) {\n    this._subs.push(\n      this.appEventService.onForceRenderImage.subscribe((x) => {\n        if (this.selections.nativeElement){\n          this.selections.nativeElement.forceRenderImage();\n        }\n      }),\n      this.settingsService.settingsLoaded.subscribe((loaded: boolean) => {\n        this.settingsLoaded = loaded;\n      })\n    );\n\n  }\n\n  ngOnInit() {\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this.configurator = undefined;\n    this.selections = undefined;\n    this.fullscreenbutton = undefined;\n  }\n\n  public setInstance(event: CustomEvent): void {\n    if (event.detail) {\n      this._ione.setInstance(event.detail);\n    }\n  }\n\n  public handleStartConfiguration(): void {\n    this.configuring = true;\n    this._changeDetector.detectChanges();\n  }\n\n  public showFullScreen(): void {\n    this.fullScreen = !this.fullScreen;\n  }\n\n  private async _getArticle(): Promise<void> {\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this._initializedSub = this._ione.controllerInitialized.subscribe(async (init: boolean) => {\n      if (init) {\n        this._ione.getFullArticle(this._sku).then((article: ArticleFullObject) => {\n          this.article = article;\n          this.configurable = this.article.goodType === 'B';\n          if (this.configurable) {\n            this.currentView = SelectorType.TwoD;\n          }\n          this.threeD = this.article.is3D;\n          this.selectorType = this.article.selectorTypeCustomer;\n          this._ione.getDeliveryPrognosis(this.article.goodId).then((stockInfo: DeliveryPrognosis) => {\n            const stockAndDelivery: DeliveryPrognosis = stockInfo;\n            this.stockAndDelivery = new StockAndDelivery(0, stockAndDelivery.returnValue ? stockAndDelivery.returnValue : ' ');\n            this._changeDetector.detectChanges();\n          });\n          this._changeDetector.detectChanges();\n        });\n      }\n    });\n  }\n\n}\n"]}
|
|
247
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-page.component.js","sourceRoot":"ng://@colijnit/product/","sources":["app/components/product-page/product-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport { Subscription } from 'rxjs';\nimport { StockAndDelivery } from '../../model/stock-and-delivery';\nimport { SelectorType } from '../../enum/selector-type.enum';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport { ProductSettingsService } from '../../service/product-settings.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport {DeliveryPrognosis} from '@colijnit/articleapi/build/model/delivery-prognosis';\n\n@Component({\n  selector: 'app-product-page',\n  templateUrl: './product-page.component.html',\n  styleUrls: ['./product-page.component.scss'],\n  animations: [\n    trigger('toggleFullScreen', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0', 'width': '100%', 'height': '100%'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'left': '*', 'width': '*', 'height': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopLeft', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0'})),\n      state('halfscreen', style({'position': 'absolute', 'top': '*', 'left': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopRight', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleFullScreenRight', [\n      state('fullscreen', style({'position': 'fixed', 'width': '400px', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'width': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleVisibilityByState', [\n      state('hide', style({'opacity': '0', 'display': 'none'})),\n      state('show', style({'display': 'block', 'opacity': '1'})),\n      transition('hide <=> show', animate('200ms 100ms ease-in-out')),\n    ]),\n    trigger('toggleVisibility', [\n      state('void', style({'opacity': '0'})),\n      state('*', style({'opacity': '1'})),\n      transition('void => *', animate('200ms ease-in-out')),\n    ])\n  ]\n})\nexport class ProductPageComponent implements OnInit, OnDestroy, AfterViewInit {\n\n  public readonly icon: typeof IconEnum = IconEnum;\n\n  @ViewChild('configurator', { read: ElementRef })\n  public configurator: ElementRef;\n\n  @ViewChild('selections', { read: ElementRef })\n  public selections: ElementRef;\n\n  @ViewChild('fullscreenbutton', { read: ElementRef })\n  public fullscreenbutton: ElementRef;\n\n  @Input()\n  public set sku(value: string) {\n    if (value) {\n      if (this.configuring) {\n        this.show3D = false;\n        this.fullScreen = false;\n        this.configuring = false;\n        this._changeDetector.detectChanges();\n      }\n      this._sku = value;\n      this._getArticle();\n    }\n  }\n\n  public get sku(): string {\n    return this._sku;\n  }\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  public set fullScreen(value: boolean) {\n    this._fullScreen = value;\n    this.fullscreenAnimationEnd = true;\n    this._changeDetector.detectChanges();\n    // setTimeout(() => {\n    //   this.fullscreenAnimationEnd = true;\n    // }, 400)\n  }\n\n  public get fullScreen(): boolean {\n    return this._fullScreen;\n  }\n\n  public get fullScreenIcon(): IconEnum {\n    return this.fullScreen ? this.icon.NormalScreen : this.icon.FullScreen;\n  }\n\n  public set currentView(value: SelectorType) {\n    this._currentView = value;\n    this.show2D = this._currentView === SelectorType.TwoD;\n    this.show3D = this._currentView === SelectorType.ThreeD;\n    this._changeDetector.detectChanges();\n  }\n\n  public get currentView(): SelectorType {\n    return this._currentView;\n  }\n\n  public article: ArticleFullObject;\n  public stockAndDelivery: StockAndDelivery;\n  public configurable = false;\n  public threeD = false;\n  public selectorType: SelectorType;\n  public show2D = true;\n  public show3D = false;\n  public configuring: boolean = false;\n  public fullscreenAnimationEnd: boolean = false;\n  public settingsLoaded: boolean = false;\n  private _sku: string;\n  private _initializedSub: Subscription;\n  private _fullScreen: boolean = false;\n  private _currentView: SelectorType;\n  private _subs: Subscription[] = [];\n  private _settings: any;\n\n  constructor(private _ione: ProductConnectorService,\n              private _renderer: Renderer2,\n              private _changeDetector: ChangeDetectorRef,\n              public iconCache: IconCacheService,\n              public settingsService: ProductSettingsService,\n              public appEventService: ProductEventService\n  ) {\n    this._subs.push(\n      this.appEventService.onForceRenderImage.subscribe((x) => {\n        if (this.selections.nativeElement) {\n          this.selections.nativeElement.forceRenderImage();\n        }\n      }),\n        this.settingsService.settingsLoaded.subscribe(loaded => this._handleSettingsLoaded(loaded)),\n        this._ione.controllerInitialized.subscribe((initialized: boolean) => {\n        this.settingsLoaded = initialized;\n      })\n    );\n\n  }\n\n  ngOnInit() {\n    if (this._settings) {\n      this.settingsService.settings = undefined;\n      this.settingsService.createSettingsFromObject(this._settings);\n    } else {\n      this._settings = this.settingsService.settings;\n    }\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this.configurator = undefined;\n    this.selections = undefined;\n    this.fullscreenbutton = undefined;\n  }\n\n  public setInstance(event: CustomEvent): void {\n    if (event.detail) {\n      this._ione.setInstance(event.detail);\n    }\n  }\n\n  public handleStartConfiguration(): void {\n    this.configuring = true;\n    this._changeDetector.detectChanges();\n  }\n\n  public showFullScreen(): void {\n    this.fullScreen = !this.fullScreen;\n  }\n\n  private _handleSettingsLoaded(loaded: boolean): void {\n    if (loaded) {\n      this._ione.initConnection();\n    }\n  }\n\n  private async _getArticle(): Promise<void> {\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this._initializedSub = this._ione.controllerInitialized.subscribe(async (init: boolean) => {\n      if (init) {\n        this._ione.getFullArticle(this._sku).then((article: ArticleFullObject) => {\n          this.article = article;\n          if (this.article) {\n            this.configurable = this.article.goodType === 'B';\n            if (this.configurable) {\n              this.currentView = SelectorType.TwoD;\n            }\n            this.threeD = this.article.is3D;\n            this.selectorType = this.article.selectorTypeCustomer;\n            this._ione.getDeliveryPrognosis(this.article.goodId).then((stockInfo: DeliveryPrognosis) => {\n              const stockAndDelivery: DeliveryPrognosis = stockInfo;\n              this.stockAndDelivery = new StockAndDelivery(0, stockAndDelivery.returnValue ? stockAndDelivery.returnValue : ' ');\n              this._changeDetector.detectChanges();\n            });\n            this._changeDetector.detectChanges();\n          }\n        });\n      }\n    });\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { ProductPageComponent } from './product-page.component';
|
|
5
|
+
import { ProductSelectorTypeComponent } from '../product-selector-type/product-selector-type.component';
|
|
6
|
+
import { ImageCarouselComponent } from '../image-carousel/image-carousel.component';
|
|
7
|
+
import { ArticleTileModule, ButtonModule, FilesUploadModule, IconModule, InputTextModule, LevelIndicatorModule, LoaderModule, NumberPickerModule, PriceDisplayPipeModule, ScrollContainerModule, TileModule } from '@colijnit/corecomponents';
|
|
8
|
+
import { ProductDescriptionComponent } from '../product-description/product-description.component';
|
|
9
|
+
import { ProductAdditionalDescriptionComponent } from '../product-additional-description/product-additional-description.component';
|
|
10
|
+
import { ProductPriceComponent } from '../product-price/product-price.component';
|
|
11
|
+
import { ProductAddtocartComponent } from '../product-addtocart/product-addtocart.component';
|
|
12
|
+
import { ProductRelatedComponent } from '../product-related/product-related.component';
|
|
13
|
+
import { ProductStockComponent } from '../product-stock/product-stock.component';
|
|
14
|
+
import { ProductDeliveryComponent } from '../product-delivery/product-delivery.component';
|
|
15
|
+
import { ProductInfoTabsComponent } from '../product-info-tabs/product-info-tabs.component';
|
|
16
|
+
import { PipeModule } from '../../pipe/pipe.module';
|
|
17
|
+
import { ProductDocumentsComponent } from '../product-documents/product-documents.component';
|
|
18
|
+
import { HeaderComponent } from '../core/header/header.component';
|
|
19
|
+
import { ProductInfoComponent } from '../product-info/product-info.component';
|
|
20
|
+
import { ProductAdditionalInfoComponent } from '../product-additional-info/product-additional-info.component';
|
|
21
|
+
import { ProductPropertiesComponent } from '../product-properties/product-properties.component';
|
|
22
|
+
import { ProductSymbolsComponent } from '../product-symbols/product-symbols.component';
|
|
23
|
+
var ProductPageModule = /** @class */ (function () {
|
|
24
|
+
function ProductPageModule() {
|
|
25
|
+
}
|
|
26
|
+
ProductPageModule = __decorate([
|
|
27
|
+
NgModule({
|
|
28
|
+
imports: [
|
|
29
|
+
CommonModule,
|
|
30
|
+
IconModule,
|
|
31
|
+
LoaderModule,
|
|
32
|
+
PipeModule,
|
|
33
|
+
NumberPickerModule,
|
|
34
|
+
ButtonModule,
|
|
35
|
+
PriceDisplayPipeModule,
|
|
36
|
+
InputTextModule,
|
|
37
|
+
FilesUploadModule,
|
|
38
|
+
ScrollContainerModule,
|
|
39
|
+
TileModule,
|
|
40
|
+
LevelIndicatorModule,
|
|
41
|
+
ArticleTileModule,
|
|
42
|
+
],
|
|
43
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
44
|
+
declarations: [
|
|
45
|
+
ProductPageComponent,
|
|
46
|
+
ProductSelectorTypeComponent,
|
|
47
|
+
ImageCarouselComponent,
|
|
48
|
+
ProductDescriptionComponent,
|
|
49
|
+
ProductAdditionalDescriptionComponent,
|
|
50
|
+
ProductPriceComponent,
|
|
51
|
+
ProductAddtocartComponent,
|
|
52
|
+
ProductRelatedComponent,
|
|
53
|
+
ProductStockComponent,
|
|
54
|
+
ProductDeliveryComponent,
|
|
55
|
+
ProductInfoTabsComponent,
|
|
56
|
+
ProductDocumentsComponent,
|
|
57
|
+
HeaderComponent,
|
|
58
|
+
ProductInfoComponent,
|
|
59
|
+
ProductAdditionalInfoComponent,
|
|
60
|
+
ProductPropertiesComponent,
|
|
61
|
+
ProductSymbolsComponent
|
|
62
|
+
],
|
|
63
|
+
exports: [ProductPageComponent]
|
|
64
|
+
})
|
|
65
|
+
], ProductPageModule);
|
|
66
|
+
return ProductPageModule;
|
|
67
|
+
}());
|
|
68
|
+
export { ProductPageModule };
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1wYWdlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bjb2xpam5pdC9wcm9kdWN0LyIsInNvdXJjZXMiOlsiYXBwL2NvbXBvbmVudHMvcHJvZHVjdC1wYWdlL3Byb2R1Y3QtcGFnZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBQyxzQkFBc0IsRUFBRSxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0QsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLDBEQUEwRCxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ2xGLE9BQU8sRUFDSCxpQkFBaUIsRUFDakIsWUFBWSxFQUNaLGlCQUFpQixFQUNqQixVQUFVLEVBQ1YsZUFBZSxFQUNmLG9CQUFvQixFQUNwQixZQUFZLEVBQ1osa0JBQWtCLEVBQ2xCLHNCQUFzQixFQUN0QixxQkFBcUIsRUFDckIsVUFBVSxFQUNiLE1BQU0sMEJBQTBCLENBQUM7QUFDbEMsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFDakcsT0FBTyxFQUFDLHFDQUFxQyxFQUFDLE1BQU0sNEVBQTRFLENBQUM7QUFDakksT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDL0UsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sa0RBQWtELENBQUM7QUFDM0YsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDckYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDL0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDeEYsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sa0RBQWtELENBQUM7QUFDMUYsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQzNGLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUNoRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsOEJBQThCLEVBQUMsTUFBTSw4REFBOEQsQ0FBQztBQUM1RyxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxvREFBb0QsQ0FBQztBQUM5RixPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQXdDckY7SUFBQTtJQUNBLENBQUM7SUFEWSxpQkFBaUI7UUF0QzdCLFFBQVEsQ0FBQztZQUNOLE9BQU8sRUFBRTtnQkFDTCxZQUFZO2dCQUNaLFVBQVU7Z0JBQ1YsWUFBWTtnQkFDWixVQUFVO2dCQUNWLGtCQUFrQjtnQkFDbEIsWUFBWTtnQkFDWixzQkFBc0I7Z0JBQ3RCLGVBQWU7Z0JBQ2YsaUJBQWlCO2dCQUNqQixxQkFBcUI7Z0JBQ3JCLFVBQVU7Z0JBQ1Ysb0JBQW9CO2dCQUNwQixpQkFBaUI7YUFDcEI7WUFDRCxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztZQUNqQyxZQUFZLEVBQUU7Z0JBQ1Ysb0JBQW9CO2dCQUNwQiw0QkFBNEI7Z0JBQzVCLHNCQUFzQjtnQkFDdEIsMkJBQTJCO2dCQUMzQixxQ0FBcUM7Z0JBQ3JDLHFCQUFxQjtnQkFDckIseUJBQXlCO2dCQUN6Qix1QkFBdUI7Z0JBQ3ZCLHFCQUFxQjtnQkFDckIsd0JBQXdCO2dCQUN4Qix3QkFBd0I7Z0JBQ3hCLHlCQUF5QjtnQkFDekIsZUFBZTtnQkFDZixvQkFBb0I7Z0JBQ3BCLDhCQUE4QjtnQkFDOUIsMEJBQTBCO2dCQUMxQix1QkFBdUI7YUFDMUI7WUFDRCxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztTQUNsQyxDQUFDO09BQ1csaUJBQWlCLENBQzdCO0lBQUQsd0JBQUM7Q0FBQSxBQURELElBQ0M7U0FEWSxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7UHJvZHVjdFBhZ2VDb21wb25lbnR9IGZyb20gJy4vcHJvZHVjdC1wYWdlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdFNlbGVjdG9yVHlwZUNvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1zZWxlY3Rvci10eXBlL3Byb2R1Y3Qtc2VsZWN0b3ItdHlwZS5jb21wb25lbnQnO1xyXG5pbXBvcnQge0ltYWdlQ2Fyb3VzZWxDb21wb25lbnR9IGZyb20gJy4uL2ltYWdlLWNhcm91c2VsL2ltYWdlLWNhcm91c2VsLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7XHJcbiAgICBBcnRpY2xlVGlsZU1vZHVsZSxcclxuICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgIEZpbGVzVXBsb2FkTW9kdWxlLFxyXG4gICAgSWNvbk1vZHVsZSxcclxuICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgIExldmVsSW5kaWNhdG9yTW9kdWxlLFxyXG4gICAgTG9hZGVyTW9kdWxlLFxyXG4gICAgTnVtYmVyUGlja2VyTW9kdWxlLFxyXG4gICAgUHJpY2VEaXNwbGF5UGlwZU1vZHVsZSxcclxuICAgIFNjcm9sbENvbnRhaW5lck1vZHVsZSxcclxuICAgIFRpbGVNb2R1bGVcclxufSBmcm9tICdAY29saWpuaXQvY29yZWNvbXBvbmVudHMnO1xyXG5pbXBvcnQge1Byb2R1Y3REZXNjcmlwdGlvbkNvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1kZXNjcmlwdGlvbi9wcm9kdWN0LWRlc2NyaXB0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdEFkZGl0aW9uYWxEZXNjcmlwdGlvbkNvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uL3Byb2R1Y3QtYWRkaXRpb25hbC1kZXNjcmlwdGlvbi5jb21wb25lbnQnO1xyXG5pbXBvcnQge1Byb2R1Y3RQcmljZUNvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1wcmljZS9wcm9kdWN0LXByaWNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdEFkZHRvY2FydENvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1hZGR0b2NhcnQvcHJvZHVjdC1hZGR0b2NhcnQuY29tcG9uZW50JztcclxuaW1wb3J0IHtQcm9kdWN0UmVsYXRlZENvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1yZWxhdGVkL3Byb2R1Y3QtcmVsYXRlZC5jb21wb25lbnQnO1xyXG5pbXBvcnQge1Byb2R1Y3RTdG9ja0NvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1zdG9jay9wcm9kdWN0LXN0b2NrLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdERlbGl2ZXJ5Q29tcG9uZW50fSBmcm9tICcuLi9wcm9kdWN0LWRlbGl2ZXJ5L3Byb2R1Y3QtZGVsaXZlcnkuY29tcG9uZW50JztcclxuaW1wb3J0IHtQcm9kdWN0SW5mb1RhYnNDb21wb25lbnR9IGZyb20gJy4uL3Byb2R1Y3QtaW5mby10YWJzL3Byb2R1Y3QtaW5mby10YWJzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UGlwZU1vZHVsZX0gZnJvbSAnLi4vLi4vcGlwZS9waXBlLm1vZHVsZSc7XHJcbmltcG9ydCB7UHJvZHVjdERvY3VtZW50c0NvbXBvbmVudH0gZnJvbSAnLi4vcHJvZHVjdC1kb2N1bWVudHMvcHJvZHVjdC1kb2N1bWVudHMuY29tcG9uZW50JztcclxuaW1wb3J0IHtIZWFkZXJDb21wb25lbnR9IGZyb20gJy4uL2NvcmUvaGVhZGVyL2hlYWRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQge1Byb2R1Y3RJbmZvQ29tcG9uZW50fSBmcm9tICcuLi9wcm9kdWN0LWluZm8vcHJvZHVjdC1pbmZvLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdEFkZGl0aW9uYWxJbmZvQ29tcG9uZW50fSBmcm9tICcuLi9wcm9kdWN0LWFkZGl0aW9uYWwtaW5mby9wcm9kdWN0LWFkZGl0aW9uYWwtaW5mby5jb21wb25lbnQnO1xyXG5pbXBvcnQge1Byb2R1Y3RQcm9wZXJ0aWVzQ29tcG9uZW50fSBmcm9tICcuLi9wcm9kdWN0LXByb3BlcnRpZXMvcHJvZHVjdC1wcm9wZXJ0aWVzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdFN5bWJvbHNDb21wb25lbnR9IGZyb20gJy4uL3Byb2R1Y3Qtc3ltYm9scy9wcm9kdWN0LXN5bWJvbHMuY29tcG9uZW50JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgTG9hZGVyTW9kdWxlLFxyXG4gICAgICAgIFBpcGVNb2R1bGUsXHJcbiAgICAgICAgTnVtYmVyUGlja2VyTW9kdWxlLFxyXG4gICAgICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgICAgICBQcmljZURpc3BsYXlQaXBlTW9kdWxlLFxyXG4gICAgICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgICAgICBGaWxlc1VwbG9hZE1vZHVsZSxcclxuICAgICAgICBTY3JvbGxDb250YWluZXJNb2R1bGUsXHJcbiAgICAgICAgVGlsZU1vZHVsZSxcclxuICAgICAgICBMZXZlbEluZGljYXRvck1vZHVsZSxcclxuICAgICAgICBBcnRpY2xlVGlsZU1vZHVsZSxcclxuICAgIF0sXHJcbiAgICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgICBQcm9kdWN0UGFnZUNvbXBvbmVudCxcclxuICAgICAgICBQcm9kdWN0U2VsZWN0b3JUeXBlQ29tcG9uZW50LFxyXG4gICAgICAgIEltYWdlQ2Fyb3VzZWxDb21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdERlc2NyaXB0aW9uQ29tcG9uZW50LFxyXG4gICAgICAgIFByb2R1Y3RBZGRpdGlvbmFsRGVzY3JpcHRpb25Db21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdFByaWNlQ29tcG9uZW50LFxyXG4gICAgICAgIFByb2R1Y3RBZGR0b2NhcnRDb21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdFJlbGF0ZWRDb21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdFN0b2NrQ29tcG9uZW50LFxyXG4gICAgICAgIFByb2R1Y3REZWxpdmVyeUNvbXBvbmVudCxcclxuICAgICAgICBQcm9kdWN0SW5mb1RhYnNDb21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdERvY3VtZW50c0NvbXBvbmVudCxcclxuICAgICAgICBIZWFkZXJDb21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdEluZm9Db21wb25lbnQsXHJcbiAgICAgICAgUHJvZHVjdEFkZGl0aW9uYWxJbmZvQ29tcG9uZW50LFxyXG4gICAgICAgIFByb2R1Y3RQcm9wZXJ0aWVzQ29tcG9uZW50LFxyXG4gICAgICAgIFByb2R1Y3RTeW1ib2xzQ29tcG9uZW50XHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW1Byb2R1Y3RQYWdlQ29tcG9uZW50XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUHJvZHVjdFBhZ2VNb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -5,6 +5,7 @@ import { ProductConnectorService } from './service/product-connector.service';
|
|
|
5
5
|
import { DictionaryService } from './service/dictionary.service';
|
|
6
6
|
import { ProductEventService } from './service/product-event.service';
|
|
7
7
|
import { ProductSettingsService } from './service/product-settings.service';
|
|
8
|
+
import { ProductConnectorAdapterService } from './service/product-connector-adapter.service';
|
|
8
9
|
var IoneProductComponent = /** @class */ (function () {
|
|
9
10
|
function IoneProductComponent(_dictionary, _jsonUtils, _ione, _changeDetector, _appEventService, _settingsService) {
|
|
10
11
|
// this.sku = 'CF-HILL';
|
|
@@ -13,6 +14,7 @@ var IoneProductComponent = /** @class */ (function () {
|
|
|
13
14
|
// this.sku = 'CF-22346001';
|
|
14
15
|
// this.sku = '104';
|
|
15
16
|
// this.sku = '1000561986';
|
|
17
|
+
// this.sku = '1000567768';
|
|
16
18
|
// this.sku = '1000234793';
|
|
17
19
|
// this.sku = '1066';
|
|
18
20
|
// this.sku = '104';
|
|
@@ -30,11 +32,13 @@ var IoneProductComponent = /** @class */ (function () {
|
|
|
30
32
|
this.onArticleReceived = new EventEmitter();
|
|
31
33
|
this.onSelectionsReceived = new EventEmitter();
|
|
32
34
|
this.onAddToQuote = new EventEmitter();
|
|
33
|
-
this.upAndLoaded = false;
|
|
34
35
|
this._subs = [];
|
|
35
|
-
this.
|
|
36
|
+
// this.sku = "70000107";
|
|
37
|
+
this._subs.push(
|
|
36
38
|
// this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),
|
|
37
|
-
this._appEventService.onAddToCart.subscribe(function (json) {
|
|
39
|
+
this._appEventService.onAddToCart.subscribe(function (json) {
|
|
40
|
+
_this._handleAddToCart(json);
|
|
41
|
+
}), this._appEventService.onAddToQuote.subscribe(function (json) { return _this.onAddToQuote.emit(json); }), this._appEventService.onAlternativeClick.subscribe(function (article) { return _this.onAlternativeClick.emit(article); }), this._appEventService.onArticleInfoReceived.subscribe(function (info) { return _this._handleAnswerInfoReceived(info); }), this._appEventService.onArticleReceived.subscribe(function (article) { return _this.onArticleReceived.emit(article); }), this._appEventService.onSelectionsReceived.subscribe(function (selections) { return _this.onSelectionsReceived.emit(selections); }));
|
|
38
42
|
}
|
|
39
43
|
Object.defineProperty(IoneProductComponent.prototype, "settings", {
|
|
40
44
|
get: function () {
|
|
@@ -62,26 +66,43 @@ var IoneProductComponent = /** @class */ (function () {
|
|
|
62
66
|
IoneProductComponent.prototype.ngOnDestroy = function () {
|
|
63
67
|
this._subs.forEach(function (s) { return s.unsubscribe(); });
|
|
64
68
|
};
|
|
65
|
-
IoneProductComponent.prototype._handleSettingsLoaded = function (loaded) {
|
|
66
|
-
if (loaded) {
|
|
67
|
-
this.upAndLoaded = true;
|
|
68
|
-
this._initConnection();
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
69
|
IoneProductComponent.prototype._handleAnswerInfoReceived = function (info) {
|
|
72
70
|
this.onArticleInfoReceived.next(info);
|
|
73
71
|
};
|
|
74
|
-
|
|
75
|
-
IoneProductComponent.prototype._initConnection = function () {
|
|
72
|
+
IoneProductComponent.prototype._handleAddToCart = function (json) {
|
|
76
73
|
return __awaiter(this, void 0, void 0, function () {
|
|
77
|
-
var
|
|
74
|
+
var articleTreeData, i, good, subArticle;
|
|
78
75
|
return __generator(this, function (_a) {
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
76
|
+
switch (_a.label) {
|
|
77
|
+
case 0:
|
|
78
|
+
if (!this._settingsService.settings.createWebOrder) return [3 /*break*/, 7];
|
|
79
|
+
if (!json) return [3 /*break*/, 7];
|
|
80
|
+
articleTreeData = JSON.parse(json);
|
|
81
|
+
if (!(articleTreeData.articleTree && articleTreeData.articleTree.article)) return [3 /*break*/, 7];
|
|
82
|
+
if (!(articleTreeData.articleTree.compositeGoods && Array.isArray(articleTreeData.articleTree.compositeGoods) &&
|
|
83
|
+
articleTreeData.articleTree.compositeGoods.length > 0 && articleTreeData.articleTree.subArticles && Array.isArray(articleTreeData.articleTree.subArticles))) return [3 /*break*/, 5];
|
|
84
|
+
i = 0;
|
|
85
|
+
_a.label = 1;
|
|
86
|
+
case 1:
|
|
87
|
+
if (!(i < articleTreeData.articleTree.compositeGoods.length - 1)) return [3 /*break*/, 4];
|
|
88
|
+
good = articleTreeData.articleTree.compositeGoods[i];
|
|
89
|
+
subArticle = articleTreeData.articleTree.subArticles[i];
|
|
90
|
+
return [4 /*yield*/, this._ione.addWebSessionTransactionLine(subArticle.articleNumber, good.quantity)];
|
|
91
|
+
case 2:
|
|
92
|
+
_a.sent();
|
|
93
|
+
_a.label = 3;
|
|
94
|
+
case 3:
|
|
95
|
+
i++;
|
|
96
|
+
return [3 /*break*/, 1];
|
|
97
|
+
case 4: return [3 /*break*/, 7];
|
|
98
|
+
case 5: return [4 /*yield*/, this._ione.addWebSessionTransactionLine(articleTreeData.articleTree.article.articleNumber, 1)];
|
|
99
|
+
case 6:
|
|
100
|
+
_a.sent();
|
|
101
|
+
_a.label = 7;
|
|
102
|
+
case 7:
|
|
103
|
+
this.onAddToCart.emit(json);
|
|
104
|
+
return [2 /*return*/];
|
|
105
|
+
}
|
|
85
106
|
});
|
|
86
107
|
});
|
|
87
108
|
};
|
|
@@ -123,7 +144,13 @@ var IoneProductComponent = /** @class */ (function () {
|
|
|
123
144
|
IoneProductComponent = __decorate([
|
|
124
145
|
Component({
|
|
125
146
|
selector: 'app-ione-product',
|
|
126
|
-
template: "<app-product-page
|
|
147
|
+
template: "\n <app-product-page [sku]=\"sku\"\n ></app-product-page>\n ",
|
|
148
|
+
providers: [
|
|
149
|
+
ProductEventService,
|
|
150
|
+
ProductSettingsService,
|
|
151
|
+
ProductConnectorAdapterService,
|
|
152
|
+
ProductConnectorService
|
|
153
|
+
],
|
|
127
154
|
encapsulation: ViewEncapsulation.Emulated,
|
|
128
155
|
styles: [""]
|
|
129
156
|
})
|
|
@@ -131,4 +158,4 @@ var IoneProductComponent = /** @class */ (function () {
|
|
|
131
158
|
return IoneProductComponent;
|
|
132
159
|
}());
|
|
133
160
|
export { IoneProductComponent };
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ione-product.component.js","sourceRoot":"ng://@colijnit/product/","sources":["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  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';\n\n@Component({\n  selector: 'app-ione-product',\n  templateUrl: './ione-product.component.html',\n  styleUrls: ['./ione-product.component.css'],\n  encapsulation: ViewEncapsulation.Emulated\n})\nexport class IoneProductComponent implements OnChanges, OnDestroy {\n\n  @Input()\n  public sku: string;\n\n  @Input()\n  public set settings(value: any) {\n    if (value) {\n      let settings: any;\n      if (typeof value === 'string') {\n        settings = JSON.parse(value);\n      } else {\n        settings = value;\n      }\n      this._settingsService.createSettingsFromObject(settings);\n      // this._initConnection(settings);\n    }\n  }\n\n  public get settings(): any {\n    return this._settings;\n  }\n\n  @Output()\n  public onAddToCart: EventEmitter<string> = new EventEmitter<string>();\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  public upAndLoaded = false;\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 = '1000234793';\n    // this.sku = '1066';\n    // this.sku = '104';\n\n    this._subs.push(\n      this._settingsService.settingsLoaded.subscribe(loaded => this._handleSettingsLoaded(loaded)),\n      // this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),\n      this._appEventService.onAddToCart.subscribe(json => this.onAddToCart.emit(json)),\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    );\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 _handleSettingsLoaded(loaded: boolean): void {\n    if (loaded) {\n      this.upAndLoaded = true;\n      this._initConnection();\n    }\n  }\n\n  private _handleAnswerInfoReceived(info: string): void {\n    this.onArticleInfoReceived.next(info);\n  }\n\n  // we need to prepare the settings before we can use it for the 3d configurator bundle\n  private async _initConnection(): Promise<void> {\n    this._ione.initDefaultDevelopTestConnection();\n    // settingsToUse.session = this._ione.connector.connector.session;\n    setTimeout(() => {\n      this._changeDetector.detectChanges();\n    });\n    // this._settings = settingsToUse;\n  }\n\n}\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ione-product.component.js","sourceRoot":"ng://@colijnit/product/","sources":["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  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 {ProductConnectorAdapterService} from './service/product-connector-adapter.service';\n\n@Component({\n  selector: 'app-ione-product',\n  template: `\n    <app-product-page [sku]=\"sku\"\n    ></app-product-page>\n  `,\n  providers: [\n    ProductEventService,\n    ProductSettingsService,\n    ProductConnectorAdapterService,\n    ProductConnectorService\n  ],\n  encapsulation: ViewEncapsulation.Emulated,\n  styleUrls: ['./ione-product.component.css']\n})\nexport class IoneProductComponent implements OnChanges, OnDestroy {\n\n  @Input()\n  public sku: string;\n\n  @Input()\n  public set settings(value: any) {\n    if (value) {\n      let settings: any;\n      if (typeof value === 'string') {\n        settings = JSON.parse(value);\n      } else {\n        settings = value;\n      }\n      this._settingsService.createSettingsFromObject(settings);\n      // this._initConnection(settings);\n    }\n  }\n\n  public get settings(): any {\n    return this._settings;\n  }\n\n  @Output()\n  public onAddToCart: EventEmitter<string> = new EventEmitter<string>();\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  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\n    // this.sku = \"70000107\";\n\n    this._subs.push(\n      // this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),\n      this._appEventService.onAddToCart.subscribe((json: string) => {\n        this._handleAddToCart(json);\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    );\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(json: string): Promise<void> {\n    if (this._settingsService.settings.createWebOrder) {\n      if (json) {\n        const articleTreeData = JSON.parse(json);\n        if (articleTreeData.articleTree && articleTreeData.articleTree.article) {\n           if (articleTreeData.articleTree.compositeGoods && Array.isArray(articleTreeData.articleTree.compositeGoods) &&\n               articleTreeData.articleTree.compositeGoods.length > 0 && articleTreeData.articleTree.subArticles && Array.isArray(articleTreeData.articleTree.subArticles)) {\n             for (let i = 0; i < articleTreeData.articleTree.compositeGoods.length - 1; i++) {\n               const good = articleTreeData.articleTree.compositeGoods[i];\n               const subArticle = articleTreeData.articleTree.subArticles[i];\n               await this._ione.addWebSessionTransactionLine(subArticle.articleNumber, good.quantity);\n             }\n           } else {\n             await this._ione.addWebSessionTransactionLine(articleTreeData.articleTree.article.articleNumber, 1);\n           }\n        }\n      }\n    }\n    this.onAddToCart.emit(json);\n  }\n}\n"]}
|
|
@@ -1,32 +1,11 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { APP_INITIALIZER,
|
|
3
|
-
import { ArticleTileModule, ButtonModule, FilesUploadModule, IconModule, InputTextModule, LevelIndicatorModule, LoaderModule, NumberPickerModule, PriceDisplayPipeModule, ScrollContainerModule, TileModule } from '@colijnit/corecomponents';
|
|
4
|
-
import { ProductDescriptionComponent } from './components/product-description/product-description.component';
|
|
5
|
-
import { ImageCarouselComponent } from './components/image-carousel/image-carousel.component';
|
|
6
|
-
import { ProductPageComponent } from './components/product-page/product-page.component';
|
|
7
|
-
import { IconCacheService } from './service/icon-cache.service';
|
|
8
|
-
import { ProductConnectorAdapterService } from './service/product-connector-adapter.service';
|
|
9
|
-
import { ProductConnectorService } from './service/product-connector.service';
|
|
10
|
-
import { ProductDocumentsComponent } from './components/product-documents/product-documents.component';
|
|
11
|
-
import { ProductRelatedComponent } from './components/product-related/product-related.component';
|
|
12
|
-
import { HeaderComponent } from './components/core/header/header.component';
|
|
13
|
-
import { ProductInfoComponent } from './components/product-info/product-info.component';
|
|
14
|
-
import { ProductAdditionalInfoComponent } from './components/product-additional-info/product-additional-info.component';
|
|
15
|
-
import { ProductPropertiesComponent } from './components/product-properties/product-properties.component';
|
|
16
|
-
import { ProductDeliveryComponent } from './components/product-delivery/product-delivery.component';
|
|
17
|
-
import { ProductStockComponent } from './components/product-stock/product-stock.component';
|
|
18
|
-
import { ProductSymbolsComponent } from './components/product-symbols/product-symbols.component';
|
|
19
|
-
import { ProductPriceComponent } from './components/product-price/product-price.component';
|
|
20
|
-
import { ProductAddtocartComponent } from './components/product-addtocart/product-addtocart.component';
|
|
21
|
-
import { LocalizePipe } from './pipe/localize.pipe';
|
|
22
|
-
import { ProductSelectorTypeComponent } from './components/product-selector-type/product-selector-type.component';
|
|
2
|
+
import { APP_INITIALIZER, NgModule } from '@angular/core';
|
|
23
3
|
import { IoneProductComponent } from './ione-product.component';
|
|
24
4
|
import { CommonModule } from '@angular/common';
|
|
25
|
-
import {
|
|
26
|
-
import { ProductInfoTabsComponent } from './components/product-info-tabs/product-info-tabs.component';
|
|
27
|
-
// import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
|
|
5
|
+
// import {BrowserAnimationsModule} from '@angular/platform-browser/animations';
|
|
28
6
|
import { ProductInitializerService } from './service/product-initializer.service';
|
|
29
|
-
import {
|
|
7
|
+
import { ProductExternalSourceModule } from './components/product-external-source/product-external-source.module';
|
|
8
|
+
import { ProductPageModule } from './components/product-page/product-page.module';
|
|
30
9
|
export function initializeApp(context) {
|
|
31
10
|
var x = function () { return context.initializeApp(); };
|
|
32
11
|
return x;
|
|
@@ -39,48 +18,16 @@ var IoneProductModule = /** @class */ (function () {
|
|
|
39
18
|
imports: [
|
|
40
19
|
// BrowserAnimationsModule,
|
|
41
20
|
CommonModule,
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
NumberPickerModule,
|
|
45
|
-
InputTextModule,
|
|
46
|
-
FilesUploadModule,
|
|
47
|
-
LoaderModule,
|
|
48
|
-
ScrollContainerModule,
|
|
49
|
-
TileModule,
|
|
50
|
-
LevelIndicatorModule,
|
|
51
|
-
PriceDisplayPipeModule,
|
|
52
|
-
ArticleTileModule
|
|
21
|
+
ProductExternalSourceModule,
|
|
22
|
+
ProductPageModule
|
|
53
23
|
],
|
|
54
|
-
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
55
24
|
declarations: [
|
|
56
|
-
IoneProductComponent
|
|
57
|
-
ProductPageComponent,
|
|
58
|
-
ImageCarouselComponent,
|
|
59
|
-
ProductDescriptionComponent,
|
|
60
|
-
ProductDocumentsComponent,
|
|
61
|
-
ProductRelatedComponent,
|
|
62
|
-
HeaderComponent,
|
|
63
|
-
ProductInfoComponent,
|
|
64
|
-
ProductAdditionalInfoComponent,
|
|
65
|
-
ProductPropertiesComponent,
|
|
66
|
-
ProductDeliveryComponent,
|
|
67
|
-
ProductStockComponent,
|
|
68
|
-
ProductSymbolsComponent,
|
|
69
|
-
ProductPriceComponent,
|
|
70
|
-
ProductAddtocartComponent,
|
|
71
|
-
ProductInfoTabsComponent,
|
|
72
|
-
LocalizePipe,
|
|
73
|
-
ProductSelectorTypeComponent,
|
|
74
|
-
ProductAdditionalDescriptionComponent
|
|
25
|
+
IoneProductComponent
|
|
75
26
|
],
|
|
76
27
|
entryComponents: [
|
|
77
28
|
IoneProductComponent
|
|
78
29
|
],
|
|
79
30
|
providers: [
|
|
80
|
-
ProductSettingsService,
|
|
81
|
-
ProductConnectorService,
|
|
82
|
-
ProductConnectorAdapterService,
|
|
83
|
-
IconCacheService,
|
|
84
31
|
{
|
|
85
32
|
provide: APP_INITIALIZER,
|
|
86
33
|
useFactory: initializeApp,
|
|
@@ -97,4 +44,4 @@ var IoneProductModule = /** @class */ (function () {
|
|
|
97
44
|
return IoneProductModule;
|
|
98
45
|
}());
|
|
99
46
|
export { IoneProductModule };
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uZS1wcm9kdWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bjb2xpam5pdC9wcm9kdWN0LyIsInNvdXJjZXMiOlsiYXBwL2lvbmUtcHJvZHVjdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBQyxlQUFlLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxnRkFBZ0Y7QUFDaEYsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDaEYsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0scUVBQXFFLENBQUM7QUFDaEgsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFFaEYsTUFBTSxVQUFVLGFBQWEsQ0FBQyxPQUFrQztJQUM1RCxJQUFNLENBQUMsR0FBRyxjQUFNLE9BQUEsT0FBTyxDQUFDLGFBQWEsRUFBRSxFQUF2QixDQUF1QixDQUFDO0lBQ3hDLE9BQU8sQ0FBQyxDQUFDO0FBQ2IsQ0FBQztBQTRCRDtJQUFBO0lBQ0EsQ0FBQztJQURZLGlCQUFpQjtRQTFCN0IsUUFBUSxDQUFDO1lBQ04sT0FBTyxFQUFFO2dCQUNMLDJCQUEyQjtnQkFDM0IsWUFBWTtnQkFDWiwyQkFBMkI7Z0JBQzNCLGlCQUFpQjthQUNwQjtZQUNELFlBQVksRUFBRTtnQkFDVixvQkFBb0I7YUFDdkI7WUFDRCxlQUFlLEVBQUU7Z0JBQ2Isb0JBQW9CO2FBQ3ZCO1lBQ0QsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSxlQUFlO29CQUN4QixVQUFVLEVBQUUsYUFBYTtvQkFDekIsSUFBSSxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ2pDLEtBQUssRUFBRSxJQUFJO2lCQUNkO2FBQ0o7WUFDRCxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztZQUMvQixTQUFTLEVBQUU7Z0JBQ1Asb0JBQW9CO2FBQ3ZCO1NBQ0osQ0FBQztPQUNXLGlCQUFpQixDQUM3QjtJQUFELHdCQUFDO0NBQUEsQUFERCxJQUNDO1NBRFksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBUFBfSU5JVElBTElaRVIsIE5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7SW9uZVByb2R1Y3RDb21wb25lbnR9IGZyb20gJy4vaW9uZS1wcm9kdWN0LmNvbXBvbmVudCc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbi8vIGltcG9ydCB7QnJvd3NlckFuaW1hdGlvbnNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQge1Byb2R1Y3RJbml0aWFsaXplclNlcnZpY2V9IGZyb20gJy4vc2VydmljZS9wcm9kdWN0LWluaXRpYWxpemVyLnNlcnZpY2UnO1xuaW1wb3J0IHtQcm9kdWN0RXh0ZXJuYWxTb3VyY2VNb2R1bGV9IGZyb20gJy4vY29tcG9uZW50cy9wcm9kdWN0LWV4dGVybmFsLXNvdXJjZS9wcm9kdWN0LWV4dGVybmFsLXNvdXJjZS5tb2R1bGUnO1xuaW1wb3J0IHtQcm9kdWN0UGFnZU1vZHVsZX0gZnJvbSAnLi9jb21wb25lbnRzL3Byb2R1Y3QtcGFnZS9wcm9kdWN0LXBhZ2UubW9kdWxlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGluaXRpYWxpemVBcHAoY29udGV4dDogUHJvZHVjdEluaXRpYWxpemVyU2VydmljZSkge1xuICAgIGNvbnN0IHggPSAoKSA9PiBjb250ZXh0LmluaXRpYWxpemVBcHAoKTtcbiAgICByZXR1cm4geDtcbn1cblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIC8vIEJyb3dzZXJBbmltYXRpb25zTW9kdWxlLFxuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFByb2R1Y3RFeHRlcm5hbFNvdXJjZU1vZHVsZSxcbiAgICAgICAgUHJvZHVjdFBhZ2VNb2R1bGVcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBJb25lUHJvZHVjdENvbXBvbmVudFxuICAgIF0sXG4gICAgZW50cnlDb21wb25lbnRzOiBbXG4gICAgICAgIElvbmVQcm9kdWN0Q29tcG9uZW50XG4gICAgXSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogQVBQX0lOSVRJQUxJWkVSLFxuICAgICAgICAgICAgdXNlRmFjdG9yeTogaW5pdGlhbGl6ZUFwcCxcbiAgICAgICAgICAgIGRlcHM6IFtQcm9kdWN0SW5pdGlhbGl6ZXJTZXJ2aWNlXSxcbiAgICAgICAgICAgIG11bHRpOiB0cnVlXG4gICAgICAgIH1cbiAgICBdLFxuICAgIGV4cG9ydHM6IFtJb25lUHJvZHVjdENvbXBvbmVudF0sXG4gICAgYm9vdHN0cmFwOiBbXG4gICAgICAgIElvbmVQcm9kdWN0Q29tcG9uZW50XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBJb25lUHJvZHVjdE1vZHVsZSB7XG59XG4iXX0=
|