@colijnit/transaction 255.1.10 → 255.1.12

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.
Files changed (33) hide show
  1. package/bundles/colijnit-transaction.umd.js +51 -15
  2. package/bundles/colijnit-transaction.umd.js.map +1 -1
  3. package/colijnit-transaction.metadata.json +1 -1
  4. package/esm2015/lib/component/add-product/add-product.component.js +17 -6
  5. package/esm2015/lib/component/transaction-header/transaction-header-delivery/transaction-header-delivery.component.js +13 -18
  6. package/esm2015/lib/component/transaction-header/transaction-header-order/transaction-header-order.component.js +4 -13
  7. package/esm2015/lib/component/transaction-header/transaction-header-payment/transaction-header-payment.component.js +3 -14
  8. package/esm2015/lib/component/transaction-header/transaction-header-relation/transaction-header-relation.component.js +3 -6
  9. package/esm2015/lib/enum/icon.enum.js +2 -1
  10. package/esm2015/lib/model/icon-svg.js +2 -1
  11. package/esm2015/lib/service/article-connector.service.js +18 -1
  12. package/esm2015/lib/service/transaction.service.js +4 -1
  13. package/esm2015/lib/transaction-version.js +3 -3
  14. package/fesm2015/colijnit-transaction.js +59 -54
  15. package/fesm2015/colijnit-transaction.js.map +1 -1
  16. package/lib/component/core/base/components/transaction-header-block/style/_material-definition.scss +1 -1
  17. package/lib/component/transaction-header/transaction-header/style/_layout.scss +1 -0
  18. package/lib/component/transaction-header/transaction-header-delivery/style/_layout.scss +4 -0
  19. package/lib/component/transaction-header/transaction-header-delivery/style/_material-definition.scss +7 -7
  20. package/lib/component/transaction-header/transaction-header-order/style/_layout.scss +7 -2
  21. package/lib/component/transaction-header/transaction-header-order/style/_material-definition.scss +4 -4
  22. package/lib/component/transaction-header/transaction-header-payment/style/_layout.scss +6 -1
  23. package/lib/component/transaction-header/transaction-header-payment/style/_material-definition.scss +3 -3
  24. package/lib/component/transaction-header/transaction-header-popup/style/_material-definition.scss +5 -5
  25. package/lib/component/transaction-header/transaction-header-relation/style/_layout.scss +2 -0
  26. package/lib/component/transaction-header-fields/transaction-header-deliverydate-definitive-button/style/_layout.scss +1 -0
  27. package/lib/component/transaction-header-fields/transaction-header-deliverydate-definitive-button/style/_material-definition.scss +2 -2
  28. package/lib/component/transaction-internal/style/_material-definition.scss +1 -1
  29. package/lib/enum/icon.enum.d.ts +1 -0
  30. package/lib/service/article-connector.service.d.ts +1 -0
  31. package/lib/service/transaction.service.d.ts +1 -0
  32. package/package.json +1 -1
  33. package/colijnit-transaction-255.1.6.tgz +0 -0
@@ -42,13 +42,24 @@ export class AddProductComponent {
42
42
  this.searchText = undefined;
43
43
  this._changeDetector.detectChanges();
44
44
  // first check if there's a single article found
45
- const foundArticles = yield this.transactionService.getArticles(this.catalogParameters);
46
- if (foundArticles && foundArticles.length === 1) {
47
- const article = yield this.transactionService.getArticleExtended(foundArticles[0].articleNumber);
45
+ // This is a two check step:
46
+ // Check if there is an exact match on barcode, ean or articlenumber
47
+ // if not: check with search like
48
+ // else open catalogus
49
+ const fullMatchSearch = yield this.transactionService.getArticleListWithBarcodeArticleNrEanCode(text);
50
+ if (fullMatchSearch && fullMatchSearch.length === 1) {
51
+ const article = yield this.transactionService.getArticleExtended(fullMatchSearch[0].articleNr);
48
52
  yield this.handleAddArticle(article);
49
53
  }
50
- else { // else open the catalog
51
- this.showCatalogDialog();
54
+ else {
55
+ const foundArticles = yield this.transactionService.getArticles(this.catalogParameters);
56
+ if (foundArticles && foundArticles.length === 1) {
57
+ const article = yield this.transactionService.getArticleExtended(foundArticles[0].articleNumber);
58
+ yield this.handleAddArticle(article);
59
+ }
60
+ else {
61
+ this.showCatalogDialog();
62
+ }
52
63
  }
53
64
  });
54
65
  }
@@ -220,4 +231,4 @@ AddProductComponent.propDecorators = {
220
231
  showClass: [{ type: HostBinding, args: ['class.co-add-product',] }],
221
232
  return: [{ type: HostBinding, args: ['class.return',] }]
222
233
  };
223
- //# 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  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\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]=\"this.return\"\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 {\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') 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  public showCatalog: boolean = false;\r\n  public isSearchInputFocused: boolean = false;\r\n  public searchText: string;\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  constructor(\r\n    public iconService: IconCacheService,\r\n    public transactionService: TransactionService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\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\r\n    this.searchText = text;\r\n    this._changeDetector.detectChanges();\r\n    this._prepareCatalogRequest();\r\n    this.searchText = undefined;\r\n    this._changeDetector.detectChanges();\r\n    // first check if there's a single article found\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      await this.handleAddArticle(article);\r\n    } else { // else open the catalog\r\n      this.showCatalogDialog();\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<boolean> {\r\n    if (this.handleAddArticleInternally) {\r\n      return await this.transactionService.addArticle(article.articleNumber, this.return ? -1 : 1);\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    this.showCatalog = false;\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    } else {\r\n      if (data.article) {\r\n        const articleTreeData = JSON.parse(data.article as string);\r\n        if (articleTreeData.articleTree && articleTreeData.articleTree.article) {\r\n          if (articleTreeData.articleTree.compositeGoods && Array.isArray(articleTreeData.articleTree.compositeGoods) &&\r\n            articleTreeData.articleTree.compositeGoods.length > 0 && articleTreeData.articleTree.subArticles && Array.isArray(articleTreeData.articleTree.subArticles)) {\r\n            const compositeGoods = articleTreeData.articleTree.compositeGoods;\r\n            compositeGoods.sort((a, b) => a.versionNumber < b.versionNumber ? -1 : 1);\r\n            for (let i = 0; i < compositeGoods.length; i++) {\r\n              const lastArticle: boolean = i === compositeGoods.length - 1;\r\n              const good = compositeGoods[i];\r\n              const subArticle = articleTreeData.articleTree.subArticles.find(s => s.goodId === good.memberGoodId);\r\n              if (subArticle) {\r\n                await this.transactionService.addArticle(subArticle.articleNumber, this.getActualQuantity(good.quantity), 0, 0, lastArticle);\r\n              }\r\n            }\r\n          } else {\r\n            await this.transactionService.addArticle(articleTreeData.articleTree.article.articleNumber, this.getActualQuantity(articleTreeData.quantity));\r\n          }\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._changeDetector.detectChanges();\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);\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);\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"]}
234
+ //# 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  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\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]=\"this.return\"\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 {\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') 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  public showCatalog: boolean = false;\r\n  public isSearchInputFocused: boolean = false;\r\n  public searchText: string;\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  constructor(\r\n    public iconService: IconCacheService,\r\n    public transactionService: TransactionService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\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\r\n    this.searchText = text;\r\n    this._changeDetector.detectChanges();\r\n    this._prepareCatalogRequest();\r\n    this.searchText = undefined;\r\n    this._changeDetector.detectChanges();\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      await this.handleAddArticle(article);\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        await this.handleAddArticle(article);\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<boolean> {\r\n    if (this.handleAddArticleInternally) {\r\n      return await this.transactionService.addArticle(article.articleNumber, this.return ? -1 : 1);\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    this.showCatalog = false;\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    } else {\r\n      if (data.article) {\r\n        const articleTreeData = JSON.parse(data.article as string);\r\n        if (articleTreeData.articleTree && articleTreeData.articleTree.article) {\r\n          if (articleTreeData.articleTree.compositeGoods && Array.isArray(articleTreeData.articleTree.compositeGoods) &&\r\n            articleTreeData.articleTree.compositeGoods.length > 0 && articleTreeData.articleTree.subArticles && Array.isArray(articleTreeData.articleTree.subArticles)) {\r\n            const compositeGoods = articleTreeData.articleTree.compositeGoods;\r\n            compositeGoods.sort((a, b) => a.versionNumber < b.versionNumber ? -1 : 1);\r\n            for (let i = 0; i < compositeGoods.length; i++) {\r\n              const lastArticle: boolean = i === compositeGoods.length - 1;\r\n              const good = compositeGoods[i];\r\n              const subArticle = articleTreeData.articleTree.subArticles.find(s => s.goodId === good.memberGoodId);\r\n              if (subArticle) {\r\n                await this.transactionService.addArticle(subArticle.articleNumber, this.getActualQuantity(good.quantity), 0, 0, lastArticle);\r\n              }\r\n            }\r\n          } else {\r\n            await this.transactionService.addArticle(articleTreeData.articleTree.article.articleNumber, this.getActualQuantity(articleTreeData.quantity));\r\n          }\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._changeDetector.detectChanges();\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);\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);\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"]}
@@ -28,11 +28,11 @@ TransactionHeaderDeliveryComponent.decorators = [
28
28
 
29
29
  </ng-template>
30
30
  <ng-template #firstBlock>
31
- <div class="transaction-header-block-row">
32
- <div class="transaction-header-icon" [screenConfigurationObject]="cfgNames.HeaderDeliveryAvatarHeader" screenConfigNativeElement>
33
- <co-icon class="header-order-icon" (click)="showDialog = true"
34
- [iconData]="iconCacheService.getIcon(icons.TruckFastSolid)">
35
- </co-icon>
31
+ <div class="transaction-header-block-row" (click)="showDialog = true">
32
+ <div class="planning-request-button-wrapper" [screenConfigurationObject]="cfgNames.HeaderDeliveryPreferedHeader" screenConfigNativeElement>
33
+ <co-icon class="planning-request-button" [class.co-transaction-check]="transactionInfo.deliveryDateDefinitive"
34
+ [iconData]="iconCacheService.getIcon(icons.CalendarDayRegular)"
35
+ (click)="showDialog = true"></co-icon>
36
36
  </div>
37
37
  <div class="header-deliverydate-wrapper" [screenConfigurationObject]="cfgNames.HeaderDeliveryDateHeader" screenConfigNativeElement>
38
38
  <div class="header-delivery-deliverydate-label co-transaction-label" [textContent]="'DELIVERY_DATE' | localize"></div>
@@ -45,17 +45,10 @@ TransactionHeaderDeliveryComponent.decorators = [
45
45
  ></co-transaction-header-delivery-date>
46
46
  </div>
47
47
  </div>
48
- <div class="header-deliverdate-definitive-wrapper" [screenConfigurationObject]="cfgNames.HeaderDeliveryDefinitiveHeader" screenConfigNativeElement>
49
- <co-transaction-header-deliverydate-definitive-button
50
- [screenConfigurationObject]="cfgNames.HeaderDeliveryDefinitiveHeader"
51
- [class.closed]="transactionInfo.deliveryDateDefinitive"
52
- [transactionInfo]="transactionInfo">
53
- </co-transaction-header-deliverydate-definitive-button>
54
- </div>
55
48
  </div>
56
49
  </ng-template>
57
50
  <ng-template #secondBlock>
58
- <co-transaction-header-delivery-method-button class="header-delivery-method"
51
+ <co-transaction-header-delivery-method-button class="header-delivery-method"
59
52
  [screenConfigurationObject]="cfgNames.HeaderDeliveryMethod"
60
53
  [transactionInfo]="transactionInfo"
61
54
  ></co-transaction-header-delivery-method-button>
@@ -68,10 +61,12 @@ TransactionHeaderDeliveryComponent.decorators = [
68
61
  ></co-transaction-header-preferred-delivery-date-->
69
62
  </ng-template>
70
63
  <ng-template #thirdBlock>
71
- <div class="planning-request-button-wrapper" [screenConfigurationObject]="cfgNames.HeaderDeliveryPreferedHeader" screenConfigNativeElement>
72
- <co-icon class="planning-request-button" [class.co-transaction-check]="transactionInfo.deliveryDateDefinitive"
73
- [iconData]="iconCacheService.getIcon(icons.CalendarDayRegular)"
74
- (click)="showDialog = true"></co-icon>
64
+ <div class="header-deliverdate-definitive-wrapper" [screenConfigurationObject]="cfgNames.HeaderDeliveryDefinitiveHeader" screenConfigNativeElement>
65
+ <co-transaction-header-deliverydate-definitive-button
66
+ [screenConfigurationObject]="cfgNames.HeaderDeliveryDefinitiveHeader"
67
+ [class.closed]="transactionInfo.deliveryDateDefinitive"
68
+ [transactionInfo]="transactionInfo">
69
+ </co-transaction-header-deliverydate-definitive-button>
75
70
  </div>
76
71
  </ng-template>
77
72
  <ng-template #hiddenBlock>
@@ -95,4 +90,4 @@ TransactionHeaderDeliveryComponent.decorators = [
95
90
  TransactionHeaderDeliveryComponent.propDecorators = {
96
91
  showClass: [{ type: HostBinding, args: ["class.co-transaction-header-delivery",] }]
97
92
  };
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-delivery.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-delivery/transaction-header-delivery.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACpF,OAAO,EAAC,wBAAwB,EAAC,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAC,IAAI,EAAC,MAAM,yBAAyB,CAAC;AAC7C,OAAO,EAAC,8CAA8C,EAAC,MAAM,8BAA8B,CAAC;AAgF5F,MAAM,OAAO,kCAAmC,SAAQ,wBAAwB;IA9EhF;;QA+EkB,UAAK,GAAgB,IAAI,CAAC;QAOnC,eAAU,GAAY,KAAK,CAAC;IACrC,CAAC;IALQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;;;YApFF,SAAS,SAAC;gBACT,QAAQ,EAAE,gCAAgC;gBAC1C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqET;gBACD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kCAAkC,CAAC;qBAClE,CAAC;gBACF,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;wBAIE,WAAW,SAAC,sCAAsC","sourcesContent":["import {Component, forwardRef, HostBinding, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\n\r\n@Component({\r\n  selector: \"co-transaction-header-delivery\",\r\n  template: `\r\n    <co-transaction-header-block\r\n      [firstBlockTemplate]=\"firstBlock\"\r\n      [secondBlockTemplate]=\"secondBlock\"\r\n      [thirdBlockTemplate]=\"thirdBlock\"\r\n      [hiddenBlockTemplate]=\"hiddenBlock\"\r\n      (headerClick)=\"showDialog = true\"\r\n    >\r\n    </co-transaction-header-block>\r\n    <ng-template #headerBlock>\r\n\r\n    </ng-template>\r\n    <ng-template #firstBlock>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"transaction-header-icon\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryAvatarHeader\" screenConfigNativeElement>\r\n          <co-icon class=\"header-order-icon\" (click)=\"showDialog = true\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.TruckFastSolid)\">\r\n          </co-icon>\r\n        </div>\r\n        <div class=\"header-deliverydate-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDateHeader\" screenConfigNativeElement>\r\n          <div class=\"header-delivery-deliverydate-label co-transaction-label\" [textContent]=\"'DELIVERY_DATE' | localize\"></div>\r\n          <div class=\"header-delivery-deliverydate-content\" [class.closed]=\"transactionInfo.deliveryDateDefinitive\">\r\n            <co-transaction-header-delivery-date class=\"header-delivery-deliverydate\"\r\n                                                 [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDateHeader\"\r\n                                                 [transactionInfo]=\"transactionInfo\"\r\n                                                 [defaultEditMode]=\"true\"\r\n                                                 [showLabel]=\"false\"\r\n            ></co-transaction-header-delivery-date>\r\n          </div>\r\n        </div>\r\n        <div class=\"header-deliverdate-definitive-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDefinitiveHeader\" screenConfigNativeElement>\r\n            <co-transaction-header-deliverydate-definitive-button\r\n              [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDefinitiveHeader\"\r\n              [class.closed]=\"transactionInfo.deliveryDateDefinitive\"\r\n              [transactionInfo]=\"transactionInfo\">\r\n            </co-transaction-header-deliverydate-definitive-button>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #secondBlock>\r\n      <co-transaction-header-delivery-method-button class=\"header-delivery-method\" \r\n          [screenConfigurationObject]=\"cfgNames.HeaderDeliveryMethod\"\r\n          [transactionInfo]=\"transactionInfo\"\r\n      ></co-transaction-header-delivery-method-button>\r\n\r\n      <!--div class=\"header-delivery-preferred-deliverydate-label co-transaction-label\" [textContent]=\"'PREFERRED_DATE' | localize\"></div>\r\n      <co-transaction-header-preferred-delivery-date class=\"header-delivery-deliverydate\"\r\n                                                     [transactionInfo]=\"transactionInfo\"\r\n                                                     [defaultEditMode]=\"false\"\r\n                                                     [showLabel]=\"false\"\r\n      ></co-transaction-header-preferred-delivery-date-->\r\n    </ng-template>\r\n    <ng-template #thirdBlock>\r\n      <div class=\"planning-request-button-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryPreferedHeader\" screenConfigNativeElement>\r\n        <co-icon class=\"planning-request-button\" [class.co-transaction-check]=\"transactionInfo.deliveryDateDefinitive\"\r\n                 [iconData]=\"iconCacheService.getIcon(icons.CalendarDayRegular)\"\r\n                 (click)=\"showDialog = true\"></co-icon>\r\n      </div>\r\n     </ng-template>\r\n    <ng-template #hiddenBlock>\r\n      <co-transaction-header-partial-delivery class=\"transaction-header-partial-delivery co-transaction-label\"\r\n                                              [screenConfigurationObject]=\"cfgNames.HeaderDeliveryPartialHeader\"\r\n                                              [transactionInfo]=\"transactionInfo\"></co-transaction-header-partial-delivery>\r\n    </ng-template>\r\n    <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                 [activeCategoryDescription]=\"'DELIVERY_INFORMATION'\"\r\n                                 [relation]=\"relation\"\r\n                                 [transaction]=\"transaction\"\r\n                                 (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionHeaderDeliveryComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderDeliveryComponent extends TransactionBaseComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding(\"class.co-transaction-header-delivery\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public showDialog: boolean = false;\r\n}\r\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-delivery.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-delivery/transaction-header-delivery.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACpF,OAAO,EAAC,wBAAwB,EAAC,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAC,IAAI,EAAC,MAAM,yBAAyB,CAAC;AAC7C,OAAO,EAAC,8CAA8C,EAAC,MAAM,8BAA8B,CAAC;AA2E5F,MAAM,OAAO,kCAAmC,SAAQ,wBAAwB;IAzEhF;;QA0EkB,UAAK,GAAgB,IAAI,CAAC;QAOnC,eAAU,GAAY,KAAK,CAAC;IACrC,CAAC;IALQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;;;YA/EF,SAAS,SAAC;gBACT,QAAQ,EAAE,gCAAgC;gBAC1C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgET;gBACD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kCAAkC,CAAC;qBAClE,CAAC;gBACF,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;wBAIE,WAAW,SAAC,sCAAsC","sourcesContent":["import {Component, forwardRef, HostBinding, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\n\r\n@Component({\r\n  selector: \"co-transaction-header-delivery\",\r\n  template: `\r\n    <co-transaction-header-block\r\n      [firstBlockTemplate]=\"firstBlock\"\r\n      [secondBlockTemplate]=\"secondBlock\"\r\n      [thirdBlockTemplate]=\"thirdBlock\"\r\n      [hiddenBlockTemplate]=\"hiddenBlock\"\r\n      (headerClick)=\"showDialog = true\"\r\n    >\r\n    </co-transaction-header-block>\r\n    <ng-template #headerBlock>\r\n\r\n    </ng-template>\r\n    <ng-template #firstBlock>\r\n      <div class=\"transaction-header-block-row\" (click)=\"showDialog = true\">\r\n        <div class=\"planning-request-button-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryPreferedHeader\" screenConfigNativeElement>\r\n          <co-icon class=\"planning-request-button\" [class.co-transaction-check]=\"transactionInfo.deliveryDateDefinitive\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.CalendarDayRegular)\"\r\n                   (click)=\"showDialog = true\"></co-icon>\r\n        </div>\r\n        <div class=\"header-deliverydate-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDateHeader\" screenConfigNativeElement>\r\n          <div class=\"header-delivery-deliverydate-label co-transaction-label\" [textContent]=\"'DELIVERY_DATE' | localize\"></div>\r\n          <div class=\"header-delivery-deliverydate-content\" [class.closed]=\"transactionInfo.deliveryDateDefinitive\">\r\n            <co-transaction-header-delivery-date class=\"header-delivery-deliverydate\"\r\n                                                 [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDateHeader\"\r\n                                                 [transactionInfo]=\"transactionInfo\"\r\n                                                 [defaultEditMode]=\"true\"\r\n                                                 [showLabel]=\"false\"\r\n            ></co-transaction-header-delivery-date>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #secondBlock>\r\n      <co-transaction-header-delivery-method-button class=\"header-delivery-method\"\r\n          [screenConfigurationObject]=\"cfgNames.HeaderDeliveryMethod\"\r\n          [transactionInfo]=\"transactionInfo\"\r\n      ></co-transaction-header-delivery-method-button>\r\n\r\n      <!--div class=\"header-delivery-preferred-deliverydate-label co-transaction-label\" [textContent]=\"'PREFERRED_DATE' | localize\"></div>\r\n      <co-transaction-header-preferred-delivery-date class=\"header-delivery-deliverydate\"\r\n                                                     [transactionInfo]=\"transactionInfo\"\r\n                                                     [defaultEditMode]=\"false\"\r\n                                                     [showLabel]=\"false\"\r\n      ></co-transaction-header-preferred-delivery-date-->\r\n    </ng-template>\r\n    <ng-template #thirdBlock>\r\n      <div class=\"header-deliverdate-definitive-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDefinitiveHeader\" screenConfigNativeElement>\r\n        <co-transaction-header-deliverydate-definitive-button\r\n          [screenConfigurationObject]=\"cfgNames.HeaderDeliveryDefinitiveHeader\"\r\n          [class.closed]=\"transactionInfo.deliveryDateDefinitive\"\r\n          [transactionInfo]=\"transactionInfo\">\r\n        </co-transaction-header-deliverydate-definitive-button>\r\n      </div>\r\n     </ng-template>\r\n    <ng-template #hiddenBlock>\r\n      <co-transaction-header-partial-delivery class=\"transaction-header-partial-delivery co-transaction-label\"\r\n                                              [screenConfigurationObject]=\"cfgNames.HeaderDeliveryPartialHeader\"\r\n                                              [transactionInfo]=\"transactionInfo\"></co-transaction-header-partial-delivery>\r\n    </ng-template>\r\n    <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                 [activeCategoryDescription]=\"'DELIVERY_INFORMATION'\"\r\n                                 [relation]=\"relation\"\r\n                                 [transaction]=\"transaction\"\r\n                                 (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionHeaderDeliveryComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderDeliveryComponent extends TransactionBaseComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding(\"class.co-transaction-header-delivery\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public showDialog: boolean = false;\r\n}\r\n"]}
@@ -30,12 +30,7 @@ TransactionHeaderOrderComponent.decorators = [
30
30
  >
31
31
  </co-transaction-header-block>
32
32
  <ng-template #firstBlock>
33
- <div class="transaction-header-block-row">
34
- <div class="transaction-header-icon" [screenConfigurationObject]="cfgNames.HeaderOrderAvatarHeader" screenConfigNativeElement>
35
- <co-icon class="header-order-icon" (click)="showDialog = true"
36
- [iconData]="iconCacheService.getIcon(icons.CartShoppingRegular)">
37
- </co-icon>
38
- </div>
33
+ <div class="transaction-header-block-row" (click)="showDialog = true">
39
34
  <div class="header-order-total-wrapper" [screenConfigurationObject]="cfgNames.HeaderOrderOrderTotalHeader" screenConfigNativeElement>
40
35
  <span class="header-order-total-label co-transaction-label" [textContent]="'ORDER_TOTAL' | localize"></span>
41
36
  <div class="header-order-total" [textContent]="transactionTotal.netAmount | coCurrency"></div>
@@ -43,14 +38,10 @@ TransactionHeaderOrderComponent.decorators = [
43
38
  </div>
44
39
  </ng-template>
45
40
  <ng-template #secondBlock>
46
- <div class="transaction-header-block-row" [screenConfigurationObject]="cfgNames.HeaderOrderDiscountHeader" screenConfigNativeElement>
41
+ <div class="transaction-header-block-row" (click)="showDialog = true" [screenConfigurationObject]="cfgNames.HeaderOrderDiscountHeader" screenConfigNativeElement>
47
42
  <div class="transaction-header-discount-button">
48
43
  <div class="header-discount" (click)="openDiscount($event)">
49
- <co-icon class="header-discount-icon" [iconData]="iconCacheService.getIcon(icons.PercentSolid)"></co-icon>
50
- <div class="spacer"></div>
51
- <span class="co-transaction-overflow-ellipsis transaction-discount"
52
- [class.transaction-negative-value]="transactionTotal.totalDiscountAmount < 0"
53
- [textContent]="(transactionTotal.totalDiscountAmount | coCurrency) || ('DISCOUNT' | localize)"></span>
44
+ <co-icon class="header-discount-icon" [iconData]="iconCacheService.getIcon(icons.RegularEuroSignMinus)"></co-icon>
54
45
  </div>
55
46
  </div>
56
47
  </div>
@@ -127,4 +118,4 @@ TransactionHeaderOrderComponent.decorators = [
127
118
  TransactionHeaderOrderComponent.propDecorators = {
128
119
  showClass: [{ type: HostBinding, args: ['class.co-transaction-header-order',] }]
129
120
  };
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-order.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-order/transaction-header-order.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACpF,OAAO,EAAC,wBAAwB,EAAC,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAC,IAAI,EAAC,MAAM,yBAAyB,CAAC;AAC7C,OAAO,EAAC,8CAA8C,EAAC,MAAM,8BAA8B,CAAC;AA0G5F,MAAM,OAAO,+BAAgC,SAAQ,wBAAwB;IAxG7E;;QAyGkB,UAAK,GAAgB,IAAI,CAAC;QAOnC,eAAU,GAAY,KAAK,CAAC;QAC5B,uBAAkB,GAAY,KAAK,CAAC;IAO7C,CAAC;IAZQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAKM,YAAY,CAAC,KAAiB;QACnC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACjC,CAAC;;;YAvHF,SAAS,SAAC;gBACT,QAAQ,EAAE,6BAA6B;gBACvC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+FT;gBACD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,+BAA+B,CAAC;qBAC/D,CAAC;gBACF,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;wBAIE,WAAW,SAAC,mCAAmC","sourcesContent":["import {Component, forwardRef, HostBinding, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\n\r\n@Component({\r\n  selector: \"co-transaction-header-order\",\r\n  template: `\r\n      <co-transaction-header-block\r\n              [firstBlockTemplate]=\"firstBlock\"\r\n              [secondBlockTemplate]=\"secondBlock\"\r\n              [hiddenBlockTemplate]=\"hiddenBlock\"\r\n              (headerClick)=\"showDialog = true\"\r\n      >\r\n      </co-transaction-header-block>\r\n      <ng-template #firstBlock>\r\n        <div class=\"transaction-header-block-row\">\r\n          <div class=\"transaction-header-icon\" [screenConfigurationObject]=\"cfgNames.HeaderOrderAvatarHeader\" screenConfigNativeElement>\r\n            <co-icon class=\"header-order-icon\" (click)=\"showDialog = true\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.CartShoppingRegular)\">\r\n            </co-icon>\r\n          </div>\r\n          <div class=\"header-order-total-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderOrderOrderTotalHeader\" screenConfigNativeElement>\r\n            <span class=\"header-order-total-label co-transaction-label\" [textContent]=\"'ORDER_TOTAL' | localize\"></span>\r\n            <div class=\"header-order-total\" [textContent]=\"transactionTotal.netAmount | coCurrency\"></div>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <ng-template #secondBlock>\r\n        <div class=\"transaction-header-block-row\" [screenConfigurationObject]=\"cfgNames.HeaderOrderDiscountHeader\" screenConfigNativeElement>\r\n          <div class=\"transaction-header-discount-button\">\r\n            <div class=\"header-discount\" (click)=\"openDiscount($event)\">\r\n              <co-icon class=\"header-discount-icon\" [iconData]=\"iconCacheService.getIcon(icons.PercentSolid)\"></co-icon>\r\n              <div class=\"spacer\"></div>\r\n              <span class=\"co-transaction-overflow-ellipsis transaction-discount\"\r\n                    [class.transaction-negative-value]=\"transactionTotal.totalDiscountAmount < 0\"\r\n                    [textContent]=\"(transactionTotal.totalDiscountAmount | coCurrency) || ('DISCOUNT' | localize)\"></span>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <ng-template #hiddenBlock>\r\n        <div class=\"transaction-header-block-row\" [screenConfigurationObject]=\"cfgNames.HeaderOrderDefinitiveHeader\" screenConfigNativeElement>\r\n          <div class=\"header-order-definitive\">\r\n            <co-transaction-header-definitive class=\"transaction-header-order-definitive\"\r\n                [screenConfigurationObject]=\"cfgNames.HeaderOrderDefinitiveHeader\"\r\n                [transactionInfo]=\"transactionInfo\"\r\n            ></co-transaction-header-definitive>\r\n          </div>\r\n          <!--span class=\"header-order-line-amount-label co-transaction-label\" [textContent]=\"'ORDER_LINES' | localize\"></span>\r\n          <div class=\"header-order-line-amount\" [textContent]=\"transactionLines.length\"></div-->\r\n        </div>\r\n      </ng-template>\r\n      <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                   [activeCategoryDescription]=\"'ORDER_INFORMATION1'\"\r\n                                   [relation]=\"relation\"\r\n                                   [transaction]=\"transaction\"\r\n                                   (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n<!--\r\n\r\n      <co-dialog class=\"transaction-header-order-dialog\" [customCssClass]=\"'co-small-scrollbar'\" [headerTemplate]=\"headerTemplate\" *ngIf=\"showDialog\"\r\n                 (closeClick)=\"showDialog = false\">\r\n          <ng-template #headerTemplate>\r\n              <div class=\"co-dialog-header-title\" [textContent]=\"'ORDER_INFORMATION1' | localize\"></div>\r\n              <co-transaction-header-block\r\n                      [headerBlockTemplate]=\"headerBlock\"\r\n                      [firstBlockTemplate]=\"firstBlock\"\r\n                      [secondBlockTemplate]=\"secondBlock\"\r\n                      [thirdBlockTemplate]=\"thirdBlock\"\r\n              >\r\n              </co-transaction-header-block>\r\n          </ng-template>\r\n          <div class=\"order-dialog-section\">\r\n              <div class=\"section-wrapper\">\r\n                  <div class=\"section-header\" [textContent]=\"'BASE_INFO1' | localize | prepend:'01 '\"></div>\r\n                  <div class=\"two-column-grid\">\r\n                      <co-transaction-header-branch [simple]=\"true\" [transaction]=\"transaction\" [transactionInfo]=\"transactionInfo\"></co-transaction-header-branch>\r\n                      <co-transaction-header-sales-person [transactionInfo]=\"transactionInfo\"></co-transaction-header-sales-person>\r\n                      <co-transaction-header-administrative-relation\r\n                              [transactionInfo]=\"transactionInfo\"></co-transaction-header-administrative-relation>\r\n                      <co-transaction-header-price-kind [transaction]=\"transaction\" [transactionInfo]=\"transactionInfo\"></co-transaction-header-price-kind>\r\n                      <co-transaction-header-currency [transaction]=\"transaction\" [transactionInfo]=\"transactionInfo\"></co-transaction-header-currency>\r\n                      <co-transaction-header-payment-condition\r\n                              [transactionInfo]=\"transactionInfo\"></co-transaction-header-payment-condition>\r\n                  </div>\r\n              </div>\r\n              <div class=\"section-wrapper\">\r\n                  <div class=\"section-header\" [textContent]=\"'ORDER_PARAMETERS' | localize | prepend:'02 '\"></div>\r\n                  <div class=\"section-sub-title\" [textContent]=\"'ON_HOLD_CODES' | localize\"></div>\r\n                  <co-transaction-header-hold-codes [transactionInfo]=\"transaction.transactionInfo\"></co-transaction-header-hold-codes>\r\n                  <div class=\"section-sub-title\" [textContent]=\"'MARKETING_CODE' | localize\"></div>\r\n                  <co-transaction-header-marketing [transactionInfo]=\"transaction.transactionInfo\"></co-transaction-header-marketing>\r\n              </div>\r\n          </div>\r\n      </co-dialog>\r\n-->\r\n      <co-dialog-transaction-header-discount class=\"discount-dialog\" *ngIf=\"showDialogDiscount\"\r\n                                             [screenConfigurationObject]=\"cfgNames.DiscountPriceInformationHeader\"\r\n                                             [transactionInfo]=\"transactionInfo\"\r\n                                             [transactionTotal]=\"transactionTotal\"\r\n                                             (close)=\"showDialogDiscount = false\">\r\n      </co-dialog-transaction-header-discount>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionHeaderOrderComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderOrderComponent extends TransactionBaseComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding('class.co-transaction-header-order')\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public showDialog: boolean = false;\r\n  public showDialogDiscount: boolean = false;\r\n\r\n  public openDiscount(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.showDialogDiscount = true;\r\n  }\r\n}\r\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-order.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-order/transaction-header-order.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACpF,OAAO,EAAC,wBAAwB,EAAC,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAC,IAAI,EAAC,MAAM,yBAAyB,CAAC;AAC7C,OAAO,EAAC,8CAA8C,EAAC,MAAM,8BAA8B,CAAC;AAiG5F,MAAM,OAAO,+BAAgC,SAAQ,wBAAwB;IA/F7E;;QAgGkB,UAAK,GAAgB,IAAI,CAAC;QAOnC,eAAU,GAAY,KAAK,CAAC;QAC5B,uBAAkB,GAAY,KAAK,CAAC;IAO7C,CAAC;IAZQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAKM,YAAY,CAAC,KAAiB;QACnC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACjC,CAAC;;;YA9GF,SAAS,SAAC;gBACT,QAAQ,EAAE,6BAA6B;gBACvC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsFT;gBACD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,+BAA+B,CAAC;qBAC/D,CAAC;gBACF,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;wBAIE,WAAW,SAAC,mCAAmC","sourcesContent":["import {Component, forwardRef, HostBinding, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\n\r\n@Component({\r\n  selector: \"co-transaction-header-order\",\r\n  template: `\r\n      <co-transaction-header-block\r\n              [firstBlockTemplate]=\"firstBlock\"\r\n              [secondBlockTemplate]=\"secondBlock\"\r\n              [hiddenBlockTemplate]=\"hiddenBlock\"\r\n              (headerClick)=\"showDialog = true\"\r\n      >\r\n      </co-transaction-header-block>\r\n      <ng-template #firstBlock>\r\n        <div class=\"transaction-header-block-row\" (click)=\"showDialog = true\">\r\n          <div class=\"header-order-total-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderOrderOrderTotalHeader\" screenConfigNativeElement>\r\n            <span class=\"header-order-total-label co-transaction-label\" [textContent]=\"'ORDER_TOTAL' | localize\"></span>\r\n            <div class=\"header-order-total\" [textContent]=\"transactionTotal.netAmount | coCurrency\"></div>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <ng-template #secondBlock>\r\n        <div class=\"transaction-header-block-row\" (click)=\"showDialog = true\" [screenConfigurationObject]=\"cfgNames.HeaderOrderDiscountHeader\" screenConfigNativeElement>\r\n          <div class=\"transaction-header-discount-button\">\r\n            <div class=\"header-discount\" (click)=\"openDiscount($event)\">\r\n              <co-icon class=\"header-discount-icon\" [iconData]=\"iconCacheService.getIcon(icons.RegularEuroSignMinus)\"></co-icon>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <ng-template #hiddenBlock>\r\n        <div class=\"transaction-header-block-row\" [screenConfigurationObject]=\"cfgNames.HeaderOrderDefinitiveHeader\" screenConfigNativeElement>\r\n          <div class=\"header-order-definitive\">\r\n            <co-transaction-header-definitive class=\"transaction-header-order-definitive\"\r\n                [screenConfigurationObject]=\"cfgNames.HeaderOrderDefinitiveHeader\"\r\n                [transactionInfo]=\"transactionInfo\"\r\n            ></co-transaction-header-definitive>\r\n          </div>\r\n          <!--span class=\"header-order-line-amount-label co-transaction-label\" [textContent]=\"'ORDER_LINES' | localize\"></span>\r\n          <div class=\"header-order-line-amount\" [textContent]=\"transactionLines.length\"></div-->\r\n        </div>\r\n      </ng-template>\r\n      <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                   [activeCategoryDescription]=\"'ORDER_INFORMATION1'\"\r\n                                   [relation]=\"relation\"\r\n                                   [transaction]=\"transaction\"\r\n                                   (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n<!--\r\n\r\n      <co-dialog class=\"transaction-header-order-dialog\" [customCssClass]=\"'co-small-scrollbar'\" [headerTemplate]=\"headerTemplate\" *ngIf=\"showDialog\"\r\n                 (closeClick)=\"showDialog = false\">\r\n          <ng-template #headerTemplate>\r\n              <div class=\"co-dialog-header-title\" [textContent]=\"'ORDER_INFORMATION1' | localize\"></div>\r\n              <co-transaction-header-block\r\n                      [headerBlockTemplate]=\"headerBlock\"\r\n                      [firstBlockTemplate]=\"firstBlock\"\r\n                      [secondBlockTemplate]=\"secondBlock\"\r\n                      [thirdBlockTemplate]=\"thirdBlock\"\r\n              >\r\n              </co-transaction-header-block>\r\n          </ng-template>\r\n          <div class=\"order-dialog-section\">\r\n              <div class=\"section-wrapper\">\r\n                  <div class=\"section-header\" [textContent]=\"'BASE_INFO1' | localize | prepend:'01 '\"></div>\r\n                  <div class=\"two-column-grid\">\r\n                      <co-transaction-header-branch [simple]=\"true\" [transaction]=\"transaction\" [transactionInfo]=\"transactionInfo\"></co-transaction-header-branch>\r\n                      <co-transaction-header-sales-person [transactionInfo]=\"transactionInfo\"></co-transaction-header-sales-person>\r\n                      <co-transaction-header-administrative-relation\r\n                              [transactionInfo]=\"transactionInfo\"></co-transaction-header-administrative-relation>\r\n                      <co-transaction-header-price-kind [transaction]=\"transaction\" [transactionInfo]=\"transactionInfo\"></co-transaction-header-price-kind>\r\n                      <co-transaction-header-currency [transaction]=\"transaction\" [transactionInfo]=\"transactionInfo\"></co-transaction-header-currency>\r\n                      <co-transaction-header-payment-condition\r\n                              [transactionInfo]=\"transactionInfo\"></co-transaction-header-payment-condition>\r\n                  </div>\r\n              </div>\r\n              <div class=\"section-wrapper\">\r\n                  <div class=\"section-header\" [textContent]=\"'ORDER_PARAMETERS' | localize | prepend:'02 '\"></div>\r\n                  <div class=\"section-sub-title\" [textContent]=\"'ON_HOLD_CODES' | localize\"></div>\r\n                  <co-transaction-header-hold-codes [transactionInfo]=\"transaction.transactionInfo\"></co-transaction-header-hold-codes>\r\n                  <div class=\"section-sub-title\" [textContent]=\"'MARKETING_CODE' | localize\"></div>\r\n                  <co-transaction-header-marketing [transactionInfo]=\"transaction.transactionInfo\"></co-transaction-header-marketing>\r\n              </div>\r\n          </div>\r\n      </co-dialog>\r\n-->\r\n      <co-dialog-transaction-header-discount class=\"discount-dialog\" *ngIf=\"showDialogDiscount\"\r\n                                             [screenConfigurationObject]=\"cfgNames.DiscountPriceInformationHeader\"\r\n                                             [transactionInfo]=\"transactionInfo\"\r\n                                             [transactionTotal]=\"transactionTotal\"\r\n                                             (close)=\"showDialogDiscount = false\">\r\n      </co-dialog-transaction-header-discount>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionHeaderOrderComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderOrderComponent extends TransactionBaseComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding('class.co-transaction-header-order')\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public showDialog: boolean = false;\r\n  public showDialogDiscount: boolean = false;\r\n\r\n  public openDiscount(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.showDialogDiscount = true;\r\n  }\r\n}\r\n"]}
@@ -95,13 +95,7 @@ TransactionHeaderPaymentComponent.decorators = [
95
95
  </div>
96
96
  </div>
97
97
  <ng-template #firstBlock>
98
- <div class="transaction-header-block-row">
99
- <div class="transaction-header-icon" [screenConfigurationObject]="cfgNames.HeaderPaymentAvatarHeader" screenConfigNativeElement>
100
- <co-icon class="header-order-icon"
101
- (click)="showDialog = true"
102
- [iconData]="iconCacheService.getIcon(icons.CreditCardRegular)">
103
- </co-icon>
104
- </div>
98
+ <div class="transaction-header-block-row" (click)="showDialog = true">
105
99
  <div class="header-downpayment-amount-wrapper" [screenConfigurationObject]="cfgNames.HeaderPaymentAmountHeader" screenConfigNativeElement>
106
100
  <div class="header-deposit-label co-transaction-label" [textContent]="'DOWNPAYMENT_AMOUNT' | localize"></div>
107
101
  <co-transaction-header-deposit-amount class="transaction-header-deposit"
@@ -114,7 +108,7 @@ TransactionHeaderPaymentComponent.decorators = [
114
108
  </div>
115
109
  </ng-template>
116
110
  <ng-template #firstBlockRest>
117
- <div class="transaction-header-block-row">
111
+ <div class="transaction-header-block-row" (click)="showDialog = true">
118
112
  <div class="transaction-header-icon" [screenConfigurationObject]="cfgNames.HeaderPaymentAvatarHeader" screenConfigNativeElement>
119
113
  <co-icon class="header-order-icon"
120
114
  (click)="showPaymentDialog = true"
@@ -149,11 +143,6 @@ TransactionHeaderPaymentComponent.decorators = [
149
143
  <div class="header-payment-button-wrapper" (click)="openPayment($event)" [screenConfigurationObject]="cfgNames.HeaderPaymentPaymentHeader" screenConfigNativeElement>
150
144
  <co-icon class="header-order-icon" [iconData]="iconCacheService.getIcon(icons.CreditCardRegularCheck)">
151
145
  </co-icon>
152
- <div class="spacer"></div>
153
- <div class="payment-payed-wrapper">
154
- <!--div class="header-payed-label co-transaction-label" [textContent]="'DOWNPAYMENT_DONE' | localize"></div-->
155
- <span class="payment-paid" [class.success]="paid >= toPay" [textContent]="(paid | coCurrency) || 0"></span>
156
- </div>
157
146
  <!--co-transaction-header-payment-button *ngIf="transactionInfo.transactionKind !== transKind.PurchaseOrder"
158
147
  [transactionInfo]="transactionInfo"
159
148
  ></co-transaction-header-payment-button-->
@@ -224,4 +213,4 @@ TransactionHeaderPaymentComponent.ctorParameters = () => [
224
213
  TransactionHeaderPaymentComponent.propDecorators = {
225
214
  showClass: [{ type: HostBinding, args: ["class.co-transaction-header-payment",] }]
226
215
  };
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-payment.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-payment/transaction-header-payment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, forwardRef, HostBinding, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {TransactionPaymentConnectorService} from '../../../service/transaction-payment-connector.service';\r\nimport {TransactionDepositPaymentInfo} from '@colijnit/transactionapi/build/model/transaction-deposit-payment-info.bo';\r\nimport {DepositPaymentViewModel} from '../../../model/deposit-payment-view-model';\r\nimport {PaymentViewmodel} from '../../../model/payment.viewmodel';\r\nimport {DictionaryService} from '../../../service/dictionary.service';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {TransactionImageService} from '../../../service/transaction-image.service';\r\nimport {TransactionScreenConfigurationService} from '../../../service/transaction-screen-configuration.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {TransactionTypeCategory} from '../../../enum/transaction-type-category.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {TransactionPaymentService} from '../../../service/transaction-payment.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-header-payment\",\r\n  template: `\r\n    <div class=\"transaction-header-payment-wrapper\">\r\n      <div class=\"transaction-header-payment-wrapper-content\" [class.show-remaining]=\"showRemainingPayment\">\r\n        <co-transaction-header-block\r\n          [firstBlockTemplate]=\"firstBlock\"\r\n          [secondBlockTemplate]=\"secondBlock\"\r\n          [thirdBlockTemplate]=\"thirdBlock\"\r\n          [hiddenBlockTemplate]=\"hiddenBlock\"\r\n          (headerClick)=\"showDialog = true\"\r\n        >\r\n        </co-transaction-header-block>\r\n        <co-transaction-header-block *ngIf=\"showRemainingPayment\"\r\n          [firstBlockTemplate]=\"firstBlockRest\"\r\n          (headerClick)=\"showDialog = true\"\r\n        >\r\n        </co-transaction-header-block>\r\n      </div>\r\n    </div>\r\n    <ng-template #firstBlock>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"transaction-header-icon\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAvatarHeader\" screenConfigNativeElement>\r\n          <co-icon class=\"header-order-icon\"\r\n                   (click)=\"showDialog = true\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegular)\">\r\n          </co-icon>\r\n        </div>\r\n        <div class=\"header-downpayment-amount-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\" screenConfigNativeElement>\r\n          <div class=\"header-deposit-label co-transaction-label\" [textContent]=\"'DOWNPAYMENT_AMOUNT' | localize\"></div>\r\n          <co-transaction-header-deposit-amount class=\"transaction-header-deposit\"\r\n                                                [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\"\r\n                                                [transaction]=\"transaction\"\r\n                                                [defaultEditMode]=\"false\"\r\n                                                [showLabel]=\"false\"\r\n          ></co-transaction-header-deposit-amount>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #firstBlockRest>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"transaction-header-icon\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAvatarHeader\" screenConfigNativeElement>\r\n          <co-icon class=\"header-order-icon\"\r\n                   (click)=\"showPaymentDialog = true\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegularCheck)\">\r\n          </co-icon>\r\n        </div>\r\n        <div class=\"header-remaining-payment-amount-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\" screenConfigNativeElement>\r\n          <div class=\"header-deposit-label co-transaction-label\" [textContent]=\"'REMAINING_PAYMENT' | localize\"></div>\r\n          <co-transaction-header-remaining-amount class=\"transaction-header-remaining\"\r\n                                                  [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\"\r\n                                                  [transactionUuid]=\"transaction.transactionInfo.uuid\"\r\n                                                  (remainingAmountChange)=\"remainingToPay = $event\"\r\n          ></co-transaction-header-remaining-amount>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #secondBlock>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"header-downpayment-percentage-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentPercentageHeader\" screenConfigNativeElement>\r\n          <div class=\"header-deposit-label co-transaction-label\" [textContent]=\"'%' | localize\"></div>\r\n          <co-transaction-header-deposit-percentage class=\"transaction-header-deposit\"\r\n                                                    [screenConfigurationObject]=\"cfgNames.HeaderPaymentPercentageHeader\"\r\n                                                    [transactionInfo]=\"transactionInfo\"\r\n                                                    [defaultEditMode]=\"false\"\r\n                                                    [showLabel]=\"false\"\r\n          ></co-transaction-header-deposit-percentage>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #thirdBlock>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"header-payment-button-wrapper\" (click)=\"openPayment($event)\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentPaymentHeader\" screenConfigNativeElement>\r\n            <co-icon class=\"header-order-icon\" [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegularCheck)\">\r\n            </co-icon>\r\n          <div class=\"spacer\"></div>\r\n          <div class=\"payment-payed-wrapper\">\r\n            <!--div class=\"header-payed-label co-transaction-label\" [textContent]=\"'DOWNPAYMENT_DONE' | localize\"></div-->\r\n            <span class=\"payment-paid\" [class.success]=\"paid >= toPay\" [textContent]=\"(paid | coCurrency) || 0\"></span>\r\n          </div>\r\n          <!--co-transaction-header-payment-button *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                                                [transactionInfo]=\"transactionInfo\"\r\n          ></co-transaction-header-payment-button-->\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #hiddenBlock>\r\n      <!--div class=\"transaction-header-block-row\">\r\n        <div class=\"header-branch-label co-transaction-label\" [textContent]=\"'BRANCH' | localize\"></div>\r\n        <div class=\"branch-label\" [textContent]=\"transactionInfo.branch?.familyName\"></div>\r\n      </div-->\r\n    </ng-template>\r\n    <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                 [activeCategoryDescription]=\"'PAYMENT_INFORMATION'\"\r\n                                 [relation]=\"relation\"\r\n                                 [transaction]=\"transaction\"\r\n                                 (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n<!--\r\n    <co-dialog class=\"transaction-header-payment-dialog\" [headerTemplate]=\"headerTemplate\" *ngIf=\"showDialog\" (closeClick)=\"showDialog = false\">\r\n      <ng-template #headerTemplate>\r\n        <div class=\"co-dialog-header-title\" [textContent]=\"'PAYMENT_INFORMATION' | localize\"></div>\r\n        <co-transaction-header-block\r\n          [headerBlockTemplate]=\"headerBlock\"\r\n          [firstBlockTemplate]=\"firstBlock\"\r\n          [secondBlockTemplate]=\"secondBlock\"\r\n        >\r\n        </co-transaction-header-block>\r\n      </ng-template>\r\n      <div class=\"payment-dialog-section\">\r\n        <co-deposit-payment [branch]=\"transactionInfo.branch?.relationNr\" [transactionUuid]=\"transactionInfo.uuid\"></co-deposit-payment>\r\n      </div>\r\n    </co-dialog>\r\n-->\r\n    <co-dialog class=\"payment-dialog\" [modal]=\"true\" [headerTemplate]=\"headerTemplate\" *ngIf=\"showPaymentDialog\" (closeClick)=\"showPaymentDialog = false\">\r\n      <ng-template #headerTemplate>\r\n        <div class=\"co-dialog-wrapper-popup-title\">\r\n          <co-icon [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegularCheck)\"></co-icon>\r\n          <div class=\"co-dialog-header-title\" [textContent]=\"'PAYMENT_METHOD' | localize\"></div>\r\n        </div>\r\n      </ng-template>\r\n      <co-payment\r\n        [transId]=\"transactionInfo.id\"\r\n        [branch]=\"transactionInfo.branch?.relationNr\"\r\n        [transactionUuid]=\"transactionInfo.uuid\"\r\n        [amount]=\"showRemainingPayment ? remainingToPay : toPay\"\r\n        [remainingPayment]=\"showRemainingPayment\"\r\n        [currencyId]=\"transactionInfo.currencyId\"\r\n        [doNotFetchAmountToPayForRemaining]=\"true\"\r\n      ></co-payment>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    {provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => TransactionHeaderPaymentComponent)}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderPaymentComponent extends TransactionBaseComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding(\"class.co-transaction-header-payment\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public paymentMethods: PaymentViewmodel[] = [];\r\n  public depositPayments: DepositPaymentViewModel[] = [];\r\n  public showDialog: boolean = false;\r\n  public showPaymentDialog: boolean = false;\r\n  public showLoaderDepositPayments: boolean = true;\r\n  public paid: number = 0;\r\n  public toPay: number = 0;\r\n  public remainingToPay: number = 0;\r\n  public showRemainingPayment: boolean = false;\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    public transactionEventService: TransactionEventService,\r\n    public service: TransactionService,\r\n    public iconCacheService: IconCacheService,\r\n    public transactionScreenConfigurationService: TransactionScreenConfigurationService,\r\n    protected dictionaryService: DictionaryService,\r\n    protected imageService: TransactionImageService,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    private _paymentConnectorService: TransactionPaymentConnectorService,\r\n  ) {\r\n    super(transactionEventService, iconCacheService, transactionScreenConfigurationService, imageService, dictionaryService, service, changeDetector);\r\n  }\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this._subs.push(\r\n        this.transactionEventService.transactionPaymentDone.subscribe(() => this._getDepositPaymentInfo()),\r\n        this.transactionEventService.activeRubricChange.subscribe((rubric: TransactionTypeCategory) => {\r\n          this.showRemainingPayment = rubric === TransactionTypeCategory.SalesOrderDeliveryNote || rubric === TransactionTypeCategory.SalesOrderInvoice;\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 async openPayment(event: MouseEvent): Promise<void> {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (await this.lockTransaction()) {\r\n      this.showPaymentDialog = true;\r\n    }\r\n  }\r\n\r\n  public async transactionSet(): Promise<void> {\r\n    this._getDepositPaymentInfo();\r\n  }\r\n\r\n  private _getDepositPaymentInfo(): void {\r\n    this.depositPayments.length = 0;\r\n    if (this.transactionInfo && this.transactionInfo.id && this.transactionInfo.uuid) {\r\n      this._paymentConnectorService.getDepositPaymentInfo(this.transactionInfo.uuid).then((info: TransactionDepositPaymentInfo) => {\r\n        if (info) {\r\n          this.toPay = info.depositAmount;\r\n          this.paid = info.depositPaymentAmountTotal;\r\n        }\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-payment.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-payment/transaction-header-payment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, forwardRef, HostBinding, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {TransactionPaymentConnectorService} from '../../../service/transaction-payment-connector.service';\r\nimport {TransactionDepositPaymentInfo} from '@colijnit/transactionapi/build/model/transaction-deposit-payment-info.bo';\r\nimport {DepositPaymentViewModel} from '../../../model/deposit-payment-view-model';\r\nimport {PaymentViewmodel} from '../../../model/payment.viewmodel';\r\nimport {DictionaryService} from '../../../service/dictionary.service';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {TransactionImageService} from '../../../service/transaction-image.service';\r\nimport {TransactionScreenConfigurationService} from '../../../service/transaction-screen-configuration.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {TransactionTypeCategory} from '../../../enum/transaction-type-category.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {TransactionPaymentService} from '../../../service/transaction-payment.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-header-payment\",\r\n  template: `\r\n    <div class=\"transaction-header-payment-wrapper\">\r\n      <div class=\"transaction-header-payment-wrapper-content\" [class.show-remaining]=\"showRemainingPayment\">\r\n        <co-transaction-header-block\r\n          [firstBlockTemplate]=\"firstBlock\"\r\n          [secondBlockTemplate]=\"secondBlock\"\r\n          [thirdBlockTemplate]=\"thirdBlock\"\r\n          [hiddenBlockTemplate]=\"hiddenBlock\"\r\n          (headerClick)=\"showDialog = true\"\r\n        >\r\n        </co-transaction-header-block>\r\n        <co-transaction-header-block *ngIf=\"showRemainingPayment\"\r\n          [firstBlockTemplate]=\"firstBlockRest\"\r\n          (headerClick)=\"showDialog = true\"\r\n        >\r\n        </co-transaction-header-block>\r\n      </div>\r\n    </div>\r\n    <ng-template #firstBlock>\r\n      <div class=\"transaction-header-block-row\" (click)=\"showDialog = true\">\r\n        <div class=\"header-downpayment-amount-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\" screenConfigNativeElement>\r\n          <div class=\"header-deposit-label co-transaction-label\" [textContent]=\"'DOWNPAYMENT_AMOUNT' | localize\"></div>\r\n          <co-transaction-header-deposit-amount class=\"transaction-header-deposit\"\r\n                                                [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\"\r\n                                                [transaction]=\"transaction\"\r\n                                                [defaultEditMode]=\"false\"\r\n                                                [showLabel]=\"false\"\r\n          ></co-transaction-header-deposit-amount>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #firstBlockRest>\r\n      <div class=\"transaction-header-block-row\" (click)=\"showDialog = true\">\r\n        <div class=\"transaction-header-icon\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAvatarHeader\" screenConfigNativeElement>\r\n          <co-icon class=\"header-order-icon\"\r\n                   (click)=\"showPaymentDialog = true\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegularCheck)\">\r\n          </co-icon>\r\n        </div>\r\n        <div class=\"header-remaining-payment-amount-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\" screenConfigNativeElement>\r\n          <div class=\"header-deposit-label co-transaction-label\" [textContent]=\"'REMAINING_PAYMENT' | localize\"></div>\r\n          <co-transaction-header-remaining-amount class=\"transaction-header-remaining\"\r\n                                                  [screenConfigurationObject]=\"cfgNames.HeaderPaymentAmountHeader\"\r\n                                                  [transactionUuid]=\"transaction.transactionInfo.uuid\"\r\n                                                  (remainingAmountChange)=\"remainingToPay = $event\"\r\n          ></co-transaction-header-remaining-amount>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #secondBlock>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"header-downpayment-percentage-wrapper\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentPercentageHeader\" screenConfigNativeElement>\r\n          <div class=\"header-deposit-label co-transaction-label\" [textContent]=\"'%' | localize\"></div>\r\n          <co-transaction-header-deposit-percentage class=\"transaction-header-deposit\"\r\n                                                    [screenConfigurationObject]=\"cfgNames.HeaderPaymentPercentageHeader\"\r\n                                                    [transactionInfo]=\"transactionInfo\"\r\n                                                    [defaultEditMode]=\"false\"\r\n                                                    [showLabel]=\"false\"\r\n          ></co-transaction-header-deposit-percentage>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #thirdBlock>\r\n      <div class=\"transaction-header-block-row\">\r\n        <div class=\"header-payment-button-wrapper\" (click)=\"openPayment($event)\" [screenConfigurationObject]=\"cfgNames.HeaderPaymentPaymentHeader\" screenConfigNativeElement>\r\n            <co-icon class=\"header-order-icon\" [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegularCheck)\">\r\n            </co-icon>\r\n          <!--co-transaction-header-payment-button *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                                                [transactionInfo]=\"transactionInfo\"\r\n          ></co-transaction-header-payment-button-->\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #hiddenBlock>\r\n      <!--div class=\"transaction-header-block-row\">\r\n        <div class=\"header-branch-label co-transaction-label\" [textContent]=\"'BRANCH' | localize\"></div>\r\n        <div class=\"branch-label\" [textContent]=\"transactionInfo.branch?.familyName\"></div>\r\n      </div-->\r\n    </ng-template>\r\n    <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                 [activeCategoryDescription]=\"'PAYMENT_INFORMATION'\"\r\n                                 [relation]=\"relation\"\r\n                                 [transaction]=\"transaction\"\r\n                                 (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n<!--\r\n    <co-dialog class=\"transaction-header-payment-dialog\" [headerTemplate]=\"headerTemplate\" *ngIf=\"showDialog\" (closeClick)=\"showDialog = false\">\r\n      <ng-template #headerTemplate>\r\n        <div class=\"co-dialog-header-title\" [textContent]=\"'PAYMENT_INFORMATION' | localize\"></div>\r\n        <co-transaction-header-block\r\n          [headerBlockTemplate]=\"headerBlock\"\r\n          [firstBlockTemplate]=\"firstBlock\"\r\n          [secondBlockTemplate]=\"secondBlock\"\r\n        >\r\n        </co-transaction-header-block>\r\n      </ng-template>\r\n      <div class=\"payment-dialog-section\">\r\n        <co-deposit-payment [branch]=\"transactionInfo.branch?.relationNr\" [transactionUuid]=\"transactionInfo.uuid\"></co-deposit-payment>\r\n      </div>\r\n    </co-dialog>\r\n-->\r\n    <co-dialog class=\"payment-dialog\" [modal]=\"true\" [headerTemplate]=\"headerTemplate\" *ngIf=\"showPaymentDialog\" (closeClick)=\"showPaymentDialog = false\">\r\n      <ng-template #headerTemplate>\r\n        <div class=\"co-dialog-wrapper-popup-title\">\r\n          <co-icon [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegularCheck)\"></co-icon>\r\n          <div class=\"co-dialog-header-title\" [textContent]=\"'PAYMENT_METHOD' | localize\"></div>\r\n        </div>\r\n      </ng-template>\r\n      <co-payment\r\n        [transId]=\"transactionInfo.id\"\r\n        [branch]=\"transactionInfo.branch?.relationNr\"\r\n        [transactionUuid]=\"transactionInfo.uuid\"\r\n        [amount]=\"showRemainingPayment ? remainingToPay : toPay\"\r\n        [remainingPayment]=\"showRemainingPayment\"\r\n        [currencyId]=\"transactionInfo.currencyId\"\r\n        [doNotFetchAmountToPayForRemaining]=\"true\"\r\n      ></co-payment>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    {provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => TransactionHeaderPaymentComponent)}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderPaymentComponent extends TransactionBaseComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding(\"class.co-transaction-header-payment\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public paymentMethods: PaymentViewmodel[] = [];\r\n  public depositPayments: DepositPaymentViewModel[] = [];\r\n  public showDialog: boolean = false;\r\n  public showPaymentDialog: boolean = false;\r\n  public showLoaderDepositPayments: boolean = true;\r\n  public paid: number = 0;\r\n  public toPay: number = 0;\r\n  public remainingToPay: number = 0;\r\n  public showRemainingPayment: boolean = false;\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    public transactionEventService: TransactionEventService,\r\n    public service: TransactionService,\r\n    public iconCacheService: IconCacheService,\r\n    public transactionScreenConfigurationService: TransactionScreenConfigurationService,\r\n    protected dictionaryService: DictionaryService,\r\n    protected imageService: TransactionImageService,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    private _paymentConnectorService: TransactionPaymentConnectorService,\r\n  ) {\r\n    super(transactionEventService, iconCacheService, transactionScreenConfigurationService, imageService, dictionaryService, service, changeDetector);\r\n  }\r\n\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    this._subs.push(\r\n        this.transactionEventService.transactionPaymentDone.subscribe(() => this._getDepositPaymentInfo()),\r\n        this.transactionEventService.activeRubricChange.subscribe((rubric: TransactionTypeCategory) => {\r\n          this.showRemainingPayment = rubric === TransactionTypeCategory.SalesOrderDeliveryNote || rubric === TransactionTypeCategory.SalesOrderInvoice;\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 async openPayment(event: MouseEvent): Promise<void> {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    if (await this.lockTransaction()) {\r\n      this.showPaymentDialog = true;\r\n    }\r\n  }\r\n\r\n  public async transactionSet(): Promise<void> {\r\n    this._getDepositPaymentInfo();\r\n  }\r\n\r\n  private _getDepositPaymentInfo(): void {\r\n    this.depositPayments.length = 0;\r\n    if (this.transactionInfo && this.transactionInfo.id && this.transactionInfo.uuid) {\r\n      this._paymentConnectorService.getDepositPaymentInfo(this.transactionInfo.uuid).then((info: TransactionDepositPaymentInfo) => {\r\n        if (info) {\r\n          this.toPay = info.depositAmount;\r\n          this.paid = info.depositPaymentAmountTotal;\r\n        }\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
@@ -71,10 +71,7 @@ TransactionHeaderRelationComponent.decorators = [
71
71
  </div>
72
72
  </ng-container>
73
73
  <ng-container *ngIf="relation && relation.relationId">
74
- <div class="transaction-relation-icon" (click)="showDialog = true" [screenConfigurationObject]="cfgNames.HeaderRelationAvatarHeader" screenConfigNativeElement>
75
- <co-avatar class="transaction-relation-avatar" [relationId]="relation.relationId"></co-avatar>
76
- </div>
77
- <div class="header-relation-content">
74
+ <div class="header-relation-content" (click)="showDialog = true">
78
75
  <label class="header-block-label co-transaction-label" [textContent]="'RELATION' | localize"
79
76
  [screenConfigurationObject]="cfgNames.HeaderRelationRelationHeader" screenConfigNativeElement
80
77
  ></label>
@@ -89,7 +86,7 @@ TransactionHeaderRelationComponent.decorators = [
89
86
  </ng-template>
90
87
  <ng-template #secondBlock>
91
88
  <ng-container *ngIf="relation && relation.relationId">
92
- <div class="header-relation-content">
89
+ <div class="header-relation-content" (click)="showDialog = true">
93
90
  <label class="header-block-label co-transaction-label" [textContent]="'COMMUNICATION' | localize" *ngIf="showCommunicationLabel"></label>
94
91
  <div class="header-relation-email text-overflow" [textContent]="relation.primaryEmail"
95
92
  [screenConfigurationObject]="cfgNames.HeaderRelationEmailHeader" screenConfigNativeElement></div>
@@ -117,4 +114,4 @@ TransactionHeaderRelationComponent.decorators = [
117
114
  TransactionHeaderRelationComponent.propDecorators = {
118
115
  showClass: [{ type: HostBinding, args: ['class.co-transaction-header-relation',] }]
119
116
  };
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-relation.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-relation/transaction-header-relation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {FormMasterService, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {Subscription} from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'co-transaction-header-relation',\r\n    template: `\r\n        <co-transaction-header-block *ngIf=\"loaded\"\r\n                [firstBlockTemplate]=\"firstBlock\"\r\n                [secondBlockTemplate]=\"secondBlock\"\r\n                (headerClick)=\"showDialog = true\"\r\n                [class]=\"'relation-header'\"\r\n        >\r\n        </co-transaction-header-block>\r\n        <ng-template #firstBlock>\r\n            <ng-container *ngIf=\"!relation || !relation.relationId\">\r\n              <div class=\"no-relation-yet\">\r\n                <co-button [label]=\"'LINK_CUSTOMER' | localize\" (click)=\"showDialog = true\"></co-button>\r\n              </div>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"relation && relation.relationId\">\r\n                <div class=\"transaction-relation-icon\" (click)=\"showDialog = true\" [screenConfigurationObject]=\"cfgNames.HeaderRelationAvatarHeader\" screenConfigNativeElement>\r\n                    <co-avatar class=\"transaction-relation-avatar\" [relationId]=\"relation.relationId\"></co-avatar>\r\n                </div>\r\n                <div class=\"header-relation-content\">\r\n                    <label class=\"header-block-label co-transaction-label\" [textContent]=\"'RELATION' | localize\"\r\n                           [screenConfigurationObject]=\"cfgNames.HeaderRelationRelationHeader\" screenConfigNativeElement\r\n                    ></label>\r\n                    <div class=\"header-relation-name text-overflow\" [textContent]=\"relation.displayName\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationRelationHeader\" screenConfigNativeElement></div>\r\n                    <div class=\"header-relation-address text-overflow\" [textContent]=\"firstAddress\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationAddressHeader\" screenConfigNativeElement></div>\r\n                    <div class=\"header-relation-postal text-overflow\" [textContent]=\"firstPostal\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationPostalHeader\" screenConfigNativeElement></div>\r\n                </div>\r\n            </ng-container>\r\n        </ng-template>\r\n        <ng-template #secondBlock>\r\n            <ng-container *ngIf=\"relation && relation.relationId\">\r\n                <div class=\"header-relation-content\">\r\n                    <label class=\"header-block-label co-transaction-label\" [textContent]=\"'COMMUNICATION' | localize\" *ngIf=\"showCommunicationLabel\"></label>\r\n                    <div class=\"header-relation-email text-overflow\" [textContent]=\"relation.primaryEmail\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationEmailHeader\" screenConfigNativeElement></div>\r\n                    <div class=\"header-relation-phone text-overflow\" [textContent]=\"relation.primaryPhoneOrMobileNumber\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationPhoneHeader\" screenConfigNativeElement></div>\r\n                </div>\r\n            </ng-container>\r\n        </ng-template>\r\n        <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                     [activeCategoryDescription]=\"transactionKind === transKind.PurchaseOrder ? 'SUPPLIER' : 'CLIENT_INFORMATION'\"\r\n                                     [(relation)]=\"relation\"\r\n                                     [transaction]=\"transaction\"\r\n                                     (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n    `,\r\n    providers: [\r\n        FormMasterService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => TransactionHeaderRelationComponent)\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderRelationComponent extends TransactionBaseComponent implements OnInit, OnDestroy {\r\n    public readonly icons: typeof Icon = Icon;\r\n\r\n    @HostBinding('class.co-transaction-header-relation')\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public showDialog: boolean = false;\r\n    public firstAddress: string;\r\n    public firstPostal: string;\r\n    public showCommunicationLabel: boolean = false;\r\n    public loaded: boolean = false;\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((configObjects: string[]) => {\r\n                if (configObjects && configObjects.length > 0) {\r\n                    this.showCommunicationLabel = this.screenConfigService.getObjectConfigurationFor(this.cfgNames.HeaderRelationPhoneHeader).immediatelyVisible() ||\r\n                        this.screenConfigService.getObjectConfigurationFor(this.cfgNames.HeaderRelationEmailHeader).immediatelyVisible();\r\n                }\r\n            }),\r\n            this.transactionService.relationUpdated.subscribe(relation => {\r\n                if (relation !== undefined) {\r\n                    this.loaded = true;\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    protected relationSet(): void {\r\n        super.relationSet();\r\n        this._setRelationAddress();\r\n    }\r\n\r\n    protected transactionInfoSet() {\r\n        super.transactionInfoSet();\r\n        this._setRelationAddress();\r\n    }\r\n\r\n    private _setRelationAddress(): void {\r\n        if (this.relation && this.relation.addresses && this.transactionInfo) {\r\n            const address: Address = this.relation.addresses.find(a => a.nawNr === this.transactionInfo.transactionAddress);\r\n            if (address) {\r\n                this.firstAddress = address.displayAddress;\r\n                this.firstPostal = address.displayPostal;\r\n            } else {\r\n                this.firstAddress = \"\";\r\n                this.firstPostal = \"\";\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-relation.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-relation/transaction-header-relation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {FormMasterService, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {Subscription} from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'co-transaction-header-relation',\r\n    template: `\r\n        <co-transaction-header-block *ngIf=\"loaded\"\r\n                [firstBlockTemplate]=\"firstBlock\"\r\n                [secondBlockTemplate]=\"secondBlock\"\r\n                (headerClick)=\"showDialog = true\"\r\n                [class]=\"'relation-header'\"\r\n        >\r\n        </co-transaction-header-block>\r\n        <ng-template #firstBlock>\r\n            <ng-container *ngIf=\"!relation || !relation.relationId\">\r\n              <div class=\"no-relation-yet\">\r\n                <co-button [label]=\"'LINK_CUSTOMER' | localize\" (click)=\"showDialog = true\"></co-button>\r\n              </div>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"relation && relation.relationId\">\r\n                <div class=\"header-relation-content\" (click)=\"showDialog = true\">\r\n                    <label class=\"header-block-label co-transaction-label\" [textContent]=\"'RELATION' | localize\"\r\n                           [screenConfigurationObject]=\"cfgNames.HeaderRelationRelationHeader\" screenConfigNativeElement\r\n                    ></label>\r\n                    <div class=\"header-relation-name text-overflow\" [textContent]=\"relation.displayName\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationRelationHeader\" screenConfigNativeElement></div>\r\n                    <div class=\"header-relation-address text-overflow\" [textContent]=\"firstAddress\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationAddressHeader\" screenConfigNativeElement></div>\r\n                    <div class=\"header-relation-postal text-overflow\" [textContent]=\"firstPostal\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationPostalHeader\" screenConfigNativeElement></div>\r\n                </div>\r\n            </ng-container>\r\n        </ng-template>\r\n        <ng-template #secondBlock>\r\n            <ng-container *ngIf=\"relation && relation.relationId\">\r\n                <div class=\"header-relation-content\" (click)=\"showDialog = true\">\r\n                    <label class=\"header-block-label co-transaction-label\" [textContent]=\"'COMMUNICATION' | localize\" *ngIf=\"showCommunicationLabel\"></label>\r\n                    <div class=\"header-relation-email text-overflow\" [textContent]=\"relation.primaryEmail\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationEmailHeader\" screenConfigNativeElement></div>\r\n                    <div class=\"header-relation-phone text-overflow\" [textContent]=\"relation.primaryPhoneOrMobileNumber\"\r\n                         [screenConfigurationObject]=\"cfgNames.HeaderRelationPhoneHeader\" screenConfigNativeElement></div>\r\n                </div>\r\n            </ng-container>\r\n        </ng-template>\r\n        <co-transaction-header-popup *ngIf=\"showDialog\"\r\n                                     [activeCategoryDescription]=\"transactionKind === transKind.PurchaseOrder ? 'SUPPLIER' : 'CLIENT_INFORMATION'\"\r\n                                     [(relation)]=\"relation\"\r\n                                     [transaction]=\"transaction\"\r\n                                     (closeClick)=\"showDialog = false\"></co-transaction-header-popup>\r\n    `,\r\n    providers: [\r\n        FormMasterService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => TransactionHeaderRelationComponent)\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderRelationComponent extends TransactionBaseComponent implements OnInit, OnDestroy {\r\n    public readonly icons: typeof Icon = Icon;\r\n\r\n    @HostBinding('class.co-transaction-header-relation')\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public showDialog: boolean = false;\r\n    public firstAddress: string;\r\n    public firstPostal: string;\r\n    public showCommunicationLabel: boolean = false;\r\n    public loaded: boolean = false;\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((configObjects: string[]) => {\r\n                if (configObjects && configObjects.length > 0) {\r\n                    this.showCommunicationLabel = this.screenConfigService.getObjectConfigurationFor(this.cfgNames.HeaderRelationPhoneHeader).immediatelyVisible() ||\r\n                        this.screenConfigService.getObjectConfigurationFor(this.cfgNames.HeaderRelationEmailHeader).immediatelyVisible();\r\n                }\r\n            }),\r\n            this.transactionService.relationUpdated.subscribe(relation => {\r\n                if (relation !== undefined) {\r\n                    this.loaded = true;\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    protected relationSet(): void {\r\n        super.relationSet();\r\n        this._setRelationAddress();\r\n    }\r\n\r\n    protected transactionInfoSet() {\r\n        super.transactionInfoSet();\r\n        this._setRelationAddress();\r\n    }\r\n\r\n    private _setRelationAddress(): void {\r\n        if (this.relation && this.relation.addresses && this.transactionInfo) {\r\n            const address: Address = this.relation.addresses.find(a => a.nawNr === this.transactionInfo.transactionAddress);\r\n            if (address) {\r\n                this.firstAddress = address.displayAddress;\r\n                this.firstPostal = address.displayPostal;\r\n            } else {\r\n                this.firstAddress = \"\";\r\n                this.firstPostal = \"\";\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}