@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.
- package/bundles/colijnit-transaction.umd.js +2708 -656
- package/bundles/colijnit-transaction.umd.js.map +1 -1
- package/colijnit-transaction.d.ts +308 -295
- package/colijnit-transaction.metadata.json +1 -1
- package/esm2015/colijnit-transaction.js +309 -296
- package/esm2015/lib/component/checkout/checkout.component.js +30 -1
- package/esm2015/lib/component/checkout-simple/checkout-simple-overview-delivery-edit/checkout-simple-overview-delivery-edit.component.js +213 -0
- package/esm2015/lib/component/checkout-simple/checkout-simple-overview-payment/checkout-simple-overview-payment.component.js +105 -0
- package/esm2015/lib/component/checkout-simple/checkout-simple-overview-relation-edit/checkout-simple-overview-relation-edit.component.js +256 -0
- package/esm2015/lib/component/checkout-simple/checkout-simple.component.js +186 -0
- package/esm2015/lib/component/checkout-simple/checkout-simple.module.js +88 -0
- package/esm2015/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.js +11 -4
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-direct-sell.component.js +160 -9
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.component.js +12 -10
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.module.js +5 -3
- package/esm2015/lib/component/relation/relation-general/relation-general.component.js +28 -20
- package/esm2015/lib/component/service-wizard-qa/question-answer-item/question-answer-item.component.js +72 -0
- package/esm2015/lib/component/service-wizard-qa/question-answer-item/question-answer-item.module.js +23 -0
- package/esm2015/lib/component/service-wizard-qa/service-wizard-qa.component.js +38 -0
- package/esm2015/lib/component/service-wizard-qa/service-wizard-qa.module.js +25 -0
- package/esm2015/lib/component/transaction-create-wizard/transaction-create-wizard.component.js +137 -0
- package/esm2015/lib/component/transaction-create-wizard/transaction-create-wizard.module.js +38 -0
- package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-create-service.component.js +134 -0
- package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-relation.component.js +18 -11
- package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-fields.component.js +41 -0
- package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-wizard.component.js +40 -0
- package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup.module.js +21 -5
- package/esm2015/lib/component/transaction-internal/transaction-internal.component.js +16 -2
- package/esm2015/lib/component/transaction-line/transaction-invoice-line/transaction-invoice-line-base.component.js +4 -2
- package/esm2015/lib/component/transaction-line/transaction-order-delivery-line/transaction-order-delivery-line-base.component.js +1 -2
- package/esm2015/lib/component/transaction-line-action-buttons/transaction-line-action-buttons-popup.component.js +20 -9
- package/esm2015/lib/component/transaction-line-action-buttons/transaction-line-action-buttons.component.js +10 -7
- package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-invoice/transaction-quick-access-invoice.component.js +1 -1
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- 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
- package/esm2015/lib/component/transaction-search/transaction-search-result/transaction-search-result.module.js +1 -1
- package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.component.js +32 -2
- package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.module.js +4 -3
- package/esm2015/lib/service/dialog.service.js +4 -3
- package/esm2015/lib/service/pending-reason.service.js +4 -4
- package/esm2015/lib/service/transaction-base.service.js +7 -3
- package/esm2015/lib/service/transaction-connector-adapter.service.js +165 -1
- package/esm2015/lib/service/transaction-connector.service.js +69 -1
- package/esm2015/lib/service/transaction-create.service.js +67 -0
- package/esm2015/lib/service/transaction-creation.service.js +3 -2
- package/esm2015/lib/service/transaction-event.service.js +3 -1
- package/esm2015/lib/service/transaction-relation-connector.service.js +22 -1
- package/esm2015/lib/service/transaction-relation.service.js +7 -1
- package/esm2015/lib/service/transaction.service.js +136 -11
- package/esm2015/lib/transaction-version.js +3 -3
- package/esm2015/public_api.js +3 -1
- package/fesm2015/colijnit-transaction.js +2409 -388
- package/fesm2015/colijnit-transaction.js.map +1 -1
- package/lib/component/checkout/checkout.component.d.ts +9 -1
- package/lib/component/checkout-simple/checkout-simple-overview-delivery-edit/checkout-simple-overview-delivery-edit.component.d.ts +55 -0
- package/lib/component/checkout-simple/checkout-simple-overview-payment/checkout-simple-overview-payment.component.d.ts +22 -0
- package/lib/component/checkout-simple/checkout-simple-overview-relation-edit/checkout-simple-overview-relation-edit.component.d.ts +46 -0
- package/lib/component/checkout-simple/checkout-simple.component.d.ts +50 -0
- package/lib/component/checkout-simple/checkout-simple.module.d.ts +2 -0
- package/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.d.ts +1 -0
- package/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-direct-sell.component.d.ts +26 -3
- package/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/style/_layout.scss +107 -1
- package/lib/component/relation/relation-general/relation-general.component.d.ts +3 -1
- package/lib/component/service-wizard-qa/question-answer-item/question-answer-item.component.d.ts +19 -0
- package/lib/component/service-wizard-qa/question-answer-item/question-answer-item.module.d.ts +2 -0
- package/lib/component/service-wizard-qa/question-answer-item/style/_layout.scss +28 -0
- package/lib/component/service-wizard-qa/question-answer-item/style/_material-definition.scss +24 -0
- package/lib/component/service-wizard-qa/question-answer-item/style/_theme.scss +5 -0
- package/lib/component/service-wizard-qa/question-answer-item/style/material.scss +3 -0
- package/lib/component/service-wizard-qa/service-wizard-qa.component.d.ts +12 -0
- package/lib/component/service-wizard-qa/service-wizard-qa.module.d.ts +2 -0
- package/lib/component/transaction-create-wizard/transaction-create-wizard.component.d.ts +34 -0
- package/lib/component/transaction-create-wizard/transaction-create-wizard.module.d.ts +2 -0
- package/lib/component/transaction-header/transaction-header-popup/style/_layout.scss +32 -1
- package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-create-service.component.d.ts +30 -0
- package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-relation.component.d.ts +3 -0
- package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-fields.component.d.ts +9 -0
- package/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-service-wizard.component.d.ts +12 -0
- package/lib/component/transaction-internal/transaction-internal.component.d.ts +1 -0
- package/lib/component/transaction-line-action-buttons/transaction-line-action-buttons-popup.component.d.ts +2 -0
- package/lib/component/transaction-line-action-buttons/transaction-line-action-buttons.component.d.ts +2 -2
- package/lib/component/transaction-service-overview/transaction-service-overview.component.d.ts +6 -0
- package/lib/service/dialog.service.d.ts +2 -1
- package/lib/service/transaction-base.service.d.ts +3 -1
- package/lib/service/transaction-connector-adapter.service.d.ts +22 -0
- package/lib/service/transaction-connector.service.d.ts +22 -0
- package/lib/service/transaction-create.service.d.ts +7 -0
- package/lib/service/transaction-event.service.d.ts +5 -0
- package/lib/service/transaction-relation-connector.service.d.ts +1 -0
- package/lib/service/transaction-relation.service.d.ts +1 -0
- package/lib/service/transaction.service.d.ts +25 -1
- package/package.json +13 -12
- 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":"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","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"]}
|