@colijnit/transaction 12.1.217 → 12.1.218

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 (46) hide show
  1. package/bundles/colijnit-transaction.umd.js +448 -69
  2. package/bundles/colijnit-transaction.umd.js.map +1 -1
  3. package/colijnit-transaction.d.ts +3 -1
  4. package/colijnit-transaction.metadata.json +1 -1
  5. package/esm2015/colijnit-transaction.js +4 -2
  6. package/esm2015/lib/component/add-product/add-product.component.js +38 -31
  7. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-location/dialog-transaction-line-warehouse-location.module.js +5 -5
  8. package/esm2015/lib/component/transaction/transaction.module.js +4 -2
  9. package/esm2015/lib/component/transaction-cash-register-order/transaction-cash-register-order-expense-dialog/transaction-cash-register-order-expense-dialog.component.js +4 -2
  10. package/esm2015/lib/component/transaction-cash-register-order/transaction-cash-register-order-receipt-dialog/transaction-cash-register-order-receipt-dialog.component.js +285 -0
  11. package/esm2015/lib/component/transaction-cash-register-order/transaction-cash-register-order-receipt-dialog/transaction-cash-register-order-receipt-dialog.module.js +25 -0
  12. package/esm2015/lib/component/transaction-cash-register-order/transaction-cash-register-payment-dialog/transaction-cash-register-payment-dialog.component.js +40 -37
  13. package/esm2015/lib/component/transaction-line/transaction-cash-register-order-line/transaction-cash-register-order-line.component.js +37 -26
  14. package/esm2015/lib/component/transaction-line/transaction-cash-register-order-line/transaction-cash-register-order-line.module.js +4 -2
  15. package/esm2015/lib/component/transaction-line/transaction-invoice-line/transaction-invoice-line.component.js +2 -2
  16. package/esm2015/lib/component/transaction-line/transaction-order-delivery-line/transaction-order-delivery-line.component.js +2 -2
  17. package/esm2015/lib/component/transaction-line/transaction-overview-line/transaction-overview-line.component.js +2 -2
  18. package/esm2015/lib/component/transaction-line/transaction-planning-line/transaction-planning-line.component.js +2 -2
  19. package/esm2015/lib/component/transaction-line/transaction-purchase-order-line/transaction-purchase-order-line.component.js +3 -3
  20. package/esm2015/lib/component/transaction-line/transaction-purchase-overview-line/transaction-purchase-overview-line.component.js +2 -2
  21. package/esm2015/lib/component/transaction-line/transaction-sales-order-quotation-line/transaction-sales-order-quotation-line.component.js +2 -2
  22. package/esm2015/lib/component/transaction-line-checkbox-list/transaction-line-checkbox-list.component.js +4 -4
  23. package/esm2015/lib/component/transaction-line-fields/transaction-line-confirmed-price/transaction-line-confirmed-price.component.js +2 -2
  24. package/esm2015/lib/component/transaction-line-fields/transaction-line-discount-button.component.js +2 -2
  25. package/esm2015/lib/component/transaction-line-fields/transaction-line-price/transaction-line-price.component.js +3 -2
  26. package/esm2015/lib/component/transaction-line-fields/transaction-line-warehouse-location-button.component.js +21 -14
  27. package/esm2015/lib/component/transaction-line-fields/transaction-line-warehouse-location-button.module.js +4 -2
  28. package/esm2015/lib/component/transaction-lines-popup/transaction-lines-popup.component.js +2 -2
  29. package/esm2015/lib/component/transaction-margin/transaction-margin.component.js +2 -2
  30. package/esm2015/lib/component/transaction-quick-access/transaction-quick-access/transaction-quick-access.component.js +1 -21
  31. package/esm2015/lib/service/dialog.service.js +12 -1
  32. package/esm2015/lib/service/transaction.service.js +15 -5
  33. package/esm2015/lib/transaction-version.js +3 -3
  34. package/fesm2015/colijnit-transaction.js +488 -155
  35. package/fesm2015/colijnit-transaction.js.map +1 -1
  36. package/lib/component/add-product/add-product.component.d.ts +3 -1
  37. package/lib/component/transaction-cash-register-order/transaction-cash-register-order-receipt-dialog/style/_layout.scss +3 -0
  38. package/lib/component/transaction-cash-register-order/transaction-cash-register-order-receipt-dialog/transaction-cash-register-order-receipt-dialog.component.d.ts +48 -0
  39. package/lib/component/transaction-cash-register-order/transaction-cash-register-order-receipt-dialog/transaction-cash-register-order-receipt-dialog.module.d.ts +2 -0
  40. package/lib/component/transaction-cash-register-order/transaction-cash-register-payment-dialog/style/_layout.scss +39 -0
  41. package/lib/component/transaction-line/transaction-cash-register-order-line/style/_layout.scss +22 -7
  42. package/lib/component/transaction-line-fields/transaction-line-warehouse-location-button.component.d.ts +1 -2
  43. package/lib/component/transaction-quick-access/transaction-quick-access/transaction-quick-access.component.d.ts +0 -2
  44. package/lib/service/dialog.service.d.ts +1 -0
  45. package/lib/service/transaction.service.d.ts +2 -1
  46. package/package.json +1 -1
@@ -0,0 +1,285 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
3
+ import { TransactionBaseComponent } from "../../core/base/transaction-base.component";
4
+ import { EmailPosReceiptRequest } from "@colijnit/transactionapi/build/model/email-pos-receipt-request";
5
+ import { PrintPosReceiptRequest } from "@colijnit/transactionapi/build/model/print-pos-receipt-request";
6
+ import { AppPopupButtonType } from "../../core/enum/app-popup-button-type.enum";
7
+ export class TransactionCashRegisterOrderReceiptDialogComponent extends TransactionBaseComponent {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.buttonType = AppPopupButtonType;
11
+ this.isReprint = false;
12
+ this.showClose = false;
13
+ this.handleReceiptOptionSelected = new EventEmitter();
14
+ this.close = new EventEmitter();
15
+ this.disableInput = false;
16
+ this.emailAddressList = [];
17
+ this.printerList = [];
18
+ this.printerLayouts = [];
19
+ this.emailLayouts = [];
20
+ this.showEmailLayoutOption = true;
21
+ }
22
+ showClass() {
23
+ return true;
24
+ }
25
+ ngOnInit() {
26
+ super.ngOnInit();
27
+ if (this.isReprint) {
28
+ this._prepareDialogData();
29
+ this._getDefaultEmailAddressListForPosReprintReceipt();
30
+ }
31
+ else {
32
+ this._getDefaultEmailAddressListForPosReceipt();
33
+ }
34
+ this.receiptOptions = this._prepareReceiptOptions();
35
+ }
36
+ emailReceipt() {
37
+ const request = new EmailPosReceiptRequest();
38
+ if (this.isReprint) {
39
+ if (this.selectedEmailLayout !== undefined) {
40
+ request.transId = this.currentTransaction.transactionInfo.id;
41
+ request.toAddresses = this.emailAddressList.join(';');
42
+ request.reportId = this.selectedEmailLayout.reportId;
43
+ this.transactionService.emailHistoricPosReceipt(request).then((success) => {
44
+ if (success) {
45
+ this.handleReceiptOptionSelected.next();
46
+ this.handleClose(this.buttonType.Ok);
47
+ }
48
+ else {
49
+ this.disableInput = false;
50
+ }
51
+ });
52
+ }
53
+ else {
54
+ this.disableInput = false;
55
+ }
56
+ }
57
+ else {
58
+ request.transId = this.transactionInfo.id;
59
+ request.toAddresses = this.emailAddressList.join(';');
60
+ request.reportId = this.cashRegisterPaymentDetails.emailLayout.reportId;
61
+ this.transactionService.emailPosReceipt(request).then((success) => {
62
+ if (success) {
63
+ this.handleReceiptOptionSelected.next();
64
+ }
65
+ else {
66
+ this.disableInput = false;
67
+ }
68
+ });
69
+ }
70
+ }
71
+ printReceipt() {
72
+ const request = new PrintPosReceiptRequest();
73
+ if (this.isReprint) {
74
+ if (this.activePrinter !== undefined && this.selectedPrinterLayout !== undefined) {
75
+ request.transId = this.currentTransaction.transactionInfo.id;
76
+ request.copies = 1;
77
+ request.printerName = this.activePrinter.name;
78
+ request.reportId = this.selectedPrinterLayout.reportId;
79
+ this.transactionService.printHistoricPosReceipt(request).then((success) => {
80
+ if (success) {
81
+ this.handleReceiptOptionSelected.next();
82
+ this.handleClose(this.buttonType.Ok);
83
+ }
84
+ else {
85
+ this.disableInput = false;
86
+ }
87
+ });
88
+ }
89
+ else {
90
+ this.disableInput = false;
91
+ }
92
+ }
93
+ else {
94
+ request.transId = this.transactionInfo.id;
95
+ request.copies = 1;
96
+ request.printerName = this.cashRegisterPaymentDetails.printer.name;
97
+ request.reportId = this.cashRegisterPaymentDetails.printerLayout.reportId;
98
+ this.transactionService.printPosReceipt(request).then((success) => {
99
+ if (success) {
100
+ this.handleReceiptOptionSelected.next();
101
+ }
102
+ else {
103
+ this.disableInput = false;
104
+ }
105
+ });
106
+ }
107
+ }
108
+ noPrintReceipt() {
109
+ this.handleReceiptOptionSelected.next();
110
+ this.disableInput = false;
111
+ }
112
+ handleClickReceipt(title) {
113
+ if (!this.disableInput) {
114
+ this.disableInput = true;
115
+ switch (title) {
116
+ case 'EMAIL':
117
+ this.emailReceipt();
118
+ break;
119
+ case 'PRINT':
120
+ this.printReceipt();
121
+ break;
122
+ case 'NO_RECEIPT':
123
+ this.noPrintReceipt();
124
+ break;
125
+ }
126
+ }
127
+ }
128
+ handlePrinterChanged(printer) {
129
+ this.activePrinter = printer;
130
+ }
131
+ handleCloseDialog(event, type) {
132
+ if (event) {
133
+ event.preventDefault();
134
+ event.stopPropagation();
135
+ }
136
+ this.handleClose(type);
137
+ }
138
+ handleClose(type) {
139
+ if (type === AppPopupButtonType.Cancel) {
140
+ this.rollback();
141
+ }
142
+ this.close.emit();
143
+ this.onClose(type);
144
+ }
145
+ onClose(eventType, output) {
146
+ return;
147
+ }
148
+ _getDefaultEmailAddressListForPosReceipt() {
149
+ return __awaiter(this, void 0, void 0, function* () {
150
+ this.transactionService.getDefaultEmailAddressListForPosReceipt(this.transactionInfo.uuid)
151
+ .then((emailAddressList) => {
152
+ this.emailAddressList = emailAddressList;
153
+ });
154
+ });
155
+ }
156
+ _getDefaultEmailAddressListForPosReprintReceipt() {
157
+ return __awaiter(this, void 0, void 0, function* () {
158
+ if (this.currentTransaction.transactionInfo.relation !== undefined) {
159
+ this.transactionService.getDefaultEmailAddressListForPosReceipt(this.currentTransaction.transactionInfo.uuid)
160
+ .then((emailAddressList) => {
161
+ this.emailAddressList = emailAddressList;
162
+ });
163
+ }
164
+ });
165
+ }
166
+ _prepareDialogData() {
167
+ return __awaiter(this, void 0, void 0, function* () {
168
+ const promises = [
169
+ this._getPrinters(),
170
+ this._getPrinterLayouts(),
171
+ this._getEmailLayouts()
172
+ ];
173
+ yield Promise.all(promises);
174
+ });
175
+ }
176
+ _getPrinters() {
177
+ return __awaiter(this, void 0, void 0, function* () {
178
+ this.printerList = yield this.transactionService.getPrinters();
179
+ });
180
+ }
181
+ _getPrinterLayouts() {
182
+ return __awaiter(this, void 0, void 0, function* () {
183
+ this.printerLayouts = yield this.transactionService.getPosReceiptPrintLayouts(this.transactionInfo.uuid);
184
+ });
185
+ }
186
+ _getEmailLayouts() {
187
+ return __awaiter(this, void 0, void 0, function* () {
188
+ this.emailLayouts = yield this.transactionService.getPosReceiptEmailLayouts(this.transactionInfo.uuid);
189
+ });
190
+ }
191
+ _prepareReceiptOptions() {
192
+ let output;
193
+ if (this.isReprint) {
194
+ if (this.currentTransaction.transactionInfo.relation !== undefined) {
195
+ output = [
196
+ { title: 'EMAIL', iconData: this.iconCacheService.getIcon(this.icons.AtSolid) },
197
+ { title: 'PRINT', iconData: this.iconCacheService.getIcon(this.icons.PrintSolid) }
198
+ ];
199
+ }
200
+ else {
201
+ this.showEmailLayoutOption = false;
202
+ output = [
203
+ { title: 'PRINT', iconData: this.iconCacheService.getIcon(this.icons.PrintSolid) }
204
+ ];
205
+ }
206
+ }
207
+ else {
208
+ output = [
209
+ { title: 'EMAIL', iconData: this.iconCacheService.getIcon(this.icons.AtSolid) },
210
+ { title: 'PRINT', iconData: this.iconCacheService.getIcon(this.icons.PrintSolid) },
211
+ { title: 'NO_RECEIPT', iconData: this.iconCacheService.getIcon(this.icons.RegularReceiptSlash) }
212
+ ];
213
+ }
214
+ return output;
215
+ }
216
+ }
217
+ TransactionCashRegisterOrderReceiptDialogComponent.decorators = [
218
+ { type: Component, args: [{
219
+ selector: "co-transaction-cash-register-order-receipt-dialog",
220
+ template: `
221
+ <co-dialog [showCloseIcon]="showClose" [headerTemplate]="headerTemplate"
222
+ (closeClick)="handleCloseDialog($event, buttonType.Cancel)">
223
+ <div class="dialog-content-wrapper">
224
+ <ng-container *ngIf="isReprint">
225
+ <co-list-of-values [label]="'PRINTER' | localize"
226
+ [(model)]="activePrinter"
227
+ [displayField]="'name'"
228
+ [collection]="printerList"
229
+ [multiselect]="false"
230
+ [required]="false"
231
+ [readonly]="headerReadonly"
232
+ [searchDisabled]="true"
233
+ (modelChange)="handlePrinterChanged($event)"
234
+ ></co-list-of-values>
235
+ <co-list-of-values [label]="'PRINTER_LAYOUT' | localize"
236
+ [(model)]="selectedPrinterLayout"
237
+ [displayField]="'name'"
238
+ [collection]="printerLayouts"
239
+ [multiselect]="false"
240
+ [required]="false"
241
+ [readonly]="headerReadonly"
242
+ [searchDisabled]="true"
243
+ ></co-list-of-values>
244
+ <co-list-of-values *ngIf="showEmailLayoutOption"
245
+ [label]="'EMAIL_LAYOUT' | localize"
246
+ [(model)]="selectedEmailLayout"
247
+ [displayField]="'name'"
248
+ [collection]="emailLayouts"
249
+ [multiselect]="false"
250
+ [required]="false"
251
+ [readonly]="headerReadonly"
252
+ [searchDisabled]="true"
253
+ ></co-list-of-values>
254
+ </ng-container>
255
+
256
+ <div class="receipt-option-wrapper">
257
+ <div class="receipt-option" [class.disabled]="disableInput" *ngFor="let receiptOption of receiptOptions"
258
+ (click)="handleClickReceipt(receiptOption.title)">
259
+ <co-icon [iconData]="receiptOption.iconData"></co-icon>
260
+ <span [textContent]="receiptOption.title | localize"></span>
261
+ </div>
262
+ </div>
263
+ </div>
264
+ </co-dialog>
265
+
266
+ <ng-template #headerTemplate>
267
+ <div class="title-wrapper">
268
+ <co-icon [iconData]="iconCacheService.getIcon(icons.CashRegister)"></co-icon>
269
+ <span class="co-dialog-header-title" [textContent]="'CASH_REGISTER_RECEIPT' | localize"></span>
270
+ </div>
271
+ </ng-template>
272
+ `,
273
+ encapsulation: ViewEncapsulation.None
274
+ },] }
275
+ ];
276
+ TransactionCashRegisterOrderReceiptDialogComponent.propDecorators = {
277
+ cashRegisterPaymentDetails: [{ type: Input }],
278
+ isReprint: [{ type: Input }],
279
+ currentTransaction: [{ type: Input }],
280
+ showClose: [{ type: Input }],
281
+ handleReceiptOptionSelected: [{ type: Output }],
282
+ close: [{ type: Output }],
283
+ showClass: [{ type: HostBinding, args: ["class.co-transaction-cash-register-order-receipt-dialog",] }]
284
+ };
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-cash-register-order-receipt-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-cash-register-order/transaction-cash-register-order-receipt-dialog/transaction-cash-register-order-receipt-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {TransactionBaseComponent} from \"../../core/base/transaction-base.component\";\r\nimport {SafeHtml} from \"@angular/platform-browser\";\r\nimport {EmailPosReceiptRequest} from \"@colijnit/transactionapi/build/model/email-pos-receipt-request\";\r\nimport {PrintPosReceiptRequest} from \"@colijnit/transactionapi/build/model/print-pos-receipt-request\";\r\nimport {PaymentTransactionViewModel} from \"../../../model/payment-transaction-view-model\";\r\nimport {Printer} from \"@colijnit/mainapi/build/model/printer.bo\";\r\nimport {ReportLayoutSelectionPrint} from \"@colijnit/mainapi/build/model/report-layout-selection-print.bo\";\r\nimport {ReportLayoutSelectionEmail} from \"@colijnit/mainapi/build/model/report-layout-selection-email.bo\";\r\nimport {TransactionInfoResponse} from \"@colijnit/transactionapi/build/model/transaction-info-response.bo\";\r\nimport {AppPopupButtonType} from \"../../core/enum/app-popup-button-type.enum\";\r\n\r\n@Component({\r\n  selector: \"co-transaction-cash-register-order-receipt-dialog\",\r\n  template: `\r\n    <co-dialog [showCloseIcon]=\"showClose\" [headerTemplate]=\"headerTemplate\"\r\n               (closeClick)=\"handleCloseDialog($event, buttonType.Cancel)\">\r\n      <div class=\"dialog-content-wrapper\">\r\n        <ng-container *ngIf=\"isReprint\">\r\n          <co-list-of-values [label]=\"'PRINTER' | localize\"\r\n                             [(model)]=\"activePrinter\"\r\n                             [displayField]=\"'name'\"\r\n                             [collection]=\"printerList\"\r\n                             [multiselect]=\"false\"\r\n                             [required]=\"false\"\r\n                             [readonly]=\"headerReadonly\"\r\n                             [searchDisabled]=\"true\"\r\n                             (modelChange)=\"handlePrinterChanged($event)\"\r\n          ></co-list-of-values>\r\n          <co-list-of-values [label]=\"'PRINTER_LAYOUT' | localize\"\r\n                             [(model)]=\"selectedPrinterLayout\"\r\n                             [displayField]=\"'name'\"\r\n                             [collection]=\"printerLayouts\"\r\n                             [multiselect]=\"false\"\r\n                             [required]=\"false\"\r\n                             [readonly]=\"headerReadonly\"\r\n                             [searchDisabled]=\"true\"\r\n          ></co-list-of-values>\r\n          <co-list-of-values *ngIf=\"showEmailLayoutOption\"\r\n                             [label]=\"'EMAIL_LAYOUT' | localize\"\r\n                             [(model)]=\"selectedEmailLayout\"\r\n                             [displayField]=\"'name'\"\r\n                             [collection]=\"emailLayouts\"\r\n                             [multiselect]=\"false\"\r\n                             [required]=\"false\"\r\n                             [readonly]=\"headerReadonly\"\r\n                             [searchDisabled]=\"true\"\r\n          ></co-list-of-values>\r\n        </ng-container>\r\n\r\n        <div class=\"receipt-option-wrapper\">\r\n          <div class=\"receipt-option\" [class.disabled]=\"disableInput\" *ngFor=\"let receiptOption of receiptOptions\"\r\n               (click)=\"handleClickReceipt(receiptOption.title)\">\r\n            <co-icon [iconData]=\"receiptOption.iconData\"></co-icon>\r\n            <span [textContent]=\"receiptOption.title | localize\"></span>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </co-dialog>\r\n\r\n    <ng-template #headerTemplate>\r\n      <div class=\"title-wrapper\">\r\n        <co-icon [iconData]=\"iconCacheService.getIcon(icons.CashRegister)\"></co-icon>\r\n        <span class=\"co-dialog-header-title\" [textContent]=\"'CASH_REGISTER_RECEIPT' | localize\"></span>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionCashRegisterOrderReceiptDialogComponent extends TransactionBaseComponent implements OnInit {\r\n  public readonly buttonType: typeof AppPopupButtonType = AppPopupButtonType;\r\n\r\n  @Input()\r\n  public cashRegisterPaymentDetails: PaymentTransactionViewModel;\r\n\r\n  @Input()\r\n  public isReprint: boolean = false;\r\n\r\n  @Input()\r\n  public currentTransaction: TransactionInfoResponse;\r\n\r\n  @Input()\r\n  public showClose: boolean = false;\r\n\r\n  @Output()\r\n  public handleReceiptOptionSelected: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public close: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  public disableInput: boolean = false;\r\n  public emailAddressList: string[] = [];\r\n  public printerList: Printer[] = [];\r\n  public activePrinter: Printer;\r\n  public printerLayouts: ReportLayoutSelectionPrint[] = [];\r\n  public emailLayouts: ReportLayoutSelectionEmail[] = [];\r\n  public selectedPrinterLayout: ReportLayoutSelectionPrint;\r\n  public selectedEmailLayout: ReportLayoutSelectionEmail;\r\n  public receiptOptions: { title: string, iconData: SafeHtml }[];\r\n  public showEmailLayoutOption: boolean = true;\r\n\r\n  @HostBinding(\"class.co-transaction-cash-register-order-receipt-dialog\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit() {\r\n    super.ngOnInit();\r\n    if (this.isReprint) {\r\n      this._prepareDialogData();\r\n      this._getDefaultEmailAddressListForPosReprintReceipt();\r\n    } else {\r\n      this._getDefaultEmailAddressListForPosReceipt();\r\n    }\r\n    this.receiptOptions = this._prepareReceiptOptions();\r\n  }\r\n\r\n  public emailReceipt(): void {\r\n    const request: EmailPosReceiptRequest = new EmailPosReceiptRequest();\r\n    if (this.isReprint) {\r\n      if (this.selectedEmailLayout !== undefined) {\r\n        request.transId = this.currentTransaction.transactionInfo.id;\r\n        request.toAddresses = this.emailAddressList.join(';');\r\n        request.reportId = this.selectedEmailLayout.reportId;\r\n        this.transactionService.emailHistoricPosReceipt(request).then((success: boolean) => {\r\n          if (success) {\r\n            this.handleReceiptOptionSelected.next();\r\n            this.handleClose(this.buttonType.Ok);\r\n          } else {\r\n            this.disableInput = false;\r\n          }\r\n        });\r\n      } else {\r\n        this.disableInput = false;\r\n      }\r\n    } else {\r\n      request.transId = this.transactionInfo.id;\r\n      request.toAddresses = this.emailAddressList.join(';');\r\n      request.reportId = this.cashRegisterPaymentDetails.emailLayout.reportId;\r\n      this.transactionService.emailPosReceipt(request).then((success: boolean) => {\r\n        if (success) {\r\n          this.handleReceiptOptionSelected.next();\r\n        } else {\r\n          this.disableInput = false;\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public printReceipt(): void {\r\n    const request: PrintPosReceiptRequest = new PrintPosReceiptRequest();\r\n    if (this.isReprint) {\r\n      if (this.activePrinter !== undefined && this.selectedPrinterLayout !== undefined) {\r\n        request.transId = this.currentTransaction.transactionInfo.id;\r\n        request.copies = 1;\r\n        request.printerName = this.activePrinter.name;\r\n        request.reportId = this.selectedPrinterLayout.reportId;\r\n        this.transactionService.printHistoricPosReceipt(request).then((success: boolean) => {\r\n          if (success) {\r\n            this.handleReceiptOptionSelected.next();\r\n            this.handleClose(this.buttonType.Ok);\r\n          } else {\r\n            this.disableInput = false;\r\n          }\r\n        });\r\n      } else {\r\n        this.disableInput = false;\r\n      }\r\n    } else {\r\n      request.transId = this.transactionInfo.id;\r\n      request.copies = 1;\r\n      request.printerName = this.cashRegisterPaymentDetails.printer.name;\r\n      request.reportId = this.cashRegisterPaymentDetails.printerLayout.reportId;\r\n      this.transactionService.printPosReceipt(request).then((success: boolean) => {\r\n        if (success) {\r\n          this.handleReceiptOptionSelected.next();\r\n        } else {\r\n          this.disableInput = false;\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public noPrintReceipt(): void {\r\n    this.handleReceiptOptionSelected.next();\r\n    this.disableInput = false;\r\n  }\r\n\r\n  public handleClickReceipt(title: string): void {\r\n    if (!this.disableInput) {\r\n      this.disableInput = true;\r\n\r\n      switch (title) {\r\n        case 'EMAIL':\r\n          this.emailReceipt();\r\n          break;\r\n        case 'PRINT':\r\n          this.printReceipt();\r\n          break;\r\n        case 'NO_RECEIPT':\r\n          this.noPrintReceipt();\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  public handlePrinterChanged(printer: Printer): void {\r\n    this.activePrinter = printer;\r\n  }\r\n\r\n  public handleCloseDialog(event: MouseEvent, type: AppPopupButtonType): void {\r\n    if (event) {\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    }\r\n    this.handleClose(type);\r\n  }\r\n\r\n  public handleClose(type: AppPopupButtonType): void {\r\n    if (type === AppPopupButtonType.Cancel) {\r\n      this.rollback();\r\n    }\r\n    this.close.emit();\r\n    this.onClose(type);\r\n  }\r\n\r\n  public onClose(eventType: AppPopupButtonType, output?: any): void {\r\n    return;\r\n  }\r\n\r\n  private async _getDefaultEmailAddressListForPosReceipt(): Promise<void> {\r\n    this.transactionService.getDefaultEmailAddressListForPosReceipt(this.transactionInfo.uuid)\r\n      .then((emailAddressList: string[]) => {\r\n        this.emailAddressList = emailAddressList;\r\n      });\r\n  }\r\n\r\n  private async _getDefaultEmailAddressListForPosReprintReceipt(): Promise<void> {\r\n    if (this.currentTransaction.transactionInfo.relation !== undefined) {\r\n      this.transactionService.getDefaultEmailAddressListForPosReceipt(this.currentTransaction.transactionInfo.uuid)\r\n        .then((emailAddressList: string[]) => {\r\n          this.emailAddressList = emailAddressList;\r\n        });\r\n    }\r\n  }\r\n\r\n  private async _prepareDialogData(): Promise<void> {\r\n    const promises: Promise<void>[] = [\r\n      this._getPrinters(),\r\n      this._getPrinterLayouts(),\r\n      this._getEmailLayouts()\r\n    ];\r\n    await Promise.all(promises);\r\n  }\r\n\r\n  private async _getPrinters(): Promise<void> {\r\n    this.printerList = await this.transactionService.getPrinters();\r\n  }\r\n\r\n  private async _getPrinterLayouts(): Promise<void> {\r\n    this.printerLayouts = await this.transactionService.getPosReceiptPrintLayouts(this.transactionInfo.uuid);\r\n  }\r\n\r\n  private async _getEmailLayouts(): Promise<void> {\r\n    this.emailLayouts = await this.transactionService.getPosReceiptEmailLayouts(this.transactionInfo.uuid);\r\n  }\r\n\r\n  private _prepareReceiptOptions() {\r\n    let output;\r\n    if (this.isReprint) {\r\n      if (this.currentTransaction.transactionInfo.relation !== undefined) {\r\n        output = [\r\n          {title: 'EMAIL', iconData: this.iconCacheService.getIcon(this.icons.AtSolid)},\r\n          {title: 'PRINT', iconData: this.iconCacheService.getIcon(this.icons.PrintSolid)}\r\n        ]\r\n      } else {\r\n        this.showEmailLayoutOption = false;\r\n        output = [\r\n          {title: 'PRINT', iconData: this.iconCacheService.getIcon(this.icons.PrintSolid)}\r\n        ]\r\n      }\r\n    } else {\r\n      output = [\r\n        {title: 'EMAIL', iconData: this.iconCacheService.getIcon(this.icons.AtSolid)},\r\n        {title: 'PRINT', iconData: this.iconCacheService.getIcon(this.icons.PrintSolid)},\r\n        {title: 'NO_RECEIPT', iconData: this.iconCacheService.getIcon(this.icons.RegularReceiptSlash)}\r\n      ]\r\n    }\r\n    return output;\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,25 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { TransactionCashRegisterOrderReceiptDialogComponent } from "./transaction-cash-register-order-receipt-dialog.component";
4
+ import { CoDialogModule, IconModule, ListOfValuesModule } from "@colijnit/corecomponents_v12";
5
+ import { PipeModule } from "../../../pipe/pipe.module";
6
+ export class TransactionCashRegisterOrderReceiptDialogModule {
7
+ }
8
+ TransactionCashRegisterOrderReceiptDialogModule.decorators = [
9
+ { type: NgModule, args: [{
10
+ imports: [
11
+ CommonModule,
12
+ PipeModule,
13
+ IconModule,
14
+ CoDialogModule,
15
+ ListOfValuesModule
16
+ ],
17
+ declarations: [
18
+ TransactionCashRegisterOrderReceiptDialogComponent
19
+ ],
20
+ exports: [
21
+ TransactionCashRegisterOrderReceiptDialogComponent
22
+ ]
23
+ },] }
24
+ ];
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24tY2FzaC1yZWdpc3Rlci1vcmRlci1yZWNlaXB0LWRpYWxvZy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC90cmFuc2FjdGlvbi1jYXNoLXJlZ2lzdGVyLW9yZGVyL3RyYW5zYWN0aW9uLWNhc2gtcmVnaXN0ZXItb3JkZXItcmVjZWlwdC1kaWFsb2cvdHJhbnNhY3Rpb24tY2FzaC1yZWdpc3Rlci1vcmRlci1yZWNlaXB0LWRpYWxvZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGtEQUFrRCxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDOUgsT0FBTyxFQUFDLGNBQWMsRUFBRSxVQUFVLEVBQUUsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUM1RixPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFpQnJELE1BQU0sT0FBTywrQ0FBK0M7OztZQWYzRCxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osVUFBVTtvQkFDVixVQUFVO29CQUNWLGNBQWM7b0JBQ2Qsa0JBQWtCO2lCQUNuQjtnQkFDQyxZQUFZLEVBQUU7b0JBQ1Ysa0RBQWtEO2lCQUNyRDtnQkFDRCxPQUFPLEVBQUU7b0JBQ0wsa0RBQWtEO2lCQUNyRDthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtUcmFuc2FjdGlvbkNhc2hSZWdpc3Rlck9yZGVyUmVjZWlwdERpYWxvZ0NvbXBvbmVudH0gZnJvbSBcIi4vdHJhbnNhY3Rpb24tY2FzaC1yZWdpc3Rlci1vcmRlci1yZWNlaXB0LWRpYWxvZy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtDb0RpYWxvZ01vZHVsZSwgSWNvbk1vZHVsZSwgTGlzdE9mVmFsdWVzTW9kdWxlfSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMlwiO1xyXG5pbXBvcnQge1BpcGVNb2R1bGV9IGZyb20gXCIuLi8uLi8uLi9waXBlL3BpcGUubW9kdWxlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFBpcGVNb2R1bGUsXHJcbiAgICBJY29uTW9kdWxlLFxyXG4gICAgQ29EaWFsb2dNb2R1bGUsXHJcbiAgICBMaXN0T2ZWYWx1ZXNNb2R1bGVcclxuICBdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgVHJhbnNhY3Rpb25DYXNoUmVnaXN0ZXJPcmRlclJlY2VpcHREaWFsb2dDb21wb25lbnRcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgVHJhbnNhY3Rpb25DYXNoUmVnaXN0ZXJPcmRlclJlY2VpcHREaWFsb2dDb21wb25lbnRcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFRyYW5zYWN0aW9uQ2FzaFJlZ2lzdGVyT3JkZXJSZWNlaXB0RGlhbG9nTW9kdWxlIHtcclxufVxyXG4iXX0=
@@ -95,42 +95,45 @@ TransactionCashRegisterPaymentDialogComponent.decorators = [
95
95
  { type: Component, args: [{
96
96
  selector: "co-transaction-cash-register-payment-dialog",
97
97
  template: `
98
- <co-dialog [showCloseIcon]=true [headerTemplate]="headerTemplate" (closeClick)="closeDialog.emit()">
99
- <div class="dialog-content-wrapper">
100
- <div class="image-wrapper">
101
- <img class="payment-image">
102
- </div>
103
- <div class="payment-wrapper" *ngIf="transactionSaved">
104
- <co-transaction-cash-register-payment-pin *ngIf="paymentState === paymentStates.Pin" @showHideContent
105
- (toCashRegisterOrderClicked)="closeDialog.next()"
106
- (changePaymentMethodClicked)="changePaymentMethodClicked()"
107
- ></co-transaction-cash-register-payment-pin>
108
- <co-transaction-cash-register-payment-cash *ngIf="paymentState === paymentStates.Cash" @showHideContent
109
- (toCashRegisterOrderClicked)="closeDialog.next()"
110
- (changePaymentMethodClicked)="changePaymentMethodClicked()"
111
- (confirmPaymentClicked)="handlePayment()"
112
- ></co-transaction-cash-register-payment-cash>
113
- <co-transaction-cash-register-payment-qr-code *ngIf="paymentState === paymentStates.QR" @showHideContent
114
- (toCashRegisterOrderClicked)="closeDialog.next()"
115
- (changePaymentMethodClicked)="changePaymentMethodClicked()"
116
- ></co-transaction-cash-register-payment-qr-code>
117
- <co-transaction-cash-register-payment-method *ngIf="paymentState === paymentStates.ChangeMethod" @showHideContent
118
- (paymentMethodChanged)="handleChangePaymentMethod($event)"
119
- ></co-transaction-cash-register-payment-method>
120
- <co-transaction-cash-register-payment-done *ngIf="paymentState === paymentStates.Done" @showHideContent
121
- [relation]="relation"
122
- (handleReceiptOptionSelected)="handleCloseDialog()"
123
- ></co-transaction-cash-register-payment-done>
124
- <span class="payment-status-message" *ngIf="paymentService.statusMessage" [textContent]="paymentService.statusMessage"></span>
125
- </div>
126
- </div>
127
- </co-dialog>
128
- <ng-template #headerTemplate>
129
- <div class="title-wrapper">
130
- <span [textContent]="'POS_ORDER2' | localize | append: ' ' | append: transactionNr"></span>
131
- <span class="title-date" [textContent]="(currentDate | date: 'dd MMMM yyy') + ' | ' + (currentDate | date: 'HH:mm')"></span>
132
- </div>
133
- </ng-template>
98
+ <co-dialog [showCloseIcon]=true [headerTemplate]="headerTemplate" (closeClick)="closeDialog.emit()">
99
+ <div class="dialog-content-wrapper">
100
+ <div class="image-wrapper">
101
+ <img class="payment-image">
102
+ </div>
103
+ <div class="payment-wrapper" *ngIf="transactionSaved">
104
+ <co-transaction-cash-register-payment-pin *ngIf="paymentState === paymentStates.Pin" @showHideContent
105
+ (toCashRegisterOrderClicked)="closeDialog.next()"
106
+ (changePaymentMethodClicked)="changePaymentMethodClicked()"
107
+ ></co-transaction-cash-register-payment-pin>
108
+ <co-transaction-cash-register-payment-cash *ngIf="paymentState === paymentStates.Cash" @showHideContent
109
+ (toCashRegisterOrderClicked)="closeDialog.next()"
110
+ (changePaymentMethodClicked)="changePaymentMethodClicked()"
111
+ (confirmPaymentClicked)="handlePayment()"
112
+ ></co-transaction-cash-register-payment-cash>
113
+ <co-transaction-cash-register-payment-qr-code *ngIf="paymentState === paymentStates.QR" @showHideContent
114
+ (toCashRegisterOrderClicked)="closeDialog.next()"
115
+ (changePaymentMethodClicked)="changePaymentMethodClicked()"
116
+ ></co-transaction-cash-register-payment-qr-code>
117
+ <co-transaction-cash-register-payment-method *ngIf="paymentState === paymentStates.ChangeMethod"
118
+ @showHideContent
119
+ (paymentMethodChanged)="handleChangePaymentMethod($event)"
120
+ ></co-transaction-cash-register-payment-method>
121
+ <co-transaction-cash-register-payment-done *ngIf="paymentState === paymentStates.Done" @showHideContent
122
+ [relation]="relation"
123
+ (handleReceiptOptionSelected)="handleCloseDialog()"
124
+ ></co-transaction-cash-register-payment-done>
125
+ <span class="payment-status-message" *ngIf="paymentService.statusMessage"
126
+ [textContent]="paymentService.statusMessage"></span>
127
+ </div>
128
+ </div>
129
+ </co-dialog>
130
+ <ng-template #headerTemplate>
131
+ <div class="title-wrapper">
132
+ <span [textContent]="'POS_ORDER2' | localize | append: ' ' | append: transactionNr"></span>
133
+ <span class="title-date"
134
+ [textContent]="(currentDate | date: 'dd MMMM yyy') + ' | ' + (currentDate | date: 'HH:mm')"></span>
135
+ </div>
136
+ </ng-template>
134
137
  `,
135
138
  providers: [
136
139
  TransactionPaymentService
@@ -162,4 +165,4 @@ TransactionCashRegisterPaymentDialogComponent.propDecorators = {
162
165
  posOrderPayed: [{ type: Output }],
163
166
  showClass: [{ type: HostBinding, args: ["class.co-transaction-cash-register-payment-dialog",] }]
164
167
  };
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-cash-register-payment-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-cash-register-order/transaction-cash-register-payment-dialog/transaction-cash-register-payment-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {PaymentViewmodel} from '../../../model/payment.viewmodel';\r\nimport {TransactionCashRegisterPaymentState} from './transaction-cash-register-payment-state.enum';\r\nimport {TransactionPaymentConnectorService} from '../../../service/transaction-payment-connector.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {TransactionPaymentBaseComponent} from '../../core/base/transaction-payment-base.component';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionInfoResponse} from '@colijnit/transactionapi/build/model/transaction-info-response.bo';\r\nimport {TransactionPaymentService} from '../../../service/transaction-payment.service';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\n\r\n@Component({\r\n  selector: \"co-transaction-cash-register-payment-dialog\",\r\n  template: `\r\n      <co-dialog [showCloseIcon]=true [headerTemplate]=\"headerTemplate\" (closeClick)=\"closeDialog.emit()\">\r\n          <div class=\"dialog-content-wrapper\">\r\n              <div class=\"image-wrapper\">\r\n                  <img class=\"payment-image\">\r\n              </div>\r\n              <div class=\"payment-wrapper\" *ngIf=\"transactionSaved\">\r\n                  <co-transaction-cash-register-payment-pin *ngIf=\"paymentState === paymentStates.Pin\" @showHideContent\r\n                                                            (toCashRegisterOrderClicked)=\"closeDialog.next()\"\r\n                                                            (changePaymentMethodClicked)=\"changePaymentMethodClicked()\"\r\n                  ></co-transaction-cash-register-payment-pin>\r\n                  <co-transaction-cash-register-payment-cash *ngIf=\"paymentState === paymentStates.Cash\" @showHideContent\r\n                                                             (toCashRegisterOrderClicked)=\"closeDialog.next()\"\r\n                                                             (changePaymentMethodClicked)=\"changePaymentMethodClicked()\"\r\n                                                             (confirmPaymentClicked)=\"handlePayment()\"\r\n                  ></co-transaction-cash-register-payment-cash>\r\n                  <co-transaction-cash-register-payment-qr-code *ngIf=\"paymentState === paymentStates.QR\" @showHideContent\r\n                                                                (toCashRegisterOrderClicked)=\"closeDialog.next()\"\r\n                                                                (changePaymentMethodClicked)=\"changePaymentMethodClicked()\"\r\n                  ></co-transaction-cash-register-payment-qr-code>\r\n                  <co-transaction-cash-register-payment-method *ngIf=\"paymentState === paymentStates.ChangeMethod\" @showHideContent\r\n                                                               (paymentMethodChanged)=\"handleChangePaymentMethod($event)\"\r\n                  ></co-transaction-cash-register-payment-method>\r\n                  <co-transaction-cash-register-payment-done *ngIf=\"paymentState === paymentStates.Done\" @showHideContent\r\n                                                             [relation]=\"relation\"\r\n                                                             (handleReceiptOptionSelected)=\"handleCloseDialog()\"\r\n                  ></co-transaction-cash-register-payment-done>\r\n                  <span class=\"payment-status-message\" *ngIf=\"paymentService.statusMessage\" [textContent]=\"paymentService.statusMessage\"></span>\r\n              </div>\r\n          </div>\r\n      </co-dialog>\r\n      <ng-template #headerTemplate>\r\n          <div class=\"title-wrapper\">\r\n              <span [textContent]=\"'POS_ORDER2' | localize | append: ' ' | append: transactionNr\"></span>\r\n              <span class=\"title-date\" [textContent]=\"(currentDate | date: 'dd MMMM yyy') + ' | ' + (currentDate | date: 'HH:mm')\"></span>\r\n          </div>\r\n      </ng-template>\r\n  `,\r\n  providers: [\r\n    TransactionPaymentService\r\n  ],\r\n  animations: [\r\n    trigger('showHideContent', [\r\n      state('void', style({transform: 'translateX(100%)'})),\r\n      state('*', style({transform: 'translateX(0)'})),\r\n      transition('void => *', animate('200ms 200ms ease-in-out')),\r\n      transition('* => void', animate('200ms ease-out'))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionCashRegisterPaymentDialogComponent extends TransactionPaymentBaseComponent implements OnInit {\r\n  public readonly paymentStates: typeof TransactionCashRegisterPaymentState = TransactionCashRegisterPaymentState;\r\n\r\n  @Input()\r\n  public relation: RelationAnyType;\r\n\r\n  @Input()\r\n  public transactionNr: number;\r\n\r\n  @Input()\r\n  public set paymentViewModel(paymentViewModel: PaymentViewmodel) {\r\n    this.paymentService.statusMessage = \"\";\r\n    this._paymentViewModel = paymentViewModel;\r\n    this.currentPaymentMethod = this._paymentViewModel.payment;\r\n    if (this.currentPaymentMethod.externalSourceId) {\r\n      if (this.currentPaymentMethod.pinTerminal) {\r\n        this._changePaymentState(TransactionCashRegisterPaymentState.Pin);\r\n      } else {\r\n        this._changePaymentState(TransactionCashRegisterPaymentState.QR);\r\n      }\r\n    } else if (this.currentPaymentMethod.cash) {\r\n      this._changePaymentState(TransactionCashRegisterPaymentState.Cash);\r\n    }\r\n  }\r\n\r\n  @Output()\r\n  public closeDialog: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public posOrderPayed: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @HostBinding(\"class.co-transaction-cash-register-payment-dialog\")\r\n  public showClass: boolean = true;\r\n\r\n  public currentDate: Date = new Date();\r\n  public paymentDone: boolean = false;\r\n  public amountPayed: number = 0;\r\n  public paymentState: TransactionCashRegisterPaymentState = TransactionCashRegisterPaymentState.Pin;\r\n  public transactionSaved: boolean = false;\r\n\r\n  private _paymentViewModel: PaymentViewmodel;\r\n\r\n  constructor(\r\n    protected transactionService: TransactionService,\r\n    protected paymentConnectorService: TransactionPaymentConnectorService,\r\n    protected transactionEventService: TransactionEventService,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    public paymentService: TransactionPaymentService,\r\n    public iconCacheService: IconCacheService,\r\n  ){\r\n    super(transactionService, paymentConnectorService, transactionEventService, changeDetector, paymentService, iconCacheService);\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.subs.push(\r\n      this.paymentService.payed.subscribe(() => this.handlePayed()),\r\n      this.paymentService.paymentFailed.subscribe(() => this.paymentState = TransactionCashRegisterPaymentState.ChangeMethod)\r\n    )\r\n    this.paymentService.getDepositAmount = false;\r\n    this.useCashRegisters = false;\r\n    const response: TransactionInfoResponse = await this.transactionService.saveTransaction();\r\n    if (response && response.isSuccess) {\r\n      this.transId = response.transactionInfo.id;\r\n    }\r\n    await super.ngOnInit();\r\n    this.transactionSaved = true;\r\n  }\r\n\r\n  public changePaymentMethodClicked(): void {\r\n    this._changePaymentState(TransactionCashRegisterPaymentState.ChangeMethod);\r\n  }\r\n\r\n  public handleChangePaymentMethod(paymentViewModel: PaymentViewmodel): void {\r\n    this.paymentViewModel = paymentViewModel;\r\n  }\r\n\r\n  public handleKeyPadModelChange(model: number): void {\r\n    this.amountPayed = model;\r\n  }\r\n\r\n  public async handlePayed(): Promise<void> {\r\n    this.paymentDone = true;\r\n    const processed: boolean = await this.paymentConnectorService.processPosTransactionByUuid(this.transactionUuid);\r\n    if (processed) {\r\n      const success: boolean = await this.transactionService.commit();\r\n      if (success) {\r\n        this._changePaymentState(TransactionCashRegisterPaymentState.Done);\r\n      }\r\n    }\r\n  }\r\n\r\n  public handleCloseDialog(): void {\r\n    this.closeDialog.next();\r\n    this.posOrderPayed.next();\r\n  }\r\n\r\n  private _changePaymentState(newState: TransactionCashRegisterPaymentState): void {\r\n    this.paymentState = undefined;\r\n    setTimeout(() => {\r\n      this.paymentState = newState;\r\n    }, 200)\r\n  }\r\n}\r\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-cash-register-payment-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/transaction-cash-register-order/transaction-cash-register-payment-dialog/transaction-cash-register-payment-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {PaymentViewmodel} from '../../../model/payment.viewmodel';\r\nimport {TransactionCashRegisterPaymentState} from './transaction-cash-register-payment-state.enum';\r\nimport {TransactionPaymentConnectorService} from '../../../service/transaction-payment-connector.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {TransactionEventService} from '../../../service/transaction-event.service';\r\nimport {TransactionPaymentBaseComponent} from '../../core/base/transaction-payment-base.component';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionInfoResponse} from '@colijnit/transactionapi/build/model/transaction-info-response.bo';\r\nimport {TransactionPaymentService} from '../../../service/transaction-payment.service';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\n\r\n@Component({\r\n  selector: \"co-transaction-cash-register-payment-dialog\",\r\n  template: `\r\n    <co-dialog [showCloseIcon]=true [headerTemplate]=\"headerTemplate\" (closeClick)=\"closeDialog.emit()\">\r\n      <div class=\"dialog-content-wrapper\">\r\n        <div class=\"image-wrapper\">\r\n          <img class=\"payment-image\">\r\n        </div>\r\n        <div class=\"payment-wrapper\" *ngIf=\"transactionSaved\">\r\n          <co-transaction-cash-register-payment-pin *ngIf=\"paymentState === paymentStates.Pin\" @showHideContent\r\n                                                    (toCashRegisterOrderClicked)=\"closeDialog.next()\"\r\n                                                    (changePaymentMethodClicked)=\"changePaymentMethodClicked()\"\r\n          ></co-transaction-cash-register-payment-pin>\r\n          <co-transaction-cash-register-payment-cash *ngIf=\"paymentState === paymentStates.Cash\" @showHideContent\r\n                                                     (toCashRegisterOrderClicked)=\"closeDialog.next()\"\r\n                                                     (changePaymentMethodClicked)=\"changePaymentMethodClicked()\"\r\n                                                     (confirmPaymentClicked)=\"handlePayment()\"\r\n          ></co-transaction-cash-register-payment-cash>\r\n          <co-transaction-cash-register-payment-qr-code *ngIf=\"paymentState === paymentStates.QR\" @showHideContent\r\n                                                        (toCashRegisterOrderClicked)=\"closeDialog.next()\"\r\n                                                        (changePaymentMethodClicked)=\"changePaymentMethodClicked()\"\r\n          ></co-transaction-cash-register-payment-qr-code>\r\n          <co-transaction-cash-register-payment-method *ngIf=\"paymentState === paymentStates.ChangeMethod\"\r\n                                                       @showHideContent\r\n                                                       (paymentMethodChanged)=\"handleChangePaymentMethod($event)\"\r\n          ></co-transaction-cash-register-payment-method>\r\n          <co-transaction-cash-register-payment-done *ngIf=\"paymentState === paymentStates.Done\" @showHideContent\r\n                                                     [relation]=\"relation\"\r\n                                                     (handleReceiptOptionSelected)=\"handleCloseDialog()\"\r\n          ></co-transaction-cash-register-payment-done>\r\n          <span class=\"payment-status-message\" *ngIf=\"paymentService.statusMessage\"\r\n                [textContent]=\"paymentService.statusMessage\"></span>\r\n        </div>\r\n      </div>\r\n    </co-dialog>\r\n    <ng-template #headerTemplate>\r\n      <div class=\"title-wrapper\">\r\n        <span [textContent]=\"'POS_ORDER2' | localize | append: ' ' | append: transactionNr\"></span>\r\n        <span class=\"title-date\"\r\n              [textContent]=\"(currentDate | date: 'dd MMMM yyy') + ' | ' + (currentDate | date: 'HH:mm')\"></span>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n  providers: [\r\n    TransactionPaymentService\r\n  ],\r\n  animations: [\r\n    trigger('showHideContent', [\r\n      state('void', style({transform: 'translateX(100%)'})),\r\n      state('*', style({transform: 'translateX(0)'})),\r\n      transition('void => *', animate('200ms 200ms ease-in-out')),\r\n      transition('* => void', animate('200ms ease-out'))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class TransactionCashRegisterPaymentDialogComponent extends TransactionPaymentBaseComponent implements OnInit {\r\n  public readonly paymentStates: typeof TransactionCashRegisterPaymentState = TransactionCashRegisterPaymentState;\r\n\r\n  @Input()\r\n  public relation: RelationAnyType;\r\n\r\n  @Input()\r\n  public transactionNr: number;\r\n\r\n  @Input()\r\n  public set paymentViewModel(paymentViewModel: PaymentViewmodel) {\r\n    this.paymentService.statusMessage = \"\";\r\n    this._paymentViewModel = paymentViewModel;\r\n    this.currentPaymentMethod = this._paymentViewModel.payment;\r\n    if (this.currentPaymentMethod.externalSourceId) {\r\n      if (this.currentPaymentMethod.pinTerminal) {\r\n        this._changePaymentState(TransactionCashRegisterPaymentState.Pin);\r\n      } else {\r\n        this._changePaymentState(TransactionCashRegisterPaymentState.QR);\r\n      }\r\n    } else if (this.currentPaymentMethod.cash) {\r\n      this._changePaymentState(TransactionCashRegisterPaymentState.Cash);\r\n    }\r\n  }\r\n\r\n  @Output()\r\n  public closeDialog: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public posOrderPayed: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @HostBinding(\"class.co-transaction-cash-register-payment-dialog\")\r\n  public showClass: boolean = true;\r\n\r\n  public currentDate: Date = new Date();\r\n  public paymentDone: boolean = false;\r\n  public amountPayed: number = 0;\r\n  public paymentState: TransactionCashRegisterPaymentState = TransactionCashRegisterPaymentState.Pin;\r\n  public transactionSaved: boolean = false;\r\n\r\n  private _paymentViewModel: PaymentViewmodel;\r\n\r\n  constructor(\r\n    protected transactionService: TransactionService,\r\n    protected paymentConnectorService: TransactionPaymentConnectorService,\r\n    protected transactionEventService: TransactionEventService,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    public paymentService: TransactionPaymentService,\r\n    public iconCacheService: IconCacheService,\r\n  ) {\r\n    super(transactionService, paymentConnectorService, transactionEventService, changeDetector, paymentService, iconCacheService);\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.subs.push(\r\n      this.paymentService.payed.subscribe(() => this.handlePayed()),\r\n      this.paymentService.paymentFailed.subscribe(() => this.paymentState = TransactionCashRegisterPaymentState.ChangeMethod)\r\n    )\r\n    this.paymentService.getDepositAmount = false;\r\n    this.useCashRegisters = false;\r\n    const response: TransactionInfoResponse = await this.transactionService.saveTransaction();\r\n    if (response && response.isSuccess) {\r\n      this.transId = response.transactionInfo.id;\r\n    }\r\n    await super.ngOnInit();\r\n    this.transactionSaved = true;\r\n  }\r\n\r\n  public changePaymentMethodClicked(): void {\r\n    this._changePaymentState(TransactionCashRegisterPaymentState.ChangeMethod);\r\n  }\r\n\r\n  public handleChangePaymentMethod(paymentViewModel: PaymentViewmodel): void {\r\n    this.paymentViewModel = paymentViewModel;\r\n  }\r\n\r\n  public handleKeyPadModelChange(model: number): void {\r\n    this.amountPayed = model;\r\n  }\r\n\r\n  public async handlePayed(): Promise<void> {\r\n    this.paymentDone = true;\r\n    const processed: boolean = await this.paymentConnectorService.processPosTransactionByUuid(this.transactionUuid);\r\n    if (processed) {\r\n      const success: boolean = await this.transactionService.commit();\r\n      if (success) {\r\n        this._changePaymentState(TransactionCashRegisterPaymentState.Done);\r\n      }\r\n    }\r\n  }\r\n\r\n  public handleCloseDialog(): void {\r\n    this.closeDialog.next();\r\n    this.posOrderPayed.next();\r\n  }\r\n\r\n  private _changePaymentState(newState: TransactionCashRegisterPaymentState): void {\r\n    this.paymentState = undefined;\r\n    setTimeout(() => {\r\n      this.paymentState = newState;\r\n    }, 200)\r\n  }\r\n}\r\n"]}