@colijnit/product 259.1.3 → 259.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,9 +2,17 @@ import { __awaiter } from "tslib";
2
2
  import { Component, Input } from '@angular/core';
3
3
  import { ProductConnectorService } from '../../service/product-connector.service';
4
4
  import { ProductEventService } from '../../service/product-event.service';
5
- import { ProductConnectorAdapterService } from "../../service/product-connector-adapter.service";
6
- import { ConfiguratorStatisticsEnvironment } from "@colijnit/articleapi/build/model/configurator-statistics-environment";
7
- import { ProductSettingsService } from "../../service/product-settings.service";
5
+ import { ProductConnectorAdapterService } from '../../service/product-connector-adapter.service';
6
+ import { ConfiguratorStatisticsEnvironment } from '@colijnit/articleapi/build/model/configurator-statistics-environment';
7
+ import { ProductSettingsService } from '../../service/product-settings.service';
8
+ export class ArticleViewModel {
9
+ constructor(article, imageData) {
10
+ this.article = article;
11
+ if (imageData) {
12
+ this.imageData = imageData;
13
+ }
14
+ }
15
+ }
8
16
  export class ProductRelatedComponent {
9
17
  constructor(_iOne, _appEventService, _productConnectorAdapterService, _settingsService) {
10
18
  this._iOne = _iOne;
@@ -13,7 +21,7 @@ export class ProductRelatedComponent {
13
21
  this._settingsService = _settingsService;
14
22
  this.isSmallModus = true;
15
23
  this.createFrozenArticle = true;
16
- this.imageData = '';
24
+ this.articleViewModels = [];
17
25
  this._articles = [];
18
26
  }
19
27
  set articles(value) {
@@ -30,6 +38,8 @@ export class ProductRelatedComponent {
30
38
  else {
31
39
  this._articles = value;
32
40
  }
41
+ this.articleViewModels.length = 0;
42
+ this._articles.forEach(a => this.articleViewModels.push(new ArticleViewModel(a)));
33
43
  this._loadImages();
34
44
  }
35
45
  }
@@ -73,12 +83,13 @@ export class ProductRelatedComponent {
73
83
  });
74
84
  }
75
85
  _loadImages() {
76
- this._articles.forEach((a) => __awaiter(this, void 0, void 0, function* () {
77
- if (a.image) {
78
- const imageContent = yield this._iOne.getImageForCoDocument(a.image, false);
79
- this.imageData = imageContent.image;
80
- }
81
- }));
86
+ return __awaiter(this, void 0, void 0, function* () {
87
+ this.articleViewModels.forEach(avm => {
88
+ if (avm.article.image) {
89
+ this._iOne.getImageForCoDocument(avm.article.image, false).then(imageContent => avm.imageData = imageContent.image);
90
+ }
91
+ });
92
+ });
82
93
  }
83
94
  }
84
95
  ProductRelatedComponent.decorators = [
@@ -88,19 +99,19 @@ ProductRelatedComponent.decorators = [
88
99
  <div *ngIf="articles && articles.length > 0">
89
100
  <app-header [label]="label" [amount]="articles?.length" *ngIf="label"></app-header>
90
101
  <co-scroll-container>
91
- <div class="article-wrapper" *ngFor="let article of articles">
92
- <co-article-tile
93
- [imageData]="imageData"
94
- [description]="article.description"
95
- [price]="article.price"
96
- [level]="article.stockStatus"
102
+ <div class="article-wrapper" *ngFor="let articleViewModel of articleViewModels">
103
+ <co-article-tile
104
+ [imageData]="articleViewModel.imageData"
105
+ [description]="articleViewModel.article.description"
106
+ [price]="articleViewModel.article.price"
107
+ [level]="articleViewModel.article.stockStatus"
97
108
  [hasCartButton]="true"
98
109
  [isSmallModus]="isSmallModus"
99
- [hasConfigureButton]="article.goodType === 'B'"
100
- (contentClick)="handleContentClick(article)"
101
- (cartButtonClick)="handleAddToCartClick(article)"
102
- (configureButtonClick)="handleContentClick(article)"
103
- (threeDButtonClick)="handleThreeDButtonClick(article)"
110
+ [hasConfigureButton]="articleViewModel.article.goodType === 'B'"
111
+ (contentClick)="handleContentClick(articleViewModel.article)"
112
+ (cartButtonClick)="handleAddToCartClick(articleViewModel.article)"
113
+ (configureButtonClick)="handleContentClick(articleViewModel.article)"
114
+ (threeDButtonClick)="handleThreeDButtonClick(articleViewModel.article)"
104
115
  ></co-article-tile>
105
116
  </div>
106
117
  </co-scroll-container>
@@ -123,4 +134,4 @@ ProductRelatedComponent.propDecorators = {
123
134
  createFrozenArticle: [{ type: Input }],
124
135
  articles: [{ type: Input }]
125
136
  };
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-related.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-related/product-related.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input} from '@angular/core';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\nimport {ProductConnectorAdapterService} from \"../../service/product-connector-adapter.service\";\nimport {ArticleQuantity} from \"../../model/article-quantity.model\";\nimport {ConfiguratorStatisticsEnvironment} from \"@colijnit/articleapi/build/model/configurator-statistics-environment\";\nimport {ProductSettingsService} from \"../../service/product-settings.service\";\nimport {ArticleFullObject} from '@colijnit/articleapi/build/model/article-full-object';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\nimport {ImageContent} from '@colijnit/mainapi/build/model/image-content.bo';\n\n@Component({\n    selector: 'app-product-related',\n    template: `\n        <div *ngIf=\"articles && articles.length > 0\">\n            <app-header [label]=\"label\" [amount]=\"articles?.length\" *ngIf=\"label\"></app-header>\n            <co-scroll-container>\n                <div class=\"article-wrapper\" *ngFor=\"let article of articles\">\n                    <co-article-tile\n                        [imageData]=\"imageData\"\n                        [description]=\"article.description\"\n                        [price]=\"article.price\"\n                        [level]=\"article.stockStatus\"\n                        [hasCartButton]=\"true\"\n                        [isSmallModus]=\"isSmallModus\"\n                        [hasConfigureButton]=\"article.goodType === 'B'\"\n                        (contentClick)=\"handleContentClick(article)\"\n                        (cartButtonClick)=\"handleAddToCartClick(article)\"\n                        (configureButtonClick)=\"handleContentClick(article)\"\n                        (threeDButtonClick)=\"handleThreeDButtonClick(article)\"\n                    ></co-article-tile>\n                </div>\n            </co-scroll-container>\n        </div>\n    `,\n    styleUrls: ['./product-related.component.scss']\n})\nexport class ProductRelatedComponent {\n\n    @Input()\n    public refType: number;\n\n    @Input()\n    public label: string;\n\n    @Input()\n    public externalSource: ExternalSource;\n\n    @Input()\n    public isSmallModus: boolean = true;\n\n    @Input()\n    public createFrozenArticle: boolean = true;\n\n    @Input()\n    public set articles(value: ArticleListObject[]) {\n        if (value) {\n            if (this.refType && this.refType !== undefined) {\n                if (value.length > 0) {\n                    value.forEach((x: ArticleListObject) => {\n                        if (x.refType === this.refType) {\n                            this._articles.push(x);\n                        }\n                    });\n                }\n            } else {\n                this._articles = value;\n            }\n            this._loadImages();\n        }\n    }\n\n    public get articles(): ArticleListObject[] {\n        return this._articles;\n    }\n\n    public imageData: string = '';\n\n    private _articles: ArticleListObject[] = [];\n\n    constructor(\n        private _iOne: ProductConnectorService,\n        private _appEventService: ProductEventService,\n        private _productConnectorAdapterService: ProductConnectorAdapterService,\n        private _settingsService: ProductSettingsService\n    ) {\n    }\n\n    public handleContentClick(article: ArticleListObject): void {\n        this._appEventService.onAlternativeClick.next(article);\n    }\n\n    public async handleAddToCartClick(article: ArticleListObject): Promise<void> {\n        const quantity: number = 1;\n        const articleFull: ArticleFullObject = await this._productConnectorAdapterService.getArticleFullObject(article.goodId, true);\n        if (articleFull) {\n            if (this.createFrozenArticle) {\n                const article: ArticleListObjectExtended = this._iOne.convertArticleFullObjectToArticleExtended(articleFull);\n                this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n                // this._appEventService.onAddToCart.next({ article: await this._getJSONFromArticleObject({article: articleFull, quantity: quantity}), quantity: quantity });\n            } else {\n                const article: ArticleListObjectExtended = this._iOne.convertArticleFullObjectToArticleExtended(articleFull);\n                this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n            }\n        }\n    }\n\n    public handleConfigureButtonClick(article: ArticleListObject): void {\n\n    }\n\n    public handleThreeDButtonClick(article: ArticleListObject): void {\n\n    }\n\n    private async _getJSONFromArticleObject(article: ArticleQuantity): Promise<string> {\n        const configuratorStatistics = new ConfiguratorStatisticsEnvironment();\n        configuratorStatistics.userType = 'iOneProductPage';\n        configuratorStatistics.transactionType = 'Sales';\n        configuratorStatistics.actionDomain = 'bundle';\n        configuratorStatistics.sessionId = this._settingsService.settings.session ? this._settingsService.settings.session.sessionId : 'unknown';\n        configuratorStatistics.webHost = window.location.host;\n        configuratorStatistics.bundleHost = window.location.host;\n        return await this._iOne.getJsonArticleFlatTree(\n            article.article.goodId, article.article.goodType, article.quantity, !!this.externalSource, true, configuratorStatistics);\n    }\n\n    private _loadImages(): void {\n        this._articles.forEach(async (a: ArticleListObject) => {\n            if (a.image) {\n                const imageContent: ImageContent = await this._iOne.getImageForCoDocument(a.image, false);\n                this.imageData = imageContent.image\n            }\n        });\n    }\n}\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-related.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-related/product-related.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input} from '@angular/core';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\nimport {ArticleQuantity} from '../../model/article-quantity.model';\nimport {ConfiguratorStatisticsEnvironment} from '@colijnit/articleapi/build/model/configurator-statistics-environment';\nimport {ProductSettingsService} from '../../service/product-settings.service';\nimport {ArticleFullObject} from '@colijnit/articleapi/build/model/article-full-object';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\n\nexport class ArticleViewModel {\n    public article: ArticleListObject;\n    public imageData: string;\n    constructor(article: ArticleListObject, imageData?: string) {\n        this.article = article;\n        if (imageData) {\n            this.imageData = imageData;\n        }\n    }\n}\n\n@Component({\n    selector: 'app-product-related',\n    template: `\n        <div *ngIf=\"articles && articles.length > 0\">\n            <app-header [label]=\"label\" [amount]=\"articles?.length\" *ngIf=\"label\"></app-header>\n            <co-scroll-container>\n                <div class=\"article-wrapper\" *ngFor=\"let articleViewModel of articleViewModels\">\n                    <co-article-tile \n                        [imageData]=\"articleViewModel.imageData\"\n                        [description]=\"articleViewModel.article.description\"\n                        [price]=\"articleViewModel.article.price\"\n                        [level]=\"articleViewModel.article.stockStatus\"\n                        [hasCartButton]=\"true\"\n                        [isSmallModus]=\"isSmallModus\"\n                        [hasConfigureButton]=\"articleViewModel.article.goodType === 'B'\"\n                        (contentClick)=\"handleContentClick(articleViewModel.article)\"\n                        (cartButtonClick)=\"handleAddToCartClick(articleViewModel.article)\"\n                        (configureButtonClick)=\"handleContentClick(articleViewModel.article)\"\n                        (threeDButtonClick)=\"handleThreeDButtonClick(articleViewModel.article)\"\n                    ></co-article-tile>\n                </div>\n            </co-scroll-container>\n        </div>\n    `,\n    styleUrls: ['./product-related.component.scss']\n})\nexport class ProductRelatedComponent {\n\n    @Input()\n    public refType: number;\n\n    @Input()\n    public label: string;\n\n    @Input()\n    public externalSource: ExternalSource;\n\n    @Input()\n    public isSmallModus: boolean = true;\n\n    @Input()\n    public createFrozenArticle: boolean = true;\n\n    @Input()\n    public set articles(value: ArticleListObject[]) {\n        if (value) {\n            if (this.refType && this.refType !== undefined) {\n                if (value.length > 0) {\n                    value.forEach((x: ArticleListObject) => {\n                        if (x.refType === this.refType) {\n                            this._articles.push(x);\n                        }\n                    });\n                }\n            } else {\n                this._articles = value;\n            }\n            this.articleViewModels.length = 0;\n            this._articles.forEach(a => this.articleViewModels.push(new ArticleViewModel(a)));\n            this._loadImages();\n        }\n    }\n\n    public get articles(): ArticleListObject[] {\n        return this._articles;\n    }\n\n    public articleViewModels: ArticleViewModel[] = [];\n    private _articles: ArticleListObject[] = [];\n\n    constructor(\n        private _iOne: ProductConnectorService,\n        private _appEventService: ProductEventService,\n        private _productConnectorAdapterService: ProductConnectorAdapterService,\n        private _settingsService: ProductSettingsService\n    ) {\n    }\n\n    public handleContentClick(article: ArticleListObject): void {\n        this._appEventService.onAlternativeClick.next(article);\n    }\n\n    public async handleAddToCartClick(article: ArticleListObject): Promise<void> {\n        const quantity: number = 1;\n        const articleFull: ArticleFullObject = await this._productConnectorAdapterService.getArticleFullObject(article.goodId, true);\n        if (articleFull) {\n            if (this.createFrozenArticle) {\n                const article: ArticleListObjectExtended = this._iOne.convertArticleFullObjectToArticleExtended(articleFull);\n                this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n                // this._appEventService.onAddToCart.next({ article: await this._getJSONFromArticleObject({article: articleFull, quantity: quantity}), quantity: quantity });\n            } else {\n                const article: ArticleListObjectExtended = this._iOne.convertArticleFullObjectToArticleExtended(articleFull);\n                this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n            }\n        }\n    }\n\n    public handleConfigureButtonClick(article: ArticleListObject): void {\n\n    }\n\n    public handleThreeDButtonClick(article: ArticleListObject): void {\n\n    }\n\n    private async _getJSONFromArticleObject(article: ArticleQuantity): Promise<string> {\n        const configuratorStatistics = new ConfiguratorStatisticsEnvironment();\n        configuratorStatistics.userType = 'iOneProductPage';\n        configuratorStatistics.transactionType = 'Sales';\n        configuratorStatistics.actionDomain = 'bundle';\n        configuratorStatistics.sessionId = this._settingsService.settings.session ? this._settingsService.settings.session.sessionId : 'unknown';\n        configuratorStatistics.webHost = window.location.host;\n        configuratorStatistics.bundleHost = window.location.host;\n        return await this._iOne.getJsonArticleFlatTree(\n            article.article.goodId, article.article.goodType, article.quantity, !!this.externalSource, true, configuratorStatistics);\n    }\n\n    private async _loadImages(): Promise<void> {\n        this.articleViewModels.forEach(avm => {\n            if (avm.article.image) {\n                this._iOne.getImageForCoDocument(avm.article.image, false).then(imageContent => avm.imageData = imageContent.image);\n            }\n        })\n    }\n}\n"]}
@@ -3,8 +3,8 @@ export class Version {
3
3
  constructor() {
4
4
  this.name = "@colijnit/product";
5
5
  this.description = "Product detail page project for iOne";
6
- this.symVer = "259.1.3";
7
- this.publishDate = "29-9-2025 15:45:45";
6
+ this.symVer = "259.1.4";
7
+ this.publishDate = "7-1-2026 17:40:44";
8
8
  }
9
9
  }
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9wcm9kdWN0LXZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELE1BQU0sT0FBTyxPQUFPO0lBQXBCO1FBQ1MsU0FBSSxHQUFHLG1CQUFtQixDQUFDO1FBQzNCLGdCQUFXLEdBQUcsc0NBQXNDLENBQUM7UUFDckQsV0FBTSxHQUFHLFNBQVMsQ0FBQztRQUNuQixnQkFBVyxHQUFHLG9CQUFvQixDQUFDO0lBQzVDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRoaXMgZmlsZSBpcyBkeW5hbWljYWxseSBjcmVhdGVkLCBkbyBub3QgY2hhbmdlIHRoaXNcbmV4cG9ydCBjbGFzcyBWZXJzaW9uIHtcbiAgcHVibGljIG5hbWUgPSBcIkBjb2xpam5pdC9wcm9kdWN0XCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiUHJvZHVjdCBkZXRhaWwgcGFnZSBwcm9qZWN0IGZvciBpT25lXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1OS4xLjNcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCIyOS05LTIwMjUgMTU6NDU6NDVcIjtcbn0iXX0=
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9wcm9kdWN0LXZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELE1BQU0sT0FBTyxPQUFPO0lBQXBCO1FBQ1MsU0FBSSxHQUFHLG1CQUFtQixDQUFDO1FBQzNCLGdCQUFXLEdBQUcsc0NBQXNDLENBQUM7UUFDckQsV0FBTSxHQUFHLFNBQVMsQ0FBQztRQUNuQixnQkFBVyxHQUFHLG1CQUFtQixDQUFDO0lBQzNDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRoaXMgZmlsZSBpcyBkeW5hbWljYWxseSBjcmVhdGVkLCBkbyBub3QgY2hhbmdlIHRoaXNcbmV4cG9ydCBjbGFzcyBWZXJzaW9uIHtcbiAgcHVibGljIG5hbWUgPSBcIkBjb2xpam5pdC9wcm9kdWN0XCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiUHJvZHVjdCBkZXRhaWwgcGFnZSBwcm9qZWN0IGZvciBpT25lXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1OS4xLjRcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCI3LTEtMjAyNiAxNzo0MDo0NFwiO1xufSJdfQ==
@@ -31,8 +31,8 @@ class Version {
31
31
  constructor() {
32
32
  this.name = "@colijnit/product";
33
33
  this.description = "Product detail page project for iOne";
34
- this.symVer = "259.1.3";
35
- this.publishDate = "29-9-2025 15:45:45";
34
+ this.symVer = "259.1.4";
35
+ this.publishDate = "7-1-2026 17:40:44";
36
36
  }
37
37
  }
38
38
 
@@ -2064,6 +2064,14 @@ ProductAddtocartModule.decorators = [
2064
2064
  },] }
2065
2065
  ];
2066
2066
 
2067
+ class ArticleViewModel {
2068
+ constructor(article, imageData) {
2069
+ this.article = article;
2070
+ if (imageData) {
2071
+ this.imageData = imageData;
2072
+ }
2073
+ }
2074
+ }
2067
2075
  class ProductRelatedComponent {
2068
2076
  constructor(_iOne, _appEventService, _productConnectorAdapterService, _settingsService) {
2069
2077
  this._iOne = _iOne;
@@ -2072,7 +2080,7 @@ class ProductRelatedComponent {
2072
2080
  this._settingsService = _settingsService;
2073
2081
  this.isSmallModus = true;
2074
2082
  this.createFrozenArticle = true;
2075
- this.imageData = '';
2083
+ this.articleViewModels = [];
2076
2084
  this._articles = [];
2077
2085
  }
2078
2086
  set articles(value) {
@@ -2089,6 +2097,8 @@ class ProductRelatedComponent {
2089
2097
  else {
2090
2098
  this._articles = value;
2091
2099
  }
2100
+ this.articleViewModels.length = 0;
2101
+ this._articles.forEach(a => this.articleViewModels.push(new ArticleViewModel(a)));
2092
2102
  this._loadImages();
2093
2103
  }
2094
2104
  }
@@ -2132,12 +2142,13 @@ class ProductRelatedComponent {
2132
2142
  });
2133
2143
  }
2134
2144
  _loadImages() {
2135
- this._articles.forEach((a) => __awaiter(this, void 0, void 0, function* () {
2136
- if (a.image) {
2137
- const imageContent = yield this._iOne.getImageForCoDocument(a.image, false);
2138
- this.imageData = imageContent.image;
2139
- }
2140
- }));
2145
+ return __awaiter(this, void 0, void 0, function* () {
2146
+ this.articleViewModels.forEach(avm => {
2147
+ if (avm.article.image) {
2148
+ this._iOne.getImageForCoDocument(avm.article.image, false).then(imageContent => avm.imageData = imageContent.image);
2149
+ }
2150
+ });
2151
+ });
2141
2152
  }
2142
2153
  }
2143
2154
  ProductRelatedComponent.decorators = [
@@ -2147,19 +2158,19 @@ ProductRelatedComponent.decorators = [
2147
2158
  <div *ngIf="articles && articles.length > 0">
2148
2159
  <app-header [label]="label" [amount]="articles?.length" *ngIf="label"></app-header>
2149
2160
  <co-scroll-container>
2150
- <div class="article-wrapper" *ngFor="let article of articles">
2151
- <co-article-tile
2152
- [imageData]="imageData"
2153
- [description]="article.description"
2154
- [price]="article.price"
2155
- [level]="article.stockStatus"
2161
+ <div class="article-wrapper" *ngFor="let articleViewModel of articleViewModels">
2162
+ <co-article-tile
2163
+ [imageData]="articleViewModel.imageData"
2164
+ [description]="articleViewModel.article.description"
2165
+ [price]="articleViewModel.article.price"
2166
+ [level]="articleViewModel.article.stockStatus"
2156
2167
  [hasCartButton]="true"
2157
2168
  [isSmallModus]="isSmallModus"
2158
- [hasConfigureButton]="article.goodType === 'B'"
2159
- (contentClick)="handleContentClick(article)"
2160
- (cartButtonClick)="handleAddToCartClick(article)"
2161
- (configureButtonClick)="handleContentClick(article)"
2162
- (threeDButtonClick)="handleThreeDButtonClick(article)"
2169
+ [hasConfigureButton]="articleViewModel.article.goodType === 'B'"
2170
+ (contentClick)="handleContentClick(articleViewModel.article)"
2171
+ (cartButtonClick)="handleAddToCartClick(articleViewModel.article)"
2172
+ (configureButtonClick)="handleContentClick(articleViewModel.article)"
2173
+ (threeDButtonClick)="handleThreeDButtonClick(articleViewModel.article)"
2163
2174
  ></co-article-tile>
2164
2175
  </div>
2165
2176
  </co-scroll-container>