@colijnit/transaction 257.1.33 → 257.1.35

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.
@@ -29,6 +29,7 @@ export class AddProductComponent {
29
29
  this.showRelatedProductsPopup = false;
30
30
  this.cartPlusIcon = this.iconService.getIcon(this.icons.CartPlusRegular);
31
31
  this.cartMinIcon = this.iconService.getIcon(this.icons.CartMinusRegular);
32
+ this.pendingAddArticleAction = false;
32
33
  this._showCatalog = false;
33
34
  this._subs = [];
34
35
  }
@@ -59,35 +60,40 @@ export class AddProductComponent {
59
60
  }
60
61
  this.searchText = text;
61
62
  this._prepareCatalogRequest();
62
- this.searchText = undefined;
63
+ this._changeDetector.detectChanges();
64
+ this.searchText = "";
63
65
  // first check if there's a single article found
64
66
  // This is a two check step:
65
67
  // Check if there is an exact match on barcode, ean or articlenumber
66
68
  // if not: check with search like
67
69
  // else open catalogus
68
- const fullMatchSearch = yield this.transactionService.getArticleListWithBarcodeArticleNrEanCode(text);
69
- if (fullMatchSearch && fullMatchSearch.length === 1) {
70
- const article = yield this.transactionService.getArticleExtended(fullMatchSearch[0].articleNr);
71
- if (article.goodType === "B") {
72
- this.showCatalogDialog();
73
- }
74
- else {
75
- yield this.handleAddArticle(article);
76
- }
77
- }
78
- else {
79
- const foundArticles = yield this.transactionService.getArticles(this.catalogParameters);
80
- if (foundArticles && foundArticles.length === 1) {
81
- const article = yield this.transactionService.getArticleExtended(foundArticles[0].articleNumber);
70
+ if (!this.pendingAddArticleAction) {
71
+ const fullMatchSearch = yield this.transactionService.getArticleListWithBarcodeArticleNrEanCode(text);
72
+ if (fullMatchSearch && fullMatchSearch.length === 1) {
73
+ const article = yield this.transactionService.getArticleExtended(fullMatchSearch[0].articleNr);
82
74
  if (article.goodType === "B") {
83
75
  this.showCatalogDialog();
84
76
  }
85
77
  else {
78
+ this.pendingAddArticleAction = true;
86
79
  yield this.handleAddArticle(article);
87
80
  }
88
81
  }
89
82
  else {
90
- this.showCatalogDialog();
83
+ const foundArticles = yield this.transactionService.getArticles(this.catalogParameters);
84
+ if (foundArticles && foundArticles.length === 1) {
85
+ const article = yield this.transactionService.getArticleExtended(foundArticles[0].articleNumber);
86
+ if (article.goodType === "B") {
87
+ this.showCatalogDialog();
88
+ }
89
+ else {
90
+ this.pendingAddArticleAction = true;
91
+ yield this.handleAddArticle(article);
92
+ }
93
+ }
94
+ else {
95
+ this.showCatalogDialog();
96
+ }
91
97
  }
92
98
  }
93
99
  });
@@ -99,9 +105,13 @@ export class AddProductComponent {
99
105
  return __awaiter(this, void 0, void 0, function* () {
100
106
  if (this.handleAddArticleInternally) {
101
107
  const success = yield this.transactionService.addArticle(article.articleNumber, this.return ? -1 : 1);
102
- if (!success) {
108
+ if (success) {
109
+ this.searchText = "";
110
+ }
111
+ else {
103
112
  this.transactionService.rollback();
104
113
  }
114
+ this.pendingAddArticleAction = false;
105
115
  }
106
116
  else {
107
117
  this.addArticle.next({
@@ -111,6 +121,7 @@ export class AddProductComponent {
111
121
  belowLineNr: 0,
112
122
  lastArticle: true
113
123
  });
124
+ this.pendingAddArticleAction = false;
114
125
  }
115
126
  });
116
127
  }
@@ -121,29 +132,7 @@ export class AddProductComponent {
121
132
  // }
122
133
  this.showCatalog = false;
123
134
  if (this.handleAddArticleInternally) {
124
- if (data && data.article) {
125
- if (typeof data.article === 'string') {
126
- const article = JSON.parse(data.article);
127
- if (article.selectorData.compositions) { // configured (frozen) article
128
- yield this.transactionService.addArticle(article.selectorData.compositions[0].compositionArticleNo, data.quantity, 0, 0, true, true);
129
- }
130
- else if (article.selectorData.articleNr) { // flat article
131
- yield this.transactionService.addArticle(article.selectorData.articleNr, data.quantity, 0, 0, true, true);
132
- }
133
- }
134
- else { // flat (simple) article
135
- let articleNr;
136
- if (data.article instanceof ArticleExtended) {
137
- articleNr = data.article.articleNumber;
138
- }
139
- else {
140
- articleNr = data.article.hasOwnProperty('articleNr') ? data.article['articleNr'] : data.article['articleNo'];
141
- }
142
- if (articleNr) {
143
- yield this.transactionService.addArticle(articleNr, data.quantity, 0, 0, true, true);
144
- }
145
- }
146
- }
135
+ yield this._handleArticleTypeOnAdd(data);
147
136
  }
148
137
  else {
149
138
  if (data && data.article instanceof ArticleExtended) {
@@ -158,6 +147,46 @@ export class AddProductComponent {
158
147
  }
159
148
  });
160
149
  }
150
+ _tryAddArticle(articleNr, quantity) {
151
+ return __awaiter(this, void 0, void 0, function* () {
152
+ const success = yield this.transactionService.addArticle(articleNr, quantity, 0, 0, true, true);
153
+ console.log(success);
154
+ if (success) {
155
+ this.searchText = "";
156
+ }
157
+ else {
158
+ // keep the search text
159
+ this.searchText = this.inputSearchText.model;
160
+ }
161
+ });
162
+ }
163
+ _handleArticleTypeOnAdd(data) {
164
+ return __awaiter(this, void 0, void 0, function* () {
165
+ if (data && data.article) {
166
+ if (typeof data.article === 'string') {
167
+ const article = JSON.parse(data.article);
168
+ if (article.selectorData.compositions) { // configured (frozen) article
169
+ yield this._tryAddArticle(article.selectorData.compositions[0].compositionArticleNo, data.quantity);
170
+ }
171
+ else if (article.selectorData.articleNr) { // flat article
172
+ yield this._tryAddArticle(article.selectorData.articleNr, data.quantity);
173
+ }
174
+ }
175
+ else { // flat (simple) article
176
+ let articleNr;
177
+ if (data.article instanceof ArticleExtended) {
178
+ articleNr = data.article.articleNumber;
179
+ }
180
+ else {
181
+ articleNr = data.article.hasOwnProperty('articleNr') ? data.article['articleNr'] : data.article['articleNo'];
182
+ }
183
+ if (articleNr) {
184
+ yield this._tryAddArticle(articleNr, data.quantity);
185
+ }
186
+ }
187
+ }
188
+ });
189
+ }
161
190
  getActualQuantity(quantityInput) {
162
191
  let quantity = 0;
163
192
  if (this.return && quantityInput > 0) {
@@ -176,6 +205,11 @@ export class AddProductComponent {
176
205
  }
177
206
  showCatalogDialog() {
178
207
  this.showCatalog = true;
208
+ this.pendingAddArticleAction = false;
209
+ }
210
+ handleCloseCatalogueClick() {
211
+ this.showCatalog = false;
212
+ this.searchText = "";
179
213
  }
180
214
  handleCartIconClick(event) {
181
215
  this.return = !this.return;
@@ -185,7 +219,7 @@ export class AddProductComponent {
185
219
  this.searchText = this.inputSearchText.model;
186
220
  }
187
221
  this._prepareCatalogRequest();
188
- this.searchText = undefined;
222
+ // this.searchText = undefined;
189
223
  this.showCatalogDialog();
190
224
  }
191
225
  handleIFrameFeedback(iFrameFeedbackObject) {
@@ -247,7 +281,7 @@ AddProductComponent.decorators = [
247
281
  [isReturn]="return"
248
282
  [showRelatedProductsPopup]="showRelatedProductsPopup"
249
283
  [transaction]="transactionService.currentTransaction"
250
- (closeClick)="showCatalog = false"
284
+ (closeClick)="handleCloseCatalogueClick()"
251
285
  (articleClicked)="handleCatalogArticleClick($event)"
252
286
  (addArticleClicked)="handleAddArticleClick($event)"
253
287
  (addCatFarmArticleClicked)="handleAddCatFarmArticleClick($event)"
@@ -271,4 +305,4 @@ AddProductComponent.propDecorators = {
271
305
  showClass: [{ type: HostBinding, args: ['class.co-add-product',] }],
272
306
  return: [{ type: HostBinding, args: ['class.return',] }]
273
307
  };
274
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-product.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/add-product/add-product.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {ArticleExtended} from '@colijnit/articleapi/build/model/article-extended.bo';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {ArticleLight} from '@colijnit/articleapi/build/model/article-light.bo';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {\r\n    ExternalCatalogAddArticleRequest\r\n} from '@colijnit/transactionapi/build/model/external-catalog-add-article-request';\r\nimport {ExternalCatalogTypes} from '@colijnit/transactionapi/build/enum/external-catalog-types.enum';\r\nimport {InputScannerComponent} from '@colijnit/corecomponents_v12';\r\nimport {TransactionEventService} from \"../../service/transaction-event.service\";\r\nimport {Subscription} from \"rxjs\";\r\n\r\nexport interface AddArticleInterface {\r\n    article: ArticleExtended;\r\n    quantity: number;\r\n    aboveLineNr: number;\r\n    belowLineNr: number;\r\n    lastArticle: boolean;\r\n}\r\n\r\n@Component({\r\n    selector: 'co-add-product',\r\n    template: `\r\n        <co-input-scanner\r\n            #inputSearch\r\n            [customCssClass]=\"'no-focus-line'\"\r\n            [(model)]=\"searchText\"\r\n            [placeholder]=\"'SEARCH_ADD_ARTICLE' | localize\"\r\n            [centerLabel]=\"true\"\r\n            [useLeftIcon]=\"true\"\r\n            [leftIconData]=\"return ? cartMinIcon : cartPlusIcon\"\r\n            [useRightIcon]=\"true\"\r\n            (leftIconClick)=\"handleCartIconClick($event)\"\r\n            (rightIconClick)=\"handleSearchIconClick()\"\r\n            (barCodeScanned)=\"handleSearch($event)\"\r\n            (search)=\"handleSearch($event)\"\r\n            (isFocused)=\"handleInputFocus($event)\"\r\n        ></co-input-scanner>\r\n        <co-dialog-catalog *ngIf=\"showCatalog\"\r\n                           [options]=\"catalogOptions\"\r\n                           [parameters]=\"catalogParameters\"\r\n                           [handleAddArticleInternally]=\"handleAddArticleInternally\"\r\n                           [showNavigation]=\"true\"\r\n                           [isReturn]=\"return\"\r\n                           [showRelatedProductsPopup]=\"showRelatedProductsPopup\"\r\n                           [transaction]=\"transactionService.currentTransaction\"\r\n                           (closeClick)=\"showCatalog = false\"\r\n                           (articleClicked)=\"handleCatalogArticleClick($event)\"\r\n                           (addArticleClicked)=\"handleAddArticleClick($event)\"\r\n                           (addCatFarmArticleClicked)=\"handleAddCatFarmArticleClick($event)\"\r\n                           (iFrameFeedback)=\"handleIFrameFeedback($event)\"\r\n        >\r\n        </co-dialog-catalog>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AddProductComponent implements OnInit {\r\n    public readonly icons: typeof Icon = Icon;\r\n\r\n    @Input()\r\n    public handleAddArticleInternally: boolean = true;\r\n\r\n    @Output()\r\n    public addArticle: EventEmitter<AddArticleInterface> = new EventEmitter<AddArticleInterface>();\r\n\r\n    @ViewChild('inputSearch')\r\n    public inputSearchText: InputScannerComponent;\r\n\r\n    @HostBinding('class.co-add-product')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    @HostBinding('class.return')\r\n    public return: boolean = false;\r\n\r\n    public catalogOptions: any = {\r\n        searchOnStart: true,\r\n        showAddToCart: false,\r\n        showLookAtArticleButton: false,\r\n        showAddArticleButton: true,\r\n        onlyThreeD: false\r\n    };\r\n    public catalogParameters: any = {};\r\n\r\n    public isSearchInputFocused: boolean = false;\r\n    public searchText: string;\r\n\r\n    public showRelatedProductsPopup: boolean = false;\r\n\r\n    public cartPlusIcon: SafeHtml = this.iconService.getIcon(this.icons.CartPlusRegular);\r\n    public cartMinIcon: SafeHtml = this.iconService.getIcon(this.icons.CartMinusRegular);\r\n\r\n    public set showCatalog(value: boolean) {\r\n        this._showCatalog = value;\r\n        this.showRelatedProductsPopup = false;\r\n    }\r\n\r\n    public get showCatalog(): boolean {\r\n        return this._showCatalog;\r\n    }\r\n\r\n    private _showCatalog: boolean = false;\r\n    private _subs: Subscription[] = [];\r\n\r\n    constructor(\r\n        public iconService: IconCacheService,\r\n        public transactionService: TransactionService,\r\n        public transactionEventService: TransactionEventService,\r\n        private _changeDetector: ChangeDetectorRef\r\n    ) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this._subs.push(\r\n            this.transactionEventService.afterAddTransactionLine.subscribe((bool) => {\r\n                if (bool) {\r\n                    this.showRelatedProductsPopup = true;\r\n                }\r\n            })\r\n        )\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.forEach(s => s.unsubscribe());\r\n    }\r\n\r\n    public async handleSearch(text: string): Promise<void> {\r\n        if (!this.isSearchInputFocused) {\r\n            return;\r\n        }\r\n        this.searchText = text;\r\n        this._prepareCatalogRequest();\r\n        this.searchText = undefined;\r\n        // first check if there's a single article found\r\n        // This is a two check step:\r\n        // Check if there is an exact match on barcode, ean or articlenumber\r\n        // if not: check with search like\r\n        // else open catalogus\r\n\r\n        const fullMatchSearch: any[] = await this.transactionService.getArticleListWithBarcodeArticleNrEanCode(text);\r\n        if (fullMatchSearch && fullMatchSearch.length === 1) {\r\n            const article: ArticleExtended = await this.transactionService.getArticleExtended(fullMatchSearch[0].articleNr);\r\n            if (article.goodType === \"B\") {\r\n                this.showCatalogDialog();\r\n            } else {\r\n                await this.handleAddArticle(article);\r\n            }\r\n        } else {\r\n            const foundArticles: ArticleLight[] = await this.transactionService.getArticles(this.catalogParameters);\r\n            if (foundArticles && foundArticles.length === 1) {\r\n                const article: ArticleExtended = await this.transactionService.getArticleExtended(foundArticles[0].articleNumber);\r\n                if (article.goodType === \"B\") {\r\n                    this.showCatalogDialog();\r\n                } else {\r\n                    await this.handleAddArticle(article);\r\n                }\r\n            } else {\r\n                this.showCatalogDialog();\r\n            }\r\n        }\r\n    }\r\n\r\n    public handleInputFocus(isFocused: boolean) {\r\n        this.isSearchInputFocused = isFocused;\r\n    }\r\n\r\n    public async handleAddArticle(article: ArticleExtended): Promise<void> {\r\n        if (this.handleAddArticleInternally) {\r\n            const success: boolean = await this.transactionService.addArticle(article.articleNumber, this.return ? -1 : 1);\r\n            if (!success) {\r\n                this.transactionService.rollback();\r\n            }\r\n        } else {\r\n            this.addArticle.next({\r\n                article: article,\r\n                quantity: this.return ? -1 : 1,\r\n                aboveLineNr: 0,\r\n                belowLineNr: 0,\r\n                lastArticle: true\r\n            });\r\n        }\r\n    }\r\n\r\n    public async handleAddArticleClick(data: { article: string | ArticleExtended, quantity: number }): Promise<void> {\r\n        // if (!this.showRelatedProductsPopup) {\r\n        //     this.showCatalog = false;\r\n        // }\r\n        this.showCatalog = false;\r\n        if (this.handleAddArticleInternally) {\r\n            if (data && data.article) {\r\n                if (typeof data.article === 'string') {\r\n                    const article = JSON.parse(data.article as string);\r\n                    if (article.selectorData.compositions) {  // configured (frozen) article\r\n                        await this.transactionService.addArticle(article.selectorData.compositions[0].compositionArticleNo, data.quantity, 0, 0, true, true);\r\n                    } else if (article.selectorData.articleNr) { // flat article\r\n                        await this.transactionService.addArticle(article.selectorData.articleNr, data.quantity, 0, 0, true, true);\r\n                    }\r\n                } else { // flat (simple) article\r\n                    let articleNr: string;\r\n                    if (data.article instanceof ArticleExtended) {\r\n                        articleNr = data.article.articleNumber;\r\n                    } else {\r\n                        articleNr = (data.article as any).hasOwnProperty('articleNr') ? data.article['articleNr'] : data.article['articleNo'];\r\n                    }\r\n                    if (articleNr) {\r\n                        await this.transactionService.addArticle(articleNr, data.quantity, 0, 0, true, true);\r\n                    }\r\n                }\r\n            }\r\n        } else {\r\n            if (data && data.article instanceof ArticleExtended) {\r\n                this.addArticle.next({\r\n                    article: data.article,\r\n                    quantity: this.getActualQuantity(data.quantity),\r\n                    aboveLineNr: 0,\r\n                    belowLineNr: 0,\r\n                    lastArticle: true\r\n                });\r\n            }\r\n        }\r\n    }\r\n\r\n    public getActualQuantity(quantityInput): number {\r\n        let quantity: number = 0;\r\n        if (this.return && quantityInput > 0) {\r\n            quantity = -1;\r\n        } else {\r\n            quantity = quantityInput;\r\n        }\r\n        return quantity;\r\n    }\r\n\r\n    public async handleCatalogArticleClick(article: ArticleExtended): Promise<void> {\r\n        await this.handleAddArticle(article);\r\n        this.showCatalog = false;\r\n    }\r\n\r\n    public showCatalogDialog(): void {\r\n        this.showCatalog = true;\r\n    }\r\n\r\n    public handleCartIconClick(event: MouseEvent): void {\r\n        this.return = !this.return;\r\n    }\r\n\r\n    public handleSearchIconClick(): void {\r\n        if (this.inputSearchText.model) {\r\n            this.searchText = this.inputSearchText.model;\r\n        }\r\n        this._prepareCatalogRequest();\r\n        this.searchText = undefined;\r\n        this.showCatalogDialog();\r\n    }\r\n\r\n    public async handleIFrameFeedback(iFrameFeedbackObject: {\r\n        jsonString: string,\r\n        catalog: number,\r\n        sourceType: string\r\n    }): Promise<void> {\r\n        this.showCatalog = false;\r\n        let request: ExternalCatalogAddArticleRequest = new ExternalCatalogAddArticleRequest();\r\n        request.catalogId = iFrameFeedbackObject.catalog;\r\n        request.catalogType = iFrameFeedbackObject.sourceType;\r\n        request.articleJson = iFrameFeedbackObject.jsonString;\r\n        await this.transactionService.addExternalCatalogArticle(request, true);\r\n    }\r\n\r\n    public async handleAddCatFarmArticleClick(data: {\r\n        quantity: number,\r\n        jsonString: string,\r\n        catalog: number\r\n    }): Promise<void> {\r\n        this.showCatalog = false;\r\n        let request: ExternalCatalogAddArticleRequest = new ExternalCatalogAddArticleRequest();\r\n        request.catalogId = data.catalog;\r\n        request.catalogType = ExternalCatalogTypes.CatalogFarm;\r\n        request.articleJson = data.jsonString;\r\n        await this.transactionService.addExternalCatalogArticle(request, true);\r\n    }\r\n\r\n    private _prepareCatalogRequest(): void {\r\n        this.catalogParameters.general = this.searchText;\r\n        this.catalogParameters.showRegularArticles = true;\r\n        this.catalogParameters.showConfiguredArticles = false;\r\n        this.catalogParameters.showConfigurableArticles = true;\r\n        this.catalogParameters.showCompositionArticles = false;\r\n        this.catalogParameters.showCustomizedArticles = false;\r\n        this.catalogParameters.showInactiveArticles = false;\r\n        this.catalogParameters.publicationCode = 71; // todo: fix this?\r\n        this.catalogParameters.isReturn = this.return;\r\n    }\r\n}\r\n"]}
308
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-product.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/add-product/add-product.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {ArticleExtended} from '@colijnit/articleapi/build/model/article-extended.bo';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {ArticleLight} from '@colijnit/articleapi/build/model/article-light.bo';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {\r\n    ExternalCatalogAddArticleRequest\r\n} from '@colijnit/transactionapi/build/model/external-catalog-add-article-request';\r\nimport {ExternalCatalogTypes} from '@colijnit/transactionapi/build/enum/external-catalog-types.enum';\r\nimport {InputScannerComponent} from '@colijnit/corecomponents_v12';\r\nimport {TransactionEventService} from \"../../service/transaction-event.service\";\r\nimport {Subscription} from \"rxjs\";\r\n\r\nexport interface AddArticleInterface {\r\n    article: ArticleExtended;\r\n    quantity: number;\r\n    aboveLineNr: number;\r\n    belowLineNr: number;\r\n    lastArticle: boolean;\r\n}\r\n\r\n@Component({\r\n    selector: 'co-add-product',\r\n    template: `\r\n        <co-input-scanner\r\n            #inputSearch\r\n            [customCssClass]=\"'no-focus-line'\"\r\n            [(model)]=\"searchText\"\r\n            [placeholder]=\"'SEARCH_ADD_ARTICLE' | localize\"\r\n            [centerLabel]=\"true\"\r\n            [useLeftIcon]=\"true\"\r\n            [leftIconData]=\"return ? cartMinIcon : cartPlusIcon\"\r\n            [useRightIcon]=\"true\"\r\n            (leftIconClick)=\"handleCartIconClick($event)\"\r\n            (rightIconClick)=\"handleSearchIconClick()\"\r\n            (barCodeScanned)=\"handleSearch($event)\"\r\n            (search)=\"handleSearch($event)\"\r\n            (isFocused)=\"handleInputFocus($event)\"\r\n        ></co-input-scanner>\r\n        <co-dialog-catalog *ngIf=\"showCatalog\"\r\n                           [options]=\"catalogOptions\"\r\n                           [parameters]=\"catalogParameters\"\r\n                           [handleAddArticleInternally]=\"handleAddArticleInternally\"\r\n                           [showNavigation]=\"true\"\r\n                           [isReturn]=\"return\"\r\n                           [showRelatedProductsPopup]=\"showRelatedProductsPopup\"\r\n                           [transaction]=\"transactionService.currentTransaction\"\r\n                           (closeClick)=\"handleCloseCatalogueClick()\"\r\n                           (articleClicked)=\"handleCatalogArticleClick($event)\"\r\n                           (addArticleClicked)=\"handleAddArticleClick($event)\"\r\n                           (addCatFarmArticleClicked)=\"handleAddCatFarmArticleClick($event)\"\r\n                           (iFrameFeedback)=\"handleIFrameFeedback($event)\"\r\n        >\r\n        </co-dialog-catalog>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AddProductComponent implements OnInit {\r\n    public readonly icons: typeof Icon = Icon;\r\n\r\n    @Input()\r\n    public handleAddArticleInternally: boolean = true;\r\n\r\n    @Output()\r\n    public addArticle: EventEmitter<AddArticleInterface> = new EventEmitter<AddArticleInterface>();\r\n\r\n    @ViewChild('inputSearch')\r\n    public inputSearchText: InputScannerComponent;\r\n\r\n    @HostBinding('class.co-add-product')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    @HostBinding('class.return')\r\n    public return: boolean = false;\r\n\r\n    public catalogOptions: any = {\r\n        searchOnStart: true,\r\n        showAddToCart: false,\r\n        showLookAtArticleButton: false,\r\n        showAddArticleButton: true,\r\n        onlyThreeD: false\r\n    };\r\n    public catalogParameters: any = {};\r\n\r\n    public isSearchInputFocused: boolean = false;\r\n    public searchText: string;\r\n\r\n    public showRelatedProductsPopup: boolean = false;\r\n\r\n    public cartPlusIcon: SafeHtml = this.iconService.getIcon(this.icons.CartPlusRegular);\r\n    public cartMinIcon: SafeHtml = this.iconService.getIcon(this.icons.CartMinusRegular);\r\n\r\n    public pendingAddArticleAction: boolean = false;\r\n\r\n    public set showCatalog(value: boolean) {\r\n        this._showCatalog = value;\r\n        this.showRelatedProductsPopup = false;\r\n    }\r\n\r\n    public get showCatalog(): boolean {\r\n        return this._showCatalog;\r\n    }\r\n\r\n    private _showCatalog: boolean = false;\r\n    private _subs: Subscription[] = [];\r\n\r\n    constructor(\r\n        public iconService: IconCacheService,\r\n        public transactionService: TransactionService,\r\n        public transactionEventService: TransactionEventService,\r\n        private _changeDetector: ChangeDetectorRef\r\n    ) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this._subs.push(\r\n            this.transactionEventService.afterAddTransactionLine.subscribe((bool) => {\r\n                if (bool) {\r\n                    this.showRelatedProductsPopup = true;\r\n                }\r\n            })\r\n        )\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.forEach(s => s.unsubscribe());\r\n    }\r\n\r\n    public async handleSearch(text: string): Promise<void> {\r\n        if (!this.isSearchInputFocused) {\r\n            return;\r\n        }\r\n        this.searchText = text;\r\n        this._prepareCatalogRequest();\r\n        this._changeDetector.detectChanges()\r\n        this.searchText = \"\";\r\n        // first check if there's a single article found\r\n        // This is a two check step:\r\n        // Check if there is an exact match on barcode, ean or articlenumber\r\n        // if not: check with search like\r\n        // else open catalogus\r\n        if (!this.pendingAddArticleAction) {\r\n            const fullMatchSearch: any[] = await this.transactionService.getArticleListWithBarcodeArticleNrEanCode(text);\r\n            if (fullMatchSearch && fullMatchSearch.length === 1) {\r\n                const article: ArticleExtended = await this.transactionService.getArticleExtended(fullMatchSearch[0].articleNr);\r\n                if (article.goodType === \"B\") {\r\n                    this.showCatalogDialog();\r\n                } else {\r\n                    this.pendingAddArticleAction = true;\r\n                    await this.handleAddArticle(article);\r\n                }\r\n            } else {\r\n                const foundArticles: ArticleLight[] = await this.transactionService.getArticles(this.catalogParameters);\r\n                if (foundArticles && foundArticles.length === 1) {\r\n                    const article: ArticleExtended = await this.transactionService.getArticleExtended(foundArticles[0].articleNumber);\r\n                    if (article.goodType === \"B\") {\r\n                        this.showCatalogDialog();\r\n                    } else {\r\n                        this.pendingAddArticleAction = true;\r\n                        await this.handleAddArticle(article);\r\n                    }\r\n                } else {\r\n                    this.showCatalogDialog();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public handleInputFocus(isFocused: boolean) {\r\n        this.isSearchInputFocused = isFocused;\r\n    }\r\n\r\n    public async handleAddArticle(article: ArticleExtended): Promise<void> {\r\n        if (this.handleAddArticleInternally) {\r\n            const success: boolean = await this.transactionService.addArticle(article.articleNumber, this.return ? -1 : 1)\r\n\r\n            if (success) {\r\n                this.searchText = \"\"\r\n            } else {\r\n                this.transactionService.rollback();\r\n            }\r\n            this.pendingAddArticleAction = false;\r\n        } else {\r\n            this.addArticle.next({\r\n                article: article,\r\n                quantity: this.return ? -1 : 1,\r\n                aboveLineNr: 0,\r\n                belowLineNr: 0,\r\n                lastArticle: true\r\n            });\r\n            this.pendingAddArticleAction = false;\r\n        }\r\n    }\r\n\r\n    public async handleAddArticleClick(data: { article: string | ArticleExtended, quantity: number }): Promise<void> {\r\n        // if (!this.showRelatedProductsPopup) {\r\n        //     this.showCatalog = false;\r\n        // }\r\n        this.showCatalog = false;\r\n        if (this.handleAddArticleInternally) {\r\n            await this._handleArticleTypeOnAdd(data);\r\n        } else {\r\n            if (data && data.article instanceof ArticleExtended) {\r\n                this.addArticle.next({\r\n                    article: data.article,\r\n                    quantity: this.getActualQuantity(data.quantity),\r\n                    aboveLineNr: 0,\r\n                    belowLineNr: 0,\r\n                    lastArticle: true\r\n                });\r\n            }\r\n        }\r\n    }\r\n\r\n    private async _tryAddArticle(articleNr: string, quantity: number) {\r\n        const success = await this.transactionService.addArticle(articleNr, quantity, 0, 0, true, true);\r\n        console.log(success)\r\n        if (success) {\r\n            this.searchText = \"\"\r\n        } else {\r\n            // keep the search text\r\n            this.searchText = this.inputSearchText.model;\r\n        }\r\n    }\r\n\r\n    private async _handleArticleTypeOnAdd(data: { article: string | ArticleExtended; quantity: number }) {\r\n        if (data && data.article) {\r\n            if (typeof data.article === 'string') {\r\n                const article = JSON.parse(data.article as string);\r\n                if (article.selectorData.compositions) {  // configured (frozen) article\r\n                    await this._tryAddArticle(article.selectorData.compositions[0].compositionArticleNo, data.quantity);\r\n                } else if (article.selectorData.articleNr) { // flat article\r\n                    await this._tryAddArticle(article.selectorData.articleNr, data.quantity)\r\n                }\r\n            } else { // flat (simple) article\r\n                let articleNr: string;\r\n\r\n                if (data.article instanceof ArticleExtended) {\r\n                    articleNr = data.article.articleNumber;\r\n                } else {\r\n                    articleNr = (data.article as any).hasOwnProperty('articleNr') ? data.article['articleNr'] : data.article['articleNo'];\r\n                }\r\n                if (articleNr) {\r\n                    await this._tryAddArticle(articleNr, data.quantity,)\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public getActualQuantity(quantityInput): number {\r\n        let quantity: number = 0;\r\n        if (this.return && quantityInput > 0) {\r\n            quantity = -1;\r\n        } else {\r\n            quantity = quantityInput;\r\n        }\r\n        return quantity;\r\n    }\r\n\r\n    public async handleCatalogArticleClick(article: ArticleExtended): Promise<void> {\r\n        await this.handleAddArticle(article);\r\n        this.showCatalog = false;\r\n    }\r\n\r\n    public showCatalogDialog(): void {\r\n        this.showCatalog = true;\r\n        this.pendingAddArticleAction = false;\r\n    }\r\n\r\n    public handleCloseCatalogueClick() {\r\n        this.showCatalog = false;\r\n        this.searchText = \"\";\r\n    }\r\n\r\n    public handleCartIconClick(event: MouseEvent): void {\r\n        this.return = !this.return;\r\n    }\r\n\r\n    public handleSearchIconClick(): void {\r\n        if (this.inputSearchText.model) {\r\n            this.searchText = this.inputSearchText.model;\r\n        }\r\n        this._prepareCatalogRequest();\r\n        // this.searchText = undefined;\r\n        this.showCatalogDialog();\r\n    }\r\n\r\n    public async handleIFrameFeedback(iFrameFeedbackObject: {\r\n        jsonString: string,\r\n        catalog: number,\r\n        sourceType: string\r\n    }): Promise<void> {\r\n        this.showCatalog = false;\r\n        let request: ExternalCatalogAddArticleRequest = new ExternalCatalogAddArticleRequest();\r\n        request.catalogId = iFrameFeedbackObject.catalog;\r\n        request.catalogType = iFrameFeedbackObject.sourceType;\r\n        request.articleJson = iFrameFeedbackObject.jsonString;\r\n        await this.transactionService.addExternalCatalogArticle(request, true);\r\n    }\r\n\r\n    public async handleAddCatFarmArticleClick(data: {\r\n        quantity: number,\r\n        jsonString: string,\r\n        catalog: number\r\n    }): Promise<void> {\r\n        this.showCatalog = false;\r\n        let request: ExternalCatalogAddArticleRequest = new ExternalCatalogAddArticleRequest();\r\n        request.catalogId = data.catalog;\r\n        request.catalogType = ExternalCatalogTypes.CatalogFarm;\r\n        request.articleJson = data.jsonString;\r\n        await this.transactionService.addExternalCatalogArticle(request, true);\r\n    }\r\n\r\n    private _prepareCatalogRequest(): void {\r\n        this.catalogParameters.general = this.searchText;\r\n        this.catalogParameters.showRegularArticles = true;\r\n        this.catalogParameters.showConfiguredArticles = false;\r\n        this.catalogParameters.showConfigurableArticles = true;\r\n        this.catalogParameters.showCompositionArticles = false;\r\n        this.catalogParameters.showCustomizedArticles = false;\r\n        this.catalogParameters.showInactiveArticles = false;\r\n        this.catalogParameters.publicationCode = 71; // todo: fix this?\r\n        this.catalogParameters.isReturn = this.return;\r\n    }\r\n}\r\n"]}
@@ -59,6 +59,10 @@ export class TransactionLineImageAndDescriptionComponent extends TransactionLine
59
59
  transactionLineSet() {
60
60
  super.transactionLineSet();
61
61
  this._loadLineImage();
62
+ if (this.transactionLine.configurationReadable) {
63
+ // @ts-ignore
64
+ this.transactionLine.configurationReadable = this.transactionLine.configurationReadable.replaceAll('\n', '<br>');
65
+ }
62
66
  }
63
67
  visibilitySet() {
64
68
  super.visibilitySet();
@@ -113,10 +117,10 @@ TransactionLineImageAndDescriptionComponent.decorators = [
113
117
  screenConfigNativeElement>
114
118
  <div [ngClass]="{'article-text-expand': true, 'large-article': !expanded && !customerPortal}" class="co-small-scrollbar">
115
119
  <div class="article-text" *ngFor="let text of transactionLine.articleTextAsArray">
116
- <span [innerHTML]="text | safeHtml" (dblclick)="handleOpenArticleText()"></span>
120
+ <div [innerHTML]="text | safeHtml" (dblclick)="handleOpenArticleText()"></div>
117
121
  </div>
118
122
  <div *ngIf="!popUpView && transactionLine.configurationReadable" class="configuration-text">
119
- <span [innerHTML]="transactionLine.configurationReadable"></span>
123
+ <div [innerHTML]="transactionLine.configurationReadable"></div>
120
124
  </div>
121
125
  </div>
122
126
  <div class="expand-wrapper" (click)="expandClicked()" *ngIf="!customerPortal">
@@ -143,4 +147,4 @@ TransactionLineImageAndDescriptionComponent.propDecorators = {
143
147
  openArticleTextClicked: [{ type: Output }],
144
148
  handleDeleteLine: [{ type: Output }]
145
149
  };
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-image-and-description.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-image-and-description/transaction-line-image-and-description.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EAEL,MAAM,EACN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,8CAA8C,EAAC,MAAM,8BAA8B,CAAC;AAE5F,OAAO,EAAC,4BAA4B,EAAC,MAAM,8CAA8C,CAAC;AA2D1F,MAAM,OAAO,2CAA4C,SAAQ,4BAA4B;IAtD7F;;QAyDS,cAAS,GAAY,KAAK,CAAC;QAG3B,qBAAgB,GAAY,KAAK,CAAC;QAGlC,mBAAc,GAAY,KAAK,CAAC;QAOhC,2BAAsB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAGtE,qBAAgB,GAA6B,IAAI,YAAY,EAAc,CAAC;QAE5E,gBAAW,GAAY,KAAK,CAAC;QAM7B,mCAA8B,GAAgC;YACnE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK;YAC1B,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS;YAClC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,kBAAkB,EAAE,IAAI,CAAC,QAAQ,CAAC,kBAAkB;YACpD,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS;SACnC,CAAC;QAEM,UAAK,GAAmB,EAAE,CAAC;IA0DrC,CAAC;IAnFQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAUM,aAAa;QAClB,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;IACjC,CAAC;IAaD,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,MAA6B,EAAE,EAAE;;YAC7E,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC/B,IAAI,CAAC,WAAW;oBACd,CAAC,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC,MAAA,IAAI,CAAC,8BAA8B,0CAAE,WAAW,CAAC;wBACnG,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC,MAAA,IAAI,CAAC,8BAA8B,0CAAE,WAAW,CAAC,CAAC,kBAAkB,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC;wBACtK,CAAC,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC,MAAA,IAAI,CAAC,8BAA8B,0CAAE,SAAS,CAAC;4BACjG,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC,MAAA,IAAI,CAAC,8BAA8B,0CAAE,SAAS,CAAC,CAAC,kBAAkB,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;aACtK;QACH,CAAC,CAAC,EACF,IAAI,CAAC,uBAAuB,CAAC,6BAA6B,CAAC,SAAS,CAAC,CAAC,MAAc,EAAE,EAAE;YACtF,IAAI,MAAM,IAAI,MAAM,KAAK,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE;gBACpD,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;aACrC;QACH,CAAC,CAAC,CACH,CAAA;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QACzC,KAAK,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;IAEM,qBAAqB;QAC1B,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC;IACrC,CAAC;IAEY,0BAA0B,CAAC,KAAiB;;YACvD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;KAAA;IAES,kBAAkB;QAC1B,KAAK,CAAC,kBAAkB,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAES,aAAa;QACrB,KAAK,CAAC,aAAa,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAC/B,OAAO;SACR;QACD,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE;YAC1D,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE;gBAC/E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACnB,IAAI,IAAI,CAAC,KAAK,EAAE;oBACd,IAAI,CAAC,aAAa,EAAE,CAAC;iBACtB;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;;;YAnJF,SAAS,SAAC;gBACT,QAAQ,EAAE,2CAA2C;gBACrD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CT;gBACD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2CAA2C,CAAC;qBAAC;iBAC5E;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;wBAGE,KAAK;+BAGL,KAAK;6BAGL,KAAK;wBAEL,WAAW,SAAC,iDAAiD;qCAK7D,MAAM;+BAGN,MAAM","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {ImageAndDescriptionCfgNames} from '../../interface/image-and-description-cfg-names.interface';\r\nimport {TransactionLineBaseComponent} from '../core/base/transaction-line-base.component';\r\nimport {Subscription} from 'rxjs';\r\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\r\n\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-image-and-description\",\r\n  template: `\r\n    <div *ngIf=\"!transactionLine.isPayment\" class=\"transaction-line-image\" [class.preview]=\"preview\" [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.image\" screenConfigNativeElement>\r\n      <co-image-display [model]=\"image\"></co-image-display>\r\n    </div>\r\n    <co-icon *ngIf=\"transactionLine.isPayment\" class=\"payment-line-icon\" [iconData]=\"iconCacheService.getIcon(icons.UpFromLineRegular)\">\r\n    </co-icon>\r\n\r\n    <div class=\"transaction-line-description\">\r\n      <div class=\"description-wrapper\">\r\n        <div class=\"colorBlock\" *ngIf=\"transactionLine.color\" [style.background-color]=\"transactionLine.color\"></div>\r\n        <co-transaction-line-description class=\"transaction-line-description-description\"\r\n                                         [configNames]=\"imageAndDescriptionConfigNames\"\r\n                                         [defaultEditMode]=\"false\"\r\n                                         [showLabel]=\"false\"\r\n                                         [showPurchaseDesc]=\"showPurchaseDesc\"\r\n                                         [customerPortal]=\"customerPortal\"\r\n        ></co-transaction-line-description>\r\n        <div class=\"transaction-line-article-number-wrapper\" *ngIf=\"!popUpView && !customerPortal\">\r\n          <span *ngIf=\"showDivider\">|</span>\r\n          <span [textContent]=\"transactionLine.articleNumber\" [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.articleNr\" screenConfigNativeElement></span>\r\n          <co-icon class=\"delete-icon\" [iconData]=\"iconCacheService.getIcon(icons.TrashCanLight)\"\r\n                   [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.deleteBtn\" screenConfigNativeElement\r\n                   (click)=\"deleteTransactionLineClick($event)\"></co-icon>\r\n        </div>\r\n\r\n      </div>\r\n      <div *ngIf=\"!preview && !popUpView && (transactionLine.articleBoundConcatenatedText || transactionLine.configurationReadable)\"\r\n           class=\"article-text-wrapper\"\r\n           [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.articleText\"\r\n           screenConfigNativeElement>\r\n        <div [ngClass]=\"{'article-text-expand': true, 'large-article': !expanded && !customerPortal}\"  class=\"co-small-scrollbar\">\r\n          <div class=\"article-text\" *ngFor=\"let text of transactionLine.articleTextAsArray\">\r\n            <span [innerHTML]=\"text | safeHtml\" (dblclick)=\"handleOpenArticleText()\"></span>\r\n          </div>\r\n          <div *ngIf=\"!popUpView && transactionLine.configurationReadable\" class=\"configuration-text\">\r\n            <span [innerHTML]=\"transactionLine.configurationReadable\"></span>\r\n          </div>\r\n        </div>\r\n        <div class=\"expand-wrapper\" (click)=\"expandClicked()\" *ngIf=\"!customerPortal\">\r\n          <span class=\"expand-text\" [textContent]=\"!expanded ? ('SHOW_MORE' | localize) : ('SHOW_LESS' | localize)\"></span>\r\n          <co-icon [iconData]=\"expanded ? iconCacheService.getIcon(icons.ChevronUpRegular) : iconCacheService.getIcon(icons.ChevronDownRegular) \"></co-icon>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionLineImageAndDescriptionComponent)}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionLineImageAndDescriptionComponent extends TransactionLineBaseComponent implements OnInit, OnDestroy {\r\n\r\n  @Input()\r\n  public popUpView: boolean = false;\r\n\r\n  @Input()\r\n  public showPurchaseDesc: boolean = false;\r\n\r\n  @Input()\r\n  public customerPortal: boolean = false;\r\n  @HostBinding(\"class.co-transaction-line-image-and-description\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Output()\r\n  public openArticleTextClicked: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public handleDeleteLine: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  public showDivider: boolean = false;\r\n\r\n  public expandClicked(): void {\r\n    this.expanded = !this.expanded;\r\n  }\r\n  public image: string;\r\n  public imageAndDescriptionConfigNames: ImageAndDescriptionCfgNames = {\r\n    image: this.cfgNames.Image,\r\n    description: this.cfgNames.Description,\r\n    articleNr: this.cfgNames.ArticleNr,\r\n    articleText: this.cfgNames.ArticleText,\r\n    descriptionEditBtn: this.cfgNames.DescriptionEditBtn,\r\n    deleteBtn: this.cfgNames.DeleteBtn\r\n  };\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this._subs.push(\r\n      this.screenConfigService.configSet.subscribe((config: ObjectConfiguration[]) => {\r\n        if (config && config.length > 0) {\r\n          this.showDivider =\r\n            (this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.description) &&\r\n              this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.description).immediatelyVisible() && !!this.transactionLine.goodDescription) &&\r\n            (this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.articleNr) &&\r\n              this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.articleNr).immediatelyVisible() && !!this.transactionLine.articleNumber);\r\n        }\r\n      }),\r\n      this.transactionEventService.articleLineTextAddedOrChanged.subscribe((lineNr: number) => {\r\n        if (lineNr && lineNr === this.transactionLine.lineNr) {\r\n          this.changeDetector.detectChanges();\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n    super.ngOnDestroy();\r\n  }\r\n\r\n  public handleOpenArticleText(): void {\r\n    this.openArticleTextClicked.next();\r\n  }\r\n\r\n  public async deleteTransactionLineClick(event: MouseEvent): Promise<void> {\r\n    this.handleDeleteLine.next(event);\r\n  }\r\n\r\n  protected transactionLineSet(): void {\r\n    super.transactionLineSet();\r\n    this._loadLineImage();\r\n  }\r\n\r\n  protected visibilitySet(): void {\r\n    super.visibilitySet();\r\n    this._loadLineImage();\r\n  }\r\n\r\n  private _loadLineImage(): void {\r\n    if (this.image || !this.visible) {\r\n      return;\r\n    }\r\n    if (this.transactionLine && this.transactionLine.isArticle) {\r\n      this.imageService.retrieveLineImage(this.transactionLine).then((image: string) => {\r\n        this.image = image;\r\n        if (this.image) {\r\n          this.detectChanges();\r\n        }\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-image-and-description.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-image-and-description/transaction-line-image-and-description.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {ImageAndDescriptionCfgNames} from '../../interface/image-and-description-cfg-names.interface';\r\nimport {TransactionLineBaseComponent} from '../core/base/transaction-line-base.component';\r\nimport {Subscription} from 'rxjs';\r\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\r\n\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-image-and-description\",\r\n  template: `\r\n    <div *ngIf=\"!transactionLine.isPayment\" class=\"transaction-line-image\" [class.preview]=\"preview\" [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.image\" screenConfigNativeElement>\r\n      <co-image-display [model]=\"image\"></co-image-display>\r\n    </div>\r\n    <co-icon *ngIf=\"transactionLine.isPayment\" class=\"payment-line-icon\" [iconData]=\"iconCacheService.getIcon(icons.UpFromLineRegular)\">\r\n    </co-icon>\r\n\r\n    <div class=\"transaction-line-description\">\r\n      <div class=\"description-wrapper\">\r\n        <div class=\"colorBlock\" *ngIf=\"transactionLine.color\" [style.background-color]=\"transactionLine.color\"></div>\r\n        <co-transaction-line-description class=\"transaction-line-description-description\"\r\n                                         [configNames]=\"imageAndDescriptionConfigNames\"\r\n                                         [defaultEditMode]=\"false\"\r\n                                         [showLabel]=\"false\"\r\n                                         [showPurchaseDesc]=\"showPurchaseDesc\"\r\n                                         [customerPortal]=\"customerPortal\"\r\n        ></co-transaction-line-description>\r\n        <div class=\"transaction-line-article-number-wrapper\" *ngIf=\"!popUpView && !customerPortal\">\r\n          <span *ngIf=\"showDivider\">|</span>\r\n          <span [textContent]=\"transactionLine.articleNumber\" [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.articleNr\" screenConfigNativeElement></span>\r\n          <co-icon class=\"delete-icon\" [iconData]=\"iconCacheService.getIcon(icons.TrashCanLight)\"\r\n                   [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.deleteBtn\" screenConfigNativeElement\r\n                   (click)=\"deleteTransactionLineClick($event)\"></co-icon>\r\n        </div>\r\n\r\n      </div>\r\n      <div *ngIf=\"!preview && !popUpView && (transactionLine.articleBoundConcatenatedText || transactionLine.configurationReadable)\"\r\n           class=\"article-text-wrapper\"\r\n           [screenConfigurationObject]=\"imageAndDescriptionConfigNames?.articleText\"\r\n           screenConfigNativeElement>\r\n        <div [ngClass]=\"{'article-text-expand': true, 'large-article': !expanded && !customerPortal}\"  class=\"co-small-scrollbar\">\r\n          <div class=\"article-text\" *ngFor=\"let text of transactionLine.articleTextAsArray\">\r\n            <div [innerHTML]=\"text | safeHtml\" (dblclick)=\"handleOpenArticleText()\"></div>\r\n          </div>\r\n          <div *ngIf=\"!popUpView && transactionLine.configurationReadable\" class=\"configuration-text\">\r\n            <div [innerHTML]=\"transactionLine.configurationReadable\"></div>\r\n          </div>\r\n        </div>\r\n        <div class=\"expand-wrapper\" (click)=\"expandClicked()\" *ngIf=\"!customerPortal\">\r\n          <span class=\"expand-text\" [textContent]=\"!expanded ? ('SHOW_MORE' | localize) : ('SHOW_LESS' | localize)\"></span>\r\n          <co-icon [iconData]=\"expanded ? iconCacheService.getIcon(icons.ChevronUpRegular) : iconCacheService.getIcon(icons.ChevronDownRegular) \"></co-icon>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionLineImageAndDescriptionComponent)}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionLineImageAndDescriptionComponent extends TransactionLineBaseComponent implements OnInit, OnDestroy {\r\n\r\n  @Input()\r\n  public popUpView: boolean = false;\r\n\r\n  @Input()\r\n  public showPurchaseDesc: boolean = false;\r\n\r\n  @Input()\r\n  public customerPortal: boolean = false;\r\n  @HostBinding(\"class.co-transaction-line-image-and-description\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Output()\r\n  public openArticleTextClicked: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public handleDeleteLine: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  public showDivider: boolean = false;\r\n\r\n  public expandClicked(): void {\r\n    this.expanded = !this.expanded;\r\n  }\r\n  public image: string;\r\n  public imageAndDescriptionConfigNames: ImageAndDescriptionCfgNames = {\r\n    image: this.cfgNames.Image,\r\n    description: this.cfgNames.Description,\r\n    articleNr: this.cfgNames.ArticleNr,\r\n    articleText: this.cfgNames.ArticleText,\r\n    descriptionEditBtn: this.cfgNames.DescriptionEditBtn,\r\n    deleteBtn: this.cfgNames.DeleteBtn\r\n  };\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this._subs.push(\r\n      this.screenConfigService.configSet.subscribe((config: ObjectConfiguration[]) => {\r\n        if (config && config.length > 0) {\r\n          this.showDivider =\r\n            (this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.description) &&\r\n              this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.description).immediatelyVisible() && !!this.transactionLine.goodDescription) &&\r\n            (this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.articleNr) &&\r\n              this.screenConfigService.getObjectConfigurationFor(this.imageAndDescriptionConfigNames?.articleNr).immediatelyVisible() && !!this.transactionLine.articleNumber);\r\n        }\r\n      }),\r\n      this.transactionEventService.articleLineTextAddedOrChanged.subscribe((lineNr: number) => {\r\n        if (lineNr && lineNr === this.transactionLine.lineNr) {\r\n          this.changeDetector.detectChanges();\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n    super.ngOnDestroy();\r\n  }\r\n\r\n  public handleOpenArticleText(): void {\r\n    this.openArticleTextClicked.next();\r\n  }\r\n\r\n  public async deleteTransactionLineClick(event: MouseEvent): Promise<void> {\r\n    this.handleDeleteLine.next(event);\r\n  }\r\n\r\n  protected transactionLineSet(): void {\r\n    super.transactionLineSet();\r\n    this._loadLineImage();\r\n    if (this.transactionLine.configurationReadable) {\r\n      // @ts-ignore\r\n      this.transactionLine.configurationReadable = this.transactionLine.configurationReadable.replaceAll('\\n', '<br>');\r\n    }\r\n  }\r\n\r\n  protected visibilitySet(): void {\r\n    super.visibilitySet();\r\n    this._loadLineImage();\r\n  }\r\n\r\n  private _loadLineImage(): void {\r\n    if (this.image || !this.visible) {\r\n      return;\r\n    }\r\n    if (this.transactionLine && this.transactionLine.isArticle) {\r\n      this.imageService.retrieveLineImage(this.transactionLine).then((image: string) => {\r\n        this.image = image;\r\n        if (this.image) {\r\n          this.detectChanges();\r\n        }\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}