@colijnit/transaction 12.1.226 → 254.1.2

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 (102) hide show
  1. package/bundles/colijnit-transaction.umd.js +2708 -656
  2. package/bundles/colijnit-transaction.umd.js.map +1 -1
  3. package/colijnit-transaction.d.ts +308 -295
  4. package/colijnit-transaction.metadata.json +1 -1
  5. package/esm2015/colijnit-transaction.js +309 -296
  6. package/esm2015/lib/component/checkout/checkout.component.js +30 -1
  7. package/esm2015/lib/component/checkout-simple/checkout-simple-overview-delivery-edit/checkout-simple-overview-delivery-edit.component.js +213 -0
  8. package/esm2015/lib/component/checkout-simple/checkout-simple-overview-payment/checkout-simple-overview-payment.component.js +105 -0
  9. package/esm2015/lib/component/checkout-simple/checkout-simple-overview-relation-edit/checkout-simple-overview-relation-edit.component.js +256 -0
  10. package/esm2015/lib/component/checkout-simple/checkout-simple.component.js +186 -0
  11. package/esm2015/lib/component/checkout-simple/checkout-simple.module.js +88 -0
  12. package/esm2015/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.js +11 -4
  13. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-direct-sell.component.js +160 -9
  14. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.component.js +12 -10
  15. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.module.js +5 -3
  16. package/esm2015/lib/component/relation/relation-general/relation-general.component.js +28 -20
  17. package/esm2015/lib/component/service-wizard-qa/question-answer-item/question-answer-item.component.js +72 -0
  18. package/esm2015/lib/component/service-wizard-qa/question-answer-item/question-answer-item.module.js +23 -0
  19. package/esm2015/lib/component/service-wizard-qa/service-wizard-qa.component.js +38 -0
  20. package/esm2015/lib/component/service-wizard-qa/service-wizard-qa.module.js +25 -0
  21. package/esm2015/lib/component/transaction-create-wizard/transaction-create-wizard.component.js +137 -0
  22. package/esm2015/lib/component/transaction-create-wizard/transaction-create-wizard.module.js +38 -0
  23. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-create-service.component.js +134 -0
  24. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-relation.component.js +18 -11
  25. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-fields.component.js +41 -0
  26. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-wizard.component.js +40 -0
  27. package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup.module.js +21 -5
  28. package/esm2015/lib/component/transaction-internal/transaction-internal.component.js +16 -2
  29. package/esm2015/lib/component/transaction-line/transaction-invoice-line/transaction-invoice-line-base.component.js +4 -2
  30. package/esm2015/lib/component/transaction-line/transaction-order-delivery-line/transaction-order-delivery-line-base.component.js +1 -2
  31. package/esm2015/lib/component/transaction-line-action-buttons/transaction-line-action-buttons-popup.component.js +20 -9
  32. package/esm2015/lib/component/transaction-line-action-buttons/transaction-line-action-buttons.component.js +10 -7
  33. package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-invoice/transaction-quick-access-invoice.component.js +1 -1
  34. package/esm2015/lib/component/transaction-search/transaction-filter-content/cash-desk-filter-content/transaction-cash-desk-filter-content-article/transaction-cash-desk-filter-content-article.component.js +2 -2
  35. package/esm2015/lib/component/transaction-search/transaction-filter-content/cash-desk-filter-content/transaction-cash-desk-filter-content-logistics/transaction-cash-desk-filter-content-logistics.component.js +3 -3
  36. package/esm2015/lib/component/transaction-search/transaction-filter-content/cash-desk-filter-content/transaction-cash-desk-filter-content-order/transaction-cash-desk-filter-content-order.component.js +2 -2
  37. package/esm2015/lib/component/transaction-search/transaction-filter-content/purchase-order-filter-content/transaction-purchase-order-filter-content-article/transaction-purchase-order-filter-content-article.component.js +2 -2
  38. package/esm2015/lib/component/transaction-search/transaction-filter-content/purchase-order-filter-content/transaction-purchase-order-filter-content-logistics/transaction-purchase-order-filter-content-logistics.component.js +3 -3
  39. package/esm2015/lib/component/transaction-search/transaction-filter-content/sales-order-filter-content/transaction-sales-order-filter-content-article/transaction-sales-order-filter-content-article.component.js +2 -2
  40. package/esm2015/lib/component/transaction-search/transaction-filter-content/sales-order-filter-content/transaction-sales-order-filter-content-logistics/transaction-sales-order-filter-content-logistics.component.js +3 -3
  41. package/esm2015/lib/component/transaction-search/transaction-filter-content/sales-order-filter-content/transaction-sales-order-filter-content-order/transaction-sales-order-filter-content-order.component.js +2 -2
  42. package/esm2015/lib/component/transaction-search/transaction-filter-content/sales-quotation-filter-content/transaction-sales-quotation-filter-content-article/transaction-sales-quotation-filter-content-article.component.js +2 -2
  43. package/esm2015/lib/component/transaction-search/transaction-filter-content/sales-quotation-filter-content/transaction-sales-quotation-filter-content-logistics/transaction-sales-quotation-filter-content-logistics.component.js +2 -2
  44. package/esm2015/lib/component/transaction-search/transaction-filter-content/sales-quotation-filter-content/transaction-sales-quotation-filter-content-order/transaction-sales-quotation-filter-content-order.component.js +2 -2
  45. package/esm2015/lib/component/transaction-search/transaction-search-result/transaction-search-result.module.js +1 -1
  46. package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.component.js +32 -2
  47. package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.module.js +4 -3
  48. package/esm2015/lib/service/dialog.service.js +4 -3
  49. package/esm2015/lib/service/pending-reason.service.js +4 -4
  50. package/esm2015/lib/service/transaction-base.service.js +7 -3
  51. package/esm2015/lib/service/transaction-connector-adapter.service.js +165 -1
  52. package/esm2015/lib/service/transaction-connector.service.js +69 -1
  53. package/esm2015/lib/service/transaction-create.service.js +67 -0
  54. package/esm2015/lib/service/transaction-creation.service.js +3 -2
  55. package/esm2015/lib/service/transaction-event.service.js +3 -1
  56. package/esm2015/lib/service/transaction-relation-connector.service.js +22 -1
  57. package/esm2015/lib/service/transaction-relation.service.js +7 -1
  58. package/esm2015/lib/service/transaction.service.js +136 -11
  59. package/esm2015/lib/transaction-version.js +3 -3
  60. package/esm2015/public_api.js +3 -1
  61. package/fesm2015/colijnit-transaction.js +2409 -388
  62. package/fesm2015/colijnit-transaction.js.map +1 -1
  63. package/lib/component/checkout/checkout.component.d.ts +9 -1
  64. package/lib/component/checkout-simple/checkout-simple-overview-delivery-edit/checkout-simple-overview-delivery-edit.component.d.ts +55 -0
  65. package/lib/component/checkout-simple/checkout-simple-overview-payment/checkout-simple-overview-payment.component.d.ts +22 -0
  66. package/lib/component/checkout-simple/checkout-simple-overview-relation-edit/checkout-simple-overview-relation-edit.component.d.ts +46 -0
  67. package/lib/component/checkout-simple/checkout-simple.component.d.ts +50 -0
  68. package/lib/component/checkout-simple/checkout-simple.module.d.ts +2 -0
  69. package/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.d.ts +1 -0
  70. package/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-direct-sell.component.d.ts +26 -3
  71. package/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/style/_layout.scss +107 -1
  72. package/lib/component/relation/relation-general/relation-general.component.d.ts +3 -1
  73. package/lib/component/service-wizard-qa/question-answer-item/question-answer-item.component.d.ts +19 -0
  74. package/lib/component/service-wizard-qa/question-answer-item/question-answer-item.module.d.ts +2 -0
  75. package/lib/component/service-wizard-qa/question-answer-item/style/_layout.scss +28 -0
  76. package/lib/component/service-wizard-qa/question-answer-item/style/_material-definition.scss +24 -0
  77. package/lib/component/service-wizard-qa/question-answer-item/style/_theme.scss +5 -0
  78. package/lib/component/service-wizard-qa/question-answer-item/style/material.scss +3 -0
  79. package/lib/component/service-wizard-qa/service-wizard-qa.component.d.ts +12 -0
  80. package/lib/component/service-wizard-qa/service-wizard-qa.module.d.ts +2 -0
  81. package/lib/component/transaction-create-wizard/transaction-create-wizard.component.d.ts +34 -0
  82. package/lib/component/transaction-create-wizard/transaction-create-wizard.module.d.ts +2 -0
  83. package/lib/component/transaction-header/transaction-header-popup/style/_layout.scss +32 -1
  84. package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-create-service.component.d.ts +30 -0
  85. package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-relation.component.d.ts +3 -0
  86. package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-fields.component.d.ts +9 -0
  87. package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-wizard.component.d.ts +12 -0
  88. package/lib/component/transaction-internal/transaction-internal.component.d.ts +1 -0
  89. package/lib/component/transaction-line-action-buttons/transaction-line-action-buttons-popup.component.d.ts +2 -0
  90. package/lib/component/transaction-line-action-buttons/transaction-line-action-buttons.component.d.ts +2 -2
  91. package/lib/component/transaction-service-overview/transaction-service-overview.component.d.ts +6 -0
  92. package/lib/service/dialog.service.d.ts +2 -1
  93. package/lib/service/transaction-base.service.d.ts +3 -1
  94. package/lib/service/transaction-connector-adapter.service.d.ts +22 -0
  95. package/lib/service/transaction-connector.service.d.ts +22 -0
  96. package/lib/service/transaction-create.service.d.ts +7 -0
  97. package/lib/service/transaction-event.service.d.ts +5 -0
  98. package/lib/service/transaction-relation-connector.service.d.ts +1 -0
  99. package/lib/service/transaction-relation.service.d.ts +1 -0
  100. package/lib/service/transaction.service.d.ts +25 -1
  101. package/package.json +13 -12
  102. package/public_api.d.ts +2 -0
@@ -0,0 +1,256 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
3
+ import { TransactionService } from '../../../service/transaction.service';
4
+ import { FormMasterService } from '@colijnit/corecomponents_v12';
5
+ import { animate, state, style, transition, trigger } from '@angular/animations';
6
+ import { Icon } from '../../../enum/icon.enum';
7
+ import { CustomerFullObject } from '@colijnit/relationapi/build/model/customer-full-object.bo';
8
+ import { RelationKind } from '@colijnit/relationapi/build/enum/relation-kind.enum';
9
+ import { AddressType } from '@colijnit/relationapi/build/enum/address-type.enum';
10
+ import { RelationNameKind } from '@colijnit/relationapi/build/enum/relation-name-kind.enum';
11
+ import { SupplierFullObject } from '@colijnit/relationapi/build/model/supplier-full-object.bo';
12
+ export class CheckoutSimpleOverviewRelationEditComponent {
13
+ constructor(_formMaster, service) {
14
+ this._formMaster = _formMaster;
15
+ this.service = service;
16
+ this.relKind = RelationKind;
17
+ this.icons = Icon;
18
+ this.addressType = AddressType;
19
+ this.validSubmit = new EventEmitter();
20
+ this.invalidSubmit = new EventEmitter();
21
+ this.deliveryAddressChange = new EventEmitter();
22
+ this.invoiceAddressChange = new EventEmitter();
23
+ this.relationChange = new EventEmitter();
24
+ this._relation = new CustomerFullObject();
25
+ this._relationKind = RelationKind.Customer;
26
+ this.relationType = RelationNameKind.Private;
27
+ }
28
+ set relation(value) {
29
+ if (this._relation && value && this._relation.relationId === value.relationId) {
30
+ return;
31
+ }
32
+ this._relation = value;
33
+ if (this._relation) {
34
+ if (this._relation instanceof SupplierFullObject) {
35
+ this._relation.type = RelationNameKind.Company;
36
+ this.relationType = RelationNameKind.Company;
37
+ }
38
+ if (this._relation instanceof CustomerFullObject) {
39
+ this.customerGroup = this._relation.customerGroup;
40
+ }
41
+ this.address = this._relation.getFirstAddressOrCreateNew();
42
+ }
43
+ }
44
+ get relation() {
45
+ return this._relation;
46
+ }
47
+ set relationKind(value) {
48
+ this._relationKind = value;
49
+ if (this._relationKind === RelationKind.Supplier) {
50
+ this.relationType = RelationNameKind.Company;
51
+ }
52
+ }
53
+ get relationKind() {
54
+ return this._relationKind;
55
+ }
56
+ showClass() {
57
+ return true;
58
+ }
59
+ get applicationUser() {
60
+ return this.service.applicationUser;
61
+ }
62
+ ngOnInit() {
63
+ return __awaiter(this, void 0, void 0, function* () {
64
+ if (this._relation) {
65
+ this.address = this._relation.getFirstAddressOrCreateNew();
66
+ }
67
+ });
68
+ }
69
+ ngAfterViewInit() {
70
+ const firstActiveAddress = this._relation.activeAddresses.length > 0 ? this._relation.activeAddresses[0] : undefined;
71
+ if (!this.deliveryAddressNawNr) {
72
+ this.deliveryAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;
73
+ this.deliveryAddressChange.emit(this.deliveryAddressNawNr);
74
+ }
75
+ if (!this.invoiceAddressNawNr) {
76
+ this.invoiceAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;
77
+ this.invoiceAddressChange.emit(this.invoiceAddressNawNr);
78
+ }
79
+ }
80
+ handleRelationTypeChange(relation) {
81
+ this.relationType = relation.type;
82
+ }
83
+ emptyRelation(event) {
84
+ this.service.createNewRelation();
85
+ this.updateRelation(this.service.relation);
86
+ }
87
+ handleCustomerGroupChange(group) {
88
+ this.customerGroup = group;
89
+ if (this._relation instanceof CustomerFullObject) {
90
+ this._relation.customerGroup = this.customerGroup;
91
+ }
92
+ }
93
+ updateRelation(rel) {
94
+ this.relation = rel;
95
+ const firstActiveAddress = this._relation.activeAddresses.length > 0 ? this._relation.activeAddresses[0] : undefined;
96
+ this.address = firstActiveAddress;
97
+ this.deliveryAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;
98
+ this.deliveryAddressChange.emit(this.deliveryAddressNawNr);
99
+ this.invoiceAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;
100
+ this.invoiceAddressChange.emit(this.invoiceAddressNawNr);
101
+ this.relationChange.emit(this.relation);
102
+ }
103
+ submit() {
104
+ return this._formMaster.submitSlaves();
105
+ }
106
+ handleDeliveryAddressChange(nawNr) {
107
+ this.deliveryAddressChange.emit(nawNr);
108
+ if (this.service.invoiceAddressSameAsDelivery) {
109
+ this.invoiceAddressChange.emit(nawNr);
110
+ }
111
+ }
112
+ checkSameAddress(checked) {
113
+ this.invoiceAddressNawNr = this.deliveryAddressNawNr;
114
+ this.invoiceAddressChange.next(this.invoiceAddressNawNr);
115
+ }
116
+ _setCountryNameToAddress(address) {
117
+ return __awaiter(this, void 0, void 0, function* () {
118
+ if (address.countryId && !address.countryName) {
119
+ const country = yield this.service.getCountry(address.countryId);
120
+ address.countryName = country.description;
121
+ }
122
+ });
123
+ }
124
+ }
125
+ CheckoutSimpleOverviewRelationEditComponent.decorators = [
126
+ { type: Component, args: [{
127
+ selector: "co-checkout-simple-overview-relation-edit",
128
+ template: `
129
+ <div class="relation-edit-content">
130
+ <co-form>
131
+ <div class="checkout-form-wrapper">
132
+ <div class="checkout-label-column">
133
+ <span>01</span>
134
+ <span class="label-description" [textContent]="'PERSONAL_DATA' | localize"></span>
135
+ </div>
136
+ <div class="checkout-data-column">
137
+ <div class="checkout-data-row">
138
+ <co-relation-type *ngIf="relationKind === relKind.Customer"
139
+ [relation]="relation"
140
+ (relationChange)="handleRelationTypeChange($event)"
141
+ ></co-relation-type>
142
+ <co-button class="empty-relation-button default-width" [label]="'EMPTY' | localize" (click)="emptyRelation($event)"></co-button>
143
+ </div>
144
+ <div class="checkout-data-row" *ngIf="relationKind === relKind.Customer">
145
+ <relation-customer-groups [model]="customerGroup" (modelChange)="handleCustomerGroupChange($event)" required></relation-customer-groups>
146
+ </div>
147
+ <div class="checkout-data-row">
148
+ <co-relation-general [relation]="relation" [relationType]="relationType" (relationChange)="updateRelation($event)"></co-relation-general>
149
+ </div>
150
+ <div class="checkout-data-row">
151
+ <co-relation-address [address]="address"></co-relation-address>
152
+ </div>
153
+ </div>
154
+ <div class="checkout-data-column">
155
+ <div class="checkout-data-row">
156
+ <co-relation-addresses
157
+ [relation]="relation"
158
+ [addresses]="relation.addresses"
159
+ [type]="addressType.DeliveryAddress"
160
+ [selectedNawNr]="deliveryAddressNawNr"
161
+ (selectedNawNrChange)="handleDeliveryAddressChange($event)"
162
+ ></co-relation-addresses>
163
+ </div>
164
+ </div>
165
+ <div class="checkout-label-column" *ngIf="relationKind === relKind.Customer">
166
+ <span>02</span>
167
+ <span class="label-description" [textContent]="'INVOICE_ADDRESS' | localize"></span>
168
+ </div>
169
+ <div class="checkout-data-column" *ngIf="relationKind === relKind.Customer">
170
+ <div class="checkout-data-row">
171
+ <co-input-checkbox [(model)]="service.invoiceAddressSameAsDelivery" (modelChange)="checkSameAddress($event)" [label]="'SAME_AS_DELIVERY' | localize"></co-input-checkbox>
172
+ </div>
173
+ <div class="overview-delivery-invoice-address" *ngIf="!service.invoiceAddressSameAsDelivery" @showHideInvoiceAddress>
174
+ <div class="checkout-data-row">
175
+ <co-relation-addresses
176
+ [relation]="relation"
177
+ [addresses]="relation.activeAddresses"
178
+ [type]="addressType.BillingAddress"
179
+ [selectedNawNr]="invoiceAddressNawNr"
180
+ (selectedNawNrChange)="invoiceAddressChange.emit($event)"
181
+ ></co-relation-addresses>
182
+ </div>
183
+ </div>
184
+ </div>
185
+ <div class="checkout-label-column">
186
+ <span>{{ relationKind === relKind.Customer ? '03' : '02'}}</span>
187
+ <span class="label-description" [textContent]="'CONTACT_DETAILS' | localize"></span>
188
+ </div>
189
+ <div class="checkout-data-column">
190
+ <div class="checkout-data-row">
191
+ <co-relation-contact-details [showPhone]="false" [(relation)]="relation" [relationKind]="relationKind"></co-relation-contact-details>
192
+ </div>
193
+ </div>
194
+ <ng-container *ngIf="relationKind === relKind.Customer">
195
+ <div class="checkout-label-column">
196
+ <span>04</span>
197
+ <span class="label-description" [textContent]="'PRIVACY_PREFERENCES' | localize"></span>
198
+ </div>
199
+ <div class="checkout-data-column">
200
+ <div class="checkout-data-row">
201
+ <co-relation-preferences [(relation)]="relation"></co-relation-preferences>
202
+ </div>
203
+ </div>
204
+ </ng-container>
205
+ </div>
206
+ </co-form>
207
+ </div>
208
+ `,
209
+ providers: [
210
+ FormMasterService
211
+ ],
212
+ animations: [
213
+ trigger("showHidePrivateRelationFields", [
214
+ state("void", style({ height: 0 })),
215
+ state("*", style({ height: "*" })),
216
+ transition("void => *", animate("200ms ease-in-out")),
217
+ transition("* => void", animate("200ms ease-out"))
218
+ ]),
219
+ trigger("showHideCompanyRelationFields", [
220
+ state("void", style({ height: 0 })),
221
+ state("*", style({ height: "*" })),
222
+ transition("void => *", animate("200ms ease-in-out")),
223
+ transition("* => void", animate("200ms ease-out"))
224
+ ]),
225
+ trigger("showHideSidebar", [
226
+ state("void", style({ transform: "translateX(100%)" })),
227
+ state("*", style({ transform: "translateX(0)" })),
228
+ transition("void <=> *", animate("200ms ease-in-out"))
229
+ ]),
230
+ trigger("showHideInvoiceAddress", [
231
+ state("void", style({ height: 0, opacity: 0 })),
232
+ state("*", style({ height: "*", opacity: 1 })),
233
+ transition("void => *", animate("200ms ease-in-out")),
234
+ transition("* => void", animate("200ms ease-out"))
235
+ ])
236
+ ],
237
+ encapsulation: ViewEncapsulation.None
238
+ },] }
239
+ ];
240
+ CheckoutSimpleOverviewRelationEditComponent.ctorParameters = () => [
241
+ { type: FormMasterService },
242
+ { type: TransactionService }
243
+ ];
244
+ CheckoutSimpleOverviewRelationEditComponent.propDecorators = {
245
+ relation: [{ type: Input }],
246
+ relationKind: [{ type: Input }],
247
+ deliveryAddressNawNr: [{ type: Input }],
248
+ invoiceAddressNawNr: [{ type: Input }],
249
+ validSubmit: [{ type: Output }],
250
+ invalidSubmit: [{ type: Output }],
251
+ deliveryAddressChange: [{ type: Output }],
252
+ invoiceAddressChange: [{ type: Output }],
253
+ relationChange: [{ type: Output }],
254
+ showClass: [{ type: HostBinding, args: ["class.co-checkout-simple-overview-relation-edit",] }]
255
+ };
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkout-simple-overview-relation-edit.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/checkout-simple/checkout-simple-overview-relation-edit/checkout-simple-overview-relation-edit.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {FormMasterService} from '@colijnit/corecomponents_v12';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {Country} from '@colijnit/transactionapi/build/model/country.bo';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {CustomerFullObject} from '@colijnit/relationapi/build/model/customer-full-object.bo';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\nimport {AddressType} from '@colijnit/relationapi/build/enum/address-type.enum';\r\nimport {RelationAnyType} from '../../../model/relation-any-type';\r\nimport {Address} from '@colijnit/relationapi/build/model/address.bo';\r\nimport {RelationNameKind} from '@colijnit/relationapi/build/enum/relation-name-kind.enum';\r\nimport {SupplierFullObject} from '@colijnit/relationapi/build/model/supplier-full-object.bo';\r\nimport {Relation} from '@colijnit/relationapi/build/model/relation.bo';\r\n\r\n@Component({\r\n    selector: \"co-checkout-simple-overview-relation-edit\",\r\n    template: `\r\n    <div class=\"relation-edit-content\">\r\n      <co-form>\r\n        <div class=\"checkout-form-wrapper\">\r\n          <div class=\"checkout-label-column\">\r\n            <span>01</span>\r\n            <span class=\"label-description\" [textContent]=\"'PERSONAL_DATA' | localize\"></span>\r\n          </div>\r\n          <div class=\"checkout-data-column\">\r\n            <div class=\"checkout-data-row\">\r\n              <co-relation-type *ngIf=\"relationKind === relKind.Customer\"\r\n                                [relation]=\"relation\"\r\n                                (relationChange)=\"handleRelationTypeChange($event)\"\r\n              ></co-relation-type>\r\n              <co-button class=\"empty-relation-button default-width\" [label]=\"'EMPTY' | localize\" (click)=\"emptyRelation($event)\"></co-button>\r\n            </div>\r\n            <div class=\"checkout-data-row\" *ngIf=\"relationKind === relKind.Customer\">\r\n              <relation-customer-groups [model]=\"customerGroup\" (modelChange)=\"handleCustomerGroupChange($event)\" required></relation-customer-groups>\r\n            </div>\r\n            <div class=\"checkout-data-row\">\r\n              <co-relation-general [relation]=\"relation\" [relationType]=\"relationType\" (relationChange)=\"updateRelation($event)\"></co-relation-general>\r\n            </div>\r\n            <div class=\"checkout-data-row\">\r\n              <co-relation-address [address]=\"address\"></co-relation-address>\r\n            </div>\r\n          </div>\r\n          <div class=\"checkout-data-column\">\r\n            <div class=\"checkout-data-row\">\r\n              <co-relation-addresses\r\n                [relation]=\"relation\"\r\n                [addresses]=\"relation.addresses\"\r\n                [type]=\"addressType.DeliveryAddress\"\r\n                [selectedNawNr]=\"deliveryAddressNawNr\"\r\n                (selectedNawNrChange)=\"handleDeliveryAddressChange($event)\"\r\n              ></co-relation-addresses>\r\n            </div>\r\n          </div>\r\n          <div class=\"checkout-label-column\" *ngIf=\"relationKind === relKind.Customer\">\r\n            <span>02</span>\r\n            <span class=\"label-description\" [textContent]=\"'INVOICE_ADDRESS' | localize\"></span>\r\n          </div>\r\n          <div class=\"checkout-data-column\" *ngIf=\"relationKind === relKind.Customer\">\r\n            <div class=\"checkout-data-row\">\r\n              <co-input-checkbox [(model)]=\"service.invoiceAddressSameAsDelivery\" (modelChange)=\"checkSameAddress($event)\" [label]=\"'SAME_AS_DELIVERY' | localize\"></co-input-checkbox>\r\n            </div>\r\n            <div class=\"overview-delivery-invoice-address\" *ngIf=\"!service.invoiceAddressSameAsDelivery\" @showHideInvoiceAddress>\r\n              <div class=\"checkout-data-row\">\r\n                <co-relation-addresses\r\n                  [relation]=\"relation\"\r\n                  [addresses]=\"relation.activeAddresses\"\r\n                  [type]=\"addressType.BillingAddress\"\r\n                  [selectedNawNr]=\"invoiceAddressNawNr\"\r\n                  (selectedNawNrChange)=\"invoiceAddressChange.emit($event)\"\r\n                ></co-relation-addresses>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"checkout-label-column\">\r\n            <span>{{  relationKind === relKind.Customer ? '03' : '02'}}</span>\r\n            <span class=\"label-description\" [textContent]=\"'CONTACT_DETAILS' | localize\"></span>\r\n          </div>\r\n          <div class=\"checkout-data-column\">\r\n            <div class=\"checkout-data-row\">\r\n              <co-relation-contact-details [showPhone]=\"false\" [(relation)]=\"relation\" [relationKind]=\"relationKind\"></co-relation-contact-details>\r\n            </div>\r\n          </div>\r\n          <ng-container *ngIf=\"relationKind === relKind.Customer\">\r\n            <div class=\"checkout-label-column\">\r\n              <span>04</span>\r\n              <span class=\"label-description\" [textContent]=\"'PRIVACY_PREFERENCES' | localize\"></span>\r\n            </div>\r\n            <div class=\"checkout-data-column\">\r\n              <div class=\"checkout-data-row\">\r\n                <co-relation-preferences [(relation)]=\"relation\"></co-relation-preferences>\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </co-form>\r\n    </div>\r\n  `,\r\n    providers: [\r\n        FormMasterService\r\n    ],\r\n    animations: [\r\n        trigger(\"showHidePrivateRelationFields\", [\r\n            state(\"void\", style({height: 0})),\r\n            state(\"*\", style({height: \"*\"})),\r\n            transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n            transition(\"* => void\", animate(\"200ms ease-out\"))\r\n        ]),\r\n        trigger(\"showHideCompanyRelationFields\", [\r\n            state(\"void\", style({height: 0})),\r\n            state(\"*\", style({height: \"*\"})),\r\n            transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n            transition(\"* => void\", animate(\"200ms ease-out\"))\r\n        ]),\r\n        trigger(\"showHideSidebar\", [\r\n            state(\"void\", style({transform: \"translateX(100%)\"})),\r\n            state(\"*\", style({transform: \"translateX(0)\"})),\r\n            transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n        ]),\r\n        trigger(\"showHideInvoiceAddress\", [\r\n            state(\"void\", style({height: 0, opacity: 0})),\r\n            state(\"*\", style({height: \"*\", opacity: 1})),\r\n            transition(\"void => *\", animate(\"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 CheckoutSimpleOverviewRelationEditComponent implements OnInit, AfterViewInit {\r\n    public readonly relKind: typeof RelationKind = RelationKind;\r\n    public readonly icons: typeof Icon = Icon;\r\n    public readonly addressType: typeof AddressType = AddressType;\r\n\r\n    @Input()\r\n    public set relation(value: RelationAnyType) {\r\n        if (this._relation && value && this._relation.relationId === value.relationId) {\r\n            return;\r\n        }\r\n        this._relation = value;\r\n        if (this._relation) {\r\n            if (this._relation instanceof SupplierFullObject) {\r\n                this._relation.type = RelationNameKind.Company;\r\n                this.relationType = RelationNameKind.Company;\r\n            }\r\n            if (this._relation instanceof CustomerFullObject) {\r\n                this.customerGroup = this._relation.customerGroup;\r\n            }\r\n            this.address = this._relation.getFirstAddressOrCreateNew();\r\n        }\r\n    }\r\n\r\n    public get relation(): RelationAnyType {\r\n        return this._relation;\r\n    }\r\n\r\n    @Input()\r\n    public set relationKind(value: RelationKind) {\r\n        this._relationKind = value;\r\n        if (this._relationKind === RelationKind.Supplier) {\r\n            this.relationType = RelationNameKind.Company;\r\n        }\r\n    }\r\n\r\n    public get relationKind(): RelationKind {\r\n        return this._relationKind;\r\n    }\r\n\r\n    @Input()\r\n    public deliveryAddressNawNr: number;\r\n\r\n    @Input()\r\n    public invoiceAddressNawNr: number;\r\n\r\n    @Output()\r\n    public validSubmit: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    @Output()\r\n    public invalidSubmit: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    @Output()\r\n    public deliveryAddressChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    @Output()\r\n    public invoiceAddressChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    @Output()\r\n    public relationChange: EventEmitter<RelationAnyType> = new EventEmitter<RelationAnyType>();\r\n\r\n    @HostBinding(\"class.co-checkout-simple-overview-relation-edit\")\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    private _relation: RelationAnyType = new CustomerFullObject();\r\n    private _relationKind: RelationKind = RelationKind.Customer;\r\n\r\n    public address: Address;\r\n    public customerGroup: string;\r\n    public relationType: RelationNameKind = RelationNameKind.Private;\r\n\r\n    public get applicationUser(): boolean {\r\n        return this.service.applicationUser;\r\n    }\r\n\r\n    constructor(\r\n        private _formMaster: FormMasterService,\r\n        public service: TransactionService\r\n    ) {\r\n    }\r\n\r\n    async ngOnInit(): Promise<void> {\r\n        if (this._relation) {\r\n            this.address = this._relation.getFirstAddressOrCreateNew();\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        const firstActiveAddress: Address = this._relation.activeAddresses.length > 0 ? this._relation.activeAddresses[0] : undefined;\r\n        if (!this.deliveryAddressNawNr) {\r\n            this.deliveryAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;\r\n            this.deliveryAddressChange.emit(this.deliveryAddressNawNr);\r\n        }\r\n        if (!this.invoiceAddressNawNr) {\r\n            this.invoiceAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;\r\n            this.invoiceAddressChange.emit(this.invoiceAddressNawNr);\r\n        }\r\n    }\r\n\r\n    public handleRelationTypeChange(relation: Relation): void {\r\n        this.relationType = relation.type;\r\n    }\r\n\r\n    public emptyRelation(event: MouseEvent): void {\r\n        this.service.createNewRelation()\r\n        this.updateRelation(this.service.relation);\r\n    }\r\n\r\n    public handleCustomerGroupChange(group: string): void {\r\n        this.customerGroup = group;\r\n        if (this._relation instanceof CustomerFullObject) {\r\n            this._relation.customerGroup = this.customerGroup;\r\n        }\r\n    }\r\n\r\n    public updateRelation(rel: RelationAnyType): void {\r\n        this.relation = rel;\r\n        const firstActiveAddress: Address = this._relation.activeAddresses.length > 0 ? this._relation.activeAddresses[0] : undefined;\r\n        this.address = firstActiveAddress;\r\n        this.deliveryAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;\r\n        this.deliveryAddressChange.emit(this.deliveryAddressNawNr);\r\n        this.invoiceAddressNawNr = firstActiveAddress ? firstActiveAddress.nawNr : 0;\r\n        this.invoiceAddressChange.emit(this.invoiceAddressNawNr);\r\n        this.relationChange.emit(this.relation);\r\n    }\r\n\r\n    public submit(): boolean {\r\n        return this._formMaster.submitSlaves();\r\n    }\r\n\r\n    public handleDeliveryAddressChange(nawNr: number): void {\r\n        this.deliveryAddressChange.emit(nawNr);\r\n        if (this.service.invoiceAddressSameAsDelivery) {\r\n            this.invoiceAddressChange.emit(nawNr);\r\n        }\r\n    }\r\n\r\n    public checkSameAddress(checked: boolean): void {\r\n        this.invoiceAddressNawNr = this.deliveryAddressNawNr;\r\n        this.invoiceAddressChange.next(this.invoiceAddressNawNr);\r\n    }\r\n\r\n    private async _setCountryNameToAddress(address: Address): Promise<void> {\r\n        if (address.countryId && !address.countryName) {\r\n            const country: Country = await this.service.getCountry(address.countryId);\r\n            address.countryName = country.description;\r\n        }\r\n    }\r\n\r\n}\r\n"]}
@@ -0,0 +1,186 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
3
+ import { TransactionService } from '../../service/transaction.service';
4
+ import { DictionaryService } from '../../service/dictionary.service';
5
+ import { DialogService } from '../../service/dialog.service';
6
+ import { TransactionKind } from '@colijnit/transactionapi/build/enum/transaction-kind.enum';
7
+ export class CheckoutSimpleComponent {
8
+ constructor(service, _dictionary, _dialogService) {
9
+ this.service = service;
10
+ this._dictionary = _dictionary;
11
+ this._dialogService = _dialogService;
12
+ this.transKind = TransactionKind;
13
+ this.newTransaction = false;
14
+ this.transactionType = TransactionKind.SalesOrder;
15
+ this.showCreateTransactionButton = false;
16
+ this.transactionFinished = new EventEmitter();
17
+ this.editCartClick = new EventEmitter();
18
+ this.deliveryAddressNawNr = 0;
19
+ this.invoiceAddressNawNr = 0;
20
+ }
21
+ showClass() {
22
+ return true;
23
+ }
24
+ ngOnInit() {
25
+ if (this.newTransaction) {
26
+ this.service.resetCurrentTransaction();
27
+ }
28
+ this.service.transactionKind = this.transactionType;
29
+ this.relationType = this.service.getRelationKindFromTransactionKind();
30
+ this.service.createNewRelation();
31
+ }
32
+ handleCreateTransaction(event) {
33
+ return __awaiter(this, void 0, void 0, function* () {
34
+ let success = true;
35
+ if (this.stepper.activeStep === 0 && (yield this.handleRelationValidation())) {
36
+ success = yield this.service.saveRelation();
37
+ if (success) {
38
+ yield this.service.updateHeaderTransactionDefinitive(this.service.currentTransaction.transactionInfo.uuid, true, true);
39
+ }
40
+ }
41
+ if (!success) {
42
+ return;
43
+ }
44
+ const saveSuccess = yield this.service.saveTransactionAndCommit();
45
+ if (saveSuccess) {
46
+ this.handleTransactionFinished(this.service.currentTransaction.transactionInfo.transactionNr);
47
+ }
48
+ });
49
+ }
50
+ handleRelationValidation() {
51
+ return __awaiter(this, void 0, void 0, function* () {
52
+ if (this.checkoutRelation && this.stepRelation) {
53
+ const valid = this.checkoutRelation.submit();
54
+ if (valid) {
55
+ this.stepRelation.completed = yield this.saveRelation();
56
+ }
57
+ return valid;
58
+ }
59
+ });
60
+ }
61
+ handleDeliveryValidation() {
62
+ return __awaiter(this, void 0, void 0, function* () {
63
+ if (this.checkoutDelivery && this.stepDelivery) {
64
+ const valid = this.checkoutDelivery.submit();
65
+ if (valid) {
66
+ const saveSuccess = yield this.service.saveTransactionAndCommit();
67
+ if (saveSuccess) {
68
+ const lockSuccess = yield this.service.tryToLockTransaction(this.service.currentTransaction.transactionInfo.id, this.service.currentTransaction.transactionInfo.version);
69
+ if (lockSuccess) {
70
+ this.stepDelivery.completed = yield this.handleSaveDelivery();
71
+ }
72
+ }
73
+ }
74
+ return valid;
75
+ }
76
+ });
77
+ }
78
+ saveRelation() {
79
+ return __awaiter(this, void 0, void 0, function* () {
80
+ const success = yield this.service.saveRelation();
81
+ if (success) {
82
+ if (this.deliveryAddressNawNr === null || this.deliveryAddressNawNr === undefined || this.deliveryAddressNawNr === 0 && this.service.relation.addresses && this.service.relation.addresses.length === 1) {
83
+ this.deliveryAddressNawNr = this.service.relation.addresses[0].nawNr;
84
+ }
85
+ if (this.deliveryAddressNawNr && this.service.currentTransaction.transactionInfo.transactionAddress !== this.deliveryAddressNawNr) {
86
+ yield this.service.updateHeaderDeliveryAddress(this.service.currentTransaction.transactionInfo.uuid, this.deliveryAddressNawNr);
87
+ }
88
+ const invoiceAddressNawNr = this.invoiceAddressNawNr ? this.invoiceAddressNawNr : this.deliveryAddressNawNr;
89
+ if (this.service.currentTransaction.transactionInfo.invoiceAddress !== invoiceAddressNawNr) {
90
+ yield this.service.updateHeaderInvoiceAddress(this.service.currentTransaction.transactionInfo.uuid, invoiceAddressNawNr);
91
+ }
92
+ }
93
+ return success;
94
+ });
95
+ }
96
+ handleSaveDelivery() {
97
+ return __awaiter(this, void 0, void 0, function* () {
98
+ return true;
99
+ });
100
+ }
101
+ handleDeliveryAddressChange(nawNr) {
102
+ this.deliveryAddressNawNr = nawNr;
103
+ }
104
+ handleInvoiceAddressChange(nawNr) {
105
+ this.invoiceAddressNawNr = nawNr;
106
+ }
107
+ handleTransactionFinished(id) {
108
+ this.service.resetCurrentTransaction();
109
+ this.transactionFinished.emit({ id: id, fromCheckout: this.showCreateTransactionButton });
110
+ }
111
+ }
112
+ CheckoutSimpleComponent.decorators = [
113
+ { type: Component, args: [{
114
+ selector: "co-checkout-simple",
115
+ template: `
116
+ <co-stepper #stepper
117
+ [title]="service.titleForCheckout"
118
+ [showStepper]="transactionType !== transKind.PurchaseOrder"
119
+ [titleIcon]="service.iconForCheckout"
120
+ [finishButtonLabel]="'CHECKOUT_FINISH' | localize"
121
+ (createClicked)="handleCreateTransaction($event)"
122
+ >
123
+ <co-stepper-step #stepRelation [index]="1" [label]="'YOUR_DATA' | localize" (validateStep)="handleRelationValidation()">
124
+ <co-checkout-simple-overview-relation-edit #checkoutRelation *ngIf="stepRelation.show"
125
+ [(relation)]="service.relation"
126
+ [relationKind]="relationType"
127
+ [deliveryAddressNawNr]="deliveryAddressNawNr"
128
+ [invoiceAddressNawNr]="invoiceAddressNawNr"
129
+ (deliveryAddressChange)="handleDeliveryAddressChange($event)"
130
+ (invoiceAddressChange)="handleInvoiceAddressChange($event)"
131
+ (relationChange)="service.relation = $event"
132
+ ></co-checkout-simple-overview-relation-edit>
133
+ </co-stepper-step>
134
+ <co-stepper-step #stepDelivery [index]="2" [label]="'DELIVERY' | localize" (validateStep)="handleDeliveryValidation()">
135
+ <co-checkout-simple-overview-delivery-edit #checkoutDelivery *ngIf="stepDelivery.show"
136
+ [transaction]="service.currentTransaction"
137
+ ></co-checkout-simple-overview-delivery-edit>
138
+ </co-stepper-step>
139
+ <co-stepper-step #stepOverview [index]="3" [label]="service.paymentStepTitleForCheckout | localize">
140
+ <co-checkout-simple-overview-payment *ngIf="stepOverview.show"
141
+ [relation]="service.relation"
142
+ [transaction]="service.currentTransaction"
143
+ [showPayment]="transactionType === transKind.SalesOrder"
144
+ (changeYourDataClick)="stepper.goto(0)"
145
+ (changeDeliveryClick)="stepper.goto(1)"
146
+ (payed)="handleTransactionFinished($event)"
147
+ ></co-checkout-simple-overview-payment>
148
+ </co-stepper-step>
149
+ <div class="co-checkout-right-panel">
150
+ <div class="co-checkout-right-panel-relation">
151
+ <co-avatar [relationId]="sellerId"></co-avatar>
152
+ </div>
153
+ <co-shopping-cart-preview *ngIf="!showCreateTransactionButton"
154
+ [showCheckoutButton]="false"
155
+ [withoutBorder]="true"
156
+ (editCartClick)="editCartClick.emit($event)"
157
+ ></co-shopping-cart-preview>
158
+ </div>
159
+ </co-stepper>
160
+ `,
161
+ encapsulation: ViewEncapsulation.None
162
+ },] }
163
+ ];
164
+ CheckoutSimpleComponent.ctorParameters = () => [
165
+ { type: TransactionService },
166
+ { type: DictionaryService },
167
+ { type: DialogService }
168
+ ];
169
+ CheckoutSimpleComponent.propDecorators = {
170
+ stepper: [{ type: ViewChild, args: ["stepper",] }],
171
+ stepRelation: [{ type: ViewChild, args: ["stepRelation",] }],
172
+ stepDelivery: [{ type: ViewChild, args: ["stepDelivery",] }],
173
+ stepOverview: [{ type: ViewChild, args: ["stepOverview",] }],
174
+ stepPay: [{ type: ViewChild, args: ["stepPay",] }],
175
+ checkoutRelation: [{ type: ViewChild, args: ["checkoutRelation",] }],
176
+ checkoutDelivery: [{ type: ViewChild, args: ["checkoutDelivery",] }],
177
+ checkoutPayment: [{ type: ViewChild, args: ["checkoutPayment",] }],
178
+ newTransaction: [{ type: Input }],
179
+ sellerId: [{ type: Input }],
180
+ transactionType: [{ type: Input }],
181
+ showCreateTransactionButton: [{ type: Input }],
182
+ transactionFinished: [{ type: Output }],
183
+ editCartClick: [{ type: Output }],
184
+ showClass: [{ type: HostBinding, args: ["class.co-checkout-simple",] }]
185
+ };
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkout-simple.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/checkout-simple/checkout-simple.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACxH,OAAO,EAAC,kBAAkB,EAAC,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AAGnE,OAAO,EAAC,aAAa,EAAC,MAAM,8BAA8B,CAAC;AAG3D,OAAO,EAAC,eAAe,EAAC,MAAM,2DAA2D,CAAC;AA2D1F,MAAM,OAAO,uBAAuB;IAuDhC,YACW,OAA2B,EAC1B,WAA8B,EAC9B,cAA6B;QAF9B,YAAO,GAAP,OAAO,CAAoB;QAC1B,gBAAW,GAAX,WAAW,CAAmB;QAC9B,mBAAc,GAAd,cAAc,CAAe;QAzDzB,cAAS,GAA2B,eAAe,CAAC;QA2B7D,mBAAc,GAAY,KAAK,CAAC;QAMhC,oBAAe,GAAoB,eAAe,CAAC,UAAU,CAAC;QAG9D,gCAA2B,GAAY,KAAK,CAAC;QAG7C,wBAAmB,GAAsD,IAAI,YAAY,EAAuC,CAAC;QAGjI,kBAAa,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAQ7D,yBAAoB,GAAW,CAAC,CAAC;QACjC,wBAAmB,GAAW,CAAC,CAAC;IAQvC,CAAC;IAdM,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAcD,QAAQ;QACJ,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE,CAAC;SAC1C;QACD,IAAI,CAAC,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC;QACpD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,kCAAkC,EAAE,CAAC;QACtE,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;IACrC,CAAC;IAEY,uBAAuB,CAAC,KAAiB;;YAClD,IAAI,OAAO,GAAY,IAAI,CAAC;YAC5B,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,CAAC,KAAI,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAA,EAAE;gBACxE,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;gBAC5C,IAAI,OAAO,EAAE;oBACT,MAAM,IAAI,CAAC,OAAO,CAAC,iCAAiC,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;iBAC1H;aACJ;YACD,IAAI,CAAC,OAAO,EAAE;gBACV,OAAO;aACV;YACD,MAAM,WAAW,GAAY,MAAM,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,CAAC;YAC3E,IAAI,WAAW,EAAE;gBACb,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;aACjG;QACL,CAAC;KAAA;IAEY,wBAAwB;;YACjC,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,YAAY,EAAE;gBAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;gBAC7C,IAAI,KAAK,EAAE;oBACP,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;iBAC3D;gBACD,OAAO,KAAK,CAAC;aAChB;QACL,CAAC;KAAA;IAEY,wBAAwB;;YACjC,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,YAAY,EAAE;gBAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;gBAC7C,IAAI,KAAK,EAAE;oBACP,MAAM,WAAW,GAAY,MAAM,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,CAAC;oBAC3E,IAAI,WAAW,EAAE;wBACb,MAAM,WAAW,GACb,MAAM,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;wBACzJ,IAAI,WAAW,EAAE;4BACb,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;yBACjE;qBACJ;iBACJ;gBACD,OAAO,KAAK,CAAC;aAChB;QACL,CAAC;KAAA;IAEY,YAAY;;YACrB,MAAM,OAAO,GAAY,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YAC3D,IAAI,OAAO,EAAE;gBACT,IAAI,IAAI,CAAC,oBAAoB,KAAK,IAAI,IAAI,IAAI,CAAC,oBAAoB,KAAK,SAAS,IAAI,IAAI,CAAC,oBAAoB,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;oBACrM,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;iBACxE;gBACD,IAAI,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,kBAAkB,KAAK,IAAI,CAAC,oBAAoB,EAAE;oBAC/H,MAAM,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;iBACnI;gBACD,MAAM,mBAAmB,GAAW,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC;gBACpH,IAAI,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,cAAc,KAAK,mBAAmB,EAAE;oBACxF,MAAM,IAAI,CAAC,OAAO,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC;iBAC5H;aACJ;YACD,OAAO,OAAO,CAAC;QACnB,CAAC;KAAA;IAEY,kBAAkB;;YAC3B,OAAO,IAAI,CAAC;QAChB,CAAC;KAAA;IAEM,2BAA2B,CAAC,KAAa;QAC5C,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;IACtC,CAAC;IAEM,0BAA0B,CAAC,KAAa;QAC3C,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;IACrC,CAAC;IAEM,yBAAyB,CAAC,EAAU;QACvC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE,CAAC;QACvC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAC,EAAE,EAAE,EAAE,EAAE,YAAY,EAAE,IAAI,CAAC,2BAA2B,EAAC,CAAC,CAAC;IAC5F,CAAC;;;YArMJ,SAAS,SAAC;gBACP,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6CX;gBACC,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;YAjEO,kBAAkB;YAClB,iBAAiB;YAGjB,aAAa;;;sBAiEhB,SAAS,SAAC,SAAS;2BAGnB,SAAS,SAAC,cAAc;2BAGxB,SAAS,SAAC,cAAc;2BAGxB,SAAS,SAAC,cAAc;sBAGxB,SAAS,SAAC,SAAS;+BAGnB,SAAS,SAAC,kBAAkB;+BAG5B,SAAS,SAAC,kBAAkB;8BAG5B,SAAS,SAAC,iBAAiB;6BAG3B,KAAK;uBAGL,KAAK;8BAGL,KAAK;0CAGL,KAAK;kCAGL,MAAM;4BAGN,MAAM;wBAGN,WAAW,SAAC,0BAA0B","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {DictionaryService} from '../../service/dictionary.service';\r\nimport {TransactionInfoResponse} from '@colijnit/transactionapi/build/model/transaction-info-response.bo';\r\nimport {StepperStepComponent} from '../stepper/component/stepper-step.component';\r\nimport {DialogService} from '../../service/dialog.service';\r\nimport {PaymentComponent} from '../payment/payment.component';\r\nimport {StepperComponent} from '../stepper/stepper.component';\r\nimport {TransactionKind} from '@colijnit/transactionapi/build/enum/transaction-kind.enum';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\nimport {\r\n    CheckoutSimpleOverviewRelationEditComponent\r\n} from './checkout-simple-overview-relation-edit/checkout-simple-overview-relation-edit.component';\r\nimport {\r\n    CheckoutSimpleOverviewDeliveryEditComponent\r\n} from './checkout-simple-overview-delivery-edit/checkout-simple-overview-delivery-edit.component';\r\n\r\n@Component({\r\n    selector: \"co-checkout-simple\",\r\n    template: `\r\n    <co-stepper #stepper\r\n                [title]=\"service.titleForCheckout\"\r\n                [showStepper]=\"transactionType !== transKind.PurchaseOrder\"\r\n                [titleIcon]=\"service.iconForCheckout\"\r\n                [finishButtonLabel]=\"'CHECKOUT_FINISH' | localize\"\r\n                (createClicked)=\"handleCreateTransaction($event)\"\r\n    >\r\n      <co-stepper-step #stepRelation [index]=\"1\" [label]=\"'YOUR_DATA' | localize\" (validateStep)=\"handleRelationValidation()\">\r\n        <co-checkout-simple-overview-relation-edit #checkoutRelation *ngIf=\"stepRelation.show\"\r\n                                            [(relation)]=\"service.relation\"\r\n                                            [relationKind]=\"relationType\"\r\n                                            [deliveryAddressNawNr]=\"deliveryAddressNawNr\"\r\n                                            [invoiceAddressNawNr]=\"invoiceAddressNawNr\"\r\n                                            (deliveryAddressChange)=\"handleDeliveryAddressChange($event)\"\r\n                                            (invoiceAddressChange)=\"handleInvoiceAddressChange($event)\"\r\n                                            (relationChange)=\"service.relation = $event\"\r\n        ></co-checkout-simple-overview-relation-edit>\r\n      </co-stepper-step>\r\n      <co-stepper-step #stepDelivery [index]=\"2\" [label]=\"'DELIVERY' | localize\" (validateStep)=\"handleDeliveryValidation()\">\r\n        <co-checkout-simple-overview-delivery-edit #checkoutDelivery *ngIf=\"stepDelivery.show\"\r\n                                            [transaction]=\"service.currentTransaction\"\r\n        ></co-checkout-simple-overview-delivery-edit>\r\n      </co-stepper-step>\r\n      <co-stepper-step #stepOverview [index]=\"3\" [label]=\"service.paymentStepTitleForCheckout | localize\">\r\n        <co-checkout-simple-overview-payment *ngIf=\"stepOverview.show\"\r\n                                      [relation]=\"service.relation\"\r\n                                      [transaction]=\"service.currentTransaction\"\r\n                                      [showPayment]=\"transactionType === transKind.SalesOrder\"\r\n                                      (changeYourDataClick)=\"stepper.goto(0)\"\r\n                                      (changeDeliveryClick)=\"stepper.goto(1)\"\r\n                                      (payed)=\"handleTransactionFinished($event)\"\r\n        ></co-checkout-simple-overview-payment>\r\n      </co-stepper-step>\r\n      <div class=\"co-checkout-right-panel\">\r\n        <div class=\"co-checkout-right-panel-relation\">\r\n          <co-avatar [relationId]=\"sellerId\"></co-avatar>\r\n        </div>\r\n        <co-shopping-cart-preview *ngIf=\"!showCreateTransactionButton\"\r\n                                  [showCheckoutButton]=\"false\"\r\n                                  [withoutBorder]=\"true\"\r\n                                  (editCartClick)=\"editCartClick.emit($event)\"\r\n        ></co-shopping-cart-preview>\r\n      </div>\r\n    </co-stepper>\r\n  `,\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CheckoutSimpleComponent implements OnInit {\r\n    public readonly transKind: typeof TransactionKind = TransactionKind;\r\n\r\n    @ViewChild(\"stepper\")\r\n    public stepper: StepperComponent;\r\n\r\n    @ViewChild(\"stepRelation\")\r\n    public stepRelation: StepperStepComponent;\r\n\r\n    @ViewChild(\"stepDelivery\")\r\n    public stepDelivery: StepperStepComponent;\r\n\r\n    @ViewChild(\"stepOverview\")\r\n    public stepOverview: StepperStepComponent;\r\n\r\n    @ViewChild(\"stepPay\")\r\n    public stepPay: StepperStepComponent;\r\n\r\n    @ViewChild(\"checkoutRelation\")\r\n    public checkoutRelation: CheckoutSimpleOverviewRelationEditComponent;\r\n\r\n    @ViewChild(\"checkoutDelivery\")\r\n    public checkoutDelivery: CheckoutSimpleOverviewDeliveryEditComponent;\r\n\r\n    @ViewChild(\"checkoutPayment\")\r\n    public checkoutPayment: PaymentComponent;\r\n\r\n    @Input()\r\n    public newTransaction: boolean = false;\r\n\r\n    @Input()\r\n    public sellerId: number;\r\n\r\n    @Input()\r\n    public transactionType: TransactionKind = TransactionKind.SalesOrder;\r\n\r\n    @Input()\r\n    public showCreateTransactionButton: boolean = false;\r\n\r\n    @Output()\r\n    public transactionFinished: EventEmitter<{id: number, fromCheckout: boolean}> = new EventEmitter<{id: number, fromCheckout: boolean}>();\r\n\r\n    @Output()\r\n    public editCartClick: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    @HostBinding(\"class.co-checkout-simple\")\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public transaction: TransactionInfoResponse;\r\n    public deliveryAddressNawNr: number = 0;\r\n    public invoiceAddressNawNr: number = 0;\r\n    public relationType: RelationKind;\r\n\r\n    constructor(\r\n        public service: TransactionService,\r\n        private _dictionary: DictionaryService,\r\n        private _dialogService: DialogService\r\n    ) {\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.newTransaction) {\r\n            this.service.resetCurrentTransaction();\r\n        }\r\n        this.service.transactionKind = this.transactionType;\r\n        this.relationType = this.service.getRelationKindFromTransactionKind();\r\n        this.service.createNewRelation();\r\n    }\r\n\r\n    public async handleCreateTransaction(event: MouseEvent): Promise<void> {\r\n        let success: boolean = true;\r\n        if (this.stepper.activeStep === 0 && await this.handleRelationValidation()) {\r\n            success = await this.service.saveRelation();\r\n            if (success) {\r\n                await this.service.updateHeaderTransactionDefinitive(this.service.currentTransaction.transactionInfo.uuid, true, true);\r\n            }\r\n        }\r\n        if (!success) {\r\n            return;\r\n        }\r\n        const saveSuccess: boolean = await this.service.saveTransactionAndCommit();\r\n        if (saveSuccess) {\r\n            this.handleTransactionFinished(this.service.currentTransaction.transactionInfo.transactionNr);\r\n        }\r\n    }\r\n\r\n    public async handleRelationValidation(): Promise<boolean> {\r\n        if (this.checkoutRelation && this.stepRelation) {\r\n            const valid = this.checkoutRelation.submit();\r\n            if (valid) {\r\n                this.stepRelation.completed = await this.saveRelation();\r\n            }\r\n            return valid;\r\n        }\r\n    }\r\n\r\n    public async handleDeliveryValidation(): Promise<boolean> {\r\n        if (this.checkoutDelivery && this.stepDelivery) {\r\n            const valid = this.checkoutDelivery.submit();\r\n            if (valid) {\r\n                const saveSuccess: boolean = await this.service.saveTransactionAndCommit();\r\n                if (saveSuccess) {\r\n                    const lockSuccess: boolean =\r\n                        await this.service.tryToLockTransaction(this.service.currentTransaction.transactionInfo.id, this.service.currentTransaction.transactionInfo.version);\r\n                    if (lockSuccess) {\r\n                        this.stepDelivery.completed = await this.handleSaveDelivery();\r\n                    }\r\n                }\r\n            }\r\n            return valid;\r\n        }\r\n    }\r\n\r\n    public async saveRelation(): Promise<boolean> {\r\n        const success: boolean = await this.service.saveRelation();\r\n        if (success) {\r\n            if (this.deliveryAddressNawNr === null || this.deliveryAddressNawNr === undefined || this.deliveryAddressNawNr === 0 && this.service.relation.addresses && this.service.relation.addresses.length === 1) {\r\n                this.deliveryAddressNawNr = this.service.relation.addresses[0].nawNr;\r\n            }\r\n            if (this.deliveryAddressNawNr && this.service.currentTransaction.transactionInfo.transactionAddress !== this.deliveryAddressNawNr) {\r\n                await this.service.updateHeaderDeliveryAddress(this.service.currentTransaction.transactionInfo.uuid, this.deliveryAddressNawNr);\r\n            }\r\n            const invoiceAddressNawNr: number = this.invoiceAddressNawNr ? this.invoiceAddressNawNr : this.deliveryAddressNawNr;\r\n            if (this.service.currentTransaction.transactionInfo.invoiceAddress !== invoiceAddressNawNr) {\r\n                await this.service.updateHeaderInvoiceAddress(this.service.currentTransaction.transactionInfo.uuid, invoiceAddressNawNr);\r\n            }\r\n        }\r\n        return success;\r\n    }\r\n\r\n    public async handleSaveDelivery(): Promise<boolean> {\r\n        return true;\r\n    }\r\n\r\n    public handleDeliveryAddressChange(nawNr: number): void {\r\n        this.deliveryAddressNawNr = nawNr;\r\n    }\r\n\r\n    public handleInvoiceAddressChange(nawNr: number): void {\r\n        this.invoiceAddressNawNr = nawNr;\r\n    }\r\n\r\n    public handleTransactionFinished(id: number): void {\r\n        this.service.resetCurrentTransaction();\r\n        this.transactionFinished.emit({id: id, fromCheckout: this.showCreateTransactionButton});\r\n    }\r\n}\r\n"]}