@colijnit/transaction 257.1.43 → 257.1.45

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/bundles/colijnit-transaction.umd.js +249 -19
  2. package/bundles/colijnit-transaction.umd.js.map +1 -1
  3. package/colijnit-transaction.metadata.json +1 -1
  4. package/esm2015/lib/component/transaction-card/transaction-card/transaction-card.component.js +32 -4
  5. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-payment.component.js +5 -1
  6. package/esm2015/lib/component/transaction-line/transaction-receive-goods-line/transaction-receive-goods-line.component.js +9 -9
  7. package/esm2015/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.js +1 -2
  8. package/esm2015/lib/component/transaction-lines/transaction-lines.component.js +3 -1
  9. package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-picked/transaction-quick-access-picked.component.js +6 -3
  10. package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-received-goods/transaction-quick-access-received-goods.component.js +29 -44
  11. package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-to-be-picked/transaction-quick-access-to-be-picked.component.js +3 -2
  12. package/esm2015/lib/component/transaction-search/transaction-date-pick-dialog/transaction-date-pick-dialog.component.js +69 -0
  13. package/esm2015/lib/component/transaction-search/transaction-date-pick-dialog/transaction-date-pick-dialog.module.js +29 -0
  14. package/esm2015/lib/component/transaction-search/transaction-search-result/transaction-search-result.component.js +32 -5
  15. package/esm2015/lib/component/transaction-search/transaction-search-result/transaction-search-result.module.js +8 -6
  16. package/esm2015/lib/component/transaction-search/transaction-search.module.js +3 -1
  17. package/esm2015/lib/service/transaction-connector-adapter.service.js +37 -1
  18. package/esm2015/lib/service/transaction-connector.service.js +16 -1
  19. package/esm2015/lib/service/transaction.service.js +16 -1
  20. package/esm2015/lib/transaction-version.js +3 -3
  21. package/esm2015/public_api.js +3 -1
  22. package/fesm2015/colijnit-transaction.js +265 -65
  23. package/fesm2015/colijnit-transaction.js.map +1 -1
  24. package/lib/component/transaction-card/transaction-card/transaction-card.component.d.ts +8 -1
  25. package/lib/component/transaction-quick-access/transaction-quick-access-received-goods/transaction-quick-access-received-goods.component.d.ts +0 -2
  26. package/lib/component/transaction-search/transaction-date-pick-dialog/style/_layout.scss +16 -0
  27. package/lib/component/transaction-search/transaction-date-pick-dialog/style/_material-definition.scss +1 -0
  28. package/lib/component/transaction-search/transaction-date-pick-dialog/style/_theme.scss +6 -0
  29. package/lib/component/transaction-search/transaction-date-pick-dialog/style/material.scss +3 -0
  30. package/lib/component/transaction-search/transaction-date-pick-dialog/transaction-date-pick-dialog.component.d.ts +15 -0
  31. package/lib/component/transaction-search/transaction-date-pick-dialog/transaction-date-pick-dialog.module.d.ts +2 -0
  32. package/lib/component/transaction-search/transaction-search-result/transaction-search-result.component.d.ts +2 -1
  33. package/lib/service/transaction-connector-adapter.service.d.ts +3 -0
  34. package/lib/service/transaction-connector.service.d.ts +3 -0
  35. package/lib/service/transaction.service.d.ts +3 -0
  36. package/package.json +3 -3
  37. package/public_api.d.ts +2 -0
@@ -3,9 +3,13 @@ import { TransactionMappingService } from '../../../service/transaction-mapping.
3
3
  import { TransactionEventService } from '../../../service/transaction-event.service';
4
4
  import { TransactionHeaderService } from '../../core/base/service/transaction-header.service';
5
5
  import { TransactionLineService } from '../../core/base/service/transaction-line.service';
6
+ import { TransactionLineInfo } from '@colijnit/transactionapi/build/model/transaction-line-info.bo';
6
7
  import { TransactionTextLineComponent } from "../../transaction-line/transaction-text-line/transaction-text-line.component";
8
+ import { PurchaseConfirmationService } from '../../../service/purchase-confirmation.service';
9
+ import { LineSelectionService } from '../../../service/line-selection.service';
7
10
  export class TransactionCardComponent {
8
- constructor(_transactionHeaderService, _transactionLineService, _transactionEventService, _changeDetector, _mappingService, _compFactoryResolver, _appRef) {
11
+ constructor(purchaseConfirmationService, _transactionHeaderService, _transactionLineService, _transactionEventService, _changeDetector, _mappingService, _compFactoryResolver, _appRef, _lineSelectionService) {
12
+ this.purchaseConfirmationService = purchaseConfirmationService;
9
13
  this._transactionHeaderService = _transactionHeaderService;
10
14
  this._transactionLineService = _transactionLineService;
11
15
  this._transactionEventService = _transactionEventService;
@@ -13,6 +17,7 @@ export class TransactionCardComponent {
13
17
  this._mappingService = _mappingService;
14
18
  this._compFactoryResolver = _compFactoryResolver;
15
19
  this._appRef = _appRef;
20
+ this._lineSelectionService = _lineSelectionService;
16
21
  this.preview = false;
17
22
  this.selected = false;
18
23
  this.isFirst = false;
@@ -28,6 +33,8 @@ export class TransactionCardComponent {
28
33
  // }
29
34
  // }
30
35
  this.showSidePanel = false;
36
+ this.showSidePanelForConfirmationAI = false;
37
+ this.activeTransactionLine = new TransactionLineInfo();
31
38
  this._subs = [];
32
39
  }
33
40
  set container(content) {
@@ -59,7 +66,20 @@ export class TransactionCardComponent {
59
66
  }
60
67
  ngOnInit() {
61
68
  this._subs.push(this._transactionEventService.openSidePanel.subscribe((line) => {
62
- this.showSidePanel = !!line;
69
+ this.activeTransactionLine = line;
70
+ this.showSidePanel = true;
71
+ this._changeDetector.detectChanges();
72
+ }), this.purchaseConfirmationService.confirmationNeeded.subscribe((needed) => {
73
+ if (needed) {
74
+ this.showSidePanelForConfirmationAI = true;
75
+ this.showSidePanel = true;
76
+ this._checkActiveLine();
77
+ this._changeDetector.detectChanges();
78
+ }
79
+ else {
80
+ this.showSidePanelForConfirmationAI = false;
81
+ this._changeDetector.detectChanges();
82
+ }
63
83
  }));
64
84
  }
65
85
  ngOnDestroy() {
@@ -108,6 +128,12 @@ export class TransactionCardComponent {
108
128
  this._changeDetector.detectChanges();
109
129
  }
110
130
  }
131
+ _checkActiveLine() {
132
+ if (this.showSidePanelForConfirmationAI && this.transactionLine) {
133
+ // this.activeTransactionLine = this.transactionLines[0];
134
+ this._lineSelectionService.selectedTransactionLine = this.transactionLine;
135
+ }
136
+ }
111
137
  }
112
138
  TransactionCardComponent.decorators = [
113
139
  { type: Component, args: [{
@@ -127,13 +153,15 @@ TransactionCardComponent.decorators = [
127
153
  },] }
128
154
  ];
129
155
  TransactionCardComponent.ctorParameters = () => [
156
+ { type: PurchaseConfirmationService },
130
157
  { type: TransactionHeaderService },
131
158
  { type: TransactionLineService },
132
159
  { type: TransactionEventService },
133
160
  { type: ChangeDetectorRef },
134
161
  { type: TransactionMappingService },
135
162
  { type: ComponentFactoryResolver },
136
- { type: ApplicationRef }
163
+ { type: ApplicationRef },
164
+ { type: LineSelectionService }
137
165
  ];
138
166
  TransactionCardComponent.propDecorators = {
139
167
  container: [{ type: ViewChild, args: ['transactionCard', { read: ViewContainerRef },] }],
@@ -148,4 +176,4 @@ TransactionCardComponent.propDecorators = {
148
176
  draggedOver: [{ type: HostBinding, args: ["class.drag-over",] }, { type: Input }],
149
177
  showClass: [{ type: HostBinding, args: ["class.co-transaction-card",] }]
150
178
  };
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-card.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-card/transaction-card/transaction-card.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ApplicationRef,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactory,\r\n  ComponentFactoryResolver,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy, OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  Type,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {TransactionTypeCategory} from '../../../enum/transaction-type-category.enum';\r\nimport {TransactionMappingService} from '../../../service/transaction-mapping.service';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {StatusBarCfgNames} from '../../../interface/status-bar-cfg-names.interface';\r\nimport {TransactionHeaderService} from '../../core/base/service/transaction-header.service';\r\nimport {TransactionLineService} from '../../core/base/service/transaction-line.service';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Subscription} from 'rxjs';\r\nimport {\r\n  TransactionTextLineComponent\r\n} from \"../../transaction-line/transaction-text-line/transaction-text-line.component\";\r\n\r\n@Component({\r\n  selector: \"co-transaction-card\",\r\n  template: `\r\n    <div class=\"transaction-card-outer-wrapper\" #transactionCard></div>\r\n    <co-transaction-line-side-panel *ngIf=\"showSidePanel\" clickOutside\r\n                                    [activeCategory]=\"activeCategory\"\r\n                                    (clickOutside)=\"showSidePanel = false\"\r\n                                    (cancelClick)=\"showSidePanel = false\">\r\n    </co-transaction-line-side-panel>\r\n  `,\r\n  providers: [\r\n    TransactionLineService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionCardComponent implements OnInit, OnChanges, OnDestroy {\r\n  @ViewChild('transactionCard', { read: ViewContainerRef }) set container(content) {\r\n    if (content) {\r\n      this._transactionCardContainer = content;\r\n      this._prepareContent();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set activeCategory(value: TransactionTypeCategory) {\r\n    this._activeCategory = value;\r\n    this._prepareContent();\r\n  }\r\n\r\n  public get activeCategory(): TransactionTypeCategory {\r\n    return this._activeCategory;\r\n  }\r\n\r\n  @Input()\r\n  public transactionLine: TransactionLineInfo;\r\n\r\n  @Input()\r\n  public statusBarConfigNames: StatusBarCfgNames;\r\n\r\n  @Input()\r\n  public preview: boolean = false;\r\n\r\n  @Input()\r\n  public selected: boolean = false;\r\n\r\n  @HostBinding('class.first')\r\n  @Input()\r\n  public isFirst: boolean = false;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Output()\r\n  public waitingForUserAction: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @HostBinding(\"class.drag-over\")\r\n  @Input()\r\n  public draggedOver: boolean = false;\r\n\r\n  @HostBinding(\"class.co-transaction-card\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  // @HostBinding('style.boxShadow')\r\n  // public get boxShadow(): string {\r\n  //   if (this.draggedOver) {\r\n  //     return 'inset 0 0 2px 1px grey';\r\n  //   } else {\r\n  //     return 'none';\r\n  //   }\r\n  // }\r\n\r\n  public showSidePanel: boolean = false;\r\n\r\n  private _transactionCardContainer: ViewContainerRef;\r\n  private _activeCategory: TransactionTypeCategory;\r\n  private _componentRef: any;\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    private _transactionHeaderService: TransactionHeaderService,\r\n    private _transactionLineService: TransactionLineService,\r\n    private _transactionEventService: TransactionEventService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private _mappingService: TransactionMappingService,\r\n    private _compFactoryResolver: ComponentFactoryResolver,\r\n    private _appRef: ApplicationRef\r\n  ) {\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    let shouldPrepareProps: boolean = false;\r\n    for (let key in changes) {\r\n      if (key !== 'draggedOver') {\r\n        shouldPrepareProps = true;\r\n      }\r\n    }\r\n    if (shouldPrepareProps) {\r\n      this._prepareProps();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._subs.push(\r\n      this._transactionEventService.openSidePanel.subscribe((line) => {\r\n        this.showSidePanel = !!line;\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n    if (this._componentRef) {\r\n      this._componentRef.destroy();\r\n      this._componentRef = undefined;\r\n    }\r\n    this._transactionCardContainer = undefined;\r\n  }\r\n\r\n  private _prepareContent(): void {\r\n    if (!this._transactionHeaderService.transactionKind || !this._activeCategory || !this._transactionCardContainer) {\r\n      return;\r\n    }\r\n\r\n    let componentClass: Type<TransactionBaseComponent>;\r\n    if (this.transactionLine.isText) {\r\n      componentClass = TransactionTextLineComponent;\r\n    } else {\r\n      componentClass = this._mappingService.getTransactionCardComponent(this._transactionHeaderService.transactionKind, this._activeCategory);\r\n    }\r\n\r\n\r\n    if (!this._componentRef) {\r\n      const factory: ComponentFactory<TransactionBaseComponent> = this._compFactoryResolver.resolveComponentFactory(componentClass);\r\n      this._transactionCardContainer.clear();\r\n      this._componentRef = this._transactionCardContainer.createComponent(factory);\r\n\r\n      this._componentRef.onDestroy(() => {\r\n        this._appRef.detachView(this._componentRef.hostView);\r\n      });\r\n    }\r\n    this._prepareProps();\r\n  }\r\n\r\n  private _prepareProps(): void {\r\n    if (this._componentRef) {\r\n      this._transactionLineService.transactionLine = this.transactionLine;\r\n      this._componentRef.instance.preview = this.preview;\r\n      this._componentRef.instance.isFirst = this.isFirst;\r\n      this._componentRef.instance.readonly = this.readonly;\r\n      this._componentRef.instance.selected = this.selected;\r\n      // this._componentRef.instance.transaction = this.transaction;\r\n      // this._componentRef.instance.transactionLine = this.transactionLine;\r\n      // this._componentRef.instance.transactionInfo = this.transactionInfo;\r\n      // this._componentRef.instance.transactionId = this.transactionId;\r\n      this._componentRef.instance.activeCategory = this.activeCategory;\r\n      this._componentRef.instance.waitingForUserAction = this.waitingForUserAction;\r\n      this._changeDetector.markForCheck();\r\n      this._changeDetector.detectChanges();\r\n    }\r\n  }\r\n}\r\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-card.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-card/transaction-card/transaction-card.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ApplicationRef,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactory,\r\n  ComponentFactoryResolver,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy, OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  Type,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {TransactionTypeCategory} from '../../../enum/transaction-type-category.enum';\r\nimport {TransactionMappingService} from '../../../service/transaction-mapping.service';\r\nimport {TransactionBaseComponent} from '../../core/base/transaction-base.component';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {StatusBarCfgNames} from '../../../interface/status-bar-cfg-names.interface';\r\nimport {TransactionHeaderService} from '../../core/base/service/transaction-header.service';\r\nimport {TransactionLineService} from '../../core/base/service/transaction-line.service';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Subscription} from 'rxjs';\r\nimport {\r\n  TransactionTextLineComponent\r\n} from \"../../transaction-line/transaction-text-line/transaction-text-line.component\";\r\nimport {PurchaseConfirmationService} from '../../../service/purchase-confirmation.service';\r\nimport {LineSelectionService} from '../../../service/line-selection.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-card\",\r\n  template: `\r\n    <div class=\"transaction-card-outer-wrapper\" #transactionCard></div>\r\n    <co-transaction-line-side-panel *ngIf=\"showSidePanel\" clickOutside\r\n                                    [activeCategory]=\"activeCategory\"\r\n                                    (clickOutside)=\"showSidePanel = false\"\r\n                                    (cancelClick)=\"showSidePanel = false\">\r\n    </co-transaction-line-side-panel>\r\n  `,\r\n  providers: [\r\n    TransactionLineService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionCardComponent implements OnInit, OnChanges, OnDestroy {\r\n  @ViewChild('transactionCard', { read: ViewContainerRef }) set container(content) {\r\n    if (content) {\r\n      this._transactionCardContainer = content;\r\n      this._prepareContent();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set activeCategory(value: TransactionTypeCategory) {\r\n    this._activeCategory = value;\r\n    this._prepareContent();\r\n  }\r\n\r\n  public get activeCategory(): TransactionTypeCategory {\r\n    return this._activeCategory;\r\n  }\r\n\r\n  @Input()\r\n  public transactionLine: TransactionLineInfo;\r\n\r\n  @Input()\r\n  public statusBarConfigNames: StatusBarCfgNames;\r\n\r\n  @Input()\r\n  public preview: boolean = false;\r\n\r\n  @Input()\r\n  public selected: boolean = false;\r\n\r\n  @HostBinding('class.first')\r\n  @Input()\r\n  public isFirst: boolean = false;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Output()\r\n  public waitingForUserAction: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @HostBinding(\"class.drag-over\")\r\n  @Input()\r\n  public draggedOver: boolean = false;\r\n\r\n  @HostBinding(\"class.co-transaction-card\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  // @HostBinding('style.boxShadow')\r\n  // public get boxShadow(): string {\r\n  //   if (this.draggedOver) {\r\n  //     return 'inset 0 0 2px 1px grey';\r\n  //   } else {\r\n  //     return 'none';\r\n  //   }\r\n  // }\r\n\r\n  public showSidePanel: boolean = false;\r\n  public showSidePanelForConfirmationAI: boolean = false;\r\n  public activeTransactionLine: TransactionLineInfo = new TransactionLineInfo();\r\n\r\n  private _transactionCardContainer: ViewContainerRef;\r\n  private _activeCategory: TransactionTypeCategory;\r\n  private _componentRef: any;\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    public purchaseConfirmationService: PurchaseConfirmationService,\r\n    private _transactionHeaderService: TransactionHeaderService,\r\n    private _transactionLineService: TransactionLineService,\r\n    private _transactionEventService: TransactionEventService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private _mappingService: TransactionMappingService,\r\n    private _compFactoryResolver: ComponentFactoryResolver,\r\n    private _appRef: ApplicationRef,\r\n    private _lineSelectionService: LineSelectionService\r\n  ) {\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    let shouldPrepareProps: boolean = false;\r\n    for (let key in changes) {\r\n      if (key !== 'draggedOver') {\r\n        shouldPrepareProps = true;\r\n      }\r\n    }\r\n    if (shouldPrepareProps) {\r\n      this._prepareProps();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._subs.push(\r\n      this._transactionEventService.openSidePanel.subscribe((line) => {\r\n        this.activeTransactionLine = line;\r\n        this.showSidePanel = true;\r\n        this._changeDetector.detectChanges();\r\n      }),\r\n      this.purchaseConfirmationService.confirmationNeeded.subscribe((needed: boolean) => {\r\n        if (needed) {\r\n          this.showSidePanelForConfirmationAI = true;\r\n          this.showSidePanel = true;\r\n          this._checkActiveLine();\r\n          this._changeDetector.detectChanges();\r\n        } else {\r\n          this.showSidePanelForConfirmationAI = false;\r\n          this._changeDetector.detectChanges();\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n    if (this._componentRef) {\r\n      this._componentRef.destroy();\r\n      this._componentRef = undefined;\r\n    }\r\n    this._transactionCardContainer = undefined;\r\n  }\r\n\r\n  private _prepareContent(): void {\r\n    if (!this._transactionHeaderService.transactionKind || !this._activeCategory || !this._transactionCardContainer) {\r\n      return;\r\n    }\r\n\r\n    let componentClass: Type<TransactionBaseComponent>;\r\n    if (this.transactionLine.isText) {\r\n      componentClass = TransactionTextLineComponent;\r\n    } else {\r\n      componentClass = this._mappingService.getTransactionCardComponent(this._transactionHeaderService.transactionKind, this._activeCategory);\r\n    }\r\n\r\n\r\n    if (!this._componentRef) {\r\n      const factory: ComponentFactory<TransactionBaseComponent> = this._compFactoryResolver.resolveComponentFactory(componentClass);\r\n      this._transactionCardContainer.clear();\r\n      this._componentRef = this._transactionCardContainer.createComponent(factory);\r\n\r\n      this._componentRef.onDestroy(() => {\r\n        this._appRef.detachView(this._componentRef.hostView);\r\n      });\r\n    }\r\n    this._prepareProps();\r\n  }\r\n\r\n  private _prepareProps(): void {\r\n    if (this._componentRef) {\r\n      this._transactionLineService.transactionLine = this.transactionLine;\r\n      this._componentRef.instance.preview = this.preview;\r\n      this._componentRef.instance.isFirst = this.isFirst;\r\n      this._componentRef.instance.readonly = this.readonly;\r\n      this._componentRef.instance.selected = this.selected;\r\n      // this._componentRef.instance.transaction = this.transaction;\r\n      // this._componentRef.instance.transactionLine = this.transactionLine;\r\n      // this._componentRef.instance.transactionInfo = this.transactionInfo;\r\n      // this._componentRef.instance.transactionId = this.transactionId;\r\n      this._componentRef.instance.activeCategory = this.activeCategory;\r\n      this._componentRef.instance.waitingForUserAction = this.waitingForUserAction;\r\n      this._changeDetector.markForCheck();\r\n      this._changeDetector.detectChanges();\r\n    }\r\n  }\r\n\r\n  protected _checkActiveLine(): void {\r\n    if (this.showSidePanelForConfirmationAI && this.transactionLine) {\r\n      // this.activeTransactionLine = this.transactionLines[0];\r\n      this._lineSelectionService.selectedTransactionLine = this.transactionLine;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -96,6 +96,10 @@ export class TransactionHeaderPopupPaymentComponent extends TransactionHeaderPop
96
96
  event.preventDefault();
97
97
  event.stopPropagation();
98
98
  this.transactionIdToPay = (_a = this.transactionIdToPay) !== null && _a !== void 0 ? _a : this.transactionInfo.id;
99
+ if (this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0).length === 1) {
100
+ const lastTransaction = this.orderPaymentAnalysis.filter(payment => payment.transactionKind === this.transKind.SalesInvoice && payment.outstandingAmount > 0)[0];
101
+ this.transactionIdToPay = lastTransaction.transactionId;
102
+ }
99
103
  if (yield this.lockTransaction()) {
100
104
  this.showPaymentDialog = true;
101
105
  }
@@ -410,4 +414,4 @@ TransactionHeaderPopupPaymentComponent.ctorParameters = () => [
410
414
  TransactionHeaderPopupPaymentComponent.propDecorators = {
411
415
  showClass: [{ type: HostBinding, args: ['class.co-transaction-header-popup-payment',] }]
412
416
  };
413
- //# 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\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 *ngIf=\"showInvoiceSelection()\" [textContent]=\"'PAY' | localize\"></th>\r\n                          <th [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 *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>\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                  <co-deposit-payment\r\n                          *ngIf=\"activeCategory.index === 1\"\r\n                          [branch]=\"transactionInfo.branch?.relationNr\"\r\n                          [transactionUuid]=\"transactionInfo.uuid\"\r\n                          [showTitle]=\"false\"\r\n                          [transactionKind]=\"transKind.SalesOrder\"\r\n                  ></co-deposit-payment>\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\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\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 (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 _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"]}
417
+ //# 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\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 *ngIf=\"showInvoiceSelection()\" [textContent]=\"'PAY' | localize\"></th>\r\n                          <th [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 *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>\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                  <co-deposit-payment\r\n                          *ngIf=\"activeCategory.index === 1\"\r\n                          [branch]=\"transactionInfo.branch?.relationNr\"\r\n                          [transactionUuid]=\"transactionInfo.uuid\"\r\n                          [showTitle]=\"false\"\r\n                          [transactionKind]=\"transKind.SalesOrder\"\r\n                  ></co-deposit-payment>\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\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\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 _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"]}
@@ -94,6 +94,14 @@ TransactionReceiveGoodsLineComponent.decorators = [
94
94
  ></co-input-text>
95
95
  </div>
96
96
  </div>
97
+ <div class="transaction-field-wrapper">
98
+ <div class="inside-field">
99
+ <co-transaction-print-package-sticker
100
+ [screenConfigurationObject]="cfgNames.StickerAmount"
101
+ [inputLabel]="true"
102
+ ></co-transaction-print-package-sticker>
103
+ </div>
104
+ </div>
97
105
  <div class="transaction-field-wrapper">
98
106
  <div class="inside-field">
99
107
  <co-transaction-line-label [insideLabel]="'QUANTITY_TO_RECEIVE'"></co-transaction-line-label>
@@ -109,14 +117,6 @@ TransactionReceiveGoodsLineComponent.decorators = [
109
117
  </co-input-number-picker>
110
118
  </div>
111
119
  </div>
112
- <div class="transaction-field-wrapper">
113
- <div class="inside-field">
114
- <co-transaction-print-package-sticker
115
- [screenConfigurationObject]="cfgNames.StickerAmount"
116
- [inputLabel]="true"
117
- ></co-transaction-print-package-sticker>
118
- </div>
119
- </div>
120
120
  <div class="transaction-field-wrapper">
121
121
  <div class="inside-field">
122
122
  <co-editable-label class="transaction-line-totals-total price"
@@ -141,4 +141,4 @@ TransactionReceiveGoodsLineComponent.decorators = [
141
141
  TransactionReceiveGoodsLineComponent.propDecorators = {
142
142
  showClass: [{ type: HostBinding, args: ["class.co-transaction-receive-goods-line",] }]
143
143
  };
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-receive-goods-line.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-line/transaction-receive-goods-line/transaction-receive-goods-line.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAU,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACzG,OAAO,EAAC,wCAAwC,EAAC,MAAM,iDAAiD,CAAC;AA4HzG,MAAM,OAAO,oCAAqC,SAAQ,wCAAwC;IAzHlG;;QAgIS,yBAAoB,GAAsB;YAC/C,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;SACvC,CAAA;IACH,CAAC;IAXQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;;;YA9HF,SAAS,SAAC;gBACT,QAAQ,EAAE,mCAAmC;gBAC7C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmHT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;wBAGE,WAAW,SAAC,yCAAyC","sourcesContent":["import {ChangeDetectionStrategy, Component, HostBinding, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionReceiveGoodsLineBaseComponent} from './transaction-receive-goods-line-base.component';\r\nimport {StatusBarCfgNames} from '../../../interface/status-bar-cfg-names.interface';\r\n\r\n@Component({\r\n  selector: \"co-transaction-receive-goods-line\",\r\n  template: `\r\n      <co-transaction-base-line\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [transactionLine]=\"transactionLine\"\r\n              [preview]=\"preview\"\r\n              [isFirst]=\"isFirst\"\r\n              [checkbox]=\"showCheckboxForLine\"\r\n              [checkboxValue]=\"transactionLine.selected\"\r\n              (checkboxValueChanged)=\"transactionLine.selected = $event\"\r\n      >\r\n          <div class=\"transaction-line-wrapper\">\r\n              <div class=\"transaction-line-extended-wrapper\">\r\n                  <div class=\"column1 small-statusbar\">\r\n                      <co-transaction-line-statusbar\r\n                              [screenConfigurationObject]=\"cfgNames.StatusBar\"\r\n                              [configNames]=\"statusBarConfigNames\"\r\n                              [activeCategory]=\"transactionTypeCategory.PurchaseOrderReceivedGoods\"></co-transaction-line-statusbar>\r\n                  </div>\r\n                  <div class=\"column2\">\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-warehouse-button\r\n                                      [screenConfigurationObject]=\"cfgNames.LineWarehouse\"\r\n                                      [inputLabel]=\"true\"\r\n                              ></co-transaction-line-warehouse-button>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-warehouse-location-button\r\n                                      *ngIf=\"transactionLine.isLocationRequired\"\r\n                                      [screenConfigurationObject]=\"cfgNames.LineWarehouseLocationReceived\"\r\n                                      [readonly]=\"warehouseLocationButtonDisabled\"\r\n                                      [inputLabel]=\"true\"\r\n                              >\r\n                              </co-transaction-line-warehouse-location-button>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n                  <div class=\"column3\">\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'QUANTITY'\"></co-transaction-line-label>\r\n                              <co-input-text\r\n                                      [model]=\"transactionLine.amount\"\r\n                                      [leftIconData]=\"iconCacheService.getIcon(icons.CartShoppingRegular)\"\r\n                                      [readonly]=\"true\"\r\n                                      [customHeight]=\"true\"\r\n                              ></co-input-text>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'QUANTITY_ACCEPTED'\"></co-transaction-line-label>\r\n                              <co-input-text\r\n                                      [leftIconData]=\"iconCacheService.getIcon(icons.RegularCartFlatbedBoxesCircleCheck)\"\r\n                                      [readonly]=\"true\"\r\n                                      [customHeight]=\"true\"\r\n                              ></co-input-text>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n                  <div class=\"column4\">\r\n                      <div class=\"transaction-field-wrapper\" *ngIf=\"transactionLine.isBatchNrRequired\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'BATCH_NR'\"></co-transaction-line-label>\r\n                              <co-input-text class=\"side-panel-input\"\r\n                                             [(model)]=\"transactionLine.batchNr\"\r\n                                             [type]=\"'number'\"\r\n                                             [hideArrowButtons]=\"true\"\r\n                                             [readonly]=\"true\"\r\n                                             [required]=\"true\"\r\n                                             [customHeight]=\"true\"\r\n                              ></co-input-text>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'QUANTITY_TO_RECEIVE'\"></co-transaction-line-label>\r\n                              <co-input-number-picker class=\"amount-number-picker\"\r\n                                                      [screenConfigurationObject]=\"cfgNames.LineQuantityToReceive\"\r\n                                                      [model]=\"transactionLine.articleLineStatus?.quantityToReceive\"\r\n                                                      [decimals]=\"decimals\"\r\n                                                      [min]=\"1\"\r\n                                                      [max]=\"transactionLine.amount - lineQuantityReceived\"\r\n                                                      [leftIconData]=\"iconCacheService.getIcon(icons.CartFlatbedBoxesRegular)\"\r\n                                                      [readonly]=\"readonly || lineQuantityReceived === transactionLine.amount\"\r\n                                                      (modelChange)=\"changeLineAmount($event)\">\r\n                              </co-input-number-picker>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-print-package-sticker\r\n                                  [screenConfigurationObject]=\"cfgNames.StickerAmount\"\r\n                                  [inputLabel]=\"true\"\r\n                              ></co-transaction-print-package-sticker>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-editable-label class=\"transaction-line-totals-total price\"\r\n                                                 [model]=\"transactionLine.displayNetLineTotal | coCurrency: true\"\r\n                                                 [editModel]=\"transactionLine.displayNetLineTotal\"\r\n                                                 [commit]=\"!readonly\"\r\n                                                 [readonly]=\"true\"\r\n                                                 [editMode]=\"false\"\r\n                                                 [inputLabel]=\"true\"\r\n                              ></co-editable-label>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n              </div>\r\n          </div>\r\n      </co-transaction-base-line>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionReceiveGoodsLineComponent extends TransactionReceiveGoodsLineBaseComponent implements OnInit {\r\n\r\n  @HostBinding(\"class.co-transaction-receive-goods-line\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public statusBarConfigNames: StatusBarCfgNames = {\r\n    statusBarIB: this.cfgNames.StatusBarIB,\r\n    statusBarNT: this.cfgNames.StatusBarNT,\r\n    statusBarBN: this.cfgNames.StatusBarBN,\r\n    statusBarBG: this.cfgNames.StatusBarBG,\r\n    statusBarFC: this.cfgNames.StatusBarFC\r\n  }\r\n}\r\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-receive-goods-line.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-line/transaction-receive-goods-line/transaction-receive-goods-line.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAU,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACzG,OAAO,EAAC,wCAAwC,EAAC,MAAM,iDAAiD,CAAC;AA4HzG,MAAM,OAAO,oCAAqC,SAAQ,wCAAwC;IAzHlG;;QAgIS,yBAAoB,GAAsB;YAC/C,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACtC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;SACvC,CAAA;IACH,CAAC;IAXQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;;;YA9HF,SAAS,SAAC;gBACT,QAAQ,EAAE,mCAAmC;gBAC7C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmHT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;wBAGE,WAAW,SAAC,yCAAyC","sourcesContent":["import {ChangeDetectionStrategy, Component, HostBinding, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionReceiveGoodsLineBaseComponent} from './transaction-receive-goods-line-base.component';\r\nimport {StatusBarCfgNames} from '../../../interface/status-bar-cfg-names.interface';\r\n\r\n@Component({\r\n  selector: \"co-transaction-receive-goods-line\",\r\n  template: `\r\n      <co-transaction-base-line\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [transactionLine]=\"transactionLine\"\r\n              [preview]=\"preview\"\r\n              [isFirst]=\"isFirst\"\r\n              [checkbox]=\"showCheckboxForLine\"\r\n              [checkboxValue]=\"transactionLine.selected\"\r\n              (checkboxValueChanged)=\"transactionLine.selected = $event\"\r\n      >\r\n          <div class=\"transaction-line-wrapper\">\r\n              <div class=\"transaction-line-extended-wrapper\">\r\n                  <div class=\"column1 small-statusbar\">\r\n                      <co-transaction-line-statusbar\r\n                              [screenConfigurationObject]=\"cfgNames.StatusBar\"\r\n                              [configNames]=\"statusBarConfigNames\"\r\n                              [activeCategory]=\"transactionTypeCategory.PurchaseOrderReceivedGoods\"></co-transaction-line-statusbar>\r\n                  </div>\r\n                  <div class=\"column2\">\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-warehouse-button\r\n                                      [screenConfigurationObject]=\"cfgNames.LineWarehouse\"\r\n                                      [inputLabel]=\"true\"\r\n                              ></co-transaction-line-warehouse-button>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-warehouse-location-button\r\n                                      *ngIf=\"transactionLine.isLocationRequired\"\r\n                                      [screenConfigurationObject]=\"cfgNames.LineWarehouseLocationReceived\"\r\n                                      [readonly]=\"warehouseLocationButtonDisabled\"\r\n                                      [inputLabel]=\"true\"\r\n                              >\r\n                              </co-transaction-line-warehouse-location-button>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n                  <div class=\"column3\">\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'QUANTITY'\"></co-transaction-line-label>\r\n                              <co-input-text\r\n                                      [model]=\"transactionLine.amount\"\r\n                                      [leftIconData]=\"iconCacheService.getIcon(icons.CartShoppingRegular)\"\r\n                                      [readonly]=\"true\"\r\n                                      [customHeight]=\"true\"\r\n                              ></co-input-text>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'QUANTITY_ACCEPTED'\"></co-transaction-line-label>\r\n                              <co-input-text\r\n                                      [leftIconData]=\"iconCacheService.getIcon(icons.RegularCartFlatbedBoxesCircleCheck)\"\r\n                                      [readonly]=\"true\"\r\n                                      [customHeight]=\"true\"\r\n                              ></co-input-text>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n                  <div class=\"column4\">\r\n                      <div class=\"transaction-field-wrapper\" *ngIf=\"transactionLine.isBatchNrRequired\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'BATCH_NR'\"></co-transaction-line-label>\r\n                              <co-input-text class=\"side-panel-input\"\r\n                                             [(model)]=\"transactionLine.batchNr\"\r\n                                             [type]=\"'number'\"\r\n                                             [hideArrowButtons]=\"true\"\r\n                                             [readonly]=\"true\"\r\n                                             [required]=\"true\"\r\n                                             [customHeight]=\"true\"\r\n                              ></co-input-text>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-print-package-sticker\r\n                                      [screenConfigurationObject]=\"cfgNames.StickerAmount\"\r\n                                      [inputLabel]=\"true\"\r\n                              ></co-transaction-print-package-sticker>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-transaction-line-label [insideLabel]=\"'QUANTITY_TO_RECEIVE'\"></co-transaction-line-label>\r\n                              <co-input-number-picker class=\"amount-number-picker\"\r\n                                                      [screenConfigurationObject]=\"cfgNames.LineQuantityToReceive\"\r\n                                                      [model]=\"transactionLine.articleLineStatus?.quantityToReceive\"\r\n                                                      [decimals]=\"decimals\"\r\n                                                      [min]=\"1\"\r\n                                                      [max]=\"transactionLine.amount - lineQuantityReceived\"\r\n                                                      [leftIconData]=\"iconCacheService.getIcon(icons.CartFlatbedBoxesRegular)\"\r\n                                                      [readonly]=\"readonly || lineQuantityReceived === transactionLine.amount\"\r\n                                                      (modelChange)=\"changeLineAmount($event)\">\r\n                              </co-input-number-picker>\r\n                          </div>\r\n                      </div>\r\n                      <div class=\"transaction-field-wrapper\">\r\n                          <div class=\"inside-field\">\r\n                              <co-editable-label class=\"transaction-line-totals-total price\"\r\n                                                 [model]=\"transactionLine.displayNetLineTotal | coCurrency: true\"\r\n                                                 [editModel]=\"transactionLine.displayNetLineTotal\"\r\n                                                 [commit]=\"!readonly\"\r\n                                                 [readonly]=\"true\"\r\n                                                 [editMode]=\"false\"\r\n                                                 [inputLabel]=\"true\"\r\n                              ></co-editable-label>\r\n                          </div>\r\n                      </div>\r\n                  </div>\r\n              </div>\r\n          </div>\r\n      </co-transaction-base-line>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionReceiveGoodsLineComponent extends TransactionReceiveGoodsLineBaseComponent implements OnInit {\r\n\r\n  @HostBinding(\"class.co-transaction-receive-goods-line\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public statusBarConfigNames: StatusBarCfgNames = {\r\n    statusBarIB: this.cfgNames.StatusBarIB,\r\n    statusBarNT: this.cfgNames.StatusBarNT,\r\n    statusBarBN: this.cfgNames.StatusBarBN,\r\n    statusBarBG: this.cfgNames.StatusBarBG,\r\n    statusBarFC: this.cfgNames.StatusBarFC\r\n  }\r\n}\r\n"]}
@@ -50,7 +50,6 @@ export class TransactionLineSidePanelComponent {
50
50
  }));
51
51
  }
52
52
  ngOnDestroy() {
53
- this._purchaseConfirmationService.reset();
54
53
  this._subs.forEach(s => s.unsubscribe());
55
54
  }
56
55
  updateActiveCategory(button) {
@@ -123,4 +122,4 @@ TransactionLineSidePanelComponent.propDecorators = {
123
122
  cancelClick: [{ type: Output }],
124
123
  showClass: [{ type: HostBinding, args: ["class.co-transaction-line-side-panel",] }]
125
124
  };
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-side-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {TransactionKind} from '@colijnit/transactionapi/build/enum/transaction-kind.enum';\r\nimport {TransactionTypeCategory} from '../../enum/transaction-type-category.enum';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {TransactionEventService} from '../../service/transaction-event.service';\r\nimport {TransactionInfo} from '@colijnit/transactionapi/build/model/transaction-info.bo';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {TransactionMappingService} from '../../service/transaction-mapping.service';\r\nimport {TransactionBarButton} from '../../model/transaction-bar-button';\r\nimport {TransactionInfoResponse} from '@colijnit/transactionapi/build/model/transaction-info-response.bo';\r\nimport {PurchaseConfirmationService} from '../../service/purchase-confirmation.service';\r\nimport {Subscription} from \"rxjs\";\r\nimport {TransactionLineService} from '../core/base/service/transaction-line.service';\r\nimport {TransactionHeaderService} from '../core/base/service/transaction-header.service';\r\nimport {LineSelectionService} from '../../service/line-selection.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-side-panel\",\r\n  template: `\r\n    <div class=\"transaction-line-side-panel-wrapper\" [class.wide]=\"wide\" @showHideSidePanel>\r\n      <icon (click)=\"cancelClick.emit($event)\" [icon]=\"icons.Crossskinny\" class=\"side-panel close-button\"></icon>\r\n      <div class=\"transaction-line-side-panel-header\">\r\n        <icon [icon]=\"activeCategoryButton?.icon\"></icon>\r\n        <span [textContent]=\"activeCategoryButton?.title | localize\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-nav-bar\">\r\n        <co-transaction-button-bar\r\n          [sidePanel]=\"true\"\r\n          [selectedCategory]=\"activeCategory\"\r\n          (buttonClicked)=\"updateActiveCategory($event)\"\r\n        ></co-transaction-button-bar>\r\n      </div>\r\n      <div class=\"total-amount\" *ngIf=\"activeCategory === TransactionTypeCategory.PurchaseOrderOrderConfirmation\">\r\n        <span>Totaal excl. BTW</span>\r\n        <span [textContent]=\"ordersTotal | coCurrency\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-content co-small-scrollbar\">\r\n        <ng-container [ngSwitch]=\"transactionInfo.transactionKind\">\r\n          <ng-container *ngSwitchCase=\"transactionTypes.PurchaseOrder\">\r\n            <co-transaction-line-side-panel-purchase [categoryType]=\"activeCategory\"></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n          <ng-container *ngSwitchCase=\"transactionTypes.SalesOrder\">\r\n            <co-transaction-line-side-panel-sales [categoryType]=\"activeCategory\"></co-transaction-line-side-panel-sales>\r\n          </ng-container>\r\n          <ng-container *ngSwitchDefault>\r\n            <co-transaction-line-side-panel-purchase [categoryType]=\"activeCategory\"></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  `,\r\n  providers: [\r\n    TransactionLineService\r\n  ],\r\n  animations: [\r\n    trigger(\"showHideSidePanel\", [\r\n      state(\"void\", style({transform: \"translateX(100%)\"})),\r\n      state(\"*\", style({transform: \"translateX(0)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineSidePanelComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n  public readonly categories: typeof TransactionTypeCategory = TransactionTypeCategory;\r\n  public readonly transactionTypes: typeof TransactionKind = TransactionKind;\r\n  public readonly TransactionTypeCategory = TransactionTypeCategory;\r\n\r\n  @Input()\r\n  public wide: boolean = false;\r\n\r\n  @Input()\r\n  public activeCategory: TransactionTypeCategory;\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-transaction-line-side-panel\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public get transaction(): TransactionInfoResponse {\r\n    return this._transactionHeaderService.transaction;\r\n  }\r\n\r\n  public get transactionInfo(): TransactionInfo {\r\n    return this._transactionHeaderService.transactionInfo;\r\n  }\r\n\r\n  public activeCategoryButton: TransactionBarButton;\r\n  public ordersTotal: number;\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    private _service: TransactionService,\r\n    private _transactionHeaderService: TransactionHeaderService,\r\n    private _transactionLineService: TransactionLineService,\r\n    private _transactionEventService: TransactionEventService,\r\n    private _transactionMappingService: TransactionMappingService,\r\n    private _purchaseConfirmationService: PurchaseConfirmationService,\r\n    private _lineSelectionService: LineSelectionService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.activeCategoryButton = this._transactionMappingService.getButtonBar(this._transactionHeaderService.transactionKind)\r\n      .find((button) => button.category === this.activeCategory);\r\n\r\n    this._subs.push(\r\n      this._lineSelectionService.selectedTransactionLineChanged.subscribe((line: TransactionLineInfo) => {\r\n        if (line) {\r\n          this._transactionLineService.transactionLine = line;\r\n          this._changeDetector.detectChanges();\r\n        }\r\n      }),\r\n      this._purchaseConfirmationService.ordersTotalObservable.subscribe(\r\n      (value) => {\r\n        this.ordersTotal = value;\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._purchaseConfirmationService.reset();\r\n    this._subs.forEach(s => s.unsubscribe());\r\n  }\r\n\r\n  public updateActiveCategory(button: TransactionBarButton): void {\r\n    this.activeCategory = button.category;\r\n    this.activeCategoryButton = button;\r\n  }\r\n}\r\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-side-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {TransactionKind} from '@colijnit/transactionapi/build/enum/transaction-kind.enum';\r\nimport {TransactionTypeCategory} from '../../enum/transaction-type-category.enum';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {TransactionEventService} from '../../service/transaction-event.service';\r\nimport {TransactionInfo} from '@colijnit/transactionapi/build/model/transaction-info.bo';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {TransactionMappingService} from '../../service/transaction-mapping.service';\r\nimport {TransactionBarButton} from '../../model/transaction-bar-button';\r\nimport {TransactionInfoResponse} from '@colijnit/transactionapi/build/model/transaction-info-response.bo';\r\nimport {PurchaseConfirmationService} from '../../service/purchase-confirmation.service';\r\nimport {Subscription} from \"rxjs\";\r\nimport {TransactionLineService} from '../core/base/service/transaction-line.service';\r\nimport {TransactionHeaderService} from '../core/base/service/transaction-header.service';\r\nimport {LineSelectionService} from '../../service/line-selection.service';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-side-panel\",\r\n  template: `\r\n    <div class=\"transaction-line-side-panel-wrapper\" [class.wide]=\"wide\" @showHideSidePanel>\r\n      <icon (click)=\"cancelClick.emit($event)\" [icon]=\"icons.Crossskinny\" class=\"side-panel close-button\"></icon>\r\n      <div class=\"transaction-line-side-panel-header\">\r\n        <icon [icon]=\"activeCategoryButton?.icon\"></icon>\r\n        <span [textContent]=\"activeCategoryButton?.title | localize\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-nav-bar\">\r\n        <co-transaction-button-bar\r\n          [sidePanel]=\"true\"\r\n          [selectedCategory]=\"activeCategory\"\r\n          (buttonClicked)=\"updateActiveCategory($event)\"\r\n        ></co-transaction-button-bar>\r\n      </div>\r\n      <div class=\"total-amount\" *ngIf=\"activeCategory === TransactionTypeCategory.PurchaseOrderOrderConfirmation\">\r\n        <span>Totaal excl. BTW</span>\r\n        <span [textContent]=\"ordersTotal | coCurrency\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-content co-small-scrollbar\">\r\n        <ng-container [ngSwitch]=\"transactionInfo.transactionKind\">\r\n          <ng-container *ngSwitchCase=\"transactionTypes.PurchaseOrder\">\r\n            <co-transaction-line-side-panel-purchase [categoryType]=\"activeCategory\"></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n          <ng-container *ngSwitchCase=\"transactionTypes.SalesOrder\">\r\n            <co-transaction-line-side-panel-sales [categoryType]=\"activeCategory\"></co-transaction-line-side-panel-sales>\r\n          </ng-container>\r\n          <ng-container *ngSwitchDefault>\r\n            <co-transaction-line-side-panel-purchase [categoryType]=\"activeCategory\"></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  `,\r\n  providers: [\r\n    TransactionLineService\r\n  ],\r\n  animations: [\r\n    trigger(\"showHideSidePanel\", [\r\n      state(\"void\", style({transform: \"translateX(100%)\"})),\r\n      state(\"*\", style({transform: \"translateX(0)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineSidePanelComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n  public readonly categories: typeof TransactionTypeCategory = TransactionTypeCategory;\r\n  public readonly transactionTypes: typeof TransactionKind = TransactionKind;\r\n  public readonly TransactionTypeCategory = TransactionTypeCategory;\r\n\r\n  @Input()\r\n  public wide: boolean = false;\r\n\r\n  @Input()\r\n  public activeCategory: TransactionTypeCategory;\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-transaction-line-side-panel\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public get transaction(): TransactionInfoResponse {\r\n    return this._transactionHeaderService.transaction;\r\n  }\r\n\r\n  public get transactionInfo(): TransactionInfo {\r\n    return this._transactionHeaderService.transactionInfo;\r\n  }\r\n\r\n  public activeCategoryButton: TransactionBarButton;\r\n  public ordersTotal: number;\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    private _service: TransactionService,\r\n    private _transactionHeaderService: TransactionHeaderService,\r\n    private _transactionLineService: TransactionLineService,\r\n    private _transactionEventService: TransactionEventService,\r\n    private _transactionMappingService: TransactionMappingService,\r\n    private _purchaseConfirmationService: PurchaseConfirmationService,\r\n    private _lineSelectionService: LineSelectionService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.activeCategoryButton = this._transactionMappingService.getButtonBar(this._transactionHeaderService.transactionKind)\r\n      .find((button) => button.category === this.activeCategory);\r\n\r\n    this._subs.push(\r\n      this._lineSelectionService.selectedTransactionLineChanged.subscribe((line: TransactionLineInfo) => {\r\n        if (line) {\r\n          this._transactionLineService.transactionLine = line;\r\n          this._changeDetector.detectChanges();\r\n        }\r\n      }),\r\n      this._purchaseConfirmationService.ordersTotalObservable.subscribe(\r\n      (value) => {\r\n        this.ordersTotal = value;\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n  }\r\n\r\n  public updateActiveCategory(button: TransactionBarButton): void {\r\n    this.activeCategory = button.category;\r\n    this.activeCategoryButton = button;\r\n  }\r\n}\r\n"]}
@@ -20,9 +20,11 @@ export class TransactionLinesComponent extends TransactionLinesBaseComponent {
20
20
  this.showSidePanelForConfirmationAI = true;
21
21
  this.showSidePanel = true;
22
22
  this._checkActiveLine();
23
+ this.changeDetector.detectChanges();
23
24
  }
24
25
  else {
25
26
  this.showSidePanelForConfirmationAI = false;
27
+ this.changeDetector.detectChanges();
26
28
  }
27
29
  }), this.transactionEventService.openSidePanel.subscribe((line) => {
28
30
  this.activeTransactionLine = line;
@@ -125,4 +127,4 @@ TransactionLinesComponent.propDecorators = {
125
127
  showClass: [{ type: HostBinding, args: ["class.co-transaction-lines",] }],
126
128
  customerPortal: [{ type: Input }]
127
129
  };
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-lines.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-lines/transaction-lines.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAqB,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAC,6BAA6B,EAAC,MAAM,+CAA+C,CAAC;AAC5F,OAAO,EAAC,mBAAmB,EAAC,MAAM,+DAA+D,CAAC;AA6ElG,MAAM,OAAO,yBAA0B,SAAQ,6BAA6B;IA1E5E;;QAiFS,mBAAc,GAAY,KAAK,CAAC;QAEhC,kBAAa,GAAY,KAAK,CAAC;QAC/B,mCAA8B,GAAY,KAAK,CAAC;QAChD,0BAAqB,GAAuB,IAAI,mBAAmB,EAAE,CAAC;QAErE,UAAK,GAAmB,EAAE,CAAC;IAsCrC,CAAC;IAjDQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAWM,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,2BAA2B,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,MAAe,EAAE,EAAE;YAChF,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC1B,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;iBAAM;gBACL,IAAI,CAAC,8BAA8B,GAAG,KAAK,CAAC;aAC7C;QACH,CAAC,CAAC,EACF,IAAI,CAAC,uBAAuB,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,IAAyB,EAAE,EAAE;YACjF,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;YAClC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACtC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QACzC,KAAK,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;IAES,cAAc;QACtB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,8BAA8B,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YACpG,yDAAyD;YACzD,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;SAC9E;IACH,CAAC;;;YA5HF,SAAS,SAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoET;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;wBAEE,WAAW,SAAC,4BAA4B;6BAKxC,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, HostBinding, Input, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionLinesBaseComponent} from '../core/base/transaction-lines-base.component';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Subscription} from 'rxjs';\r\n\r\n@Component({\r\n  selector: \"co-transaction-lines\",\r\n  template: `\r\n    <div *ngIf=\"customerPortal\">\r\n      <div class=\"draggable-transaction-line\" *ngFor=\"let line of (historicTransactionLines ? historicTransactionLines : transactionLines);\">\r\n        <co-transaction-line\r\n          [transactionLine]=\"line\"\r\n          [activeCategory]=\"category.SalesCustomerPortal\"\r\n          [preview]=\"preview\"\r\n          [readonly]=\"historicTransactionLines !== null\"\r\n          (waitingForUserAction)=\"userActionRequired = $event\"\r\n          [class.customer-line]=\"customerPortal\"\r\n          observeVisibility #observer=visibilityObserve (visibilityChange)=\"handleVisibilityChange(line, $event)\"\r\n        ></co-transaction-line>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"!customerPortal\" #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n         class=\"transaction-lines-drag-drop-list\"\r\n         [cdkDropListDisabled]=\"preview || userActionRequired\"\r\n         [cdkDropListData]=\"transactionLines\"\r\n         [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n         (cdkDropListDropped)=\"handleDrop($event)\"\r\n         (cdkDropListEntered)=\"handleDropListEntered($event)\"\r\n    >\r\n      <div class=\"draggable-transaction-line\"\r\n           *ngFor=\"let line of (historicTransactionLines ? historicTransactionLines : transactionLines);let isFirst = first; trackBy:trackByFn;\"\r\n           [cdkDragDisabled]=\"activeCategory !== category.SalesOrderOverview && activeCategory !== category.SalesOrderQuotation\"\r\n           cdkDrag>\r\n        <co-icon *ngIf=\"!preview && (activeCategory === category.SalesOrderOverview || activeCategory == category.SalesOrderQuotation)\" class=\"transaction-line-drag-handle\"\r\n                 [class.show]=\"line === selectedTransactionLine && transactionLines.length > 1\" cdkDragHandle\r\n                 [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n        </co-icon>\r\n        <co-transaction-line\r\n          [draggedOver]=\"lineDraggedOver === line.lineNr\"\r\n          [transactionLine]=\"line\"\r\n          [activeCategory]=\"activeCategory\"\r\n          [preview]=\"preview\"\r\n          [isFirst]=\"isFirst\"\r\n          [readonly]=\"historicTransactionLines !== null\"\r\n          (waitingForUserAction)=\"userActionRequired = $event\"\r\n          (click)=\"selectedTransactionLine = line\"\r\n          (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n          observeVisibility #observer=visibilityObserve (visibilityChange)=\"handleVisibilityChange(line, $event)\"\r\n        ></co-transaction-line>\r\n      </div>\r\n      <ng-container *ngIf=\"activeCategory === category.SalesOrderDeliveryNote || activeCategory === category.SalesOrderInvoice || activeCategory === category.SalesOrderPlanning\">\r\n        <div class=\"draggable-transaction-line\" *ngFor=\"let line of deliveryCostLines; trackBy:trackByFn;\" cdkDrag>\r\n          <co-icon *ngIf=\"!preview\" class=\"transaction-line-drag-handle\"\r\n                   [class.show]=\"line === selectedTransactionLine\" cdkDragHandle\r\n                   [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n          </co-icon>\r\n          <co-transaction-line\r\n            [transactionLine]=\"line\"\r\n            [activeCategory]=\"activeCategory\"\r\n            [preview]=\"preview\"\r\n            [readonly]=\"historicTransactionLines !== null\"\r\n            [isFirst]=\"isFirst\"\r\n            (waitingForUserAction)=\"userActionRequired = $event\"\r\n            (click)=\"selectedTransactionLine = line\"\r\n            (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n            observeVisibility #observer=visibilityObserve (visibilityChange)=\"handleVisibilityChange(line, $event)\"\r\n          ></co-transaction-line>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <co-transaction-line-side-panel *ngIf=\"showSidePanel\"\r\n                                    [activeCategory]=\"activeCategory\"\r\n                                    (cancelClick)=\"showSidePanel = false\">\r\n    </co-transaction-line-side-panel>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionLinesComponent extends TransactionLinesBaseComponent implements OnInit, OnDestroy {\r\n  @HostBinding(\"class.co-transaction-lines\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public customerPortal: boolean = false;\r\n\r\n  public showSidePanel: boolean = false;\r\n  public showSidePanelForConfirmationAI: boolean = false;\r\n  public activeTransactionLine: TransactionLineInfo= new TransactionLineInfo();\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this._subs.push(\r\n      this.purchaseConfirmationService.confirmationNeeded.subscribe((needed: boolean) => {\r\n        if (needed) {\r\n          this.showSidePanelForConfirmationAI = true;\r\n          this.showSidePanel = true;\r\n          this._checkActiveLine();\r\n        } else {\r\n          this.showSidePanelForConfirmationAI = false;\r\n        }\r\n      }),\r\n      this.transactionEventService.openSidePanel.subscribe((line: TransactionLineInfo) => {\r\n        this.activeTransactionLine = line;\r\n        this.showSidePanel = true;\r\n        this.changeDetector.detectChanges();\r\n      })\r\n    );\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n    super.ngOnDestroy();\r\n  }\r\n\r\n  protected transactionSet(): void {\r\n    super.transactionSet();\r\n    this._checkActiveLine();\r\n  }\r\n\r\n  protected _checkActiveLine(): void {\r\n    if (this.showSidePanelForConfirmationAI && this.transactionLines && this.transactionLines.length > 0) {\r\n      // this.activeTransactionLine = this.transactionLines[0];\r\n      this.lineSelectionService.selectedTransactionLine = this.transactionLines[0];\r\n    }\r\n  }\r\n}\r\n\r\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-lines.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-lines/transaction-lines.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAqB,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAC,6BAA6B,EAAC,MAAM,+CAA+C,CAAC;AAC5F,OAAO,EAAC,mBAAmB,EAAC,MAAM,+DAA+D,CAAC;AA6ElG,MAAM,OAAO,yBAA0B,SAAQ,6BAA6B;IA1E5E;;QAiFS,mBAAc,GAAY,KAAK,CAAC;QAEhC,kBAAa,GAAY,KAAK,CAAC;QAC/B,mCAA8B,GAAY,KAAK,CAAC;QAChD,0BAAqB,GAAwB,IAAI,mBAAmB,EAAE,CAAC;QAEtE,UAAK,GAAmB,EAAE,CAAC;IAwCrC,CAAC;IAnDQ,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAWM,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,2BAA2B,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,MAAe,EAAE,EAAE;YAChF,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC1B,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;aACrC;iBAAM;gBACL,IAAI,CAAC,8BAA8B,GAAG,KAAK,CAAC;gBAC5C,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;aACrC;QACH,CAAC,CAAC,EACF,IAAI,CAAC,uBAAuB,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,IAAyB,EAAE,EAAE;YACjF,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;YAClC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACtC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QACzC,KAAK,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;IAES,cAAc;QACtB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,8BAA8B,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YACpG,yDAAyD;YACzD,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;SAC9E;IACH,CAAC;;;YA9HF,SAAS,SAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoET;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;wBAEE,WAAW,SAAC,4BAA4B;6BAKxC,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, HostBinding, Input, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionLinesBaseComponent} from '../core/base/transaction-lines-base.component';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Subscription} from 'rxjs';\r\n\r\n@Component({\r\n  selector: \"co-transaction-lines\",\r\n  template: `\r\n    <div *ngIf=\"customerPortal\">\r\n      <div class=\"draggable-transaction-line\" *ngFor=\"let line of (historicTransactionLines ? historicTransactionLines : transactionLines);\">\r\n        <co-transaction-line\r\n          [transactionLine]=\"line\"\r\n          [activeCategory]=\"category.SalesCustomerPortal\"\r\n          [preview]=\"preview\"\r\n          [readonly]=\"historicTransactionLines !== null\"\r\n          (waitingForUserAction)=\"userActionRequired = $event\"\r\n          [class.customer-line]=\"customerPortal\"\r\n          observeVisibility #observer=visibilityObserve (visibilityChange)=\"handleVisibilityChange(line, $event)\"\r\n        ></co-transaction-line>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"!customerPortal\" #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n         class=\"transaction-lines-drag-drop-list\"\r\n         [cdkDropListDisabled]=\"preview || userActionRequired\"\r\n         [cdkDropListData]=\"transactionLines\"\r\n         [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n         (cdkDropListDropped)=\"handleDrop($event)\"\r\n         (cdkDropListEntered)=\"handleDropListEntered($event)\"\r\n    >\r\n      <div class=\"draggable-transaction-line\"\r\n           *ngFor=\"let line of (historicTransactionLines ? historicTransactionLines : transactionLines);let isFirst = first; trackBy:trackByFn;\"\r\n           [cdkDragDisabled]=\"activeCategory !== category.SalesOrderOverview && activeCategory !== category.SalesOrderQuotation\"\r\n           cdkDrag>\r\n        <co-icon *ngIf=\"!preview && (activeCategory === category.SalesOrderOverview || activeCategory == category.SalesOrderQuotation)\" class=\"transaction-line-drag-handle\"\r\n                 [class.show]=\"line === selectedTransactionLine && transactionLines.length > 1\" cdkDragHandle\r\n                 [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n        </co-icon>\r\n        <co-transaction-line\r\n          [draggedOver]=\"lineDraggedOver === line.lineNr\"\r\n          [transactionLine]=\"line\"\r\n          [activeCategory]=\"activeCategory\"\r\n          [preview]=\"preview\"\r\n          [isFirst]=\"isFirst\"\r\n          [readonly]=\"historicTransactionLines !== null\"\r\n          (waitingForUserAction)=\"userActionRequired = $event\"\r\n          (click)=\"selectedTransactionLine = line\"\r\n          (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n          observeVisibility #observer=visibilityObserve (visibilityChange)=\"handleVisibilityChange(line, $event)\"\r\n        ></co-transaction-line>\r\n      </div>\r\n      <ng-container *ngIf=\"activeCategory === category.SalesOrderDeliveryNote || activeCategory === category.SalesOrderInvoice || activeCategory === category.SalesOrderPlanning\">\r\n        <div class=\"draggable-transaction-line\" *ngFor=\"let line of deliveryCostLines; trackBy:trackByFn;\" cdkDrag>\r\n          <co-icon *ngIf=\"!preview\" class=\"transaction-line-drag-handle\"\r\n                   [class.show]=\"line === selectedTransactionLine\" cdkDragHandle\r\n                   [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n          </co-icon>\r\n          <co-transaction-line\r\n            [transactionLine]=\"line\"\r\n            [activeCategory]=\"activeCategory\"\r\n            [preview]=\"preview\"\r\n            [readonly]=\"historicTransactionLines !== null\"\r\n            [isFirst]=\"isFirst\"\r\n            (waitingForUserAction)=\"userActionRequired = $event\"\r\n            (click)=\"selectedTransactionLine = line\"\r\n            (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n            observeVisibility #observer=visibilityObserve (visibilityChange)=\"handleVisibilityChange(line, $event)\"\r\n          ></co-transaction-line>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <co-transaction-line-side-panel *ngIf=\"showSidePanel\"\r\n                                    [activeCategory]=\"activeCategory\"\r\n                                    (cancelClick)=\"showSidePanel = false\">\r\n    </co-transaction-line-side-panel>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionLinesComponent extends TransactionLinesBaseComponent implements OnInit, OnDestroy {\r\n  @HostBinding(\"class.co-transaction-lines\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public customerPortal: boolean = false;\r\n\r\n  public showSidePanel: boolean = false;\r\n  public showSidePanelForConfirmationAI: boolean = false;\r\n  public activeTransactionLine: TransactionLineInfo = new TransactionLineInfo();\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this._subs.push(\r\n      this.purchaseConfirmationService.confirmationNeeded.subscribe((needed: boolean) => {\r\n        if (needed) {\r\n          this.showSidePanelForConfirmationAI = true;\r\n          this.showSidePanel = true;\r\n          this._checkActiveLine();\r\n          this.changeDetector.detectChanges();\r\n        } else {\r\n          this.showSidePanelForConfirmationAI = false;\r\n          this.changeDetector.detectChanges();\r\n        }\r\n      }),\r\n      this.transactionEventService.openSidePanel.subscribe((line: TransactionLineInfo) => {\r\n        this.activeTransactionLine = line;\r\n        this.showSidePanel = true;\r\n        this.changeDetector.detectChanges();\r\n      })\r\n    );\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this._subs.forEach(s => s.unsubscribe());\r\n    super.ngOnDestroy();\r\n  }\r\n\r\n  protected transactionSet(): void {\r\n    super.transactionSet();\r\n    this._checkActiveLine();\r\n  }\r\n\r\n  protected _checkActiveLine(): void {\r\n    if (this.showSidePanelForConfirmationAI && this.transactionLines && this.transactionLines.length > 0) {\r\n      // this.activeTransactionLine = this.transactionLines[0];\r\n      this.lineSelectionService.selectedTransactionLine = this.transactionLines[0];\r\n    }\r\n  }\r\n}\r\n\r\n"]}