@colijnit/transaction 257.1.61 → 257.1.63

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.
@@ -60,6 +60,7 @@ export class TransactionHeaderPopupPaymentComponent extends TransactionHeaderPop
60
60
  this._paymentSubs.push(this.transactionEventService.transactionPaymentDone.subscribe(() => {
61
61
  this._getDepositInfo();
62
62
  this._getOutstandingAmounts();
63
+ this.handleCloseDialog();
63
64
  }), this.screenConfigService.configSet.subscribe((configObjects) => this._getObjectConfiguration(configObjects)));
64
65
  this.showCashOnDelivery = yield this.transactionService.getInternalParameter(InternalParam.SellDirectlyFromSuppl);
65
66
  });
@@ -91,7 +92,7 @@ export class TransactionHeaderPopupPaymentComponent extends TransactionHeaderPop
91
92
  this.cashOnDelivery = value;
92
93
  }
93
94
  showPaymentButton() {
94
- return this.orderPaymentAnalysis.some(t => t.outstandingAmount > 0) && this.chosenAmountToPay > 0;
95
+ return this.orderPaymentAnalysis.some(t => t.outstandingAmount !== 0) && this.chosenAmountToPay !== 0;
95
96
  }
96
97
  openPayment(event) {
97
98
  var _a;
@@ -399,9 +400,9 @@ TransactionHeaderPopupPaymentComponent.decorators = [
399
400
 
400
401
  <co-dialog
401
402
  class="payment-dialog"
403
+ *ngIf="showPaymentDialog"
402
404
  [modal]="true"
403
405
  [headerTemplate]="headerTemplate"
404
- *ngIf="showPaymentDialog"
405
406
  (closeClick)="handleCloseDialog()">
406
407
  <ng-template #headerTemplate>
407
408
  <div class="co-dialog-wrapper-popup-title">
@@ -417,8 +418,8 @@ TransactionHeaderPopupPaymentComponent.decorators = [
417
418
  [remainingPayment]="true"
418
419
  [currencyId]="transactionInfo.currencyId"
419
420
  [doNotFetchAmountToPayForRemaining]="true"
420
- [showPaymentDate]="true"
421
- ></co-payment>
421
+ [showPaymentDate]="true">
422
+ </co-payment>
422
423
  </co-dialog>
423
424
  `,
424
425
  encapsulation: ViewEncapsulation.None
@@ -441,4 +442,4 @@ TransactionHeaderPopupPaymentComponent.ctorParameters = () => [
441
442
  TransactionHeaderPopupPaymentComponent.propDecorators = {
442
443
  showClass: [{ type: HostBinding, args: ['class.co-transaction-header-popup-payment',] }]
443
444
  };
444
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-popup-payment.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-payment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, HostBinding, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionHeaderPopupBaseComponent} from './transaction-header-popup-base.component';\r\nimport {TransactionDepositPaymentInfo} from '@colijnit/transactionapi/build/model/transaction-deposit-payment-info.bo';\r\nimport {PaymentAnalysis} from '@colijnit/transactionapi/build/model/payment-analysis.bo';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionScreenConfigurationService} from '../../../service/transaction-screen-configuration.service';\r\nimport {DictionaryService} from '../../../service/dictionary.service';\r\nimport {TransactionImageService} from '../../../service/transaction-image.service';\r\nimport {TransactionDialogService} from '../../../service/transaction-dialog.service';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {TransactionRelationService} from '../../../service/transaction-relation.service';\r\nimport {TransactionPaymentConnectorService} from '../../../service/transaction-payment-connector.service';\r\nimport {InternalParam} from '@colijnit/mainapi/build/enum/internal-param.enum';\r\nimport {TransactionHeaderService} from '../../core/base/service/transaction-header.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\r\nimport {CoCurrencyPipe} from '../../../pipe/co-currency.pipe';\r\nimport {OrderPaymentAnalysis} from '@colijnit/transactionapi/build/model/order-payment-analysis.bo';\r\nimport {OrderPaymentAnalysisFilter} from '@colijnit/transactionapi/build/model/order-payment-analysis-filter.bo';\r\nimport {TransactionRegisteredPaymentInfo} from '@colijnit/transactionapi/build/model/transaction-registered-payment-info.bo';\r\n\r\nexport interface PaymentCategory {\r\n  index: number;\r\n  title: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'co-transaction-header-popup-payment',\r\n  template: `\r\n      <div class=\"transaction-header-popup-category-wrapper co-small-scrollbar\">\r\n          <co-form>\r\n              <div class=\"transaction-header-popup-section\">\r\n                  <div\r\n                          class=\"transaction-header-popup-section-label\"\r\n                          *ngIf=\"showPayDownLabel\"\r\n                          [textContent]=\"'TO_PAY_DOWN' | localize\">\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-two-column-grid\">\r\n                      <co-transaction-header-deposit-percentage\r\n                              [screenConfigurationObject]=\"cfgNames.DepositPercentage\"\r\n                              [lockAndSave]=\"true\"\r\n                              (depositUpdated)=\"showOutstandingAmounts()\">\r\n                      </co-transaction-header-deposit-percentage>\r\n                      <co-transaction-header-deposit-amount class=\"transaction-line-totals-price price\"\r\n                                                            [screenConfigurationObject]=\"cfgNames.DepositAmount\"\r\n                                                            [lockAndSave]=\"true\"\r\n                                                            (businessRuleApplied)=\"showBusinessRuleInfo = $event\">\r\n                      </co-transaction-header-deposit-amount>\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-three-column-grid\">\r\n                      <co-transaction-header-use-deposit-rule\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [screenConfigurationObject]=\"cfgNames.UseDepositRule\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-use-deposit-rule>\r\n                      <co-transaction-header-auto-recalculate-deposit\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [screenConfigurationObject]=\"cfgNames.AutoRecalculateDeposit\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-auto-recalculate-deposit>\r\n                      <co-transaction-header-divide-evenly\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [screenConfigurationObject]=\"cfgNames.DivideEvenly\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-divide-evenly>\r\n                      <div class=\"transaction-header-popup-business-rule-applied\" *ngIf=\"showBusinessRuleInfo\">\r\n                          <co-icon [iconData]=\"iconCacheService.getIcon(icons.CircleExclamationRegular)\"></co-icon>\r\n                          <span [textContent]=\"'DEPOSIT_BUSINESS_RULE_APPLIED' | localize\"></span>\r\n                      </div>\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-two-column-grid\">\r\n                      <co-transaction-header-amount-to-settle\r\n                              [screenConfigurationObject]=\"cfgNames.AmountToSettle\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-amount-to-settle>\r\n                      <div class=\"transaction-header-popup-already-paid\">\r\n                          <co-input-text\r\n                                  [screenConfigurationObject]=\"cfgNames.TotalPaidDown\"\r\n                                  [placeholder]=\"'TOTAL_PAID_DOWN' | localize\" [forceReadonly]=\"true\"\r\n                                  [model]=\"paidDown\" [formatPipe]=\"currencyPipe\">\r\n                          </co-input-text>\r\n                          <co-input-text\r\n                                  [screenConfigurationObject]=\"cfgNames.SettledSoFar\"\r\n                                  [placeholder]=\"'SETTLED_SO_FAR' | localize\" [forceReadonly]=\"true\"\r\n                                  [model]=\"settled\" [formatPipe]=\"currencyPipe\">\r\n                          </co-input-text>\r\n                      </div>\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-two-column-grid\" *ngIf=\"showCashOnDelivery\">\r\n                      <div class=\"cash-on-delivery-row\">\r\n                          <co-input-text\r\n                                  [placeholder]=\"'CASH_ON_DELIVERY' | localize\"\r\n                                  [forceReadonly]=\"true\"\r\n                                  [(model)]=\"cashOnDelivery\"\r\n                                  [formatPipe]=\"currencyPipe\">\r\n                          </co-input-text>\r\n                          <co-button\r\n                                  class=\"save-button\"\r\n                                  [disabled]=\"!isDirectSellEnabled()\"\r\n                                  [iconData]=\"iconCacheService.getIcon(icons.TruckMovingRegular)\"\r\n                                  (click)=\"cashOnDeliveryModalVisible = true\">\r\n                          </co-button>\r\n                      </div>\r\n                      <div></div>\r\n                  </div>\r\n\r\n                  <div\r\n                          class=\"transaction-header-popup-two-column-grid\"\r\n                          [screenConfigurationObject]=\"cfgNames.PaymentBtn\"\r\n                          screenConfigNativeElement>\r\n                      <co-transaction-header-payment-button\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [label]=\"('DELIVERY_TOTAL' | localize) | append:' / ' | append:('TO_SETTLE' | localize:false)\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-payment-button>\r\n                  </div>\r\n              </div>\r\n\r\n              <div *ngIf=\"paymentAnalysis\" class=\"transaction-header-popup-section\">\r\n                  <div class=\"transaction-header-popup-section-label\" [textContent]=\"'TO_INVOICE' | localize\"></div>\r\n                  <div class=\"still-top-pay-stats\">\r\n                      <div class=\"payment-item\">\r\n                          <label [textContent]=\"'TO_BE_INVOICED' | localize\"></label>\r\n                          <div class=\"amount\">{{ paymentAnalysis?.totalToInvoice | coCurrency:true }}</div>\r\n                      </div>\r\n                      <div class=\"payment-item\">\r\n                          <label [textContent]=\"'ALREADY_INVOICED' | localize\"></label>\r\n                          <div class=\"amount\">{{ paymentAnalysis?.totalDepositInvoice | coCurrency:true }}</div>\r\n                      </div>\r\n                      <div class=\"payment-item\">\r\n                          <label [textContent]=\"'STILL_TO_PAY' | localize\"></label>\r\n                          <div class=\"amount\" [class.outstanding]=\"paymentAnalysis?.totalToPay > 0\">\r\n                              <strong>{{ paymentAnalysis?.totalToPay | coCurrency:true }}</strong>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n              </div>\r\n\r\n              <div *ngIf=\"orderPaymentAnalysis.length > 0\" class=\"payment-information\">\r\n                  <co-button\r\n                          class=\"save-button payment-button\"\r\n                          *ngIf=\"showPaymentButton()\"\r\n                          [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegular)\"\r\n                          (click)=\"openPayment($event)\">\r\n                  </co-button>\r\n\r\n                  <div class=\"payment-categories\">\r\n                      <div\r\n                              class=\"payment-category\"\r\n                              [class.selected]=\"activeCategory.index === category.index\"\r\n                              *ngFor=\"let category of paymentCategories\"\r\n                              (click)=\"handleCategoryClick(category)\">\r\n                          <div class=\"title\" [textContent]=\"category.title | localize\"></div>\r\n                      </div>\r\n                  </div>\r\n\r\n                  <table *ngIf=\"activeCategory.index === 0\">\r\n                      <thead>\r\n                      <tr>\r\n                          <th class=\"left\" *ngIf=\"showInvoiceSelection()\" [textContent]=\"'PAY' | localize\"></th>\r\n                          <th class=\"left\" [textContent]=\"'DESCRIPTION' | localize\"></th>\r\n                          <th [textContent]=\"'AMOUNT2' | localize\"></th>\r\n                          <th [textContent]=\"'PAID' | localize\"></th>\r\n                          <th [textContent]=\"'SETTLED' | localize\"></th>\r\n                          <th [textContent]=\"'OUTSTANDING' | localize\"></th>\r\n                      </tr>\r\n                      </thead>\r\n                      <tbody>\r\n                      <tr *ngFor=\"let paymentInfo of orderPaymentAnalysis\">\r\n                          <td class=\"left\" *ngIf=\"showInvoiceSelection()\">\r\n                              <co-input-radio-button\r\n                                      *ngIf=\"paymentInfo.transactionKind === transKind.SalesInvoice && paymentInfo.outstandingAmount > 0\"\r\n                                      class=\"default-width\"\r\n                                      [(model)]=\"paymentInfo.isSelected\"\r\n                                      (modelChange)=\"handleSelectInvoiceLines(paymentInfo)\">\r\n                              </co-input-radio-button>\r\n                          </td>\r\n                          <td class=\"left\">\r\n                              <span\r\n                                      *ngIf=\"paymentInfo.transactionKind === transKind.SalesOrder\"\r\n                                      [textContent]=\"'DEPOSIT' | localize\">\r\n                              </span>\r\n                              <span *ngIf=\"paymentInfo.transactionKind === transKind.SalesInvoice\">\r\n                                <span [textContent]=\"'INVOICE' | localize\"></span>\r\n                                <span> {{ paymentInfo.transactionNumber }}</span>\r\n                                <span> {{ paymentInfo.transactionDate | date:'dd-MM-yyyy' }}</span>\r\n                              </span>\r\n                          </td>\r\n                          <td><strong>{{ paymentInfo.invoiceAmount | coCurrency:true }}</strong></td>\r\n                          <td [class.paid]=\"paymentInfo.paidAmount > 0\">\r\n                              <strong>{{ paymentInfo.paidAmount | coCurrency:true }}</strong>\r\n                          </td>\r\n                          <td>{{ paymentInfo.settledAmount | coCurrency:true }}</td>\r\n                          <td [class.outstanding]=\"paymentInfo.outstandingAmount > 0\">\r\n                              <strong>{{ paymentInfo.outstandingAmount | coCurrency:true }}</strong>\r\n                          </td>\r\n                      </tr>\r\n                      </tbody>\r\n                  </table>\r\n\r\n                  <div *ngIf=\"activeCategory.index === 1\">\r\n                      <p\r\n                              *ngIf=\"registeredPaymentInfo && registeredPaymentInfo.payments.length === 0\"\r\n                              [textContent]=\"'NOT_FOUND' | localize\">\r\n                      </p>\r\n\r\n                      <table *ngIf=\"registeredPaymentInfo && registeredPaymentInfo.payments.length > 0\">\r\n                          <thead>\r\n                          <tr>\r\n                              <th class=\"left\" [textContent]=\"'DESCRIPTION' | localize\"></th>\r\n                              <th [textContent]=\"'AMOUNT2' | localize\"></th>\r\n                              <th [textContent]=\"'DATE' | localize\"></th>\r\n                          </tr>\r\n                          </thead>\r\n                          <tbody>\r\n                          <tr *ngFor=\"let paymentInfo of registeredPaymentInfo.payments\">\r\n                              <td class=\"left\">{{ paymentInfo.reference }}</td>\r\n                              <td><strong>{{ paymentInfo.amount | coCurrency:true }}</strong></td>\r\n                              <td>{{ paymentInfo.paymentDateTime | date:'dd-MM-yyyy' }}</td>\r\n                          </tr>\r\n                          </tbody>\r\n                      </table>\r\n                  </div>\r\n              </div>\r\n          </co-form>\r\n\r\n          <co-cash-on-delivery-modal\r\n                  *ngIf=\"cashOnDeliveryModalVisible\"\r\n                  [transactionInfoUuid]=\"transactionInfo.uuid\"\r\n                  (cashAmount)=\"getCashAmount($event)\"\r\n                  (showCashOnDeliveryModal)=\"showCashOnDeliveryModal($event)\">\r\n          </co-cash-on-delivery-modal>\r\n      </div>\r\n\r\n      <co-dialog\r\n              class=\"payment-dialog\"\r\n              [modal]=\"true\"\r\n              [headerTemplate]=\"headerTemplate\"\r\n              *ngIf=\"showPaymentDialog\"\r\n              (closeClick)=\"handleCloseDialog()\">\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]=\"transactionIdToPay\"\r\n                  [branch]=\"transactionInfo.branch?.relationNr\"\r\n                  [transactionUuid]=\"transactionInfo.uuid\"\r\n                  [amount]=\"chosenAmountToPay\"\r\n                  [remainingPayment]=\"true\"\r\n                  [currencyId]=\"transactionInfo.currencyId\"\r\n                  [doNotFetchAmountToPayForRemaining]=\"true\"\r\n                  [showPaymentDate]=\"true\"\r\n          ></co-payment>\r\n      </co-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderPopupPaymentComponent extends TransactionHeaderPopupBaseComponent implements OnInit, OnDestroy {\r\n  @HostBinding('class.co-transaction-header-popup-payment')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public currencyPipe: typeof CoCurrencyPipe = CoCurrencyPipe;\r\n  public paidDown: number = 0;\r\n  public settled: number = 0;\r\n  public cashOnDelivery: number = 0;\r\n  public showBusinessRuleInfo: boolean = false;\r\n  public showPayDownLabel: boolean = false;\r\n  public cashOnDeliveryModalVisible: boolean = false;\r\n  public showCashOnDelivery: boolean = false;\r\n  public showPaymentDialog: boolean = false;\r\n  // public outstandingCustomerAmount: OutstandingAmountCustomer[] = [];\r\n  public orderPaymentAnalysis: OrderPaymentAnalysis[] = [];\r\n  public paymentAnalysis: PaymentAnalysis;\r\n  public paymentCategories: PaymentCategory[] = [\r\n    {index: 0, title: 'PAYMENT_ANALYSIS'},\r\n    {index: 1, title: 'PAYMENTS_MADE'}\r\n  ];\r\n  public activeCategory: PaymentCategory = this.paymentCategories[0];\r\n  public chosenAmountToPay: number;\r\n  public transactionIdToPay: number;\r\n  public registeredPaymentInfo: TransactionRegisteredPaymentInfo;\r\n\r\n  private _paymentSubs: Subscription[] = [];\r\n\r\n  constructor(\r\n    public transactionHeaderService: TransactionHeaderService,\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    protected dialogService: TransactionDialogService,\r\n    protected formMasterService: FormMasterService,\r\n    protected relationService: TransactionRelationService,\r\n    private _paymentConnectorService: TransactionPaymentConnectorService\r\n  ) {\r\n    super(transactionHeaderService, transactionEventService, service, iconCacheService, transactionScreenConfigurationService, dictionaryService, imageService, changeDetector, dialogService, formMasterService, relationService);\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    await super.ngOnInit();\r\n    this._paymentSubs.push(\r\n      this.transactionEventService.transactionPaymentDone.subscribe(() => {\r\n        this._getDepositInfo();\r\n        this._getOutstandingAmounts();\r\n      }),\r\n      this.screenConfigService.configSet.subscribe((configObjects: ObjectConfiguration[]) => this._getObjectConfiguration(configObjects))\r\n    );\r\n    this.showCashOnDelivery = await this.transactionService.getInternalParameter(InternalParam.SellDirectlyFromSuppl);\r\n  }\r\n\r\n  async ngOnDestroy(): Promise<void> {\r\n    this._paymentSubs.forEach(s => s.unsubscribe());\r\n    await super.ngOnDestroy();\r\n  }\r\n\r\n  public handleCategoryClick(cat: PaymentCategory): void {\r\n    this.activeCategory = cat;\r\n\r\n    if (this.activeCategory.index === 1) {\r\n      this._getRegisteredPaymentInfo();\r\n    }\r\n  }\r\n\r\n  public async showOutstandingAmounts() {\r\n    await this.service.saveTransaction();\r\n  }\r\n\r\n  public showCashOnDeliveryModal(value: boolean): void {\r\n    this.cashOnDeliveryModalVisible = value;\r\n  }\r\n\r\n  public getCashAmount(value: number): void {\r\n    this.cashOnDelivery = value;\r\n  }\r\n\r\n  public showPaymentButton(): boolean {\r\n    return this.orderPaymentAnalysis.some(t => t.outstandingAmount > 0) && this.chosenAmountToPay > 0;\r\n  }\r\n\r\n  public async openPayment(event: MouseEvent): Promise<void> {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.transactionIdToPay = this.transactionIdToPay ?? this.transactionInfo.id;\r\n    if (this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0).length === 1) {\r\n      const lastTransaction = this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0)[0];\r\n      this.transactionIdToPay = lastTransaction.transactionId;\r\n    }\r\n    if (await this.lockTransaction()) {\r\n      this.showPaymentDialog = true;\r\n    }\r\n  }\r\n\r\n  public handleCloseDialog(): void {\r\n    this.showPaymentDialog = false;\r\n    this.transactionService.rollback();\r\n  }\r\n\r\n  public isDirectSellEnabled(): boolean {\r\n    return this.transactionLines.some(line => line.directSell && line.dropShipment);\r\n  }\r\n\r\n  public showInvoiceSelection(): boolean {\r\n    return this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0).length > 1;\r\n  }\r\n\r\n  public handleSelectInvoiceLines(paymentInfo: OrderPaymentAnalysis): void {\r\n    this.orderPaymentAnalysis.forEach(invoice => (invoice as any).isSelected = false);\r\n    (paymentInfo as any).isSelected = true;\r\n    this.chosenAmountToPay = paymentInfo.outstandingAmount;\r\n    this.transactionIdToPay = paymentInfo.transactionId;\r\n  }\r\n\r\n  protected transactionSet() {\r\n    super.transactionSet();\r\n    this._getDepositInfo();\r\n    this._getOutstandingAmounts();\r\n  }\r\n\r\n  private _getDepositInfo(): void {\r\n    this._paymentConnectorService.getDepositPaymentInfo(this.transactionInfo.uuid).then((info: TransactionDepositPaymentInfo) => {\r\n      if (info) {\r\n        this.paidDown = info.depositPaymentAmountTotal;\r\n        this.settled = info.depositAmountSettled;\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getOutstandingAmounts(): void {\r\n    // keeping this for now, could be that we need to use this call after all\r\n    // const outstandingAmountsRequest: OutstandingAmountFilterCustomer = new OutstandingAmountFilterCustomer();\r\n    // outstandingAmountsRequest.transactionId = this.transactionInfo.id;\r\n    // this._paymentConnectorService.getOutstandingCustomerAmounts(outstandingAmountsRequest).then((response: OutstandingAmountCustomer[]) => {\r\n    //   this.outstandingCustomerAmount = response;\r\n    // });\r\n\r\n    const paymentAnalysisRequest: OrderPaymentAnalysisFilter = new OrderPaymentAnalysisFilter();\r\n    paymentAnalysisRequest.transactionId = this.transactionInfo.id;\r\n    this._paymentConnectorService.getSalesOrderPaymentAnalysis(paymentAnalysisRequest).then((response: OrderPaymentAnalysis[]) => {\r\n      this.orderPaymentAnalysis = response;\r\n      this.orderPaymentAnalysis = this.orderPaymentAnalysis.map(transaction => ({\r\n        ...transaction,\r\n        isSelected: false\r\n      })) as unknown as OrderPaymentAnalysis[];\r\n    });\r\n\r\n    this._paymentConnectorService.getPaymentAnalysis(this.transactionInfo.uuid).then((response: PaymentAnalysis) => {\r\n      this.paymentAnalysis = response;\r\n      this.chosenAmountToPay = this.paymentAnalysis.totalToPay;\r\n      this._updateChosenAmountToPay();\r\n    });\r\n  }\r\n\r\n  private async _getRegisteredPaymentInfo(): Promise<void> {\r\n    const paymentInfo: TransactionRegisteredPaymentInfo = await this._paymentConnectorService.getRegisteredPaymentInfo(this.transactionInfo.uuid);\r\n    if (paymentInfo) {\r\n      this.registeredPaymentInfo = paymentInfo;\r\n    }\r\n  }\r\n\r\n  private _getObjectConfiguration(configObjects: ObjectConfiguration[]): void {\r\n    if (configObjects && configObjects.length > 0) {\r\n      this.showPayDownLabel = this.screenConfigService.getObjectConfigurationFor(this.cfgNames.DepositPercentage).immediatelyVisible() ||\r\n        this.screenConfigService.getObjectConfigurationFor(this.cfgNames.DepositAmount).immediatelyVisible();\r\n    }\r\n  }\r\n\r\n  private _updateChosenAmountToPay(): void {\r\n    if (this.orderPaymentAnalysis.some(t => t.outstandingAmount > 0) &&\r\n      this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice).length === 0) {\r\n      this.chosenAmountToPay = this.paymentAnalysis.totalDeposit;\r\n    }\r\n\r\n    if (this.orderPaymentAnalysis.filter(payment => (payment.transactionKind === this.transKind.SalesInvoice) && (payment.outstandingAmount > 0)).length === 1) {\r\n      const remainingInvoice = this.orderPaymentAnalysis.filter(payment => (payment.transactionKind === this.transKind.SalesInvoice) && (payment.outstandingAmount > 0))[0];\r\n      this.chosenAmountToPay = remainingInvoice.outstandingAmount;\r\n    }\r\n\r\n    if (this.orderPaymentAnalysis.filter(payment => (payment.transactionKind === this.transKind.SalesInvoice) && (payment.outstandingAmount > 0)).length > 1) {\r\n      this.chosenAmountToPay = 0;\r\n    }\r\n  }\r\n}\r\n"]}
445
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-header-popup-payment.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-payment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, HostBinding, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionHeaderPopupBaseComponent} from './transaction-header-popup-base.component';\r\nimport {TransactionDepositPaymentInfo} from '@colijnit/transactionapi/build/model/transaction-deposit-payment-info.bo';\r\nimport {PaymentAnalysis} from '@colijnit/transactionapi/build/model/payment-analysis.bo';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionScreenConfigurationService} from '../../../service/transaction-screen-configuration.service';\r\nimport {DictionaryService} from '../../../service/dictionary.service';\r\nimport {TransactionImageService} from '../../../service/transaction-image.service';\r\nimport {TransactionDialogService} from '../../../service/transaction-dialog.service';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {TransactionRelationService} from '../../../service/transaction-relation.service';\r\nimport {TransactionPaymentConnectorService} from '../../../service/transaction-payment-connector.service';\r\nimport {InternalParam} from '@colijnit/mainapi/build/enum/internal-param.enum';\r\nimport {TransactionHeaderService} from '../../core/base/service/transaction-header.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\r\nimport {CoCurrencyPipe} from '../../../pipe/co-currency.pipe';\r\nimport {OrderPaymentAnalysis} from '@colijnit/transactionapi/build/model/order-payment-analysis.bo';\r\nimport {OrderPaymentAnalysisFilter} from '@colijnit/transactionapi/build/model/order-payment-analysis-filter.bo';\r\nimport {TransactionRegisteredPaymentInfo} from '@colijnit/transactionapi/build/model/transaction-registered-payment-info.bo';\r\n\r\nexport interface PaymentCategory {\r\n  index: number;\r\n  title: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'co-transaction-header-popup-payment',\r\n  template: `\r\n      <div class=\"transaction-header-popup-category-wrapper co-small-scrollbar\">\r\n          <co-form>\r\n              <div class=\"transaction-header-popup-section\">\r\n                  <div\r\n                          class=\"transaction-header-popup-section-label\"\r\n                          *ngIf=\"showPayDownLabel\"\r\n                          [textContent]=\"'TO_PAY_DOWN' | localize\">\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-two-column-grid\">\r\n                      <co-transaction-header-deposit-percentage\r\n                              [screenConfigurationObject]=\"cfgNames.DepositPercentage\"\r\n                              [lockAndSave]=\"true\"\r\n                              (depositUpdated)=\"showOutstandingAmounts()\">\r\n                      </co-transaction-header-deposit-percentage>\r\n                      <co-transaction-header-deposit-amount class=\"transaction-line-totals-price price\"\r\n                                                            [screenConfigurationObject]=\"cfgNames.DepositAmount\"\r\n                                                            [lockAndSave]=\"true\"\r\n                                                            (businessRuleApplied)=\"showBusinessRuleInfo = $event\">\r\n                      </co-transaction-header-deposit-amount>\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-three-column-grid\">\r\n                      <co-transaction-header-use-deposit-rule\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [screenConfigurationObject]=\"cfgNames.UseDepositRule\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-use-deposit-rule>\r\n                      <co-transaction-header-auto-recalculate-deposit\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [screenConfigurationObject]=\"cfgNames.AutoRecalculateDeposit\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-auto-recalculate-deposit>\r\n                      <co-transaction-header-divide-evenly\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [screenConfigurationObject]=\"cfgNames.DivideEvenly\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-divide-evenly>\r\n                      <div class=\"transaction-header-popup-business-rule-applied\" *ngIf=\"showBusinessRuleInfo\">\r\n                          <co-icon [iconData]=\"iconCacheService.getIcon(icons.CircleExclamationRegular)\"></co-icon>\r\n                          <span [textContent]=\"'DEPOSIT_BUSINESS_RULE_APPLIED' | localize\"></span>\r\n                      </div>\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-two-column-grid\">\r\n                      <co-transaction-header-amount-to-settle\r\n                              [screenConfigurationObject]=\"cfgNames.AmountToSettle\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-amount-to-settle>\r\n                      <div class=\"transaction-header-popup-already-paid\">\r\n                          <co-input-text\r\n                                  [screenConfigurationObject]=\"cfgNames.TotalPaidDown\"\r\n                                  [placeholder]=\"'TOTAL_PAID_DOWN' | localize\" [forceReadonly]=\"true\"\r\n                                  [model]=\"paidDown\" [formatPipe]=\"currencyPipe\">\r\n                          </co-input-text>\r\n                          <co-input-text\r\n                                  [screenConfigurationObject]=\"cfgNames.SettledSoFar\"\r\n                                  [placeholder]=\"'SETTLED_SO_FAR' | localize\" [forceReadonly]=\"true\"\r\n                                  [model]=\"settled\" [formatPipe]=\"currencyPipe\">\r\n                          </co-input-text>\r\n                      </div>\r\n                  </div>\r\n\r\n                  <div class=\"transaction-header-popup-two-column-grid\" *ngIf=\"showCashOnDelivery\">\r\n                      <div class=\"cash-on-delivery-row\">\r\n                          <co-input-text\r\n                                  [placeholder]=\"'CASH_ON_DELIVERY' | localize\"\r\n                                  [forceReadonly]=\"true\"\r\n                                  [(model)]=\"cashOnDelivery\"\r\n                                  [formatPipe]=\"currencyPipe\">\r\n                          </co-input-text>\r\n                          <co-button\r\n                                  class=\"save-button\"\r\n                                  [disabled]=\"!isDirectSellEnabled()\"\r\n                                  [iconData]=\"iconCacheService.getIcon(icons.TruckMovingRegular)\"\r\n                                  (click)=\"cashOnDeliveryModalVisible = true\">\r\n                          </co-button>\r\n                      </div>\r\n                      <div></div>\r\n                  </div>\r\n\r\n                  <div\r\n                          class=\"transaction-header-popup-two-column-grid\"\r\n                          [screenConfigurationObject]=\"cfgNames.PaymentBtn\"\r\n                          screenConfigNativeElement>\r\n                      <co-transaction-header-payment-button\r\n                              *ngIf=\"transactionInfo.transactionKind !== transKind.PurchaseOrder\"\r\n                              [label]=\"('DELIVERY_TOTAL' | localize) | append:' / ' | append:('TO_SETTLE' | localize:false)\"\r\n                              [lockAndSave]=\"false\">\r\n                      </co-transaction-header-payment-button>\r\n                  </div>\r\n              </div>\r\n\r\n              <div *ngIf=\"paymentAnalysis\" class=\"transaction-header-popup-section\">\r\n                  <div class=\"transaction-header-popup-section-label\" [textContent]=\"'TO_INVOICE' | localize\"></div>\r\n                  <div class=\"still-top-pay-stats\">\r\n                      <div class=\"payment-item\">\r\n                          <label [textContent]=\"'TO_BE_INVOICED' | localize\"></label>\r\n                          <div class=\"amount\">{{ paymentAnalysis?.totalToInvoice | coCurrency:true }}</div>\r\n                      </div>\r\n                      <div class=\"payment-item\">\r\n                          <label [textContent]=\"'ALREADY_INVOICED' | localize\"></label>\r\n                          <div class=\"amount\">{{ paymentAnalysis?.totalDepositInvoice | coCurrency:true }}</div>\r\n                      </div>\r\n                      <div class=\"payment-item\">\r\n                          <label [textContent]=\"'STILL_TO_PAY' | localize\"></label>\r\n                          <div class=\"amount\" [class.outstanding]=\"paymentAnalysis?.totalToPay > 0\">\r\n                              <strong>{{ paymentAnalysis?.totalToPay | coCurrency:true }}</strong>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n              </div>\r\n\r\n              <div *ngIf=\"orderPaymentAnalysis.length > 0\" class=\"payment-information\">\r\n                  <co-button\r\n                          class=\"save-button payment-button\"\r\n                          *ngIf=\"showPaymentButton()\"\r\n                          [iconData]=\"iconCacheService.getIcon(icons.CreditCardRegular)\"\r\n                          (click)=\"openPayment($event)\">\r\n                  </co-button>\r\n\r\n                  <div class=\"payment-categories\">\r\n                      <div\r\n                              class=\"payment-category\"\r\n                              [class.selected]=\"activeCategory.index === category.index\"\r\n                              *ngFor=\"let category of paymentCategories\"\r\n                              (click)=\"handleCategoryClick(category)\">\r\n                          <div class=\"title\" [textContent]=\"category.title | localize\"></div>\r\n                      </div>\r\n                  </div>\r\n\r\n                  <table *ngIf=\"activeCategory.index === 0\">\r\n                      <thead>\r\n                      <tr>\r\n                          <th class=\"left\" *ngIf=\"showInvoiceSelection()\" [textContent]=\"'PAY' | localize\"></th>\r\n                          <th class=\"left\" [textContent]=\"'DESCRIPTION' | localize\"></th>\r\n                          <th [textContent]=\"'AMOUNT2' | localize\"></th>\r\n                          <th [textContent]=\"'PAID' | localize\"></th>\r\n                          <th [textContent]=\"'SETTLED' | localize\"></th>\r\n                          <th [textContent]=\"'OUTSTANDING' | localize\"></th>\r\n                      </tr>\r\n                      </thead>\r\n                      <tbody>\r\n                      <tr *ngFor=\"let paymentInfo of orderPaymentAnalysis\">\r\n                          <td class=\"left\" *ngIf=\"showInvoiceSelection()\">\r\n                              <co-input-radio-button\r\n                                      *ngIf=\"paymentInfo.transactionKind === transKind.SalesInvoice && paymentInfo.outstandingAmount > 0\"\r\n                                      class=\"default-width\"\r\n                                      [(model)]=\"paymentInfo.isSelected\"\r\n                                      (modelChange)=\"handleSelectInvoiceLines(paymentInfo)\">\r\n                              </co-input-radio-button>\r\n                          </td>\r\n                          <td class=\"left\">\r\n                              <span\r\n                                      *ngIf=\"paymentInfo.transactionKind === transKind.SalesOrder\"\r\n                                      [textContent]=\"'DEPOSIT' | localize\">\r\n                              </span>\r\n                              <span *ngIf=\"paymentInfo.transactionKind === transKind.SalesInvoice\">\r\n                                <span [textContent]=\"'INVOICE' | localize\"></span>\r\n                                <span> {{ paymentInfo.transactionNumber }}</span>\r\n                                <span> {{ paymentInfo.transactionDate | date:'dd-MM-yyyy' }}</span>\r\n                              </span>\r\n                          </td>\r\n                          <td><strong>{{ paymentInfo.invoiceAmount | coCurrency:true }}</strong></td>\r\n                          <td [class.paid]=\"paymentInfo.paidAmount > 0\">\r\n                              <strong>{{ paymentInfo.paidAmount | coCurrency:true }}</strong>\r\n                          </td>\r\n                          <td>{{ paymentInfo.settledAmount | coCurrency:true }}</td>\r\n                          <td [class.outstanding]=\"paymentInfo.outstandingAmount > 0\">\r\n                              <strong>{{ paymentInfo.outstandingAmount | coCurrency:true }}</strong>\r\n                          </td>\r\n                      </tr>\r\n                      </tbody>\r\n                  </table>\r\n\r\n                  <div *ngIf=\"activeCategory.index === 1\">\r\n                      <p\r\n                              *ngIf=\"registeredPaymentInfo && registeredPaymentInfo.payments.length === 0\"\r\n                              [textContent]=\"'NOT_FOUND' | localize\">\r\n                      </p>\r\n\r\n                      <table *ngIf=\"registeredPaymentInfo && registeredPaymentInfo.payments.length > 0\">\r\n                          <thead>\r\n                          <tr>\r\n                              <th class=\"left\" [textContent]=\"'DESCRIPTION' | localize\"></th>\r\n                              <th [textContent]=\"'AMOUNT2' | localize\"></th>\r\n                              <th [textContent]=\"'DATE' | localize\"></th>\r\n                          </tr>\r\n                          </thead>\r\n                          <tbody>\r\n                          <tr *ngFor=\"let paymentInfo of registeredPaymentInfo.payments\">\r\n                              <td class=\"left\">{{ paymentInfo.reference }}</td>\r\n                              <td><strong>{{ paymentInfo.amount | coCurrency:true }}</strong></td>\r\n                              <td>{{ paymentInfo.paymentDateTime | date:'dd-MM-yyyy' }}</td>\r\n                          </tr>\r\n                          </tbody>\r\n                      </table>\r\n                  </div>\r\n              </div>\r\n          </co-form>\r\n\r\n          <co-cash-on-delivery-modal\r\n                  *ngIf=\"cashOnDeliveryModalVisible\"\r\n                  [transactionInfoUuid]=\"transactionInfo.uuid\"\r\n                  (cashAmount)=\"getCashAmount($event)\"\r\n                  (showCashOnDeliveryModal)=\"showCashOnDeliveryModal($event)\">\r\n          </co-cash-on-delivery-modal>\r\n      </div>\r\n\r\n      <co-dialog\r\n              class=\"payment-dialog\"\r\n              *ngIf=\"showPaymentDialog\"\r\n              [modal]=\"true\"\r\n              [headerTemplate]=\"headerTemplate\"\r\n              (closeClick)=\"handleCloseDialog()\">\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]=\"transactionIdToPay\"\r\n                  [branch]=\"transactionInfo.branch?.relationNr\"\r\n                  [transactionUuid]=\"transactionInfo.uuid\"\r\n                  [amount]=\"chosenAmountToPay\"\r\n                  [remainingPayment]=\"true\"\r\n                  [currencyId]=\"transactionInfo.currencyId\"\r\n                  [doNotFetchAmountToPayForRemaining]=\"true\"\r\n                  [showPaymentDate]=\"true\">\r\n          </co-payment>\r\n      </co-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionHeaderPopupPaymentComponent extends TransactionHeaderPopupBaseComponent implements OnInit, OnDestroy {\r\n  @HostBinding('class.co-transaction-header-popup-payment')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public currencyPipe: typeof CoCurrencyPipe = CoCurrencyPipe;\r\n  public paidDown: number = 0;\r\n  public settled: number = 0;\r\n  public cashOnDelivery: number = 0;\r\n  public showBusinessRuleInfo: boolean = false;\r\n  public showPayDownLabel: boolean = false;\r\n  public cashOnDeliveryModalVisible: boolean = false;\r\n  public showCashOnDelivery: boolean = false;\r\n  public showPaymentDialog: boolean = false;\r\n  // public outstandingCustomerAmount: OutstandingAmountCustomer[] = [];\r\n  public orderPaymentAnalysis: OrderPaymentAnalysis[] = [];\r\n  public paymentAnalysis: PaymentAnalysis;\r\n  public paymentCategories: PaymentCategory[] = [\r\n    {index: 0, title: 'PAYMENT_ANALYSIS'},\r\n    {index: 1, title: 'PAYMENTS_MADE'}\r\n  ];\r\n  public activeCategory: PaymentCategory = this.paymentCategories[0];\r\n  public chosenAmountToPay: number;\r\n  public transactionIdToPay: number;\r\n  public registeredPaymentInfo: TransactionRegisteredPaymentInfo;\r\n\r\n  private _paymentSubs: Subscription[] = [];\r\n\r\n  constructor(\r\n    public transactionHeaderService: TransactionHeaderService,\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    protected dialogService: TransactionDialogService,\r\n    protected formMasterService: FormMasterService,\r\n    protected relationService: TransactionRelationService,\r\n    private _paymentConnectorService: TransactionPaymentConnectorService\r\n  ) {\r\n    super(transactionHeaderService, transactionEventService, service, iconCacheService, transactionScreenConfigurationService, dictionaryService, imageService, changeDetector, dialogService, formMasterService, relationService);\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    await super.ngOnInit();\r\n    this._paymentSubs.push(\r\n      this.transactionEventService.transactionPaymentDone.subscribe(() => {\r\n        this._getDepositInfo();\r\n        this._getOutstandingAmounts();\r\n        this.handleCloseDialog();\r\n      }),\r\n      this.screenConfigService.configSet.subscribe((configObjects: ObjectConfiguration[]) => this._getObjectConfiguration(configObjects))\r\n    );\r\n    this.showCashOnDelivery = await this.transactionService.getInternalParameter(InternalParam.SellDirectlyFromSuppl);\r\n  }\r\n\r\n  async ngOnDestroy(): Promise<void> {\r\n    this._paymentSubs.forEach(s => s.unsubscribe());\r\n    await super.ngOnDestroy();\r\n  }\r\n\r\n  public handleCategoryClick(cat: PaymentCategory): void {\r\n    this.activeCategory = cat;\r\n\r\n    if (this.activeCategory.index === 1) {\r\n      this._getRegisteredPaymentInfo();\r\n    }\r\n  }\r\n\r\n  public async showOutstandingAmounts() {\r\n    await this.service.saveTransaction();\r\n  }\r\n\r\n  public showCashOnDeliveryModal(value: boolean): void {\r\n    this.cashOnDeliveryModalVisible = value;\r\n  }\r\n\r\n  public getCashAmount(value: number): void {\r\n    this.cashOnDelivery = value;\r\n  }\r\n\r\n  public showPaymentButton(): boolean {\r\n    return this.orderPaymentAnalysis.some(t => t.outstandingAmount !== 0) && this.chosenAmountToPay !== 0;\r\n  }\r\n\r\n  public async openPayment(event: MouseEvent): Promise<void> {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.transactionIdToPay = this.transactionIdToPay ?? this.transactionInfo.id;\r\n    if (this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0).length === 1) {\r\n      const lastTransaction = this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0)[0];\r\n      this.transactionIdToPay = lastTransaction.transactionId;\r\n    }\r\n    if (await this.lockTransaction()) {\r\n      this.showPaymentDialog = true;\r\n    }\r\n  }\r\n\r\n  public handleCloseDialog(): void {\r\n    this.showPaymentDialog = false;\r\n    this.transactionService.rollback();\r\n  }\r\n\r\n  public isDirectSellEnabled(): boolean {\r\n    return this.transactionLines.some(line => line.directSell && line.dropShipment);\r\n  }\r\n\r\n  public showInvoiceSelection(): boolean {\r\n    return this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0).length > 1;\r\n  }\r\n\r\n  public handleSelectInvoiceLines(paymentInfo: OrderPaymentAnalysis): void {\r\n    this.orderPaymentAnalysis.forEach(invoice => (invoice as any).isSelected = false);\r\n    (paymentInfo as any).isSelected = true;\r\n    this.chosenAmountToPay = paymentInfo.outstandingAmount;\r\n    this.transactionIdToPay = paymentInfo.transactionId;\r\n  }\r\n\r\n  protected transactionSet() {\r\n    super.transactionSet();\r\n    this._getDepositInfo();\r\n    this._getOutstandingAmounts();\r\n  }\r\n\r\n  private _getDepositInfo(): void {\r\n    this._paymentConnectorService.getDepositPaymentInfo(this.transactionInfo.uuid).then((info: TransactionDepositPaymentInfo) => {\r\n      if (info) {\r\n        this.paidDown = info.depositPaymentAmountTotal;\r\n        this.settled = info.depositAmountSettled;\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getOutstandingAmounts(): void {\r\n    // keeping this for now, could be that we need to use this call after all\r\n    // const outstandingAmountsRequest: OutstandingAmountFilterCustomer = new OutstandingAmountFilterCustomer();\r\n    // outstandingAmountsRequest.transactionId = this.transactionInfo.id;\r\n    // this._paymentConnectorService.getOutstandingCustomerAmounts(outstandingAmountsRequest).then((response: OutstandingAmountCustomer[]) => {\r\n    //   this.outstandingCustomerAmount = response;\r\n    // });\r\n\r\n    const paymentAnalysisRequest: OrderPaymentAnalysisFilter = new OrderPaymentAnalysisFilter();\r\n    paymentAnalysisRequest.transactionId = this.transactionInfo.id;\r\n    this._paymentConnectorService.getSalesOrderPaymentAnalysis(paymentAnalysisRequest).then((response: OrderPaymentAnalysis[]) => {\r\n      this.orderPaymentAnalysis = response;\r\n      this.orderPaymentAnalysis = this.orderPaymentAnalysis.map(transaction => ({\r\n        ...transaction,\r\n        isSelected: false\r\n      })) as unknown as OrderPaymentAnalysis[];\r\n    });\r\n\r\n    this._paymentConnectorService.getPaymentAnalysis(this.transactionInfo.uuid).then((response: PaymentAnalysis) => {\r\n      this.paymentAnalysis = response;\r\n      this.chosenAmountToPay = this.paymentAnalysis.totalToPay;\r\n      this._updateChosenAmountToPay();\r\n    });\r\n  }\r\n\r\n  private async _getRegisteredPaymentInfo(): Promise<void> {\r\n    const paymentInfo: TransactionRegisteredPaymentInfo = await this._paymentConnectorService.getRegisteredPaymentInfo(this.transactionInfo.uuid);\r\n    if (paymentInfo) {\r\n      this.registeredPaymentInfo = paymentInfo;\r\n    }\r\n  }\r\n\r\n  private _getObjectConfiguration(configObjects: ObjectConfiguration[]): void {\r\n    if (configObjects && configObjects.length > 0) {\r\n      this.showPayDownLabel = this.screenConfigService.getObjectConfigurationFor(this.cfgNames.DepositPercentage).immediatelyVisible() ||\r\n        this.screenConfigService.getObjectConfigurationFor(this.cfgNames.DepositAmount).immediatelyVisible();\r\n    }\r\n  }\r\n\r\n  private _updateChosenAmountToPay(): void {\r\n    if (this.orderPaymentAnalysis.some(t => t.outstandingAmount > 0) &&\r\n      this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice).length === 0) {\r\n      this.chosenAmountToPay = this.paymentAnalysis.totalDeposit;\r\n    }\r\n\r\n    if (this.orderPaymentAnalysis.filter(payment => (payment.transactionKind === this.transKind.SalesInvoice) && (payment.outstandingAmount > 0)).length === 1) {\r\n      const remainingInvoice = this.orderPaymentAnalysis.filter(payment => (payment.transactionKind === this.transKind.SalesInvoice) && (payment.outstandingAmount > 0))[0];\r\n      this.chosenAmountToPay = remainingInvoice.outstandingAmount;\r\n    }\r\n\r\n    if (this.orderPaymentAnalysis.filter(payment => (payment.transactionKind === this.transKind.SalesInvoice) && (payment.outstandingAmount > 0)).length > 1) {\r\n      this.chosenAmountToPay = 0;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -75,34 +75,39 @@ export class TransactionLineDropShipmentButtonComponent extends TransactionLineB
75
75
  }
76
76
  TransactionLineDropShipmentButtonComponent.decorators = [
77
77
  { type: Component, args: [{
78
- selector: "co-transaction-line-drop-shipment-button",
78
+ selector: 'co-transaction-line-drop-shipment-button',
79
79
  template: `
80
- <div class="inside-field">
81
- <co-transaction-line-label *ngIf="transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment && inputLabel"
82
- [insideLabel]="'DROPSHIPMENT'"></co-transaction-line-label>
83
- <co-transaction-button *ngIf="transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment"
84
- [hidden]="hidden"
85
- [readonly]="readonly"
86
- [label]="'DROPSHIPMENT' | localize"
87
- (click)="handleToggleDropShipment($event)"
88
- ></co-transaction-button>
89
- <co-transaction-button *ngIf="!transactionService.internalParameterAllowsDropShipment || !supplierAllowsDropShipment"
90
- class="disabled-button"
91
- [hidden]="hidden"
92
- [readonly]="readonly"
93
- [label]="'DROPSHIPMENT_NO' | localize"
94
- ></co-transaction-button>
95
- </div>
96
- <co-dialog-transaction-line-warehouse *ngIf="showDialogWarehouse && !readonly"
97
- [autoClose]="true"
98
- (close)="showDialogWarehouse = false"
99
- ></co-dialog-transaction-line-warehouse>
80
+ <div class="inside-field">
81
+ <co-transaction-line-label
82
+ *ngIf="transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment && inputLabel"
83
+ [insideLabel]="'DROPSHIPMENT'">
84
+ </co-transaction-line-label>
85
+ <co-transaction-button
86
+ *ngIf="transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment"
87
+ [hidden]="hidden"
88
+ [readonly]="readonly"
89
+ [label]="'DROPSHIPMENT' | localize"
90
+ (click)="handleToggleDropShipment($event)">
91
+ </co-transaction-button>
92
+ <co-transaction-button
93
+ *ngIf="!transactionService.internalParameterAllowsDropShipment || !supplierAllowsDropShipment"
94
+ class="disabled-button"
95
+ [hidden]="hidden"
96
+ [readonly]="readonly"
97
+ [label]="'DROPSHIPMENT_NO' | localize">
98
+ </co-transaction-button>
99
+ </div>
100
+
101
+ <co-dialog-transaction-line-warehouse
102
+ *ngIf="showDialogWarehouse && !readonly"
103
+ [autoClose]="true"
104
+ (close)="showDialogWarehouse = false">
105
+ </co-dialog-transaction-line-warehouse>
100
106
  `,
101
107
  providers: [{
102
108
  provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
103
109
  useExisting: forwardRef(() => TransactionLineDropShipmentButtonComponent)
104
- }
105
- ],
110
+ }],
106
111
  encapsulation: ViewEncapsulation.None
107
112
  },] }
108
113
  ];
@@ -121,6 +126,6 @@ TransactionLineDropShipmentButtonComponent.ctorParameters = () => [
121
126
  TransactionLineDropShipmentButtonComponent.propDecorators = {
122
127
  showLabel: [{ type: Input }],
123
128
  inputLabel: [{ type: Input }],
124
- showClass: [{ type: HostBinding, args: ["class.co-transaction-line-drop-shipment-button",] }]
129
+ showClass: [{ type: HostBinding, args: ['class.co-transaction-line-drop-shipment-button',] }]
125
130
  };
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-drop-shipment-button.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-fields/transaction-line-drop-shipment-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, forwardRef, HostBinding, Input, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {TransactionRelationService} from '../../service/transaction-relation.service';\r\nimport {DictionaryService} from '../../service/dictionary.service';\r\nimport {TransactionImageService} from '../../service/transaction-image.service';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {TransactionEventService} from '../../service/transaction-event.service';\r\nimport {TransactionScreenConfigurationService} from '../../service/transaction-screen-configuration.service';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {SupplierLightObject} from '@colijnit/relationapi/build/model/supplier-light-object.bo';\r\nimport {TransactionLineBaseComponent} from '../core/base/transaction-line-base.component';\r\nimport {TransactionHeaderService} from '../core/base/service/transaction-header.service';\r\nimport {TransactionLineService} from '../core/base/service/transaction-line.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-drop-shipment-button\",\r\n  template: `\r\n    <div class=\"inside-field\">\r\n      <co-transaction-line-label *ngIf=\"transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment && inputLabel\"\r\n                                 [insideLabel]=\"'DROPSHIPMENT'\"></co-transaction-line-label>\r\n      <co-transaction-button *ngIf=\"transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment\"\r\n                             [hidden]=\"hidden\"\r\n                             [readonly]=\"readonly\"\r\n                             [label]=\"'DROPSHIPMENT' | localize\"\r\n                             (click)=\"handleToggleDropShipment($event)\"\r\n      ></co-transaction-button>\r\n      <co-transaction-button *ngIf=\"!transactionService.internalParameterAllowsDropShipment || !supplierAllowsDropShipment\"\r\n                             class=\"disabled-button\"\r\n                             [hidden]=\"hidden\"\r\n                             [readonly]=\"readonly\"\r\n                             [label]=\"'DROPSHIPMENT_NO' | localize\"\r\n      ></co-transaction-button>\r\n    </div>\r\n    <co-dialog-transaction-line-warehouse *ngIf=\"showDialogWarehouse && !readonly\"\r\n                                          [autoClose]=\"true\"\r\n                                          (close)=\"showDialogWarehouse = false\"\r\n    ></co-dialog-transaction-line-warehouse>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionLineDropShipmentButtonComponent)}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineDropShipmentButtonComponent extends TransactionLineBaseComponent {\r\n\r\n  public supplierAllowsDropShipment: boolean;\r\n  public buttonDisabled: boolean = false;\r\n  public showDialogWarehouse: boolean = false;\r\n\r\n  @Input()\r\n  public showLabel: boolean = false;\r\n\r\n  @Input()\r\n  public inputLabel: boolean = false;\r\n\r\n  @HostBinding(\"class.co-transaction-line-drop-shipment-button\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    public transactionHeaderService: TransactionHeaderService,\r\n    public transactionLineService: TransactionLineService,\r\n    public transactionEventService: TransactionEventService,\r\n    public transactionService: 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 _relationService: TransactionRelationService\r\n  ) {\r\n    super(transactionHeaderService, transactionLineService, transactionEventService, iconCacheService, transactionScreenConfigurationService, imageService, dictionaryService, transactionService, changeDetector);\r\n  }\r\n\r\n  public async handleToggleDropShipment(event: MouseEvent): Promise<void> {\r\n    if (!this.buttonDisabled) {\r\n      this.buttonDisabled = true;\r\n      this.transactionService.tryToLockTransaction(this.transactionInfo.id, this.transactionInfo.version)\r\n        .then(async (locked) => {\r\n          if (locked) {\r\n            const oldDropShipmentValue: boolean = this.transactionLine.dropShipment;\r\n            const success = await this.transactionService.updateDropShipmentTransactionLine(\r\n              this.transactionService.currentTransaction.transactionInfo.uuid, this.transactionLine.uuid, !oldDropShipmentValue);\r\n            if (!success) {\r\n              this.transactionLine.dropShipment = oldDropShipmentValue;\r\n            } else {\r\n              this.showDialogWarehouse = true;\r\n            }\r\n          }\r\n        })\r\n        .finally(() => {\r\n          this.buttonDisabled = false;\r\n          this.detectChanges();\r\n        });\r\n    }\r\n  }\r\n\r\n  protected transactionLineSet(): void {\r\n    super.transactionLineSet();\r\n    this._getSupplierAllowsDropShipmentParameter();\r\n  }\r\n\r\n  protected visibilitySet(): void {\r\n    super.visibilitySet();\r\n    this._getSupplierAllowsDropShipmentParameter();\r\n  }\r\n\r\n  private _getSupplierAllowsDropShipmentParameter(): void {\r\n    if (this.transactionLine && this.visible && this.supplierAllowsDropShipment === undefined) {\r\n      this._relationService.getSupplierLightById(this.transactionLine.supplierId).then((supplier: SupplierLightObject) => {\r\n        this.supplierAllowsDropShipment = supplier.dropShipment;\r\n        this.detectChanges();\r\n      })\r\n    }\r\n  }\r\n}\r\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-drop-shipment-button.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-fields/transaction-line-drop-shipment-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, forwardRef, HostBinding, Input, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {TransactionRelationService} from '../../service/transaction-relation.service';\r\nimport {DictionaryService} from '../../service/dictionary.service';\r\nimport {TransactionImageService} from '../../service/transaction-image.service';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {TransactionEventService} from '../../service/transaction-event.service';\r\nimport {TransactionScreenConfigurationService} from '../../service/transaction-screen-configuration.service';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {SupplierLightObject} from '@colijnit/relationapi/build/model/supplier-light-object.bo';\r\nimport {TransactionLineBaseComponent} from '../core/base/transaction-line-base.component';\r\nimport {TransactionHeaderService} from '../core/base/service/transaction-header.service';\r\nimport {TransactionLineService} from '../core/base/service/transaction-line.service';\r\n\r\n@Component({\r\n  selector: 'co-transaction-line-drop-shipment-button',\r\n  template: `\r\n      <div class=\"inside-field\">\r\n          <co-transaction-line-label\r\n                  *ngIf=\"transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment && inputLabel\"\r\n                  [insideLabel]=\"'DROPSHIPMENT'\">\r\n          </co-transaction-line-label>\r\n          <co-transaction-button\r\n                  *ngIf=\"transactionService.internalParameterAllowsDropShipment && supplierAllowsDropShipment\"\r\n                  [hidden]=\"hidden\"\r\n                  [readonly]=\"readonly\"\r\n                  [label]=\"'DROPSHIPMENT' | localize\"\r\n                  (click)=\"handleToggleDropShipment($event)\">\r\n          </co-transaction-button>\r\n          <co-transaction-button\r\n                  *ngIf=\"!transactionService.internalParameterAllowsDropShipment || !supplierAllowsDropShipment\"\r\n                  class=\"disabled-button\"\r\n                  [hidden]=\"hidden\"\r\n                  [readonly]=\"readonly\"\r\n                  [label]=\"'DROPSHIPMENT_NO' | localize\">\r\n          </co-transaction-button>\r\n      </div>\r\n\r\n      <co-dialog-transaction-line-warehouse\r\n              *ngIf=\"showDialogWarehouse && !readonly\"\r\n              [autoClose]=\"true\"\r\n              (close)=\"showDialogWarehouse = false\">\r\n      </co-dialog-transaction-line-warehouse>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => TransactionLineDropShipmentButtonComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineDropShipmentButtonComponent extends TransactionLineBaseComponent {\r\n\r\n  public supplierAllowsDropShipment: boolean;\r\n  public buttonDisabled: boolean = false;\r\n  public showDialogWarehouse: boolean = false;\r\n\r\n  @Input()\r\n  public showLabel: boolean = false;\r\n\r\n  @Input()\r\n  public inputLabel: boolean = false;\r\n\r\n  @HostBinding('class.co-transaction-line-drop-shipment-button')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    public transactionHeaderService: TransactionHeaderService,\r\n    public transactionLineService: TransactionLineService,\r\n    public transactionEventService: TransactionEventService,\r\n    public transactionService: 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 _relationService: TransactionRelationService\r\n  ) {\r\n    super(transactionHeaderService, transactionLineService, transactionEventService, iconCacheService, transactionScreenConfigurationService, imageService, dictionaryService, transactionService, changeDetector);\r\n  }\r\n\r\n  public async handleToggleDropShipment(event: MouseEvent): Promise<void> {\r\n    if (!this.buttonDisabled) {\r\n      this.buttonDisabled = true;\r\n      this.transactionService.tryToLockTransaction(this.transactionInfo.id, this.transactionInfo.version)\r\n        .then(async (locked: boolean) => {\r\n          if (locked) {\r\n            const oldDropShipmentValue: boolean = this.transactionLine.dropShipment;\r\n            const success: boolean = await this.transactionService.updateDropShipmentTransactionLine(\r\n              this.transactionService.currentTransaction.transactionInfo.uuid,\r\n              this.transactionLine.uuid,\r\n              !oldDropShipmentValue\r\n            );\r\n\r\n            if (!success) {\r\n              this.transactionLine.dropShipment = oldDropShipmentValue;\r\n            } else {\r\n              this.showDialogWarehouse = true;\r\n            }\r\n          }\r\n        })\r\n        .finally(() => {\r\n          this.buttonDisabled = false;\r\n          this.detectChanges();\r\n        });\r\n    }\r\n  }\r\n\r\n  protected transactionLineSet(): void {\r\n    super.transactionLineSet();\r\n    this._getSupplierAllowsDropShipmentParameter();\r\n  }\r\n\r\n  protected visibilitySet(): void {\r\n    super.visibilitySet();\r\n    this._getSupplierAllowsDropShipmentParameter();\r\n  }\r\n\r\n  private _getSupplierAllowsDropShipmentParameter(): void {\r\n    if (this.transactionLine && this.visible && this.supplierAllowsDropShipment === undefined) {\r\n      this._relationService.getSupplierLightById(this.transactionLine.supplierId).then((supplier: SupplierLightObject) => {\r\n        this.supplierAllowsDropShipment = supplier.dropShipment;\r\n        this.detectChanges();\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
@@ -67,7 +67,7 @@ export class TransactionLineSidePanelArticleDetailsComponent {
67
67
  }
68
68
  _getAlternateSuppliers() {
69
69
  this.alternateSuppliers = [];
70
- if (!this.suppliers || this.suppliers.length === 0) {
70
+ if (!this.suppliers || this.suppliers.length === 0 || !this.purchaseAdviceLine) {
71
71
  return;
72
72
  }
73
73
  this.selectedSupplierId = this.purchaseAdviceLine.supplierId;
@@ -330,4 +330,4 @@ TransactionLineSidePanelArticleDetailsComponent.propDecorators = {
330
330
  closeSideBarClicked: [{ type: Output }],
331
331
  showClass: [{ type: HostBinding, args: ["class.co-transaction-line-side-panel-article-details",] }]
332
332
  };
333
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-side-panel-article-details.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-side-panel-article-details/transaction-line-side-panel-article-details.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from '@angular/core';\r\nimport {PurchaseAdviceLine} from '@colijnit/transactionapi/build/model/purchase-advice-line.bo';\r\nimport {Warehouse} from '@colijnit/transactionapi/build/model/warehouse.bo';\r\nimport {RelationListObject} from '@colijnit/relationapi/build/model/relation-list-object.bo';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {AlternateSupplierViewmodel} from '../../model/alternate-supplier.viewmodel';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-side-panel-article-details\",\r\n  template: `\r\n    <div class=\"transaction-line-side-panel-article-details-wrapper\">\r\n      <co-icon (click)=\"handleCancelClick()\" [iconData]=\"iconCacheService.getIcon(icons.Crossskinny)\"\r\n               class=\"side-panel close-button\"></co-icon>\r\n      <div class=\"transaction-line-side-panel-header\">\r\n        <co-icon [iconData]=\"iconCacheService.getIcon(icons.ShelvesOpen)\"></co-icon>\r\n        <span [textContent]=\"'ORDER_ADVICE' | localize\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-article-details-header\">\r\n        <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'ARTICLE_NR'| localize\"></span>\r\n          <span class=\"side-panel-header-field\" [textContent]=\"purchaseAdviceLine.articleNo\"></span>\r\n        </div>\r\n        <div class=\"side-panel-header-divider\"></div>\r\n        <div class=\"transaction-line-side-panel-article-details-header-item max-width-40\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'DESCRIPTION'| localize\"></span>\r\n          <span class=\"side-panel-header-field\" [textContent]=\"purchaseAdviceLine.purchaseDescription\"></span>\r\n        </div>\r\n        <div class=\"side-panel-header-divider\"></div>\r\n        <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'AMOUNT2'| localize\"></span>\r\n          <span class=\"side-panel-header-field\"\r\n                [textContent]=\"purchaseAdviceLine.orderAmount ? purchaseAdviceLine.orderAmount : '-'\"></span>\r\n        </div>\r\n        <div class=\"side-panel-header-divider\"></div>\r\n        <div class=\"transaction-line-side-panel-article-details-header-item last-item-margin\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'PRICE' | localize\"></span>\r\n          <span class=\"side-panel-header-field\"\r\n                [textContent]=\"purchaseAdviceLine.purchasePrice ? (purchaseAdviceLine.purchasePrice | priceDisplay) : '-'\"></span>\r\n        </div>\r\n\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-content co-small-scrollbar\">\r\n        <div class=\"default-details-wrapper form-and-buttons\">\r\n          <div class=\"section-wrapper\">\r\n            <span class=\"section-title\" [textContent]=\"'STOCK_PARAMETERS' | localize\"></span>\r\n            <div class=\"purchase-advice-detail-header\">\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'ECONOMIC'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.econStock ? purchaseAdviceLine.econStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'TARGET2'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.targetStock ? purchaseAdviceLine.targetStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'DYNAMIC_MINIMAL'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.minDynamicStock ? purchaseAdviceLine.minDynamicStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'MINIMAL'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.minStock ? purchaseAdviceLine.minStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'MAX'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.maxStock ? purchaseAdviceLine.maxStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'DIRECTLY_AVAILABLE'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.readilyAvailable ? purchaseAdviceLine.readilyAvailable : '-'\"></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <div class=\"detail-column-container\">\r\n              <div class=\"detail-column\">\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'SALES_DESCRIPTION' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.salesDescription ? purchaseAdviceLine.salesDescription : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'TURNOVER_GROUP' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.turnOverGroupNo ? purchaseAdviceLine.turnOverGroupNo : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'EXCEEDANCE_CODE' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.exceedanceCode ? purchaseAdviceLine.exceedanceCode : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n              <div class=\"detail-column\">\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'ORDER_CODE' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.orderCode ? purchaseAdviceLine.orderCode : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'NAME' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.articleName ? purchaseAdviceLine.articleName : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <span class=\"section-title\" [textContent]=\"'ORDER_INFORMATION' | localize\"></span>\r\n            <div class=\"purchase-advice-detail-header\">\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'SALES_QUANTITY'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.amountSales ? purchaseAdviceLine.amountSales : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'PURCHASE_QUANTITY'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.amountPurchase ? purchaseAdviceLine.amountPurchase : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'ORDER_AMOUNT'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"$any(purchaseAdviceLine).displayOrderAmount ? $any(purchaseAdviceLine).displayOrderAmount : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'VELOCITY'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.velocityMonth ? purchaseAdviceLine.velocityMonth : '-'\"></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <div class=\"detail-column-container\">\r\n              <div class=\"detail-column\">\r\n                <div class=\"column-input-item\">\r\n                  <co-input-number-picker\r\n                    [label]=\"'AMOUNT' | localize\"\r\n                    [(model)]=\"purchaseAdviceLine.amountPurchaseList\"\r\n                    (modelChange)=\"handleModelChange($event)\"\r\n                    [min]=\"1\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                  ></co-input-number-picker>\r\n                </div>\r\n<!--\r\n                <div class=\"column-input-item\">\r\n                    <co-list-of-values class=\"details-input\"\r\n                                       [(model)]=\"purchaseAdviceLine.warehouseNo\"\r\n                                       [collection]=\"warehouses\"\r\n                                       [displayField]=\"'description'\"\r\n                                       [label]=\"'WAREHOUSE' | localize\"\r\n                    ></co-list-of-values>\r\n                </div>\r\n-->\r\n              </div>\r\n              <div class=\"detail-column\">\r\n                <div class=\"column-input-item\">\r\n                  <co-input-text\r\n                    [placeholder]=\"'PURCHASE_PRICE' | localize\"\r\n                    [type]=\"'number'\"\r\n                    [(model)]=\"purchaseAdviceLine.purchasePrice\"\r\n                    [min]=\"0\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                    (modelChange)=\"handleCostChange()\"\r\n                  ></co-input-text>\r\n                </div>\r\n                <div class=\"column-input-item\">\r\n                  <co-input-text\r\n                    [placeholder]=\"'TRANSPORT_PRICE' | localize\"\r\n                    [type]=\"'number'\"\r\n                    [(model)]=\"purchaseAdviceLine.shippingCost\"\r\n                    [min]=\"0\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                    [readonly]=\"true\"\r\n                    (modelChange)=\"handleCostChange()\"\r\n                  ></co-input-text>\r\n                </div>\r\n                <div class=\"column-input-item\">\r\n                  <co-input-text\r\n                    [placeholder]=\"'MANUFACTURING_PRICE' | localize\"\r\n                    [type]=\"'number'\"\r\n                    [(model)]=\"calculatedAssemblyCost\"\r\n                    [min]=\"0\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                    [readonly]=\"true\"\r\n                    (modelChange)=\"handleAssemblyCostChange()\"\r\n                  ></co-input-text>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <span class=\"section-title\" [textContent]=\"'ALTERNATIVE_SUPPLIERS' | localize\"></span>\r\n            <div class=\"detail-column-container\">\r\n              <div class=\"detail-column\">\r\n                <div class=\"dynamic-suppliers-wrapper\">\r\n                  <co-alternate-supplier-tile  *ngFor=\"let supplier of alternateSuppliers\" (supplierClicked)=\"handleSelectSupplier($event)\"\r\n                  [supplier]=\"supplier\" [selectedSupplierId]=\"selectedSupplierId\" [goodId]=\"purchaseAdviceLine?.goodId\"></co-alternate-supplier-tile>\r\n                </div>\r\n              </div>\r\n              <div class=\"detail-column\">\r\n                <co-list-of-values class=\"supplier-list\"\r\n                                   [label]=\"'SUPPLIER' | localize\"\r\n                                   [required]=\"true\"\r\n                                   [noClickFocus]=\"true\"\r\n                                   [searchPlaceholder]=\"'SEARCH' | localize\"\r\n                                   [collection]=\"suppliers\"\r\n                                   [displayField]=\"'familyName'\"\r\n                                   [(model)]=\"selectedSupplier\"\r\n                                   (modelChange)=\"handleSupplierChanged($event)\"\r\n                ></co-list-of-values>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineSidePanelArticleDetailsComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  set suppliers(value: RelationListObject[]) {\r\n    this._suppliers = value;\r\n    this._getAlternateSuppliers();\r\n  };\r\n\r\n  get suppliers(): RelationListObject[] {\r\n    return this._suppliers;\r\n  }\r\n\r\n  //not currently in use....\r\n  @Input()\r\n  public warehouses: Warehouse[];\r\n\r\n  @Input()\r\n  public set purchaseAdviceLine(value: PurchaseAdviceLine) {\r\n    this._purchaseAdviceLine = value;\r\n    this.handleCostChange();\r\n    this._getAlternateSuppliers();\r\n  }\r\n\r\n  public get purchaseAdviceLine(): PurchaseAdviceLine {\r\n    return this._purchaseAdviceLine;\r\n  }\r\n\r\n  @Input()\r\n  public onlySupplierAvailable: Boolean = false;\r\n\r\n  @Output()\r\n  public purchaseAdviceLineChange: EventEmitter<PurchaseAdviceLine> = new EventEmitter<PurchaseAdviceLine>();\r\n\r\n  @Output()\r\n  public closeSideBarClicked: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  public supplierDropdownFields: {} = {text: \"familyName\", value: \"relationId\"};\r\n\r\n  public warehouseDropDownFields: { text, value } = {text: \"description\", value: \"warehouseNo\"};\r\n  public selectedSupplierId: number;\r\n  public selectedSupplier: RelationListObject;\r\n\r\n  public calculatedAssemblyCost: number;\r\n  public alternateSuppliers: AlternateSupplierViewmodel[] = [];\r\n\r\n  private _purchaseAdviceLine: PurchaseAdviceLine;\r\n  private _suppliers: RelationListObject[] = [];\r\n\r\n  @HostBinding(\"class.co-transaction-line-side-panel-article-details\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService\r\n  ) {\r\n  }\r\n\r\n  public handleCancelClick(): void {\r\n    this.closeSideBarClicked.next();\r\n  }\r\n\r\n  // Velden aanpassen of object vervangen met getPurchaseLine(goodId)?\r\n  public handleSupplierChanged(supplier: RelationListObject | number): void {\r\n    if (typeof supplier === 'number') {\r\n      this.selectedSupplier = this.suppliers.find(s => s.relationId === supplier);\r\n    }\r\n    this.purchaseAdviceLine.supplierId =  this.selectedSupplier.relationId;\r\n    this.purchaseAdviceLine.supplierNo = + this.selectedSupplier.relationNr;\r\n    this.purchaseAdviceLine.supplierName =  this.selectedSupplier.familyName;\r\n    this.handleModelChange();\r\n  }\r\n\r\n  public handleCostChange(): void {\r\n    if (this.purchaseAdviceLine.purchasePrice && this.purchaseAdviceLine.shippingCost) {\r\n      this.calculatedAssemblyCost = +(+this.purchaseAdviceLine.purchasePrice - +this.purchaseAdviceLine.shippingCost).toFixed(2);\r\n    }\r\n    this.handleModelChange();\r\n  }\r\n\r\n  public handleAssemblyCostChange(): void {\r\n    if (this.calculatedAssemblyCost && this.purchaseAdviceLine.shippingCost) {\r\n      this.purchaseAdviceLine.purchasePrice = +(+this.calculatedAssemblyCost + +this.purchaseAdviceLine.shippingCost).toFixed(2);\r\n      this.handleModelChange();\r\n    }\r\n  }\r\n\r\n  public handleSelectSupplier(supplier: AlternateSupplierViewmodel): void {\r\n    this.selectedSupplierId = supplier.supplierProduct.relationIdSupplier;\r\n    this.handleSupplierChanged(supplier.supplierProduct.relationIdSupplier);\r\n  }\r\n\r\n  public handleModelChange(model?: any): void {\r\n    this.purchaseAdviceLineChange.next(this.purchaseAdviceLine);\r\n  }\r\n\r\n  private _getAlternateSuppliers(): void {\r\n    this.alternateSuppliers = [];\r\n    if (!this.suppliers || this.suppliers.length === 0) {\r\n      return;\r\n    }\r\n    this.selectedSupplierId = this.purchaseAdviceLine.supplierId;\r\n    this.selectedSupplier = this.suppliers.find(s => s.relationId === this.selectedSupplierId);\r\n    this.purchaseAdviceLine.supplierProduct.forEach((supplier) => {\r\n      const alternateSupplier: AlternateSupplierViewmodel = new AlternateSupplierViewmodel();\r\n      alternateSupplier.supplierProduct = supplier;\r\n      alternateSupplier.relationName = this.suppliers.find((s) => s.relationId === supplier.relationIdSupplier)?.familyName;\r\n      this.alternateSuppliers.push(alternateSupplier);\r\n    });\r\n  }\r\n}\r\n"]}
333
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-side-panel-article-details.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-side-panel-article-details/transaction-line-side-panel-article-details.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from '@angular/core';\r\nimport {PurchaseAdviceLine} from '@colijnit/transactionapi/build/model/purchase-advice-line.bo';\r\nimport {Warehouse} from '@colijnit/transactionapi/build/model/warehouse.bo';\r\nimport {RelationListObject} from '@colijnit/relationapi/build/model/relation-list-object.bo';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {AlternateSupplierViewmodel} from '../../model/alternate-supplier.viewmodel';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-side-panel-article-details\",\r\n  template: `\r\n    <div class=\"transaction-line-side-panel-article-details-wrapper\">\r\n      <co-icon (click)=\"handleCancelClick()\" [iconData]=\"iconCacheService.getIcon(icons.Crossskinny)\"\r\n               class=\"side-panel close-button\"></co-icon>\r\n      <div class=\"transaction-line-side-panel-header\">\r\n        <co-icon [iconData]=\"iconCacheService.getIcon(icons.ShelvesOpen)\"></co-icon>\r\n        <span [textContent]=\"'ORDER_ADVICE' | localize\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-article-details-header\">\r\n        <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'ARTICLE_NR'| localize\"></span>\r\n          <span class=\"side-panel-header-field\" [textContent]=\"purchaseAdviceLine.articleNo\"></span>\r\n        </div>\r\n        <div class=\"side-panel-header-divider\"></div>\r\n        <div class=\"transaction-line-side-panel-article-details-header-item max-width-40\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'DESCRIPTION'| localize\"></span>\r\n          <span class=\"side-panel-header-field\" [textContent]=\"purchaseAdviceLine.purchaseDescription\"></span>\r\n        </div>\r\n        <div class=\"side-panel-header-divider\"></div>\r\n        <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'AMOUNT2'| localize\"></span>\r\n          <span class=\"side-panel-header-field\"\r\n                [textContent]=\"purchaseAdviceLine.orderAmount ? purchaseAdviceLine.orderAmount : '-'\"></span>\r\n        </div>\r\n        <div class=\"side-panel-header-divider\"></div>\r\n        <div class=\"transaction-line-side-panel-article-details-header-item last-item-margin\">\r\n          <span class=\"side-panel-header-label\" [textContent]=\"'PRICE' | localize\"></span>\r\n          <span class=\"side-panel-header-field\"\r\n                [textContent]=\"purchaseAdviceLine.purchasePrice ? (purchaseAdviceLine.purchasePrice | priceDisplay) : '-'\"></span>\r\n        </div>\r\n\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-content co-small-scrollbar\">\r\n        <div class=\"default-details-wrapper form-and-buttons\">\r\n          <div class=\"section-wrapper\">\r\n            <span class=\"section-title\" [textContent]=\"'STOCK_PARAMETERS' | localize\"></span>\r\n            <div class=\"purchase-advice-detail-header\">\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'ECONOMIC'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.econStock ? purchaseAdviceLine.econStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'TARGET2'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.targetStock ? purchaseAdviceLine.targetStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'DYNAMIC_MINIMAL'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.minDynamicStock ? purchaseAdviceLine.minDynamicStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'MINIMAL'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.minStock ? purchaseAdviceLine.minStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'MAX'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.maxStock ? purchaseAdviceLine.maxStock : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'DIRECTLY_AVAILABLE'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.readilyAvailable ? purchaseAdviceLine.readilyAvailable : '-'\"></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <div class=\"detail-column-container\">\r\n              <div class=\"detail-column\">\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'SALES_DESCRIPTION' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.salesDescription ? purchaseAdviceLine.salesDescription : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'TURNOVER_GROUP' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.turnOverGroupNo ? purchaseAdviceLine.turnOverGroupNo : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'EXCEEDANCE_CODE' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.exceedanceCode ? purchaseAdviceLine.exceedanceCode : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n              <div class=\"detail-column\">\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'ORDER_CODE' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.orderCode ? purchaseAdviceLine.orderCode : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"transaction-line-side-panel-article-details-header-item\">\r\n                  <div class=\"detail-column-item\">\r\n                    <span class=\"side-panel-header-label\" [textContent]=\"'NAME' | localize\"></span>\r\n                    <span class=\"side-panel-header-field\"\r\n                          [textContent]=\"purchaseAdviceLine.articleName ? purchaseAdviceLine.articleName : '-'\"></span>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <span class=\"section-title\" [textContent]=\"'ORDER_INFORMATION' | localize\"></span>\r\n            <div class=\"purchase-advice-detail-header\">\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'SALES_QUANTITY'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.amountSales ? purchaseAdviceLine.amountSales : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'PURCHASE_QUANTITY'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.amountPurchase ? purchaseAdviceLine.amountPurchase : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'ORDER_AMOUNT'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"$any(purchaseAdviceLine).displayOrderAmount ? $any(purchaseAdviceLine).displayOrderAmount : '-'\"></span>\r\n              </div>\r\n              <div class=\"side-panel-header-divider\"></div>\r\n              <div class=\"transaction-line-side-panel-article-details-header-item center\">\r\n                <span class=\"side-panel-header-label\" [textContent]=\"'VELOCITY'| localize\"></span>\r\n                <span class=\"side-panel-header-field bold\"\r\n                      [textContent]=\"purchaseAdviceLine.velocityMonth ? purchaseAdviceLine.velocityMonth : '-'\"></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <div class=\"detail-column-container\">\r\n              <div class=\"detail-column\">\r\n                <div class=\"column-input-item\">\r\n                  <co-input-number-picker\r\n                    [label]=\"'AMOUNT' | localize\"\r\n                    [(model)]=\"purchaseAdviceLine.amountPurchaseList\"\r\n                    (modelChange)=\"handleModelChange($event)\"\r\n                    [min]=\"1\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                  ></co-input-number-picker>\r\n                </div>\r\n<!--\r\n                <div class=\"column-input-item\">\r\n                    <co-list-of-values class=\"details-input\"\r\n                                       [(model)]=\"purchaseAdviceLine.warehouseNo\"\r\n                                       [collection]=\"warehouses\"\r\n                                       [displayField]=\"'description'\"\r\n                                       [label]=\"'WAREHOUSE' | localize\"\r\n                    ></co-list-of-values>\r\n                </div>\r\n-->\r\n              </div>\r\n              <div class=\"detail-column\">\r\n                <div class=\"column-input-item\">\r\n                  <co-input-text\r\n                    [placeholder]=\"'PURCHASE_PRICE' | localize\"\r\n                    [type]=\"'number'\"\r\n                    [(model)]=\"purchaseAdviceLine.purchasePrice\"\r\n                    [min]=\"0\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                    (modelChange)=\"handleCostChange()\"\r\n                  ></co-input-text>\r\n                </div>\r\n                <div class=\"column-input-item\">\r\n                  <co-input-text\r\n                    [placeholder]=\"'TRANSPORT_PRICE' | localize\"\r\n                    [type]=\"'number'\"\r\n                    [(model)]=\"purchaseAdviceLine.shippingCost\"\r\n                    [min]=\"0\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                    [readonly]=\"true\"\r\n                    (modelChange)=\"handleCostChange()\"\r\n                  ></co-input-text>\r\n                </div>\r\n                <div class=\"column-input-item\">\r\n                  <co-input-text\r\n                    [placeholder]=\"'MANUFACTURING_PRICE' | localize\"\r\n                    [type]=\"'number'\"\r\n                    [(model)]=\"calculatedAssemblyCost\"\r\n                    [min]=\"0\" [forceReadonly]=\"onlySupplierAvailable\"\r\n                    [readonly]=\"true\"\r\n                    (modelChange)=\"handleAssemblyCostChange()\"\r\n                  ></co-input-text>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"section-wrapper\">\r\n            <span class=\"section-title\" [textContent]=\"'ALTERNATIVE_SUPPLIERS' | localize\"></span>\r\n            <div class=\"detail-column-container\">\r\n              <div class=\"detail-column\">\r\n                <div class=\"dynamic-suppliers-wrapper\">\r\n                  <co-alternate-supplier-tile  *ngFor=\"let supplier of alternateSuppliers\" (supplierClicked)=\"handleSelectSupplier($event)\"\r\n                  [supplier]=\"supplier\" [selectedSupplierId]=\"selectedSupplierId\" [goodId]=\"purchaseAdviceLine?.goodId\"></co-alternate-supplier-tile>\r\n                </div>\r\n              </div>\r\n              <div class=\"detail-column\">\r\n                <co-list-of-values class=\"supplier-list\"\r\n                                   [label]=\"'SUPPLIER' | localize\"\r\n                                   [required]=\"true\"\r\n                                   [noClickFocus]=\"true\"\r\n                                   [searchPlaceholder]=\"'SEARCH' | localize\"\r\n                                   [collection]=\"suppliers\"\r\n                                   [displayField]=\"'familyName'\"\r\n                                   [(model)]=\"selectedSupplier\"\r\n                                   (modelChange)=\"handleSupplierChanged($event)\"\r\n                ></co-list-of-values>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineSidePanelArticleDetailsComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public set suppliers(value: RelationListObject[]) {\r\n    this._suppliers = value;\r\n    this._getAlternateSuppliers();\r\n  };\r\n\r\n  public get suppliers(): RelationListObject[] {\r\n    return this._suppliers;\r\n  }\r\n\r\n  //not currently in use....\r\n  @Input()\r\n  public warehouses: Warehouse[];\r\n\r\n  @Input()\r\n  public set purchaseAdviceLine(value: PurchaseAdviceLine) {\r\n    this._purchaseAdviceLine = value;\r\n    this.handleCostChange();\r\n    this._getAlternateSuppliers();\r\n  }\r\n\r\n  public get purchaseAdviceLine(): PurchaseAdviceLine {\r\n    return this._purchaseAdviceLine;\r\n  }\r\n\r\n  @Input()\r\n  public onlySupplierAvailable: Boolean = false;\r\n\r\n  @Output()\r\n  public purchaseAdviceLineChange: EventEmitter<PurchaseAdviceLine> = new EventEmitter<PurchaseAdviceLine>();\r\n\r\n  @Output()\r\n  public closeSideBarClicked: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  public supplierDropdownFields: {} = {text: \"familyName\", value: \"relationId\"};\r\n\r\n  public warehouseDropDownFields: { text, value } = {text: \"description\", value: \"warehouseNo\"};\r\n  public selectedSupplierId: number;\r\n  public selectedSupplier: RelationListObject;\r\n\r\n  public calculatedAssemblyCost: number;\r\n  public alternateSuppliers: AlternateSupplierViewmodel[] = [];\r\n\r\n  private _purchaseAdviceLine: PurchaseAdviceLine;\r\n  private _suppliers: RelationListObject[] = [];\r\n\r\n  @HostBinding(\"class.co-transaction-line-side-panel-article-details\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService\r\n  ) {\r\n  }\r\n\r\n  public handleCancelClick(): void {\r\n    this.closeSideBarClicked.next();\r\n  }\r\n\r\n  // Velden aanpassen of object vervangen met getPurchaseLine(goodId)?\r\n  public handleSupplierChanged(supplier: RelationListObject | number): void {\r\n    if (typeof supplier === 'number') {\r\n      this.selectedSupplier = this.suppliers.find(s => s.relationId === supplier);\r\n    }\r\n    this.purchaseAdviceLine.supplierId =  this.selectedSupplier.relationId;\r\n    this.purchaseAdviceLine.supplierNo = + this.selectedSupplier.relationNr;\r\n    this.purchaseAdviceLine.supplierName =  this.selectedSupplier.familyName;\r\n    this.handleModelChange();\r\n  }\r\n\r\n  public handleCostChange(): void {\r\n    if (this.purchaseAdviceLine.purchasePrice && this.purchaseAdviceLine.shippingCost) {\r\n      this.calculatedAssemblyCost = +(+this.purchaseAdviceLine.purchasePrice - +this.purchaseAdviceLine.shippingCost).toFixed(2);\r\n    }\r\n    this.handleModelChange();\r\n  }\r\n\r\n  public handleAssemblyCostChange(): void {\r\n    if (this.calculatedAssemblyCost && this.purchaseAdviceLine.shippingCost) {\r\n      this.purchaseAdviceLine.purchasePrice = +(+this.calculatedAssemblyCost + +this.purchaseAdviceLine.shippingCost).toFixed(2);\r\n      this.handleModelChange();\r\n    }\r\n  }\r\n\r\n  public handleSelectSupplier(supplier: AlternateSupplierViewmodel): void {\r\n    this.selectedSupplierId = supplier.supplierProduct.relationIdSupplier;\r\n    this.handleSupplierChanged(supplier.supplierProduct.relationIdSupplier);\r\n  }\r\n\r\n  public handleModelChange(model?: any): void {\r\n    this.purchaseAdviceLineChange.next(this.purchaseAdviceLine);\r\n  }\r\n\r\n  private _getAlternateSuppliers(): void {\r\n    this.alternateSuppliers = [];\r\n    if (!this.suppliers || this.suppliers.length === 0 || !this.purchaseAdviceLine) {\r\n      return;\r\n    }\r\n    this.selectedSupplierId = this.purchaseAdviceLine.supplierId;\r\n    this.selectedSupplier = this.suppliers.find(s => s.relationId === this.selectedSupplierId);\r\n    this.purchaseAdviceLine.supplierProduct.forEach((supplier) => {\r\n      const alternateSupplier: AlternateSupplierViewmodel = new AlternateSupplierViewmodel();\r\n      alternateSupplier.supplierProduct = supplier;\r\n      alternateSupplier.relationName = this.suppliers.find((s) => s.relationId === supplier.relationIdSupplier)?.familyName;\r\n      this.alternateSuppliers.push(alternateSupplier);\r\n    });\r\n  }\r\n}\r\n"]}