@colijnit/product 12.0.6 → 12.0.8
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/core/header/header.component.d.ts +7 -7
- package/app/components/core/header/header.module.d.ts +2 -2
- package/app/components/image-carousel/image-carousel.component.d.ts +39 -39
- package/app/components/image-carousel/image-carousel.module.d.ts +2 -2
- package/app/components/product-additional-description/product-additional-description.component.d.ts +14 -14
- package/app/components/product-additional-description/product-additional-description.module.d.ts +2 -2
- package/app/components/product-additional-info/product-additional-info.component.d.ts +21 -21
- package/app/components/product-additional-info/product-additional-info.module.d.ts +2 -2
- package/app/components/product-addtocart/product-addtocart.component.d.ts +33 -33
- package/app/components/product-addtocart/product-addtocart.module.d.ts +2 -2
- package/app/components/product-delivery/product-delivery.component.d.ts +18 -18
- package/app/components/product-delivery/product-delivery.module.d.ts +2 -2
- package/app/components/product-description/product-description.component.d.ts +7 -7
- package/app/components/product-description/product-description.module.d.ts +2 -2
- package/app/components/product-documents/product-document.module.d.ts +2 -2
- package/app/components/product-documents/product-documents.component.d.ts +10 -10
- package/app/components/product-external-source/product-external-source.component.d.ts +34 -34
- package/app/components/product-external-source/product-external-source.module.d.ts +2 -2
- package/app/components/product-info-tabs/product-info-tabs.component.d.ts +18 -18
- package/app/components/product-info-tabs/product-info-tabs.module.d.ts +2 -2
- package/app/components/product-page/product-page.component.d.ts +58 -58
- package/app/components/product-page/product-page.module.d.ts +2 -2
- package/app/components/product-price/product-price.component.d.ts +19 -19
- package/app/components/product-price/product-price.module.d.ts +2 -2
- package/app/components/product-properties/product-properties.component.d.ts +16 -16
- package/app/components/product-properties/product-properties.module.d.ts +2 -2
- package/app/components/product-related/product-related.component.d.ts +16 -16
- package/app/components/product-related/product-related.module.d.ts +2 -2
- package/app/components/product-selector-type/product-selector-type.component.d.ts +21 -21
- package/app/components/product-selector-type/product-selector-type.module.d.ts +2 -2
- package/app/components/product-stock/product-stock.component.d.ts +20 -20
- package/app/components/product-stock/product-stock.module.d.ts +2 -2
- package/app/components/product-symbols/product-symbols.component.d.ts +10 -10
- package/app/components/product-symbols/product-symbols.module.d.ts +2 -2
- package/app/enum/icon.enum.d.ts +17 -17
- package/app/enum/language-code.enum.d.ts +6 -6
- package/app/enum/selector-type.enum.d.ts +5 -5
- package/app/ione-product.component.d.ts +43 -43
- package/app/ione-product.module.d.ts +2 -2
- package/app/model/article-quantity.model.d.ts +5 -5
- package/app/model/icon.d.ts +4 -4
- package/app/model/productSettings.d.ts +30 -29
- package/app/model/render-modes.d.ts +5 -5
- package/app/model/render-parameters.d.ts +7 -7
- package/app/model/settings-options.d.ts +10 -10
- package/app/model/stock-and-delivery.d.ts +5 -5
- package/app/pipe/localize.pipe.d.ts +7 -7
- package/app/pipe/pipe.module.d.ts +2 -2
- package/app/product-version.d.ts +6 -6
- package/app/service/dictionary.service.d.ts +24 -24
- package/app/service/icon-cache.service.d.ts +17 -17
- package/app/service/product-connector-adapter.service.d.ts +34 -34
- package/app/service/product-connector.service.d.ts +38 -38
- package/app/service/product-event.service.d.ts +22 -22
- package/app/service/product-settings.service.d.ts +16 -16
- package/app/style/_scrollbars.mixins.scss +18 -18
- package/app/style/_variables.scss +21 -21
- package/app/utils/bit-utils.d.ts +7 -7
- package/app/utils/json-utils.service.d.ts +3 -3
- package/assets/dictionary/text.properties.d.ts +3 -3
- package/bundles/colijnit-product.umd.js +3108 -3108
- package/bundles/colijnit-product.umd.js.map +1 -1
- package/colijnit-product.d.ts +41 -41
- package/colijnit-product.metadata.json +1 -1
- package/esm2015/app/components/core/header/header.component.js +18 -18
- package/esm2015/app/components/core/header/header.module.js +19 -19
- package/esm2015/app/components/image-carousel/image-carousel.component.js +143 -143
- package/esm2015/app/components/image-carousel/image-carousel.module.js +23 -23
- package/esm2015/app/components/product-additional-description/product-additional-description.component.js +50 -50
- package/esm2015/app/components/product-additional-description/product-additional-description.module.js +21 -21
- package/esm2015/app/components/product-additional-info/product-additional-info.component.js +102 -102
- package/esm2015/app/components/product-additional-info/product-additional-info.module.js +21 -21
- package/esm2015/app/components/product-addtocart/product-addtocart.component.js +90 -90
- package/esm2015/app/components/product-addtocart/product-addtocart.module.js +24 -24
- package/esm2015/app/components/product-delivery/product-delivery.component.js +39 -39
- package/esm2015/app/components/product-delivery/product-delivery.module.js +23 -23
- package/esm2015/app/components/product-description/product-description.component.js +17 -17
- package/esm2015/app/components/product-description/product-description.module.js +19 -19
- package/esm2015/app/components/product-documents/product-document.module.js +25 -25
- package/esm2015/app/components/product-documents/product-documents.component.js +25 -25
- package/esm2015/app/components/product-external-source/product-external-source.component.js +110 -110
- package/esm2015/app/components/product-external-source/product-external-source.module.js +21 -21
- package/esm2015/app/components/product-info-tabs/product-info-tabs.component.js +59 -59
- package/esm2015/app/components/product-info-tabs/product-info-tabs.module.js +29 -29
- package/esm2015/app/components/product-page/product-page.component.js +215 -215
- package/esm2015/app/components/product-page/product-page.module.js +44 -44
- package/esm2015/app/components/product-price/product-price.component.js +60 -60
- package/esm2015/app/components/product-price/product-price.module.js +23 -23
- package/esm2015/app/components/product-properties/product-properties.component.js +50 -50
- package/esm2015/app/components/product-properties/product-properties.module.js +21 -21
- package/esm2015/app/components/product-related/product-related.component.js +62 -62
- package/esm2015/app/components/product-related/product-related.module.js +24 -24
- package/esm2015/app/components/product-selector-type/product-selector-type.component.js +42 -42
- package/esm2015/app/components/product-selector-type/product-selector-type.module.js +26 -26
- package/esm2015/app/components/product-stock/product-stock.component.js +59 -59
- package/esm2015/app/components/product-stock/product-stock.module.js +23 -23
- package/esm2015/app/components/product-symbols/product-symbols.component.js +34 -34
- package/esm2015/app/components/product-symbols/product-symbols.module.js +26 -26
- package/esm2015/app/enum/icon.enum.js +18 -18
- package/esm2015/app/enum/language-code.enum.js +8 -8
- package/esm2015/app/enum/selector-type.enum.js +7 -7
- package/esm2015/app/ione-product.component.js +114 -114
- package/esm2015/app/ione-product.module.js +29 -29
- package/esm2015/app/model/article-quantity.model.js +3 -3
- package/esm2015/app/model/icon.js +17 -17
- package/esm2015/app/model/productSettings.js +16 -16
- package/esm2015/app/model/render-modes.js +7 -7
- package/esm2015/app/model/render-parameters.js +10 -10
- package/esm2015/app/model/settings-options.js +13 -13
- package/esm2015/app/model/stock-and-delivery.js +8 -8
- package/esm2015/app/pipe/localize.pipe.js +27 -27
- package/esm2015/app/pipe/pipe.module.js +18 -18
- package/esm2015/app/product-version.js +10 -10
- package/esm2015/app/service/dictionary.service.js +94 -94
- package/esm2015/app/service/icon-cache.service.js +40 -40
- package/esm2015/app/service/product-connector-adapter.service.js +171 -171
- package/esm2015/app/service/product-connector.service.js +106 -106
- package/esm2015/app/service/product-event.service.js +29 -29
- package/esm2015/app/service/product-settings.service.js +86 -86
- package/esm2015/app/utils/bit-utils.js +18 -18
- package/esm2015/app/utils/json-utils.service.js +29 -29
- package/esm2015/assets/dictionary/text.properties.js +67 -67
- package/esm2015/colijnit-product.js +41 -41
- package/esm2015/public_api.js +10 -10
- package/fesm2015/colijnit-product.js +2212 -2212
- package/fesm2015/colijnit-product.js.map +1 -1
- package/package.json +5 -5
- package/public_api.d.ts +9 -9
|
@@ -1,110 +1,110 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
3
|
-
import { DomSanitizer } from '@angular/platform-browser';
|
|
4
|
-
import { ProductConnectorService } from '../../service/product-connector.service';
|
|
5
|
-
import { ProductEventService } from '../../service/product-event.service';
|
|
6
|
-
import { ProductSettingsService } from '../../service/product-settings.service';
|
|
7
|
-
import { ProductConnectorAdapterService } from '../../service/product-connector-adapter.service';
|
|
8
|
-
export class ProductExternalSourceComponent {
|
|
9
|
-
constructor(_sanitizer, _productConnectorService, _appEventService) {
|
|
10
|
-
this._sanitizer = _sanitizer;
|
|
11
|
-
this._productConnectorService = _productConnectorService;
|
|
12
|
-
this._appEventService = _appEventService;
|
|
13
|
-
this.addToCart = new EventEmitter();
|
|
14
|
-
this.addToQuote = new EventEmitter();
|
|
15
|
-
this.alternativeClick = new EventEmitter();
|
|
16
|
-
this.showProduct = false;
|
|
17
|
-
this.loaded = false;
|
|
18
|
-
this.externalSettings = {};
|
|
19
|
-
this._subs = [];
|
|
20
|
-
}
|
|
21
|
-
set externalSource(value) {
|
|
22
|
-
this._externalSource = value;
|
|
23
|
-
this.loaded = false;
|
|
24
|
-
this._prepareExternalSource();
|
|
25
|
-
}
|
|
26
|
-
get externalSource() {
|
|
27
|
-
return this._externalSource;
|
|
28
|
-
}
|
|
29
|
-
showClass() {
|
|
30
|
-
return true;
|
|
31
|
-
}
|
|
32
|
-
ngOnInit() {
|
|
33
|
-
this._subs.push(this._appEventService.onAddToCart.subscribe(json => this.addToCart.next(json)), this._appEventService.onAddToQuote.subscribe(json => this.addToQuote.next(json)), this._appEventService.onAlternativeClick.subscribe(article => this.alternativeClick.next(article)));
|
|
34
|
-
}
|
|
35
|
-
ngOnDestroy() {
|
|
36
|
-
this._subs.forEach(s => s.unsubscribe());
|
|
37
|
-
}
|
|
38
|
-
_prepareExternalSource() {
|
|
39
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
-
if (!this._externalSource) {
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
this.externalUrl = undefined;
|
|
44
|
-
this.externalSettings = {};
|
|
45
|
-
if (this.externalSource.type === 'CATF') {
|
|
46
|
-
// get bundle settings from external source
|
|
47
|
-
const bundleSettings = yield this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));
|
|
48
|
-
this.externalSettings = JSON.parse(bundleSettings);
|
|
49
|
-
if (this.options) {
|
|
50
|
-
this.externalSettings.options = this.options;
|
|
51
|
-
}
|
|
52
|
-
// this.externalSettings.assetPath = "https://cdn1.colijn-it.nl/content43";
|
|
53
|
-
// this.externalSettings.threeDAssetPath = "https://cdn1.colijn-it.nl/content43";
|
|
54
|
-
if (this.externalSource.username && this.externalSource.password) {
|
|
55
|
-
this.externalSettings.useLoginEncryption = true;
|
|
56
|
-
this.externalSettings.username = this.externalSource.username;
|
|
57
|
-
this.externalSettings.password = this.externalSource.password;
|
|
58
|
-
}
|
|
59
|
-
// finally show the catalog
|
|
60
|
-
this.showProduct = true;
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
this.externalUrl = this.externalSource.url;
|
|
64
|
-
this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);
|
|
65
|
-
this.showProduct = false;
|
|
66
|
-
}
|
|
67
|
-
this.loaded = true;
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
ProductExternalSourceComponent.decorators = [
|
|
72
|
-
{ type: Component, args: [{
|
|
73
|
-
selector: 'co-product-external-source',
|
|
74
|
-
template: `
|
|
75
|
-
<ng-container *ngIf="loaded">
|
|
76
|
-
<ng-container *ngIf="showProduct">
|
|
77
|
-
<app-product-page
|
|
78
|
-
[sku]="sku"
|
|
79
|
-
[settings]="externalSettings"
|
|
80
|
-
></app-product-page>
|
|
81
|
-
</ng-container>
|
|
82
|
-
<ng-container *ngIf="!showProduct">
|
|
83
|
-
<iframe width="100%" height="100%" [src]="safeUrl" frameborder="0" allowfullscreen></iframe>
|
|
84
|
-
</ng-container>
|
|
85
|
-
</ng-container>
|
|
86
|
-
`,
|
|
87
|
-
providers: [
|
|
88
|
-
ProductEventService,
|
|
89
|
-
ProductSettingsService,
|
|
90
|
-
ProductConnectorAdapterService,
|
|
91
|
-
ProductConnectorService
|
|
92
|
-
],
|
|
93
|
-
encapsulation: ViewEncapsulation.None
|
|
94
|
-
},] }
|
|
95
|
-
];
|
|
96
|
-
ProductExternalSourceComponent.ctorParameters = () => [
|
|
97
|
-
{ type: DomSanitizer },
|
|
98
|
-
{ type: ProductConnectorService },
|
|
99
|
-
{ type: ProductEventService }
|
|
100
|
-
];
|
|
101
|
-
ProductExternalSourceComponent.propDecorators = {
|
|
102
|
-
sku: [{ type: Input }],
|
|
103
|
-
externalSource: [{ type: Input }],
|
|
104
|
-
options: [{ type: Input }],
|
|
105
|
-
addToCart: [{ type: Output }],
|
|
106
|
-
addToQuote: [{ type: Output }],
|
|
107
|
-
alternativeClick: [{ type: Output }],
|
|
108
|
-
showClass: [{ type: HostBinding, args: ['class.co-product-external-source',] }]
|
|
109
|
-
};
|
|
110
|
-
//# 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 {ArticleExtended} from '@colijnit/articleapi/build/model/article-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                ></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        ProductEventService,\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 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<{ article: string | ArticleExtended, quantity: number }> = new EventEmitter<{ article: string | ArticleExtended, quantity: number }>();\r\n\r\n    @Output()\r\n    public addToQuote: EventEmitter<string> = new EventEmitter<string>();\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(json => this.addToCart.next(json)),\r\n            this._appEventService.onAddToQuote.subscribe(json => this.addToQuote.next(json)),\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"]}
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
4
|
+
import { ProductConnectorService } from '../../service/product-connector.service';
|
|
5
|
+
import { ProductEventService } from '../../service/product-event.service';
|
|
6
|
+
import { ProductSettingsService } from '../../service/product-settings.service';
|
|
7
|
+
import { ProductConnectorAdapterService } from '../../service/product-connector-adapter.service';
|
|
8
|
+
export class ProductExternalSourceComponent {
|
|
9
|
+
constructor(_sanitizer, _productConnectorService, _appEventService) {
|
|
10
|
+
this._sanitizer = _sanitizer;
|
|
11
|
+
this._productConnectorService = _productConnectorService;
|
|
12
|
+
this._appEventService = _appEventService;
|
|
13
|
+
this.addToCart = new EventEmitter();
|
|
14
|
+
this.addToQuote = new EventEmitter();
|
|
15
|
+
this.alternativeClick = new EventEmitter();
|
|
16
|
+
this.showProduct = false;
|
|
17
|
+
this.loaded = false;
|
|
18
|
+
this.externalSettings = {};
|
|
19
|
+
this._subs = [];
|
|
20
|
+
}
|
|
21
|
+
set externalSource(value) {
|
|
22
|
+
this._externalSource = value;
|
|
23
|
+
this.loaded = false;
|
|
24
|
+
this._prepareExternalSource();
|
|
25
|
+
}
|
|
26
|
+
get externalSource() {
|
|
27
|
+
return this._externalSource;
|
|
28
|
+
}
|
|
29
|
+
showClass() {
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this._subs.push(this._appEventService.onAddToCart.subscribe(json => this.addToCart.next(json)), this._appEventService.onAddToQuote.subscribe(json => this.addToQuote.next(json)), this._appEventService.onAlternativeClick.subscribe(article => this.alternativeClick.next(article)));
|
|
34
|
+
}
|
|
35
|
+
ngOnDestroy() {
|
|
36
|
+
this._subs.forEach(s => s.unsubscribe());
|
|
37
|
+
}
|
|
38
|
+
_prepareExternalSource() {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
if (!this._externalSource) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
this.externalUrl = undefined;
|
|
44
|
+
this.externalSettings = {};
|
|
45
|
+
if (this.externalSource.type === 'CATF') {
|
|
46
|
+
// get bundle settings from external source
|
|
47
|
+
const bundleSettings = yield this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));
|
|
48
|
+
this.externalSettings = JSON.parse(bundleSettings);
|
|
49
|
+
if (this.options) {
|
|
50
|
+
this.externalSettings.options = this.options;
|
|
51
|
+
}
|
|
52
|
+
// this.externalSettings.assetPath = "https://cdn1.colijn-it.nl/content43";
|
|
53
|
+
// this.externalSettings.threeDAssetPath = "https://cdn1.colijn-it.nl/content43";
|
|
54
|
+
if (this.externalSource.username && this.externalSource.password) {
|
|
55
|
+
this.externalSettings.useLoginEncryption = true;
|
|
56
|
+
this.externalSettings.username = this.externalSource.username;
|
|
57
|
+
this.externalSettings.password = this.externalSource.password;
|
|
58
|
+
}
|
|
59
|
+
// finally show the catalog
|
|
60
|
+
this.showProduct = true;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
this.externalUrl = this.externalSource.url;
|
|
64
|
+
this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);
|
|
65
|
+
this.showProduct = false;
|
|
66
|
+
}
|
|
67
|
+
this.loaded = true;
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
ProductExternalSourceComponent.decorators = [
|
|
72
|
+
{ type: Component, args: [{
|
|
73
|
+
selector: 'co-product-external-source',
|
|
74
|
+
template: `
|
|
75
|
+
<ng-container *ngIf="loaded">
|
|
76
|
+
<ng-container *ngIf="showProduct">
|
|
77
|
+
<app-product-page
|
|
78
|
+
[sku]="sku"
|
|
79
|
+
[settings]="externalSettings"
|
|
80
|
+
></app-product-page>
|
|
81
|
+
</ng-container>
|
|
82
|
+
<ng-container *ngIf="!showProduct">
|
|
83
|
+
<iframe width="100%" height="100%" [src]="safeUrl" frameborder="0" allowfullscreen></iframe>
|
|
84
|
+
</ng-container>
|
|
85
|
+
</ng-container>
|
|
86
|
+
`,
|
|
87
|
+
providers: [
|
|
88
|
+
ProductEventService,
|
|
89
|
+
ProductSettingsService,
|
|
90
|
+
ProductConnectorAdapterService,
|
|
91
|
+
ProductConnectorService
|
|
92
|
+
],
|
|
93
|
+
encapsulation: ViewEncapsulation.None
|
|
94
|
+
},] }
|
|
95
|
+
];
|
|
96
|
+
ProductExternalSourceComponent.ctorParameters = () => [
|
|
97
|
+
{ type: DomSanitizer },
|
|
98
|
+
{ type: ProductConnectorService },
|
|
99
|
+
{ type: ProductEventService }
|
|
100
|
+
];
|
|
101
|
+
ProductExternalSourceComponent.propDecorators = {
|
|
102
|
+
sku: [{ type: Input }],
|
|
103
|
+
externalSource: [{ type: Input }],
|
|
104
|
+
options: [{ type: Input }],
|
|
105
|
+
addToCart: [{ type: Output }],
|
|
106
|
+
addToQuote: [{ type: Output }],
|
|
107
|
+
alternativeClick: [{ type: Output }],
|
|
108
|
+
showClass: [{ type: HostBinding, args: ['class.co-product-external-source',] }]
|
|
109
|
+
};
|
|
110
|
+
//# 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';\nimport {DomSanitizer, SafeResourceUrl} from '@angular/platform-browser';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {Subscription} from 'rxjs';\nimport {ProductSettingsService} from '../../service/product-settings.service';\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\nimport {ArticleExtended} from '@colijnit/articleapi/build/model/article-extended.bo';\n\n@Component({\n    selector: 'co-product-external-source',\n    template: `\n        <ng-container *ngIf=\"loaded\">\n            <ng-container *ngIf=\"showProduct\">\n                <app-product-page\n                        [sku]=\"sku\"\n                        [settings]=\"externalSettings\"\n                ></app-product-page>\n            </ng-container>\n            <ng-container *ngIf=\"!showProduct\">\n                <iframe width=\"100%\" height=\"100%\" [src]=\"safeUrl\" frameborder=\"0\" allowfullscreen></iframe>\n            </ng-container>\n        </ng-container>\n    `,\n    providers: [\n        ProductEventService,\n        ProductSettingsService,\n        ProductConnectorAdapterService,\n        ProductConnectorService\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class ProductExternalSourceComponent implements OnInit, OnDestroy {\n\n    @Input()\n    public sku: string;\n\n    @Input()\n    public set externalSource(value: ExternalSource) {\n        this._externalSource = value;\n        this.loaded = false;\n        this._prepareExternalSource();\n    }\n\n    public get externalSource(): ExternalSource {\n        return this._externalSource;\n    }\n\n    @Input()\n    public options: {};\n\n    @Output()\n    public addToCart: EventEmitter<{ article: string | ArticleExtended, quantity: number }> = new EventEmitter<{ article: string | ArticleExtended, quantity: number }>();\n\n    @Output()\n    public addToQuote: EventEmitter<string> = new EventEmitter<string>();\n\n    @Output()\n    public alternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\n\n    @HostBinding('class.co-product-external-source')\n    public showClass() {\n        return true;\n    }\n\n    public showProduct: boolean = false;\n    public safeUrl: SafeResourceUrl;\n    public loaded: boolean = false;\n    public externalUrl: string;\n    public externalSettings: any = {};\n\n    private _externalSource: ExternalSource;\n    private _subs: Subscription[] = [];\n\n    constructor(\n        private _sanitizer: DomSanitizer,\n        private _productConnectorService: ProductConnectorService,\n        private _appEventService: ProductEventService\n    ) {\n    }\n\n    ngOnInit() {\n        this._subs.push(\n            this._appEventService.onAddToCart.subscribe(json => this.addToCart.next(json)),\n            this._appEventService.onAddToQuote.subscribe(json => this.addToQuote.next(json)),\n            this._appEventService.onAlternativeClick.subscribe(article => this.alternativeClick.next(article))\n        )\n    }\n\n    ngOnDestroy() {\n        this._subs.forEach(s => s.unsubscribe());\n    }\n\n    private async _prepareExternalSource(): Promise<void> {\n        if (!this._externalSource) {\n            return;\n        }\n        this.externalUrl = undefined;\n        this.externalSettings = {};\n        if (this.externalSource.type === 'CATF') {\n            // get bundle settings from external source\n            const bundleSettings: string = await this._productConnectorService.getProductBundleSettings(this.externalSource.url, parseInt(this.externalSource.schema, 0));\n            this.externalSettings = JSON.parse(bundleSettings);\n            if (this.options) {\n                this.externalSettings.options = this.options;\n            }\n            // this.externalSettings.assetPath = \"https://cdn1.colijn-it.nl/content43\";\n            // this.externalSettings.threeDAssetPath = \"https://cdn1.colijn-it.nl/content43\";\n            if (this.externalSource.username && this.externalSource.password) {\n                this.externalSettings.useLoginEncryption = true;\n                this.externalSettings.username = this.externalSource.username;\n                this.externalSettings.password = this.externalSource.password;\n            }\n            // finally show the catalog\n            this.showProduct = true;\n        } else {\n            this.externalUrl = this.externalSource.url;\n            this.safeUrl = this._sanitizer.bypassSecurityTrustResourceUrl(this.externalUrl);\n            this.showProduct = false;\n        }\n        this.loaded = true;\n    }\n}\n"]}
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { ProductExternalSourceComponent } from './product-external-source.component';
|
|
4
|
-
import { ProductPageModule } from '../product-page/product-page.module';
|
|
5
|
-
export class ProductExternalSourceModule {
|
|
6
|
-
}
|
|
7
|
-
ProductExternalSourceModule.decorators = [
|
|
8
|
-
{ type: NgModule, args: [{
|
|
9
|
-
imports: [
|
|
10
|
-
CommonModule,
|
|
11
|
-
ProductPageModule
|
|
12
|
-
],
|
|
13
|
-
declarations: [
|
|
14
|
-
ProductExternalSourceComponent
|
|
15
|
-
],
|
|
16
|
-
exports: [
|
|
17
|
-
ProductExternalSourceComponent
|
|
18
|
-
]
|
|
19
|
-
},] }
|
|
20
|
-
];
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { ProductExternalSourceComponent } from './product-external-source.component';
|
|
4
|
+
import { ProductPageModule } from '../product-page/product-page.module';
|
|
5
|
+
export class ProductExternalSourceModule {
|
|
6
|
+
}
|
|
7
|
+
ProductExternalSourceModule.decorators = [
|
|
8
|
+
{ type: NgModule, args: [{
|
|
9
|
+
imports: [
|
|
10
|
+
CommonModule,
|
|
11
|
+
ProductPageModule
|
|
12
|
+
],
|
|
13
|
+
declarations: [
|
|
14
|
+
ProductExternalSourceComponent
|
|
15
|
+
],
|
|
16
|
+
exports: [
|
|
17
|
+
ProductExternalSourceComponent
|
|
18
|
+
]
|
|
19
|
+
},] }
|
|
20
|
+
];
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1leHRlcm5hbC1zb3VyY2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsOEJBQThCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNuRixPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQWN0RSxNQUFNLE9BQU8sMkJBQTJCOzs7WUFadkMsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLGlCQUFpQjtpQkFDcEI7Z0JBQ0QsWUFBWSxFQUFFO29CQUNWLDhCQUE4QjtpQkFDakM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLDhCQUE4QjtpQkFDakM7YUFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1Byb2R1Y3RFeHRlcm5hbFNvdXJjZUNvbXBvbmVudH0gZnJvbSAnLi9wcm9kdWN0LWV4dGVybmFsLXNvdXJjZS5jb21wb25lbnQnO1xuaW1wb3J0IHtQcm9kdWN0UGFnZU1vZHVsZX0gZnJvbSAnLi4vcHJvZHVjdC1wYWdlL3Byb2R1Y3QtcGFnZS5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBQcm9kdWN0UGFnZU1vZHVsZVxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFByb2R1Y3RFeHRlcm5hbFNvdXJjZUNvbXBvbmVudFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBQcm9kdWN0RXh0ZXJuYWxTb3VyY2VDb21wb25lbnRcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIFByb2R1Y3RFeHRlcm5hbFNvdXJjZU1vZHVsZSB7XG59XG4iXX0=
|
|
@@ -1,51 +1,51 @@
|
|
|
1
|
-
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
-
import { ProductEventService } from '../../service/product-event.service';
|
|
3
|
-
export class ProductInfoTabsComponent {
|
|
4
|
-
constructor(_appEventService) {
|
|
5
|
-
this._appEventService = _appEventService;
|
|
6
|
-
this.activeTabHeight = 0;
|
|
7
|
-
this.tabs = [];
|
|
8
|
-
this._subs = [];
|
|
9
|
-
this._subs.push(this._appEventService.onUpdateProductInfoTab.subscribe((index) => {
|
|
10
|
-
this.updateTab(index);
|
|
11
|
-
this.tabContent.nativeElement.scrollIntoView({ behavior: 'smooth' });
|
|
12
|
-
}));
|
|
13
|
-
}
|
|
14
|
-
set article(value) {
|
|
15
|
-
if (value) {
|
|
16
|
-
this.articleObject = value;
|
|
17
|
-
this._setupTabs();
|
|
18
|
-
this.updateTab(0);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
ngOnDestroy() {
|
|
22
|
-
this._subs.forEach(s => s.unsubscribe());
|
|
23
|
-
}
|
|
24
|
-
updateTab(tabIndex) {
|
|
25
|
-
this.activeTab = tabIndex;
|
|
26
|
-
this.updateHeight(tabIndex);
|
|
27
|
-
}
|
|
28
|
-
updateHeight(tabIndex) {
|
|
29
|
-
if (this.tabContent.nativeElement.children.length > 0) {
|
|
30
|
-
if (this.tabContent.nativeElement.children[tabIndex] !== undefined) {
|
|
31
|
-
this.activeTabHeight = this.tabContent.nativeElement.children[tabIndex].offsetHeight;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
_setupTabs() {
|
|
36
|
-
this.tabs.push({ title: 'DESCRIPTION' });
|
|
37
|
-
this.tabs.push({ title: 'FEATURES' });
|
|
38
|
-
if (this.articleObject.documents !== undefined && this.articleObject.documents.length > 0) {
|
|
39
|
-
this.tabs.push({ title: 'DOWNLOADS' });
|
|
40
|
-
}
|
|
41
|
-
if (this.articleObject.symbols !== undefined && this.articleObject.symbols.length > 0) {
|
|
42
|
-
this.tabs.push({ title: 'SYMBOLS' });
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
ProductInfoTabsComponent.decorators = [
|
|
47
|
-
{ type: Component, args: [{
|
|
48
|
-
selector: 'app-product-info-tabs',
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { ProductEventService } from '../../service/product-event.service';
|
|
3
|
+
export class ProductInfoTabsComponent {
|
|
4
|
+
constructor(_appEventService) {
|
|
5
|
+
this._appEventService = _appEventService;
|
|
6
|
+
this.activeTabHeight = 0;
|
|
7
|
+
this.tabs = [];
|
|
8
|
+
this._subs = [];
|
|
9
|
+
this._subs.push(this._appEventService.onUpdateProductInfoTab.subscribe((index) => {
|
|
10
|
+
this.updateTab(index);
|
|
11
|
+
this.tabContent.nativeElement.scrollIntoView({ behavior: 'smooth' });
|
|
12
|
+
}));
|
|
13
|
+
}
|
|
14
|
+
set article(value) {
|
|
15
|
+
if (value) {
|
|
16
|
+
this.articleObject = value;
|
|
17
|
+
this._setupTabs();
|
|
18
|
+
this.updateTab(0);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
ngOnDestroy() {
|
|
22
|
+
this._subs.forEach(s => s.unsubscribe());
|
|
23
|
+
}
|
|
24
|
+
updateTab(tabIndex) {
|
|
25
|
+
this.activeTab = tabIndex;
|
|
26
|
+
this.updateHeight(tabIndex);
|
|
27
|
+
}
|
|
28
|
+
updateHeight(tabIndex) {
|
|
29
|
+
if (this.tabContent.nativeElement.children.length > 0) {
|
|
30
|
+
if (this.tabContent.nativeElement.children[tabIndex] !== undefined) {
|
|
31
|
+
this.activeTabHeight = this.tabContent.nativeElement.children[tabIndex].offsetHeight;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
_setupTabs() {
|
|
36
|
+
this.tabs.push({ title: 'DESCRIPTION' });
|
|
37
|
+
this.tabs.push({ title: 'FEATURES' });
|
|
38
|
+
if (this.articleObject.documents !== undefined && this.articleObject.documents.length > 0) {
|
|
39
|
+
this.tabs.push({ title: 'DOWNLOADS' });
|
|
40
|
+
}
|
|
41
|
+
if (this.articleObject.symbols !== undefined && this.articleObject.symbols.length > 0) {
|
|
42
|
+
this.tabs.push({ title: 'SYMBOLS' });
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
ProductInfoTabsComponent.decorators = [
|
|
47
|
+
{ type: Component, args: [{
|
|
48
|
+
selector: 'app-product-info-tabs',
|
|
49
49
|
template: `
|
|
50
50
|
<div class="tab-container">
|
|
51
51
|
<div class="tab-header">
|
|
@@ -68,15 +68,15 @@ ProductInfoTabsComponent.decorators = [
|
|
|
68
68
|
</div>
|
|
69
69
|
</div>
|
|
70
70
|
</div>
|
|
71
|
-
`,
|
|
72
|
-
styles: ["*:focus{outline:none}:host .tab-header{border-bottom:3px solid #f6f5f4;margin:0 0 30px}:host .tab-header .tab-header-button{background:transparent;border:none;border-bottom:3px solid transparent;line-height:20px;padding:15px 20px;cursor:pointer;font-family:iOneMontserrat;color:#22313c;font-weight:bold;margin:0 0 -3px;opacity:.5}:host .tab-header .tab-header-button:hover{opacity:1}:host .tab-header .tab-header-button.active{opacity:1;border-color:#74b77f}:host .tab-content{padding:0 20px 30px;margin:0 0 20px;border-bottom:2px solid #f6f5f4;transition:all .2s ease-in-out;position:relative}:host .tab-content .tab-content-item{opacity:0;position:absolute;left:0;top:0;visibility:hidden;width:100%}:host .tab-content .tab-content-item.active{opacity:1;visibility:visible;position:static}@media screen and (max-width: 650px){:host .tab-content{padding:0 10px 15px}}@media screen and (max-width: 450px){:host .tab-header{display:flex}:host .tab-header .tab-header-button{width:100%;padding:10px;font-size:11px}}\n"]
|
|
73
|
-
},] }
|
|
74
|
-
];
|
|
75
|
-
ProductInfoTabsComponent.ctorParameters = () => [
|
|
76
|
-
{ type: ProductEventService }
|
|
77
|
-
];
|
|
78
|
-
ProductInfoTabsComponent.propDecorators = {
|
|
79
|
-
tabContent: [{ type: ViewChild, args: ['tabContent',] }],
|
|
80
|
-
article: [{ type: Input }]
|
|
81
|
-
};
|
|
71
|
+
`,
|
|
72
|
+
styles: ["*:focus{outline:none}:host .tab-header{border-bottom:3px solid #f6f5f4;margin:0 0 30px}:host .tab-header .tab-header-button{background:transparent;border:none;border-bottom:3px solid transparent;line-height:20px;padding:15px 20px;cursor:pointer;font-family:iOneMontserrat;color:#22313c;font-weight:bold;margin:0 0 -3px;opacity:.5}:host .tab-header .tab-header-button:hover{opacity:1}:host .tab-header .tab-header-button.active{opacity:1;border-color:#74b77f}:host .tab-content{padding:0 20px 30px;margin:0 0 20px;border-bottom:2px solid #f6f5f4;transition:all .2s ease-in-out;position:relative}:host .tab-content .tab-content-item{opacity:0;position:absolute;left:0;top:0;visibility:hidden;width:100%}:host .tab-content .tab-content-item.active{opacity:1;visibility:visible;position:static}@media screen and (max-width: 650px){:host .tab-content{padding:0 10px 15px}}@media screen and (max-width: 450px){:host .tab-header{display:flex}:host .tab-header .tab-header-button{width:100%;padding:10px;font-size:11px}}\n"]
|
|
73
|
+
},] }
|
|
74
|
+
];
|
|
75
|
+
ProductInfoTabsComponent.ctorParameters = () => [
|
|
76
|
+
{ type: ProductEventService }
|
|
77
|
+
];
|
|
78
|
+
ProductInfoTabsComponent.propDecorators = {
|
|
79
|
+
tabContent: [{ type: ViewChild, args: ['tabContent',] }],
|
|
80
|
+
article: [{ type: Input }]
|
|
81
|
+
};
|
|
82
82
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1pbmZvLXRhYnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3Byb2R1Y3QtaW5mby10YWJzL3Byb2R1Y3QtaW5mby10YWJzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBYyxLQUFLLEVBQWEsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3RHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBNkIxRSxNQUFNLE9BQU8sd0JBQXdCO0lBdUJuQyxZQUNVLGdCQUFxQztRQUFyQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQXFCO1FBckJ4QyxvQkFBZSxHQUFXLENBQUMsQ0FBQztRQUs1QixTQUFJLEdBQVUsRUFBRSxDQUFDO1FBYWhCLFVBQUssR0FBbUIsRUFBRSxDQUFDO1FBS2pDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNiLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxzQkFBc0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtZQUN2RSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3RCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLGNBQWMsQ0FBQyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDO0lBcEJELElBQ0ksT0FBTyxDQUFDLEtBQXdCO1FBQ2xDLElBQUksS0FBSyxFQUFFO1lBQ1QsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7WUFDM0IsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ2xCLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDbkI7SUFDSCxDQUFDO0lBZUQsV0FBVztRQUNULElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVNLFNBQVMsQ0FBQyxRQUFnQjtRQUMvQixJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztRQUMxQixJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFTSxZQUFZLENBQUMsUUFBZ0I7UUFDbEMsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNyRCxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxTQUFTLEVBQUU7Z0JBQ2xFLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFlBQVksQ0FBQzthQUN0RjtTQUNGO0lBQ0gsQ0FBQztJQUVPLFVBQVU7UUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsYUFBYSxFQUFFLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBRXRDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDekYsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztTQUN4QztRQUVELElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDckYsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztTQUN0QztJQUVILENBQUM7OztZQTFGRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtnQkFDakMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBc0JUOzthQUVGOzs7WUE1QlEsbUJBQW1COzs7eUJBa0N6QixTQUFTLFNBQUMsWUFBWTtzQkFPdEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIElucHV0LCBPbkRlc3Ryb3ksIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXJ0aWNsZUZ1bGxPYmplY3QgfSBmcm9tICdAY29saWpuaXQvYXJ0aWNsZWFwaS9idWlsZC9tb2RlbC9hcnRpY2xlLWZ1bGwtb2JqZWN0JztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgUHJvZHVjdEV2ZW50U2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2UvcHJvZHVjdC1ldmVudC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLXByb2R1Y3QtaW5mby10YWJzJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwidGFiLWNvbnRhaW5lclwiPlxuICAgICAgPGRpdiBjbGFzcz1cInRhYi1oZWFkZXJcIj5cbiAgICAgICAgPGJ1dHRvbiAqbmdGb3I9XCJsZXQgdGFiIG9mIHRhYnM7IGxldCBpID0gaW5kZXhcIiBjbGFzcz1cInRhYi1oZWFkZXItYnV0dG9uXCIgW2NsYXNzLmFjdGl2ZV09XCJhY3RpdmVUYWIgPT09IGlcIiBbdGV4dENvbnRlbnRdPVwidGFiLnRpdGxlIHwgbG9jYWxpemVcIiAoY2xpY2spPVwidXBkYXRlVGFiKGkpXCI+PC9idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJ0YWItY29udGVudFwiICN0YWJDb250ZW50IFtzdHlsZS5oZWlnaHQucHhdPVwiKGFjdGl2ZVRhYkhlaWdodCA+IDAgPyBhY3RpdmVUYWJIZWlnaHQgOiAnJylcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cInRhYi1jb250ZW50LWl0ZW1cIiAqbmdGb3I9XCJsZXQgdGFiIG9mIHRhYnM7IGxldCBpID0gaW5kZXhcIiBbY2xhc3MuYWN0aXZlXT1cImFjdGl2ZVRhYiA9PT0gaVwiPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJpID09PSAwXCI+XG4gICAgICAgICAgICA8YXBwLXByb2R1Y3QtYWRkaXRpb25hbC1pbmZvIGNsYXNzPVwiXCIgW2FydGljbGVdPVwiYXJ0aWNsZU9iamVjdFwiIFtzaG93TGFiZWxdPVwiZmFsc2VcIj48L2FwcC1wcm9kdWN0LWFkZGl0aW9uYWwtaW5mbz5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaSA9PT0gMVwiPlxuICAgICAgICAgICAgPGFwcC1wcm9kdWN0LXByb3BlcnRpZXMgY2xhc3M9XCJcIiBbYXJ0aWNsZV09XCJhcnRpY2xlT2JqZWN0XCIgW3Nob3dMYWJlbF09XCJmYWxzZVwiPjwvYXBwLXByb2R1Y3QtcHJvcGVydGllcz5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaSA9PT0gMlwiPlxuICAgICAgICAgICAgPGFwcC1wcm9kdWN0LWRvY3VtZW50cyBbc2hvd0xhYmVsXT1cImZhbHNlXCIgY2xhc3M9XCJcIiAqbmdJZj1cImFydGljbGVPYmplY3Q/LmRvY3VtZW50cyAmJiBhcnRpY2xlT2JqZWN0Py5kb2N1bWVudHMubGVuZ3RoID4gMFwiIFtkb2N1bWVudHNdPVwiYXJ0aWNsZU9iamVjdD8uZG9jdW1lbnRzXCI+PC9hcHAtcHJvZHVjdC1kb2N1bWVudHM+XG4gICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImkgPT09IDNcIj5cbiAgICAgICAgICAgIDxhcHAtcHJvZHVjdC1zeW1ib2xzIGNsYXNzPVwiXCIgKm5nSWY9XCJhcnRpY2xlT2JqZWN0Py5zeW1ib2xzICYmIGFydGljbGVPYmplY3Q/LnN5bWJvbHMubGVuZ3RoID4gMFwiIFtzeW1ib2xzXT1cImFydGljbGVPYmplY3Q/LnN5bWJvbHNcIj48L2FwcC1wcm9kdWN0LXN5bWJvbHM+XG4gICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3Byb2R1Y3QtaW5mby10YWJzLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgUHJvZHVjdEluZm9UYWJzQ29tcG9uZW50IGltcGxlbWVudHMgT25EZXN0cm95IHtcblxuICBwdWJsaWMgYWN0aXZlVGFiOiBudW1iZXI7XG4gIHB1YmxpYyBhY3RpdmVUYWJIZWlnaHQ6IG51bWJlciA9IDA7XG5cbiAgQFZpZXdDaGlsZCgndGFiQ29udGVudCcpXG4gIHB1YmxpYyB0YWJDb250ZW50OiBFbGVtZW50UmVmO1xuXG4gIHB1YmxpYyB0YWJzOiBhbnlbXSA9IFtdO1xuXG4gIHB1YmxpYyBhcnRpY2xlT2JqZWN0OiBBcnRpY2xlRnVsbE9iamVjdDtcblxuICBASW5wdXQgKClcbiAgc2V0IGFydGljbGUodmFsdWU6IEFydGljbGVGdWxsT2JqZWN0KSB7XG4gICAgaWYgKHZhbHVlKSB7XG4gICAgICB0aGlzLmFydGljbGVPYmplY3QgPSB2YWx1ZTtcbiAgICAgIHRoaXMuX3NldHVwVGFicygpO1xuICAgICAgdGhpcy51cGRhdGVUYWIoMCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfc3ViczogU3Vic2NyaXB0aW9uW10gPSBbXTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9hcHBFdmVudFNlcnZpY2U6IFByb2R1Y3RFdmVudFNlcnZpY2VcbiAgKSB7XG4gICAgdGhpcy5fc3Vicy5wdXNoKFxuICAgICAgdGhpcy5fYXBwRXZlbnRTZXJ2aWNlLm9uVXBkYXRlUHJvZHVjdEluZm9UYWIuc3Vic2NyaWJlKChpbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICAgIHRoaXMudXBkYXRlVGFiKGluZGV4KTtcbiAgICAgICAgdGhpcy50YWJDb250ZW50Lm5hdGl2ZUVsZW1lbnQuc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgICB9KVxuICAgICk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9zdWJzLmZvckVhY2gocyA9PiBzLnVuc3Vic2NyaWJlKCkpO1xuICB9XG5cbiAgcHVibGljIHVwZGF0ZVRhYih0YWJJbmRleDogbnVtYmVyKSB7XG4gICAgdGhpcy5hY3RpdmVUYWIgPSB0YWJJbmRleDtcbiAgICB0aGlzLnVwZGF0ZUhlaWdodCh0YWJJbmRleCk7XG4gIH1cblxuICBwdWJsaWMgdXBkYXRlSGVpZ2h0KHRhYkluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAodGhpcy50YWJDb250ZW50Lm5hdGl2ZUVsZW1lbnQuY2hpbGRyZW4ubGVuZ3RoID4gMCkge1xuICAgICAgaWYgKHRoaXMudGFiQ29udGVudC5uYXRpdmVFbGVtZW50LmNoaWxkcmVuW3RhYkluZGV4XSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHRoaXMuYWN0aXZlVGFiSGVpZ2h0ID0gdGhpcy50YWJDb250ZW50Lm5hdGl2ZUVsZW1lbnQuY2hpbGRyZW5bdGFiSW5kZXhdLm9mZnNldEhlaWdodDtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBwcml2YXRlIF9zZXR1cFRhYnMoKTogdm9pZCB7XG4gICAgdGhpcy50YWJzLnB1c2goeyB0aXRsZTogJ0RFU0NSSVBUSU9OJyB9KTtcbiAgICB0aGlzLnRhYnMucHVzaCh7IHRpdGxlOiAnRkVBVFVSRVMnIH0pO1xuXG4gICAgaWYgKHRoaXMuYXJ0aWNsZU9iamVjdC5kb2N1bWVudHMgIT09IHVuZGVmaW5lZCAmJiB0aGlzLmFydGljbGVPYmplY3QuZG9jdW1lbnRzLmxlbmd0aCA+IDApIHtcbiAgICAgIHRoaXMudGFicy5wdXNoKHsgdGl0bGU6ICdET1dOTE9BRFMnIH0pO1xuICAgIH1cblxuICAgIGlmICh0aGlzLmFydGljbGVPYmplY3Quc3ltYm9scyAhPT0gdW5kZWZpbmVkICYmIHRoaXMuYXJ0aWNsZU9iamVjdC5zeW1ib2xzLmxlbmd0aCA+IDApIHtcbiAgICAgIHRoaXMudGFicy5wdXNoKHsgdGl0bGU6ICdTWU1CT0xTJyB9KTtcbiAgICB9XG5cbiAgfVxuXG59XG4iXX0=
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { ProductInfoTabsComponent } from './product-info-tabs.component';
|
|
4
|
-
import { PipeModule } from '../../pipe/pipe.module';
|
|
5
|
-
import { ProductAdditionalInfoModule } from '../product-additional-info/product-additional-info.module';
|
|
6
|
-
import { ProductPropertiesModule } from '../product-properties/product-properties.module';
|
|
7
|
-
import { ProductDocumentModule } from '../product-documents/product-document.module';
|
|
8
|
-
import { ProductSymbolsModule } from '../product-symbols/product-symbols.module';
|
|
9
|
-
export class ProductInfoTabsModule {
|
|
10
|
-
}
|
|
11
|
-
ProductInfoTabsModule.decorators = [
|
|
12
|
-
{ type: NgModule, args: [{
|
|
13
|
-
imports: [
|
|
14
|
-
CommonModule,
|
|
15
|
-
PipeModule,
|
|
16
|
-
ProductAdditionalInfoModule,
|
|
17
|
-
ProductPropertiesModule,
|
|
18
|
-
ProductDocumentModule,
|
|
19
|
-
ProductSymbolsModule
|
|
20
|
-
],
|
|
21
|
-
declarations: [
|
|
22
|
-
ProductInfoTabsComponent
|
|
23
|
-
],
|
|
24
|
-
exports: [
|
|
25
|
-
ProductInfoTabsComponent
|
|
26
|
-
]
|
|
27
|
-
},] }
|
|
28
|
-
];
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { ProductInfoTabsComponent } from './product-info-tabs.component';
|
|
4
|
+
import { PipeModule } from '../../pipe/pipe.module';
|
|
5
|
+
import { ProductAdditionalInfoModule } from '../product-additional-info/product-additional-info.module';
|
|
6
|
+
import { ProductPropertiesModule } from '../product-properties/product-properties.module';
|
|
7
|
+
import { ProductDocumentModule } from '../product-documents/product-document.module';
|
|
8
|
+
import { ProductSymbolsModule } from '../product-symbols/product-symbols.module';
|
|
9
|
+
export class ProductInfoTabsModule {
|
|
10
|
+
}
|
|
11
|
+
ProductInfoTabsModule.decorators = [
|
|
12
|
+
{ type: NgModule, args: [{
|
|
13
|
+
imports: [
|
|
14
|
+
CommonModule,
|
|
15
|
+
PipeModule,
|
|
16
|
+
ProductAdditionalInfoModule,
|
|
17
|
+
ProductPropertiesModule,
|
|
18
|
+
ProductDocumentModule,
|
|
19
|
+
ProductSymbolsModule
|
|
20
|
+
],
|
|
21
|
+
declarations: [
|
|
22
|
+
ProductInfoTabsComponent
|
|
23
|
+
],
|
|
24
|
+
exports: [
|
|
25
|
+
ProductInfoTabsComponent
|
|
26
|
+
]
|
|
27
|
+
},] }
|
|
28
|
+
];
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1pbmZvLXRhYnMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3Byb2R1Y3QtaW5mby10YWJzL3Byb2R1Y3QtaW5mby10YWJzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDbEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sMkRBQTJELENBQUM7QUFDdEcsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0saURBQWlELENBQUM7QUFDeEYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDbkYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFrQi9FLE1BQU0sT0FBTyxxQkFBcUI7OztZQWhCakMsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLFVBQVU7b0JBQ1YsMkJBQTJCO29CQUMzQix1QkFBdUI7b0JBQ3ZCLHFCQUFxQjtvQkFDckIsb0JBQW9CO2lCQUN2QjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1Ysd0JBQXdCO2lCQUMzQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ0wsd0JBQXdCO2lCQUMzQjthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7UHJvZHVjdEluZm9UYWJzQ29tcG9uZW50fSBmcm9tICcuL3Byb2R1Y3QtaW5mby10YWJzLmNvbXBvbmVudCc7XG5pbXBvcnQge1BpcGVNb2R1bGV9IGZyb20gJy4uLy4uL3BpcGUvcGlwZS5tb2R1bGUnO1xuaW1wb3J0IHtQcm9kdWN0QWRkaXRpb25hbEluZm9Nb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtYWRkaXRpb25hbC1pbmZvL3Byb2R1Y3QtYWRkaXRpb25hbC1pbmZvLm1vZHVsZSc7XG5pbXBvcnQge1Byb2R1Y3RQcm9wZXJ0aWVzTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LXByb3BlcnRpZXMvcHJvZHVjdC1wcm9wZXJ0aWVzLm1vZHVsZSc7XG5pbXBvcnQge1Byb2R1Y3REb2N1bWVudE1vZHVsZX0gZnJvbSAnLi4vcHJvZHVjdC1kb2N1bWVudHMvcHJvZHVjdC1kb2N1bWVudC5tb2R1bGUnO1xuaW1wb3J0IHtQcm9kdWN0U3ltYm9sc01vZHVsZX0gZnJvbSAnLi4vcHJvZHVjdC1zeW1ib2xzL3Byb2R1Y3Qtc3ltYm9scy5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBQaXBlTW9kdWxlLFxuICAgICAgICBQcm9kdWN0QWRkaXRpb25hbEluZm9Nb2R1bGUsXG4gICAgICAgIFByb2R1Y3RQcm9wZXJ0aWVzTW9kdWxlLFxuICAgICAgICBQcm9kdWN0RG9jdW1lbnRNb2R1bGUsXG4gICAgICAgIFByb2R1Y3RTeW1ib2xzTW9kdWxlXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtcbiAgICAgICAgUHJvZHVjdEluZm9UYWJzQ29tcG9uZW50XG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIFByb2R1Y3RJbmZvVGFic0NvbXBvbmVudFxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgUHJvZHVjdEluZm9UYWJzTW9kdWxlIHtcbn1cbiJdfQ==
|