@colijnit/transaction 254.1.2 → 254.1.3

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 (64) hide show
  1. package/bundles/colijnit-transaction.umd.js +932 -669
  2. package/bundles/colijnit-transaction.umd.js.map +1 -1
  3. package/colijnit-transaction.d.ts +566 -562
  4. package/colijnit-transaction.metadata.json +1 -1
  5. package/esm2015/colijnit-transaction.js +567 -563
  6. package/esm2015/lib/component/checkout/checkout.component.js +1 -1
  7. package/esm2015/lib/component/checkout/checkout.module.js +4 -2
  8. package/esm2015/lib/component/checkout-simple/checkout-simple.component.js +1 -1
  9. package/esm2015/lib/component/checkout-simple/checkout-simple.module.js +4 -2
  10. package/esm2015/lib/component/core/base/stepper-base.component.js +57 -0
  11. package/esm2015/lib/component/payment/payment.component.js +75 -7
  12. package/esm2015/lib/component/payment/payment.module.js +4 -3
  13. package/esm2015/lib/component/relation/relation-contact-details/relation-contact-details.component.js +4 -2
  14. package/esm2015/lib/component/simple-vertical-stepper/co-simple-vertical-stepper.component.js +58 -0
  15. package/esm2015/lib/component/simple-vertical-stepper/co-simple-vertical-stepper.module.js +27 -0
  16. package/esm2015/lib/component/stepper/stepper.component.js +13 -48
  17. package/esm2015/lib/component/stepper/stepper.module.js +3 -6
  18. package/esm2015/lib/component/stepper-step/stepper-step.component.js +40 -0
  19. package/esm2015/lib/component/stepper-step/stepper-step.module.js +27 -0
  20. package/esm2015/lib/component/transaction-create-wizard/transaction-create-wizard.component.js +30 -5
  21. package/esm2015/lib/component/transaction-create-wizard/transaction-create-wizard.module.js +6 -2
  22. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-create-service.component.js +20 -18
  23. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-relation.component.js +2 -1
  24. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-wizard.component.js +1 -1
  25. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup.module.js +4 -2
  26. package/esm2015/lib/component/transaction-labeled-warehouse-location-button/transaction-labeled-warehouse-location-button.component.js +23 -24
  27. package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-received-goods/transaction-quick-access-received-goods.component.js +25 -11
  28. package/esm2015/lib/service/transaction-connector-adapter.service.js +2 -2
  29. package/esm2015/lib/transaction-version.js +3 -3
  30. package/fesm2015/colijnit-transaction.js +336 -108
  31. package/fesm2015/colijnit-transaction.js.map +1 -1
  32. package/lib/component/checkout/checkout.component.d.ts +1 -1
  33. package/lib/component/checkout/style/material.scss +1 -0
  34. package/lib/component/checkout-simple/checkout-simple.component.d.ts +1 -1
  35. package/lib/component/checkout-simple/style/material.scss +1 -0
  36. package/lib/component/core/base/stepper-base.component.d.ts +25 -0
  37. package/lib/component/dialog/transaction-search/style/_layout.scss +29 -0
  38. package/lib/component/dialog/transaction-search/style/_material-definition.scss +2 -0
  39. package/lib/component/dialog/transaction-search/style/_theme.scss +4 -0
  40. package/lib/component/dialog/transaction-search/style/material.scss +4 -0
  41. package/lib/component/payment/payment.component.d.ts +15 -1
  42. package/lib/component/relation/relation-contact-details/relation-contact-details.component.d.ts +1 -0
  43. package/lib/component/simple-vertical-stepper/co-simple-vertical-stepper.component.d.ts +12 -0
  44. package/lib/component/simple-vertical-stepper/co-simple-vertical-stepper.module.d.ts +2 -0
  45. package/lib/component/simple-vertical-stepper/style/_layout.scss +37 -0
  46. package/lib/component/simple-vertical-stepper/style/_material-definition.scss +30 -0
  47. package/lib/component/simple-vertical-stepper/style/_theme.scss +7 -0
  48. package/lib/component/simple-vertical-stepper/style/material.scss +3 -0
  49. package/lib/component/stepper/stepper.component.d.ts +4 -22
  50. package/lib/component/stepper-step/stepper-step.module.d.ts +2 -0
  51. package/lib/component/stepper-step/style/_layout.scss +12 -0
  52. package/lib/component/stepper-step/style/_material-definition.scss +30 -0
  53. package/lib/component/stepper-step/style/_theme.scss +41 -0
  54. package/lib/component/stepper-step/style/material.scss +3 -0
  55. package/lib/component/transaction-create-wizard/style/_layout.scss +4 -0
  56. package/lib/component/transaction-create-wizard/style/_material-definition.scss +4 -0
  57. package/lib/component/transaction-create-wizard/style/_theme.scss +4 -0
  58. package/lib/component/transaction-create-wizard/style/material.scss +6 -0
  59. package/lib/component/transaction-create-wizard/transaction-create-wizard.component.d.ts +12 -2
  60. package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-create-service.component.d.ts +5 -3
  61. package/lib/component/transaction-quick-access/transaction-quick-access-received-goods/transaction-quick-access-received-goods.component.d.ts +4 -1
  62. package/package.json +1 -1
  63. package/esm2015/lib/component/stepper/component/stepper-step.component.js +0 -40
  64. /package/lib/component/{stepper/component → stepper-step}/stepper-step.component.d.ts +0 -0
@@ -1,10 +1,64 @@
1
+ import { __awaiter } from "tslib";
1
2
  import { Component, HostBinding, ViewEncapsulation } from '@angular/core';
2
3
  import { TransactionPaymentBaseComponent } from '../core/base/transaction-payment-base.component';
3
4
  import { TransactionPaymentService } from '../../service/transaction-payment.service';
5
+ import { CashDrawersRequest } from "@colijnit/transactionapi/build/model/cash-drawers-request";
4
6
  export class PaymentComponent extends TransactionPaymentBaseComponent {
5
7
  constructor() {
6
8
  super(...arguments);
7
9
  this.showClass = true;
10
+ this.cashRegisters = [];
11
+ this.cashDrawers = [];
12
+ }
13
+ ngOnInit() {
14
+ const _super = Object.create(null, {
15
+ ngOnInit: { get: () => super.ngOnInit }
16
+ });
17
+ return __awaiter(this, void 0, void 0, function* () {
18
+ yield _super.ngOnInit.call(this);
19
+ yield this._prepareCashRegister();
20
+ });
21
+ }
22
+ handleDrawerChanged(cashDrawer) {
23
+ this.activeCashDrawer = cashDrawer;
24
+ this.cashRegisterDrawerId = cashDrawer.id;
25
+ }
26
+ cashRegisterSelected(cashRegister, index) {
27
+ this.cashRegisterIdx = index;
28
+ this.cashRegisterNr = cashRegister.nr;
29
+ this.cashRegisterGroupId = cashRegister.group;
30
+ this.cashRegisterDrawerId = +cashRegister.defaultDrawerNumber;
31
+ this.activeCashRegister = cashRegister;
32
+ this._getCashDrawers(this.activeCashRegister.group).then(() => this._checkDefaultParameters(this.activeCashRegister));
33
+ }
34
+ _getCashDrawers(group) {
35
+ return __awaiter(this, void 0, void 0, function* () {
36
+ const cashDrawersRequest = new CashDrawersRequest();
37
+ cashDrawersRequest.group = group;
38
+ this.cashDrawers = yield this.transactionService.getCashDrawers(cashDrawersRequest);
39
+ this.changeDetector.detectChanges();
40
+ });
41
+ }
42
+ _checkDefaultParameters(cashRegister) {
43
+ this.activeCashDrawer = null;
44
+ if (cashRegister.defaultDrawerNumber) {
45
+ const defaultCashDrawer = this.cashDrawers.find((drawer) => drawer.nr === cashRegister.defaultDrawerNumber);
46
+ this.activeCashDrawer = defaultCashDrawer ? defaultCashDrawer : this.activeCashDrawer;
47
+ }
48
+ }
49
+ _prepareCashRegister() {
50
+ return __awaiter(this, void 0, void 0, function* () {
51
+ yield this._getCashRegistersDrawers(this.transactionService.currentBranch);
52
+ });
53
+ }
54
+ _getCashRegistersDrawers(branch) {
55
+ return __awaiter(this, void 0, void 0, function* () {
56
+ this.cashRegisters = yield this.transactionService.getCashRegisters(branch);
57
+ if (this.cashRegisters.length > 0) {
58
+ this.activeCashRegister = this.cashRegisters[0];
59
+ yield this._getCashDrawers(this.activeCashRegister.group);
60
+ }
61
+ });
8
62
  }
9
63
  }
10
64
  PaymentComponent.decorators = [
@@ -43,6 +97,17 @@ PaymentComponent.decorators = [
43
97
  (selectedChange)="cashRegisterSelected(cashRegister, index)"
44
98
  ></co-payment-tile>
45
99
  </div>
100
+
101
+ <co-list-of-values [label]="'CASH_DRAWER' | localize"
102
+ [(model)]="activeCashDrawer"
103
+ [displayField]="'nr'"
104
+ [collection]="cashDrawers"
105
+ [multiselect]="false"
106
+ [required]="false"
107
+ [searchDisabled]="true"
108
+ (modelChange)="handleDrawerChanged($event)"
109
+ ></co-list-of-values>
110
+
46
111
  </div>
47
112
  </div>
48
113
  <div class="payment-to-pay-wrapper">
@@ -53,12 +118,15 @@ PaymentComponent.decorators = [
53
118
  </div>
54
119
  <div class="payment-input-button-wrapper">
55
120
  <div class="payment-input-button">
56
- <co-payment-to-pay [amountToPay]="remainingPayment ? amount : paymentService.amountToPay"></co-payment-to-pay>
57
- <div class="payment-to-pay-button">
58
- <co-button [iconData]="iconCacheService.getIcon(icons.CheckDuotone)" (click)="handlePayment()" [disabled]="paymentService.amountToPay === 0"></co-button>
59
- </div>
121
+ <co-payment-to-pay
122
+ [amountToPay]="remainingPayment ? amount : paymentService.amountToPay"></co-payment-to-pay>
123
+ <div class="payment-to-pay-button">
124
+ <co-button [iconData]="iconCacheService.getIcon(icons.CheckDuotone)" (click)="handlePayment()"
125
+ [disabled]="paymentService.amountToPay === 0"></co-button>
126
+ </div>
60
127
  </div>
61
- <div class="payment-error-message" *ngIf="paymentService.statusMessage" [textContent]="paymentService.statusMessage"></div>
128
+ <div class="payment-error-message" *ngIf="paymentService.statusMessage"
129
+ [textContent]="paymentService.statusMessage"></div>
62
130
  </div>
63
131
  </div>
64
132
 
@@ -76,7 +144,7 @@ PaymentComponent.decorators = [
76
144
  </div>
77
145
  <co-dialog *ngIf="paymentService.showPspQrCode" (closeClick)="paymentService.showPspQrCode = false">
78
146
  <co-payment-qr-code
79
- [qrCodeImage]="paymentService.qrCodeImage"
147
+ [qrCodeImage]="paymentService.qrCodeImage"
80
148
  ></co-payment-qr-code>
81
149
  </co-dialog>
82
150
  `,
@@ -89,4 +157,4 @@ PaymentComponent.decorators = [
89
157
  PaymentComponent.propDecorators = {
90
158
  showClass: [{ type: HostBinding, args: ["class.co-payment",] }]
91
159
  };
92
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9wYXltZW50L3BheW1lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBQ2hHLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBK0VwRixNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsK0JBQStCO0lBN0VyRTs7UUFnRlMsY0FBUyxHQUFZLElBQUksQ0FBQztJQUVuQyxDQUFDOzs7WUFsRkEsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxZQUFZO2dCQUN0QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFFVDtnQkFDRCxTQUFTLEVBQUU7b0JBQ1QseUJBQXlCO2lCQUMxQjtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN0Qzs7O3dCQUdFLFdBQVcsU0FBQyxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSG9zdEJpbmRpbmcsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtUcmFuc2FjdGlvblBheW1lbnRCYXNlQ29tcG9uZW50fSBmcm9tICcuLi9jb3JlL2Jhc2UvdHJhbnNhY3Rpb24tcGF5bWVudC1iYXNlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7VHJhbnNhY3Rpb25QYXltZW50U2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZS90cmFuc2FjdGlvbi1wYXltZW50LnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiY28tcGF5bWVudFwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZGl2IGNsYXNzPVwicGF5bWVudC13cmFwcGVyXCI+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJwYXltZW50LW1ldGhvZHMtcmVnaXN0ZXItd3JhcHBlclwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJwYXltZW50LW1ldGhvZHMtd3JhcHBlclwiPlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cInBheW1lbnQtbWV0aG9kcy1oZWFkZXJcIj5cclxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJwYXltZW50LWhlYWRlci10aXRsZVwiIFt0ZXh0Q29udGVudF09XCInU0VMRUNUJyB8IGxvY2FsaXplXCI+PC9zcGFuPlxyXG4gICAgICAgICAgICA8IS0tc3BhbiBjbGFzcz1cInBheW1lbnQtaGVhZGVyLXRpdGxlIGV4dHJhXCIgW3RleHRDb250ZW50XT1cIidGUkVFJyB8IGxvY2FsaXplOmZhbHNlXCI+PC9zcGFuLS0+XHJcbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwicGF5bWVudC1oZWFkZXItdGl0bGVcIiBbdGV4dENvbnRlbnRdPVwiJ1BBWU1FTlRfTUVUSE9EJyB8IGxvY2FsaXplOmZhbHNlXCI+PC9zcGFuPlxyXG4gICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwicGF5bWVudC1tZXRob2RzIGNvLXNtYWxsLXNjcm9sbGJhclwiPlxyXG4gICAgICAgICAgICA8Y28tbG9hZGVyIGNsYXNzPVwibG9hZGVyXCIgKm5nSWY9XCJzaG93TG9hZGVyXCI+PC9jby1sb2FkZXI+XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhc2hvd0xvYWRlclwiPlxyXG4gICAgICAgICAgICAgIDxjby1wYXltZW50LXRpbGUgKm5nRm9yPVwibGV0IHBheW1lbnRNZXRob2Qgb2YgcGF5bWVudE1ldGhvZHM7IGxldCBpbmRleCA9IGluZGV4XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtpbWFnZV09XCJwYXltZW50TWV0aG9kLmltYWdlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtkZXNjcmlwdGlvbl09XCJwYXltZW50TWV0aG9kLnBheW1lbnQuZGVzY3JpcHRpb25cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW3NlbGVjdGVkXT1cInBheW1lbnRNZXRob2RJZHggPT09IGluZGV4XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIChzZWxlY3RlZENoYW5nZSk9XCJwYXltZW50TWV0aG9kU2VsZWN0ZWQocGF5bWVudE1ldGhvZC5wYXltZW50LCBpbmRleClcIlxyXG4gICAgICAgICAgICAgID48L2NvLXBheW1lbnQtdGlsZT5cclxuICAgICAgICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwicGF5bWVudC1jYXNoLXJlZ2lzdGVyLXdyYXBwZXJcIiAqbmdJZj1cInNob3dDYXNoUmVnaXN0ZXJzXCI+XHJcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwicGF5bWVudC1jYXNoLXJlZ2lzdGVyLWhlYWRlclwiPlxyXG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInBheW1lbnQtaGVhZGVyLXRpdGxlXCIgW3RleHRDb250ZW50XT1cIidTRUxFQ1RfQ0FTSF9SRUdJU1RFUicgfCBsb2NhbGl6ZVwiPjwvc3Bhbj5cclxuICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cInBheW1lbnQtbWV0aG9kc1wiPlxyXG4gICAgICAgICAgICA8Y28tcGF5bWVudC10aWxlICpuZ0Zvcj1cImxldCBjYXNoUmVnaXN0ZXIgb2YgY2FzaFJlZ2lzdGVyczsgbGV0IGluZGV4ID0gaW5kZXhcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtpY29uXT1cImNhc2hSZWdpc3Rlci5pY29uXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbZGVzY3JpcHRpb25dPVwiY2FzaFJlZ2lzdGVyLmRlc2NyaXB0aW9uXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc2VsZWN0ZWRdPVwiY2FzaFJlZ2lzdGVySWR4ID09PSBpbmRleFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKHNlbGVjdGVkQ2hhbmdlKT1cImNhc2hSZWdpc3RlclNlbGVjdGVkKGNhc2hSZWdpc3RlciwgaW5kZXgpXCJcclxuICAgICAgICAgICAgPjwvY28tcGF5bWVudC10aWxlPlxyXG4gICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8ZGl2IGNsYXNzPVwicGF5bWVudC10by1wYXktd3JhcHBlclwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJwYXltZW50LXRvLXBheS10b3RhbFwiPlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cInBheW1lbnQtdG8tcGF5LWhlYWRlclwiPlxyXG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInBheW1lbnQtaGVhZGVyLXRpdGxlXCIgW3RleHRDb250ZW50XT1cIidUT1RBTF9BTU9VTlRfVE9fUEFZJyB8IGxvY2FsaXplXCI+PC9zcGFuPlxyXG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInBheW1lbnQtdG90YWwtcGF5XCIgW3RleHRDb250ZW50XT1cImFtb3VudCA9PT0gMCA/IGFtb3VudCA6IChhbW91bnQgfCBjb0N1cnJlbmN5KVwiPjwvc3Bhbj5cclxuICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cInBheW1lbnQtaW5wdXQtYnV0dG9uLXdyYXBwZXJcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInBheW1lbnQtaW5wdXQtYnV0dG9uXCI+XHJcbiAgICAgICAgICAgICAgICA8Y28tcGF5bWVudC10by1wYXkgW2Ftb3VudFRvUGF5XT1cInJlbWFpbmluZ1BheW1lbnQgPyBhbW91bnQgOiBwYXltZW50U2VydmljZS5hbW91bnRUb1BheVwiPjwvY28tcGF5bWVudC10by1wYXk+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwicGF5bWVudC10by1wYXktYnV0dG9uXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGNvLWJ1dHRvbiBbaWNvbkRhdGFdPVwiaWNvbkNhY2hlU2VydmljZS5nZXRJY29uKGljb25zLkNoZWNrRHVvdG9uZSlcIiAoY2xpY2spPVwiaGFuZGxlUGF5bWVudCgpXCIgW2Rpc2FibGVkXT1cInBheW1lbnRTZXJ2aWNlLmFtb3VudFRvUGF5ID09PSAwXCI+PC9jby1idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJwYXltZW50LWVycm9yLW1lc3NhZ2VcIiAqbmdJZj1cInBheW1lbnRTZXJ2aWNlLnN0YXR1c01lc3NhZ2VcIiBbdGV4dENvbnRlbnRdPVwicGF5bWVudFNlcnZpY2Uuc3RhdHVzTWVzc2FnZVwiPjwvZGl2PlxyXG4gICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJwYXltZW50LWRlcG9zaXRcIj5cclxuICAgICAgICAgIDxjby1kZXBvc2l0LXBheW1lbnQgW2JyYW5jaF09XCJicmFuY2hcIiBbdHJhbnNhY3Rpb25VdWlkXT1cInRyYW5zYWN0aW9uVXVpZFwiPjwvY28tZGVwb3NpdC1wYXltZW50PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxjby1rZXktcGFkIGNsYXNzPVwicGF5bWVudC10by1wYXkta2V5cGFkXCIgKm5nSWY9XCJzaG93S2V5UGFkXCJcclxuICAgICAgICAgICAgICAgICAgICBbc2hvd1ZhbHVlXT1cImZhbHNlXCJcclxuICAgICAgICAgICAgICAgICAgICBbZW1pdE1vZGVsQ2hhbmdlT25FbnRlcl09XCJmYWxzZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgW21vZGVsXT1cInBheW1lbnRTZXJ2aWNlLmFtb3VudFRvUGF5XCJcclxuICAgICAgICAgICAgICAgICAgICAobW9kZWxDaGFuZ2UpPVwiaGFuZGxlS2V5UGFkTW9kZWxDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAgICAgKGVudGVyQ2xpY2spPVwiaGFuZGxlUGF5bWVudCgpXCJcclxuICAgICAgICA+PC9jby1rZXktcGFkPlxyXG4gICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG4gICAgPGNvLWRpYWxvZyAqbmdJZj1cInBheW1lbnRTZXJ2aWNlLnNob3dQc3BRckNvZGVcIiAoY2xvc2VDbGljayk9XCJwYXltZW50U2VydmljZS5zaG93UHNwUXJDb2RlID0gZmFsc2VcIj5cclxuICAgICAgPGNvLXBheW1lbnQtcXItY29kZVxyXG4gICAgICAgICAgW3FyQ29kZUltYWdlXT1cInBheW1lbnRTZXJ2aWNlLnFyQ29kZUltYWdlXCJcclxuICAgICAgPjwvY28tcGF5bWVudC1xci1jb2RlPlxyXG4gICAgPC9jby1kaWFsb2c+XHJcbiAgYCxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIFRyYW5zYWN0aW9uUGF5bWVudFNlcnZpY2VcclxuICBdLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIFBheW1lbnRDb21wb25lbnQgZXh0ZW5kcyBUcmFuc2FjdGlvblBheW1lbnRCYXNlQ29tcG9uZW50IHtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28tcGF5bWVudFwiKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3M6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxufVxyXG4iXX0=
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"payment.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/payment/payment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, OnInit, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionPaymentBaseComponent} from '../core/base/transaction-payment-base.component';\r\nimport {TransactionPaymentService} from '../../service/transaction-payment.service';\r\nimport {CashDrawer} from \"@colijnit/transactionapi/build/model/cash-drawer.bo\";\r\nimport {CashRegister} from \"@colijnit/transactionapi/build/model/cash-register\";\r\nimport {CashDrawersRequest} from \"@colijnit/transactionapi/build/model/cash-drawers-request\";\r\n\r\n@Component({\r\n  selector: \"co-payment\",\r\n  template: `\r\n    <div class=\"payment-wrapper\">\r\n      <div class=\"payment-methods-register-wrapper\">\r\n        <div class=\"payment-methods-wrapper\">\r\n          <div class=\"payment-methods-header\">\r\n            <span class=\"payment-header-title\" [textContent]=\"'SELECT' | localize\"></span>\r\n            <!--span class=\"payment-header-title extra\" [textContent]=\"'FREE' | localize:false\"></span-->\r\n            <span class=\"payment-header-title\" [textContent]=\"'PAYMENT_METHOD' | localize:false\"></span>\r\n          </div>\r\n          <div class=\"payment-methods co-small-scrollbar\">\r\n            <co-loader class=\"loader\" *ngIf=\"showLoader\"></co-loader>\r\n            <ng-container *ngIf=\"!showLoader\">\r\n              <co-payment-tile *ngFor=\"let paymentMethod of paymentMethods; let index = index\"\r\n                               [image]=\"paymentMethod.image\"\r\n                               [description]=\"paymentMethod.payment.description\"\r\n                               [selected]=\"paymentMethodIdx === index\"\r\n                               (selectedChange)=\"paymentMethodSelected(paymentMethod.payment, index)\"\r\n              ></co-payment-tile>\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n        <div class=\"payment-cash-register-wrapper\" *ngIf=\"showCashRegisters\">\r\n          <div class=\"payment-cash-register-header\">\r\n            <span class=\"payment-header-title\" [textContent]=\"'SELECT_CASH_REGISTER' | localize\"></span>\r\n          </div>\r\n          <div class=\"payment-methods\">\r\n            <co-payment-tile *ngFor=\"let cashRegister of cashRegisters; let index = index\"\r\n                             [icon]=\"cashRegister.icon\"\r\n                             [description]=\"cashRegister.description\"\r\n                             [selected]=\"cashRegisterIdx === index\"\r\n                             (selectedChange)=\"cashRegisterSelected(cashRegister, index)\"\r\n            ></co-payment-tile>\r\n          </div>\r\n\r\n          <co-list-of-values [label]=\"'CASH_DRAWER' | localize\"\r\n                             [(model)]=\"activeCashDrawer\"\r\n                             [displayField]=\"'nr'\"\r\n                             [collection]=\"cashDrawers\"\r\n                             [multiselect]=\"false\"\r\n                             [required]=\"false\"\r\n                             [searchDisabled]=\"true\"\r\n                             (modelChange)=\"handleDrawerChanged($event)\"\r\n          ></co-list-of-values>\r\n\r\n        </div>\r\n      </div>\r\n      <div class=\"payment-to-pay-wrapper\">\r\n        <div class=\"payment-to-pay-total\">\r\n          <div class=\"payment-to-pay-header\">\r\n            <span class=\"payment-header-title\" [textContent]=\"'TOTAL_AMOUNT_TO_PAY' | localize\"></span>\r\n            <span class=\"payment-total-pay\" [textContent]=\"amount === 0 ? amount : (amount | coCurrency)\"></span>\r\n          </div>\r\n          <div class=\"payment-input-button-wrapper\">\r\n            <div class=\"payment-input-button\">\r\n              <co-payment-to-pay\r\n                [amountToPay]=\"remainingPayment ? amount : paymentService.amountToPay\"></co-payment-to-pay>\r\n              <div class=\"payment-to-pay-button\">\r\n                <co-button [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\" (click)=\"handlePayment()\"\r\n                           [disabled]=\"paymentService.amountToPay === 0\"></co-button>\r\n              </div>\r\n            </div>\r\n            <div class=\"payment-error-message\" *ngIf=\"paymentService.statusMessage\"\r\n                 [textContent]=\"paymentService.statusMessage\"></div>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"payment-deposit\">\r\n          <co-deposit-payment [branch]=\"branch\" [transactionUuid]=\"transactionUuid\"></co-deposit-payment>\r\n        </div>\r\n        <co-key-pad class=\"payment-to-pay-keypad\" *ngIf=\"showKeyPad\"\r\n                    [showValue]=\"false\"\r\n                    [emitModelChangeOnEnter]=\"false\"\r\n                    [model]=\"paymentService.amountToPay\"\r\n                    (modelChange)=\"handleKeyPadModelChange($event)\"\r\n                    (enterClick)=\"handlePayment()\"\r\n        ></co-key-pad>\r\n      </div>\r\n    </div>\r\n    <co-dialog *ngIf=\"paymentService.showPspQrCode\" (closeClick)=\"paymentService.showPspQrCode = false\">\r\n      <co-payment-qr-code\r\n        [qrCodeImage]=\"paymentService.qrCodeImage\"\r\n      ></co-payment-qr-code>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    TransactionPaymentService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class PaymentComponent extends TransactionPaymentBaseComponent implements OnInit {\r\n\r\n  @HostBinding(\"class.co-payment\")\r\n  public showClass: boolean = true;\r\n\r\n  public cashRegisters: any[] = [];\r\n  public activeCashRegister: CashRegister;\r\n  public cashDrawers: CashDrawer[] = [];\r\n  public activeCashDrawer: CashDrawer;\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    await super.ngOnInit();\r\n    await this._prepareCashRegister();\r\n  }\r\n\r\n  public handleDrawerChanged(cashDrawer: CashDrawer): void {\r\n    this.activeCashDrawer = cashDrawer;\r\n    this.cashRegisterDrawerId = cashDrawer.id\r\n  }\r\n\r\n  public cashRegisterSelected(cashRegister: CashRegister, index: number) {\r\n    this.cashRegisterIdx = index;\r\n    this.cashRegisterNr = cashRegister.nr;\r\n    this.cashRegisterGroupId = cashRegister.group;\r\n    this.cashRegisterDrawerId = +cashRegister.defaultDrawerNumber;\r\n    this.activeCashRegister = cashRegister;\r\n    this._getCashDrawers(this.activeCashRegister.group).then(() => this._checkDefaultParameters(this.activeCashRegister));\r\n  }\r\n\r\n  private async _getCashDrawers(group: number): Promise<void> {\r\n    const cashDrawersRequest: CashDrawersRequest = new CashDrawersRequest();\r\n    cashDrawersRequest.group = group;\r\n    this.cashDrawers = await this.transactionService.getCashDrawers(cashDrawersRequest);\r\n    this.changeDetector.detectChanges();\r\n  }\r\n\r\n  private _checkDefaultParameters(cashRegister: CashRegister): void {\r\n    this.activeCashDrawer = null;\r\n    if (cashRegister.defaultDrawerNumber) {\r\n      const defaultCashDrawer: CashDrawer = this.cashDrawers.find((drawer: CashDrawer) => drawer.nr === cashRegister.defaultDrawerNumber);\r\n      this.activeCashDrawer = defaultCashDrawer ? defaultCashDrawer : this.activeCashDrawer;\r\n    }\r\n  }\r\n\r\n  private async _prepareCashRegister(): Promise<void> {\r\n    await this._getCashRegistersDrawers(this.transactionService.currentBranch);\r\n  }\r\n\r\n  private async _getCashRegistersDrawers(branch: string): Promise<void> {\r\n    this.cashRegisters = await this.transactionService.getCashRegisters(branch);\r\n    if (this.cashRegisters.length > 0) {\r\n      this.activeCashRegister = this.cashRegisters[0];\r\n      await this._getCashDrawers(this.activeCashRegister.group);\r\n    }\r\n  }\r\n}\r\n"]}
@@ -4,7 +4,7 @@ import { PaymentComponent } from "./payment.component";
4
4
  import { CoreModule } from "../core/core.module";
5
5
  import { PipeModule } from "../../pipe/pipe.module";
6
6
  import { PaymentTileModule } from "../payment-tile/payment-tile.module";
7
- import { ButtonModule, CoDialogModule, IconModule, PriceDisplayPipeModule } from "@colijnit/corecomponents_v12";
7
+ import { ButtonModule, CoDialogModule, IconModule, ListOfValuesModule, PriceDisplayPipeModule } from "@colijnit/corecomponents_v12";
8
8
  import { KeyPadModule } from "@colijnit/sharedcomponents";
9
9
  import { PaymentQrCodeModule } from "../payment-qr-code/payment-qr-code.module";
10
10
  import { LoaderModule } from "../loader/loader.module";
@@ -27,7 +27,8 @@ PaymentModule.decorators = [
27
27
  DepositPaymentModule,
28
28
  LoaderModule,
29
29
  PaymentToPayModule,
30
- IconModule
30
+ IconModule,
31
+ ListOfValuesModule
31
32
  ],
32
33
  declarations: [
33
34
  PaymentComponent
@@ -37,4 +38,4 @@ PaymentModule.decorators = [
37
38
  ]
38
39
  },] }
39
40
  ];
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9wYXltZW50L3BheW1lbnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDbEQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFDLFlBQVksRUFBRSxjQUFjLEVBQUUsVUFBVSxFQUFFLHNCQUFzQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDOUcsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNyRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQXlCM0UsTUFBTSxPQUFPLGFBQWE7OztZQXZCekIsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLFVBQVU7b0JBQ1YsVUFBVTtvQkFDVixpQkFBaUI7b0JBQ2pCLHNCQUFzQjtvQkFDdEIsWUFBWTtvQkFDWixjQUFjO29CQUNkLFlBQVk7b0JBQ1osbUJBQW1CO29CQUNuQixvQkFBb0I7b0JBQ3BCLFlBQVk7b0JBQ1osa0JBQWtCO29CQUNsQixVQUFVO2lCQUNiO2dCQUNILFlBQVksRUFBRTtvQkFDWixnQkFBZ0I7aUJBQ2pCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxnQkFBZ0I7aUJBQ2pCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge1BheW1lbnRDb21wb25lbnR9IGZyb20gXCIuL3BheW1lbnQuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7Q29yZU1vZHVsZX0gZnJvbSBcIi4uL2NvcmUvY29yZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtQaXBlTW9kdWxlfSBmcm9tIFwiLi4vLi4vcGlwZS9waXBlLm1vZHVsZVwiO1xyXG5pbXBvcnQge1BheW1lbnRUaWxlTW9kdWxlfSBmcm9tIFwiLi4vcGF5bWVudC10aWxlL3BheW1lbnQtdGlsZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtCdXR0b25Nb2R1bGUsIENvRGlhbG9nTW9kdWxlLCBJY29uTW9kdWxlLCBQcmljZURpc3BsYXlQaXBlTW9kdWxlfSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMlwiO1xyXG5pbXBvcnQge0tleVBhZE1vZHVsZX0gZnJvbSBcIkBjb2xpam5pdC9zaGFyZWRjb21wb25lbnRzXCI7XHJcbmltcG9ydCB7UGF5bWVudFFyQ29kZU1vZHVsZX0gZnJvbSBcIi4uL3BheW1lbnQtcXItY29kZS9wYXltZW50LXFyLWNvZGUubW9kdWxlXCI7XHJcbmltcG9ydCB7TG9hZGVyTW9kdWxlfSBmcm9tIFwiLi4vbG9hZGVyL2xvYWRlci5tb2R1bGVcIjtcclxuaW1wb3J0IHtEZXBvc2l0UGF5bWVudE1vZHVsZX0gZnJvbSBcIi4uL2RlcG9zaXQtcGF5bWVudC9kZXBvc2l0LXBheW1lbnQubW9kdWxlXCI7XHJcbmltcG9ydCB7UGF5bWVudFRvUGF5TW9kdWxlfSBmcm9tIFwiLi4vcGF5bWVudC10by1wYXkvcGF5bWVudC10by1wYXkubW9kdWxlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBDb3JlTW9kdWxlLFxyXG4gICAgICAgIFBpcGVNb2R1bGUsXHJcbiAgICAgICAgUGF5bWVudFRpbGVNb2R1bGUsXHJcbiAgICAgICAgUHJpY2VEaXNwbGF5UGlwZU1vZHVsZSxcclxuICAgICAgICBLZXlQYWRNb2R1bGUsXHJcbiAgICAgICAgQ29EaWFsb2dNb2R1bGUsXHJcbiAgICAgICAgQnV0dG9uTW9kdWxlLFxyXG4gICAgICAgIFBheW1lbnRRckNvZGVNb2R1bGUsXHJcbiAgICAgICAgRGVwb3NpdFBheW1lbnRNb2R1bGUsXHJcbiAgICAgICAgTG9hZGVyTW9kdWxlLFxyXG4gICAgICAgIFBheW1lbnRUb1BheU1vZHVsZSxcclxuICAgICAgICBJY29uTW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgUGF5bWVudENvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgUGF5bWVudENvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFBheW1lbnRNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9wYXltZW50L3BheW1lbnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDbEQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUNMLFlBQVksRUFDWixjQUFjLEVBQ2QsVUFBVSxFQUNWLGtCQUFrQixFQUNsQixzQkFBc0IsRUFDdkIsTUFBTSw4QkFBOEIsQ0FBQztBQUN0QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDeEQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDOUUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBMEIzRSxNQUFNLE9BQU8sYUFBYTs7O1lBeEJ6QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixVQUFVO29CQUNWLGlCQUFpQjtvQkFDakIsc0JBQXNCO29CQUN0QixZQUFZO29CQUNaLGNBQWM7b0JBQ2QsWUFBWTtvQkFDWixtQkFBbUI7b0JBQ25CLG9CQUFvQjtvQkFDcEIsWUFBWTtvQkFDWixrQkFBa0I7b0JBQ2xCLFVBQVU7b0JBQ1Ysa0JBQWtCO2lCQUNuQjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1osZ0JBQWdCO2lCQUNqQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsZ0JBQWdCO2lCQUNqQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtQYXltZW50Q29tcG9uZW50fSBmcm9tIFwiLi9wYXltZW50LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0NvcmVNb2R1bGV9IGZyb20gXCIuLi9jb3JlL2NvcmUubW9kdWxlXCI7XHJcbmltcG9ydCB7UGlwZU1vZHVsZX0gZnJvbSBcIi4uLy4uL3BpcGUvcGlwZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtQYXltZW50VGlsZU1vZHVsZX0gZnJvbSBcIi4uL3BheW1lbnQtdGlsZS9wYXltZW50LXRpbGUubW9kdWxlXCI7XHJcbmltcG9ydCB7XHJcbiAgQnV0dG9uTW9kdWxlLFxyXG4gIENvRGlhbG9nTW9kdWxlLFxyXG4gIEljb25Nb2R1bGUsXHJcbiAgTGlzdE9mVmFsdWVzTW9kdWxlLFxyXG4gIFByaWNlRGlzcGxheVBpcGVNb2R1bGVcclxufSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMlwiO1xyXG5pbXBvcnQge0tleVBhZE1vZHVsZX0gZnJvbSBcIkBjb2xpam5pdC9zaGFyZWRjb21wb25lbnRzXCI7XHJcbmltcG9ydCB7UGF5bWVudFFyQ29kZU1vZHVsZX0gZnJvbSBcIi4uL3BheW1lbnQtcXItY29kZS9wYXltZW50LXFyLWNvZGUubW9kdWxlXCI7XHJcbmltcG9ydCB7TG9hZGVyTW9kdWxlfSBmcm9tIFwiLi4vbG9hZGVyL2xvYWRlci5tb2R1bGVcIjtcclxuaW1wb3J0IHtEZXBvc2l0UGF5bWVudE1vZHVsZX0gZnJvbSBcIi4uL2RlcG9zaXQtcGF5bWVudC9kZXBvc2l0LXBheW1lbnQubW9kdWxlXCI7XHJcbmltcG9ydCB7UGF5bWVudFRvUGF5TW9kdWxlfSBmcm9tIFwiLi4vcGF5bWVudC10by1wYXkvcGF5bWVudC10by1wYXkubW9kdWxlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIENvcmVNb2R1bGUsXHJcbiAgICBQaXBlTW9kdWxlLFxyXG4gICAgUGF5bWVudFRpbGVNb2R1bGUsXHJcbiAgICBQcmljZURpc3BsYXlQaXBlTW9kdWxlLFxyXG4gICAgS2V5UGFkTW9kdWxlLFxyXG4gICAgQ29EaWFsb2dNb2R1bGUsXHJcbiAgICBCdXR0b25Nb2R1bGUsXHJcbiAgICBQYXltZW50UXJDb2RlTW9kdWxlLFxyXG4gICAgRGVwb3NpdFBheW1lbnRNb2R1bGUsXHJcbiAgICBMb2FkZXJNb2R1bGUsXHJcbiAgICBQYXltZW50VG9QYXlNb2R1bGUsXHJcbiAgICBJY29uTW9kdWxlLFxyXG4gICAgTGlzdE9mVmFsdWVzTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFBheW1lbnRDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFBheW1lbnRDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYXltZW50TW9kdWxlIHtcclxuXHJcbn1cclxuIl19
@@ -9,6 +9,7 @@ export class RelationContactDetailsComponent extends RelationBaseComponent {
9
9
  super(...arguments);
10
10
  this.readonly = false;
11
11
  this.showPhone = true;
12
+ this.showInviteForAccount = true;
12
13
  this.relationKind = RelationKind.Customer;
13
14
  this.emailAddress = new ContactOption();
14
15
  this.phoneNumber = new ContactOption();
@@ -66,7 +67,7 @@ RelationContactDetailsComponent.decorators = [
66
67
  [(relation)]="relation"
67
68
  ></co-relation-contact-options>
68
69
  <div class="default-data-row" *ngIf="relationKind === relKind.Customer">
69
- <co-input-checkbox
70
+ <co-input-checkbox *ngIf="showInviteForAccount"
70
71
  [screenConfigurationObject]="configNames?.relationInviteToAccount"
71
72
  [readonly]="readonly"
72
73
  [label]="'INVITE_TO_ACCOUNT' | localize"
@@ -81,7 +82,8 @@ RelationContactDetailsComponent.propDecorators = {
81
82
  configNames: [{ type: Input }],
82
83
  readonly: [{ type: Input }],
83
84
  showPhone: [{ type: Input }],
85
+ showInviteForAccount: [{ type: Input }],
84
86
  relationKind: [{ type: Input }],
85
87
  showClass: [{ type: HostBinding, args: ["class.co-relation-contact-details",] }]
86
88
  };
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-contact-details/relation-contact-details.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, ViewEncapsulation} from '@angular/core';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {isNill} from '@colijnit/ioneconnector/build/utils/function/is-nill.function';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\nimport {RelationContactDetailsCfgNames} from '../../../interface/relation-contact-details-cfg-names.interface';\r\nimport {CustomerFullObject} from '@colijnit/relationapi/build/model/customer-full-object.bo';\r\n\r\n@Component({\r\n  selector: \"co-relation-contact-details\",\r\n  template: `\r\n      <co-relation-contact-options\r\n              [(relation)]=\"relation\"\r\n      ></co-relation-contact-options>\r\n    <div class=\"default-data-row\" *ngIf=\"relationKind === relKind.Customer\">\r\n      <co-input-checkbox\r\n          [screenConfigurationObject]=\"configNames?.relationInviteToAccount\"\r\n          [readonly]=\"readonly\"\r\n          [label]=\"'INVITE_TO_ACCOUNT' | localize\"\r\n          [(model)]=\"inviteRelation\"\r\n          (modelChange)=\"handleCreateCustomerUserAndInviteMark($event)\"></co-input-checkbox>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactDetailsComponent extends RelationBaseComponent {\r\n\r\n  @Input()\r\n  public configNames: RelationContactDetailsCfgNames;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public showPhone: boolean = true;\r\n\r\n  @Input()\r\n  public relationKind: RelationKind = RelationKind.Customer;\r\n\r\n  @HostBinding(\"class.co-relation-contact-details\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public emailAddress: ContactOption = new ContactOption();\r\n  public phoneNumber: ContactOption = new ContactOption();\r\n  public inviteRelation: boolean = false;\r\n\r\n  public handlePhoneChange(): void {\r\n    const comPhone: ContactOption = this.relation.contactOptions.find(c => c.comNr === this.phoneNumber.comNr && c.type === CommunicationType.Telephone);\r\n    if (comPhone) {\r\n      comPhone.value = this.phoneNumber.value;\r\n    }\r\n    this._updateSuggestionGeneralRequest();\r\n  }\r\n\r\n  public handleEmailChange(): void {\r\n    const comEmail: ContactOption = this.relation.contactOptions.find(c => c.comNr === this.emailAddress.comNr && c.type === CommunicationType.Email);\r\n    if (comEmail) {\r\n      comEmail.value = this.emailAddress.value;\r\n    }\r\n    this._updateSuggestionGeneralRequest();\r\n  }\r\n\r\n  public preparePrimaryEmail(): void {\r\n    if (this.relation) {\r\n      this.emailAddress = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Email);\r\n    }\r\n  }\r\n\r\n  public preparePrimaryPhone(): void {\r\n    if (this.relation) {\r\n      this.phoneNumber = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Telephone);\r\n    }\r\n  }\r\n\r\n  public handleCreateCustomerUserAndInviteMark(checkMark: boolean): void {\r\n    this.inviteRelation = checkMark;\r\n    if (this.relation instanceof CustomerFullObject) {\r\n      this.relation.createUserAndSendInvite = this.inviteRelation;\r\n    }\r\n    this.inviteRelation = false;\r\n  }\r\n\r\n  protected relationSet() {\r\n    this.preparePrimaryEmail();\r\n    this.preparePrimaryPhone();\r\n  }\r\n\r\n  private _updateSuggestionGeneralRequest(): void {\r\n    this.suggestionRequest.general =\r\n        (this.phoneNumber.value ? this.phoneNumber.value : \"\") + (this.emailAddress.value ? \" \" : \"\") + (this.emailAddress.value ? this.emailAddress.value : \"\");\r\n    this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n  }\r\n\r\n}\r\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-contact-details/relation-contact-details.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, ViewEncapsulation} from '@angular/core';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {isNill} from '@colijnit/ioneconnector/build/utils/function/is-nill.function';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\nimport {RelationContactDetailsCfgNames} from '../../../interface/relation-contact-details-cfg-names.interface';\r\nimport {CustomerFullObject} from '@colijnit/relationapi/build/model/customer-full-object.bo';\r\n\r\n@Component({\r\n  selector: \"co-relation-contact-details\",\r\n  template: `\r\n      <co-relation-contact-options\r\n              [(relation)]=\"relation\"\r\n      ></co-relation-contact-options>\r\n    <div class=\"default-data-row\" *ngIf=\"relationKind === relKind.Customer\">\r\n      <co-input-checkbox *ngIf=\"showInviteForAccount\"\r\n          [screenConfigurationObject]=\"configNames?.relationInviteToAccount\"\r\n          [readonly]=\"readonly\"\r\n          [label]=\"'INVITE_TO_ACCOUNT' | localize\"\r\n          [(model)]=\"inviteRelation\"\r\n          (modelChange)=\"handleCreateCustomerUserAndInviteMark($event)\"></co-input-checkbox>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactDetailsComponent extends RelationBaseComponent {\r\n\r\n  @Input()\r\n  public configNames: RelationContactDetailsCfgNames;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public showPhone: boolean = true;\r\n\r\n  @Input()\r\n  public showInviteForAccount: boolean = true;\r\n\r\n  @Input()\r\n  public relationKind: RelationKind = RelationKind.Customer;\r\n\r\n  @HostBinding(\"class.co-relation-contact-details\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public emailAddress: ContactOption = new ContactOption();\r\n  public phoneNumber: ContactOption = new ContactOption();\r\n  public inviteRelation: boolean = false;\r\n\r\n  public handlePhoneChange(): void {\r\n    const comPhone: ContactOption = this.relation.contactOptions.find(c => c.comNr === this.phoneNumber.comNr && c.type === CommunicationType.Telephone);\r\n    if (comPhone) {\r\n      comPhone.value = this.phoneNumber.value;\r\n    }\r\n    this._updateSuggestionGeneralRequest();\r\n  }\r\n\r\n  public handleEmailChange(): void {\r\n    const comEmail: ContactOption = this.relation.contactOptions.find(c => c.comNr === this.emailAddress.comNr && c.type === CommunicationType.Email);\r\n    if (comEmail) {\r\n      comEmail.value = this.emailAddress.value;\r\n    }\r\n    this._updateSuggestionGeneralRequest();\r\n  }\r\n\r\n  public preparePrimaryEmail(): void {\r\n    if (this.relation) {\r\n      this.emailAddress = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Email);\r\n    }\r\n  }\r\n\r\n  public preparePrimaryPhone(): void {\r\n    if (this.relation) {\r\n      this.phoneNumber = this.relation.getLowestSequenceOfContactOptionsWithType(CommunicationType.Telephone);\r\n    }\r\n  }\r\n\r\n  public handleCreateCustomerUserAndInviteMark(checkMark: boolean): void {\r\n    this.inviteRelation = checkMark;\r\n    if (this.relation instanceof CustomerFullObject) {\r\n      this.relation.createUserAndSendInvite = this.inviteRelation;\r\n    }\r\n    this.inviteRelation = false;\r\n  }\r\n\r\n  protected relationSet() {\r\n    this.preparePrimaryEmail();\r\n    this.preparePrimaryPhone();\r\n  }\r\n\r\n  private _updateSuggestionGeneralRequest(): void {\r\n    this.suggestionRequest.general =\r\n        (this.phoneNumber.value ? this.phoneNumber.value : \"\") + (this.emailAddress.value ? \" \" : \"\") + (this.emailAddress.value ? this.emailAddress.value : \"\");\r\n    this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n  }\r\n\r\n}\r\n"]}
@@ -0,0 +1,58 @@
1
+ import { Component, forwardRef, HostBinding, ViewEncapsulation } from '@angular/core';
2
+ import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '@colijnit/corecomponents_v12';
3
+ import { StepperBaseComponent } from "../core/base/stepper-base.component";
4
+ export class SimpleVerticalStepperComponent extends StepperBaseComponent {
5
+ showClass() {
6
+ return true;
7
+ }
8
+ continueRequested() {
9
+ this.validateCurrentStep();
10
+ }
11
+ validateCurrentStep(nextStep) {
12
+ this.stepChildren[this.activeStep].onComplete = (complete) => {
13
+ if (complete) {
14
+ this.setActive(nextStep === undefined ? this.activeStep + 1 : nextStep);
15
+ }
16
+ };
17
+ this.stepChildren[this.activeStep].validateStep.next();
18
+ }
19
+ setActive(idx) {
20
+ const prevStep = this.stepChildren[idx - 1];
21
+ if (!prevStep || prevStep.completed) {
22
+ if (this.stepChildren) {
23
+ this.stepChildren[idx].show = true;
24
+ this.activeStep = idx;
25
+ }
26
+ }
27
+ }
28
+ }
29
+ SimpleVerticalStepperComponent.decorators = [
30
+ { type: Component, args: [{
31
+ selector: "co-simple-vertical-stepper",
32
+ template: `
33
+ <div class="simple-vertical-stepper-title">
34
+ <div class="simple-vertical-stepper-title-wrapper">
35
+ <co-icon class="title-icon" [iconData]="iconCacheService.getIcon(titleIcon)" ></co-icon> <!--[screenConfigurationObject]="cfgNames.Title" screenConfigNativeElement-->
36
+ <div class="title" [textContent]="title | localize"></div>
37
+ </div>
38
+ </div>
39
+ <div class="simple-vertical-stepper-content-wrapper">
40
+ <ng-content></ng-content>
41
+ </div>
42
+ <ng-container [ngTemplateOutlet]="buttonTemplate"></ng-container>
43
+ <ng-template #buttonTemplate>
44
+ <co-default-ok-cancel-buttons [hideCancel]="true"
45
+ (okClick)="continueRequested()"></co-default-ok-cancel-buttons>
46
+ </ng-template>
47
+ `,
48
+ providers: [{
49
+ provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
50
+ useExisting: forwardRef(() => SimpleVerticalStepperComponent)
51
+ }],
52
+ encapsulation: ViewEncapsulation.None
53
+ },] }
54
+ ];
55
+ SimpleVerticalStepperComponent.propDecorators = {
56
+ showClass: [{ type: HostBinding, args: ["class.co-simple-vertical-stepper",] }]
57
+ };
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY28tc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJhbnNhY3Rpb24vc3JjL2xpYi9jb21wb25lbnQvc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXIvY28tc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsVUFBVSxFQUNWLFdBQVcsRUFDWCxpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLDhDQUE4QyxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFFNUYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFnQ3pFLE1BQU0sT0FBTyw4QkFBK0IsU0FBUSxvQkFBb0I7SUFHL0QsU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVNLGlCQUFpQjtRQUN0QixJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRVMsbUJBQW1CLENBQUMsUUFBaUI7UUFDN0MsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsVUFBVSxHQUFHLENBQUMsUUFBaUIsRUFBRSxFQUFFO1lBQ3BFLElBQUksUUFBUSxFQUFFO2dCQUNaLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2FBQ3pFO1FBQ0gsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3pELENBQUM7SUFFUyxTQUFTLENBQUUsR0FBVztRQUM5QixNQUFNLFFBQVEsR0FBeUIsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDbEUsSUFBSSxDQUFDLFFBQVEsSUFBSSxRQUFRLENBQUMsU0FBUyxFQUFFO1lBQ25DLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtnQkFDckIsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO2dCQUNuQyxJQUFJLENBQUMsVUFBVSxHQUFHLEdBQUcsQ0FBQzthQUN2QjtTQUNGO0lBQ0gsQ0FBQzs7O1lBcERGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsNEJBQTRCO2dCQUN0QyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7OztHQWVUO2dCQUNELFNBQVMsRUFBRSxDQUFDO3dCQUNWLE9BQU8sRUFBRSw4Q0FBOEM7d0JBQ3ZELFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsOEJBQThCLENBQUM7cUJBQzlELENBQUM7Z0JBQ0YsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7YUFDdEM7Ozt3QkFHRSxXQUFXLFNBQUMsa0NBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb21wb25lbnQsXHJcbiAgZm9yd2FyZFJlZixcclxuICBIb3N0QmluZGluZyxcclxuICBWaWV3RW5jYXBzdWxhdGlvblxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1NDUkVFTl9DT05GSUdfQURBUFRFUl9DT01QT05FTlRfSU5URVJGQUNFX05BTUV9IGZyb20gJ0Bjb2xpam5pdC9jb3JlY29tcG9uZW50c192MTInO1xyXG5pbXBvcnQge1N0ZXBwZXJTdGVwQ29tcG9uZW50fSBmcm9tIFwiLi4vc3RlcHBlci1zdGVwL3N0ZXBwZXItc3RlcC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtTdGVwcGVyQmFzZUNvbXBvbmVudH0gZnJvbSBcIi4uL2NvcmUvYmFzZS9zdGVwcGVyLWJhc2UuY29tcG9uZW50XCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIHN0ZXBzIHtcclxuICBpbmRleDogbnVtYmVyO1xyXG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XHJcbiAgY29tcGxldGU6IGJvb2xlYW47XHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImNvLXNpbXBsZS12ZXJ0aWNhbC1zdGVwcGVyXCIsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgICAgPGRpdiBjbGFzcz1cInNpbXBsZS12ZXJ0aWNhbC1zdGVwcGVyLXRpdGxlXCI+XHJcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXItdGl0bGUtd3JhcHBlclwiPlxyXG4gICAgICAgICAgICAgIDxjby1pY29uIGNsYXNzPVwidGl0bGUtaWNvblwiIFtpY29uRGF0YV09XCJpY29uQ2FjaGVTZXJ2aWNlLmdldEljb24odGl0bGVJY29uKVwiID48L2NvLWljb24+IDwhLS1bc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdF09XCJjZmdOYW1lcy5UaXRsZVwiIHNjcmVlbkNvbmZpZ05hdGl2ZUVsZW1lbnQtLT5cclxuICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGl0bGVcIiBbdGV4dENvbnRlbnRdPVwidGl0bGUgfCBsb2NhbGl6ZVwiPjwvZGl2PlxyXG4gICAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8ZGl2IGNsYXNzPVwic2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXItY29udGVudC13cmFwcGVyXCI+XHJcbiAgICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImJ1dHRvblRlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICAgIDxuZy10ZW1wbGF0ZSAjYnV0dG9uVGVtcGxhdGU+XHJcbiAgICAgICAgICA8Y28tZGVmYXVsdC1vay1jYW5jZWwtYnV0dG9ucyBbaGlkZUNhbmNlbF09XCJ0cnVlXCJcclxuICAgICAgICAgIChva0NsaWNrKT1cImNvbnRpbnVlUmVxdWVzdGVkKClcIj48L2NvLWRlZmF1bHQtb2stY2FuY2VsLWJ1dHRvbnM+XHJcbiAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgYCxcclxuICBwcm92aWRlcnM6IFt7XHJcbiAgICBwcm92aWRlOiBTQ1JFRU5fQ09ORklHX0FEQVBURVJfQ09NUE9ORU5UX0lOVEVSRkFDRV9OQU1FLFxyXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gU2ltcGxlVmVydGljYWxTdGVwcGVyQ29tcG9uZW50KVxyXG4gIH1dLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIFNpbXBsZVZlcnRpY2FsU3RlcHBlckNvbXBvbmVudCBleHRlbmRzIFN0ZXBwZXJCYXNlQ29tcG9uZW50IHtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28tc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXJcIilcclxuICBwdWJsaWMgc2hvd0NsYXNzKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY29udGludWVSZXF1ZXN0ZWQoKTogdm9pZCB7XHJcbiAgICB0aGlzLnZhbGlkYXRlQ3VycmVudFN0ZXAoKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCB2YWxpZGF0ZUN1cnJlbnRTdGVwKG5leHRTdGVwPzogbnVtYmVyKTogdm9pZCB7XHJcbiAgICB0aGlzLnN0ZXBDaGlsZHJlblt0aGlzLmFjdGl2ZVN0ZXBdLm9uQ29tcGxldGUgPSAoY29tcGxldGU6IGJvb2xlYW4pID0+IHtcclxuICAgICAgaWYgKGNvbXBsZXRlKSB7XHJcbiAgICAgICAgdGhpcy5zZXRBY3RpdmUobmV4dFN0ZXAgPT09IHVuZGVmaW5lZCA/IHRoaXMuYWN0aXZlU3RlcCArIDEgOiBuZXh0U3RlcCk7XHJcbiAgICAgIH1cclxuICAgIH07XHJcbiAgICB0aGlzLnN0ZXBDaGlsZHJlblt0aGlzLmFjdGl2ZVN0ZXBdLnZhbGlkYXRlU3RlcC5uZXh0KCk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgc2V0QWN0aXZlIChpZHg6IG51bWJlcikge1xyXG4gICAgY29uc3QgcHJldlN0ZXA6IFN0ZXBwZXJTdGVwQ29tcG9uZW50ID0gdGhpcy5zdGVwQ2hpbGRyZW5baWR4IC0gMV07XHJcbiAgICBpZiAoIXByZXZTdGVwIHx8IHByZXZTdGVwLmNvbXBsZXRlZCkge1xyXG4gICAgICBpZiAodGhpcy5zdGVwQ2hpbGRyZW4pIHtcclxuICAgICAgICB0aGlzLnN0ZXBDaGlsZHJlbltpZHhdLnNob3cgPSB0cnVlO1xyXG4gICAgICAgIHRoaXMuYWN0aXZlU3RlcCA9IGlkeDtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,27 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { StepperStepModule } from "../stepper-step/stepper-step.module";
3
+ import { SimpleVerticalStepperComponent } from "./co-simple-vertical-stepper.component";
4
+ import { IconModule } from "@colijnit/corecomponents_v12";
5
+ import { PipeModule } from "../../pipe/pipe.module";
6
+ import { CommonModule } from "@angular/common";
7
+ import { DefaultOkCancelButtonsModule } from "../core/base/components/default-ok-cancel-buttons/default-ok-cancel-buttons.module";
8
+ export class SimpleVerticalStepperModule {
9
+ }
10
+ SimpleVerticalStepperModule.decorators = [
11
+ { type: NgModule, args: [{
12
+ imports: [
13
+ StepperStepModule,
14
+ IconModule,
15
+ PipeModule,
16
+ CommonModule,
17
+ DefaultOkCancelButtonsModule
18
+ ],
19
+ declarations: [
20
+ SimpleVerticalStepperComponent
21
+ ],
22
+ exports: [
23
+ SimpleVerticalStepperComponent
24
+ ]
25
+ },] }
26
+ ];
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY28tc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHJhbnNhY3Rpb24vc3JjL2xpYi9jb21wb25lbnQvc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXIvY28tc2ltcGxlLXZlcnRpY2FsLXN0ZXBwZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDdEYsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNsRCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUNMLDRCQUE0QixFQUM3QixNQUFNLG9GQUFvRixDQUFDO0FBaUI1RixNQUFNLE9BQU8sMkJBQTJCOzs7WUFmdkMsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxpQkFBaUI7b0JBQ2pCLFVBQVU7b0JBQ1YsVUFBVTtvQkFDVixZQUFZO29CQUNaLDRCQUE0QjtpQkFDN0I7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLDhCQUE4QjtpQkFDL0I7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLDhCQUE4QjtpQkFDL0I7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1N0ZXBwZXJTdGVwTW9kdWxlfSBmcm9tIFwiLi4vc3RlcHBlci1zdGVwL3N0ZXBwZXItc3RlcC5tb2R1bGVcIjtcclxuaW1wb3J0IHtTaW1wbGVWZXJ0aWNhbFN0ZXBwZXJDb21wb25lbnR9IGZyb20gXCIuL2NvLXNpbXBsZS12ZXJ0aWNhbC1zdGVwcGVyLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gXCJAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyXCI7XHJcbmltcG9ydCB7UGlwZU1vZHVsZX0gZnJvbSBcIi4uLy4uL3BpcGUvcGlwZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtcclxuICBEZWZhdWx0T2tDYW5jZWxCdXR0b25zTW9kdWxlXHJcbn0gZnJvbSBcIi4uL2NvcmUvYmFzZS9jb21wb25lbnRzL2RlZmF1bHQtb2stY2FuY2VsLWJ1dHRvbnMvZGVmYXVsdC1vay1jYW5jZWwtYnV0dG9ucy5tb2R1bGVcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgU3RlcHBlclN0ZXBNb2R1bGUsXHJcbiAgICBJY29uTW9kdWxlLFxyXG4gICAgUGlwZU1vZHVsZSxcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIERlZmF1bHRPa0NhbmNlbEJ1dHRvbnNNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgU2ltcGxlVmVydGljYWxTdGVwcGVyQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBTaW1wbGVWZXJ0aWNhbFN0ZXBwZXJDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTaW1wbGVWZXJ0aWNhbFN0ZXBwZXJNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
@@ -1,28 +1,13 @@
1
- import { Component, ContentChildren, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
2
- import { StepperStepComponent } from './component/stepper-step.component';
3
- import { Icon } from '../../enum/icon.enum';
4
- import { IconCacheService } from '../../service/icon-cache.service';
5
- import { CheckoutCfgName } from '../../enum/checkout-cfg-name.enum';
1
+ import { Component, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
6
2
  import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '@colijnit/corecomponents_v12';
7
- export class StepperComponent {
8
- constructor(iconCacheService) {
9
- this.iconCacheService = iconCacheService;
10
- this.cfgNames = CheckoutCfgName;
11
- this.icons = Icon;
3
+ import { StepperBaseComponent } from "../core/base/stepper-base.component";
4
+ export class StepperComponent extends StepperBaseComponent {
5
+ constructor() {
6
+ super(...arguments);
12
7
  this.showCreate = true;
13
8
  this.showStepper = true;
14
9
  this.createClicked = new EventEmitter();
15
- this.firstStep = 0;
16
10
  this.truckPosition = 0;
17
- this._activeStep = 0;
18
- }
19
- set content(children) {
20
- this.stepChildren = children.toArray();
21
- if (this.stepChildren) {
22
- setTimeout(() => {
23
- this._setActive(0);
24
- });
25
- }
26
11
  }
27
12
  set child(child) {
28
13
  if (child && child.nativeElement) {
@@ -32,13 +17,6 @@ export class StepperComponent {
32
17
  showClass() {
33
18
  return true;
34
19
  }
35
- set stepChildren(value) {
36
- this._stepChildren = value;
37
- this._prepareSteps();
38
- }
39
- get stepChildren() {
40
- return this._stepChildren;
41
- }
42
20
  get canPrevious() {
43
21
  return this.activeStep > this.firstStep;
44
22
  }
@@ -48,36 +26,29 @@ export class StepperComponent {
48
26
  get finished() {
49
27
  return this.activeStep === this.lastStep;
50
28
  }
51
- set activeStep(value) {
52
- this._activeStep = value;
53
- this.truckPosition = (100 / this.stepChildren.length) * (this._activeStep + 1);
54
- }
55
- get activeStep() {
56
- return this._activeStep;
57
- }
58
29
  goto(idx) {
59
30
  if (idx > this.activeStep) {
60
- this._validateCurrentStep(idx);
31
+ this.validateCurrentStep(idx);
61
32
  }
62
33
  else {
63
- this._setActive(idx);
34
+ this.setActive(idx);
64
35
  }
65
36
  }
66
37
  gotoPrevious() {
67
- this._setActive(this.activeStep - 1);
38
+ this.setActive(this.activeStep - 1);
68
39
  }
69
40
  gotoNext() {
70
- this._validateCurrentStep();
41
+ this.validateCurrentStep();
71
42
  }
72
- _validateCurrentStep(nextStep) {
43
+ validateCurrentStep(nextStep) {
73
44
  this.stepChildren[this.activeStep].onComplete = (complete) => {
74
45
  if (complete) {
75
- this._setActive(nextStep === undefined ? this.activeStep + 1 : nextStep);
46
+ this.setActive(nextStep === undefined ? this.activeStep + 1 : nextStep);
76
47
  }
77
48
  };
78
49
  this.stepChildren[this.activeStep].validateStep.next();
79
50
  }
80
- _setActive(idx) {
51
+ setActive(idx) {
81
52
  const prevStep = this.stepChildren[idx - 1];
82
53
  if (!prevStep || prevStep.completed) {
83
54
  if (this.stepChildren) {
@@ -142,18 +113,12 @@ StepperComponent.decorators = [
142
113
  encapsulation: ViewEncapsulation.None
143
114
  },] }
144
115
  ];
145
- StepperComponent.ctorParameters = () => [
146
- { type: IconCacheService }
147
- ];
148
116
  StepperComponent.propDecorators = {
149
- content: [{ type: ContentChildren, args: [StepperStepComponent,] }],
150
117
  child: [{ type: ViewChild, args: ['deliveryTruck', { read: ElementRef },] }],
151
- title: [{ type: Input }],
152
- titleIcon: [{ type: Input }],
153
118
  finishButtonLabel: [{ type: Input }],
154
119
  showCreate: [{ type: Input }],
155
120
  showStepper: [{ type: Input }],
156
121
  createClicked: [{ type: Output }],
157
122
  showClass: [{ type: HostBinding, args: ["class.co-stepper",] }]
158
123
  };
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/stepper/stepper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ContentChildren,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {StepperStepComponent} from './component/stepper-step.component';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {CheckoutCfgName} from '../../enum/checkout-cfg-name.enum';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\n\r\nexport interface steps {\r\n  index: number;\r\n  description: string;\r\n  complete: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: \"co-stepper\",\r\n  template: `\r\n      <div class=\"stepper-title\">\r\n          <div class=\"stepper-title-wrapper\">\r\n              <co-icon class=\"title-icon\" [iconData]=\"iconCacheService.getIcon(titleIcon)\" [screenConfigurationObject]=\"cfgNames.Title\" screenConfigNativeElement></co-icon>\r\n              <div class=\"title\" [textContent]=\"title | localize\" [screenConfigurationObject]=\"cfgNames.Title\" screenConfigNativeElement></div>\r\n          </div>\r\n          <ng-container [ngTemplateOutlet]=\"buttonTemplate\"></ng-container>\r\n      </div>\r\n      <div class=\"co-stepper-content\" *ngIf=\"showStepper\">\r\n          <div class=\"stepper-step\" [class.last]=\"index === stepChildren.length - 1\" *ngFor=\"let step of stepChildren; let index = index\"\r\n               [class.active]=\"index === activeStep\"\r\n               [class.complete]=\"step.completed\"\r\n               (click)=\"goto(index)\">\r\n              <ng-container *ngIf=\"stepChildren.length > 1\">\r\n                  <div class=\"description\" [textContent]=\"step.label\"></div>\r\n                  <div class=\"index\"></div>\r\n              </ng-container>\r\n          </div>\r\n          <icon #deliveryTruck *ngIf=\"activeStep !== lastStep\" class=\"delivery-truck\" [icon]=\"icons.DeliveryTruck\"\r\n                [style.left.%]=\"truckPosition\"></icon>\r\n      </div>\r\n      <div class=\"co-stepper-content-wrapper\">\r\n          <ng-content></ng-content>\r\n      </div>\r\n      <ng-container [ngTemplateOutlet]=\"buttonTemplate\"></ng-container>\r\n      <ng-template #buttonTemplate>\r\n          <div class=\"stepper-button-wrapper\">\r\n              <ng-container *ngIf=\"showStepper\">\r\n                  <co-button [iconData]=\"iconCacheService.getIcon(icons.ArrowLeftRegular)\" [label]=\"'PREVIOUS' | localize\"\r\n                             *ngIf=\"canPrevious\" (click)=\"gotoPrevious()\"></co-button>\r\n                  <co-button [iconDataRight]=\"iconCacheService.getIcon(icons.ArrowRightRegular)\" [label]=\"'NEXT' | localize\" *ngIf=\"canNext\"\r\n                             (click)=\"gotoNext()\"></co-button>\r\n              </ng-container>\r\n              <co-button *ngIf=\"showCreate\"\r\n                         [screenConfigurationObject]=\"cfgNames.OrderButton\"\r\n                         [iconData]=\"iconCacheService.getIcon(icons.DetailView)\"\r\n                         [label]=\"'ORDER' | localize\"\r\n                         (click)=\"createClicked.emit($event)\"></co-button>\r\n          </div>\r\n      </ng-template>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => StepperComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class StepperComponent {\r\n  public readonly cfgNames: typeof CheckoutCfgName = CheckoutCfgName;\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ContentChildren(StepperStepComponent) set content(children) {\r\n    this.stepChildren = children.toArray();\r\n    if (this.stepChildren) {\r\n      setTimeout(() => {\r\n        this._setActive(0);\r\n      });\r\n    }\r\n  }\r\n\r\n  @ViewChild('deliveryTruck', { read: ElementRef}) set child(child) {\r\n    if (child && child.nativeElement) {\r\n      this._deliveryTruckClientRect = child.nativeElement.getBoundingClientRect();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public title: string;\r\n\r\n  @Input()\r\n  public titleIcon: Icon;\r\n\r\n  @Input()\r\n  public finishButtonLabel: string;\r\n\r\n  @Input()\r\n  public showCreate: boolean = true;\r\n\r\n  @Input()\r\n  public showStepper: boolean = true;\r\n\r\n  @Output()\r\n  public createClicked: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-stepper\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public set stepChildren(value: StepperStepComponent[]) {\r\n    this._stepChildren = value;\r\n    this._prepareSteps();\r\n  }\r\n\r\n  public get stepChildren(): StepperStepComponent[] {\r\n    return this._stepChildren;\r\n  }\r\n\r\n  public get canPrevious(): boolean {\r\n    return this.activeStep > this.firstStep;\r\n  }\r\n\r\n  public get canNext(): boolean {\r\n    return this.activeStep < this.lastStep;\r\n  }\r\n\r\n  public get finished(): boolean {\r\n    return this.activeStep === this.lastStep;\r\n  }\r\n\r\n  public set activeStep(value: number) {\r\n    this._activeStep = value;\r\n    this.truckPosition = (100 / this.stepChildren.length) * (this._activeStep + 1);\r\n  }\r\n\r\n  public get activeStep(): number {\r\n    return this._activeStep;\r\n  }\r\n\r\n  public firstStep: number = 0;\r\n  public lastStep: number;\r\n  public truckPosition: number = 0;\r\n\r\n  private _stepChildren: StepperStepComponent[];\r\n  private _activeStep: number = 0;\r\n  private _deliveryTruckClientRect: ClientRect;\r\n\r\n  constructor(public iconCacheService: IconCacheService) {\r\n  }\r\n\r\n  public goto(idx: number): void {\r\n    if (idx > this.activeStep) {\r\n      this._validateCurrentStep(idx);\r\n    } else {\r\n      this._setActive(idx);\r\n    }\r\n  }\r\n\r\n  public gotoPrevious(): void {\r\n    this._setActive(this.activeStep - 1);\r\n  }\r\n\r\n  public gotoNext(): void {\r\n    this._validateCurrentStep();\r\n  }\r\n\r\n  private _validateCurrentStep(nextStep?: number): void {\r\n    this.stepChildren[this.activeStep].onComplete = (complete: boolean) => {\r\n      if (complete) {\r\n        this._setActive(nextStep === undefined ? this.activeStep + 1 : nextStep);\r\n      }\r\n    };\r\n    this.stepChildren[this.activeStep].validateStep.next();\r\n  }\r\n\r\n  private _setActive(idx: number): void {\r\n    const prevStep: StepperStepComponent = this.stepChildren[idx - 1];\r\n    if (!prevStep || prevStep.completed) {\r\n      if (this.stepChildren) {\r\n        this.stepChildren.map(s => s.show = false);\r\n        this.stepChildren[idx].show = true;\r\n        this.activeStep = idx;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _prepareSteps(): void {\r\n    this.lastStep = this.stepChildren.length - 1;\r\n  }\r\n}\r\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/stepper/stepper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '@colijnit/corecomponents_v12';\r\nimport {StepperStepComponent} from \"../stepper-step/stepper-step.component\";\r\nimport {StepperBaseComponent} from \"../core/base/stepper-base.component\";\r\n\r\nexport interface steps {\r\n  index: number;\r\n  description: string;\r\n  complete: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: \"co-stepper\",\r\n  template: `\r\n      <div class=\"stepper-title\">\r\n          <div class=\"stepper-title-wrapper\">\r\n              <co-icon class=\"title-icon\" [iconData]=\"iconCacheService.getIcon(titleIcon)\" [screenConfigurationObject]=\"cfgNames.Title\" screenConfigNativeElement></co-icon>\r\n              <div class=\"title\" [textContent]=\"title | localize\" [screenConfigurationObject]=\"cfgNames.Title\" screenConfigNativeElement></div>\r\n          </div>\r\n          <ng-container [ngTemplateOutlet]=\"buttonTemplate\"></ng-container>\r\n      </div>\r\n      <div class=\"co-stepper-content\" *ngIf=\"showStepper\">\r\n          <div class=\"stepper-step\" [class.last]=\"index === stepChildren.length - 1\" *ngFor=\"let step of stepChildren; let index = index\"\r\n               [class.active]=\"index === activeStep\"\r\n               [class.complete]=\"step.completed\"\r\n               (click)=\"goto(index)\">\r\n              <ng-container *ngIf=\"stepChildren.length > 1\">\r\n                  <div class=\"description\" [textContent]=\"step.label\"></div>\r\n                  <div class=\"index\"></div>\r\n              </ng-container>\r\n          </div>\r\n          <icon #deliveryTruck *ngIf=\"activeStep !== lastStep\" class=\"delivery-truck\" [icon]=\"icons.DeliveryTruck\"\r\n                [style.left.%]=\"truckPosition\"></icon>\r\n      </div>\r\n      <div class=\"co-stepper-content-wrapper\">\r\n          <ng-content></ng-content>\r\n      </div>\r\n      <ng-container [ngTemplateOutlet]=\"buttonTemplate\"></ng-container>\r\n      <ng-template #buttonTemplate>\r\n          <div class=\"stepper-button-wrapper\">\r\n              <ng-container *ngIf=\"showStepper\">\r\n                  <co-button [iconData]=\"iconCacheService.getIcon(icons.ArrowLeftRegular)\" [label]=\"'PREVIOUS' | localize\"\r\n                             *ngIf=\"canPrevious\" (click)=\"gotoPrevious()\"></co-button>\r\n                  <co-button [iconDataRight]=\"iconCacheService.getIcon(icons.ArrowRightRegular)\" [label]=\"'NEXT' | localize\" *ngIf=\"canNext\"\r\n                             (click)=\"gotoNext()\"></co-button>\r\n              </ng-container>\r\n              <co-button *ngIf=\"showCreate\"\r\n                         [screenConfigurationObject]=\"cfgNames.OrderButton\"\r\n                         [iconData]=\"iconCacheService.getIcon(icons.DetailView)\"\r\n                         [label]=\"'ORDER' | localize\"\r\n                         (click)=\"createClicked.emit($event)\"></co-button>\r\n          </div>\r\n      </ng-template>\r\n  `,\r\n  providers: [{\r\n    provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => StepperComponent)\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class StepperComponent extends StepperBaseComponent {\r\n\r\n  @ViewChild('deliveryTruck', { read: ElementRef}) set child(child) {\r\n    if (child && child.nativeElement) {\r\n      this._deliveryTruckClientRect = child.nativeElement.getBoundingClientRect();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public finishButtonLabel: string;\r\n\r\n  @Input()\r\n  public showCreate: boolean = true;\r\n\r\n  @Input()\r\n  public showStepper: boolean = true;\r\n\r\n  @Output()\r\n  public createClicked: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-stepper\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public get canPrevious(): boolean {\r\n    return this.activeStep > this.firstStep;\r\n  }\r\n\r\n  public get canNext(): boolean {\r\n    return this.activeStep < this.lastStep;\r\n  }\r\n\r\n  public get finished(): boolean {\r\n    return this.activeStep === this.lastStep;\r\n  }\r\n\r\n  public truckPosition: number = 0;\r\n\r\n  private _deliveryTruckClientRect: ClientRect;\r\n\r\n  public goto(idx: number): void {\r\n    if (idx > this.activeStep) {\r\n      this.validateCurrentStep(idx);\r\n    } else {\r\n      this.setActive(idx);\r\n    }\r\n  }\r\n\r\n  public gotoPrevious(): void {\r\n    this.setActive(this.activeStep - 1);\r\n  }\r\n\r\n  public gotoNext(): void {\r\n    this.validateCurrentStep();\r\n  }\r\n\r\n  protected validateCurrentStep(nextStep?: number): void {\r\n    this.stepChildren[this.activeStep].onComplete = (complete: boolean) => {\r\n      if (complete) {\r\n        this.setActive(nextStep === undefined ? this.activeStep + 1 : nextStep);\r\n      }\r\n    };\r\n    this.stepChildren[this.activeStep].validateStep.next();\r\n  }\r\n\r\n  protected setActive(idx: number): void {\r\n    const prevStep: StepperStepComponent = this.stepChildren[idx - 1];\r\n    if (!prevStep || prevStep.completed) {\r\n      if (this.stepChildren) {\r\n        this.stepChildren.map(s => s.show = false);\r\n        this.stepChildren[idx].show = true;\r\n        this.activeStep = idx;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _prepareSteps(): void {\r\n    this.lastStep = this.stepChildren.length - 1;\r\n  }\r\n}\r\n"]}
@@ -1,7 +1,6 @@
1
1
  import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { StepperComponent } from './stepper.component';
4
- import { StepperStepComponent } from './component/stepper-step.component';
5
4
  import { ButtonModule, IconModule, ScreenConfigurationModule } from '@colijnit/corecomponents_v12';
6
5
  import { PipeModule } from '../../pipe/pipe.module';
7
6
  import { CoreModule } from '../core/core.module';
@@ -18,13 +17,11 @@ StepperModule.decorators = [
18
17
  ScreenConfigurationModule
19
18
  ],
20
19
  declarations: [
21
- StepperComponent,
22
- StepperStepComponent
20
+ StepperComponent
23
21
  ],
24
22
  exports: [
25
- StepperComponent,
26
- StepperStepComponent
23
+ StepperComponent
27
24
  ]
28
25
  },] }
29
26
  ];
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9zdGVwcGVyL3N0ZXBwZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyxZQUFZLEVBQUUsVUFBVSxFQUFFLHlCQUF5QixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDakcsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQW9CL0MsTUFBTSxPQUFPLGFBQWE7OztZQWxCekIsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixVQUFVO29CQUNWLFVBQVU7b0JBQ1YseUJBQXlCO2lCQUM1QjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osZ0JBQWdCO29CQUNoQixvQkFBb0I7aUJBQ3JCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxnQkFBZ0I7b0JBQ2hCLG9CQUFvQjtpQkFDckI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtTdGVwcGVyQ29tcG9uZW50fSBmcm9tICcuL3N0ZXBwZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHtTdGVwcGVyU3RlcENvbXBvbmVudH0gZnJvbSAnLi9jb21wb25lbnQvc3RlcHBlci1zdGVwLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7QnV0dG9uTW9kdWxlLCBJY29uTW9kdWxlLCBTY3JlZW5Db25maWd1cmF0aW9uTW9kdWxlfSBmcm9tICdAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyJztcclxuaW1wb3J0IHtQaXBlTW9kdWxlfSBmcm9tICcuLi8uLi9waXBlL3BpcGUubW9kdWxlJztcclxuaW1wb3J0IHtDb3JlTW9kdWxlfSBmcm9tICcuLi9jb3JlL2NvcmUubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgICAgICBQaXBlTW9kdWxlLFxyXG4gICAgICAgIEljb25Nb2R1bGUsXHJcbiAgICAgICAgQ29yZU1vZHVsZSxcclxuICAgICAgICBTY3JlZW5Db25maWd1cmF0aW9uTW9kdWxlXHJcbiAgICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgU3RlcHBlckNvbXBvbmVudCxcclxuICAgIFN0ZXBwZXJTdGVwQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBTdGVwcGVyQ29tcG9uZW50LFxyXG4gICAgU3RlcHBlclN0ZXBDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTdGVwcGVyTW9kdWxlIHtcclxuXHJcbn1cclxuIl19
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9zdGVwcGVyL3N0ZXBwZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFBQyxZQUFZLEVBQUUsVUFBVSxFQUFFLHlCQUF5QixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDakcsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQWtCL0MsTUFBTSxPQUFPLGFBQWE7OztZQWhCekIsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixVQUFVO29CQUNWLFVBQVU7b0JBQ1YseUJBQXlCO2lCQUM1QjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osZ0JBQWdCO2lCQUNqQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsZ0JBQWdCO2lCQUNqQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge1N0ZXBwZXJDb21wb25lbnR9IGZyb20gJy4vc3RlcHBlci5jb21wb25lbnQnO1xyXG5pbXBvcnQge0J1dHRvbk1vZHVsZSwgSWNvbk1vZHVsZSwgU2NyZWVuQ29uZmlndXJhdGlvbk1vZHVsZX0gZnJvbSAnQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMic7XHJcbmltcG9ydCB7UGlwZU1vZHVsZX0gZnJvbSAnLi4vLi4vcGlwZS9waXBlLm1vZHVsZSc7XHJcbmltcG9ydCB7Q29yZU1vZHVsZX0gZnJvbSAnLi4vY29yZS9jb3JlLm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBCdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgUGlwZU1vZHVsZSxcclxuICAgICAgICBJY29uTW9kdWxlLFxyXG4gICAgICAgIENvcmVNb2R1bGUsXHJcbiAgICAgICAgU2NyZWVuQ29uZmlndXJhdGlvbk1vZHVsZVxyXG4gICAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFN0ZXBwZXJDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFN0ZXBwZXJDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTdGVwcGVyTW9kdWxlIHtcclxuXHJcbn1cclxuIl19
@@ -0,0 +1,40 @@
1
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
2
+ export class StepperStepComponent {
3
+ constructor() {
4
+ this.index = 0;
5
+ this.show = false;
6
+ this.validateStep = new EventEmitter();
7
+ this._completed = false;
8
+ this.onComplete = (complete) => { };
9
+ }
10
+ set completed(value) {
11
+ this._completed = value;
12
+ this.onComplete(this._completed);
13
+ }
14
+ get completed() {
15
+ return this._completed;
16
+ }
17
+ showClass() {
18
+ return true;
19
+ }
20
+ }
21
+ StepperStepComponent.decorators = [
22
+ { type: Component, args: [{
23
+ selector: "co-stepper-step",
24
+ template: `
25
+ <ng-container *ngIf="show">
26
+ <ng-content></ng-content>
27
+ </ng-container>
28
+ `,
29
+ encapsulation: ViewEncapsulation.None
30
+ },] }
31
+ ];
32
+ StepperStepComponent.propDecorators = {
33
+ index: [{ type: Input }],
34
+ label: [{ type: Input }],
35
+ completed: [{ type: Input }],
36
+ show: [{ type: HostBinding, args: ['class.show',] }, { type: Input }],
37
+ validateStep: [{ type: Output }],
38
+ showClass: [{ type: HostBinding, args: ["class.co-stepper-step",] }]
39
+ };
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcHBlci1zdGVwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RyYW5zYWN0aW9uL3NyYy9saWIvY29tcG9uZW50L3N0ZXBwZXItc3RlcC9zdGVwcGVyLXN0ZXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBV3JHLE1BQU0sT0FBTyxvQkFBb0I7SUFUakM7UUFZUyxVQUFLLEdBQVcsQ0FBQyxDQUFDO1FBaUJsQixTQUFJLEdBQVksS0FBSyxDQUFDO1FBR3RCLGlCQUFZLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFPM0QsZUFBVSxHQUFZLEtBQUssQ0FBQztRQUU3QixlQUFVLEdBQUcsQ0FBQyxRQUFpQixFQUFFLEVBQUUsR0FBRSxDQUFDLENBQUE7SUFDL0MsQ0FBQztJQXpCQyxJQUNXLFNBQVMsQ0FBQyxLQUFjO1FBQ2pDLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ25DLENBQUM7SUFFRCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7SUFVTSxTQUFTO1FBQ2QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOzs7WUFyQ0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxpQkFBaUI7Z0JBQzNCLFFBQVEsRUFBRTs7OztHQUlUO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7b0JBR0UsS0FBSztvQkFHTCxLQUFLO3dCQUdMLEtBQUs7bUJBVUwsV0FBVyxTQUFDLFlBQVksY0FDeEIsS0FBSzsyQkFHTCxNQUFNO3dCQUdOLFdBQVcsU0FBQyx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJjby1zdGVwcGVyLXN0ZXBcIixcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInNob3dcIj5cclxuICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgPC9uZy1jb250YWluZXI+XHJcbiAgYCxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTdGVwcGVyU3RlcENvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGluZGV4OiBudW1iZXIgPSAwO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbDogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgY29tcGxldGVkKHZhbHVlOiBib29sZWFuKSB7XHJcbiAgICB0aGlzLl9jb21wbGV0ZWQgPSB2YWx1ZTtcclxuICAgIHRoaXMub25Db21wbGV0ZSh0aGlzLl9jb21wbGV0ZWQpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBjb21wbGV0ZWQoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5fY29tcGxldGVkO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5zaG93JylcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzaG93OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyB2YWxpZGF0ZVN0ZXA6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28tc3RlcHBlci1zdGVwXCIpXHJcbiAgcHVibGljIHNob3dDbGFzcygpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfY29tcGxldGVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIHB1YmxpYyBvbkNvbXBsZXRlID0gKGNvbXBsZXRlOiBib29sZWFuKSA9PiB7fVxyXG59XHJcbiJdfQ==